chrome-devtools-frontend 1.0.930993 → 1.0.932348
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/config/gni/devtools_grd_files.gni +6 -2
- package/front_end/core/common/ParsedURL.ts +12 -10
- package/front_end/core/host/InspectorFrontendHostAPI.ts +8 -6
- package/front_end/core/i18n/locales/en-US.json +345 -12
- package/front_end/core/i18n/locales/en-XL.json +345 -12
- package/front_end/core/platform/DevToolsPath.ts +34 -0
- package/front_end/core/platform/platform.ts +2 -0
- package/front_end/core/protocol_client/NodeURL.ts +2 -1
- package/front_end/core/sdk/CSSStyleSheetHeader.ts +4 -2
- package/front_end/core/sdk/ChildTargetManager.ts +2 -0
- package/front_end/core/sdk/CompilerSourceMappingContentProvider.ts +4 -2
- package/front_end/core/sdk/DebuggerModel.ts +4 -3
- package/front_end/core/sdk/NetworkRequest.ts +3 -2
- package/front_end/core/sdk/Resource.ts +6 -5
- package/front_end/core/sdk/Script.ts +4 -2
- package/front_end/core/sdk/Target.ts +4 -0
- package/front_end/core/sdk/TracingModel.ts +8 -17
- package/front_end/entrypoint_template.html +1 -1
- package/front_end/entrypoints/formatter_worker/ESTreeWalker.ts +1 -1
- package/front_end/models/bindings/BreakpointManager.ts +6 -3
- package/front_end/models/bindings/ResourceMapping.ts +2 -1
- package/front_end/models/bindings/StylesSourceMapping.ts +2 -1
- package/front_end/models/emulation/DeviceModeModel.ts +1 -1
- package/front_end/models/persistence/IsolatedFileSystem.ts +9 -7
- package/front_end/models/persistence/IsolatedFileSystemManager.ts +8 -7
- package/front_end/models/persistence/PersistenceActions.ts +1 -1
- package/front_end/models/persistence/PlatformFileSystem.ts +4 -3
- package/front_end/models/text_utils/ContentProvider.ts +2 -1
- package/front_end/models/text_utils/StaticContentProvider.ts +4 -2
- package/front_end/models/workspace/UISourceCode.ts +3 -2
- package/front_end/panels/animation/AnimationGroupPreviewUI.ts +25 -25
- package/front_end/panels/animation/AnimationModel.ts +157 -156
- package/front_end/panels/animation/AnimationScreenshotPopover.ts +26 -26
- package/front_end/panels/animation/AnimationTimeline.ts +274 -260
- package/front_end/panels/animation/AnimationUI.ts +155 -145
- package/front_end/panels/application/BackForwardCacheStrings.ts +621 -0
- package/front_end/panels/application/BackForwardCacheView.ts +24 -8
- package/front_end/panels/application/ReportingApiReportsView.ts +3 -2
- package/front_end/panels/application/ReportingApiView.ts +1 -2
- package/front_end/panels/application/backForwardCacheView.css +10 -0
- package/front_end/panels/browser_debugger/CategorizedBreakpointsSidebarPane.ts +48 -40
- package/front_end/panels/browser_debugger/DOMBreakpointsSidebarPane.ts +37 -37
- package/front_end/panels/browser_debugger/ObjectEventListenersSidebarPane.ts +23 -19
- package/front_end/panels/browser_debugger/XHRBreakpointsSidebarPane.ts +56 -56
- package/front_end/panels/changes/ChangesView.ts +42 -225
- package/front_end/panels/changes/changes-legacy.ts +0 -2
- package/front_end/panels/changes/changes.ts +0 -6
- package/front_end/panels/changes/changesView.css +2 -69
- package/front_end/panels/changes/module.json +1 -1
- package/front_end/panels/console/ConsolePinPane.ts +80 -75
- package/front_end/panels/console/ConsoleView.ts +1 -9
- package/front_end/panels/console/consolePinPane.css +4 -1
- package/front_end/panels/elements/StylesSidebarPane.ts +2 -1
- package/front_end/panels/security/mainView.css +2 -1
- package/front_end/panels/snippets/ScriptSnippetFileSystem.ts +2 -1
- package/front_end/panels/sources/NavigatorView.ts +5 -2
- package/front_end/panels/sources/SourcesPanel.ts +28 -1
- package/front_end/panels/sources/sources-meta.ts +1 -4
- package/front_end/third_party/codemirror.next/bundle.ts +6 -4
- package/front_end/third_party/codemirror.next/chunk/codemirror.js +1 -1
- package/front_end/third_party/codemirror.next/chunk/markdown.js +1 -1
- package/front_end/third_party/codemirror.next/codemirror.next.d.ts +30 -1
- package/front_end/third_party/codemirror.next/codemirror.next.js +1 -1
- package/front_end/third_party/codemirror.next/package.json +4 -3
- package/front_end/ui/components/buttons/Button.ts +22 -6
- package/front_end/ui/components/buttons/button.css +50 -4
- package/front_end/ui/components/diff_view/DiffView.ts +288 -0
- package/front_end/ui/components/diff_view/diffView.css +73 -0
- package/front_end/ui/components/diff_view/diff_view.ts +5 -0
- package/front_end/ui/components/docs/button/basic.html +28 -0
- package/front_end/ui/components/docs/button/basic.ts +43 -2
- package/front_end/ui/components/report_view/report.css +1 -0
- package/front_end/ui/components/text_editor/config.ts +34 -1
- package/front_end/ui/legacy/ForwardedInputEventHandler.ts +5 -3
- package/front_end/ui/legacy/components/color_picker/spectrum.css +2 -4
- package/front_end/ui/legacy/themeColors.css +4 -0
- package/package.json +1 -1
- package/scripts/build/generate_css_js_files.js +1 -0
- package/scripts/migration/class-fields/migrate.js +1 -3
- package/front_end/panels/changes/ChangesHighlighter.ts +0 -179
- package/front_end/panels/changes/ChangesTextEditor.ts +0 -96
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=1024;let e=0;class i{constructor(t,e){this.from=t,this.to=e}}class s{constructor(t={}){this.id=e++,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=o.match(t)),e=>{let i=t(e);return void 0===i?null:[this,i]}}}s.closedBy=new s({deserialize:t=>t.split(" ")}),s.openedBy=new s({deserialize:t=>t.split(" ")}),s.group=new s({deserialize:t=>t.split(" ")}),s.contextHash=new s({perNode:!0}),s.lookAhead=new s({perNode:!0}),s.mounted=new s({perNode:!0});class n{constructor(t,e,i){this.tree=t,this.overlay=e,this.parser=i}}const r=Object.create(null);class o{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):r,i=(t.top?1:0)|(t.skipped?2:0)|(t.error?4:0)|(null==t.name?8:0),s=new o(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(s.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(s.group),n=-1;n<(i?i.length:0);n++){let s=e[n<0?t.name:i[n]];if(s)return s}}}}o.none=new o("",Object.create(null),0,8);class h{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)),s[t[0].id]=t[1])}e.push(s?new o(i.name,s,i.id,i.flags):i)}return new h(e)}}const l=new WeakMap;class a{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(s.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,e=0){let i=null!=t&&l.get(this)||this.topNode,s=new v(i);return null!=t&&(s.moveTo(t,e),l.set(this,s._tree)),s}fullCursor(){return new v(this.topNode,1)}get topNode(){return new p(this,0,0,null)}resolve(t,e=0){return this.cursor(t,e).node}resolveInner(t,e=0){let i=this.topNode;for(;;){let s=i.enter(t,e);if(!s)return i;i=s}}iterate(t){let{enter:e,leave:i,from:s=0,to:n=this.length}=t;for(let t=this.cursor(),r=()=>t.node;;){let o=!1;if(t.from<=n&&t.to>=s&&(t.type.isAnonymous||!1!==e(t.type,t.from,t.to,r))){if(t.firstChild())continue;t.type.isAnonymous||(o=!0)}for(;o&&i&&i(t.type,t.from,t.to,r),o=t.type.isAnonymous,!t.nextSibling();){if(!t.parent())return;o=!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:k(this.type,this.children,this.positions,0,this.children.length,0,this.length,((t,e,i)=>new a(this.type,t,e,i,this.propValues)),t.makeTree||((t,e,i)=>new a(o.none,t,e,i)))}static build(e){return function(e){var i;let{buffer:n,nodeSet:r,maxBufferLength:o=t,reused:h=[],minRepeatType:l=r.types.length}=e,f=Array.isArray(n)?new c(n,n.length):n,d=r.types,p=0,g=0;function m(t,e,i,s,n){let{id:a,start:c,end:S,size:A}=f,C=g;for(;A<0;){if(f.next(),-1==A){let e=h[a];return i.push(e),void s.push(c-t)}if(-3==A)return void(p=a);if(-4==A)return void(g=a);throw new RangeError(`Unrecognized record size: ${A}`)}let M,D,O=d[a],T=c-t;if(S-c<=o&&(D=b(f.pos-e,n))){let e=new Uint16Array(D.size-D.skip),i=f.pos-D.size,s=e.length;for(;f.pos>i;)s=x(D.start,e,s);M=new u(e,S-D.start,r),T=D.start-t}else{let t=f.pos-A;f.next();let e=[],i=[],s=a>=l?a:-1,n=0,r=S;for(;f.pos>t;)s>=0&&f.id==s&&f.size>=0?(f.end<=r-o&&(v(e,i,c,n,f.end,r,s,C),n=e.length,r=f.end),f.next()):m(c,t,e,i,s);if(s>=0&&n>0&&n<e.length&&v(e,i,c,n,c,r,s,C),e.reverse(),i.reverse(),s>-1&&n>0){let t=w(O);M=k(O,e,i,0,e.length,0,S-c,t,t)}else M=y(O,e,i,S-c,C-S)}i.push(M),s.push(T)}function w(t){return(e,i,n)=>{let r,o,h=0,l=e.length-1;if(l>=0&&(r=e[l])instanceof a){if(!l&&r.type==t&&r.length==n)return r;(o=r.prop(s.lookAhead))&&(h=i[l]+r.length+o)}return y(t,e,i,n,h)}}function v(t,e,i,s,n,o,h,l){let a=[],c=[];for(;t.length>s;)a.push(t.pop()),c.push(e.pop()+i-n);t.push(y(r.types[h],a,c,o-n,l-o)),e.push(n-i)}function y(t,e,i,n,r=0,o){if(p){let t=[s.contextHash,p];o=o?[t].concat(o):[t]}if(r>25){let t=[s.lookAhead,r];o=o?[t].concat(o):[t]}return new a(t,e,i,n,o)}function b(t,e){let i=f.fork(),s=0,n=0,r=0,h=i.end-o,a={size:0,start:0,skip:0};t:for(let o=i.pos-t;i.pos>o;){let t=i.size;if(i.id==e&&t>=0){a.size=s,a.start=n,a.skip=r,r+=4,s+=4,i.next();continue}let c=i.pos-t;if(t<0||c<o||i.start<h)break;let u=i.id>=l?4:0,f=i.start;for(i.next();i.pos>c;){if(i.size<0){if(-3!=i.size)break t;u+=4}else i.id>=l&&(u+=4);i.next()}n=f,s+=t,r+=u}return(e<0||s==t)&&(a.size=s,a.start=n,a.skip=r),a.size>4?a:void 0}function x(t,e,i){let{id:s,start:n,end:r,size:o}=f;if(f.next(),o>=0&&s<l){let h=i;if(o>4){let s=f.pos-(o-4);for(;f.pos>s;)i=x(t,e,i)}e[--i]=h,e[--i]=r-t,e[--i]=n-t,e[--i]=s}else-3==o?p=s:-4==o&&(g=s);return i}let S=[],A=[];for(;f.pos>0;)m(e.start||0,e.bufferStart||0,S,A,-1);let C=null!==(i=e.length)&&void 0!==i?i:S.length?A[0]+S[0].length:0;return new a(d[e.topID],S.reverse(),A.reverse(),C)}(e)}}a.empty=new a(o.none,[],[],0);class c{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 c(this.buffer,this.index)}}class u{constructor(t,e,i){this.buffer=t,this.length=e,this.set=i}get type(){return o.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&&!(f(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 u(r,s-i,this.set)}}function f(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 d(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}class p{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 from(){return this._from}get to(){return this._from+this.node.length}nextChild(t,e,i,n,r=0){for(let o=this;;){for(let{children:h,positions:l}=o.node,a=e>0?h.length:-1;t!=a;t+=e){let a=h[t],c=l[t]+o._from;if(f(n,i,c,c+a.length))if(a instanceof u){if(2&r)continue;let s=a.findChild(0,a.buffer.length,e,i-c,n);if(s>-1)return new w(new m(o,a,t,c),null,s)}else if(1&r||!a.type.isAnonymous||y(a)){let h;if(a.props&&(h=a.prop(s.mounted))&&!h.overlay)return new p(h.tree,c,t,o);let l=new p(a,c,t,o);return 1&r||!l.type.isAnonymous?l:l.nextChild(e<0?a.children.length-1:0,e,i,n)}}if(1&r||!o.type.isAnonymous)return null;if(t=o.index>=0?o.index+e:e<0?-1:o._parent.node.children.length,o=o._parent,!o)return null}}get firstChild(){return this.nextChild(0,1,0,4)}get lastChild(){return this.nextChild(this.node.children.length-1,-1,0,4)}childAfter(t){return this.nextChild(0,1,t,2)}childBefore(t){return this.nextChild(this.node.children.length-1,-1,t,-2)}enter(t,e,i=!0,n=!0){let r;if(i&&(r=this.node.prop(s.mounted))&&r.overlay){let i=t-this.from;for(let{from:t,to:s}of r.overlay)if((e>0?t<=i:t<i)&&(e<0?s>=i:s>i))return new p(r.tree,r.overlay[0].from+this.from,-1,this)}return this.nextChild(0,1,t,e,n?0:2)}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}get cursor(){return new v(this)}get tree(){return this.node}toTree(){return this.node}resolve(t,e=0){return this.cursor.moveTo(t,e).node}enterUnfinishedNodesBefore(t){return d(this,t)}getChild(t,e=null,i=null){let s=g(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return g(this,t,e,i)}toString(){return this.node.toString()}}function g(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 m{constructor(t,e,i,s){this.parent=t,this.buffer=e,this.index=i,this.start=s}}class w{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 w(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,s=!0){if(!s)return null;let{buffer:n}=this.context,r=n.findChild(this.index+4,n.buffer[this.index+3],e>0?1:-1,t-this.context.start,e);return r<0?null:new w(this.context,this,r)}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 w(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 w(this.context,this._parent,t.findChild(e,this.index,-1,0,4))}get cursor(){return new v(this)}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 a(this.type,t,e,this.to-this.from)}resolve(t,e=0){return this.cursor.moveTo(t,e).node}enterUnfinishedNodesBefore(t){return d(this,t)}toString(){return this.context.buffer.childString(this.index)}getChild(t,e=null,i=null){let s=g(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return g(this,t,e,i)}}class v{constructor(t,e=0){if(this.mode=e,this.buffer=null,this.stack=[],this.index=0,this.bufferNode=null,t instanceof p)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 p?(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.node.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=!0,s=!0){return this.buffer?!!s&&this.enterChild(1,t,e):this.yield(this._tree.enter(t,e,i,s))}parent(){if(!this.buffer)return this.yieldNode(1&this.mode?this._tree._parent:this._tree.parent);if(this.stack.length)return this.yieldBuf(this.stack.pop());let t=1&this.mode?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.node.children.length;s!=n;s+=t){let t=i.node.children[s];if(1&this.mode||t instanceof u||!t.type.isAnonymous||y(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 w(this.buffer,e,this.stack[t]);return this.bufferNode=new w(this.buffer,e,this.index)}get tree(){return this.buffer?null:this._tree.node}}function y(t){return t.children.some((t=>t instanceof u||!t.type.isAnonymous||y(t)))}const b=new WeakMap;function x(t,e){if(!t.isAnonymous||e instanceof u||e.type!=t)return 1;let i=b.get(e);return null==i&&(i=e.children.reduce(((e,i)=>e+x(t,i)),1),b.set(e,i)),i}function k(t,e,i,s,n,r,o,h,l){let a=0;for(let i=s;i<n;i++)a+=x(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=x(t,i[a]);for(a++;a<o;a++){let e=x(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(k(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 S{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 S(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 S(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 A{startParse(t,e,s){return"string"==typeof t&&(t=new C(t)),s=s?s.length?s.map((t=>new i(t.from,t.to))):[new i(0,0)]:[new i(0,t.length)],this.createParse(t,e||[],s)}parse(t,e,i){let s=this.startParse(t,e,i);for(;;){let t=s.advance();if(t)return t}}}class C{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)}}function M(t){return(e,i,s,n)=>new T(e,t,i,s,n)}class D{constructor(t,e,i,s){this.parser=t,this.parse=e,this.overlay=i,this.target=s}}class O{constructor(t,e,i,s,n,r,o){this.parser=t,this.predicate=e,this.mounts=i,this.index=s,this.start=n,this.target=r,this.prev=o,this.depth=0,this.ranges=[]}}class T{constructor(t,e,i,s,n){this.nest=e,this.input=i,this.fragments=s,this.ranges=n,this.inner=[],this.innerDone=0,this.baseTree=null,this.stoppedAt=null,this.baseParse=t}advance(){if(this.baseParse){let t=this.baseParse.advance();if(!t)return null;this.baseParse=null,this.baseTree=t,this.startInner()}if(this.innerDone==this.inner.length)return this.baseTree;let t=this.inner[this.innerDone],e=t.parse.advance();if(e){this.innerDone++;let i=Object.assign(Object.create(null),t.target.props);i[s.mounted.id]=new n(e,t.overlay,t.parser),t.target.props=i}return null}get parsedPos(){if(this.baseParse)return 0;let t=this.inner[this.innerDone];return t?t.parse.parsedPos:this.input.length}stopAt(t){if(this.stoppedAt=t,this.baseParse)this.baseParse.stopAt(t);else for(let e=this.innerDone;e<this.inner.length;e++)this.inner[e].parse.stopAt(t)}startInner(){let t=new N(this.fragments),e=null,s=null;t:for(let n,r,o=this.baseTree.fullCursor();;){let h,l=!0;if(t.hasNode(o)){if(e){let t=e.mounts.find((t=>t.frag.from<=o.from&&t.frag.to>=o.to&&t.mount.overlay));if(t)for(let i of t.mount.overlay){let s=i.from+t.pos,n=i.to+t.pos;s>=o.from&&n<=o.to&&e.ranges.push({from:s,to:n})}}l=!1}else if(s&&(r=P(s.ranges,o.from,o.to)))l=2!=r;else if(!o.type.isAnonymous&&o.from<o.to&&(n=this.nest(o,this.input))){o.tree||R(o);let r=t.findMounts(o.from,n.parser);if("function"==typeof n.overlay)e=new O(n.parser,n.overlay,r,this.inner.length,o.from,o.tree,e);else{let t=I(this.ranges,n.overlay||[new i(o.from,o.to)]);t.length&&this.inner.push(new D(n.parser,n.parser.startParse(this.input,V(r,t),t),n.overlay?n.overlay.map((t=>new i(t.from-o.from,t.to-o.from))):null,o.tree)),n.overlay?t.length&&(s={ranges:t,depth:0,prev:s}):l=!1}}else e&&(h=e.predicate(o))&&(!0===h&&(h=new i(o.from,o.to)),h.from<h.to&&e.ranges.push(h));if(l&&o.firstChild())e&&e.depth++,s&&s.depth++;else for(;!o.nextSibling();){if(!o.parent())break t;if(e&&!--e.depth){let t=I(this.ranges,e.ranges);t.length&&this.inner.splice(e.index,0,new D(e.parser,e.parser.startParse(this.input,V(e.mounts,t),t),e.ranges.map((t=>new i(t.from-e.start,t.to-e.start))),e.target)),e=e.prev}s&&!--s.depth&&(s=s.prev)}}}}function P(t,e,i){for(let s of t){if(s.from>=i)break;if(s.to>e)return s.from<=e&&s.to>=i?2:1}return 0}function E(t,e,i,s,n,r){if(e<i){let o=t.buffer[e+1],h=t.buffer[i-2];s.push(t.slice(e,i,o,h)),n.push(o-r)}}function R(t){let{node:e}=t,i=0;do{t.parent(),i++}while(!t.tree);let s=0,n=t.tree,r=0;for(;r=n.positions[s]+t.from,!(r<=e.from&&r+n.children[s].length>=e.to);s++);let h=n.children[s],l=h.buffer;n.children[s]=function t(i,s,n,o){let c=i;for(;l[c+2]+r<=e.from;)c=l[c+3];let u=[],f=[];E(h,i,c,u,f,o);let d=l[c+1]+r==e.from&&l[c+2]+r==e.to&&l[c]==e.type.id;u.push(d?e.toTree():t(c+4,l[c+3],h.set.types[l[c]],l[c+1])),f.push(l[c+1]-o),E(h,l[c+3],s,u,f,o);let p=u.length-1;return new a(n,u,f,f[p]+u[p].length)}(0,l.length,o.none,0);for(let s=0;s<=i;s++)t.childAfter(e.from)}class L{constructor(t,e){this.offset=e,this.done=!1,this.cursor=t.fullCursor()}moveTo(t){let{cursor:e}=this,i=t-this.offset;for(;!this.done&&e.from<i;)e.to>=t&&e.enter(i,1,!1,!1)||e.next(!1)||(this.done=!0)}hasNode(t){if(this.moveTo(t.from),!this.done&&this.cursor.from+this.offset==t.from&&this.cursor.tree)for(let e=this.cursor.tree;;){if(e==t.tree)return!0;if(!(e.children.length&&0==e.positions[0]&&e.children[0]instanceof a))break;e=e.children[0]}return!1}}class N{constructor(t){if(this.fragments=t,this.fragI=0,t.length){let e=this.curFrag=t[0];this.inner=new L(e.tree,-e.offset)}else this.curFrag=this.inner=null}hasNode(t){for(;this.curFrag&&t.from>=this.curFrag.to;)this.nextFrag();return this.curFrag&&this.curFrag.from<=t.from&&this.curFrag.to>=t.to&&this.inner.hasNode(t)}nextFrag(){if(this.fragI++,this.fragI==this.fragments.length)this.curFrag=this.inner=null;else{let t=this.curFrag=this.fragments[this.fragI];this.inner=new L(t.tree,-t.offset)}}findMounts(t,e){var i;let n=[];if(this.inner){this.inner.cursor.moveTo(t,1);for(let t=this.inner.cursor.node;t;t=t.parent){let r=null===(i=t.tree)||void 0===i?void 0:i.prop(s.mounted);if(r&&r.parser==e)for(let e=this.fragI;e<this.fragments.length;e++){let i=this.fragments[e];if(i.from>=t.to)break;i.tree==this.curFrag.tree&&n.push({frag:i,pos:t.from-i.offset,mount:r})}}}return n}}function I(t,e){let s=null,n=e;for(let r=1,o=0;r<t.length;r++){let h=t[r-1].to,l=t[r].from;for(;o<n.length;o++){let t=n[o];if(t.from>=l)break;t.to<=h||(s||(n=s=e.slice()),t.from<h?(s[o]=new i(t.from,h),t.to>l&&s.splice(o+1,0,new i(l,t.to))):t.to>l?s[o--]=new i(l,t.to):s.splice(o--,1))}}return n}function B(t,e,s,n){let r=0,o=0,h=!1,l=!1,a=-1e9,c=[];for(;;){let u=r==t.length?1e9:h?t[r].to:t[r].from,f=o==e.length?1e9:l?e[o].to:e[o].from;if(h!=l){let t=Math.max(a,s),e=Math.min(u,f,n);t<e&&c.push(new i(t,e))}if(a=Math.min(u,f),1e9==a)break;u==a&&(h?(h=!1,r++):h=!0),f==a&&(l?(l=!1,o++):l=!0)}return c}function V(t,e){let s=[];for(let{pos:n,mount:r,frag:o}of t){let t=n+(r.overlay?r.overlay[0].from:0),h=t+r.tree.length,l=Math.max(o.from,t),a=Math.min(o.to,h);if(r.overlay){let h=B(e,r.overlay.map((t=>new i(t.from+n,t.to+n))),l,a);for(let e=0,i=l;;e++){let n=e==h.length,l=n?a:h[e].from;if(l>i&&s.push(new S(i,l,r.tree,-t,o.from>=i,o.to<=l)),n)break;i=h[e].to}}else s.push(new S(l,a,r.tree,-t,o.from>=t,o.to<=h))}return s}const z="undefined"==typeof Symbol?"__ͼ":Symbol.for("ͼ"),F="undefined"==typeof Symbol?"__styleSet"+Math.floor(1e8*Math.random()):Symbol("styleSet"),H="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:{};class W{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=H[z]||1;return H[z]=t+1,"ͼ"+t.toString(36)}static mount(t,e){(t[F]||new j(t)).mount(Array.isArray(e)?e:[e])}}let q=null;class j{constructor(t){if(!t.head&&t.adoptedStyleSheets&&"undefined"!=typeof CSSStyleSheet){if(q)return t.adoptedStyleSheets=[q.sheet].concat(t.adoptedStyleSheets),t[F]=q;this.sheet=new CSSStyleSheet,t.adoptedStyleSheets=[this.sheet].concat(t.adoptedStyleSheets),q=this}else{this.styleTag=(t.ownerDocument||t).createElement("style");let e=t.head||t;e.insertBefore(this.styleTag,e.firstChild)}this.modules=[],t[F]=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}}}let _="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<_.length;t++)_[t]+=_[t-1];function $(t){for(let e=1;e<_.length;e+=2)if(_[e]>t)return _[e-1]<=t;return!1}function U(t){return t>=127462&&t<=127487}function G(t,e,i=!0){return(i?K:J)(t,e)}function K(t,e){if(e==t.length)return e;e&&X(t.charCodeAt(e))&&Y(t.charCodeAt(e-1))&&e--;let i=Q(t,e);for(e+=tt(i);e<t.length;){let s=Q(t,e);if(8205==i||8205==s||$(s))e+=tt(s),i=s;else{if(!U(s))break;{let i=0,s=e-2;for(;s>=0&&U(Q(t,s));)i++,s-=2;if(i%2==0)break;e+=2}}}return e}function J(t,e){for(;e>0;){let i=K(t,e-2);if(i<e)return i;e--}return 0}function X(t){return t>=56320&&t<57344}function Y(t){return t>=55296&&t<56320}function Q(t,e){let i=t.charCodeAt(e);if(!Y(i)||e+1==t.length)return i;let s=t.charCodeAt(e+1);return X(s)?s-56320+(i-55296<<10)+65536:i}function Z(t){return t<=65535?String.fromCharCode(t):(t-=65536,String.fromCharCode(55296+(t>>10),56320+(1023&t)))}function tt(t){return t<65536?1:2}function et(t,e,i=t.length){let s=0;for(let n=0;n<i;)9==t.charCodeAt(n)?(s+=e-s%e,n++):(s++,n=G(t,n));return s}class it{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,i){let s=[];return this.decompose(0,t,s,2),i.length&&i.decompose(0,i.length,s,3),this.decompose(e,this.length,s,1),nt.from(s,this.length-(e-t)+i.length)}append(t){return this.replace(this.length,this.length,t)}slice(t,e=this.length){let i=[];return this.decompose(t,e,i,0),nt.from(i,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 ht(this),n=new ht(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 ht(this,t)}iterRange(t,e=this.length){return new lt(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 at(i)}toString(){return this.sliceString(0)}toJSON(){let t=[];return this.flatten(t),t}static of(t){if(0==t.length)throw new RangeError("A document must have at least one line");return 1!=t.length||t[0]?t.length<=32?new st(t):nt.from(st.split(t,[])):it.empty}}class st extends it{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 ct(s,o,i,r);s=o+1,i++}}decompose(t,e,i,s){let n=t<=0&&e>=this.length?this:new st(ot(this.text,t,e),Math.min(e,this.length)-Math.max(0,t));if(1&s){let t=i.pop(),e=rt(n.text,t.text.slice(),0,n.length);if(e.length<=32)i.push(new st(e,t.length+n.length));else{let t=e.length>>1;i.push(new st(e.slice(0,t)),new st(e.slice(t)))}}else i.push(n)}replace(t,e,i){if(!(i instanceof st))return super.replace(t,e,i);let s=rt(this.text,rt(i.text,ot(this.text,0,t)),e),n=this.length+i.length-(e-t);return s.length<=32?new st(s,n):nt.from(st.split(s,[]),n)}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,e){let i=[],s=-1;for(let n of t)i.push(n),s+=n.length+1,32==i.length&&(e.push(new st(i,s)),i=[],s=-1);return s>-1&&e.push(new st(i,s)),e}}class nt extends it{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,i){if(i.lines<this.lines)for(let s=0,n=0;s<this.children.length;s++){let r=this.children[s],o=n+r.length;if(t>=n&&e<=o){let h=r.replace(t-n,e-n,i),l=this.lines-r.lines+h.lines;if(h.lines<l>>4&&h.lines>l>>6){let n=this.children.slice();return n[s]=h,new nt(n,this.length-(e-t)+i.length)}return super.replace(n,o,h)}n=o+1}return super.replace(t,e,i)}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 nt))return 0;let i=0,[s,n,r,o]=e>0?[0,0,this.children.length,t.children.length]:[this.children.length-1,t.children.length-1,-1,-1];for(;;s+=e,n+=e){if(s==r||n==o)return i;let h=this.children[s],l=t.children[n];if(h!=l)return i+h.scanIdentical(l,e);i+=h.length+1}}static from(t,e=t.reduce(((t,e)=>t+e.length+1),-1)){let i=0;for(let e of t)i+=e.lines;if(i<32){let i=[];for(let e of t)e.flatten(i);return new st(i,e)}let s=Math.max(32,i>>5),n=s<<1,r=s>>1,o=[],h=0,l=-1,a=[];function c(t){let e;if(t.lines>n&&t instanceof nt)for(let e of t.children)c(e);else t.lines>r&&(h>r||!h)?(u(),o.push(t)):t instanceof st&&h&&(e=a[a.length-1])instanceof st&&t.lines+e.lines<=32?(h+=t.lines,l+=t.length+1,a[a.length-1]=new st(e.text.concat(t.text),e.length+1+t.length)):(h+t.lines>s&&u(),h+=t.lines,l+=t.length+1,a.push(t))}function u(){0!=h&&(o.push(1==a.length?a[0]:nt.from(a,l)),l=-1,h=a.length=0)}for(let e of t)c(e);return u(),1==o.length?o[0]:new nt(o,e)}}function rt(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 ot(t,e,i){return rt(t,[""],e,i)}it.empty=new st([""],0);class ht{constructor(t,e=1){this.dir=e,this.done=!1,this.lineBreak=!1,this.value="",this.nodes=[t],this.offsets=[e>0?1:(t instanceof st?t.text.length:t.children.length)<<1]}nextInner(t,e){for(this.done=this.lineBreak=!1;;){let i=this.nodes.length-1,s=this.nodes[i],n=this.offsets[i],r=n>>1,o=s instanceof st?s.text.length:s.children.length;if(r==(e>0?o:0)){if(0==i)return this.done=!0,this.value="",this;e>0&&this.offsets[i-1]++,this.nodes.pop(),this.offsets.pop()}else if((1&n)==(e>0?0:1)){if(this.offsets[i]+=e,0==t)return this.lineBreak=!0,this.value="\n",this;t--}else if(s instanceof st){let n=s.text[r+(e<0?-1:0)];if(this.offsets[i]+=e,n.length>Math.max(0,t))return this.value=0==t?n:e>0?n.slice(t):n.slice(0,n.length-t),this;t-=n.length}else{let n=s.children[r+(e<0?-1:0)];t>n.length?(t-=n.length,this.offsets[i]+=e):(e<0&&this.offsets[i]--,this.nodes.push(n),this.offsets.push(e>0?1:(n instanceof st?n.text.length:n.children.length)<<1))}}}next(t=0){return t<0&&(this.nextInner(-t,-this.dir),t=this.value.length),this.nextInner(t,this.dir)}}class lt{constructor(t,e,i){this.value="",this.done=!1,this.cursor=new ht(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 at{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&&(it.prototype[Symbol.iterator]=function(){return this.iter()},ht.prototype[Symbol.iterator]=lt.prototype[Symbol.iterator]=at.prototype[Symbol.iterator]=function(){return this});class ct{constructor(t,e,i,s){this.from=t,this.to=e,this.number=i,this.text=s}get length(){return this.to-this.from}}const ut=/\r\n?|\n/;var ft=function(t){return t[t.Simple=0]="Simple",t[t.TrackDel=1]="TrackDel",t[t.TrackBefore=2]="TrackBefore",t[t.TrackAfter=3]="TrackAfter",t}(ft||(ft={}));class dt{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){wt(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 dt(t)}composeDesc(t){return this.empty?t:t.empty?this:yt(this,t)}mapDesc(t,e=!1){return t.empty?this:vt(this,t,e)}mapPos(t,e=-1,i=ft.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!=ft.Simple&&l>=t&&(i==ft.TrackDel&&s<t&&l>t||i==ft.TrackBefore&&s<t||i==ft.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 dt(t)}}class pt extends dt{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 wt(this,((e,i,s,n,r)=>t=t.replace(s,s+(i-e),r)),!1),t}mapDesc(t,e=!1){return vt(this,t,e,!0)}invert(t){let e=this.sections.slice(),i=[];for(let s=0,n=0;s<e.length;s+=2){let r=e[s],o=e[s+1];if(o>=0){e[s]=o,e[s+1]=r;let h=s>>1;for(;i.length<h;)i.push(it.empty);i.push(r?t.slice(n,n+r):it.empty)}n+=r}return new pt(e,i)}compose(t){return this.empty?t:t.empty?this:yt(this,t,!0)}map(t,e=!1){return t.empty?this:vt(this,t,e,!0)}iterChanges(t,e=!1){wt(this,t,e)}get desc(){return new dt(this.sections)}filter(t){let e=[],i=[],s=[],n=new bt(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);gt(s,t,-1);let r=-1==n.ins?-1:0==n.off?n.ins:0;gt(e,t,r),r>0&&mt(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);gt(e,t,-1),gt(s,t,-1==n.ins?-1:0==n.off?n.ins:0),n.forward(t),o+=t}}return{changes:new pt(e,i),filtered:new dt(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(t,e,i){let s=[],n=[],r=0,o=null;function h(t=!1){if(!t&&!s.length)return;r<e&>(s,e-r,-1);let i=new pt(s,n);o=o?o.compose(i.map(o)):i,s=[],n=[],r=0}return function t(l){if(Array.isArray(l))for(let e of l)t(e);else if(l instanceof pt){if(l.length!=e)throw new RangeError(`Mismatched change set length (got ${l.length}, expected ${e})`);h(),o=o?o.compose(l.map(o)):l}else{let{from:t,to:o=t,insert:a}=l;if(t>o||t<0||o>e)throw new RangeError(`Invalid change range ${t} to ${o} (in doc of length ${e})`);let c=a?"string"==typeof a?it.of(a.split(i||ut)):a:it.empty,u=c.length;if(t==o&&0==u)return;t<r&&h(),t>r&>(s,t-r,-1),gt(s,o-t,u),mt(n,s,c),r=o}}(t),h(!o),o}static empty(t){return new pt(t?[t,-1]:[],[])}static fromJSON(t){if(!Array.isArray(t))throw new RangeError("Invalid JSON representation of ChangeSet");let e=[],i=[];for(let s=0;s<t.length;s++){let n=t[s];if("number"==typeof n)e.push(n,-1);else{if(!Array.isArray(n)||"number"!=typeof n[0]||n.some(((t,e)=>e&&"string"!=typeof t)))throw new RangeError("Invalid JSON representation of ChangeSet");if(1==n.length)e.push(n[0],0);else{for(;i.length<s;)i.push(it.empty);i[s]=it.of(n.slice(1)),e.push(n[0],i[s].length)}}}return new pt(e,i)}}function gt(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 mt(t,e,i){if(0==i.length)return;let s=e.length-2>>1;if(s<t.length)t[t.length-1]=t[t.length-1].append(i);else{for(;t.length<s;)t.push(it.empty);t.push(i)}}function wt(t,e,i){let s=t.inserted;for(let n=0,r=0,o=0;o<t.sections.length;){let h=t.sections[o++],l=t.sections[o++];if(l<0)n+=h,r+=h;else{let a=n,c=r,u=it.empty;for(;a+=h,c+=l,l&&s&&(u=u.append(s[o-2>>1])),!(i||o==t.sections.length||t.sections[o+1]<0);)h=t.sections[o++],l=t.sections[o++];e(n,a,r,c,u),n=a,r=c}}}function vt(t,e,i,s=!1){let n=[],r=s?[]:null,o=new bt(t),h=new bt(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),gt(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(gt(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 pt(n,r):new dt(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}}gt(n,i,o.ins),r&&mt(r,n,o.text),t=s,o.next()}}}function yt(t,e,i=!1){let s=[],n=i?[]:null,r=new bt(t),o=new bt(e);for(let t=!1;;){if(r.done&&o.done)return n?new pt(s,n):new dt(s);if(0==r.ins)gt(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;gt(s,e,i,t),n&&i&&mt(n,s,o.text)}else-1==o.ins?(gt(s,r.off?0:r.len,e,t),n&&mt(n,s,r.textBit(e))):(gt(s,r.off?0:r.len,o.off?0:o.ins,t),n&&!o.off&&mt(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 gt(s,0,o.ins,t),n&&mt(n,s,o.text),o.next()}}class bt{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:t}=this.set,e=this.i-2>>1;return e>=t.length?it.empty:t[e]}textBit(t){let{inserted:e}=this.set,i=this.i-2>>1;return i>=e.length&&!t?it.empty:e[i].slice(this.off,null==t?void 0:this.off+t)}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 xt{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=t.mapPos(this.from,e),s=t.mapPos(this.to,e);return i==this.from&&s==this.to?this:new xt(i,s,this.flags)}extend(t,e=t){if(t<=this.anchor&&e>=this.anchor)return kt.range(t,e);let i=Math.abs(t-this.anchor)>Math.abs(e-this.anchor)?t:e;return kt.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 kt.range(t.anchor,t.head)}}class kt{constructor(t,e=0){this.ranges=t,this.mainIndex=e}map(t,e=-1){return t.empty?this:kt.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 kt([this.main])}addRange(t,e=!0){return kt.create([t].concat(this.ranges),e?0:this.mainIndex+1)}replaceRange(t,e=this.mainIndex){let i=this.ranges.slice();return i[e]=t,kt.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 kt(t.ranges.map((t=>xt.fromJSON(t))),t.main)}static single(t,e=t){return new kt([kt.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 St(t.slice(),e);i=n.to}return new kt(t,e)}static cursor(t,e=0,i,s){return new xt(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 xt(e,t,16|s):new xt(t,e,s)}}function St(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?kt.range(o,r):kt.range(r,o))}}return new kt(t,e)}function At(t,e){for(let i of t.ranges)if(i.to>e)throw new RangeError("Selection points outside of document")}let Ct=0;class Mt{constructor(t,e,i,s,n){this.combine=t,this.compareInput=e,this.compare=i,this.isStatic=s,this.extensions=n,this.id=Ct++,this.default=t([])}static define(t={}){return new Mt(t.combine||(t=>t),t.compareInput||((t,e)=>t===e),t.compare||(t.combine?(t,e)=>t===e:Dt),!!t.static,t.enables)}of(t){return new Ot([],this,0,t)}compute(t,e){if(this.isStatic)throw new Error("Can't compute a static facet");return new Ot(t,this,1,e)}computeN(t,e){if(this.isStatic)throw new Error("Can't compute a static facet");return new Ot(t,this,2,e)}from(t,e){return e||(e=t=>t),this.compute([t],(i=>e(i.field(t))))}}function Dt(t,e){return t==e||t.length==e.length&&t.every(((t,i)=>t===e[i]))}class Ot{constructor(t,e,i,s){this.dependencies=t,this.facet=e,this.type=i,this.value=s,this.id=Ct++}dynamicSlot(t){var e;let i=this.value,s=this.facet.compareInput,n=t[this.id]>>1,r=2==this.type,o=!1,h=!1,l=[];for(let i of this.dependencies)"doc"==i?o=!0:"selection"==i?h=!0:0==(1&(null!==(e=t[i.id])&&void 0!==e?e:1))&&l.push(t[i.id]);return(t,e)=>{if(!e||e.reconfigured)return t.values[n]=i(t),1;{if(!(o&&e.docChanged||h&&(e.docChanged||e.selection)||l.some((e=>(1&qt(t,e))>0))))return 0;let a=i(t),c=e.startState.values[n];return(r?function(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}(a,c,s):s(a,c))?0:(t.values[n]=a,1)}}}}function Tt(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;return(t,i)=>{let h=i?i.reconfigured?i.startState.config.address[e.id]:o<<1:null,l=null==h;for(let e of r)1&qt(t,e)&&(l=!0);if(!l)return 0;let a=[];for(let e=0;e<s.length;e++){let i=jt(t,s[e]);if(2==n[e])for(let t of i)a.push(t);else a.push(i)}let c=e.combine(a);return null!=h&&e.compare(c,jt(i.startState,h))?0:(t.values[o]=c,1)}}function Pt(t,e){let i=t.config.address[e];return null==i?null:i>>1}const Et=Mt.define({static:!0});class Rt{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 Rt(Ct++,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(Et).find((t=>t.field==this));return((null==e?void 0:e.create)||this.createF)(t)}slot(t){let e=t[this.id]>>1;return(t,i)=>{if(!i||i.reconfigured&&null==Pt(i.startState,this.id))return t.values[e]=this.create(t),1;let s,n=0;i.reconfigured?(s=i.startState.values[Pt(i.startState,this.id)],n=1):s=i.startState.values[e];let r=this.updateF(s,i);return n||this.compareF(s,r)||(n=1),n&&(t.values[e]=r),n}}init(t){return[this,Et.of({field:this,create:t})]}get extension(){return this}}const Lt=2,Nt=1,It=0;function Bt(t){return e=>new zt(e,t)}const Vt={fallback:Bt(3),default:Bt(Lt),extend:Bt(Nt),override:Bt(It)};class zt{constructor(t,e){this.inner=t,this.prec=e}}class Ft{of(t){return new Ht(this,t)}reconfigure(t){return Ft.reconfigure.of({compartment:this,extension:t})}get(t){return t.config.compartments.get(this)}}class Ht{constructor(t,e){this.compartment=t,this.inner=e}}class Wt{constructor(t,e,i,s,n){for(this.base=t,this.compartments=e,this.dynamicSlots=i,this.address=s,this.staticValues=n,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 Ht&&i.delete(t.compartment)}if(n.set(t,o),Array.isArray(t))for(let e of t)r(e,o);else if(t instanceof Ht){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 zt)r(t.inner,t.prec);else if(t instanceof Rt)s[o].push(t),t.provides&&r(t.provides,o);else if(t instanceof Ot)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,Lt),s.reduce(((t,e)=>t.concat(e)))}(t,e,r))i instanceof Rt?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)));for(let t in n){let e=n[t],s=e[0].facet;if(e.every((t=>0==t.type))){o[s.id]=h.length<<1|1;let t=s.combine(e.map((t=>t.value))),n=i?i.config.address[s.id]:null;if(null!=n){let e=jt(i,n);s.compare(t,e)&&(t=e)}h.push(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=>Tt(t,s,e)))}}return new Wt(t,r,l.map((t=>t(o))),o,h)}}function qt(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.config.dynamicSlots[i](t,t.applying);return t.status[i]=2|n}function jt(t,e){return 1&e?t.config.staticValues[e>>1]:t.values[e>>1]}const _t=Mt.define(),$t=Mt.define({combine:t=>t.some((t=>t)),static:!0}),Ut=Mt.define({combine:t=>t.length?t[0]:void 0,static:!0}),Gt=Mt.define(),Kt=Mt.define(),Jt=Mt.define(),Xt=Mt.define({combine:t=>!!t.length&&t[0]});class Yt{constructor(t,e){this.type=t,this.value=e}static define(){return new Qt}}class Qt{of(t){return new Yt(this,t)}}class Zt{constructor(t){this.map=t}of(t){return new te(this,t)}}class te{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 te(this.type,e)}is(t){return this.type==t}static define(t={}){return new Zt(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}}te.reconfigure=te.define(),te.appendConfig=te.define();class ee{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&&At(i,e.newLength),n.some((t=>t.type==ee.time))||(this.annotations=n.concat(ee.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(ee.userEvent);return e&&(e==t||e.length>t.length&&e.slice(0,t.length)==t&&"."==e[t.length])}}function ie(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 se(t,e,i){var s;let n,r,o;return i?(n=e.changes,r=pt.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:te.mapEffects(t.effects,n).concat(te.mapEffects(e.effects,r)),annotations:t.annotations.length?t.annotations.concat(e.annotations):e.annotations,scrollIntoView:t.scrollIntoView||e.scrollIntoView}}function ne(t,e,i){let s=e.selection,n=he(e.annotations);return e.userEvent&&(n=n.concat(ee.userEvent.of(e.userEvent))),{changes:e.changes instanceof pt?e.changes:pt.of(e.changes||[],i,t.facet(Ut)),selection:s&&(s instanceof kt?s:kt.single(s.anchor,s.head)),effects:he(e.effects),annotations:n,scrollIntoView:!!e.scrollIntoView}}function re(t,e,i){let s=ne(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=se(s,ne(t,e[n],r?s.changes.newLength:t.doc.length),r)}let n=new ee(t,s.changes,s.selection,s.effects,s.annotations,s.scrollIntoView);return function(t){let e=t.startState,i=e.facet(Jt),s=t;for(let n=i.length-1;n>=0;n--){let r=i[n](t);r&&Object.keys(r).length&&(s=se(t,ne(e,r,t.changes.newLength),!0))}return s==t?t:new ee(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(Gt)){let e=s(t);if(!1===e){i=!1;break}Array.isArray(e)&&(i=!0===i?e:ie(i,e))}if(!0!==i){let s,n;if(!1===i)n=t.changes.invertedDesc,s=pt.empty(e.doc.length);else{let e=t.changes.filter(i);s=e.changes,n=e.filtered.invertedDesc}t=new ee(e,s,t.selection&&t.selection.map(n),te.mapEffects(t.effects,n),t.annotations,t.scrollIntoView)}let s=e.facet(Kt);for(let i=s.length-1;i>=0;i--){let n=s[i](t);t=n instanceof ee?n:Array.isArray(n)&&1==n.length&&n[0]instanceof ee?n[0]:re(e,he(n),!1)}return t}(n):n)}ee.time=Yt.define(),ee.userEvent=Yt.define(),ee.addToHistory=Yt.define(),ee.remote=Yt.define();const oe=[];function he(t){return null==t?oe:Array.isArray(t)?t:[t]}var le=function(t){return t[t.Word=0]="Word",t[t.Space=1]="Space",t[t.Other=2]="Other",t}(le||(le={}));const ae=/[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/;let ce;try{ce=new RegExp("[\\p{Alphabetic}\\p{Number}_]","u")}catch(t){}function ue(t){return e=>{if(!/\S/.test(e))return le.Space;if(function(t){if(ce)return ce.test(t);for(let e=0;e<t.length;e++){let i=t[e];if(/\w/.test(i)||i>""&&(i.toUpperCase()!=i.toLowerCase()||ae.test(i)))return!0}return!1}(e))return le.Word;for(let i=0;i<t.length;i++)if(e.indexOf(t[i])>-1)return le.Word;return le.Other}}class fe{constructor(t,e,i,s=null){if(this.config=t,this.doc=e,this.selection=i,this.applying=null,this.status=t.statusTemplate.slice(),s&&s.startState.config==t)this.values=s.startState.values.slice();else if(this.values=t.dynamicSlots.map((t=>null)),s)for(let e in t.address){let i=t.address[e],n=s.startState.config.address[e];null!=n&&0==(1&i)&&(this.values[i>>1]=jt(s.startState,n))}this.applying=s,s&&(s._state=this);for(let t=0;t<this.config.dynamicSlots.length;t++)qt(this,t<<1);this.applying=null}field(t,e=!0){let i=this.config.address[t.id];if(null!=i)return qt(this,i),jt(this,i);if(e)throw new RangeError("Field is not present in this state")}update(...t){return re(this,t,!0)}applyTransaction(t){let e=this.config,{base:i,compartments:s}=e;for(let n of t.effects)n.is(Ft.reconfigure)?(e&&(s=new Map,e.compartments.forEach(((t,e)=>s.set(e,t))),e=null),s.set(n.value.compartment,n.value.extension)):n.is(te.reconfigure)?(e=null,i=n.value):n.is(te.appendConfig)&&(e=null,i=he(i).concat(n.value));new fe(e||Wt.resolve(i,s,this),t.newDoc,t.newSelection,t)}replaceSelection(t){return"string"==typeof t&&(t=this.toText(t)),this.changeByRange((e=>({changes:{from:e.from,to:e.to,insert:t},range:kt.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=he(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=te.mapEffects(r,l).concat(te.mapEffects(he(o.effects),a))}return{changes:s,selection:kt.create(n,e.mainIndex),effects:r}}changes(t=[]){return t instanceof pt?t:pt.of(t,this.doc.length,this.facet(fe.lineSeparator))}toText(t){return it.of(t.split(this.facet(fe.lineSeparator)||ut))}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:(qt(this,e),jt(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 Rt&&(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 fe.create({doc:t.doc,selection:kt.fromJSON(t.selection),extensions:e.extensions?s.concat([e.extensions]):s})}static create(t={}){let e=Wt.resolve(t.extensions||[],new Map),i=t.doc instanceof it?t.doc:it.of((t.doc||"").split(e.staticFacet(fe.lineSeparator)||ut)),s=t.selection?t.selection instanceof kt?t.selection:kt.single(t.selection.anchor,t.selection.head):kt.single(0);return At(s,i.length),e.staticFacet($t)||(s=s.asSingle()),new fe(e,i,s)}get tabSize(){return this.facet(fe.tabSize)}get lineBreak(){return this.facet(fe.lineSeparator)||"\n"}get readOnly(){return this.facet(Xt)}phrase(t){for(let e of this.facet(fe.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(_t))for(let r of n(this,e,i))Object.prototype.hasOwnProperty.call(r,t)&&s.push(r[t]);return s}charCategorizer(t){return ue(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=G(e,r,!1);if(n(e.slice(t,r))!=le.Word)break;r=t}for(;o<s;){let t=G(e,o);if(n(e.slice(o,t))!=le.Word)break;o=t}return r==o?null:kt.range(r+i,o+i)}}function de(t,e,i={}){let s={};for(let e of t)for(let t of Object.keys(e)){let n=e[t],r=s[t];if(void 0===r)s[t]=n;else if(r===n||void 0===n);else{if(!Object.hasOwnProperty.call(i,t))throw new Error("Config merge conflict for field "+t);s[t]=i[t](r,n)}}for(let t in e)void 0===s[t]&&(s[t]=e[t]);return s}fe.allowMultipleSelections=$t,fe.tabSize=Mt.define({combine:t=>t.length?t[0]:4}),fe.lineSeparator=Ut,fe.readOnly=Xt,fe.phrases=Mt.define(),fe.languageData=_t,fe.changeFilter=Gt,fe.transactionFilter=Kt,fe.transactionExtender=Jt,Ft.reconfigure=te.define();class pe{eq(t){return this==t}range(t,e=t){return new ge(t,e,this)}}pe.prototype.startSide=pe.prototype.endSide=0,pe.prototype.point=!1,pe.prototype.mapMode=ft.TrackDel;class ge{constructor(t,e,i){this.from=t,this.to=e,this.value=i}}function me(t,e){return t.from-e.from||t.value.startSide-e.value.startSide}class we{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;l=a=t}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 we(s,n,i,o):null,pos:r}}}class ve{constructor(t,e,i=ve.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.slice().sort(me),this.isEmpty)return e.length?ve.of(e):this;let o=new xe(this,null,-1).goto(0),h=0,l=[],a=new ye;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 ge(o.from,o.to,o.value))),o.next());return a.finishInner(this.nextLayer.isEmpty&&!l.length?ve.empty:this.nextLayer.update({add:l,filter:r,filterFrom:s,filterTo:n}))}map(t){if(0==t.length||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 ve(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 ke.from([this]).goto(t)}get isEmpty(){return this.nextLayer==this}static iter(t,e=0){return ke.from(t).goto(e)}static compare(t,e,i,s,n=-1){let r=t.filter((t=>t.maxPoint>=500||!t.isEmpty&&e.indexOf(t)<0&&t.maxPoint>=n)),o=e.filter((e=>e.maxPoint>=500||!e.isEmpty&&t.indexOf(e)<0&&e.maxPoint>=n)),h=be(r,o),l=new Ae(r,h,n),a=new Ae(o,h,n);i.iterGaps(((t,e,i)=>Ce(l,t,a,e,i,s))),i.empty&&0==i.length&&Ce(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=be(n,r),h=new Ae(n,o,0).goto(i),l=new Ae(r,o,0).goto(i);for(;;){if(h.to!=l.to||!Me(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 Ae(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),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 ye;for(let s of t instanceof ge?[t]:e?function(t){if(t.length>1)for(let e=t[0],i=1;i<t.length;i++){let s=t[i];if(me(e,s)>0)return t.slice().sort(me);e=s}return t}(t):t)i.add(s.from,s.to,s.value);return i.finish()}}ve.empty=new ve([],[],null,-1),ve.empty.nextLayer=ve.empty;class ye{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 we(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 ye)).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(ve.empty)}finishInner(t){if(this.from.length&&this.finishChunk(!1),0==this.chunks.length)return t;let e=new ve(this.chunkPos,this.chunks,this.nextLayer?this.nextLayer.finishInner(t):t,this.setMaxPoint);return this.from=null,e}}function be(t,e){let i=new Map;for(let e of t)for(let t=0;t<e.chunk.length;t++)e.chunk[t].maxPoint<500&&i.set(e.chunk[t],e.chunkPos[t]);let s=new Set;for(let t of e)for(let e=0;e<t.chunk.length;e++)i.get(t.chunk[e])==t.chunkPos[e]&&s.add(t.chunk[e]);return s}class xe{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.to-t.to||this.endSide-t.endSide}}class ke{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 xe(r,e,i,n));return 1==s.length?s[0]:new ke(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--)Se(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--)Se(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(),Se(this.heap,0)}}}function Se(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 Ae{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=ke.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){De(this.active,t),De(this.activeTo,t),De(this.activeRank,t),this.minActive=Te(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++;Oe(this.active,e,i),Oe(this.activeTo,e,s),Oe(this.activeRank,e,n),t&&Oe(t,e,this.cursor.from),this.minActive=Te(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&&De(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&&n.endSide==this.endSide)){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.to>t&&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 Ce(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))&&Me(t.activeForPoint(t.to+l),i.activeForPoint(i.to))||r.comparePoint(h,n,t.point,i.point):n>h&&!Me(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 Me(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 De(t,e){for(let i=e,s=t.length-1;i<s;i++)t[i]=t[i+1];t.pop()}function Oe(t,e,i){for(let i=t.length-1;i>=e;i--)t[i+1]=t[i];t[e]=i}function Te(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}for(var Pe={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"},Ee={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"},Re="undefined"!=typeof navigator&&/Chrome\/(\d+)/.exec(navigator.userAgent),Le="undefined"!=typeof navigator&&/Apple Computer/.test(navigator.vendor),Ne="undefined"!=typeof navigator&&/Gecko\/\d+/.test(navigator.userAgent),Ie="undefined"!=typeof navigator&&/Mac/.test(navigator.platform),Be="undefined"!=typeof navigator&&/MSIE \d|Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(navigator.userAgent),Ve=Re&&(Ie||+Re[1]<57)||Ne&&Ie,ze=0;ze<10;ze++)Pe[48+ze]=Pe[96+ze]=String(ze);for(ze=1;ze<=24;ze++)Pe[ze+111]="F"+ze;for(ze=65;ze<=90;ze++)Pe[ze]=String.fromCharCode(ze+32),Ee[ze]=String.fromCharCode(ze);for(var Fe in Pe)Ee.hasOwnProperty(Fe)||(Ee[Fe]=Pe[Fe]);function He(t){let e;return e=11==t.nodeType?t.getSelection?t:t.ownerDocument:t,e.getSelection()}function We(t,e){return!!e&&t.contains(1!=e.nodeType?e.parentNode:e)}function qe(t,e){if(!e.anchorNode)return!1;try{return We(t,e.anchorNode)}catch(t){return!1}}function je(t){return 3==t.nodeType?ei(t,0,t.nodeValue.length).getClientRects():1==t.nodeType?t.getClientRects():[]}function _e(t,e,i,s){return!!i&&(Ue(t,e,i,s,-1)||Ue(t,e,i,s,1))}function $e(t){for(var e=0;;e++)if(!(t=t.previousSibling))return e}function Ue(t,e,i,s,n){for(;;){if(t==i&&e==s)return!0;if(e==(n<0?0:Ge(t))){if("DIV"==t.nodeName)return!1;let i=t.parentNode;if(!i||1!=i.nodeType)return!1;e=$e(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?Ge(t):0}}}function Ge(t){return 3==t.nodeType?t.nodeValue.length:t.childNodes.length}const Ke={left:0,right:0,top:0,bottom:0};function Je(t,e){let i=e?t.left:t.right;return{left:i,right:i,top:t.top,bottom:t.bottom}}function Xe(t){return{left:0,right:t.innerWidth,top:0,bottom:t.innerHeight}}class Ye{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}set(t){this.anchorNode=t.anchorNode,this.anchorOffset=t.anchorOffset,this.focusNode=t.focusNode,this.focusOffset=t.focusOffset}}let Qe,Ze=null;function ti(t){if(t.setActive)return t.setActive();if(Ze)return t.focus(Ze);let e=[];for(let i=t;i&&(e.push(i,i.scrollTop,i.scrollLeft),i!=i.ownerDocument);i=i.parentNode);if(t.focus(null==Ze?{get preventScroll(){return Ze={preventScroll:!0},!0}}:void 0),!Ze){Ze=!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 ei(t,e,i=e){let s=Qe||(Qe=document.createRange());return s.setEnd(t,i),s.setStart(t,e),s}function ii(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}let si=null;function ni(){if(null==si){si=!1;let t=document.createElement("div");try{t.contentEditable="plaintext-only",si="plaintext-only"==t.contentEditable}catch(t){}}return si}class ri{constructor(t,e,i=!0){this.node=t,this.offset=e,this.precise=i}static before(t,e){return new ri(t.parentNode,$e(t),e)}static after(t,e){return new ri(t.parentNode,$e(t)+1,e)}}const oi=[];class hi{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){var e;if(2&this.dirty){let i=this.dom,s=null;for(let n of this.children){if(n.dirty){let r=s?s.nextSibling:i.firstChild;n.dom||!r||(null===(e=hi.get(r))||void 0===e?void 0:e.parent)||n.reuseDOM(r),n.sync(t),n.dirty=0}t&&t.node==i&&s!=n.dom&&(t.written=!0),ai(i,s,n.dom),s=n.dom}let n=s?s.nextSibling:i.firstChild;for(n&&t&&t.node==i&&(t.written=!0);n;)n=li(n)}else if(1&this.dirty)for(let e of this.children)e.dirty&&(e.sync(t),e.dirty=0)}reuseDOM(t){return!1}localPosFromDOM(t,e){let i;if(t==this.dom)i=this.dom.childNodes[e];else{let s=0==Ge(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&&!hi.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=oi){this.markDirty();for(let i=t;i<e;i++){let t=this.children[i];t.parent==this&&(t.parent=null)}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 ci(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}}function li(t){let e=t.nextSibling;return t.parentNode.removeChild(t),e}function ai(t,e,i){let s=e?e.nextSibling:t.firstChild;if(i.parentNode==t)for(;s!=i;)s=li(s);else t.insertBefore(i,s)}hi.prototype.breakAfter=0;class ci{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}}}let[ui,fi]="undefined"!=typeof navigator?[navigator,document]:[{userAgent:"",vendor:"",platform:""},{documentElement:{style:{}}}];const di=/Edge\/(\d+)/.exec(ui.userAgent),pi=/MSIE \d/.test(ui.userAgent),gi=/Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(ui.userAgent),mi=!!(pi||gi||di),wi=!mi&&/gecko\/(\d+)/i.test(ui.userAgent),vi=!mi&&/Chrome\/(\d+)/.exec(ui.userAgent),yi="webkitFontSmoothing"in fi.documentElement.style,bi=!mi&&/Apple Computer/.test(ui.vendor);var xi={mac:/Mac/.test(ui.platform),ie:mi,ie_version:pi?fi.documentMode||6:gi?+gi[1]:di?+di[1]:0,gecko:wi,gecko_version:wi?+(/Firefox\/(\d+)/.exec(ui.userAgent)||[0,0])[1]:0,chrome:!!vi,chrome_version:vi?+vi[1]:0,ios:bi&&(/Mobile\/\w+/.test(ui.userAgent)||ui.maxTouchPoints>2),android:/Android\b/.test(ui.userAgent),webkit:yi,safari:bi,webkit_version:yi?+(/\bAppleWebKit\/(\d+)/.exec(navigator.userAgent)||[0,0])[1]:0,tabSize:null!=fi.documentElement.style.tabSize?"tab-size":"-moz-tab-size"};const ki=[];class Si extends hi{become(t){return!1}getSide(){return 0}}Si.prototype.children=ki;class Ai extends Si{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){return 3==t.nodeType&&(this.createDOM(t),!0)}merge(t,e,i){return(!i||i instanceof Ai&&!(this.length-(e-t)+i.length>256))&&(this.text=this.text.slice(0,t)+(i?i.text:"")+this.text.slice(e),this.markDirty(),!0)}slice(t){let e=new Ai(this.text.slice(t));return this.text=this.text.slice(0,t),e}localPosFromDOM(t,e){return t==this.dom?e:e?this.text.length:0}domAtPos(t){return new ri(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 Mi(this.dom,t,e)}}class Ci extends Si{constructor(t,e=[],i=0){super(),this.mark=t,this.children=e,this.length=i;for(let t of e)t.setParent(this)}createDOM(){let t=document.createElement(this.mark.tagName);if(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]);this.setDOM(t)}sync(t){(!this.dom||4&this.dirty)&&this.createDOM(),super.sync(t)}merge(t,e,i,s,n){return(!i||!(!(i instanceof Ci&&i.mark.eq(this.mark))||t&&s<=0||e<this.length&&n<=0))&&(Ti(this,t,e,i?i.children:ki,s-1,n-1),this.markDirty(),!0)}slice(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.slice(t-i):r),s<0&&i>=t&&(s=n),i=o,n++}let r=this.length-t;return this.length=t,s>-1&&this.replaceChildren(s,this.children.length),new Ci(this.mark,e,r)}domAtPos(t){return Pi(this.dom,this.children,t)}coordsAt(t,e){return Ri(this,t,e)}}function Mi(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?xi.chrome||xi.gecko||(e?(n--,o=1):(r++,o=-1)):i<0?n--:r++;let h=ei(t,n,r).getClientRects();if(!h.length)return Ke;let l=h[(o?o<0:i>=0)?0:h.length-1];return xi.safari&&!o&&0==l.width&&(l=Array.prototype.find.call(h,(t=>t.width))||l),o?Je(l,o<0):l}class Di extends Si{constructor(t,e,i){super(),this.widget=t,this.length=e,this.side=i}static create(t,e,i){return new(t.customView||Di)(t,e,i)}slice(t){let e=Di.create(this.widget,this.length-t,this.side);return this.length-=t,e}sync(){this.dom&&this.widget.updateDOM(this.dom)||(this.setDOM(this.widget.toDOM(this.editorView)),this.dom.contentEditable="false")}getSide(){return this.side}merge(t,e,i,s,n){return!(i&&(!(i instanceof Di&&this.widget.compare(i.widget))||t>0&&s<=0||e<this.length&&n<=0))&&(this.length=t+(i?i.length:0)+(this.length-e),!0)}become(t){return t.length==this.length&&t instanceof Di&&t.side==this.side&&this.widget.constructor==t.widget.constructor&&(this.widget.eq(t.widget)||this.markDirty(!0),this.widget=t.widget,!0)}ignoreMutation(){return!0}ignoreEvent(t){return this.widget.ignoreEvent(t)}get overrideDOMText(){if(0==this.length)return it.empty;let t=this;for(;t.parent;)t=t.parent;let e=t.editorView,i=e&&e.state.doc,s=this.posAtStart;return i?i.slice(s,s+this.length):it.empty}domAtPos(t){return 0==t?ri.before(this.dom):ri.after(this.dom,t==this.length)}domBoundsAround(){return null}coordsAt(t,e){let i=this.dom.getClientRects(),s=null;if(!i.length)return Ke;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:Je(s,0==t)}}class Oi extends Di{domAtPos(t){return new ri(this.widget.text,t)}sync(){this.dom||this.setDOM(this.widget.toDOM())}localPosFromDOM(t,e){return e?3==t.nodeType?Math.min(e,this.length):this.length:0}ignoreMutation(){return!1}get overrideDOMText(){return null}coordsAt(t,e){return Mi(this.widget.text,t,e)}}function Ti(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;let{children:f}=t;if(a==h&&c){let t=f[a];if(1==s.length&&t.merge(c,l,s[0],n,r))return;if(0==s.length)return void t.merge(c,l,null,n,r);let e=t.slice(l);e.merge(0,0,s[s.length-1],0,r)?s[s.length-1]=e:s.push(e),h++,r=l=0}if(l){let t=f[h];s.length&&t.merge(0,l,s[s.length-1],0,r)?(s.pop(),r=s.length?0:n):t.merge(0,l,null,0,0)}else h<f.length&&s.length&&f[h].merge(0,0,s[s.length-1],0,r)&&(s.pop(),r=s.length?0:n);if(c){let t=f[a];s.length&&t.merge(c,t.length,s[0],n,0)?(s.shift(),n=s.length?0:r):t.merge(c,t.length,null,0,0),a++}else if(a&&s.length){let t=f[a-1];t.merge(t.length,t.length,s[0],n,0)&&(s.shift(),n=s.length?0:r)}for(;a<h&&s.length&&f[h-1].become(s[s.length-1]);)s.pop(),h--,r=s.length?0:n;for(;a<h&&s.length&&f[a].become(s[0]);)s.shift(),a++,n=s.length?0:r;!s.length&&a&&h<f.length&&f[h].merge(0,0,f[a-1],n,r)&&a--,(s.length||a!=h)&&t.replaceChildren(a,h,s)}function Pi(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 ri.after(i)}return new ri(t,0)}function Ei(t,e,i){let s,{children:n}=t;i>0&&e instanceof Ci&&n.length&&(s=n[n.length-1])instanceof Ci&&s.mark.eq(e.mark)?Ei(s,e.children[0],i-1):(n.push(e),e.setParent(t)),t.length+=e.length}function Ri(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(e-s,i);return t&&n?Je(n,i<0):n}s=h}let s=t.dom.lastChild;if(!s)return t.dom.getBoundingClientRect();let n=je(s);return n[n.length-1]}function Li(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 Ni(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 Ii(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])}class Bi{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}}var Vi=function(t){return t[t.Text=0]="Text",t[t.WidgetBefore=1]="WidgetBefore",t[t.WidgetAfter=2]="WidgetAfter",t[t.WidgetRange=3]="WidgetRange",t}(Vi||(Vi={}));class zi extends pe{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 Fi(t)}static widget(t){let e=t.side||0;return t.block&&(e+=200000001*(e>0?1:-1)),new Wi(t,e,e,!!t.block,t.widget||null,!1)}static replace(t){let e=!!t.block,{start:i,end:s}=qi(t);return new Wi(t,e?-2e8*(i?2:1):1e8*(i?-1:1),e?2e8*(s?2:1):1e8*(s?1:-1),e,t.widget||null,!0)}static line(t){return new Hi(t)}static set(t,e=!1){return ve.of(t,e)}hasHeight(){return!!this.widget&&this.widget.estimatedHeight>-1}}zi.none=ve.empty;class Fi extends zi{constructor(t){let{start:e,end:i}=qi(t);super(1e8*(e?-1:1),1e8*(i?1:-1),null,t),this.tagName=t.tagName||"span",this.class=t.class||"",this.attrs=t.attributes||null}eq(t){return this==t||t instanceof Fi&&this.tagName==t.tagName&&this.class==t.class&&Ni(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)}}Fi.prototype.point=!1;class Hi extends zi{constructor(t){super(-1e8,-1e8,null,t)}eq(t){return t instanceof Hi&&Ni(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)}}Hi.prototype.mapMode=ft.TrackBefore,Hi.prototype.point=!0;class Wi extends zi{constructor(t,e,i,s,n,r){super(e,i,n,t),this.block=s,this.isReplace=r,this.mapMode=s?e<0?ft.TrackBefore:ft.TrackAfter:ft.TrackDel}get type(){return this.startSide<this.endSide?Vi.WidgetRange:this.startSide<0?Vi.WidgetBefore:Vi.WidgetAfter}get heightRelevant(){return this.block||!!this.widget&&this.widget.estimatedHeight>=5}eq(t){return t instanceof Wi&&(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 qi(t){let{inclusiveStart:e,inclusiveEnd:i}=t;return null==e&&(e=t.inclusive),null==i&&(i=t.inclusive),{start:e||!1,end:i||!1}}function ji(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)}Wi.prototype.point=!0;class _i extends hi{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 _i))return!1;this.dom||i.transferDOM(this)}return s&&this.setDeco(i?i.attrs:null),Ti(this,t,e,i?i.children:$i,n,r),!0}split(t){let e=new _i;if(e.breakAfter=this.breakAfter,0==this.length)return e;let{i:i,off:s}=this.childPos(t);s&&(e.append(this.children[i].slice(s),0),this.children[i].merge(s,this.children[i].length,null,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-1].parent=null,i--;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){Ni(this.attrs,t)||(this.dom&&(this.prevAttrs=this.attrs,this.markDirty()),this.attrs=t)}append(t,e){Ei(this,t,e)}addLineDeco(t){let e=t.spec.attributes;e&&(this.attrs=Li(e,this.attrs||{}))}domAtPos(t){return Pi(this.dom,this.children,t)}sync(t){(!this.dom||4&this.dirty)&&(this.setDOM(document.createElement("div")),this.dom.className="cm-line",this.prevAttrs=this.attrs?null:void 0),void 0!==this.prevAttrs&&(Ii(this.dom,this.prevAttrs,this.attrs),this.dom.classList.add("cm-line"),this.prevAttrs=void 0),super.sync(t);let e=this.dom.lastChild;for(;e&&hi.get(e)instanceof Ci;)e=e.lastChild;if(!e||"BR"!=e.nodeName&&hi.get(e)instanceof Di&&(!xi.ios||!this.children.some((t=>t instanceof Ai)))){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 Ai))return null;let i=je(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 Ri(this,t,e)}match(t){return!1}get type(){return Vi.Text}static find(t,e){for(let i=0,s=0;;i++){let n=t.children[i],r=s+n.length;if(r>=e){if(n instanceof _i)return n;if(n.length)return null}s=r+n.breakAfter}}}const $i=[];class Ui extends hi{constructor(t,e,i){super(),this.widget=t,this.length=e,this.type=i,this.breakAfter=0}merge(t,e,i,s,n,r){return!(i&&(!(i instanceof Ui&&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?ri.before(this.dom):ri.after(this.dom,t==this.length)}split(t){let e=this.length-t;return this.length=t,new Ui(this.widget,e,this.type)}get children(){return $i}sync(){this.dom&&this.widget.updateDOM(this.dom)||(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):it.empty}domBoundsAround(){return null}match(t){return t instanceof Ui&&t.type==this.type&&t.widget.constructor==this.widget.constructor&&(t.widget.eq(this.widget)||this.markDirty(!0),this.widget=t.widget,this.length=t.length,this.breakAfter=t.breakAfter,!0)}ignoreMutation(){return!0}ignoreEvent(t){return this.widget.ignoreEvent(t)}}class Gi{constructor(t,e,i){this.doc=t,this.pos=e,this.end=i,this.content=[],this.curLine=null,this.breakAtStart=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 Ui&&t.type==Vi.WidgetBefore)}getLine(){return this.curLine||this.content.push(this.curLine=new _i),this.curLine}addWidget(t){this.curLine=null,this.content.push(t)}finish(){this.posCovered()||this.getLine()}wrapMarks(t,e){for(let i of e)t=new Ci(i,[t],t.length);return t}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.curLine=null,t--;continue}this.text=e,this.textOff=0}let s=Math.min(this.text.length-this.textOff,t,512);this.getLine().append(this.wrapMarks(new Ai(this.text.slice(this.textOff,this.textOff+s)),e),i),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){let r=e-t;if(i instanceof Wi)if(i.block){let{type:t}=i;t!=Vi.WidgetAfter||this.posCovered()||this.getLine(),this.addWidget(new Ui(i.widget||new Ki("div"),r,t))}else{let t=this.wrapMarks(Di.create(i.widget||new Ki("span"),r,i.startSide),s);this.getLine().append(t,n)}else this.doc.lineAt(this.pos).from==this.pos&&this.getLine().addLineDeco(i);r&&(this.textOff+r<=this.text.length?this.textOff+=r:(this.skip+=r-(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){let n=new Gi(t,e,i);return n.openEnd=ve.spans(s,e,i,n),n.openStart<0&&(n.openStart=n.openEnd),n.finish(),n}}class Ki extends Bi{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 Ji=[],Xi=Mt.define(),Yi=Mt.define(),Qi=Mt.define(),Zi=Mt.define(),ts=Mt.define(),es=Mt.define(),is=te.define({map:(t,e)=>t.map(e)});function ss(t,e,i){let s=t.facet(Zi);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 ns=Mt.define({combine:t=>!t.length||t[0]});class rs{constructor(t,e){this.field=t,this.get=e}}class os{from(t){return new rs(this,t)}static define(){return new os}}os.decorations=os.define(),os.atomicRanges=os.define(),os.scrollMargins=os.define();let hs=0;const ls=Mt.define();class as{constructor(t,e,i){this.id=t,this.create=e,this.fields=i,this.extension=ls.of(this)}static define(t,e){let{eventHandlers:i,provide:s,decorations:n}=e||{},r=[];if(s)for(let t of Array.isArray(s)?s:[s])r.push(t);return i&&r.push(cs.from((t=>({plugin:t,handlers:i})))),n&&r.push(os.decorations.from(n)),new as(hs++,t,r)}static fromClass(t,e){return as.define((e=>new t(e)),e)}}const cs=os.define();class us{constructor(t){this.spec=t,this.mustUpdate=null,this.value=null}takeField(t,e){for(let{field:i,get:s}of this.spec.fields)i==t&&e.push(s(this.value))}update(t){if(this.value){if(this.mustUpdate){let t=this.mustUpdate;if(this.mustUpdate=null,!this.value.update)return this;try{this.value.update(t)}catch(e){if(ss(t.state,e,"CodeMirror plugin crashed"),this.value.destroy)try{this.value.destroy()}catch(t){}return us.dummy}}}else try{this.value=this.spec.create(t)}catch(e){return ss(t.state,e,"CodeMirror plugin crashed"),us.dummy}return this}destroy(t){var e;if(null===(e=this.value)||void 0===e?void 0:e.destroy)try{this.value.destroy()}catch(e){ss(t.state,e,"CodeMirror plugin crashed")}}}us.dummy=new us(as.define((()=>({}))));const fs=Mt.define({combine:t=>t.reduce(((t,e)=>Li(e,t)),{})}),ds=Mt.define({combine:t=>t.reduce(((t,e)=>Li(e,t)),{})}),ps=Mt.define(),gs=Mt.define();class ms{constructor(t,e,i,s){this.fromA=t,this.toA=e,this.fromB=i,this.toB=s}join(t){return new ms(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 ms(r+l,h+l,r,h).addToSet(i),s>a)break;n+=2}if(!h)return i;new ms(h.fromA,h.toA,h.fromB,h.toB).addToSet(i),r=h.toA,o=h.toB}}}class ws{constructor(t,e,i=Ji){this.view=t,this.state=e,this.transactions=i,this.flags=0,this.startState=t.state,this.changes=pt.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 ms(t,e,i,n)))),this.changedRanges=s;let n=t.hasFocus;n!=t.inputState.notifiedFocused&&(t.inputState.notifiedFocused=n,this.flags|=1),this.docChanged&&(this.flags|=2)}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.transactions.some((t=>t.docChanged))}get selectionSet(){return this.transactions.some((t=>t.selection))}get empty(){return 0==this.flags&&0==this.transactions.length}}class vs extends hi{constructor(t){super(),this.view=t,this.compositionDeco=zi.none,this.decorations=[],this.minWidth=0,this.minWidthFrom=0,this.minWidthTo=0,this.impreciseAnchor=null,this.impreciseHead=null,this.setDOM(t.contentDOM),this.children=[new _i],this.children[0].setParent(this),this.updateInner([new ms(0,0,0,t.state.doc.length)],this.updateDeco(),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=0),this.view.inputState.composing<0?this.compositionDeco=zi.none:t.transactions.length&&(this.compositionDeco=function(t,e){let i=t.observer.selectionRange,s=i.focusNode&&xs(i.focusNode,i.focusOffset,0);if(!s)return zi.none;let n,r,o=t.docView.nearest(s),h=s;if(o instanceof Si){for(;o.parent instanceof Si;)o=o.parent;n=o.posAtStart,r=n+o.length,h=o.dom}else{if(!(o instanceof _i))return zi.none;{for(;h.parentNode!=o.dom;)h=h.parentNode;let t=h.previousSibling;for(;t&&!hi.get(t);)t=t.previousSibling;n=r=t?hi.get(t).posAtEnd:o.posAtStart}}let l=e.mapPos(n,1),a=Math.max(l,e.mapPos(r,-1)),c=s.nodeValue,{state:u}=t;if(a-l<c.length)if(u.sliceDoc(l,Math.min(u.doc.length,l+c.length))==c)a=l+c.length;else{if(u.sliceDoc(Math.max(0,a-c.length),a)!=c)return zi.none;l=a-c.length}else if(u.sliceDoc(l,a)!=c)return zi.none;return zi.set(zi.replace({widget:new bs(h,s)}).range(l,a))}(this.view,t.changes));let i=(xi.ie||xi.chrome)&&!this.compositionDeco.size&&t&&t.state.doc.lines!=t.startState.doc.lines,s=this.decorations,n=this.updateDeco(),r=function(t,e,i){let s=new ks;return ve.compare(t,e,i,s),s.changes}(s,n,t.changes);e=ms.extendWithRanges(e,r);let o=t.transactions.some((t=>t.isUserEvent("select.pointer")));return 0==this.dirty&&0==e.length&&!(4&t.flags)&&t.state.selection.main.from>=this.view.viewport.from&&t.state.selection.main.to<=this.view.viewport.to?(this.updateSelection(i,o),!1):(this.updateInner(e,n,t.startState.doc.length,i,o),!0)}updateInner(t,e,i,s=!1,n=!1){this.updateChildren(t,e,i);let{observer:r}=this.view;r.ignore((()=>{this.dom.style.height=this.view.viewState.domHeight+"px",this.dom.style.minWidth=this.minWidth?this.minWidth+"px":"";let t=xi.chrome||xi.ios?{node:r.selectionRange.focusNode,written:!1}:void 0;this.sync(t),this.dirty=0,t&&(t.written||r.selectionRange.focusNode!=t.node)&&(s=!0),this.updateSelection(s,n),this.dom.style.height=""}));let o=[];if(this.view.viewport.from||this.view.viewport.to<this.view.state.doc.length)for(let t of this.children)t instanceof Ui&&t.widget instanceof ys&&o.push(t.dom);r.updateGaps(o)}updateChildren(t,e,i){let s=this.childCursor(i);for(let i=t.length-1;;i--){let n=i>=0?t[i]:null;if(!n)break;let{fromA:r,toA:o,fromB:h,toB:l}=n,{content:a,breakAtStart:c,openStart:u,openEnd:f}=Gi.build(this.view.state.doc,h,l,e),{i:d,off:p}=s.findPos(o,1),{i:g,off:m}=s.findPos(r,-1);this.replaceRange(g,m,d,p,a,c,u,f)}}replaceRange(t,e,i,s,n,r,o,h){let l=this.children[t],a=n.length?n[n.length-1]:null,c=a?a.breakAfter:r;if(t==i&&!r&&!c&&n.length<2&&l.merge(e,s,n.length?a:null,0==e,o,h))return;let u=this.children[i];for(s<u.length?(t==i&&(u=u.split(s),s=0),!c&&a&&u.merge(0,s,a,!0,0,h)?n[n.length-1]=u:(s&&u.merge(0,s,null,!1,0,h),n.push(u))):u.breakAfter&&(a?a.breakAfter=1:r=1),i++,l.breakAfter=r,e>0&&(!r&&n.length&&l.merge(e,l.length,n[0],!1,o,0)?l.breakAfter=n.shift().breakAfter:(e<l.length||l.children.length&&0==l.children[l.children.length-1].length)&&l.merge(e,l.length,null,!1,o,0),t++);t<i&&n.length;)if(this.children[i-1].match(n[n.length-1]))i--,n.pop();else{if(!this.children[t].match(n[0]))break;t++,n.shift()}(t<i||n.length)&&this.replaceChildren(t,i,n)}updateSelection(t=!1,e=!1){if(!e&&!this.mayControlSelection()||xi.ios&&this.view.inputState.rapidCompositionStart)return;let i=this.view.state.selection.main,s=this.domAtPos(i.anchor),n=i.empty?s:this.domAtPos(i.head);if(xi.gecko&&i.empty&&(1==(r=s).node.nodeType&&r.node.firstChild&&(0==r.offset||"false"==r.node.childNodes[r.offset-1].contentEditable)&&(r.offset==r.node.childNodes.length||"false"==r.node.childNodes[r.offset].contentEditable))){let e=document.createTextNode("");this.view.observer.ignore((()=>s.node.insertBefore(e,s.node.childNodes[s.offset]||null))),s=n=new ri(e,0),t=!0}var r;let o=this.view.observer.selectionRange;!t&&o.focusNode&&_e(s.node,s.offset,o.anchorNode,o.anchorOffset)&&_e(n.node,n.offset,o.focusNode,o.focusOffset)||(this.view.observer.ignore((()=>{let t=He(this.root);if(i.empty){if(xi.gecko){let t=(e=s.node,r=s.offset,1!=e.nodeType?0:(r&&"false"==e.childNodes[r-1].contentEditable?1:0)|(r<e.childNodes.length&&"false"==e.childNodes[r].contentEditable?2:0));if(t&&3!=t){let e=xs(s.node,s.offset,1==t?1:-1);e&&(s=new ri(e,1==t?0:e.nodeValue.length))}}t.collapse(s.node,s.offset),null!=i.bidiLevel&&null!=o.cursorBidiLevel&&(o.cursorBidiLevel=i.bidiLevel)}else if(t.extend)t.collapse(s.node,s.offset),t.extend(n.node,n.offset);else{let e=document.createRange();i.anchor>i.head&&([s,n]=[n,s]),e.setEnd(n.node,n.offset),e.setStart(s.node,s.offset),t.removeAllRanges(),t.addRange(e)}var e,r})),this.view.observer.setSelectionRange(s,n)),this.impreciseAnchor=s.precise?null:new ri(o.anchorNode,o.anchorOffset),this.impreciseHead=n.precise?null:new ri(o.focusNode,o.focusOffset)}enforceCursorAssoc(){if(this.view.composing)return;let t=this.view.state.selection.main,e=He(this.root);if(!t.empty||!t.assoc||!e.modify)return;let i=_i.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(ns)?this.root.activeElement==this.dom:qe(this.dom,this.view.observer.selectionRange)}nearest(t){for(let e=t;e;){let t=hi.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 _i)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!=Vi.WidgetBefore&&n.type!=Vi.WidgetAfter&&(!s||2==e||this.children[s-1].breakAfter||this.children[s-1].type==Vi.WidgetBefore&&e>-2))return n.coordsAt(t-r,e);i=r}}measureVisibleLineHeights(){let t=[],{from:e,to:i}=this.view.viewState.viewport,s=Math.max(this.view.scrollDOM.clientWidth,this.minWidth)+1;for(let n=0,r=0;r<this.children.length;r++){let o=this.children[r],h=n+o.length;if(h>i)break;if(n>=e){t.push(o.dom.getBoundingClientRect().height);let e=o.dom.scrollWidth;e>s&&(this.minWidth=s=e,this.minWidthFrom=n,this.minWidthTo=h)}n=h+o.breakAfter}return t}measureTextSize(){for(let t of this.children)if(t instanceof _i){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=je(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 ci(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.lineAt(r,0).bottom-e.lineAt(i,0).top;t.push(zi.replace({widget:new ys(s),block:!0,inclusive:!0}).range(i,r))}if(!n)break;i=n.to+1}return zi.set(t)}updateDeco(){return this.decorations=[...this.view.pluginField(os.decorations),...this.view.state.facet(ps),this.compositionDeco,this.computeBlockGapDeco(),this.view.viewState.lineGapDeco]}scrollRangeIntoView(t){let e,i=this.coordsAt(t.head,t.empty?t.assoc:t.head>t.anchor?-1:1);if(!i)return;!t.empty&&(e=this.coordsAt(t.anchor,t.anchor>t.head?-1:1))&&(i={left:Math.min(i.left,e.left),top:Math.min(i.top,e.top),right:Math.max(i.right,e.right),bottom:Math.max(i.bottom,e.bottom)});let s=0,n=0,r=0,o=0;for(let t of this.view.pluginField(os.scrollMargins))if(t){let{left:e,right:i,top:h,bottom:l}=t;null!=e&&(s=Math.max(s,e)),null!=i&&(n=Math.max(n,i)),null!=h&&(r=Math.max(r,h)),null!=l&&(o=Math.max(o,l))}!function(t,e,i){let s=t.ownerDocument,n=s.defaultView;for(let r=t.parentNode;r;)if(1==r.nodeType){let t,o=r==s.body;if(o)t=Xe(n);else{if(r.scrollHeight<=r.clientHeight&&r.scrollWidth<=r.clientWidth){r=r.parentNode;continue}let e=r.getBoundingClientRect();t={left:e.left,right:e.left+r.clientWidth,top:e.top,bottom:e.top+r.clientHeight}}let h=0,l=0;if(e.top<t.top?(l=-(t.top-e.top+5),i>0&&e.bottom>t.bottom+l&&(l=e.bottom-t.bottom+l+5)):e.bottom>t.bottom&&(l=e.bottom-t.bottom+5,i<0&&e.top-l<t.top&&(l=-(t.top+l-e.top+5))),e.left<t.left?(h=-(t.left-e.left+5),i>0&&e.right>t.right+h&&(h=e.right-t.right+h+5)):e.right>t.right&&(h=e.right-t.right+5,i<0&&e.left<t.left+h&&(h=-(t.left+h-e.left+5))),h||l)if(o)n.scrollBy(h,l);else{if(l){let t=r.scrollTop;r.scrollTop+=l,l=r.scrollTop-t}if(h){let t=r.scrollLeft;r.scrollLeft+=h,h=r.scrollLeft-t}e={left:e.left-h,top:e.top-l,right:e.right-h,bottom:e.bottom-l}}if(o)break;r=r.assignedSlot||r.parentNode}else{if(11!=r.nodeType)break;r=r.host}}(this.dom,{left:i.left-s,top:i.top-r,right:i.right+n,bottom:i.bottom+o},t.head<t.anchor?-1:1)}}class ys extends Bi{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}}class bs extends Bi{constructor(t,e){super(),this.top=t,this.text=e}eq(t){return this.top==t.top&&this.text==t.text}toDOM(){return this.top}ignoreEvent(){return!1}get customView(){return Oi}}function xs(t,e,i){for(;;){if(3==t.nodeType)return t;if(1==t.nodeType&&e>0&&i<=0)e=Ge(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 ks{constructor(){this.changes=[]}compareRange(t,e){ji(t,e,this.changes)}comparePoint(t,e){ji(t,e,this.changes)}}var Ss=function(t){return t[t.LTR=0]="LTR",t[t.RTL=1]="RTL",t}(Ss||(Ss={}));const As=Ss.LTR,Cs=Ss.RTL;function Ms(t){let e=[];for(let i=0;i<t.length;i++)e.push(1<<+t[i]);return e}const Ds=Ms("88888888888888888888888888888888888666888888787833333333337888888000000000000000000000000008888880000000000000000000000000088888888888888888888888888888888888887866668888088888663380888308888800000000000000000000000800000000000000000000000000000008"),Os=Ms("4444448826627288999999999992222222222222222222222222222222222222222222222229999999999999999999994444444444644222822222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222999999949999999229989999223333333333"),Ts=Object.create(null),Ps=[];for(let t of["()","[]","{}"]){let e=t.charCodeAt(0),i=t.charCodeAt(1);Ts[e]=i,Ts[i]=-e}const Es=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/;class Rs{constructor(t,e,i){this.from=t,this.to=e,this.level=i}get dir(){return this.level%2?Cs:As}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 Ls=[];function Ns(t){return[new Rs(0,t,0)]}let Is="";function Bs(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=Rs.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=G(t.text,o,a);if(Is=t.text.slice(Math.min(o,c),Math.max(o,c)),c!=l.side(n,i))return kt.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?kt.cursor(u.side(!n,i)+t.from,n?1:-1,u.level):kt.cursor(c+t.from,n?-1:1,l.level):kt.cursor(n?t.to:t.from,n?-1:1,i)}function Vs(t,e){return e.left>t?e.left-t:Math.max(0,t-e.right)}function zs(t,e){return e.top>t?e.top-t:Math.max(0,t-e.bottom)}function Fs(t,e){return t.top<e.bottom-1&&t.bottom>e.top+1}function Hs(t,e){return e<t.top?{top:e,left:t.left,right:t.right,bottom:t.bottom}:t}function Ws(t,e){return e>t.bottom?{top:t.top,left:t.left,right:t.right,bottom:e}:t}function qs(t,e,i){let s,n,r,o,h,l,a,c;for(let u=t.firstChild;u;u=u.nextSibling){let t=je(u);for(let f=0;f<t.length;f++){let d=t[f];n&&Fs(n,d)&&(d=Hs(Ws(d,n.bottom),n.top));let p=Vs(e,d),g=zs(i,d);if(0==p&&0==g)return 3==u.nodeType?js(u,e,i):qs(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&&Fs(a,d)?a=Ws(a,d.bottom):c&&Fs(c,d)&&(c=Hs(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?js(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)}:qs(s,u,i)}function js(t,e,i){let s=t.nodeValue.length,n=-1,r=1e9,o=0;for(let h=0;h<s;h++){let s=ei(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(xi.chrome||xi.gecko){ei(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 _s(t,{x:e,y:i},s,n=-1){let r,o=t.contentDOM.getBoundingClientRect(),h=t.defaultLineHeight/2;for(let e=!1;;){if(r=t.blockAtHeight(i,o.top),r.top>i||r.bottom<i){if(n=r.top>i?-1:1,i=Math.min(r.bottom-h,Math.max(r.top+h,i)),e)return s?null:0;e=!0}if(r.type==Vi.Text)break;i=n>0?r.bottom+h:r.top-h}let l=r.from;if(e=Math.max(o.left+1,Math.min(o.right-1,e)),l<t.viewport.from)return 0==t.viewport.from?0:$s(t,o,r,e,i);if(l>t.viewport.to)return t.viewport.to==t.state.doc.length?t.state.doc.length:$s(t,o,r,e,i);let a,c=t.dom.ownerDocument,u=(t.root.elementFromPoint?t.root:c).elementFromPoint(e,i),f=-1;if(u&&t.contentDOM.contains(u)&&!(t.docView.nearest(u)instanceof Di))if(c.caretPositionFromPoint){let t=c.caretPositionFromPoint(e,i);t&&({offsetNode:a,offset:f}=t)}else if(c.caretRangeFromPoint){let t=c.caretRangeFromPoint(e,i);t&&(({startContainer:a,startOffset:f}=t),xi.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 ei(t,s-1,s).getBoundingClientRect().left>i}(a,f,e)&&(a=void 0))}if(!a||!t.docView.dom.contains(a)){let s=_i.find(t.docView,l);({node:a,offset:f}=qs(s.dom,e,i))}return t.docView.posFromDOM(a,f)}function $s(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=G(t,s)}return!0===s?-1:t.length}(o,r,t.state.tabSize)}function Us(t,e,i,s){let n=t.state.doc.lineAt(e.head),r=t.bidiSpans(n);for(let o=e,h=null;;){let e=Bs(n,r,t.textDirection,o,i),l=Is;if(!e){if(n.number==(i?t.state.doc.lines:1))return o;l="\n",n=t.state.doc.line(n.number+(i?1:-1)),r=t.bidiSpans(n),e=kt.cursor(i?n.from:n.to)}if(h){if(!h(l))return o}else{if(!s)return e;h=s(l)}o=e}}function Gs(t,e,i){let s=t.pluginField(os.atomicRanges);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?kt.cursor(s,1):kt.cursor(n,-1),t=!0)}));if(!t)return i}}class Ks{constructor(t){this.lastKeyCode=0,this.lastKeyTime=0,this.pendingIOSKey=null,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 Qs){let i=Qs[e];t.contentDOM.addEventListener(e,(s=>{"keydown"==e&&this.keydown(t,s)||Ys(t,s)&&!this.ignoreDuringComposition(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,this.ensureHandlers(t),xi.safari&&t.contentDOM.addEventListener("input",(()=>null))}setSelectionOrigin(t){this.lastSelectionOrigin=t,this.lastSelectionTime=Date.now()}ensureHandlers(t){let e=this.customHandlers=t.pluginField(cs);for(let i of e)for(let e in i.handlers)this.registeredEvents.indexOf(e)<0&&"scroll"!=e&&(this.registeredEvents.push(e),t.contentDOM.addEventListener(e,(i=>{Ys(t,i)&&this.runCustomHandlers(e,t,i)&&i.preventDefault()})))}runCustomHandlers(t,e,i){for(let s of this.customHandlers){let n=s.handlers[t],r=!1;if(n){try{r=n.call(s.plugin,i,e)}catch(t){ss(e.state,t)}if(r||i.defaultPrevented)return xi.android&&"keydown"==t&&13==i.keyCode&&e.observer.flushSoon(),!0}}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){ss(t.state,e)}}}keydown(t,e){return this.lastKeyCode=e.keyCode,this.lastKeyTime=Date.now(),!!this.screenKeyEvent(t,e)||!(!xi.ios||13!=e.keyCode&&8!=e.keyCode||e.ctrlKey||e.altKey||e.metaKey||e.synthetic)&&(this.pendingIOSKey=13==e.keyCode?"enter":"backspace",setTimeout((()=>this.flushIOSKey(t)),250),!0)}flushIOSKey(t){if(!this.pendingIOSKey)return!1;let e=t.contentDOM,i=this.pendingIOSKey;return this.pendingIOSKey=null,"enter"==i?ii(e,"Enter",13):ii(e,"Backspace",8)}ignoreDuringComposition(t){return!!/^key/.test(t.type)&&(this.composing>0||!!(xi.safari&&Date.now()-this.compositionEndedAt<500)&&(this.compositionEndedAt=0,!0))}screenKeyEvent(t,e){let i=9==e.keyCode&&Date.now()<this.lastEscPress+2e3;return 27==e.keyCode?this.lastEscPress=Date.now():Js.indexOf(e.keyCode)<0&&(this.lastEscPress=0),i}mustFlushObserver(t){return"keydown"==t.type&&229!=t.keyCode||"compositionend"==t.type&&!xi.ios}startMouseSelection(t,e,i){this.mouseSelection&&this.mouseSelection.destroy(),this.mouseSelection=new Xs(this,t,e,i)}update(t){this.mouseSelection&&this.mouseSelection.update(t),t.transactions.length&&(this.lastKeyCode=this.lastSelectionTime=0)}destroy(){this.mouseSelection&&this.mouseSelection.destroy()}}const Js=[16,17,18,20,91,92,224,225];class Xs{constructor(t,e,i,s){this.inputState=t,this.view=e,this.style=s,this.lastEvent=i;let n=e.contentDOM.ownerDocument;n.addEventListener("mousemove",this.move=this.move.bind(this)),n.addEventListener("mouseup",this.up=this.up.bind(this)),this.extend=i.shiftKey,this.multiple=e.state.facet(fe.allowMultipleSelections)&&function(t,e){let i=t.state.facet(Xi);return i.length?i[0](e):xi.mac?e.metaKey:e.ctrlKey}(e,i),this.dragMove=function(t,e){let i=t.state.facet(Yi);return i.length?i[0](e):xi.mac?!e.altKey:!e.ctrlKey}(e,i),this.dragging=!!function(t,e){let{main:i}=t.state.selection;if(i.empty)return!1;let s=He(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}(e,i)&&null,!1===this.dragging&&(i.preventDefault(),this.select(i))}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.inputState.mouseSelection=null}select(t){let e=this.style.get(t,this.extend,this.multiple);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})}update(t){t.docChanged&&this.dragging&&(this.dragging=this.dragging.map(t.changes)),this.style.update(t)&&setTimeout((()=>this.select(this.lastEvent)),20)}}function Ys(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=hi.get(s))&&i.ignoreEvent(e))return!1;return!0}const Qs=Object.create(null),Zs=xi.ie&&xi.ie_version<15||xi.ios&&xi.webkit_version<604;function tn(t,e){let i,{state:s}=t,n=1,r=s.toText(e),o=r.lines==s.selection.ranges.length;if(null!=dn&&s.selection.ranges.every((t=>t.empty))&&dn==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:kt.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:kt.cursor(t.from+e.length)}})):s.replaceSelection(r);t.dispatch(i,{userEvent:"input.paste",scrollIntoView:!0})}Qs.keydown=(t,e)=>{t.inputState.setSelectionOrigin("select")};let en=0;function sn(t,e,i,s){if(1==s)return kt.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 kt.cursor(e);0==r?i=1:r==n.length&&(i=-1);let o=r,h=r;i<0?o=G(n.text,r,!1):h=G(n.text,r);let l=s(n.text.slice(o,h));for(;o>0;){let t=G(n.text,o,!1);if(s(n.text.slice(t,o))!=l)break;o=t}for(;h<n.length;){let t=G(n.text,h);if(s(n.text.slice(h,t))!=l)break;h=t}return kt.range(o+n.from,h+n.from)}(t.state,e,i);{let i=_i.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++,kt.range(n,r)}}Qs.touchstart=(t,e)=>{en=Date.now(),t.inputState.setSelectionOrigin("select.pointer")},Qs.touchmove=t=>{t.inputState.setSelectionOrigin("select.pointer")},Qs.mousedown=(t,e)=>{if(t.observer.flush(),en>Date.now()-2e3)return;let i=null;for(let s of t.state.facet(Qi))if(i=s(t,e),i)break;i||0!=e.button||(i=function(t,e){let i=hn(t,e),s=function(t){if(!ln)return t.detail;let e=an,i=un;return an=t,un=Date.now(),cn=!e||i>Date.now()-400&&Math.abs(e.clientX-t.clientX)<2&&Math.abs(e.clientY-t.clientY)<2?(cn+1)%3:1}(e),n=t.state.selection,r=i,o=e;return{update(t){t.changes&&(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=hn(t,e),o=e),!a||!i)return n;let c=sn(t,a.pos,a.bias,s);if(i.pos!=a.pos&&!h){let e=sn(t,i.pos,i.bias,s),n=Math.min(e.from,c.from),r=Math.max(e.to,c.to);c=n<c.from?kt.range(n,r):kt.range(r,n)}return h?n.replaceRange(n.main.extend(c.from,c.to)):l?n.addRange(c):kt.create([c])}}}(t,e)),i&&(t.root.activeElement!=t.contentDOM&&t.observer.ignore((()=>ti(t.contentDOM))),t.inputState.startMouseSelection(t,e,i))};let nn=(t,e)=>t>=e.top&&t<=e.bottom,rn=(t,e,i)=>nn(e,i)&&t>=i.left&&t<=i.right;function on(t,e,i,s){let n=_i.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&&rn(i,s,o))return-1;let h=n.coordsAt(r,1);return h&&rn(i,s,h)?1:o&&nn(s,o)?-1:1}function hn(t,e){let i=t.posAtCoords({x:e.clientX,y:e.clientY},!1);return{pos:i,bias:on(t,i,e.clientX,e.clientY)}}const ln=xi.ie&&xi.ie_version<=11;let an=null,cn=0,un=0;function fn(t,e,i,s){let n=t.posAtCoords({x:e.clientX,y:e.clientY});if(null==n||!i)return;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"})}Qs.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")},Qs.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&&fn(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 fn(t,e,e.dataTransfer.getData("Text"),!0)},Qs.paste=(t,e)=>{if(t.state.readOnly)return e.preventDefault();t.observer.flush();let i=Zs?null:e.clipboardData;i?(tn(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(),tn(t,i.value)}),50)}(t)};let dn=null;function pn(t,e){if(t.docView.compositionDeco.size){t.inputState.rapidCompositionStart=e;try{t.update([])}finally{t.inputState.rapidCompositionStart=!1}}}Qs.copy=Qs.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;dn=n?i:null;let r=Zs?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"})},Qs.focus=Qs.blur=t=>{setTimeout((()=>{t.hasFocus!=t.inputState.notifiedFocused&&t.update([])}),10)},Qs.beforeprint=t=>{t.viewState.printing=!0,t.requestMeasure(),setTimeout((()=>{t.viewState.printing=!1,t.requestMeasure()}),2e3)},Qs.compositionstart=Qs.compositionupdate=t=>{null==t.inputState.compositionFirstChange&&(t.inputState.compositionFirstChange=!0),t.inputState.composing<0&&(t.docView.compositionDeco.size&&(t.observer.flush(),pn(t,!0)),t.inputState.composing=0)},Qs.compositionend=t=>{t.inputState.composing=-1,t.inputState.compositionEndedAt=Date.now(),t.inputState.compositionFirstChange=null,setTimeout((()=>{t.inputState.composing<0&&pn(t,!1)}),50)},Qs.contextmenu=t=>{t.inputState.lastContextMenu=Date.now()};const gn=["pre-wrap","normal","pre-line"];class mn{constructor(){this.doc=it.empty,this.lineWrapping=!1,this.direction=Ss.LTR,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}mustRefresh(t,e,i){let s=!1;for(let e=0;e<t.length;e++){let i=t[e];i<0?e++:this.heightSamples[Math.floor(10*i)]||(s=!0,this.heightSamples[Math.floor(10*i)]=!0)}return s||gn.indexOf(e)>-1!=this.lineWrapping||this.direction!=i}refresh(t,e,i,s,n,r){let o=gn.indexOf(t)>-1,h=Math.round(i)!=Math.round(this.lineHeight)||this.lineWrapping!=o||this.direction!=e;if(this.lineWrapping=o,this.direction=e,this.lineHeight=i,this.charWidth=s,this.lineLength=n,h){this.heightSamples={};for(let t=0;t<r.length;t++){let e=r[t];e<0?t++:this.heightSamples[Math.floor(10*e)]=!0}}return h}}class wn{constructor(t,e){this.from=t,this.heights=e,this.index=0}get more(){return this.index<this.heights.length}}class vn{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 vn(this.from,this.length+t.length,this.top,this.height+t.height,e)}}var yn=function(t){return t[t.ByPos=0]="ByPos",t[t.ByHeight=1]="ByHeight",t[t.ByPosNoHeight=2]="ByPosNoHeight",t}(yn||(yn={}));class bn{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)>1e-4&&(t.heightChanged=!0),this.height=e)}replace(t,e,i){return bn.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,yn.ByPosNoHeight,e,0,0),u=c.to>=h?c:n.lineAt(h,yn.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,yn.ByPosNoHeight,e,0,0));l+=c.from-o,o=c.from;let f=Mn.build(i,t,l,a);n=n.replace(o,h,f)}return n.updateHeight(i,0)}static empty(){return new kn(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 An(bn.of(t.slice(0,e)),r,bn.of(t.slice(i)))}}bn.prototype.size=1;class xn extends bn{constructor(t,e,i){super(t,e),this.type=i}blockAt(t,e,i,s){return new vn(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){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 kn extends xn{constructor(t,e){super(t,e,Vi.Text),this.collapsed=0,this.widgetHeight=0}replace(t,e,i){let s=i[0];return 1==i.length&&(s instanceof kn||s instanceof Sn&&4&s.flags)&&Math.abs(this.length-s.length)<10?(s instanceof Sn?s=new kn(s.length,this.height):s.height=this.height,this.outdated||(s.outdated=!1),s):bn.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 Sn extends bn{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 vn(l,a,i+o*h,o,Vi.Text)}lineAt(t,e,i,s,n){if(e==yn.ByHeight)return this.blockAt(t,i,s,n);if(e==yn.ByPosNoHeight){let{from:e,to:s}=i.lineAt(t);return new vn(e,s-e,0,0,Vi.Text)}let{firstLine:r,lineHeight:o}=this.lines(i,n),{from:h,length:l,number:a}=i.lineAt(t);return new vn(h,l,s+o*(a-r),o,Vi.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 vn(e.from,e.length,s,h,Vi.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 Sn?i[i.length-1]=new Sn(t.length+s):i.push(null,new Sn(s-1))}if(t>0){let e=i[0];e instanceof Sn?i[0]=new Sn(t+e.length):i.unshift(new Sn(t-1),null)}return bn.of(i)}decomposeLeft(t,e){e.push(new Sn(t-1),null)}decomposeRight(t,e){e.push(null,new Sn(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);for(s.from>e&&i.push(new Sn(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=new kn(e,s.heights[s.index++]);n.outdated=!1,i.push(n),r+=e+1}return r<=n&&i.push(null,new Sn(n-r).updateHeight(t,r)),t.heightChanged=!0,bn.of(i)}return(i||this.outdated)&&(this.setHeight(t,t.heightForGap(e,e+this.length)),this.outdated=!1),this}toString(){return`gap(${this.length})`}}class An extends bn{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||0==this.right.height?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==yn.ByHeight?t<r||0==this.right.height: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==yn.ByPosNoHeight?yn.ByPosNoHeight:yn.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,yn.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&&Cn(n,r-1),e<this.length){let t=n.length;this.decomposeRight(e,n),Cn(n,t)}return bn.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?bn.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 Cn(t,e){let i,s;null==t[e]&&(i=t[e-1])instanceof Sn&&(s=t[e+1])instanceof Sn&&t.splice(e-1,3,new Sn(i.length+1+s.length))}class Mn{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 kn?i.length+=t-this.pos:(t>this.pos||!this.isCovered)&&this.nodes.push(new kn(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?Math.max(0,i.widget.estimatedHeight):0,n=e-t;i.block?this.addBlock(new xn(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 kn(this.pos-t,-1)),this.writtenTo=this.pos}blankContent(t,e){let i=new Sn(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 kn)return t;let e=new kn(0,-1);return this.nodes.push(e),e}addBlock(t){this.enterLine(),t.type!=Vi.WidgetAfter||this.isCovered||this.ensureLine(),this.nodes.push(t),this.writtenTo=this.pos=this.pos+t.length,t.type!=Vi.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 kn||this.isCovered?(this.writtenTo<this.pos||null==e)&&this.nodes.push(this.blankContent(this.writtenTo,this.pos)):this.nodes.push(new kn(0,-1));let i=t;for(let t of this.nodes)t instanceof kn&&t.updateHeight(this.oracle,i),i+=t?t.length:1;return this.nodes}static build(t,e,i,s){let n=new Mn(i,t);return ve.spans(e,i,s,n,0),n.finish(i)}}class Dn{constructor(){this.changes=[]}compareRange(){}comparePoint(t,e,i,s){(t<e||i&&i.heightRelevant||s&&s.heightRelevant)&&ji(t,e,this.changes,5)}}class On{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 zi.replace({widget:new Tn(this.size,t)}).range(this.from,this.to)}}class Tn extends Bi{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 Pn{constructor(t){this.state=t,this.pixelViewport={left:0,right:window.innerWidth,top:0,bottom:0},this.inView=!0,this.paddingTop=0,this.paddingBottom=0,this.contentWidth=0,this.heightOracle=new mn,this.scaler=In,this.scrollTo=null,this.printing=!1,this.visibleRanges=[],this.mustEnforceCursorAssoc=!1,this.heightMap=bn.empty().applyChanges(t.facet(ps),it.empty,this.heightOracle.setDoc(t.doc),[new ms(0,0,0,t.doc.length)]),this.viewport=this.getViewport(0,null),this.updateForViewport(),this.lineGaps=this.ensureLineGaps([]),this.lineGapDeco=zi.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.lineAt(s,0);t.push(new En(e,i))}}this.viewports=t.sort(((t,e)=>t.from-e.from)),this.scaler=this.heightMap.height<=7e6?In:new Bn(this.heightOracle.doc,this.heightMap,this.viewports)}update(t,e=null){let i=this.state;this.state=t.state;let s=this.state.facet(ps),n=t.changedRanges,r=ms.extendWithRanges(n,function(t,e,i){let s=new Dn;return ve.compare(t,e,i,s,0),s.changes}(t.startState.facet(ps),s,t?t.changes:pt.empty(this.state.doc.length))),o=this.heightMap.height;this.heightMap=this.heightMap.applyChanges(s,i.doc,this.heightOracle.setDoc(this.state.doc),r),this.heightMap.height!=o&&(t.flags|=2);let h=r.length?this.mapViewport(this.viewport,t.changes):this.viewport;(e&&(e.head<h.from||e.head>h.to)||!this.viewportIsAppropriate(h))&&(h=this.getViewport(0,e)),this.viewport=h,this.updateForViewport(),(this.lineGaps.length||this.viewport.to-this.viewport.from>15e3)&&this.updateLineGaps(this.ensureLineGaps(this.mapLineGaps(this.lineGaps,t.changes))),t.flags|=this.computeVisibleRanges(),e&&(this.scrollTo=e),!this.mustEnforceCursorAssoc&&t.selectionSet&&t.view.lineWrapping&&t.state.selection.main.empty&&t.state.selection.main.assoc&&(this.mustEnforceCursorAssoc=!0)}measure(t,e){let i=t.dom,s="",n=Ss.LTR,r=0;if(!e){let t=window.getComputedStyle(i);s=t.whiteSpace,n="rtl"==t.direction?Ss.RTL:Ss.LTR;let e=parseInt(t.paddingTop)||0,o=parseInt(t.paddingBottom)||0;this.paddingTop==e&&this.paddingBottom==o||(r|=8,this.paddingTop=e,this.paddingBottom=o)}let o=this.printing?{top:-1e8,bottom:1e8,left:-1e8,right:1e8}:function(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);for(let e=t.parentNode;e;)if(1==e.nodeType){let t=window.getComputedStyle(e);if((e.scrollHeight>e.clientHeight||e.scrollWidth>e.clientWidth)&&"visible"!=t.overflow){let t=e.getBoundingClientRect();s=Math.max(s,t.left),n=Math.min(n,t.right),r=Math.max(r,t.top),o=Math.min(o,t.bottom)}e="absolute"==t.position||"fixed"==t.position?e.offsetParent:e.parentNode}else{if(11!=e.nodeType)break;e=e.host}return{left:s-i.left,right:n-i.left,top:r-(i.top+e),bottom:o-(i.top+e)}}(i,this.paddingTop),h=o.top-this.pixelViewport.top,l=o.bottom-this.pixelViewport.bottom;if(this.pixelViewport=o,this.inView=this.pixelViewport.bottom>this.pixelViewport.top&&this.pixelViewport.right>this.pixelViewport.left,!this.inView)return 0;let a=t.measureVisibleLineHeights(),c=!1,u=0,f=this.heightOracle;if(!e){let e=t.dom.clientWidth;if(f.mustRefresh(a,s,n)||f.lineWrapping&&Math.abs(e-this.contentWidth)>f.charWidth){let{lineHeight:i,charWidth:o}=t.measureTextSize();c=f.refresh(s,n,i,o,e/o,a),c&&(t.minWidth=0,r|=8)}this.contentWidth!=e&&(this.contentWidth=e,r|=8),h>0&&l>0?u=Math.max(h,l):h<0&&l<0&&(u=Math.min(h,l))}return f.heightChanged=!1,this.heightMap=this.heightMap.updateHeight(f,0,c,new wn(this.viewport.from,a)),f.heightChanged&&(r|=2),(!this.viewportIsAppropriate(this.viewport,u)||this.scrollTo&&(this.scrollTo.head<this.viewport.from||this.scrollTo.head>this.viewport.to))&&(this.viewport=this.getViewport(u,this.scrollTo)),this.updateForViewport(),(this.lineGaps.length||this.viewport.to-this.viewport.from>15e3)&&this.updateLineGaps(this.ensureLineGaps(c?[]:this.lineGaps)),r|=this.computeVisibleRanges(),this.mustEnforceCursorAssoc&&(this.mustEnforceCursorAssoc=!1,t.enforceCursorAssoc()),r}get visibleTop(){return this.scaler.fromDOM(this.pixelViewport.top,0)}get visibleBottom(){return this.scaler.fromDOM(this.pixelViewport.bottom,0)}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 En(s.lineAt(r-1e3*i,yn.ByHeight,n,0,0).from,s.lineAt(o+1e3*(1-i),yn.ByHeight,n,0,0).to);if(e)if(e.head<h.from){let{top:t}=s.lineAt(e.head,yn.ByPos,n,0,0);h=new En(s.lineAt(t-500,yn.ByHeight,n,0,0).from,s.lineAt(t+(o-r)+500,yn.ByHeight,n,0,0).to)}else if(e.head>h.to){let{bottom:t}=s.lineAt(e.head,yn.ByPos,n,0,0);h=new En(s.lineAt(t-(o-r)-500,yn.ByHeight,n,0,0).from,s.lineAt(t+500,yn.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 En(this.heightMap.lineAt(i,yn.ByPos,this.state.doc,0,0).from,this.heightMap.lineAt(s,yn.ByPos,this.state.doc,0,0).to)}viewportIsAppropriate({from:t,to:e},i=0){let{top:s}=this.heightMap.lineAt(t,yn.ByPos,this.state.doc,0,0),{bottom:n}=this.heightMap.lineAt(e,yn.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 On(e.mapPos(s.from),e.mapPos(s.to),s.size));return i}ensureLineGaps(t){let e=[];return this.heightOracle.direction!=Ss.LTR||this.heightMap.forEachLine(this.viewport.from,this.viewport.to,this.state.doc,0,0,(i=>{if(i.length<1e4)return;let s,n,r=function(t,e,i){let s=[],n=t,r=0;ve.spans(i.facet(ps),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);return{total:r,ranges:s}}(i.from,i.to,this.state);if(r.total<1e4)return;if(this.heightOracle.lineWrapping)s=i.from!=this.viewport.from?i.from:Rn(r,(this.visibleTop-i.top)/i.height),n=i.to!=this.viewport.to?i.to:Rn(r,(this.visibleBottom-i.top)/i.height);else{let t=r.total*this.heightOracle.charWidth;s=Rn(r,this.pixelViewport.left/t),n=Rn(r,this.pixelViewport.right/t)}let o=this.state.selection.main;o.from<=s&&o.to>=i.from&&(s=o.from),o.from<=i.to&&o.to>=n&&(n=o.to);let h=s-1e4,l=n+1e4;h>i.from+5e3&&e.push(Nn(t,(t=>t.from==i.from&&t.to>h-5e3&&t.to<h+5e3))||new On(i.from,h,this.gapSize(i,h,!0,r))),l<i.to-5e3&&e.push(Nn(t,(t=>t.to==i.to&&t.from>l-5e3&&t.from<l+5e3))||new On(l,i.to,this.gapSize(i,l,!1,r)))})),e}gapSize(t,e,i,s){if(this.heightOracle.lineWrapping){let n=t.height*Ln(s,e);return i?n:t.height-n}{let t=Ln(s,e);return s.total*this.heightOracle.charWidth*(i?t:1-t)}}updateLineGaps(t){On.same(t,this.lineGaps)||(this.lineGaps=t,this.lineGapDeco=zi.set(t.map((t=>t.draw(this.heightOracle.lineWrapping)))))}computeVisibleRanges(){let t=this.state.facet(ps);this.lineGaps.length&&(t=t.concat(this.lineGapDeco));let e=[];ve.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}lineAt(t,e){return e+=this.paddingTop,Vn(this.heightMap.lineAt(t,yn.ByPos,this.state.doc,e,0),this.scaler,e)}lineAtHeight(t,e){return e+=this.paddingTop,Vn(this.heightMap.lineAt(this.scaler.fromDOM(t,e),yn.ByHeight,this.state.doc,e,0),this.scaler,e)}blockAtHeight(t,e){return e+=this.paddingTop,Vn(this.heightMap.blockAt(this.scaler.fromDOM(t,e),this.state.doc,e,0),this.scaler,e)}forEachLine(t,e,i,s){return s+=this.paddingTop,this.heightMap.forEachLine(t,e,this.state.doc,s,0,1==this.scaler.scale?i:t=>i(Vn(t,this.scaler,s)))}get contentHeight(){return this.domHeight+this.paddingTop+this.paddingBottom}get domHeight(){return this.scaler.toDOM(this.heightMap.height,this.paddingTop)}}class En{constructor(t,e){this.from=t,this.to=e}}function Rn({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 Ln(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 Nn(t,e){for(let i of t)if(e(i))return i}const In={toDOM:t=>t,fromDOM:t=>t,scale:1};class Bn{constructor(t,e,i){let s=0,n=0,r=0;this.viewports=i.map((({from:i,to:n})=>{let r=e.lineAt(i,yn.ByPos,t,0,0).top,o=e.lineAt(n,yn.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,e){t-=e;for(let i=0,s=0,n=0;;i++){let r=i<this.viewports.length?this.viewports[i]:null;if(!r||t<r.top)return n+(t-s)*this.scale+e;if(t<=r.bottom)return r.domTop+(t-r.top)+e;s=r.bottom,n=r.domBottom}}fromDOM(t,e){t-=e;for(let i=0,s=0,n=0;;i++){let r=i<this.viewports.length?this.viewports[i]:null;if(!r||t<r.domTop)return s+(t-n)/this.scale+e;if(t<=r.domBottom)return r.top+(t-r.domTop)+e;s=r.bottom,n=r.domBottom}}}function Vn(t,e,i){if(1==e.scale)return t;let s=e.toDOM(t.top,i),n=e.toDOM(t.bottom,i);return new vn(t.from,t.length,s,n-s,Array.isArray(t.type)?t.type.map((t=>Vn(t,e,i))):t.type)}const zn=Mt.define({combine:t=>t.join(" ")}),Fn=Mt.define({combine:t=>t.indexOf(!0)>-1}),Hn=W.newName(),Wn=W.newName(),qn=W.newName(),jn={"&light":"."+Wn,"&dark":"."+qn};function _n(t,e,i){return new W(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 $n=_n("."+Hn,{"&":{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"},".cm-lineWrapping":{whiteSpace:"pre-wrap",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":{position:"absolute",borderLeft:"1.2px solid black",marginLeft:"-0.6px",pointerEvents:"none",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-tab":{display:"inline-block",overflow:"hidden",verticalAlign:"bottom"},".cm-placeholder":{color:"#888",display:"inline-block"},".cm-button":{verticalAlign:"middle",color:"inherit",fontSize:"70%",padding:".2em 1em",borderRadius:"3px"},"&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"}},jn),Un={childList:!0,characterData:!0,subtree:!0,attributes:!0,characterDataOldValue:!0},Gn=xi.ie&&xi.ie_version<=11;class Kn{constructor(t,e,i){this.view=t,this.onChange=e,this.onScrollChanged=i,this.active=!1,this.ignoreSelection=new Ye,this.delayedFlush=-1,this.queue=[],this.lastFlush=0,this.scrollTargets=[],this.intersection=null,this.intersecting=!1,this.gapIntersection=null,this.gaps=[],this._selectionRange=null,this.parentCheck=-1,this.dom=t.contentDOM,this.observer=new MutationObserver((e=>{for(let t of e)this.queue.push(t);this._selectionRange=null,(xi.ie&&xi.ie_version<=11||xi.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()})),Gn&&(this.onCharData=t=>{this.queue.push({target:t.target,type:"characterData",oldValue:t.prevValue}),this.flushSoon()}),this.onSelectionChange=this.onSelectionChange.bind(this),this.start(),this.onScroll=this.onScroll.bind(this),window.addEventListener("scroll",this.onScroll),"function"==typeof IntersectionObserver&&(this.intersection=new IntersectionObserver((t=>{this.parentCheck<0&&(this.parentCheck=setTimeout(this.listenForScroll.bind(this),1e3)),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[t.length-1].intersectionRatio>0&&this.onScrollChanged(document.createEvent("Event"))}),{})),this.listenForScroll()}onScroll(t){this.intersecting&&this.flush(),this.onScrollChanged(t)}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){this.lastFlush<Date.now()-50&&(this._selectionRange=null);let{view:e}=this,i=this.selectionRange;if(e.state.facet(ns)?e.root.activeElement!=this.dom:!qe(e.dom,i))return;let s=i.anchorNode&&e.docView.nearest(i.anchorNode);s&&s.ignoreEvent(t)||(xi.ie&&xi.ie_version<=11&&!e.state.selection.main.empty&&i.focusNode&&_e(i.focusNode,i.focusOffset,i.anchorNode,i.anchorOffset)?this.flushSoon():this.flush())}get selectionRange(){if(!this._selectionRange){let{root:t}=this.view,e=He(t);xi.safari&&11==t.nodeType&&function(){let t=document.activeElement;for(;t&&t.shadowRoot;)t=t.shadowRoot.activeElement;return t}()==this.view.contentDOM&&(e=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);_e(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),this._selectionRange=e}return this._selectionRange}setSelectionRange(t,e){var i;(null===(i=this._selectionRange)||void 0===i?void 0:i.type)||(this._selectionRange={anchorNode:t.node,anchorOffset:t.offset,focusNode:e.node,focusOffset:e.offset})}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,Un),this.dom.ownerDocument.addEventListener("selectionchange",this.onSelectionChange),Gn&&this.dom.addEventListener("DOMCharacterDataModified",this.onCharData),this.active=!0)}stop(){this.active&&(this.active=!1,this.observer.disconnect(),this.dom.ownerDocument.removeEventListener("selectionchange",this.onSelectionChange),Gn&&this.dom.removeEventListener("DOMCharacterDataModified",this.onCharData))}clearSelection(){this.ignoreSelection.set(this.selectionRange)}clear(){this.observer.takeRecords(),this.queue.length=0,this.clearSelection()}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())}flush(){if(this.delayedFlush>=0)return;this.lastFlush=Date.now();let t=this.queue;for(let e of this.observer.takeRecords())t.push(e);t.length&&(this.queue=[]);let e=this.selectionRange,i=!this.ignoreSelection.eq(e)&&qe(this.dom,e);if(0==t.length&&!i)return;let s=-1,n=-1,r=!1;for(let e of t){let t=this.readMutation(e);t&&(t.typeOver&&(r=!0),-1==s?({from:s,to:n}=t):(s=Math.min(t.from,s),n=Math.max(t.to,n)))}let o=this.view.state;(s>-1||i)&&this.onChange(s,n,r),this.view.state==o&&(this.view.docView.dirty&&(this.ignore((()=>this.view.docView.sync())),this.view.docView.dirty=0),i&&this.view.docView.updateSelection()),this.clearSelection()}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=Jn(e,t.previousSibling||t.target.previousSibling,-1),s=Jn(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(){this.stop(),this.intersection&&this.intersection.disconnect(),this.gapIntersection&&this.gapIntersection.disconnect();for(let t of this.scrollTargets)t.removeEventListener("scroll",this.onScroll);window.removeEventListener("scroll",this.onScroll),clearTimeout(this.parentCheck)}}function Jn(t,e,i){for(;e;){let s=hi.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 Xn(t,e,i,s){let n,r,o,h=t.state.selection.main;if(e>-1&&!t.state.readOnly&&(o=t.docView.domBoundsAround(e,i,0))){let{from:e,to:i}=o,s=t.docView.impreciseHead||t.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 Zn(i,s)),n==i&&r==s||e.push(new Zn(n,r)));return e}(t),l=new Yn(s,t);l.readRange(o.startDOM,o.endDOM),r=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?kt.single(i+e,s+e):null}(s,e);let a=h.from,c=null;(8===t.inputState.lastKeyCode&&t.inputState.lastKeyTime>Date.now()-100||xi.android&&l.text.length<i-e)&&(a=h.to,c="end");let u=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}}(t.state.sliceDoc(e,i),l.text,a-e,c);u&&(n={from:e+u.from,to:e+u.toA,insert:t.state.toText(l.text.slice(u.from,u.toB))})}else if(t.hasFocus||!t.state.facet(ns)){let e=t.observer.selectionRange,{impreciseHead:i,impreciseAnchor:s}=t.docView,n=i&&i.node==e.focusNode&&i.offset==e.focusOffset||!We(t.contentDOM,e.focusNode)?t.state.selection.main.head:t.docView.posFromDOM(e.focusNode,e.focusOffset),o=s&&s.node==e.anchorNode&&s.offset==e.anchorOffset||!We(t.contentDOM,e.anchorNode)?t.state.selection.main.anchor:t.docView.posFromDOM(e.anchorNode,e.anchorOffset);n==h.head&&o==h.anchor||(r=kt.single(o,n))}if(n||r)if(!n&&s&&!h.empty&&r&&r.main.empty?n={from:h.from,to:h.to,insert:t.state.doc.slice(h.from,h.to)}:n&&n.from>=h.from&&n.to<=h.to&&(n.from!=h.from||n.to!=h.to)&&h.to-h.from-(n.to-n.from)<=4&&(n={from:h.from,to:h.to,insert:t.state.doc.slice(h.from,n.from).append(n.insert).append(t.state.doc.slice(n.to,h.to))}),n){let e=t.state;if(xi.android&&(n.from==h.from&&n.to==h.to&&1==n.insert.length&&2==n.insert.lines&&ii(t.contentDOM,"Enter",13)||n.from==h.from-1&&n.to==h.to&&0==n.insert.length&&ii(t.contentDOM,"Backspace",8)||n.from==h.from&&n.to==h.to+1&&0==n.insert.length&&ii(t.contentDOM,"Delete",46))||xi.ios&&t.inputState.flushIOSKey(t))return;let i,s=n.insert.toString();if(t.state.facet(es).some((e=>e(t,n.from,n.to,s))))return;if(t.inputState.composing>=0&&t.inputState.composing++,n.from>=h.from&&n.to<=h.to&&n.to-n.from>=(h.to-h.from)/3&&(!r||r.main.empty&&r.main.from==n.from+n.insert.length)){let s=h.from<n.from?e.sliceDoc(h.from,n.from):"",r=h.to>n.to?e.sliceDoc(n.to,h.to):"";i=e.replaceSelection(t.state.toText(s+n.insert.sliceString(0,void 0,t.state.lineBreak)+r))}else{let t=e.changes(n);i={changes:t,selection:r&&!e.selection.main.eq(r.main)&&r.main.to<=t.newLength?e.selection.replaceRange(r.main):void 0}}let o="input.type";t.composing&&(o+=".compose",t.inputState.compositionFirstChange&&(o+=".start",t.inputState.compositionFirstChange=!1)),t.dispatch(i,{scrollIntoView:!0,userEvent:o})}else if(r&&!r.main.eq(h)){let e=!1,i="select";t.inputState.lastSelectionTime>Date.now()-50&&("select"==t.inputState.lastSelectionOrigin&&(e=!0),i=t.inputState.lastSelectionOrigin),t.dispatch({selection:r,scrollIntoView:e,userEvent:i})}}class Yn{constructor(t,e){this.points=t,this.view=e,this.text="",this.lineBreak=e.state.lineBreak}readRange(t,e){if(!t)return;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=hi.get(s),r=hi.get(t);(n&&r?n.breakAfter:(n?n.breakAfter:Qn(s))||Qn(t)&&("BR"!=s.nodeName||s.cmIgnore))&&(this.text+=this.lineBreak),s=t}this.findPointBefore(i,e)}readNode(t){if(t.cmIgnore)return;let e,i=hi.get(t),s=i&&i.overrideDOMText;null!=s?e=s.sliceString(0,void 0,this.lineBreak):3==t.nodeType?e=t.nodeValue:"BR"==t.nodeName?e=t.nextSibling?this.lineBreak:"":1==t.nodeType&&this.readRange(t.firstChild,null),null!=e&&(this.findPointIn(t,e.length),this.text+=e,xi.chrome&&13==this.view.inputState.lastKeyCode&&!t.nextSibling&&/\n\n$/.test(this.text)&&(this.text=this.text.slice(0,-1)))}findPointBefore(t,e){for(let i of this.points)i.node==t&&t.childNodes[i.offset]==e&&(i.pos=this.text.length)}findPointIn(t,e){for(let i of this.points)i.node==t&&(i.pos=this.text.length+Math.min(i.offset,e))}}function Qn(t){return 1==t.nodeType&&/^(DIV|P|LI|UL|OL|BLOCKQUOTE|DD|DT|H\d|SECTION|PRE)$/.test(t.nodeName)}class Zn{constructor(t,e){this.node=t,this.offset=e,this.pos=-1}}class tr{constructor(t={}){this.plugins=[],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||document,this.viewState=new Pn(t.state||fe.create()),this.plugins=this.state.facet(ls).map((t=>new us(t).update(this))),this.observer=new Kn(this,((t,e,i)=>{Xn(this,t,e,i)}),(t=>{this.inputState.runScrollHandlers(this,t),this.observer.intersecting&&this.measure()})),this.inputState=new Ks(this),this.docView=new vs(this),this.mountStyles(),this.updateAttrs(),this.updateState=0,window.addEventListener("resize",(()=>{-1==sr&&(sr=setTimeout(nr,50))})),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}dispatch(...t){this._dispatch(1==t.length&&t[0]instanceof ee?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(fe.phrases)!=this.state.facet(fe.phrases))return this.setState(s);e=new ws(this,s,t);let n=null;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=t.empty?t:kt.cursor(t.head,t.head>t.anchor?-1:1)}for(let t of e.effects)t.is(is)&&(n=t.value)}this.viewState.update(e,n),this.bidiCache=or.update(this.bidiCache,e.changes),e.empty||(this.updatePlugins(e),this.inputState.update(e)),i=this.docView.update(e),this.state.facet(gs)!=this.styleModules&&this.mountStyles(),this.updateAttrs(),this.showAnnouncements(t)}finally{this.updateState=0}if((i||n||this.viewState.mustEnforceCursorAssoc)&&this.requestMeasure(),!e.empty)for(let t of this.state.facet(ts))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)this.viewState.state=t;else{this.updateState=2;try{for(let t of this.plugins)t.destroy(this);this.viewState=new Pn(t),this.plugins=t.facet(ls).map((t=>new us(t).update(this))),this.docView=new vs(this),this.inputState.ensureHandlers(this),this.mountStyles(),this.updateAttrs(),this.bidiCache=[]}finally{this.updateState=0}this.requestMeasure()}}updatePlugins(t){let e=t.startState.facet(ls),i=t.state.facet(ls);if(e!=i){let s=[];for(let n of i){let i=e.indexOf(n);if(i<0)s.push(new us(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.inputState.ensureHandlers(this)}else for(let e of this.plugins)e.mustUpdate=t;for(let t=0;t<this.plugins.length;t++)this.plugins[t]=this.plugins[t].update(this)}measure(t=!0){if(this.destroyed)return;this.measureScheduled>-1&&cancelAnimationFrame(this.measureScheduled),this.measureScheduled=-1,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.docView,t>0);if(!s&&!this.measureRequests.length&&null==this.viewState.scrollTo)break;if(t>5){console.warn("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 ss(this.state,t),rr}})),o=new ws(this,this.state);o.flags|=s,e?e.flags|=s:e=o,this.updateState=2,o.empty||(this.updatePlugins(o),this.inputState.update(o)),this.updateAttrs(),s&&this.docView.update(o);for(let t=0;t<n.length;t++)if(r[t]!=rr)try{n[t].write(r[t],this)}catch(t){ss(this.state,t)}if(this.viewState.scrollTo&&(this.docView.scrollRangeIntoView(this.viewState.scrollTo),this.viewState.scrollTo=null),this.viewport.from==i.from&&this.viewport.to==i.to&&0==this.measureRequests.length)break}}finally{this.updateState=0}if(this.measureScheduled=-1,e&&!e.empty)for(let t of this.state.facet(ts))t(e)}get themeClasses(){return Hn+" "+(this.state.facet(Fn)?qn:Wn)+" "+this.state.facet(zn)}updateAttrs(){let t=Li(this.state.facet(fs),{class:"cm-editor"+(this.hasFocus?" cm-focused ":" ")+this.themeClasses});Ii(this.dom,this.editorAttrs,t),this.editorAttrs=t;let e={spellcheck:"false",autocorrect:"off",autocapitalize:"off",contenteditable:this.state.facet(ns)?ni()?"plaintext-only":"true":"false",class:"cm-content",style:`${xi.tabSize}: ${this.state.tabSize}`,role:"textbox","aria-multiline":"true"};this.state.readOnly&&(e["aria-readonly"]="true"),Li(this.state.facet(ds),e),Ii(this.contentDOM,this.contentAttrs,e),this.contentAttrs=e}showAnnouncements(t){let e=!0;for(let i of t)for(let t of i.effects)if(t.is(tr.announce)){e&&(this.announceDOM.textContent=""),e=!1,this.announceDOM.appendChild(document.createElement("div")).textContent=t.value}}mountStyles(){this.styleModules=this.state.facet(gs),W.mount(this.root,this.styleModules.concat($n).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)}}pluginField(t){let e=[];for(let i of this.plugins)i.update(this).takeField(t,e);return e}plugin(t){for(let e of this.plugins)if(e.spec==t)return e.update(this).value;return null}blockAtHeight(t,e){return this.readMeasured(),this.viewState.blockAtHeight(t,ir(e,this.contentDOM))}visualLineAtHeight(t,e){return this.readMeasured(),this.viewState.lineAtHeight(t,ir(e,this.contentDOM))}viewportLines(t,e){let{from:i,to:s}=this.viewport;this.viewState.forEachLine(i,s,t,ir(e,this.contentDOM))}visualLineAt(t,e=0){return this.viewState.lineAt(t,e)}get contentHeight(){return this.viewState.contentHeight}moveByChar(t,e,i){return Gs(this,t,Us(this,t,e,i))}moveByGroup(t,e){return Gs(this,t,Us(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==le.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.posAtCoords({x:i==(t.textDirection==Ss.LTR)?e.right-1:e.left+1,y:(r.top+r.bottom)/2});if(null!=s)return kt.cursor(s,i?-1:1)}let o=_i.find(t.docView,e.head),h=o?i?o.posAtEnd:o.posAtStart:i?n.to:n.from;return kt.cursor(h,i?-1:1)}(this,t,e,i)}moveVertically(t,e,i){return Gs(this,t,function(t,e,i,s){let n=e.head,r=i?1:-1;if(n==(i?t.state.doc.length:0))return kt.cursor(n);let o,h=e.goalColumn,l=t.contentDOM.getBoundingClientRect(),a=t.coordsAtPos(n);if(a)null==h&&(h=a.left-l.left),o=r<0?a.top:a.bottom;else{let e=t.viewState.lineAt(n,t.dom.getBoundingClientRect().top);null==h&&(h=Math.min(l.right-l.left,t.defaultCharacterWidth*(n-e.from))),o=r<0?e.top:e.bottom}let c=l.left+h,u=null!=s?s:t.defaultLineHeight>>1;for(let e=0;;e+=10){let i=o+(u+e)*r,s=_s(t,{x:c,y:i},!1,r);if(i<l.top||i>l.bottom||(r<0?s<n:s>n))return kt.cursor(s,void 0,void 0,h)}}(this,t,e,i))}scrollPosIntoView(t){this.viewState.scrollTo=kt.cursor(t),this.requestMeasure()}domAtPos(t){return this.docView.domAtPos(t)}posAtDOM(t,e=0){return this.docView.posFromDOM(t,e)}posAtCoords(t,e=!0){return this.readMeasured(),_s(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 Je(i,n[Rs.find(n,t-s.from,-1,e)].dir==Ss.LTR==e>0)}get defaultCharacterWidth(){return this.viewState.heightOracle.charWidth}get defaultLineHeight(){return this.viewState.heightOracle.lineHeight}get textDirection(){return this.viewState.heightOracle.direction}get lineWrapping(){return this.viewState.heightOracle.lineWrapping}bidiSpans(t){if(t.length>er)return Ns(t.length);let e=this.textDirection;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==As?1:2,n=e==As?2:1;if(!t||1==s&&!Es.test(t))return Ns(i);for(let e=0,n=s,o=s;e<i;e++){let i=(r=t.charCodeAt(e))<=247?Ds[r]:1424<=r&&r<=1524?2:1536<=r&&r<=1785?Os[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),Ls[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=Ls[t];if(128==s)t<i-1&&e==Ls[t+1]&&24&e?s=Ls[t]=e:Ls[t]=256;else if(64==s){let s=t+1;for(;s<i&&64==Ls[s];)s++;let r=t&&8==e||s<i&&8==Ls[s]?1==n?1:8:256;for(let e=t;e<s;e++)Ls[e]=r;t=s-1}else 8==s&&1==n&&(Ls[t]=1);e=s,7&s&&(n=s)}for(let e,r,o,h=0,l=0,a=0;h<i;h++)if(r=Ts[e=t.charCodeAt(h)])if(r<0){for(let t=l-3;t>=0;t-=3)if(Ps[t+1]==-r){let e=Ps[t+2],i=2&e?s:4&e?1&e?n:s:0;i&&(Ls[h]=Ls[Ps[t]]=i),l=t;break}}else{if(189==Ps.length)break;Ps[l++]=h,Ps[l++]=e,Ps[l++]=a}else if(2==(o=Ls[h])||1==o){let t=o==s;a=t?0:1;for(let e=l-3;e>=0;e-=3){let i=Ps[e+2];if(2&i)break;if(t)Ps[e+2]|=2;else{if(4&i)break;Ps[e+2]|=4}}}for(let t=0;t<i;t++)if(256==Ls[t]){let e=t+1;for(;e<i&&256==Ls[e];)e++;let n=1==(t?Ls[t-1]:s),r=n==(1==(e<i?Ls[e]:s))?n?1:2:s;for(let i=t;i<e;i++)Ls[i]=r;t=e-1}let o=[];if(1==s)for(let t=0;t<i;){let e=t,s=1!=Ls[t++];for(;t<i&&s==(1!=Ls[t]);)t++;if(s)for(let i=t;i>e;){let t=i,s=2!=Ls[--i];for(;i>e&&s==(2!=Ls[i-1]);)i--;o.push(new Rs(i,t,s?2:1))}else o.push(new Rs(e,t,0))}else for(let t=0;t<i;){let e=t,s=2==Ls[t++];for(;t<i&&s==(2==Ls[t]);)t++;o.push(new Rs(e,t,s?1:2))}return o}(t.text,this.textDirection);return this.bidiCache.push(new or(t.from,t.to,e,i)),i}get hasFocus(){var t;return(document.hasFocus()||xi.safari&&(null===(t=this.inputState)||void 0===t?void 0:t.lastContextMenu)>Date.now()-3e4)&&this.root.activeElement==this.contentDOM}focus(){this.observer.ignore((()=>{ti(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 domEventHandlers(t){return as.define((()=>({})),{eventHandlers:t})}static theme(t,e){let i=W.newName(),s=[zn.of(i),gs.of(_n(`.${i}`,t))];return e&&e.dark&&s.push(Fn.of(!0)),s}static baseTheme(t){return Vt.fallback(gs.of(_n("."+Hn,t,jn)))}}tr.scrollTo=is,tr.styleModule=gs,tr.inputHandler=es,tr.exceptionSink=Zi,tr.updateListener=ts,tr.editable=ns,tr.mouseSelectionStyle=Qi,tr.dragMovesSelection=Yi,tr.clickAddsSelectionRange=Xi,tr.decorations=ps,tr.contentAttributes=ds,tr.editorAttributes=fs,tr.lineWrapping=tr.contentAttributes.of({class:"cm-lineWrapping"}),tr.announce=te.define();const er=4096;function ir(t,e){return null==t?e.getBoundingClientRect().top:t}let sr=-1;function nr(){sr=-1;let t=document.querySelectorAll(".cm-content");for(let e=0;e<t.length;e++){let i=hi.get(t[e]);i&&i.editorView.requestMeasure()}}const rr={};class or{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:Ss.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 or(e.mapPos(r.from,1),e.mapPos(r.to,-1),r.dir,r.order))}return i}}const hr="undefined"==typeof navigator?"key":/Mac/.test(navigator.platform)?"mac":/Win/.test(navigator.platform)?"win":/Linux|X11/.test(navigator.platform)?"linux":"key";function lr(t,e,i){return e.altKey&&(t="Alt-"+t),e.ctrlKey&&(t="Ctrl-"+t),e.metaKey&&(t="Meta-"+t),!1!==i&&e.shiftKey&&(t="Shift-"+t),t}const ar=tr.domEventHandlers({keydown:(t,e)=>function(t,e,i,s){let n=function(t){var e=!(Ve&&(t.ctrlKey||t.altKey||t.metaKey)||(Le||Be)&&t.shiftKey&&t.key&&1==t.key.length)&&t.key||(t.shiftKey?Ee:Pe)[t.keyCode]||t.key||"Unidentified";return"Esc"==e&&(e="Escape"),"Del"==e&&(e="Delete"),"Left"==e&&(e="ArrowLeft"),"Up"==e&&(e="ArrowUp"),"Right"==e&&(e="ArrowRight"),"Down"==e&&(e="ArrowDown"),e}(e),r=1==n.length&&" "!=n,o="",h=!1;fr&&fr.view==i&&fr.scope==s&&(o=fr.prefix+" ",(h=Js.indexOf(e.keyCode)<0)&&(fr=null));let l,a=t=>{if(t){for(let e of t.commands)if(e(i))return!0;t.preventDefault&&(h=!0)}return!1},c=t[s];if(c){if(a(c[o+lr(n,e,!r)]))return!0;if(r&&(e.shiftKey||e.altKey||e.metaKey)&&(l=Pe[e.keyCode])&&l!=n){if(a(c[o+lr(l,e,!0)]))return!0}else if(r&&e.shiftKey&&a(c[o+lr(n,e,!0)]))return!0}return h}(function(t){let e=t.facet(cr),i=ur.get(e);i||ur.set(e,i=function(t,e=hr){let i=Object.create(null),s=Object.create(null),n=(t,e)=>{let i=s[t];if(null==i)s[t]=e;else if(i!=e)throw new Error("Key binding "+t+" is used both as a regular binding and as a multi-stroke prefix")},r=(t,s,r,o)=>{let h=i[t]||(i[t]=Object.create(null)),l=s.split(/ (?!$)/).map((t=>function(t,e){const i=t.split(/-(?!$)/);let s,n,r,o,h=i[i.length-1];"Space"==h&&(h=" ");for(let t=0;t<i.length-1;++t){const h=i[t];if(/^(cmd|meta|m)$/i.test(h))o=!0;else if(/^a(lt)?$/i.test(h))s=!0;else if(/^(c|ctrl|control)$/i.test(h))n=!0;else if(/^s(hift)?$/i.test(h))r=!0;else{if(!/^mod$/i.test(h))throw new Error("Unrecognized modifier name: "+h);"mac"==e?o=!0:n=!0}}return s&&(h="Alt-"+h),n&&(h="Ctrl-"+h),o&&(h="Meta-"+h),r&&(h="Shift-"+h),h}(t,e)));for(let e=1;e<l.length;e++){let i=l.slice(0,e).join(" ");n(i,!0),h[i]||(h[i]={preventDefault:!0,commands:[e=>{let s=fr={view:e,prefix:i,scope:t};return setTimeout((()=>{fr==s&&(fr=null)}),4e3),!0}]})}let a=l.join(" ");n(a,!1);let c=h[a]||(h[a]={preventDefault:!1,commands:[]});c.commands.push(r),o&&(c.preventDefault=!0)};for(let i of t){let t=i[e]||i.key;if(t)for(let e of i.scope?i.scope.split(" "):["editor"])r(e,t,i.run,i.preventDefault),i.shift&&r(e,"Shift-"+t,i.shift,i.preventDefault)}return i}(e.reduce(((t,e)=>t.concat(e)),[])));return i}(e.state),t,e,"editor")}),cr=Mt.define({enables:ar}),ur=new WeakMap;let fr=null;const dr=!xi.ios,pr=Mt.define({combine:t=>de(t,{cursorBlinkRate:1200,drawRangeCursor:!0},{cursorBlinkRate:(t,e)=>Math.min(t,e),drawRangeCursor:(t,e)=>t||e})});function gr(t={}){return[pr.of(t),wr,yr]}class mr{constructor(t,e,i,s,n){this.left=t,this.top=e,this.width=i,this.height=s,this.className=n}draw(){let t=document.createElement("div");return t.className=this.className,this.adjust(t),t}adjust(t){t.style.left=this.left+"px",t.style.top=this.top+"px",this.width>=0&&(t.style.width=this.width+"px"),t.style.height=this.height+"px"}eq(t){return this.left==t.left&&this.top==t.top&&this.width==t.width&&this.height==t.height&&this.className==t.className}}const wr=as.fromClass(class{constructor(t){this.view=t,this.rangePieces=[],this.cursors=[],this.measureReq={read:this.readPos.bind(this),write:this.drawSel.bind(this)},this.selectionLayer=t.scrollDOM.appendChild(document.createElement("div")),this.selectionLayer.className="cm-selectionLayer",this.selectionLayer.setAttribute("aria-hidden","true"),this.cursorLayer=t.scrollDOM.appendChild(document.createElement("div")),this.cursorLayer.className="cm-cursorLayer",this.cursorLayer.setAttribute("aria-hidden","true"),t.requestMeasure(this.measureReq),this.setBlinkRate()}setBlinkRate(){this.cursorLayer.style.animationDuration=this.view.state.facet(pr).cursorBlinkRate+"ms"}update(t){let e=t.startState.facet(pr)!=t.state.facet(pr);(e||t.selectionSet||t.geometryChanged||t.viewportChanged)&&this.view.requestMeasure(this.measureReq),t.transactions.some((t=>t.scrollIntoView))&&(this.cursorLayer.style.animationName="cm-blink"==this.cursorLayer.style.animationName?"cm-blink2":"cm-blink"),e&&this.setBlinkRate()}readPos(){let{state:t}=this.view,e=t.facet(pr),i=t.selection.ranges.map((t=>t.empty?[]:function(t,e){if(e.to<=t.viewport.from||e.from>=t.viewport.to)return[];let i=Math.max(e.from,t.viewport.from),s=Math.min(e.to,t.viewport.to),n=t.textDirection==Ss.LTR,r=t.contentDOM,o=r.getBoundingClientRect(),h=br(t),l=window.getComputedStyle(r.firstChild),a=o.left+parseInt(l.paddingLeft),c=o.right-parseInt(l.paddingRight),u=kr(t,i),f=kr(t,s),d=u.type==Vi.Text?u:null,p=f.type==Vi.Text?f:null;t.lineWrapping&&(d&&(d=xr(t,i,d)),p&&(p=xr(t,s,p)));if(d&&p&&d.from==p.from)return m(w(e.from,e.to,d));{let i=d?w(e.from,null,d):v(u,!1),s=p?w(null,e.to,p):v(f,!0),n=[];return(d||u).to<(p||f).from-1?n.push(g(a,i.bottom,c,s.top)):i.bottom<s.top&&kr(t,(i.bottom+s.top)/2).type==Vi.Text&&(i.bottom=s.top=(i.bottom+s.top)/2),m(i).concat(n).concat(m(s))}function g(t,e,i,s){return new mr(t-h.left,e-h.top,i-t,s-e,"cm-selectionBackground")}function m({top:t,bottom:e,horizontal:i}){let s=[];for(let n=0;n<i.length;n+=2)s.push(g(i[n],t,i[n+1],e));return s}function w(e,i,s){let r=1e9,o=-1e9,h=[];function l(e,i,l,u,f){let d=t.coordsAtPos(e,e==s.to?-2:2),p=t.coordsAtPos(l,l==s.from?2:-2);r=Math.min(d.top,p.top,r),o=Math.max(d.bottom,p.bottom,o),f==Ss.LTR?h.push(n&&i?a:d.left,n&&u?c:p.right):h.push(!n&&u?a:p.left,!n&&i?c:d.right)}let u=null!=e?e:s.from,f=null!=i?i:s.to;for(let s of t.visibleRanges)if(s.to>u&&s.from<f)for(let n=Math.max(s.from,u),r=Math.min(s.to,f);;){let s=t.state.doc.lineAt(n);for(let o of t.bidiSpans(s)){let t=o.from+s.from,h=o.to+s.from;if(t>=r)break;h>n&&l(Math.max(t,n),null==e&&t<=u,Math.min(h,r),null==i&&h>=f,o.dir)}if(n=s.to+1,n>=r)break}return 0==h.length&&l(u,null==e,f,null==i,t.textDirection),{top:r,bottom:o,horizontal:h}}function v(t,e){let i=o.top+(e?t.top:t.bottom);return{top:i,bottom:i,horizontal:[]}}}(this.view,t))).reduce(((t,e)=>t.concat(e))),s=[];for(let i of t.selection.ranges){let n=i==t.selection.main;if(i.empty?!n||dr:e.drawRangeCursor){let t=Sr(this.view,i,n);t&&s.push(t)}}return{rangePieces:i,cursors:s}}drawSel({rangePieces:t,cursors:e}){if(t.length!=this.rangePieces.length||t.some(((t,e)=>!t.eq(this.rangePieces[e])))){this.selectionLayer.textContent="";for(let e of t)this.selectionLayer.appendChild(e.draw());this.rangePieces=t}if(e.length!=this.cursors.length||e.some(((t,e)=>!t.eq(this.cursors[e])))){let t=this.cursorLayer.children;if(t.length!==e.length){this.cursorLayer.textContent="";for(const t of e)this.cursorLayer.appendChild(t.draw())}else e.forEach(((e,i)=>e.adjust(t[i])));this.cursors=e}}destroy(){this.selectionLayer.remove(),this.cursorLayer.remove()}}),vr={".cm-line":{"& ::selection":{backgroundColor:"transparent !important"},"&::selection":{backgroundColor:"transparent !important"}}};dr&&(vr[".cm-line"].caretColor="transparent !important");const yr=Vt.override(tr.theme(vr));function br(t){let e=t.scrollDOM.getBoundingClientRect();return{left:(t.textDirection==Ss.LTR?e.left:e.right-t.scrollDOM.clientWidth)-t.scrollDOM.scrollLeft,top:e.top-t.scrollDOM.scrollTop}}function xr(t,e,i){let s=kt.cursor(e);return{from:Math.max(i.from,t.moveToLineBoundary(s,!1,!0).from),to:Math.min(i.to,t.moveToLineBoundary(s,!0,!0).from),type:Vi.Text}}function kr(t,e){let i=t.visualLineAt(e);if(Array.isArray(i.type))for(let t of i.type)if(t.to>e||t.to==e&&(t.to==i.to||t.type==Vi.Text))return t;return i}function Sr(t,e,i){let s=t.coordsAtPos(e.head,e.assoc||1);if(!s)return null;let n=br(t);return new mr(s.left-n.left,s.top-n.top,-1,s.bottom-s.top,i?"cm-cursor cm-cursor-primary":"cm-cursor cm-cursor-secondary")}function Ar(t,e,i,s,n){e.lastIndex=0;for(let r,o=t.iterRange(i,s),h=i;!o.next().done;h+=o.value.length)if(!o.lineBreak)for(;r=e.exec(o.value);)n(h+r.index,h+r.index+r[0].length,r)}class Cr{constructor(t){let{regexp:e,decoration:i,boundary:s}=t;if(!e.global)throw new RangeError("The regular expression given to MatchDecorator should have its 'g' flag set");this.regexp=e,this.getDeco="function"==typeof i?i:()=>i,this.boundary=s}createDeco(t){let e=new ye;for(let{from:i,to:s}of t.visibleRanges)Ar(t.state.doc,this.regexp,i,s,((i,s,n)=>e.add(i,s,this.getDeco(n,t,i))));return e.finish()}updateDeco(t,e){let i=1e9,s=-1;return t.docChanged&&t.changes.iterChanges(((e,n,r,o)=>{o>t.view.viewport.from&&r<t.view.viewport.to&&(i=Math.min(r,i),s=Math.max(o,s))})),t.viewportChanged||s-i>1e3?this.createDeco(t.view):s>-1?this.updateRange(t.view,e.map(t.changes),i,s):e}updateRange(t,e,i,s){for(let n of t.visibleRanges){let r=Math.max(n.from,i),o=Math.min(n.to,s);if(o>r){let i=t.state.doc.lineAt(r),s=i.to<o?t.state.doc.lineAt(o):i,h=Math.max(n.from,i.from),l=Math.min(n.to,s.to);if(this.boundary){for(;r>i.from;r--)if(this.boundary.test(i.text[r-1-i.from])){h=r;break}for(;o<s.to;o++)if(this.boundary.test(s.text[o-s.from])){l=o;break}}let a,c=[];if(i==s)for(this.regexp.lastIndex=h-i.from;(a=this.regexp.exec(i.text))&&a.index<l-i.from;){let e=a.index+i.from;c.push(this.getDeco(a,t,e).range(e,e+a[0].length))}else Ar(t.state.doc,this.regexp,h,l,((e,i,s)=>c.push(this.getDeco(s,t,e).range(e,i))));e=e.update({filterFrom:h,filterTo:l,filter:(t,e)=>t<h||e>l,add:c})}}return e}}const Mr=null!=/x/.unicode?"gu":"g",Dr=new RegExp("[\0-\b\n--\u2028\u2029\ufeff-]",Mr),Or={0:"null",7:"bell",8:"backspace",10:"newline",11:"vertical tab",13:"carriage return",27:"escape",8203:"zero width space",8204:"zero width non-joiner",8205:"zero width joiner",8206:"left-to-right mark",8207:"right-to-left mark",8232:"line separator",8233:"paragraph separator",65279:"zero width no-break space",65532:"object replacement"};let Tr=null;const Pr=Mt.define({combine(t){let e=de(t,{render:null,specialChars:Dr,addSpecialChars:null});return(e.replaceTabs=!function(){var t;if(null==Tr&&"undefined"!=typeof document&&document.body){let e=document.body.style;Tr=null!=(null!==(t=e.tabSize)&&void 0!==t?t:e.MozTabSize)}return Tr||!1}())&&(e.specialChars=new RegExp("\t|"+e.specialChars.source,Mr)),e.addSpecialChars&&(e.specialChars=new RegExp(e.specialChars.source+"|"+e.addSpecialChars.source,Mr)),e}});function Er(t={}){return[Pr.of(t),Rr||(Rr=as.fromClass(class{constructor(t){this.view=t,this.decorations=zi.none,this.decorationCache=Object.create(null),this.decorator=this.makeDecorator(t.state.facet(Pr)),this.decorations=this.decorator.createDeco(t)}makeDecorator(t){return new Cr({regexp:t.specialChars,decoration:(e,i,s)=>{let{doc:n}=i.state,r=Q(e[0],0);if(9==r){let t=n.lineAt(s),e=i.state.tabSize,r=et(t.text,e,s-t.from);return zi.replace({widget:new Nr((e-r%e)*this.view.defaultCharacterWidth)})}return this.decorationCache[r]||(this.decorationCache[r]=zi.replace({widget:new Lr(t,r)}))},boundary:t.replaceTabs?void 0:/[^]/})}update(t){let e=t.state.facet(Pr);t.startState.facet(Pr)!=e?(this.decorator=this.makeDecorator(e),this.decorations=this.decorator.createDeco(t.view)):this.decorations=this.decorator.updateDeco(t,this.decorations)}},{decorations:t=>t.decorations}))]}let Rr=null;class Lr extends Bi{constructor(t,e){super(),this.options=t,this.code=e}eq(t){return t.code==this.code}toDOM(t){let e=function(t){return t>=32?"•":10==t?"":String.fromCharCode(9216+t)}(this.code),i=t.state.phrase("Control character")+" "+(Or[this.code]||"0x"+this.code.toString(16)),s=this.options.render&&this.options.render(this.code,i,e);if(s)return s;let n=document.createElement("span");return n.textContent=e,n.title=i,n.setAttribute("aria-label",i),n.className="cm-specialChar",n}ignoreEvent(){return!1}}class Nr extends Bi{constructor(t){super(),this.width=t}eq(t){return t.width==this.width}toDOM(){let t=document.createElement("span");return t.textContent="\t",t.className="cm-tab",t.style.width=this.width+"px",t}ignoreEvent(){return!1}}const Ir=as.fromClass(class{constructor(t){this.height=-1,this.measure={read:t=>Math.max(0,t.scrollDOM.clientHeight-t.defaultLineHeight),write:(t,e)=>{Math.abs(t-this.height)>1&&(this.height=t,e.contentDOM.style.paddingBottom=t+"px")}},t.requestMeasure(this.measure)}update(t){t.geometryChanged&&t.view.requestMeasure(this.measure)}});function Br(){return Ir}class Vr extends Bi{constructor(t){super(),this.content=t}toDOM(){let t=document.createElement("span");return t.className="cm-placeholder",t.style.pointerEvents="none",t.appendChild("string"==typeof this.content?document.createTextNode(this.content):this.content),"string"==typeof this.content?t.setAttribute("aria-label","placeholder "+this.content):t.setAttribute("aria-hidden","true"),t}ignoreEvent(){return!1}}function zr(t){return as.fromClass(class{constructor(e){this.view=e,this.placeholder=zi.set([zi.widget({widget:new Vr(t),side:1}).range(0)])}get decorations(){return this.view.state.doc.length?zi.none:this.placeholder}},{decorations:t=>t.decorations})}const Fr=new s;function Hr(t){return Mt.define({combine:t?e=>e.concat(t):void 0})}class Wr{constructor(t,e,i,s=[]){this.data=t,this.topNode=i,fe.prototype.hasOwnProperty("tree")||Object.defineProperty(fe.prototype,"tree",{get(){return _r(this)}}),this.parser=e,this.extension=[Zr.of(this),fe.languageData.of(((t,e,i)=>t.facet(qr(t,e,i))))].concat(s)}isActiveAt(t,e,i=-1){return qr(t,e,i)==this.data}findRegions(t){let e=t.facet(Zr);if((null==e?void 0:e.data)==this.data)return[{from:0,to:t.doc.length}];if(!e||!e.allowsNesting)return[];let i=[],n=(t,e)=>{if(t.prop(Fr)==this.data)return void i.push({from:e,to:e+t.length});let r=t.prop(s.mounted);if(r){if(r.tree.prop(Fr)==this.data){if(r.overlay)for(let t of r.overlay)i.push({from:t.from+e,to:t.to+e});else i.push({from:e,to:e+t.length});return}if(r.overlay){let t=i.length;if(n(r.tree,r.overlay[0].from+e),i.length>t)return}}for(let i=0;i<t.children.length;i++){let s=t.children[i];s instanceof a&&n(s,t.positions[i]+e)}};return n(_r(t),0),i}get allowsNesting(){return!0}}function qr(t,e,i){let s=t.facet(Zr);if(!s)return null;let n=s.data;if(s.allowsNesting)for(let s=_r(t).topNode;s;s=s.enter(e,i,!0,!1))n=s.type.prop(Fr)||n;return n}Wr.setState=te.define();class jr extends Wr{constructor(t,e){super(t,e,e.topNode),this.parser=e}static define(t){let e=Hr(t.languageData);return new jr(e,t.parser.configure({props:[Fr.add((t=>t.isTop?e:void 0))]}))}configure(t){return new jr(this.data,this.parser.configure(t))}get allowsNesting(){return this.parser.wrappers.length>0}}function _r(t){let e=t.field(Wr.state,!1);return e?e.tree:a.empty}class $r{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 Ur=null;class Gr{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 $r(this.state.doc),this.fragments)}work(t,e){return null!=e&&e>=this.state.doc.length&&(e=void 0),this.tree!=a.empty&&this.isDone(null!=e?e:this.state.doc.length)?(this.takeTree(),!0):this.withContext((()=>{var i;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=Date.now()+t;for(;;){let t=this.parse.advance();if(t){if(this.fragments=this.withoutTempSkipped(S.addTree(t,this.fragments,null!=this.parse.stoppedAt)),this.treeLen=null!==(i=this.parse.stoppedAt)&&void 0!==i?i:this.state.doc.length,this.tree=t,this.parse=null,!(this.treeLen<(null!=e?e:this.state.doc.length)))return!0;this.parse=this.startParse()}if(Date.now()>s)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.tree=e,this.fragments=this.withoutTempSkipped(S.addTree(this.tree,this.fragments,!0)),this.parse=null)}withContext(t){let e=Ur;Ur=this;try{return t()}finally{Ur=e}}withoutTempSkipped(t){for(let e;e=this.tempSkipped.pop();)t=Kr(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=S.applyChanges(i,e),s=a.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 Gr(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=Kr(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 A{createParse(e,i,s){let n=s[0].from,r=s[s.length-1].to;return{parsedPos:n,advance(){let e=Ur;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 a(o.none,[],[],r-n)},stoppedAt:null,stopAt(){}}}}}movedPast(t){return this.treeLen<t&&this.parse&&this.parse.parsedPos>=t}isDone(t){let e=this.fragments;return this.treeLen>=t&&e.length&&0==e[0].from&&e[0].to>=t}static get(){return Ur}}function Kr(t,e,i){return S.applyChanges(t,[{fromA:e,toA:i,fromB:e,toB:i}])}class Jr{constructor(t){this.context=t,this.tree=t.tree}apply(t){if(!t.docChanged)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(25,i)||e.takeTree(),new Jr(e)}static init(t){let e=new Gr(t.facet(Zr).parser,t,[],a.empty,0,{from:0,to:t.doc.length},[],null);return e.work(25)||e.takeTree(),new Jr(e)}}Wr.state=Rt.define({create:Jr.init,update(t,e){for(let t of e.effects)if(t.is(Wr.setState))return t.value;return e.startState.facet(Zr)!=e.state.facet(Zr)?Jr.init(e.state):t.apply(e)}});let Xr="undefined"!=typeof window&&window.requestIdleCallback||((t,{timeout:e})=>setTimeout(t,e)),Yr="undefined"!=typeof window&&window.cancelIdleCallback||clearTimeout;const Qr=as.fromClass(class{constructor(t){this.view=t,this.working=-1,this.chunkEnd=-1,this.chunkBudget=-1,this.work=this.work.bind(this),this.scheduleWork()}update(t){let e=this.view.state.field(Wr.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>-1)return;let{state:t}=this.view,e=t.field(Wr.state);e.tree==e.context.tree&&e.context.isDone(t.doc.length)||(this.working=Xr(this.work,{timeout:500}))}work(t){this.working=-1;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(Wr.state);if(n.tree==n.context.tree&&n.context.treeLen>=s+1e6)return;let r=Math.min(this.chunkBudget,t?Math.max(25,t.timeRemaining()):100),o=n.context.work(r,s+1e6);this.chunkBudget-=Date.now()-e,(o||this.chunkBudget<=0||n.context.movedPast(s))&&(n.context.takeTree(),this.view.dispatch({effects:Wr.setState.of(new Jr(n.context))})),!o&&this.chunkBudget>0&&this.scheduleWork(),this.checkAsyncSchedule(n.context)}checkAsyncSchedule(t){t.scheduleOn&&(t.scheduleOn.then((()=>this.scheduleWork())),t.scheduleOn=null)}destroy(){this.working>=0&&Yr(this.working)}},{eventHandlers:{focus(){this.scheduleWork()}}}),Zr=Mt.define({combine:t=>t.length?t[0]:null,enables:[Wr.state,Qr]});class to{constructor(t,e=[]){this.language=t,this.support=e,this.extension=[t,e]}}class eo{constructor(t,e,i,s,n){this.name=t,this.alias=e,this.extensions=i,this.filename=s,this.loadFunc=n,this.support=void 0,this.loading=null}load(){return this.loading||(this.loading=this.loadFunc().then((t=>this.support=t),(t=>{throw this.loading=null,t})))}static of(t){return new eo(t.name,(t.alias||[]).concat(t.name).map((t=>t.toLowerCase())),t.extensions||[],t.filename,t.load)}static matchFilename(t,e){for(let i of t)if(i.filename&&i.filename.test(e))return i;let i=/\.([^.]+)$/.exec(e);if(i)for(let e of t)if(e.extensions.indexOf(i[1])>-1)return e;return null}static matchLanguageName(t,e,i=!0){e=e.toLowerCase();for(let i of t)if(i.alias.some((t=>t==e)))return i;if(i)for(let i of t)for(let t of i.alias){let s=e.indexOf(t);if(s>-1&&(t.length>2||!/\w/.test(e[s-1])&&!/\w/.test(e[s+t.length])))return i}return null}}const io=Mt.define(),so=Mt.define({combine:t=>{if(!t.length)return" ";if(!/^(?: +|\t+)$/.test(t[0]))throw new Error("Invalid indent unit: "+JSON.stringify(t[0]));return t[0]}});function no(t){let e=t.facet(so);return 9==e.charCodeAt(0)?t.tabSize*e.length:e.length}function ro(t,e){let i="",s=t.tabSize;if(9==t.facet(so).charCodeAt(0))for(;e>=s;)i+="\t",e-=s;for(let t=0;t<e;t++)i+=" ";return i}function oo(t,e){t instanceof fe&&(t=new ho(t));for(let i of t.state.facet(io)){let s=i(t,e);if(null!=s)return s}let i=_r(t.state);return i?function(t,e,i){return co(e.resolveInner(i).enterUnfinishedNodesBefore(i),i,t)}(t,i,e):null}class ho{constructor(t,e={}){this.state=t,this.options=e,this.unit=no(t)}lineAt(t,e=1){let i=this.state.doc.lineAt(t),{simulateBreak:s}=this.options;return null!=s&&s>=i.from&&s<=i.to?(e<0?s<t:s<=t)?{text:i.text.slice(s-i.from),from:s}:{text:i.text.slice(0,s-i.from),from:i.from}:i}textAfterPos(t,e=1){if(this.options.simulateDoubleBreak&&t==this.options.simulateBreak)return"";let{text:i,from:s}=this.lineAt(t,e);return i.slice(t-s,Math.min(i.length,t+100-s))}column(t,e=1){let{text:i,from:s}=this.lineAt(t,e),n=this.countColumn(i,t-s),r=this.options.overrideIndentation?this.options.overrideIndentation(s):-1;return r>-1&&(n+=r-this.countColumn(i,i.search(/\S|$/))),n}countColumn(t,e=t.length){return et(t,this.state.tabSize,e)}lineIndent(t,e=1){let{text:i,from:s}=this.lineAt(t,e),n=this.options.overrideIndentation;if(n){let t=n(s);if(t>-1)return t}return this.countColumn(i,i.search(/\S|$/))}get simulatedBreak(){return this.options.simulateBreak||null}}const lo=new s;function ao(t){let e=t.type.prop(lo);if(e)return e;let i,n=t.firstChild;if(n&&(i=n.type.prop(s.closedBy))){let e=t.lastChild,s=e&&i.indexOf(e.name)>-1;return t=>mo(t,!0,1,void 0,s&&!function(t){return t.pos==t.options.simulateBreak&&t.options.simulateDoubleBreak}(t)?e.from:void 0)}return null==t.parent?uo:null}function co(t,e,i){for(;t;t=t.parent){let s=ao(t);if(s)return s(new fo(i,e,t))}return null}function uo(){return 0}class fo extends ho{constructor(t,e,i){super(t.state,t.options),this.base=t,this.pos=e,this.node=i}get textAfter(){return this.textAfterPos(this.pos)}get baseIndent(){let t=this.state.doc.lineAt(this.node.from);for(;;){let e=this.node.resolve(t.from);for(;e.parent&&e.parent.from==e.from;)e=e.parent;if(po(e,this.node))break;t=this.state.doc.lineAt(e.from)}return this.lineIndent(t.from)}continue(){let t=this.node.parent;return t?co(t,this.pos,this.base):0}}function po(t,e){for(let i=e;i;i=i.parent)if(t==i)return!0;return!1}function go({closing:t,align:e=!0,units:i=1}){return s=>mo(s,e,i,t)}function mo(t,e,i,s,n){let r=t.textAfter,o=r.match(/^\s*/)[0].length,h=s&&r.slice(o,o+s.length)==s||n==t.pos+o,l=e?function(t){let e=t.node,i=e.childAfter(e.from),s=e.lastChild;if(!i)return null;let n=t.options.simulateBreak,r=t.state.doc.lineAt(i.from),o=null==n||n<=r.from?r.to:Math.min(r.to,n);for(let t=i.to;;){let n=e.childAfter(t);if(!n||n==s)return null;if(!n.type.isSkipped)return n.from<o?i:null;t=n.to}}(t):null;return l?h?t.column(l.from):t.column(l.to):t.baseIndent+(h?0:t.unit*i)}const wo=t=>t.baseIndent;function vo({except:t,units:e=1}={}){return i=>{let s=t&&t.test(i.textAfter);return i.baseIndent+(s?0:e*i.unit)}}function yo(){return fe.transactionFilter.of((t=>{if(!t.docChanged||!t.isUserEvent("input.type"))return t;let e=t.startState.languageDataAt("indentOnInput",t.startState.selection.main.head);if(!e.length)return t;let i=t.newDoc,{head:s}=t.newSelection.main,n=i.lineAt(s);if(s>n.from+200)return t;let r=i.sliceString(n.from,s);if(!e.some((t=>t.test(r))))return t;let{state:o}=t,h=-1,l=[];for(let{head:t}of o.selection.ranges){let e=o.doc.lineAt(t);if(e.from==h)continue;h=e.from;let i=oo(o,e.from);if(null==i)continue;let s=/^\s*/.exec(e.text)[0],n=ro(o,i);s!=n&&l.push({from:e.from,to:e.from+s.length,insert:n})}return l.length?[t,{changes:l,sequential:!0}]:t}))}const bo=Mt.define(),xo=new s;function ko(t){let e=t.firstChild,i=t.lastChild;return e&&e.to<i.from?{from:e.to,to:i.type.isError?t.to:i.from}:null}function So(t,e,i){for(let s of t.facet(bo)){let n=s(t,e,i);if(n)return n}return function(t,e,i){let s=_r(t);if(0==s.length)return null;let n=null;for(let r=s.resolveInner(i);r;r=r.parent){if(r.to<=i||r.from>i)continue;if(n&&r.from<e)break;let s=r.type.prop(xo);if(s){let o=s(r,t);o&&o.from<=i&&o.from>=e&&o.to>i&&(n=o)}}return n}(t,e,i)}let Ao=0;class Co{constructor(t,e,i){this.set=t,this.base=e,this.modified=i,this.id=Ao++}static define(t){if(null==t?void 0:t.base)throw new Error("Can not derive from a modified tag");let e=new Co([],null,[]);if(e.set.push(e),t)for(let i of t.set)e.set.push(i);return e}static defineModifier(){let t=new Do;return e=>e.modified.indexOf(t)>-1?e:Do.get(e.base||e,e.modified.concat(t).sort(((t,e)=>t.id-e.id)))}}let Mo=0;class Do{constructor(){this.instances=[],this.id=Mo++}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 Co(s,t,e);for(let t of e)t.instances.push(n);let r=Oo(e);for(let e of t.set)for(let t of r)s.push(Do.get(e,t));return n}}function Oo(t){let e=[t];for(let i=0;i<t.length;i++)for(let s of Oo(t.slice(0,i).concat(t.slice(i+1))))e.push(s);return e}function To(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]?null:'"'==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 No(s,n,o>0?i.slice(0,o):null);e[h]=l.sort(e[h])}}return Po.add(e)}const Po=new s,Eo=Mt.define({combine:t=>t.length?Io.combinedMatch(t):null}),Ro=Mt.define({combine:t=>t.length?t[0].match:null});function Lo(t){return t.facet(Eo)||t.facet(Ro)}class No{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}}class Io{constructor(t,e){let i;function s(t){let e=W.newName();return(i||(i=Object.create(null)))["."+e]=t,e}this.map=Object.create(null),this.all="string"==typeof e.all?e.all:e.all?s(e.all):null;for(let e of t){let t=(e.class||s(Object.assign({},e,{tag:null})))+(this.all?" "+this.all:""),i=e.tag;if(Array.isArray(i))for(let e of i)this.map[e.id]=t;else this.map[i.id]=t}this.module=i?new W(i):null,this.scope=e.scope||null,this.match=this.match.bind(this);let n=[zo];this.module&&n.push(tr.styleModule.of(this.module)),this.extension=n.concat(Eo.of(this)),this.fallback=n.concat(Ro.of(this))}match(t,e){if(this.scope&&e!=this.scope)return null;for(let e of t.set){let i=this.map[e.id];if(void 0!==i)return e!=t&&(this.map[t.id]=i),i}return this.map[t.id]=this.all}static combinedMatch(t){if(1==t.length)return t[0].match;let e=t.some((t=>t.scope))?void 0:Object.create(null);return(i,s)=>{let n=e&&e[i.id];if(void 0!==n)return n;let r=null;for(let e of t){let t=e.match(i,s);t&&(r=r?r+" "+t:t)}return e&&(e[i.id]=r),r}}static define(t,e){return new Io(t,e||{})}static get(t,e,i){let s=Lo(t);return s&&s(e,i||o.none)}}function Bo(t,e,i,s=0,n=t.length){Wo(t,s,n,e,i)}class Vo{constructor(t){this.markCache=Object.create(null),this.tree=_r(t.state),this.decorations=this.buildDeco(t,Lo(t.state))}update(t){let e=_r(t.state),i=Lo(t.state),s=i!=t.startState.facet(Eo);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 zi.none;let i=new ye;for(let{from:s,to:n}of t.visibleRanges)Wo(this.tree,s,n,e,((t,e,s)=>{i.add(t,e,this.markCache[s]||(this.markCache[s]=zi.mark({class:s})))}));return i.finish()}}const zo=Vt.extend(as.fromClass(Vo,{decorations:t=>t.decorations})),Fo=[""];class Ho{constructor(t,e,i){this.at=t,this.style=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,n,r,o){let{type:h,from:l,to:a}=t;if(l>=i||a<=e)return;Fo[r]=h.name,h.isTop&&(o=h);let c=n,u=h.prop(Po),f=!1;for(;u;){if(!u.context||qo(u.context,Fo,r)){for(let t of u.tags){let e=this.style(t,o);e&&(c&&(c+=" "),c+=e,1==u.mode?n+=(n?" ":"")+e:0==u.mode&&(f=!0))}break}u=u.next}if(this.startSpan(t.from,c),f)return;let d=t.tree&&t.tree.prop(s.mounted);if(d&&d.overlay){let s=t.node.enter(d.overlay[0].from+l,1),h=t.firstChild();for(let u=0,f=l;;u++){let p=u<d.overlay.length?d.overlay[u]:null,g=p?p.from+l:a,m=Math.max(e,f),w=Math.min(i,g);if(m<w&&h)for(;t.from<w&&(this.highlightRange(t,m,w,n,r+1,o),this.startSpan(Math.min(i,t.to),c),!(t.to>=g)&&t.nextSibling()););if(!p||g>i)break;f=p.to+l,f>e&&(this.highlightRange(s.cursor,Math.max(e,p.from+l),Math.min(i,f),n,r,d.tree.type),this.startSpan(f,c))}h&&t.parent()}else if(t.firstChild()){do{if(!(t.to<=e)){if(t.from>=i)break;this.highlightRange(t,e,i,n,r+1,o),this.startSpan(Math.min(i,t.to),c)}}while(t.nextSibling());t.parent()}}}function Wo(t,e,i,s,n){let r=new Ho(e,s,n);r.highlightRange(t.cursor(),e,i,"",0,t.type),r.flush(i)}function qo(t,e,i){if(t.length>i-1)return!1;for(let s=i-1,n=t.length-1;n>=0;n--,s--){let i=t[n];if(i&&i!=e[s])return!1}return!0}const jo=Co.define,_o=jo(),$o=jo(),Uo=jo($o),Go=jo($o),Ko=jo(),Jo=jo(Ko),Xo=jo(Ko),Yo=jo(),Qo=jo(Yo),Zo=jo(),th=jo(),eh=jo(),ih=jo(eh),sh=jo(),nh={comment:_o,lineComment:jo(_o),blockComment:jo(_o),docComment:jo(_o),name:$o,variableName:jo($o),typeName:Uo,tagName:jo(Uo),propertyName:Go,attributeName:jo(Go),className:jo($o),labelName:jo($o),namespace:jo($o),macroName:jo($o),literal:Ko,string:Jo,docString:jo(Jo),character:jo(Jo),attributeValue:jo(Jo),number:Xo,integer:jo(Xo),float:jo(Xo),bool:jo(Ko),regexp:jo(Ko),escape:jo(Ko),color:jo(Ko),url:jo(Ko),keyword:Zo,self:jo(Zo),null:jo(Zo),atom:jo(Zo),unit:jo(Zo),modifier:jo(Zo),operatorKeyword:jo(Zo),controlKeyword:jo(Zo),definitionKeyword:jo(Zo),operator:th,derefOperator:jo(th),arithmeticOperator:jo(th),logicOperator:jo(th),bitwiseOperator:jo(th),compareOperator:jo(th),updateOperator:jo(th),definitionOperator:jo(th),typeOperator:jo(th),controlOperator:jo(th),punctuation:eh,separator:jo(eh),bracket:ih,angleBracket:jo(ih),squareBracket:jo(ih),paren:jo(ih),brace:jo(ih),content:Yo,heading:Qo,heading1:jo(Qo),heading2:jo(Qo),heading3:jo(Qo),heading4:jo(Qo),heading5:jo(Qo),heading6:jo(Qo),contentSeparator:jo(Yo),list:jo(Yo),quote:jo(Yo),emphasis:jo(Yo),strong:jo(Yo),link:jo(Yo),monospace:jo(Yo),strikethrough:jo(Yo),inserted:jo(),deleted:jo(),changed:jo(),invalid:jo(),meta:sh,documentMeta:jo(sh),annotation:jo(sh),processingInstruction:jo(sh),definition:Co.defineModifier(),constant:Co.defineModifier(),function:Co.defineModifier(),standard:Co.defineModifier(),local:Co.defineModifier(),special:Co.defineModifier()};function rh(t,e,i,s=0,n=0){null==e&&-1==(e=t.search(/[^\s\u00a0]/))&&(e=t.length);let r=n;for(let n=s;n<e;n++)9==t.charCodeAt(n)?r+=i-r%i:r++;return r}class oh{constructor(t,e,i){this.string=t,this.tabSize=e,this.indentUnit=i,this.pos=0,this.start=0,this.lastColumnPos=0,this.lastColumnValue=0}eol(){return this.pos>=this.string.length}sol(){return 0==this.pos}peek(){return this.string.charAt(this.pos)||void 0}next(){if(this.pos<this.string.length)return this.string.charAt(this.pos++)}eat(t){let e,i=this.string.charAt(this.pos);if(e="string"==typeof t?i==t:i&&(t instanceof RegExp?t.test(i):t(i)),e)return++this.pos,i}eatWhile(t){let e=this.pos;for(;this.eat(t););return this.pos>e}eatSpace(){let t=this.pos;for(;/[\s\u00a0]/.test(this.string.charAt(this.pos));)++this.pos;return this.pos>t}skipToEnd(){this.pos=this.string.length}skipTo(t){let e=this.string.indexOf(t,this.pos);if(e>-1)return this.pos=e,!0}backUp(t){this.pos-=t}column(){return this.lastColumnPos<this.start&&(this.lastColumnValue=rh(this.string,this.start,this.tabSize,this.lastColumnPos,this.lastColumnValue),this.lastColumnPos=this.start),this.lastColumnValue}indentation(){return rh(this.string,null,this.tabSize)}match(t,e,i){if("string"==typeof t){let s=t=>i?t.toLowerCase():t;return s(this.string.substr(this.pos,t.length))==s(t)?(!1!==e&&(this.pos+=t.length),!0):null}{let i=this.string.slice(this.pos).match(t);return i&&i.index>0?null:(i&&!1!==e&&(this.pos+=i[0].length),i)}}current(){return this.string.slice(this.start,this.pos)}}function hh(t){if("object"!=typeof t)return t;let e={};for(let i in t){let s=t[i];e[i]=s instanceof Array?s.slice():s}return e}class lh extends Wr{constructor(t){let e,i=Hr(t.languageData),n={token:(r=t).token,blankLine:r.blankLine||(()=>{}),startState:r.startState||(()=>!0),copyState:r.copyState||hh,indent:r.indent||(()=>null),languageData:r.languageData||{}};var r;super(i,new class extends A{createParse(t,i,s){return new uh(e,t,i,s)}},function(t){let e=o.define({id:ph.length,name:"Document",props:[Fr.add((()=>t))]});return ph.push(e),e}(i),[io.of(((t,e)=>this.getIndent(t,e)))]),e=this,this.streamParser=n,this.stateAfter=new s({perNode:!0})}static define(t){return new lh(t)}getIndent(t,e){let i=_r(t.state),s=i.resolve(e);for(;s&&s.type!=this.topNode;)s=s.parent;if(!s)return null;let n,r,o=ah(this,i,0,s.from,e);if(o?(r=o.state,n=o.pos+1):(r=this.streamParser.startState(t.unit),n=0),e-n>1e4)return null;for(;n<e;){let i=t.state.doc.lineAt(n),s=Math.min(e,i.to);if(i.length){let e=new oh(i.text,t.state.tabSize,t.unit);for(;e.pos<s-i.from;)fh(this.streamParser.token,e,r)}else this.streamParser.blankLine(r,t.unit);if(s==e)break;n=i.to+1}let{text:h}=t.state.doc.lineAt(e);return this.streamParser.indent(r,/^\s*(.*)/.exec(h)[1],t)}get allowsNesting(){return!1}}function ah(t,e,i,s,n){let r=i>=s&&i+e.length<=n&&e.prop(t.stateAfter);if(r)return{state:t.streamParser.copyState(r),pos:i+e.length};for(let r=e.children.length-1;r>=0;r--){let o=e.children[r],h=i+e.positions[r],l=o instanceof a&&h<n&&ah(t,o,h,s,n);if(l)return l}return null}function ch(t,e,i,s,n){if(n&&i<=0&&s>=e.length)return e;n||e.type!=t.topNode||(n=!0);for(let r=e.children.length-1;r>=0;r--){let o,h=e.positions[r]+i,l=e.children[r];if(h<s&&l instanceof a){if(!(o=ch(t,l,i-h,s-h,n)))break;return n?new a(e.type,e.children.slice(0,r).concat(o),e.positions.slice(0,r+1),h+o.length):o}}return null}class uh{constructor(t,e,i,s){this.lang=t,this.input=e,this.fragments=i,this.ranges=s,this.stoppedAt=null,this.chunks=[],this.chunkPos=[],this.chunk=[],this.chunkReused=void 0,this.rangeIndex=0,this.to=s[s.length-1].to;let n=Gr.get(),r=s[0].from,{state:o,tree:h}=function(t,e,i,s){for(let s of e){let e,n=s.from+(s.openStart?25:0),r=s.to-(s.openEnd?25:0),o=n<=i&&r>i&&ah(t,s.tree,0-s.offset,i,r);if(o&&(e=ch(t,s.tree,i+s.offset,o.pos+s.offset,!1)))return{state:o.state,tree:e}}return{state:t.streamParser.startState(s?no(s):4),tree:a.empty}}(t,i,r,null==n?void 0:n.state);this.state=o,this.parsedPos=this.chunkStart=r+h.length,h.length&&(this.chunks.push(h),this.chunkPos.push(0)),n&&this.parsedPos<n.viewport.from-1e5&&(this.state=this.lang.streamParser.startState(no(n.state)),n.skipUntilInView(this.parsedPos,n.viewport.from),this.parsedPos=n.viewport.from)}advance(){let t=Gr.get(),e=null==this.stoppedAt?this.to:this.stoppedAt,i=Math.min(e,this.chunkStart+2048);for(t&&(i=Math.min(i,t.viewport.to));this.parsedPos<i;)this.parseLine(t);return this.chunkStart<this.parsedPos&&this.finishChunk(),this.parsedPos>=e?this.finish():t&&this.parsedPos>t.viewport.to?(t.skipUntilInView(this.parsedPos,e),this.finish()):null}stopAt(t){this.stoppedAt=t}lineAfter(t){let e=this.input.chunk(t);if(this.input.lineChunks)"\n"==e&&(e="");else{let t=e.indexOf("\n");t>-1&&(e=e.slice(0,t))}return t+e.length<=this.to?e:e.slice(0,this.to-t)}nextLine(){let t=this.parsedPos,e=this.lineAfter(t),i=t+e.length;for(let t=this.rangeIndex;;){let s=this.ranges[t].to;if(s>=i)break;if(e=e.slice(0,s-(i-e.length)),t++,t==this.ranges.length)break;let n=this.ranges[t].from,r=this.lineAfter(n);e+=r,i=n+r.length}return{line:e,end:i}}skipGapsTo(t,e,i){for(;;){let s=this.ranges[this.rangeIndex].to,n=t+e;if(i>0?s>n:s>=n)break;e+=this.ranges[++this.rangeIndex].from-s}return e}emitToken(t,e,i,s,n){if(this.ranges.length>1){e+=n=this.skipGapsTo(e,n,1);let t=this.chunk.length;i+=n=this.skipGapsTo(i,n,-1),s+=this.chunk.length-t}return this.chunk.push(t,e,i,s),n}parseLine(t){let{line:e,end:i}=this.nextLine(),s=0,{streamParser:n}=this.lang,r=new oh(e,t?t.state.tabSize:4,t?no(t.state):2);if(r.eol())n.blankLine(this.state,r.indentUnit);else for(;!r.eol();){let t=fh(n.token,r,this.state);t&&(s=this.emitToken(wh(t),this.parsedPos+r.start,this.parsedPos+r.pos,4,s))}this.parsedPos=i,this.parsedPos<this.to&&this.parsedPos++}finishChunk(){let t=a.build({buffer:this.chunk,start:this.chunkStart,length:this.parsedPos-this.chunkStart,nodeSet:gh,topID:0,maxBufferLength:2048,reused:this.chunkReused});t=new a(t.type,t.children,t.positions,t.length,[[this.lang.stateAfter,this.lang.streamParser.copyState(this.state)]]),this.chunks.push(t),this.chunkPos.push(this.chunkStart-this.ranges[0].from),this.chunk=[],this.chunkReused=void 0,this.chunkStart=this.parsedPos}finish(){return new a(this.lang.topNode,this.chunks,this.chunkPos,this.parsedPos-this.ranges[0].from).balance()}}function fh(t,e,i){e.start=e.pos;for(let s=0;s<10;s++){let s=t(e,i);if(e.pos>e.start)return s}throw new Error("Stream parser failed to advance stream.")}const dh=Object.create(null),ph=[o.none],gh=new h(ph),mh=[];function wh(t){return t?dh[t]||(dh[t]=function(t){let e=null;for(let i of t.split(".")){let t=nh[i];t?"function"==typeof t?e?e=t(e):vh(i,`Modifier ${i} used at start of tag`):e?vh(i,`Tag ${i} used as modifier`):e=t:vh(i,`Unknown highlighting tag ${i}`)}if(!e)return 0;let i=t.replace(/ /g,"_"),s=o.define({id:ph.length,name:i,props:[To({[i]:e})]});return ph.push(s),s.id}(t)):0}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"]])dh[t]=wh(e);function vh(t,e){mh.indexOf(t)>-1||(mh.push(t),console.warn(e))}const yh="undefined"!=typeof navigator&&!/Edge\/(\d+)/.exec(navigator.userAgent)&&/Apple Computer/.test(navigator.vendor)&&(/Mobile\/\w+/.test(navigator.userAgent)||navigator.maxTouchPoints>2);class bh{constructor(t,e,i){this.facet=e,this.createTooltipView=i,this.input=t.state.facet(e),this.tooltips=this.input.filter((t=>t)),this.tooltipViews=this.tooltips.map(i)}update(t){let e=t.state.facet(this.facet),i=e.filter((t=>t));if(e===this.input){for(let e of this.tooltipViews)e.update&&e.update(t);return{shouldMeasure:!1}}let s=[];for(let e=0;e<i.length;e++){let n=i[e],r=-1;if(n){for(let t=0;t<this.tooltips.length;t++){let e=this.tooltips[t];e&&e.create==n.create&&(r=t)}if(r<0)s[e]=this.createTooltipView(n);else{let i=s[e]=this.tooltipViews[r];i.update&&i.update(t)}}}for(let t of this.tooltipViews)s.indexOf(t)<0&&t.dom.remove();return this.input=e,this.tooltips=i,this.tooltipViews=s,{shouldMeasure:!0}}}function xh(t={}){return t.position?kh.of(t.position):[]}const kh=Mt.define({combine:t=>yh?"absolute":t.length?t[0]:"fixed"}),Sh=as.fromClass(class{constructor(t){this.view=t,this.inView=!0,this.position=t.state.facet(kh),this.measureReq={read:this.readMeasure.bind(this),write:this.writeMeasure.bind(this),key:this},this.manager=new bh(t,Ch,(t=>this.createTooltip(t)))}update(t){let{shouldMeasure:e}=this.manager.update(t),i=t.state.facet(kh);if(i!=this.position){this.position=i;for(let t of this.manager.tooltipViews)t.dom.style.position=i;e=!0}e&&this.maybeMeasure()}createTooltip(t){let e=t.create(this.view);return e.dom.classList.add("cm-tooltip"),e.dom.style.position=this.position,e.dom.style.top="-10000px",this.view.dom.appendChild(e.dom),e.mount&&e.mount(this.view),e}destroy(){for(let{dom:t}of this.manager.tooltipViews)t.remove()}readMeasure(){return{editor:this.view.dom.getBoundingClientRect(),pos:this.manager.tooltips.map((t=>this.view.coordsAtPos(t.pos))),size:this.manager.tooltipViews.map((({dom:t})=>t.getBoundingClientRect())),innerWidth:window.innerWidth,innerHeight:window.innerHeight}}writeMeasure(t){let{editor:e}=t,i=[];for(let s=0;s<this.manager.tooltips.length;s++){let n=this.manager.tooltips[s],r=this.manager.tooltipViews[s],{dom:o}=r,h=t.pos[s],l=t.size[s];if(!h||h.bottom<=e.top||h.top>=e.bottom||h.right<=e.left||h.left>=e.right){o.style.top="-10000px";continue}let a=l.right-l.left,c=l.bottom-l.top,u=this.view.textDirection==Ss.LTR?Math.min(h.left,t.innerWidth-a):Math.max(0,h.left-a),f=!!n.above;!n.strictSide&&(f?h.top-(l.bottom-l.top)<0:h.bottom+(l.bottom-l.top)>t.innerHeight)&&(f=!f);let d=f?h.top-c:h.bottom,p=u+a;for(let t of i)t.left<p&&t.right>u&&t.top<d+c&&t.bottom>d&&(d=f?t.top-c:t.bottom);"absolute"==this.position?(o.style.top=d-e.top+"px",o.style.left=u-e.left+"px"):(o.style.top=d+"px",o.style.left=u+"px"),i.push({left:u,top:d,right:p,bottom:d+c}),o.classList.toggle("cm-tooltip-above",f),o.classList.toggle("cm-tooltip-below",!f),r.positioned&&r.positioned()}}maybeMeasure(){if(this.manager.tooltips.length&&(this.view.inView&&this.view.requestMeasure(this.measureReq),this.inView!=this.view.inView&&(this.inView=this.view.inView,!this.inView)))for(let t of this.manager.tooltipViews)t.dom.style.top="-10000px"}},{eventHandlers:{scroll(){this.maybeMeasure()}}}),Ah=tr.baseTheme({".cm-tooltip":{zIndex:100},"&light .cm-tooltip":{border:"1px solid #ddd",backgroundColor:"#f5f5f5"},"&light .cm-tooltip-section:not(:first-child)":{borderTop:"1px solid #ddd"},"&dark .cm-tooltip":{backgroundColor:"#333338",color:"white"}}),Ch=Mt.define({enables:[Sh,Ah]});class Mh{constructor(t,e,i){this.state=t,this.pos=e,this.explicit=i,this.abortListeners=[]}tokenBefore(t){let e=_r(this.state).resolveInner(this.pos,-1);for(;e&&t.indexOf(e.name)<0;)e=e.parent;return e?{from:e.from,to:this.pos,text:this.state.sliceDoc(e.from,this.pos),type:e.type}:null}matchBefore(t){let e=this.state.doc.lineAt(this.pos),i=Math.max(e.from,this.pos-250),s=e.text.slice(i-e.from,this.pos-e.from),n=s.search(Rh(t,!1));return n<0?null:{from:i+n,to:this.pos,text:s.slice(n)}}get aborted(){return null==this.abortListeners}addEventListener(t,e){"abort"==t&&this.abortListeners&&this.abortListeners.push(e)}}function Dh(t){let e=Object.keys(t).join(""),i=/\w/.test(e);return i&&(e=e.replace(/\w/g,"")),`[${i?"\\w":""}${e.replace(/[^\w\s]/g,"\\$&")}]`}function Oh(t){let e=t.map((t=>"string"==typeof t?{label:t}:t)),[i,s]=e.every((t=>/^\w+$/.test(t.label)))?[/\w*$/,/\w+$/]:function(t){let e=Object.create(null),i=Object.create(null);for(let{label:s}of t){e[s[0]]=!0;for(let t=1;t<s.length;t++)i[s[t]]=!0}let s=Dh(e)+Dh(i)+"*$";return[new RegExp("^"+s),new RegExp(s)]}(e);return t=>{let n=t.matchBefore(s);return n||t.explicit?{from:n?n.from:t.pos,options:e,span:i}:null}}function Th(t,e){return i=>{for(let e=_r(i.state).resolveInner(i.pos,-1);e;e=e.parent)if(t.indexOf(e.name)>-1)return null;return e(i)}}class Ph{constructor(t,e,i){this.completion=t,this.source=e,this.match=i}}function Eh(t){return t.selection.main.head}function Rh(t,e){var i;let{source:s}=t,n=e&&"^"!=s[0],r="$"!=s[s.length-1];return n||r?new RegExp(`${n?"^":""}(?:${s})${r?"$":""}`,null!==(i=t.flags)&&void 0!==i?i:t.ignoreCase?"i":""):t}function Lh(t,e){let i=e.completion.apply||e.completion.label,s=e.source;"string"==typeof i?t.dispatch({changes:{from:s.from,to:s.to,insert:i},selection:{anchor:s.from+i.length},userEvent:"input.complete"}):i(t,e.completion,s.from,s.to)}const Nh=new WeakMap;function Ih(t){if(!Array.isArray(t))return t;let e=Nh.get(t);return e||Nh.set(t,e=Oh(t)),e}class Bh{constructor(t){this.pattern=t,this.chars=[],this.folded=[],this.any=[],this.precise=[],this.byWord=[];for(let e=0;e<t.length;){let i=Q(t,e),s=tt(i);this.chars.push(i);let n=t.slice(e,e+s),r=n.toUpperCase();this.folded.push(Q(r==n?n.toLowerCase():r,0)),e+=s}this.astral=t.length!=this.chars.length}match(t){if(0==this.pattern.length)return[0];if(t.length<this.pattern.length)return null;let{chars:e,folded:i,any:s,precise:n,byWord:r}=this;if(1==e.length){let s=Q(t,0);return s==e[0]?[0,0,tt(s)]:s==i[0]?[-200,0,tt(s)]:null}let o=t.indexOf(this.pattern);if(0==o)return[0,0,this.pattern.length];let h=e.length,l=0;if(o<0){for(let n=0,r=Math.min(t.length,200);n<r&&l<h;){let r=Q(t,n);r!=e[l]&&r!=i[l]||(s[l++]=n),n+=tt(r)}if(l<h)return null}let a=0,c=0,u=!1,f=0,d=-1,p=-1,g=/[a-z]/.test(t);for(let s=0,l=Math.min(t.length,200),m=0;s<l&&c<h;){let l=Q(t,s);o<0&&(a<h&&l==e[a]&&(n[a++]=s),f<h&&(l==e[f]||l==i[f]?(0==f&&(d=s),p=s,f++):f=0));let w,v=l<255?l>=48&&l<=57||l>=97&&l<=122?2:l>=65&&l<=90?1:0:(w=Z(l))!=w.toLowerCase()?1:w!=w.toUpperCase()?2:0;(1==v&&g||0==m&&0!=v)&&(e[c]==l||i[c]==l&&(u=!0))&&(r[c++]=s),m=v,s+=tt(l)}return c==h&&0==r[0]?this.result((u?-200:0)-100,r,t):f==h&&0==d?[-200,0,p]:o>-1?[-700,o,o+this.pattern.length]:f==h?[-900,d,p]:c==h?this.result((u?-200:0)-100-700,r,t):2==e.length?null:this.result((s[0]?-700:0)-200-1100,s,t)}result(t,e,i){let s=[t],n=1;for(let t of e){let e=t+(this.astral?tt(Q(i,t)):1);n>1&&s[n-1]==t?s[n-1]=e:(s[n++]=t,s[n++]=e)}return s}}const Vh=Mt.define({combine:t=>de(t,{activateOnTyping:!0,override:null,maxRenderedOptions:100,defaultKeymap:!0,optionClass:()=>"",icons:!0,addToOptions:[]},{defaultKeymap:(t,e)=>t&&e,icons:(t,e)=>t&&e,optionClass:(t,e)=>i=>function(t,e){return t?e?t+" "+e:t:e}(t(i),e(i)),addToOptions:(t,e)=>t.concat(e)})});const zh=tr.baseTheme({".cm-tooltip.cm-tooltip-autocomplete":{"& > ul":{fontFamily:"monospace",whiteSpace:"nowrap",overflow:"auto",maxWidth_fallback:"700px",maxWidth:"min(700px, 95vw)",maxHeight:"10em",listStyle:"none",margin:0,padding:0,"& > li":{cursor:"pointer",padding:"1px 1em 1px 3px",lineHeight:1.2},"& > li[aria-selected]":{background_fallback:"#bdf",backgroundColor:"Highlight",color_fallback:"white",color:"HighlightText"}}},".cm-completionListIncompleteTop:before, .cm-completionListIncompleteBottom:after":{content:'"···"',opacity:.5,display:"block",textAlign:"center"},".cm-tooltip.cm-completionInfo":{position:"absolute",padding:"3px 9px",width:"max-content",maxWidth:"300px"},".cm-completionInfo.cm-completionInfo-left":{right:"100%"},".cm-completionInfo.cm-completionInfo-right":{left:"100%"},"&light .cm-snippetField":{backgroundColor:"#00000022"},"&dark .cm-snippetField":{backgroundColor:"#ffffff22"},".cm-snippetFieldPosition":{verticalAlign:"text-top",width:0,height:"1.15em",margin:"0 -0.7px -.7em",borderLeft:"1.4px dotted #888"},".cm-completionMatchedText":{textDecoration:"underline"},".cm-completionDetail":{marginLeft:"0.5em",fontStyle:"italic"},".cm-completionIcon":{fontSize:"90%",width:".8em",display:"inline-block",textAlign:"center",paddingRight:".6em",opacity:"0.6"},".cm-completionIcon-function, .cm-completionIcon-method":{"&:after":{content:"'ƒ'"}},".cm-completionIcon-class":{"&:after":{content:"'○'"}},".cm-completionIcon-interface":{"&:after":{content:"'◌'"}},".cm-completionIcon-variable":{"&:after":{content:"'𝑥'"}},".cm-completionIcon-constant":{"&:after":{content:"'𝐶'"}},".cm-completionIcon-type":{"&:after":{content:"'𝑡'"}},".cm-completionIcon-enum":{"&:after":{content:"'∪'"}},".cm-completionIcon-property":{"&:after":{content:"'□'"}},".cm-completionIcon-keyword":{"&:after":{content:"'🔑︎'"}},".cm-completionIcon-namespace":{"&:after":{content:"'▢'"}},".cm-completionIcon-text":{"&:after":{content:"'abc'",fontSize:"50%",verticalAlign:"middle"}}});function Fh(t,e,i){if(t<=i)return{from:0,to:t};if(e<=t>>1){let t=Math.floor(e/i);return{from:t*i,to:(t+1)*i}}let s=Math.floor((t-e)/i);return{from:t-(s+1)*i,to:t-s*i}}class Hh{constructor(t,e){this.view=t,this.stateField=e,this.info=null,this.placeInfo={read:()=>this.measureInfo(),write:t=>this.positionInfo(t),key:this};let i=t.state.field(e),{options:s,selected:n}=i.open,r=t.state.facet(Vh);this.optionContent=function(t){let e=t.addToOptions.slice();return t.icons&&e.push({render(t){let e=document.createElement("div");return e.classList.add("cm-completionIcon"),t.type&&e.classList.add(...t.type.split(/\s+/g).map((t=>"cm-completionIcon-"+t))),e.setAttribute("aria-hidden","true"),e},position:20}),e.push({render(t,e,i){let s=document.createElement("span");s.className="cm-completionLabel";let{label:n}=t,r=0;for(let t=1;t<i.length;){let e=i[t++],o=i[t++];e>r&&s.appendChild(document.createTextNode(n.slice(r,e)));let h=s.appendChild(document.createElement("span"));h.appendChild(document.createTextNode(n.slice(e,o))),h.className="cm-completionMatchedText",r=o}return r<n.length&&s.appendChild(document.createTextNode(n.slice(r))),s},position:50},{render(t){if(!t.detail)return null;let e=document.createElement("span");return e.className="cm-completionDetail",e.textContent=t.detail,e},position:80}),e.sort(((t,e)=>t.position-e.position)).map((t=>t.render))}(r),this.optionClass=r.optionClass,this.range=Fh(s.length,n,r.maxRenderedOptions),this.dom=document.createElement("div"),this.dom.className="cm-tooltip-autocomplete",this.dom.addEventListener("mousedown",(e=>{for(let i,n=e.target;n&&n!=this.dom;n=n.parentNode)if("LI"==n.nodeName&&(i=/-(\d+)$/.exec(n.id))&&+i[1]<s.length)return Lh(t,s[+i[1]]),void e.preventDefault()})),this.list=this.dom.appendChild(this.createListBox(s,i.id,this.range)),this.list.addEventListener("scroll",(()=>{this.info&&this.view.requestMeasure(this.placeInfo)}))}mount(){this.updateSel()}update(t){t.state.field(this.stateField)!=t.startState.field(this.stateField)&&this.updateSel()}positioned(){this.info&&this.view.requestMeasure(this.placeInfo)}updateSel(){let t=this.view.state.field(this.stateField),e=t.open;if((e.selected<this.range.from||e.selected>=this.range.to)&&(this.range=Fh(e.options.length,e.selected,this.view.state.facet(Vh).maxRenderedOptions),this.list.remove(),this.list=this.dom.appendChild(this.createListBox(e.options,t.id,this.range)),this.list.addEventListener("scroll",(()=>{this.info&&this.view.requestMeasure(this.placeInfo)}))),this.updateSelectedOption(e.selected)){this.info&&(this.info.remove(),this.info=null);let t=e.options[e.selected];t.completion.info&&(this.info=this.dom.appendChild(function(t,e){let i=document.createElement("div");i.className="cm-tooltip cm-completionInfo";let{info:s}=t.completion;if("string"==typeof s)i.textContent=s;else{let n=s(t.completion);n.then?n.then((t=>i.appendChild(t)),(t=>ss(e.state,t,"completion info"))):i.appendChild(n)}return i}(t,this.view)),this.view.requestMeasure(this.placeInfo))}}updateSelectedOption(t){let e=null;for(let i=this.list.firstChild,s=this.range.from;i;i=i.nextSibling,s++)s==t?i.hasAttribute("aria-selected")||(i.setAttribute("aria-selected","true"),e=i):i.hasAttribute("aria-selected")&&i.removeAttribute("aria-selected");return e&&function(t,e){let i=t.getBoundingClientRect(),s=e.getBoundingClientRect();s.top<i.top?t.scrollTop-=i.top-s.top:s.bottom>i.bottom&&(t.scrollTop+=s.bottom-i.bottom)}(this.list,e),e}measureInfo(){let t=this.dom.querySelector("[aria-selected]");if(!t)return null;let e=this.dom.getBoundingClientRect(),i=t.getBoundingClientRect().top-e.top;if(i<0||i>this.list.clientHeight-10)return null;let s=this.view.textDirection==Ss.RTL,n=e.left,r=innerWidth-e.right;return s&&n<Math.min(300,r)?s=!1:!s&&r<Math.min(300,n)&&(s=!0),{top:i,left:s}}positionInfo(t){this.info&&t&&(this.info.style.top=t.top+"px",this.info.classList.toggle("cm-completionInfo-left",t.left),this.info.classList.toggle("cm-completionInfo-right",!t.left))}createListBox(t,e,i){const s=document.createElement("ul");s.id=e,s.setAttribute("role","listbox");for(let n=i.from;n<i.to;n++){let{completion:i,match:r}=t[n];const o=s.appendChild(document.createElement("li"));o.id=e+"-"+n,o.setAttribute("role","option");let h=this.optionClass(i);h&&(o.className=h);for(let t of this.optionContent){let e=t(i,this.view.state,r);e&&o.appendChild(e)}}return i.from&&s.classList.add("cm-completionListIncompleteTop"),i.to<t.length&&s.classList.add("cm-completionListIncompleteBottom"),s}}function Wh(t){return 100*(t.boost||0)+(t.apply?10:0)+(t.info?5:0)+(t.type?1:0)}class qh{constructor(t,e,i,s,n){this.options=t,this.attrs=e,this.tooltip=i,this.timestamp=s,this.selected=n}setSelected(t,e){return t==this.selected||t>=this.options.length?this:new qh(this.options,$h(e,t),this.tooltip,this.timestamp,t)}static build(t,e,i,s){let n=function(t,e){let i=[],s=0;for(let n of t)if(n.hasResult())if(!1===n.result.filter)for(let t of n.result.options)i.push(new Ph(t,n,[1e9-s++]));else{let t,s=new Bh(e.sliceDoc(n.from,n.to));for(let e of n.result.options)(t=s.match(e.label))&&(null!=e.boost&&(t[0]+=e.boost),i.push(new Ph(e,n,t)))}i.sort(Gh);let n=[],r=null;for(let t of i.sort(Gh)){if(300==n.length)break;r&&r.label==t.completion.label&&r.detail==t.completion.detail?Wh(t.completion)>Wh(r)&&(n[n.length-1]=t):n.push(t),r=t.completion}return n}(t,e);if(!n.length)return null;let r=0;if(s&&s.selected){let t=s.options[s.selected].completion;for(let e=0;e<n.length&&!r;e++)n[e].completion==t&&(r=e)}return new qh(n,$h(i,r),{pos:t.reduce(((t,e)=>e.hasResult()?Math.min(t,e.from):t),1e8),create:(o=el,t=>new Hh(t,o))},s?s.timestamp:Date.now(),r);var o}map(t){return new qh(this.options,this.attrs,Object.assign(Object.assign({},this.tooltip),{pos:t.mapPos(this.tooltip.pos)}),this.timestamp,this.selected)}}class jh{constructor(t,e,i){this.active=t,this.id=e,this.open=i}static start(){return new jh(Uh,"cm-ac-"+Math.floor(2e6*Math.random()).toString(36),null)}update(t){let{state:e}=t,i=e.facet(Vh),s=(i.override||e.languageDataAt("autocomplete",Eh(e)).map(Ih)).map((e=>(this.active.find((t=>t.source==e))||new Jh(e,this.active.some((t=>0!=t.state))?1:0)).update(t,i)));s.length==this.active.length&&s.every(((t,e)=>t==this.active[e]))&&(s=this.active);let n=t.selection||s.some((e=>e.hasResult()&&t.changes.touchesRange(e.from,e.to)))||!function(t,e){if(t==e)return!0;for(let i=0,s=0;;){for(;i<t.length&&!t[i].hasResult;)i++;for(;s<e.length&&!e[s].hasResult;)s++;let n=i==t.length,r=s==e.length;if(n||r)return n==r;if(t[i++].result!=e[s++].result)return!1}}(s,this.active)?qh.build(s,e,this.id,this.open):this.open&&t.docChanged?this.open.map(t.changes):this.open;!n&&s.every((t=>1!=t.state))&&s.some((t=>t.hasResult()))&&(s=s.map((t=>t.hasResult()?new Jh(t.source,0):t)));for(let e of t.effects)e.is(tl)&&(n=n&&n.setSelected(e.value,this.id));return s==this.active&&n==this.open?this:new jh(s,this.id,n)}get tooltip(){return this.open?this.open.tooltip:null}get attrs(){return this.open?this.open.attrs:_h}}const _h={"aria-autocomplete":"list","aria-expanded":"false"};function $h(t,e){return{"aria-autocomplete":"list","aria-expanded":"true","aria-activedescendant":t+"-"+e,"aria-controls":t}}const Uh=[];function Gh(t,e){let i=e.match[0]-t.match[0];return i||t.completion.label.localeCompare(e.completion.label)}function Kh(t){return t.isUserEvent("input.type")?"input":t.isUserEvent("delete.backward")?"delete":null}class Jh{constructor(t,e,i=-1){this.source=t,this.state=e,this.explicitPos=i}hasResult(){return!1}update(t,e){let i=Kh(t),s=this;i?s=s.handleUserEvent(t,i,e):t.docChanged?s=s.handleChange(t):t.selection&&0!=s.state&&(s=new Jh(s.source,0));for(let e of t.effects)if(e.is(Yh))s=new Jh(s.source,1,e.value?Eh(t.state):-1);else if(e.is(Qh))s=new Jh(s.source,0);else if(e.is(Zh))for(let t of e.value)t.source==s.source&&(s=t);return s}handleUserEvent(t,e,i){return"delete"!=e&&i.activateOnTyping?new Jh(this.source,1):this.map(t.changes)}handleChange(t){return t.changes.touchesRange(Eh(t.startState))?new Jh(this.source,0):this.map(t.changes)}map(t){return t.empty||this.explicitPos<0?this:new Jh(this.source,this.state,t.mapPos(this.explicitPos))}}class Xh extends Jh{constructor(t,e,i,s,n,r){super(t,2,e),this.result=i,this.from=s,this.to=n,this.span=r}hasResult(){return!0}handleUserEvent(t,e,i){let s=t.changes.mapPos(this.from),n=t.changes.mapPos(this.to,1),r=Eh(t.state);if((this.explicitPos>-1?r<s:r<=s)||r>n)return new Jh(this.source,"input"==e&&i.activateOnTyping?1:0);let o=this.explicitPos<0?-1:t.changes.mapPos(this.explicitPos);return this.span&&(s==n||this.span.test(t.state.sliceDoc(s,n)))?new Xh(this.source,o,this.result,s,n,this.span):new Jh(this.source,1,o)}handleChange(t){return t.changes.touchesRange(this.from,this.to)?new Jh(this.source,0):this.map(t.changes)}map(t){return t.empty?this:new Xh(this.source,this.explicitPos<0?-1:t.mapPos(this.explicitPos),this.result,t.mapPos(this.from),t.mapPos(this.to,1),this.span)}}const Yh=te.define(),Qh=te.define(),Zh=te.define({map:(t,e)=>t.map((t=>t.map(e)))}),tl=te.define(),el=Rt.define({create:()=>jh.start(),update:(t,e)=>t.update(e),provide:t=>[Ch.from(t,(t=>t.tooltip)),tr.contentAttributes.from(t,(t=>t.attrs))]});function il(t,e="option"){return i=>{let s=i.state.field(el,!1);if(!s||!s.open||Date.now()-s.open.timestamp<75)return!1;let n,r=1;"page"==e&&(n=i.dom.querySelector(".cm-tooltip-autocomplete"))&&(r=Math.max(2,Math.floor(n.offsetHeight/n.firstChild.offsetHeight)));let o=s.open.selected+r*(t?1:-1),{length:h}=s.open.options;return o<0?o="page"==e?0:h-1:o>=h&&(o="page"==e?h-1:0),i.dispatch({effects:tl.of(o)}),!0}}const sl=t=>{let e=t.state.field(el,!1);return!(!e||!e.open||Date.now()-e.open.timestamp<75)&&(Lh(t,e.open.options[e.open.selected]),!0)};class nl{constructor(t,e){this.active=t,this.context=e,this.time=Date.now(),this.updates=[],this.done=void 0}}const rl=as.fromClass(class{constructor(t){this.view=t,this.debounceUpdate=-1,this.running=[],this.debounceAccept=-1,this.composing=0;for(let e of t.state.field(el).active)1==e.state&&this.startQuery(e)}update(t){let e=t.state.field(el);if(!t.selectionSet&&!t.docChanged&&t.startState.field(el)==e)return;let i=t.transactions.some((t=>(t.selection||t.docChanged)&&!Kh(t)));for(let e=0;e<this.running.length;e++){let s=this.running[e];if(i||s.updates.length+t.transactions.length>50&&s.time-Date.now()>1e3){for(let t of s.context.abortListeners)try{t()}catch(t){ss(this.view.state,t)}s.context.abortListeners=null,this.running.splice(e--,1)}else s.updates.push(...t.transactions)}if(this.debounceUpdate>-1&&clearTimeout(this.debounceUpdate),this.debounceUpdate=e.active.some((t=>1==t.state&&!this.running.some((e=>e.active.source==t.source))))?setTimeout((()=>this.startUpdate()),50):-1,0!=this.composing)for(let e of t.transactions)"input"==Kh(e)?this.composing=2:2==this.composing&&e.selection&&(this.composing=3)}startUpdate(){this.debounceUpdate=-1;let{state:t}=this.view,e=t.field(el);for(let t of e.active)1!=t.state||this.running.some((e=>e.active.source==t.source))||this.startQuery(t)}startQuery(t){let{state:e}=this.view,i=Eh(e),s=new Mh(e,i,t.explicitPos==i),n=new nl(t,s);this.running.push(n),Promise.resolve(t.source(s)).then((t=>{n.context.aborted||(n.done=t||null,this.scheduleAccept())}),(t=>{this.view.dispatch({effects:Qh.of(null)}),ss(this.view.state,t)}))}scheduleAccept(){this.running.every((t=>void 0!==t.done))?this.accept():this.debounceAccept<0&&(this.debounceAccept=setTimeout((()=>this.accept()),50))}accept(){var t;this.debounceAccept>-1&&clearTimeout(this.debounceAccept),this.debounceAccept=-1;let e=[],i=this.view.state.facet(Vh);for(let s=0;s<this.running.length;s++){let n=this.running[s];if(void 0===n.done)continue;if(this.running.splice(s--,1),n.done){let s=new Xh(n.active.source,n.active.explicitPos,n.done,n.done.from,null!==(t=n.done.to)&&void 0!==t?t:Eh(n.updates.length?n.updates[0].startState:this.view.state),n.done.span&&!1!==n.done.filter?Rh(n.done.span,!0):null);for(let t of n.updates)s=s.update(t,i);if(s.hasResult()){e.push(s);continue}}let r=this.view.state.field(el).active.find((t=>t.source==n.active.source));if(r&&1==r.state)if(null==n.done){let t=new Jh(n.active.source,0);for(let e of n.updates)t=t.update(e,i);1!=t.state&&e.push(t)}else this.startQuery(r)}e.length&&this.view.dispatch({effects:Zh.of(e)})}},{eventHandlers:{compositionstart(){this.composing=1},compositionend(){3==this.composing&&setTimeout((()=>this.view.dispatch({effects:Yh.of(!1)})),20),this.composing=0}}});class ol{constructor(t,e,i,s){this.field=t,this.line=e,this.from=i,this.to=s}}class hl{constructor(t,e,i){this.field=t,this.from=e,this.to=i}map(t){return new hl(this.field,t.mapPos(this.from,-1),t.mapPos(this.to,1))}}class ll{constructor(t,e){this.lines=t,this.fieldPositions=e}instantiate(t,e){let i=[],s=[e],n=t.doc.lineAt(e),r=/^\s*/.exec(n.text)[0];for(let n of this.lines){if(i.length){let i=r,o=/^\t*/.exec(n)[0].length;for(let e=0;e<o;e++)i+=t.facet(so);s.push(e+i.length-o),n=i+n.slice(o)}i.push(n),e+=n.length+1}let o=this.fieldPositions.map((t=>new hl(t.field,s[t.line]+t.from,s[t.line]+t.to)));return{text:i,ranges:o}}static parse(t){let e,i=[],s=[],n=[];for(let r of t.split(/\r\n?|\n/)){for(;e=/[#$]\{(?:(\d+)(?::([^}]*))?|([^}]*))\}/.exec(r);){let t=e[1]?+e[1]:null,o=e[2]||e[3],h=-1;for(let e=0;e<i.length;e++)(null!=t?i[e].seq==t:o&&i[e].name==o)&&(h=e);if(h<0){let e=0;for(;e<i.length&&(null==t||null!=i[e].seq&&i[e].seq<t);)e++;i.splice(e,0,{seq:t,name:o||null}),h=e;for(let t of n)t.field>=h&&t.field++}n.push(new ol(h,s.length,e.index,e.index+o.length)),r=r.slice(0,e.index)+o+r.slice(e.index+e[0].length)}s.push(r)}return new ll(s,n)}}let al=zi.widget({widget:new class extends Bi{toDOM(){let t=document.createElement("span");return t.className="cm-snippetFieldPosition",t}ignoreEvent(){return!1}}}),cl=zi.mark({class:"cm-snippetField"});class ul{constructor(t,e){this.ranges=t,this.active=e,this.deco=zi.set(t.map((t=>(t.from==t.to?al:cl).range(t.from,t.to))))}map(t){return new ul(this.ranges.map((e=>e.map(t))),this.active)}selectionInsideField(t){return t.ranges.every((t=>this.ranges.some((e=>e.field==this.active&&e.from<=t.from&&e.to>=t.to))))}}const fl=te.define({map:(t,e)=>t&&t.map(e)}),dl=te.define(),pl=Rt.define({create:()=>null,update(t,e){for(let i of e.effects){if(i.is(fl))return i.value;if(i.is(dl)&&t)return new ul(t.ranges,i.value)}return t&&e.docChanged&&(t=t.map(e.changes)),t&&e.selection&&!t.selectionInsideField(e.selection)&&(t=null),t},provide:t=>tr.decorations.from(t,(t=>t?t.deco:zi.none))});function gl(t,e){return kt.create(t.filter((t=>t.field==e)).map((t=>kt.range(t.from,t.to))))}function ml(t){let e=ll.parse(t);return(t,i,s,n)=>{let{text:r,ranges:o}=e.instantiate(t.state,s),h={changes:{from:s,to:n,insert:it.of(r)}};if(o.length&&(h.selection=gl(o,0)),o.length>1){let e=new ul(o,0),i=h.effects=[fl.of(e)];void 0===t.state.field(pl,!1)&&i.push(te.appendConfig.of([pl.init((()=>e)),bl,kl,zh]))}t.dispatch(t.state.update(h))}}function wl(t){return({state:e,dispatch:i})=>{let s=e.field(pl,!1);if(!s||t<0&&0==s.active)return!1;let n=s.active+t,r=t>0&&!s.ranges.some((e=>e.field==n+t));return i(e.update({selection:gl(s.ranges,n),effects:fl.of(r?null:new ul(s.ranges,n))})),!0}}const vl=[{key:"Tab",run:wl(1),shift:wl(-1)},{key:"Escape",run:({state:t,dispatch:e})=>!!t.field(pl,!1)&&(e(t.update({effects:fl.of(null)})),!0)}],yl=Mt.define({combine:t=>t.length?t[0]:vl}),bl=Vt.override(cr.compute([yl],(t=>t.facet(yl))));function xl(t,e){return Object.assign(Object.assign({},e),{apply:ml(t)})}const kl=tr.domEventHandlers({mousedown(t,e){let i,s=e.state.field(pl,!1);if(!s||null==(i=e.posAtCoords({x:t.clientX,y:t.clientY})))return!1;let n=s.ranges.find((t=>t.from<=i&&t.to>=i));return!(!n||n.field==s.active)&&(e.dispatch({selection:gl(s.ranges,n.field),effects:fl.of(s.ranges.some((t=>t.field>n.field))?new ul(s.ranges,n.field):null)}),!0)}});function Sl(t,e){return new RegExp(e(t.source),t.unicode?"u":"")}const Al=Object.create(null);function Cl(t,e,i,s,n){for(let r=t.iterLines(),o=0;!r.next().done;){let t,{value:h}=r;for(e.lastIndex=0;t=e.exec(h);)if(!s[t[0]]&&o+t.index!=n&&(i.push({type:"text",label:t[0]}),s[t[0]]=!0,i.length>=2e3))return;o+=h.length+1}}function Ml(t,e,i,s,n){let r=t.length>=1e3,o=r&&e.get(t);if(o)return o;let h=[],l=Object.create(null);if(t.children){let r=0;for(let o of t.children){if(o.length>=1e3)for(let t of Ml(o,e,i,s-r,n-r))l[t.label]||(l[t.label]=!0,h.push(t));else Cl(o,i,h,l,n-r);r+=o.length+1}}else Cl(t,i,h,l,n);return r&&h.length<2e3&&e.set(t,h),h}const Dl=t=>{let e=t.state.languageDataAt("wordChars",t.pos).join(""),i=function(t){let e=t.replace(/[\\[.+*?(){|^$]/g,"\\$&");try{return new RegExp(`[\\p{Alphabetic}\\p{Number}_${e}]+`,"ug")}catch(t){return new RegExp(`[w${e}]`,"g")}}(e),s=t.matchBefore(Sl(i,(t=>t+"$")));if(!s&&!t.explicit)return null;let n=s?s.from:t.pos,r=Ml(t.state.doc,function(t){return Al[t]||(Al[t]=new WeakMap)}(e),i,5e4,n);return{from:n,options:r,span:Sl(i,(t=>"^"+t))}};function Ol(t={}){return[el,Vh.of(t),rl,Pl,zh]}const Tl=[{key:"Ctrl-Space",run:t=>!!t.state.field(el,!1)&&(t.dispatch({effects:Yh.of(!0)}),!0)},{key:"Escape",run:t=>{let e=t.state.field(el,!1);return!(!e||!e.active.some((t=>0!=t.state)))&&(t.dispatch({effects:Qh.of(null)}),!0)}},{key:"ArrowDown",run:il(!0)},{key:"ArrowUp",run:il(!1)},{key:"PageDown",run:il(!0,"page")},{key:"PageUp",run:il(!1,"page")},{key:"Enter",run:sl}],Pl=Vt.override(cr.computeN([Vh],(t=>t.facet(Vh).defaultKeymap?[Tl]:[])));function El(t){var e;let i=null===(e=t.field(el,!1))||void 0===e?void 0:e.open;return i?i.options.map((t=>t.completion)):[]}const Rl={brackets:["(","[","{","'",'"'],before:")]}'\":;>"},Ll=te.define({map(t,e){let i=e.mapPos(t,-1,ft.TrackAfter);return null==i?void 0:i}}),Nl=te.define({map:(t,e)=>e.mapPos(t)}),Il=new class extends pe{};Il.startSide=1,Il.endSide=-1;const Bl=Rt.define({create:()=>ve.empty,update(t,e){if(e.selection){let i=e.state.doc.lineAt(e.selection.main.head).from,s=e.startState.doc.lineAt(e.startState.selection.main.head).from;i!=e.changes.mapPos(s,-1)&&(t=ve.empty)}t=t.map(e.changes);for(let i of e.effects)i.is(Ll)?t=t.update({add:[Il.range(i.value,i.value+1)]}):i.is(Nl)&&(t=t.update({filter:t=>t!=i.value}));return t}});function Vl(){return[tr.inputHandler.of(Hl),Bl]}function zl(t){for(let e=0;e<"()[]{}<>".length;e+=2)if("()[]{}<>".charCodeAt(e)==t)return"()[]{}<>".charAt(e+1);return Z(t<128?t:t+1)}function Fl(t,e){return t.languageDataAt("closeBrackets",e)[0]||Rl}function Hl(t,e,i,s){if(t.composing)return!1;let n=t.state.selection.main;if(s.length>2||2==s.length&&1==tt(Q(s,0))||e!=n.from||i!=n.to)return!1;let r=function(t,e){let i=Fl(t,t.selection.main.head),s=i.brackets||Rl.brackets;for(let n of s){let r=zl(Q(n,0));if(e==n)return r==n?Ul(t,n,s.indexOf(n+n+n)>-1):_l(t,n,r,i.before||Rl.before);if(e==r&&ql(t,t.selection.main.from))return $l(t,n,r)}return null}(t.state,s);return!!r&&(t.dispatch(r),!0)}const Wl=[{key:"Backspace",run:({state:t,dispatch:e})=>{let i=Fl(t,t.selection.main.head).brackets||Rl.brackets,s=null,n=t.changeByRange((e=>{if(e.empty){let s=function(t,e){let i=t.sliceString(e-2,e);return tt(Q(i,0))==i.length?i:i.slice(1)}(t.doc,e.head);for(let n of i)if(n==s&&jl(t.doc,e.head)==zl(Q(n,0)))return{changes:{from:e.head-n.length,to:e.head+n.length},range:kt.cursor(e.head-n.length),userEvent:"delete.backward"}}return{range:s=e}}));return s||e(t.update(n,{scrollIntoView:!0})),!s}}];function ql(t,e){let i=!1;return t.field(Bl).between(0,t.doc.length,(t=>{t==e&&(i=!0)})),i}function jl(t,e){let i=t.sliceString(e,e+2);return i.slice(0,tt(Q(i,0)))}function _l(t,e,i,s){let n=null,r=t.changeByRange((r=>{if(!r.empty)return{changes:[{insert:e,from:r.from},{insert:i,from:r.to}],effects:Ll.of(r.to+e.length),range:kt.range(r.anchor+e.length,r.head+e.length)};let o=jl(t.doc,r.head);return!o||/\s/.test(o)||s.indexOf(o)>-1?{changes:{insert:e+i,from:r.head},effects:Ll.of(r.head+e.length),range:kt.cursor(r.head+e.length)}:{range:n=r}}));return n?null:t.update(r,{scrollIntoView:!0,userEvent:"input.type"})}function $l(t,e,i){let s=null,n=t.selection.ranges.map((e=>e.empty&&jl(t.doc,e.head)==i?kt.cursor(e.head+i.length):s=e));return s?null:t.update({selection:kt.create(n,t.selection.mainIndex),scrollIntoView:!0,effects:t.selection.ranges.map((({from:t})=>Nl.of(t)))})}function Ul(t,e,i){let s=null,n=t.changeByRange((n=>{if(!n.empty)return{changes:[{insert:e,from:n.from},{insert:e,from:n.to}],effects:Ll.of(n.to+e.length),range:kt.range(n.anchor+e.length,n.head+e.length)};let r=n.head,o=jl(t.doc,r);if(o==e){if(Gl(t,r))return{changes:{insert:e+e,from:r},effects:Ll.of(r+e.length),range:kt.cursor(r+e.length)};if(ql(t,r)){let s=i&&t.sliceDoc(r,r+3*e.length)==e+e+e;return{range:kt.cursor(r+e.length*(s?3:1)),effects:Nl.of(r)}}}else{if(i&&t.sliceDoc(r-2*e.length,r)==e+e&&Gl(t,r-2*e.length))return{changes:{insert:e+e+e+e,from:r},effects:Ll.of(r+e.length),range:kt.cursor(r+e.length)};if(t.charCategorizer(r)(o)!=le.Word){let i=t.sliceDoc(r-1,r);if(i!=e&&t.charCategorizer(r)(i)!=le.Word)return{changes:{insert:e+e,from:r},effects:Ll.of(r+e.length),range:kt.cursor(r+e.length)}}}return{range:s=n}}));return s?null:t.update(n,{scrollIntoView:!0,userEvent:"input.type"})}function Gl(t,e){let i=_r(t).resolveInner(e+1);return i.parent&&i.from==e}const Kl=tr.baseTheme({".cm-matchingBracket":{backgroundColor:"#328c8252"},".cm-nonmatchingBracket":{backgroundColor:"#bb555544"}}),Jl=Mt.define({combine:t=>de(t,{afterCursor:!0,brackets:"()[]{}",maxScanDistance:1e4})}),Xl=zi.mark({class:"cm-matchingBracket"}),Yl=zi.mark({class:"cm-nonmatchingBracket"}),Ql=Rt.define({create:()=>zi.none,update(t,e){if(!e.docChanged&&!e.selection)return t;let i=[],s=e.state.facet(Jl);for(let t of e.state.selection.ranges){if(!t.empty)continue;let n=ia(e.state,t.head,-1,s)||t.head>0&&ia(e.state,t.head-1,1,s)||s.afterCursor&&(ia(e.state,t.head,1,s)||t.head<e.state.doc.length&&ia(e.state,t.head+1,-1,s));if(!n)continue;let r=n.matched?Xl:Yl;i.push(r.range(n.start.from,n.start.to)),n.end&&i.push(r.range(n.end.from,n.end.to))}return zi.set(i,!0)},provide:t=>tr.decorations.from(t)}),Zl=[Ql,Kl];function ta(t={}){return[Jl.of(t),Zl]}function ea(t,e,i){let n=t.prop(e<0?s.openedBy:s.closedBy);if(n)return n;if(1==t.name.length){let s=i.indexOf(t.name);if(s>-1&&s%2==(e<0?1:0))return[i[s+e]]}return null}function ia(t,e,i,s={}){let n=s.maxScanDistance||1e4,r=s.brackets||"()[]{}",o=_r(t),h=o.resolveInner(e,i);for(let s=h;s;s=s.parent){let n=ea(s.type,i,r);if(n&&s.from<s.to)return sa(t,e,i,s,n,r)}return function(t,e,i,s,n,r,o){let h=i<0?t.sliceDoc(e-1,e):t.sliceDoc(e,e+1),l=o.indexOf(h);if(l<0||l%2==0!=i>0)return null;let a={from:i<0?e-1:e,to:i>0?e+1:e},c=t.doc.iterRange(e,i>0?t.doc.length:0),u=0;for(let t=0;!c.next().done&&t<=r;){let r=c.value;i<0&&(t+=r.length);let h=e+t*i;for(let t=i>0?0:r.length-1,e=i>0?r.length:-1;t!=e;t+=i){let e=o.indexOf(r[t]);if(!(e<0||s.resolve(h+t,1).type!=n))if(e%2==0==i>0)u++;else{if(1==u)return{start:a,end:{from:h+t,to:h+t+1},matched:e>>1==l>>1};u--}}i>0&&(t+=r.length)}return c.done?{start:a,matched:!1}:null}(t,e,i,o,h.type,n,r)}function sa(t,e,i,s,n,r){let o=s.parent,h={from:s.from,to:s.to},l=0,a=null==o?void 0:o.cursor;if(a&&(i<0?a.childBefore(s.from):a.childAfter(s.to)))do{if(i<0?a.to<=s.from:a.from>=s.to){if(0==l&&n.indexOf(a.type.name)>-1&&a.from<a.to)return{start:h,end:{from:a.from,to:a.to},matched:!0};if(ea(a.type,i,r))l++;else if(ea(a.type,-i,r)&&(l--,0==l))return{start:h,end:a.from==a.to?void 0:{from:a.from,to:a.to},matched:!1}}}while(i<0?a.prevSibling():a.nextSibling());return{start:h,matched:!1}}function na(t,e){return kt.create(t.ranges.map(e),t.mainIndex)}function ra(t,e){return t.update({selection:e,scrollIntoView:!0,userEvent:"select"})}function oa({state:t,dispatch:e},i){let s=na(t.selection,i);return!s.eq(t.selection)&&(e(ra(t,s)),!0)}function ha(t,e){return kt.cursor(e?t.to:t.from)}function la(t,e){return oa(t,(i=>i.empty?t.moveByChar(i,e):ha(i,e)))}const aa=t=>la(t,t.textDirection!=Ss.LTR),ca=t=>la(t,t.textDirection==Ss.LTR);function ua(t,e){return oa(t,(i=>i.empty?t.moveByGroup(i,e):ha(i,e)))}function fa(t,e,i){let s=t.state.charCategorizer(e.from);return t.moveByChar(e,i,(n=>{let r=le.Space,o=e.from,h=!1,l=!1,a=!1,c=e=>{if(h)return!1;o+=i?e.length:-e.length;let n,c=s(e);if(r==le.Space&&(r=c),r!=c)return!1;if(r==le.Word)if(e.toLowerCase()==e){if(!i&&l)return!1;a=!0}else if(a){if(i)return!1;h=!0}else{if(l&&i&&s(n=t.state.sliceDoc(o,o+1))==le.Word&&n.toLowerCase()==n)return!1;l=!0}return!0};return c(n),c}))}function da(t,e){return oa(t,(i=>i.empty?fa(t,i,e):ha(i,e)))}const pa=t=>da(t,!0),ga=t=>da(t,!1);function ma(t,e){return oa(t,(i=>{if(!i.empty)return ha(i,e);let s=t.moveVertically(i,e);return s.head!=i.head?s:t.moveToLineBoundary(i,e)}))}const wa=t=>ma(t,!1),va=t=>ma(t,!0);function ya(t,e){return oa(t,(i=>i.empty?t.moveVertically(i,e,t.dom.clientHeight):ha(i,e)))}const ba=t=>ya(t,!1),xa=t=>ya(t,!0);function ka(t,e,i){let s=t.visualLineAt(e.head),n=t.moveToLineBoundary(e,i);if(n.head==e.head&&n.head!=(i?s.to:s.from)&&(n=t.moveToLineBoundary(e,i,!1)),!i&&n.head==s.from&&s.length){let i=/^\s*/.exec(t.state.sliceDoc(s.from,Math.min(s.from+100,s.to)))[0].length;i&&e.head!=s.from+i&&(n=kt.cursor(s.from+i))}return n}const Sa=t=>oa(t,(e=>ka(t,e,!0))),Aa=t=>oa(t,(e=>ka(t,e,!1)));function Ca(t,e,i){let s=!1,n=na(t.selection,(e=>{let n=ia(t,e.head,-1)||ia(t,e.head,1)||e.head>0&&ia(t,e.head-1,1)||e.head<t.doc.length&&ia(t,e.head+1,-1);if(!n||!n.end)return e;s=!0;let r=n.start.from==e.head?n.end.to:n.end.from;return i?kt.range(e.anchor,r):kt.cursor(r)}));return!!s&&(e(ra(t,n)),!0)}const Ma=({state:t,dispatch:e})=>Ca(t,e,!1),Da=({state:t,dispatch:e})=>Ca(t,e,!0);function Oa(t,e){let i=na(t.state.selection,(t=>{let i=e(t);return kt.range(t.anchor,i.head,i.goalColumn)}));return!i.eq(t.state.selection)&&(t.dispatch(ra(t.state,i)),!0)}function Ta(t,e){return Oa(t,(i=>t.moveByChar(i,e)))}const Pa=t=>Ta(t,t.textDirection!=Ss.LTR),Ea=t=>Ta(t,t.textDirection==Ss.LTR);function Ra(t,e){return Oa(t,(i=>t.moveByGroup(i,e)))}function La(t,e){return Oa(t,(i=>fa(t,i,e)))}const Na=t=>La(t,!0),Ia=t=>La(t,!1);function Ba(t,e){return Oa(t,(i=>t.moveVertically(i,e)))}const Va=t=>Ba(t,!1),za=t=>Ba(t,!0);function Fa(t,e){return Oa(t,(i=>t.moveVertically(i,e,t.dom.clientHeight)))}const Ha=t=>Fa(t,!1),Wa=t=>Fa(t,!0),qa=t=>Oa(t,(e=>ka(t,e,!0))),ja=t=>Oa(t,(e=>ka(t,e,!1))),_a=({state:t,dispatch:e})=>(e(ra(t,{anchor:0})),!0),$a=({state:t,dispatch:e})=>(e(ra(t,{anchor:t.doc.length})),!0),Ua=({state:t,dispatch:e})=>(e(ra(t,{anchor:t.selection.main.anchor,head:0})),!0),Ga=({state:t,dispatch:e})=>(e(ra(t,{anchor:t.selection.main.anchor,head:t.doc.length})),!0);function Ka({state:t,dispatch:e},i){if(t.readOnly)return!1;let s="delete.selection",n=t.changeByRange((t=>{let{from:e,to:n}=t;if(e==n){let t=i(e);t<e?s="delete.backward":t>e&&(s="delete.forward"),e=Math.min(e,t),n=Math.max(n,t)}return e==n?{range:t}:{changes:{from:e,to:n},range:kt.cursor(e)}}));return!n.changes.empty&&(e(t.update(n,{scrollIntoView:!0,userEvent:s})),!0)}function Ja(t,e,i){if(t instanceof tr)for(let s of t.pluginField(os.atomicRanges))s.between(e,e,((t,s)=>{t<e&&s>e&&(e=i?s:t)}));return e}const Xa=(t,e)=>Ka(t,(i=>{let s,n,{state:r}=t,o=r.doc.lineAt(i);if(!e&&i>o.from&&i<o.from+200&&!/[^ \t]/.test(s=o.text.slice(0,i-o.from))){if("\t"==s[s.length-1])return i-1;let t=et(s,r.tabSize)%no(r)||no(r);for(let e=0;e<t&&" "==s[s.length-1-e];e++)i--;n=i}else n=G(o.text,i-o.from,e)+o.from,n==i&&o.number!=(e?r.doc.lines:1)&&(n+=e?1:-1);return Ja(t,n,e)})),Ya=t=>Xa(t,!1),Qa=t=>Xa(t,!0),Za=(t,e)=>Ka(t,(i=>{let s=i,{state:n}=t,r=n.doc.lineAt(s),o=n.charCategorizer(s);for(let t=null;;){if(s==(e?r.to:r.from)){s==i&&r.number!=(e?n.doc.lines:1)&&(s+=e?1:-1);break}let h=G(r.text,s-r.from,e)+r.from,l=r.text.slice(Math.min(s,h)-r.from,Math.max(s,h)-r.from),a=o(l);if(null!=t&&a!=t)break;" "==l&&s==i||(t=a),s=h}return Ja(t,s,e)})),tc=t=>Za(t,!1),ec=t=>Ka(t,(e=>{let i=t.visualLineAt(e).to;return Ja(t,e<i?i:Math.min(t.state.doc.length,e+1),!0)}));function ic(t,e){let i=-1;return t.changeByRange((s=>{let n=[];for(let r=s.from;r<=s.to;){let o=t.doc.lineAt(r);o.number>i&&(s.empty||s.to>o.from)&&(e(o,n,s),i=o.number),r=o.to+1}let r=t.changes(n);return{changes:n,range:kt.range(r.mapPos(s.anchor,1),r.mapPos(s.head,1))}}))}const sc=({state:t,dispatch:e})=>!t.readOnly&&(e(t.update(ic(t,((e,i)=>{i.push({from:e.from,insert:t.facet(so)})})),{userEvent:"input.indent"})),!0),nc=({state:t,dispatch:e})=>!t.readOnly&&(e(t.update(ic(t,((e,i)=>{let s=/^\s*/.exec(e.text)[0];if(!s)return;let n=et(s,t.tabSize),r=0,o=ro(t,Math.max(0,n-no(t)));for(;r<s.length&&r<o.length&&s.charCodeAt(r)==o.charCodeAt(r);)r++;i.push({from:e.from+r,to:e.from+s.length,insert:o.slice(r)})})),{userEvent:"delete.dedent"})),!0),rc=[{key:"ArrowLeft",run:aa,shift:Pa,preventDefault:!0},{key:"Mod-ArrowLeft",mac:"Alt-ArrowLeft",run:t=>ua(t,t.textDirection!=Ss.LTR),shift:t=>Ra(t,t.textDirection!=Ss.LTR)},{mac:"Cmd-ArrowLeft",run:Aa,shift:ja},{key:"ArrowRight",run:ca,shift:Ea,preventDefault:!0},{key:"Mod-ArrowRight",mac:"Alt-ArrowRight",run:t=>ua(t,t.textDirection==Ss.LTR),shift:t=>Ra(t,t.textDirection==Ss.LTR)},{mac:"Cmd-ArrowRight",run:Sa,shift:qa},{key:"ArrowUp",run:wa,shift:Va,preventDefault:!0},{mac:"Cmd-ArrowUp",run:_a,shift:Ua},{mac:"Ctrl-ArrowUp",run:ba,shift:Ha},{key:"ArrowDown",run:va,shift:za,preventDefault:!0},{mac:"Cmd-ArrowDown",run:$a,shift:Ga},{mac:"Ctrl-ArrowDown",run:xa,shift:Wa},{key:"PageUp",run:ba,shift:Ha},{key:"PageDown",run:xa,shift:Wa},{key:"Home",run:Aa,shift:ja},{key:"Mod-Home",run:_a,shift:Ua},{key:"End",run:Sa,shift:qa},{key:"Mod-End",run:$a,shift:Ga},{key:"Enter",run:({state:t,dispatch:e})=>{if(t.readOnly)return!1;let i=t.changeByRange((({from:e,to:i})=>{let n=e==i&&function(t,e){if(/\(\)|\[\]|\{\}/.test(t.sliceDoc(e-1,e+1)))return{from:e,to:e};let i,n=_r(t).resolveInner(e),r=n.childBefore(e),o=n.childAfter(e);return r&&o&&r.to<=e&&o.from>=e&&(i=r.type.prop(s.closedBy))&&i.indexOf(o.name)>-1&&t.doc.lineAt(r.to).from==t.doc.lineAt(o.from).from?{from:r.to,to:o.from}:null}(t,e),r=new ho(t,{simulateBreak:e,simulateDoubleBreak:!!n}),o=oo(r,e);null==o&&(o=/^\s*/.exec(t.doc.lineAt(e).text)[0].length);let h=t.doc.lineAt(e);for(;i<h.to&&/\s/.test(h.text[i-h.from]);)i++;n?({from:e,to:i}=n):e>h.from&&e<h.from+100&&!/\S/.test(h.text.slice(0,e))&&(e=h.from);let l=["",ro(t,o)];return n&&l.push(ro(t,r.lineIndent(h.from,-1))),{changes:{from:e,to:i,insert:it.of(l)},range:kt.cursor(e+1+l[1].length)}}));return e(t.update(i,{scrollIntoView:!0,userEvent:"input"})),!0}},{key:"Mod-a",run:({state:t,dispatch:e})=>(e(t.update({selection:{anchor:0,head:t.doc.length},userEvent:"select"})),!0)},{key:"Backspace",run:Ya,shift:Ya},{key:"Delete",run:Qa,shift:Qa},{key:"Mod-Backspace",mac:"Alt-Backspace",run:tc},{key:"Mod-Delete",mac:"Alt-Delete",run:t=>Za(t,!0)},{mac:"Mod-Backspace",run:t=>Ka(t,(e=>{let i=t.visualLineAt(e).from;return Ja(t,e>i?i:Math.max(0,e-1),!1)}))},{mac:"Mod-Delete",run:ec}].concat([{key:"Ctrl-b",run:aa,shift:Pa,preventDefault:!0},{key:"Ctrl-f",run:ca,shift:Ea},{key:"Ctrl-p",run:wa,shift:Va},{key:"Ctrl-n",run:va,shift:za},{key:"Ctrl-a",run:t=>oa(t,(e=>kt.cursor(t.visualLineAt(e.head).from,1))),shift:t=>Oa(t,(e=>kt.cursor(t.visualLineAt(e.head).from)))},{key:"Ctrl-e",run:t=>oa(t,(e=>kt.cursor(t.visualLineAt(e.head).to,-1))),shift:t=>Oa(t,(e=>kt.cursor(t.visualLineAt(e.head).to)))},{key:"Ctrl-d",run:Qa},{key:"Ctrl-h",run:Ya},{key:"Ctrl-k",run:ec},{key:"Ctrl-Alt-h",run:tc},{key:"Ctrl-o",run:({state:t,dispatch:e})=>{if(t.readOnly)return!1;let i=t.changeByRange((t=>({changes:{from:t.from,to:t.to,insert:it.of(["",""])},range:kt.cursor(t.from)})));return e(t.update(i,{scrollIntoView:!0,userEvent:"input"})),!0}},{key:"Ctrl-t",run:({state:t,dispatch:e})=>{if(t.readOnly)return!1;let i=t.changeByRange((e=>{if(!e.empty||0==e.from||e.from==t.doc.length)return{range:e};let i=e.from,s=t.doc.lineAt(i),n=i==s.from?i-1:G(s.text,i-s.from,!1)+s.from,r=i==s.to?i+1:G(s.text,i-s.from,!0)+s.from;return{changes:{from:n,to:r,insert:t.doc.slice(i,r).append(t.doc.slice(n,i))},range:kt.cursor(r)}}));return!i.changes.empty&&(e(t.update(i,{scrollIntoView:!0,userEvent:"move.character"})),!0)}},{key:"Alt-<",run:_a},{key:"Alt->",run:$a},{key:"Ctrl-v",run:xa},{key:"Alt-v",run:ba}].map((t=>({mac:t.key,run:t.run,shift:t.shift})))),oc=t=>{let e=cc(t.state);return e.line?lc(t):!!e.block&&ac(t)};function hc(t,e){return({state:i,dispatch:s})=>{let n=t(e,i.selection.ranges,i);return!!n&&(s(i.update(n)),!0)}}const lc=hc(fc,0),ac=hc(uc,0);function cc(t,e=t.selection.main.head){let i=t.languageDataAt("commentTokens",e);return i.length?i[0]:{}}function uc(t,e,i){let s=e.map((t=>cc(i,t.from).block));if(!s.every((t=>t)))return null;let n=e.map(((t,e)=>function(t,{open:e,close:i},s,n){let r,o,h=t.sliceDoc(s-50,s),l=t.sliceDoc(n,n+50),a=/\s*$/.exec(h)[0].length,c=/^\s*/.exec(l)[0].length,u=h.length-a;if(h.slice(u-e.length,u)==e&&l.slice(c,c+i.length)==i)return{open:{pos:s-a,margin:a&&1},close:{pos:n+c,margin:c&&1}};n-s<=100?r=o=t.sliceDoc(s,n):(r=t.sliceDoc(s,s+50),o=t.sliceDoc(n-50,n));let f=/^\s*/.exec(r)[0].length,d=/\s*$/.exec(o)[0].length,p=o.length-d-i.length;return r.slice(f,f+e.length)==e&&o.slice(p,p+i.length)==i?{open:{pos:s+f+e.length,margin:/\s/.test(r.charAt(f+e.length))?1:0},close:{pos:n-d-i.length,margin:/\s/.test(o.charAt(p-1))?1:0}}:null}(i,s[e],t.from,t.to)));if(2!=t&&!n.every((t=>t))){let t=0;return i.changeByRange((e=>{let{open:i,close:r}=s[t++];if(n[t])return{range:e};let o=i.length+1;return{changes:[{from:e.from,insert:i+" "},{from:e.to,insert:" "+r}],range:kt.range(e.anchor+o,e.head+o)}}))}if(1!=t&&n.some((t=>t))){let t=[];for(let e,i=0;i<n.length;i++)if(e=n[i]){let n=s[i],{open:r,close:o}=e;t.push({from:r.pos-n.open.length,to:r.pos+r.margin},{from:o.pos-o.margin,to:o.pos+n.close.length})}return{changes:t}}return null}function fc(t,e,i){let s=[],n=-1;for(let{from:t,to:r}of e){let e=s.length,o=1e9;for(let e=t;e<=r;){let h=i.doc.lineAt(e);if(h.from>n&&(t==r||r>h.from)){n=h.from;let t=cc(i,e).line;if(!t)continue;let r=/^\s*/.exec(h.text)[0].length,l=r==h.length,a=h.text.slice(r,r+t.length)==t?r:-1;r<h.text.length&&r<o&&(o=r),s.push({line:h,comment:a,token:t,indent:r,empty:l,single:!1})}e=h.to+1}if(o<1e9)for(let t=e;t<s.length;t++)s[t].indent<s[t].line.text.length&&(s[t].indent=o);s.length==e+1&&(s[e].single=!0)}if(2!=t&&s.some((t=>t.comment<0&&(!t.empty||t.single)))){let t=[];for(let{line:e,token:i,indent:n,empty:r,single:o}of s)!o&&r||t.push({from:e.from+n,insert:i+" "});let e=i.changes(t);return{changes:e,selection:i.selection.map(e,1)}}if(1!=t&&s.some((t=>t.comment>=0))){let t=[];for(let{line:e,comment:i,token:n}of s)if(i>=0){let s=e.from+i,r=s+n.length;" "==e.text[r-e.from]&&r++,t.push({from:s,to:r})}return{changes:t}}return null}class dc extends pe{compare(t){return this==t||this.constructor==t.constructor&&this.eq(t)}eq(t){return!1}}dc.prototype.elementClass="",dc.prototype.toDOM=void 0,dc.prototype.mapMode=ft.TrackBefore,dc.prototype.startSide=dc.prototype.endSide=-1,dc.prototype.point=!0;const pc=Mt.define(),gc={class:"",renderEmptyElements:!1,elementStyle:"",markers:()=>ve.empty,lineMarker:()=>null,initialSpacer:null,updateSpacer:null,domEventHandlers:{}},mc=Mt.define();function wc(t){return[bc(),mc.of(Object.assign(Object.assign({},gc),t))]}const vc=tr.baseTheme({".cm-gutters":{display:"flex",height:"100%",boxSizing:"border-box",left:0,zIndex:200},"&light .cm-gutters":{backgroundColor:"#f5f5f5",color:"#999",borderRight:"1px solid #ddd"},"&dark .cm-gutters":{backgroundColor:"#333338",color:"#ccc"},".cm-gutter":{display:"flex !important",flexDirection:"column",flexShrink:0,boxSizing:"border-box",height:"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"}}),yc=Mt.define({combine:t=>t.some((t=>t))});function bc(t){let e=[xc,vc];return t&&!1===t.fixed&&e.push(yc.of(!0)),e}const xc=as.fromClass(class{constructor(t){this.view=t,this.dom=document.createElement("div"),this.dom.className="cm-gutters",this.dom.setAttribute("aria-hidden","true"),this.gutters=t.state.facet(mc).map((e=>new Cc(t,e)));for(let t of this.gutters)this.dom.appendChild(t.dom);this.fixed=!t.state.facet(yc),this.fixed&&(this.dom.style.position="sticky"),t.scrollDOM.insertBefore(this.dom,t.contentDOM),this.syncGutters()}update(t){this.updateGutters(t)&&this.syncGutters()}syncGutters(){let t=ve.iter(this.view.state.facet(pc),this.view.viewport.from),e=[],i=this.gutters.map((t=>new Ac(t,this.view.viewport)));this.view.viewportLines((s=>{let n;if(Array.isArray(s.type)){for(let t of s.type)if(t.type==Vi.Text){n=t;break}}else n=s.type==Vi.Text?s:void 0;if(n){e.length&&(e=[]),Sc(t,e,s.from);for(let t of i)t.line(this.view,n,e)}}),0);for(let t of i)t.finish();this.dom.style.minHeight=this.view.contentHeight+"px",this.view.state.facet(yc)!=!this.fixed&&(this.fixed=!this.fixed,this.dom.style.position=this.fixed?"sticky":"")}updateGutters(t){let e=t.startState.facet(mc),i=t.state.facet(mc),s=t.docChanged||t.heightChanged||t.viewportChanged||!ve.eq(t.startState.facet(pc),t.state.facet(pc),t.view.viewport.from,t.view.viewport.to);if(e==i)for(let e of this.gutters)e.update(t)&&(s=!0);else{s=!0;let n=[];for(let s of i){let i=e.indexOf(s);i<0?n.push(new Cc(this.view,s)):(this.gutters[i].update(t),n.push(this.gutters[i]))}for(let t of this.gutters)t.dom.remove();for(let t of n)this.dom.appendChild(t.dom);this.gutters=n}return s}destroy(){this.dom.remove()}},{provide:os.scrollMargins.from((t=>0!=t.gutters.length&&t.fixed?t.view.textDirection==Ss.LTR?{left:t.dom.offsetWidth}:{right:t.dom.offsetWidth}:null))});function kc(t){return Array.isArray(t)?t:[t]}function Sc(t,e,i){for(;t.value&&t.from<=i;)t.from==i&&e.push(t.value),t.next()}class Ac{constructor(t,e){this.gutter=t,this.localMarkers=[],this.i=0,this.height=0,this.cursor=ve.iter(t.markers,e.from)}line(t,e,i){this.localMarkers.length&&(this.localMarkers=[]),Sc(this.cursor,this.localMarkers,e.from);let s=i.length?this.localMarkers.concat(i):this.localMarkers,n=this.gutter.config.lineMarker(t,e,s);n&&s.unshift(n);let r=this.gutter;if(0==s.length&&!r.config.renderEmptyElements)return;let o=e.top-this.height;if(this.i==r.elements.length){let i=new Mc(t,e.height,o,s);r.elements.push(i),r.dom.appendChild(i.dom)}else{let i=r.elements[this.i];(function(t,e){if(t.length!=e.length)return!1;for(let i=0;i<t.length;i++)if(!t[i].compare(e[i]))return!1;return!0})(s,i.markers)&&(s=i.markers),i.update(t,e.height,o,s)}this.height=e.bottom,this.i++}finish(){let t=this.gutter;for(;t.elements.length>this.i;)t.dom.removeChild(t.elements.pop().dom)}}class Cc{constructor(t,e){this.view=t,this.config=e,this.elements=[],this.spacer=null,this.dom=document.createElement("div"),this.dom.className="cm-gutter"+(this.config.class?" "+this.config.class:"");for(let i in e.domEventHandlers)this.dom.addEventListener(i,(s=>{let n=t.visualLineAtHeight(s.clientY,t.contentDOM.getBoundingClientRect().top);e.domEventHandlers[i](t,n,s)&&s.preventDefault()}));this.markers=kc(e.markers(t)),e.initialSpacer&&(this.spacer=new Mc(t,0,0,[e.initialSpacer(t)]),this.dom.appendChild(this.spacer.dom),this.spacer.dom.style.cssText+="visibility: hidden; pointer-events: none")}update(t){let e=this.markers;if(this.markers=kc(this.config.markers(t.view)),this.spacer&&this.config.updateSpacer){let e=this.config.updateSpacer(this.spacer.markers[0],t);e!=this.spacer.markers[0]&&this.spacer.update(t.view,0,0,[e])}let i=t.view.viewport;return!ve.eq(this.markers,e,i.from,i.to)}}class Mc{constructor(t,e,i,s){this.height=-1,this.above=0,this.dom=document.createElement("div"),this.update(t,e,i,s)}update(t,e,i,s){if(this.height!=e&&(this.dom.style.height=(this.height=e)+"px"),this.above!=i&&(this.dom.style.marginTop=(this.above=i)?i+"px":""),this.markers!=s){this.markers=s;for(let t;t=this.dom.lastChild;)t.remove();let e="cm-gutterElement";for(let i of s){i.toDOM&&this.dom.appendChild(i.toDOM(t));let s=i.elementClass;s&&(e+=" "+s)}this.dom.className=e}}}const Dc=Mt.define(),Oc=Mt.define({combine:t=>de(t,{formatNumber:String,domEventHandlers:{}},{domEventHandlers(t,e){let i=Object.assign({},t);for(let t in e){let s=i[t],n=e[t];i[t]=s?(t,e,i)=>s(t,e,i)||n(t,e,i):n}return i}})});class Tc extends dc{constructor(t){super(),this.number=t}eq(t){return this.number==t.number}toDOM(t){return document.createTextNode(this.number)}}function Pc(t,e){return t.state.facet(Oc).formatNumber(e,t.state)}const Ec=mc.compute([Oc],(t=>({class:"cm-lineNumbers",renderEmptyElements:!1,markers:t=>t.state.facet(Dc),lineMarker:(t,e,i)=>i.some((t=>t.toDOM))?null:new Tc(Pc(t,t.state.doc.lineAt(e.from).number)),initialSpacer:t=>new Tc(Pc(t,Lc(t.state.doc.lines))),updateSpacer(t,e){let i=Pc(e.view,Lc(e.view.state.doc.lines));return i==t.number?t:new Tc(i)},domEventHandlers:t.facet(Oc).domEventHandlers})));function Rc(t={}){return[Oc.of(t),bc(),Ec]}function Lc(t){let e=9;for(;e<t;)e=10*e+9;return e}function Nc(t,e){let i=e.mapPos(t.from,1),s=e.mapPos(t.to,-1);return i>=s?void 0:{from:i,to:s}}const Ic=te.define({map:Nc}),Bc=te.define({map:Nc});function Vc(t){let e=[];for(let{head:i}of t.state.selection.ranges)e.some((t=>t.from<=i&&t.to>=i))||e.push(t.visualLineAt(i));return e}const zc=Rt.define({create:()=>zi.none,update(t,e){t=t.map(e.changes);for(let i of e.effects)i.is(Ic)&&!Hc(t,i.value.from,i.value.to)?t=t.update({add:[Gc.range(i.value.from,i.value.to)]}):i.is(Bc)&&(t=t.update({filter:(t,e)=>i.value.from!=t||i.value.to!=e,filterFrom:i.value.from,filterTo:i.value.to}));if(e.selection){let i=!1,{head:s}=e.selection.main;t.between(s,s,((t,e)=>{t<s&&e>s&&(i=!0)})),i&&(t=t.update({filterFrom:s,filterTo:s,filter:(t,e)=>e<=s||t>=s}))}return t},provide:t=>tr.decorations.from(t)});function Fc(t,e,i){var s;let n=null;return null===(s=t.field(zc,!1))||void 0===s||s.between(e,i,((t,e)=>{(!n||n.from>t)&&(n={from:t,to:e})})),n}function Hc(t,e,i){let s=!1;return t.between(e,e,((t,n)=>{t==e&&n==i&&(s=!0)})),s}function Wc(t,e){return t.field(zc,!1)?e:e.concat(te.appendConfig.of(Uc()))}function qc(t,e,i=!0){let s=t.state.doc.lineAt(e.from).number,n=t.state.doc.lineAt(e.to).number;return tr.announce.of(`${t.state.phrase(i?"Folded lines":"Unfolded lines")} ${s} ${t.state.phrase("to")} ${n}.`)}const jc=[{key:"Ctrl-Shift-[",mac:"Cmd-Alt-[",run:t=>{for(let e of Vc(t)){let i=So(t.state,e.from,e.to);if(i)return t.dispatch({effects:Wc(t.state,[Ic.of(i),qc(t,i)])}),!0}return!1}},{key:"Ctrl-Shift-]",mac:"Cmd-Alt-]",run:t=>{if(!t.state.field(zc,!1))return!1;let e=[];for(let i of Vc(t)){let s=Fc(t.state,i.from,i.to);s&&e.push(Bc.of(s),qc(t,s,!1))}return e.length&&t.dispatch({effects:e}),e.length>0}},{key:"Ctrl-Alt-[",run:t=>{let{state:e}=t,i=[];for(let s=0;s<e.doc.length;){let n=t.visualLineAt(s),r=So(e,n.from,n.to);r&&i.push(Ic.of(r)),s=(r?t.visualLineAt(r.to):n).to+1}return i.length&&t.dispatch({effects:Wc(t.state,i)}),!!i.length}},{key:"Ctrl-Alt-]",run:t=>{let e=t.state.field(zc,!1);if(!e||!e.size)return!1;let i=[];return e.between(0,t.state.doc.length,((t,e)=>{i.push(Bc.of({from:t,to:e}))})),t.dispatch({effects:i}),!0}}],_c={placeholderDOM:null,placeholderText:"…"},$c=Mt.define({combine:t=>de(t,_c)});function Uc(t){let e=[zc,Yc];return t&&e.push($c.of(t)),e}const Gc=zi.replace({widget:new class extends Bi{ignoreEvents(){return!1}toDOM(t){let{state:e}=t,i=e.facet($c);if(i.placeholderDOM)return i.placeholderDOM();let s=document.createElement("span");return s.textContent=i.placeholderText,s.setAttribute("aria-label",e.phrase("folded code")),s.title=e.phrase("unfold"),s.className="cm-foldPlaceholder",s.onclick=e=>{let i=t.visualLineAt(t.posAtDOM(e.target)),s=Fc(t.state,i.from,i.to);s&&t.dispatch({effects:Bc.of(s)}),e.preventDefault()},s}}}),Kc={openText:"⌄",closedText:"›",markerDOM:null};class Jc extends dc{constructor(t,e){super(),this.config=t,this.open=e}eq(t){return this.config==t.config&&this.open==t.open}toDOM(t){if(this.config.markerDOM)return this.config.markerDOM(this.open);let e=document.createElement("span");return e.textContent=this.open?this.config.openText:this.config.closedText,e.title=t.state.phrase(this.open?"Fold line":"Unfold line"),e}}function Xc(t={}){let e=Object.assign(Object.assign({},Kc),t),i=new Jc(e,!0),s=new Jc(e,!1),n=as.fromClass(class{constructor(t){this.from=t.viewport.from,this.markers=this.buildMarkers(t)}update(t){(t.docChanged||t.viewportChanged||t.startState.facet(Zr)!=t.state.facet(Zr)||t.startState.field(zc,!1)!=t.state.field(zc,!1))&&(this.markers=this.buildMarkers(t.view))}buildMarkers(t){let e=new ye;return t.viewportLines((n=>{let r=Fc(t.state,n.from,n.to)?s:So(t.state,n.from,n.to)?i:null;r&&e.add(n.from,n.from,r)})),e.finish()}});return[n,wc({class:"cm-foldGutter",markers(t){var e;return(null===(e=t.plugin(n))||void 0===e?void 0:e.markers)||ve.empty},initialSpacer:()=>new Jc(e,!1),domEventHandlers:{click:(t,e)=>{let i=Fc(t.state,e.from,e.to);if(i)return t.dispatch({effects:Bc.of(i)}),!0;let s=So(t.state,e.from,e.to);return!!s&&(t.dispatch({effects:Ic.of(s)}),!0)}}}),Uc()]}const Yc=tr.baseTheme({".cm-foldPlaceholder":{backgroundColor:"#eee",border:"1px solid #ddd",color:"#888",borderRadius:".2em",margin:"0 1px",padding:"0 1px",cursor:"pointer"},".cm-foldGutter .cm-gutterElement":{padding:"0 1px",cursor:"pointer"}}),Qc=Yt.define(),Zc=Yt.define(),tu=Mt.define(),eu=Mt.define({combine:t=>de(t,{minDepth:100,newGroupDelay:500},{minDepth:Math.max,newGroupDelay:Math.min})}),iu=Rt.define({create:()=>wu.empty,update(t,e){let i=e.state.facet(eu),s=e.annotation(Qc);if(s){let n=au.fromTransaction(e),r=s.side,o=0==r?t.undone:t.done;return o=n?cu(o,o.length,i.minDepth,n):du(o,e.startState.selection),new wu(0==r?s.rest:o,0==r?o:s.rest)}let n=e.annotation(Zc);if("full"!=n&&"before"!=n||(t=t.isolate()),!1===e.annotation(ee.addToHistory))return e.changes.empty?t:t.addMapping(e.changes.desc);let r=au.fromTransaction(e),o=e.annotation(ee.time),h=e.annotation(ee.userEvent);return r?t=t.addChanges(r,o,h,i.newGroupDelay,i.minDepth):e.selection&&(t=t.addSelection(e.startState.selection,o,h,i.newGroupDelay)),"full"!=n&&"after"!=n||(t=t.isolate()),t},toJSON:t=>({done:t.done.map((t=>t.toJSON())),undone:t.undone.map((t=>t.toJSON()))}),fromJSON:t=>new wu(t.done.map(au.fromJSON),t.undone.map(au.fromJSON))});function su(t={}){return[iu,eu.of(t),tr.domEventHandlers({beforeinput:(t,e)=>"historyUndo"==t.inputType?ru(e):"historyRedo"==t.inputType&&ou(e)})]}function nu(t,e){return function({state:i,dispatch:s}){let n=i.field(iu,!1);if(!n)return!1;let r=n.pop(t,i,e);return!!r&&(s(r),!0)}}const ru=nu(0,!1),ou=nu(1,!1),hu=nu(0,!0),lu=nu(1,!0);class au{constructor(t,e,i,s,n){this.changes=t,this.effects=e,this.mapped=i,this.startSelection=s,this.selectionsAfter=n}setSelAfter(t){return new au(this.changes,this.effects,this.mapped,this.startSelection,t)}toJSON(){var t,e,i;return{changes:null===(t=this.changes)||void 0===t?void 0:t.toJSON(),mapped:null===(e=this.mapped)||void 0===e?void 0:e.toJSON(),startSelection:null===(i=this.startSelection)||void 0===i?void 0:i.toJSON(),selectionsAfter:this.selectionsAfter.map((t=>t.toJSON()))}}static fromJSON(t){return new au(t.changes&&pt.fromJSON(t.changes),[],t.mapped&&dt.fromJSON(t.mapped),t.startSelection&&kt.fromJSON(t.startSelection),t.selectionsAfter.map(kt.fromJSON))}static fromTransaction(t){let e=fu;for(let i of t.startState.facet(tu)){let s=i(t);s.length&&(e=e.concat(s))}return!e.length&&t.changes.empty?null:new au(t.changes.invert(t.startState.doc),e,void 0,t.startState.selection,fu)}static selection(t){return new au(void 0,fu,void 0,void 0,t)}}function cu(t,e,i,s){let n=e+1>i+20?e-i-1:0,r=t.slice(n,e);return r.push(s),r}function uu(t,e){return t.length?e.length?t.concat(e):t:e}const fu=[];function du(t,e){if(t.length){let i=t[t.length-1],s=i.selectionsAfter.slice(Math.max(0,i.selectionsAfter.length-200));return s.length&&s[s.length-1].eq(e)?t:(s.push(e),cu(t,t.length-1,1e9,i.setSelAfter(s)))}return[au.selection([e])]}function pu(t){let e=t[t.length-1],i=t.slice();return i[t.length-1]=e.setSelAfter(e.selectionsAfter.slice(0,e.selectionsAfter.length-1)),i}function gu(t,e){if(!t.length)return t;let i=t.length,s=fu;for(;i;){let n=mu(t[i-1],e,s);if(n.changes&&!n.changes.empty||n.effects.length){let e=t.slice(0,i);return e[i-1]=n,e}e=n.mapped,i--,s=n.selectionsAfter}return s.length?[au.selection(s)]:fu}function mu(t,e,i){let s=uu(t.selectionsAfter.length?t.selectionsAfter.map((t=>t.map(e))):fu,i);if(!t.changes)return au.selection(s);let n=t.changes.map(e),r=e.mapDesc(t.changes,!0),o=t.mapped?t.mapped.composeDesc(r):r;return new au(n,te.mapEffects(t.effects,e),o,t.startSelection.map(r),s)}class wu{constructor(t,e,i=0,s){this.done=t,this.undone=e,this.prevTime=i,this.prevUserEvent=s}isolate(){return this.prevTime?new wu(this.done,this.undone):this}addChanges(t,e,i,s,n){let r=this.done,o=r[r.length-1];return r=o&&o.changes&&!o.changes.empty&&t.changes&&(!o.selectionsAfter.length&&e-this.prevTime<s&&function(t,e){let i=[],s=!1;return t.iterChangedRanges(((t,e)=>i.push(t,e))),e.iterChangedRanges(((t,e,n,r)=>{for(let t=0;t<i.length;){let e=i[t++],o=i[t++];r>=e&&n<=o&&(s=!0)}})),s}(o.changes,t.changes)||"input.type.compose"==i)?cu(r,r.length-1,n,new au(t.changes.compose(o.changes),uu(t.effects,o.effects),o.mapped,o.startSelection,fu)):cu(r,r.length,n,t),new wu(r,fu,e,i)}addSelection(t,e,i,s){let n=this.done.length?this.done[this.done.length-1].selectionsAfter:fu;return n.length>0&&e-this.prevTime<s&&i==this.prevUserEvent&&i&&/^select($|\.)/.test(i)&&(r=n[n.length-1],o=t,r.ranges.length==o.ranges.length&&0===r.ranges.filter(((t,e)=>t.empty!=o.ranges[e].empty)).length)?this:new wu(du(this.done,t),this.undone,e,i);var r,o}addMapping(t){return new wu(gu(this.done,t),gu(this.undone,t),this.prevTime,this.prevUserEvent)}pop(t,e,i){let s=0==t?this.done:this.undone;if(0==s.length)return null;let n=s[s.length-1];if(i&&n.selectionsAfter.length)return e.update({selection:n.selectionsAfter[n.selectionsAfter.length-1],annotations:Qc.of({side:t,rest:pu(s)}),userEvent:0==t?"select.undo":"select.redo"});if(n.changes){let i=1==s.length?fu:s.slice(0,s.length-1);return n.mapped&&(i=gu(i,n.mapped)),e.update({changes:n.changes,selection:n.startSelection,effects:n.effects,annotations:Qc.of({side:t,rest:i}),filter:!1,userEvent:0==t?"undo":"redo"})}return null}}wu.empty=new wu(fu,fu);const vu=[{key:"Mod-z",run:ru,preventDefault:!0},{key:"Mod-y",mac:"Mod-Shift-z",run:ou,preventDefault:!0},{key:"Mod-u",run:hu,preventDefault:!0},{key:"Alt-u",mac:"Mod-Shift-u",run:lu,preventDefault:!0}],yu="function"==typeof String.prototype.normalize?t=>t.normalize("NFKD"):t=>t;class bu{constructor(t,e,i=0,s=t.length,n){this.value={from:0,to:0},this.done=!1,this.matches=[],this.buffer="",this.bufferPos=0,this.iter=t.iterRange(i,s),this.bufferStart=i,this.normalize=n?t=>n(yu(t)):yu,this.query=this.normalize(e)}peek(){if(this.bufferPos==this.buffer.length){if(this.bufferStart+=this.buffer.length,this.iter.next(),this.iter.done)return-1;this.bufferPos=0,this.buffer=this.iter.value}return Q(this.buffer,this.bufferPos)}next(){for(;this.matches.length;)this.matches.pop();return this.nextOverlapping()}nextOverlapping(){for(;;){let t=this.peek();if(t<0)return this.done=!0,this;let e=Z(t),i=this.bufferStart+this.bufferPos;this.bufferPos+=tt(t);let s=this.normalize(e);for(let t=0,n=i;;t++){let r=s.charCodeAt(t),o=this.match(r,n);if(o)return this.value=o,this;if(t==s.length-1)break;n==i&&t<e.length&&e.charCodeAt(t)==r&&n++}}}match(t,e){let i=null;for(let s=0;s<this.matches.length;s+=2){let n=this.matches[s],r=!1;this.query.charCodeAt(n)==t&&(n==this.query.length-1?i={from:this.matches[s+1],to:e+1}:(this.matches[s]++,r=!0)),r||(this.matches.splice(s,2),s-=2)}return this.query.charCodeAt(0)==t&&(1==this.query.length?i={from:e,to:e+1}:this.matches.push(1,e)),i}}const xu=({state:t,dispatch:e})=>{let{ranges:i}=t.selection;if(i.some((t=>t.from===t.to)))return(({state:t,dispatch:e})=>{let{selection:i}=t,s=kt.create(i.ranges.map((e=>t.wordAt(e.head)||kt.cursor(e.head))),i.mainIndex);return!s.eq(i)&&(e(t.update({selection:s})),!0)})({state:t,dispatch:e});let s=t.sliceDoc(i[0].from,i[0].to);if(t.selection.ranges.some((e=>t.sliceDoc(e.from,e.to)!=s)))return!1;let n=function(t,e){let{main:i,ranges:s}=t.selection,n=t.wordAt(i.head),r=n&&n.from==i.from&&n.to==i.to;for(let i=!1,n=new bu(t.doc,e,s[s.length-1].to);;){if(n.next(),!n.done){if(i&&s.some((t=>t.from==n.value.from)))continue;if(r){let e=t.wordAt(n.value.from);if(!e||e.from!=n.value.from||e.to!=n.value.to)continue}return n.value}if(i)return null;n=new bu(t.doc,e,0,Math.max(0,s[s.length-1].from-1)),i=!0}}(t,s);return!!n&&(e(t.update({selection:t.selection.addRange(kt.range(n.from,n.to),!1),scrollIntoView:!0})),!0)};class ku{constructor(t,e,i,s,n,r,o,h,l,a=0,c){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.lookAhead=a,this.parent=c}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 ku(t,[],e,i,i,0,[],0,s?new Su(s,s.start):null,0,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,this.reducePos);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,o)}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){let s=this.pos;if(131072&t)this.pushState(65535&t,this.pos);else if(0==(262144&t)){let 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),this.shiftContext(e,s),e<=r.maxNode&&this.buffer.push(e,s,i,4)}else this.pos=i,this.shiftContext(e,s),e<=this.p.parser.maxNode&&this.buffer.push(e,s,i,4)}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,this.p.stream.reset(this.pos-t.length)))}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 ku(this.p,this.stack.slice(),this.state,this.reducePos,this.pos,this.score,i,s,this.curContext,this.lookAhead,t)}recoverByDelete(t,e){let i=t<=this.p.parser.maxNode;i&&this.storeNode(t,this.pos,e,4),this.storeNode(0,this.pos,e,i?8:4),this.pos=this.reducePos=e,this.score-=190}canShift(t){for(let e=new Cu(this);;){let i=this.p.parser.stateSlot(e.state,4)||this.p.parser.hasAction(e.state,t);if(0==(65536&i))return!0;if(0==i)return!1;e.reduce(i)}}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],this.pos),n.score-=200,i.push(n)}return i}forceReduce(){let t=this.p.parser.stateSlot(this.state,5);if(0==(65536&t))return!1;let{parser:e}=this.p;if(!e.validAction(this.state,t)){let i=t>>19,s=65535&t,n=this.stack.length-3*i;if(n<0||e.getGoto(this.stack[n],s,!1)<0)return!1;this.storeNode(0,this.reducePos,this.reducePos,4,!0),this.score-=100}return 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,e){this.curContext&&this.updateContext(this.curContext.tracker.shift(this.curContext.context,t,this,this.p.stream.reset(e)))}reduceContext(t,e){this.curContext&&this.updateContext(this.curContext.tracker.reduce(this.curContext.context,t,this,this.p.stream.reset(e)))}emitContext(){let t=this.buffer.length-1;(t<0||-3!=this.buffer[t])&&this.buffer.push(this.curContext.hash,this.reducePos,this.reducePos,-3)}emitLookAhead(){let t=this.buffer.length-1;(t<0||-4!=this.buffer[t])&&this.buffer.push(this.lookAhead,this.reducePos,this.reducePos,-4)}updateContext(t){if(t!=this.curContext.context){let e=new Su(this.curContext.tracker,t);e.hash!=this.curContext.hash&&this.emitContext(),this.curContext=e}}setLookAhead(t){t>this.lookAhead&&(this.emitLookAhead(),this.lookAhead=t)}close(){this.curContext&&this.curContext.tracker.strict&&this.emitContext(),this.lookAhead>0&&this.emitLookAhead()}}class Su{constructor(t,e){this.tracker=t,this.context=e,this.hash=t.strict?t.hash(e):0}}var Au;!function(t){t[t.Insert=200]="Insert",t[t.Delete=190]="Delete",t[t.Reduce=100]="Reduce",t[t.MaxNext=4]="MaxNext",t[t.MaxInsertStackDepth=300]="MaxInsertStackDepth",t[t.DampenInsertStackDepth=120]="DampenInsertStackDepth"}(Au||(Au={}));class Cu{constructor(t){this.start=t,this.state=t.state,this.stack=t.stack,this.base=this.stack.length}reduce(t){let e=65535&t,i=t>>19;0==i?(this.stack==this.start.stack&&(this.stack=this.stack.slice()),this.stack.push(this.state,0,0),this.base+=3):this.base-=3*(i-1);let s=this.start.p.parser.getGoto(this.stack[this.base-3],e,!0);this.state=s}}class Mu{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,e=t.bufferBase+t.buffer.length){return new Mu(t,e,e-t.bufferBase)}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 Mu(this.stack,this.pos,this.index)}}class Du{constructor(){this.start=-1,this.value=-1,this.end=-1,this.extended=-1,this.lookAhead=0,this.mask=0,this.context=0}}const Ou=new Du;class Tu{constructor(t,e){this.input=t,this.ranges=e,this.chunk="",this.chunkOff=0,this.chunk2="",this.chunk2Pos=0,this.next=-1,this.token=Ou,this.rangeIndex=0,this.pos=this.chunkPos=e[0].from,this.range=e[0],this.end=e[e.length-1].to,this.readNext()}resolveOffset(t,e){let i=this.range,s=this.rangeIndex,n=this.pos+t;for(;n<i.from;){if(!s)return null;let t=this.ranges[--s];n-=i.from-t.to,i=t}for(;e<0?n>i.to:n>=i.to;){if(s==this.ranges.length-1)return null;let t=this.ranges[++s];n+=t.from-i.to,i=t}return n}peek(t){let e,i,s=this.chunkOff+t;if(s>=0&&s<this.chunk.length)e=this.pos+t,i=this.chunk.charCodeAt(s);else{let s=this.resolveOffset(t,1);if(null==s)return-1;if(e=s,e>=this.chunk2Pos&&e<this.chunk2Pos+this.chunk2.length)i=this.chunk2.charCodeAt(e-this.chunk2Pos);else{let t=this.rangeIndex,s=this.range;for(;s.to<=e;)s=this.ranges[++t];this.chunk2=this.input.chunk(this.chunk2Pos=e),e+this.chunk2.length>s.to&&(this.chunk2=this.chunk2.slice(0,s.to-e)),i=this.chunk2.charCodeAt(0)}}return e>this.token.lookAhead&&(this.token.lookAhead=e),i}acceptToken(t,e=0){let i=e?this.resolveOffset(e,-1):this.pos;if(null==i||i<this.token.start)throw new RangeError("Token end out of bounds");this.token.value=t,this.token.end=i}getChunk(){if(this.pos>=this.chunk2Pos&&this.pos<this.chunk2Pos+this.chunk2.length){let{chunk:t,chunkPos:e}=this;this.chunk=this.chunk2,this.chunkPos=this.chunk2Pos,this.chunk2=t,this.chunk2Pos=e,this.chunkOff=this.pos-this.chunkPos}else{this.chunk2=this.chunk,this.chunk2Pos=this.chunkPos;let t=this.input.chunk(this.pos),e=this.pos+t.length;this.chunk=e>this.range.to?t.slice(0,this.range.to-this.pos):t,this.chunkPos=this.pos,this.chunkOff=0}}readNext(){return this.chunkOff>=this.chunk.length&&(this.getChunk(),this.chunkOff==this.chunk.length)?this.next=-1:this.next=this.chunk.charCodeAt(this.chunkOff)}advance(t=1){for(this.chunkOff+=t;this.pos+t>=this.range.to;){if(this.rangeIndex==this.ranges.length-1)return this.setDone();t-=this.range.to-this.pos,this.range=this.ranges[++this.rangeIndex],this.pos=this.range.from}return this.pos+=t,this.pos>this.token.lookAhead&&(this.token.lookAhead=this.pos),this.readNext()}setDone(){return this.pos=this.chunkPos=this.end,this.range=this.ranges[this.rangeIndex=this.ranges.length-1],this.chunk="",this.next=-1}reset(t,e){if(e?(this.token=e,e.start=e.lookAhead=t,e.value=e.extended=-1):this.token=Ou,this.pos!=t){if(this.pos=t,t==this.end)return this.setDone(),this;for(;t<this.range.from;)this.range=this.ranges[--this.rangeIndex];for(;t>=this.range.to;)this.range=this.ranges[++this.rangeIndex];t>=this.chunkPos&&t<this.chunkPos+this.chunk.length?this.chunkOff=t-this.chunkPos:(this.chunk="",this.chunkOff=0),this.readNext()}return this}read(t,e){if(t>=this.chunkPos&&e<=this.chunkPos+this.chunk.length)return this.chunk.slice(t-this.chunkPos,e-this.chunkPos);if(t>=this.range.from&&e<=this.range.to)return this.input.read(t,e);let i="";for(let s of this.ranges){if(s.from>=e)break;s.to>t&&(i+=this.input.read(Math.max(s.from,t),Math.min(s.to,e)))}return i}}class Pu{constructor(t,e){this.data=t,this.id=e}token(t,e){!function(t,e,i,s){let n=0,r=1<<s,{parser:o}=i.p,{dialect:h}=o;t:for(;0!=(r&t[n]);){let i=t[n+1];for(let s=n+3;s<i;s+=2)if((t[s+1]&r)>0){let i=t[s];if(h.allows(i)&&(-1==e.token.value||e.token.value==i||o.overrides(i,e.token.value))){e.acceptToken(i);break}}for(let s=e.next,r=0,o=t[n+2];r<o;){let h=r+o>>1,l=i+h+(h<<1),a=t[l],c=t[l+1];if(s<a)o=h;else{if(!(s>=c)){n=t[l+2],e.advance();continue t}r=h+1}}break}}(this.data,t,e,this.id)}}Pu.prototype.contextual=Pu.prototype.fallback=Pu.prototype.extend=!1;class Eu{constructor(t,e={}){this.token=t,this.contextual=!!e.contextual,this.fallback=!!e.fallback,this.extend=!!e.extend}}function Ru(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}const Lu="undefined"!=typeof process&&/\bparse\b/.test(process.env.LOG);let Nu=null;var Iu,Bu;function Vu(t,e,i){let s=t.fullCursor();for(s.moveTo(e);;)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-25)):Math.min(t.length,Math.max(s.from+1,e+25));if(i<0?s.prevSibling():s.nextSibling())break;if(!s.parent())return i<0?0:t.length}}!function(t){t[t.Margin=25]="Margin"}(Iu||(Iu={}));class zu{constructor(t,e){this.fragments=t,this.nodeSet=e,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?Vu(t.tree,t.from+t.offset,1)-t.offset:t.from,this.safeTo=t.openEnd?Vu(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],n=this.index[e];if(n==i.children.length){this.trees.pop(),this.start.pop(),this.index.pop();continue}let r=i.children[n],o=this.start[e]+i.positions[n];if(o>t)return this.nextStart=o,null;if(r instanceof a){if(o==t){if(o<this.safeFrom)return null;let t=o+r.length;if(t<=this.safeTo){let e=r.prop(s.lookAhead);if(!e||t+e<this.fragment.to)return r}}this.index[e]++,o+r.length>=Math.max(this.safeFrom,t)&&(this.trees.push(r),this.start.push(o),this.index.push(0))}else this.index[e]++,this.nextStart=o+r.length}}}class Fu{constructor(t,e){this.stream=e,this.tokens=[],this.mainToken=null,this.actions=[],this.tokens=t.tokenizers.map((t=>new Du))}getActions(t){let e=0,i=null,{parser:s}=t.p,{tokenizers:n}=s,r=s.stateSlot(t.state,3),o=t.curContext?t.curContext.hash:0,h=0;for(let s=0;s<n.length;s++){if(0==(1<<s&r))continue;let l=n[s],a=this.tokens[s];if((!i||l.fallback)&&((l.contextual||a.start!=t.pos||a.mask!=r||a.context!=o)&&(this.updateCachedToken(a,l,t),a.mask=r,a.context=o),a.lookAhead>a.end+25&&(h=Math.max(a.lookAhead,h)),0!=a.value)){let s=e;if(a.extended>-1&&(e=this.addActions(t,a.extended,a.end,e)),e=this.addActions(t,a.value,a.end,e),!l.extend&&(i=a,e>s))break}}for(;this.actions.length>e;)this.actions.pop();return h&&t.setLookAhead(h),i||t.pos!=this.stream.end||(i=new Du,i.value=t.p.parser.eofTerm,i.start=i.end=t.pos,e=this.addActions(t,i.value,i.end,e)),this.mainToken=i,this.actions}getMainToken(t){if(this.mainToken)return this.mainToken;let e=new Du,{pos:i,p:s}=t;return e.start=i,e.end=Math.min(i+1,s.stream.end),e.value=i==s.stream.end?s.parser.eofTerm:0,e}updateCachedToken(t,e,i){if(e.token(this.stream.reset(i.pos,t),i),t.value>-1){let{parser:e}=i.p;for(let s=0;s<e.specialized.length;s++)if(e.specialized[s]==t.value){let n=e.specializers[s](this.stream.read(t.start,t.end),i);if(n>=0&&i.p.parser.dialect.allows(n>>1)){0==(1&n)?t.value=n>>1:t.extended=n>>1;break}}}else t.value=0,t.end=Math.min(i.p.stream.end,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(Uu(o,h+1),e,i,s));break}h=Uu(o,h+2)}o[h]==e&&(s=this.putAction(Uu(o,h+1),e,i,s))}return s}}!function(t){t[t.Distance=5]="Distance",t[t.MaxRemainingPerStep=3]="MaxRemainingPerStep",t[t.MinBufferLengthPrune=200]="MinBufferLengthPrune",t[t.ForceReduceLimit=10]="ForceReduceLimit"}(Bu||(Bu={}));class Hu{constructor(t,e,i,s){this.parser=t,this.input=e,this.ranges=s,this.recovering=0,this.nextStackID=9812,this.minStackPos=0,this.reused=[],this.stoppedAt=null,this.stream=new Tu(e,s),this.tokens=new Fu(t,this.stream),this.topTerm=t.top[1];let{from:n}=s[0];this.stacks=[ku.start(this,t.top[0],n)],this.fragments=i.length&&this.stream.end-n>4*t.bufferLength?new zu(i,t.nodeSet):null}get parsedPos(){return this.minStackPos}advance(){let t,e,i=this.stacks,s=this.minStackPos,n=this.stacks=[];for(let r=0;r<i.length;r++){let o=i[r];for(;;){if(this.tokens.mainToken=null,o.pos>s)n.push(o);else{if(this.advanceStack(o,n,i))continue;{t||(t=[],e=[]),t.push(o);let i=this.tokens.getMainToken(o);e.push(i.value,i.end)}}break}}if(!n.length){let e=t&&function(t){let e=null;for(let i of t){let t=i.p.stoppedAt;(i.pos==i.p.stream.end||null!=t&&i.pos>t)&&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 Lu&&t&&console.log("Stuck with token "+(this.tokens.mainToken?this.parser.getName(this.tokens.mainToken.value):"none")),new SyntaxError("No parse at "+s);this.recovering||(this.recovering=5)}if(this.recovering&&t){let i=this.runRecovery(t,e,n);if(i)return this.stackToTree(i.forceAll())}if(this.recovering){let t=1==this.recovering?1:3*this.recovering;if(n.length>t)for(n.sort(((t,e)=>e.score-t.score));n.length>t;)n.pop();n.some((t=>t.reducePos>s))&&this.recovering--}else if(n.length>1)t:for(let t=0;t<n.length-1;t++){let e=n[t];for(let i=t+1;i<n.length;i++){let s=n[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)){n.splice(t--,1);continue t}n.splice(i--,1)}}}this.minStackPos=n[0].pos;for(let t=1;t<n.length;t++)n[t].pos<this.minStackPos&&(this.minStackPos=n[t].pos);return null}stopAt(t){if(null!=this.stoppedAt&&this.stoppedAt<t)throw new RangeError("Can't move stoppedAt forward");this.stoppedAt=t}advanceStack(t,e,i){let n=t.pos,{parser:r}=this,o=Lu?this.stackID(t)+" -> ":"";if(null!=this.stoppedAt&&n>this.stoppedAt)return t.forceReduce()?t:null;if(this.fragments){let e=t.curContext&&t.curContext.tracker.strict,i=e?t.curContext.hash:0;for(let h=this.fragments.nodeAt(n);h;){let n=this.parser.nodeSet.types[h.type.id]==h.type?r.getGoto(t.state,h.type.id):-1;if(n>-1&&h.length&&(!e||(h.prop(s.contextHash)||0)==i))return t.useNode(h,n),Lu&&console.log(o+this.stackID(t)+` (via reuse of ${r.getName(h.type.id)})`),!0;if(!(h instanceof a)||0==h.children.length||h.positions[0]>0)break;let l=h.children[0];if(!(l instanceof a&&0==h.positions[0]))break;h=l}}let h=r.stateSlot(t.state,4);if(h>0)return t.reduce(h),Lu&&console.log(o+this.stackID(t)+` (via always-reduce ${r.getName(65535&h)})`),!0;let l=this.tokens.getActions(t);for(let s=0;s<l.length;){let h=l[s++],a=l[s++],c=l[s++],u=s==l.length||!i,f=u?t:t.split();if(f.apply(h,a,c),Lu&&console.log(o+this.stackID(f)+` (via ${0==(65536&h)?"shift":`reduce of ${r.getName(65535&h)}`} for ${r.getName(a)} @ ${n}${f==t?"":", split"})`),u)return!0;f.pos>n?e.push(f):i.push(f)}return!1}advanceFully(t,e){let i=t.pos;for(;;){if(!this.advanceStack(t,null,null))return!1;if(t.pos>i)return Wu(t,e),!0}}runRecovery(t,e,i){let s=null,n=!1;for(let r=0;r<t.length;r++){let o=t[r],h=e[r<<1],l=e[1+(r<<1)],a=Lu?this.stackID(o)+" -> ":"";if(o.deadEnd){if(n)continue;if(n=!0,o.restart(),Lu&&console.log(a+this.stackID(o)+" (restarted)"),this.advanceFully(o,i))continue}let c=o.split(),u=a;for(let t=0;c.forceReduce()&&t<10;t++){if(Lu&&console.log(u+this.stackID(c)+" (via force-reduce)"),this.advanceFully(c,i))break;Lu&&(u=this.stackID(c)+" -> ")}for(let t of o.recoverByInsert(h))Lu&&console.log(a+this.stackID(t)+" (via recover-insert)"),this.advanceFully(t,i);this.stream.end>o.pos?(l==o.pos&&(l++,h=0),o.recoverByDelete(h,l),Lu&&console.log(a+this.stackID(o)+` (via recover-delete ${this.parser.getName(h)})`),Wu(o,i)):(!s||s.score<o.score)&&(s=o)}return s}stackToTree(t){return t.close(),a.build({buffer:Mu.create(t),nodeSet:this.parser.nodeSet,topID:this.topTerm,maxBufferLength:this.parser.bufferLength,reused:this.reused,start:this.ranges[0].from,length:t.pos-this.ranges[0].from,minRepeatType:this.parser.minRepeatTerm})}stackID(t){let e=(Nu||(Nu=new WeakMap)).get(t);return e||Nu.set(t,e=String.fromCodePoint(this.nextStackID++)),e+t}}function Wu(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 qu{constructor(t,e,i){this.source=t,this.flags=e,this.disabled=i}allows(t){return!this.disabled||0==this.disabled[t]}}const ju=t=>t;class _u{constructor(t){this.start=t.start,this.shift=t.shift||ju,this.reduce=t.reduce||ju,this.reuse=t.reuse||ju,this.hash=t.hash||(()=>0),this.strict=!1!==t.strict}}class $u extends A{constructor(e){if(super(),this.wrappers=[],13!=e.version)throw new RangeError(`Parser version (${e.version}) doesn't match runtime version (13)`);let i=e.nodeNames.split(" ");this.minRepeatTerm=i.length;for(let t=0;t<e.repeatNodeCount;t++)i.push("");let s=Object.keys(e.topRules).map((t=>e.topRules[t][1])),n=[];for(let t=0;t<i.length;t++)n.push([]);function r(t,e,i){n[t].push([e,e.deserialize(String(i))])}if(e.nodeProps)for(let t of e.nodeProps){let e=t[0];for(let i=1;i<t.length;){let s=t[i++];if(s>=0)r(s,e,t[i++]);else{let n=t[i+-s];for(let o=-s;o>0;o--)r(t[i++],e,n);i++}}}this.nodeSet=new h(i.map(((t,i)=>o.define({name:i>=this.minRepeatTerm?void 0:t,id:i,props:n[i],top:s.indexOf(i)>-1,error:0==i,skipped:e.skippedNodes&&e.skippedNodes.indexOf(i)>-1})))),this.strict=!1,this.bufferLength=t;let l=Ru(e.tokenData);if(this.context=e.context,this.specialized=new Uint16Array(e.specialized?e.specialized.length:0),this.specializers=[],e.specialized)for(let t=0;t<e.specialized.length;t++)this.specialized[t]=e.specialized[t].term,this.specializers[t]=e.specialized[t].get;this.states=Ru(e.states,Uint32Array),this.data=Ru(e.stateData),this.goto=Ru(e.goto),this.maxTerm=e.maxTerm,this.tokenizers=e.tokenizers.map((t=>"number"==typeof t?new Pu(l,t):t)),this.topRules=e.topRules,this.dialects=e.dialects||{},this.dynamicPrecedences=e.dynamicPrecedences||null,this.tokenPrecTable=e.tokenPrec,this.termNames=e.termNames||null,this.maxNode=this.nodeSet.types.length-1,this.dialect=this.parseDialect(),this.top=this.topRules[Object.keys(this.topRules)[0]]}createParse(t,e,i){let s=new Hu(this,t,e,i);for(let n of this.wrappers)s=n(s,t,e,i);return s}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 Uu(i,r+2);break}n=i[r=Uu(i,r+2)]}if(n==e||0==n)return Uu(i,r+1)}return 0}stateSlot(t,e){return this.states[6*t+e]}stateFlag(t,e){return(this.stateSlot(t,0)&e)>0}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=Uu(this.data,i+2)}if(e==Uu(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=Uu(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=Gu(this.data,this.tokenPrecTable,e);return i<0||Gu(this.data,this.tokenPrecTable,t)<i}configure(t){let e=Object.assign(Object.create($u.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.contextTracker&&(e.context=t.contextTracker),t.dialect&&(e.dialect=this.parseDialect(t.dialect)),null!=t.strict&&(e.strict=t.strict),t.wrap&&(e.wrappers=e.wrappers.concat(t.wrap)),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 topNode(){return this.nodeSet.types[this.top[1]]}dynamicPrecedence(t){let e=this.dynamicPrecedences;return null==e?0:e[t]||0}parseDialect(t){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 new qu(t,i,s)}static deserialize(t){return new $u(t)}}function Uu(t,e){return t[e]|t[e+1]<<16}function Gu(t,e,i){for(let s,n=e;65535!=(s=t[n]);n++)if(s==i)return n-e;return-1}async function Ku(){return lh.define((await import("./legacy.js").then((function(t){return t.c}))).clojure)}async function Ju(){return lh.define((await import("./legacy.js").then((function(t){return t.a}))).coffeeScript)}function Xu(){return import("./cpp.js")}function Yu(){return import("./css.js")}function Qu(){return import("./html.js")}function Zu(){return import("./java.js")}function tf(){return import("./javascript.js")}function ef(){return import("./json.js")}function sf(){return import("./markdown.js")}function nf(){return import("./php.js")}function rf(){return import("./python.js")}async function of(){return lh.define((await import("./legacy.js").then((function(t){return t.s}))).shell)}function hf(){return import("./wast.js")}function lf(){return import("./xml.js")}export{Ma as $,Ku as A,Ju as B,_u as C,Xu as D,Eu as E,Yu as F,Qu as G,Zu as H,tf as I,ef as J,sf as K,$u as L,nf as M,s as N,rf as O,A as P,of as Q,hf as R,lf as S,a as T,sl as U,Ol as V,Dl as W,Mh as X,El as Y,Vl as Z,Wl as _,jr as a,ga as a0,pa as a1,nc as a2,sc as a3,Da as a4,Ia as a5,Na as a6,rc as a7,oc as a8,Uc as a9,Mt as aA,xt as aB,te as aC,Zt as aD,Rt as aE,ee as aF,lh as aG,oh as aH,ct as aI,it as aJ,Ch as aK,xh as aL,zi as aM,gr as aN,Er as aO,Cr as aP,zr as aQ,Br as aR,as as aS,ws as aT,Bi as aU,v as aV,Xc as aa,jc as ab,wc as ac,dc as ad,bc as ae,Rc as af,Io as ag,Bo as ah,Co as ai,su as aj,vu as ak,ou as al,lu as am,ru as an,hu as ao,yo as ap,so as aq,ta as ar,ge as as,ve as at,ye as au,xu as av,Yt as aw,Qt as ax,Ft as ay,fe as az,xo as b,vo as c,ko as d,to as e,wo as f,_r as g,tr as h,lo as i,kt as j,xl as k,go as l,Th as m,Oh as n,o,M as p,h as q,Fr as r,To as s,nh as t,Wr as u,Vt as v,cr as w,Hr as x,eo as y,Gr as z};
|
|
1
|
+
const t=1024;let e=0;class i{constructor(t,e){this.from=t,this.to=e}}class s{constructor(t={}){this.id=e++,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=o.match(t)),e=>{let i=t(e);return void 0===i?null:[this,i]}}}s.closedBy=new s({deserialize:t=>t.split(" ")}),s.openedBy=new s({deserialize:t=>t.split(" ")}),s.group=new s({deserialize:t=>t.split(" ")}),s.contextHash=new s({perNode:!0}),s.lookAhead=new s({perNode:!0}),s.mounted=new s({perNode:!0});class n{constructor(t,e,i){this.tree=t,this.overlay=e,this.parser=i}}const r=Object.create(null);class o{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):r,i=(t.top?1:0)|(t.skipped?2:0)|(t.error?4:0)|(null==t.name?8:0),s=new o(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(s.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(s.group),n=-1;n<(i?i.length:0);n++){let s=e[n<0?t.name:i[n]];if(s)return s}}}}o.none=new o("",Object.create(null),0,8);class h{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)),s[t[0].id]=t[1])}e.push(s?new o(i.name,s,i.id,i.flags):i)}return new h(e)}}const l=new WeakMap;class a{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(s.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,e=0){let i=null!=t&&l.get(this)||this.topNode,s=new w(i);return null!=t&&(s.moveTo(t,e),l.set(this,s._tree)),s}fullCursor(){return new w(this.topNode,1)}get topNode(){return new p(this,0,0,null)}resolve(t,e=0){return this.cursor(t,e).node}resolveInner(t,e=0){let i=this.topNode;for(;;){let s=i.enter(t,e);if(!s)return i;i=s}}iterate(t){let{enter:e,leave:i,from:s=0,to:n=this.length}=t;for(let t=this.cursor(),r=()=>t.node;;){let o=!1;if(t.from<=n&&t.to>=s&&(t.type.isAnonymous||!1!==e(t.type,t.from,t.to,r))){if(t.firstChild())continue;t.type.isAnonymous||(o=!0)}for(;o&&i&&i(t.type,t.from,t.to,r),o=t.type.isAnonymous,!t.nextSibling();){if(!t.parent())return;o=!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:k(this.type,this.children,this.positions,0,this.children.length,0,this.length,((t,e,i)=>new a(this.type,t,e,i,this.propValues)),t.makeTree||((t,e,i)=>new a(o.none,t,e,i)))}static build(e){return function(e){var i;let{buffer:n,nodeSet:r,maxBufferLength:o=t,reused:h=[],minRepeatType:l=r.types.length}=e,f=Array.isArray(n)?new c(n,n.length):n,d=r.types,p=0,g=0;function m(t,e,i,s,n){let{id:a,start:c,end:S,size:A}=f,C=g;for(;A<0;){if(f.next(),-1==A){let e=h[a];return i.push(e),void s.push(c-t)}if(-3==A)return void(p=a);if(-4==A)return void(g=a);throw new RangeError(`Unrecognized record size: ${A}`)}let M,D,T=d[a],O=c-t;if(S-c<=o&&(D=y(f.pos-e,n))){let e=new Uint16Array(D.size-D.skip),i=f.pos-D.size,s=e.length;for(;f.pos>i;)s=x(D.start,e,s);M=new u(e,S-D.start,r),O=D.start-t}else{let t=f.pos-A;f.next();let e=[],i=[],s=a>=l?a:-1,n=0,r=S;for(;f.pos>t;)s>=0&&f.id==s&&f.size>=0?(f.end<=r-o&&(w(e,i,c,n,f.end,r,s,C),n=e.length,r=f.end),f.next()):m(c,t,e,i,s);if(s>=0&&n>0&&n<e.length&&w(e,i,c,n,c,r,s,C),e.reverse(),i.reverse(),s>-1&&n>0){let t=v(T);M=k(T,e,i,0,e.length,0,S-c,t,t)}else M=b(T,e,i,S-c,C-S)}i.push(M),s.push(O)}function v(t){return(e,i,n)=>{let r,o,h=0,l=e.length-1;if(l>=0&&(r=e[l])instanceof a){if(!l&&r.type==t&&r.length==n)return r;(o=r.prop(s.lookAhead))&&(h=i[l]+r.length+o)}return b(t,e,i,n,h)}}function w(t,e,i,s,n,o,h,l){let a=[],c=[];for(;t.length>s;)a.push(t.pop()),c.push(e.pop()+i-n);t.push(b(r.types[h],a,c,o-n,l-o)),e.push(n-i)}function b(t,e,i,n,r=0,o){if(p){let t=[s.contextHash,p];o=o?[t].concat(o):[t]}if(r>25){let t=[s.lookAhead,r];o=o?[t].concat(o):[t]}return new a(t,e,i,n,o)}function y(t,e){let i=f.fork(),s=0,n=0,r=0,h=i.end-o,a={size:0,start:0,skip:0};t:for(let o=i.pos-t;i.pos>o;){let t=i.size;if(i.id==e&&t>=0){a.size=s,a.start=n,a.skip=r,r+=4,s+=4,i.next();continue}let c=i.pos-t;if(t<0||c<o||i.start<h)break;let u=i.id>=l?4:0,f=i.start;for(i.next();i.pos>c;){if(i.size<0){if(-3!=i.size)break t;u+=4}else i.id>=l&&(u+=4);i.next()}n=f,s+=t,r+=u}return(e<0||s==t)&&(a.size=s,a.start=n,a.skip=r),a.size>4?a:void 0}function x(t,e,i){let{id:s,start:n,end:r,size:o}=f;if(f.next(),o>=0&&s<l){let h=i;if(o>4){let s=f.pos-(o-4);for(;f.pos>s;)i=x(t,e,i)}e[--i]=h,e[--i]=r-t,e[--i]=n-t,e[--i]=s}else-3==o?p=s:-4==o&&(g=s);return i}let S=[],A=[];for(;f.pos>0;)m(e.start||0,e.bufferStart||0,S,A,-1);let C=null!==(i=e.length)&&void 0!==i?i:S.length?A[0]+S[0].length:0;return new a(d[e.topID],S.reverse(),A.reverse(),C)}(e)}}a.empty=new a(o.none,[],[],0);class c{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 c(this.buffer,this.index)}}class u{constructor(t,e,i){this.buffer=t,this.length=e,this.set=i}get type(){return o.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&&!(f(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 u(r,s-i,this.set)}}function f(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 d(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}class p{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 from(){return this._from}get to(){return this._from+this.node.length}nextChild(t,e,i,n,r=0){for(let o=this;;){for(let{children:h,positions:l}=o.node,a=e>0?h.length:-1;t!=a;t+=e){let a=h[t],c=l[t]+o._from;if(f(n,i,c,c+a.length))if(a instanceof u){if(2&r)continue;let s=a.findChild(0,a.buffer.length,e,i-c,n);if(s>-1)return new v(new m(o,a,t,c),null,s)}else if(1&r||!a.type.isAnonymous||b(a)){let h;if(a.props&&(h=a.prop(s.mounted))&&!h.overlay)return new p(h.tree,c,t,o);let l=new p(a,c,t,o);return 1&r||!l.type.isAnonymous?l:l.nextChild(e<0?a.children.length-1:0,e,i,n)}}if(1&r||!o.type.isAnonymous)return null;if(t=o.index>=0?o.index+e:e<0?-1:o._parent.node.children.length,o=o._parent,!o)return null}}get firstChild(){return this.nextChild(0,1,0,4)}get lastChild(){return this.nextChild(this.node.children.length-1,-1,0,4)}childAfter(t){return this.nextChild(0,1,t,2)}childBefore(t){return this.nextChild(this.node.children.length-1,-1,t,-2)}enter(t,e,i=!0,n=!0){let r;if(i&&(r=this.node.prop(s.mounted))&&r.overlay){let i=t-this.from;for(let{from:t,to:s}of r.overlay)if((e>0?t<=i:t<i)&&(e<0?s>=i:s>i))return new p(r.tree,r.overlay[0].from+this.from,-1,this)}return this.nextChild(0,1,t,e,n?0:2)}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}get cursor(){return new w(this)}get tree(){return this.node}toTree(){return this.node}resolve(t,e=0){return this.cursor.moveTo(t,e).node}enterUnfinishedNodesBefore(t){return d(this,t)}getChild(t,e=null,i=null){let s=g(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return g(this,t,e,i)}toString(){return this.node.toString()}}function g(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 m{constructor(t,e,i,s){this.parent=t,this.buffer=e,this.index=i,this.start=s}}class v{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 v(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,s=!0){if(!s)return null;let{buffer:n}=this.context,r=n.findChild(this.index+4,n.buffer[this.index+3],e>0?1:-1,t-this.context.start,e);return r<0?null:new v(this.context,this,r)}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 v(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 v(this.context,this._parent,t.findChild(e,this.index,-1,0,4))}get cursor(){return new w(this)}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 a(this.type,t,e,this.to-this.from)}resolve(t,e=0){return this.cursor.moveTo(t,e).node}enterUnfinishedNodesBefore(t){return d(this,t)}toString(){return this.context.buffer.childString(this.index)}getChild(t,e=null,i=null){let s=g(this,t,e,i);return s.length?s[0]:null}getChildren(t,e=null,i=null){return g(this,t,e,i)}}class w{constructor(t,e=0){if(this.mode=e,this.buffer=null,this.stack=[],this.index=0,this.bufferNode=null,t instanceof p)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 p?(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.node.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=!0,s=!0){return this.buffer?!!s&&this.enterChild(1,t,e):this.yield(this._tree.enter(t,e,i,s))}parent(){if(!this.buffer)return this.yieldNode(1&this.mode?this._tree._parent:this._tree.parent);if(this.stack.length)return this.yieldBuf(this.stack.pop());let t=1&this.mode?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.node.children.length;s!=n;s+=t){let t=i.node.children[s];if(1&this.mode||t instanceof u||!t.type.isAnonymous||b(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 v(this.buffer,e,this.stack[t]);return this.bufferNode=new v(this.buffer,e,this.index)}get tree(){return this.buffer?null:this._tree.node}}function b(t){return t.children.some((t=>t instanceof u||!t.type.isAnonymous||b(t)))}const y=new WeakMap;function x(t,e){if(!t.isAnonymous||e instanceof u||e.type!=t)return 1;let i=y.get(e);return null==i&&(i=e.children.reduce(((e,i)=>e+x(t,i)),1),y.set(e,i)),i}function k(t,e,i,s,n,r,o,h,l){let a=0;for(let i=s;i<n;i++)a+=x(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=x(t,i[a]);for(a++;a<o;a++){let e=x(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(k(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 S{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 S(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 S(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 A{startParse(t,e,s){return"string"==typeof t&&(t=new C(t)),s=s?s.length?s.map((t=>new i(t.from,t.to))):[new i(0,0)]:[new i(0,t.length)],this.createParse(t,e||[],s)}parse(t,e,i){let s=this.startParse(t,e,i);for(;;){let t=s.advance();if(t)return t}}}class C{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)}}function M(t){return(e,i,s,n)=>new O(e,t,i,s,n)}class D{constructor(t,e,i,s){this.parser=t,this.parse=e,this.overlay=i,this.target=s}}class T{constructor(t,e,i,s,n,r,o){this.parser=t,this.predicate=e,this.mounts=i,this.index=s,this.start=n,this.target=r,this.prev=o,this.depth=0,this.ranges=[]}}class O{constructor(t,e,i,s,n){this.nest=e,this.input=i,this.fragments=s,this.ranges=n,this.inner=[],this.innerDone=0,this.baseTree=null,this.stoppedAt=null,this.baseParse=t}advance(){if(this.baseParse){let t=this.baseParse.advance();if(!t)return null;this.baseParse=null,this.baseTree=t,this.startInner()}if(this.innerDone==this.inner.length)return this.baseTree;let t=this.inner[this.innerDone],e=t.parse.advance();if(e){this.innerDone++;let i=Object.assign(Object.create(null),t.target.props);i[s.mounted.id]=new n(e,t.overlay,t.parser),t.target.props=i}return null}get parsedPos(){if(this.baseParse)return 0;let t=this.inner[this.innerDone];return t?t.parse.parsedPos:this.input.length}stopAt(t){if(this.stoppedAt=t,this.baseParse)this.baseParse.stopAt(t);else for(let e=this.innerDone;e<this.inner.length;e++)this.inner[e].parse.stopAt(t)}startInner(){let t=new N(this.fragments),e=null,s=null,n=new w(new p(this.baseTree,this.ranges[0].from,0,null),1);t:for(let r,o;;){let h,l=!0;if(t.hasNode(n)){if(e){let t=e.mounts.find((t=>t.frag.from<=n.from&&t.frag.to>=n.to&&t.mount.overlay));if(t)for(let i of t.mount.overlay){let s=i.from+t.pos,r=i.to+t.pos;s>=n.from&&r<=n.to&&e.ranges.push({from:s,to:r})}}l=!1}else if(s&&(o=P(s.ranges,n.from,n.to)))l=2!=o;else if(!n.type.isAnonymous&&n.from<n.to&&(r=this.nest(n,this.input))){n.tree||R(n);let o=t.findMounts(n.from,r.parser);if("function"==typeof r.overlay)e=new T(r.parser,r.overlay,o,this.inner.length,n.from,n.tree,e);else{let t=I(this.ranges,r.overlay||[new i(n.from,n.to)]);t.length&&this.inner.push(new D(r.parser,r.parser.startParse(this.input,V(o,t),t),r.overlay?r.overlay.map((t=>new i(t.from-n.from,t.to-n.from))):null,n.tree)),r.overlay?t.length&&(s={ranges:t,depth:0,prev:s}):l=!1}}else e&&(h=e.predicate(n))&&(!0===h&&(h=new i(n.from,n.to)),h.from<h.to&&e.ranges.push(h));if(l&&n.firstChild())e&&e.depth++,s&&s.depth++;else for(;!n.nextSibling();){if(!n.parent())break t;if(e&&!--e.depth){let t=I(this.ranges,e.ranges);t.length&&this.inner.splice(e.index,0,new D(e.parser,e.parser.startParse(this.input,V(e.mounts,t),t),e.ranges.map((t=>new i(t.from-e.start,t.to-e.start))),e.target)),e=e.prev}s&&!--s.depth&&(s=s.prev)}}}}function P(t,e,i){for(let s of t){if(s.from>=i)break;if(s.to>e)return s.from<=e&&s.to>=i?2:1}return 0}function E(t,e,i,s,n,r){if(e<i){let o=t.buffer[e+1],h=t.buffer[i-2];s.push(t.slice(e,i,o,h)),n.push(o-r)}}function R(t){let{node:e}=t,i=0;do{t.parent(),i++}while(!t.tree);let s=0,n=t.tree,r=0;for(;r=n.positions[s]+t.from,!(r<=e.from&&r+n.children[s].length>=e.to);s++);let h=n.children[s],l=h.buffer;n.children[s]=function t(i,s,n,o){let c=i;for(;l[c+2]+r<=e.from;)c=l[c+3];let u=[],f=[];E(h,i,c,u,f,o);let d=l[c+1]+r==e.from&&l[c+2]+r==e.to&&l[c]==e.type.id;u.push(d?e.toTree():t(c+4,l[c+3],h.set.types[l[c]],l[c+1])),f.push(l[c+1]-o),E(h,l[c+3],s,u,f,o);let p=u.length-1;return new a(n,u,f,f[p]+u[p].length)}(0,l.length,o.none,0);for(let s=0;s<=i;s++)t.childAfter(e.from)}class L{constructor(t,e){this.offset=e,this.done=!1,this.cursor=t.fullCursor()}moveTo(t){let{cursor:e}=this,i=t-this.offset;for(;!this.done&&e.from<i;)e.to>=t&&e.enter(i,1,!1,!1)||e.next(!1)||(this.done=!0)}hasNode(t){if(this.moveTo(t.from),!this.done&&this.cursor.from+this.offset==t.from&&this.cursor.tree)for(let e=this.cursor.tree;;){if(e==t.tree)return!0;if(!(e.children.length&&0==e.positions[0]&&e.children[0]instanceof a))break;e=e.children[0]}return!1}}class N{constructor(t){if(this.fragments=t,this.fragI=0,t.length){let e=this.curFrag=t[0];this.inner=new L(e.tree,-e.offset)}else this.curFrag=this.inner=null}hasNode(t){for(;this.curFrag&&t.from>=this.curFrag.to;)this.nextFrag();return this.curFrag&&this.curFrag.from<=t.from&&this.curFrag.to>=t.to&&this.inner.hasNode(t)}nextFrag(){if(this.fragI++,this.fragI==this.fragments.length)this.curFrag=this.inner=null;else{let t=this.curFrag=this.fragments[this.fragI];this.inner=new L(t.tree,-t.offset)}}findMounts(t,e){var i;let n=[];if(this.inner){this.inner.cursor.moveTo(t,1);for(let t=this.inner.cursor.node;t;t=t.parent){let r=null===(i=t.tree)||void 0===i?void 0:i.prop(s.mounted);if(r&&r.parser==e)for(let e=this.fragI;e<this.fragments.length;e++){let i=this.fragments[e];if(i.from>=t.to)break;i.tree==this.curFrag.tree&&n.push({frag:i,pos:t.from-i.offset,mount:r})}}}return n}}function I(t,e){let s=null,n=e;for(let r=1,o=0;r<t.length;r++){let h=t[r-1].to,l=t[r].from;for(;o<n.length;o++){let t=n[o];if(t.from>=l)break;t.to<=h||(s||(n=s=e.slice()),t.from<h?(s[o]=new i(t.from,h),t.to>l&&s.splice(o+1,0,new i(l,t.to))):t.to>l?s[o--]=new i(l,t.to):s.splice(o--,1))}}return n}function B(t,e,s,n){let r=0,o=0,h=!1,l=!1,a=-1e9,c=[];for(;;){let u=r==t.length?1e9:h?t[r].to:t[r].from,f=o==e.length?1e9:l?e[o].to:e[o].from;if(h!=l){let t=Math.max(a,s),e=Math.min(u,f,n);t<e&&c.push(new i(t,e))}if(a=Math.min(u,f),1e9==a)break;u==a&&(h?(h=!1,r++):h=!0),f==a&&(l?(l=!1,o++):l=!0)}return c}function V(t,e){let s=[];for(let{pos:n,mount:r,frag:o}of t){let t=n+(r.overlay?r.overlay[0].from:0),h=t+r.tree.length,l=Math.max(o.from,t),a=Math.min(o.to,h);if(r.overlay){let h=B(e,r.overlay.map((t=>new i(t.from+n,t.to+n))),l,a);for(let e=0,i=l;;e++){let n=e==h.length,l=n?a:h[e].from;if(l>i&&s.push(new S(i,l,r.tree,-t,o.from>=i,o.to<=l)),n)break;i=h[e].to}}else s.push(new S(l,a,r.tree,-t,o.from>=t,o.to<=h))}return s}const H="undefined"==typeof Symbol?"__ͼ":Symbol.for("ͼ"),z="undefined"==typeof Symbol?"__styleSet"+Math.floor(1e8*Math.random()):Symbol("styleSet"),F="undefined"!=typeof globalThis?globalThis:"undefined"!=typeof window?window:{};class W{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=F[H]||1;return F[H]=t+1,"ͼ"+t.toString(36)}static mount(t,e){(t[z]||new j(t)).mount(Array.isArray(e)?e:[e])}}let q=null;class j{constructor(t){if(!t.head&&t.adoptedStyleSheets&&"undefined"!=typeof CSSStyleSheet){if(q)return t.adoptedStyleSheets=[q.sheet].concat(t.adoptedStyleSheets),t[z]=q;this.sheet=new CSSStyleSheet,t.adoptedStyleSheets=[this.sheet].concat(t.adoptedStyleSheets),q=this}else{this.styleTag=(t.ownerDocument||t).createElement("style");let e=t.head||t;e.insertBefore(this.styleTag,e.firstChild)}this.modules=[],t[z]=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}}}let _="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<_.length;t++)_[t]+=_[t-1];function $(t){for(let e=1;e<_.length;e+=2)if(_[e]>t)return _[e-1]<=t;return!1}function U(t){return t>=127462&&t<=127487}function G(t,e,i=!0){return(i?K:J)(t,e)}function K(t,e){if(e==t.length)return e;e&&X(t.charCodeAt(e))&&Y(t.charCodeAt(e-1))&&e--;let i=Q(t,e);for(e+=tt(i);e<t.length;){let s=Q(t,e);if(8205==i||8205==s||$(s))e+=tt(s),i=s;else{if(!U(s))break;{let i=0,s=e-2;for(;s>=0&&U(Q(t,s));)i++,s-=2;if(i%2==0)break;e+=2}}}return e}function J(t,e){for(;e>0;){let i=K(t,e-2);if(i<e)return i;e--}return 0}function X(t){return t>=56320&&t<57344}function Y(t){return t>=55296&&t<56320}function Q(t,e){let i=t.charCodeAt(e);if(!Y(i)||e+1==t.length)return i;let s=t.charCodeAt(e+1);return X(s)?s-56320+(i-55296<<10)+65536:i}function Z(t){return t<=65535?String.fromCharCode(t):(t-=65536,String.fromCharCode(55296+(t>>10),56320+(1023&t)))}function tt(t){return t<65536?1:2}function et(t,e,i=t.length){let s=0;for(let n=0;n<i;)9==t.charCodeAt(n)?(s+=e-s%e,n++):(s++,n=G(t,n));return s}class it{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,i){let s=[];return this.decompose(0,t,s,2),i.length&&i.decompose(0,i.length,s,3),this.decompose(e,this.length,s,1),nt.from(s,this.length-(e-t)+i.length)}append(t){return this.replace(this.length,this.length,t)}slice(t,e=this.length){let i=[];return this.decompose(t,e,i,0),nt.from(i,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 ht(this),n=new ht(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 ht(this,t)}iterRange(t,e=this.length){return new lt(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 at(i)}toString(){return this.sliceString(0)}toJSON(){let t=[];return this.flatten(t),t}static of(t){if(0==t.length)throw new RangeError("A document must have at least one line");return 1!=t.length||t[0]?t.length<=32?new st(t):nt.from(st.split(t,[])):it.empty}}class st extends it{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 ct(s,o,i,r);s=o+1,i++}}decompose(t,e,i,s){let n=t<=0&&e>=this.length?this:new st(ot(this.text,t,e),Math.min(e,this.length)-Math.max(0,t));if(1&s){let t=i.pop(),e=rt(n.text,t.text.slice(),0,n.length);if(e.length<=32)i.push(new st(e,t.length+n.length));else{let t=e.length>>1;i.push(new st(e.slice(0,t)),new st(e.slice(t)))}}else i.push(n)}replace(t,e,i){if(!(i instanceof st))return super.replace(t,e,i);let s=rt(this.text,rt(i.text,ot(this.text,0,t)),e),n=this.length+i.length-(e-t);return s.length<=32?new st(s,n):nt.from(st.split(s,[]),n)}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,e){let i=[],s=-1;for(let n of t)i.push(n),s+=n.length+1,32==i.length&&(e.push(new st(i,s)),i=[],s=-1);return s>-1&&e.push(new st(i,s)),e}}class nt extends it{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,i){if(i.lines<this.lines)for(let s=0,n=0;s<this.children.length;s++){let r=this.children[s],o=n+r.length;if(t>=n&&e<=o){let h=r.replace(t-n,e-n,i),l=this.lines-r.lines+h.lines;if(h.lines<l>>4&&h.lines>l>>6){let n=this.children.slice();return n[s]=h,new nt(n,this.length-(e-t)+i.length)}return super.replace(n,o,h)}n=o+1}return super.replace(t,e,i)}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 nt))return 0;let i=0,[s,n,r,o]=e>0?[0,0,this.children.length,t.children.length]:[this.children.length-1,t.children.length-1,-1,-1];for(;;s+=e,n+=e){if(s==r||n==o)return i;let h=this.children[s],l=t.children[n];if(h!=l)return i+h.scanIdentical(l,e);i+=h.length+1}}static from(t,e=t.reduce(((t,e)=>t+e.length+1),-1)){let i=0;for(let e of t)i+=e.lines;if(i<32){let i=[];for(let e of t)e.flatten(i);return new st(i,e)}let s=Math.max(32,i>>5),n=s<<1,r=s>>1,o=[],h=0,l=-1,a=[];function c(t){let e;if(t.lines>n&&t instanceof nt)for(let e of t.children)c(e);else t.lines>r&&(h>r||!h)?(u(),o.push(t)):t instanceof st&&h&&(e=a[a.length-1])instanceof st&&t.lines+e.lines<=32?(h+=t.lines,l+=t.length+1,a[a.length-1]=new st(e.text.concat(t.text),e.length+1+t.length)):(h+t.lines>s&&u(),h+=t.lines,l+=t.length+1,a.push(t))}function u(){0!=h&&(o.push(1==a.length?a[0]:nt.from(a,l)),l=-1,h=a.length=0)}for(let e of t)c(e);return u(),1==o.length?o[0]:new nt(o,e)}}function rt(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 ot(t,e,i){return rt(t,[""],e,i)}it.empty=new st([""],0);class ht{constructor(t,e=1){this.dir=e,this.done=!1,this.lineBreak=!1,this.value="",this.nodes=[t],this.offsets=[e>0?1:(t instanceof st?t.text.length:t.children.length)<<1]}nextInner(t,e){for(this.done=this.lineBreak=!1;;){let i=this.nodes.length-1,s=this.nodes[i],n=this.offsets[i],r=n>>1,o=s instanceof st?s.text.length:s.children.length;if(r==(e>0?o:0)){if(0==i)return this.done=!0,this.value="",this;e>0&&this.offsets[i-1]++,this.nodes.pop(),this.offsets.pop()}else if((1&n)==(e>0?0:1)){if(this.offsets[i]+=e,0==t)return this.lineBreak=!0,this.value="\n",this;t--}else if(s instanceof st){let n=s.text[r+(e<0?-1:0)];if(this.offsets[i]+=e,n.length>Math.max(0,t))return this.value=0==t?n:e>0?n.slice(t):n.slice(0,n.length-t),this;t-=n.length}else{let n=s.children[r+(e<0?-1:0)];t>n.length?(t-=n.length,this.offsets[i]+=e):(e<0&&this.offsets[i]--,this.nodes.push(n),this.offsets.push(e>0?1:(n instanceof st?n.text.length:n.children.length)<<1))}}}next(t=0){return t<0&&(this.nextInner(-t,-this.dir),t=this.value.length),this.nextInner(t,this.dir)}}class lt{constructor(t,e,i){this.value="",this.done=!1,this.cursor=new ht(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 at{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&&(it.prototype[Symbol.iterator]=function(){return this.iter()},ht.prototype[Symbol.iterator]=lt.prototype[Symbol.iterator]=at.prototype[Symbol.iterator]=function(){return this});class ct{constructor(t,e,i,s){this.from=t,this.to=e,this.number=i,this.text=s}get length(){return this.to-this.from}}const ut=/\r\n?|\n/;var ft=function(t){return t[t.Simple=0]="Simple",t[t.TrackDel=1]="TrackDel",t[t.TrackBefore=2]="TrackBefore",t[t.TrackAfter=3]="TrackAfter",t}(ft||(ft={}));class dt{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){vt(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 dt(t)}composeDesc(t){return this.empty?t:t.empty?this:bt(this,t)}mapDesc(t,e=!1){return t.empty?this:wt(this,t,e)}mapPos(t,e=-1,i=ft.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!=ft.Simple&&l>=t&&(i==ft.TrackDel&&s<t&&l>t||i==ft.TrackBefore&&s<t||i==ft.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 dt(t)}}class pt extends dt{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 vt(this,((e,i,s,n,r)=>t=t.replace(s,s+(i-e),r)),!1),t}mapDesc(t,e=!1){return wt(this,t,e,!0)}invert(t){let e=this.sections.slice(),i=[];for(let s=0,n=0;s<e.length;s+=2){let r=e[s],o=e[s+1];if(o>=0){e[s]=o,e[s+1]=r;let h=s>>1;for(;i.length<h;)i.push(it.empty);i.push(r?t.slice(n,n+r):it.empty)}n+=r}return new pt(e,i)}compose(t){return this.empty?t:t.empty?this:bt(this,t,!0)}map(t,e=!1){return t.empty?this:wt(this,t,e,!0)}iterChanges(t,e=!1){vt(this,t,e)}get desc(){return new dt(this.sections)}filter(t){let e=[],i=[],s=[],n=new yt(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);gt(s,t,-1);let r=-1==n.ins?-1:0==n.off?n.ins:0;gt(e,t,r),r>0&&mt(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);gt(e,t,-1),gt(s,t,-1==n.ins?-1:0==n.off?n.ins:0),n.forward(t),o+=t}}return{changes:new pt(e,i),filtered:new dt(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(t,e,i){let s=[],n=[],r=0,o=null;function h(t=!1){if(!t&&!s.length)return;r<e&>(s,e-r,-1);let i=new pt(s,n);o=o?o.compose(i.map(o)):i,s=[],n=[],r=0}return function t(l){if(Array.isArray(l))for(let e of l)t(e);else if(l instanceof pt){if(l.length!=e)throw new RangeError(`Mismatched change set length (got ${l.length}, expected ${e})`);h(),o=o?o.compose(l.map(o)):l}else{let{from:t,to:o=t,insert:a}=l;if(t>o||t<0||o>e)throw new RangeError(`Invalid change range ${t} to ${o} (in doc of length ${e})`);let c=a?"string"==typeof a?it.of(a.split(i||ut)):a:it.empty,u=c.length;if(t==o&&0==u)return;t<r&&h(),t>r&>(s,t-r,-1),gt(s,o-t,u),mt(n,s,c),r=o}}(t),h(!o),o}static empty(t){return new pt(t?[t,-1]:[],[])}static fromJSON(t){if(!Array.isArray(t))throw new RangeError("Invalid JSON representation of ChangeSet");let e=[],i=[];for(let s=0;s<t.length;s++){let n=t[s];if("number"==typeof n)e.push(n,-1);else{if(!Array.isArray(n)||"number"!=typeof n[0]||n.some(((t,e)=>e&&"string"!=typeof t)))throw new RangeError("Invalid JSON representation of ChangeSet");if(1==n.length)e.push(n[0],0);else{for(;i.length<s;)i.push(it.empty);i[s]=it.of(n.slice(1)),e.push(n[0],i[s].length)}}}return new pt(e,i)}}function gt(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 mt(t,e,i){if(0==i.length)return;let s=e.length-2>>1;if(s<t.length)t[t.length-1]=t[t.length-1].append(i);else{for(;t.length<s;)t.push(it.empty);t.push(i)}}function vt(t,e,i){let s=t.inserted;for(let n=0,r=0,o=0;o<t.sections.length;){let h=t.sections[o++],l=t.sections[o++];if(l<0)n+=h,r+=h;else{let a=n,c=r,u=it.empty;for(;a+=h,c+=l,l&&s&&(u=u.append(s[o-2>>1])),!(i||o==t.sections.length||t.sections[o+1]<0);)h=t.sections[o++],l=t.sections[o++];e(n,a,r,c,u),n=a,r=c}}}function wt(t,e,i,s=!1){let n=[],r=s?[]:null,o=new yt(t),h=new yt(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),gt(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(gt(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 pt(n,r):new dt(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}}gt(n,i,o.ins),r&&mt(r,n,o.text),t=s,o.next()}}}function bt(t,e,i=!1){let s=[],n=i?[]:null,r=new yt(t),o=new yt(e);for(let t=!1;;){if(r.done&&o.done)return n?new pt(s,n):new dt(s);if(0==r.ins)gt(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;gt(s,e,i,t),n&&i&&mt(n,s,o.text)}else-1==o.ins?(gt(s,r.off?0:r.len,e,t),n&&mt(n,s,r.textBit(e))):(gt(s,r.off?0:r.len,o.off?0:o.ins,t),n&&!o.off&&mt(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 gt(s,0,o.ins,t),n&&mt(n,s,o.text),o.next()}}class yt{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:t}=this.set,e=this.i-2>>1;return e>=t.length?it.empty:t[e]}textBit(t){let{inserted:e}=this.set,i=this.i-2>>1;return i>=e.length&&!t?it.empty:e[i].slice(this.off,null==t?void 0:this.off+t)}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 xt{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=t.mapPos(this.from,e),s=t.mapPos(this.to,e);return i==this.from&&s==this.to?this:new xt(i,s,this.flags)}extend(t,e=t){if(t<=this.anchor&&e>=this.anchor)return kt.range(t,e);let i=Math.abs(t-this.anchor)>Math.abs(e-this.anchor)?t:e;return kt.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 kt.range(t.anchor,t.head)}}class kt{constructor(t,e=0){this.ranges=t,this.mainIndex=e}map(t,e=-1){return t.empty?this:kt.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 kt([this.main])}addRange(t,e=!0){return kt.create([t].concat(this.ranges),e?0:this.mainIndex+1)}replaceRange(t,e=this.mainIndex){let i=this.ranges.slice();return i[e]=t,kt.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 kt(t.ranges.map((t=>xt.fromJSON(t))),t.main)}static single(t,e=t){return new kt([kt.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 St(t.slice(),e);i=n.to}return new kt(t,e)}static cursor(t,e=0,i,s){return new xt(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 xt(e,t,16|s):new xt(t,e,s)}}function St(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?kt.range(o,r):kt.range(r,o))}}return new kt(t,e)}function At(t,e){for(let i of t.ranges)if(i.to>e)throw new RangeError("Selection points outside of document")}let Ct=0;class Mt{constructor(t,e,i,s,n){this.combine=t,this.compareInput=e,this.compare=i,this.isStatic=s,this.extensions=n,this.id=Ct++,this.default=t([])}static define(t={}){return new Mt(t.combine||(t=>t),t.compareInput||((t,e)=>t===e),t.compare||(t.combine?(t,e)=>t===e:Dt),!!t.static,t.enables)}of(t){return new Tt([],this,0,t)}compute(t,e){if(this.isStatic)throw new Error("Can't compute a static facet");return new Tt(t,this,1,e)}computeN(t,e){if(this.isStatic)throw new Error("Can't compute a static facet");return new Tt(t,this,2,e)}from(t,e){return e||(e=t=>t),this.compute([t],(i=>e(i.field(t))))}}function Dt(t,e){return t==e||t.length==e.length&&t.every(((t,i)=>t===e[i]))}class Tt{constructor(t,e,i,s){this.dependencies=t,this.facet=e,this.type=i,this.value=s,this.id=Ct++}dynamicSlot(t){var e;let i=this.value,s=this.facet.compareInput,n=t[this.id]>>1,r=2==this.type,o=!1,h=!1,l=[];for(let i of this.dependencies)"doc"==i?o=!0:"selection"==i?h=!0:0==(1&(null!==(e=t[i.id])&&void 0!==e?e:1))&&l.push(t[i.id]);return(t,e)=>{if(!e||e.reconfigured)return t.values[n]=i(t),1;{if(!(o&&e.docChanged||h&&(e.docChanged||e.selection)||l.some((e=>(1&qt(t,e))>0))))return 0;let a=i(t),c=e.startState.values[n];return(r?function(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}(a,c,s):s(a,c))?0:(t.values[n]=a,1)}}}}function Ot(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;return(t,i)=>{let h=i?i.reconfigured?i.startState.config.address[e.id]:o<<1:null,l=null==h;for(let e of r)1&qt(t,e)&&(l=!0);if(!l)return 0;let a=[];for(let e=0;e<s.length;e++){let i=jt(t,s[e]);if(2==n[e])for(let t of i)a.push(t);else a.push(i)}let c=e.combine(a);return null!=h&&e.compare(c,jt(i.startState,h))?0:(t.values[o]=c,1)}}function Pt(t,e){let i=t.config.address[e];return null==i?null:i>>1}const Et=Mt.define({static:!0});class Rt{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 Rt(Ct++,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(Et).find((t=>t.field==this));return((null==e?void 0:e.create)||this.createF)(t)}slot(t){let e=t[this.id]>>1;return(t,i)=>{if(!i||i.reconfigured&&null==Pt(i.startState,this.id))return t.values[e]=this.create(t),1;let s,n=0;i.reconfigured?(s=i.startState.values[Pt(i.startState,this.id)],n=1):s=i.startState.values[e];let r=this.updateF(s,i);return n||this.compareF(s,r)||(n=1),n&&(t.values[e]=r),n}}init(t){return[this,Et.of({field:this,create:t})]}get extension(){return this}}const Lt=2,Nt=1,It=0;function Bt(t){return e=>new Ht(e,t)}const Vt={fallback:Bt(3),default:Bt(Lt),extend:Bt(Nt),override:Bt(It)};class Ht{constructor(t,e){this.inner=t,this.prec=e}}class zt{of(t){return new Ft(this,t)}reconfigure(t){return zt.reconfigure.of({compartment:this,extension:t})}get(t){return t.config.compartments.get(this)}}class Ft{constructor(t,e){this.compartment=t,this.inner=e}}class Wt{constructor(t,e,i,s,n){for(this.base=t,this.compartments=e,this.dynamicSlots=i,this.address=s,this.staticValues=n,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 Ft&&i.delete(t.compartment)}if(n.set(t,o),Array.isArray(t))for(let e of t)r(e,o);else if(t instanceof Ft){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 Ht)r(t.inner,t.prec);else if(t instanceof Rt)s[o].push(t),t.provides&&r(t.provides,o);else if(t instanceof Tt)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,Lt),s.reduce(((t,e)=>t.concat(e)))}(t,e,r))i instanceof Rt?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)));for(let t in n){let e=n[t],s=e[0].facet;if(e.every((t=>0==t.type))){o[s.id]=h.length<<1|1;let t=s.combine(e.map((t=>t.value))),n=i?i.config.address[s.id]:null;if(null!=n){let e=jt(i,n);s.compare(t,e)&&(t=e)}h.push(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=>Ot(t,s,e)))}}return new Wt(t,r,l.map((t=>t(o))),o,h)}}function qt(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.config.dynamicSlots[i](t,t.applying);return t.status[i]=2|n}function jt(t,e){return 1&e?t.config.staticValues[e>>1]:t.values[e>>1]}const _t=Mt.define(),$t=Mt.define({combine:t=>t.some((t=>t)),static:!0}),Ut=Mt.define({combine:t=>t.length?t[0]:void 0,static:!0}),Gt=Mt.define(),Kt=Mt.define(),Jt=Mt.define(),Xt=Mt.define({combine:t=>!!t.length&&t[0]});class Yt{constructor(t,e){this.type=t,this.value=e}static define(){return new Qt}}class Qt{of(t){return new Yt(this,t)}}class Zt{constructor(t){this.map=t}of(t){return new te(this,t)}}class te{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 te(this.type,e)}is(t){return this.type==t}static define(t={}){return new Zt(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}}te.reconfigure=te.define(),te.appendConfig=te.define();class ee{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&&At(i,e.newLength),n.some((t=>t.type==ee.time))||(this.annotations=n.concat(ee.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(ee.userEvent);return e&&(e==t||e.length>t.length&&e.slice(0,t.length)==t&&"."==e[t.length])}}function ie(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 se(t,e,i){var s;let n,r,o;return i?(n=e.changes,r=pt.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:te.mapEffects(t.effects,n).concat(te.mapEffects(e.effects,r)),annotations:t.annotations.length?t.annotations.concat(e.annotations):e.annotations,scrollIntoView:t.scrollIntoView||e.scrollIntoView}}function ne(t,e,i){let s=e.selection,n=he(e.annotations);return e.userEvent&&(n=n.concat(ee.userEvent.of(e.userEvent))),{changes:e.changes instanceof pt?e.changes:pt.of(e.changes||[],i,t.facet(Ut)),selection:s&&(s instanceof kt?s:kt.single(s.anchor,s.head)),effects:he(e.effects),annotations:n,scrollIntoView:!!e.scrollIntoView}}function re(t,e,i){let s=ne(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=se(s,ne(t,e[n],r?s.changes.newLength:t.doc.length),r)}let n=new ee(t,s.changes,s.selection,s.effects,s.annotations,s.scrollIntoView);return function(t){let e=t.startState,i=e.facet(Jt),s=t;for(let n=i.length-1;n>=0;n--){let r=i[n](t);r&&Object.keys(r).length&&(s=se(t,ne(e,r,t.changes.newLength),!0))}return s==t?t:new ee(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(Gt)){let e=s(t);if(!1===e){i=!1;break}Array.isArray(e)&&(i=!0===i?e:ie(i,e))}if(!0!==i){let s,n;if(!1===i)n=t.changes.invertedDesc,s=pt.empty(e.doc.length);else{let e=t.changes.filter(i);s=e.changes,n=e.filtered.invertedDesc}t=new ee(e,s,t.selection&&t.selection.map(n),te.mapEffects(t.effects,n),t.annotations,t.scrollIntoView)}let s=e.facet(Kt);for(let i=s.length-1;i>=0;i--){let n=s[i](t);t=n instanceof ee?n:Array.isArray(n)&&1==n.length&&n[0]instanceof ee?n[0]:re(e,he(n),!1)}return t}(n):n)}ee.time=Yt.define(),ee.userEvent=Yt.define(),ee.addToHistory=Yt.define(),ee.remote=Yt.define();const oe=[];function he(t){return null==t?oe:Array.isArray(t)?t:[t]}var le=function(t){return t[t.Word=0]="Word",t[t.Space=1]="Space",t[t.Other=2]="Other",t}(le||(le={}));const ae=/[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/;let ce;try{ce=new RegExp("[\\p{Alphabetic}\\p{Number}_]","u")}catch(t){}function ue(t){return e=>{if(!/\S/.test(e))return le.Space;if(function(t){if(ce)return ce.test(t);for(let e=0;e<t.length;e++){let i=t[e];if(/\w/.test(i)||i>""&&(i.toUpperCase()!=i.toLowerCase()||ae.test(i)))return!0}return!1}(e))return le.Word;for(let i=0;i<t.length;i++)if(e.indexOf(t[i])>-1)return le.Word;return le.Other}}class fe{constructor(t,e,i,s=null){if(this.config=t,this.doc=e,this.selection=i,this.applying=null,this.status=t.statusTemplate.slice(),s&&s.startState.config==t)this.values=s.startState.values.slice();else if(this.values=t.dynamicSlots.map((t=>null)),s)for(let e in t.address){let i=t.address[e],n=s.startState.config.address[e];null!=n&&0==(1&i)&&(this.values[i>>1]=jt(s.startState,n))}this.applying=s,s&&(s._state=this);for(let t=0;t<this.config.dynamicSlots.length;t++)qt(this,t<<1);this.applying=null}field(t,e=!0){let i=this.config.address[t.id];if(null!=i)return qt(this,i),jt(this,i);if(e)throw new RangeError("Field is not present in this state")}update(...t){return re(this,t,!0)}applyTransaction(t){let e=this.config,{base:i,compartments:s}=e;for(let n of t.effects)n.is(zt.reconfigure)?(e&&(s=new Map,e.compartments.forEach(((t,e)=>s.set(e,t))),e=null),s.set(n.value.compartment,n.value.extension)):n.is(te.reconfigure)?(e=null,i=n.value):n.is(te.appendConfig)&&(e=null,i=he(i).concat(n.value));new fe(e||Wt.resolve(i,s,this),t.newDoc,t.newSelection,t)}replaceSelection(t){return"string"==typeof t&&(t=this.toText(t)),this.changeByRange((e=>({changes:{from:e.from,to:e.to,insert:t},range:kt.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=he(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=te.mapEffects(r,l).concat(te.mapEffects(he(o.effects),a))}return{changes:s,selection:kt.create(n,e.mainIndex),effects:r}}changes(t=[]){return t instanceof pt?t:pt.of(t,this.doc.length,this.facet(fe.lineSeparator))}toText(t){return it.of(t.split(this.facet(fe.lineSeparator)||ut))}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:(qt(this,e),jt(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 Rt&&(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 fe.create({doc:t.doc,selection:kt.fromJSON(t.selection),extensions:e.extensions?s.concat([e.extensions]):s})}static create(t={}){let e=Wt.resolve(t.extensions||[],new Map),i=t.doc instanceof it?t.doc:it.of((t.doc||"").split(e.staticFacet(fe.lineSeparator)||ut)),s=t.selection?t.selection instanceof kt?t.selection:kt.single(t.selection.anchor,t.selection.head):kt.single(0);return At(s,i.length),e.staticFacet($t)||(s=s.asSingle()),new fe(e,i,s)}get tabSize(){return this.facet(fe.tabSize)}get lineBreak(){return this.facet(fe.lineSeparator)||"\n"}get readOnly(){return this.facet(Xt)}phrase(t){for(let e of this.facet(fe.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(_t))for(let r of n(this,e,i))Object.prototype.hasOwnProperty.call(r,t)&&s.push(r[t]);return s}charCategorizer(t){return ue(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=G(e,r,!1);if(n(e.slice(t,r))!=le.Word)break;r=t}for(;o<s;){let t=G(e,o);if(n(e.slice(o,t))!=le.Word)break;o=t}return r==o?null:kt.range(r+i,o+i)}}function de(t,e,i={}){let s={};for(let e of t)for(let t of Object.keys(e)){let n=e[t],r=s[t];if(void 0===r)s[t]=n;else if(r===n||void 0===n);else{if(!Object.hasOwnProperty.call(i,t))throw new Error("Config merge conflict for field "+t);s[t]=i[t](r,n)}}for(let t in e)void 0===s[t]&&(s[t]=e[t]);return s}fe.allowMultipleSelections=$t,fe.tabSize=Mt.define({combine:t=>t.length?t[0]:4}),fe.lineSeparator=Ut,fe.readOnly=Xt,fe.phrases=Mt.define(),fe.languageData=_t,fe.changeFilter=Gt,fe.transactionFilter=Kt,fe.transactionExtender=Jt,zt.reconfigure=te.define();class pe{eq(t){return this==t}range(t,e=t){return new ge(t,e,this)}}pe.prototype.startSide=pe.prototype.endSide=0,pe.prototype.point=!1,pe.prototype.mapMode=ft.TrackDel;class ge{constructor(t,e,i){this.from=t,this.to=e,this.value=i}}function me(t,e){return t.from-e.from||t.value.startSide-e.value.startSide}class ve{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;l=a=t}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 ve(s,n,i,o):null,pos:r}}}class we{constructor(t,e,i=we.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.slice().sort(me),this.isEmpty)return e.length?we.of(e):this;let o=new xe(this,null,-1).goto(0),h=0,l=[],a=new be;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 ge(o.from,o.to,o.value))),o.next());return a.finishInner(this.nextLayer.isEmpty&&!l.length?we.empty:this.nextLayer.update({add:l,filter:r,filterFrom:s,filterTo:n}))}map(t){if(0==t.length||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 we(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 ke.from([this]).goto(t)}get isEmpty(){return this.nextLayer==this}static iter(t,e=0){return ke.from(t).goto(e)}static compare(t,e,i,s,n=-1){let r=t.filter((t=>t.maxPoint>=500||!t.isEmpty&&e.indexOf(t)<0&&t.maxPoint>=n)),o=e.filter((e=>e.maxPoint>=500||!e.isEmpty&&t.indexOf(e)<0&&e.maxPoint>=n)),h=ye(r,o),l=new Ae(r,h,n),a=new Ae(o,h,n);i.iterGaps(((t,e,i)=>Ce(l,t,a,e,i,s))),i.empty&&0==i.length&&Ce(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=ye(n,r),h=new Ae(n,o,0).goto(i),l=new Ae(r,o,0).goto(i);for(;;){if(h.to!=l.to||!Me(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 Ae(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),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 be;for(let s of t instanceof ge?[t]:e?function(t){if(t.length>1)for(let e=t[0],i=1;i<t.length;i++){let s=t[i];if(me(e,s)>0)return t.slice().sort(me);e=s}return t}(t):t)i.add(s.from,s.to,s.value);return i.finish()}}we.empty=new we([],[],null,-1),we.empty.nextLayer=we.empty;class be{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 ve(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 be)).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(we.empty)}finishInner(t){if(this.from.length&&this.finishChunk(!1),0==this.chunks.length)return t;let e=new we(this.chunkPos,this.chunks,this.nextLayer?this.nextLayer.finishInner(t):t,this.setMaxPoint);return this.from=null,e}}function ye(t,e){let i=new Map;for(let e of t)for(let t=0;t<e.chunk.length;t++)e.chunk[t].maxPoint<500&&i.set(e.chunk[t],e.chunkPos[t]);let s=new Set;for(let t of e)for(let e=0;e<t.chunk.length;e++)i.get(t.chunk[e])==t.chunkPos[e]&&s.add(t.chunk[e]);return s}class xe{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.to-t.to||this.endSide-t.endSide}}class ke{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 xe(r,e,i,n));return 1==s.length?s[0]:new ke(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--)Se(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--)Se(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(),Se(this.heap,0)}}}function Se(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 Ae{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=ke.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){De(this.active,t),De(this.activeTo,t),De(this.activeRank,t),this.minActive=Oe(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++;Te(this.active,e,i),Te(this.activeTo,e,s),Te(this.activeRank,e,n),t&&Te(t,e,this.cursor.from),this.minActive=Oe(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&&De(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&&n.endSide==this.endSide)){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.to>t&&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 Ce(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))&&Me(t.activeForPoint(t.to+l),i.activeForPoint(i.to))||r.comparePoint(h,n,t.point,i.point):n>h&&!Me(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 Me(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 De(t,e){for(let i=e,s=t.length-1;i<s;i++)t[i]=t[i+1];t.pop()}function Te(t,e,i){for(let i=t.length-1;i>=e;i--)t[i+1]=t[i];t[e]=i}function Oe(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}for(var Pe={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"},Ee={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"},Re="undefined"!=typeof navigator&&/Chrome\/(\d+)/.exec(navigator.userAgent),Le="undefined"!=typeof navigator&&/Apple Computer/.test(navigator.vendor),Ne="undefined"!=typeof navigator&&/Gecko\/\d+/.test(navigator.userAgent),Ie="undefined"!=typeof navigator&&/Mac/.test(navigator.platform),Be="undefined"!=typeof navigator&&/MSIE \d|Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(navigator.userAgent),Ve=Re&&(Ie||+Re[1]<57)||Ne&&Ie,He=0;He<10;He++)Pe[48+He]=Pe[96+He]=String(He);for(He=1;He<=24;He++)Pe[He+111]="F"+He;for(He=65;He<=90;He++)Pe[He]=String.fromCharCode(He+32),Ee[He]=String.fromCharCode(He);for(var ze in Pe)Ee.hasOwnProperty(ze)||(Ee[ze]=Pe[ze]);function Fe(t){let e;return e=11==t.nodeType?t.getSelection?t:t.ownerDocument:t,e.getSelection()}function We(t,e){return!!e&&t.contains(1!=e.nodeType?e.parentNode:e)}function qe(t,e){if(!e.anchorNode)return!1;try{return We(t,e.anchorNode)}catch(t){return!1}}function je(t){return 3==t.nodeType?ei(t,0,t.nodeValue.length).getClientRects():1==t.nodeType?t.getClientRects():[]}function _e(t,e,i,s){return!!i&&(Ue(t,e,i,s,-1)||Ue(t,e,i,s,1))}function $e(t){for(var e=0;;e++)if(!(t=t.previousSibling))return e}function Ue(t,e,i,s,n){for(;;){if(t==i&&e==s)return!0;if(e==(n<0?0:Ge(t))){if("DIV"==t.nodeName)return!1;let i=t.parentNode;if(!i||1!=i.nodeType)return!1;e=$e(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?Ge(t):0}}}function Ge(t){return 3==t.nodeType?t.nodeValue.length:t.childNodes.length}const Ke={left:0,right:0,top:0,bottom:0};function Je(t,e){let i=e?t.left:t.right;return{left:i,right:i,top:t.top,bottom:t.bottom}}function Xe(t){return{left:0,right:t.innerWidth,top:0,bottom:t.innerHeight}}class Ye{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}set(t){this.anchorNode=t.anchorNode,this.anchorOffset=t.anchorOffset,this.focusNode=t.focusNode,this.focusOffset=t.focusOffset}}let Qe,Ze=null;function ti(t){if(t.setActive)return t.setActive();if(Ze)return t.focus(Ze);let e=[];for(let i=t;i&&(e.push(i,i.scrollTop,i.scrollLeft),i!=i.ownerDocument);i=i.parentNode);if(t.focus(null==Ze?{get preventScroll(){return Ze={preventScroll:!0},!0}}:void 0),!Ze){Ze=!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 ei(t,e,i=e){let s=Qe||(Qe=document.createRange());return s.setEnd(t,i),s.setStart(t,e),s}function ii(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}let si=null;function ni(){if(null==si){si=!1;let t=document.createElement("div");try{t.contentEditable="plaintext-only",si="plaintext-only"==t.contentEditable}catch(t){}}return si}class ri{constructor(t,e,i=!0){this.node=t,this.offset=e,this.precise=i}static before(t,e){return new ri(t.parentNode,$e(t),e)}static after(t,e){return new ri(t.parentNode,$e(t)+1,e)}}const oi=[];class hi{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){var e;if(2&this.dirty){let i=this.dom,s=null;for(let n of this.children){if(n.dirty){let r=s?s.nextSibling:i.firstChild;n.dom||!r||(null===(e=hi.get(r))||void 0===e?void 0:e.parent)||n.reuseDOM(r),n.sync(t),n.dirty=0}t&&t.node==i&&s!=n.dom&&(t.written=!0),ai(i,s,n.dom),s=n.dom}let n=s?s.nextSibling:i.firstChild;for(n&&t&&t.node==i&&(t.written=!0);n;)n=li(n)}else if(1&this.dirty)for(let e of this.children)e.dirty&&(e.sync(t),e.dirty=0)}reuseDOM(t){return!1}localPosFromDOM(t,e){let i;if(t==this.dom)i=this.dom.childNodes[e];else{let s=0==Ge(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&&!hi.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=oi){this.markDirty();for(let i=t;i<e;i++){let t=this.children[i];t.parent==this&&(t.parent=null)}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 ci(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}}function li(t){let e=t.nextSibling;return t.parentNode.removeChild(t),e}function ai(t,e,i){let s=e?e.nextSibling:t.firstChild;if(i.parentNode==t)for(;s!=i;)s=li(s);else t.insertBefore(i,s)}hi.prototype.breakAfter=0;class ci{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}}}let[ui,fi]="undefined"!=typeof navigator?[navigator,document]:[{userAgent:"",vendor:"",platform:""},{documentElement:{style:{}}}];const di=/Edge\/(\d+)/.exec(ui.userAgent),pi=/MSIE \d/.test(ui.userAgent),gi=/Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(ui.userAgent),mi=!!(pi||gi||di),vi=!mi&&/gecko\/(\d+)/i.test(ui.userAgent),wi=!mi&&/Chrome\/(\d+)/.exec(ui.userAgent),bi="webkitFontSmoothing"in fi.documentElement.style,yi=!mi&&/Apple Computer/.test(ui.vendor);var xi={mac:/Mac/.test(ui.platform),ie:mi,ie_version:pi?fi.documentMode||6:gi?+gi[1]:di?+di[1]:0,gecko:vi,gecko_version:vi?+(/Firefox\/(\d+)/.exec(ui.userAgent)||[0,0])[1]:0,chrome:!!wi,chrome_version:wi?+wi[1]:0,ios:yi&&(/Mobile\/\w+/.test(ui.userAgent)||ui.maxTouchPoints>2),android:/Android\b/.test(ui.userAgent),webkit:bi,safari:yi,webkit_version:bi?+(/\bAppleWebKit\/(\d+)/.exec(navigator.userAgent)||[0,0])[1]:0,tabSize:null!=fi.documentElement.style.tabSize?"tab-size":"-moz-tab-size"};const ki=[];class Si extends hi{become(t){return!1}getSide(){return 0}}Si.prototype.children=ki;class Ai extends Si{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){return 3==t.nodeType&&(this.createDOM(t),!0)}merge(t,e,i){return(!i||i instanceof Ai&&!(this.length-(e-t)+i.length>256))&&(this.text=this.text.slice(0,t)+(i?i.text:"")+this.text.slice(e),this.markDirty(),!0)}slice(t){let e=new Ai(this.text.slice(t));return this.text=this.text.slice(0,t),e}localPosFromDOM(t,e){return t==this.dom?e:e?this.text.length:0}domAtPos(t){return new ri(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 Mi(this.dom,t,e)}}class Ci extends Si{constructor(t,e=[],i=0){super(),this.mark=t,this.children=e,this.length=i;for(let t of e)t.setParent(this)}createDOM(){let t=document.createElement(this.mark.tagName);if(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]);this.setDOM(t)}sync(t){(!this.dom||4&this.dirty)&&this.createDOM(),super.sync(t)}merge(t,e,i,s,n){return(!i||!(!(i instanceof Ci&&i.mark.eq(this.mark))||t&&s<=0||e<this.length&&n<=0))&&(Oi(this,t,e,i?i.children:ki,s-1,n-1),this.markDirty(),!0)}slice(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.slice(t-i):r),s<0&&i>=t&&(s=n),i=o,n++}let r=this.length-t;return this.length=t,s>-1&&this.replaceChildren(s,this.children.length),new Ci(this.mark,e,r)}domAtPos(t){return Pi(this.dom,this.children,t)}coordsAt(t,e){return Ri(this,t,e)}}function Mi(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?xi.chrome||xi.gecko||(e?(n--,o=1):(r++,o=-1)):i<0?n--:r++;let h=ei(t,n,r).getClientRects();if(!h.length)return Ke;let l=h[(o?o<0:i>=0)?0:h.length-1];return xi.safari&&!o&&0==l.width&&(l=Array.prototype.find.call(h,(t=>t.width))||l),o?Je(l,o<0):l}class Di extends Si{constructor(t,e,i){super(),this.widget=t,this.length=e,this.side=i}static create(t,e,i){return new(t.customView||Di)(t,e,i)}slice(t){let e=Di.create(this.widget,this.length-t,this.side);return this.length-=t,e}sync(){this.dom&&this.widget.updateDOM(this.dom)||(this.setDOM(this.widget.toDOM(this.editorView)),this.dom.contentEditable="false")}getSide(){return this.side}merge(t,e,i,s,n){return!(i&&(!(i instanceof Di&&this.widget.compare(i.widget))||t>0&&s<=0||e<this.length&&n<=0))&&(this.length=t+(i?i.length:0)+(this.length-e),!0)}become(t){return t.length==this.length&&t instanceof Di&&t.side==this.side&&this.widget.constructor==t.widget.constructor&&(this.widget.eq(t.widget)||this.markDirty(!0),this.widget=t.widget,!0)}ignoreMutation(){return!0}ignoreEvent(t){return this.widget.ignoreEvent(t)}get overrideDOMText(){if(0==this.length)return it.empty;let t=this;for(;t.parent;)t=t.parent;let e=t.editorView,i=e&&e.state.doc,s=this.posAtStart;return i?i.slice(s,s+this.length):it.empty}domAtPos(t){return 0==t?ri.before(this.dom):ri.after(this.dom,t==this.length)}domBoundsAround(){return null}coordsAt(t,e){let i=this.dom.getClientRects(),s=null;if(!i.length)return Ke;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:Je(s,0==t)}}class Ti extends Di{domAtPos(t){return new ri(this.widget.text,t)}sync(){this.dom||this.setDOM(this.widget.toDOM())}localPosFromDOM(t,e){return e?3==t.nodeType?Math.min(e,this.length):this.length:0}ignoreMutation(){return!1}get overrideDOMText(){return null}coordsAt(t,e){return Mi(this.widget.text,t,e)}}function Oi(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;let{children:f}=t;if(a==h&&c){let t=f[a];if(1==s.length&&t.merge(c,l,s[0],n,r))return;if(0==s.length)return void t.merge(c,l,null,n,r);let e=t.slice(l);e.merge(0,0,s[s.length-1],0,r)?s[s.length-1]=e:s.push(e),h++,r=l=0}if(l){let t=f[h];s.length&&t.merge(0,l,s[s.length-1],0,r)?(s.pop(),r=s.length?0:n):t.merge(0,l,null,0,0)}else h<f.length&&s.length&&f[h].merge(0,0,s[s.length-1],0,r)&&(s.pop(),r=s.length?0:n);if(c){let t=f[a];s.length&&t.merge(c,t.length,s[0],n,0)?(s.shift(),n=s.length?0:r):t.merge(c,t.length,null,0,0),a++}else if(a&&s.length){let t=f[a-1];t.merge(t.length,t.length,s[0],n,0)&&(s.shift(),n=s.length?0:r)}for(;a<h&&s.length&&f[h-1].become(s[s.length-1]);)s.pop(),h--,r=s.length?0:n;for(;a<h&&s.length&&f[a].become(s[0]);)s.shift(),a++,n=s.length?0:r;!s.length&&a&&h<f.length&&f[h].merge(0,0,f[a-1],n,r)&&a--,(s.length||a!=h)&&t.replaceChildren(a,h,s)}function Pi(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 ri.after(i)}return new ri(t,0)}function Ei(t,e,i){let s,{children:n}=t;i>0&&e instanceof Ci&&n.length&&(s=n[n.length-1])instanceof Ci&&s.mark.eq(e.mark)?Ei(s,e.children[0],i-1):(n.push(e),e.setParent(t)),t.length+=e.length}function Ri(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(e-s,i);return t&&n?Je(n,i<0):n}s=h}let s=t.dom.lastChild;if(!s)return t.dom.getBoundingClientRect();let n=je(s);return n[n.length-1]}function Li(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 Ni(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 Ii(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])}class Bi{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}}var Vi=function(t){return t[t.Text=0]="Text",t[t.WidgetBefore=1]="WidgetBefore",t[t.WidgetAfter=2]="WidgetAfter",t[t.WidgetRange=3]="WidgetRange",t}(Vi||(Vi={}));class Hi extends pe{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 zi(t)}static widget(t){let e=t.side||0;return t.block&&(e+=200000001*(e>0?1:-1)),new Wi(t,e,e,!!t.block,t.widget||null,!1)}static replace(t){let e=!!t.block,{start:i,end:s}=qi(t);return new Wi(t,e?-2e8*(i?2:1):1e8*(i?-1:1),e?2e8*(s?2:1):1e8*(s?1:-1),e,t.widget||null,!0)}static line(t){return new Fi(t)}static set(t,e=!1){return we.of(t,e)}hasHeight(){return!!this.widget&&this.widget.estimatedHeight>-1}}Hi.none=we.empty;class zi extends Hi{constructor(t){let{start:e,end:i}=qi(t);super(1e8*(e?-1:1),1e8*(i?1:-1),null,t),this.tagName=t.tagName||"span",this.class=t.class||"",this.attrs=t.attributes||null}eq(t){return this==t||t instanceof zi&&this.tagName==t.tagName&&this.class==t.class&&Ni(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)}}zi.prototype.point=!1;class Fi extends Hi{constructor(t){super(-1e8,-1e8,null,t)}eq(t){return t instanceof Fi&&Ni(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)}}Fi.prototype.mapMode=ft.TrackBefore,Fi.prototype.point=!0;class Wi extends Hi{constructor(t,e,i,s,n,r){super(e,i,n,t),this.block=s,this.isReplace=r,this.mapMode=s?e<0?ft.TrackBefore:ft.TrackAfter:ft.TrackDel}get type(){return this.startSide<this.endSide?Vi.WidgetRange:this.startSide<0?Vi.WidgetBefore:Vi.WidgetAfter}get heightRelevant(){return this.block||!!this.widget&&this.widget.estimatedHeight>=5}eq(t){return t instanceof Wi&&(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 qi(t){let{inclusiveStart:e,inclusiveEnd:i}=t;return null==e&&(e=t.inclusive),null==i&&(i=t.inclusive),{start:e||!1,end:i||!1}}function ji(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)}Wi.prototype.point=!0;class _i extends hi{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 _i))return!1;this.dom||i.transferDOM(this)}return s&&this.setDeco(i?i.attrs:null),Oi(this,t,e,i?i.children:$i,n,r),!0}split(t){let e=new _i;if(e.breakAfter=this.breakAfter,0==this.length)return e;let{i:i,off:s}=this.childPos(t);s&&(e.append(this.children[i].slice(s),0),this.children[i].merge(s,this.children[i].length,null,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-1].parent=null,i--;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){Ni(this.attrs,t)||(this.dom&&(this.prevAttrs=this.attrs,this.markDirty()),this.attrs=t)}append(t,e){Ei(this,t,e)}addLineDeco(t){let e=t.spec.attributes;e&&(this.attrs=Li(e,this.attrs||{}))}domAtPos(t){return Pi(this.dom,this.children,t)}sync(t){(!this.dom||4&this.dirty)&&(this.setDOM(document.createElement("div")),this.dom.className="cm-line",this.prevAttrs=this.attrs?null:void 0),void 0!==this.prevAttrs&&(Ii(this.dom,this.prevAttrs,this.attrs),this.dom.classList.add("cm-line"),this.prevAttrs=void 0),super.sync(t);let e=this.dom.lastChild;for(;e&&hi.get(e)instanceof Ci;)e=e.lastChild;if(!e||"BR"!=e.nodeName&&hi.get(e)instanceof Di&&(!xi.ios||!this.children.some((t=>t instanceof Ai)))){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 Ai))return null;let i=je(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 Ri(this,t,e)}match(t){return!1}get type(){return Vi.Text}static find(t,e){for(let i=0,s=0;;i++){let n=t.children[i],r=s+n.length;if(r>=e){if(n instanceof _i)return n;if(n.length)return null}s=r+n.breakAfter}}}const $i=[];class Ui extends hi{constructor(t,e,i){super(),this.widget=t,this.length=e,this.type=i,this.breakAfter=0}merge(t,e,i,s,n,r){return!(i&&(!(i instanceof Ui&&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?ri.before(this.dom):ri.after(this.dom,t==this.length)}split(t){let e=this.length-t;return this.length=t,new Ui(this.widget,e,this.type)}get children(){return $i}sync(){this.dom&&this.widget.updateDOM(this.dom)||(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):it.empty}domBoundsAround(){return null}match(t){return t instanceof Ui&&t.type==this.type&&t.widget.constructor==this.widget.constructor&&(t.widget.eq(this.widget)||this.markDirty(!0),this.widget=t.widget,this.length=t.length,this.breakAfter=t.breakAfter,!0)}ignoreMutation(){return!0}ignoreEvent(t){return this.widget.ignoreEvent(t)}}class Gi{constructor(t,e,i){this.doc=t,this.pos=e,this.end=i,this.content=[],this.curLine=null,this.breakAtStart=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 Ui&&t.type==Vi.WidgetBefore)}getLine(){return this.curLine||this.content.push(this.curLine=new _i),this.curLine}addWidget(t){this.curLine=null,this.content.push(t)}finish(){this.posCovered()||this.getLine()}wrapMarks(t,e){for(let i of e)t=new Ci(i,[t],t.length);return t}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.curLine=null,t--;continue}this.text=e,this.textOff=0}let s=Math.min(this.text.length-this.textOff,t,512);this.getLine().append(this.wrapMarks(new Ai(this.text.slice(this.textOff,this.textOff+s)),e),i),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){let r=e-t;if(i instanceof Wi)if(i.block){let{type:t}=i;t!=Vi.WidgetAfter||this.posCovered()||this.getLine(),this.addWidget(new Ui(i.widget||new Ki("div"),r,t))}else{let t=this.wrapMarks(Di.create(i.widget||new Ki("span"),r,i.startSide),s);this.getLine().append(t,n)}else this.doc.lineAt(this.pos).from==this.pos&&this.getLine().addLineDeco(i);r&&(this.textOff+r<=this.text.length?this.textOff+=r:(this.skip+=r-(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){let n=new Gi(t,e,i);return n.openEnd=we.spans(s,e,i,n),n.openStart<0&&(n.openStart=n.openEnd),n.finish(),n}}class Ki extends Bi{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 Ji=[],Xi=Mt.define(),Yi=Mt.define(),Qi=Mt.define(),Zi=Mt.define(),ts=Mt.define(),es=Mt.define(),is=te.define({map:(t,e)=>t.map(e)});function ss(t,e,i){let s=t.facet(Zi);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 ns=Mt.define({combine:t=>!t.length||t[0]});class rs{constructor(t,e){this.field=t,this.get=e}}class os{from(t){return new rs(this,t)}static define(){return new os}}os.decorations=os.define(),os.atomicRanges=os.define(),os.scrollMargins=os.define();let hs=0;const ls=Mt.define();class as{constructor(t,e,i){this.id=t,this.create=e,this.fields=i,this.extension=ls.of(this)}static define(t,e){let{eventHandlers:i,provide:s,decorations:n}=e||{},r=[];if(s)for(let t of Array.isArray(s)?s:[s])r.push(t);return i&&r.push(cs.from((t=>({plugin:t,handlers:i})))),n&&r.push(os.decorations.from(n)),new as(hs++,t,r)}static fromClass(t,e){return as.define((e=>new t(e)),e)}}const cs=os.define();class us{constructor(t){this.spec=t,this.mustUpdate=null,this.value=null}takeField(t,e){for(let{field:i,get:s}of this.spec.fields)i==t&&e.push(s(this.value))}update(t){if(this.value){if(this.mustUpdate){let t=this.mustUpdate;if(this.mustUpdate=null,!this.value.update)return this;try{this.value.update(t)}catch(e){if(ss(t.state,e,"CodeMirror plugin crashed"),this.value.destroy)try{this.value.destroy()}catch(t){}return us.dummy}}}else try{this.value=this.spec.create(t)}catch(e){return ss(t.state,e,"CodeMirror plugin crashed"),us.dummy}return this}destroy(t){var e;if(null===(e=this.value)||void 0===e?void 0:e.destroy)try{this.value.destroy()}catch(e){ss(t.state,e,"CodeMirror plugin crashed")}}}us.dummy=new us(as.define((()=>({}))));const fs=Mt.define({combine:t=>t.reduce(((t,e)=>Li(e,t)),{})}),ds=Mt.define({combine:t=>t.reduce(((t,e)=>Li(e,t)),{})}),ps=Mt.define(),gs=Mt.define();class ms{constructor(t,e,i,s){this.fromA=t,this.toA=e,this.fromB=i,this.toB=s}join(t){return new ms(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 ms(r+l,h+l,r,h).addToSet(i),s>a)break;n+=2}if(!h)return i;new ms(h.fromA,h.toA,h.fromB,h.toB).addToSet(i),r=h.toA,o=h.toB}}}class vs{constructor(t,e,i=Ji){this.view=t,this.state=e,this.transactions=i,this.flags=0,this.startState=t.state,this.changes=pt.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 ms(t,e,i,n)))),this.changedRanges=s;let n=t.hasFocus;n!=t.inputState.notifiedFocused&&(t.inputState.notifiedFocused=n,this.flags|=1),this.docChanged&&(this.flags|=2)}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.transactions.some((t=>t.docChanged))}get selectionSet(){return this.transactions.some((t=>t.selection))}get empty(){return 0==this.flags&&0==this.transactions.length}}class ws extends hi{constructor(t){super(),this.view=t,this.compositionDeco=Hi.none,this.decorations=[],this.minWidth=0,this.minWidthFrom=0,this.minWidthTo=0,this.impreciseAnchor=null,this.impreciseHead=null,this.setDOM(t.contentDOM),this.children=[new _i],this.children[0].setParent(this),this.updateInner([new ms(0,0,0,t.state.doc.length)],this.updateDeco(),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=0),this.view.inputState.composing<0?this.compositionDeco=Hi.none:t.transactions.length&&(this.compositionDeco=function(t,e){let i=t.observer.selectionRange,s=i.focusNode&&xs(i.focusNode,i.focusOffset,0);if(!s)return Hi.none;let n,r,o=t.docView.nearest(s),h=s;if(o instanceof Si){for(;o.parent instanceof Si;)o=o.parent;n=o.posAtStart,r=n+o.length,h=o.dom}else{if(!(o instanceof _i))return Hi.none;{for(;h.parentNode!=o.dom;)h=h.parentNode;let t=h.previousSibling;for(;t&&!hi.get(t);)t=t.previousSibling;n=r=t?hi.get(t).posAtEnd:o.posAtStart}}let l=e.mapPos(n,1),a=Math.max(l,e.mapPos(r,-1)),c=s.nodeValue,{state:u}=t;if(a-l<c.length)if(u.sliceDoc(l,Math.min(u.doc.length,l+c.length))==c)a=l+c.length;else{if(u.sliceDoc(Math.max(0,a-c.length),a)!=c)return Hi.none;l=a-c.length}else if(u.sliceDoc(l,a)!=c)return Hi.none;return Hi.set(Hi.replace({widget:new ys(h,s)}).range(l,a))}(this.view,t.changes));let i=(xi.ie||xi.chrome)&&!this.compositionDeco.size&&t&&t.state.doc.lines!=t.startState.doc.lines,s=this.decorations,n=this.updateDeco(),r=function(t,e,i){let s=new ks;return we.compare(t,e,i,s),s.changes}(s,n,t.changes);e=ms.extendWithRanges(e,r);let o=t.transactions.some((t=>t.isUserEvent("select.pointer")));return 0==this.dirty&&0==e.length&&!(4&t.flags)&&t.state.selection.main.from>=this.view.viewport.from&&t.state.selection.main.to<=this.view.viewport.to?(this.updateSelection(i,o),!1):(this.updateInner(e,n,t.startState.doc.length,i,o),!0)}updateInner(t,e,i,s=!1,n=!1){this.updateChildren(t,e,i);let{observer:r}=this.view;r.ignore((()=>{this.dom.style.height=this.view.viewState.domHeight+"px",this.dom.style.minWidth=this.minWidth?this.minWidth+"px":"";let t=xi.chrome||xi.ios?{node:r.selectionRange.focusNode,written:!1}:void 0;this.sync(t),this.dirty=0,t&&(t.written||r.selectionRange.focusNode!=t.node)&&(s=!0),this.updateSelection(s,n),this.dom.style.height=""}));let o=[];if(this.view.viewport.from||this.view.viewport.to<this.view.state.doc.length)for(let t of this.children)t instanceof Ui&&t.widget instanceof bs&&o.push(t.dom);r.updateGaps(o)}updateChildren(t,e,i){let s=this.childCursor(i);for(let i=t.length-1;;i--){let n=i>=0?t[i]:null;if(!n)break;let{fromA:r,toA:o,fromB:h,toB:l}=n,{content:a,breakAtStart:c,openStart:u,openEnd:f}=Gi.build(this.view.state.doc,h,l,e),{i:d,off:p}=s.findPos(o,1),{i:g,off:m}=s.findPos(r,-1);this.replaceRange(g,m,d,p,a,c,u,f)}}replaceRange(t,e,i,s,n,r,o,h){let l=this.children[t],a=n.length?n[n.length-1]:null,c=a?a.breakAfter:r;if(t==i&&!r&&!c&&n.length<2&&l.merge(e,s,n.length?a:null,0==e,o,h))return;let u=this.children[i];for(s<u.length?(t==i&&(u=u.split(s),s=0),!c&&a&&u.merge(0,s,a,!0,0,h)?n[n.length-1]=u:(s&&u.merge(0,s,null,!1,0,h),n.push(u))):u.breakAfter&&(a?a.breakAfter=1:r=1),i++,l.breakAfter=r,e>0&&(!r&&n.length&&l.merge(e,l.length,n[0],!1,o,0)?l.breakAfter=n.shift().breakAfter:(e<l.length||l.children.length&&0==l.children[l.children.length-1].length)&&l.merge(e,l.length,null,!1,o,0),t++);t<i&&n.length;)if(this.children[i-1].match(n[n.length-1]))i--,n.pop();else{if(!this.children[t].match(n[0]))break;t++,n.shift()}(t<i||n.length)&&this.replaceChildren(t,i,n)}updateSelection(t=!1,e=!1){if(!e&&!this.mayControlSelection()||xi.ios&&this.view.inputState.rapidCompositionStart)return;let i=this.view.state.selection.main,s=this.domAtPos(i.anchor),n=i.empty?s:this.domAtPos(i.head);if(xi.gecko&&i.empty&&(1==(r=s).node.nodeType&&r.node.firstChild&&(0==r.offset||"false"==r.node.childNodes[r.offset-1].contentEditable)&&(r.offset==r.node.childNodes.length||"false"==r.node.childNodes[r.offset].contentEditable))){let e=document.createTextNode("");this.view.observer.ignore((()=>s.node.insertBefore(e,s.node.childNodes[s.offset]||null))),s=n=new ri(e,0),t=!0}var r;let o=this.view.observer.selectionRange;!t&&o.focusNode&&_e(s.node,s.offset,o.anchorNode,o.anchorOffset)&&_e(n.node,n.offset,o.focusNode,o.focusOffset)||(this.view.observer.ignore((()=>{let t=Fe(this.root);if(i.empty){if(xi.gecko){let t=(e=s.node,r=s.offset,1!=e.nodeType?0:(r&&"false"==e.childNodes[r-1].contentEditable?1:0)|(r<e.childNodes.length&&"false"==e.childNodes[r].contentEditable?2:0));if(t&&3!=t){let e=xs(s.node,s.offset,1==t?1:-1);e&&(s=new ri(e,1==t?0:e.nodeValue.length))}}t.collapse(s.node,s.offset),null!=i.bidiLevel&&null!=o.cursorBidiLevel&&(o.cursorBidiLevel=i.bidiLevel)}else if(t.extend)t.collapse(s.node,s.offset),t.extend(n.node,n.offset);else{let e=document.createRange();i.anchor>i.head&&([s,n]=[n,s]),e.setEnd(n.node,n.offset),e.setStart(s.node,s.offset),t.removeAllRanges(),t.addRange(e)}var e,r})),this.view.observer.setSelectionRange(s,n)),this.impreciseAnchor=s.precise?null:new ri(o.anchorNode,o.anchorOffset),this.impreciseHead=n.precise?null:new ri(o.focusNode,o.focusOffset)}enforceCursorAssoc(){if(this.view.composing)return;let t=this.view.state.selection.main,e=Fe(this.root);if(!t.empty||!t.assoc||!e.modify)return;let i=_i.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(ns)?this.root.activeElement==this.dom:qe(this.dom,this.view.observer.selectionRange)}nearest(t){for(let e=t;e;){let t=hi.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 _i)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!=Vi.WidgetBefore&&n.type!=Vi.WidgetAfter&&(!s||2==e||this.children[s-1].breakAfter||this.children[s-1].type==Vi.WidgetBefore&&e>-2))return n.coordsAt(t-r,e);i=r}}measureVisibleLineHeights(){let t=[],{from:e,to:i}=this.view.viewState.viewport,s=Math.max(this.view.scrollDOM.clientWidth,this.minWidth)+1;for(let n=0,r=0;r<this.children.length;r++){let o=this.children[r],h=n+o.length;if(h>i)break;if(n>=e){t.push(o.dom.getBoundingClientRect().height);let e=o.dom.scrollWidth;e>s&&(this.minWidth=s=e,this.minWidthFrom=n,this.minWidthTo=h)}n=h+o.breakAfter}return t}measureTextSize(){for(let t of this.children)if(t instanceof _i){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=je(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 ci(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.lineAt(r,0).bottom-e.lineAt(i,0).top;t.push(Hi.replace({widget:new bs(s),block:!0,inclusive:!0}).range(i,r))}if(!n)break;i=n.to+1}return Hi.set(t)}updateDeco(){return this.decorations=[...this.view.pluginField(os.decorations),...this.view.state.facet(ps),this.compositionDeco,this.computeBlockGapDeco(),this.view.viewState.lineGapDeco]}scrollRangeIntoView(t){let e,i=this.coordsAt(t.head,t.empty?t.assoc:t.head>t.anchor?-1:1);if(!i)return;!t.empty&&(e=this.coordsAt(t.anchor,t.anchor>t.head?-1:1))&&(i={left:Math.min(i.left,e.left),top:Math.min(i.top,e.top),right:Math.max(i.right,e.right),bottom:Math.max(i.bottom,e.bottom)});let s=0,n=0,r=0,o=0;for(let t of this.view.pluginField(os.scrollMargins))if(t){let{left:e,right:i,top:h,bottom:l}=t;null!=e&&(s=Math.max(s,e)),null!=i&&(n=Math.max(n,i)),null!=h&&(r=Math.max(r,h)),null!=l&&(o=Math.max(o,l))}!function(t,e,i){let s=t.ownerDocument,n=s.defaultView;for(let r=t.parentNode;r;)if(1==r.nodeType){let t,o=r==s.body;if(o)t=Xe(n);else{if(r.scrollHeight<=r.clientHeight&&r.scrollWidth<=r.clientWidth){r=r.parentNode;continue}let e=r.getBoundingClientRect();t={left:e.left,right:e.left+r.clientWidth,top:e.top,bottom:e.top+r.clientHeight}}let h=0,l=0;if(e.top<t.top?(l=-(t.top-e.top+5),i>0&&e.bottom>t.bottom+l&&(l=e.bottom-t.bottom+l+5)):e.bottom>t.bottom&&(l=e.bottom-t.bottom+5,i<0&&e.top-l<t.top&&(l=-(t.top+l-e.top+5))),e.left<t.left?(h=-(t.left-e.left+5),i>0&&e.right>t.right+h&&(h=e.right-t.right+h+5)):e.right>t.right&&(h=e.right-t.right+5,i<0&&e.left<t.left+h&&(h=-(t.left+h-e.left+5))),h||l)if(o)n.scrollBy(h,l);else{if(l){let t=r.scrollTop;r.scrollTop+=l,l=r.scrollTop-t}if(h){let t=r.scrollLeft;r.scrollLeft+=h,h=r.scrollLeft-t}e={left:e.left-h,top:e.top-l,right:e.right-h,bottom:e.bottom-l}}if(o)break;r=r.assignedSlot||r.parentNode}else{if(11!=r.nodeType)break;r=r.host}}(this.dom,{left:i.left-s,top:i.top-r,right:i.right+n,bottom:i.bottom+o},t.head<t.anchor?-1:1)}}class bs extends Bi{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}}class ys extends Bi{constructor(t,e){super(),this.top=t,this.text=e}eq(t){return this.top==t.top&&this.text==t.text}toDOM(){return this.top}ignoreEvent(){return!1}get customView(){return Ti}}function xs(t,e,i){for(;;){if(3==t.nodeType)return t;if(1==t.nodeType&&e>0&&i<=0)e=Ge(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 ks{constructor(){this.changes=[]}compareRange(t,e){ji(t,e,this.changes)}comparePoint(t,e){ji(t,e,this.changes)}}var Ss=function(t){return t[t.LTR=0]="LTR",t[t.RTL=1]="RTL",t}(Ss||(Ss={}));const As=Ss.LTR,Cs=Ss.RTL;function Ms(t){let e=[];for(let i=0;i<t.length;i++)e.push(1<<+t[i]);return e}const Ds=Ms("88888888888888888888888888888888888666888888787833333333337888888000000000000000000000000008888880000000000000000000000000088888888888888888888888888888888888887866668888088888663380888308888800000000000000000000000800000000000000000000000000000008"),Ts=Ms("4444448826627288999999999992222222222222222222222222222222222222222222222229999999999999999999994444444444644222822222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222222999999949999999229989999223333333333"),Os=Object.create(null),Ps=[];for(let t of["()","[]","{}"]){let e=t.charCodeAt(0),i=t.charCodeAt(1);Os[e]=i,Os[i]=-e}const Es=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/;class Rs{constructor(t,e,i){this.from=t,this.to=e,this.level=i}get dir(){return this.level%2?Cs:As}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 Ls=[];function Ns(t){return[new Rs(0,t,0)]}let Is="";function Bs(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=Rs.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=G(t.text,o,a);if(Is=t.text.slice(Math.min(o,c),Math.max(o,c)),c!=l.side(n,i))return kt.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?kt.cursor(u.side(!n,i)+t.from,n?1:-1,u.level):kt.cursor(c+t.from,n?-1:1,l.level):kt.cursor(n?t.to:t.from,n?-1:1,i)}function Vs(t,e){return e.left>t?e.left-t:Math.max(0,t-e.right)}function Hs(t,e){return e.top>t?e.top-t:Math.max(0,t-e.bottom)}function zs(t,e){return t.top<e.bottom-1&&t.bottom>e.top+1}function Fs(t,e){return e<t.top?{top:e,left:t.left,right:t.right,bottom:t.bottom}:t}function Ws(t,e){return e>t.bottom?{top:t.top,left:t.left,right:t.right,bottom:e}:t}function qs(t,e,i){let s,n,r,o,h,l,a,c;for(let u=t.firstChild;u;u=u.nextSibling){let t=je(u);for(let f=0;f<t.length;f++){let d=t[f];n&&zs(n,d)&&(d=Fs(Ws(d,n.bottom),n.top));let p=Vs(e,d),g=Hs(i,d);if(0==p&&0==g)return 3==u.nodeType?js(u,e,i):qs(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&&zs(a,d)?a=Ws(a,d.bottom):c&&zs(c,d)&&(c=Fs(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?js(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)}:qs(s,u,i)}function js(t,e,i){let s=t.nodeValue.length,n=-1,r=1e9,o=0;for(let h=0;h<s;h++){let s=ei(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(xi.chrome||xi.gecko){ei(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 _s(t,{x:e,y:i},s,n=-1){let r,o=t.contentDOM.getBoundingClientRect(),h=t.defaultLineHeight/2;for(let e=!1;;){if(r=t.blockAtHeight(i,o.top),r.top>i||r.bottom<i){if(n=r.top>i?-1:1,i=Math.min(r.bottom-h,Math.max(r.top+h,i)),e)return s?null:0;e=!0}if(r.type==Vi.Text)break;i=n>0?r.bottom+h:r.top-h}let l=r.from;if(e=Math.max(o.left+1,Math.min(o.right-1,e)),l<t.viewport.from)return 0==t.viewport.from?0:$s(t,o,r,e,i);if(l>t.viewport.to)return t.viewport.to==t.state.doc.length?t.state.doc.length:$s(t,o,r,e,i);let a,c=t.dom.ownerDocument,u=(t.root.elementFromPoint?t.root:c).elementFromPoint(e,i),f=-1;if(u&&t.contentDOM.contains(u)&&!(t.docView.nearest(u)instanceof Di))if(c.caretPositionFromPoint){let t=c.caretPositionFromPoint(e,i);t&&({offsetNode:a,offset:f}=t)}else if(c.caretRangeFromPoint){let t=c.caretRangeFromPoint(e,i);t&&(({startContainer:a,startOffset:f}=t),xi.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 ei(t,s-1,s).getBoundingClientRect().left>i}(a,f,e)&&(a=void 0))}if(!a||!t.docView.dom.contains(a)){let s=_i.find(t.docView,l);({node:a,offset:f}=qs(s.dom,e,i))}return t.docView.posFromDOM(a,f)}function $s(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=G(t,s)}return!0===s?-1:t.length}(o,r,t.state.tabSize)}function Us(t,e,i,s){let n=t.state.doc.lineAt(e.head),r=t.bidiSpans(n);for(let o=e,h=null;;){let e=Bs(n,r,t.textDirection,o,i),l=Is;if(!e){if(n.number==(i?t.state.doc.lines:1))return o;l="\n",n=t.state.doc.line(n.number+(i?1:-1)),r=t.bidiSpans(n),e=kt.cursor(i?n.from:n.to)}if(h){if(!h(l))return o}else{if(!s)return e;h=s(l)}o=e}}function Gs(t,e,i){let s=t.pluginField(os.atomicRanges);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?kt.cursor(s,1):kt.cursor(n,-1),t=!0)}));if(!t)return i}}class Ks{constructor(t){this.lastKeyCode=0,this.lastKeyTime=0,this.pendingIOSKey=null,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 Qs){let i=Qs[e];t.contentDOM.addEventListener(e,(s=>{"keydown"==e&&this.keydown(t,s)||Ys(t,s)&&!this.ignoreDuringComposition(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,this.ensureHandlers(t),xi.safari&&t.contentDOM.addEventListener("input",(()=>null))}setSelectionOrigin(t){this.lastSelectionOrigin=t,this.lastSelectionTime=Date.now()}ensureHandlers(t){let e=this.customHandlers=t.pluginField(cs);for(let i of e)for(let e in i.handlers)this.registeredEvents.indexOf(e)<0&&"scroll"!=e&&(this.registeredEvents.push(e),t.contentDOM.addEventListener(e,(i=>{Ys(t,i)&&this.runCustomHandlers(e,t,i)&&i.preventDefault()})))}runCustomHandlers(t,e,i){for(let s of this.customHandlers){let n=s.handlers[t],r=!1;if(n){try{r=n.call(s.plugin,i,e)}catch(t){ss(e.state,t)}if(r||i.defaultPrevented)return xi.android&&"keydown"==t&&13==i.keyCode&&e.observer.flushSoon(),!0}}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){ss(t.state,e)}}}keydown(t,e){return this.lastKeyCode=e.keyCode,this.lastKeyTime=Date.now(),!!this.screenKeyEvent(t,e)||!(!xi.ios||13!=e.keyCode&&8!=e.keyCode||e.ctrlKey||e.altKey||e.metaKey||e.synthetic)&&(this.pendingIOSKey=13==e.keyCode?"enter":"backspace",setTimeout((()=>this.flushIOSKey(t)),250),!0)}flushIOSKey(t){if(!this.pendingIOSKey)return!1;let e=t.contentDOM,i=this.pendingIOSKey;return this.pendingIOSKey=null,"enter"==i?ii(e,"Enter",13):ii(e,"Backspace",8)}ignoreDuringComposition(t){return!!/^key/.test(t.type)&&(this.composing>0||!!(xi.safari&&Date.now()-this.compositionEndedAt<500)&&(this.compositionEndedAt=0,!0))}screenKeyEvent(t,e){let i=9==e.keyCode&&Date.now()<this.lastEscPress+2e3;return 27==e.keyCode?this.lastEscPress=Date.now():Js.indexOf(e.keyCode)<0&&(this.lastEscPress=0),i}mustFlushObserver(t){return"keydown"==t.type&&229!=t.keyCode||"compositionend"==t.type&&!xi.ios}startMouseSelection(t,e,i){this.mouseSelection&&this.mouseSelection.destroy(),this.mouseSelection=new Xs(this,t,e,i)}update(t){this.mouseSelection&&this.mouseSelection.update(t),t.transactions.length&&(this.lastKeyCode=this.lastSelectionTime=0)}destroy(){this.mouseSelection&&this.mouseSelection.destroy()}}const Js=[16,17,18,20,91,92,224,225];class Xs{constructor(t,e,i,s){this.inputState=t,this.view=e,this.style=s,this.lastEvent=i;let n=e.contentDOM.ownerDocument;n.addEventListener("mousemove",this.move=this.move.bind(this)),n.addEventListener("mouseup",this.up=this.up.bind(this)),this.extend=i.shiftKey,this.multiple=e.state.facet(fe.allowMultipleSelections)&&function(t,e){let i=t.state.facet(Xi);return i.length?i[0](e):xi.mac?e.metaKey:e.ctrlKey}(e,i),this.dragMove=function(t,e){let i=t.state.facet(Yi);return i.length?i[0](e):xi.mac?!e.altKey:!e.ctrlKey}(e,i),this.dragging=!!function(t,e){let{main:i}=t.state.selection;if(i.empty)return!1;let s=Fe(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}(e,i)&&null,!1===this.dragging&&(i.preventDefault(),this.select(i))}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.inputState.mouseSelection=null}select(t){let e=this.style.get(t,this.extend,this.multiple);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})}update(t){t.docChanged&&this.dragging&&(this.dragging=this.dragging.map(t.changes)),this.style.update(t)&&setTimeout((()=>this.select(this.lastEvent)),20)}}function Ys(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=hi.get(s))&&i.ignoreEvent(e))return!1;return!0}const Qs=Object.create(null),Zs=xi.ie&&xi.ie_version<15||xi.ios&&xi.webkit_version<604;function tn(t,e){let i,{state:s}=t,n=1,r=s.toText(e),o=r.lines==s.selection.ranges.length;if(null!=dn&&s.selection.ranges.every((t=>t.empty))&&dn==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:kt.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:kt.cursor(t.from+e.length)}})):s.replaceSelection(r);t.dispatch(i,{userEvent:"input.paste",scrollIntoView:!0})}Qs.keydown=(t,e)=>{t.inputState.setSelectionOrigin("select")};let en=0;function sn(t,e,i,s){if(1==s)return kt.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 kt.cursor(e);0==r?i=1:r==n.length&&(i=-1);let o=r,h=r;i<0?o=G(n.text,r,!1):h=G(n.text,r);let l=s(n.text.slice(o,h));for(;o>0;){let t=G(n.text,o,!1);if(s(n.text.slice(t,o))!=l)break;o=t}for(;h<n.length;){let t=G(n.text,h);if(s(n.text.slice(h,t))!=l)break;h=t}return kt.range(o+n.from,h+n.from)}(t.state,e,i);{let i=_i.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++,kt.range(n,r)}}Qs.touchstart=(t,e)=>{en=Date.now(),t.inputState.setSelectionOrigin("select.pointer")},Qs.touchmove=t=>{t.inputState.setSelectionOrigin("select.pointer")},Qs.mousedown=(t,e)=>{if(t.observer.flush(),en>Date.now()-2e3)return;let i=null;for(let s of t.state.facet(Qi))if(i=s(t,e),i)break;i||0!=e.button||(i=function(t,e){let i=hn(t,e),s=function(t){if(!ln)return t.detail;let e=an,i=un;return an=t,un=Date.now(),cn=!e||i>Date.now()-400&&Math.abs(e.clientX-t.clientX)<2&&Math.abs(e.clientY-t.clientY)<2?(cn+1)%3:1}(e),n=t.state.selection,r=i,o=e;return{update(t){t.changes&&(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=hn(t,e),o=e),!a||!i)return n;let c=sn(t,a.pos,a.bias,s);if(i.pos!=a.pos&&!h){let e=sn(t,i.pos,i.bias,s),n=Math.min(e.from,c.from),r=Math.max(e.to,c.to);c=n<c.from?kt.range(n,r):kt.range(r,n)}return h?n.replaceRange(n.main.extend(c.from,c.to)):l?n.addRange(c):kt.create([c])}}}(t,e)),i&&(t.root.activeElement!=t.contentDOM&&t.observer.ignore((()=>ti(t.contentDOM))),t.inputState.startMouseSelection(t,e,i))};let nn=(t,e)=>t>=e.top&&t<=e.bottom,rn=(t,e,i)=>nn(e,i)&&t>=i.left&&t<=i.right;function on(t,e,i,s){let n=_i.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&&rn(i,s,o))return-1;let h=n.coordsAt(r,1);return h&&rn(i,s,h)?1:o&&nn(s,o)?-1:1}function hn(t,e){let i=t.posAtCoords({x:e.clientX,y:e.clientY},!1);return{pos:i,bias:on(t,i,e.clientX,e.clientY)}}const ln=xi.ie&&xi.ie_version<=11;let an=null,cn=0,un=0;function fn(t,e,i,s){let n=t.posAtCoords({x:e.clientX,y:e.clientY});if(null==n||!i)return;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"})}Qs.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")},Qs.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&&fn(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 fn(t,e,e.dataTransfer.getData("Text"),!0)},Qs.paste=(t,e)=>{if(t.state.readOnly)return e.preventDefault();t.observer.flush();let i=Zs?null:e.clipboardData;i?(tn(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(),tn(t,i.value)}),50)}(t)};let dn=null;function pn(t,e){if(t.docView.compositionDeco.size){t.inputState.rapidCompositionStart=e;try{t.update([])}finally{t.inputState.rapidCompositionStart=!1}}}Qs.copy=Qs.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;dn=n?i:null;let r=Zs?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"})},Qs.focus=Qs.blur=t=>{setTimeout((()=>{t.hasFocus!=t.inputState.notifiedFocused&&t.update([])}),10)},Qs.beforeprint=t=>{t.viewState.printing=!0,t.requestMeasure(),setTimeout((()=>{t.viewState.printing=!1,t.requestMeasure()}),2e3)},Qs.compositionstart=Qs.compositionupdate=t=>{null==t.inputState.compositionFirstChange&&(t.inputState.compositionFirstChange=!0),t.inputState.composing<0&&(t.docView.compositionDeco.size&&(t.observer.flush(),pn(t,!0)),t.inputState.composing=0)},Qs.compositionend=t=>{t.inputState.composing=-1,t.inputState.compositionEndedAt=Date.now(),t.inputState.compositionFirstChange=null,setTimeout((()=>{t.inputState.composing<0&&pn(t,!1)}),50)},Qs.contextmenu=t=>{t.inputState.lastContextMenu=Date.now()};const gn=["pre-wrap","normal","pre-line"];class mn{constructor(){this.doc=it.empty,this.lineWrapping=!1,this.direction=Ss.LTR,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}mustRefresh(t,e,i){let s=!1;for(let e=0;e<t.length;e++){let i=t[e];i<0?e++:this.heightSamples[Math.floor(10*i)]||(s=!0,this.heightSamples[Math.floor(10*i)]=!0)}return s||gn.indexOf(e)>-1!=this.lineWrapping||this.direction!=i}refresh(t,e,i,s,n,r){let o=gn.indexOf(t)>-1,h=Math.round(i)!=Math.round(this.lineHeight)||this.lineWrapping!=o||this.direction!=e;if(this.lineWrapping=o,this.direction=e,this.lineHeight=i,this.charWidth=s,this.lineLength=n,h){this.heightSamples={};for(let t=0;t<r.length;t++){let e=r[t];e<0?t++:this.heightSamples[Math.floor(10*e)]=!0}}return h}}class vn{constructor(t,e){this.from=t,this.heights=e,this.index=0}get more(){return this.index<this.heights.length}}class wn{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 wn(this.from,this.length+t.length,this.top,this.height+t.height,e)}}var bn=function(t){return t[t.ByPos=0]="ByPos",t[t.ByHeight=1]="ByHeight",t[t.ByPosNoHeight=2]="ByPosNoHeight",t}(bn||(bn={}));class yn{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)>1e-4&&(t.heightChanged=!0),this.height=e)}replace(t,e,i){return yn.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,bn.ByPosNoHeight,e,0,0),u=c.to>=h?c:n.lineAt(h,bn.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,bn.ByPosNoHeight,e,0,0));l+=c.from-o,o=c.from;let f=Mn.build(i,t,l,a);n=n.replace(o,h,f)}return n.updateHeight(i,0)}static empty(){return new kn(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 An(yn.of(t.slice(0,e)),r,yn.of(t.slice(i)))}}yn.prototype.size=1;class xn extends yn{constructor(t,e,i){super(t,e),this.type=i}blockAt(t,e,i,s){return new wn(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){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 kn extends xn{constructor(t,e){super(t,e,Vi.Text),this.collapsed=0,this.widgetHeight=0}replace(t,e,i){let s=i[0];return 1==i.length&&(s instanceof kn||s instanceof Sn&&4&s.flags)&&Math.abs(this.length-s.length)<10?(s instanceof Sn?s=new kn(s.length,this.height):s.height=this.height,this.outdated||(s.outdated=!1),s):yn.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 Sn extends yn{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 wn(l,a,i+o*h,o,Vi.Text)}lineAt(t,e,i,s,n){if(e==bn.ByHeight)return this.blockAt(t,i,s,n);if(e==bn.ByPosNoHeight){let{from:e,to:s}=i.lineAt(t);return new wn(e,s-e,0,0,Vi.Text)}let{firstLine:r,lineHeight:o}=this.lines(i,n),{from:h,length:l,number:a}=i.lineAt(t);return new wn(h,l,s+o*(a-r),o,Vi.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 wn(e.from,e.length,s,h,Vi.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 Sn?i[i.length-1]=new Sn(t.length+s):i.push(null,new Sn(s-1))}if(t>0){let e=i[0];e instanceof Sn?i[0]=new Sn(t+e.length):i.unshift(new Sn(t-1),null)}return yn.of(i)}decomposeLeft(t,e){e.push(new Sn(t-1),null)}decomposeRight(t,e){e.push(null,new Sn(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);for(s.from>e&&i.push(new Sn(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=new kn(e,s.heights[s.index++]);n.outdated=!1,i.push(n),r+=e+1}return r<=n&&i.push(null,new Sn(n-r).updateHeight(t,r)),t.heightChanged=!0,yn.of(i)}return(i||this.outdated)&&(this.setHeight(t,t.heightForGap(e,e+this.length)),this.outdated=!1),this}toString(){return`gap(${this.length})`}}class An extends yn{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||0==this.right.height?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==bn.ByHeight?t<r||0==this.right.height: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==bn.ByPosNoHeight?bn.ByPosNoHeight:bn.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,bn.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&&Cn(n,r-1),e<this.length){let t=n.length;this.decomposeRight(e,n),Cn(n,t)}return yn.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?yn.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 Cn(t,e){let i,s;null==t[e]&&(i=t[e-1])instanceof Sn&&(s=t[e+1])instanceof Sn&&t.splice(e-1,3,new Sn(i.length+1+s.length))}class Mn{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 kn?i.length+=t-this.pos:(t>this.pos||!this.isCovered)&&this.nodes.push(new kn(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?Math.max(0,i.widget.estimatedHeight):0,n=e-t;i.block?this.addBlock(new xn(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 kn(this.pos-t,-1)),this.writtenTo=this.pos}blankContent(t,e){let i=new Sn(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 kn)return t;let e=new kn(0,-1);return this.nodes.push(e),e}addBlock(t){this.enterLine(),t.type!=Vi.WidgetAfter||this.isCovered||this.ensureLine(),this.nodes.push(t),this.writtenTo=this.pos=this.pos+t.length,t.type!=Vi.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 kn||this.isCovered?(this.writtenTo<this.pos||null==e)&&this.nodes.push(this.blankContent(this.writtenTo,this.pos)):this.nodes.push(new kn(0,-1));let i=t;for(let t of this.nodes)t instanceof kn&&t.updateHeight(this.oracle,i),i+=t?t.length:1;return this.nodes}static build(t,e,i,s){let n=new Mn(i,t);return we.spans(e,i,s,n,0),n.finish(i)}}class Dn{constructor(){this.changes=[]}compareRange(){}comparePoint(t,e,i,s){(t<e||i&&i.heightRelevant||s&&s.heightRelevant)&&ji(t,e,this.changes,5)}}class Tn{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 Hi.replace({widget:new On(this.size,t)}).range(this.from,this.to)}}class On extends Bi{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 Pn{constructor(t){this.state=t,this.pixelViewport={left:0,right:window.innerWidth,top:0,bottom:0},this.inView=!0,this.paddingTop=0,this.paddingBottom=0,this.contentWidth=0,this.heightOracle=new mn,this.scaler=In,this.scrollTo=null,this.printing=!1,this.visibleRanges=[],this.mustEnforceCursorAssoc=!1,this.heightMap=yn.empty().applyChanges(t.facet(ps),it.empty,this.heightOracle.setDoc(t.doc),[new ms(0,0,0,t.doc.length)]),this.viewport=this.getViewport(0,null),this.updateForViewport(),this.lineGaps=this.ensureLineGaps([]),this.lineGapDeco=Hi.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.lineAt(s,0);t.push(new En(e,i))}}this.viewports=t.sort(((t,e)=>t.from-e.from)),this.scaler=this.heightMap.height<=7e6?In:new Bn(this.heightOracle.doc,this.heightMap,this.viewports)}update(t,e=null){let i=this.state;this.state=t.state;let s=this.state.facet(ps),n=t.changedRanges,r=ms.extendWithRanges(n,function(t,e,i){let s=new Dn;return we.compare(t,e,i,s,0),s.changes}(t.startState.facet(ps),s,t?t.changes:pt.empty(this.state.doc.length))),o=this.heightMap.height;this.heightMap=this.heightMap.applyChanges(s,i.doc,this.heightOracle.setDoc(this.state.doc),r),this.heightMap.height!=o&&(t.flags|=2);let h=r.length?this.mapViewport(this.viewport,t.changes):this.viewport;(e&&(e.head<h.from||e.head>h.to)||!this.viewportIsAppropriate(h))&&(h=this.getViewport(0,e)),this.viewport=h,this.updateForViewport(),(this.lineGaps.length||this.viewport.to-this.viewport.from>15e3)&&this.updateLineGaps(this.ensureLineGaps(this.mapLineGaps(this.lineGaps,t.changes))),t.flags|=this.computeVisibleRanges(),e&&(this.scrollTo=e),!this.mustEnforceCursorAssoc&&t.selectionSet&&t.view.lineWrapping&&t.state.selection.main.empty&&t.state.selection.main.assoc&&(this.mustEnforceCursorAssoc=!0)}measure(t,e){let i=t.dom,s="",n=Ss.LTR,r=0;if(!e){let t=window.getComputedStyle(i);s=t.whiteSpace,n="rtl"==t.direction?Ss.RTL:Ss.LTR;let e=parseInt(t.paddingTop)||0,o=parseInt(t.paddingBottom)||0;this.paddingTop==e&&this.paddingBottom==o||(r|=8,this.paddingTop=e,this.paddingBottom=o)}let o=this.printing?{top:-1e8,bottom:1e8,left:-1e8,right:1e8}:function(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);for(let e=t.parentNode;e;)if(1==e.nodeType){let t=window.getComputedStyle(e);if((e.scrollHeight>e.clientHeight||e.scrollWidth>e.clientWidth)&&"visible"!=t.overflow){let t=e.getBoundingClientRect();s=Math.max(s,t.left),n=Math.min(n,t.right),r=Math.max(r,t.top),o=Math.min(o,t.bottom)}e="absolute"==t.position||"fixed"==t.position?e.offsetParent:e.parentNode}else{if(11!=e.nodeType)break;e=e.host}return{left:s-i.left,right:n-i.left,top:r-(i.top+e),bottom:o-(i.top+e)}}(i,this.paddingTop),h=o.top-this.pixelViewport.top,l=o.bottom-this.pixelViewport.bottom;if(this.pixelViewport=o,this.inView=this.pixelViewport.bottom>this.pixelViewport.top&&this.pixelViewport.right>this.pixelViewport.left,!this.inView)return 0;let a=t.measureVisibleLineHeights(),c=!1,u=0,f=this.heightOracle;if(!e){let e=t.dom.clientWidth;if(f.mustRefresh(a,s,n)||f.lineWrapping&&Math.abs(e-this.contentWidth)>f.charWidth){let{lineHeight:i,charWidth:o}=t.measureTextSize();c=f.refresh(s,n,i,o,e/o,a),c&&(t.minWidth=0,r|=8)}this.contentWidth!=e&&(this.contentWidth=e,r|=8),h>0&&l>0?u=Math.max(h,l):h<0&&l<0&&(u=Math.min(h,l))}return f.heightChanged=!1,this.heightMap=this.heightMap.updateHeight(f,0,c,new vn(this.viewport.from,a)),f.heightChanged&&(r|=2),(!this.viewportIsAppropriate(this.viewport,u)||this.scrollTo&&(this.scrollTo.head<this.viewport.from||this.scrollTo.head>this.viewport.to))&&(this.viewport=this.getViewport(u,this.scrollTo)),this.updateForViewport(),(this.lineGaps.length||this.viewport.to-this.viewport.from>15e3)&&this.updateLineGaps(this.ensureLineGaps(c?[]:this.lineGaps)),r|=this.computeVisibleRanges(),this.mustEnforceCursorAssoc&&(this.mustEnforceCursorAssoc=!1,t.enforceCursorAssoc()),r}get visibleTop(){return this.scaler.fromDOM(this.pixelViewport.top,0)}get visibleBottom(){return this.scaler.fromDOM(this.pixelViewport.bottom,0)}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 En(s.lineAt(r-1e3*i,bn.ByHeight,n,0,0).from,s.lineAt(o+1e3*(1-i),bn.ByHeight,n,0,0).to);if(e)if(e.head<h.from){let{top:t}=s.lineAt(e.head,bn.ByPos,n,0,0);h=new En(s.lineAt(t-500,bn.ByHeight,n,0,0).from,s.lineAt(t+(o-r)+500,bn.ByHeight,n,0,0).to)}else if(e.head>h.to){let{bottom:t}=s.lineAt(e.head,bn.ByPos,n,0,0);h=new En(s.lineAt(t-(o-r)-500,bn.ByHeight,n,0,0).from,s.lineAt(t+500,bn.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 En(this.heightMap.lineAt(i,bn.ByPos,this.state.doc,0,0).from,this.heightMap.lineAt(s,bn.ByPos,this.state.doc,0,0).to)}viewportIsAppropriate({from:t,to:e},i=0){let{top:s}=this.heightMap.lineAt(t,bn.ByPos,this.state.doc,0,0),{bottom:n}=this.heightMap.lineAt(e,bn.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 Tn(e.mapPos(s.from),e.mapPos(s.to),s.size));return i}ensureLineGaps(t){let e=[];return this.heightOracle.direction!=Ss.LTR||this.heightMap.forEachLine(this.viewport.from,this.viewport.to,this.state.doc,0,0,(i=>{if(i.length<1e4)return;let s,n,r=function(t,e,i){let s=[],n=t,r=0;we.spans(i.facet(ps),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);return{total:r,ranges:s}}(i.from,i.to,this.state);if(r.total<1e4)return;if(this.heightOracle.lineWrapping)s=i.from!=this.viewport.from?i.from:Rn(r,(this.visibleTop-i.top)/i.height),n=i.to!=this.viewport.to?i.to:Rn(r,(this.visibleBottom-i.top)/i.height);else{let t=r.total*this.heightOracle.charWidth;s=Rn(r,this.pixelViewport.left/t),n=Rn(r,this.pixelViewport.right/t)}let o=this.state.selection.main;o.from<=s&&o.to>=i.from&&(s=o.from),o.from<=i.to&&o.to>=n&&(n=o.to);let h=s-1e4,l=n+1e4;h>i.from+5e3&&e.push(Nn(t,(t=>t.from==i.from&&t.to>h-5e3&&t.to<h+5e3))||new Tn(i.from,h,this.gapSize(i,h,!0,r))),l<i.to-5e3&&e.push(Nn(t,(t=>t.to==i.to&&t.from>l-5e3&&t.from<l+5e3))||new Tn(l,i.to,this.gapSize(i,l,!1,r)))})),e}gapSize(t,e,i,s){if(this.heightOracle.lineWrapping){let n=t.height*Ln(s,e);return i?n:t.height-n}{let t=Ln(s,e);return s.total*this.heightOracle.charWidth*(i?t:1-t)}}updateLineGaps(t){Tn.same(t,this.lineGaps)||(this.lineGaps=t,this.lineGapDeco=Hi.set(t.map((t=>t.draw(this.heightOracle.lineWrapping)))))}computeVisibleRanges(){let t=this.state.facet(ps);this.lineGaps.length&&(t=t.concat(this.lineGapDeco));let e=[];we.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}lineAt(t,e){return e+=this.paddingTop,Vn(this.heightMap.lineAt(t,bn.ByPos,this.state.doc,e,0),this.scaler,e)}lineAtHeight(t,e){return e+=this.paddingTop,Vn(this.heightMap.lineAt(this.scaler.fromDOM(t,e),bn.ByHeight,this.state.doc,e,0),this.scaler,e)}blockAtHeight(t,e){return e+=this.paddingTop,Vn(this.heightMap.blockAt(this.scaler.fromDOM(t,e),this.state.doc,e,0),this.scaler,e)}forEachLine(t,e,i,s){return s+=this.paddingTop,this.heightMap.forEachLine(t,e,this.state.doc,s,0,1==this.scaler.scale?i:t=>i(Vn(t,this.scaler,s)))}get contentHeight(){return this.domHeight+this.paddingTop+this.paddingBottom}get domHeight(){return this.scaler.toDOM(this.heightMap.height,this.paddingTop)}}class En{constructor(t,e){this.from=t,this.to=e}}function Rn({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 Ln(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 Nn(t,e){for(let i of t)if(e(i))return i}const In={toDOM:t=>t,fromDOM:t=>t,scale:1};class Bn{constructor(t,e,i){let s=0,n=0,r=0;this.viewports=i.map((({from:i,to:n})=>{let r=e.lineAt(i,bn.ByPos,t,0,0).top,o=e.lineAt(n,bn.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,e){t-=e;for(let i=0,s=0,n=0;;i++){let r=i<this.viewports.length?this.viewports[i]:null;if(!r||t<r.top)return n+(t-s)*this.scale+e;if(t<=r.bottom)return r.domTop+(t-r.top)+e;s=r.bottom,n=r.domBottom}}fromDOM(t,e){t-=e;for(let i=0,s=0,n=0;;i++){let r=i<this.viewports.length?this.viewports[i]:null;if(!r||t<r.domTop)return s+(t-n)/this.scale+e;if(t<=r.domBottom)return r.top+(t-r.domTop)+e;s=r.bottom,n=r.domBottom}}}function Vn(t,e,i){if(1==e.scale)return t;let s=e.toDOM(t.top,i),n=e.toDOM(t.bottom,i);return new wn(t.from,t.length,s,n-s,Array.isArray(t.type)?t.type.map((t=>Vn(t,e,i))):t.type)}const Hn=Mt.define({combine:t=>t.join(" ")}),zn=Mt.define({combine:t=>t.indexOf(!0)>-1}),Fn=W.newName(),Wn=W.newName(),qn=W.newName(),jn={"&light":"."+Wn,"&dark":"."+qn};function _n(t,e,i){return new W(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 $n=_n("."+Fn,{"&":{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"},".cm-lineWrapping":{whiteSpace:"pre-wrap",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":{position:"absolute",borderLeft:"1.2px solid black",marginLeft:"-0.6px",pointerEvents:"none",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-tab":{display:"inline-block",overflow:"hidden",verticalAlign:"bottom"},".cm-placeholder":{color:"#888",display:"inline-block"},".cm-button":{verticalAlign:"middle",color:"inherit",fontSize:"70%",padding:".2em 1em",borderRadius:"3px"},"&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"}},jn),Un={childList:!0,characterData:!0,subtree:!0,attributes:!0,characterDataOldValue:!0},Gn=xi.ie&&xi.ie_version<=11;class Kn{constructor(t,e,i){this.view=t,this.onChange=e,this.onScrollChanged=i,this.active=!1,this.ignoreSelection=new Ye,this.delayedFlush=-1,this.queue=[],this.lastFlush=0,this.scrollTargets=[],this.intersection=null,this.intersecting=!1,this.gapIntersection=null,this.gaps=[],this._selectionRange=null,this.parentCheck=-1,this.dom=t.contentDOM,this.observer=new MutationObserver((e=>{for(let t of e)this.queue.push(t);this._selectionRange=null,(xi.ie&&xi.ie_version<=11||xi.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()})),Gn&&(this.onCharData=t=>{this.queue.push({target:t.target,type:"characterData",oldValue:t.prevValue}),this.flushSoon()}),this.onSelectionChange=this.onSelectionChange.bind(this),this.start(),this.onScroll=this.onScroll.bind(this),window.addEventListener("scroll",this.onScroll),"function"==typeof IntersectionObserver&&(this.intersection=new IntersectionObserver((t=>{this.parentCheck<0&&(this.parentCheck=setTimeout(this.listenForScroll.bind(this),1e3)),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[t.length-1].intersectionRatio>0&&this.onScrollChanged(document.createEvent("Event"))}),{})),this.listenForScroll()}onScroll(t){this.intersecting&&this.flush(),this.onScrollChanged(t)}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){this.lastFlush<Date.now()-50&&(this._selectionRange=null);let{view:e}=this,i=this.selectionRange;if(e.state.facet(ns)?e.root.activeElement!=this.dom:!qe(e.dom,i))return;let s=i.anchorNode&&e.docView.nearest(i.anchorNode);s&&s.ignoreEvent(t)||(xi.ie&&xi.ie_version<=11&&!e.state.selection.main.empty&&i.focusNode&&_e(i.focusNode,i.focusOffset,i.anchorNode,i.anchorOffset)?this.flushSoon():this.flush())}get selectionRange(){if(!this._selectionRange){let{root:t}=this.view,e=Fe(t);xi.safari&&11==t.nodeType&&function(){let t=document.activeElement;for(;t&&t.shadowRoot;)t=t.shadowRoot.activeElement;return t}()==this.view.contentDOM&&(e=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);_e(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),this._selectionRange=e}return this._selectionRange}setSelectionRange(t,e){var i;(null===(i=this._selectionRange)||void 0===i?void 0:i.type)||(this._selectionRange={anchorNode:t.node,anchorOffset:t.offset,focusNode:e.node,focusOffset:e.offset})}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,Un),this.dom.ownerDocument.addEventListener("selectionchange",this.onSelectionChange),Gn&&this.dom.addEventListener("DOMCharacterDataModified",this.onCharData),this.active=!0)}stop(){this.active&&(this.active=!1,this.observer.disconnect(),this.dom.ownerDocument.removeEventListener("selectionchange",this.onSelectionChange),Gn&&this.dom.removeEventListener("DOMCharacterDataModified",this.onCharData))}clearSelection(){this.ignoreSelection.set(this.selectionRange)}clear(){this.observer.takeRecords(),this.queue.length=0,this.clearSelection()}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())}flush(){if(this.delayedFlush>=0)return;this.lastFlush=Date.now();let t=this.queue;for(let e of this.observer.takeRecords())t.push(e);t.length&&(this.queue=[]);let e=this.selectionRange,i=!this.ignoreSelection.eq(e)&&qe(this.dom,e);if(0==t.length&&!i)return;let s=-1,n=-1,r=!1;for(let e of t){let t=this.readMutation(e);t&&(t.typeOver&&(r=!0),-1==s?({from:s,to:n}=t):(s=Math.min(t.from,s),n=Math.max(t.to,n)))}let o=this.view.state;(s>-1||i)&&this.onChange(s,n,r),this.view.state==o&&(this.view.docView.dirty&&(this.ignore((()=>this.view.docView.sync())),this.view.docView.dirty=0),i&&this.view.docView.updateSelection()),this.clearSelection()}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=Jn(e,t.previousSibling||t.target.previousSibling,-1),s=Jn(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(){this.stop(),this.intersection&&this.intersection.disconnect(),this.gapIntersection&&this.gapIntersection.disconnect();for(let t of this.scrollTargets)t.removeEventListener("scroll",this.onScroll);window.removeEventListener("scroll",this.onScroll),clearTimeout(this.parentCheck)}}function Jn(t,e,i){for(;e;){let s=hi.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 Xn(t,e,i,s){let n,r,o,h=t.state.selection.main;if(e>-1&&!t.state.readOnly&&(o=t.docView.domBoundsAround(e,i,0))){let{from:e,to:i}=o,s=t.docView.impreciseHead||t.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 Zn(i,s)),n==i&&r==s||e.push(new Zn(n,r)));return e}(t),l=new Yn(s,t);l.readRange(o.startDOM,o.endDOM),r=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?kt.single(i+e,s+e):null}(s,e);let a=h.from,c=null;(8===t.inputState.lastKeyCode&&t.inputState.lastKeyTime>Date.now()-100||xi.android&&l.text.length<i-e)&&(a=h.to,c="end");let u=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}}(t.state.sliceDoc(e,i),l.text,a-e,c);u&&(n={from:e+u.from,to:e+u.toA,insert:t.state.toText(l.text.slice(u.from,u.toB))})}else if(t.hasFocus||!t.state.facet(ns)){let e=t.observer.selectionRange,{impreciseHead:i,impreciseAnchor:s}=t.docView,n=i&&i.node==e.focusNode&&i.offset==e.focusOffset||!We(t.contentDOM,e.focusNode)?t.state.selection.main.head:t.docView.posFromDOM(e.focusNode,e.focusOffset),o=s&&s.node==e.anchorNode&&s.offset==e.anchorOffset||!We(t.contentDOM,e.anchorNode)?t.state.selection.main.anchor:t.docView.posFromDOM(e.anchorNode,e.anchorOffset);n==h.head&&o==h.anchor||(r=kt.single(o,n))}if(n||r)if(!n&&s&&!h.empty&&r&&r.main.empty?n={from:h.from,to:h.to,insert:t.state.doc.slice(h.from,h.to)}:n&&n.from>=h.from&&n.to<=h.to&&(n.from!=h.from||n.to!=h.to)&&h.to-h.from-(n.to-n.from)<=4&&(n={from:h.from,to:h.to,insert:t.state.doc.slice(h.from,n.from).append(n.insert).append(t.state.doc.slice(n.to,h.to))}),n){let e=t.state;if(xi.android&&(n.from==h.from&&n.to==h.to&&1==n.insert.length&&2==n.insert.lines&&ii(t.contentDOM,"Enter",13)||n.from==h.from-1&&n.to==h.to&&0==n.insert.length&&ii(t.contentDOM,"Backspace",8)||n.from==h.from&&n.to==h.to+1&&0==n.insert.length&&ii(t.contentDOM,"Delete",46))||xi.ios&&t.inputState.flushIOSKey(t))return;let i,s=n.insert.toString();if(t.state.facet(es).some((e=>e(t,n.from,n.to,s))))return;if(t.inputState.composing>=0&&t.inputState.composing++,n.from>=h.from&&n.to<=h.to&&n.to-n.from>=(h.to-h.from)/3&&(!r||r.main.empty&&r.main.from==n.from+n.insert.length)){let s=h.from<n.from?e.sliceDoc(h.from,n.from):"",r=h.to>n.to?e.sliceDoc(n.to,h.to):"";i=e.replaceSelection(t.state.toText(s+n.insert.sliceString(0,void 0,t.state.lineBreak)+r))}else{let t=e.changes(n);i={changes:t,selection:r&&!e.selection.main.eq(r.main)&&r.main.to<=t.newLength?e.selection.replaceRange(r.main):void 0}}let o="input.type";t.composing&&(o+=".compose",t.inputState.compositionFirstChange&&(o+=".start",t.inputState.compositionFirstChange=!1)),t.dispatch(i,{scrollIntoView:!0,userEvent:o})}else if(r&&!r.main.eq(h)){let e=!1,i="select";t.inputState.lastSelectionTime>Date.now()-50&&("select"==t.inputState.lastSelectionOrigin&&(e=!0),i=t.inputState.lastSelectionOrigin),t.dispatch({selection:r,scrollIntoView:e,userEvent:i})}}class Yn{constructor(t,e){this.points=t,this.view=e,this.text="",this.lineBreak=e.state.lineBreak}readRange(t,e){if(!t)return;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=hi.get(s),r=hi.get(t);(n&&r?n.breakAfter:(n?n.breakAfter:Qn(s))||Qn(t)&&("BR"!=s.nodeName||s.cmIgnore))&&(this.text+=this.lineBreak),s=t}this.findPointBefore(i,e)}readNode(t){if(t.cmIgnore)return;let e,i=hi.get(t),s=i&&i.overrideDOMText;null!=s?e=s.sliceString(0,void 0,this.lineBreak):3==t.nodeType?e=t.nodeValue:"BR"==t.nodeName?e=t.nextSibling?this.lineBreak:"":1==t.nodeType&&this.readRange(t.firstChild,null),null!=e&&(this.findPointIn(t,e.length),this.text+=e,xi.chrome&&13==this.view.inputState.lastKeyCode&&!t.nextSibling&&/\n\n$/.test(this.text)&&(this.text=this.text.slice(0,-1)))}findPointBefore(t,e){for(let i of this.points)i.node==t&&t.childNodes[i.offset]==e&&(i.pos=this.text.length)}findPointIn(t,e){for(let i of this.points)i.node==t&&(i.pos=this.text.length+Math.min(i.offset,e))}}function Qn(t){return 1==t.nodeType&&/^(DIV|P|LI|UL|OL|BLOCKQUOTE|DD|DT|H\d|SECTION|PRE)$/.test(t.nodeName)}class Zn{constructor(t,e){this.node=t,this.offset=e,this.pos=-1}}class tr{constructor(t={}){this.plugins=[],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||document,this.viewState=new Pn(t.state||fe.create()),this.plugins=this.state.facet(ls).map((t=>new us(t).update(this))),this.observer=new Kn(this,((t,e,i)=>{Xn(this,t,e,i)}),(t=>{this.inputState.runScrollHandlers(this,t),this.observer.intersecting&&this.measure()})),this.inputState=new Ks(this),this.docView=new ws(this),this.mountStyles(),this.updateAttrs(),this.updateState=0,window.addEventListener("resize",(()=>{-1==sr&&(sr=setTimeout(nr,50))})),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}dispatch(...t){this._dispatch(1==t.length&&t[0]instanceof ee?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(fe.phrases)!=this.state.facet(fe.phrases))return this.setState(s);e=new vs(this,s,t);let n=null;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=t.empty?t:kt.cursor(t.head,t.head>t.anchor?-1:1)}for(let t of e.effects)t.is(is)&&(n=t.value)}this.viewState.update(e,n),this.bidiCache=or.update(this.bidiCache,e.changes),e.empty||(this.updatePlugins(e),this.inputState.update(e)),i=this.docView.update(e),this.state.facet(gs)!=this.styleModules&&this.mountStyles(),this.updateAttrs(),this.showAnnouncements(t)}finally{this.updateState=0}if((i||n||this.viewState.mustEnforceCursorAssoc)&&this.requestMeasure(),!e.empty)for(let t of this.state.facet(ts))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)this.viewState.state=t;else{this.updateState=2;try{for(let t of this.plugins)t.destroy(this);this.viewState=new Pn(t),this.plugins=t.facet(ls).map((t=>new us(t).update(this))),this.docView=new ws(this),this.inputState.ensureHandlers(this),this.mountStyles(),this.updateAttrs(),this.bidiCache=[]}finally{this.updateState=0}this.requestMeasure()}}updatePlugins(t){let e=t.startState.facet(ls),i=t.state.facet(ls);if(e!=i){let s=[];for(let n of i){let i=e.indexOf(n);if(i<0)s.push(new us(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.inputState.ensureHandlers(this)}else for(let e of this.plugins)e.mustUpdate=t;for(let t=0;t<this.plugins.length;t++)this.plugins[t]=this.plugins[t].update(this)}measure(t=!0){if(this.destroyed)return;this.measureScheduled>-1&&cancelAnimationFrame(this.measureScheduled),this.measureScheduled=-1,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.docView,t>0);if(!s&&!this.measureRequests.length&&null==this.viewState.scrollTo)break;if(t>5){console.warn("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 ss(this.state,t),rr}})),o=new vs(this,this.state);o.flags|=s,e?e.flags|=s:e=o,this.updateState=2,o.empty||(this.updatePlugins(o),this.inputState.update(o)),this.updateAttrs(),s&&this.docView.update(o);for(let t=0;t<n.length;t++)if(r[t]!=rr)try{n[t].write(r[t],this)}catch(t){ss(this.state,t)}if(this.viewState.scrollTo&&(this.docView.scrollRangeIntoView(this.viewState.scrollTo),this.viewState.scrollTo=null),this.viewport.from==i.from&&this.viewport.to==i.to&&0==this.measureRequests.length)break}}finally{this.updateState=0}if(this.measureScheduled=-1,e&&!e.empty)for(let t of this.state.facet(ts))t(e)}get themeClasses(){return Fn+" "+(this.state.facet(zn)?qn:Wn)+" "+this.state.facet(Hn)}updateAttrs(){let t=Li(this.state.facet(fs),{class:"cm-editor"+(this.hasFocus?" cm-focused ":" ")+this.themeClasses});Ii(this.dom,this.editorAttrs,t),this.editorAttrs=t;let e={spellcheck:"false",autocorrect:"off",autocapitalize:"off",contenteditable:this.state.facet(ns)?ni()?"plaintext-only":"true":"false",class:"cm-content",style:`${xi.tabSize}: ${this.state.tabSize}`,role:"textbox","aria-multiline":"true"};this.state.readOnly&&(e["aria-readonly"]="true"),Li(this.state.facet(ds),e),Ii(this.contentDOM,this.contentAttrs,e),this.contentAttrs=e}showAnnouncements(t){let e=!0;for(let i of t)for(let t of i.effects)if(t.is(tr.announce)){e&&(this.announceDOM.textContent=""),e=!1,this.announceDOM.appendChild(document.createElement("div")).textContent=t.value}}mountStyles(){this.styleModules=this.state.facet(gs),W.mount(this.root,this.styleModules.concat($n).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)}}pluginField(t){let e=[];for(let i of this.plugins)i.update(this).takeField(t,e);return e}plugin(t){for(let e of this.plugins)if(e.spec==t)return e.update(this).value;return null}blockAtHeight(t,e){return this.readMeasured(),this.viewState.blockAtHeight(t,ir(e,this.contentDOM))}visualLineAtHeight(t,e){return this.readMeasured(),this.viewState.lineAtHeight(t,ir(e,this.contentDOM))}viewportLines(t,e){let{from:i,to:s}=this.viewport;this.viewState.forEachLine(i,s,t,ir(e,this.contentDOM))}visualLineAt(t,e=0){return this.viewState.lineAt(t,e)}get contentHeight(){return this.viewState.contentHeight}moveByChar(t,e,i){return Gs(this,t,Us(this,t,e,i))}moveByGroup(t,e){return Gs(this,t,Us(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==le.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.posAtCoords({x:i==(t.textDirection==Ss.LTR)?e.right-1:e.left+1,y:(r.top+r.bottom)/2});if(null!=s)return kt.cursor(s,i?-1:1)}let o=_i.find(t.docView,e.head),h=o?i?o.posAtEnd:o.posAtStart:i?n.to:n.from;return kt.cursor(h,i?-1:1)}(this,t,e,i)}moveVertically(t,e,i){return Gs(this,t,function(t,e,i,s){let n=e.head,r=i?1:-1;if(n==(i?t.state.doc.length:0))return kt.cursor(n);let o,h=e.goalColumn,l=t.contentDOM.getBoundingClientRect(),a=t.coordsAtPos(n);if(a)null==h&&(h=a.left-l.left),o=r<0?a.top:a.bottom;else{let e=t.viewState.lineAt(n,t.dom.getBoundingClientRect().top);null==h&&(h=Math.min(l.right-l.left,t.defaultCharacterWidth*(n-e.from))),o=r<0?e.top:e.bottom}let c=l.left+h,u=null!=s?s:t.defaultLineHeight>>1;for(let e=0;;e+=10){let i=o+(u+e)*r,s=_s(t,{x:c,y:i},!1,r);if(i<l.top||i>l.bottom||(r<0?s<n:s>n))return kt.cursor(s,void 0,void 0,h)}}(this,t,e,i))}scrollPosIntoView(t){this.viewState.scrollTo=kt.cursor(t),this.requestMeasure()}domAtPos(t){return this.docView.domAtPos(t)}posAtDOM(t,e=0){return this.docView.posFromDOM(t,e)}posAtCoords(t,e=!0){return this.readMeasured(),_s(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 Je(i,n[Rs.find(n,t-s.from,-1,e)].dir==Ss.LTR==e>0)}get defaultCharacterWidth(){return this.viewState.heightOracle.charWidth}get defaultLineHeight(){return this.viewState.heightOracle.lineHeight}get textDirection(){return this.viewState.heightOracle.direction}get lineWrapping(){return this.viewState.heightOracle.lineWrapping}bidiSpans(t){if(t.length>er)return Ns(t.length);let e=this.textDirection;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==As?1:2,n=e==As?2:1;if(!t||1==s&&!Es.test(t))return Ns(i);for(let e=0,n=s,o=s;e<i;e++){let i=(r=t.charCodeAt(e))<=247?Ds[r]:1424<=r&&r<=1524?2:1536<=r&&r<=1785?Ts[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),Ls[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=Ls[t];if(128==s)t<i-1&&e==Ls[t+1]&&24&e?s=Ls[t]=e:Ls[t]=256;else if(64==s){let s=t+1;for(;s<i&&64==Ls[s];)s++;let r=t&&8==e||s<i&&8==Ls[s]?1==n?1:8:256;for(let e=t;e<s;e++)Ls[e]=r;t=s-1}else 8==s&&1==n&&(Ls[t]=1);e=s,7&s&&(n=s)}for(let e,r,o,h=0,l=0,a=0;h<i;h++)if(r=Os[e=t.charCodeAt(h)])if(r<0){for(let t=l-3;t>=0;t-=3)if(Ps[t+1]==-r){let e=Ps[t+2],i=2&e?s:4&e?1&e?n:s:0;i&&(Ls[h]=Ls[Ps[t]]=i),l=t;break}}else{if(189==Ps.length)break;Ps[l++]=h,Ps[l++]=e,Ps[l++]=a}else if(2==(o=Ls[h])||1==o){let t=o==s;a=t?0:1;for(let e=l-3;e>=0;e-=3){let i=Ps[e+2];if(2&i)break;if(t)Ps[e+2]|=2;else{if(4&i)break;Ps[e+2]|=4}}}for(let t=0;t<i;t++)if(256==Ls[t]){let e=t+1;for(;e<i&&256==Ls[e];)e++;let n=1==(t?Ls[t-1]:s),r=n==(1==(e<i?Ls[e]:s))?n?1:2:s;for(let i=t;i<e;i++)Ls[i]=r;t=e-1}let o=[];if(1==s)for(let t=0;t<i;){let e=t,s=1!=Ls[t++];for(;t<i&&s==(1!=Ls[t]);)t++;if(s)for(let i=t;i>e;){let t=i,s=2!=Ls[--i];for(;i>e&&s==(2!=Ls[i-1]);)i--;o.push(new Rs(i,t,s?2:1))}else o.push(new Rs(e,t,0))}else for(let t=0;t<i;){let e=t,s=2==Ls[t++];for(;t<i&&s==(2==Ls[t]);)t++;o.push(new Rs(e,t,s?1:2))}return o}(t.text,this.textDirection);return this.bidiCache.push(new or(t.from,t.to,e,i)),i}get hasFocus(){var t;return(document.hasFocus()||xi.safari&&(null===(t=this.inputState)||void 0===t?void 0:t.lastContextMenu)>Date.now()-3e4)&&this.root.activeElement==this.contentDOM}focus(){this.observer.ignore((()=>{ti(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 domEventHandlers(t){return as.define((()=>({})),{eventHandlers:t})}static theme(t,e){let i=W.newName(),s=[Hn.of(i),gs.of(_n(`.${i}`,t))];return e&&e.dark&&s.push(zn.of(!0)),s}static baseTheme(t){return Vt.fallback(gs.of(_n("."+Fn,t,jn)))}}tr.scrollTo=is,tr.styleModule=gs,tr.inputHandler=es,tr.exceptionSink=Zi,tr.updateListener=ts,tr.editable=ns,tr.mouseSelectionStyle=Qi,tr.dragMovesSelection=Yi,tr.clickAddsSelectionRange=Xi,tr.decorations=ps,tr.contentAttributes=ds,tr.editorAttributes=fs,tr.lineWrapping=tr.contentAttributes.of({class:"cm-lineWrapping"}),tr.announce=te.define();const er=4096;function ir(t,e){return null==t?e.getBoundingClientRect().top:t}let sr=-1;function nr(){sr=-1;let t=document.querySelectorAll(".cm-content");for(let e=0;e<t.length;e++){let i=hi.get(t[e]);i&&i.editorView.requestMeasure()}}const rr={};class or{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:Ss.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 or(e.mapPos(r.from,1),e.mapPos(r.to,-1),r.dir,r.order))}return i}}const hr="undefined"==typeof navigator?"key":/Mac/.test(navigator.platform)?"mac":/Win/.test(navigator.platform)?"win":/Linux|X11/.test(navigator.platform)?"linux":"key";function lr(t,e,i){return e.altKey&&(t="Alt-"+t),e.ctrlKey&&(t="Ctrl-"+t),e.metaKey&&(t="Meta-"+t),!1!==i&&e.shiftKey&&(t="Shift-"+t),t}const ar=tr.domEventHandlers({keydown:(t,e)=>function(t,e,i,s){let n=function(t){var e=!(Ve&&(t.ctrlKey||t.altKey||t.metaKey)||(Le||Be)&&t.shiftKey&&t.key&&1==t.key.length)&&t.key||(t.shiftKey?Ee:Pe)[t.keyCode]||t.key||"Unidentified";return"Esc"==e&&(e="Escape"),"Del"==e&&(e="Delete"),"Left"==e&&(e="ArrowLeft"),"Up"==e&&(e="ArrowUp"),"Right"==e&&(e="ArrowRight"),"Down"==e&&(e="ArrowDown"),e}(e),r=1==n.length&&" "!=n,o="",h=!1;fr&&fr.view==i&&fr.scope==s&&(o=fr.prefix+" ",(h=Js.indexOf(e.keyCode)<0)&&(fr=null));let l,a=t=>{if(t){for(let e of t.commands)if(e(i))return!0;t.preventDefault&&(h=!0)}return!1},c=t[s];if(c){if(a(c[o+lr(n,e,!r)]))return!0;if(r&&(e.shiftKey||e.altKey||e.metaKey)&&(l=Pe[e.keyCode])&&l!=n){if(a(c[o+lr(l,e,!0)]))return!0}else if(r&&e.shiftKey&&a(c[o+lr(n,e,!0)]))return!0}return h}(function(t){let e=t.facet(cr),i=ur.get(e);i||ur.set(e,i=function(t,e=hr){let i=Object.create(null),s=Object.create(null),n=(t,e)=>{let i=s[t];if(null==i)s[t]=e;else if(i!=e)throw new Error("Key binding "+t+" is used both as a regular binding and as a multi-stroke prefix")},r=(t,s,r,o)=>{let h=i[t]||(i[t]=Object.create(null)),l=s.split(/ (?!$)/).map((t=>function(t,e){const i=t.split(/-(?!$)/);let s,n,r,o,h=i[i.length-1];"Space"==h&&(h=" ");for(let t=0;t<i.length-1;++t){const h=i[t];if(/^(cmd|meta|m)$/i.test(h))o=!0;else if(/^a(lt)?$/i.test(h))s=!0;else if(/^(c|ctrl|control)$/i.test(h))n=!0;else if(/^s(hift)?$/i.test(h))r=!0;else{if(!/^mod$/i.test(h))throw new Error("Unrecognized modifier name: "+h);"mac"==e?o=!0:n=!0}}return s&&(h="Alt-"+h),n&&(h="Ctrl-"+h),o&&(h="Meta-"+h),r&&(h="Shift-"+h),h}(t,e)));for(let e=1;e<l.length;e++){let i=l.slice(0,e).join(" ");n(i,!0),h[i]||(h[i]={preventDefault:!0,commands:[e=>{let s=fr={view:e,prefix:i,scope:t};return setTimeout((()=>{fr==s&&(fr=null)}),4e3),!0}]})}let a=l.join(" ");n(a,!1);let c=h[a]||(h[a]={preventDefault:!1,commands:[]});c.commands.push(r),o&&(c.preventDefault=!0)};for(let i of t){let t=i[e]||i.key;if(t)for(let e of i.scope?i.scope.split(" "):["editor"])r(e,t,i.run,i.preventDefault),i.shift&&r(e,"Shift-"+t,i.shift,i.preventDefault)}return i}(e.reduce(((t,e)=>t.concat(e)),[])));return i}(e.state),t,e,"editor")}),cr=Mt.define({enables:ar}),ur=new WeakMap;let fr=null;const dr=!xi.ios,pr=Mt.define({combine:t=>de(t,{cursorBlinkRate:1200,drawRangeCursor:!0},{cursorBlinkRate:(t,e)=>Math.min(t,e),drawRangeCursor:(t,e)=>t||e})});function gr(t={}){return[pr.of(t),vr,br]}class mr{constructor(t,e,i,s,n){this.left=t,this.top=e,this.width=i,this.height=s,this.className=n}draw(){let t=document.createElement("div");return t.className=this.className,this.adjust(t),t}adjust(t){t.style.left=this.left+"px",t.style.top=this.top+"px",this.width>=0&&(t.style.width=this.width+"px"),t.style.height=this.height+"px"}eq(t){return this.left==t.left&&this.top==t.top&&this.width==t.width&&this.height==t.height&&this.className==t.className}}const vr=as.fromClass(class{constructor(t){this.view=t,this.rangePieces=[],this.cursors=[],this.measureReq={read:this.readPos.bind(this),write:this.drawSel.bind(this)},this.selectionLayer=t.scrollDOM.appendChild(document.createElement("div")),this.selectionLayer.className="cm-selectionLayer",this.selectionLayer.setAttribute("aria-hidden","true"),this.cursorLayer=t.scrollDOM.appendChild(document.createElement("div")),this.cursorLayer.className="cm-cursorLayer",this.cursorLayer.setAttribute("aria-hidden","true"),t.requestMeasure(this.measureReq),this.setBlinkRate()}setBlinkRate(){this.cursorLayer.style.animationDuration=this.view.state.facet(pr).cursorBlinkRate+"ms"}update(t){let e=t.startState.facet(pr)!=t.state.facet(pr);(e||t.selectionSet||t.geometryChanged||t.viewportChanged)&&this.view.requestMeasure(this.measureReq),t.transactions.some((t=>t.scrollIntoView))&&(this.cursorLayer.style.animationName="cm-blink"==this.cursorLayer.style.animationName?"cm-blink2":"cm-blink"),e&&this.setBlinkRate()}readPos(){let{state:t}=this.view,e=t.facet(pr),i=t.selection.ranges.map((t=>t.empty?[]:function(t,e){if(e.to<=t.viewport.from||e.from>=t.viewport.to)return[];let i=Math.max(e.from,t.viewport.from),s=Math.min(e.to,t.viewport.to),n=t.textDirection==Ss.LTR,r=t.contentDOM,o=r.getBoundingClientRect(),h=yr(t),l=window.getComputedStyle(r.firstChild),a=o.left+parseInt(l.paddingLeft),c=o.right-parseInt(l.paddingRight),u=kr(t,i),f=kr(t,s),d=u.type==Vi.Text?u:null,p=f.type==Vi.Text?f:null;t.lineWrapping&&(d&&(d=xr(t,i,d)),p&&(p=xr(t,s,p)));if(d&&p&&d.from==p.from)return m(v(e.from,e.to,d));{let i=d?v(e.from,null,d):w(u,!1),s=p?v(null,e.to,p):w(f,!0),n=[];return(d||u).to<(p||f).from-1?n.push(g(a,i.bottom,c,s.top)):i.bottom<s.top&&kr(t,(i.bottom+s.top)/2).type==Vi.Text&&(i.bottom=s.top=(i.bottom+s.top)/2),m(i).concat(n).concat(m(s))}function g(t,e,i,s){return new mr(t-h.left,e-h.top,i-t,s-e,"cm-selectionBackground")}function m({top:t,bottom:e,horizontal:i}){let s=[];for(let n=0;n<i.length;n+=2)s.push(g(i[n],t,i[n+1],e));return s}function v(e,i,s){let r=1e9,o=-1e9,h=[];function l(e,i,l,u,f){let d=t.coordsAtPos(e,e==s.to?-2:2),p=t.coordsAtPos(l,l==s.from?2:-2);r=Math.min(d.top,p.top,r),o=Math.max(d.bottom,p.bottom,o),f==Ss.LTR?h.push(n&&i?a:d.left,n&&u?c:p.right):h.push(!n&&u?a:p.left,!n&&i?c:d.right)}let u=null!=e?e:s.from,f=null!=i?i:s.to;for(let s of t.visibleRanges)if(s.to>u&&s.from<f)for(let n=Math.max(s.from,u),r=Math.min(s.to,f);;){let s=t.state.doc.lineAt(n);for(let o of t.bidiSpans(s)){let t=o.from+s.from,h=o.to+s.from;if(t>=r)break;h>n&&l(Math.max(t,n),null==e&&t<=u,Math.min(h,r),null==i&&h>=f,o.dir)}if(n=s.to+1,n>=r)break}return 0==h.length&&l(u,null==e,f,null==i,t.textDirection),{top:r,bottom:o,horizontal:h}}function w(t,e){let i=o.top+(e?t.top:t.bottom);return{top:i,bottom:i,horizontal:[]}}}(this.view,t))).reduce(((t,e)=>t.concat(e))),s=[];for(let i of t.selection.ranges){let n=i==t.selection.main;if(i.empty?!n||dr:e.drawRangeCursor){let t=Sr(this.view,i,n);t&&s.push(t)}}return{rangePieces:i,cursors:s}}drawSel({rangePieces:t,cursors:e}){if(t.length!=this.rangePieces.length||t.some(((t,e)=>!t.eq(this.rangePieces[e])))){this.selectionLayer.textContent="";for(let e of t)this.selectionLayer.appendChild(e.draw());this.rangePieces=t}if(e.length!=this.cursors.length||e.some(((t,e)=>!t.eq(this.cursors[e])))){let t=this.cursorLayer.children;if(t.length!==e.length){this.cursorLayer.textContent="";for(const t of e)this.cursorLayer.appendChild(t.draw())}else e.forEach(((e,i)=>e.adjust(t[i])));this.cursors=e}}destroy(){this.selectionLayer.remove(),this.cursorLayer.remove()}}),wr={".cm-line":{"& ::selection":{backgroundColor:"transparent !important"},"&::selection":{backgroundColor:"transparent !important"}}};dr&&(wr[".cm-line"].caretColor="transparent !important");const br=Vt.override(tr.theme(wr));function yr(t){let e=t.scrollDOM.getBoundingClientRect();return{left:(t.textDirection==Ss.LTR?e.left:e.right-t.scrollDOM.clientWidth)-t.scrollDOM.scrollLeft,top:e.top-t.scrollDOM.scrollTop}}function xr(t,e,i){let s=kt.cursor(e);return{from:Math.max(i.from,t.moveToLineBoundary(s,!1,!0).from),to:Math.min(i.to,t.moveToLineBoundary(s,!0,!0).from),type:Vi.Text}}function kr(t,e){let i=t.visualLineAt(e);if(Array.isArray(i.type))for(let t of i.type)if(t.to>e||t.to==e&&(t.to==i.to||t.type==Vi.Text))return t;return i}function Sr(t,e,i){let s=t.coordsAtPos(e.head,e.assoc||1);if(!s)return null;let n=yr(t);return new mr(s.left-n.left,s.top-n.top,-1,s.bottom-s.top,i?"cm-cursor cm-cursor-primary":"cm-cursor cm-cursor-secondary")}function Ar(t,e,i,s,n){e.lastIndex=0;for(let r,o=t.iterRange(i,s),h=i;!o.next().done;h+=o.value.length)if(!o.lineBreak)for(;r=e.exec(o.value);)n(h+r.index,h+r.index+r[0].length,r)}class Cr{constructor(t){let{regexp:e,decoration:i,boundary:s}=t;if(!e.global)throw new RangeError("The regular expression given to MatchDecorator should have its 'g' flag set");this.regexp=e,this.getDeco="function"==typeof i?i:()=>i,this.boundary=s}createDeco(t){let e=new be;for(let{from:i,to:s}of t.visibleRanges)Ar(t.state.doc,this.regexp,i,s,((i,s,n)=>e.add(i,s,this.getDeco(n,t,i))));return e.finish()}updateDeco(t,e){let i=1e9,s=-1;return t.docChanged&&t.changes.iterChanges(((e,n,r,o)=>{o>t.view.viewport.from&&r<t.view.viewport.to&&(i=Math.min(r,i),s=Math.max(o,s))})),t.viewportChanged||s-i>1e3?this.createDeco(t.view):s>-1?this.updateRange(t.view,e.map(t.changes),i,s):e}updateRange(t,e,i,s){for(let n of t.visibleRanges){let r=Math.max(n.from,i),o=Math.min(n.to,s);if(o>r){let i=t.state.doc.lineAt(r),s=i.to<o?t.state.doc.lineAt(o):i,h=Math.max(n.from,i.from),l=Math.min(n.to,s.to);if(this.boundary){for(;r>i.from;r--)if(this.boundary.test(i.text[r-1-i.from])){h=r;break}for(;o<s.to;o++)if(this.boundary.test(s.text[o-s.from])){l=o;break}}let a,c=[];if(i==s)for(this.regexp.lastIndex=h-i.from;(a=this.regexp.exec(i.text))&&a.index<l-i.from;){let e=a.index+i.from;c.push(this.getDeco(a,t,e).range(e,e+a[0].length))}else Ar(t.state.doc,this.regexp,h,l,((e,i,s)=>c.push(this.getDeco(s,t,e).range(e,i))));e=e.update({filterFrom:h,filterTo:l,filter:(t,e)=>t<h||e>l,add:c})}}return e}}const Mr=null!=/x/.unicode?"gu":"g",Dr=new RegExp("[\0-\b\n--\u2028\u2029\ufeff-]",Mr),Tr={0:"null",7:"bell",8:"backspace",10:"newline",11:"vertical tab",13:"carriage return",27:"escape",8203:"zero width space",8204:"zero width non-joiner",8205:"zero width joiner",8206:"left-to-right mark",8207:"right-to-left mark",8232:"line separator",8233:"paragraph separator",65279:"zero width no-break space",65532:"object replacement"};let Or=null;const Pr=Mt.define({combine(t){let e=de(t,{render:null,specialChars:Dr,addSpecialChars:null});return(e.replaceTabs=!function(){var t;if(null==Or&&"undefined"!=typeof document&&document.body){let e=document.body.style;Or=null!=(null!==(t=e.tabSize)&&void 0!==t?t:e.MozTabSize)}return Or||!1}())&&(e.specialChars=new RegExp("\t|"+e.specialChars.source,Mr)),e.addSpecialChars&&(e.specialChars=new RegExp(e.specialChars.source+"|"+e.addSpecialChars.source,Mr)),e}});function Er(t={}){return[Pr.of(t),Rr||(Rr=as.fromClass(class{constructor(t){this.view=t,this.decorations=Hi.none,this.decorationCache=Object.create(null),this.decorator=this.makeDecorator(t.state.facet(Pr)),this.decorations=this.decorator.createDeco(t)}makeDecorator(t){return new Cr({regexp:t.specialChars,decoration:(e,i,s)=>{let{doc:n}=i.state,r=Q(e[0],0);if(9==r){let t=n.lineAt(s),e=i.state.tabSize,r=et(t.text,e,s-t.from);return Hi.replace({widget:new Nr((e-r%e)*this.view.defaultCharacterWidth)})}return this.decorationCache[r]||(this.decorationCache[r]=Hi.replace({widget:new Lr(t,r)}))},boundary:t.replaceTabs?void 0:/[^]/})}update(t){let e=t.state.facet(Pr);t.startState.facet(Pr)!=e?(this.decorator=this.makeDecorator(e),this.decorations=this.decorator.createDeco(t.view)):this.decorations=this.decorator.updateDeco(t,this.decorations)}},{decorations:t=>t.decorations}))]}let Rr=null;class Lr extends Bi{constructor(t,e){super(),this.options=t,this.code=e}eq(t){return t.code==this.code}toDOM(t){let e=function(t){return t>=32?"•":10==t?"":String.fromCharCode(9216+t)}(this.code),i=t.state.phrase("Control character")+" "+(Tr[this.code]||"0x"+this.code.toString(16)),s=this.options.render&&this.options.render(this.code,i,e);if(s)return s;let n=document.createElement("span");return n.textContent=e,n.title=i,n.setAttribute("aria-label",i),n.className="cm-specialChar",n}ignoreEvent(){return!1}}class Nr extends Bi{constructor(t){super(),this.width=t}eq(t){return t.width==this.width}toDOM(){let t=document.createElement("span");return t.textContent="\t",t.className="cm-tab",t.style.width=this.width+"px",t}ignoreEvent(){return!1}}const Ir=as.fromClass(class{constructor(t){this.height=-1,this.measure={read:t=>Math.max(0,t.scrollDOM.clientHeight-t.defaultLineHeight),write:(t,e)=>{Math.abs(t-this.height)>1&&(this.height=t,e.contentDOM.style.paddingBottom=t+"px")}},t.requestMeasure(this.measure)}update(t){t.geometryChanged&&t.view.requestMeasure(this.measure)}});function Br(){return Ir}class Vr extends Bi{constructor(t){super(),this.content=t}toDOM(){let t=document.createElement("span");return t.className="cm-placeholder",t.style.pointerEvents="none",t.appendChild("string"==typeof this.content?document.createTextNode(this.content):this.content),"string"==typeof this.content?t.setAttribute("aria-label","placeholder "+this.content):t.setAttribute("aria-hidden","true"),t}ignoreEvent(){return!1}}function Hr(t){return as.fromClass(class{constructor(e){this.view=e,this.placeholder=Hi.set([Hi.widget({widget:new Vr(t),side:1}).range(0)])}get decorations(){return this.view.state.doc.length?Hi.none:this.placeholder}},{decorations:t=>t.decorations})}const zr=new s;function Fr(t){return Mt.define({combine:t?e=>e.concat(t):void 0})}class Wr{constructor(t,e,i,s=[]){this.data=t,this.topNode=i,fe.prototype.hasOwnProperty("tree")||Object.defineProperty(fe.prototype,"tree",{get(){return _r(this)}}),this.parser=e,this.extension=[Zr.of(this),fe.languageData.of(((t,e,i)=>t.facet(qr(t,e,i))))].concat(s)}isActiveAt(t,e,i=-1){return qr(t,e,i)==this.data}findRegions(t){let e=t.facet(Zr);if((null==e?void 0:e.data)==this.data)return[{from:0,to:t.doc.length}];if(!e||!e.allowsNesting)return[];let i=[],n=(t,e)=>{if(t.prop(zr)==this.data)return void i.push({from:e,to:e+t.length});let r=t.prop(s.mounted);if(r){if(r.tree.prop(zr)==this.data){if(r.overlay)for(let t of r.overlay)i.push({from:t.from+e,to:t.to+e});else i.push({from:e,to:e+t.length});return}if(r.overlay){let t=i.length;if(n(r.tree,r.overlay[0].from+e),i.length>t)return}}for(let i=0;i<t.children.length;i++){let s=t.children[i];s instanceof a&&n(s,t.positions[i]+e)}};return n(_r(t),0),i}get allowsNesting(){return!0}}function qr(t,e,i){let s=t.facet(Zr);if(!s)return null;let n=s.data;if(s.allowsNesting)for(let s=_r(t).topNode;s;s=s.enter(e,i,!0,!1))n=s.type.prop(zr)||n;return n}Wr.setState=te.define();class jr extends Wr{constructor(t,e){super(t,e,e.topNode),this.parser=e}static define(t){let e=Fr(t.languageData);return new jr(e,t.parser.configure({props:[zr.add((t=>t.isTop?e:void 0))]}))}configure(t){return new jr(this.data,this.parser.configure(t))}get allowsNesting(){return this.parser.wrappers.length>0}}function _r(t){let e=t.field(Wr.state,!1);return e?e.tree:a.empty}class $r{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 Ur=null;class Gr{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 $r(this.state.doc),this.fragments)}work(t,e){return null!=e&&e>=this.state.doc.length&&(e=void 0),this.tree!=a.empty&&this.isDone(null!=e?e:this.state.doc.length)?(this.takeTree(),!0):this.withContext((()=>{var i;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=Date.now()+t;for(;;){let t=this.parse.advance();if(t){if(this.fragments=this.withoutTempSkipped(S.addTree(t,this.fragments,null!=this.parse.stoppedAt)),this.treeLen=null!==(i=this.parse.stoppedAt)&&void 0!==i?i:this.state.doc.length,this.tree=t,this.parse=null,!(this.treeLen<(null!=e?e:this.state.doc.length)))return!0;this.parse=this.startParse()}if(Date.now()>s)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.tree=e,this.fragments=this.withoutTempSkipped(S.addTree(this.tree,this.fragments,!0)),this.parse=null)}withContext(t){let e=Ur;Ur=this;try{return t()}finally{Ur=e}}withoutTempSkipped(t){for(let e;e=this.tempSkipped.pop();)t=Kr(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=S.applyChanges(i,e),s=a.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 Gr(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=Kr(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 A{createParse(e,i,s){let n=s[0].from,r=s[s.length-1].to;return{parsedPos:n,advance(){let e=Ur;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 a(o.none,[],[],r-n)},stoppedAt:null,stopAt(){}}}}}movedPast(t){return this.treeLen<t&&this.parse&&this.parse.parsedPos>=t}isDone(t){let e=this.fragments;return this.treeLen>=t&&e.length&&0==e[0].from&&e[0].to>=t}static get(){return Ur}}function Kr(t,e,i){return S.applyChanges(t,[{fromA:e,toA:i,fromB:e,toB:i}])}class Jr{constructor(t){this.context=t,this.tree=t.tree}apply(t){if(!t.docChanged)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(25,i)||e.takeTree(),new Jr(e)}static init(t){let e=new Gr(t.facet(Zr).parser,t,[],a.empty,0,{from:0,to:t.doc.length},[],null);return e.work(25)||e.takeTree(),new Jr(e)}}Wr.state=Rt.define({create:Jr.init,update(t,e){for(let t of e.effects)if(t.is(Wr.setState))return t.value;return e.startState.facet(Zr)!=e.state.facet(Zr)?Jr.init(e.state):t.apply(e)}});let Xr="undefined"!=typeof window&&window.requestIdleCallback||((t,{timeout:e})=>setTimeout(t,e)),Yr="undefined"!=typeof window&&window.cancelIdleCallback||clearTimeout;const Qr=as.fromClass(class{constructor(t){this.view=t,this.working=-1,this.chunkEnd=-1,this.chunkBudget=-1,this.work=this.work.bind(this),this.scheduleWork()}update(t){let e=this.view.state.field(Wr.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>-1)return;let{state:t}=this.view,e=t.field(Wr.state);e.tree==e.context.tree&&e.context.isDone(t.doc.length)||(this.working=Xr(this.work,{timeout:500}))}work(t){this.working=-1;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(Wr.state);if(n.tree==n.context.tree&&n.context.treeLen>=s+1e6)return;let r=Math.min(this.chunkBudget,t?Math.max(25,t.timeRemaining()):100),o=n.context.work(r,s+1e6);this.chunkBudget-=Date.now()-e,(o||this.chunkBudget<=0||n.context.movedPast(s))&&(n.context.takeTree(),this.view.dispatch({effects:Wr.setState.of(new Jr(n.context))})),!o&&this.chunkBudget>0&&this.scheduleWork(),this.checkAsyncSchedule(n.context)}checkAsyncSchedule(t){t.scheduleOn&&(t.scheduleOn.then((()=>this.scheduleWork())),t.scheduleOn=null)}destroy(){this.working>=0&&Yr(this.working)}},{eventHandlers:{focus(){this.scheduleWork()}}}),Zr=Mt.define({combine:t=>t.length?t[0]:null,enables:[Wr.state,Qr]});class to{constructor(t,e=[]){this.language=t,this.support=e,this.extension=[t,e]}}class eo{constructor(t,e,i,s,n){this.name=t,this.alias=e,this.extensions=i,this.filename=s,this.loadFunc=n,this.support=void 0,this.loading=null}load(){return this.loading||(this.loading=this.loadFunc().then((t=>this.support=t),(t=>{throw this.loading=null,t})))}static of(t){return new eo(t.name,(t.alias||[]).concat(t.name).map((t=>t.toLowerCase())),t.extensions||[],t.filename,t.load)}static matchFilename(t,e){for(let i of t)if(i.filename&&i.filename.test(e))return i;let i=/\.([^.]+)$/.exec(e);if(i)for(let e of t)if(e.extensions.indexOf(i[1])>-1)return e;return null}static matchLanguageName(t,e,i=!0){e=e.toLowerCase();for(let i of t)if(i.alias.some((t=>t==e)))return i;if(i)for(let i of t)for(let t of i.alias){let s=e.indexOf(t);if(s>-1&&(t.length>2||!/\w/.test(e[s-1])&&!/\w/.test(e[s+t.length])))return i}return null}}const io=Mt.define(),so=Mt.define({combine:t=>{if(!t.length)return" ";if(!/^(?: +|\t+)$/.test(t[0]))throw new Error("Invalid indent unit: "+JSON.stringify(t[0]));return t[0]}});function no(t){let e=t.facet(so);return 9==e.charCodeAt(0)?t.tabSize*e.length:e.length}function ro(t,e){let i="",s=t.tabSize;if(9==t.facet(so).charCodeAt(0))for(;e>=s;)i+="\t",e-=s;for(let t=0;t<e;t++)i+=" ";return i}function oo(t,e){t instanceof fe&&(t=new ho(t));for(let i of t.state.facet(io)){let s=i(t,e);if(null!=s)return s}let i=_r(t.state);return i?function(t,e,i){return co(e.resolveInner(i).enterUnfinishedNodesBefore(i),i,t)}(t,i,e):null}class ho{constructor(t,e={}){this.state=t,this.options=e,this.unit=no(t)}lineAt(t,e=1){let i=this.state.doc.lineAt(t),{simulateBreak:s}=this.options;return null!=s&&s>=i.from&&s<=i.to?(e<0?s<t:s<=t)?{text:i.text.slice(s-i.from),from:s}:{text:i.text.slice(0,s-i.from),from:i.from}:i}textAfterPos(t,e=1){if(this.options.simulateDoubleBreak&&t==this.options.simulateBreak)return"";let{text:i,from:s}=this.lineAt(t,e);return i.slice(t-s,Math.min(i.length,t+100-s))}column(t,e=1){let{text:i,from:s}=this.lineAt(t,e),n=this.countColumn(i,t-s),r=this.options.overrideIndentation?this.options.overrideIndentation(s):-1;return r>-1&&(n+=r-this.countColumn(i,i.search(/\S|$/))),n}countColumn(t,e=t.length){return et(t,this.state.tabSize,e)}lineIndent(t,e=1){let{text:i,from:s}=this.lineAt(t,e),n=this.options.overrideIndentation;if(n){let t=n(s);if(t>-1)return t}return this.countColumn(i,i.search(/\S|$/))}get simulatedBreak(){return this.options.simulateBreak||null}}const lo=new s;function ao(t){let e=t.type.prop(lo);if(e)return e;let i,n=t.firstChild;if(n&&(i=n.type.prop(s.closedBy))){let e=t.lastChild,s=e&&i.indexOf(e.name)>-1;return t=>mo(t,!0,1,void 0,s&&!function(t){return t.pos==t.options.simulateBreak&&t.options.simulateDoubleBreak}(t)?e.from:void 0)}return null==t.parent?uo:null}function co(t,e,i){for(;t;t=t.parent){let s=ao(t);if(s)return s(new fo(i,e,t))}return null}function uo(){return 0}class fo extends ho{constructor(t,e,i){super(t.state,t.options),this.base=t,this.pos=e,this.node=i}get textAfter(){return this.textAfterPos(this.pos)}get baseIndent(){let t=this.state.doc.lineAt(this.node.from);for(;;){let e=this.node.resolve(t.from);for(;e.parent&&e.parent.from==e.from;)e=e.parent;if(po(e,this.node))break;t=this.state.doc.lineAt(e.from)}return this.lineIndent(t.from)}continue(){let t=this.node.parent;return t?co(t,this.pos,this.base):0}}function po(t,e){for(let i=e;i;i=i.parent)if(t==i)return!0;return!1}function go({closing:t,align:e=!0,units:i=1}){return s=>mo(s,e,i,t)}function mo(t,e,i,s,n){let r=t.textAfter,o=r.match(/^\s*/)[0].length,h=s&&r.slice(o,o+s.length)==s||n==t.pos+o,l=e?function(t){let e=t.node,i=e.childAfter(e.from),s=e.lastChild;if(!i)return null;let n=t.options.simulateBreak,r=t.state.doc.lineAt(i.from),o=null==n||n<=r.from?r.to:Math.min(r.to,n);for(let t=i.to;;){let n=e.childAfter(t);if(!n||n==s)return null;if(!n.type.isSkipped)return n.from<o?i:null;t=n.to}}(t):null;return l?h?t.column(l.from):t.column(l.to):t.baseIndent+(h?0:t.unit*i)}const vo=t=>t.baseIndent;function wo({except:t,units:e=1}={}){return i=>{let s=t&&t.test(i.textAfter);return i.baseIndent+(s?0:e*i.unit)}}function bo(){return fe.transactionFilter.of((t=>{if(!t.docChanged||!t.isUserEvent("input.type"))return t;let e=t.startState.languageDataAt("indentOnInput",t.startState.selection.main.head);if(!e.length)return t;let i=t.newDoc,{head:s}=t.newSelection.main,n=i.lineAt(s);if(s>n.from+200)return t;let r=i.sliceString(n.from,s);if(!e.some((t=>t.test(r))))return t;let{state:o}=t,h=-1,l=[];for(let{head:t}of o.selection.ranges){let e=o.doc.lineAt(t);if(e.from==h)continue;h=e.from;let i=oo(o,e.from);if(null==i)continue;let s=/^\s*/.exec(e.text)[0],n=ro(o,i);s!=n&&l.push({from:e.from,to:e.from+s.length,insert:n})}return l.length?[t,{changes:l,sequential:!0}]:t}))}const yo=Mt.define(),xo=new s;function ko(t){let e=t.firstChild,i=t.lastChild;return e&&e.to<i.from?{from:e.to,to:i.type.isError?t.to:i.from}:null}function So(t,e,i){for(let s of t.facet(yo)){let n=s(t,e,i);if(n)return n}return function(t,e,i){let s=_r(t);if(0==s.length)return null;let n=null;for(let r=s.resolveInner(i);r;r=r.parent){if(r.to<=i||r.from>i)continue;if(n&&r.from<e)break;let s=r.type.prop(xo);if(s){let o=s(r,t);o&&o.from<=i&&o.from>=e&&o.to>i&&(n=o)}}return n}(t,e,i)}let Ao=0;class Co{constructor(t,e,i){this.set=t,this.base=e,this.modified=i,this.id=Ao++}static define(t){if(null==t?void 0:t.base)throw new Error("Can not derive from a modified tag");let e=new Co([],null,[]);if(e.set.push(e),t)for(let i of t.set)e.set.push(i);return e}static defineModifier(){let t=new Do;return e=>e.modified.indexOf(t)>-1?e:Do.get(e.base||e,e.modified.concat(t).sort(((t,e)=>t.id-e.id)))}}let Mo=0;class Do{constructor(){this.instances=[],this.id=Mo++}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 Co(s,t,e);for(let t of e)t.instances.push(n);let r=To(e);for(let e of t.set)for(let t of r)s.push(Do.get(e,t));return n}}function To(t){let e=[t];for(let i=0;i<t.length;i++)for(let s of To(t.slice(0,i).concat(t.slice(i+1))))e.push(s);return e}function Oo(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]?null:'"'==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 No(s,n,o>0?i.slice(0,o):null);e[h]=l.sort(e[h])}}return Po.add(e)}const Po=new s,Eo=Mt.define({combine:t=>t.length?Io.combinedMatch(t):null}),Ro=Mt.define({combine:t=>t.length?t[0].match:null});function Lo(t){return t.facet(Eo)||t.facet(Ro)}class No{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}}class Io{constructor(t,e){let i;function s(t){let e=W.newName();return(i||(i=Object.create(null)))["."+e]=t,e}this.map=Object.create(null),this.all="string"==typeof e.all?e.all:e.all?s(e.all):null;for(let e of t){let t=(e.class||s(Object.assign({},e,{tag:null})))+(this.all?" "+this.all:""),i=e.tag;if(Array.isArray(i))for(let e of i)this.map[e.id]=t;else this.map[i.id]=t}this.module=i?new W(i):null,this.scope=e.scope||null,this.match=this.match.bind(this);let n=[Ho];this.module&&n.push(tr.styleModule.of(this.module)),this.extension=n.concat(Eo.of(this)),this.fallback=n.concat(Ro.of(this))}match(t,e){if(this.scope&&e!=this.scope)return null;for(let e of t.set){let i=this.map[e.id];if(void 0!==i)return e!=t&&(this.map[t.id]=i),i}return this.map[t.id]=this.all}static combinedMatch(t){if(1==t.length)return t[0].match;let e=t.some((t=>t.scope))?void 0:Object.create(null);return(i,s)=>{let n=e&&e[i.id];if(void 0!==n)return n;let r=null;for(let e of t){let t=e.match(i,s);t&&(r=r?r+" "+t:t)}return e&&(e[i.id]=r),r}}static define(t,e){return new Io(t,e||{})}static get(t,e,i){let s=Lo(t);return s&&s(e,i||o.none)}}function Bo(t,e,i,s=0,n=t.length){Wo(t,s,n,e,i)}class Vo{constructor(t){this.markCache=Object.create(null),this.tree=_r(t.state),this.decorations=this.buildDeco(t,Lo(t.state))}update(t){let e=_r(t.state),i=Lo(t.state),s=i!=t.startState.facet(Eo);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 Hi.none;let i=new be;for(let{from:s,to:n}of t.visibleRanges)Wo(this.tree,s,n,e,((t,e,s)=>{i.add(t,e,this.markCache[s]||(this.markCache[s]=Hi.mark({class:s})))}));return i.finish()}}const Ho=Vt.extend(as.fromClass(Vo,{decorations:t=>t.decorations})),zo=[""];class Fo{constructor(t,e,i){this.at=t,this.style=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,n,r,o){let{type:h,from:l,to:a}=t;if(l>=i||a<=e)return;zo[r]=h.name,h.isTop&&(o=h);let c=n,u=h.prop(Po),f=!1;for(;u;){if(!u.context||qo(u.context,zo,r)){for(let t of u.tags){let e=this.style(t,o);e&&(c&&(c+=" "),c+=e,1==u.mode?n+=(n?" ":"")+e:0==u.mode&&(f=!0))}break}u=u.next}if(this.startSpan(t.from,c),f)return;let d=t.tree&&t.tree.prop(s.mounted);if(d&&d.overlay){let s=t.node.enter(d.overlay[0].from+l,1),h=t.firstChild();for(let u=0,f=l;;u++){let p=u<d.overlay.length?d.overlay[u]:null,g=p?p.from+l:a,m=Math.max(e,f),v=Math.min(i,g);if(m<v&&h)for(;t.from<v&&(this.highlightRange(t,m,v,n,r+1,o),this.startSpan(Math.min(i,t.to),c),!(t.to>=g)&&t.nextSibling()););if(!p||g>i)break;f=p.to+l,f>e&&(this.highlightRange(s.cursor,Math.max(e,p.from+l),Math.min(i,f),n,r,d.tree.type),this.startSpan(f,c))}h&&t.parent()}else if(t.firstChild()){do{if(!(t.to<=e)){if(t.from>=i)break;this.highlightRange(t,e,i,n,r+1,o),this.startSpan(Math.min(i,t.to),c)}}while(t.nextSibling());t.parent()}}}function Wo(t,e,i,s,n){let r=new Fo(e,s,n);r.highlightRange(t.cursor(),e,i,"",0,t.type),r.flush(i)}function qo(t,e,i){if(t.length>i-1)return!1;for(let s=i-1,n=t.length-1;n>=0;n--,s--){let i=t[n];if(i&&i!=e[s])return!1}return!0}const jo=Co.define,_o=jo(),$o=jo(),Uo=jo($o),Go=jo($o),Ko=jo(),Jo=jo(Ko),Xo=jo(Ko),Yo=jo(),Qo=jo(Yo),Zo=jo(),th=jo(),eh=jo(),ih=jo(eh),sh=jo(),nh={comment:_o,lineComment:jo(_o),blockComment:jo(_o),docComment:jo(_o),name:$o,variableName:jo($o),typeName:Uo,tagName:jo(Uo),propertyName:Go,attributeName:jo(Go),className:jo($o),labelName:jo($o),namespace:jo($o),macroName:jo($o),literal:Ko,string:Jo,docString:jo(Jo),character:jo(Jo),attributeValue:jo(Jo),number:Xo,integer:jo(Xo),float:jo(Xo),bool:jo(Ko),regexp:jo(Ko),escape:jo(Ko),color:jo(Ko),url:jo(Ko),keyword:Zo,self:jo(Zo),null:jo(Zo),atom:jo(Zo),unit:jo(Zo),modifier:jo(Zo),operatorKeyword:jo(Zo),controlKeyword:jo(Zo),definitionKeyword:jo(Zo),operator:th,derefOperator:jo(th),arithmeticOperator:jo(th),logicOperator:jo(th),bitwiseOperator:jo(th),compareOperator:jo(th),updateOperator:jo(th),definitionOperator:jo(th),typeOperator:jo(th),controlOperator:jo(th),punctuation:eh,separator:jo(eh),bracket:ih,angleBracket:jo(ih),squareBracket:jo(ih),paren:jo(ih),brace:jo(ih),content:Yo,heading:Qo,heading1:jo(Qo),heading2:jo(Qo),heading3:jo(Qo),heading4:jo(Qo),heading5:jo(Qo),heading6:jo(Qo),contentSeparator:jo(Yo),list:jo(Yo),quote:jo(Yo),emphasis:jo(Yo),strong:jo(Yo),link:jo(Yo),monospace:jo(Yo),strikethrough:jo(Yo),inserted:jo(),deleted:jo(),changed:jo(),invalid:jo(),meta:sh,documentMeta:jo(sh),annotation:jo(sh),processingInstruction:jo(sh),definition:Co.defineModifier(),constant:Co.defineModifier(),function:Co.defineModifier(),standard:Co.defineModifier(),local:Co.defineModifier(),special:Co.defineModifier()};function rh(t,e,i,s=0,n=0){null==e&&-1==(e=t.search(/[^\s\u00a0]/))&&(e=t.length);let r=n;for(let n=s;n<e;n++)9==t.charCodeAt(n)?r+=i-r%i:r++;return r}class oh{constructor(t,e,i){this.string=t,this.tabSize=e,this.indentUnit=i,this.pos=0,this.start=0,this.lastColumnPos=0,this.lastColumnValue=0}eol(){return this.pos>=this.string.length}sol(){return 0==this.pos}peek(){return this.string.charAt(this.pos)||void 0}next(){if(this.pos<this.string.length)return this.string.charAt(this.pos++)}eat(t){let e,i=this.string.charAt(this.pos);if(e="string"==typeof t?i==t:i&&(t instanceof RegExp?t.test(i):t(i)),e)return++this.pos,i}eatWhile(t){let e=this.pos;for(;this.eat(t););return this.pos>e}eatSpace(){let t=this.pos;for(;/[\s\u00a0]/.test(this.string.charAt(this.pos));)++this.pos;return this.pos>t}skipToEnd(){this.pos=this.string.length}skipTo(t){let e=this.string.indexOf(t,this.pos);if(e>-1)return this.pos=e,!0}backUp(t){this.pos-=t}column(){return this.lastColumnPos<this.start&&(this.lastColumnValue=rh(this.string,this.start,this.tabSize,this.lastColumnPos,this.lastColumnValue),this.lastColumnPos=this.start),this.lastColumnValue}indentation(){return rh(this.string,null,this.tabSize)}match(t,e,i){if("string"==typeof t){let s=t=>i?t.toLowerCase():t;return s(this.string.substr(this.pos,t.length))==s(t)?(!1!==e&&(this.pos+=t.length),!0):null}{let i=this.string.slice(this.pos).match(t);return i&&i.index>0?null:(i&&!1!==e&&(this.pos+=i[0].length),i)}}current(){return this.string.slice(this.start,this.pos)}}function hh(t){if("object"!=typeof t)return t;let e={};for(let i in t){let s=t[i];e[i]=s instanceof Array?s.slice():s}return e}class lh extends Wr{constructor(t){let e,i=Fr(t.languageData),n={token:(r=t).token,blankLine:r.blankLine||(()=>{}),startState:r.startState||(()=>!0),copyState:r.copyState||hh,indent:r.indent||(()=>null),languageData:r.languageData||{}};var r;super(i,new class extends A{createParse(t,i,s){return new uh(e,t,i,s)}},function(t){let e=o.define({id:ph.length,name:"Document",props:[zr.add((()=>t))]});return ph.push(e),e}(i),[io.of(((t,e)=>this.getIndent(t,e)))]),e=this,this.streamParser=n,this.stateAfter=new s({perNode:!0})}static define(t){return new lh(t)}getIndent(t,e){let i=_r(t.state),s=i.resolve(e);for(;s&&s.type!=this.topNode;)s=s.parent;if(!s)return null;let n,r,o=ah(this,i,0,s.from,e);if(o?(r=o.state,n=o.pos+1):(r=this.streamParser.startState(t.unit),n=0),e-n>1e4)return null;for(;n<e;){let i=t.state.doc.lineAt(n),s=Math.min(e,i.to);if(i.length){let e=new oh(i.text,t.state.tabSize,t.unit);for(;e.pos<s-i.from;)fh(this.streamParser.token,e,r)}else this.streamParser.blankLine(r,t.unit);if(s==e)break;n=i.to+1}let{text:h}=t.state.doc.lineAt(e);return this.streamParser.indent(r,/^\s*(.*)/.exec(h)[1],t)}get allowsNesting(){return!1}}function ah(t,e,i,s,n){let r=i>=s&&i+e.length<=n&&e.prop(t.stateAfter);if(r)return{state:t.streamParser.copyState(r),pos:i+e.length};for(let r=e.children.length-1;r>=0;r--){let o=e.children[r],h=i+e.positions[r],l=o instanceof a&&h<n&&ah(t,o,h,s,n);if(l)return l}return null}function ch(t,e,i,s,n){if(n&&i<=0&&s>=e.length)return e;n||e.type!=t.topNode||(n=!0);for(let r=e.children.length-1;r>=0;r--){let o,h=e.positions[r]+i,l=e.children[r];if(h<s&&l instanceof a){if(!(o=ch(t,l,i-h,s-h,n)))break;return n?new a(e.type,e.children.slice(0,r).concat(o),e.positions.slice(0,r+1),h+o.length):o}}return null}class uh{constructor(t,e,i,s){this.lang=t,this.input=e,this.fragments=i,this.ranges=s,this.stoppedAt=null,this.chunks=[],this.chunkPos=[],this.chunk=[],this.chunkReused=void 0,this.rangeIndex=0,this.to=s[s.length-1].to;let n=Gr.get(),r=s[0].from,{state:o,tree:h}=function(t,e,i,s){for(let s of e){let e,n=s.from+(s.openStart?25:0),r=s.to-(s.openEnd?25:0),o=n<=i&&r>i&&ah(t,s.tree,0-s.offset,i,r);if(o&&(e=ch(t,s.tree,i+s.offset,o.pos+s.offset,!1)))return{state:o.state,tree:e}}return{state:t.streamParser.startState(s?no(s):4),tree:a.empty}}(t,i,r,null==n?void 0:n.state);this.state=o,this.parsedPos=this.chunkStart=r+h.length,h.length&&(this.chunks.push(h),this.chunkPos.push(0)),n&&this.parsedPos<n.viewport.from-1e5&&(this.state=this.lang.streamParser.startState(no(n.state)),n.skipUntilInView(this.parsedPos,n.viewport.from),this.parsedPos=n.viewport.from)}advance(){let t=Gr.get(),e=null==this.stoppedAt?this.to:this.stoppedAt,i=Math.min(e,this.chunkStart+2048);for(t&&(i=Math.min(i,t.viewport.to));this.parsedPos<i;)this.parseLine(t);return this.chunkStart<this.parsedPos&&this.finishChunk(),this.parsedPos>=e?this.finish():t&&this.parsedPos>t.viewport.to?(t.skipUntilInView(this.parsedPos,e),this.finish()):null}stopAt(t){this.stoppedAt=t}lineAfter(t){let e=this.input.chunk(t);if(this.input.lineChunks)"\n"==e&&(e="");else{let t=e.indexOf("\n");t>-1&&(e=e.slice(0,t))}return t+e.length<=this.to?e:e.slice(0,this.to-t)}nextLine(){let t=this.parsedPos,e=this.lineAfter(t),i=t+e.length;for(let t=this.rangeIndex;;){let s=this.ranges[t].to;if(s>=i)break;if(e=e.slice(0,s-(i-e.length)),t++,t==this.ranges.length)break;let n=this.ranges[t].from,r=this.lineAfter(n);e+=r,i=n+r.length}return{line:e,end:i}}skipGapsTo(t,e,i){for(;;){let s=this.ranges[this.rangeIndex].to,n=t+e;if(i>0?s>n:s>=n)break;e+=this.ranges[++this.rangeIndex].from-s}return e}emitToken(t,e,i,s,n){if(this.ranges.length>1){e+=n=this.skipGapsTo(e,n,1);let t=this.chunk.length;i+=n=this.skipGapsTo(i,n,-1),s+=this.chunk.length-t}return this.chunk.push(t,e,i,s),n}parseLine(t){let{line:e,end:i}=this.nextLine(),s=0,{streamParser:n}=this.lang,r=new oh(e,t?t.state.tabSize:4,t?no(t.state):2);if(r.eol())n.blankLine(this.state,r.indentUnit);else for(;!r.eol();){let t=fh(n.token,r,this.state);t&&(s=this.emitToken(vh(t),this.parsedPos+r.start,this.parsedPos+r.pos,4,s))}this.parsedPos=i,this.parsedPos<this.to&&this.parsedPos++}finishChunk(){let t=a.build({buffer:this.chunk,start:this.chunkStart,length:this.parsedPos-this.chunkStart,nodeSet:gh,topID:0,maxBufferLength:2048,reused:this.chunkReused});t=new a(t.type,t.children,t.positions,t.length,[[this.lang.stateAfter,this.lang.streamParser.copyState(this.state)]]),this.chunks.push(t),this.chunkPos.push(this.chunkStart-this.ranges[0].from),this.chunk=[],this.chunkReused=void 0,this.chunkStart=this.parsedPos}finish(){return new a(this.lang.topNode,this.chunks,this.chunkPos,this.parsedPos-this.ranges[0].from).balance()}}function fh(t,e,i){e.start=e.pos;for(let s=0;s<10;s++){let s=t(e,i);if(e.pos>e.start)return s}throw new Error("Stream parser failed to advance stream.")}const dh=Object.create(null),ph=[o.none],gh=new h(ph),mh=[];function vh(t){return t?dh[t]||(dh[t]=function(t){let e=null;for(let i of t.split(".")){let t=nh[i];t?"function"==typeof t?e?e=t(e):wh(i,`Modifier ${i} used at start of tag`):e?wh(i,`Tag ${i} used as modifier`):e=t:wh(i,`Unknown highlighting tag ${i}`)}if(!e)return 0;let i=t.replace(/ /g,"_"),s=o.define({id:ph.length,name:i,props:[Oo({[i]:e})]});return ph.push(s),s.id}(t)):0}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"]])dh[t]=vh(e);function wh(t,e){mh.indexOf(t)>-1||(mh.push(t),console.warn(e))}var bh;const yh="undefined"!=typeof navigator&&!/Edge\/(\d+)/.exec(navigator.userAgent)&&/Apple Computer/.test(navigator.vendor)&&(/Mobile\/\w+/.test(navigator.userAgent)||navigator.maxTouchPoints>2);class xh{constructor(t,e,i){this.facet=e,this.createTooltipView=i,this.input=t.state.facet(e),this.tooltips=this.input.filter((t=>t)),this.tooltipViews=this.tooltips.map(i)}update(t){let e=t.state.facet(this.facet),i=e.filter((t=>t));if(e===this.input){for(let e of this.tooltipViews)e.update&&e.update(t);return{shouldMeasure:!1}}let s=[];for(let e=0;e<i.length;e++){let n=i[e],r=-1;if(n){for(let t=0;t<this.tooltips.length;t++){let e=this.tooltips[t];e&&e.create==n.create&&(r=t)}if(r<0)s[e]=this.createTooltipView(n);else{let i=s[e]=this.tooltipViews[r];i.update&&i.update(t)}}}for(let t of this.tooltipViews)s.indexOf(t)<0&&t.dom.remove();return this.input=e,this.tooltips=i,this.tooltipViews=s,{shouldMeasure:!0}}}function kh(t={}){return Sh.of(t)}const Sh=Mt.define({combine:t=>{var e,i;return{position:yh?"absolute":(null===(e=t.find((t=>t.position)))||void 0===e?void 0:e.position)||"fixed",parent:(null===(i=t.find((t=>t.parent)))||void 0===i?void 0:i.parent)||null}}}),Ah=as.fromClass(class{constructor(t){this.view=t,this.inView=!0;let e=t.state.facet(Sh);this.position=e.position,this.parent=e.parent,this.classes=t.themeClasses,this.createContainer(),this.measureReq={read:this.readMeasure.bind(this),write:this.writeMeasure.bind(this),key:this},this.manager=new xh(t,Dh,(t=>this.createTooltip(t))),this.maybeMeasure()}createContainer(){this.parent?(this.container=document.createElement("div"),this.container.style.position="relative",this.container.className=this.view.themeClasses,this.parent.appendChild(this.container)):this.container=this.view.dom}update(t){let{shouldMeasure:e}=this.manager.update(t),i=t.state.facet(Sh);if(i.position!=this.position){this.position=i.position;for(let t of this.manager.tooltipViews)t.dom.style.position=this.position;e=!0}if(i.parent!=this.parent){this.parent&&this.container.remove(),this.parent=i.parent,this.createContainer();for(let t of this.manager.tooltipViews)this.container.appendChild(t.dom);e=!0}else this.parent&&this.view.themeClasses!=this.classes&&(this.classes=this.container.className=this.view.themeClasses);e&&this.maybeMeasure()}createTooltip(t){let e=t.create(this.view);return e.dom.classList.add("cm-tooltip"),t.arrow&&e.dom.classList.add("cm-tooltip-arrow"),e.dom.style.position=this.position,e.dom.style.top="-10000px",this.container.appendChild(e.dom),e.mount&&e.mount(this.view),e}destroy(){for(let{dom:t}of this.manager.tooltipViews)t.remove()}readMeasure(){let t=this.view.dom.getBoundingClientRect();return{editor:t,parent:this.parent?this.container.getBoundingClientRect():t,pos:this.manager.tooltips.map((t=>this.view.coordsAtPos(t.pos))),size:this.manager.tooltipViews.map((({dom:t})=>t.getBoundingClientRect())),innerWidth:window.innerWidth,innerHeight:window.innerHeight}}writeMeasure(t){let{editor:e}=t,i=[];for(let s=0;s<this.manager.tooltips.length;s++){let n=this.manager.tooltips[s],r=this.manager.tooltipViews[s],{dom:o}=r,h=t.pos[s],l=t.size[s];if(!h||h.bottom<=e.top||h.top>=e.bottom||h.right<=e.left||h.left>=e.right){o.style.top="-10000px";continue}let a=!!n.arrow,c=!!n.above,u=l.right-l.left,f=l.bottom-l.top+(a?7:0),d=this.view.textDirection==Ss.LTR?Math.min(h.left-(a?14:0),t.innerWidth-u):Math.max(0,h.left-u+(a?14:0));!n.strictSide&&(c?h.top-(l.bottom-l.top)<0:h.bottom+(l.bottom-l.top)>t.innerHeight)&&(c=!c);let p=c?h.top-f:h.bottom+(a?7:0),g=d+u;for(let t of i)t.left<g&&t.right>d&&t.top<p+f&&t.bottom>p&&(p=c?t.top-f:t.bottom);"absolute"==this.position?(o.style.top=p-t.parent.top+"px",o.style.left=d-t.parent.left+"px"):(o.style.top=p+"px",o.style.left=d+"px"),i.push({left:d,top:p,right:g,bottom:p+f}),o.classList.toggle("cm-tooltip-above",c),o.classList.toggle("cm-tooltip-below",!c),r.positioned&&r.positioned()}}maybeMeasure(){if(this.manager.tooltips.length&&(this.view.inView&&this.view.requestMeasure(this.measureReq),this.inView!=this.view.inView&&(this.inView=this.view.inView,!this.inView)))for(let t of this.manager.tooltipViews)t.dom.style.top="-10000px"}},{eventHandlers:{scroll(){this.maybeMeasure()}}}),Ch="undefined"==typeof document||null!=(null===(bh=document.body)||void 0===bh?void 0:bh.style.insetInlineStart)?"insetInlineStart":"left",Mh=tr.baseTheme({".cm-tooltip":{zIndex:100},"&light .cm-tooltip":{border:"1px solid #bbb",backgroundColor:"#f5f5f5"},"&light .cm-tooltip-section:not(:first-child)":{borderTop:"1px solid #bbb"},"&dark .cm-tooltip":{backgroundColor:"#333338",color:"white"},".cm-tooltip.cm-tooltip-arrow:before, .cm-tooltip.cm-tooltip-arrow:after":{position:"absolute",content:"''",[Ch]:"7px",width:0,height:0,borderLeft:"7px solid transparent",borderRight:"7px solid transparent",zIndex:-1},".cm-tooltip-above.cm-tooltip-arrow:before":{borderTop:"7px solid #f5f5f5",bottom:"-6px"},".cm-tooltip-below.cm-tooltip-arrow:before":{borderBottom:"7px solid #f5f5f5",top:"-6px"},".cm-tooltip-above.cm-tooltip-arrow:after":{borderTop:"7px solid #bbb",bottom:"-7px",zIndex:-2},".cm-tooltip-below.cm-tooltip-arrow:after":{borderBottom:"7px solid #bbb",top:"-7px",zIndex:-2},"&dark .cm-tooltip.cm-tooltip-arrow:before":{borderTopColor:"#333338",borderBottomColor:"#333338"},"&dark .cm-tooltip.cm-tooltip-arrow:after":{borderTopColor:"transparent",borderBottomColor:"transparent"}}),Dh=Mt.define({enables:[Ah,Mh]}),Th=Mt.define();class Oh{constructor(t){this.view=t,this.mounted=!1,this.dom=document.createElement("div"),this.dom.classList.add("cm-tooltip-hover"),this.manager=new xh(t,Th,(t=>this.createHostedView(t)))}static create(t){return new Oh(t)}createHostedView(t){let e=t.create(this.view);return e.dom.classList.add("cm-tooltip-section"),this.dom.appendChild(e.dom),this.mounted&&e.mount&&e.mount(this.view),e}mount(t){for(let e of this.manager.tooltipViews)e.mount&&e.mount(t);this.mounted=!0}positioned(){for(let t of this.manager.tooltipViews)t.positioned&&t.positioned()}update(t){this.manager.update(t)}}const Ph=Dh.compute([Th],(t=>{let e=t.facet(Th).filter((t=>t));return 0===e.length?null:{pos:Math.min(...e.map((t=>t.pos))),end:Math.max(...e.filter((t=>null!=t.end)).map((t=>t.end))),create:Oh.create,above:e[0].above,arrow:e.some((t=>t.arrow))}}));class Eh{constructor(t,e,i,s,n){this.view=t,this.source=e,this.field=i,this.setHover=s,this.hoverTime=n,this.lastMouseMove=null,this.lastMoveTime=0,this.hoverTimeout=-1,this.restartTimeout=-1,this.pending=null,this.checkHover=this.checkHover.bind(this),t.dom.addEventListener("mouseleave",this.mouseleave=this.mouseleave.bind(this)),t.dom.addEventListener("mousemove",this.mousemove=this.mousemove.bind(this))}update(){this.pending&&(this.pending=null,clearTimeout(this.restartTimeout),this.restartTimeout=setTimeout((()=>this.startHover()),20))}get active(){return this.view.state.field(this.field)}checkHover(){if(this.hoverTimeout=-1,this.active)return;let t=Date.now()-this.lastMoveTime;t<this.hoverTime?this.hoverTimeout=setTimeout(this.checkHover,this.hoverTime-t):this.startHover()}startHover(){var t;clearTimeout(this.restartTimeout);let e=this.lastMouseMove,i={x:e.clientX,y:e.clientY},s=this.view.contentDOM.contains(e.target)?this.view.posAtCoords(i):null;if(null==s)return;let n=this.view.coordsAtPos(s);if(null==n||i.y<n.top||i.y>n.bottom||i.x<n.left-this.view.defaultCharacterWidth||i.x>n.right+this.view.defaultCharacterWidth)return;let r=this.view.bidiSpans(this.view.state.doc.lineAt(s)).find((t=>t.from<=s&&t.to>=s)),o=r&&r.dir==Ss.RTL?-1:1,h=this.source(this.view,s,i.x<n.left?-o:o);if(null===(t=h)||void 0===t?void 0:t.then){let t=this.pending={pos:s};h.then((e=>{this.pending==t&&(this.pending=null,e&&this.view.dispatch({effects:this.setHover.of(e)}))}),(t=>ss(this.view.state,t,"hover tooltip")))}else h&&this.view.dispatch({effects:this.setHover.of(h)})}mousemove(t){var e;this.lastMouseMove=t,this.lastMoveTime=Date.now(),this.hoverTimeout<0&&(this.hoverTimeout=setTimeout(this.checkHover,this.hoverTime));let i=this.active;if(i&&!function(t){for(let e=t;e;e=e.parentNode)if(1==e.nodeType&&e.classList.contains("cm-tooltip"))return!0;return!1}(t.target)||this.pending){let{pos:s}=i||this.pending,n=null!==(e=null==i?void 0:i.end)&&void 0!==e?e:s;(s==n?this.view.posAtCoords({x:t.clientX,y:t.clientY})==s:function(t,e,i,s,n,r){let o=document.createRange(),h=t.domAtPos(e),l=t.domAtPos(i);o.setEnd(l.node,l.offset),o.setStart(h.node,h.offset);let a=o.getClientRects();o.detach();for(let t=0;t<a.length;t++){let e=a[t];if(Math.max(e.top-n,n-e.bottom,e.left-s,s-e.right)<=r)return!0}return!1}(this.view,s,n,t.clientX,t.clientY,6))||(this.view.dispatch({effects:this.setHover.of(null)}),this.pending=null)}}mouseleave(){clearTimeout(this.hoverTimeout),this.hoverTimeout=-1,this.active&&this.view.dispatch({effects:this.setHover.of(null)})}destroy(){clearTimeout(this.hoverTimeout),this.view.dom.removeEventListener("mouseleave",this.mouseleave),this.view.dom.removeEventListener("mousemove",this.mousemove)}}function Rh(t,e={}){let i=te.define(),s=Rt.define({create:()=>null,update(t,s){if(t&&e.hideOnChange&&(s.docChanged||s.selection))return null;for(let t of s.effects)if(t.is(i))return t.value;if(t&&s.docChanged){let e=s.changes.mapPos(t.pos,-1,ft.TrackDel);if(null==e)return null;let i=Object.assign(Object.create(null),t);return i.pos=e,null!=t.end&&(i.end=s.changes.mapPos(t.end)),i}return t},provide:t=>Th.from(t)}),n=e.hoverTime||750;return[s,as.define((e=>new Eh(e,t,s,i,n))),Ph]}class Lh{constructor(t,e,i){this.state=t,this.pos=e,this.explicit=i,this.abortListeners=[]}tokenBefore(t){let e=_r(this.state).resolveInner(this.pos,-1);for(;e&&t.indexOf(e.name)<0;)e=e.parent;return e?{from:e.from,to:this.pos,text:this.state.sliceDoc(e.from,this.pos),type:e.type}:null}matchBefore(t){let e=this.state.doc.lineAt(this.pos),i=Math.max(e.from,this.pos-250),s=e.text.slice(i-e.from,this.pos-e.from),n=s.search(zh(t,!1));return n<0?null:{from:i+n,to:this.pos,text:s.slice(n)}}get aborted(){return null==this.abortListeners}addEventListener(t,e){"abort"==t&&this.abortListeners&&this.abortListeners.push(e)}}function Nh(t){let e=Object.keys(t).join(""),i=/\w/.test(e);return i&&(e=e.replace(/\w/g,"")),`[${i?"\\w":""}${e.replace(/[^\w\s]/g,"\\$&")}]`}function Ih(t){let e=t.map((t=>"string"==typeof t?{label:t}:t)),[i,s]=e.every((t=>/^\w+$/.test(t.label)))?[/\w*$/,/\w+$/]:function(t){let e=Object.create(null),i=Object.create(null);for(let{label:s}of t){e[s[0]]=!0;for(let t=1;t<s.length;t++)i[s[t]]=!0}let s=Nh(e)+Nh(i)+"*$";return[new RegExp("^"+s),new RegExp(s)]}(e);return t=>{let n=t.matchBefore(s);return n||t.explicit?{from:n?n.from:t.pos,options:e,span:i}:null}}function Bh(t,e){return i=>{for(let e=_r(i.state).resolveInner(i.pos,-1);e;e=e.parent)if(t.indexOf(e.name)>-1)return null;return e(i)}}class Vh{constructor(t,e,i){this.completion=t,this.source=e,this.match=i}}function Hh(t){return t.selection.main.head}function zh(t,e){var i;let{source:s}=t,n=e&&"^"!=s[0],r="$"!=s[s.length-1];return n||r?new RegExp(`${n?"^":""}(?:${s})${r?"$":""}`,null!==(i=t.flags)&&void 0!==i?i:t.ignoreCase?"i":""):t}function Fh(t,e){let i=e.completion.apply||e.completion.label,s=e.source;"string"==typeof i?t.dispatch({changes:{from:s.from,to:s.to,insert:i},selection:{anchor:s.from+i.length},userEvent:"input.complete"}):i(t,e.completion,s.from,s.to)}const Wh=new WeakMap;function qh(t){if(!Array.isArray(t))return t;let e=Wh.get(t);return e||Wh.set(t,e=Ih(t)),e}class jh{constructor(t){this.pattern=t,this.chars=[],this.folded=[],this.any=[],this.precise=[],this.byWord=[];for(let e=0;e<t.length;){let i=Q(t,e),s=tt(i);this.chars.push(i);let n=t.slice(e,e+s),r=n.toUpperCase();this.folded.push(Q(r==n?n.toLowerCase():r,0)),e+=s}this.astral=t.length!=this.chars.length}match(t){if(0==this.pattern.length)return[0];if(t.length<this.pattern.length)return null;let{chars:e,folded:i,any:s,precise:n,byWord:r}=this;if(1==e.length){let s=Q(t,0);return s==e[0]?[0,0,tt(s)]:s==i[0]?[-200,0,tt(s)]:null}let o=t.indexOf(this.pattern);if(0==o)return[0,0,this.pattern.length];let h=e.length,l=0;if(o<0){for(let n=0,r=Math.min(t.length,200);n<r&&l<h;){let r=Q(t,n);r!=e[l]&&r!=i[l]||(s[l++]=n),n+=tt(r)}if(l<h)return null}let a=0,c=0,u=!1,f=0,d=-1,p=-1,g=/[a-z]/.test(t);for(let s=0,l=Math.min(t.length,200),m=0;s<l&&c<h;){let l=Q(t,s);o<0&&(a<h&&l==e[a]&&(n[a++]=s),f<h&&(l==e[f]||l==i[f]?(0==f&&(d=s),p=s,f++):f=0));let v,w=l<255?l>=48&&l<=57||l>=97&&l<=122?2:l>=65&&l<=90?1:0:(v=Z(l))!=v.toLowerCase()?1:v!=v.toUpperCase()?2:0;(1==w&&g||0==m&&0!=w)&&(e[c]==l||i[c]==l&&(u=!0))&&(r[c++]=s),m=w,s+=tt(l)}return c==h&&0==r[0]?this.result((u?-200:0)-100,r,t):f==h&&0==d?[-200,0,p]:o>-1?[-700,o,o+this.pattern.length]:f==h?[-900,d,p]:c==h?this.result((u?-200:0)-100-700,r,t):2==e.length?null:this.result((s[0]?-700:0)-200-1100,s,t)}result(t,e,i){let s=[t],n=1;for(let t of e){let e=t+(this.astral?tt(Q(i,t)):1);n>1&&s[n-1]==t?s[n-1]=e:(s[n++]=t,s[n++]=e)}return s}}const _h=Mt.define({combine:t=>de(t,{activateOnTyping:!0,override:null,maxRenderedOptions:100,defaultKeymap:!0,optionClass:()=>"",icons:!0,addToOptions:[]},{defaultKeymap:(t,e)=>t&&e,icons:(t,e)=>t&&e,optionClass:(t,e)=>i=>function(t,e){return t?e?t+" "+e:t:e}(t(i),e(i)),addToOptions:(t,e)=>t.concat(e)})});const $h=tr.baseTheme({".cm-tooltip.cm-tooltip-autocomplete":{"& > ul":{fontFamily:"monospace",whiteSpace:"nowrap",overflow:"auto",maxWidth_fallback:"700px",maxWidth:"min(700px, 95vw)",maxHeight:"10em",listStyle:"none",margin:0,padding:0,"& > li":{cursor:"pointer",padding:"1px 1em 1px 3px",lineHeight:1.2},"& > li[aria-selected]":{background_fallback:"#bdf",backgroundColor:"Highlight",color_fallback:"white",color:"HighlightText"}}},".cm-completionListIncompleteTop:before, .cm-completionListIncompleteBottom:after":{content:'"···"',opacity:.5,display:"block",textAlign:"center"},".cm-tooltip.cm-completionInfo":{position:"absolute",padding:"3px 9px",width:"max-content",maxWidth:"300px"},".cm-completionInfo.cm-completionInfo-left":{right:"100%"},".cm-completionInfo.cm-completionInfo-right":{left:"100%"},"&light .cm-snippetField":{backgroundColor:"#00000022"},"&dark .cm-snippetField":{backgroundColor:"#ffffff22"},".cm-snippetFieldPosition":{verticalAlign:"text-top",width:0,height:"1.15em",margin:"0 -0.7px -.7em",borderLeft:"1.4px dotted #888"},".cm-completionMatchedText":{textDecoration:"underline"},".cm-completionDetail":{marginLeft:"0.5em",fontStyle:"italic"},".cm-completionIcon":{fontSize:"90%",width:".8em",display:"inline-block",textAlign:"center",paddingRight:".6em",opacity:"0.6"},".cm-completionIcon-function, .cm-completionIcon-method":{"&:after":{content:"'ƒ'"}},".cm-completionIcon-class":{"&:after":{content:"'○'"}},".cm-completionIcon-interface":{"&:after":{content:"'◌'"}},".cm-completionIcon-variable":{"&:after":{content:"'𝑥'"}},".cm-completionIcon-constant":{"&:after":{content:"'𝐶'"}},".cm-completionIcon-type":{"&:after":{content:"'𝑡'"}},".cm-completionIcon-enum":{"&:after":{content:"'∪'"}},".cm-completionIcon-property":{"&:after":{content:"'□'"}},".cm-completionIcon-keyword":{"&:after":{content:"'🔑︎'"}},".cm-completionIcon-namespace":{"&:after":{content:"'▢'"}},".cm-completionIcon-text":{"&:after":{content:"'abc'",fontSize:"50%",verticalAlign:"middle"}}});function Uh(t,e,i){if(t<=i)return{from:0,to:t};if(e<=t>>1){let t=Math.floor(e/i);return{from:t*i,to:(t+1)*i}}let s=Math.floor((t-e)/i);return{from:t-(s+1)*i,to:t-s*i}}class Gh{constructor(t,e){this.view=t,this.stateField=e,this.info=null,this.placeInfo={read:()=>this.measureInfo(),write:t=>this.positionInfo(t),key:this};let i=t.state.field(e),{options:s,selected:n}=i.open,r=t.state.facet(_h);this.optionContent=function(t){let e=t.addToOptions.slice();return t.icons&&e.push({render(t){let e=document.createElement("div");return e.classList.add("cm-completionIcon"),t.type&&e.classList.add(...t.type.split(/\s+/g).map((t=>"cm-completionIcon-"+t))),e.setAttribute("aria-hidden","true"),e},position:20}),e.push({render(t,e,i){let s=document.createElement("span");s.className="cm-completionLabel";let{label:n}=t,r=0;for(let t=1;t<i.length;){let e=i[t++],o=i[t++];e>r&&s.appendChild(document.createTextNode(n.slice(r,e)));let h=s.appendChild(document.createElement("span"));h.appendChild(document.createTextNode(n.slice(e,o))),h.className="cm-completionMatchedText",r=o}return r<n.length&&s.appendChild(document.createTextNode(n.slice(r))),s},position:50},{render(t){if(!t.detail)return null;let e=document.createElement("span");return e.className="cm-completionDetail",e.textContent=t.detail,e},position:80}),e.sort(((t,e)=>t.position-e.position)).map((t=>t.render))}(r),this.optionClass=r.optionClass,this.range=Uh(s.length,n,r.maxRenderedOptions),this.dom=document.createElement("div"),this.dom.className="cm-tooltip-autocomplete",this.dom.addEventListener("mousedown",(e=>{for(let i,n=e.target;n&&n!=this.dom;n=n.parentNode)if("LI"==n.nodeName&&(i=/-(\d+)$/.exec(n.id))&&+i[1]<s.length)return Fh(t,s[+i[1]]),void e.preventDefault()})),this.list=this.dom.appendChild(this.createListBox(s,i.id,this.range)),this.list.addEventListener("scroll",(()=>{this.info&&this.view.requestMeasure(this.placeInfo)}))}mount(){this.updateSel()}update(t){t.state.field(this.stateField)!=t.startState.field(this.stateField)&&this.updateSel()}positioned(){this.info&&this.view.requestMeasure(this.placeInfo)}updateSel(){let t=this.view.state.field(this.stateField),e=t.open;if((e.selected<this.range.from||e.selected>=this.range.to)&&(this.range=Uh(e.options.length,e.selected,this.view.state.facet(_h).maxRenderedOptions),this.list.remove(),this.list=this.dom.appendChild(this.createListBox(e.options,t.id,this.range)),this.list.addEventListener("scroll",(()=>{this.info&&this.view.requestMeasure(this.placeInfo)}))),this.updateSelectedOption(e.selected)){this.info&&(this.info.remove(),this.info=null);let t=e.options[e.selected];t.completion.info&&(this.info=this.dom.appendChild(function(t,e){let i=document.createElement("div");i.className="cm-tooltip cm-completionInfo";let{info:s}=t.completion;if("string"==typeof s)i.textContent=s;else{let n=s(t.completion);n.then?n.then((t=>i.appendChild(t)),(t=>ss(e.state,t,"completion info"))):i.appendChild(n)}return i}(t,this.view)),this.view.requestMeasure(this.placeInfo))}}updateSelectedOption(t){let e=null;for(let i=this.list.firstChild,s=this.range.from;i;i=i.nextSibling,s++)s==t?i.hasAttribute("aria-selected")||(i.setAttribute("aria-selected","true"),e=i):i.hasAttribute("aria-selected")&&i.removeAttribute("aria-selected");return e&&function(t,e){let i=t.getBoundingClientRect(),s=e.getBoundingClientRect();s.top<i.top?t.scrollTop-=i.top-s.top:s.bottom>i.bottom&&(t.scrollTop+=s.bottom-i.bottom)}(this.list,e),e}measureInfo(){let t=this.dom.querySelector("[aria-selected]");if(!t)return null;let e=this.dom.getBoundingClientRect(),i=t.getBoundingClientRect().top-e.top;if(i<0||i>this.list.clientHeight-10)return null;let s=this.view.textDirection==Ss.RTL,n=e.left,r=innerWidth-e.right;return s&&n<Math.min(300,r)?s=!1:!s&&r<Math.min(300,n)&&(s=!0),{top:i,left:s}}positionInfo(t){this.info&&t&&(this.info.style.top=t.top+"px",this.info.classList.toggle("cm-completionInfo-left",t.left),this.info.classList.toggle("cm-completionInfo-right",!t.left))}createListBox(t,e,i){const s=document.createElement("ul");s.id=e,s.setAttribute("role","listbox");for(let n=i.from;n<i.to;n++){let{completion:i,match:r}=t[n];const o=s.appendChild(document.createElement("li"));o.id=e+"-"+n,o.setAttribute("role","option");let h=this.optionClass(i);h&&(o.className=h);for(let t of this.optionContent){let e=t(i,this.view.state,r);e&&o.appendChild(e)}}return i.from&&s.classList.add("cm-completionListIncompleteTop"),i.to<t.length&&s.classList.add("cm-completionListIncompleteBottom"),s}}function Kh(t){return 100*(t.boost||0)+(t.apply?10:0)+(t.info?5:0)+(t.type?1:0)}class Jh{constructor(t,e,i,s,n){this.options=t,this.attrs=e,this.tooltip=i,this.timestamp=s,this.selected=n}setSelected(t,e){return t==this.selected||t>=this.options.length?this:new Jh(this.options,Qh(e,t),this.tooltip,this.timestamp,t)}static build(t,e,i,s){let n=function(t,e){let i=[],s=0;for(let n of t)if(n.hasResult())if(!1===n.result.filter)for(let t of n.result.options)i.push(new Vh(t,n,[1e9-s++]));else{let t,s=new jh(e.sliceDoc(n.from,n.to));for(let e of n.result.options)(t=s.match(e.label))&&(null!=e.boost&&(t[0]+=e.boost),i.push(new Vh(e,n,t)))}i.sort(tl);let n=[],r=null;for(let t of i.sort(tl)){if(300==n.length)break;r&&r.label==t.completion.label&&r.detail==t.completion.detail?Kh(t.completion)>Kh(r)&&(n[n.length-1]=t):n.push(t),r=t.completion}return n}(t,e);if(!n.length)return null;let r=0;if(s&&s.selected){let t=s.options[s.selected].completion;for(let e=0;e<n.length&&!r;e++)n[e].completion==t&&(r=e)}return new Jh(n,Qh(i,r),{pos:t.reduce(((t,e)=>e.hasResult()?Math.min(t,e.from):t),1e8),create:(o=ll,t=>new Gh(t,o))},s?s.timestamp:Date.now(),r);var o}map(t){return new Jh(this.options,this.attrs,Object.assign(Object.assign({},this.tooltip),{pos:t.mapPos(this.tooltip.pos)}),this.timestamp,this.selected)}}class Xh{constructor(t,e,i){this.active=t,this.id=e,this.open=i}static start(){return new Xh(Zh,"cm-ac-"+Math.floor(2e6*Math.random()).toString(36),null)}update(t){let{state:e}=t,i=e.facet(_h),s=(i.override||e.languageDataAt("autocomplete",Hh(e)).map(qh)).map((e=>(this.active.find((t=>t.source==e))||new il(e,this.active.some((t=>0!=t.state))?1:0)).update(t,i)));s.length==this.active.length&&s.every(((t,e)=>t==this.active[e]))&&(s=this.active);let n=t.selection||s.some((e=>e.hasResult()&&t.changes.touchesRange(e.from,e.to)))||!function(t,e){if(t==e)return!0;for(let i=0,s=0;;){for(;i<t.length&&!t[i].hasResult;)i++;for(;s<e.length&&!e[s].hasResult;)s++;let n=i==t.length,r=s==e.length;if(n||r)return n==r;if(t[i++].result!=e[s++].result)return!1}}(s,this.active)?Jh.build(s,e,this.id,this.open):this.open&&t.docChanged?this.open.map(t.changes):this.open;!n&&s.every((t=>1!=t.state))&&s.some((t=>t.hasResult()))&&(s=s.map((t=>t.hasResult()?new il(t.source,0):t)));for(let e of t.effects)e.is(hl)&&(n=n&&n.setSelected(e.value,this.id));return s==this.active&&n==this.open?this:new Xh(s,this.id,n)}get tooltip(){return this.open?this.open.tooltip:null}get attrs(){return this.open?this.open.attrs:Yh}}const Yh={"aria-autocomplete":"list","aria-expanded":"false"};function Qh(t,e){return{"aria-autocomplete":"list","aria-expanded":"true","aria-activedescendant":t+"-"+e,"aria-controls":t}}const Zh=[];function tl(t,e){let i=e.match[0]-t.match[0];return i||t.completion.label.localeCompare(e.completion.label)}function el(t){return t.isUserEvent("input.type")?"input":t.isUserEvent("delete.backward")?"delete":null}class il{constructor(t,e,i=-1){this.source=t,this.state=e,this.explicitPos=i}hasResult(){return!1}update(t,e){let i=el(t),s=this;i?s=s.handleUserEvent(t,i,e):t.docChanged?s=s.handleChange(t):t.selection&&0!=s.state&&(s=new il(s.source,0));for(let e of t.effects)if(e.is(nl))s=new il(s.source,1,e.value?Hh(t.state):-1);else if(e.is(rl))s=new il(s.source,0);else if(e.is(ol))for(let t of e.value)t.source==s.source&&(s=t);return s}handleUserEvent(t,e,i){return"delete"!=e&&i.activateOnTyping?new il(this.source,1):this.map(t.changes)}handleChange(t){return t.changes.touchesRange(Hh(t.startState))?new il(this.source,0):this.map(t.changes)}map(t){return t.empty||this.explicitPos<0?this:new il(this.source,this.state,t.mapPos(this.explicitPos))}}class sl extends il{constructor(t,e,i,s,n,r){super(t,2,e),this.result=i,this.from=s,this.to=n,this.span=r}hasResult(){return!0}handleUserEvent(t,e,i){let s=t.changes.mapPos(this.from),n=t.changes.mapPos(this.to,1),r=Hh(t.state);if((this.explicitPos>-1?r<s:r<=s)||r>n)return new il(this.source,"input"==e&&i.activateOnTyping?1:0);let o=this.explicitPos<0?-1:t.changes.mapPos(this.explicitPos);return this.span&&(s==n||this.span.test(t.state.sliceDoc(s,n)))?new sl(this.source,o,this.result,s,n,this.span):new il(this.source,1,o)}handleChange(t){return t.changes.touchesRange(this.from,this.to)?new il(this.source,0):this.map(t.changes)}map(t){return t.empty?this:new sl(this.source,this.explicitPos<0?-1:t.mapPos(this.explicitPos),this.result,t.mapPos(this.from),t.mapPos(this.to,1),this.span)}}const nl=te.define(),rl=te.define(),ol=te.define({map:(t,e)=>t.map((t=>t.map(e)))}),hl=te.define(),ll=Rt.define({create:()=>Xh.start(),update:(t,e)=>t.update(e),provide:t=>[Dh.from(t,(t=>t.tooltip)),tr.contentAttributes.from(t,(t=>t.attrs))]});function al(t,e="option"){return i=>{let s=i.state.field(ll,!1);if(!s||!s.open||Date.now()-s.open.timestamp<75)return!1;let n,r=1;"page"==e&&(n=i.dom.querySelector(".cm-tooltip-autocomplete"))&&(r=Math.max(2,Math.floor(n.offsetHeight/n.firstChild.offsetHeight)));let o=s.open.selected+r*(t?1:-1),{length:h}=s.open.options;return o<0?o="page"==e?0:h-1:o>=h&&(o="page"==e?h-1:0),i.dispatch({effects:hl.of(o)}),!0}}const cl=t=>{let e=t.state.field(ll,!1);return!(!e||!e.open||Date.now()-e.open.timestamp<75)&&(Fh(t,e.open.options[e.open.selected]),!0)};class ul{constructor(t,e){this.active=t,this.context=e,this.time=Date.now(),this.updates=[],this.done=void 0}}const fl=as.fromClass(class{constructor(t){this.view=t,this.debounceUpdate=-1,this.running=[],this.debounceAccept=-1,this.composing=0;for(let e of t.state.field(ll).active)1==e.state&&this.startQuery(e)}update(t){let e=t.state.field(ll);if(!t.selectionSet&&!t.docChanged&&t.startState.field(ll)==e)return;let i=t.transactions.some((t=>(t.selection||t.docChanged)&&!el(t)));for(let e=0;e<this.running.length;e++){let s=this.running[e];if(i||s.updates.length+t.transactions.length>50&&s.time-Date.now()>1e3){for(let t of s.context.abortListeners)try{t()}catch(t){ss(this.view.state,t)}s.context.abortListeners=null,this.running.splice(e--,1)}else s.updates.push(...t.transactions)}if(this.debounceUpdate>-1&&clearTimeout(this.debounceUpdate),this.debounceUpdate=e.active.some((t=>1==t.state&&!this.running.some((e=>e.active.source==t.source))))?setTimeout((()=>this.startUpdate()),50):-1,0!=this.composing)for(let e of t.transactions)"input"==el(e)?this.composing=2:2==this.composing&&e.selection&&(this.composing=3)}startUpdate(){this.debounceUpdate=-1;let{state:t}=this.view,e=t.field(ll);for(let t of e.active)1!=t.state||this.running.some((e=>e.active.source==t.source))||this.startQuery(t)}startQuery(t){let{state:e}=this.view,i=Hh(e),s=new Lh(e,i,t.explicitPos==i),n=new ul(t,s);this.running.push(n),Promise.resolve(t.source(s)).then((t=>{n.context.aborted||(n.done=t||null,this.scheduleAccept())}),(t=>{this.view.dispatch({effects:rl.of(null)}),ss(this.view.state,t)}))}scheduleAccept(){this.running.every((t=>void 0!==t.done))?this.accept():this.debounceAccept<0&&(this.debounceAccept=setTimeout((()=>this.accept()),50))}accept(){var t;this.debounceAccept>-1&&clearTimeout(this.debounceAccept),this.debounceAccept=-1;let e=[],i=this.view.state.facet(_h);for(let s=0;s<this.running.length;s++){let n=this.running[s];if(void 0===n.done)continue;if(this.running.splice(s--,1),n.done){let s=new sl(n.active.source,n.active.explicitPos,n.done,n.done.from,null!==(t=n.done.to)&&void 0!==t?t:Hh(n.updates.length?n.updates[0].startState:this.view.state),n.done.span&&!1!==n.done.filter?zh(n.done.span,!0):null);for(let t of n.updates)s=s.update(t,i);if(s.hasResult()){e.push(s);continue}}let r=this.view.state.field(ll).active.find((t=>t.source==n.active.source));if(r&&1==r.state)if(null==n.done){let t=new il(n.active.source,0);for(let e of n.updates)t=t.update(e,i);1!=t.state&&e.push(t)}else this.startQuery(r)}e.length&&this.view.dispatch({effects:ol.of(e)})}},{eventHandlers:{compositionstart(){this.composing=1},compositionend(){3==this.composing&&setTimeout((()=>this.view.dispatch({effects:nl.of(!1)})),20),this.composing=0}}});class dl{constructor(t,e,i,s){this.field=t,this.line=e,this.from=i,this.to=s}}class pl{constructor(t,e,i){this.field=t,this.from=e,this.to=i}map(t){return new pl(this.field,t.mapPos(this.from,-1),t.mapPos(this.to,1))}}class gl{constructor(t,e){this.lines=t,this.fieldPositions=e}instantiate(t,e){let i=[],s=[e],n=t.doc.lineAt(e),r=/^\s*/.exec(n.text)[0];for(let n of this.lines){if(i.length){let i=r,o=/^\t*/.exec(n)[0].length;for(let e=0;e<o;e++)i+=t.facet(so);s.push(e+i.length-o),n=i+n.slice(o)}i.push(n),e+=n.length+1}let o=this.fieldPositions.map((t=>new pl(t.field,s[t.line]+t.from,s[t.line]+t.to)));return{text:i,ranges:o}}static parse(t){let e,i=[],s=[],n=[];for(let r of t.split(/\r\n?|\n/)){for(;e=/[#$]\{(?:(\d+)(?::([^}]*))?|([^}]*))\}/.exec(r);){let t=e[1]?+e[1]:null,o=e[2]||e[3],h=-1;for(let e=0;e<i.length;e++)(null!=t?i[e].seq==t:o&&i[e].name==o)&&(h=e);if(h<0){let e=0;for(;e<i.length&&(null==t||null!=i[e].seq&&i[e].seq<t);)e++;i.splice(e,0,{seq:t,name:o||null}),h=e;for(let t of n)t.field>=h&&t.field++}n.push(new dl(h,s.length,e.index,e.index+o.length)),r=r.slice(0,e.index)+o+r.slice(e.index+e[0].length)}s.push(r)}return new gl(s,n)}}let ml=Hi.widget({widget:new class extends Bi{toDOM(){let t=document.createElement("span");return t.className="cm-snippetFieldPosition",t}ignoreEvent(){return!1}}}),vl=Hi.mark({class:"cm-snippetField"});class wl{constructor(t,e){this.ranges=t,this.active=e,this.deco=Hi.set(t.map((t=>(t.from==t.to?ml:vl).range(t.from,t.to))))}map(t){return new wl(this.ranges.map((e=>e.map(t))),this.active)}selectionInsideField(t){return t.ranges.every((t=>this.ranges.some((e=>e.field==this.active&&e.from<=t.from&&e.to>=t.to))))}}const bl=te.define({map:(t,e)=>t&&t.map(e)}),yl=te.define(),xl=Rt.define({create:()=>null,update(t,e){for(let i of e.effects){if(i.is(bl))return i.value;if(i.is(yl)&&t)return new wl(t.ranges,i.value)}return t&&e.docChanged&&(t=t.map(e.changes)),t&&e.selection&&!t.selectionInsideField(e.selection)&&(t=null),t},provide:t=>tr.decorations.from(t,(t=>t?t.deco:Hi.none))});function kl(t,e){return kt.create(t.filter((t=>t.field==e)).map((t=>kt.range(t.from,t.to))))}function Sl(t){let e=gl.parse(t);return(t,i,s,n)=>{let{text:r,ranges:o}=e.instantiate(t.state,s),h={changes:{from:s,to:n,insert:it.of(r)}};if(o.length&&(h.selection=kl(o,0)),o.length>1){let e=new wl(o,0),i=h.effects=[bl.of(e)];void 0===t.state.field(xl,!1)&&i.push(te.appendConfig.of([xl.init((()=>e)),Dl,Ol,$h]))}t.dispatch(t.state.update(h))}}function Al(t){return({state:e,dispatch:i})=>{let s=e.field(xl,!1);if(!s||t<0&&0==s.active)return!1;let n=s.active+t,r=t>0&&!s.ranges.some((e=>e.field==n+t));return i(e.update({selection:kl(s.ranges,n),effects:bl.of(r?null:new wl(s.ranges,n))})),!0}}const Cl=[{key:"Tab",run:Al(1),shift:Al(-1)},{key:"Escape",run:({state:t,dispatch:e})=>!!t.field(xl,!1)&&(e(t.update({effects:bl.of(null)})),!0)}],Ml=Mt.define({combine:t=>t.length?t[0]:Cl}),Dl=Vt.override(cr.compute([Ml],(t=>t.facet(Ml))));function Tl(t,e){return Object.assign(Object.assign({},e),{apply:Sl(t)})}const Ol=tr.domEventHandlers({mousedown(t,e){let i,s=e.state.field(xl,!1);if(!s||null==(i=e.posAtCoords({x:t.clientX,y:t.clientY})))return!1;let n=s.ranges.find((t=>t.from<=i&&t.to>=i));return!(!n||n.field==s.active)&&(e.dispatch({selection:kl(s.ranges,n.field),effects:bl.of(s.ranges.some((t=>t.field>n.field))?new wl(s.ranges,n.field):null)}),!0)}});function Pl(t,e){return new RegExp(e(t.source),t.unicode?"u":"")}const El=Object.create(null);function Rl(t,e,i,s,n){for(let r=t.iterLines(),o=0;!r.next().done;){let t,{value:h}=r;for(e.lastIndex=0;t=e.exec(h);)if(!s[t[0]]&&o+t.index!=n&&(i.push({type:"text",label:t[0]}),s[t[0]]=!0,i.length>=2e3))return;o+=h.length+1}}function Ll(t,e,i,s,n){let r=t.length>=1e3,o=r&&e.get(t);if(o)return o;let h=[],l=Object.create(null);if(t.children){let r=0;for(let o of t.children){if(o.length>=1e3)for(let t of Ll(o,e,i,s-r,n-r))l[t.label]||(l[t.label]=!0,h.push(t));else Rl(o,i,h,l,n-r);r+=o.length+1}}else Rl(t,i,h,l,n);return r&&h.length<2e3&&e.set(t,h),h}const Nl=t=>{let e=t.state.languageDataAt("wordChars",t.pos).join(""),i=function(t){let e=t.replace(/[\\[.+*?(){|^$]/g,"\\$&");try{return new RegExp(`[\\p{Alphabetic}\\p{Number}_${e}]+`,"ug")}catch(t){return new RegExp(`[w${e}]`,"g")}}(e),s=t.matchBefore(Pl(i,(t=>t+"$")));if(!s&&!t.explicit)return null;let n=s?s.from:t.pos,r=Ll(t.state.doc,function(t){return El[t]||(El[t]=new WeakMap)}(e),i,5e4,n);return{from:n,options:r,span:Pl(i,(t=>"^"+t))}};function Il(t={}){return[ll,_h.of(t),fl,Vl,$h]}const Bl=[{key:"Ctrl-Space",run:t=>!!t.state.field(ll,!1)&&(t.dispatch({effects:nl.of(!0)}),!0)},{key:"Escape",run:t=>{let e=t.state.field(ll,!1);return!(!e||!e.active.some((t=>0!=t.state)))&&(t.dispatch({effects:rl.of(null)}),!0)}},{key:"ArrowDown",run:al(!0)},{key:"ArrowUp",run:al(!1)},{key:"PageDown",run:al(!0,"page")},{key:"PageUp",run:al(!1,"page")},{key:"Enter",run:cl}],Vl=Vt.override(cr.computeN([_h],(t=>t.facet(_h).defaultKeymap?[Bl]:[])));function Hl(t){var e;let i=null===(e=t.field(ll,!1))||void 0===e?void 0:e.open;return i?i.options.map((t=>t.completion)):[]}const zl={brackets:["(","[","{","'",'"'],before:")]}'\":;>"},Fl=te.define({map(t,e){let i=e.mapPos(t,-1,ft.TrackAfter);return null==i?void 0:i}}),Wl=te.define({map:(t,e)=>e.mapPos(t)}),ql=new class extends pe{};ql.startSide=1,ql.endSide=-1;const jl=Rt.define({create:()=>we.empty,update(t,e){if(e.selection){let i=e.state.doc.lineAt(e.selection.main.head).from,s=e.startState.doc.lineAt(e.startState.selection.main.head).from;i!=e.changes.mapPos(s,-1)&&(t=we.empty)}t=t.map(e.changes);for(let i of e.effects)i.is(Fl)?t=t.update({add:[ql.range(i.value,i.value+1)]}):i.is(Wl)&&(t=t.update({filter:t=>t!=i.value}));return t}});function _l(){return[tr.inputHandler.of(Gl),jl]}function $l(t){for(let e=0;e<"()[]{}<>".length;e+=2)if("()[]{}<>".charCodeAt(e)==t)return"()[]{}<>".charAt(e+1);return Z(t<128?t:t+1)}function Ul(t,e){return t.languageDataAt("closeBrackets",e)[0]||zl}function Gl(t,e,i,s){if(t.composing)return!1;let n=t.state.selection.main;if(s.length>2||2==s.length&&1==tt(Q(s,0))||e!=n.from||i!=n.to)return!1;let r=function(t,e){let i=Ul(t,t.selection.main.head),s=i.brackets||zl.brackets;for(let n of s){let r=$l(Q(n,0));if(e==n)return r==n?Zl(t,n,s.indexOf(n+n+n)>-1):Yl(t,n,r,i.before||zl.before);if(e==r&&Jl(t,t.selection.main.from))return Ql(t,n,r)}return null}(t.state,s);return!!r&&(t.dispatch(r),!0)}const Kl=[{key:"Backspace",run:({state:t,dispatch:e})=>{let i=Ul(t,t.selection.main.head).brackets||zl.brackets,s=null,n=t.changeByRange((e=>{if(e.empty){let s=function(t,e){let i=t.sliceString(e-2,e);return tt(Q(i,0))==i.length?i:i.slice(1)}(t.doc,e.head);for(let n of i)if(n==s&&Xl(t.doc,e.head)==$l(Q(n,0)))return{changes:{from:e.head-n.length,to:e.head+n.length},range:kt.cursor(e.head-n.length),userEvent:"delete.backward"}}return{range:s=e}}));return s||e(t.update(n,{scrollIntoView:!0})),!s}}];function Jl(t,e){let i=!1;return t.field(jl).between(0,t.doc.length,(t=>{t==e&&(i=!0)})),i}function Xl(t,e){let i=t.sliceString(e,e+2);return i.slice(0,tt(Q(i,0)))}function Yl(t,e,i,s){let n=null,r=t.changeByRange((r=>{if(!r.empty)return{changes:[{insert:e,from:r.from},{insert:i,from:r.to}],effects:Fl.of(r.to+e.length),range:kt.range(r.anchor+e.length,r.head+e.length)};let o=Xl(t.doc,r.head);return!o||/\s/.test(o)||s.indexOf(o)>-1?{changes:{insert:e+i,from:r.head},effects:Fl.of(r.head+e.length),range:kt.cursor(r.head+e.length)}:{range:n=r}}));return n?null:t.update(r,{scrollIntoView:!0,userEvent:"input.type"})}function Ql(t,e,i){let s=null,n=t.selection.ranges.map((e=>e.empty&&Xl(t.doc,e.head)==i?kt.cursor(e.head+i.length):s=e));return s?null:t.update({selection:kt.create(n,t.selection.mainIndex),scrollIntoView:!0,effects:t.selection.ranges.map((({from:t})=>Wl.of(t)))})}function Zl(t,e,i){let s=null,n=t.changeByRange((n=>{if(!n.empty)return{changes:[{insert:e,from:n.from},{insert:e,from:n.to}],effects:Fl.of(n.to+e.length),range:kt.range(n.anchor+e.length,n.head+e.length)};let r=n.head,o=Xl(t.doc,r);if(o==e){if(ta(t,r))return{changes:{insert:e+e,from:r},effects:Fl.of(r+e.length),range:kt.cursor(r+e.length)};if(Jl(t,r)){let s=i&&t.sliceDoc(r,r+3*e.length)==e+e+e;return{range:kt.cursor(r+e.length*(s?3:1)),effects:Wl.of(r)}}}else{if(i&&t.sliceDoc(r-2*e.length,r)==e+e&&ta(t,r-2*e.length))return{changes:{insert:e+e+e+e,from:r},effects:Fl.of(r+e.length),range:kt.cursor(r+e.length)};if(t.charCategorizer(r)(o)!=le.Word){let i=t.sliceDoc(r-1,r);if(i!=e&&t.charCategorizer(r)(i)!=le.Word)return{changes:{insert:e+e,from:r},effects:Fl.of(r+e.length),range:kt.cursor(r+e.length)}}}return{range:s=n}}));return s?null:t.update(n,{scrollIntoView:!0,userEvent:"input.type"})}function ta(t,e){let i=_r(t).resolveInner(e+1);return i.parent&&i.from==e}const ea=tr.baseTheme({".cm-matchingBracket":{backgroundColor:"#328c8252"},".cm-nonmatchingBracket":{backgroundColor:"#bb555544"}}),ia=Mt.define({combine:t=>de(t,{afterCursor:!0,brackets:"()[]{}",maxScanDistance:1e4})}),sa=Hi.mark({class:"cm-matchingBracket"}),na=Hi.mark({class:"cm-nonmatchingBracket"}),ra=Rt.define({create:()=>Hi.none,update(t,e){if(!e.docChanged&&!e.selection)return t;let i=[],s=e.state.facet(ia);for(let t of e.state.selection.ranges){if(!t.empty)continue;let n=aa(e.state,t.head,-1,s)||t.head>0&&aa(e.state,t.head-1,1,s)||s.afterCursor&&(aa(e.state,t.head,1,s)||t.head<e.state.doc.length&&aa(e.state,t.head+1,-1,s));if(!n)continue;let r=n.matched?sa:na;i.push(r.range(n.start.from,n.start.to)),n.end&&i.push(r.range(n.end.from,n.end.to))}return Hi.set(i,!0)},provide:t=>tr.decorations.from(t)}),oa=[ra,ea];function ha(t={}){return[ia.of(t),oa]}function la(t,e,i){let n=t.prop(e<0?s.openedBy:s.closedBy);if(n)return n;if(1==t.name.length){let s=i.indexOf(t.name);if(s>-1&&s%2==(e<0?1:0))return[i[s+e]]}return null}function aa(t,e,i,s={}){let n=s.maxScanDistance||1e4,r=s.brackets||"()[]{}",o=_r(t),h=o.resolveInner(e,i);for(let s=h;s;s=s.parent){let n=la(s.type,i,r);if(n&&s.from<s.to)return ca(t,e,i,s,n,r)}return function(t,e,i,s,n,r,o){let h=i<0?t.sliceDoc(e-1,e):t.sliceDoc(e,e+1),l=o.indexOf(h);if(l<0||l%2==0!=i>0)return null;let a={from:i<0?e-1:e,to:i>0?e+1:e},c=t.doc.iterRange(e,i>0?t.doc.length:0),u=0;for(let t=0;!c.next().done&&t<=r;){let r=c.value;i<0&&(t+=r.length);let h=e+t*i;for(let t=i>0?0:r.length-1,e=i>0?r.length:-1;t!=e;t+=i){let e=o.indexOf(r[t]);if(!(e<0||s.resolve(h+t,1).type!=n))if(e%2==0==i>0)u++;else{if(1==u)return{start:a,end:{from:h+t,to:h+t+1},matched:e>>1==l>>1};u--}}i>0&&(t+=r.length)}return c.done?{start:a,matched:!1}:null}(t,e,i,o,h.type,n,r)}function ca(t,e,i,s,n,r){let o=s.parent,h={from:s.from,to:s.to},l=0,a=null==o?void 0:o.cursor;if(a&&(i<0?a.childBefore(s.from):a.childAfter(s.to)))do{if(i<0?a.to<=s.from:a.from>=s.to){if(0==l&&n.indexOf(a.type.name)>-1&&a.from<a.to)return{start:h,end:{from:a.from,to:a.to},matched:!0};if(la(a.type,i,r))l++;else if(la(a.type,-i,r)&&(l--,0==l))return{start:h,end:a.from==a.to?void 0:{from:a.from,to:a.to},matched:!1}}}while(i<0?a.prevSibling():a.nextSibling());return{start:h,matched:!1}}function ua(t,e){return kt.create(t.ranges.map(e),t.mainIndex)}function fa(t,e){return t.update({selection:e,scrollIntoView:!0,userEvent:"select"})}function da({state:t,dispatch:e},i){let s=ua(t.selection,i);return!s.eq(t.selection)&&(e(fa(t,s)),!0)}function pa(t,e){return kt.cursor(e?t.to:t.from)}function ga(t,e){return da(t,(i=>i.empty?t.moveByChar(i,e):pa(i,e)))}const ma=t=>ga(t,t.textDirection!=Ss.LTR),va=t=>ga(t,t.textDirection==Ss.LTR);function wa(t,e){return da(t,(i=>i.empty?t.moveByGroup(i,e):pa(i,e)))}function ba(t,e,i){let s=t.state.charCategorizer(e.from);return t.moveByChar(e,i,(n=>{let r=le.Space,o=e.from,h=!1,l=!1,a=!1,c=e=>{if(h)return!1;o+=i?e.length:-e.length;let n,c=s(e);if(r==le.Space&&(r=c),r!=c)return!1;if(r==le.Word)if(e.toLowerCase()==e){if(!i&&l)return!1;a=!0}else if(a){if(i)return!1;h=!0}else{if(l&&i&&s(n=t.state.sliceDoc(o,o+1))==le.Word&&n.toLowerCase()==n)return!1;l=!0}return!0};return c(n),c}))}function ya(t,e){return da(t,(i=>i.empty?ba(t,i,e):pa(i,e)))}const xa=t=>ya(t,!0),ka=t=>ya(t,!1);function Sa(t,e){return da(t,(i=>{if(!i.empty)return pa(i,e);let s=t.moveVertically(i,e);return s.head!=i.head?s:t.moveToLineBoundary(i,e)}))}const Aa=t=>Sa(t,!1),Ca=t=>Sa(t,!0);function Ma(t,e){return da(t,(i=>i.empty?t.moveVertically(i,e,t.dom.clientHeight):pa(i,e)))}const Da=t=>Ma(t,!1),Ta=t=>Ma(t,!0);function Oa(t,e,i){let s=t.visualLineAt(e.head),n=t.moveToLineBoundary(e,i);if(n.head==e.head&&n.head!=(i?s.to:s.from)&&(n=t.moveToLineBoundary(e,i,!1)),!i&&n.head==s.from&&s.length){let i=/^\s*/.exec(t.state.sliceDoc(s.from,Math.min(s.from+100,s.to)))[0].length;i&&e.head!=s.from+i&&(n=kt.cursor(s.from+i))}return n}const Pa=t=>da(t,(e=>Oa(t,e,!0))),Ea=t=>da(t,(e=>Oa(t,e,!1)));function Ra(t,e,i){let s=!1,n=ua(t.selection,(e=>{let n=aa(t,e.head,-1)||aa(t,e.head,1)||e.head>0&&aa(t,e.head-1,1)||e.head<t.doc.length&&aa(t,e.head+1,-1);if(!n||!n.end)return e;s=!0;let r=n.start.from==e.head?n.end.to:n.end.from;return i?kt.range(e.anchor,r):kt.cursor(r)}));return!!s&&(e(fa(t,n)),!0)}const La=({state:t,dispatch:e})=>Ra(t,e,!1),Na=({state:t,dispatch:e})=>Ra(t,e,!0);function Ia(t,e){let i=ua(t.state.selection,(t=>{let i=e(t);return kt.range(t.anchor,i.head,i.goalColumn)}));return!i.eq(t.state.selection)&&(t.dispatch(fa(t.state,i)),!0)}function Ba(t,e){return Ia(t,(i=>t.moveByChar(i,e)))}const Va=t=>Ba(t,t.textDirection!=Ss.LTR),Ha=t=>Ba(t,t.textDirection==Ss.LTR);function za(t,e){return Ia(t,(i=>t.moveByGroup(i,e)))}function Fa(t,e){return Ia(t,(i=>ba(t,i,e)))}const Wa=t=>Fa(t,!0),qa=t=>Fa(t,!1);function ja(t,e){return Ia(t,(i=>t.moveVertically(i,e)))}const _a=t=>ja(t,!1),$a=t=>ja(t,!0);function Ua(t,e){return Ia(t,(i=>t.moveVertically(i,e,t.dom.clientHeight)))}const Ga=t=>Ua(t,!1),Ka=t=>Ua(t,!0),Ja=t=>Ia(t,(e=>Oa(t,e,!0))),Xa=t=>Ia(t,(e=>Oa(t,e,!1))),Ya=({state:t,dispatch:e})=>(e(fa(t,{anchor:0})),!0),Qa=({state:t,dispatch:e})=>(e(fa(t,{anchor:t.doc.length})),!0),Za=({state:t,dispatch:e})=>(e(fa(t,{anchor:t.selection.main.anchor,head:0})),!0),tc=({state:t,dispatch:e})=>(e(fa(t,{anchor:t.selection.main.anchor,head:t.doc.length})),!0);function ec({state:t,dispatch:e},i){if(t.readOnly)return!1;let s="delete.selection",n=t.changeByRange((t=>{let{from:e,to:n}=t;if(e==n){let t=i(e);t<e?s="delete.backward":t>e&&(s="delete.forward"),e=Math.min(e,t),n=Math.max(n,t)}return e==n?{range:t}:{changes:{from:e,to:n},range:kt.cursor(e)}}));return!n.changes.empty&&(e(t.update(n,{scrollIntoView:!0,userEvent:s})),!0)}function ic(t,e,i){if(t instanceof tr)for(let s of t.pluginField(os.atomicRanges))s.between(e,e,((t,s)=>{t<e&&s>e&&(e=i?s:t)}));return e}const sc=(t,e)=>ec(t,(i=>{let s,n,{state:r}=t,o=r.doc.lineAt(i);if(!e&&i>o.from&&i<o.from+200&&!/[^ \t]/.test(s=o.text.slice(0,i-o.from))){if("\t"==s[s.length-1])return i-1;let t=et(s,r.tabSize)%no(r)||no(r);for(let e=0;e<t&&" "==s[s.length-1-e];e++)i--;n=i}else n=G(o.text,i-o.from,e)+o.from,n==i&&o.number!=(e?r.doc.lines:1)&&(n+=e?1:-1);return ic(t,n,e)})),nc=t=>sc(t,!1),rc=t=>sc(t,!0),oc=(t,e)=>ec(t,(i=>{let s=i,{state:n}=t,r=n.doc.lineAt(s),o=n.charCategorizer(s);for(let t=null;;){if(s==(e?r.to:r.from)){s==i&&r.number!=(e?n.doc.lines:1)&&(s+=e?1:-1);break}let h=G(r.text,s-r.from,e)+r.from,l=r.text.slice(Math.min(s,h)-r.from,Math.max(s,h)-r.from),a=o(l);if(null!=t&&a!=t)break;" "==l&&s==i||(t=a),s=h}return ic(t,s,e)})),hc=t=>oc(t,!1),lc=t=>ec(t,(e=>{let i=t.visualLineAt(e).to;return ic(t,e<i?i:Math.min(t.state.doc.length,e+1),!0)}));function ac(t,e){let i=-1;return t.changeByRange((s=>{let n=[];for(let r=s.from;r<=s.to;){let o=t.doc.lineAt(r);o.number>i&&(s.empty||s.to>o.from)&&(e(o,n,s),i=o.number),r=o.to+1}let r=t.changes(n);return{changes:n,range:kt.range(r.mapPos(s.anchor,1),r.mapPos(s.head,1))}}))}const cc=({state:t,dispatch:e})=>!t.readOnly&&(e(t.update(ac(t,((e,i)=>{i.push({from:e.from,insert:t.facet(so)})})),{userEvent:"input.indent"})),!0),uc=({state:t,dispatch:e})=>!t.readOnly&&(e(t.update(ac(t,((e,i)=>{let s=/^\s*/.exec(e.text)[0];if(!s)return;let n=et(s,t.tabSize),r=0,o=ro(t,Math.max(0,n-no(t)));for(;r<s.length&&r<o.length&&s.charCodeAt(r)==o.charCodeAt(r);)r++;i.push({from:e.from+r,to:e.from+s.length,insert:o.slice(r)})})),{userEvent:"delete.dedent"})),!0),fc=[{key:"ArrowLeft",run:ma,shift:Va,preventDefault:!0},{key:"Mod-ArrowLeft",mac:"Alt-ArrowLeft",run:t=>wa(t,t.textDirection!=Ss.LTR),shift:t=>za(t,t.textDirection!=Ss.LTR)},{mac:"Cmd-ArrowLeft",run:Ea,shift:Xa},{key:"ArrowRight",run:va,shift:Ha,preventDefault:!0},{key:"Mod-ArrowRight",mac:"Alt-ArrowRight",run:t=>wa(t,t.textDirection==Ss.LTR),shift:t=>za(t,t.textDirection==Ss.LTR)},{mac:"Cmd-ArrowRight",run:Pa,shift:Ja},{key:"ArrowUp",run:Aa,shift:_a,preventDefault:!0},{mac:"Cmd-ArrowUp",run:Ya,shift:Za},{mac:"Ctrl-ArrowUp",run:Da,shift:Ga},{key:"ArrowDown",run:Ca,shift:$a,preventDefault:!0},{mac:"Cmd-ArrowDown",run:Qa,shift:tc},{mac:"Ctrl-ArrowDown",run:Ta,shift:Ka},{key:"PageUp",run:Da,shift:Ga},{key:"PageDown",run:Ta,shift:Ka},{key:"Home",run:Ea,shift:Xa},{key:"Mod-Home",run:Ya,shift:Za},{key:"End",run:Pa,shift:Ja},{key:"Mod-End",run:Qa,shift:tc},{key:"Enter",run:({state:t,dispatch:e})=>{if(t.readOnly)return!1;let i=t.changeByRange((({from:e,to:i})=>{let n=e==i&&function(t,e){if(/\(\)|\[\]|\{\}/.test(t.sliceDoc(e-1,e+1)))return{from:e,to:e};let i,n=_r(t).resolveInner(e),r=n.childBefore(e),o=n.childAfter(e);return r&&o&&r.to<=e&&o.from>=e&&(i=r.type.prop(s.closedBy))&&i.indexOf(o.name)>-1&&t.doc.lineAt(r.to).from==t.doc.lineAt(o.from).from?{from:r.to,to:o.from}:null}(t,e),r=new ho(t,{simulateBreak:e,simulateDoubleBreak:!!n}),o=oo(r,e);null==o&&(o=/^\s*/.exec(t.doc.lineAt(e).text)[0].length);let h=t.doc.lineAt(e);for(;i<h.to&&/\s/.test(h.text[i-h.from]);)i++;n?({from:e,to:i}=n):e>h.from&&e<h.from+100&&!/\S/.test(h.text.slice(0,e))&&(e=h.from);let l=["",ro(t,o)];return n&&l.push(ro(t,r.lineIndent(h.from,-1))),{changes:{from:e,to:i,insert:it.of(l)},range:kt.cursor(e+1+l[1].length)}}));return e(t.update(i,{scrollIntoView:!0,userEvent:"input"})),!0}},{key:"Mod-a",run:({state:t,dispatch:e})=>(e(t.update({selection:{anchor:0,head:t.doc.length},userEvent:"select"})),!0)},{key:"Backspace",run:nc,shift:nc},{key:"Delete",run:rc,shift:rc},{key:"Mod-Backspace",mac:"Alt-Backspace",run:hc},{key:"Mod-Delete",mac:"Alt-Delete",run:t=>oc(t,!0)},{mac:"Mod-Backspace",run:t=>ec(t,(e=>{let i=t.visualLineAt(e).from;return ic(t,e>i?i:Math.max(0,e-1),!1)}))},{mac:"Mod-Delete",run:lc}].concat([{key:"Ctrl-b",run:ma,shift:Va,preventDefault:!0},{key:"Ctrl-f",run:va,shift:Ha},{key:"Ctrl-p",run:Aa,shift:_a},{key:"Ctrl-n",run:Ca,shift:$a},{key:"Ctrl-a",run:t=>da(t,(e=>kt.cursor(t.visualLineAt(e.head).from,1))),shift:t=>Ia(t,(e=>kt.cursor(t.visualLineAt(e.head).from)))},{key:"Ctrl-e",run:t=>da(t,(e=>kt.cursor(t.visualLineAt(e.head).to,-1))),shift:t=>Ia(t,(e=>kt.cursor(t.visualLineAt(e.head).to)))},{key:"Ctrl-d",run:rc},{key:"Ctrl-h",run:nc},{key:"Ctrl-k",run:lc},{key:"Ctrl-Alt-h",run:hc},{key:"Ctrl-o",run:({state:t,dispatch:e})=>{if(t.readOnly)return!1;let i=t.changeByRange((t=>({changes:{from:t.from,to:t.to,insert:it.of(["",""])},range:kt.cursor(t.from)})));return e(t.update(i,{scrollIntoView:!0,userEvent:"input"})),!0}},{key:"Ctrl-t",run:({state:t,dispatch:e})=>{if(t.readOnly)return!1;let i=t.changeByRange((e=>{if(!e.empty||0==e.from||e.from==t.doc.length)return{range:e};let i=e.from,s=t.doc.lineAt(i),n=i==s.from?i-1:G(s.text,i-s.from,!1)+s.from,r=i==s.to?i+1:G(s.text,i-s.from,!0)+s.from;return{changes:{from:n,to:r,insert:t.doc.slice(i,r).append(t.doc.slice(n,i))},range:kt.cursor(r)}}));return!i.changes.empty&&(e(t.update(i,{scrollIntoView:!0,userEvent:"move.character"})),!0)}},{key:"Alt-<",run:Ya},{key:"Alt->",run:Qa},{key:"Ctrl-v",run:Ta},{key:"Alt-v",run:Da}].map((t=>({mac:t.key,run:t.run,shift:t.shift})))),dc=t=>{let e=vc(t.state);return e.line?gc(t):!!e.block&&mc(t)};function pc(t,e){return({state:i,dispatch:s})=>{let n=t(e,i.selection.ranges,i);return!!n&&(s(i.update(n)),!0)}}const gc=pc(bc,0),mc=pc(wc,0);function vc(t,e=t.selection.main.head){let i=t.languageDataAt("commentTokens",e);return i.length?i[0]:{}}function wc(t,e,i){let s=e.map((t=>vc(i,t.from).block));if(!s.every((t=>t)))return null;let n=e.map(((t,e)=>function(t,{open:e,close:i},s,n){let r,o,h=t.sliceDoc(s-50,s),l=t.sliceDoc(n,n+50),a=/\s*$/.exec(h)[0].length,c=/^\s*/.exec(l)[0].length,u=h.length-a;if(h.slice(u-e.length,u)==e&&l.slice(c,c+i.length)==i)return{open:{pos:s-a,margin:a&&1},close:{pos:n+c,margin:c&&1}};n-s<=100?r=o=t.sliceDoc(s,n):(r=t.sliceDoc(s,s+50),o=t.sliceDoc(n-50,n));let f=/^\s*/.exec(r)[0].length,d=/\s*$/.exec(o)[0].length,p=o.length-d-i.length;return r.slice(f,f+e.length)==e&&o.slice(p,p+i.length)==i?{open:{pos:s+f+e.length,margin:/\s/.test(r.charAt(f+e.length))?1:0},close:{pos:n-d-i.length,margin:/\s/.test(o.charAt(p-1))?1:0}}:null}(i,s[e],t.from,t.to)));if(2!=t&&!n.every((t=>t))){let t=0;return i.changeByRange((e=>{let{open:i,close:r}=s[t++];if(n[t])return{range:e};let o=i.length+1;return{changes:[{from:e.from,insert:i+" "},{from:e.to,insert:" "+r}],range:kt.range(e.anchor+o,e.head+o)}}))}if(1!=t&&n.some((t=>t))){let t=[];for(let e,i=0;i<n.length;i++)if(e=n[i]){let n=s[i],{open:r,close:o}=e;t.push({from:r.pos-n.open.length,to:r.pos+r.margin},{from:o.pos-o.margin,to:o.pos+n.close.length})}return{changes:t}}return null}function bc(t,e,i){let s=[],n=-1;for(let{from:t,to:r}of e){let e=s.length,o=1e9;for(let e=t;e<=r;){let h=i.doc.lineAt(e);if(h.from>n&&(t==r||r>h.from)){n=h.from;let t=vc(i,e).line;if(!t)continue;let r=/^\s*/.exec(h.text)[0].length,l=r==h.length,a=h.text.slice(r,r+t.length)==t?r:-1;r<h.text.length&&r<o&&(o=r),s.push({line:h,comment:a,token:t,indent:r,empty:l,single:!1})}e=h.to+1}if(o<1e9)for(let t=e;t<s.length;t++)s[t].indent<s[t].line.text.length&&(s[t].indent=o);s.length==e+1&&(s[e].single=!0)}if(2!=t&&s.some((t=>t.comment<0&&(!t.empty||t.single)))){let t=[];for(let{line:e,token:i,indent:n,empty:r,single:o}of s)!o&&r||t.push({from:e.from+n,insert:i+" "});let e=i.changes(t);return{changes:e,selection:i.selection.map(e,1)}}if(1!=t&&s.some((t=>t.comment>=0))){let t=[];for(let{line:e,comment:i,token:n}of s)if(i>=0){let s=e.from+i,r=s+n.length;" "==e.text[r-e.from]&&r++,t.push({from:s,to:r})}return{changes:t}}return null}class yc extends pe{compare(t){return this==t||this.constructor==t.constructor&&this.eq(t)}eq(t){return!1}}yc.prototype.elementClass="",yc.prototype.toDOM=void 0,yc.prototype.mapMode=ft.TrackBefore,yc.prototype.startSide=yc.prototype.endSide=-1,yc.prototype.point=!0;const xc=Mt.define(),kc={class:"",renderEmptyElements:!1,elementStyle:"",markers:()=>we.empty,lineMarker:()=>null,initialSpacer:null,updateSpacer:null,domEventHandlers:{}},Sc=Mt.define();function Ac(t){return[Dc(),Sc.of(Object.assign(Object.assign({},kc),t))]}const Cc=tr.baseTheme({".cm-gutters":{display:"flex",height:"100%",boxSizing:"border-box",left:0,zIndex:200},"&light .cm-gutters":{backgroundColor:"#f5f5f5",color:"#999",borderRight:"1px solid #ddd"},"&dark .cm-gutters":{backgroundColor:"#333338",color:"#ccc"},".cm-gutter":{display:"flex !important",flexDirection:"column",flexShrink:0,boxSizing:"border-box",height:"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"}}),Mc=Mt.define({combine:t=>t.some((t=>t))});function Dc(t){let e=[Tc,Cc];return t&&!1===t.fixed&&e.push(Mc.of(!0)),e}const Tc=as.fromClass(class{constructor(t){this.view=t,this.dom=document.createElement("div"),this.dom.className="cm-gutters",this.dom.setAttribute("aria-hidden","true"),this.gutters=t.state.facet(Sc).map((e=>new Rc(t,e)));for(let t of this.gutters)this.dom.appendChild(t.dom);this.fixed=!t.state.facet(Mc),this.fixed&&(this.dom.style.position="sticky"),t.scrollDOM.insertBefore(this.dom,t.contentDOM),this.syncGutters()}update(t){this.updateGutters(t)&&this.syncGutters()}syncGutters(){let t=we.iter(this.view.state.facet(xc),this.view.viewport.from),e=[],i=this.gutters.map((t=>new Ec(t,this.view.viewport)));this.view.viewportLines((s=>{let n;if(Array.isArray(s.type)){for(let t of s.type)if(t.type==Vi.Text){n=t;break}}else n=s.type==Vi.Text?s:void 0;if(n){e.length&&(e=[]),Pc(t,e,s.from);for(let t of i)t.line(this.view,n,e)}}),0);for(let t of i)t.finish();this.dom.style.minHeight=this.view.contentHeight+"px",this.view.state.facet(Mc)!=!this.fixed&&(this.fixed=!this.fixed,this.dom.style.position=this.fixed?"sticky":"")}updateGutters(t){let e=t.startState.facet(Sc),i=t.state.facet(Sc),s=t.docChanged||t.heightChanged||t.viewportChanged||!we.eq(t.startState.facet(xc),t.state.facet(xc),t.view.viewport.from,t.view.viewport.to);if(e==i)for(let e of this.gutters)e.update(t)&&(s=!0);else{s=!0;let n=[];for(let s of i){let i=e.indexOf(s);i<0?n.push(new Rc(this.view,s)):(this.gutters[i].update(t),n.push(this.gutters[i]))}for(let t of this.gutters)t.dom.remove();for(let t of n)this.dom.appendChild(t.dom);this.gutters=n}return s}destroy(){this.dom.remove()}},{provide:os.scrollMargins.from((t=>0!=t.gutters.length&&t.fixed?t.view.textDirection==Ss.LTR?{left:t.dom.offsetWidth}:{right:t.dom.offsetWidth}:null))});function Oc(t){return Array.isArray(t)?t:[t]}function Pc(t,e,i){for(;t.value&&t.from<=i;)t.from==i&&e.push(t.value),t.next()}class Ec{constructor(t,e){this.gutter=t,this.localMarkers=[],this.i=0,this.height=0,this.cursor=we.iter(t.markers,e.from)}line(t,e,i){this.localMarkers.length&&(this.localMarkers=[]),Pc(this.cursor,this.localMarkers,e.from);let s=i.length?this.localMarkers.concat(i):this.localMarkers,n=this.gutter.config.lineMarker(t,e,s);n&&s.unshift(n);let r=this.gutter;if(0==s.length&&!r.config.renderEmptyElements)return;let o=e.top-this.height;if(this.i==r.elements.length){let i=new Lc(t,e.height,o,s);r.elements.push(i),r.dom.appendChild(i.dom)}else{let i=r.elements[this.i];(function(t,e){if(t.length!=e.length)return!1;for(let i=0;i<t.length;i++)if(!t[i].compare(e[i]))return!1;return!0})(s,i.markers)&&(s=i.markers),i.update(t,e.height,o,s)}this.height=e.bottom,this.i++}finish(){let t=this.gutter;for(;t.elements.length>this.i;)t.dom.removeChild(t.elements.pop().dom)}}class Rc{constructor(t,e){this.view=t,this.config=e,this.elements=[],this.spacer=null,this.dom=document.createElement("div"),this.dom.className="cm-gutter"+(this.config.class?" "+this.config.class:"");for(let i in e.domEventHandlers)this.dom.addEventListener(i,(s=>{let n=t.visualLineAtHeight(s.clientY,t.contentDOM.getBoundingClientRect().top);e.domEventHandlers[i](t,n,s)&&s.preventDefault()}));this.markers=Oc(e.markers(t)),e.initialSpacer&&(this.spacer=new Lc(t,0,0,[e.initialSpacer(t)]),this.dom.appendChild(this.spacer.dom),this.spacer.dom.style.cssText+="visibility: hidden; pointer-events: none")}update(t){let e=this.markers;if(this.markers=Oc(this.config.markers(t.view)),this.spacer&&this.config.updateSpacer){let e=this.config.updateSpacer(this.spacer.markers[0],t);e!=this.spacer.markers[0]&&this.spacer.update(t.view,0,0,[e])}let i=t.view.viewport;return!we.eq(this.markers,e,i.from,i.to)}}class Lc{constructor(t,e,i,s){this.height=-1,this.above=0,this.dom=document.createElement("div"),this.update(t,e,i,s)}update(t,e,i,s){if(this.height!=e&&(this.dom.style.height=(this.height=e)+"px"),this.above!=i&&(this.dom.style.marginTop=(this.above=i)?i+"px":""),this.markers!=s){this.markers=s;for(let t;t=this.dom.lastChild;)t.remove();let e="cm-gutterElement";for(let i of s){i.toDOM&&this.dom.appendChild(i.toDOM(t));let s=i.elementClass;s&&(e+=" "+s)}this.dom.className=e}}}const Nc=Mt.define(),Ic=Mt.define({combine:t=>de(t,{formatNumber:String,domEventHandlers:{}},{domEventHandlers(t,e){let i=Object.assign({},t);for(let t in e){let s=i[t],n=e[t];i[t]=s?(t,e,i)=>s(t,e,i)||n(t,e,i):n}return i}})});class Bc extends yc{constructor(t){super(),this.number=t}eq(t){return this.number==t.number}toDOM(t){return document.createTextNode(this.number)}}function Vc(t,e){return t.state.facet(Ic).formatNumber(e,t.state)}const Hc=Sc.compute([Ic],(t=>({class:"cm-lineNumbers",renderEmptyElements:!1,markers:t=>t.state.facet(Nc),lineMarker:(t,e,i)=>i.some((t=>t.toDOM))?null:new Bc(Vc(t,t.state.doc.lineAt(e.from).number)),initialSpacer:t=>new Bc(Vc(t,Fc(t.state.doc.lines))),updateSpacer(t,e){let i=Vc(e.view,Fc(e.view.state.doc.lines));return i==t.number?t:new Bc(i)},domEventHandlers:t.facet(Ic).domEventHandlers})));function zc(t={}){return[Ic.of(t),Dc(),Hc]}function Fc(t){let e=9;for(;e<t;)e=10*e+9;return e}function Wc(t,e){let i=e.mapPos(t.from,1),s=e.mapPos(t.to,-1);return i>=s?void 0:{from:i,to:s}}const qc=te.define({map:Wc}),jc=te.define({map:Wc});function _c(t){let e=[];for(let{head:i}of t.state.selection.ranges)e.some((t=>t.from<=i&&t.to>=i))||e.push(t.visualLineAt(i));return e}const $c=Rt.define({create:()=>Hi.none,update(t,e){t=t.map(e.changes);for(let i of e.effects)i.is(qc)&&!Gc(t,i.value.from,i.value.to)?t=t.update({add:[tu.range(i.value.from,i.value.to)]}):i.is(jc)&&(t=t.update({filter:(t,e)=>i.value.from!=t||i.value.to!=e,filterFrom:i.value.from,filterTo:i.value.to}));if(e.selection){let i=!1,{head:s}=e.selection.main;t.between(s,s,((t,e)=>{t<s&&e>s&&(i=!0)})),i&&(t=t.update({filterFrom:s,filterTo:s,filter:(t,e)=>e<=s||t>=s}))}return t},provide:t=>tr.decorations.from(t)});function Uc(t,e,i){var s;let n=null;return null===(s=t.field($c,!1))||void 0===s||s.between(e,i,((t,e)=>{(!n||n.from>t)&&(n={from:t,to:e})})),n}function Gc(t,e,i){let s=!1;return t.between(e,e,((t,n)=>{t==e&&n==i&&(s=!0)})),s}function Kc(t,e){return t.field($c,!1)?e:e.concat(te.appendConfig.of(Zc()))}function Jc(t,e,i=!0){let s=t.state.doc.lineAt(e.from).number,n=t.state.doc.lineAt(e.to).number;return tr.announce.of(`${t.state.phrase(i?"Folded lines":"Unfolded lines")} ${s} ${t.state.phrase("to")} ${n}.`)}const Xc=[{key:"Ctrl-Shift-[",mac:"Cmd-Alt-[",run:t=>{for(let e of _c(t)){let i=So(t.state,e.from,e.to);if(i)return t.dispatch({effects:Kc(t.state,[qc.of(i),Jc(t,i)])}),!0}return!1}},{key:"Ctrl-Shift-]",mac:"Cmd-Alt-]",run:t=>{if(!t.state.field($c,!1))return!1;let e=[];for(let i of _c(t)){let s=Uc(t.state,i.from,i.to);s&&e.push(jc.of(s),Jc(t,s,!1))}return e.length&&t.dispatch({effects:e}),e.length>0}},{key:"Ctrl-Alt-[",run:t=>{let{state:e}=t,i=[];for(let s=0;s<e.doc.length;){let n=t.visualLineAt(s),r=So(e,n.from,n.to);r&&i.push(qc.of(r)),s=(r?t.visualLineAt(r.to):n).to+1}return i.length&&t.dispatch({effects:Kc(t.state,i)}),!!i.length}},{key:"Ctrl-Alt-]",run:t=>{let e=t.state.field($c,!1);if(!e||!e.size)return!1;let i=[];return e.between(0,t.state.doc.length,((t,e)=>{i.push(jc.of({from:t,to:e}))})),t.dispatch({effects:i}),!0}}],Yc={placeholderDOM:null,placeholderText:"…"},Qc=Mt.define({combine:t=>de(t,Yc)});function Zc(t){let e=[$c,nu];return t&&e.push(Qc.of(t)),e}const tu=Hi.replace({widget:new class extends Bi{ignoreEvents(){return!1}toDOM(t){let{state:e}=t,i=e.facet(Qc);if(i.placeholderDOM)return i.placeholderDOM();let s=document.createElement("span");return s.textContent=i.placeholderText,s.setAttribute("aria-label",e.phrase("folded code")),s.title=e.phrase("unfold"),s.className="cm-foldPlaceholder",s.onclick=e=>{let i=t.visualLineAt(t.posAtDOM(e.target)),s=Uc(t.state,i.from,i.to);s&&t.dispatch({effects:jc.of(s)}),e.preventDefault()},s}}}),eu={openText:"⌄",closedText:"›",markerDOM:null};class iu extends yc{constructor(t,e){super(),this.config=t,this.open=e}eq(t){return this.config==t.config&&this.open==t.open}toDOM(t){if(this.config.markerDOM)return this.config.markerDOM(this.open);let e=document.createElement("span");return e.textContent=this.open?this.config.openText:this.config.closedText,e.title=t.state.phrase(this.open?"Fold line":"Unfold line"),e}}function su(t={}){let e=Object.assign(Object.assign({},eu),t),i=new iu(e,!0),s=new iu(e,!1),n=as.fromClass(class{constructor(t){this.from=t.viewport.from,this.markers=this.buildMarkers(t)}update(t){(t.docChanged||t.viewportChanged||t.startState.facet(Zr)!=t.state.facet(Zr)||t.startState.field($c,!1)!=t.state.field($c,!1))&&(this.markers=this.buildMarkers(t.view))}buildMarkers(t){let e=new be;return t.viewportLines((n=>{let r=Uc(t.state,n.from,n.to)?s:So(t.state,n.from,n.to)?i:null;r&&e.add(n.from,n.from,r)})),e.finish()}});return[n,Ac({class:"cm-foldGutter",markers(t){var e;return(null===(e=t.plugin(n))||void 0===e?void 0:e.markers)||we.empty},initialSpacer:()=>new iu(e,!1),domEventHandlers:{click:(t,e)=>{let i=Uc(t.state,e.from,e.to);if(i)return t.dispatch({effects:jc.of(i)}),!0;let s=So(t.state,e.from,e.to);return!!s&&(t.dispatch({effects:qc.of(s)}),!0)}}}),Zc()]}const nu=tr.baseTheme({".cm-foldPlaceholder":{backgroundColor:"#eee",border:"1px solid #ddd",color:"#888",borderRadius:".2em",margin:"0 1px",padding:"0 1px",cursor:"pointer"},".cm-foldGutter .cm-gutterElement":{padding:"0 1px",cursor:"pointer"}}),ru=Yt.define(),ou=Yt.define(),hu=Mt.define(),lu=Mt.define({combine:t=>de(t,{minDepth:100,newGroupDelay:500},{minDepth:Math.max,newGroupDelay:Math.min})}),au=Rt.define({create:()=>Au.empty,update(t,e){let i=e.state.facet(lu),s=e.annotation(ru);if(s){let n=mu.fromTransaction(e),r=s.side,o=0==r?t.undone:t.done;return o=n?vu(o,o.length,i.minDepth,n):yu(o,e.startState.selection),new Au(0==r?s.rest:o,0==r?o:s.rest)}let n=e.annotation(ou);if("full"!=n&&"before"!=n||(t=t.isolate()),!1===e.annotation(ee.addToHistory))return e.changes.empty?t:t.addMapping(e.changes.desc);let r=mu.fromTransaction(e),o=e.annotation(ee.time),h=e.annotation(ee.userEvent);return r?t=t.addChanges(r,o,h,i.newGroupDelay,i.minDepth):e.selection&&(t=t.addSelection(e.startState.selection,o,h,i.newGroupDelay)),"full"!=n&&"after"!=n||(t=t.isolate()),t},toJSON:t=>({done:t.done.map((t=>t.toJSON())),undone:t.undone.map((t=>t.toJSON()))}),fromJSON:t=>new Au(t.done.map(mu.fromJSON),t.undone.map(mu.fromJSON))});function cu(t={}){return[au,lu.of(t),tr.domEventHandlers({beforeinput:(t,e)=>"historyUndo"==t.inputType?fu(e):"historyRedo"==t.inputType&&du(e)})]}function uu(t,e){return function({state:i,dispatch:s}){let n=i.field(au,!1);if(!n)return!1;let r=n.pop(t,i,e);return!!r&&(s(r),!0)}}const fu=uu(0,!1),du=uu(1,!1),pu=uu(0,!0),gu=uu(1,!0);class mu{constructor(t,e,i,s,n){this.changes=t,this.effects=e,this.mapped=i,this.startSelection=s,this.selectionsAfter=n}setSelAfter(t){return new mu(this.changes,this.effects,this.mapped,this.startSelection,t)}toJSON(){var t,e,i;return{changes:null===(t=this.changes)||void 0===t?void 0:t.toJSON(),mapped:null===(e=this.mapped)||void 0===e?void 0:e.toJSON(),startSelection:null===(i=this.startSelection)||void 0===i?void 0:i.toJSON(),selectionsAfter:this.selectionsAfter.map((t=>t.toJSON()))}}static fromJSON(t){return new mu(t.changes&&pt.fromJSON(t.changes),[],t.mapped&&dt.fromJSON(t.mapped),t.startSelection&&kt.fromJSON(t.startSelection),t.selectionsAfter.map(kt.fromJSON))}static fromTransaction(t){let e=bu;for(let i of t.startState.facet(hu)){let s=i(t);s.length&&(e=e.concat(s))}return!e.length&&t.changes.empty?null:new mu(t.changes.invert(t.startState.doc),e,void 0,t.startState.selection,bu)}static selection(t){return new mu(void 0,bu,void 0,void 0,t)}}function vu(t,e,i,s){let n=e+1>i+20?e-i-1:0,r=t.slice(n,e);return r.push(s),r}function wu(t,e){return t.length?e.length?t.concat(e):t:e}const bu=[];function yu(t,e){if(t.length){let i=t[t.length-1],s=i.selectionsAfter.slice(Math.max(0,i.selectionsAfter.length-200));return s.length&&s[s.length-1].eq(e)?t:(s.push(e),vu(t,t.length-1,1e9,i.setSelAfter(s)))}return[mu.selection([e])]}function xu(t){let e=t[t.length-1],i=t.slice();return i[t.length-1]=e.setSelAfter(e.selectionsAfter.slice(0,e.selectionsAfter.length-1)),i}function ku(t,e){if(!t.length)return t;let i=t.length,s=bu;for(;i;){let n=Su(t[i-1],e,s);if(n.changes&&!n.changes.empty||n.effects.length){let e=t.slice(0,i);return e[i-1]=n,e}e=n.mapped,i--,s=n.selectionsAfter}return s.length?[mu.selection(s)]:bu}function Su(t,e,i){let s=wu(t.selectionsAfter.length?t.selectionsAfter.map((t=>t.map(e))):bu,i);if(!t.changes)return mu.selection(s);let n=t.changes.map(e),r=e.mapDesc(t.changes,!0),o=t.mapped?t.mapped.composeDesc(r):r;return new mu(n,te.mapEffects(t.effects,e),o,t.startSelection.map(r),s)}class Au{constructor(t,e,i=0,s){this.done=t,this.undone=e,this.prevTime=i,this.prevUserEvent=s}isolate(){return this.prevTime?new Au(this.done,this.undone):this}addChanges(t,e,i,s,n){let r=this.done,o=r[r.length-1];return r=o&&o.changes&&!o.changes.empty&&t.changes&&(!o.selectionsAfter.length&&e-this.prevTime<s&&function(t,e){let i=[],s=!1;return t.iterChangedRanges(((t,e)=>i.push(t,e))),e.iterChangedRanges(((t,e,n,r)=>{for(let t=0;t<i.length;){let e=i[t++],o=i[t++];r>=e&&n<=o&&(s=!0)}})),s}(o.changes,t.changes)||"input.type.compose"==i)?vu(r,r.length-1,n,new mu(t.changes.compose(o.changes),wu(t.effects,o.effects),o.mapped,o.startSelection,bu)):vu(r,r.length,n,t),new Au(r,bu,e,i)}addSelection(t,e,i,s){let n=this.done.length?this.done[this.done.length-1].selectionsAfter:bu;return n.length>0&&e-this.prevTime<s&&i==this.prevUserEvent&&i&&/^select($|\.)/.test(i)&&(r=n[n.length-1],o=t,r.ranges.length==o.ranges.length&&0===r.ranges.filter(((t,e)=>t.empty!=o.ranges[e].empty)).length)?this:new Au(yu(this.done,t),this.undone,e,i);var r,o}addMapping(t){return new Au(ku(this.done,t),ku(this.undone,t),this.prevTime,this.prevUserEvent)}pop(t,e,i){let s=0==t?this.done:this.undone;if(0==s.length)return null;let n=s[s.length-1];if(i&&n.selectionsAfter.length)return e.update({selection:n.selectionsAfter[n.selectionsAfter.length-1],annotations:ru.of({side:t,rest:xu(s)}),userEvent:0==t?"select.undo":"select.redo"});if(n.changes){let i=1==s.length?bu:s.slice(0,s.length-1);return n.mapped&&(i=ku(i,n.mapped)),e.update({changes:n.changes,selection:n.startSelection,effects:n.effects,annotations:ru.of({side:t,rest:i}),filter:!1,userEvent:0==t?"undo":"redo"})}return null}}Au.empty=new Au(bu,bu);const Cu=[{key:"Mod-z",run:fu,preventDefault:!0},{key:"Mod-y",mac:"Mod-Shift-z",run:du,preventDefault:!0},{key:"Mod-u",run:pu,preventDefault:!0},{key:"Alt-u",mac:"Mod-Shift-u",run:gu,preventDefault:!0}],Mu="function"==typeof String.prototype.normalize?t=>t.normalize("NFKD"):t=>t;class Du{constructor(t,e,i=0,s=t.length,n){this.value={from:0,to:0},this.done=!1,this.matches=[],this.buffer="",this.bufferPos=0,this.iter=t.iterRange(i,s),this.bufferStart=i,this.normalize=n?t=>n(Mu(t)):Mu,this.query=this.normalize(e)}peek(){if(this.bufferPos==this.buffer.length){if(this.bufferStart+=this.buffer.length,this.iter.next(),this.iter.done)return-1;this.bufferPos=0,this.buffer=this.iter.value}return Q(this.buffer,this.bufferPos)}next(){for(;this.matches.length;)this.matches.pop();return this.nextOverlapping()}nextOverlapping(){for(;;){let t=this.peek();if(t<0)return this.done=!0,this;let e=Z(t),i=this.bufferStart+this.bufferPos;this.bufferPos+=tt(t);let s=this.normalize(e);for(let t=0,n=i;;t++){let r=s.charCodeAt(t),o=this.match(r,n);if(o)return this.value=o,this;if(t==s.length-1)break;n==i&&t<e.length&&e.charCodeAt(t)==r&&n++}}}match(t,e){let i=null;for(let s=0;s<this.matches.length;s+=2){let n=this.matches[s],r=!1;this.query.charCodeAt(n)==t&&(n==this.query.length-1?i={from:this.matches[s+1],to:e+1}:(this.matches[s]++,r=!0)),r||(this.matches.splice(s,2),s-=2)}return this.query.charCodeAt(0)==t&&(1==this.query.length?i={from:e,to:e+1}:this.matches.push(1,e)),i}}const Tu=({state:t,dispatch:e})=>{let{ranges:i}=t.selection;if(i.some((t=>t.from===t.to)))return(({state:t,dispatch:e})=>{let{selection:i}=t,s=kt.create(i.ranges.map((e=>t.wordAt(e.head)||kt.cursor(e.head))),i.mainIndex);return!s.eq(i)&&(e(t.update({selection:s})),!0)})({state:t,dispatch:e});let s=t.sliceDoc(i[0].from,i[0].to);if(t.selection.ranges.some((e=>t.sliceDoc(e.from,e.to)!=s)))return!1;let n=function(t,e){let{main:i,ranges:s}=t.selection,n=t.wordAt(i.head),r=n&&n.from==i.from&&n.to==i.to;for(let i=!1,n=new Du(t.doc,e,s[s.length-1].to);;){if(n.next(),!n.done){if(i&&s.some((t=>t.from==n.value.from)))continue;if(r){let e=t.wordAt(n.value.from);if(!e||e.from!=n.value.from||e.to!=n.value.to)continue}return n.value}if(i)return null;n=new Du(t.doc,e,0,Math.max(0,s[s.length-1].from-1)),i=!0}}(t,s);return!!n&&(e(t.update({selection:t.selection.addRange(kt.range(n.from,n.to),!1),scrollIntoView:!0})),!0)};class Ou{constructor(t,e,i,s,n,r,o,h,l,a=0,c){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.lookAhead=a,this.parent=c}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 Ou(t,[],e,i,i,0,[],0,s?new Pu(s,s.start):null,0,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,this.reducePos);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,o)}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){let s=this.pos;if(131072&t)this.pushState(65535&t,this.pos);else if(0==(262144&t)){let 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),this.shiftContext(e,s),e<=r.maxNode&&this.buffer.push(e,s,i,4)}else this.pos=i,this.shiftContext(e,s),e<=this.p.parser.maxNode&&this.buffer.push(e,s,i,4)}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,this.p.stream.reset(this.pos-t.length)))}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 Ou(this.p,this.stack.slice(),this.state,this.reducePos,this.pos,this.score,i,s,this.curContext,this.lookAhead,t)}recoverByDelete(t,e){let i=t<=this.p.parser.maxNode;i&&this.storeNode(t,this.pos,e,4),this.storeNode(0,this.pos,e,i?8:4),this.pos=this.reducePos=e,this.score-=190}canShift(t){for(let e=new Ru(this);;){let i=this.p.parser.stateSlot(e.state,4)||this.p.parser.hasAction(e.state,t);if(0==(65536&i))return!0;if(0==i)return!1;e.reduce(i)}}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],this.pos),n.score-=200,i.push(n)}return i}forceReduce(){let t=this.p.parser.stateSlot(this.state,5);if(0==(65536&t))return!1;let{parser:e}=this.p;if(!e.validAction(this.state,t)){let i=t>>19,s=65535&t,n=this.stack.length-3*i;if(n<0||e.getGoto(this.stack[n],s,!1)<0)return!1;this.storeNode(0,this.reducePos,this.reducePos,4,!0),this.score-=100}return 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,e){this.curContext&&this.updateContext(this.curContext.tracker.shift(this.curContext.context,t,this,this.p.stream.reset(e)))}reduceContext(t,e){this.curContext&&this.updateContext(this.curContext.tracker.reduce(this.curContext.context,t,this,this.p.stream.reset(e)))}emitContext(){let t=this.buffer.length-1;(t<0||-3!=this.buffer[t])&&this.buffer.push(this.curContext.hash,this.reducePos,this.reducePos,-3)}emitLookAhead(){let t=this.buffer.length-1;(t<0||-4!=this.buffer[t])&&this.buffer.push(this.lookAhead,this.reducePos,this.reducePos,-4)}updateContext(t){if(t!=this.curContext.context){let e=new Pu(this.curContext.tracker,t);e.hash!=this.curContext.hash&&this.emitContext(),this.curContext=e}}setLookAhead(t){t>this.lookAhead&&(this.emitLookAhead(),this.lookAhead=t)}close(){this.curContext&&this.curContext.tracker.strict&&this.emitContext(),this.lookAhead>0&&this.emitLookAhead()}}class Pu{constructor(t,e){this.tracker=t,this.context=e,this.hash=t.strict?t.hash(e):0}}var Eu;!function(t){t[t.Insert=200]="Insert",t[t.Delete=190]="Delete",t[t.Reduce=100]="Reduce",t[t.MaxNext=4]="MaxNext",t[t.MaxInsertStackDepth=300]="MaxInsertStackDepth",t[t.DampenInsertStackDepth=120]="DampenInsertStackDepth"}(Eu||(Eu={}));class Ru{constructor(t){this.start=t,this.state=t.state,this.stack=t.stack,this.base=this.stack.length}reduce(t){let e=65535&t,i=t>>19;0==i?(this.stack==this.start.stack&&(this.stack=this.stack.slice()),this.stack.push(this.state,0,0),this.base+=3):this.base-=3*(i-1);let s=this.start.p.parser.getGoto(this.stack[this.base-3],e,!0);this.state=s}}class Lu{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,e=t.bufferBase+t.buffer.length){return new Lu(t,e,e-t.bufferBase)}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 Lu(this.stack,this.pos,this.index)}}class Nu{constructor(){this.start=-1,this.value=-1,this.end=-1,this.extended=-1,this.lookAhead=0,this.mask=0,this.context=0}}const Iu=new Nu;class Bu{constructor(t,e){this.input=t,this.ranges=e,this.chunk="",this.chunkOff=0,this.chunk2="",this.chunk2Pos=0,this.next=-1,this.token=Iu,this.rangeIndex=0,this.pos=this.chunkPos=e[0].from,this.range=e[0],this.end=e[e.length-1].to,this.readNext()}resolveOffset(t,e){let i=this.range,s=this.rangeIndex,n=this.pos+t;for(;n<i.from;){if(!s)return null;let t=this.ranges[--s];n-=i.from-t.to,i=t}for(;e<0?n>i.to:n>=i.to;){if(s==this.ranges.length-1)return null;let t=this.ranges[++s];n+=t.from-i.to,i=t}return n}peek(t){let e,i,s=this.chunkOff+t;if(s>=0&&s<this.chunk.length)e=this.pos+t,i=this.chunk.charCodeAt(s);else{let s=this.resolveOffset(t,1);if(null==s)return-1;if(e=s,e>=this.chunk2Pos&&e<this.chunk2Pos+this.chunk2.length)i=this.chunk2.charCodeAt(e-this.chunk2Pos);else{let t=this.rangeIndex,s=this.range;for(;s.to<=e;)s=this.ranges[++t];this.chunk2=this.input.chunk(this.chunk2Pos=e),e+this.chunk2.length>s.to&&(this.chunk2=this.chunk2.slice(0,s.to-e)),i=this.chunk2.charCodeAt(0)}}return e>this.token.lookAhead&&(this.token.lookAhead=e),i}acceptToken(t,e=0){let i=e?this.resolveOffset(e,-1):this.pos;if(null==i||i<this.token.start)throw new RangeError("Token end out of bounds");this.token.value=t,this.token.end=i}getChunk(){if(this.pos>=this.chunk2Pos&&this.pos<this.chunk2Pos+this.chunk2.length){let{chunk:t,chunkPos:e}=this;this.chunk=this.chunk2,this.chunkPos=this.chunk2Pos,this.chunk2=t,this.chunk2Pos=e,this.chunkOff=this.pos-this.chunkPos}else{this.chunk2=this.chunk,this.chunk2Pos=this.chunkPos;let t=this.input.chunk(this.pos),e=this.pos+t.length;this.chunk=e>this.range.to?t.slice(0,this.range.to-this.pos):t,this.chunkPos=this.pos,this.chunkOff=0}}readNext(){return this.chunkOff>=this.chunk.length&&(this.getChunk(),this.chunkOff==this.chunk.length)?this.next=-1:this.next=this.chunk.charCodeAt(this.chunkOff)}advance(t=1){for(this.chunkOff+=t;this.pos+t>=this.range.to;){if(this.rangeIndex==this.ranges.length-1)return this.setDone();t-=this.range.to-this.pos,this.range=this.ranges[++this.rangeIndex],this.pos=this.range.from}return this.pos+=t,this.pos>this.token.lookAhead&&(this.token.lookAhead=this.pos),this.readNext()}setDone(){return this.pos=this.chunkPos=this.end,this.range=this.ranges[this.rangeIndex=this.ranges.length-1],this.chunk="",this.next=-1}reset(t,e){if(e?(this.token=e,e.start=e.lookAhead=t,e.value=e.extended=-1):this.token=Iu,this.pos!=t){if(this.pos=t,t==this.end)return this.setDone(),this;for(;t<this.range.from;)this.range=this.ranges[--this.rangeIndex];for(;t>=this.range.to;)this.range=this.ranges[++this.rangeIndex];t>=this.chunkPos&&t<this.chunkPos+this.chunk.length?this.chunkOff=t-this.chunkPos:(this.chunk="",this.chunkOff=0),this.readNext()}return this}read(t,e){if(t>=this.chunkPos&&e<=this.chunkPos+this.chunk.length)return this.chunk.slice(t-this.chunkPos,e-this.chunkPos);if(t>=this.range.from&&e<=this.range.to)return this.input.read(t,e);let i="";for(let s of this.ranges){if(s.from>=e)break;s.to>t&&(i+=this.input.read(Math.max(s.from,t),Math.min(s.to,e)))}return i}}class Vu{constructor(t,e){this.data=t,this.id=e}token(t,e){!function(t,e,i,s){let n=0,r=1<<s,{parser:o}=i.p,{dialect:h}=o;t:for(;0!=(r&t[n]);){let i=t[n+1];for(let s=n+3;s<i;s+=2)if((t[s+1]&r)>0){let i=t[s];if(h.allows(i)&&(-1==e.token.value||e.token.value==i||o.overrides(i,e.token.value))){e.acceptToken(i);break}}for(let s=e.next,r=0,o=t[n+2];r<o;){let h=r+o>>1,l=i+h+(h<<1),a=t[l],c=t[l+1];if(s<a)o=h;else{if(!(s>=c)){n=t[l+2],e.advance();continue t}r=h+1}}break}}(this.data,t,e,this.id)}}Vu.prototype.contextual=Vu.prototype.fallback=Vu.prototype.extend=!1;class Hu{constructor(t,e={}){this.token=t,this.contextual=!!e.contextual,this.fallback=!!e.fallback,this.extend=!!e.extend}}function zu(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}const Fu="undefined"!=typeof process&&/\bparse\b/.test(process.env.LOG);let Wu=null;var qu,ju;function _u(t,e,i){let s=t.fullCursor();for(s.moveTo(e);;)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-25)):Math.min(t.length,Math.max(s.from+1,e+25));if(i<0?s.prevSibling():s.nextSibling())break;if(!s.parent())return i<0?0:t.length}}!function(t){t[t.Margin=25]="Margin"}(qu||(qu={}));class $u{constructor(t,e){this.fragments=t,this.nodeSet=e,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?_u(t.tree,t.from+t.offset,1)-t.offset:t.from,this.safeTo=t.openEnd?_u(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],n=this.index[e];if(n==i.children.length){this.trees.pop(),this.start.pop(),this.index.pop();continue}let r=i.children[n],o=this.start[e]+i.positions[n];if(o>t)return this.nextStart=o,null;if(r instanceof a){if(o==t){if(o<this.safeFrom)return null;let t=o+r.length;if(t<=this.safeTo){let e=r.prop(s.lookAhead);if(!e||t+e<this.fragment.to)return r}}this.index[e]++,o+r.length>=Math.max(this.safeFrom,t)&&(this.trees.push(r),this.start.push(o),this.index.push(0))}else this.index[e]++,this.nextStart=o+r.length}}}class Uu{constructor(t,e){this.stream=e,this.tokens=[],this.mainToken=null,this.actions=[],this.tokens=t.tokenizers.map((t=>new Nu))}getActions(t){let e=0,i=null,{parser:s}=t.p,{tokenizers:n}=s,r=s.stateSlot(t.state,3),o=t.curContext?t.curContext.hash:0,h=0;for(let s=0;s<n.length;s++){if(0==(1<<s&r))continue;let l=n[s],a=this.tokens[s];if((!i||l.fallback)&&((l.contextual||a.start!=t.pos||a.mask!=r||a.context!=o)&&(this.updateCachedToken(a,l,t),a.mask=r,a.context=o),a.lookAhead>a.end+25&&(h=Math.max(a.lookAhead,h)),0!=a.value)){let s=e;if(a.extended>-1&&(e=this.addActions(t,a.extended,a.end,e)),e=this.addActions(t,a.value,a.end,e),!l.extend&&(i=a,e>s))break}}for(;this.actions.length>e;)this.actions.pop();return h&&t.setLookAhead(h),i||t.pos!=this.stream.end||(i=new Nu,i.value=t.p.parser.eofTerm,i.start=i.end=t.pos,e=this.addActions(t,i.value,i.end,e)),this.mainToken=i,this.actions}getMainToken(t){if(this.mainToken)return this.mainToken;let e=new Nu,{pos:i,p:s}=t;return e.start=i,e.end=Math.min(i+1,s.stream.end),e.value=i==s.stream.end?s.parser.eofTerm:0,e}updateCachedToken(t,e,i){if(e.token(this.stream.reset(i.pos,t),i),t.value>-1){let{parser:e}=i.p;for(let s=0;s<e.specialized.length;s++)if(e.specialized[s]==t.value){let n=e.specializers[s](this.stream.read(t.start,t.end),i);if(n>=0&&i.p.parser.dialect.allows(n>>1)){0==(1&n)?t.value=n>>1:t.extended=n>>1;break}}}else t.value=0,t.end=Math.min(i.p.stream.end,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(Zu(o,h+1),e,i,s));break}h=Zu(o,h+2)}o[h]==e&&(s=this.putAction(Zu(o,h+1),e,i,s))}return s}}!function(t){t[t.Distance=5]="Distance",t[t.MaxRemainingPerStep=3]="MaxRemainingPerStep",t[t.MinBufferLengthPrune=200]="MinBufferLengthPrune",t[t.ForceReduceLimit=10]="ForceReduceLimit"}(ju||(ju={}));class Gu{constructor(t,e,i,s){this.parser=t,this.input=e,this.ranges=s,this.recovering=0,this.nextStackID=9812,this.minStackPos=0,this.reused=[],this.stoppedAt=null,this.stream=new Bu(e,s),this.tokens=new Uu(t,this.stream),this.topTerm=t.top[1];let{from:n}=s[0];this.stacks=[Ou.start(this,t.top[0],n)],this.fragments=i.length&&this.stream.end-n>4*t.bufferLength?new $u(i,t.nodeSet):null}get parsedPos(){return this.minStackPos}advance(){let t,e,i=this.stacks,s=this.minStackPos,n=this.stacks=[];for(let r=0;r<i.length;r++){let o=i[r];for(;;){if(this.tokens.mainToken=null,o.pos>s)n.push(o);else{if(this.advanceStack(o,n,i))continue;{t||(t=[],e=[]),t.push(o);let i=this.tokens.getMainToken(o);e.push(i.value,i.end)}}break}}if(!n.length){let e=t&&function(t){let e=null;for(let i of t){let t=i.p.stoppedAt;(i.pos==i.p.stream.end||null!=t&&i.pos>t)&&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 Fu&&t&&console.log("Stuck with token "+(this.tokens.mainToken?this.parser.getName(this.tokens.mainToken.value):"none")),new SyntaxError("No parse at "+s);this.recovering||(this.recovering=5)}if(this.recovering&&t){let i=this.runRecovery(t,e,n);if(i)return this.stackToTree(i.forceAll())}if(this.recovering){let t=1==this.recovering?1:3*this.recovering;if(n.length>t)for(n.sort(((t,e)=>e.score-t.score));n.length>t;)n.pop();n.some((t=>t.reducePos>s))&&this.recovering--}else if(n.length>1)t:for(let t=0;t<n.length-1;t++){let e=n[t];for(let i=t+1;i<n.length;i++){let s=n[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)){n.splice(t--,1);continue t}n.splice(i--,1)}}}this.minStackPos=n[0].pos;for(let t=1;t<n.length;t++)n[t].pos<this.minStackPos&&(this.minStackPos=n[t].pos);return null}stopAt(t){if(null!=this.stoppedAt&&this.stoppedAt<t)throw new RangeError("Can't move stoppedAt forward");this.stoppedAt=t}advanceStack(t,e,i){let n=t.pos,{parser:r}=this,o=Fu?this.stackID(t)+" -> ":"";if(null!=this.stoppedAt&&n>this.stoppedAt)return t.forceReduce()?t:null;if(this.fragments){let e=t.curContext&&t.curContext.tracker.strict,i=e?t.curContext.hash:0;for(let h=this.fragments.nodeAt(n);h;){let n=this.parser.nodeSet.types[h.type.id]==h.type?r.getGoto(t.state,h.type.id):-1;if(n>-1&&h.length&&(!e||(h.prop(s.contextHash)||0)==i))return t.useNode(h,n),Fu&&console.log(o+this.stackID(t)+` (via reuse of ${r.getName(h.type.id)})`),!0;if(!(h instanceof a)||0==h.children.length||h.positions[0]>0)break;let l=h.children[0];if(!(l instanceof a&&0==h.positions[0]))break;h=l}}let h=r.stateSlot(t.state,4);if(h>0)return t.reduce(h),Fu&&console.log(o+this.stackID(t)+` (via always-reduce ${r.getName(65535&h)})`),!0;let l=this.tokens.getActions(t);for(let s=0;s<l.length;){let h=l[s++],a=l[s++],c=l[s++],u=s==l.length||!i,f=u?t:t.split();if(f.apply(h,a,c),Fu&&console.log(o+this.stackID(f)+` (via ${0==(65536&h)?"shift":`reduce of ${r.getName(65535&h)}`} for ${r.getName(a)} @ ${n}${f==t?"":", split"})`),u)return!0;f.pos>n?e.push(f):i.push(f)}return!1}advanceFully(t,e){let i=t.pos;for(;;){if(!this.advanceStack(t,null,null))return!1;if(t.pos>i)return Ku(t,e),!0}}runRecovery(t,e,i){let s=null,n=!1;for(let r=0;r<t.length;r++){let o=t[r],h=e[r<<1],l=e[1+(r<<1)],a=Fu?this.stackID(o)+" -> ":"";if(o.deadEnd){if(n)continue;if(n=!0,o.restart(),Fu&&console.log(a+this.stackID(o)+" (restarted)"),this.advanceFully(o,i))continue}let c=o.split(),u=a;for(let t=0;c.forceReduce()&&t<10;t++){if(Fu&&console.log(u+this.stackID(c)+" (via force-reduce)"),this.advanceFully(c,i))break;Fu&&(u=this.stackID(c)+" -> ")}for(let t of o.recoverByInsert(h))Fu&&console.log(a+this.stackID(t)+" (via recover-insert)"),this.advanceFully(t,i);this.stream.end>o.pos?(l==o.pos&&(l++,h=0),o.recoverByDelete(h,l),Fu&&console.log(a+this.stackID(o)+` (via recover-delete ${this.parser.getName(h)})`),Ku(o,i)):(!s||s.score<o.score)&&(s=o)}return s}stackToTree(t){return t.close(),a.build({buffer:Lu.create(t),nodeSet:this.parser.nodeSet,topID:this.topTerm,maxBufferLength:this.parser.bufferLength,reused:this.reused,start:this.ranges[0].from,length:t.pos-this.ranges[0].from,minRepeatType:this.parser.minRepeatTerm})}stackID(t){let e=(Wu||(Wu=new WeakMap)).get(t);return e||Wu.set(t,e=String.fromCodePoint(this.nextStackID++)),e+t}}function Ku(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 Ju{constructor(t,e,i){this.source=t,this.flags=e,this.disabled=i}allows(t){return!this.disabled||0==this.disabled[t]}}const Xu=t=>t;class Yu{constructor(t){this.start=t.start,this.shift=t.shift||Xu,this.reduce=t.reduce||Xu,this.reuse=t.reuse||Xu,this.hash=t.hash||(()=>0),this.strict=!1!==t.strict}}class Qu extends A{constructor(e){if(super(),this.wrappers=[],13!=e.version)throw new RangeError(`Parser version (${e.version}) doesn't match runtime version (13)`);let i=e.nodeNames.split(" ");this.minRepeatTerm=i.length;for(let t=0;t<e.repeatNodeCount;t++)i.push("");let s=Object.keys(e.topRules).map((t=>e.topRules[t][1])),n=[];for(let t=0;t<i.length;t++)n.push([]);function r(t,e,i){n[t].push([e,e.deserialize(String(i))])}if(e.nodeProps)for(let t of e.nodeProps){let e=t[0];for(let i=1;i<t.length;){let s=t[i++];if(s>=0)r(s,e,t[i++]);else{let n=t[i+-s];for(let o=-s;o>0;o--)r(t[i++],e,n);i++}}}this.nodeSet=new h(i.map(((t,i)=>o.define({name:i>=this.minRepeatTerm?void 0:t,id:i,props:n[i],top:s.indexOf(i)>-1,error:0==i,skipped:e.skippedNodes&&e.skippedNodes.indexOf(i)>-1})))),this.strict=!1,this.bufferLength=t;let l=zu(e.tokenData);if(this.context=e.context,this.specialized=new Uint16Array(e.specialized?e.specialized.length:0),this.specializers=[],e.specialized)for(let t=0;t<e.specialized.length;t++)this.specialized[t]=e.specialized[t].term,this.specializers[t]=e.specialized[t].get;this.states=zu(e.states,Uint32Array),this.data=zu(e.stateData),this.goto=zu(e.goto),this.maxTerm=e.maxTerm,this.tokenizers=e.tokenizers.map((t=>"number"==typeof t?new Vu(l,t):t)),this.topRules=e.topRules,this.dialects=e.dialects||{},this.dynamicPrecedences=e.dynamicPrecedences||null,this.tokenPrecTable=e.tokenPrec,this.termNames=e.termNames||null,this.maxNode=this.nodeSet.types.length-1,this.dialect=this.parseDialect(),this.top=this.topRules[Object.keys(this.topRules)[0]]}createParse(t,e,i){let s=new Gu(this,t,e,i);for(let n of this.wrappers)s=n(s,t,e,i);return s}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 Zu(i,r+2);break}n=i[r=Zu(i,r+2)]}if(n==e||0==n)return Zu(i,r+1)}return 0}stateSlot(t,e){return this.states[6*t+e]}stateFlag(t,e){return(this.stateSlot(t,0)&e)>0}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=Zu(this.data,i+2)}if(e==Zu(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=Zu(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=tf(this.data,this.tokenPrecTable,e);return i<0||tf(this.data,this.tokenPrecTable,t)<i}configure(t){let e=Object.assign(Object.create(Qu.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.contextTracker&&(e.context=t.contextTracker),t.dialect&&(e.dialect=this.parseDialect(t.dialect)),null!=t.strict&&(e.strict=t.strict),t.wrap&&(e.wrappers=e.wrappers.concat(t.wrap)),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 topNode(){return this.nodeSet.types[this.top[1]]}dynamicPrecedence(t){let e=this.dynamicPrecedences;return null==e?0:e[t]||0}parseDialect(t){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 new Ju(t,i,s)}static deserialize(t){return new Qu(t)}}function Zu(t,e){return t[e]|t[e+1]<<16}function tf(t,e,i){for(let s,n=e;65535!=(s=t[n]);n++)if(s==i)return n-e;return-1}async function ef(){return lh.define((await import("./legacy.js").then((function(t){return t.c}))).clojure)}async function sf(){return lh.define((await import("./legacy.js").then((function(t){return t.a}))).coffeeScript)}function nf(){return import("./cpp.js")}function rf(){return import("./css.js")}function of(){return import("./html.js")}function hf(){return import("./java.js")}function lf(){return import("./javascript.js")}function af(){return import("./json.js")}function cf(){return import("./markdown.js")}function uf(){return import("./php.js")}function ff(){return import("./python.js")}async function df(){return lh.define((await import("./legacy.js").then((function(t){return t.s}))).shell)}function pf(){return import("./wast.js")}function gf(){return import("./xml.js")}export{La as $,ef as A,sf as B,Yu as C,nf as D,Hu as E,rf as F,of as G,hf as H,lf as I,af as J,cf as K,Qu as L,uf as M,s as N,ff as O,A as P,df as Q,pf as R,gf as S,a as T,cl as U,Il as V,Nl as W,Lh as X,Hl as Y,_l as Z,Kl as _,jr as a,ka as a0,xa as a1,uc as a2,cc as a3,Na as a4,qa as a5,Wa as a6,fc as a7,dc as a8,Zc as a9,zt as aA,fe as aB,Mt as aC,xt as aD,te as aE,Zt as aF,Rt as aG,ee as aH,lh as aI,oh as aJ,ct as aK,it as aL,Rh as aM,Dh as aN,kh as aO,Hi as aP,gr as aQ,Er as aR,Cr as aS,Hr as aT,Br as aU,as as aV,vs as aW,Bi as aX,w as aY,W as aZ,su as aa,Xc as ab,Ac as ac,yc as ad,Dc as ae,zc as af,Io as ag,Bo as ah,Co as ai,cu as aj,Cu as ak,du as al,gu as am,fu as an,pu as ao,bo as ap,so as aq,ha as ar,ge as as,we as at,be as au,Tu as av,Yt as aw,Qt as ax,dt as ay,pt as az,xo as b,wo as c,ko as d,to as e,vo as f,_r as g,tr as h,lo as i,kt as j,Tl as k,go as l,Bh as m,Ih as n,o,M as p,h as q,zr as r,Oo as s,nh as t,Wr as u,Vt as v,cr as w,Fr as x,eo as y,Gr as z};
|