@bpmn-io/feel-editor 0.4.0 → 0.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/index.es.js +98 -21225
- package/dist/index.js +131 -21258
- package/package.json +13 -12
- package/dist/index.es.jsmin +0 -1
- package/dist/index.jsmin +0 -1
package/dist/index.jsmin
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports,"__esModule",{value:!0});class t{constructor(){}lineAt(t){if(t<0||t>this.length)throw new RangeError(`Invalid position ${t} in document of length ${this.length}`);return this.lineInner(t,!1,1,0)}line(t){if(t<1||t>this.lines)throw new RangeError(`Invalid line number ${t} in ${this.lines}-line document`);return this.lineInner(t,!0,1,0)}replace(t,e,s){let n=[];return this.decompose(0,t,n,2),s.length&&s.decompose(0,s.length,n,3),this.decompose(e,this.length,n,1),i.from(n,this.length-(e-t)+s.length)}append(t){return this.replace(this.length,this.length,t)}slice(t,e=this.length){let s=[];return this.decompose(t,e,s,0),i.from(s,e-t)}eq(t){if(t==this)return!0;if(t.length!=this.length||t.lines!=this.lines)return!1;let e=this.scanIdentical(t,1),i=this.length-this.scanIdentical(t,-1),s=new r(this),n=new r(t);for(let t=e,r=e;;){if(s.next(t),n.next(t),t=0,s.lineBreak!=n.lineBreak||s.done!=n.done||s.value!=n.value)return!1;if(r+=s.value.length,s.done||r>=i)return!0}}iter(t=1){return new r(this,t)}iterRange(t,e=this.length){return new o(this,t,e)}iterLines(t,e){let i;if(null==t)i=this.iter();else{null==e&&(e=this.lines+1);let s=this.line(t).from;i=this.iterRange(s,Math.max(s,e==this.lines+1?this.length:e<=1?0:this.line(e-1).to))}return new h(i)}toString(){return this.sliceString(0)}toJSON(){let t=[];return this.flatten(t),t}static of(s){if(0==s.length)throw new RangeError("A document must have at least one line");return 1!=s.length||s[0]?s.length<=32?new e(s):i.from(e.split(s,[])):t.empty}}class e extends t{constructor(t,e=function(t){let e=-1;for(let i of t)e+=i.length+1;return e}(t)){super(),this.text=t,this.length=e}get lines(){return this.text.length}get children(){return null}lineInner(t,e,i,s){for(let n=0;;n++){let r=this.text[n],o=s+r.length;if((e?i:o)>=t)return new l(s,o,i,r);s=o+1,i++}}decompose(t,i,r,o){let h=t<=0&&i>=this.length?this:new e(n(this.text,t,i),Math.min(i,this.length)-Math.max(0,t));if(1&o){let t=r.pop(),i=s(h.text,t.text.slice(),0,h.length);if(i.length<=32)r.push(new e(i,t.length+h.length));else{let t=i.length>>1;r.push(new e(i.slice(0,t)),new e(i.slice(t)))}}else r.push(h)}replace(t,r,o){if(!(o instanceof e))return super.replace(t,r,o);let h=s(this.text,s(o.text,n(this.text,0,t)),r),l=this.length+o.length-(r-t);return h.length<=32?new e(h,l):i.from(e.split(h,[]),l)}sliceString(t,e=this.length,i="\n"){let s="";for(let n=0,r=0;n<=e&&r<this.text.length;r++){let o=this.text[r],h=n+o.length;n>t&&r&&(s+=i),t<h&&e>n&&(s+=o.slice(Math.max(0,t-n),e-n)),n=h+1}return s}flatten(t){for(let e of this.text)t.push(e)}scanIdentical(){return 0}static split(t,i){let s=[],n=-1;for(let r of t)s.push(r),n+=r.length+1,32==s.length&&(i.push(new e(s,n)),s=[],n=-1);return n>-1&&i.push(new e(s,n)),i}}class i extends t{constructor(t,e){super(),this.children=t,this.length=e,this.lines=0;for(let e of t)this.lines+=e.lines}lineInner(t,e,i,s){for(let n=0;;n++){let r=this.children[n],o=s+r.length,h=i+r.lines-1;if((e?h:o)>=t)return r.lineInner(t,e,i,s);s=o+1,i=h+1}}decompose(t,e,i,s){for(let n=0,r=0;r<=e&&n<this.children.length;n++){let o=this.children[n],h=r+o.length;if(t<=h&&e>=r){let n=s&((r<=t?1:0)|(h>=e?2:0));r>=t&&h<=e&&!n?i.push(o):o.decompose(t-r,e-r,i,n)}r=h+1}}replace(t,e,s){if(s.lines<this.lines)for(let n=0,r=0;n<this.children.length;n++){let o=this.children[n],h=r+o.length;if(t>=r&&e<=h){let l=o.replace(t-r,e-r,s),a=this.lines-o.lines+l.lines;if(l.lines<a>>4&&l.lines>a>>6){let r=this.children.slice();return r[n]=l,new i(r,this.length-(e-t)+s.length)}return super.replace(r,h,l)}r=h+1}return super.replace(t,e,s)}sliceString(t,e=this.length,i="\n"){let s="";for(let n=0,r=0;n<this.children.length&&r<=e;n++){let o=this.children[n],h=r+o.length;r>t&&n&&(s+=i),t<h&&e>r&&(s+=o.sliceString(t-r,e-r,i)),r=h+1}return s}flatten(t){for(let e of this.children)e.flatten(t)}scanIdentical(t,e){if(!(t instanceof i))return 0;let s=0,[n,r,o,h]=e>0?[0,0,this.children.length,t.children.length]:[this.children.length-1,t.children.length-1,-1,-1];for(;;n+=e,r+=e){if(n==o||r==h)return s;let i=this.children[n],l=t.children[r];if(i!=l)return s+i.scanIdentical(l,e);s+=i.length+1}}static from(t,s=t.reduce(((t,e)=>t+e.length+1),-1)){let n=0;for(let e of t)n+=e.lines;if(n<32){let i=[];for(let e of t)e.flatten(i);return new e(i,s)}let r=Math.max(32,n>>5),o=r<<1,h=r>>1,l=[],a=0,c=-1,u=[];function f(t){let s;if(t.lines>o&&t instanceof i)for(let e of t.children)f(e);else t.lines>h&&(a>h||!a)?(d(),l.push(t)):t instanceof e&&a&&(s=u[u.length-1])instanceof e&&t.lines+s.lines<=32?(a+=t.lines,c+=t.length+1,u[u.length-1]=new e(s.text.concat(t.text),s.length+1+t.length)):(a+t.lines>r&&d(),a+=t.lines,c+=t.length+1,u.push(t))}function d(){0!=a&&(l.push(1==u.length?u[0]:i.from(u,c)),c=-1,a=u.length=0)}for(let e of t)f(e);return d(),1==l.length?l[0]:new i(l,s)}}function s(t,e,i=0,s=1e9){for(let n=0,r=0,o=!0;r<t.length&&n<=s;r++){let h=t[r],l=n+h.length;l>=i&&(l>s&&(h=h.slice(0,s-n)),n<i&&(h=h.slice(i-n)),o?(e[e.length-1]+=h,o=!1):e.push(h)),n=l+1}return e}function n(t,e,i){return s(t,[""],e,i)}t.empty=new e([""],0);class r{constructor(t,i=1){this.dir=i,this.done=!1,this.lineBreak=!1,this.value="",this.nodes=[t],this.offsets=[i>0?1:(t instanceof e?t.text.length:t.children.length)<<1]}nextInner(t,i){for(this.done=this.lineBreak=!1;;){let s=this.nodes.length-1,n=this.nodes[s],r=this.offsets[s],o=r>>1,h=n instanceof e?n.text.length:n.children.length;if(o==(i>0?h:0)){if(0==s)return this.done=!0,this.value="",this;i>0&&this.offsets[s-1]++,this.nodes.pop(),this.offsets.pop()}else if((1&r)==(i>0?0:1)){if(this.offsets[s]+=i,0==t)return this.lineBreak=!0,this.value="\n",this;t--}else if(n instanceof e){let e=n.text[o+(i<0?-1:0)];if(this.offsets[s]+=i,e.length>Math.max(0,t))return this.value=0==t?e:i>0?e.slice(t):e.slice(0,e.length-t),this;t-=e.length}else{let r=n.children[o+(i<0?-1:0)];t>r.length?(t-=r.length,this.offsets[s]+=i):(i<0&&this.offsets[s]--,this.nodes.push(r),this.offsets.push(i>0?1:(r instanceof e?r.text.length:r.children.length)<<1))}}}next(t=0){return t<0&&(this.nextInner(-t,-this.dir),t=this.value.length),this.nextInner(t,this.dir)}}class o{constructor(t,e,i){this.value="",this.done=!1,this.cursor=new r(t,e>i?-1:1),this.pos=e>i?t.length:0,this.from=Math.min(e,i),this.to=Math.max(e,i)}nextInner(t,e){if(e<0?this.pos<=this.from:this.pos>=this.to)return this.value="",this.done=!0,this;t+=Math.max(0,e<0?this.pos-this.to:this.from-this.pos);let i=e<0?this.pos-this.from:this.to-this.pos;t>i&&(t=i),i-=t;let{value:s}=this.cursor.next(t);return this.pos+=(s.length+t)*e,this.value=s.length<=i?s:e<0?s.slice(s.length-i):s.slice(0,i),this.done=!this.value,this}next(t=0){return t<0?t=Math.max(t,this.from-this.pos):t>0&&(t=Math.min(t,this.to-this.pos)),this.nextInner(t,this.cursor.dir)}get lineBreak(){return this.cursor.lineBreak&&""!=this.value}}class h{constructor(t){this.inner=t,this.afterBreak=!0,this.value="",this.done=!1}next(t=0){let{done:e,lineBreak:i,value:s}=this.inner.next(t);return e?(this.done=!0,this.value=""):i?this.afterBreak?this.value="":(this.afterBreak=!0,this.next()):(this.value=s,this.afterBreak=!1),this}get lineBreak(){return!1}}"undefined"!=typeof Symbol&&(t.prototype[Symbol.iterator]=function(){return this.iter()},r.prototype[Symbol.iterator]=o.prototype[Symbol.iterator]=h.prototype[Symbol.iterator]=function(){return this});class l{constructor(t,e,i,s){this.from=t,this.to=e,this.number=i,this.text=s}get length(){return this.to-this.from}}let a="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((t=>t?parseInt(t,36):1));for(let t=1;t<a.length;t++)a[t]+=a[t-1];function c(t){for(let e=1;e<a.length;e+=2)if(a[e]>t)return a[e-1]<=t;return!1}function u(t){return t>=127462&&t<=127487}function f(t,e,i=!0,s=!0){return(i?d:p)(t,e,s)}function d(t,e,i){if(e==t.length)return e;e&&g(t.charCodeAt(e))&&O(t.charCodeAt(e-1))&&e--;let s=m(t,e);for(e+=b(s);e<t.length;){let n=m(t,e);if(8205==s||8205==n||i&&c(n))e+=b(n),s=n;else{if(!u(n))break;{let i=0,s=e-2;for(;s>=0&&u(m(t,s));)i++,s-=2;if(i%2==0)break;e+=2}}}return e}function p(t,e,i){for(;e>0;){let s=d(t,e-2,i);if(s<e)return s;e--}return 0}function g(t){return t>=56320&&t<57344}function O(t){return t>=55296&&t<56320}function m(t,e){let i=t.charCodeAt(e);if(!O(i)||e+1==t.length)return i;let s=t.charCodeAt(e+1);return g(s)?s-56320+(i-55296<<10)+65536:i}function b(t){return t<65536?1:2}const v=/\r\n?|\n/;var y=function(t){return t[t.Simple=0]="Simple",t[t.TrackDel=1]="TrackDel",t[t.TrackBefore=2]="TrackBefore",t[t.TrackAfter=3]="TrackAfter",t}(y||(y={}));class w{constructor(t){this.sections=t}get length(){let t=0;for(let e=0;e<this.sections.length;e+=2)t+=this.sections[e];return t}get newLength(){let t=0;for(let e=0;e<this.sections.length;e+=2){let i=this.sections[e+1];t+=i<0?this.sections[e]:i}return t}get empty(){return 0==this.sections.length||2==this.sections.length&&this.sections[1]<0}iterGaps(t){for(let e=0,i=0,s=0;e<this.sections.length;){let n=this.sections[e++],r=this.sections[e++];r<0?(t(i,s,n),s+=n):s+=r,i+=n}}iterChangedRanges(t,e=!1){P(this,t,e)}get invertedDesc(){let t=[];for(let e=0;e<this.sections.length;){let i=this.sections[e++],s=this.sections[e++];s<0?t.push(i,s):t.push(s,i)}return new w(t)}composeDesc(t){return this.empty?t:t.empty?this:Q(this,t)}mapDesc(t,e=!1){return t.empty?this:$(this,t,e)}mapPos(t,e=-1,i=y.Simple){let s=0,n=0;for(let r=0;r<this.sections.length;){let o=this.sections[r++],h=this.sections[r++],l=s+o;if(h<0){if(l>t)return n+(t-s);n+=o}else{if(i!=y.Simple&&l>=t&&(i==y.TrackDel&&s<t&&l>t||i==y.TrackBefore&&s<t||i==y.TrackAfter&&l>t))return null;if(l>t||l==t&&e<0&&!o)return t==s||e<0?n:n+h;n+=h}s=l}if(t>s)throw new RangeError(`Position ${t} is out of range for changeset of length ${s}`);return n}touchesRange(t,e=t){for(let i=0,s=0;i<this.sections.length&&s<=e;){let n=s+this.sections[i++];if(this.sections[i++]>=0&&s<=e&&n>=t)return!(s<t&&n>e)||"cover";s=n}return!1}toString(){let t="";for(let e=0;e<this.sections.length;){let i=this.sections[e++],s=this.sections[e++];t+=(t?" ":"")+i+(s>=0?":"+s:"")}return t}toJSON(){return this.sections}static fromJSON(t){if(!Array.isArray(t)||t.length%2||t.some((t=>"number"!=typeof t)))throw new RangeError("Invalid JSON representation of ChangeDesc");return new w(t)}}class x extends w{constructor(t,e){super(t),this.inserted=e}apply(t){if(this.length!=t.length)throw new RangeError("Applying change set to a document with the wrong length");return P(this,((e,i,s,n,r)=>t=t.replace(s,s+(i-e),r)),!1),t}mapDesc(t,e=!1){return $(this,t,e,!0)}invert(e){let i=this.sections.slice(),s=[];for(let n=0,r=0;n<i.length;n+=2){let o=i[n],h=i[n+1];if(h>=0){i[n]=h,i[n+1]=o;let l=n>>1;for(;s.length<l;)s.push(t.empty);s.push(o?e.slice(r,r+o):t.empty)}r+=o}return new x(i,s)}compose(t){return this.empty?t:t.empty?this:Q(this,t,!0)}map(t,e=!1){return t.empty?this:$(this,t,e,!0)}iterChanges(t,e=!1){P(this,t,e)}get desc(){return new w(this.sections)}filter(t){let e=[],i=[],s=[],n=new R(this);t:for(let r=0,o=0;;){let h=r==t.length?1e9:t[r++];for(;o<h||o==h&&0==n.len;){if(n.done)break t;let t=Math.min(n.len,h-o);S(s,t,-1);let r=-1==n.ins?-1:0==n.off?n.ins:0;S(e,t,r),r>0&&k(i,e,n.text),n.forward(t),o+=t}let l=t[r++];for(;o<l;){if(n.done)break t;let t=Math.min(n.len,l-o);S(e,t,-1),S(s,t,-1==n.ins?-1:0==n.off?n.ins:0),n.forward(t),o+=t}}return{changes:new x(e,i),filtered:new w(s)}}toJSON(){let t=[];for(let e=0;e<this.sections.length;e+=2){let i=this.sections[e],s=this.sections[e+1];s<0?t.push(i):0==s?t.push([i]):t.push([i].concat(this.inserted[e>>1].toJSON()))}return t}static of(e,i,s){let n=[],r=[],o=0,h=null;function l(t=!1){if(!t&&!n.length)return;o<i&&S(n,i-o,-1);let e=new x(n,r);h=h?h.compose(e.map(h)):e,n=[],r=[],o=0}return function e(a){if(Array.isArray(a))for(let t of a)e(t);else if(a instanceof x){if(a.length!=i)throw new RangeError(`Mismatched change set length (got ${a.length}, expected ${i})`);l(),h=h?h.compose(a.map(h)):a}else{let{from:e,to:h=e,insert:c}=a;if(e>h||e<0||h>i)throw new RangeError(`Invalid change range ${e} to ${h} (in doc of length ${i})`);let u=c?"string"==typeof c?t.of(c.split(s||v)):c:t.empty,f=u.length;if(e==h&&0==f)return;e<o&&l(),e>o&&S(n,e-o,-1),S(n,h-e,f),k(r,n,u),o=h}}(e),l(!h),h}static empty(t){return new x(t?[t,-1]:[],[])}static fromJSON(e){if(!Array.isArray(e))throw new RangeError("Invalid JSON representation of ChangeSet");let i=[],s=[];for(let n=0;n<e.length;n++){let r=e[n];if("number"==typeof r)i.push(r,-1);else{if(!Array.isArray(r)||"number"!=typeof r[0]||r.some(((t,e)=>e&&"string"!=typeof t)))throw new RangeError("Invalid JSON representation of ChangeSet");if(1==r.length)i.push(r[0],0);else{for(;s.length<n;)s.push(t.empty);s[n]=t.of(r.slice(1)),i.push(r[0],s[n].length)}}}return new x(i,s)}}function S(t,e,i,s=!1){if(0==e&&i<=0)return;let n=t.length-2;n>=0&&i<=0&&i==t[n+1]?t[n]+=e:0==e&&0==t[n]?t[n+1]+=i:s?(t[n]+=e,t[n+1]+=i):t.push(e,i)}function k(e,i,s){if(0==s.length)return;let n=i.length-2>>1;if(n<e.length)e[e.length-1]=e[e.length-1].append(s);else{for(;e.length<n;)e.push(t.empty);e.push(s)}}function P(e,i,s){let n=e.inserted;for(let r=0,o=0,h=0;h<e.sections.length;){let l=e.sections[h++],a=e.sections[h++];if(a<0)r+=l,o+=l;else{let c=r,u=o,f=t.empty;for(;c+=l,u+=a,a&&n&&(f=f.append(n[h-2>>1])),!(s||h==e.sections.length||e.sections[h+1]<0);)l=e.sections[h++],a=e.sections[h++];i(r,c,o,u,f),r=c,o=u}}}function $(t,e,i,s=!1){let n=[],r=s?[]:null,o=new R(t),h=new R(e);for(let t=0,e=0;;)if(-1==o.ins)t+=o.len,o.next();else if(-1==h.ins&&e<t){let i=Math.min(h.len,t-e);h.forward(i),S(n,i,-1),e+=i}else if(h.ins>=0&&(o.done||e<t||e==t&&(h.len<o.len||h.len==o.len&&!i))){for(S(n,h.ins,-1);t>e&&!o.done&&t+o.len<e+h.len;)t+=o.len,o.next();e+=h.len,h.next()}else{if(!(o.ins>=0)){if(o.done&&h.done)return r?new x(n,r):new w(n);throw new Error("Mismatched change set lengths")}{let i=0,s=t+o.len;for(;;)if(h.ins>=0&&e>t&&e+h.len<s)i+=h.ins,e+=h.len,h.next();else{if(!(-1==h.ins&&e<s))break;{let t=Math.min(h.len,s-e);i+=t,h.forward(t),e+=t}}S(n,i,o.ins),r&&k(r,n,o.text),t=s,o.next()}}}function Q(t,e,i=!1){let s=[],n=i?[]:null,r=new R(t),o=new R(e);for(let t=!1;;){if(r.done&&o.done)return n?new x(s,n):new w(s);if(0==r.ins)S(s,r.len,0,t),r.next();else if(0!=o.len||o.done){if(r.done||o.done)throw new Error("Mismatched change set lengths");{let e=Math.min(r.len2,o.len),i=s.length;if(-1==r.ins){let i=-1==o.ins?-1:o.off?0:o.ins;S(s,e,i,t),n&&i&&k(n,s,o.text)}else-1==o.ins?(S(s,r.off?0:r.len,e,t),n&&k(n,s,r.textBit(e))):(S(s,r.off?0:r.len,o.off?0:o.ins,t),n&&!o.off&&k(n,s,o.text));t=(r.ins>e||o.ins>=0&&o.len>e)&&(t||s.length>i),r.forward2(e),o.forward(e)}}else S(s,0,o.ins,t),n&&k(n,s,o.text),o.next()}}class R{constructor(t){this.set=t,this.i=0,this.next()}next(){let{sections:t}=this.set;this.i<t.length?(this.len=t[this.i++],this.ins=t[this.i++]):(this.len=0,this.ins=-2),this.off=0}get done(){return-2==this.ins}get len2(){return this.ins<0?this.len:this.ins}get text(){let{inserted:e}=this.set,i=this.i-2>>1;return i>=e.length?t.empty:e[i]}textBit(e){let{inserted:i}=this.set,s=this.i-2>>1;return s>=i.length&&!e?t.empty:i[s].slice(this.off,null==e?void 0:this.off+e)}forward(t){t==this.len?this.next():(this.len-=t,this.off+=t)}forward2(t){-1==this.ins?this.forward(t):t==this.ins?this.next():(this.ins-=t,this.off+=t)}}class q{constructor(t,e,i){this.from=t,this.to=e,this.flags=i}get anchor(){return 16&this.flags?this.to:this.from}get head(){return 16&this.flags?this.from:this.to}get empty(){return this.from==this.to}get assoc(){return 4&this.flags?-1:8&this.flags?1:0}get bidiLevel(){let t=3&this.flags;return 3==t?null:t}get goalColumn(){let t=this.flags>>5;return 33554431==t?void 0:t}map(t,e=-1){let i,s;return this.empty?i=s=t.mapPos(this.from,e):(i=t.mapPos(this.from,1),s=t.mapPos(this.to,-1)),i==this.from&&s==this.to?this:new q(i,s,this.flags)}extend(t,e=t){if(t<=this.anchor&&e>=this.anchor)return A.range(t,e);let i=Math.abs(t-this.anchor)>Math.abs(e-this.anchor)?t:e;return A.range(this.anchor,i)}eq(t){return this.anchor==t.anchor&&this.head==t.head}toJSON(){return{anchor:this.anchor,head:this.head}}static fromJSON(t){if(!t||"number"!=typeof t.anchor||"number"!=typeof t.head)throw new RangeError("Invalid JSON representation for SelectionRange");return A.range(t.anchor,t.head)}}class A{constructor(t,e=0){this.ranges=t,this.mainIndex=e}map(t,e=-1){return t.empty?this:A.create(this.ranges.map((i=>i.map(t,e))),this.mainIndex)}eq(t){if(this.ranges.length!=t.ranges.length||this.mainIndex!=t.mainIndex)return!1;for(let e=0;e<this.ranges.length;e++)if(!this.ranges[e].eq(t.ranges[e]))return!1;return!0}get main(){return this.ranges[this.mainIndex]}asSingle(){return 1==this.ranges.length?this:new A([this.main])}addRange(t,e=!0){return A.create([t].concat(this.ranges),e?0:this.mainIndex+1)}replaceRange(t,e=this.mainIndex){let i=this.ranges.slice();return i[e]=t,A.create(i,this.mainIndex)}toJSON(){return{ranges:this.ranges.map((t=>t.toJSON())),main:this.mainIndex}}static fromJSON(t){if(!t||!Array.isArray(t.ranges)||"number"!=typeof t.main||t.main>=t.ranges.length)throw new RangeError("Invalid JSON representation for EditorSelection");return new A(t.ranges.map((t=>q.fromJSON(t))),t.main)}static single(t,e=t){return new A([A.range(t,e)],0)}static create(t,e=0){if(0==t.length)throw new RangeError("A selection needs at least one range");for(let i=0,s=0;s<t.length;s++){let n=t[s];if(n.empty?n.from<=i:n.from<i)return T(t.slice(),e);i=n.to}return new A(t,e)}static cursor(t,e=0,i,s){return new q(t,t,(0==e?0:e<0?4:8)|(null==i?3:Math.min(2,i))|(null!=s?s:33554431)<<5)}static range(t,e,i){let s=(null!=i?i:33554431)<<5;return e<t?new q(e,t,24|s):new q(t,e,s|(e>t?4:0))}}function T(t,e=0){let i=t[e];t.sort(((t,e)=>t.from-e.from)),e=t.indexOf(i);for(let i=1;i<t.length;i++){let s=t[i],n=t[i-1];if(s.empty?s.from<=n.to:s.from<n.to){let r=n.from,o=Math.max(s.to,n.to);i<=e&&e--,t.splice(--i,2,s.anchor>s.head?A.range(o,r):A.range(r,o))}}return new A(t,e)}function C(t,e){for(let i of t.ranges)if(i.to>e)throw new RangeError("Selection points outside of document")}let X=0;class M{constructor(t,e,i,s,n){this.combine=t,this.compareInput=e,this.compare=i,this.isStatic=s,this.extensions=n,this.id=X++,this.default=t([])}static define(t={}){return new M(t.combine||(t=>t),t.compareInput||((t,e)=>t===e),t.compare||(t.combine?(t,e)=>t===e:D),!!t.static,t.enables)}of(t){return new E([],this,0,t)}compute(t,e){if(this.isStatic)throw new Error("Can't compute a static facet");return new E(t,this,1,e)}computeN(t,e){if(this.isStatic)throw new Error("Can't compute a static facet");return new E(t,this,2,e)}from(t,e){return e||(e=t=>t),this.compute([t],(i=>e(i.field(t))))}}function D(t,e){return t==e||t.length==e.length&&t.every(((t,i)=>t===e[i]))}class E{constructor(t,e,i,s){this.dependencies=t,this.facet=e,this.type=i,this.value=s,this.id=X++}dynamicSlot(t){var e;let i=this.value,s=this.facet.compareInput,n=this.id,r=t[n]>>1,o=2==this.type,h=!1,l=!1,a=[];for(let i of this.dependencies)"doc"==i?h=!0:"selection"==i?l=!0:0==(1&(null!==(e=t[i.id])&&void 0!==e?e:1))&&a.push(t[i.id]);return{create:t=>(t.values[r]=i(t),1),update(t,e){if(h&&e.docChanged||l&&(e.docChanged||e.selection)||_(t,a)){let e=i(t);if(o?!N(e,t.values[r],s):!s(e,t.values[r]))return t.values[r]=e,1}return 0},reconfigure:(t,e)=>{let h=i(t),l=e.config.address[n];if(null!=l){let i=J(e,l);if(this.dependencies.every((i=>i instanceof M?e.facet(i)===t.facet(i):!(i instanceof j)||e.field(i,!1)==t.field(i,!1)))||(o?N(h,i,s):s(h,i)))return t.values[r]=i,0}return t.values[r]=h,1}}}}function N(t,e,i){if(t.length!=e.length)return!1;for(let s=0;s<t.length;s++)if(!i(t[s],e[s]))return!1;return!0}function _(t,e){let i=!1;for(let s of e)1&K(t,s)&&(i=!0);return i}function B(t,e,i){let s=i.map((e=>t[e.id])),n=i.map((t=>t.type)),r=s.filter((t=>!(1&t))),o=t[e.id]>>1;function h(t){let i=[];for(let e=0;e<s.length;e++){let r=J(t,s[e]);if(2==n[e])for(let t of r)i.push(t);else i.push(r)}return e.combine(i)}return{create(t){for(let e of s)K(t,e);return t.values[o]=h(t),1},update(t,i){if(!_(t,r))return 0;let s=h(t);return e.compare(s,t.values[o])?0:(t.values[o]=s,1)},reconfigure(t,n){let r=_(t,s),l=n.config.facets[e.id],a=n.facet(e);if(l&&!r&&D(i,l))return t.values[o]=a,0;let c=h(t);return e.compare(c,a)?(t.values[o]=a,0):(t.values[o]=c,1)}}}const V=M.define({static:!0});class j{constructor(t,e,i,s,n){this.id=t,this.createF=e,this.updateF=i,this.compareF=s,this.spec=n,this.provides=void 0}static define(t){let e=new j(X++,t.create,t.update,t.compare||((t,e)=>t===e),t);return t.provide&&(e.provides=t.provide(e)),e}create(t){let e=t.facet(V).find((t=>t.field==this));return((null==e?void 0:e.create)||this.createF)(t)}slot(t){let e=t[this.id]>>1;return{create:t=>(t.values[e]=this.create(t),1),update:(t,i)=>{let s=t.values[e],n=this.updateF(s,i);return this.compareF(s,n)?0:(t.values[e]=n,1)},reconfigure:(t,i)=>null!=i.config.address[this.id]?(t.values[e]=i.field(this),0):(t.values[e]=this.create(t),1)}}init(t){return[this,V.of({field:this,create:t})]}get extension(){return this}}const z=4,W=3,I=2,L=1;function F(t){return e=>new G(e,t)}const H={highest:F(0),high:F(L),default:F(I),low:F(W),lowest:F(z)};class G{constructor(t,e){this.inner=t,this.prec=e}}class Z{of(t){return new U(this,t)}reconfigure(t){return Z.reconfigure.of({compartment:this,extension:t})}get(t){return t.config.compartments.get(this)}}class U{constructor(t,e){this.compartment=t,this.inner=e}}class Y{constructor(t,e,i,s,n,r){for(this.base=t,this.compartments=e,this.dynamicSlots=i,this.address=s,this.staticValues=n,this.facets=r,this.statusTemplate=[];this.statusTemplate.length<i.length;)this.statusTemplate.push(0)}staticFacet(t){let e=this.address[t.id];return null==e?t.default:this.staticValues[e>>1]}static resolve(t,e,i){let s=[],n=Object.create(null),r=new Map;for(let i of function(t,e,i){let s=[[],[],[],[],[]],n=new Map;function r(t,o){let h=n.get(t);if(null!=h){if(h<=o)return;let e=s[h].indexOf(t);e>-1&&s[h].splice(e,1),t instanceof U&&i.delete(t.compartment)}if(n.set(t,o),Array.isArray(t))for(let e of t)r(e,o);else if(t instanceof U){if(i.has(t.compartment))throw new RangeError("Duplicate use of compartment in extensions");let s=e.get(t.compartment)||t.inner;i.set(t.compartment,s),r(s,o)}else if(t instanceof G)r(t.inner,t.prec);else if(t instanceof j)s[o].push(t),t.provides&&r(t.provides,o);else if(t instanceof E)s[o].push(t),t.facet.extensions&&r(t.facet.extensions,o);else{let e=t.extension;if(!e)throw new Error(`Unrecognized extension value in extension set (${t}). This sometimes happens because multiple instances of @codemirror/state are loaded, breaking instanceof checks.`);r(e,o)}}return r(t,I),s.reduce(((t,e)=>t.concat(e)))}(t,e,r))i instanceof j?s.push(i):(n[i.facet.id]||(n[i.facet.id]=[])).push(i);let o=Object.create(null),h=[],l=[];for(let t of s)o[t.id]=l.length<<1,l.push((e=>t.slot(e)));let a=null==i?void 0:i.config.facets;for(let t in n){let e=n[t],s=e[0].facet,r=a&&a[t]||[];if(e.every((t=>0==t.type)))if(o[s.id]=h.length<<1|1,D(r,e))h.push(i.facet(s));else{let t=s.combine(e.map((t=>t.value)));h.push(i&&s.compare(t,i.facet(s))?i.facet(s):t)}else{for(let t of e)0==t.type?(o[t.id]=h.length<<1|1,h.push(t.value)):(o[t.id]=l.length<<1,l.push((e=>t.dynamicSlot(e))));o[s.id]=l.length<<1,l.push((t=>B(t,s,e)))}}let c=l.map((t=>t(o)));return new Y(t,r,c,o,h,n)}}function K(t,e){if(1&e)return 2;let i=e>>1,s=t.status[i];if(4==s)throw new Error("Cyclic dependency between fields and/or facets");if(2&s)return s;t.status[i]=4;let n=t.computeSlot(t,t.config.dynamicSlots[i]);return t.status[i]=2|n}function J(t,e){return 1&e?t.config.staticValues[e>>1]:t.values[e>>1]}const tt=M.define(),et=M.define({combine:t=>t.some((t=>t)),static:!0}),it=M.define({combine:t=>t.length?t[0]:void 0,static:!0}),st=M.define(),nt=M.define(),rt=M.define(),ot=M.define({combine:t=>!!t.length&&t[0]});class ht{constructor(t,e){this.type=t,this.value=e}static define(){return new lt}}class lt{of(t){return new ht(this,t)}}class at{constructor(t){this.map=t}of(t){return new ct(this,t)}}class ct{constructor(t,e){this.type=t,this.value=e}map(t){let e=this.type.map(this.value,t);return void 0===e?void 0:e==this.value?this:new ct(this.type,e)}is(t){return this.type==t}static define(t={}){return new at(t.map||(t=>t))}static mapEffects(t,e){if(!t.length)return t;let i=[];for(let s of t){let t=s.map(e);t&&i.push(t)}return i}}ct.reconfigure=ct.define(),ct.appendConfig=ct.define();class ut{constructor(t,e,i,s,n,r){this.startState=t,this.changes=e,this.selection=i,this.effects=s,this.annotations=n,this.scrollIntoView=r,this._doc=null,this._state=null,i&&C(i,e.newLength),n.some((t=>t.type==ut.time))||(this.annotations=n.concat(ut.time.of(Date.now())))}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(t){for(let e of this.annotations)if(e.type==t)return e.value}get docChanged(){return!this.changes.empty}get reconfigured(){return this.startState.config!=this.state.config}isUserEvent(t){let e=this.annotation(ut.userEvent);return!(!e||!(e==t||e.length>t.length&&e.slice(0,t.length)==t&&"."==e[t.length]))}}function ft(t,e){let i=[];for(let s=0,n=0;;){let r,o;if(s<t.length&&(n==e.length||e[n]>=t[s]))r=t[s++],o=t[s++];else{if(!(n<e.length))return i;r=e[n++],o=e[n++]}!i.length||i[i.length-1]<r?i.push(r,o):i[i.length-1]<o&&(i[i.length-1]=o)}}function dt(t,e,i){var s;let n,r,o;return i?(n=e.changes,r=x.empty(e.changes.length),o=t.changes.compose(e.changes)):(n=e.changes.map(t.changes),r=t.changes.mapDesc(e.changes,!0),o=t.changes.compose(n)),{changes:o,selection:e.selection?e.selection.map(r):null===(s=t.selection)||void 0===s?void 0:s.map(n),effects:ct.mapEffects(t.effects,n).concat(ct.mapEffects(e.effects,r)),annotations:t.annotations.length?t.annotations.concat(e.annotations):e.annotations,scrollIntoView:t.scrollIntoView||e.scrollIntoView}}function pt(t,e,i){let s=e.selection,n=mt(e.annotations);return e.userEvent&&(n=n.concat(ut.userEvent.of(e.userEvent))),{changes:e.changes instanceof x?e.changes:x.of(e.changes||[],i,t.facet(it)),selection:s&&(s instanceof A?s:A.single(s.anchor,s.head)),effects:mt(e.effects),annotations:n,scrollIntoView:!!e.scrollIntoView}}function gt(t,e,i){let s=pt(t,e.length?e[0]:{},t.doc.length);e.length&&!1===e[0].filter&&(i=!1);for(let n=1;n<e.length;n++){!1===e[n].filter&&(i=!1);let r=!!e[n].sequential;s=dt(s,pt(t,e[n],r?s.changes.newLength:t.doc.length),r)}let n=new ut(t,s.changes,s.selection,s.effects,s.annotations,s.scrollIntoView);return function(t){let e=t.startState,i=e.facet(rt),s=t;for(let n=i.length-1;n>=0;n--){let r=i[n](t);r&&Object.keys(r).length&&(s=dt(t,pt(e,r,t.changes.newLength),!0))}return s==t?t:new ut(e,t.changes,t.selection,s.effects,s.annotations,s.scrollIntoView)}(i?function(t){let e=t.startState,i=!0;for(let s of e.facet(st)){let e=s(t);if(!1===e){i=!1;break}Array.isArray(e)&&(i=!0===i?e:ft(i,e))}if(!0!==i){let s,n;if(!1===i)n=t.changes.invertedDesc,s=x.empty(e.doc.length);else{let e=t.changes.filter(i);s=e.changes,n=e.filtered.invertedDesc}t=new ut(e,s,t.selection&&t.selection.map(n),ct.mapEffects(t.effects,n),t.annotations,t.scrollIntoView)}let s=e.facet(nt);for(let i=s.length-1;i>=0;i--){let n=s[i](t);t=n instanceof ut?n:Array.isArray(n)&&1==n.length&&n[0]instanceof ut?n[0]:gt(e,mt(n),!1)}return t}(n):n)}ut.time=ht.define(),ut.userEvent=ht.define(),ut.addToHistory=ht.define(),ut.remote=ht.define();const Ot=[];function mt(t){return null==t?Ot:Array.isArray(t)?t:[t]}var bt=function(t){return t[t.Word=0]="Word",t[t.Space=1]="Space",t[t.Other=2]="Other",t}(bt||(bt={}));const vt=/[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/;let yt;try{yt=new RegExp("[\\p{Alphabetic}\\p{Number}_]","u")}catch(t){}function wt(t){return e=>{if(!/\S/.test(e))return bt.Space;if(function(t){if(yt)return yt.test(t);for(let e=0;e<t.length;e++){let i=t[e];if(/\w/.test(i)||i>""&&(i.toUpperCase()!=i.toLowerCase()||vt.test(i)))return!0}return!1}(e))return bt.Word;for(let i=0;i<t.length;i++)if(e.indexOf(t[i])>-1)return bt.Word;return bt.Other}}class xt{constructor(t,e,i,s,n,r){this.config=t,this.doc=e,this.selection=i,this.values=s,this.status=t.statusTemplate.slice(),this.computeSlot=n,r&&(r._state=this);for(let t=0;t<this.config.dynamicSlots.length;t++)K(this,t<<1);this.computeSlot=null}field(t,e=!0){let i=this.config.address[t.id];if(null!=i)return K(this,i),J(this,i);if(e)throw new RangeError("Field is not present in this state")}update(...t){return gt(this,t,!0)}applyTransaction(t){let e,i=this.config,{base:s,compartments:n}=i;for(let e of t.effects)e.is(Z.reconfigure)?(i&&(n=new Map,i.compartments.forEach(((t,e)=>n.set(e,t))),i=null),n.set(e.value.compartment,e.value.extension)):e.is(ct.reconfigure)?(i=null,s=e.value):e.is(ct.appendConfig)&&(i=null,s=mt(s).concat(e.value));if(i)e=t.startState.values.slice();else{i=Y.resolve(s,n,this),e=new xt(i,this.doc,this.selection,i.dynamicSlots.map((()=>null)),((t,e)=>e.reconfigure(t,this)),null).values}new xt(i,t.newDoc,t.newSelection,e,((e,i)=>i.update(e,t)),t)}replaceSelection(t){return"string"==typeof t&&(t=this.toText(t)),this.changeByRange((e=>({changes:{from:e.from,to:e.to,insert:t},range:A.cursor(e.from+t.length)})))}changeByRange(t){let e=this.selection,i=t(e.ranges[0]),s=this.changes(i.changes),n=[i.range],r=mt(i.effects);for(let i=1;i<e.ranges.length;i++){let o=t(e.ranges[i]),h=this.changes(o.changes),l=h.map(s);for(let t=0;t<i;t++)n[t]=n[t].map(l);let a=s.mapDesc(h,!0);n.push(o.range.map(a)),s=s.compose(l),r=ct.mapEffects(r,l).concat(ct.mapEffects(mt(o.effects),a))}return{changes:s,selection:A.create(n,e.mainIndex),effects:r}}changes(t=[]){return t instanceof x?t:x.of(t,this.doc.length,this.facet(xt.lineSeparator))}toText(e){return t.of(e.split(this.facet(xt.lineSeparator)||v))}sliceDoc(t=0,e=this.doc.length){return this.doc.sliceString(t,e,this.lineBreak)}facet(t){let e=this.config.address[t.id];return null==e?t.default:(K(this,e),J(this,e))}toJSON(t){let e={doc:this.sliceDoc(),selection:this.selection.toJSON()};if(t)for(let i in t){let s=t[i];s instanceof j&&(e[i]=s.spec.toJSON(this.field(t[i]),this))}return e}static fromJSON(t,e={},i){if(!t||"string"!=typeof t.doc)throw new RangeError("Invalid JSON representation for EditorState");let s=[];if(i)for(let e in i){let n=i[e],r=t[e];s.push(n.init((t=>n.spec.fromJSON(r,t))))}return xt.create({doc:t.doc,selection:A.fromJSON(t.selection),extensions:e.extensions?s.concat([e.extensions]):s})}static create(e={}){let i=Y.resolve(e.extensions||[],new Map),s=e.doc instanceof t?e.doc:t.of((e.doc||"").split(i.staticFacet(xt.lineSeparator)||v)),n=e.selection?e.selection instanceof A?e.selection:A.single(e.selection.anchor,e.selection.head):A.single(0);return C(n,s.length),i.staticFacet(et)||(n=n.asSingle()),new xt(i,s,n,i.dynamicSlots.map((()=>null)),((t,e)=>e.create(t)),null)}get tabSize(){return this.facet(xt.tabSize)}get lineBreak(){return this.facet(xt.lineSeparator)||"\n"}get readOnly(){return this.facet(ot)}phrase(t){for(let e of this.facet(xt.phrases))if(Object.prototype.hasOwnProperty.call(e,t))return e[t];return t}languageDataAt(t,e,i=-1){let s=[];for(let n of this.facet(tt))for(let r of n(this,e,i))Object.prototype.hasOwnProperty.call(r,t)&&s.push(r[t]);return s}charCategorizer(t){return wt(this.languageDataAt("wordChars",t).join(""))}wordAt(t){let{text:e,from:i,length:s}=this.doc.lineAt(t),n=this.charCategorizer(t),r=t-i,o=t-i;for(;r>0;){let t=f(e,r,!1);if(n(e.slice(t,r))!=bt.Word)break;r=t}for(;o<s;){let t=f(e,o);if(n(e.slice(o,t))!=bt.Word)break;o=t}return r==o?null:A.range(r+i,o+i)}}xt.allowMultipleSelections=et,xt.tabSize=M.define({combine:t=>t.length?t[0]:4}),xt.lineSeparator=it,xt.readOnly=ot,xt.phrases=M.define({compare(t,e){let i=Object.keys(t),s=Object.keys(e);return i.length==s.length&&i.every((i=>t[i]==e[i]))}}),xt.languageData=tt,xt.changeFilter=st,xt.transactionFilter=nt,xt.transactionExtender=rt,Z.reconfigure=ct.define();class St{eq(t){return this==t}range(t,e=t){return new kt(t,e,this)}}St.prototype.startSide=St.prototype.endSide=0,St.prototype.point=!1,St.prototype.mapMode=y.TrackDel;class kt{constructor(t,e,i){this.from=t,this.to=e,this.value=i}}function Pt(t,e){return t.from-e.from||t.value.startSide-e.value.startSide}class $t{constructor(t,e,i,s){this.from=t,this.to=e,this.value=i,this.maxPoint=s}get length(){return this.to[this.to.length-1]}findIndex(t,e,i,s=0){let n=i?this.to:this.from;for(let r=s,o=n.length;;){if(r==o)return r;let s=r+o>>1,h=n[s]-t||(i?this.value[s].endSide:this.value[s].startSide)-e;if(s==r)return h>=0?r:o;h>=0?o=s:r=s+1}}between(t,e,i,s){for(let n=this.findIndex(e,-1e9,!0),r=this.findIndex(i,1e9,!1,n);n<r;n++)if(!1===s(this.from[n]+t,this.to[n]+t,this.value[n]))return!1}map(t,e){let i=[],s=[],n=[],r=-1,o=-1;for(let h=0;h<this.value.length;h++){let l,a,c=this.value[h],u=this.from[h]+t,f=this.to[h]+t;if(u==f){let t=e.mapPos(u,c.startSide,c.mapMode);if(null==t)continue;if(l=a=t,c.startSide!=c.endSide&&(a=e.mapPos(u,c.endSide),a<l))continue}else if(l=e.mapPos(u,c.startSide),a=e.mapPos(f,c.endSide),l>a||l==a&&c.startSide>0&&c.endSide<=0)continue;(a-l||c.endSide-c.startSide)<0||(r<0&&(r=l),c.point&&(o=Math.max(o,a-l)),i.push(c),s.push(l-r),n.push(a-r))}return{mapped:i.length?new $t(s,n,i,o):null,pos:r}}}class Qt{constructor(t,e,i=Qt.empty,s){this.chunkPos=t,this.chunk=e,this.nextLayer=i,this.maxPoint=s}get length(){let t=this.chunk.length-1;return t<0?0:Math.max(this.chunkEnd(t),this.nextLayer.length)}get size(){if(this.isEmpty)return 0;let t=this.nextLayer.size;for(let e of this.chunk)t+=e.value.length;return t}chunkEnd(t){return this.chunkPos[t]+this.chunk[t].length}update(t){let{add:e=[],sort:i=!1,filterFrom:s=0,filterTo:n=this.length}=t,r=t.filter;if(0==e.length&&!r)return this;if(i&&(e=e.slice().sort(Pt)),this.isEmpty)return e.length?Qt.of(e):this;let o=new At(this,null,-1).goto(0),h=0,l=[],a=new Rt;for(;o.value||h<e.length;)if(h<e.length&&(o.from-e[h].from||o.startSide-e[h].value.startSide)>=0){let t=e[h++];a.addInner(t.from,t.to,t.value)||l.push(t)}else 1==o.rangeIndex&&o.chunkIndex<this.chunk.length&&(h==e.length||this.chunkEnd(o.chunkIndex)<e[h].from)&&(!r||s>this.chunkEnd(o.chunkIndex)||n<this.chunkPos[o.chunkIndex])&&a.addChunk(this.chunkPos[o.chunkIndex],this.chunk[o.chunkIndex])?o.nextChunk():((!r||s>o.to||n<o.from||r(o.from,o.to,o.value))&&(a.addInner(o.from,o.to,o.value)||l.push(new kt(o.from,o.to,o.value))),o.next());return a.finishInner(this.nextLayer.isEmpty&&!l.length?Qt.empty:this.nextLayer.update({add:l,filter:r,filterFrom:s,filterTo:n}))}map(t){if(t.empty||this.isEmpty)return this;let e=[],i=[],s=-1;for(let n=0;n<this.chunk.length;n++){let r=this.chunkPos[n],o=this.chunk[n],h=t.touchesRange(r,r+o.length);if(!1===h)s=Math.max(s,o.maxPoint),e.push(o),i.push(t.mapPos(r));else if(!0===h){let{mapped:n,pos:h}=o.map(r,t);n&&(s=Math.max(s,n.maxPoint),e.push(n),i.push(h))}}let n=this.nextLayer.map(t);return 0==e.length?n:new Qt(i,e,n,s)}between(t,e,i){if(!this.isEmpty){for(let s=0;s<this.chunk.length;s++){let n=this.chunkPos[s],r=this.chunk[s];if(e>=n&&t<=n+r.length&&!1===r.between(n,t-n,e-n,i))return}this.nextLayer.between(t,e,i)}}iter(t=0){return Tt.from([this]).goto(t)}get isEmpty(){return this.nextLayer==this}static iter(t,e=0){return Tt.from(t).goto(e)}static compare(t,e,i,s,n=-1){let r=t.filter((t=>t.maxPoint>0||!t.isEmpty&&t.maxPoint>=n)),o=e.filter((t=>t.maxPoint>0||!t.isEmpty&&t.maxPoint>=n)),h=qt(r,o,i),l=new Xt(r,h,n),a=new Xt(o,h,n);i.iterGaps(((t,e,i)=>Mt(l,t,a,e,i,s))),i.empty&&0==i.length&&Mt(l,0,a,0,0,s)}static eq(t,e,i=0,s){null==s&&(s=1e9);let n=t.filter((t=>!t.isEmpty&&e.indexOf(t)<0)),r=e.filter((e=>!e.isEmpty&&t.indexOf(e)<0));if(n.length!=r.length)return!1;if(!n.length)return!0;let o=qt(n,r),h=new Xt(n,o,0).goto(i),l=new Xt(r,o,0).goto(i);for(;;){if(h.to!=l.to||!Dt(h.active,l.active)||h.point&&(!l.point||!h.point.eq(l.point)))return!1;if(h.to>s)return!0;h.next(),l.next()}}static spans(t,e,i,s,n=-1){let r=new Xt(t,null,n).goto(e),o=e,h=r.openStart;for(;;){let t=Math.min(r.to,i);if(r.point?(s.point(o,t,r.point,r.activeForPoint(r.to),h,r.pointRank),h=r.openEnd(t)+(r.to>t?1:0)):t>o&&(s.span(o,t,r.active,h),h=r.openEnd(t)),r.to>i)break;o=r.to,r.next()}return h}static of(t,e=!1){let i=new Rt;for(let s of t instanceof kt?[t]:e?function(t){if(t.length>1)for(let e=t[0],i=1;i<t.length;i++){let s=t[i];if(Pt(e,s)>0)return t.slice().sort(Pt);e=s}return t}(t):t)i.add(s.from,s.to,s.value);return i.finish()}}Qt.empty=new Qt([],[],null,-1),Qt.empty.nextLayer=Qt.empty;class Rt{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}finishChunk(t){this.chunks.push(new $t(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,t&&(this.from=[],this.to=[],this.value=[])}add(t,e,i){this.addInner(t,e,i)||(this.nextLayer||(this.nextLayer=new Rt)).add(t,e,i)}addInner(t,e,i){let s=t-this.lastTo||i.startSide-this.last.endSide;if(s<=0&&(t-this.lastFrom||i.startSide-this.last.startSide)<0)throw new Error("Ranges must be added sorted by `from` position and `startSide`");return!(s<0)&&(250==this.from.length&&this.finishChunk(!0),this.chunkStart<0&&(this.chunkStart=t),this.from.push(t-this.chunkStart),this.to.push(e-this.chunkStart),this.last=i,this.lastFrom=t,this.lastTo=e,this.value.push(i),i.point&&(this.maxPoint=Math.max(this.maxPoint,e-t)),!0)}addChunk(t,e){if((t-this.lastTo||e.value[0].startSide-this.last.endSide)<0)return!1;this.from.length&&this.finishChunk(!0),this.setMaxPoint=Math.max(this.setMaxPoint,e.maxPoint),this.chunks.push(e),this.chunkPos.push(t);let i=e.value.length-1;return this.last=e.value[i],this.lastFrom=e.from[i]+t,this.lastTo=e.to[i]+t,!0}finish(){return this.finishInner(Qt.empty)}finishInner(t){if(this.from.length&&this.finishChunk(!1),0==this.chunks.length)return t;let e=new Qt(this.chunkPos,this.chunks,this.nextLayer?this.nextLayer.finishInner(t):t,this.setMaxPoint);return this.from=null,e}}function qt(t,e,i){let s=new Map;for(let e of t)for(let t=0;t<e.chunk.length;t++)e.chunk[t].maxPoint<=0&&s.set(e.chunk[t],e.chunkPos[t]);let n=new Set;for(let t of e)for(let e=0;e<t.chunk.length;e++){let r=s.get(t.chunk[e]);null==r||(i?i.mapPos(r):r)!=t.chunkPos[e]||(null==i?void 0:i.touchesRange(r,r+t.chunk[e].length))||n.add(t.chunk[e])}return n}class At{constructor(t,e,i,s=0){this.layer=t,this.skip=e,this.minPoint=i,this.rank=s}get startSide(){return this.value?this.value.startSide:0}get endSide(){return this.value?this.value.endSide:0}goto(t,e=-1e9){return this.chunkIndex=this.rangeIndex=0,this.gotoInner(t,e,!1),this}gotoInner(t,e,i){for(;this.chunkIndex<this.layer.chunk.length;){let e=this.layer.chunk[this.chunkIndex];if(!(this.skip&&this.skip.has(e)||this.layer.chunkEnd(this.chunkIndex)<t||e.maxPoint<this.minPoint))break;this.chunkIndex++,i=!1}if(this.chunkIndex<this.layer.chunk.length){let s=this.layer.chunk[this.chunkIndex].findIndex(t-this.layer.chunkPos[this.chunkIndex],e,!0);(!i||this.rangeIndex<s)&&this.setRangeIndex(s)}this.next()}forward(t,e){(this.to-t||this.endSide-e)<0&&this.gotoInner(t,e,!0)}next(){for(;;){if(this.chunkIndex==this.layer.chunk.length){this.from=this.to=1e9,this.value=null;break}{let t=this.layer.chunkPos[this.chunkIndex],e=this.layer.chunk[this.chunkIndex],i=t+e.from[this.rangeIndex];if(this.from=i,this.to=t+e.to[this.rangeIndex],this.value=e.value[this.rangeIndex],this.setRangeIndex(this.rangeIndex+1),this.minPoint<0||this.value.point&&this.to-this.from>=this.minPoint)break}}}setRangeIndex(t){if(t==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=t}nextChunk(){this.chunkIndex++,this.rangeIndex=0,this.next()}compare(t){return this.from-t.from||this.startSide-t.startSide||this.rank-t.rank||this.to-t.to||this.endSide-t.endSide}}class Tt{constructor(t){this.heap=t}static from(t,e=null,i=-1){let s=[];for(let n=0;n<t.length;n++)for(let r=t[n];!r.isEmpty;r=r.nextLayer)r.maxPoint>=i&&s.push(new At(r,e,i,n));return 1==s.length?s[0]:new Tt(s)}get startSide(){return this.value?this.value.startSide:0}goto(t,e=-1e9){for(let i of this.heap)i.goto(t,e);for(let t=this.heap.length>>1;t>=0;t--)Ct(this.heap,t);return this.next(),this}forward(t,e){for(let i of this.heap)i.forward(t,e);for(let t=this.heap.length>>1;t>=0;t--)Ct(this.heap,t);(this.to-t||this.value.endSide-e)<0&&this.next()}next(){if(0==this.heap.length)this.from=this.to=1e9,this.value=null,this.rank=-1;else{let t=this.heap[0];this.from=t.from,this.to=t.to,this.value=t.value,this.rank=t.rank,t.value&&t.next(),Ct(this.heap,0)}}}function Ct(t,e){for(let i=t[e];;){let s=1+(e<<1);if(s>=t.length)break;let n=t[s];if(s+1<t.length&&n.compare(t[s+1])>=0&&(n=t[s+1],s++),i.compare(n)<0)break;t[s]=i,t[e]=n,e=s}}class Xt{constructor(t,e,i){this.minPoint=i,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=Tt.from(t,e,i)}goto(t,e=-1e9){return this.cursor.goto(t,e),this.active.length=this.activeTo.length=this.activeRank.length=0,this.minActive=-1,this.to=t,this.endSide=e,this.openStart=-1,this.next(),this}forward(t,e){for(;this.minActive>-1&&(this.activeTo[this.minActive]-t||this.active[this.minActive].endSide-e)<0;)this.removeActive(this.minActive);this.cursor.forward(t,e)}removeActive(t){Et(this.active,t),Et(this.activeTo,t),Et(this.activeRank,t),this.minActive=_t(this.active,this.activeTo)}addActive(t){let e=0,{value:i,to:s,rank:n}=this.cursor;for(;e<this.activeRank.length&&this.activeRank[e]<=n;)e++;Nt(this.active,e,i),Nt(this.activeTo,e,s),Nt(this.activeRank,e,n),t&&Nt(t,e,this.cursor.from),this.minActive=_t(this.active,this.activeTo)}next(){let t=this.to,e=this.point;this.point=null;let i=this.openStart<0?[]:null,s=0;for(;;){let n=this.minActive;if(n>-1&&(this.activeTo[n]-this.cursor.from||this.active[n].endSide-this.cursor.startSide)<0){if(this.activeTo[n]>t){this.to=this.activeTo[n],this.endSide=this.active[n].endSide;break}this.removeActive(n),i&&Et(i,n)}else{if(!this.cursor.value){this.to=this.endSide=1e9;break}if(this.cursor.from>t){this.to=this.cursor.from,this.endSide=this.cursor.startSide;break}{let n=this.cursor.value;if(n.point){if(!(e&&this.cursor.to==this.to&&this.cursor.from<this.cursor.to)){this.point=n,this.pointFrom=this.cursor.from,this.pointRank=this.cursor.rank,this.to=this.cursor.to,this.endSide=n.endSide,this.cursor.from<t&&(s=1),this.cursor.next(),this.forward(this.to,this.endSide);break}this.cursor.next()}else this.addActive(i),this.cursor.next()}}}if(i){let e=0;for(;e<i.length&&i[e]<t;)e++;this.openStart=e+s}}activeForPoint(t){if(!this.active.length)return this.active;let e=[];for(let i=this.active.length-1;i>=0&&!(this.activeRank[i]<this.pointRank);i--)(this.activeTo[i]>t||this.activeTo[i]==t&&this.active[i].endSide>=this.point.endSide)&&e.push(this.active[i]);return e.reverse()}openEnd(t){let e=0;for(let i=this.activeTo.length-1;i>=0&&this.activeTo[i]>t;i--)e++;return e}}function Mt(t,e,i,s,n,r){t.goto(e),i.goto(s);let o=s+n,h=s,l=s-e;for(;;){let e=t.to+l-i.to||t.endSide-i.endSide,s=e<0?t.to+l:i.to,n=Math.min(s,o);if(t.point||i.point?t.point&&i.point&&(t.point==i.point||t.point.eq(i.point))&&Dt(t.activeForPoint(t.to+l),i.activeForPoint(i.to))||r.comparePoint(h,n,t.point,i.point):n>h&&!Dt(t.active,i.active)&&r.compareRange(h,n,t.active,i.active),s>o)break;h=s,e<=0&&t.next(),e>=0&&i.next()}}function Dt(t,e){if(t.length!=e.length)return!1;for(let i=0;i<t.length;i++)if(t[i]!=e[i]&&!t[i].eq(e[i]))return!1;return!0}function Et(t,e){for(let i=e,s=t.length-1;i<s;i++)t[i]=t[i+1];t.pop()}function Nt(t,e,i){for(let i=t.length-1;i>=e;i--)t[i+1]=t[i];t[e]=i}function _t(t,e){let i=-1,s=1e9;for(let n=0;n<e.length;n++)(e[n]-s||t[n].endSide-t[i].endSide)<0&&(i=n,s=e[n]);return i}const Bt="undefined"==typeof Symbol?"__ͼ":Symbol.for("ͼ"),Vt="undefined"==typeof Symbol?"__styleSet"+Math.floor(1e8*Math.random()):Symbol("styleSet"),jt="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:{};class zt{constructor(t,e){this.rules=[];let{finish:i}=e||{};function s(t){return/^@/.test(t)?[t]:t.split(/,\s*/)}function n(t,e,r,o){let h=[],l=/^@(\w+)\b/.exec(t[0]),a=l&&"keyframes"==l[1];if(l&&null==e)return r.push(t[0]+";");for(let i in e){let o=e[i];if(/&/.test(i))n(i.split(/,\s*/).map((e=>t.map((t=>e.replace(/&/,t))))).reduce(((t,e)=>t.concat(e))),o,r);else if(o&&"object"==typeof o){if(!l)throw new RangeError("The value of a property ("+i+") should be a primitive value.");n(s(i),o,h,a)}else null!=o&&h.push(i.replace(/_.*/,"").replace(/[A-Z]/g,(t=>"-"+t.toLowerCase()))+": "+o+";")}(h.length||a)&&r.push((!i||l||o?t:t.map(i)).join(", ")+" {"+h.join(" ")+"}")}for(let e in t)n(s(e),t[e],this.rules)}getRules(){return this.rules.join("\n")}static newName(){let t=jt[Bt]||1;return jt[Bt]=t+1,"ͼ"+t.toString(36)}static mount(t,e){(t[Vt]||new It(t)).mount(Array.isArray(e)?e:[e])}}let Wt=null;class It{constructor(t){if(!t.head&&t.adoptedStyleSheets&&"undefined"!=typeof CSSStyleSheet){if(Wt)return t.adoptedStyleSheets=[Wt.sheet].concat(t.adoptedStyleSheets),t[Vt]=Wt;this.sheet=new CSSStyleSheet,t.adoptedStyleSheets=[this.sheet].concat(t.adoptedStyleSheets),Wt=this}else{this.styleTag=(t.ownerDocument||t).createElement("style");let e=t.head||t;e.insertBefore(this.styleTag,e.firstChild)}this.modules=[],t[Vt]=this}mount(t){let e=this.sheet,i=0,s=0;for(let n=0;n<t.length;n++){let r=t[n],o=this.modules.indexOf(r);if(o<s&&o>-1&&(this.modules.splice(o,1),s--,o=-1),-1==o){if(this.modules.splice(s++,0,r),e)for(let t=0;t<r.rules.length;t++)e.insertRule(r.rules[t],i++)}else{for(;s<o;)i+=this.modules[s++].rules.length;i+=r.rules.length,s++}}if(!e){let t="";for(let e=0;e<this.modules.length;e++)t+=this.modules[e].getRules()+"\n";this.styleTag.textContent=t}}}var Lt={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:"'",229:"q"},Ft={48:")",49:"!",50:"@",51:"#",52:"$",53:"%",54:"^",55:"&",56:"*",57:"(",59:":",61:"+",173:"_",186:":",187:"+",188:"<",189:"_",190:">",191:"?",192:"~",219:"{",220:"|",221:"}",222:'"',229:"Q"},Ht="undefined"!=typeof navigator&&/Chrome\/(\d+)/.exec(navigator.userAgent);"undefined"!=typeof navigator&&/Apple Computer/.test(navigator.vendor);"undefined"!=typeof navigator&&/Gecko\/\d+/.test(navigator.userAgent);var Gt="undefined"!=typeof navigator&&/Mac/.test(navigator.platform);"undefined"!=typeof navigator&&/MSIE \d|Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(navigator.userAgent),Ht&&(Gt||Ht[1]);for(var Zt=0;Zt<10;Zt++)Lt[48+Zt]=Lt[96+Zt]=String(Zt);for(Zt=1;Zt<=24;Zt++)Lt[Zt+111]="F"+Zt;for(Zt=65;Zt<=90;Zt++)Lt[Zt]=String.fromCharCode(Zt+32),Ft[Zt]=String.fromCharCode(Zt);for(var Ut in Lt)Ft.hasOwnProperty(Ut)||(Ft[Ut]=Lt[Ut]);function Yt(t){let e;return e=11==t.nodeType?t.getSelection?t:t.ownerDocument:t,e.getSelection()}function Kt(t,e){return!!e&&(t==e||t.contains(1!=e.nodeType?e.parentNode:e))}function Jt(t,e){if(!e.anchorNode)return!1;try{return Kt(t,e.anchorNode)}catch(t){return!1}}function te(t){return 3==t.nodeType?fe(t,0,t.nodeValue.length).getClientRects():1==t.nodeType?t.getClientRects():[]}function ee(t,e,i,s){return!!i&&(se(t,e,i,s,-1)||se(t,e,i,s,1))}function ie(t){for(var e=0;;e++)if(!(t=t.previousSibling))return e}function se(t,e,i,s,n){for(;;){if(t==i&&e==s)return!0;if(e==(n<0?0:ne(t))){if("DIV"==t.nodeName)return!1;let i=t.parentNode;if(!i||1!=i.nodeType)return!1;e=ie(t)+(n<0?0:1),t=i}else{if(1!=t.nodeType)return!1;if(1==(t=t.childNodes[e+(n<0?-1:0)]).nodeType&&"false"==t.contentEditable)return!1;e=n<0?ne(t):0}}}function ne(t){return 3==t.nodeType?t.nodeValue.length:t.childNodes.length}const re={left:0,right:0,top:0,bottom:0};function oe(t,e){let i=e?t.left:t.right;return{left:i,right:i,top:t.top,bottom:t.bottom}}function he(t){return{left:0,right:t.innerWidth,top:0,bottom:t.innerHeight}}class le{constructor(){this.anchorNode=null,this.anchorOffset=0,this.focusNode=null,this.focusOffset=0}eq(t){return this.anchorNode==t.anchorNode&&this.anchorOffset==t.anchorOffset&&this.focusNode==t.focusNode&&this.focusOffset==t.focusOffset}setRange(t){this.set(t.anchorNode,t.anchorOffset,t.focusNode,t.focusOffset)}set(t,e,i,s){this.anchorNode=t,this.anchorOffset=e,this.focusNode=i,this.focusOffset=s}}let ae,ce=null;function ue(t){if(t.setActive)return t.setActive();if(ce)return t.focus(ce);let e=[];for(let i=t;i&&(e.push(i,i.scrollTop,i.scrollLeft),i!=i.ownerDocument);i=i.parentNode);if(t.focus(null==ce?{get preventScroll(){return ce={preventScroll:!0},!0}}:void 0),!ce){ce=!1;for(let t=0;t<e.length;){let i=e[t++],s=e[t++],n=e[t++];i.scrollTop!=s&&(i.scrollTop=s),i.scrollLeft!=n&&(i.scrollLeft=n)}}}function fe(t,e,i=e){let s=ae||(ae=document.createRange());return s.setEnd(t,i),s.setStart(t,e),s}function de(t,e,i){let s={key:e,code:e,keyCode:i,which:i,cancelable:!0},n=new KeyboardEvent("keydown",s);n.synthetic=!0,t.dispatchEvent(n);let r=new KeyboardEvent("keyup",s);return r.synthetic=!0,t.dispatchEvent(r),n.defaultPrevented||r.defaultPrevented}function pe(t){for(;t.attributes.length;)t.removeAttributeNode(t.attributes[0])}class ge{constructor(t,e,i=!0){this.node=t,this.offset=e,this.precise=i}static before(t,e){return new ge(t.parentNode,ie(t),e)}static after(t,e){return new ge(t.parentNode,ie(t)+1,e)}}const Oe=[];class me{constructor(){this.parent=null,this.dom=null,this.dirty=2}get editorView(){if(!this.parent)throw new Error("Accessing view in orphan content view");return this.parent.editorView}get overrideDOMText(){return null}get posAtStart(){return this.parent?this.parent.posBefore(this):0}get posAtEnd(){return this.posAtStart+this.length}posBefore(t){let e=this.posAtStart;for(let i of this.children){if(i==t)return e;e+=i.length+i.breakAfter}throw new RangeError("Invalid child in posBefore")}posAfter(t){return this.posBefore(t)+t.length}coordsAt(t,e){return null}sync(t){if(2&this.dirty){let e,i=this.dom,s=null;for(let n of this.children){if(n.dirty){if(!n.dom&&(e=s?s.nextSibling:i.firstChild)){let t=me.get(e);t&&(t.parent||t.constructor!=n.constructor)||n.reuseDOM(e)}n.sync(t),n.dirty=0}if(e=s?s.nextSibling:i.firstChild,t&&!t.written&&t.node==i&&e!=n.dom&&(t.written=!0),n.dom.parentNode==i)for(;e&&e!=n.dom;)e=be(e);else i.insertBefore(n.dom,e);s=n.dom}for(e=s?s.nextSibling:i.firstChild,e&&t&&t.node==i&&(t.written=!0);e;)e=be(e)}else if(1&this.dirty)for(let e of this.children)e.dirty&&(e.sync(t),e.dirty=0)}reuseDOM(t){}localPosFromDOM(t,e){let i;if(t==this.dom)i=this.dom.childNodes[e];else{let s=0==ne(t)?0:0==e?-1:1;for(;;){let e=t.parentNode;if(e==this.dom)break;0==s&&e.firstChild!=e.lastChild&&(s=t==e.firstChild?-1:1),t=e}i=s<0?t:t.nextSibling}if(i==this.dom.firstChild)return 0;for(;i&&!me.get(i);)i=i.nextSibling;if(!i)return this.length;for(let t=0,e=0;;t++){let s=this.children[t];if(s.dom==i)return e;e+=s.length+s.breakAfter}}domBoundsAround(t,e,i=0){let s=-1,n=-1,r=-1,o=-1;for(let h=0,l=i,a=i;h<this.children.length;h++){let i=this.children[h],c=l+i.length;if(l<t&&c>e)return i.domBoundsAround(t,e,l);if(c>=t&&-1==s&&(s=h,n=l),l>e&&i.dom.parentNode==this.dom){r=h,o=a;break}a=c,l=c+i.breakAfter}return{from:n,to:o<0?i+this.length:o,startDOM:(s?this.children[s-1].dom.nextSibling:null)||this.dom.firstChild,endDOM:r<this.children.length&&r>=0?this.children[r].dom:null}}markDirty(t=!1){this.dirty|=2,this.markParentsDirty(t)}markParentsDirty(t){for(let e=this.parent;e;e=e.parent){if(t&&(e.dirty|=2),1&e.dirty)return;e.dirty|=1,t=!1}}setParent(t){this.parent!=t&&(this.parent=t,this.dirty&&this.markParentsDirty(!0))}setDOM(t){this.dom&&(this.dom.cmView=null),this.dom=t,t.cmView=this}get rootView(){for(let t=this;;){let e=t.parent;if(!e)return t;t=e}}replaceChildren(t,e,i=Oe){this.markDirty();for(let i=t;i<e;i++){let t=this.children[i];t.parent==this&&t.destroy()}this.children.splice(t,e-t,...i);for(let t=0;t<i.length;t++)i[t].setParent(this)}ignoreMutation(t){return!1}ignoreEvent(t){return!1}childCursor(t=this.length){return new ve(this.children,t,this.children.length)}childPos(t,e=1){return this.childCursor().findPos(t,e)}toString(){let t=this.constructor.name.replace("View","");return t+(this.children.length?"("+this.children.join()+")":this.length?"["+("Text"==t?this.text:this.length)+"]":"")+(this.breakAfter?"#":"")}static get(t){return t.cmView}get isEditable(){return!0}merge(t,e,i,s,n,r){return!1}become(t){return!1}getSide(){return 0}destroy(){this.parent=null}}function be(t){let e=t.nextSibling;return t.parentNode.removeChild(t),e}me.prototype.breakAfter=0;class ve{constructor(t,e,i){this.children=t,this.pos=e,this.i=i,this.off=0}findPos(t,e=1){for(;;){if(t>this.pos||t==this.pos&&(e>0||0==this.i||this.children[this.i-1].breakAfter))return this.off=t-this.pos,this;let i=this.children[--this.i];this.pos-=i.length+i.breakAfter}}}function ye(t,e,i,s,n,r,o,h,l){let{children:a}=t,c=a.length?a[e]:null,u=r.length?r[r.length-1]:null,f=u?u.breakAfter:o;if(!(e==s&&c&&!o&&!f&&r.length<2&&c.merge(i,n,r.length?u:null,0==i,h,l))){if(s<a.length){let t=a[s];t&&n<t.length?(e==s&&(t=t.split(n),n=0),!f&&u&&t.merge(0,n,u,!0,0,l)?r[r.length-1]=t:(n&&t.merge(0,n,null,!1,0,l),r.push(t))):(null==t?void 0:t.breakAfter)&&(u?u.breakAfter=1:o=1),s++}for(c&&(c.breakAfter=o,i>0&&(!o&&r.length&&c.merge(i,c.length,r[0],!1,h,0)?c.breakAfter=r.shift().breakAfter:(i<c.length||c.children.length&&0==c.children[c.children.length-1].length)&&c.merge(i,c.length,null,!1,h,0),e++));e<s&&r.length;)if(a[s-1].become(r[r.length-1]))s--,r.pop(),l=r.length?0:h;else{if(!a[e].become(r[0]))break;e++,r.shift(),h=r.length?0:l}!r.length&&e&&s<a.length&&!a[e-1].breakAfter&&a[s].merge(0,0,a[e-1],!1,h,l)&&e--,(e<s||r.length)&&t.replaceChildren(e,s,r)}}function we(t,e,i,s,n,r){let o=t.childCursor(),{i:h,off:l}=o.findPos(i,1),{i:a,off:c}=o.findPos(e,-1),u=e-i;for(let t of s)u+=t.length;t.length+=u,ye(t,a,c,h,l,s,0,n,r)}let xe="undefined"!=typeof navigator?navigator:{userAgent:"",vendor:"",platform:""},Se="undefined"!=typeof document?document:{documentElement:{style:{}}};const ke=/Edge\/(\d+)/.exec(xe.userAgent),Pe=/MSIE \d/.test(xe.userAgent),$e=/Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(xe.userAgent),Qe=!!(Pe||$e||ke),Re=!Qe&&/gecko\/(\d+)/i.test(xe.userAgent),qe=!Qe&&/Chrome\/(\d+)/.exec(xe.userAgent),Ae="webkitFontSmoothing"in Se.documentElement.style,Te=!Qe&&/Apple Computer/.test(xe.vendor),Ce=Te&&(/Mobile\/\w+/.test(xe.userAgent)||xe.maxTouchPoints>2);var Xe={mac:Ce||/Mac/.test(xe.platform),windows:/Win/.test(xe.platform),linux:/Linux|X11/.test(xe.platform),ie:Qe,ie_version:Pe?Se.documentMode||6:$e?+$e[1]:ke?+ke[1]:0,gecko:Re,gecko_version:Re?+(/Firefox\/(\d+)/.exec(xe.userAgent)||[0,0])[1]:0,chrome:!!qe,chrome_version:qe?+qe[1]:0,ios:Ce,android:/Android\b/.test(xe.userAgent),webkit:Ae,safari:Te,webkit_version:Ae?+(/\bAppleWebKit\/(\d+)/.exec(navigator.userAgent)||[0,0])[1]:0,tabSize:null!=Se.documentElement.style.tabSize?"tab-size":"-moz-tab-size"};class Me extends me{constructor(t){super(),this.text=t}get length(){return this.text.length}createDOM(t){this.setDOM(t||document.createTextNode(this.text))}sync(t){this.dom||this.createDOM(),this.dom.nodeValue!=this.text&&(t&&t.node==this.dom&&(t.written=!0),this.dom.nodeValue=this.text)}reuseDOM(t){3==t.nodeType&&this.createDOM(t)}merge(t,e,i){return(!i||i instanceof Me&&!(this.length-(e-t)+i.length>256))&&(this.text=this.text.slice(0,t)+(i?i.text:"")+this.text.slice(e),this.markDirty(),!0)}split(t){let e=new Me(this.text.slice(t));return this.text=this.text.slice(0,t),this.markDirty(),e}localPosFromDOM(t,e){return t==this.dom?e:e?this.text.length:0}domAtPos(t){return new ge(this.dom,t)}domBoundsAround(t,e,i){return{from:i,to:i+this.length,startDOM:this.dom,endDOM:this.dom.nextSibling}}coordsAt(t,e){return Ee(this.dom,t,e)}}class De extends me{constructor(t,e=[],i=0){super(),this.mark=t,this.children=e,this.length=i;for(let t of e)t.setParent(this)}setAttrs(t){if(pe(t),this.mark.class&&(t.className=this.mark.class),this.mark.attrs)for(let e in this.mark.attrs)t.setAttribute(e,this.mark.attrs[e]);return t}reuseDOM(t){t.nodeName==this.mark.tagName.toUpperCase()&&(this.setDOM(t),this.dirty|=6)}sync(t){this.dom?4&this.dirty&&this.setAttrs(this.dom):this.setDOM(this.setAttrs(document.createElement(this.mark.tagName))),super.sync(t)}merge(t,e,i,s,n,r){return(!i||!(!(i instanceof De&&i.mark.eq(this.mark))||t&&n<=0||e<this.length&&r<=0))&&(we(this,t,e,i?i.children:[],n-1,r-1),this.markDirty(),!0)}split(t){let e=[],i=0,s=-1,n=0;for(let r of this.children){let o=i+r.length;o>t&&e.push(i<t?r.split(t-i):r),s<0&&i>=t&&(s=n),i=o,n++}let r=this.length-t;return this.length=t,s>-1&&(this.children.length=s,this.markDirty()),new De(this.mark,e,r)}domAtPos(t){return ze(this.dom,this.children,t)}coordsAt(t,e){return Ie(this,t,e)}}function Ee(t,e,i){let s=t.nodeValue.length;e>s&&(e=s);let n=e,r=e,o=0;0==e&&i<0||e==s&&i>=0?Xe.chrome||Xe.gecko||(e?(n--,o=1):(r++,o=-1)):i<0?n--:r++;let h=fe(t,n,r).getClientRects();if(!h.length)return re;let l=h[(o?o<0:i>=0)?0:h.length-1];return Xe.safari&&!o&&0==l.width&&(l=Array.prototype.find.call(h,(t=>t.width))||l),o?oe(l,o<0):l||null}class Ne extends me{constructor(t,e,i){super(),this.widget=t,this.length=e,this.side=i,this.prevWidget=null}static create(t,e,i){return new(t.customView||Ne)(t,e,i)}split(t){let e=Ne.create(this.widget,this.length-t,this.side);return this.length-=t,e}sync(){this.dom&&this.widget.updateDOM(this.dom)||(this.dom&&this.prevWidget&&this.prevWidget.destroy(this.dom),this.prevWidget=null,this.setDOM(this.widget.toDOM(this.editorView)),this.dom.contentEditable="false")}getSide(){return this.side}merge(t,e,i,s,n,r){return!(i&&(!(i instanceof Ne&&this.widget.compare(i.widget))||t>0&&n<=0||e<this.length&&r<=0))&&(this.length=t+(i?i.length:0)+(this.length-e),!0)}become(t){return t.length==this.length&&t instanceof Ne&&t.side==this.side&&this.widget.constructor==t.widget.constructor&&(this.widget.eq(t.widget)||this.markDirty(!0),this.dom&&!this.prevWidget&&(this.prevWidget=this.widget),this.widget=t.widget,!0)}ignoreMutation(){return!0}ignoreEvent(t){return this.widget.ignoreEvent(t)}get overrideDOMText(){if(0==this.length)return t.empty;let e=this;for(;e.parent;)e=e.parent;let i=e.editorView,s=i&&i.state.doc,n=this.posAtStart;return s?s.slice(n,n+this.length):t.empty}domAtPos(t){return 0==t?ge.before(this.dom):ge.after(this.dom,t==this.length)}domBoundsAround(){return null}coordsAt(t,e){let i=this.dom.getClientRects(),s=null;if(!i.length)return re;for(let e=t>0?i.length-1:0;s=i[e],!(t>0?0==e:e==i.length-1||s.top<s.bottom);e+=t>0?-1:1);return 0==t&&e>0||t==this.length&&e<=0?s:oe(s,0==t)}get isEditable(){return!1}destroy(){super.destroy(),this.dom&&this.widget.destroy(this.dom)}}class _e extends Ne{domAtPos(t){let{topView:e,text:i}=this.widget;return e?Be(t,0,e,i,((t,e)=>t.domAtPos(e)),(t=>new ge(i,Math.min(t,i.nodeValue.length)))):new ge(i,Math.min(t,i.nodeValue.length))}sync(){this.setDOM(this.widget.toDOM())}localPosFromDOM(t,e){let{topView:i,text:s}=this.widget;return i?Ve(t,e,i,s):Math.min(e,this.length)}ignoreMutation(){return!1}get overrideDOMText(){return null}coordsAt(t,e){let{topView:i,text:s}=this.widget;return i?Be(t,e,i,s,((t,e,i)=>t.coordsAt(e,i)),((t,e)=>Ee(s,t,e))):Ee(s,t,e)}destroy(){var t;super.destroy(),null===(t=this.widget.topView)||void 0===t||t.destroy()}get isEditable(){return!0}}function Be(t,e,i,s,n,r){if(i instanceof De){for(let o of i.children){let i=Kt(o.dom,s),h=i?s.nodeValue.length:o.length;if(t<h||t==h&&o.getSide()<=0)return i?Be(t,e,o,s,n,r):n(o,t,e);t-=h}return n(i,i.length,-1)}return i.dom==s?r(t,e):n(i,t,e)}function Ve(t,e,i,s){if(i instanceof De)for(let n of i.children){let i=0,r=Kt(n.dom,s);if(Kt(n.dom,t))return i+(r?Ve(t,e,n,s):n.localPosFromDOM(t,e));i+=r?s.nodeValue.length:n.length}else if(i.dom==s)return Math.min(e,s.nodeValue.length);return i.localPosFromDOM(t,e)}class je extends me{constructor(t){super(),this.side=t}get length(){return 0}merge(){return!1}become(t){return t instanceof je&&t.side==this.side}split(){return new je(this.side)}sync(){if(!this.dom){let t=document.createElement("img");t.className="cm-widgetBuffer",t.setAttribute("aria-hidden","true"),this.setDOM(t)}}getSide(){return this.side}domAtPos(t){return ge.before(this.dom)}localPosFromDOM(){return 0}domBoundsAround(){return null}coordsAt(t){let e=this.dom.getBoundingClientRect(),i=function(t,e){let i=t.parent,s=i?i.children.indexOf(t):-1;for(;i&&s>=0;)if(e<0?s>0:s<i.children.length){let t=i.children[s+e];if(t instanceof Me){let i=t.coordsAt(e<0?t.length:0,e);if(i)return i}s+=e}else{if(!(i instanceof De&&i.parent)){let t=i.dom.lastChild;if(t&&"BR"==t.nodeName)return t.getClientRects()[0];break}s=i.parent.children.indexOf(i)+(e<0?0:1),i=i.parent}return}(this,this.side>0?-1:1);return i&&i.top<e.bottom&&i.bottom>e.top?{left:e.left,right:e.right,top:i.top,bottom:i.bottom}:e}get overrideDOMText(){return t.empty}}function ze(t,e,i){let s=0;for(let n=0;s<e.length;s++){let r=e[s],o=n+r.length;if(!(o==n&&r.getSide()<=0)){if(i>n&&i<o&&r.dom.parentNode==t)return r.domAtPos(i-n);if(i<=n)break;n=o}}for(;s>0;s--){let i=e[s-1].dom;if(i.parentNode==t)return ge.after(i)}return new ge(t,0)}function We(t,e,i){let s,{children:n}=t;i>0&&e instanceof De&&n.length&&(s=n[n.length-1])instanceof De&&s.mark.eq(e.mark)?We(s,e.children[0],i-1):(n.push(e),e.setParent(t)),t.length+=e.length}function Ie(t,e,i){for(let s=0,n=0;n<t.children.length;n++){let r,o=t.children[n],h=s+o.length;if((i<=0||h==t.length||o.getSide()>0?h>=e:h>e)&&(e<h||n+1==t.children.length||(r=t.children[n+1]).length||r.getSide()>0)){let t=0;if(h==s){if(o.getSide()<=0)continue;t=i=-o.getSide()}let n=o.coordsAt(Math.max(0,e-s),i);return t&&n?oe(n,i<0):n}s=h}let s=t.dom.lastChild;if(!s)return t.dom.getBoundingClientRect();let n=te(s);return n[n.length-1]||null}function Le(t,e){for(let i in t)"class"==i&&e.class?e.class+=" "+t.class:"style"==i&&e.style?e.style+=";"+t.style:e[i]=t[i];return e}function Fe(t,e){if(t==e)return!0;if(!t||!e)return!1;let i=Object.keys(t),s=Object.keys(e);if(i.length!=s.length)return!1;for(let n of i)if(-1==s.indexOf(n)||t[n]!==e[n])return!1;return!0}function He(t,e,i){if(e)for(let s in e)i&&s in i||t.removeAttribute(s);if(i)for(let s in i)e&&e[s]==i[s]||t.setAttribute(s,i[s])}Me.prototype.children=Ne.prototype.children=je.prototype.children=Oe;class Ge{eq(t){return!1}updateDOM(t){return!1}compare(t){return this==t||this.constructor==t.constructor&&this.eq(t)}get estimatedHeight(){return-1}ignoreEvent(t){return!0}get customView(){return null}destroy(t){}}var Ze=function(t){return t[t.Text=0]="Text",t[t.WidgetBefore=1]="WidgetBefore",t[t.WidgetAfter=2]="WidgetAfter",t[t.WidgetRange=3]="WidgetRange",t}(Ze||(Ze={}));class Ue extends St{constructor(t,e,i,s){super(),this.startSide=t,this.endSide=e,this.widget=i,this.spec=s}get heightRelevant(){return!1}static mark(t){return new Ye(t)}static widget(t){let e=t.side||0,i=!!t.block;return e+=i?e>0?3e8:-4e8:e>0?1e8:-1e8,new Je(t,e,e,i,t.widget||null,!1)}static replace(t){let e,i,s=!!t.block;if(t.isBlockGap)e=-5e8,i=4e8;else{let{start:n,end:r}=ti(t,s);e=(n?s?-3e8:-1:5e8)-1,i=1+(r?s?2e8:1:-6e8)}return new Je(t,e,i,s,t.widget||null,!0)}static line(t){return new Ke(t)}static set(t,e=!1){return Qt.of(t,e)}hasHeight(){return!!this.widget&&this.widget.estimatedHeight>-1}}Ue.none=Qt.empty;class Ye extends Ue{constructor(t){let{start:e,end:i}=ti(t);super(e?-1:5e8,i?1:-6e8,null,t),this.tagName=t.tagName||"span",this.class=t.class||"",this.attrs=t.attributes||null}eq(t){return this==t||t instanceof Ye&&this.tagName==t.tagName&&this.class==t.class&&Fe(this.attrs,t.attrs)}range(t,e=t){if(t>=e)throw new RangeError("Mark decorations may not be empty");return super.range(t,e)}}Ye.prototype.point=!1;class Ke extends Ue{constructor(t){super(-2e8,-2e8,null,t)}eq(t){return t instanceof Ke&&Fe(this.spec.attributes,t.spec.attributes)}range(t,e=t){if(e!=t)throw new RangeError("Line decoration ranges must be zero-length");return super.range(t,e)}}Ke.prototype.mapMode=y.TrackBefore,Ke.prototype.point=!0;class Je extends Ue{constructor(t,e,i,s,n,r){super(e,i,n,t),this.block=s,this.isReplace=r,this.mapMode=s?e<=0?y.TrackBefore:y.TrackAfter:y.TrackDel}get type(){return this.startSide<this.endSide?Ze.WidgetRange:this.startSide<=0?Ze.WidgetBefore:Ze.WidgetAfter}get heightRelevant(){return this.block||!!this.widget&&this.widget.estimatedHeight>=5}eq(t){return t instanceof Je&&(e=this.widget,i=t.widget,e==i||!!(e&&i&&e.compare(i)))&&this.block==t.block&&this.startSide==t.startSide&&this.endSide==t.endSide;var e,i}range(t,e=t){if(this.isReplace&&(t>e||t==e&&this.startSide>0&&this.endSide<=0))throw new RangeError("Invalid range for replacement decoration");if(!this.isReplace&&e!=t)throw new RangeError("Widget decorations can only have zero-length ranges");return super.range(t,e)}}function ti(t,e=!1){let{inclusiveStart:i,inclusiveEnd:s}=t;return null==i&&(i=t.inclusive),null==s&&(s=t.inclusive),{start:null!=i?i:e,end:null!=s?s:e}}function ei(t,e,i,s=0){let n=i.length-1;n>=0&&i[n]+s>=t?i[n]=Math.max(i[n],e):i.push(t,e)}Je.prototype.point=!0;class ii extends me{constructor(){super(...arguments),this.children=[],this.length=0,this.prevAttrs=void 0,this.attrs=null,this.breakAfter=0}merge(t,e,i,s,n,r){if(i){if(!(i instanceof ii))return!1;this.dom||i.transferDOM(this)}return s&&this.setDeco(i?i.attrs:null),we(this,t,e,i?i.children:[],n,r),!0}split(t){let e=new ii;if(e.breakAfter=this.breakAfter,0==this.length)return e;let{i:i,off:s}=this.childPos(t);s&&(e.append(this.children[i].split(s),0),this.children[i].merge(s,this.children[i].length,null,!1,0,0),i++);for(let t=i;t<this.children.length;t++)e.append(this.children[t],0);for(;i>0&&0==this.children[i-1].length;)this.children[--i].destroy();return this.children.length=i,this.markDirty(),this.length=t,e}transferDOM(t){this.dom&&(t.setDOM(this.dom),t.prevAttrs=void 0===this.prevAttrs?this.attrs:this.prevAttrs,this.prevAttrs=void 0,this.dom=null)}setDeco(t){Fe(this.attrs,t)||(this.dom&&(this.prevAttrs=this.attrs,this.markDirty()),this.attrs=t)}append(t,e){We(this,t,e)}addLineDeco(t){let e=t.spec.attributes,i=t.spec.class;e&&(this.attrs=Le(e,this.attrs||{})),i&&(this.attrs=Le({class:i},this.attrs||{}))}domAtPos(t){return ze(this.dom,this.children,t)}reuseDOM(t){"DIV"==t.nodeName&&(this.setDOM(t),this.dirty|=6)}sync(t){var e;this.dom?4&this.dirty&&(pe(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),void 0!==this.prevAttrs&&(He(this.dom,this.prevAttrs,this.attrs),this.dom.classList.add("cm-line"),this.prevAttrs=void 0),super.sync(t);let i=this.dom.lastChild;for(;i&&me.get(i)instanceof De;)i=i.lastChild;if(!(i&&this.length&&("BR"==i.nodeName||0!=(null===(e=me.get(i))||void 0===e?void 0:e.isEditable)||Xe.ios&&this.children.some((t=>t instanceof Me))))){let t=document.createElement("BR");t.cmIgnore=!0,this.dom.appendChild(t)}}measureTextSize(){if(0==this.children.length||this.length>20)return null;let t=0;for(let e of this.children){if(!(e instanceof Me))return null;let i=te(e.dom);if(1!=i.length)return null;t+=i[0].width}return{lineHeight:this.dom.getBoundingClientRect().height,charWidth:t/this.length}}coordsAt(t,e){return Ie(this,t,e)}become(t){return!1}get type(){return Ze.Text}static find(t,e){for(let i=0,s=0;i<t.children.length;i++){let n=t.children[i],r=s+n.length;if(r>=e){if(n instanceof ii)return n;if(r>e)break}s=r+n.breakAfter}return null}}class si extends me{constructor(t,e,i){super(),this.widget=t,this.length=e,this.type=i,this.breakAfter=0,this.prevWidget=null}merge(t,e,i,s,n,r){return!(i&&(!(i instanceof si&&this.widget.compare(i.widget))||t>0&&n<=0||e<this.length&&r<=0))&&(this.length=t+(i?i.length:0)+(this.length-e),!0)}domAtPos(t){return 0==t?ge.before(this.dom):ge.after(this.dom,t==this.length)}split(t){let e=this.length-t;this.length=t;let i=new si(this.widget,e,this.type);return i.breakAfter=this.breakAfter,i}get children(){return Oe}sync(){this.dom&&this.widget.updateDOM(this.dom)||(this.dom&&this.prevWidget&&this.prevWidget.destroy(this.dom),this.prevWidget=null,this.setDOM(this.widget.toDOM(this.editorView)),this.dom.contentEditable="false")}get overrideDOMText(){return this.parent?this.parent.view.state.doc.slice(this.posAtStart,this.posAtEnd):t.empty}domBoundsAround(){return null}become(t){return t instanceof si&&t.type==this.type&&t.widget.constructor==this.widget.constructor&&(t.widget.eq(this.widget)||this.markDirty(!0),this.dom&&!this.prevWidget&&(this.prevWidget=this.widget),this.widget=t.widget,this.length=t.length,this.breakAfter=t.breakAfter,!0)}ignoreMutation(){return!0}ignoreEvent(t){return this.widget.ignoreEvent(t)}destroy(){super.destroy(),this.dom&&this.widget.destroy(this.dom)}}class ni{constructor(t,e,i,s){this.doc=t,this.pos=e,this.end=i,this.disallowBlockEffectsFor=s,this.content=[],this.curLine=null,this.breakAtStart=0,this.pendingBuffer=0,this.atCursorPos=!0,this.openStart=-1,this.openEnd=-1,this.text="",this.textOff=0,this.cursor=t.iter(),this.skip=e}posCovered(){if(0==this.content.length)return!this.breakAtStart&&this.doc.lineAt(this.pos).from!=this.pos;let t=this.content[this.content.length-1];return!(t.breakAfter||t instanceof si&&t.type==Ze.WidgetBefore)}getLine(){return this.curLine||(this.content.push(this.curLine=new ii),this.atCursorPos=!0),this.curLine}flushBuffer(t){this.pendingBuffer&&(this.curLine.append(ri(new je(-1),t),t.length),this.pendingBuffer=0)}addBlockWidget(t){this.flushBuffer([]),this.curLine=null,this.content.push(t)}finish(t){t?this.pendingBuffer=0:this.flushBuffer([]),this.posCovered()||this.getLine()}buildText(t,e,i){for(;t>0;){if(this.textOff==this.text.length){let{value:e,lineBreak:i,done:s}=this.cursor.next(this.skip);if(this.skip=0,s)throw new Error("Ran out of text content when drawing inline views");if(i){this.posCovered()||this.getLine(),this.content.length?this.content[this.content.length-1].breakAfter=1:this.breakAtStart=1,this.flushBuffer([]),this.curLine=null,t--;continue}this.text=e,this.textOff=0}let s=Math.min(this.text.length-this.textOff,t,512);this.flushBuffer(e.slice(0,i)),this.getLine().append(ri(new Me(this.text.slice(this.textOff,this.textOff+s)),e),i),this.atCursorPos=!0,this.textOff+=s,t-=s,i=0}}span(t,e,i,s){this.buildText(e-t,i,s),this.pos=e,this.openStart<0&&(this.openStart=s)}point(t,e,i,s,n,r){if(this.disallowBlockEffectsFor[r]&&i instanceof Je){if(i.block)throw new RangeError("Block decorations may not be specified via plugins");if(e>this.doc.lineAt(this.pos).to)throw new RangeError("Decorations that replace line breaks may not be specified via plugins")}let o=e-t;if(i instanceof Je)if(i.block){let{type:t}=i;t!=Ze.WidgetAfter||this.posCovered()||this.getLine(),this.addBlockWidget(new si(i.widget||new oi("div"),o,t))}else{let r=Ne.create(i.widget||new oi("span"),o,i.startSide),h=this.atCursorPos&&!r.isEditable&&n<=s.length&&(t<e||i.startSide>0),l=!r.isEditable&&(t<e||i.startSide<=0),a=this.getLine();2!=this.pendingBuffer||h||(this.pendingBuffer=0),this.flushBuffer(s),h&&(a.append(ri(new je(1),s),n),n=s.length+Math.max(0,n-s.length)),a.append(ri(r,s),n),this.atCursorPos=l,this.pendingBuffer=l?t<e?1:2:0}else this.doc.lineAt(this.pos).from==this.pos&&this.getLine().addLineDeco(i);o&&(this.textOff+o<=this.text.length?this.textOff+=o:(this.skip+=o-(this.text.length-this.textOff),this.text="",this.textOff=0),this.pos=e),this.openStart<0&&(this.openStart=n)}static build(t,e,i,s,n){let r=new ni(t,e,i,n);return r.openEnd=Qt.spans(s,e,i,r),r.openStart<0&&(r.openStart=r.openEnd),r.finish(r.openEnd),r}}function ri(t,e){for(let i of e)t=new De(i,[t],t.length);return t}class oi extends Ge{constructor(t){super(),this.tag=t}eq(t){return t.tag==this.tag}toDOM(){return document.createElement(this.tag)}updateDOM(t){return t.nodeName.toLowerCase()==this.tag}}const hi=M.define(),li=M.define(),ai=M.define(),ci=M.define(),ui=M.define(),fi=M.define(),di=M.define({combine:t=>t.some((t=>t))});class pi{constructor(t,e="nearest",i="nearest",s=5,n=5){this.range=t,this.y=e,this.x=i,this.yMargin=s,this.xMargin=n}map(t){return t.empty?this:new pi(this.range.map(t),this.y,this.x,this.yMargin,this.xMargin)}}const gi=ct.define({map:(t,e)=>t.map(e)});function Oi(t,e,i){let s=t.facet(ci);s.length?s[0](e):window.onerror?window.onerror(String(e),i,void 0,void 0,e):i?console.error(i+":",e):console.error(e)}const mi=M.define({combine:t=>!t.length||t[0]});let bi=0;const vi=M.define();class yi{constructor(t,e,i,s){this.id=t,this.create=e,this.domEventHandlers=i,this.extension=s(this)}static define(t,e){const{eventHandlers:i,provide:s,decorations:n}=e||{};return new yi(bi++,t,i,(t=>{let e=[vi.of(t)];return n&&e.push(ki.of((e=>{let i=e.plugin(t);return i?n(i):Ue.none}))),s&&e.push(s(t)),e}))}static fromClass(t,e){return yi.define((e=>new t(e)),e)}}class wi{constructor(t){this.spec=t,this.mustUpdate=null,this.value=null}update(t){if(this.value){if(this.mustUpdate){let t=this.mustUpdate;if(this.mustUpdate=null,this.value.update)try{this.value.update(t)}catch(e){if(Oi(t.state,e,"CodeMirror plugin crashed"),this.value.destroy)try{this.value.destroy()}catch(t){}this.deactivate()}}}else if(this.spec)try{this.value=this.spec.create(t)}catch(e){Oi(t.state,e,"CodeMirror plugin crashed"),this.deactivate()}return this}destroy(t){var e;if(null===(e=this.value)||void 0===e?void 0:e.destroy)try{this.value.destroy()}catch(e){Oi(t.state,e,"CodeMirror plugin crashed")}}deactivate(){this.spec=this.value=null}}const xi=M.define(),Si=M.define(),ki=M.define(),Pi=M.define(),$i=M.define(),Qi=M.define();class Ri{constructor(t,e,i,s){this.fromA=t,this.toA=e,this.fromB=i,this.toB=s}join(t){return new Ri(Math.min(this.fromA,t.fromA),Math.max(this.toA,t.toA),Math.min(this.fromB,t.fromB),Math.max(this.toB,t.toB))}addToSet(t){let e=t.length,i=this;for(;e>0;e--){let s=t[e-1];if(!(s.fromA>i.toA)){if(s.toA<i.fromA)break;i=i.join(s),t.splice(e-1,1)}}return t.splice(e,0,i),t}static extendWithRanges(t,e){if(0==e.length)return t;let i=[];for(let s=0,n=0,r=0,o=0;;s++){let h=s==t.length?null:t[s],l=r-o,a=h?h.fromB:1e9;for(;n<e.length&&e[n]<a;){let t=e[n],s=e[n+1],r=Math.max(o,t),h=Math.min(a,s);if(r<=h&&new Ri(r+l,h+l,r,h).addToSet(i),s>a)break;n+=2}if(!h)return i;new Ri(h.fromA,h.toA,h.fromB,h.toB).addToSet(i),r=h.toA,o=h.toB}}}class qi{constructor(t,e,i){this.view=t,this.state=e,this.transactions=i,this.flags=0,this.startState=t.state,this.changes=x.empty(this.startState.doc.length);for(let t of i)this.changes=this.changes.compose(t.changes);let s=[];this.changes.iterChangedRanges(((t,e,i,n)=>s.push(new Ri(t,e,i,n)))),this.changedRanges=s;let n=t.hasFocus;n!=t.inputState.notifiedFocused&&(t.inputState.notifiedFocused=n,this.flags|=1)}static create(t,e,i){return new qi(t,e,i)}get viewportChanged(){return(4&this.flags)>0}get heightChanged(){return(2&this.flags)>0}get geometryChanged(){return this.docChanged||(10&this.flags)>0}get focusChanged(){return(1&this.flags)>0}get docChanged(){return!this.changes.empty}get selectionSet(){return this.transactions.some((t=>t.selection))}get empty(){return 0==this.flags&&0==this.transactions.length}}var Ai=function(t){return t[t.LTR=0]="LTR",t[t.RTL=1]="RTL",t}(Ai||(Ai={}));const Ti=Ai.LTR,Ci=Ai.RTL;function Xi(t){let e=[];for(let i=0;i<t.length;i++)e.push(1<<+t[i]);return e}const Mi=Xi("88888888888888888888888888888888888666888888787833333333337888888000000000000000000000000008888880000000000000000000000000088888888888888888888888888888888888887866668888088888663380888308888800000000000000000000000800000000000000000000000000000008"),Di=Xi("4444448826627288999999999992222222222222222222222222222222222222222222222229999999999999999999994444444444644222822222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222999999949999999229989999223333333333"),Ei=Object.create(null),Ni=[];for(let t of["()","[]","{}"]){let e=t.charCodeAt(0),i=t.charCodeAt(1);Ei[e]=i,Ei[i]=-e}const _i=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/;class Bi{constructor(t,e,i){this.from=t,this.to=e,this.level=i}get dir(){return this.level%2?Ci:Ti}side(t,e){return this.dir==e==t?this.to:this.from}static find(t,e,i,s){let n=-1;for(let r=0;r<t.length;r++){let o=t[r];if(o.from<=e&&o.to>=e){if(o.level==i)return r;(n<0||(0!=s?s<0?o.from<e:o.to>e:t[n].level>o.level))&&(n=r)}}if(n<0)throw new RangeError("Index out of range");return n}}const Vi=[];function ji(t){return[new Bi(0,t,0)]}let zi="";function Wi(t,e,i,s,n){var r;let o=s.head-t.from,h=-1;if(0==o){if(!n||!t.length)return null;e[0].level!=i&&(o=e[0].side(!1,i),h=0)}else if(o==t.length){if(n)return null;let t=e[e.length-1];t.level!=i&&(o=t.side(!0,i),h=e.length-1)}h<0&&(h=Bi.find(e,o,null!==(r=s.bidiLevel)&&void 0!==r?r:-1,s.assoc));let l=e[h];o==l.side(n,i)&&(l=e[h+=n?1:-1],o=l.side(!n,i));let a=n==(l.dir==i),c=f(t.text,o,a);if(zi=t.text.slice(Math.min(o,c),Math.max(o,c)),c!=l.side(n,i))return A.cursor(c+t.from,a?-1:1,l.level);let u=h==(n?e.length-1:0)?null:e[h+(n?1:-1)];return u||l.level==i?u&&u.level<l.level?A.cursor(u.side(!n,i)+t.from,n?1:-1,u.level):A.cursor(c+t.from,n?-1:1,l.level):A.cursor(n?t.to:t.from,n?-1:1,i)}class Ii{constructor(t,e){this.points=t,this.text="",this.lineSeparator=e.facet(xt.lineSeparator)}append(t){this.text+=t}lineBreak(){this.text+=""}readRange(t,e){if(!t)return this;let i=t.parentNode;for(let s=t;;){this.findPointBefore(i,s),this.readNode(s);let t=s.nextSibling;if(t==e)break;let n=me.get(s),r=me.get(t);(n&&r?n.breakAfter:(n?n.breakAfter:Li(s))||Li(t)&&("BR"!=s.nodeName||s.cmIgnore))&&this.lineBreak(),s=t}return this.findPointBefore(i,e),this}readTextNode(t){let e=t.nodeValue;for(let i of this.points)i.node==t&&(i.pos=this.text.length+Math.min(i.offset,e.length));for(let i=0,s=this.lineSeparator?null:/\r\n?|\n/g;;){let n,r=-1,o=1;if(this.lineSeparator?(r=e.indexOf(this.lineSeparator,i),o=this.lineSeparator.length):(n=s.exec(e))&&(r=n.index,o=n[0].length),this.append(e.slice(i,r<0?e.length:r)),r<0)break;if(this.lineBreak(),o>1)for(let e of this.points)e.node==t&&e.pos>this.text.length&&(e.pos-=o-1);i=r+o}}readNode(t){if(t.cmIgnore)return;let e=me.get(t),i=e&&e.overrideDOMText;if(null!=i){this.findPointInside(t,i.length);for(let t=i.iter();!t.next().done;)t.lineBreak?this.lineBreak():this.append(t.value)}else 3==t.nodeType?this.readTextNode(t):"BR"==t.nodeName?t.nextSibling&&this.lineBreak():1==t.nodeType&&this.readRange(t.firstChild,null)}findPointBefore(t,e){for(let i of this.points)i.node==t&&t.childNodes[i.offset]==e&&(i.pos=this.text.length)}findPointInside(t,e){for(let i of this.points)(3==t.nodeType?i.node==t:t.contains(i.node))&&(i.pos=this.text.length+Math.min(e,i.offset))}}function Li(t){return 1==t.nodeType&&/^(DIV|P|LI|UL|OL|BLOCKQUOTE|DD|DT|H\d|SECTION|PRE)$/.test(t.nodeName)}class Fi{constructor(t,e){this.node=t,this.offset=e,this.pos=-1}}class Hi extends me{constructor(t){super(),this.view=t,this.compositionDeco=Ue.none,this.decorations=[],this.dynamicDecorationMap=[],this.minWidth=0,this.minWidthFrom=0,this.minWidthTo=0,this.impreciseAnchor=null,this.impreciseHead=null,this.forceSelection=!1,this.lastUpdate=Date.now(),this.setDOM(t.contentDOM),this.children=[new ii],this.children[0].setParent(this),this.updateDeco(),this.updateInner([new Ri(0,0,0,t.state.doc.length)],0)}get root(){return this.view.root}get editorView(){return this.view}get length(){return this.view.state.doc.length}update(t){let e=t.changedRanges;this.minWidth>0&&e.length&&(e.every((({fromA:t,toA:e})=>e<this.minWidthFrom||t>this.minWidthTo))?(this.minWidthFrom=t.changes.mapPos(this.minWidthFrom,1),this.minWidthTo=t.changes.mapPos(this.minWidthTo,1)):this.minWidth=this.minWidthFrom=this.minWidthTo=0),this.view.inputState.composing<0?this.compositionDeco=Ue.none:(t.transactions.length||this.dirty)&&(this.compositionDeco=function(t,e){let i=Zi(t);if(!i)return Ue.none;let{from:s,to:n,node:r,text:o}=i,h=e.mapPos(s,1),l=Math.max(h,e.mapPos(n,-1)),{state:a}=t,c=3==r.nodeType?r.nodeValue:new Ii([],a).readRange(r.firstChild,null).text;if(l-h<c.length)if(a.doc.sliceString(h,Math.min(a.doc.length,h+c.length),"")==c)l=h+c.length;else{if(a.doc.sliceString(Math.max(0,l-c.length),l,"")!=c)return Ue.none;h=l-c.length}else if(a.doc.sliceString(h,l,"")!=c)return Ue.none;let u=me.get(r);u instanceof _e?u=u.widget.topView:u&&(u.parent=null);return Ue.set(Ue.replace({widget:new Ui(r,o,u),inclusive:!0}).range(h,l))}(this.view,t.changes)),(Xe.ie||Xe.chrome)&&!this.compositionDeco.size&&t&&t.state.doc.lines!=t.startState.doc.lines&&(this.forceSelection=!0);let i=function(t,e,i){let s=new Ki;return Qt.compare(t,e,i,s),s.changes}(this.decorations,this.updateDeco(),t.changes);return e=Ri.extendWithRanges(e,i),(0!=this.dirty||0!=e.length)&&(this.updateInner(e,t.startState.doc.length),t.transactions.length&&(this.lastUpdate=Date.now()),!0)}updateInner(t,e){this.view.viewState.mustMeasureContent=!0,this.updateChildren(t,e);let{observer:i}=this.view;i.ignore((()=>{this.dom.style.height=this.view.viewState.contentHeight+"px",this.dom.style.minWidth=this.minWidth?this.minWidth+"px":"";let t=Xe.chrome||Xe.ios?{node:i.selectionRange.focusNode,written:!1}:void 0;this.sync(t),this.dirty=0,t&&(t.written||i.selectionRange.focusNode!=t.node)&&(this.forceSelection=!0),this.dom.style.height=""}));let s=[];if(this.view.viewport.from||this.view.viewport.to<this.view.state.doc.length)for(let t of this.children)t instanceof si&&t.widget instanceof Gi&&s.push(t.dom);i.updateGaps(s)}updateChildren(t,e){let i=this.childCursor(e);for(let e=t.length-1;;e--){let s=e>=0?t[e]:null;if(!s)break;let{fromA:n,toA:r,fromB:o,toB:h}=s,{content:l,breakAtStart:a,openStart:c,openEnd:u}=ni.build(this.view.state.doc,o,h,this.decorations,this.dynamicDecorationMap),{i:f,off:d}=i.findPos(r,1),{i:p,off:g}=i.findPos(n,-1);ye(this,p,g,f,d,l,a,c,u)}}updateSelection(t=!1,e=!1){if(t&&this.view.observer.readSelectionRange(),!e&&!this.mayControlSelection()||Xe.ios&&this.view.inputState.rapidCompositionStart)return;let i=this.forceSelection;this.forceSelection=!1;let s=this.view.state.selection.main,n=this.domAtPos(s.anchor),r=s.empty?n:this.domAtPos(s.head);if(Xe.gecko&&s.empty&&(1==(o=n).node.nodeType&&o.node.firstChild&&(0==o.offset||"false"==o.node.childNodes[o.offset-1].contentEditable)&&(o.offset==o.node.childNodes.length||"false"==o.node.childNodes[o.offset].contentEditable))){let t=document.createTextNode("");this.view.observer.ignore((()=>n.node.insertBefore(t,n.node.childNodes[n.offset]||null))),n=r=new ge(t,0),i=!0}var o;let h=this.view.observer.selectionRange;!i&&h.focusNode&&ee(n.node,n.offset,h.anchorNode,h.anchorOffset)&&ee(r.node,r.offset,h.focusNode,h.focusOffset)||(this.view.observer.ignore((()=>{Xe.android&&Xe.chrome&&this.dom.contains(h.focusNode)&&function(t,e){for(let i=t;i&&i!=e;i=i.assignedSlot||i.parentNode)if(1==i.nodeType&&"false"==i.contentEditable)return!0;return!1}(h.focusNode,this.dom)&&(this.dom.blur(),this.dom.focus({preventScroll:!0}));let t=Yt(this.root);if(s.empty){if(Xe.gecko){let t=(e=n.node,i=n.offset,1!=e.nodeType?0:(i&&"false"==e.childNodes[i-1].contentEditable?1:0)|(i<e.childNodes.length&&"false"==e.childNodes[i].contentEditable?2:0));if(t&&3!=t){let e=Yi(n.node,n.offset,1==t?1:-1);e&&(n=new ge(e,1==t?0:e.nodeValue.length))}}t.collapse(n.node,n.offset),null!=s.bidiLevel&&null!=h.cursorBidiLevel&&(h.cursorBidiLevel=s.bidiLevel)}else if(t.extend)t.collapse(n.node,n.offset),t.extend(r.node,r.offset);else{let e=document.createRange();s.anchor>s.head&&([n,r]=[r,n]),e.setEnd(r.node,r.offset),e.setStart(n.node,n.offset),t.removeAllRanges(),t.addRange(e)}var e,i})),this.view.observer.setSelectionRange(n,r)),this.impreciseAnchor=n.precise?null:new ge(h.anchorNode,h.anchorOffset),this.impreciseHead=r.precise?null:new ge(h.focusNode,h.focusOffset)}enforceCursorAssoc(){if(this.compositionDeco.size)return;let t=this.view.state.selection.main,e=Yt(this.root);if(!t.empty||!t.assoc||!e.modify)return;let i=ii.find(this,t.head);if(!i)return;let s=i.posAtStart;if(t.head==s||t.head==s+i.length)return;let n=this.coordsAt(t.head,-1),r=this.coordsAt(t.head,1);if(!n||!r||n.bottom>r.top)return;let o=this.domAtPos(t.head+t.assoc);e.collapse(o.node,o.offset),e.modify("move",t.assoc<0?"forward":"backward","lineboundary")}mayControlSelection(){return this.view.state.facet(mi)?this.root.activeElement==this.dom:Jt(this.dom,this.view.observer.selectionRange)}nearest(t){for(let e=t;e;){let t=me.get(e);if(t&&t.rootView==this)return t;e=e.parentNode}return null}posFromDOM(t,e){let i=this.nearest(t);if(!i)throw new RangeError("Trying to find position for a DOM position outside of the document");return i.localPosFromDOM(t,e)+i.posAtStart}domAtPos(t){let{i:e,off:i}=this.childCursor().findPos(t,-1);for(;e<this.children.length-1;){let t=this.children[e];if(i<t.length||t instanceof ii)break;e++,i=0}return this.children[e].domAtPos(i)}coordsAt(t,e){for(let i=this.length,s=this.children.length-1;;s--){let n=this.children[s],r=i-n.breakAfter-n.length;if(t>r||t==r&&n.type!=Ze.WidgetBefore&&n.type!=Ze.WidgetAfter&&(!s||2==e||this.children[s-1].breakAfter||this.children[s-1].type==Ze.WidgetBefore&&e>-2))return n.coordsAt(t-r,e);i=r}}measureVisibleLineHeights(t){let e=[],{from:i,to:s}=t,n=this.view.contentDOM.clientWidth,r=n>Math.max(this.view.scrollDOM.clientWidth,this.minWidth)+1,o=-1,h=this.view.textDirection==Ai.LTR;for(let t=0,l=0;l<this.children.length;l++){let a=this.children[l],c=t+a.length;if(c>s)break;if(t>=i){let i=a.dom.getBoundingClientRect();if(e.push(i.height),r){let e=a.dom.lastChild,s=e?te(e):[];if(s.length){let e=s[s.length-1],r=h?e.right-i.left:i.right-e.left;r>o&&(o=r,this.minWidth=n,this.minWidthFrom=t,this.minWidthTo=c)}}}t=c+a.breakAfter}return e}textDirectionAt(t){let{i:e}=this.childPos(t,1);return"rtl"==getComputedStyle(this.children[e].dom).direction?Ai.RTL:Ai.LTR}measureTextSize(){for(let t of this.children)if(t instanceof ii){let e=t.measureTextSize();if(e)return e}let t,e,i=document.createElement("div");return i.className="cm-line",i.textContent="abc def ghi jkl mno pqr stu",this.view.observer.ignore((()=>{this.dom.appendChild(i);let s=te(i.firstChild)[0];t=i.getBoundingClientRect().height,e=s?s.width/27:7,i.remove()})),{lineHeight:t,charWidth:e}}childCursor(t=this.length){let e=this.children.length;return e&&(t-=this.children[--e].length),new ve(this.children,t,e)}computeBlockGapDeco(){let t=[],e=this.view.viewState;for(let i=0,s=0;;s++){let n=s==e.viewports.length?null:e.viewports[s],r=n?n.from-1:this.length;if(r>i){let s=e.lineBlockAt(r).bottom-e.lineBlockAt(i).top;t.push(Ue.replace({widget:new Gi(s),block:!0,inclusive:!0,isBlockGap:!0}).range(i,r))}if(!n)break;i=n.to+1}return Ue.set(t)}updateDeco(){let t=this.view.state.facet(ki).map(((t,e)=>(this.dynamicDecorationMap[e]="function"==typeof t)?t(this.view):t));for(let e=t.length;e<t.length+3;e++)this.dynamicDecorationMap[e]=!1;return this.decorations=[...t,this.compositionDeco,this.computeBlockGapDeco(),this.view.viewState.lineGapDeco]}scrollIntoView(t){let e,{range:i}=t,s=this.coordsAt(i.head,i.empty?i.assoc:i.head>i.anchor?-1:1);if(!s)return;!i.empty&&(e=this.coordsAt(i.anchor,i.anchor>i.head?-1:1))&&(s={left:Math.min(s.left,e.left),top:Math.min(s.top,e.top),right:Math.max(s.right,e.right),bottom:Math.max(s.bottom,e.bottom)});let n=0,r=0,o=0,h=0;for(let t of this.view.state.facet($i).map((t=>t(this.view))))if(t){let{left:e,right:i,top:s,bottom:l}=t;null!=e&&(n=Math.max(n,e)),null!=i&&(r=Math.max(r,i)),null!=s&&(o=Math.max(o,s)),null!=l&&(h=Math.max(h,l))}let l={left:s.left-n,top:s.top-o,right:s.right+r,bottom:s.bottom+h};!function(t,e,i,s,n,r,o,h){let l=t.ownerDocument,a=l.defaultView;for(let c=t;c;)if(1==c.nodeType){let t,u=c==l.body;if(u)t=he(a);else{if(c.scrollHeight<=c.clientHeight&&c.scrollWidth<=c.clientWidth){c=c.parentNode;continue}let e=c.getBoundingClientRect();t={left:e.left,right:e.left+c.clientWidth,top:e.top,bottom:e.top+c.clientHeight}}let f=0,d=0;if("nearest"==n)e.top<t.top?(d=-(t.top-e.top+o),i>0&&e.bottom>t.bottom+d&&(d=e.bottom-t.bottom+d+o)):e.bottom>t.bottom&&(d=e.bottom-t.bottom+o,i<0&&e.top-d<t.top&&(d=-(t.top+d-e.top+o)));else{let s=e.bottom-e.top,r=t.bottom-t.top;d=("center"==n&&s<=r?e.top+s/2-r/2:"start"==n||"center"==n&&i<0?e.top-o:e.bottom-r+o)-t.top}if("nearest"==s?e.left<t.left?(f=-(t.left-e.left+r),i>0&&e.right>t.right+f&&(f=e.right-t.right+f+r)):e.right>t.right&&(f=e.right-t.right+r,i<0&&e.left<t.left+f&&(f=-(t.left+f-e.left+r))):f=("center"==s?e.left+(e.right-e.left)/2-(t.right-t.left)/2:"start"==s==h?e.left-r:e.right-(t.right-t.left)+r)-t.left,f||d)if(u)a.scrollBy(f,d);else{if(d){let t=c.scrollTop;c.scrollTop+=d,d=c.scrollTop-t}if(f){let t=c.scrollLeft;c.scrollLeft+=f,f=c.scrollLeft-t}e={left:e.left-f,top:e.top-d,right:e.right-f,bottom:e.bottom-d}}if(u)break;c=c.assignedSlot||c.parentNode,s=n="nearest"}else{if(11!=c.nodeType)break;c=c.host}}(this.view.scrollDOM,l,i.head<i.anchor?-1:1,t.x,t.y,t.xMargin,t.yMargin,this.view.textDirection==Ai.LTR)}}class Gi extends Ge{constructor(t){super(),this.height=t}toDOM(){let t=document.createElement("div");return this.updateDOM(t),t}eq(t){return t.height==this.height}updateDOM(t){return t.style.height=this.height+"px",!0}get estimatedHeight(){return this.height}}function Zi(t){let e=t.observer.selectionRange,i=e.focusNode&&Yi(e.focusNode,e.focusOffset,0);if(!i)return null;let s=t.docView.nearest(i);if(!s)return null;if(s instanceof ii){let t=i;for(;t.parentNode!=s.dom;)t=t.parentNode;let e=t.previousSibling;for(;e&&!me.get(e);)e=e.previousSibling;let n=e?me.get(e).posAtEnd:s.posAtStart;return{from:n,to:n,node:t,text:i}}{for(;;){let{parent:t}=s;if(!t)return null;if(t instanceof ii)break;s=t}let t=s.posAtStart;return{from:t,to:t+s.length,node:s.dom,text:i}}}class Ui extends Ge{constructor(t,e,i){super(),this.top=t,this.text=e,this.topView=i}eq(t){return this.top==t.top&&this.text==t.text}toDOM(){return this.top}ignoreEvent(){return!1}get customView(){return _e}}function Yi(t,e,i){for(;;){if(3==t.nodeType)return t;if(1==t.nodeType&&e>0&&i<=0)e=ne(t=t.childNodes[e-1]);else{if(!(1==t.nodeType&&e<t.childNodes.length&&i>=0))return null;t=t.childNodes[e],e=0}}}class Ki{constructor(){this.changes=[]}compareRange(t,e){ei(t,e,this.changes)}comparePoint(t,e){ei(t,e,this.changes)}}function Ji(t,e){return e.left>t?e.left-t:Math.max(0,t-e.right)}function ts(t,e){return e.top>t?e.top-t:Math.max(0,t-e.bottom)}function es(t,e){return t.top<e.bottom-1&&t.bottom>e.top+1}function is(t,e){return e<t.top?{top:e,left:t.left,right:t.right,bottom:t.bottom}:t}function ss(t,e){return e>t.bottom?{top:t.top,left:t.left,right:t.right,bottom:e}:t}function ns(t,e,i){let s,n,r,o,h,l,a,c;for(let u=t.firstChild;u;u=u.nextSibling){let t=te(u);for(let f=0;f<t.length;f++){let d=t[f];n&&es(n,d)&&(d=is(ss(d,n.bottom),n.top));let p=Ji(e,d),g=ts(i,d);if(0==p&&0==g)return 3==u.nodeType?rs(u,e,i):ns(u,e,i);(!s||o>g||o==g&&r>p)&&(s=u,n=d,r=p,o=g),0==p?i>d.bottom&&(!a||a.bottom<d.bottom)?(h=u,a=d):i<d.top&&(!c||c.top>d.top)&&(l=u,c=d):a&&es(a,d)?a=ss(a,d.bottom):c&&es(c,d)&&(c=is(c,d.top))}}if(a&&a.bottom>=i?(s=h,n=a):c&&c.top<=i&&(s=l,n=c),!s)return{node:t,offset:0};let u=Math.max(n.left,Math.min(n.right,e));return 3==s.nodeType?rs(s,u,i):r||"true"!=s.contentEditable?{node:t,offset:Array.prototype.indexOf.call(t.childNodes,s)+(e>=(n.left+n.right)/2?1:0)}:ns(s,u,i)}function rs(t,e,i){let s=t.nodeValue.length,n=-1,r=1e9,o=0;for(let h=0;h<s;h++){let s=fe(t,h,h+1).getClientRects();for(let l=0;l<s.length;l++){let a=s[l];if(a.top==a.bottom)continue;o||(o=e-a.left);let c=(a.top>i?a.top-i:i-a.bottom)-1;if(a.left-1<=e&&a.right+1>=e&&c<r){let i=e>=(a.left+a.right)/2,s=i;if(Xe.chrome||Xe.gecko){fe(t,h).getBoundingClientRect().left==a.right&&(s=!i)}if(c<=0)return{node:t,offset:h+(s?1:0)};n=h+(s?1:0),r=c}}}return{node:t,offset:n>-1?n:o>0?t.nodeValue.length:0}}function os(t,{x:e,y:i},s,n=-1){var r;let o,h=t.contentDOM.getBoundingClientRect(),l=h.top+t.viewState.paddingTop,{docHeight:a}=t.viewState,c=i-l;if(c<0)return 0;if(c>a)return t.state.doc.length;for(let e=t.defaultLineHeight/2,i=!1;o=t.elementAtHeight(c),o.type!=Ze.Text;)for(;c=n>0?o.bottom+e:o.top-e,!(c>=0&&c<=a);){if(i)return s?null:0;i=!0,n=-n}i=l+c;let u=o.from;if(u<t.viewport.from)return 0==t.viewport.from?0:s?null:hs(t,h,o,e,i);if(u>t.viewport.to)return t.viewport.to==t.state.doc.length?t.state.doc.length:s?null:hs(t,h,o,e,i);let f=t.dom.ownerDocument,d=t.root.elementFromPoint?t.root:f,p=d.elementFromPoint(e,i);p&&!t.contentDOM.contains(p)&&(p=null),p||(e=Math.max(h.left+1,Math.min(h.right-1,e)),p=d.elementFromPoint(e,i),p&&!t.contentDOM.contains(p)&&(p=null));let g,O=-1;if(p&&0!=(null===(r=t.docView.nearest(p))||void 0===r?void 0:r.isEditable))if(f.caretPositionFromPoint){let t=f.caretPositionFromPoint(e,i);t&&({offsetNode:g,offset:O}=t)}else if(f.caretRangeFromPoint){let t=f.caretRangeFromPoint(e,i);t&&(({startContainer:g,startOffset:O}=t),Xe.safari&&function(t,e,i){let s;if(3!=t.nodeType||e!=(s=t.nodeValue.length))return!1;for(let e=t.nextSibling;e;e=e.nextSibling)if(1!=e.nodeType||"BR"!=e.nodeName)return!1;return fe(t,s-1,s).getBoundingClientRect().left>i}(g,O,e)&&(g=void 0))}if(!g||!t.docView.dom.contains(g)){let s=ii.find(t.docView,u);if(!s)return c>o.top+o.height/2?o.to:o.from;({node:g,offset:O}=ns(s.dom,e,i))}return t.docView.posFromDOM(g,O)}function hs(t,e,i,s,n){let r=Math.round((s-e.left)*t.defaultCharacterWidth);if(t.lineWrapping&&i.height>1.5*t.defaultLineHeight){r+=Math.floor((n-i.top)/t.defaultLineHeight)*t.viewState.heightOracle.lineLength}let o=t.state.sliceDoc(i.from,i.to);return i.from+function(t,e,i,s){for(let s=0,n=0;;){if(n>=e)return s;if(s==t.length)break;n+=9==t.charCodeAt(s)?i-n%i:1,s=f(t,s)}return!0===s?-1:t.length}(o,r,t.state.tabSize)}function ls(t,e,i,s){let n=t.state.doc.lineAt(e.head),r=t.bidiSpans(n),o=t.textDirectionAt(n.from);for(let h=e,l=null;;){let e=Wi(n,r,o,h,i),a=zi;if(!e){if(n.number==(i?t.state.doc.lines:1))return h;a="\n",n=t.state.doc.line(n.number+(i?1:-1)),r=t.bidiSpans(n),e=A.cursor(i?n.from:n.to)}if(l){if(!l(a))return h}else{if(!s)return e;l=s(a)}h=e}}function as(t,e,i){let s=t.state.facet(Pi).map((e=>e(t)));for(;;){let t=!1;for(let n of s)n.between(i.from-1,i.from+1,((s,n,r)=>{i.from>s&&i.from<n&&(i=e.from>i.from?A.cursor(s,1):A.cursor(n,-1),t=!0)}));if(!t)return i}}class cs{constructor(t){this.lastKeyCode=0,this.lastKeyTime=0,this.pendingIOSKey=void 0,this.lastSelectionOrigin=null,this.lastSelectionTime=0,this.lastEscPress=0,this.lastContextMenu=0,this.scrollHandlers=[],this.registeredEvents=[],this.customHandlers=[],this.composing=-1,this.compositionFirstChange=null,this.compositionEndedAt=0,this.rapidCompositionStart=!1,this.mouseSelection=null;for(let e in gs){let i=gs[e];t.contentDOM.addEventListener(e,(s=>{ps(t,s)&&!this.ignoreDuringComposition(s)&&("keydown"==e&&this.keydown(t,s)||(this.mustFlushObserver(s)&&t.observer.forceFlush(),this.runCustomHandlers(e,t,s)?s.preventDefault():i(t,s)))})),this.registeredEvents.push(e)}this.notifiedFocused=t.hasFocus,Xe.safari&&t.contentDOM.addEventListener("input",(()=>null))}setSelectionOrigin(t){this.lastSelectionOrigin=t,this.lastSelectionTime=Date.now()}ensureHandlers(t,e){var i;let s;for(let n of e)if(s=null===(i=n.update(t).spec)||void 0===i?void 0:i.domEventHandlers){this.customHandlers.push({plugin:n.value,handlers:s});for(let e in s)this.registeredEvents.indexOf(e)<0&&"scroll"!=e&&(this.registeredEvents.push(e),t.contentDOM.addEventListener(e,(i=>{ps(t,i)&&this.runCustomHandlers(e,t,i)&&i.preventDefault()})))}}runCustomHandlers(t,e,i){for(let s of this.customHandlers){let n=s.handlers[t];if(n)try{if(n.call(s.plugin,i,e)||i.defaultPrevented)return!0}catch(t){Oi(e.state,t)}}return!1}runScrollHandlers(t,e){for(let i of this.customHandlers){let s=i.handlers.scroll;if(s)try{s.call(i.plugin,e,t)}catch(e){Oi(t.state,e)}}}keydown(t,e){if(this.lastKeyCode=e.keyCode,this.lastKeyTime=Date.now(),9==e.keyCode&&Date.now()<this.lastEscPress+2e3)return!0;if(Xe.android&&Xe.chrome&&!e.synthetic&&(13==e.keyCode||8==e.keyCode))return t.observer.delayAndroidKey(e.key,e.keyCode),!0;let i;return!(!Xe.ios||!(i=us.find((t=>t.keyCode==e.keyCode)))||e.ctrlKey||e.altKey||e.metaKey||e.synthetic)&&(this.pendingIOSKey=i,setTimeout((()=>this.flushIOSKey(t)),250),!0)}flushIOSKey(t){let e=this.pendingIOSKey;return!!e&&(this.pendingIOSKey=void 0,de(t.contentDOM,e.key,e.keyCode))}ignoreDuringComposition(t){return!!/^key/.test(t.type)&&(this.composing>0||!!(Xe.safari&&Date.now()-this.compositionEndedAt<100)&&(this.compositionEndedAt=0,!0))}mustFlushObserver(t){return"keydown"==t.type&&229!=t.keyCode||"compositionend"==t.type&&!Xe.ios}startMouseSelection(t){this.mouseSelection&&this.mouseSelection.destroy(),this.mouseSelection=t}update(t){this.mouseSelection&&this.mouseSelection.update(t),t.transactions.length&&(this.lastKeyCode=this.lastSelectionTime=0)}destroy(){this.mouseSelection&&this.mouseSelection.destroy()}}const us=[{key:"Backspace",keyCode:8,inputType:"deleteContentBackward"},{key:"Enter",keyCode:13,inputType:"insertParagraph"},{key:"Delete",keyCode:46,inputType:"deleteContentForward"}],fs=[16,17,18,20,91,92,224,225];class ds{constructor(t,e,i,s){this.view=t,this.style=i,this.mustSelect=s,this.lastEvent=e;let n=t.contentDOM.ownerDocument;n.addEventListener("mousemove",this.move=this.move.bind(this)),n.addEventListener("mouseup",this.up=this.up.bind(this)),this.extend=e.shiftKey,this.multiple=t.state.facet(xt.allowMultipleSelections)&&function(t,e){let i=t.state.facet(hi);return i.length?i[0](e):Xe.mac?e.metaKey:e.ctrlKey}(t,e),this.dragMove=function(t,e){let i=t.state.facet(li);return i.length?i[0](e):Xe.mac?!e.altKey:!e.ctrlKey}(t,e),this.dragging=!(!function(t,e){let{main:i}=t.state.selection;if(i.empty)return!1;let s=Yt(t.root);if(0==s.rangeCount)return!0;let n=s.getRangeAt(0).getClientRects();for(let t=0;t<n.length;t++){let i=n[t];if(i.left<=e.clientX&&i.right>=e.clientX&&i.top<=e.clientY&&i.bottom>=e.clientY)return!0}return!1}(t,e)||1!=Rs(e))&&null,!1===this.dragging&&(e.preventDefault(),this.select(e))}move(t){if(0==t.buttons)return this.destroy();!1===this.dragging&&this.select(this.lastEvent=t)}up(t){null==this.dragging&&this.select(this.lastEvent),this.dragging||t.preventDefault(),this.destroy()}destroy(){let t=this.view.contentDOM.ownerDocument;t.removeEventListener("mousemove",this.move),t.removeEventListener("mouseup",this.up),this.view.inputState.mouseSelection=null}select(t){let e=this.style.get(t,this.extend,this.multiple);!this.mustSelect&&e.eq(this.view.state.selection)&&e.main.assoc==this.view.state.selection.main.assoc||this.view.dispatch({selection:e,userEvent:"select.pointer",scrollIntoView:!0}),this.mustSelect=!1}update(t){t.docChanged&&this.dragging&&(this.dragging=this.dragging.map(t.changes)),this.style.update(t)&&setTimeout((()=>this.select(this.lastEvent)),20)}}function ps(t,e){if(!e.bubbles)return!0;if(e.defaultPrevented)return!1;for(let i,s=e.target;s!=t.contentDOM;s=s.parentNode)if(!s||11==s.nodeType||(i=me.get(s))&&i.ignoreEvent(e))return!1;return!0}const gs=Object.create(null),Os=Xe.ie&&Xe.ie_version<15||Xe.ios&&Xe.webkit_version<604;function ms(t,e){let i,{state:s}=t,n=1,r=s.toText(e),o=r.lines==s.selection.ranges.length;if(null!=As&&s.selection.ranges.every((t=>t.empty))&&As==r.toString()){let t=-1;i=s.changeByRange((i=>{let h=s.doc.lineAt(i.from);if(h.from==t)return{range:i};t=h.from;let l=s.toText((o?r.line(n++).text:e)+s.lineBreak);return{changes:{from:h.from,insert:l},range:A.cursor(i.from+l.length)}}))}else i=o?s.changeByRange((t=>{let e=r.line(n++);return{changes:{from:t.from,to:t.to,insert:e.text},range:A.cursor(t.from+e.length)}})):s.replaceSelection(r);t.dispatch(i,{userEvent:"input.paste",scrollIntoView:!0})}gs.keydown=(t,e)=>{t.inputState.setSelectionOrigin("select"),27==e.keyCode?t.inputState.lastEscPress=Date.now():fs.indexOf(e.keyCode)<0&&(t.inputState.lastEscPress=0)};let bs=0;function vs(t,e,i,s){if(1==s)return A.cursor(e,i);if(2==s)return function(t,e,i=1){let s=t.charCategorizer(e),n=t.doc.lineAt(e),r=e-n.from;if(0==n.length)return A.cursor(e);0==r?i=1:r==n.length&&(i=-1);let o=r,h=r;i<0?o=f(n.text,r,!1):h=f(n.text,r);let l=s(n.text.slice(o,h));for(;o>0;){let t=f(n.text,o,!1);if(s(n.text.slice(t,o))!=l)break;o=t}for(;h<n.length;){let t=f(n.text,h);if(s(n.text.slice(h,t))!=l)break;h=t}return A.range(o+n.from,h+n.from)}(t.state,e,i);{let i=ii.find(t.docView,e),s=t.state.doc.lineAt(i?i.posAtEnd:e),n=i?i.posAtStart:s.from,r=i?i.posAtEnd:s.to;return r<t.state.doc.length&&r==s.to&&r++,A.range(n,r)}}gs.touchstart=(t,e)=>{bs=Date.now(),t.inputState.setSelectionOrigin("select.pointer")},gs.touchmove=t=>{t.inputState.setSelectionOrigin("select.pointer")},gs.mousedown=(t,e)=>{if(t.observer.flush(),bs>Date.now()-2e3&&1==Rs(e))return;let i=null;for(let s of t.state.facet(ai))if(i=s(t,e),i)break;if(i||0!=e.button||(i=function(t,e){let i=Ss(t,e),s=Rs(e),n=t.state.selection,r=i,o=e;return{update(t){t.docChanged&&(i&&(i.pos=t.changes.mapPos(i.pos)),n=n.map(t.changes),o=null)},get(e,h,l){let a;if(o&&e.clientX==o.clientX&&e.clientY==o.clientY?a=r:(a=r=Ss(t,e),o=e),!a||!i)return n;let c=vs(t,a.pos,a.bias,s);if(i.pos!=a.pos&&!h){let e=vs(t,i.pos,i.bias,s),n=Math.min(e.from,c.from),r=Math.max(e.to,c.to);c=n<c.from?A.range(n,r):A.range(r,n)}return h?n.replaceRange(n.main.extend(c.from,c.to)):l?n.addRange(c):A.create([c])}}}(t,e)),i){let s=t.root.activeElement!=t.contentDOM;s&&t.observer.ignore((()=>ue(t.contentDOM))),t.inputState.startMouseSelection(new ds(t,e,i,s))}};let ys=(t,e)=>t>=e.top&&t<=e.bottom,ws=(t,e,i)=>ys(e,i)&&t>=i.left&&t<=i.right;function xs(t,e,i,s){let n=ii.find(t.docView,e);if(!n)return 1;let r=e-n.posAtStart;if(0==r)return 1;if(r==n.length)return-1;let o=n.coordsAt(r,-1);if(o&&ws(i,s,o))return-1;let h=n.coordsAt(r,1);return h&&ws(i,s,h)?1:o&&ys(s,o)?-1:1}function Ss(t,e){let i=t.posAtCoords({x:e.clientX,y:e.clientY},!1);return{pos:i,bias:xs(t,i,e.clientX,e.clientY)}}const ks=Xe.ie&&Xe.ie_version<=11;let Ps=null,$s=0,Qs=0;function Rs(t){if(!ks)return t.detail;let e=Ps,i=Qs;return Ps=t,Qs=Date.now(),$s=!e||i>Date.now()-400&&Math.abs(e.clientX-t.clientX)<2&&Math.abs(e.clientY-t.clientY)<2?($s+1)%3:1}function qs(t,e,i,s){if(!i)return;let n=t.posAtCoords({x:e.clientX,y:e.clientY},!1);e.preventDefault();let{mouseSelection:r}=t.inputState,o=s&&r&&r.dragging&&r.dragMove?{from:r.dragging.from,to:r.dragging.to}:null,h={from:n,insert:i},l=t.state.changes(o?[o,h]:h);t.focus(),t.dispatch({changes:l,selection:{anchor:l.mapPos(n,-1),head:l.mapPos(n,1)},userEvent:o?"move.drop":"input.drop"})}gs.dragstart=(t,e)=>{let{selection:{main:i}}=t.state,{mouseSelection:s}=t.inputState;s&&(s.dragging=i),e.dataTransfer&&(e.dataTransfer.setData("Text",t.state.sliceDoc(i.from,i.to)),e.dataTransfer.effectAllowed="copyMove")},gs.drop=(t,e)=>{if(!e.dataTransfer)return;if(t.state.readOnly)return e.preventDefault();let i=e.dataTransfer.files;if(i&&i.length){e.preventDefault();let s=Array(i.length),n=0,r=()=>{++n==i.length&&qs(t,e,s.filter((t=>null!=t)).join(t.state.lineBreak),!1)};for(let t=0;t<i.length;t++){let e=new FileReader;e.onerror=r,e.onload=()=>{/[\x00-\x08\x0e-\x1f]{2}/.test(e.result)||(s[t]=e.result),r()},e.readAsText(i[t])}}else qs(t,e,e.dataTransfer.getData("Text"),!0)},gs.paste=(t,e)=>{if(t.state.readOnly)return e.preventDefault();t.observer.flush();let i=Os?null:e.clipboardData;i?(ms(t,i.getData("text/plain")),e.preventDefault()):function(t){let e=t.dom.parentNode;if(!e)return;let i=e.appendChild(document.createElement("textarea"));i.style.cssText="position: fixed; left: -10000px; top: 10px",i.focus(),setTimeout((()=>{t.focus(),i.remove(),ms(t,i.value)}),50)}(t)};let As=null;function Ts(t){setTimeout((()=>{t.hasFocus!=t.inputState.notifiedFocused&&t.update([])}),10)}function Cs(t,e){if(t.docView.compositionDeco.size){t.inputState.rapidCompositionStart=e;try{t.update([])}finally{t.inputState.rapidCompositionStart=!1}}}gs.copy=gs.cut=(t,e)=>{let{text:i,ranges:s,linewise:n}=function(t){let e=[],i=[],s=!1;for(let s of t.selection.ranges)s.empty||(e.push(t.sliceDoc(s.from,s.to)),i.push(s));if(!e.length){let n=-1;for(let{from:s}of t.selection.ranges){let r=t.doc.lineAt(s);r.number>n&&(e.push(r.text),i.push({from:r.from,to:Math.min(t.doc.length,r.to+1)})),n=r.number}s=!0}return{text:e.join(t.lineBreak),ranges:i,linewise:s}}(t.state);if(!i&&!n)return;As=n?i:null;let r=Os?null:e.clipboardData;r?(e.preventDefault(),r.clearData(),r.setData("text/plain",i)):function(t,e){let i=t.dom.parentNode;if(!i)return;let s=i.appendChild(document.createElement("textarea"));s.style.cssText="position: fixed; left: -10000px; top: 10px",s.value=e,s.focus(),s.selectionEnd=e.length,s.selectionStart=0,setTimeout((()=>{s.remove(),t.focus()}),50)}(t,i),"cut"!=e.type||t.state.readOnly||t.dispatch({changes:s,scrollIntoView:!0,userEvent:"delete.cut"})},gs.focus=Ts,gs.blur=t=>{t.observer.clearSelectionRange(),Ts(t)},gs.compositionstart=gs.compositionupdate=t=>{null==t.inputState.compositionFirstChange&&(t.inputState.compositionFirstChange=!0),t.inputState.composing<0&&(t.inputState.composing=0,t.docView.compositionDeco.size&&(t.observer.flush(),Cs(t,!0)))},gs.compositionend=t=>{t.inputState.composing=-1,t.inputState.compositionEndedAt=Date.now(),t.inputState.compositionFirstChange=null,setTimeout((()=>{t.inputState.composing<0&&Cs(t,!1)}),50)},gs.contextmenu=t=>{t.inputState.lastContextMenu=Date.now()},gs.beforeinput=(t,e)=>{var i;let s;if(Xe.chrome&&Xe.android&&(s=us.find((t=>t.inputType==e.inputType)))&&(t.observer.delayAndroidKey(s.key,s.keyCode),"Backspace"==s.key||"Delete"==s.key)){let e=(null===(i=window.visualViewport)||void 0===i?void 0:i.height)||0;setTimeout((()=>{var i;((null===(i=window.visualViewport)||void 0===i?void 0:i.height)||0)>e+10&&t.hasFocus&&(t.contentDOM.blur(),t.focus())}),100)}};const Xs=["pre-wrap","normal","pre-line","break-spaces"];class Ms{constructor(){this.doc=t.empty,this.lineWrapping=!1,this.heightSamples={},this.lineHeight=14,this.charWidth=7,this.lineLength=30,this.heightChanged=!1}heightForGap(t,e){let i=this.doc.lineAt(e).number-this.doc.lineAt(t).number+1;return this.lineWrapping&&(i+=Math.ceil((e-t-i*this.lineLength*.5)/this.lineLength)),this.lineHeight*i}heightForLine(t){if(!this.lineWrapping)return this.lineHeight;return(1+Math.max(0,Math.ceil((t-this.lineLength)/(this.lineLength-5))))*this.lineHeight}setDoc(t){return this.doc=t,this}mustRefreshForWrapping(t){return Xs.indexOf(t)>-1!=this.lineWrapping}mustRefreshForHeights(t){let e=!1;for(let i=0;i<t.length;i++){let s=t[i];s<0?i++:this.heightSamples[Math.floor(10*s)]||(e=!0,this.heightSamples[Math.floor(10*s)]=!0)}return e}refresh(t,e,i,s,n){let r=Xs.indexOf(t)>-1,o=Math.round(e)!=Math.round(this.lineHeight)||this.lineWrapping!=r;if(this.lineWrapping=r,this.lineHeight=e,this.charWidth=i,this.lineLength=s,o){this.heightSamples={};for(let t=0;t<n.length;t++){let e=n[t];e<0?t++:this.heightSamples[Math.floor(10*e)]=!0}}return o}}class Ds{constructor(t,e){this.from=t,this.heights=e,this.index=0}get more(){return this.index<this.heights.length}}class Es{constructor(t,e,i,s,n){this.from=t,this.length=e,this.top=i,this.height=s,this.type=n}get to(){return this.from+this.length}get bottom(){return this.top+this.height}join(t){let e=(Array.isArray(this.type)?this.type:[this]).concat(Array.isArray(t.type)?t.type:[t]);return new Es(this.from,this.length+t.length,this.top,this.height+t.height,e)}}var Ns=function(t){return t[t.ByPos=0]="ByPos",t[t.ByHeight=1]="ByHeight",t[t.ByPosNoHeight=2]="ByPosNoHeight",t}(Ns||(Ns={}));class _s{constructor(t,e,i=2){this.length=t,this.height=e,this.flags=i}get outdated(){return(2&this.flags)>0}set outdated(t){this.flags=(t?2:0)|-3&this.flags}setHeight(t,e){this.height!=e&&(Math.abs(this.height-e)>.001&&(t.heightChanged=!0),this.height=e)}replace(t,e,i){return _s.of(i)}decomposeLeft(t,e){e.push(this)}decomposeRight(t,e){e.push(this)}applyChanges(t,e,i,s){let n=this;for(let r=s.length-1;r>=0;r--){let{fromA:o,toA:h,fromB:l,toB:a}=s[r],c=n.lineAt(o,Ns.ByPosNoHeight,e,0,0),u=c.to>=h?c:n.lineAt(h,Ns.ByPosNoHeight,e,0,0);for(a+=u.to-h,h=u.to;r>0&&c.from<=s[r-1].toA;)o=s[r-1].fromA,l=s[r-1].fromB,r--,o<c.from&&(c=n.lineAt(o,Ns.ByPosNoHeight,e,0,0));l+=c.from-o,o=c.from;let f=Is.build(i,t,l,a);n=n.replace(o,h,f)}return n.updateHeight(i,0)}static empty(){return new Vs(0,0)}static of(t){if(1==t.length)return t[0];let e=0,i=t.length,s=0,n=0;for(;;)if(e==i)if(s>2*n){let n=t[e-1];n.break?t.splice(--e,1,n.left,null,n.right):t.splice(--e,1,n.left,n.right),i+=1+n.break,s-=n.size}else{if(!(n>2*s))break;{let e=t[i];e.break?t.splice(i,1,e.left,null,e.right):t.splice(i,1,e.left,e.right),i+=2+e.break,n-=e.size}}else if(s<n){let i=t[e++];i&&(s+=i.size)}else{let e=t[--i];e&&(n+=e.size)}let r=0;return null==t[e-1]?(r=1,e--):null==t[e]&&(r=1,i++),new zs(_s.of(t.slice(0,e)),r,_s.of(t.slice(i)))}}_s.prototype.size=1;class Bs extends _s{constructor(t,e,i){super(t,e),this.type=i}blockAt(t,e,i,s){return new Es(s,this.length,i,this.height,this.type)}lineAt(t,e,i,s,n){return this.blockAt(0,i,s,n)}forEachLine(t,e,i,s,n,r){t<=n+this.length&&e>=n&&r(this.blockAt(0,i,s,n))}updateHeight(t,e=0,i=!1,s){return s&&s.from<=e&&s.more&&this.setHeight(t,s.heights[s.index++]),this.outdated=!1,this}toString(){return`block(${this.length})`}}class Vs extends Bs{constructor(t,e){super(t,e,Ze.Text),this.collapsed=0,this.widgetHeight=0}replace(t,e,i){let s=i[0];return 1==i.length&&(s instanceof Vs||s instanceof js&&4&s.flags)&&Math.abs(this.length-s.length)<10?(s instanceof js?s=new Vs(s.length,this.height):s.height=this.height,this.outdated||(s.outdated=!1),s):_s.of(i)}updateHeight(t,e=0,i=!1,s){return s&&s.from<=e&&s.more?this.setHeight(t,s.heights[s.index++]):(i||this.outdated)&&this.setHeight(t,Math.max(this.widgetHeight,t.heightForLine(this.length-this.collapsed))),this.outdated=!1,this}toString(){return`line(${this.length}${this.collapsed?-this.collapsed:""}${this.widgetHeight?":"+this.widgetHeight:""})`}}class js extends _s{constructor(t){super(t,0)}lines(t,e){let i=t.lineAt(e).number,s=t.lineAt(e+this.length).number;return{firstLine:i,lastLine:s,lineHeight:this.height/(s-i+1)}}blockAt(t,e,i,s){let{firstLine:n,lastLine:r,lineHeight:o}=this.lines(e,s),h=Math.max(0,Math.min(r-n,Math.floor((t-i)/o))),{from:l,length:a}=e.line(n+h);return new Es(l,a,i+o*h,o,Ze.Text)}lineAt(t,e,i,s,n){if(e==Ns.ByHeight)return this.blockAt(t,i,s,n);if(e==Ns.ByPosNoHeight){let{from:e,to:s}=i.lineAt(t);return new Es(e,s-e,0,0,Ze.Text)}let{firstLine:r,lineHeight:o}=this.lines(i,n),{from:h,length:l,number:a}=i.lineAt(t);return new Es(h,l,s+o*(a-r),o,Ze.Text)}forEachLine(t,e,i,s,n,r){let{firstLine:o,lineHeight:h}=this.lines(i,n);for(let l=Math.max(t,n),a=Math.min(n+this.length,e);l<=a;){let e=i.lineAt(l);l==t&&(s+=h*(e.number-o)),r(new Es(e.from,e.length,s,h,Ze.Text)),s+=h,l=e.to+1}}replace(t,e,i){let s=this.length-e;if(s>0){let t=i[i.length-1];t instanceof js?i[i.length-1]=new js(t.length+s):i.push(null,new js(s-1))}if(t>0){let e=i[0];e instanceof js?i[0]=new js(t+e.length):i.unshift(new js(t-1),null)}return _s.of(i)}decomposeLeft(t,e){e.push(new js(t-1),null)}decomposeRight(t,e){e.push(null,new js(this.length-t-1))}updateHeight(t,e=0,i=!1,s){let n=e+this.length;if(s&&s.from<=e+this.length&&s.more){let i=[],r=Math.max(e,s.from),o=-1,h=t.heightChanged;for(s.from>e&&i.push(new js(s.from-e-1).updateHeight(t,e));r<=n&&s.more;){let e=t.doc.lineAt(r).length;i.length&&i.push(null);let n=s.heights[s.index++];-1==o?o=n:Math.abs(n-o)>=.001&&(o=-2);let h=new Vs(e,n);h.outdated=!1,i.push(h),r+=e+1}r<=n&&i.push(null,new js(n-r).updateHeight(t,r));let l=_s.of(i);return t.heightChanged=h||o<0||Math.abs(l.height-this.height)>=.001||Math.abs(o-this.lines(t.doc,e).lineHeight)>=.001,l}return(i||this.outdated)&&(this.setHeight(t,t.heightForGap(e,e+this.length)),this.outdated=!1),this}toString(){return`gap(${this.length})`}}class zs extends _s{constructor(t,e,i){super(t.length+e+i.length,t.height+i.height,e|(t.outdated||i.outdated?2:0)),this.left=t,this.right=i,this.size=t.size+i.size}get break(){return 1&this.flags}blockAt(t,e,i,s){let n=i+this.left.height;return t<n?this.left.blockAt(t,e,i,s):this.right.blockAt(t,e,n,s+this.left.length+this.break)}lineAt(t,e,i,s,n){let r=s+this.left.height,o=n+this.left.length+this.break,h=e==Ns.ByHeight?t<r:t<o,l=h?this.left.lineAt(t,e,i,s,n):this.right.lineAt(t,e,i,r,o);if(this.break||(h?l.to<o:l.from>o))return l;let a=e==Ns.ByPosNoHeight?Ns.ByPosNoHeight:Ns.ByPos;return h?l.join(this.right.lineAt(o,a,i,r,o)):this.left.lineAt(o,a,i,s,n).join(l)}forEachLine(t,e,i,s,n,r){let o=s+this.left.height,h=n+this.left.length+this.break;if(this.break)t<h&&this.left.forEachLine(t,e,i,s,n,r),e>=h&&this.right.forEachLine(t,e,i,o,h,r);else{let l=this.lineAt(h,Ns.ByPos,i,s,n);t<l.from&&this.left.forEachLine(t,l.from-1,i,s,n,r),l.to>=t&&l.from<=e&&r(l),e>l.to&&this.right.forEachLine(l.to+1,e,i,o,h,r)}}replace(t,e,i){let s=this.left.length+this.break;if(e<s)return this.balanced(this.left.replace(t,e,i),this.right);if(t>this.left.length)return this.balanced(this.left,this.right.replace(t-s,e-s,i));let n=[];t>0&&this.decomposeLeft(t,n);let r=n.length;for(let t of i)n.push(t);if(t>0&&Ws(n,r-1),e<this.length){let t=n.length;this.decomposeRight(e,n),Ws(n,t)}return _s.of(n)}decomposeLeft(t,e){let i=this.left.length;if(t<=i)return this.left.decomposeLeft(t,e);e.push(this.left),this.break&&(i++,t>=i&&e.push(null)),t>i&&this.right.decomposeLeft(t-i,e)}decomposeRight(t,e){let i=this.left.length,s=i+this.break;if(t>=s)return this.right.decomposeRight(t-s,e);t<i&&this.left.decomposeRight(t,e),this.break&&t<s&&e.push(null),e.push(this.right)}balanced(t,e){return t.size>2*e.size||e.size>2*t.size?_s.of(this.break?[t,null,e]:[t,e]):(this.left=t,this.right=e,this.height=t.height+e.height,this.outdated=t.outdated||e.outdated,this.size=t.size+e.size,this.length=t.length+this.break+e.length,this)}updateHeight(t,e=0,i=!1,s){let{left:n,right:r}=this,o=e+n.length+this.break,h=null;return s&&s.from<=e+n.length&&s.more?h=n=n.updateHeight(t,e,i,s):n.updateHeight(t,e,i),s&&s.from<=o+r.length&&s.more?h=r=r.updateHeight(t,o,i,s):r.updateHeight(t,o,i),h?this.balanced(n,r):(this.height=this.left.height+this.right.height,this.outdated=!1,this)}toString(){return this.left+(this.break?" ":"-")+this.right}}function Ws(t,e){let i,s;null==t[e]&&(i=t[e-1])instanceof js&&(s=t[e+1])instanceof js&&t.splice(e-1,3,new js(i.length+1+s.length))}class Is{constructor(t,e){this.pos=t,this.oracle=e,this.nodes=[],this.lineStart=-1,this.lineEnd=-1,this.covering=null,this.writtenTo=t}get isCovered(){return this.covering&&this.nodes[this.nodes.length-1]==this.covering}span(t,e){if(this.lineStart>-1){let t=Math.min(e,this.lineEnd),i=this.nodes[this.nodes.length-1];i instanceof Vs?i.length+=t-this.pos:(t>this.pos||!this.isCovered)&&this.nodes.push(new Vs(t-this.pos,-1)),this.writtenTo=t,e>t&&(this.nodes.push(null),this.writtenTo++,this.lineStart=-1)}this.pos=e}point(t,e,i){if(t<e||i.heightRelevant){let s=i.widget?i.widget.estimatedHeight:0;s<0&&(s=this.oracle.lineHeight);let n=e-t;i.block?this.addBlock(new Bs(n,s,i.type)):(n||s>=5)&&this.addLineDeco(s,n)}else e>t&&this.span(t,e);this.lineEnd>-1&&this.lineEnd<this.pos&&(this.lineEnd=this.oracle.doc.lineAt(this.pos).to)}enterLine(){if(this.lineStart>-1)return;let{from:t,to:e}=this.oracle.doc.lineAt(this.pos);this.lineStart=t,this.lineEnd=e,this.writtenTo<t&&((this.writtenTo<t-1||null==this.nodes[this.nodes.length-1])&&this.nodes.push(this.blankContent(this.writtenTo,t-1)),this.nodes.push(null)),this.pos>t&&this.nodes.push(new Vs(this.pos-t,-1)),this.writtenTo=this.pos}blankContent(t,e){let i=new js(e-t);return this.oracle.doc.lineAt(t).to==e&&(i.flags|=4),i}ensureLine(){this.enterLine();let t=this.nodes.length?this.nodes[this.nodes.length-1]:null;if(t instanceof Vs)return t;let e=new Vs(0,-1);return this.nodes.push(e),e}addBlock(t){this.enterLine(),t.type!=Ze.WidgetAfter||this.isCovered||this.ensureLine(),this.nodes.push(t),this.writtenTo=this.pos=this.pos+t.length,t.type!=Ze.WidgetBefore&&(this.covering=t)}addLineDeco(t,e){let i=this.ensureLine();i.length+=e,i.collapsed+=e,i.widgetHeight=Math.max(i.widgetHeight,t),this.writtenTo=this.pos=this.pos+e}finish(t){let e=0==this.nodes.length?null:this.nodes[this.nodes.length-1];!(this.lineStart>-1)||e instanceof Vs||this.isCovered?(this.writtenTo<this.pos||null==e)&&this.nodes.push(this.blankContent(this.writtenTo,this.pos)):this.nodes.push(new Vs(0,-1));let i=t;for(let t of this.nodes)t instanceof Vs&&t.updateHeight(this.oracle,i),i+=t?t.length:1;return this.nodes}static build(t,e,i,s){let n=new Is(i,t);return Qt.spans(e,i,s,n,0),n.finish(i)}}class Ls{constructor(){this.changes=[]}compareRange(){}comparePoint(t,e,i,s){(t<e||i&&i.heightRelevant||s&&s.heightRelevant)&&ei(t,e,this.changes,5)}}function Fs(t,e){let i=t.getBoundingClientRect(),s=Math.max(0,i.left),n=Math.min(innerWidth,i.right),r=Math.max(0,i.top),o=Math.min(innerHeight,i.bottom),h=t.ownerDocument.body;for(let e=t.parentNode;e&&e!=h;)if(1==e.nodeType){let t=e,i=window.getComputedStyle(t);if((t.scrollHeight>t.clientHeight||t.scrollWidth>t.clientWidth)&&"visible"!=i.overflow){let e=t.getBoundingClientRect();s=Math.max(s,e.left),n=Math.min(n,e.right),r=Math.max(r,e.top),o=Math.min(o,e.bottom)}e="absolute"==i.position||"fixed"==i.position?t.offsetParent:t.parentNode}else{if(11!=e.nodeType)break;e=e.host}return{left:s-i.left,right:Math.max(s,n)-i.left,top:r-(i.top+e),bottom:Math.max(r,o)-(i.top+e)}}function Hs(t,e){let i=t.getBoundingClientRect();return{left:0,right:i.right-i.left,top:e,bottom:i.bottom-(i.top+e)}}class Gs{constructor(t,e,i){this.from=t,this.to=e,this.size=i}static same(t,e){if(t.length!=e.length)return!1;for(let i=0;i<t.length;i++){let s=t[i],n=e[i];if(s.from!=n.from||s.to!=n.to||s.size!=n.size)return!1}return!0}draw(t){return Ue.replace({widget:new Zs(this.size,t)}).range(this.from,this.to)}}class Zs extends Ge{constructor(t,e){super(),this.size=t,this.vertical=e}eq(t){return t.size==this.size&&t.vertical==this.vertical}toDOM(){let t=document.createElement("div");return this.vertical?t.style.height=this.size+"px":(t.style.width=this.size+"px",t.style.height="2px",t.style.display="inline-block"),t}get estimatedHeight(){return this.vertical?this.size:-1}}class Us{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.heightOracle=new Ms,this.scaler=nn,this.scrollTarget=null,this.printing=!1,this.mustMeasureContent=!0,this.defaultTextDirection=Ai.RTL,this.visibleRanges=[],this.mustEnforceCursorAssoc=!1,this.stateDeco=e.facet(ki).filter((t=>"function"!=typeof t)),this.heightMap=_s.empty().applyChanges(this.stateDeco,t.empty,this.heightOracle.setDoc(e.doc),[new Ri(0,0,0,e.doc.length)]),this.viewport=this.getViewport(0,null),this.updateViewportLines(),this.updateForViewport(),this.lineGaps=this.ensureLineGaps([]),this.lineGapDeco=Ue.set(this.lineGaps.map((t=>t.draw(!1)))),this.computeVisibleRanges()}updateForViewport(){let t=[this.viewport],{main:e}=this.state.selection;for(let i=0;i<=1;i++){let s=i?e.head:e.anchor;if(!t.some((({from:t,to:e})=>s>=t&&s<=e))){let{from:e,to:i}=this.lineBlockAt(s);t.push(new Ys(e,i))}}this.viewports=t.sort(((t,e)=>t.from-e.from)),this.scaler=this.heightMap.height<=7e6?nn:new rn(this.heightOracle.doc,this.heightMap,this.viewports)}updateViewportLines(){this.viewportLines=[],this.heightMap.forEachLine(this.viewport.from,this.viewport.to,this.state.doc,0,0,(t=>{this.viewportLines.push(1==this.scaler.scale?t:on(t,this.scaler))}))}update(t,e=null){this.state=t.state;let i=this.stateDeco;this.stateDeco=this.state.facet(ki).filter((t=>"function"!=typeof t));let s=t.changedRanges,n=Ri.extendWithRanges(s,function(t,e,i){let s=new Ls;return Qt.compare(t,e,i,s,0),s.changes}(i,this.stateDeco,t?t.changes:x.empty(this.state.doc.length))),r=this.heightMap.height;this.heightMap=this.heightMap.applyChanges(this.stateDeco,t.startState.doc,this.heightOracle.setDoc(this.state.doc),n),this.heightMap.height!=r&&(t.flags|=2);let o=n.length?this.mapViewport(this.viewport,t.changes):this.viewport;(e&&(e.range.head<o.from||e.range.head>o.to)||!this.viewportIsAppropriate(o))&&(o=this.getViewport(0,e));let h=!t.changes.empty||2&t.flags||o.from!=this.viewport.from||o.to!=this.viewport.to;this.viewport=o,this.updateForViewport(),h&&this.updateViewportLines(),(this.lineGaps.length||this.viewport.to-this.viewport.from>4e3)&&this.updateLineGaps(this.ensureLineGaps(this.mapLineGaps(this.lineGaps,t.changes))),t.flags|=this.computeVisibleRanges(),e&&(this.scrollTarget=e),!this.mustEnforceCursorAssoc&&t.selectionSet&&t.view.lineWrapping&&t.state.selection.main.empty&&t.state.selection.main.assoc&&(this.mustEnforceCursorAssoc=!0)}measure(t){let e=t.contentDOM,i=window.getComputedStyle(e),s=this.heightOracle,n=i.whiteSpace;this.defaultTextDirection="rtl"==i.direction?Ai.RTL:Ai.LTR;let r=this.heightOracle.mustRefreshForWrapping(n),o=r||this.mustMeasureContent||this.contentDOMHeight!=e.clientHeight,h=0,l=0;if(this.editorWidth!=t.scrollDOM.clientWidth&&(s.lineWrapping&&(o=!0),this.editorWidth=t.scrollDOM.clientWidth,h|=8),o){this.mustMeasureContent=!1,this.contentDOMHeight=e.clientHeight;let t=parseInt(i.paddingTop)||0,s=parseInt(i.paddingBottom)||0;this.paddingTop==t&&this.paddingBottom==s||(h|=8,this.paddingTop=t,this.paddingBottom=s)}let a=(this.printing?Hs:Fs)(e,this.paddingTop),c=a.top-this.pixelViewport.top,u=a.bottom-this.pixelViewport.bottom;this.pixelViewport=a;let f=this.pixelViewport.bottom>this.pixelViewport.top&&this.pixelViewport.right>this.pixelViewport.left;if(f!=this.inView&&(this.inView=f,f&&(o=!0)),!this.inView)return 0;let d=e.clientWidth;if(this.contentDOMWidth==d&&this.editorHeight==t.scrollDOM.clientHeight||(this.contentDOMWidth=d,this.editorHeight=t.scrollDOM.clientHeight,h|=8),o){let e=t.docView.measureVisibleLineHeights(this.viewport);if(s.mustRefreshForHeights(e)&&(r=!0),r||s.lineWrapping&&Math.abs(d-this.contentDOMWidth)>s.charWidth){let{lineHeight:i,charWidth:o}=t.docView.measureTextSize();r=s.refresh(n,i,o,d/o,e),r&&(t.docView.minWidth=0,h|=8)}c>0&&u>0?l=Math.max(c,u):c<0&&u<0&&(l=Math.min(c,u)),s.heightChanged=!1;for(let i of this.viewports){let n=i.from==this.viewport.from?e:t.docView.measureVisibleLineHeights(i);this.heightMap=this.heightMap.updateHeight(s,0,r,new Ds(i.from,n))}s.heightChanged&&(h|=2)}let p=!this.viewportIsAppropriate(this.viewport,l)||this.scrollTarget&&(this.scrollTarget.range.head<this.viewport.from||this.scrollTarget.range.head>this.viewport.to);return p&&(this.viewport=this.getViewport(l,this.scrollTarget)),this.updateForViewport(),(2&h||p)&&this.updateViewportLines(),(this.lineGaps.length||this.viewport.to-this.viewport.from>4e3)&&this.updateLineGaps(this.ensureLineGaps(r?[]:this.lineGaps)),h|=this.computeVisibleRanges(),this.mustEnforceCursorAssoc&&(this.mustEnforceCursorAssoc=!1,t.docView.enforceCursorAssoc()),h}get visibleTop(){return this.scaler.fromDOM(this.pixelViewport.top)}get visibleBottom(){return this.scaler.fromDOM(this.pixelViewport.bottom)}getViewport(t,e){let i=.5-Math.max(-.5,Math.min(.5,t/1e3/2)),s=this.heightMap,n=this.state.doc,{visibleTop:r,visibleBottom:o}=this,h=new Ys(s.lineAt(r-1e3*i,Ns.ByHeight,n,0,0).from,s.lineAt(o+1e3*(1-i),Ns.ByHeight,n,0,0).to);if(e){let{head:t}=e.range;if(t<h.from||t>h.to){let i,r=Math.min(this.editorHeight,this.pixelViewport.bottom-this.pixelViewport.top),o=s.lineAt(t,Ns.ByPos,n,0,0);i="center"==e.y?(o.top+o.bottom)/2-r/2:"start"==e.y||"nearest"==e.y&&t<h.from?o.top:o.bottom-r,h=new Ys(s.lineAt(i-500,Ns.ByHeight,n,0,0).from,s.lineAt(i+r+500,Ns.ByHeight,n,0,0).to)}}return h}mapViewport(t,e){let i=e.mapPos(t.from,-1),s=e.mapPos(t.to,1);return new Ys(this.heightMap.lineAt(i,Ns.ByPos,this.state.doc,0,0).from,this.heightMap.lineAt(s,Ns.ByPos,this.state.doc,0,0).to)}viewportIsAppropriate({from:t,to:e},i=0){if(!this.inView)return!0;let{top:s}=this.heightMap.lineAt(t,Ns.ByPos,this.state.doc,0,0),{bottom:n}=this.heightMap.lineAt(e,Ns.ByPos,this.state.doc,0,0),{visibleTop:r,visibleBottom:o}=this;return(0==t||s<=r-Math.max(10,Math.min(-i,250)))&&(e==this.state.doc.length||n>=o+Math.max(10,Math.min(i,250)))&&s>r-2e3&&n<o+2e3}mapLineGaps(t,e){if(!t.length||e.empty)return t;let i=[];for(let s of t)e.touchesRange(s.from,s.to)||i.push(new Gs(e.mapPos(s.from),e.mapPos(s.to),s.size));return i}ensureLineGaps(t){let e=[];if(this.defaultTextDirection!=Ai.LTR)return e;for(let i of this.viewportLines){if(i.length<4e3)continue;let s,n,r=Ks(i.from,i.to,this.stateDeco);if(r.total<4e3)continue;if(this.heightOracle.lineWrapping){let t=2e3/this.heightOracle.lineLength*this.heightOracle.lineHeight;s=Js(r,(this.visibleTop-i.top-t)/i.height),n=Js(r,(this.visibleBottom-i.top+t)/i.height)}else{let t=r.total*this.heightOracle.charWidth,e=2e3*this.heightOracle.charWidth;s=Js(r,(this.pixelViewport.left-e)/t),n=Js(r,(this.pixelViewport.right+e)/t)}let o=[];s>i.from&&o.push({from:i.from,to:s}),n<i.to&&o.push({from:n,to:i.to});let h=this.state.selection.main;h.from>=i.from&&h.from<=i.to&&en(o,h.from-10,h.from+10),!h.empty&&h.to>=i.from&&h.to<=i.to&&en(o,h.to-10,h.to+10);for(let{from:s,to:n}of o)n-s>1e3&&e.push(sn(t,(t=>t.from>=i.from&&t.to<=i.to&&Math.abs(t.from-s)<1e3&&Math.abs(t.to-n)<1e3))||new Gs(s,n,this.gapSize(i,s,n,r)))}return e}gapSize(t,e,i,s){let n=tn(s,i)-tn(s,e);return this.heightOracle.lineWrapping?t.height*n:s.total*this.heightOracle.charWidth*n}updateLineGaps(t){Gs.same(t,this.lineGaps)||(this.lineGaps=t,this.lineGapDeco=Ue.set(t.map((t=>t.draw(this.heightOracle.lineWrapping)))))}computeVisibleRanges(){let t=this.stateDeco;this.lineGaps.length&&(t=t.concat(this.lineGapDeco));let e=[];Qt.spans(t,this.viewport.from,this.viewport.to,{span(t,i){e.push({from:t,to:i})},point(){}},20);let i=e.length!=this.visibleRanges.length||this.visibleRanges.some(((t,i)=>t.from!=e[i].from||t.to!=e[i].to));return this.visibleRanges=e,i?4:0}lineBlockAt(t){return t>=this.viewport.from&&t<=this.viewport.to&&this.viewportLines.find((e=>e.from<=t&&e.to>=t))||on(this.heightMap.lineAt(t,Ns.ByPos,this.state.doc,0,0),this.scaler)}lineBlockAtHeight(t){return on(this.heightMap.lineAt(this.scaler.fromDOM(t),Ns.ByHeight,this.state.doc,0,0),this.scaler)}elementAtHeight(t){return on(this.heightMap.blockAt(this.scaler.fromDOM(t),this.state.doc,0,0),this.scaler)}get docHeight(){return this.scaler.toDOM(this.heightMap.height)}get contentHeight(){return this.docHeight+this.paddingTop+this.paddingBottom}}class Ys{constructor(t,e){this.from=t,this.to=e}}function Ks(t,e,i){let s=[],n=t,r=0;return Qt.spans(i,t,e,{span(){},point(t,e){t>n&&(s.push({from:n,to:t}),r+=t-n),n=e}},20),n<e&&(s.push({from:n,to:e}),r+=e-n),{total:r,ranges:s}}function Js({total:t,ranges:e},i){if(i<=0)return e[0].from;if(i>=1)return e[e.length-1].to;let s=Math.floor(t*i);for(let t=0;;t++){let{from:i,to:n}=e[t],r=n-i;if(s<=r)return i+s;s-=r}}function tn(t,e){let i=0;for(let{from:s,to:n}of t.ranges){if(e<=n){i+=e-s;break}i+=n-s}return i/t.total}function en(t,e,i){for(let s=0;s<t.length;s++){let n=t[s];if(n.from<i&&n.to>e){let r=[];n.from<e&&r.push({from:n.from,to:e}),n.to>i&&r.push({from:i,to:n.to}),t.splice(s,1,...r),s+=r.length-1}}}function sn(t,e){for(let i of t)if(e(i))return i}const nn={toDOM:t=>t,fromDOM:t=>t,scale:1};class rn{constructor(t,e,i){let s=0,n=0,r=0;this.viewports=i.map((({from:i,to:n})=>{let r=e.lineAt(i,Ns.ByPos,t,0,0).top,o=e.lineAt(n,Ns.ByPos,t,0,0).bottom;return s+=o-r,{from:i,to:n,top:r,bottom:o,domTop:0,domBottom:0}})),this.scale=(7e6-s)/(e.height-s);for(let t of this.viewports)t.domTop=r+(t.top-n)*this.scale,r=t.domBottom=t.domTop+(t.bottom-t.top),n=t.bottom}toDOM(t){for(let e=0,i=0,s=0;;e++){let n=e<this.viewports.length?this.viewports[e]:null;if(!n||t<n.top)return s+(t-i)*this.scale;if(t<=n.bottom)return n.domTop+(t-n.top);i=n.bottom,s=n.domBottom}}fromDOM(t){for(let e=0,i=0,s=0;;e++){let n=e<this.viewports.length?this.viewports[e]:null;if(!n||t<n.domTop)return i+(t-s)/this.scale;if(t<=n.domBottom)return n.top+(t-n.domTop);i=n.bottom,s=n.domBottom}}}function on(t,e){if(1==e.scale)return t;let i=e.toDOM(t.top),s=e.toDOM(t.bottom);return new Es(t.from,t.length,i,s-i,Array.isArray(t.type)?t.type.map((t=>on(t,e))):t.type)}const hn=M.define({combine:t=>t.join(" ")}),ln=M.define({combine:t=>t.indexOf(!0)>-1}),an=zt.newName(),cn=zt.newName(),un=zt.newName(),fn={"&light":"."+cn,"&dark":"."+un};function dn(t,e,i){return new zt(e,{finish:e=>/&/.test(e)?e.replace(/&\w*/,(e=>{if("&"==e)return t;if(!i||!i[e])throw new RangeError(`Unsupported selector: ${e}`);return i[e]})):t+" "+e})}const pn=dn("."+an,{"&.cm-editor":{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},".cm-content":{margin:0,flexGrow:2,minHeight:"100%",display:"block",whiteSpace:"pre",wordWrap:"normal",boxSizing:"border-box",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"},"&light .cm-content":{caretColor:"black"},"&dark .cm-content":{caretColor:"white"},".cm-line":{display:"block",padding:"0 2px 0 4px"},".cm-selectionLayer":{zIndex:-1,contain:"size style"},".cm-selectionBackground":{position:"absolute"},"&light .cm-selectionBackground":{background:"#d9d9d9"},"&dark .cm-selectionBackground":{background:"#222"},"&light.cm-focused .cm-selectionBackground":{background:"#d7d4f0"},"&dark.cm-focused .cm-selectionBackground":{background:"#233"},".cm-cursorLayer":{zIndex:100,contain:"size style",pointerEvents:"none"},"&.cm-focused .cm-cursorLayer":{animation:"steps(1) cm-blink 1.2s infinite"},"@keyframes cm-blink":{"0%":{},"50%":{visibility:"hidden"},"100%":{}},"@keyframes cm-blink2":{"0%":{},"50%":{visibility:"hidden"},"100%":{}},".cm-cursor, .cm-dropCursor":{position:"absolute",borderLeft:"1.2px solid black",marginLeft:"-0.6px",pointerEvents:"none"},".cm-cursor":{display:"none"},"&dark .cm-cursor":{borderLeftColor:"#444"},"&.cm-focused .cm-cursor":{display:"block"},"&light .cm-activeLine":{backgroundColor:"#f3f9ff"},"&dark .cm-activeLine":{backgroundColor:"#223039"},"&light .cm-specialChar":{color:"red"},"&dark .cm-specialChar":{color:"#f78"},".cm-gutters":{display:"flex",height:"100%",boxSizing:"border-box",left:0,zIndex:200},"&light .cm-gutters":{backgroundColor:"#f5f5f5",color:"#6c6c6c",borderRight:"1px solid #ddd"},"&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},"&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-tab":{display:"inline-block",overflow:"hidden",verticalAlign:"bottom"},".cm-widgetBuffer":{verticalAlign:"text-top",height:"1em",display:"inline"},".cm-placeholder":{color:"#888",display:"inline-block",verticalAlign:"top"},".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"}},fn),gn={childList:!0,characterData:!0,subtree:!0,attributes:!0,characterDataOldValue:!0},On=Xe.ie&&Xe.ie_version<=11;class mn{constructor(t,e,i){this.view=t,this.onChange=e,this.onScrollChanged=i,this.active=!1,this.selectionRange=new le,this.selectionChanged=!1,this.delayedFlush=-1,this.resizeTimeout=-1,this.queue=[],this.delayedAndroidKey=null,this.scrollTargets=[],this.intersection=null,this.resize=null,this.intersecting=!1,this.gapIntersection=null,this.gaps=[],this.parentCheck=-1,this.dom=t.contentDOM,this.observer=new MutationObserver((e=>{for(let t of e)this.queue.push(t);(Xe.ie&&Xe.ie_version<=11||Xe.ios&&t.composing)&&e.some((t=>"childList"==t.type&&t.removedNodes.length||"characterData"==t.type&&t.oldValue.length>t.target.nodeValue.length))?this.flushSoon():this.flush()})),On&&(this.onCharData=t=>{this.queue.push({target:t.target,type:"characterData",oldValue:t.prevValue}),this.flushSoon()}),this.onSelectionChange=this.onSelectionChange.bind(this),window.addEventListener("resize",this.onResize=this.onResize.bind(this)),"function"==typeof ResizeObserver&&(this.resize=new ResizeObserver((()=>{this.view.docView.lastUpdate<Date.now()-75&&this.onResize()})),this.resize.observe(t.scrollDOM)),window.addEventListener("beforeprint",this.onPrint=this.onPrint.bind(this)),this.start(),window.addEventListener("scroll",this.onScroll=this.onScroll.bind(this)),"function"==typeof IntersectionObserver&&(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")))}),{}),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(),this.dom.ownerDocument.addEventListener("selectionchange",this.onSelectionChange)}onScroll(t){this.intersecting&&this.flush(!1),this.onScrollChanged(t)}onResize(){this.resizeTimeout<0&&(this.resizeTimeout=setTimeout((()=>{this.resizeTimeout=-1,this.view.requestMeasure()}),50))}onPrint(){this.view.viewState.printing=!0,this.view.measure(),setTimeout((()=>{this.view.viewState.printing=!1,this.view.requestMeasure()}),500)}updateGaps(t){if(this.gapIntersection&&(t.length!=this.gaps.length||this.gaps.some(((e,i)=>e!=t[i])))){this.gapIntersection.disconnect();for(let e of t)this.gapIntersection.observe(e);this.gaps=t}}onSelectionChange(t){if(!this.readSelectionRange()||this.delayedAndroidKey)return;let{view:e}=this,i=this.selectionRange;if(e.state.facet(mi)?e.root.activeElement!=this.dom:!Jt(e.dom,i))return;let s=i.anchorNode&&e.docView.nearest(i.anchorNode);s&&s.ignoreEvent(t)||((Xe.ie&&Xe.ie_version<=11||Xe.android&&Xe.chrome)&&!e.state.selection.main.empty&&i.focusNode&&ee(i.focusNode,i.focusOffset,i.anchorNode,i.anchorOffset)?this.flushSoon():this.flush(!1))}readSelectionRange(){let{root:t}=this.view,e=Yt(t),i=Xe.safari&&11==t.nodeType&&function(){let t=document.activeElement;for(;t&&t.shadowRoot;)t=t.shadowRoot.activeElement;return t}()==this.view.contentDOM&&function(t){let e=null;function i(t){t.preventDefault(),t.stopImmediatePropagation(),e=t.getTargetRanges()[0]}if(t.contentDOM.addEventListener("beforeinput",i,!0),document.execCommand("indent"),t.contentDOM.removeEventListener("beforeinput",i,!0),!e)return null;let s=e.startContainer,n=e.startOffset,r=e.endContainer,o=e.endOffset,h=t.docView.domAtPos(t.state.selection.main.anchor);ee(h.node,h.offset,r,o)&&([s,n,r,o]=[r,o,s,n]);return{anchorNode:s,anchorOffset:n,focusNode:r,focusOffset:o}}(this.view)||e;return!this.selectionRange.eq(i)&&(this.selectionRange.setRange(i),this.selectionChanged=!0)}setSelectionRange(t,e){this.selectionRange.set(t.node,t.offset,e.node,e.offset),this.selectionChanged=!1}clearSelectionRange(){this.selectionRange.set(null,0,null,0)}listenForScroll(){this.parentCheck=-1;let t=0,e=null;for(let i=this.dom;i;)if(1==i.nodeType)!e&&t<this.scrollTargets.length&&this.scrollTargets[t]==i?t++:e||(e=this.scrollTargets.slice(0,t)),e&&e.push(i),i=i.assignedSlot||i.parentNode;else{if(11!=i.nodeType)break;i=i.host}if(t<this.scrollTargets.length&&!e&&(e=this.scrollTargets.slice(0,t)),e){for(let t of this.scrollTargets)t.removeEventListener("scroll",this.onScroll);for(let t of this.scrollTargets=e)t.addEventListener("scroll",this.onScroll)}}ignore(t){if(!this.active)return t();try{return this.stop(),t()}finally{this.start(),this.clear()}}start(){this.active||(this.observer.observe(this.dom,gn),On&&this.dom.addEventListener("DOMCharacterDataModified",this.onCharData),this.active=!0)}stop(){this.active&&(this.active=!1,this.observer.disconnect(),On&&this.dom.removeEventListener("DOMCharacterDataModified",this.onCharData))}clear(){this.processRecords(),this.queue.length=0,this.selectionChanged=!1}delayAndroidKey(t,e){this.delayedAndroidKey||requestAnimationFrame((()=>{let t=this.delayedAndroidKey;this.delayedAndroidKey=null;let e=this.view.state;this.readSelectionRange(),de(this.view.contentDOM,t.key,t.keyCode)?this.processRecords():this.flush(),this.view.state==e&&this.view.update([])})),this.delayedAndroidKey&&"Enter"!=t||(this.delayedAndroidKey={key:t,keyCode:e})}flushSoon(){this.delayedFlush<0&&(this.delayedFlush=window.setTimeout((()=>{this.delayedFlush=-1,this.flush()}),20))}forceFlush(){this.delayedFlush>=0&&(window.clearTimeout(this.delayedFlush),this.delayedFlush=-1,this.flush())}processRecords(){let t=this.queue;for(let e of this.observer.takeRecords())t.push(e);t.length&&(this.queue=[]);let e=-1,i=-1,s=!1;for(let n of t){let t=this.readMutation(n);t&&(t.typeOver&&(s=!0),-1==e?({from:e,to:i}=t):(e=Math.min(t.from,e),i=Math.max(t.to,i)))}return{from:e,to:i,typeOver:s}}flush(t=!0){if(this.delayedFlush>=0||this.delayedAndroidKey)return;t&&this.readSelectionRange();let{from:e,to:i,typeOver:s}=this.processRecords(),n=this.selectionChanged&&Jt(this.dom,this.selectionRange);if(e<0&&!n)return;this.selectionChanged=!1;let r=this.view.state;this.onChange(e,i,s),this.view.state==r&&this.view.update([])}readMutation(t){let e=this.view.docView.nearest(t.target);if(!e||e.ignoreMutation(t))return null;if(e.markDirty("attributes"==t.type),"attributes"==t.type&&(e.dirty|=4),"childList"==t.type){let i=bn(e,t.previousSibling||t.target.previousSibling,-1),s=bn(e,t.nextSibling||t.target.nextSibling,1);return{from:i?e.posAfter(i):e.posAtStart,to:s?e.posBefore(s):e.posAtEnd,typeOver:!1}}return"characterData"==t.type?{from:e.posAtStart,to:e.posAtEnd,typeOver:t.target.nodeValue==t.oldValue}:null}destroy(){var t,e,i;this.stop(),null===(t=this.intersection)||void 0===t||t.disconnect(),null===(e=this.gapIntersection)||void 0===e||e.disconnect(),null===(i=this.resize)||void 0===i||i.disconnect();for(let t of this.scrollTargets)t.removeEventListener("scroll",this.onScroll);window.removeEventListener("scroll",this.onScroll),window.removeEventListener("resize",this.onResize),window.removeEventListener("beforeprint",this.onPrint),this.dom.ownerDocument.removeEventListener("selectionchange",this.onSelectionChange),clearTimeout(this.parentCheck),clearTimeout(this.resizeTimeout)}}function bn(t,e,i){for(;e;){let s=me.get(e);if(s&&s.parent==t)return s;let n=e.parentNode;e=n!=t.dom?n:i>0?e.nextSibling:e.previousSibling}return null}function vn(e,i,s,n){let r,o,h=e.state.selection.main;if(i>-1){let n=e.docView.domBoundsAround(i,s,0);if(!n||e.state.readOnly)return;let{from:l,to:a}=n,c=e.docView.impreciseHead||e.docView.impreciseAnchor?[]:function(t){let e=[];if(t.root.activeElement!=t.contentDOM)return e;let{anchorNode:i,anchorOffset:s,focusNode:n,focusOffset:r}=t.observer.selectionRange;i&&(e.push(new Fi(i,s)),n==i&&r==s||e.push(new Fi(n,r)));return e}(e),u=new Ii(c,e.state);u.readRange(n.startDOM,n.endDOM);let f=h.from,d=null;(8===e.inputState.lastKeyCode&&e.inputState.lastKeyTime>Date.now()-100||Xe.android&&u.text.length<a-l)&&(f=h.to,d="end");let p=function(t,e,i,s){let n=Math.min(t.length,e.length),r=0;for(;r<n&&t.charCodeAt(r)==e.charCodeAt(r);)r++;if(r==n&&t.length==e.length)return null;let o=t.length,h=e.length;for(;o>0&&h>0&&t.charCodeAt(o-1)==e.charCodeAt(h-1);)o--,h--;if("end"==s){i-=o+Math.max(0,r-Math.min(o,h))-r}if(o<r&&t.length<e.length){r-=i<=r&&i>=o?r-i:0,h=r+(h-o),o=r}else if(h<r){r-=i<=r&&i>=h?r-i:0,o=r+(o-h),h=r}return{from:r,toA:o,toB:h}}(e.state.doc.sliceString(l,a,""),u.text,f-l,d);p&&(Xe.chrome&&13==e.inputState.lastKeyCode&&p.toB==p.from+2&&""==u.text.slice(p.from,p.toB)&&p.toB--,r={from:l+p.from,to:l+p.toA,insert:t.of(u.text.slice(p.from,p.toB).split(""))}),o=function(t,e){if(0==t.length)return null;let i=t[0].pos,s=2==t.length?t[1].pos:i;return i>-1&&s>-1?A.single(i+e,s+e):null}(c,l)}else if(e.hasFocus||!e.state.facet(mi)){let t=e.observer.selectionRange,{impreciseHead:i,impreciseAnchor:s}=e.docView,n=i&&i.node==t.focusNode&&i.offset==t.focusOffset||!Kt(e.contentDOM,t.focusNode)?e.state.selection.main.head:e.docView.posFromDOM(t.focusNode,t.focusOffset),r=s&&s.node==t.anchorNode&&s.offset==t.anchorOffset||!Kt(e.contentDOM,t.anchorNode)?e.state.selection.main.anchor:e.docView.posFromDOM(t.anchorNode,t.anchorOffset);n==h.head&&r==h.anchor||(o=A.single(r,n))}if(r||o)if(!r&&n&&!h.empty&&o&&o.main.empty?r={from:h.from,to:h.to,insert:e.state.doc.slice(h.from,h.to)}:r&&r.from>=h.from&&r.to<=h.to&&(r.from!=h.from||r.to!=h.to)&&h.to-h.from-(r.to-r.from)<=4?r={from:h.from,to:h.to,insert:e.state.doc.slice(h.from,r.from).append(r.insert).append(e.state.doc.slice(r.to,h.to))}:Xe.mac&&r&&r.from==r.to&&r.from==h.head-1&&"."==r.insert.toString()&&(r={from:h.from,to:h.to,insert:t.of([" "])}),r){let t=e.state;if(Xe.ios&&e.inputState.flushIOSKey(e))return;if(Xe.android&&(r.from==h.from&&r.to==h.to&&1==r.insert.length&&2==r.insert.lines&&de(e.contentDOM,"Enter",13)||r.from==h.from-1&&r.to==h.to&&0==r.insert.length&&de(e.contentDOM,"Backspace",8)||r.from==h.from&&r.to==h.to+1&&0==r.insert.length&&de(e.contentDOM,"Delete",46)))return;let i,s=r.insert.toString();if(e.state.facet(fi).some((t=>t(e,r.from,r.to,s))))return;if(e.inputState.composing>=0&&e.inputState.composing++,r.from>=h.from&&r.to<=h.to&&r.to-r.from>=(h.to-h.from)/3&&(!o||o.main.empty&&o.main.from==r.from+r.insert.length)&&e.inputState.composing<0){let s=h.from<r.from?t.sliceDoc(h.from,r.from):"",n=h.to>r.to?t.sliceDoc(r.to,h.to):"";i=t.replaceSelection(e.state.toText(s+r.insert.sliceString(0,void 0,e.state.lineBreak)+n))}else{let s=t.changes(r),n=o&&!t.selection.main.eq(o.main)&&o.main.to<=s.newLength?o.main:void 0;if(t.selection.ranges.length>1&&e.inputState.composing>=0&&r.to<=h.to&&r.to>=h.to-10){let o=e.state.sliceDoc(r.from,r.to),l=Zi(e)||e.state.doc.lineAt(h.head),a=h.to-r.to,c=h.to-h.from;i=t.changeByRange((i=>{if(i.from==h.from&&i.to==h.to)return{changes:s,range:n||i.map(s)};let u=i.to-a,f=u-o.length;if(i.to-i.from!=c||e.state.sliceDoc(f,u)!=o||l&&i.to>=l.from&&i.from<=l.to)return{range:i};let d=t.changes({from:f,to:u,insert:r.insert}),p=i.to-h.to;return{changes:d,range:n?A.range(Math.max(0,n.anchor+p),Math.max(0,n.head+p)):i.map(d)}}))}else i={changes:s,selection:n&&t.selection.replaceRange(n)}}let n="input.type";e.composing&&(n+=".compose",e.inputState.compositionFirstChange&&(n+=".start",e.inputState.compositionFirstChange=!1)),e.dispatch(i,{scrollIntoView:!0,userEvent:n})}else if(o&&!o.main.eq(h)){let t=!1,i="select";e.inputState.lastSelectionTime>Date.now()-50&&("select"==e.inputState.lastSelectionOrigin&&(t=!0),i=e.inputState.lastSelectionOrigin),e.dispatch({selection:o,scrollIntoView:t,userEvent:i})}}class yn{constructor(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.style.cssText="position: absolute; top: -10000px",this.announceDOM.setAttribute("aria-live","polite"),this.dom=document.createElement("div"),this.dom.appendChild(this.announceDOM),this.dom.appendChild(this.scrollDOM),this._dispatch=t.dispatch||(t=>this.update([t])),this.dispatch=this.dispatch.bind(this),this.root=t.root||function(t){for(;t;){if(t&&(9==t.nodeType||11==t.nodeType&&t.host))return t;t=t.assignedSlot||t.parentNode}return null}(t.parent)||document,this.viewState=new Us(t.state||xt.create()),this.plugins=this.state.facet(vi).map((t=>new wi(t)));for(let t of this.plugins)t.update(this);this.observer=new mn(this,((t,e,i)=>{vn(this,t,e,i)}),(t=>{this.inputState.runScrollHandlers(this,t),this.observer.intersecting&&this.measure()})),this.inputState=new cs(this),this.inputState.ensureHandlers(this,this.plugins),this.docView=new Hi(this),this.mountStyles(),this.updateAttrs(),this.updateState=0,this.requestMeasure(),t.parent&&t.parent.appendChild(this.dom)}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.composing>0}get compositionStarted(){return this.inputState.composing>=0}dispatch(...t){this._dispatch(1==t.length&&t[0]instanceof ut?t[0]:this.state.update(...t))}update(t){if(0!=this.updateState)throw new Error("Calls to EditorView.update are not allowed while an update is in progress");let e,i=!1,s=this.state;for(let e of t){if(e.startState!=s)throw new RangeError("Trying to update state with a transaction that doesn't start from the previous state.");s=e.state}if(this.destroyed)return void(this.viewState.state=s);if(s.facet(xt.phrases)!=this.state.facet(xt.phrases))return this.setState(s);e=qi.create(this,s,t);let n=this.viewState.scrollTarget;try{this.updateState=2;for(let e of t){if(n&&(n=n.map(e.changes)),e.scrollIntoView){let{main:t}=e.state.selection;n=new pi(t.empty?t:A.cursor(t.head,t.head>t.anchor?-1:1))}for(let t of e.effects)t.is(gi)&&(n=t.value)}this.viewState.update(e,n),this.bidiCache=Sn.update(this.bidiCache,e.changes),e.empty||(this.updatePlugins(e),this.inputState.update(e)),i=this.docView.update(e),this.state.facet(Qi)!=this.styleModules&&this.mountStyles(),this.updateAttrs(),this.showAnnouncements(t),this.docView.updateSelection(i,t.some((t=>t.isUserEvent("select.pointer"))))}finally{this.updateState=0}if(e.startState.facet(hn)!=e.state.facet(hn)&&(this.viewState.mustMeasureContent=!0),(i||n||this.viewState.mustEnforceCursorAssoc||this.viewState.mustMeasureContent)&&this.requestMeasure(),!e.empty)for(let t of this.state.facet(ui))t(e)}setState(t){if(0!=this.updateState)throw new Error("Calls to EditorView.setState are not allowed while an update is in progress");if(this.destroyed)return void(this.viewState.state=t);this.updateState=2;let e=this.hasFocus;try{for(let t of this.plugins)t.destroy(this);this.viewState=new Us(t),this.plugins=t.facet(vi).map((t=>new wi(t))),this.pluginMap.clear();for(let t of this.plugins)t.update(this);this.docView=new Hi(this),this.inputState.ensureHandlers(this,this.plugins),this.mountStyles(),this.updateAttrs(),this.bidiCache=[]}finally{this.updateState=0}e&&this.focus(),this.requestMeasure()}updatePlugins(t){let e=t.startState.facet(vi),i=t.state.facet(vi);if(e!=i){let s=[];for(let n of i){let i=e.indexOf(n);if(i<0)s.push(new wi(n));else{let e=this.plugins[i];e.mustUpdate=t,s.push(e)}}for(let e of this.plugins)e.mustUpdate!=t&&e.destroy(this);this.plugins=s,this.pluginMap.clear(),this.inputState.ensureHandlers(this,this.plugins)}else for(let e of this.plugins)e.mustUpdate=t;for(let t=0;t<this.plugins.length;t++)this.plugins[t].update(this)}measure(t=!0){if(this.destroyed)return;this.measureScheduled>-1&&cancelAnimationFrame(this.measureScheduled),this.measureScheduled=0,t&&this.observer.flush();let e=null;try{for(let t=0;;t++){this.updateState=1;let i=this.viewport,s=this.viewState.measure(this);if(!s&&!this.measureRequests.length&&null==this.viewState.scrollTarget)break;if(t>5){console.warn(this.measureRequests.length?"Measure loop restarted more than 5 times":"Viewport failed to stabilize");break}let n=[];4&s||([this.measureRequests,n]=[n,this.measureRequests]);let r=n.map((t=>{try{return t.read(this)}catch(t){return Oi(this.state,t),xn}})),o=qi.create(this,this.state,[]),h=!1,l=!1;o.flags|=s,e?e.flags|=s:e=o,this.updateState=2,o.empty||(this.updatePlugins(o),this.inputState.update(o),this.updateAttrs(),h=this.docView.update(o));for(let t=0;t<n.length;t++)if(r[t]!=xn)try{let e=n[t];e.write&&e.write(r[t],this)}catch(t){Oi(this.state,t)}if(this.viewState.scrollTarget&&(this.docView.scrollIntoView(this.viewState.scrollTarget),this.viewState.scrollTarget=null,l=!0),h&&this.docView.updateSelection(!0),this.viewport.from==i.from&&this.viewport.to==i.to&&!l&&0==this.measureRequests.length)break}}finally{this.updateState=0,this.measureScheduled=-1}if(e&&!e.empty)for(let t of this.state.facet(ui))t(e)}get themeClasses(){return an+" "+(this.state.facet(ln)?un:cn)+" "+this.state.facet(hn)}updateAttrs(){let t=kn(this,xi,{class:"cm-editor"+(this.hasFocus?" cm-focused ":" ")+this.themeClasses}),e={spellcheck:"false",autocorrect:"off",autocapitalize:"off",translate:"no",contenteditable:this.state.facet(mi)?"true":"false",class:"cm-content",style:`${Xe.tabSize}: ${this.state.tabSize}`,role:"textbox","aria-multiline":"true"};this.state.readOnly&&(e["aria-readonly"]="true"),kn(this,Si,e),this.observer.ignore((()=>{He(this.contentDOM,this.contentAttrs,e),He(this.dom,this.editorAttrs,t)})),this.editorAttrs=t,this.contentAttrs=e}showAnnouncements(t){let e=!0;for(let i of t)for(let t of i.effects)if(t.is(yn.announce)){e&&(this.announceDOM.textContent=""),e=!1,this.announceDOM.appendChild(document.createElement("div")).textContent=t.value}}mountStyles(){this.styleModules=this.state.facet(Qi),zt.mount(this.root,this.styleModules.concat(pn).reverse())}readMeasured(){if(2==this.updateState)throw new Error("Reading the editor layout isn't allowed during an update");0==this.updateState&&this.measureScheduled>-1&&this.measure(!1)}requestMeasure(t){if(this.measureScheduled<0&&(this.measureScheduled=requestAnimationFrame((()=>this.measure()))),t){if(null!=t.key)for(let e=0;e<this.measureRequests.length;e++)if(this.measureRequests[e].key===t.key)return void(this.measureRequests[e]=t);this.measureRequests.push(t)}}plugin(t){let e=this.pluginMap.get(t);return(void 0===e||e&&e.spec!=t)&&this.pluginMap.set(t,e=this.plugins.find((e=>e.spec==t))||null),e&&e.update(this).value}get documentTop(){return this.contentDOM.getBoundingClientRect().top+this.viewState.paddingTop}get documentPadding(){return{top:this.viewState.paddingTop,bottom:this.viewState.paddingBottom}}elementAtHeight(t){return this.readMeasured(),this.viewState.elementAtHeight(t)}lineBlockAtHeight(t){return this.readMeasured(),this.viewState.lineBlockAtHeight(t)}get viewportLineBlocks(){return this.viewState.viewportLines}lineBlockAt(t){return this.viewState.lineBlockAt(t)}get contentHeight(){return this.viewState.contentHeight}moveByChar(t,e,i){return as(this,t,ls(this,t,e,i))}moveByGroup(t,e){return as(this,t,ls(this,t,e,(e=>function(t,e,i){let s=t.state.charCategorizer(e),n=s(i);return t=>{let e=s(t);return n==bt.Space&&(n=e),n==e}}(this,t.head,e))))}moveToLineBoundary(t,e,i=!0){return function(t,e,i,s){let n=t.state.doc.lineAt(e.head),r=s&&t.lineWrapping?t.coordsAtPos(e.assoc<0&&e.head>n.from?e.head-1:e.head):null;if(r){let e=t.dom.getBoundingClientRect(),s=t.textDirectionAt(n.from),o=t.posAtCoords({x:i==(s==Ai.LTR)?e.right-1:e.left+1,y:(r.top+r.bottom)/2});if(null!=o)return A.cursor(o,i?-1:1)}let o=ii.find(t.docView,e.head),h=o?i?o.posAtEnd:o.posAtStart:i?n.to:n.from;return A.cursor(h,i?-1:1)}(this,t,e,i)}moveVertically(t,e,i){return as(this,t,function(t,e,i,s){let n=e.head,r=i?1:-1;if(n==(i?t.state.doc.length:0))return A.cursor(n,e.assoc);let o,h=e.goalColumn,l=t.contentDOM.getBoundingClientRect(),a=t.coordsAtPos(n),c=t.documentTop;if(a)null==h&&(h=a.left-l.left),o=r<0?a.top:a.bottom;else{let e=t.viewState.lineBlockAt(n);null==h&&(h=Math.min(l.right-l.left,t.defaultCharacterWidth*(n-e.from))),o=(r<0?e.top:e.bottom)+c}let u=l.left+h,f=null!=s?s:t.defaultLineHeight>>1;for(let i=0;;i+=10){let s=o+(f+i)*r,a=os(t,{x:u,y:s},!1,r);if(s<l.top||s>l.bottom||(r<0?a<n:a>n))return A.cursor(a,e.assoc,void 0,h)}}(this,t,e,i))}domAtPos(t){return this.docView.domAtPos(t)}posAtDOM(t,e=0){return this.docView.posFromDOM(t,e)}posAtCoords(t,e=!0){return this.readMeasured(),os(this,t,e)}coordsAtPos(t,e=1){this.readMeasured();let i=this.docView.coordsAt(t,e);if(!i||i.left==i.right)return i;let s=this.state.doc.lineAt(t),n=this.bidiSpans(s);return oe(i,n[Bi.find(n,t-s.from,-1,e)].dir==Ai.LTR==e>0)}get defaultCharacterWidth(){return this.viewState.heightOracle.charWidth}get defaultLineHeight(){return this.viewState.heightOracle.lineHeight}get textDirection(){return this.viewState.defaultTextDirection}textDirectionAt(t){return!this.state.facet(di)||t<this.viewport.from||t>this.viewport.to?this.textDirection:(this.readMeasured(),this.docView.textDirectionAt(t))}get lineWrapping(){return this.viewState.heightOracle.lineWrapping}bidiSpans(t){if(t.length>wn)return ji(t.length);let e=this.textDirectionAt(t.from);for(let i of this.bidiCache)if(i.from==t.from&&i.dir==e)return i.order;let i=function(t,e){let i=t.length,s=e==Ti?1:2,n=e==Ti?2:1;if(!t||1==s&&!_i.test(t))return ji(i);for(let e=0,n=s,o=s;e<i;e++){let i=(r=t.charCodeAt(e))<=247?Mi[r]:1424<=r&&r<=1524?2:1536<=r&&r<=1785?Di[r-1536]:1774<=r&&r<=2220?4:8192<=r&&r<=8203||8204==r?256:1;512==i?i=n:8==i&&4==o&&(i=16),Vi[e]=4==i?2:i,7&i&&(o=i),n=i}var r;for(let t=0,e=s,n=s;t<i;t++){let s=Vi[t];if(128==s)t<i-1&&e==Vi[t+1]&&24&e?s=Vi[t]=e:Vi[t]=256;else if(64==s){let s=t+1;for(;s<i&&64==Vi[s];)s++;let r=t&&8==e||s<i&&8==Vi[s]?1==n?1:8:256;for(let e=t;e<s;e++)Vi[e]=r;t=s-1}else 8==s&&1==n&&(Vi[t]=1);e=s,7&s&&(n=s)}for(let e,r,o,h=0,l=0,a=0;h<i;h++)if(r=Ei[e=t.charCodeAt(h)])if(r<0){for(let t=l-3;t>=0;t-=3)if(Ni[t+1]==-r){let e=Ni[t+2],i=2&e?s:4&e?1&e?n:s:0;i&&(Vi[h]=Vi[Ni[t]]=i),l=t;break}}else{if(189==Ni.length)break;Ni[l++]=h,Ni[l++]=e,Ni[l++]=a}else if(2==(o=Vi[h])||1==o){let t=o==s;a=t?0:1;for(let e=l-3;e>=0;e-=3){let i=Ni[e+2];if(2&i)break;if(t)Ni[e+2]|=2;else{if(4&i)break;Ni[e+2]|=4}}}for(let t=0;t<i;t++)if(256==Vi[t]){let e=t+1;for(;e<i&&256==Vi[e];)e++;let n=1==(t?Vi[t-1]:s),r=n==(1==(e<i?Vi[e]:s))?n?1:2:s;for(let i=t;i<e;i++)Vi[i]=r;t=e-1}let o=[];if(1==s)for(let t=0;t<i;){let e=t,s=1!=Vi[t++];for(;t<i&&s==(1!=Vi[t]);)t++;if(s)for(let i=t;i>e;){let t=i,s=2!=Vi[--i];for(;i>e&&s==(2!=Vi[i-1]);)i--;o.push(new Bi(i,t,s?2:1))}else o.push(new Bi(e,t,0))}else for(let t=0;t<i;){let e=t,s=2==Vi[t++];for(;t<i&&s==(2==Vi[t]);)t++;o.push(new Bi(e,t,s?1:2))}return o}(t.text,e);return this.bidiCache.push(new Sn(t.from,t.to,e,i)),i}get hasFocus(){var t;return(document.hasFocus()||Xe.safari&&(null===(t=this.inputState)||void 0===t?void 0:t.lastContextMenu)>Date.now()-3e4)&&this.root.activeElement==this.contentDOM}focus(){this.observer.ignore((()=>{ue(this.contentDOM),this.docView.updateSelection()}))}destroy(){for(let t of this.plugins)t.destroy(this);this.plugins=[],this.inputState.destroy(),this.dom.remove(),this.observer.destroy(),this.measureScheduled>-1&&cancelAnimationFrame(this.measureScheduled),this.destroyed=!0}static scrollIntoView(t,e={}){return gi.of(new pi("number"==typeof t?A.cursor(t):t,e.y,e.x,e.yMargin,e.xMargin))}static domEventHandlers(t){return yi.define((()=>({})),{eventHandlers:t})}static theme(t,e){let i=zt.newName(),s=[hn.of(i),Qi.of(dn(`.${i}`,t))];return e&&e.dark&&s.push(ln.of(!0)),s}static baseTheme(t){return H.lowest(Qi.of(dn("."+an,t,fn)))}}yn.styleModule=Qi,yn.inputHandler=fi,yn.perLineTextDirection=di,yn.exceptionSink=ci,yn.updateListener=ui,yn.editable=mi,yn.mouseSelectionStyle=ai,yn.dragMovesSelection=li,yn.clickAddsSelectionRange=hi,yn.decorations=ki,yn.atomicRanges=Pi,yn.scrollMargins=$i,yn.darkTheme=ln,yn.contentAttributes=Si,yn.editorAttributes=xi,yn.lineWrapping=yn.contentAttributes.of({class:"cm-lineWrapping"}),yn.announce=ct.define();const wn=4096,xn={};class Sn{constructor(t,e,i,s){this.from=t,this.to=e,this.dir=i,this.order=s}static update(t,e){if(e.empty)return t;let i=[],s=t.length?t[t.length-1].dir:Ai.LTR;for(let n=Math.max(0,t.length-10);n<t.length;n++){let r=t[n];r.dir!=s||e.touchesRange(r.from,r.to)||i.push(new Sn(e.mapPos(r.from,1),e.mapPos(r.to,-1),r.dir,r.order))}return i}}function kn(t,e,i){for(let s=t.state.facet(e),n=s.length-1;n>=0;n--){let e=s[n],r="function"==typeof e?e(t):e;r&&Le(r,i)}return i}class Pn extends St{compare(t){return this==t||this.constructor==t.constructor&&this.eq(t)}eq(t){return!1}destroy(t){}}Pn.prototype.elementClass="",Pn.prototype.toDOM=void 0,Pn.prototype.mapMode=y.TrackBefore,Pn.prototype.startSide=Pn.prototype.endSide=-1,Pn.prototype.point=!0;const $n=1024;let Qn=0;class Rn{constructor(t,e){this.from=t,this.to=e}}class qn{constructor(t={}){this.id=Qn++,this.perNode=!!t.perNode,this.deserialize=t.deserialize||(()=>{throw new Error("This node type doesn't define a deserialize function")})}add(t){if(this.perNode)throw new RangeError("Can't add per-node props to node types");return"function"!=typeof t&&(t=Tn.match(t)),e=>{let i=t(e);return void 0===i?null:[this,i]}}}qn.closedBy=new qn({deserialize:t=>t.split(" ")}),qn.openedBy=new qn({deserialize:t=>t.split(" ")}),qn.group=new qn({deserialize:t=>t.split(" ")}),qn.contextHash=new qn({perNode:!0}),qn.lookAhead=new qn({perNode:!0}),qn.mounted=new qn({perNode:!0});const An=Object.create(null);class Tn{constructor(t,e,i,s=0){this.name=t,this.props=e,this.id=i,this.flags=s}static define(t){let e=t.props&&t.props.length?Object.create(null):An,i=(t.top?1:0)|(t.skipped?2:0)|(t.error?4:0)|(null==t.name?8:0),s=new Tn(t.name||"",e,t.id,i);if(t.props)for(let i of t.props)if(Array.isArray(i)||(i=i(s)),i){if(i[0].perNode)throw new RangeError("Can't store a per-node prop on a node type");e[i[0].id]=i[1]}return s}prop(t){return this.props[t.id]}get isTop(){return(1&this.flags)>0}get isSkipped(){return(2&this.flags)>0}get isError(){return(4&this.flags)>0}get isAnonymous(){return(8&this.flags)>0}is(t){if("string"==typeof t){if(this.name==t)return!0;let e=this.prop(qn.group);return!!e&&e.indexOf(t)>-1}return this.id==t}static match(t){let e=Object.create(null);for(let i in t)for(let s of i.split(" "))e[s]=t[i];return t=>{for(let i=t.prop(qn.group),s=-1;s<(i?i.length:0);s++){let n=e[s<0?t.name:i[s]];if(n)return n}}}}Tn.none=new Tn("",Object.create(null),0,8);const Cn=new WeakMap,Xn=new WeakMap;var Mn;!function(t){t[t.ExcludeBuffers=1]="ExcludeBuffers",t[t.IncludeAnonymous=2]="IncludeAnonymous",t[t.IgnoreMounts=4]="IgnoreMounts",t[t.IgnoreOverlays=8]="IgnoreOverlays"}(Mn||(Mn={}));class Dn{constructor(t,e,i,s,n){if(this.type=t,this.children=e,this.positions=i,this.length=s,this.props=null,n&&n.length){this.props=Object.create(null);for(let[t,e]of n)this.props["number"==typeof t?t:t.id]=e}}toString(){let t=this.prop(qn.mounted);if(t&&!t.overlay)return t.tree.toString();let e="";for(let t of this.children){let i=t.toString();i&&(e&&(e+=","),e+=i)}return this.type.name?(/\W/.test(this.type.name)&&!this.type.isError?JSON.stringify(this.type.name):this.type.name)+(e.length?"("+e+")":""):e}cursor(t=0){return new Fn(this.topNode,t)}cursorAt(t,e=0,i=0){let s=Cn.get(this)||this.topNode,n=new Fn(s);return n.moveTo(t,e),Cn.set(this,n._tree),n}get topNode(){return new jn(this,0,0,null)}resolve(t,e=0){let i=Vn(Cn.get(this)||this.topNode,t,e,!1);return Cn.set(this,i),i}resolveInner(t,e=0){let i=Vn(Xn.get(this)||this.topNode,t,e,!0);return Xn.set(this,i),i}iterate(t){let{enter:e,leave:i,from:s=0,to:n=this.length}=t;for(let r=this.cursor((t.mode||0)|Mn.IncludeAnonymous);;){let t=!1;if(r.from<=n&&r.to>=s&&(r.type.isAnonymous||!1!==e(r))){if(r.firstChild())continue;t=!0}for(;t&&i&&!r.type.isAnonymous&&i(r),!r.nextSibling();){if(!r.parent())return;t=!0}}}prop(t){return t.perNode?this.props?this.props[t.id]:void 0:this.type.prop(t)}get propValues(){let t=[];if(this.props)for(let e in this.props)t.push([+e,this.props[e]]);return t}balance(t={}){return this.children.length<=8?this:Un(Tn.none,this.children,this.positions,0,this.children.length,0,this.length,((t,e,i)=>new Dn(this.type,t,e,i,this.propValues)),t.makeTree||((t,e,i)=>new Dn(Tn.none,t,e,i)))}static build(t){return function(t){var e;let{buffer:i,nodeSet:s,maxBufferLength:n=$n,reused:r=[],minRepeatType:o=s.types.length}=t,h=Array.isArray(i)?new En(i,i.length):i,l=s.types,a=0,c=0;function u(t,e,i,m,b){let{id:v,start:y,end:w,size:x}=h,S=c;for(;x<0;){if(h.next(),-1==x){let e=r[v];return i.push(e),void m.push(y-t)}if(-3==x)return void(a=v);if(-4==x)return void(c=v);throw new RangeError(`Unrecognized record size: ${x}`)}let k,P,$=l[v],Q=y-t;if(w-y<=n&&(P=g(h.pos-e,b))){let e=new Uint16Array(P.size-P.skip),i=h.pos-P.size,n=e.length;for(;h.pos>i;)n=O(P.start,e,n);k=new Nn(e,w-P.start,s),Q=P.start-t}else{let t=h.pos-x;h.next();let e=[],i=[],s=v>=o?v:-1,r=0,l=w;for(;h.pos>t;)s>=0&&h.id==s&&h.size>=0?(h.end<=l-n&&(d(e,i,y,r,h.end,l,s,S),r=e.length,l=h.end),h.next()):u(y,t,e,i,s);if(s>=0&&r>0&&r<e.length&&d(e,i,y,r,y,l,s,S),e.reverse(),i.reverse(),s>-1&&r>0){let t=f($);k=Un($,e,i,0,e.length,0,w-y,t,t)}else k=p($,e,i,w-y,S-w)}i.push(k),m.push(Q)}function f(t){return(e,i,s)=>{let n,r,o=0,h=e.length-1;if(h>=0&&(n=e[h])instanceof Dn){if(!h&&n.type==t&&n.length==s)return n;(r=n.prop(qn.lookAhead))&&(o=i[h]+n.length+r)}return p(t,e,i,s,o)}}function d(t,e,i,n,r,o,h,l){let a=[],c=[];for(;t.length>n;)a.push(t.pop()),c.push(e.pop()+i-r);t.push(p(s.types[h],a,c,o-r,l-o)),e.push(r-i)}function p(t,e,i,s,n=0,r){if(a){let t=[qn.contextHash,a];r=r?[t].concat(r):[t]}if(n>25){let t=[qn.lookAhead,n];r=r?[t].concat(r):[t]}return new Dn(t,e,i,s,r)}function g(t,e){let i=h.fork(),s=0,r=0,l=0,a=i.end-n,c={size:0,start:0,skip:0};t:for(let n=i.pos-t;i.pos>n;){let t=i.size;if(i.id==e&&t>=0){c.size=s,c.start=r,c.skip=l,l+=4,s+=4,i.next();continue}let h=i.pos-t;if(t<0||h<n||i.start<a)break;let u=i.id>=o?4:0,f=i.start;for(i.next();i.pos>h;){if(i.size<0){if(-3!=i.size)break t;u+=4}else i.id>=o&&(u+=4);i.next()}r=f,s+=t,l+=u}return(e<0||s==t)&&(c.size=s,c.start=r,c.skip=l),c.size>4?c:void 0}function O(t,e,i){let{id:s,start:n,end:r,size:l}=h;if(h.next(),l>=0&&s<o){let o=i;if(l>4){let s=h.pos-(l-4);for(;h.pos>s;)i=O(t,e,i)}e[--i]=o,e[--i]=r-t,e[--i]=n-t,e[--i]=s}else-3==l?a=s:-4==l&&(c=s);return i}let m=[],b=[];for(;h.pos>0;)u(t.start||0,t.bufferStart||0,m,b,-1);let v=null!==(e=t.length)&&void 0!==e?e:m.length?b[0]+m[0].length:0;return new Dn(l[t.topID],m.reverse(),b.reverse(),v)}(t)}}Dn.empty=new Dn(Tn.none,[],[],0);class En{constructor(t,e){this.buffer=t,this.index=e}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 En(this.buffer,this.index)}}class Nn{constructor(t,e,i){this.buffer=t,this.length=e,this.set=i}get type(){return Tn.none}toString(){let t=[];for(let e=0;e<this.buffer.length;)t.push(this.childString(e)),e=this.buffer[e+3];return t.join(",")}childString(t){let e=this.buffer[t],i=this.buffer[t+3],s=this.set.types[e],n=s.name;if(/\W/.test(n)&&!s.isError&&(n=JSON.stringify(n)),i==(t+=4))return n;let r=[];for(;t<i;)r.push(this.childString(t)),t=this.buffer[t+3];return n+"("+r.join(",")+")"}findChild(t,e,i,s,n){let{buffer:r}=this,o=-1;for(let h=t;h!=e&&!(_n(n,s,r[h+1],r[h+2])&&(o=h,i>0));h=r[h+3]);return o}slice(t,e,i,s){let n=this.buffer,r=new Uint16Array(e-t);for(let s=t,o=0;s<e;)r[o++]=n[s++],r[o++]=n[s++]-i,r[o++]=n[s++]-i,r[o++]=n[s++]-t;return new Nn(r,s-i,this.set)}}function _n(t,e,i,s){switch(t){case-2:return i<e;case-1:return s>=e&&i<e;case 0:return i<e&&s>e;case 1:return i<=e&&s>e;case 2:return s>e;case 4:return!0}}function Bn(t,e){let i=t.childBefore(e);for(;i;){let e=i.lastChild;if(!e||e.to!=i.to)break;e.type.isError&&e.from==e.to?(t=i,i=e.prevSibling):i=e}return t}function Vn(t,e,i,s){for(var n;t.from==t.to||(i<1?t.from>=e:t.from>e)||(i>-1?t.to<=e:t.to<e);){let e=!s&&t instanceof jn&&t.index<0?null:t.parent;if(!e)return t;t=e}let r=s?0:Mn.IgnoreOverlays;if(s)for(let s=t,o=s.parent;o;s=o,o=s.parent)s instanceof jn&&s.index<0&&(null===(n=o.enter(e,i,r))||void 0===n?void 0:n.from)!=s.from&&(t=o);for(;;){let s=t.enter(e,i,r);if(!s)return t;t=s}}class jn{constructor(t,e,i,s){this._tree=t,this.from=e,this.index=i,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(t,e,i,s,n=0){for(let r=this;;){for(let{children:o,positions:h}=r._tree,l=e>0?o.length:-1;t!=l;t+=e){let l=o[t],a=h[t]+r.from;if(_n(s,i,a,a+l.length))if(l instanceof Nn){if(n&Mn.ExcludeBuffers)continue;let o=l.findChild(0,l.buffer.length,e,i-a,s);if(o>-1)return new Ln(new In(r,l,t,a),null,o)}else if(n&Mn.IncludeAnonymous||!l.type.isAnonymous||Hn(l)){let o;if(!(n&Mn.IgnoreMounts)&&l.props&&(o=l.prop(qn.mounted))&&!o.overlay)return new jn(o.tree,a,t,r);let h=new jn(l,a,t,r);return n&Mn.IncludeAnonymous||!h.type.isAnonymous?h:h.nextChild(e<0?l.children.length-1:0,e,i,s)}}if(n&Mn.IncludeAnonymous||!r.type.isAnonymous)return null;if(t=r.index>=0?r.index+e:e<0?-1:r._parent._tree.children.length,r=r._parent,!r)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(t){return this.nextChild(0,1,t,2)}childBefore(t){return this.nextChild(this._tree.children.length-1,-1,t,-2)}enter(t,e,i=0){let s;if(!(i&Mn.IgnoreOverlays)&&(s=this._tree.prop(qn.mounted))&&s.overlay){let i=t-this.from;for(let{from:t,to:n}of s.overlay)if((e>0?t<=i:t<i)&&(e<0?n>=i:n>i))return new jn(s.tree,s.overlay[0].from+this.from,-1,this)}return this.nextChild(0,1,t,e,i)}nextSignificantParent(){let t=this;for(;t.type.isAnonymous&&t._parent;)t=t._parent;return t}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}cursor(t=0){return new Fn(this,t)}get tree(){return this._tree}toTree(){return this._tree}resolve(t,e=0){return Vn(this,t,e,!1)}resolveInner(t,e=0){return Vn(this,t,e,!0)}enterUnfinishedNodesBefore(t){return Bn(this,t)}getChild(t,e=null,i=null){let s=zn(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return zn(this,t,e,i)}toString(){return this._tree.toString()}get node(){return this}matchContext(t){return Wn(this,t)}}function zn(t,e,i,s){let n=t.cursor(),r=[];if(!n.firstChild())return r;if(null!=i)for(;!n.type.is(i);)if(!n.nextSibling())return r;for(;;){if(null!=s&&n.type.is(s))return r;if(n.type.is(e)&&r.push(n.node),!n.nextSibling())return null==s?r:[]}}function Wn(t,e,i=e.length-1){for(let s=t.parent;i>=0;s=s.parent){if(!s)return!1;if(!s.type.isAnonymous){if(e[i]&&e[i]!=s.name)return!1;i--}}return!0}class In{constructor(t,e,i,s){this.parent=t,this.buffer=e,this.index=i,this.start=s}}class Ln{constructor(t,e,i){this.context=t,this._parent=e,this.index=i,this.type=t.buffer.set.types[t.buffer.buffer[i]]}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]}child(t,e,i){let{buffer:s}=this.context,n=s.findChild(this.index+4,s.buffer[this.index+3],t,e-this.context.start,i);return n<0?null:new Ln(this.context,this,n)}get firstChild(){return this.child(1,0,4)}get lastChild(){return this.child(-1,0,4)}childAfter(t){return this.child(1,t,2)}childBefore(t){return this.child(-1,t,-2)}enter(t,e,i=0){if(i&Mn.ExcludeBuffers)return null;let{buffer:s}=this.context,n=s.findChild(this.index+4,s.buffer[this.index+3],e>0?1:-1,t-this.context.start,e);return n<0?null:new Ln(this.context,this,n)}get parent(){return this._parent||this.context.parent.nextSignificantParent()}externalSibling(t){return this._parent?null:this.context.parent.nextChild(this.context.index+t,t,0,4)}get nextSibling(){let{buffer:t}=this.context,e=t.buffer[this.index+3];return e<(this._parent?t.buffer[this._parent.index+3]:t.buffer.length)?new Ln(this.context,this._parent,e):this.externalSibling(1)}get prevSibling(){let{buffer:t}=this.context,e=this._parent?this._parent.index+4:0;return this.index==e?this.externalSibling(-1):new Ln(this.context,this._parent,t.findChild(e,this.index,-1,0,4))}cursor(t=0){return new Fn(this,t)}get tree(){return null}toTree(){let t=[],e=[],{buffer:i}=this.context,s=this.index+4,n=i.buffer[this.index+3];if(n>s){let r=i.buffer[this.index+1],o=i.buffer[this.index+2];t.push(i.slice(s,n,r,o)),e.push(0)}return new Dn(this.type,t,e,this.to-this.from)}resolve(t,e=0){return Vn(this,t,e,!1)}resolveInner(t,e=0){return Vn(this,t,e,!0)}enterUnfinishedNodesBefore(t){return Bn(this,t)}toString(){return this.context.buffer.childString(this.index)}getChild(t,e=null,i=null){let s=zn(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return zn(this,t,e,i)}get node(){return this}matchContext(t){return Wn(this,t)}}class Fn{constructor(t,e=0){if(this.mode=e,this.buffer=null,this.stack=[],this.index=0,this.bufferNode=null,t instanceof jn)this.yieldNode(t);else{this._tree=t.context.parent,this.buffer=t.context;for(let e=t._parent;e;e=e._parent)this.stack.unshift(e.index);this.bufferNode=t,this.yieldBuf(t.index)}}get name(){return this.type.name}yieldNode(t){return!!t&&(this._tree=t,this.type=t.type,this.from=t.from,this.to=t.to,!0)}yieldBuf(t,e){this.index=t;let{start:i,buffer:s}=this.buffer;return this.type=e||s.set.types[s.buffer[t]],this.from=i+s.buffer[t+1],this.to=i+s.buffer[t+2],!0}yield(t){return!!t&&(t instanceof jn?(this.buffer=null,this.yieldNode(t)):(this.buffer=t.context,this.yieldBuf(t.index,t.type)))}toString(){return this.buffer?this.buffer.buffer.childString(this.index):this._tree.toString()}enterChild(t,e,i){if(!this.buffer)return this.yield(this._tree.nextChild(t<0?this._tree._tree.children.length-1:0,t,e,i,this.mode));let{buffer:s}=this.buffer,n=s.findChild(this.index+4,s.buffer[this.index+3],t,e-this.buffer.start,i);return!(n<0)&&(this.stack.push(this.index),this.yieldBuf(n))}firstChild(){return this.enterChild(1,0,4)}lastChild(){return this.enterChild(-1,0,4)}childAfter(t){return this.enterChild(1,t,2)}childBefore(t){return this.enterChild(-1,t,-2)}enter(t,e,i=this.mode){return this.buffer?!(i&Mn.ExcludeBuffers)&&this.enterChild(1,t,e):this.yield(this._tree.enter(t,e,i))}parent(){if(!this.buffer)return this.yieldNode(this.mode&Mn.IncludeAnonymous?this._tree._parent:this._tree.parent);if(this.stack.length)return this.yieldBuf(this.stack.pop());let t=this.mode&Mn.IncludeAnonymous?this.buffer.parent:this.buffer.parent.nextSignificantParent();return this.buffer=null,this.yieldNode(t)}sibling(t){if(!this.buffer)return!!this._tree._parent&&this.yield(this._tree.index<0?null:this._tree._parent.nextChild(this._tree.index+t,t,0,4,this.mode));let{buffer:e}=this.buffer,i=this.stack.length-1;if(t<0){let t=i<0?0:this.stack[i]+4;if(this.index!=t)return this.yieldBuf(e.findChild(t,this.index,-1,0,4))}else{let t=e.buffer[this.index+3];if(t<(i<0?e.buffer.length:e.buffer[this.stack[i]+3]))return this.yieldBuf(t)}return i<0&&this.yield(this.buffer.parent.nextChild(this.buffer.index+t,t,0,4,this.mode))}nextSibling(){return this.sibling(1)}prevSibling(){return this.sibling(-1)}atLastNode(t){let e,i,{buffer:s}=this;if(s){if(t>0){if(this.index<s.buffer.buffer.length)return!1}else for(let t=0;t<this.index;t++)if(s.buffer.buffer[t+3]<this.index)return!1;({index:e,parent:i}=s)}else({index:e,_parent:i}=this._tree);for(;i;({index:e,_parent:i}=i))if(e>-1)for(let s=e+t,n=t<0?-1:i._tree.children.length;s!=n;s+=t){let t=i._tree.children[s];if(this.mode&Mn.IncludeAnonymous||t instanceof Nn||!t.type.isAnonymous||Hn(t))return!1}return!0}move(t,e){if(e&&this.enterChild(t,0,4))return!0;for(;;){if(this.sibling(t))return!0;if(this.atLastNode(t)||!this.parent())return!1}}next(t=!0){return this.move(1,t)}prev(t=!0){return this.move(-1,t)}moveTo(t,e=0){for(;(this.from==this.to||(e<1?this.from>=t:this.from>t)||(e>-1?this.to<=t:this.to<t))&&this.parent(););for(;this.enterChild(1,t,e););return this}get node(){if(!this.buffer)return this._tree;let t=this.bufferNode,e=null,i=0;if(t&&t.context==this.buffer)t:for(let s=this.index,n=this.stack.length;n>=0;){for(let r=t;r;r=r._parent)if(r.index==s){if(s==this.index)return r;e=r,i=n+1;break t}s=this.stack[--n]}for(let t=i;t<this.stack.length;t++)e=new Ln(this.buffer,e,this.stack[t]);return this.bufferNode=new Ln(this.buffer,e,this.index)}get tree(){return this.buffer?null:this._tree._tree}iterate(t,e){for(let i=0;;){let s=!1;if(this.type.isAnonymous||!1!==t(this)){if(this.firstChild()){i++;continue}this.type.isAnonymous||(s=!0)}for(;s&&e&&e(this),s=this.type.isAnonymous,!this.nextSibling();){if(!i)return;this.parent(),i--,s=!0}}}matchContext(t){if(!this.buffer)return Wn(this.node,t);let{buffer:e}=this.buffer,{types:i}=e.set;for(let s=t.length-1,n=this.stack.length-1;s>=0;n--){if(n<0)return Wn(this.node,t,s);let r=i[e.buffer[this.stack[n]]];if(!r.isAnonymous){if(t[s]&&t[s]!=r.name)return!1;s--}}return!0}}function Hn(t){return t.children.some((t=>t instanceof Nn||!t.type.isAnonymous||Hn(t)))}const Gn=new WeakMap;function Zn(t,e){if(!t.isAnonymous||e instanceof Nn||e.type!=t)return 1;let i=Gn.get(e);if(null==i){i=1;for(let s of e.children){if(s.type!=t||!(s instanceof Dn)){i=1;break}i+=Zn(t,s)}Gn.set(e,i)}return i}function Un(t,e,i,s,n,r,o,h,l){let a=0;for(let i=s;i<n;i++)a+=Zn(t,e[i]);let c=Math.ceil(1.5*a/8),u=[],f=[];return function e(i,s,n,o,h){for(let a=n;a<o;){let n=a,d=s[a],p=Zn(t,i[a]);for(a++;a<o;a++){let e=Zn(t,i[a]);if(p+e>=c)break;p+=e}if(a==n+1){if(p>c){let t=i[n];e(t.children,t.positions,0,t.children.length,s[n]+h);continue}u.push(i[n])}else{let e=s[a-1]+i[a-1].length-d;u.push(Un(t,i,s,n,a,d,e,null,l))}f.push(d+h-r)}}(e,i,s,n,0),(h||l)(u,f,o)}class Yn{constructor(t,e,i,s,n=!1,r=!1){this.from=t,this.to=e,this.tree=i,this.offset=s,this.open=(n?1:0)|(r?2:0)}get openStart(){return(1&this.open)>0}get openEnd(){return(2&this.open)>0}static addTree(t,e=[],i=!1){let s=[new Yn(0,t.length,t,0,!1,i)];for(let i of e)i.to>t.length&&s.push(i);return s}static applyChanges(t,e,i=128){if(!e.length)return t;let s=[],n=1,r=t.length?t[0]:null;for(let o=0,h=0,l=0;;o++){let a=o<e.length?e[o]:null,c=a?a.fromA:1e9;if(c-h>=i)for(;r&&r.from<c;){let e=r;if(h>=e.from||c<=e.to||l){let t=Math.max(e.from,h)-l,i=Math.min(e.to,c)-l;e=t>=i?null:new Yn(t,i,e.tree,e.offset+l,o>0,!!a)}if(e&&s.push(e),r.to>c)break;r=n<t.length?t[n++]:null}if(!a)break;h=a.toA,l=a.toA-a.toB}return s}}class Kn{constructor(t){this.string=t}get length(){return this.string.length}chunk(t){return this.string.slice(t)}get lineChunks(){return!1}read(t,e){return this.string.slice(t,e)}}new qn({perNode:!0});let Jn=0;class tr{constructor(t,e,i){this.set=t,this.base=e,this.modified=i,this.id=Jn++}static define(t){if(null==t?void 0:t.base)throw new Error("Can not derive from a modified tag");let e=new tr([],null,[]);if(e.set.push(e),t)for(let i of t.set)e.set.push(i);return e}static defineModifier(){let t=new ir;return e=>e.modified.indexOf(t)>-1?e:ir.get(e.base||e,e.modified.concat(t).sort(((t,e)=>t.id-e.id)))}}let er=0;class ir{constructor(){this.instances=[],this.id=er++}static get(t,e){if(!e.length)return t;let i=e[0].instances.find((i=>{return i.base==t&&(s=e,n=i.modified,s.length==n.length&&s.every(((t,e)=>t==n[e])));var s,n}));if(i)return i;let s=[],n=new tr(s,t,e);for(let t of e)t.instances.push(n);let r=sr(e);for(let e of t.set)for(let t of r)s.push(ir.get(e,t));return n}}function sr(t){let e=[t];for(let i=0;i<t.length;i++)for(let s of sr(t.slice(0,i).concat(t.slice(i+1))))e.push(s);return e}function nr(t){let e=Object.create(null);for(let i in t){let s=t[i];Array.isArray(s)||(s=[s]);for(let t of i.split(" "))if(t){let i=[],n=2,r=t;for(let e=0;;){if("..."==r&&e>0&&e+3==t.length){n=1;break}let s=/^"(?:[^"\\]|\\.)*?"|[^\/!]+/.exec(r);if(!s)throw new RangeError("Invalid path: "+t);if(i.push("*"==s[0]?"":'"'==s[0][0]?JSON.parse(s[0]):s[0]),e+=s[0].length,e==t.length)break;let o=t[e++];if(e==t.length&&"!"==o){n=0;break}if("/"!=o)throw new RangeError("Invalid path: "+t);r=t.slice(e)}let o=i.length-1,h=i[o];if(!h)throw new RangeError("Invalid path: "+t);let l=new or(s,n,o>0?i.slice(0,o):null);e[h]=l.sort(e[h])}}return rr.add(e)}const rr=new qn;class or{constructor(t,e,i,s){this.tags=t,this.mode=e,this.context=i,this.next=s}sort(t){return!t||t.depth<this.depth?(this.next=t,this):(t.next=this.sort(t.next),t)}get depth(){return this.context?this.context.length:0}}function hr(t,e){let i=Object.create(null);for(let e of t)if(Array.isArray(e.tag))for(let t of e.tag)i[t.id]=e.class;else i[e.tag.id]=e.class;let{scope:s,all:n=null}=e||{};return{style:t=>{let e=n;for(let s of t)for(let t of s.set){let s=i[t.id];if(s){e=e?e+" "+s:s;break}}return e},scope:s}}function lr(t,e){let i=null;for(let s of t){let t=s.style(e);t&&(i=i?i+" "+t:t)}return i}function ar(t,e,i,s=0,n=t.length){let r=new cr(s,Array.isArray(e)?e:[e],i);r.highlightRange(t.cursor(),s,n,"",r.highlighters),r.flush(n)}class cr{constructor(t,e,i){this.at=t,this.highlighters=e,this.span=i,this.class=""}startSpan(t,e){e!=this.class&&(this.flush(t),t>this.at&&(this.at=t),this.class=e)}flush(t){t>this.at&&this.class&&this.span(this.at,t,this.class)}highlightRange(t,e,i,s,n){let{type:r,from:o,to:h}=t;if(o>=i||h<=e)return;r.isTop&&(n=this.highlighters.filter((t=>!t.scope||t.scope(r))));let l=s,a=r.prop(rr),c=!1;for(;a;){if(!a.context||t.matchContext(a.context)){let t=lr(n,a.tags);t&&(l&&(l+=" "),l+=t,1==a.mode?s+=(s?" ":"")+t:0==a.mode&&(c=!0));break}a=a.next}if(this.startSpan(t.from,l),c)return;let u=t.tree&&t.tree.prop(qn.mounted);if(u&&u.overlay){let r=t.node.enter(u.overlay[0].from+o,1),a=this.highlighters.filter((t=>!t.scope||t.scope(u.tree.type))),c=t.firstChild();for(let f=0,d=o;;f++){let p=f<u.overlay.length?u.overlay[f]:null,g=p?p.from+o:h,O=Math.max(e,d),m=Math.min(i,g);if(O<m&&c)for(;t.from<m&&(this.highlightRange(t,O,m,s,n),this.startSpan(Math.min(i,t.to),l),!(t.to>=g)&&t.nextSibling()););if(!p||g>i)break;d=p.to+o,d>e&&(this.highlightRange(r.cursor(),Math.max(e,p.from+o),Math.min(i,d),s,a),this.startSpan(d,l))}c&&t.parent()}else if(t.firstChild()){do{if(!(t.to<=e)){if(t.from>=i)break;this.highlightRange(t,e,i,s,n),this.startSpan(Math.min(i,t.to),l)}}while(t.nextSibling());t.parent()}}}const ur=tr.define,fr=ur(),dr=ur(),pr=ur(dr),gr=ur(dr),Or=ur(),mr=ur(Or),br=ur(Or),vr=ur(),yr=ur(vr),wr=ur(),xr=ur(),Sr=ur(),kr=ur(Sr),Pr=ur(),$r={comment:fr,lineComment:ur(fr),blockComment:ur(fr),docComment:ur(fr),name:dr,variableName:ur(dr),typeName:pr,tagName:ur(pr),propertyName:gr,attributeName:ur(gr),className:ur(dr),labelName:ur(dr),namespace:ur(dr),macroName:ur(dr),literal:Or,string:mr,docString:ur(mr),character:ur(mr),attributeValue:ur(mr),number:br,integer:ur(br),float:ur(br),bool:ur(Or),regexp:ur(Or),escape:ur(Or),color:ur(Or),url:ur(Or),keyword:wr,self:ur(wr),null:ur(wr),atom:ur(wr),unit:ur(wr),modifier:ur(wr),operatorKeyword:ur(wr),controlKeyword:ur(wr),definitionKeyword:ur(wr),moduleKeyword:ur(wr),operator:xr,derefOperator:ur(xr),arithmeticOperator:ur(xr),logicOperator:ur(xr),bitwiseOperator:ur(xr),compareOperator:ur(xr),updateOperator:ur(xr),definitionOperator:ur(xr),typeOperator:ur(xr),controlOperator:ur(xr),punctuation:Sr,separator:ur(Sr),bracket:kr,angleBracket:ur(kr),squareBracket:ur(kr),paren:ur(kr),brace:ur(kr),content:vr,heading:yr,heading1:ur(yr),heading2:ur(yr),heading3:ur(yr),heading4:ur(yr),heading5:ur(yr),heading6:ur(yr),contentSeparator:ur(vr),list:ur(vr),quote:ur(vr),emphasis:ur(vr),strong:ur(vr),link:ur(vr),monospace:ur(vr),strikethrough:ur(vr),inserted:ur(),deleted:ur(),changed:ur(),invalid:ur(),meta:Pr,documentMeta:ur(Pr),annotation:ur(Pr),processingInstruction:ur(Pr),definition:tr.defineModifier(),constant:tr.defineModifier(),function:tr.defineModifier(),standard:tr.defineModifier(),local:tr.defineModifier(),special:tr.defineModifier()};var Qr;hr([{tag:$r.link,class:"tok-link"},{tag:$r.heading,class:"tok-heading"},{tag:$r.emphasis,class:"tok-emphasis"},{tag:$r.strong,class:"tok-strong"},{tag:$r.keyword,class:"tok-keyword"},{tag:$r.atom,class:"tok-atom"},{tag:$r.bool,class:"tok-bool"},{tag:$r.url,class:"tok-url"},{tag:$r.labelName,class:"tok-labelName"},{tag:$r.inserted,class:"tok-inserted"},{tag:$r.deleted,class:"tok-deleted"},{tag:$r.literal,class:"tok-literal"},{tag:$r.string,class:"tok-string"},{tag:$r.number,class:"tok-number"},{tag:[$r.regexp,$r.escape,$r.special($r.string)],class:"tok-string2"},{tag:$r.variableName,class:"tok-variableName"},{tag:$r.local($r.variableName),class:"tok-variableName tok-local"},{tag:$r.definition($r.variableName),class:"tok-variableName tok-definition"},{tag:$r.special($r.variableName),class:"tok-variableName2"},{tag:$r.definition($r.propertyName),class:"tok-propertyName tok-definition"},{tag:$r.typeName,class:"tok-typeName"},{tag:$r.namespace,class:"tok-namespace"},{tag:$r.className,class:"tok-className"},{tag:$r.macroName,class:"tok-macroName"},{tag:$r.propertyName,class:"tok-propertyName"},{tag:$r.operator,class:"tok-operator"},{tag:$r.comment,class:"tok-comment"},{tag:$r.meta,class:"tok-meta"},{tag:$r.invalid,class:"tok-invalid"},{tag:$r.punctuation,class:"tok-punctuation"}]);const Rr=new qn;class qr{constructor(t,e,i=[]){this.data=t,xt.prototype.hasOwnProperty("tree")||Object.defineProperty(xt.prototype,"tree",{get(){return Cr(this)}}),this.parser=e,this.extension=[jr.of(this),xt.languageData.of(((t,e,i)=>t.facet(Ar(t,e,i))))].concat(i)}isActiveAt(t,e,i=-1){return Ar(t,e,i)==this.data}findRegions(t){let e=t.facet(jr);if((null==e?void 0:e.data)==this.data)return[{from:0,to:t.doc.length}];if(!e||!e.allowsNesting)return[];let i=[],s=(t,e)=>{if(t.prop(Rr)==this.data)return void i.push({from:e,to:e+t.length});let n=t.prop(qn.mounted);if(n){if(n.tree.prop(Rr)==this.data){if(n.overlay)for(let t of n.overlay)i.push({from:t.from+e,to:t.to+e});else i.push({from:e,to:e+t.length});return}if(n.overlay){let t=i.length;if(s(n.tree,n.overlay[0].from+e),i.length>t)return}}for(let i=0;i<t.children.length;i++){let n=t.children[i];n instanceof Dn&&s(n,t.positions[i]+e)}};return s(Cr(t),0),i}get allowsNesting(){return!0}}function Ar(t,e,i){let s=t.facet(jr);if(!s)return null;let n=s.data;if(s.allowsNesting)for(let s=Cr(t).topNode;s;s=s.enter(e,i,Mn.ExcludeBuffers))n=s.type.prop(Rr)||n;return n}qr.setState=ct.define();class Tr extends qr{constructor(t,e){super(t,e),this.parser=e}static define(t){let e=(i=t.languageData,M.define({combine:i?t=>t.concat(i):void 0}));var i;return new Tr(e,t.parser.configure({props:[Rr.add((t=>t.isTop?e:void 0))]}))}configure(t){return new Tr(this.data,this.parser.configure(t))}get allowsNesting(){return this.parser.hasWrappers()}}function Cr(t){let e=t.field(qr.state,!1);return e?e.tree:Dn.empty}class Xr{constructor(t,e=t.length){this.doc=t,this.length=e,this.cursorPos=0,this.string="",this.cursor=t.iter()}syncTo(t){return this.string=this.cursor.next(t-this.cursorPos).value,this.cursorPos=t+this.string.length,this.cursorPos-this.string.length}chunk(t){return this.syncTo(t),this.string}get lineChunks(){return!0}read(t,e){let i=this.cursorPos-this.string.length;return t<i||e>=this.cursorPos?this.doc.sliceString(t,e):this.string.slice(t-i,e-i)}}let Mr=null;class Dr{constructor(t,e,i=[],s,n,r,o,h){this.parser=t,this.state=e,this.fragments=i,this.tree=s,this.treeLen=n,this.viewport=r,this.skipped=o,this.scheduleOn=h,this.parse=null,this.tempSkipped=[]}startParse(){return this.parser.startParse(new Xr(this.state.doc),this.fragments)}work(t,e){return null!=e&&e>=this.state.doc.length&&(e=void 0),this.tree!=Dn.empty&&this.isDone(null!=e?e:this.state.doc.length)?(this.takeTree(),!0):this.withContext((()=>{var i;if("number"==typeof t){let e=Date.now()+t;t=()=>Date.now()>e}for(this.parse||(this.parse=this.startParse()),null!=e&&(null==this.parse.stoppedAt||this.parse.stoppedAt>e)&&e<this.state.doc.length&&this.parse.stopAt(e);;){let s=this.parse.advance();if(s){if(this.fragments=this.withoutTempSkipped(Yn.addTree(s,this.fragments,null!=this.parse.stoppedAt)),this.treeLen=null!==(i=this.parse.stoppedAt)&&void 0!==i?i:this.state.doc.length,this.tree=s,this.parse=null,!(this.treeLen<(null!=e?e:this.state.doc.length)))return!0;this.parse=this.startParse()}if(t())return!1}}))}takeTree(){let t,e;this.parse&&(t=this.parse.parsedPos)>=this.treeLen&&((null==this.parse.stoppedAt||this.parse.stoppedAt>t)&&this.parse.stopAt(t),this.withContext((()=>{for(;!(e=this.parse.advance()););})),this.treeLen=t,this.tree=e,this.fragments=this.withoutTempSkipped(Yn.addTree(this.tree,this.fragments,!0)),this.parse=null)}withContext(t){let e=Mr;Mr=this;try{return t()}finally{Mr=e}}withoutTempSkipped(t){for(let e;e=this.tempSkipped.pop();)t=Er(t,e.from,e.to);return t}changes(t,e){let{fragments:i,tree:s,treeLen:n,viewport:r,skipped:o}=this;if(this.takeTree(),!t.empty){let e=[];if(t.iterChangedRanges(((t,i,s,n)=>e.push({fromA:t,toA:i,fromB:s,toB:n}))),i=Yn.applyChanges(i,e),s=Dn.empty,n=0,r={from:t.mapPos(r.from,-1),to:t.mapPos(r.to,1)},this.skipped.length){o=[];for(let e of this.skipped){let i=t.mapPos(e.from,1),s=t.mapPos(e.to,-1);i<s&&o.push({from:i,to:s})}}}return new Dr(this.parser,e,i,s,n,r,o,this.scheduleOn)}updateViewport(t){if(this.viewport.from==t.from&&this.viewport.to==t.to)return!1;this.viewport=t;let e=this.skipped.length;for(let e=0;e<this.skipped.length;e++){let{from:i,to:s}=this.skipped[e];i<t.to&&s>t.from&&(this.fragments=Er(this.fragments,i,s),this.skipped.splice(e--,1))}return!(this.skipped.length>=e)&&(this.reset(),!0)}reset(){this.parse&&(this.takeTree(),this.parse=null)}skipUntilInView(t,e){this.skipped.push({from:t,to:e})}static getSkippingParser(t){return new class extends class{startParse(t,e,i){return"string"==typeof t&&(t=new Kn(t)),i=i?i.length?i.map((t=>new Rn(t.from,t.to))):[new Rn(0,0)]:[new Rn(0,t.length)],this.createParse(t,e||[],i)}parse(t,e,i){let s=this.startParse(t,e,i);for(;;){let t=s.advance();if(t)return t}}}{createParse(e,i,s){let n=s[0].from,r=s[s.length-1].to;return{parsedPos:n,advance(){let e=Mr;if(e){for(let t of s)e.tempSkipped.push(t);t&&(e.scheduleOn=e.scheduleOn?Promise.all([e.scheduleOn,t]):t)}return this.parsedPos=r,new Dn(Tn.none,[],[],r-n)},stoppedAt:null,stopAt(){}}}}}isDone(t){t=Math.min(t,this.state.doc.length);let e=this.fragments;return this.treeLen>=t&&e.length&&0==e[0].from&&e[0].to>=t}static get(){return Mr}}function Er(t,e,i){return Yn.applyChanges(t,[{fromA:e,toA:i,fromB:e,toB:i}])}class Nr{constructor(t){this.context=t,this.tree=t.tree}apply(t){if(!t.docChanged&&this.tree==this.context.tree)return this;let e=this.context.changes(t.changes,t.state),i=this.context.treeLen==t.startState.doc.length?void 0:Math.max(t.changes.mapPos(this.context.treeLen),e.viewport.to);return e.work(20,i)||e.takeTree(),new Nr(e)}static init(t){let e=Math.min(3e3,t.doc.length),i=new Dr(t.facet(jr).parser,t,[],Dn.empty,0,{from:0,to:e},[],null);return i.work(20,e)||i.takeTree(),new Nr(i)}}qr.state=j.define({create:Nr.init,update(t,e){for(let t of e.effects)if(t.is(qr.setState))return t.value;return e.startState.facet(jr)!=e.state.facet(jr)?Nr.init(e.state):t.apply(e)}});let _r=t=>{let e=setTimeout((()=>t()),500);return()=>clearTimeout(e)};"undefined"!=typeof requestIdleCallback&&(_r=t=>{let e=-1,i=setTimeout((()=>{e=requestIdleCallback(t,{timeout:400})}),100);return()=>e<0?clearTimeout(i):cancelIdleCallback(e)});const Br="undefined"!=typeof navigator&&(null===(Qr=navigator.scheduling)||void 0===Qr?void 0:Qr.isInputPending)?()=>navigator.scheduling.isInputPending():null,Vr=yi.fromClass(class{constructor(t){this.view=t,this.working=null,this.workScheduled=0,this.chunkEnd=-1,this.chunkBudget=-1,this.work=this.work.bind(this),this.scheduleWork()}update(t){let e=this.view.state.field(qr.state).context;(e.updateViewport(t.view.viewport)||this.view.viewport.to>e.treeLen)&&this.scheduleWork(),t.docChanged&&(this.view.hasFocus&&(this.chunkBudget+=50),this.scheduleWork()),this.checkAsyncSchedule(e)}scheduleWork(){if(this.working)return;let{state:t}=this.view,e=t.field(qr.state);e.tree==e.context.tree&&e.context.isDone(t.doc.length)||(this.working=_r(this.work))}work(t){this.working=null;let e=Date.now();if(this.chunkEnd<e&&(this.chunkEnd<0||this.view.hasFocus)&&(this.chunkEnd=e+3e4,this.chunkBudget=3e3),this.chunkBudget<=0)return;let{state:i,viewport:{to:s}}=this.view,n=i.field(qr.state);if(n.tree==n.context.tree&&n.context.isDone(s+1e5))return;let r=Date.now()+Math.min(this.chunkBudget,100,t&&!Br?Math.max(25,t.timeRemaining()-5):1e9),o=n.context.treeLen<s&&i.doc.length>s+1e3,h=n.context.work((()=>Br&&Br()||Date.now()>r),s+(o?0:1e5));this.chunkBudget-=Date.now()-e,(h||this.chunkBudget<=0)&&(n.context.takeTree(),this.view.dispatch({effects:qr.setState.of(new Nr(n.context))})),this.chunkBudget>0&&(!h||o)&&this.scheduleWork(),this.checkAsyncSchedule(n.context)}checkAsyncSchedule(t){t.scheduleOn&&(this.workScheduled++,t.scheduleOn.then((()=>this.scheduleWork())).catch((t=>Oi(this.view.state,t))).then((()=>this.workScheduled--)),t.scheduleOn=null)}destroy(){this.working&&this.working()}isWorking(){return!!(this.working||this.workScheduled>0)}},{eventHandlers:{focus(){this.scheduleWork()}}}),jr=M.define({combine:t=>t.length?t[0]:null,enables:[qr.state,Vr]});class zr{constructor(t,e=[]){this.language=t,this.support=e,this.extension=[t,e]}}class Wr{constructor(t,e){let i;function s(t){let e=zt.newName();return(i||(i=Object.create(null)))["."+e]=t,e}const n=e.scope;this.scope=n instanceof qr?t=>t.prop(Rr)==n.data:n?t=>t==n:void 0,this.style=hr(t.map((t=>({tag:t.tag,class:t.class||s(Object.assign({},t,{tag:null}))}))),{all:"string"==typeof e.all?e.all:e.all?s(e.all):void 0}).style,this.module=i?new zt(i):null,this.themeType=e.themeType}static define(t,e){return new Wr(t,e||{})}}const Ir=M.define(),Lr=M.define({combine:t=>t.length?[t[0]]:null});function Fr(t){let e=t.facet(Ir);return e.length?e:t.facet(Lr)}class Hr{constructor(t){this.markCache=Object.create(null),this.tree=Cr(t.state),this.decorations=this.buildDeco(t,Fr(t.state))}update(t){let e=Cr(t.state),i=Fr(t.state),s=i!=Fr(t.startState);e.length<t.view.viewport.to&&!s&&e.type==this.tree.type?this.decorations=this.decorations.map(t.changes):(e!=this.tree||t.viewportChanged||s)&&(this.tree=e,this.decorations=this.buildDeco(t.view,i))}buildDeco(t,e){if(!e||!this.tree.length)return Ue.none;let i=new Rt;for(let{from:s,to:n}of t.visibleRanges)ar(this.tree,e,((t,e,s)=>{i.add(t,e,this.markCache[s]||(this.markCache[s]=Ue.mark({class:s})))}),s,n);return i.finish()}}const Gr=H.high(yi.fromClass(Hr,{decorations:t=>t.decorations})),Zr=Object.create(null),Ur=[Tn.none],Yr=[],Kr=Object.create(null);for(let[t,e]of[["variable","variableName"],["variable-2","variableName.special"],["string-2","string.special"],["def","variableName.definition"],["tag","typeName"],["attribute","propertyName"],["type","typeName"],["builtin","variableName.standard"],["qualifier","modifier"],["error","invalid"],["header","heading"],["property","propertyName"]])Kr[t]=to(Zr,e);function Jr(t,e){Yr.indexOf(t)>-1||(Yr.push(t),console.warn(e))}function to(t,e){let i=null;for(let s of e.split(".")){let e=t[s]||$r[s];e?"function"==typeof e?i?i=e(i):Jr(s,`Modifier ${s} used at start of tag`):i?Jr(s,`Tag ${s} used as modifier`):i=e:Jr(s,`Unknown highlighting tag ${s}`)}if(!i)return 0;let s=e.replace(/ /g,"_"),n=Tn.define({id:Ur.length,name:s,props:[nr({[s]:i})]});return Ur.push(n),n.id}const eo=1024;let io=0;const so=new WeakMap;class no{constructor({deserialize:t}={}){this.id=io++,this.deserialize=t||(()=>{throw new Error("This node type doesn't define a deserialize function")})}static string(){return new no({deserialize:t=>t})}static number(){return new no({deserialize:Number})}static flag(){return new no({deserialize:()=>!0})}set(t,e){return t[this.id]=e,t}add(t){return"function"!=typeof t&&(t=oo.match(t)),e=>{let i=t(e);return void 0===i?null:[this,i]}}}no.closedBy=new no({deserialize:t=>t.split(" ")}),no.openedBy=new no({deserialize:t=>t.split(" ")}),no.group=new no({deserialize:t=>t.split(" ")});const ro=Object.create(null);class oo{constructor(t,e,i,s=0){this.name=t,this.props=e,this.id=i,this.flags=s}static define(t){let e=t.props&&t.props.length?Object.create(null):ro,i=(t.top?1:0)|(t.skipped?2:0)|(t.error?4:0)|(null==t.name?8:0),s=new oo(t.name||"",e,t.id,i);if(t.props)for(let i of t.props)Array.isArray(i)||(i=i(s)),i&&i[0].set(e,i[1]);return s}prop(t){return this.props[t.id]}get isTop(){return(1&this.flags)>0}get isSkipped(){return(2&this.flags)>0}get isError(){return(4&this.flags)>0}get isAnonymous(){return(8&this.flags)>0}is(t){if("string"==typeof t){if(this.name==t)return!0;let e=this.prop(no.group);return!!e&&e.indexOf(t)>-1}return this.id==t}static match(t){let e=Object.create(null);for(let i in t)for(let s of i.split(" "))e[s]=t[i];return t=>{for(let i=t.prop(no.group),s=-1;s<(i?i.length:0);s++){let n=e[s<0?t.name:i[s]];if(n)return n}}}}oo.none=new oo("",Object.create(null),0,8);class ho{constructor(t){this.types=t;for(let e=0;e<t.length;e++)if(t[e].id!=e)throw new RangeError("Node type ids should correspond to array positions when creating a node set")}extend(...t){let e=[];for(let i of this.types){let s=null;for(let e of t){let t=e(i);t&&(s||(s=Object.assign({},i.props)),t[0].set(s,t[1]))}e.push(s?new oo(i.name,s,i.id,i.flags):i)}return new ho(e)}}class lo{constructor(t,e,i,s){this.type=t,this.children=e,this.positions=i,this.length=s}toString(){let t=this.children.map((t=>t.toString())).join();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(t,e=0){let i=null!=t&&so.get(this)||this.topNode,s=new Oo(i);return null!=t&&(s.moveTo(t,e),so.set(this,s._tree)),s}fullCursor(){return new Oo(this.topNode,!0)}get topNode(){return new uo(this,0,0,null)}resolve(t,e=0){return this.cursor(t,e).node}iterate(t){let{enter:e,leave:i,from:s=0,to:n=this.length}=t;for(let t=this.cursor();;){let r=!1;if(t.from<=n&&t.to>=s&&(t.type.isAnonymous||!1!==e(t.type,t.from,t.to))){if(t.firstChild())continue;t.type.isAnonymous||(r=!0)}for(;r&&i&&i(t.type,t.from,t.to),r=t.type.isAnonymous,!t.nextSibling();){if(!t.parent())return;r=!0}}}balance(t=eo){return this.children.length<=vo?this:yo(this.type,oo.none,this.children,this.positions,0,this.children.length,0,t,this.length,0)}static build(t){return function(t){var e;let{buffer:i,nodeSet:s,topID:n=0,maxBufferLength:r=eo,reused:o=[],minRepeatType:h=s.types.length}=t,l=Array.isArray(i)?new bo(i,i.length):i,a=s.types,c=0;function u(t,e,i,n,p){let{id:g,start:O,end:m,size:b}=l,v=O-t;if(b<0)return-1==b?(i.push(o[g]),n.push(v)):c=g,void l.next();let y,w,x=a[g];if(m-O<=r&&(w=f(l.pos-e,p))){let e=new Uint16Array(w.size-w.skip),i=l.pos-w.size,n=e.length;for(;l.pos>i;)n=d(w.start,e,n,p);y=new co(e,m-w.start,s,p<0?oo.none:a[p]),v=w.start-t}else{let t=l.pos-b;l.next();let e=[],i=[],s=g>=h?g:-1;for(;l.pos>t;)l.id==s?l.next():u(O,t,e,i,s);e.reverse(),i.reverse(),y=s>-1&&e.length>vo?yo(x,x,e,i,0,e.length,0,r,m-O,c):ao(new lo(x,e,i,m-O),c)}i.push(y),n.push(v)}function f(t,e){let i=l.fork(),s=0,n=0,o=0,a=i.end-r,c={size:0,start:0,skip:0};t:for(let r=i.pos-t;i.pos>r;){if(i.id==e){c.size=s,c.start=n,c.skip=o,o+=4,s+=4,i.next();continue}let t=i.size,l=i.pos-t;if(t<0||l<r||i.start<a)break;let u=i.id>=h?4:0,f=i.start;for(i.next();i.pos>l;){if(i.size<0)break t;i.id>=h&&(u+=4),i.next()}n=f,s+=t,o+=u}return(e<0||s==t)&&(c.size=s,c.start=n,c.skip=o),c.size>4?c:void 0}function d(t,e,i,s){let{id:n,start:r,end:o,size:a}=l;if(l.next(),n==s)return i;let c=i;if(a>4){let n=l.pos-(a-4);for(;l.pos>n;)i=d(t,e,i,s)}return n<h&&(e[--i]=c,e[--i]=o-t,e[--i]=r-t,e[--i]=n),i}let p=[],g=[];for(;l.pos>0;)u(t.start||0,0,p,g,-1);let O=null!==(e=t.length)&&void 0!==e?e:p.length?g[0]+p[0].length:0;return new lo(a[n],p.reverse(),g.reverse(),O)}(t)}}function ao(t,e){return e&&(t.contextHash=e),t}lo.empty=new lo(oo.none,[],[],0);class co{constructor(t,e,i,s=oo.none){this.buffer=t,this.length=e,this.set=i,this.type=s}toString(){let t=[];for(let e=0;e<this.buffer.length;)t.push(this.childString(e)),e=this.buffer[e+3];return t.join(",")}childString(t){let e=this.buffer[t],i=this.buffer[t+3],s=this.set.types[e],n=s.name;if(/\W/.test(n)&&!s.isError&&(n=JSON.stringify(n)),i==(t+=4))return n;let r=[];for(;t<i;)r.push(this.childString(t)),t=this.buffer[t+3];return n+"("+r.join(",")+")"}findChild(t,e,i,s){let{buffer:n}=this,r=-1;for(let o=t;o!=e;o=n[o+3])if(-1e8!=s){let t=n[o+1],e=n[o+2];if(i>0){if(e>s&&(r=o),e>s)break}else if(t<s&&(r=o),e>=s)break}else if(r=o,i>0)break;return r}}class uo{constructor(t,e,i,s){this.node=t,this.from=e,this.index=i,this._parent=s}get type(){return this.node.type}get name(){return this.node.type.name}get to(){return this.from+this.node.length}nextChild(t,e,i,s=!1){for(let n=this;;){for(let{children:r,positions:o}=n.node,h=e>0?r.length:-1;t!=h;t+=e){let h=r[t],l=o[t]+n.from;if(-1e8==i||!(e<0?l>=i:l+h.length<=i))if(h instanceof co){let s=h.findChild(0,h.buffer.length,e,-1e8==i?-1e8:i-l);if(s>-1)return new go(new po(n,h,t,l),null,s)}else if(s||!h.type.isAnonymous||mo(h)){let r=new uo(h,l,t,n);return s||!r.type.isAnonymous?r:r.nextChild(e<0?h.children.length-1:0,e,i)}}if(s||!n.type.isAnonymous)return null;if(t=n.index+e,n=n._parent,!n)return null}}get firstChild(){return this.nextChild(0,1,-1e8)}get lastChild(){return this.nextChild(this.node.children.length-1,-1,-1e8)}childAfter(t){return this.nextChild(0,1,t)}childBefore(t){return this.nextChild(this.node.children.length-1,-1,t)}nextSignificantParent(){let t=this;for(;t.type.isAnonymous&&t._parent;)t=t._parent;return t}get parent(){return this._parent?this._parent.nextSignificantParent():null}get nextSibling(){return this._parent?this._parent.nextChild(this.index+1,1,-1):null}get prevSibling(){return this._parent?this._parent.nextChild(this.index-1,-1,-1):null}get cursor(){return new Oo(this)}resolve(t,e=0){return this.cursor.moveTo(t,e).node}getChild(t,e=null,i=null){let s=fo(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return fo(this,t,e,i)}toString(){return this.node.toString()}}function fo(t,e,i,s){let n=t.cursor,r=[];if(!n.firstChild())return r;if(null!=i)for(;!n.type.is(i);)if(!n.nextSibling())return r;for(;;){if(null!=s&&n.type.is(s))return r;if(n.type.is(e)&&r.push(n.node),!n.nextSibling())return null==s?r:[]}}class po{constructor(t,e,i,s){this.parent=t,this.buffer=e,this.index=i,this.start=s}}class go{constructor(t,e,i){this.context=t,this._parent=e,this.index=i,this.type=t.buffer.set.types[t.buffer.buffer[i]]}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]}child(t,e){let{buffer:i}=this.context,s=i.findChild(this.index+4,i.buffer[this.index+3],t,-1e8==e?-1e8:e-this.context.start);return s<0?null:new go(this.context,this,s)}get firstChild(){return this.child(1,-1e8)}get lastChild(){return this.child(-1,-1e8)}childAfter(t){return this.child(1,t)}childBefore(t){return this.child(-1,t)}get parent(){return this._parent||this.context.parent.nextSignificantParent()}externalSibling(t){return this._parent?null:this.context.parent.nextChild(this.context.index+t,t,-1)}get nextSibling(){let{buffer:t}=this.context,e=t.buffer[this.index+3];return e<(this._parent?t.buffer[this._parent.index+3]:t.buffer.length)?new go(this.context,this._parent,e):this.externalSibling(1)}get prevSibling(){let{buffer:t}=this.context,e=this._parent?this._parent.index+4:0;return this.index==e?this.externalSibling(-1):new go(this.context,this._parent,t.findChild(e,this.index,-1,-1e8))}get cursor(){return new Oo(this)}resolve(t,e=0){return this.cursor.moveTo(t,e).node}toString(){return this.context.buffer.childString(this.index)}getChild(t,e=null,i=null){let s=fo(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return fo(this,t,e,i)}}class Oo{constructor(t,e=!1){if(this.full=e,this.buffer=null,this.stack=[],this.index=0,this.bufferNode=null,t instanceof uo)this.yieldNode(t);else{this._tree=t.context.parent,this.buffer=t.context;for(let e=t._parent;e;e=e._parent)this.stack.unshift(e.index);this.bufferNode=t,this.yieldBuf(t.index)}}get name(){return this.type.name}yieldNode(t){return!!t&&(this._tree=t,this.type=t.type,this.from=t.from,this.to=t.to,!0)}yieldBuf(t,e){this.index=t;let{start:i,buffer:s}=this.buffer;return this.type=e||s.set.types[s.buffer[t]],this.from=i+s.buffer[t+1],this.to=i+s.buffer[t+2],!0}yield(t){return!!t&&(t instanceof uo?(this.buffer=null,this.yieldNode(t)):(this.buffer=t.context,this.yieldBuf(t.index,t.type)))}toString(){return this.buffer?this.buffer.buffer.childString(this.index):this._tree.toString()}enter(t,e){if(!this.buffer)return this.yield(this._tree.nextChild(t<0?this._tree.node.children.length-1:0,t,e,this.full));let{buffer:i}=this.buffer,s=i.findChild(this.index+4,i.buffer[this.index+3],t,-1e8==e?-1e8:e-this.buffer.start);return!(s<0)&&(this.stack.push(this.index),this.yieldBuf(s))}firstChild(){return this.enter(1,-1e8)}lastChild(){return this.enter(-1,-1e8)}childAfter(t){return this.enter(1,t)}childBefore(t){return this.enter(-1,t)}parent(){if(!this.buffer)return this.yieldNode(this.full?this._tree._parent:this._tree.parent);if(this.stack.length)return this.yieldBuf(this.stack.pop());let t=this.full?this.buffer.parent:this.buffer.parent.nextSignificantParent();return this.buffer=null,this.yieldNode(t)}sibling(t){if(!this.buffer)return!!this._tree._parent&&this.yield(this._tree._parent.nextChild(this._tree.index+t,t,-1e8,this.full));let{buffer:e}=this.buffer,i=this.stack.length-1;if(t<0){let t=i<0?0:this.stack[i]+4;if(this.index!=t)return this.yieldBuf(e.findChild(t,this.index,-1,-1e8))}else{let t=e.buffer[this.index+3];if(t<(i<0?e.buffer.length:e.buffer[this.stack[i]+3]))return this.yieldBuf(t)}return i<0&&this.yield(this.buffer.parent.nextChild(this.buffer.index+t,t,-1e8,this.full))}nextSibling(){return this.sibling(1)}prevSibling(){return this.sibling(-1)}atLastNode(t){let e,i,{buffer:s}=this;if(s){if(t>0){if(this.index<s.buffer.buffer.length)return!1}else for(let t=0;t<this.index;t++)if(s.buffer.buffer[t+3]<this.index)return!1;({index:e,parent:i}=s)}else({index:e,_parent:i}=this._tree);for(;i;({index:e,_parent:i}=i))for(let s=e+t,n=t<0?-1:i.node.children.length;s!=n;s+=t){let t=i.node.children[s];if(this.full||!t.type.isAnonymous||t instanceof co||mo(t))return!1}return!0}move(t){if(this.enter(t,-1e8))return!0;for(;;){if(this.sibling(t))return!0;if(this.atLastNode(t)||!this.parent())return!1}}next(){return this.move(1)}prev(){return this.move(-1)}moveTo(t,e=0){for(;(this.from==this.to||(e<1?this.from>=t:this.from>t)||(e>-1?this.to<=t:this.to<t))&&this.parent(););for(;e<0?this.childBefore(t):this.childAfter(t);)if(this.from==this.to||(e<1?this.from>=t:this.from>t)||(e>-1?this.to<=t:this.to<t)){this.parent();break}return this}get node(){if(!this.buffer)return this._tree;let t=this.bufferNode,e=null,i=0;if(t&&t.context==this.buffer)t:for(let s=this.index,n=this.stack.length;n>=0;){for(let r=t;r;r=r._parent)if(r.index==s){if(s==this.index)return r;e=r,i=n+1;break t}s=this.stack[--n]}for(let t=i;t<this.stack.length;t++)e=new go(this.buffer,e,this.stack[t]);return this.bufferNode=new go(this.buffer,e,this.index)}get tree(){return this.buffer?null:this._tree.node}}function mo(t){return t.children.some((t=>!t.type.isAnonymous||t instanceof co||mo(t)))}class bo{constructor(t,e){this.buffer=t,this.index=e}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 bo(this.buffer,this.index)}}const vo=8;function yo(t,e,i,s,n,r,o,h,l,a){let c=[],u=[];if(l<=h)for(let t=n;t<r;t++)c.push(i[t]),u.push(s[t]-o);else{let t=Math.max(h,Math.ceil(1.5*l/vo));for(let l=n;l<r;){let n=l,f=s[l];for(l++;l<r;l++){if(s[l]+i[l].length-f>t)break}if(l==n+1){let s=i[n];if(s instanceof lo&&s.type==e&&s.length>t<<1){for(let t=0;t<s.children.length;t++)c.push(s.children[t]),u.push(s.positions[t]+f-o);continue}c.push(s)}else if(l==n+1)c.push(i[n]);else{let t=yo(e,e,i,s,n,l,f,h,s[l-1]+i[l-1].length-f,a);e==oo.none||wo(t.children,e)||(t=ao(new lo(oo.none,t.children,t.positions,t.length),a)),c.push(t)}u.push(f-o)}}return ao(new lo(t,c,u,l),a)}function wo(t,e){for(let i of t)if(i.type==e)return!0;return!1}function xo(t){return new So(t)}class So{constructor(t,e=t.length){this.string=t,this.length=e}get(t){return t<0||t>=this.length?-1:this.string.charCodeAt(t)}lineAfter(t){if(t<0)return"";let e=this.string.indexOf("\n",t);return this.string.slice(t,e<0?this.length:Math.min(e,this.length))}read(t,e){return this.string.slice(t,Math.min(this.length,e))}clip(t){return new So(this.string,t)}}class ko{constructor(t,e,i,s,n,r,o,h,l,a){this.p=t,this.stack=e,this.state=i,this.reducePos=s,this.pos=n,this.score=r,this.buffer=o,this.bufferBase=h,this.curContext=l,this.parent=a}toString(){return`[${this.stack.filter(((t,e)=>e%3==0)).concat(this.state)}]@${this.pos}${this.score?"!"+this.score:""}`}static start(t,e,i=0){let s=t.parser.context;return new ko(t,[],e,i,i,0,[],0,s?new Po(s,s.start):null,null)}get context(){return this.curContext?this.curContext.context:null}pushState(t,e){this.stack.push(this.state,e,this.bufferBase+this.buffer.length),this.state=t}reduce(t){let e=t>>19,i=65535&t,{parser:s}=this.p,n=s.dynamicPrecedence(i);if(n&&(this.score+=n),0==e)return i<s.minRepeatTerm&&this.storeNode(i,this.reducePos,this.reducePos,4,!0),this.pushState(s.getGoto(this.state,i,!0),this.reducePos),void this.reduceContext(i);let r=this.stack.length-3*(e-1)-(262144&t?6:0),o=this.stack[r-2],h=this.stack[r-1],l=this.bufferBase+this.buffer.length-h;if(i<s.minRepeatTerm||131072&t){let t=s.stateFlag(this.state,1)?this.pos:this.reducePos;this.storeNode(i,o,t,l+4,!0)}if(262144&t)this.state=this.stack[r];else{let t=this.stack[r-3];this.state=s.getGoto(t,i,!0)}for(;this.stack.length>r;)this.stack.pop();this.reduceContext(i)}storeNode(t,e,i,s=4,n=!1){if(0==t){let t=this,s=this.buffer.length;if(0==s&&t.parent&&(s=t.bufferBase-t.parent.bufferBase,t=t.parent),s>0&&0==t.buffer[s-4]&&t.buffer[s-1]>-1){if(e==i)return;if(t.buffer[s-2]>=e)return void(t.buffer[s-2]=i)}}if(n&&this.pos!=i){let n=this.buffer.length;if(n>0&&0!=this.buffer[n-4])for(;n>0&&this.buffer[n-2]>i;)this.buffer[n]=this.buffer[n-4],this.buffer[n+1]=this.buffer[n-3],this.buffer[n+2]=this.buffer[n-2],this.buffer[n+3]=this.buffer[n-1],n-=4,s>4&&(s-=4);this.buffer[n]=t,this.buffer[n+1]=e,this.buffer[n+2]=i,this.buffer[n+3]=s}else this.buffer.push(t,e,i,s)}shift(t,e,i){if(131072&t)this.pushState(65535&t,this.pos);else if(0==(262144&t)){let s=this.pos,n=t,{parser:r}=this.p;(i>this.pos||e<=r.maxNode)&&(this.pos=i,r.stateFlag(n,1)||(this.reducePos=i)),this.pushState(n,s),e<=r.maxNode&&this.buffer.push(e,s,i,4),this.shiftContext(e)}else e<=this.p.parser.maxNode&&this.buffer.push(e,this.pos,i,4),this.pos=i}apply(t,e,i){65536&t?this.reduce(t):this.shift(t,e,i)}useNode(t,e){let i=this.p.reused.length-1;(i<0||this.p.reused[i]!=t)&&(this.p.reused.push(t),i++);let s=this.pos;this.reducePos=this.pos=s+t.length,this.pushState(e,s),this.buffer.push(i,s,this.reducePos,-1),this.curContext&&this.updateContext(this.curContext.tracker.reuse(this.curContext.context,t,this.p.input,this))}split(){let t=this,e=t.buffer.length;for(;e>0&&t.buffer[e-2]>t.reducePos;)e-=4;let i=t.buffer.slice(e),s=t.bufferBase+e;for(;t&&s==t.bufferBase;)t=t.parent;return new ko(this.p,this.stack.slice(),this.state,this.reducePos,this.pos,this.score,i,s,this.curContext,t)}recoverByDelete(t,e){let i=t<=this.p.parser.maxNode;i&&this.storeNode(t,this.pos,e),this.storeNode(0,this.pos,e,i?8:4),this.pos=this.reducePos=e,this.score-=200}canShift(t){for(let e=new Qo(this);;){let i=this.p.parser.stateSlot(e.top,4)||this.p.parser.hasAction(e.top,t);if(0==(65536&i))return!0;if(0==i)return!1;e.reduce(i)}}get ruleStart(){for(let t=this.state,e=this.stack.length;;){let i=this.p.parser.stateSlot(t,5);if(!(65536&i))return 0;if(e-=3*(i>>19),(65535&i)<this.p.parser.minRepeatTerm)return this.stack[e+1];t=this.stack[e]}}startOf(t,e){let i=this.state,s=this.stack.length,{parser:n}=this.p;for(;;){let r=n.stateSlot(i,5),o=r>>19,h=65535&r;if(t.indexOf(h)>-1){let t=s-3*(r>>19),i=this.stack[t+1];if(null==e||e>i)return i}if(0==s)return null;0==o?(s-=3,i=this.stack[s]):(s-=3*(o-1),i=n.getGoto(this.stack[s-3],h,!0))}}recoverByInsert(t){if(this.stack.length>=300)return[];let e=this.p.parser.nextStates(this.state);if(e.length>8||this.stack.length>=120){let i=[];for(let s,n=0;n<e.length;n+=2)(s=e[n+1])!=this.state&&this.p.parser.hasAction(s,t)&&i.push(e[n],s);if(this.stack.length<120)for(let t=0;i.length<8&&t<e.length;t+=2){let s=e[t+1];i.some(((t,e)=>1&e&&t==s))||i.push(e[t],s)}e=i}let i=[];for(let t=0;t<e.length&&i.length<4;t+=2){let s=e[t+1];if(s==this.state)continue;let n=this.split();n.storeNode(0,n.pos,n.pos,4,!0),n.pushState(s,this.pos),n.shiftContext(e[t]),n.score-=200,i.push(n)}return i}forceReduce(){let t=this.p.parser.stateSlot(this.state,5);return 0!=(65536&t)&&(this.p.parser.validAction(this.state,t)||(this.storeNode(0,this.reducePos,this.reducePos,4,!0),this.score-=100),this.reduce(t),!0)}forceAll(){for(;!this.p.parser.stateFlag(this.state,2)&&this.forceReduce(););return this}get deadEnd(){if(3!=this.stack.length)return!1;let{parser:t}=this.p;return 65535==t.data[t.stateSlot(this.state,1)]&&!t.stateSlot(this.state,4)}restart(){this.state=this.stack[0],this.stack.length=0}sameState(t){if(this.state!=t.state||this.stack.length!=t.stack.length)return!1;for(let e=0;e<this.stack.length;e+=3)if(this.stack[e]!=t.stack[e])return!1;return!0}get parser(){return this.p.parser}dialectEnabled(t){return this.p.parser.dialect.flags[t]}shiftContext(t){this.curContext&&this.updateContext(this.curContext.tracker.shift(this.curContext.context,t,this.p.input,this))}reduceContext(t){this.curContext&&this.updateContext(this.curContext.tracker.reduce(this.curContext.context,t,this.p.input,this))}emitContext(){let t=this.curContext;if(!t.tracker.strict)return;let e=this.buffer.length-1;(e<0||-2!=this.buffer[e])&&this.buffer.push(t.hash,this.reducePos,this.reducePos,-2)}updateContext(t){if(t!=this.curContext.context){let e=new Po(this.curContext.tracker,t);e.hash!=this.curContext.hash&&this.emitContext(),this.curContext=e}}}class Po{constructor(t,e){this.tracker=t,this.context=e,this.hash=t.hash(e)}}var $o;!function(t){t[t.Token=200]="Token",t[t.Reduce=100]="Reduce",t[t.MaxNext=4]="MaxNext",t[t.MaxInsertStackDepth=300]="MaxInsertStackDepth",t[t.DampenInsertStackDepth=120]="DampenInsertStackDepth"}($o||($o={}));class Qo{constructor(t){this.stack=t,this.top=t.state,this.rest=t.stack,this.offset=this.rest.length}reduce(t){let e=65535&t,i=t>>19;0==i?(this.rest==this.stack.stack&&(this.rest=this.rest.slice()),this.rest.push(this.top,0,0),this.offset+=3):this.offset-=3*(i-1);let s=this.stack.p.parser.getGoto(this.rest[this.offset-3],e,!0);this.top=s}}class Ro{constructor(t,e,i){this.stack=t,this.pos=e,this.index=i,this.buffer=t.buffer,0==this.index&&this.maybeNext()}static create(t){return new Ro(t,t.bufferBase+t.buffer.length,t.buffer.length)}maybeNext(){let t=this.stack.parent;null!=t&&(this.index=this.stack.bufferBase-t.bufferBase,this.stack=t,this.buffer=t.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,0==this.index&&this.maybeNext()}fork(){return new Ro(this.stack,this.pos,this.index)}}class qo{constructor(){this.start=-1,this.value=-1,this.end=-1}accept(t,e){this.value=t,this.end=e}}class Ao{constructor(t,e){this.data=t,this.id=e}token(t,e,i){!function(t,e,i,s,n){let r=0,o=1<<n,h=s.p.parser.dialect;t:for(let n=i.start;0!=(o&t[r]);){let l=t[r+1];for(let e=r+3;e<l;e+=2)if((t[e+1]&o)>0){let r=t[e];if(h.allows(r)&&(-1==i.value||i.value==r||s.p.parser.overrides(r,i.value))){i.accept(r,n);break}}let a=e.get(n++);for(let e=0,i=t[r+2];e<i;){let s=e+i>>1,n=l+s+(s<<1),o=t[n],h=t[n+1];if(a<o)i=s;else{if(!(a>=h)){r=t[n+2];continue t}e=s+1}}break}}(this.data,t,e,i,this.id)}}function To(t,e=Uint16Array){if("string"!=typeof t)return t;let i=null;for(let s=0,n=0;s<t.length;){let r=0;for(;;){let e=t.charCodeAt(s++),i=!1;if(126==e){r=65535;break}e>=92&&e--,e>=34&&e--;let n=e-32;if(n>=46&&(n-=46,i=!0),r+=n,i)break;r*=46}i?i[n++]=r:i=new e(r)}return i}Ao.prototype.contextual=Ao.prototype.fallback=Ao.prototype.extend=!1;const Co="undefined"!=typeof process&&/\bparse\b/.test(process.env.LOG);let Xo=null;function Mo(t,e,i){let s=t.cursor(e);for(;;)if(!(i<0?s.childBefore(e):s.childAfter(e)))for(;;){if((i<0?s.to<e:s.from>e)&&!s.type.isError)return i<0?Math.max(0,Math.min(s.to-1,e-5)):Math.min(t.length,Math.max(s.from+1,e+5));if(i<0?s.prevSibling():s.nextSibling())break;if(!s.parent())return i<0?0:t.length}}class Do{constructor(t){this.fragments=t,this.i=0,this.fragment=null,this.safeFrom=-1,this.safeTo=-1,this.trees=[],this.start=[],this.index=[],this.nextFragment()}nextFragment(){let t=this.fragment=this.i==this.fragments.length?null:this.fragments[this.i++];if(t){for(this.safeFrom=t.openStart?Mo(t.tree,t.from+t.offset,1)-t.offset:t.from,this.safeTo=t.openEnd?Mo(t.tree,t.to+t.offset,-1)-t.offset:t.to;this.trees.length;)this.trees.pop(),this.start.pop(),this.index.pop();this.trees.push(t.tree),this.start.push(-t.offset),this.index.push(0),this.nextStart=this.safeFrom}else this.nextStart=1e9}nodeAt(t){if(t<this.nextStart)return null;for(;this.fragment&&this.safeTo<=t;)this.nextFragment();if(!this.fragment)return null;for(;;){let e=this.trees.length-1;if(e<0)return this.nextFragment(),null;let i=this.trees[e],s=this.index[e];if(s==i.children.length){this.trees.pop(),this.start.pop(),this.index.pop();continue}let n=i.children[s],r=this.start[e]+i.positions[s];if(r>t)return this.nextStart=r,null;if(r==t&&r+n.length<=this.safeTo)return r==t&&r>=this.safeFrom?n:null;n instanceof co?(this.index[e]++,this.nextStart=r+n.length):(this.index[e]++,r+n.length>=t&&(this.trees.push(n),this.start.push(r),this.index.push(0)))}}}class Eo extends qo{constructor(){super(...arguments),this.extended=-1,this.mask=0,this.context=0}clear(t){this.start=t,this.value=this.extended=-1}}const No=new qo;class _o{constructor(t){this.tokens=[],this.mainToken=No,this.actions=[],this.tokens=t.tokenizers.map((t=>new Eo))}getActions(t,e){let i=0,s=null,{parser:n}=t.p,{tokenizers:r}=n,o=n.stateSlot(t.state,3),h=t.curContext?t.curContext.hash:0;for(let n=0;n<r.length;n++){if(0==(1<<n&o))continue;let l=r[n],a=this.tokens[n];if((!s||l.fallback)&&((l.contextual||a.start!=t.pos||a.mask!=o||a.context!=h)&&(this.updateCachedToken(a,l,t,e),a.mask=o,a.context=h),0!=a.value)){let e=i;if(a.extended>-1&&(i=this.addActions(t,a.extended,a.end,i)),i=this.addActions(t,a.value,a.end,i),!l.extend&&(s=a,i>e))break}}for(;this.actions.length>i;)this.actions.pop();return s||(s=No,s.start=t.pos,t.pos==e.length?s.accept(t.p.parser.eofTerm,t.pos):s.accept(0,t.pos+1)),this.mainToken=s,this.actions}updateCachedToken(t,e,i,s){if(t.clear(i.pos),e.token(s,t,i),t.value>-1){let{parser:e}=i.p;for(let n=0;n<e.specialized.length;n++)if(e.specialized[n]==t.value){let r=e.specializers[n](s.read(t.start,t.end),i);if(r>=0&&i.p.parser.dialect.allows(r>>1)){0==(1&r)?t.value=r>>1:t.extended=r>>1;break}}}else i.pos==s.length?t.accept(i.p.parser.eofTerm,i.pos):t.accept(0,i.pos+1)}putAction(t,e,i,s){for(let e=0;e<s;e+=3)if(this.actions[e]==t)return s;return this.actions[s++]=t,this.actions[s++]=e,this.actions[s++]=i,s}addActions(t,e,i,s){let{state:n}=t,{parser:r}=t.p,{data:o}=r;for(let t=0;t<2;t++)for(let h=r.stateSlot(n,t?2:1);;h+=3){if(65535==o[h]){if(1!=o[h+1]){0==s&&2==o[h+1]&&(s=this.putAction(Io(o,h+1),e,i,s));break}h=Io(o,h+2)}o[h]==e&&(s=this.putAction(Io(o,h+1),e,i,s))}return s}}var Bo;!function(t){t[t.Distance=5]="Distance",t[t.MaxRemainingPerStep=3]="MaxRemainingPerStep",t[t.MinBufferLengthPrune=200]="MinBufferLengthPrune",t[t.ForceReduceLimit=10]="ForceReduceLimit"}(Bo||(Bo={}));class Vo{constructor(t,e,i,s){this.parser=t,this.input=e,this.startPos=i,this.context=s,this.pos=0,this.recovering=0,this.nextStackID=9812,this.nested=null,this.nestEnd=0,this.nestWrap=null,this.reused=[],this.tokens=new _o(t),this.topTerm=t.top[1],this.stacks=[ko.start(this,t.top[0],this.startPos)];let n=null==s?void 0:s.fragments;this.fragments=n&&n.length?new Do(n):null}advance(){if(this.nested){let t=this.nested.advance();return this.pos=this.nested.pos,t&&(this.finishNested(this.stacks[0],t),this.nested=null),null}let t,e,i,s=this.stacks,n=this.pos,r=this.stacks=[];for(let o=0;o<s.length;o++){let h,l=s[o];for(;;){if(l.pos>n)r.push(l);else if(h=this.checkNest(l))(!i||i.stack.score<l.score)&&(i=h);else{if(this.advanceStack(l,r,s))continue;{t||(t=[],e=[]),t.push(l);let i=this.tokens.mainToken;e.push(i.value,i.end)}}break}}if(i)return this.startNested(i),null;if(!r.length){let e=t&&function(t){let e=null;for(let i of t)i.pos==i.p.input.length&&i.p.parser.stateFlag(i.state,2)&&(!e||e.score<i.score)&&(e=i);return e}(t);if(e)return this.stackToTree(e);if(this.parser.strict)throw Co&&t&&console.log("Stuck with token "+this.parser.getName(this.tokens.mainToken.value)),new SyntaxError("No parse at "+n);this.recovering||(this.recovering=5)}if(this.recovering&&t){let i=this.runRecovery(t,e,r);if(i)return this.stackToTree(i.forceAll())}if(this.recovering){let t=1==this.recovering?1:3*this.recovering;if(r.length>t)for(r.sort(((t,e)=>e.score-t.score));r.length>t;)r.pop();r.some((t=>t.reducePos>n))&&this.recovering--}else if(r.length>1)t:for(let t=0;t<r.length-1;t++){let e=r[t];for(let i=t+1;i<r.length;i++){let s=r[i];if(e.sameState(s)||e.buffer.length>200&&s.buffer.length>200){if(!((e.score-s.score||e.buffer.length-s.buffer.length)>0)){r.splice(t--,1);continue t}r.splice(i--,1)}}}this.pos=r[0].pos;for(let t=1;t<r.length;t++)r[t].pos<this.pos&&(this.pos=r[t].pos);return null}advanceStack(t,e,i){let s=t.pos,{input:n,parser:r}=this,o=Co?this.stackID(t)+" -> ":"";if(this.fragments){let e=t.curContext&&t.curContext.tracker.strict,i=e?t.curContext.hash:0;for(let n=this.fragments.nodeAt(s);n;){let s=this.parser.nodeSet.types[n.type.id]==n.type?r.getGoto(t.state,n.type.id):-1;if(s>-1&&n.length&&(!e||(n.contextHash||0)==i))return t.useNode(n,s),Co&&console.log(o+this.stackID(t)+` (via reuse of ${r.getName(n.type.id)})`),!0;if(!(n instanceof lo)||0==n.children.length||n.positions[0]>0)break;let h=n.children[0];if(!(h instanceof lo))break;n=h}}let h=r.stateSlot(t.state,4);if(h>0)return t.reduce(h),Co&&console.log(o+this.stackID(t)+` (via always-reduce ${r.getName(65535&h)})`),!0;let l=this.tokens.getActions(t,n);for(let n=0;n<l.length;){let h=l[n++],a=l[n++],c=l[n++],u=n==l.length||!i,f=u?t:t.split();if(f.apply(h,a,c),Co&&console.log(o+this.stackID(f)+` (via ${0==(65536&h)?"shift":`reduce of ${r.getName(65535&h)}`} for ${r.getName(a)} @ ${s}${f==t?"":", split"})`),u)return!0;f.pos>s?e.push(f):i.push(f)}return!1}advanceFully(t,e){let i=t.pos;for(;;){let s=this.checkNest(t);if(s)return s;if(!this.advanceStack(t,null,null))return!1;if(t.pos>i)return jo(t,e),!0}}runRecovery(t,e,i){let s,n=null,r=!1;for(let o=0;o<t.length;o++){let h=t[o],l=e[o<<1],a=e[1+(o<<1)],c=Co?this.stackID(h)+" -> ":"";if(h.deadEnd){if(r)continue;r=!0,h.restart(),Co&&console.log(c+this.stackID(h)+" (restarted)");let t=this.advanceFully(h,i);if(t){!0!==t&&(s=t);continue}}let u=h.split(),f=c;for(let t=0;u.forceReduce()&&t<10;t++){Co&&console.log(f+this.stackID(u)+" (via force-reduce)");let t=this.advanceFully(u,i);if(t){!0!==t&&(s=t);break}Co&&(f=this.stackID(u)+" -> ")}for(let t of h.recoverByInsert(l))Co&&console.log(c+this.stackID(t)+" (via recover-insert)"),this.advanceFully(t,i);this.input.length>h.pos?(a==h.pos&&(a++,l=0),h.recoverByDelete(l,a),Co&&console.log(c+this.stackID(h)+` (via recover-delete ${this.parser.getName(l)})`),jo(h,i)):(!n||n.score<h.score)&&(n=h)}if(n)return n;if(s)for(let t of this.stacks)if(t.score>s.stack.score){s=void 0;break}return s&&this.startNested(s),null}forceFinish(){let t=this.stacks[0].split();return this.nested&&this.finishNested(t,this.nested.forceFinish()),this.stackToTree(t.forceAll())}stackToTree(t,e=t.pos){return this.parser.context&&t.emitContext(),lo.build({buffer:Ro.create(t),nodeSet:this.parser.nodeSet,topID:this.topTerm,maxBufferLength:this.parser.bufferLength,reused:this.reused,start:this.startPos,length:e-this.startPos,minRepeatType:this.parser.minRepeatTerm})}checkNest(t){let e=this.parser.findNested(t.state);if(!e)return null;let i=e.value;return"function"==typeof i&&(i=i(this.input,t)),i?{stack:t,info:e,spec:i}:null}startNested(t){let{stack:e,info:i,spec:s}=t;this.stacks=[e],this.nestEnd=this.scanForNestEnd(e,i.end,s.filterEnd),this.nestWrap="number"==typeof s.wrapType?this.parser.nodeSet.types[s.wrapType]:s.wrapType||null,s.startParse?this.nested=s.startParse(this.input.clip(this.nestEnd),e.pos,this.context):this.finishNested(e)}scanForNestEnd(t,e,i){for(let s=t.pos;s<this.input.length;s++)if(No.start=s,No.value=-1,e.token(this.input,No,t),No.value>-1&&(!i||i(this.input.read(s,No.end))))return s;return this.input.length}finishNested(t,e){this.nestWrap?e=new lo(this.nestWrap,e?[e]:[],e?[0]:[],this.nestEnd-t.pos):e||(e=new lo(oo.none,[],[],this.nestEnd-t.pos));let i=this.parser.findNested(t.state);t.useNode(e,this.parser.getGoto(t.state,i.placeholder,!0)),Co&&console.log(this.stackID(t)+" (via unnest)")}stackID(t){let e=(Xo||(Xo=new WeakMap)).get(t);return e||Xo.set(t,e=String.fromCodePoint(this.nextStackID++)),e+t}}function jo(t,e){for(let i=0;i<e.length;i++){let s=e[i];if(s.pos==t.pos&&s.sameState(t))return void(e[i].score<t.score&&(e[i]=t))}e.push(t)}class zo{constructor(t,e,i){this.source=t,this.flags=e,this.disabled=i}allows(t){return!this.disabled||0==this.disabled[t]}}class Wo{constructor(t){if(this.bufferLength=eo,this.strict=!1,this.cachedDialect=null,13!=t.version)throw new RangeError(`Parser version (${t.version}) doesn't match runtime version (13)`);let e=To(t.tokenData),i=t.nodeNames.split(" ");this.minRepeatTerm=i.length,this.context=t.context;for(let e=0;e<t.repeatNodeCount;e++)i.push("");let s=[];for(let t=0;t<i.length;t++)s.push([]);function n(t,e,i){s[t].push([e,e.deserialize(String(i))])}if(t.nodeProps)for(let e of t.nodeProps){let t=e[0];for(let i=1;i<e.length;){let s=e[i++];if(s>=0)n(s,t,e[i++]);else{let r=e[i+-s];for(let o=-s;o>0;o--)n(e[i++],t,r);i++}}}if(this.specialized=new Uint16Array(t.specialized?t.specialized.length:0),this.specializers=[],t.specialized)for(let e=0;e<t.specialized.length;e++)this.specialized[e]=t.specialized[e].term,this.specializers[e]=t.specialized[e].get;this.states=To(t.states,Uint32Array),this.data=To(t.stateData),this.goto=To(t.goto);let r=Object.keys(t.topRules).map((e=>t.topRules[e][1]));this.nodeSet=new ho(i.map(((e,i)=>oo.define({name:i>=this.minRepeatTerm?void 0:e,id:i,props:s[i],top:r.indexOf(i)>-1,error:0==i,skipped:t.skippedNodes&&t.skippedNodes.indexOf(i)>-1})))),this.maxTerm=t.maxTerm,this.tokenizers=t.tokenizers.map((t=>"number"==typeof t?new Ao(e,t):t)),this.topRules=t.topRules,this.nested=(t.nested||[]).map((([t,e,i,s])=>({name:t,value:e,end:new Ao(To(i),0),placeholder:s}))),this.dialects=t.dialects||{},this.dynamicPrecedences=t.dynamicPrecedences||null,this.tokenPrecTable=t.tokenPrec,this.termNames=t.termNames||null,this.maxNode=this.nodeSet.types.length-1,this.dialect=this.parseDialect(),this.top=this.topRules[Object.keys(this.topRules)[0]]}parse(t,e=0,i={}){"string"==typeof t&&(t=xo(t));let s=new Vo(this,t,e,i);for(;;){let t=s.advance();if(t)return t}}startParse(t,e=0,i={}){return"string"==typeof t&&(t=xo(t)),new Vo(this,t,e,i)}getGoto(t,e,i=!1){let s=this.goto;if(e>=s[0])return-1;for(let n=s[e+1];;){let e=s[n++],r=1&e,o=s[n++];if(r&&i)return o;for(let i=n+(e>>1);n<i;n++)if(s[n]==t)return o;if(r)return-1}}hasAction(t,e){let i=this.data;for(let s=0;s<2;s++)for(let n,r=this.stateSlot(t,s?2:1);;r+=3){if(65535==(n=i[r])){if(1!=i[r+1]){if(2==i[r+1])return Io(i,r+2);break}n=i[r=Io(i,r+2)]}if(n==e||0==n)return Io(i,r+1)}return 0}stateSlot(t,e){return this.states[6*t+e]}stateFlag(t,e){return(this.stateSlot(t,0)&e)>0}findNested(t){let e=this.stateSlot(t,0);return 4&e?this.nested[e>>10]:null}validAction(t,e){if(e==this.stateSlot(t,4))return!0;for(let i=this.stateSlot(t,1);;i+=3){if(65535==this.data[i]){if(1!=this.data[i+1])return!1;i=Io(this.data,i+2)}if(e==Io(this.data,i+1))return!0}}nextStates(t){let e=[];for(let i=this.stateSlot(t,1);;i+=3){if(65535==this.data[i]){if(1!=this.data[i+1])break;i=Io(this.data,i+2)}if(0==(1&this.data[i+2])){let t=this.data[i+1];e.some(((e,i)=>1&i&&e==t))||e.push(this.data[i],t)}}return e}overrides(t,e){let i=Lo(this.data,this.tokenPrecTable,e);return i<0||Lo(this.data,this.tokenPrecTable,t)<i}configure(t){let e=Object.assign(Object.create(Wo.prototype),this);if(t.props&&(e.nodeSet=this.nodeSet.extend(...t.props)),t.top){let i=this.topRules[t.top];if(!i)throw new RangeError(`Invalid top rule name ${t.top}`);e.top=i}return t.tokenizers&&(e.tokenizers=this.tokenizers.map((e=>{let i=t.tokenizers.find((t=>t.from==e));return i?i.to:e}))),t.dialect&&(e.dialect=this.parseDialect(t.dialect)),t.nested&&(e.nested=this.nested.map((e=>Object.prototype.hasOwnProperty.call(t.nested,e.name)?{name:e.name,value:t.nested[e.name],end:e.end,placeholder:e.placeholder}:e))),null!=t.strict&&(e.strict=t.strict),null!=t.bufferLength&&(e.bufferLength=t.bufferLength),e}getName(t){return this.termNames?this.termNames[t]:String(t<=this.maxNode&&this.nodeSet.types[t].name||t)}get eofTerm(){return this.maxNode+1}get hasNested(){return this.nested.length>0}get topNode(){return this.nodeSet.types[this.top[1]]}dynamicPrecedence(t){let e=this.dynamicPrecedences;return null==e?0:e[t]||0}parseDialect(t){if(this.cachedDialect&&this.cachedDialect.source==t)return this.cachedDialect;let e=Object.keys(this.dialects),i=e.map((()=>!1));if(t)for(let s of t.split(" ")){let t=e.indexOf(s);t>=0&&(i[t]=!0)}let s=null;for(let t=0;t<e.length;t++)if(!i[t])for(let i,n=this.dialects[e[t]];65535!=(i=this.data[n++]);)(s||(s=new Uint8Array(this.maxTerm+1)))[i]=1;return this.cachedDialect=new zo(t,i,s)}static deserialize(t){return new Wo(t)}}function Io(t,e){return t[e]|t[e+1]<<16}function Lo(t,e,i){for(let s,n=e;65535!=(s=t[n]);n++)if(s==i)return n-e;return-1}const Fo={__proto__:null,for:10,in:18,return:23,if:26,then:28,else:30,some:34,every:36,satisfies:43,or:46,and:50,between:58,instance:82,of:85,days:93,time:95,duration:97,years:99,months:101,date:103,list:109,context:115,function:122,string:141,length:143,upper:145,case:147,lower:149,substring:151,before:153,after:155,starts:157,with:159,ends:161,contains:163,insert:165,index:167,distinct:169,values:171,met:173,by:175,overlaps:177,finished:179,started:181,day:183,year:185,week:187,month:189,get:191,value:193,entries:195,start:205,position:207,decimal:209,sep:211,separator:213,grouping:215,null:218,true:342,false:342,"?":232,external:248,method:265,signature:267,not:273},Ho=Wo.deserialize({version:13,states:"!#OO]QPOOO&hQPOOO'sQPO'#FiO]QPO'#DOO*[QPO'#DOO,zQPO'#DrOOQO'#En'#EnOOQO'#Ep'#EpO,zQPO'#EqOOQO'#F{'#F{OOQO'#Fz'#FzOOQO'#Es'#EsO-PQPO'#EvO-kQPO'#EwO0ZQPO'#ExO-PQPO'#EuOOQO'#Eu'#EuOOQO'#Fk'#FkO0bQPO'#FQOOQO'#GP'#GPOOQO'#Fj'#FjOOQO'#FZ'#FZQ]QPOOO0pQPO'#C`O]QPO'#ChO0pQPO'#ClO0uQPO'#DsO0zQPO'#DsO1PQPO'#DsO1UQPO'#DsO1^QPO'#DsO1cQPO'#DsO1hQPO'#DsO1mQPO'#DsO1rQPO'#DsO1wQPO'#DsO1|QPO'#DsO2RQPO'#DsO2WQPO'#DsO2`QPO'#ErOOQO'#Er'#ErO2hQPO'#EyO2mQPO'#CzO5hQPO'#FqOOQO'#C|'#C|O5sQPO'#FXQOQPOOO5zQPOOO]QPO,59bO]QPO,59jO]QPO,59jO]QPO,59jO0pQPO,5:YO]QPO,5:[O8lQPO'#FwOOQO,5:^,5:^OOQO,5<T,5<TO]QPO,59^O]QPO,59`O]QPO,59bO;lQPO,59bO;sQPO,59pO;xQPO,59jOB]QPO,5;YOOQO,5;],5;]OOQO'#Cd'#CdOGqQPO'#DYOKoQPO'#EnOOQO'#GO'#GOOKtQPO,5;bOMQQPO'#CdOM_QPO,5;cOMfQPO'#FzONsQPO'#FyO! QQPO,5;dOOQO,5;a,5;aOOQO'#FS'#FSO! VQPO'#FRO! [QPO'#GRO! dQPO,5;lO! iQPO'#FTOOQO-E9X-E9XO! nQPO'#FmOOQO'#Cb'#CbO! vQPO'#CcO! {QPO,58zO!!QQPO,59SO!!XQPO'#FpOOQO'#Co'#CoO!!aQPO'#CpO!!fQPO,59WO!!kQPO,5:_OOQO,5:_,5:_O!!pQPO,5:_O!!xQPO,5:_O!!}QPO,5;^O!#SQPO,5;eO]QPO'#F^O!#eQPO,5<]O]QPOOO!'XQPO1G.|O!+^QPO1G/UO!+hQPO1G/UO!/jQPO1G/UOOQO1G/t1G/tO!/tQPO1G/vOOQO'#Ed'#EdO!/{QPO'#EcO!0QQPO'#FxOOQO'#Eb'#EbOOQO'#El'#ElO!0YQPO,5<cO!0_QPO'#EeO!0dQPO'#EeO!3tQPO1G.xO!7sQPO1G.zO!9bQPO1G.|O-kQPO1G.|OOQO1G.|1G.|O!9iQPO1G/[O0pQPO'#F_O!:QQPO,59tOOQO,5;Y,5;YO-PQPO1G0|OOQO1G0}1G0}O]QPO'#FcO!>OQPO,5<eOOQO1G1O1G1OO]QPO,5;mO!>ZQPO'#FeO!>fQPO,5<mOOQO1G1W1G1WOOQO,5;o,5;oO0pQPO'#F[O!>nQPO,5<XO!>vQPO,58}O]QPO1G.fO!AfQPO1G.nO0pQPO'#F]O!DUQPO,5<[O]QPO,59[O]QPO1G.rO!D^QPO1G/yOOQO1G/y1G/yOOQO1G0x1G0xO!DcQPO'#E{O!DnQPO'#GQOOQO'#Ez'#EzO!DvQPO1G1POOQO,5;x,5;xOOQO-E9[-E9[O!D{QPOOOOQO7+%b7+%bO]QPO,5:}O!EQQPO'#FbO!E`QPO,5<dOOQO1G1}1G1}OOQO,5;P,5;PO]QPO7+$hO!EhQPO,5;cO!ErQPO7+$hOOQO'#DX'#DXO!EwQPO'#DZO!E|QPO'#DZO!FRQPO'#DZO!FWQQO'#DcO!F]QQO'#DfO!FbQQO'#DjOOQO7+$v7+$vOOQO,5;y,5;yOOQO-E9]-E9]O!FgQPO7+&hO!FrQPO,5;}OOQO-E9a-E9aO!GPQPO1G1XOOQO,5<P,5<POOQO-E9c-E9cOOQO,5;v,5;vOOQO-E9Y-E9YO!H[QPO'#CfOOQO1G.i1G.iO!HiQPO7+$QO# [QPO7+$YOOQO,5;w,5;wOOQO-E9Z-E9ZO# cQPO1G.vO# mQPO7+$^OOQO7+%e7+%eO!9iQPO,5;gO!EQQPO'#FdO#$hQPO,5<lO#$pQPO7+&kO#$wQPO1G0iOOQO,5;|,5;|OOQO-E9`-E9`O#(jQPO<<HSOOQO<<HS<<HSO#(}QPO,59uO#)SQPO,59uO#)XQPO,59uO#)^QPO,59}O0pQPO,5:QO#)uQQO,5:UOOQO<<JS<<JSO]QPO,59QO]QPO<<GtOOQO1G1R1G1ROOQO,5<O,5<OOOQO-E9b-E9bO#)|QPO'#E}OOQO<<JV<<JVO]QPO<<JVO#,wQPO1G/aOOQO1G/a1G/aO#,|QQO'#DYO#-XQQO1G/iO#-^QPO'#DiO#-cQQO'#FsOOQO'#Dh'#DhO#-kQQO1G/lOOQO'#Dm'#DmO#-pQQO'#FuOOQO'#Dl'#DlO#-xQQO1G/pO#-}QPO1G.lO#.XQPOAN=`OOQOAN?qAN?qOOQO7+${7+${O#1SQQO,59tOOQO7+%T7+%TO#)^QPO,5:TO0pQPO'#F`O#1_QQO,5<_OOQO7+%W7+%WO#)^QPO'#FaO#1gQQO,5<aO#1oQQO7+%[OOQO1G/o1G/oOOQO,5;z,5;zOOQO-E9^-E9^OOQO,5;{,5;{OOQO-E9_-E9_O!9iQPO<<HvOOQOAN>bAN>bO#1tQPO,5;YO#1{QPO'#CdO#2SQPO7+$YO#)^QPO<<HvO#4vQPO'#DOO!>vQPO,59bO!>vQPO,59jO!>vQPO,59jO!>vQPO,59jO!>vQPO,59^O!>vQPO,59`O#7jQPO,59bO#8lQPO1G.|O#:TQPO1G/UO#:_QPO1G/UO#;gQPO1G.xO#<rQPO1G.zO!>vQPO1G.fO#=VQPO1G.nO!AfQPO1G.nO#=VQPO1G.nO!>vQPO1G.rO!>vQPO7+$hO#?uQPO7+$QO#A^QPO7+$YO#AeQPO7+$^O#ArQPO7+&kO#BtQPO<<HSO!>vQPO<<GtO#CXQPO'#E}O!>vQPO<<JVO#CfQPOAN=`O#CsQQO7+%[O#CxQPO7+$YO!>vQPO'#DOO#DPQPO'#CzO#D^QPO,58zO#DcQPO,59SO#DjQPO,59SO#DqQPO,59SO#DxQPO,59WO#D}QPO1G.|O#EUQPO1G1PO#EZQQO1G/pO0pQPO'#C`O]QPO'#ChO]QPO'#ChO]QPO'#ChO0pQPO'#ClO!AfQPO,59bO!AfQPO,59jO!AfQPO,59jO!AfQPO,59jO!AfQPO,59^O!AfQPO,59`O]QPO,59bO#G{QPO,59bO!#SQPO,5;eO#HSQPO1G.|O#L_QPO1G/UO#LiQPO1G/UO#LpQPO1G.xO#MgQPO1G.zO!AfQPO1G.fO!AfQPO1G.rO!AfQPO7+$hO$ [QPO7+$QO$$YQPO7+$^O$'WQPO7+&kO$'_QPO<<HSO#)uQQO,5:UP!AfQPO<<GtO$'uQPO'#E}O!AfQPO<<JVP$*sQPOAN=`O$0^QPO'#DOO#=VQPO,59bO#=VQPO,59jO#=VQPO,59jO#=VQPO,59jO#=VQPO,59^O#=VQPO,59`O$3QQPO,59bO$3XQPO1G.|O$4vQPO1G/UO$5QQPO1G/UO$6YQPO1G.xO$7hQPO1G.zO#=VQPO1G.fO#=VQPO1G.rO#=VQPO7+$hO$8OQPO7+$QO$8cQPO7+$^O$8vQPO7+&kO$8}QPO<<HSP#=VQPO<<GtO$9eQPO'#E}O#=VQPO<<JVP$9xQPOAN=`O#=VQPO'#DOO$:]QPO'#CzO$:pQPO,58zO$:uQPO,59WO$:zQPO1G.|O$;RQPO1G1PO!AfQPO'#DOO$=^QPO'#DOO$=zQPO'#EyO$>PQPO'#CzO$@}QPO,58zO$ASQPO,59WO$AXQPO1G.|O$A`QPO1G1PO$AeQQO'#DjO0pQPO'#C`O0pQPO'#ClO]QPO,59bO!#SQPO,5;eO0pQPO'#C`O0pQPO'#ClO]QPO,59bO!#SQPO,5;eO$AjQPO'#EyO$AoQPO'#Ey",stateData:"$At~O$[OSPOSQOS~OTgO]hOaiObiOl_Oo]OsROtSO!PxO!QxO!RjO!TwO!WoO!_yO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~OTgO]hOaiObiOl_Oo]OsRO!PxO!QxO!RjO!TwO!WoO!_yO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~Ot}O#|!PO~P#{OX!^Og!ZOi![Ok!QOl!QOm!]Oo!WOs!ROt!ROu!SOv!SOw!TOy!_O!e!VO$f!UO~O$v!YOT$]X]$]Xa$]Xb$]X!P$]X!Q$]X!R$]X!T$]X!W$]X!_$]X!c$]X!h$]X!j$]X!l$]X!m$]X!p$]X!r$]X!t$]X!u$]X!v$]X!x$]X!z$]X!{$]X!|$]X!}$]X#P$]X#Q$]X#R$]X#a$]X#c$]X#h$]X#s$]X$Y$]X$`$]X$p$]X$q$]X~P&rOTgO]hOaiObiOl_Oo]OsROtSO!PxO!QxO!RjO!TwO!WoO!_yO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$p!aO$qVO~Oo!WO~Ot!eO!PxO!QxO!TwO#cXO$`!cO$pUO$qVO~OTgO]hOaiObiOl_Oo]OsROtSO!PxO!QxO!RjO!TwO!WoO!_yO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`!hO$pUO$qVO~O!c$mP~P-kO#c!nO#x!rO$`!cO#r$uP~O$`!cO~Oi!}O~O!i#OO~O!k#OO~O!n#OO!o#OO~O!q#OO~O!s#OO~O!n#OO~Oz#OO~O!w#OO~O!y#OO~Oz#PO~Oz#QO~O#S#OO#T#OO~Oi#ROo#fX~Oo#SO~O$YnX$cnXTnX]nXanXbnX!PnX!QnX!RnX!TnX!WnX!_nX!cnX!hnX!jnX!lnX!mnX!pnX!rnX!tnX!unX!vnX!xnX!znX!{nX!|nX!}nX#PnX#QnX#RnX#anX#cnX#hnX#snX$`nX$pnX$qnX$vnXqnX^nX#rnXenXZnX~P&rO$c#TO$Y$eXq$eX~O$Y#{X~P*[Oo#VO~OTgO]hOaiObiOl_Oo]OsROtSO!PxO!QxO!RjO!TwO!WoO!_yO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$pUO$qVO~O#Y#dO#[#eO#_#eO$`&_Oq$mP~P6POTgO]hOaiObiOl_OsROtSO!PxO!QxO!RjO!TwO!WoO!_yO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~Oo#iO~P9POz#kO~Oo!WOy!_O!e!VO$f!UOTraXra]raarabragrairakralramrasratrauravrawra!Pra!Qra!Rra!Tra!Wra!_ra!cra!hra!jra!lra!mra!pra!rra!tra!ura!vra!xra!zra!{ra!|ra!}ra#Pra#Qra#Rra#ara#cra#hra#sra$Yra$`ra$pra$qra$vra$craqra^ra#rraZra$bra_raera~OX#bXX#bag#bXg#bai#bXi#bak#bXk#bal#bXl#bam#bXm#bao#bXo#bas#bXs#bat#bXt#bau#bXu#bav#bXv#baw#bXw#bay#bXy#ba!e#bX!e#ba$f#bX$f#ba$c#bX$c#ba$b#ba_#bX_#baZ#bXZ#ba~OT#bXT#ba]#bX]#baa#bXa#bab#bXb#ba!P#bX!P#ba!Q#bX!Q#ba!R#bX!R#ba!T#bX!T#ba!W#bX!W#ba!_#bX!_#ba!c#bX!c#ba!h#bX!h#ba!j#bX!j#ba!l#bX!l#ba!m#bX!m#ba!p#bX!p#ba!r#bX!r#ba!t#bX!t#ba!u#bX!u#ba!v#bX!v#ba!x#bX!x#ba!z#bX!z#ba!{#bX!{#ba!|#bX!|#ba!}#bX!}#ba#P#bX#P#ba#Q#bX#Q#ba#R#bX#R#ba#a#bX#a#ba#c#bX#c#ba#h#bX#h#ba#s#bX#s#ba$Y#bX$Y#ba$`#bX$`#ba$p#bX$p#ba$q#bX$q#ba$v#bX$v#baq#bXq#ba^#bX^#ba#r#bX#r#bae#bXe#ba~P?vO$f#lO$b|XT|XX|X]|Xa|Xb|Xg|Xi|Xk|Xl|Xm|Xo|Xs|Xt|Xu|Xv|Xw|Xy|X!P|X!Q|X!R|X!T|X!W|X!_|X!c|X!e|X!h|X!j|X!l|X!m|X!p|X!r|X!t|X!u|X!v|X!x|X!z|X!{|X!||X!}|X#P|X#Q|X#R|X#a|X#c|X#h|X#s|X$Y|X$`|X$p|X$q|X$v|X$c|Xq|X^|X#r|XZ|X_|Xe|X~O$p#nO~O$b#oO~OX#gXg#gXi#gXk#gXl#gXm#gXo#gXq#gXs#gXt#gXu#gXv#gXw#gXy#gX!e#gX$f#gX$c#gX~O$bWX$fWX!c#gX~PKyOq#pO~P&rOX$nXg$nXi$nXk$nXl$nXm$nXo$nXq$nXs$nXt$nXu$nXv$nXw$nXy$nX!e$nX$b$rX$f$nX!c$nX$c$nX~O$c#qO!c$mXq$mX~P&rO!c#sO~O$h#tO~O$c#uO#r$uX~O#r#wO~O#y#xO~O$c#yOZ$aX~OX#{O~OZ#|O~O^#}O~P&rO$c$OOe$dX~OX$QO~Oe$RO~O!S$SO~O#O$TO#P$TO~O#O$TO~O!P$UO~O#Y#dO#[#eO#_#eO$`!cOq$tP~O$c#TO$Y$eaq$ea~Oo!WOy!_O!e!VO$f!UOTjiXji]jiajibjigjiijikjiljimji!Pji!Qji!Rji!Tji!Wji!_ji!cji!hji!jji!lji!mji!pji!rji!tji!uji!vji!xji!zji!{ji!|ji!}ji#Pji#Qji#Rji#aji#cji#hji#sji$Yji$`ji$pji$qji$vji$cjiqji^ji#rjiejiZji~Os!ROt!ROu!SOv!SOw!TO~P!#pOo!WOw!TOy!_O!e!VO$f!UOTriXri]riaribrigriirikrilrimrisritri!Pri!Qri!Rri!Tri!Wri!_ri!cri!hri!jri!lri!mri!pri!rri!tri!uri!vri!xri!zri!{ri!|ri!}ri#Pri#Qri#Rri#ari#cri#hri#sri$Yri$`ri$pri$qri$vri$criqri^ri#rrieriZri~Ou!SOv!SO~P!'lOurivri~P!'lOo!WOy!_O!e!VO$f!UOTriXri]riaribrigriirikrilrimrisritriurivri!Pri!Qri!Rri!Tri!Wri!_ri!cri!hri!jri!lri!mri!pri!rri!tri!uri!vri!xri!zri!{ri!|ri!}ri#Pri#Qri#Rri#ari#cri#hri#sri$Yri$`ri$pri$qri$vri$criqri^ri#rriZri_rieri~Owri$bri~P!+rO!c$^O~P&rO$h$_O~O$c$`Oq$lX~Oq$bO~O#Z$cO~O#]$cO#^$cO~Oo!WOy!_O!e!VO$f!UOTfi]fiafibfigfi!Pfi!Qfi!Rfi!Tfi!Wfi!_fi!cfi!hfi!jfi!lfi!mfi!pfi!rfi!tfi!ufi!vfi!xfi!zfi!{fi!|fi!}fi#Pfi#Qfi#Rfi#afi#cfi#hfi#sfi$Yfi$`fi$pfi$qfi$vfi$cfiqfi^fi#rfiefiZfi~OX!^Oi![Ok!QOl!QOm!]Os!ROt!ROu!SOv!SOw!TO~P!0lOo!WOy!_O!e!VO$f!UOThi]hiahibhighiihi!Phi!Qhi!Rhi!Thi!Whi!_hi!chi!hhi!jhi!lhi!mhi!phi!rhi!thi!uhi!vhi!xhi!zhi!{hi!|hi!}hi#Phi#Qhi#Rhi#ahi#chi#hhi#shi$Yhi$`hi$phi$qhi$vhi$chiqhi^hi#rhiehiZhi~OX!^Ok!QOl!QOm!]Os!ROt!ROu!SOv!SOw!TO~P!4hOX!^Og!ZOk!QOl!QOm!]Oo!WOs!ROt!ROu!SOv!SOw!TOy!_O!e!VO$f!UO~Oi$dO~P!8dO!O$hO!R$iO!T$jO!W$kO!Z$lO!_$mO$`!cO~O$f#lO$b|aT|aX|a]|aa|ab|ag|ai|ak|al|am|ao|as|at|au|av|aw|ay|a!P|a!Q|a!R|a!T|a!W|a!_|a!c|a!e|a!h|a!j|a!l|a!m|a!p|a!r|a!t|a!u|a!v|a!x|a!z|a!{|a!||a!}|a#P|a#Q|a#R|a#a|a#c|a#h|a#s|a$Y|a$`|a$p|a$q|a$v|a$c|aq|a^|a#r|aZ|a_|ae|a~O$c#qO!c$maq$ma~O#c!nO#x!rO$`!cO~O$c#uO#r$ua~O$c#yOZ$aa~OT'[O]']Oa'`Ob'`Ol_Oo]Os'QOt&bO!PxO!QxO!RjO!TwO!WoO!_(mO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~OT(xO]'^Oa(yOb(yOl_Oo]Os(kOt(lO!PxO!QxO!RjO!TwO!WoO!_(}O!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~O$c$OOe$da~O!Q%RO~O$h%SOq#oX$c#oX~O$c%TOq$tX~Oq%VO~Oq!OO~O#Y#dO#[#eO#_#eO$`!cO~O$c$`Oq$la~Oq#pO$cnX~P&rOq%[O~Oi%]O~Oi%^O~Oi%_O~O!X%`O~O!X%aO~O!X%bO~Oq%cO!c%cO!e%cO~O!c$Va$c$Vaq$Va~P&rO#r#ui$c#ui~P&rOX&iOg&gOi&hOk&cOl&cOm'gOo!WOs&dOt&dOu&eOv&eOw&fOy!_O!e!VO$f!UO~O$b%dOZYX$cYX~P!GZOTSq]SqaSqbSq!PSq!QSq!RSq!TSq!WSq!_Sq!cSq!hSq!jSq!lSq!mSq!pSq!rSq!tSq!uSq!vSq!xSq!zSq!{Sq!|Sq!}Sq#PSq#QSq#RSq#aSq#cSq#hSq#sSq$YSq$`Sq$pSq$qSq$vSq$cSqqSq^Sq#rSqeSqZSq~P&rOX'hOg'eOi'fOk'aOl'aOm(zOo!WOs'bOt'bOu'cOv'cOw'dOy!_O!e!VO$f!UOT[q][qa[qb[q!P[q!Q[q!R[q!T[q!W[q!_[q!c[q!h[q!j[q!l[q!m[q!p[q!r[q!t[q!u[q!v[q!x[q!z[q!{[q!|[q!}[q#P[q#Q[q#R[q#a[q#c[q#h[q#s[q$Y[q$`[q$p[q$q[q$v[q$c[qq[q^[q#r[qe[qZ[q~O_%eO~P!KdOedi$cdi~P&rOT`q]`qa`qb`q!P`q!Q`q!R`q!T`q!W`q!_`q!c`q!h`q!j`q!l`q!m`q!p`q!r`q!t`q!u`q!v`q!x`q!z`q!{`q!|`q!}`q#P`q#Q`q#R`q#a`q#c`q#h`q#s`q$Y`q$``q$p`q$q`q$v`q$c`qq`q^`q#r`qe`qZ`q~P&rO$c%TOq$ta~O#p%kO~P]Oq#Vi$c#Vi~P&rOo!WOy!_O!e!VO$f!UOTjyXjy]jyajybjygjyijykjyljymjy!Pjy!Qjy!Rjy!Tjy!Wjy!_jy!cjy!hjy!jjy!ljy!mjy!pjy!rjy!tjy!ujy!vjy!xjy!zjy!{jy!|jy!}jy#Pjy#Qjy#Rjy#ajy#cjy#hjy#sjy$Yjy$`jy$pjy$qjy$vjy$cjyqjy^jy#rjyejyZjy~Os!ROt!ROu!SOv!SOw!TO~P#%RO!P%lO~O!S%lO~O!P%mO~O!O$hO!R$iO!T$jO!W$kO!Z$lO!_(sO$`!cO~O!U$iP~P#)^OT#qX]#qXa#qXb#qX!P#qX!Q#qX!R#qX!T#qX!W#qX!_#qX!c#qX!h#qX!j#qX!l#qX!m#qX!p#qX!r#qX!t#qX!u#qX!v#qX!x#qX!z#qX!{#qX!|#qX!}#qX#P#qX#Q#qX#R#qX#a#qX#c#qX#h#qX#s#qX$Y#qX$`#qX$p#qX$q#qX$v#qX$c#qXq#qX^#qX#r#qXe#qXZ#qX~P&rO!Q%{O~O$f#lO!U|X$c|X~O!U%}O~O$h&OO~O$c&PO!U$gX~O!U&RO~O$c&SO!U$iX~O!U&UO~OZYi$cYi~P&rOT[!R][!Ra[!Rb[!R!P[!R!Q[!R!R[!R!T[!R!W[!R!_[!R!c[!R!h[!R!j[!R!l[!R!m[!R!p[!R!r[!R!t[!R!u[!R!v[!R!x[!R!z[!R!{[!R!|[!R!}[!R#P[!R#Q[!R#R[!R#a[!R#c[!R#h[!R#s[!R$Y[!R$`[!R$p[!R$q[!R$v[!R$c[!Rq[!R^[!R#r[!Re[!RZ[!R~P&rO$f#lO!U|a$c|a~O$c&PO!U$ga~O$c&SO!U$ia~O$j&[O~O$b#bX~P?vO$hWX~PKyO_[q~P!KdOT'[O]']Oa'`Ob'`Ol_Oo]Os'QOt&bO!PxO!QxO!RjO!TwO!WoO!_(mO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$qVO~O$p&^O~P#2ZOT'[O]']Oa'`Ob'`Ol_Os'QOt&bO!PxO!QxO!RjO!TwO!WoO!_(mO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~Oo#iO~P#4}Oo!WOy!_O!e!VO$f!UOXjiZjigjiijikjiljimji$bji$cji~Os&dOt&dOu&eOv&eOw&fO~P#7qOo!WOw&fOy!_O!e!VO$f!UOXriZrigriirikrilrimrisritri$bri$cri~Ou&eOv&eO~P#9POurivri~P#9POX&iOi&hOk&cOl&cOm'gOo!WOs&dOt&dOu&eOv&eOw&fOy!_O!e!VO$f!UO~OZfigfi$bfi$cfi~P#:iOX&iOk&cOl&cOm'gOo!WOs&dOt&dOu&eOv&eOw&fOy!_O!e!VO$f!UO~OZhighiihi$bhi$chi~P#;wOT(tO]'_Oa(uOb(uOl_Oo]Os(eOt'{O!PxO!QxO!RjO!TwO!WoO!_(|O!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~OZSq$bSq$cSq~P!GZOX(SOg(QOi(ROk'|Ol'|Om(vOo!WOs'}Ot'}Ou(OOv(OOw(POy!_O!e!VO$f!UOZ[q$b[q$c[q~O_&zO~P#@SOZ`q$b`q$c`q~P!GZO#p&|O~P!>vOo!WOy!_O!e!VO$f!UOXjyZjygjyijykjyljymjy$bjy$cjy~Os&dOt&dOu&eOv&eOw&fO~P#AyOZ#qX$b#qX$c#qX~P!GZOZ[!R$b[!R$c[!R~P!GZO$j&aO~O_[q~P#@SOZnX$bnX$cnX~P!GZOZ&oO~O^&pO~P&rO^&qO~P&rO^&rO~P&rOe&sO~Oi&tO~P!8dOq&xO~O!U'OO~OT(xO]'^Oa(yOb(yOl_Os(kOt(lO!PxO!QxO!RjO!TwO!WoO!_(}O!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~Oo#iO~P#E`Os'bOt'bOu'cOv'cOw'dO_ji~P!#pOo!WOw'dOy!_O!e!VO$f!UOTriXri]ri_riaribrigriirikrilrimrisritri!Pri!Qri!Rri!Tri!Wri!_ri!cri!hri!jri!lri!mri!pri!rri!tri!uri!vri!xri!zri!{ri!|ri!}ri#Pri#Qri#Rri#ari#cri#hri#sri$Yri$`ri$pri$qri$vri$criqri^ri#rrieriZri~Ou'cOv'cO~P#HjOw'dO~P!+rOX'hOi'fOk'aOl'aOm(zOs'bOt'bOu'cOv'cOw'dO_fi~P!0lOX'hOk'aOl'aOm(zOs'bOt'bOu'cOv'cOw'dO_hi~P!4hOX'hOg'eOi'fOk'aOl'aOm(zOo!WOs'bOt'bOu'cOv'cOw'dOy!_O!e!VO$f!UO~OTSq]Sq_SqaSqbSq!PSq!QSq!RSq!TSq!WSq!_Sq!cSq!hSq!jSq!lSq!mSq!pSq!rSq!tSq!uSq!vSq!xSq!zSq!{Sq!|Sq!}Sq#PSq#QSq#RSq#aSq#cSq#hSq#sSq$YSq$`Sq$pSq$qSq$vSq$cSqqSq^Sq#rSqeSqZSq~P#NZOT`q]`q_`qa`qb`q!P`q!Q`q!R`q!T`q!W`q!_`q!c`q!h`q!j`q!l`q!m`q!p`q!r`q!t`q!u`q!v`q!x`q!z`q!{`q!|`q!}`q#P`q#Q`q#R`q#a`q#c`q#h`q#s`q$Y`q$``q$p`q$q`q$v`q$c`qq`q^`q#r`qe`qZ`q~P#NZO#p'yO~P!AfOs'bOt'bOu'cOv'cOw'dO_jy~P#%ROT#qX]#qX_#qXa#qXb#qX!P#qX!Q#qX!R#qX!T#qX!W#qX!_#qX!c#qX!h#qX!j#qX!l#qX!m#qX!p#qX!r#qX!t#qX!u#qX!v#qX!x#qX!z#qX!{#qX!|#qX!}#qX#P#qX#Q#qX#R#qX#a#qX#c#qX#h#qX#s#qX$Y#qX$`#qX$p#qX$q#qX$v#qX$c#qXq#qX^#qX#r#qXe#qXZ#qX~P#NZOT[!R][!R_[!Ra[!Rb[!R!P[!R!Q[!R!R[!R!T[!R!W[!R!_[!R!c[!R!h[!R!j[!R!l[!R!m[!R!p[!R!r[!R!t[!R!u[!R!v[!R!x[!R!z[!R!{[!R!|[!R!}[!R#P[!R#Q[!R#R[!R#a[!R#c[!R#h[!R#s[!R$Y[!R$`[!R$p[!R$q[!R$v[!R$c[!Rq[!R^[!R#r[!Re[!RZ[!R~P#NZOT(tO]'_Oa(uOb(uOl_Oo]Os(eOt'{O!PxO!QxO!RjO!TwO!WoO!_(|O!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$qVO~O$p&^O~P$-qOT(tO]'_Oa(uOb(uOl_Os(eOt'{O!PxO!QxO!RjO!TwO!WoO!_(|O!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$pUO$qVO~Oo#iO~P$0eOs'}Ot'}Ou(OOv(OOw(PO_ji~P#7qOo!WOw(POy!_O!e!VO$f!UOXriZri_rigriirikrilrimrisritri$bri$cri~Ou(OOv(OO~P$3oOurivri~P$3oOX(SOi(ROk'|Ol'|Om(vOo!WOs'}Ot'}Ou(OOv(OOw(POy!_O!e!VO$f!UO~OZfi_figfi$bfi$cfi~P$5[OX(SOk'|Ol'|Om(vOo!WOs'}Ot'}Ou(OOv(OOw(POy!_O!e!VO$f!UO~OZhi_highiihi$bhi$chi~P$6mOg(QOZSq_Sq$bSq$cSq~P$5[Og(QOZ`q_`q$b`q$c`q~P$5[O#p(cO~P#=VOs'}Ot'}Ou(OOv(OOw(PO_jy~P#AyOg(QOZ#qX_#qX$b#qX$c#qX~P$5[Og(QOZ[!R_[!R$b[!R$c[!R~P$5[Og(QOZnX_nX$bnX$cnX~P$5[OZ(YO~Oe(ZO~Oi([O~P!8dOq(_O~Ol_Oo]O!PxO!QxO!RjO!TwO!WoO!c[O!e^O!hkO!jlO!llO!mmO!pnO!rnO!tpO!uqO!vrO!xsO!zmO!{sO!|sO!}tO#PuO#QuO#RvO#aYO#cXO#haO#sbO$`ZO$qVO~OT(xO]'^Oa(yOb(yOs(kOt(lO!_(}O$p!aO~P$;WOo'iO~OTnX]nX_nXanXbnX!PnX!QnX!RnX!TnX!WnX!_nX!cnX!hnX!jnX!lnX!mnX!pnX!rnX!tnX!unX!vnX!xnX!znX!{nX!|nX!}nX#PnX#QnX#RnX#anX#cnX#hnX#snX$YnX$`nX$pnX$qnX$vnX$cnXqnX^nX#rnXenXZnX~P#NZOZ'oO~Oe'pO~Oi'qO~P!8dOq'tO~O!X'vO~Oo(wO~Oo({O~O",goto:"DR$vPPPP$wP&v'S']P(gP$wPPP$wPP(j(vP$wP$wP$wPPP)PP)_P$wPPPPP$wPP)h)}*VPPPPPPP*VPP*VP*b*e*VP*k*q$wP$wP$w*xPPPPPPPPPPPPPPPPPPPPPPPPPPPP,w,z-Q-]PPPPPP,wP-fP-f-f/h$wP$w1j$w3i3i5h5tP5}PP3i6Z6a6ePPP6iP6l6r6x7O7U7`7f7l7r7x8OPPP8U8Y=VP?UPP?[?bP?gP?jP?nA]A`$wAfPPCl=VCxDO$yaOPRS]^fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(zQ!wgQ'S'[Q(g(tR(o(xW!tg'[(t(xR$w#yb!d[]^_#i#k#o%S&[S!nb#uY!vg#y'[(t(xY!{i$O'`(u(yQ#[!U^#^!W#S$`%T'i(w({Q$o#l[%n%`%b&O&S&a'vT%p%a&PR$z#{Q!|iQ'W'`Q(h(uR(p(yW!yi'`(u(yR$}$OU{P#V#iW#j!^&i'h(SR$Z#TQ!OPQ$]#VR$f#iQ$n#kQ%f%SQ%o%`U%t%b&S'vQ&V&OT&]&[&a[!f[]^_#i#oc$g#k%S%`%b&O&S&[&a'vR%s%aQ%q%aR&W&PQ%w%bR'Z'vS%u%b'vR&Y&S$yTOPRS]^fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(zR#c!WQ#`!WR%X$`S#_!W$`Z$V#S%T'i(w({_#^!W#S$`%T'i(w({%PXOPRS[]^_fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#o#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(z%PWOPRS[]^_fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#o#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(z$y`OPRS]^fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(z$ycOPRS]^fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(zQ$Y#SQ'Y'iQ(j(wR(r({W$W#S'i(w({R%g%TW%j%V&x't(_X%z%k&|'y(cQ!pbR$u#uT!ob#uT!nb#uR!OPQfOR!sfQ#z!tR$x#zQ$P!yR%O$PQ#U{R$[#UQ#m!dS$p#m%|R%|%nQ&Q%qR&X&QQ&T%uR&Z&TQ$a#`R%Y$aQ#r!kR$s#rQ%U$WR%h%UQ#v!pR$v#vTeOfSQOfWzP!^#T#Vb!`RS}&b'Q'{(e(k(lQ!i]S!k^!WQ!xhQ#W!QQ#X!RQ#Y!SW#Z!T&f'd(PQ#]!VQ#f!ZQ#g![Q#h!]Q$e#iQ$r#qQ$t#tQ$y#{Q${#|Q$|#}Q%P$QQ%Q$RQ%W$_Q%Z$dS%i%V%kQ%x%dQ%y%eQ&`&qQ&j&cQ&k&dQ&l&eQ&m&gQ&n&hQ&u&oQ&v&pQ&w&sQ&y&tS&{&x&|Q&}&zQ'P&rQ'R&iQ'T']Q'U'^Q'V'_Q'X'gQ'j'aQ'k'bQ'l'cQ'm'eQ'n'fQ'r'oQ's'pQ'u'qS'x't'yQ'z'wQ(T'|Q(U'}Q(V(OQ(W(QQ(X(RQ(](YQ(^(ZQ(`([S(b(_(cQ(d(aQ(f(SQ(i(vQ(n'hR(q(z$ydOPRS]^fh}!Q!R!S!T!V!W!Z![!]!^#T#V#i#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(zX!ug'[(t(xX!zi'`(u(yV|P#V#iR%r%aT%v%b'v$Q!XQTz!`!i!k!x#W#X#Y#Z#]#f#g#h$e$r$t$y${$|%P%Q%W%Z%i%x%y&`&j&k&l&m&n&u&v&w&y&{&}'P'R'T'U'V'X'j'k'l'm'n'r's'u'x'z(T(U(V(W(X(](^(`(b(d(f(i(n(qR!bWR#a!WQ!l^R#b!W$rYOPRSfh}!Q!R!S!T!V!W!Z![!]!^#T#V#q#t#{#|#}$Q$R$_$d%V%d%e%k&b&c&d&e&f&g&h&i&o&p&q&r&s&t&x&z&|'Q']'^'_'a'b'c'd'e'f'g'h'o'p'q't'w'y'{'|'}(O(P(Q(R(S(Y(Z([(_(a(c(e(k(l(v(zU!f[_#oV!j]^#iW!g[]^#iQ!m_R$q#oX$X#S'i(w({R!qb",nodeNames:"⚠ LineComment BlockComment Expressions ForExpression for InExpressions InExpression Name in IterationContext return IfExpression if then else QuantifiedExpression some every InExpressions InExpression satisfies Disjunction or Conjunction and Comparison CompareOp CompareOp between PositiveUnaryTest ( PositiveUnaryTests ) ArithmeticExpression ArithOp ArithOp ArithOp ArithOp ArithOp InstanceOf instance of Type QualifiedName SpecialType days time duration years months date > ListType list < ContextType context ContextEntryTypes ContextEntryType FunctionType function ArgumentTypes ArgumentType PathExpression ] FilterExpression [ FunctionInvocation SpecialFunctionName string length upper case lower substring before after starts with ends contains insert index distinct values met by overlaps finished started day year week month get value entries NamedParameters NamedParameter ParameterName SpecialParameterName start position decimal sep separator grouping PositionalParameters null NumericLiteral StringLiteral BooleanLiteral DateTimeLiteral DateTimeConstructor VariableName ? SimplePositiveUnaryTest Interval ParenthesizedExpression List FunctionDefinition FormalParameters FormalParameter external FunctionBody } { Context ContextEntry Key SpecialKey method signature UnaryTests Wildcard not",maxTerm:176,nodeProps:[[no.group,-18,4,12,16,22,24,26,34,40,64,66,68,115,116,117,119,120,121,128,"Expression",-5,109,110,111,112,113,"Expression Literal"],[no.closedBy,31,")",67,"]",127,"}"],[no.openedBy,33,"(",65,"[",126,"{"]],skippedNodes:[0,1,2],repeatNodeCount:11,tokenData:",r~R|XY#{Y^#{pq#{qr$prs${tu%oxy(Tyz(Yz{(_{|(l|}(q}!O(v!O!P)T!P!Q)m!Q![*x![!]+c!]!^+h!^!_+m!_!`$v!`!a+|!a!b%o!c!}%o!}#O,W#P#Q,]#Q#R(g#R#S%o#T#o%o#o#p,b#q#r,g#y#z#{$f$g#{#BY#BZ#{$IS$I_#{$I`$Ib%o$I|$JO#{$JT$JU#{$KV$KW#{$Kh%#t%o&/x&Et%o&FU&FV#{&FV;'S%o;'S;:j,l?&r?Ah%o?BY?Mn%o~$QY$[~X^#{pq#{#y#z#{$f$g#{#BY#BZ#{$IS$I_#{$I|$JO#{$JT$JU#{$KV$KW#{&FU&FV#{~$sP!_!`$v~${Ok~~%QU#c~OY${Zr${rs%ds#O${#O#P%i#P~${~%iO#c~~%lPO~${~%t_$`~tu&s!Q![&s!a!b&s!c!}&s#R#S&s#T#o&s1p4U&s$I`$Ib&s$Je$Jg&s$Kh%#t&s&/x&Et&s&FV;'S&s;'S;:j'}?&r?Ah&s?BY?Mn&s~&x_$`~tu&s!Q![&s!a!b&s!c!}&s#R#S&s#T#o&s1p4U&s$I`$Ib&s$Je$Jg&s$Kh%#t&s&/x&Et&s&FV;'S&s;'S;:j'w?&r?Ah&s?BY?Mn&s~'zP;=`<%l&s~(QP;=`<%l&s~(YOo~~(_Oq~~(dPu~z{(g~(lOw~~(qOs~~(vO$c~R({PtP!`!a)OQ)TO$jQ~)YQ$f~!O!P)`!Q![)e~)eO$b~~)jP$p~!Q![)e~)rQv~z{)x!P!Q*m~){ROz)xz{*U{~)x~*XTOz)xz{*U{!P)x!P!Q*h!Q~)x~*mOQ~~*rQP~OY*mZ~*m~*}Q$p~!O!P+T!Q![*x~+WP!Q![+Z~+`P$p~!Q![+Z~+hO$h~~+mO$v~R+tP!XQlP!_!`+wP+|OlPR,TP!UQlP!_!`+w~,]O!e~~,bO!c~~,gO#s~~,lO#r~~,oP;=`<%l%o",tokenizers:[0,1],topRules:{Expressions:[0,3],UnaryTests:[1,134]},dynamicPrecedences:{24:-1,68:-1,151:-1},specialized:[{term:154,get:t=>Fo[t]||-1}],tokenPrec:0}),Go=function(t,e){let i,s=[Gr];return t instanceof Wr&&(t.module&&s.push(yn.styleModule.of(t.module)),i=t.themeType),(null==e?void 0:e.fallback)?s.push(Lr.of(t)):i?s.push(Ir.computeN([yn.darkTheme],(e=>e.facet(yn.darkTheme)==("dark"==i)?[t]:[]))):s.push(Ir.of(t)),s}(Wr.define([{tag:$r.variableName,color:"#10f"},{tag:$r.name,color:"#10f"},{tag:$r.number,color:"#164"},{tag:$r.string,color:"#a11"},{tag:$r.function($r.variableName),color:"#aa3731",fontWeight:"bold"},{tag:$r.keyword,color:"#708",fontWeight:"bold"}])),Zo=nr({VariableName:$r.variableName,NumericLiteral:$r.number,QualifiedName:$r.name,Name:$r.name,BooleanLiteral:$r.bool,StringLiteral:$r.string,LineComment:$r.lineComment,BlockComment:$r.blockComment,"( )":$r.paren,BuiltInFunctionName:$r.function($r.variableName),BuiltInType:$r.function($r.variableName),ListType:$r.function($r.variableName),ContextType:$r.function($r.variableName),FunctionType:$r.function($r.variableName),DateAndTime:$r.function($r.variableName),"DateTimeConstructor!":$r.function($r.variableName),"for in return null":$r.keyword,List:$r.list,Interval:$r.list});let Uo=Ho.configure({props:[Zo]});const Yo=Tr.define({parser:Uo});function Ko(t){const{name:e,error:i}=t;return i||"⚠"===e?"error":"BuiltInFunctionName"===e||"BuiltInType"===e||"ListType"===e||"ContextType"===e||"FunctionType"===e||"DateAndTime"===e||"DateTimeConstructor"===e?"builtin":"BlockComment"===e||"LineComment"===e?"comment":"Parameters"===e?"parameters":"List"===e?"list":"Context"===e?"context":"Interval"===e?"interval":"StringLiteral"===e?"string":"NumericLiteral"===e?"number":"BooleanLiteral"===e?"boolean":"QualifiedName"===e?"qname":"Name"===e?"name":"VariableName"===e?"variable":e}const Jo=yn.updateListener.of((t=>{console.log(t),console.log(t.state.tree),1===t.state.tree.children.length&&t.state.tree.children[0].buffer&&console.log(function(t){const e=[{children:[]}];return console.log(t),t.iterate({enter(t,i,s){const{name:n}=t;console.log(t);const r={name:n,start:i,end:s,children:[],type:Ko(t)};e.push(r)},leave(t,i,s){const n=e.pop();if(n.skip)return;const r=e[e.length-1];r.children.push(n),n.parent=r,n.tokenType||n.error}}),e[0].children[0]}(t.state.tree))}));exports.FeelEditor=function({container:t}){return new yn({state:xt.create({extensions:[Jo,new zr(Yo,[]),Go]}),parent:t})};
|