From fc6f528b762825d19cb4edada9e0f658933220a6 Mon Sep 17 00:00:00 2001 From: Louis Date: Mon, 4 Sep 2023 15:54:22 +0200 Subject: [PATCH] backup 04/09/2023 15h54 --- .obsidian/app.json | 3 + .obsidian/appearance.json | 3 + .obsidian/community-plugins.json | 5 + .obsidian/core-plugins-migration.json | 30 + .obsidian/core-plugins.json | 21 + .obsidian/graph.json | 22 + .obsidian/hotkeys.json | 1 + .../main.js | 38 + .../manifest.json | 11 + .../styles.css | 1 + .obsidian/plugins/obsidian-git/data.json | 55 + .obsidian/plugins/obsidian-git/main.js | 44242 ++++++++++++++++ .obsidian/plugins/obsidian-git/manifest.json | 9 + .obsidian/plugins/obsidian-git/styles.css | 512 + .../obsidian-table-generator/data.json | 7 + .../plugins/obsidian-table-generator/main.js | 2461 + .../obsidian-table-generator/manifest.json | 15 + .../obsidian-table-generator/styles.css | 44 + .obsidian/workspace-mobile.json | 138 + .obsidian/workspace.json | 176 + Algo/Séminaire/Chapter 1 - CAML basics.md | 150 + Algo/Séminaire/Chapter 2 - Functions.md | 68 + Algo/Séminaire/Introduction.md | 67 + Mathématiques/Séminaire/Logics/Logics.md | 71 + .../Logics/Pasted image 20230904093718.png | Bin 0 -> 12797 bytes .../Logics/Pasted image 20230904094156.png | Bin 0 -> 47644 bytes .../Logics/Pasted image 20230904094230.png | Bin 0 -> 46726 bytes .../Logics/Pasted image 20230904095003.png | Bin 0 -> 50520 bytes .../Logics/Pasted image 20230904100125.png | Bin 0 -> 58047 bytes .../Logics/Pasted image 20230904100934.png | Bin 0 -> 72215 bytes .../Logics/Pasted image 20230904101446.png | Bin 0 -> 75624 bytes .../Logics/Pasted image 20230904101453.png | Bin 0 -> 75624 bytes .../Logics/Pasted image 20230904101721.png | Bin 0 -> 81019 bytes .../Logics/Pasted image 20230904102817.png | Bin 0 -> 37144 bytes README.md | 1 + 35 files changed, 48151 insertions(+) create mode 100644 .obsidian/app.json create mode 100644 .obsidian/appearance.json create mode 100644 .obsidian/community-plugins.json create mode 100644 .obsidian/core-plugins-migration.json create mode 100644 .obsidian/core-plugins.json create mode 100644 .obsidian/graph.json create mode 100644 .obsidian/hotkeys.json create mode 100644 .obsidian/plugins/antidote-grammar-checker-integration/main.js create mode 100644 .obsidian/plugins/antidote-grammar-checker-integration/manifest.json create mode 100644 .obsidian/plugins/antidote-grammar-checker-integration/styles.css create mode 100644 .obsidian/plugins/obsidian-git/data.json create mode 100644 .obsidian/plugins/obsidian-git/main.js create mode 100644 .obsidian/plugins/obsidian-git/manifest.json create mode 100644 .obsidian/plugins/obsidian-git/styles.css create mode 100644 .obsidian/plugins/obsidian-table-generator/data.json create mode 100644 .obsidian/plugins/obsidian-table-generator/main.js create mode 100644 .obsidian/plugins/obsidian-table-generator/manifest.json create mode 100644 .obsidian/plugins/obsidian-table-generator/styles.css create mode 100644 .obsidian/workspace-mobile.json create mode 100644 .obsidian/workspace.json create mode 100644 Algo/Séminaire/Chapter 1 - CAML basics.md create mode 100644 Algo/Séminaire/Chapter 2 - Functions.md create mode 100644 Algo/Séminaire/Introduction.md create mode 100644 Mathématiques/Séminaire/Logics/Logics.md create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904093718.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904094156.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904094230.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904095003.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904100125.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904100934.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904101446.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904101453.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904101721.png create mode 100644 Mathématiques/Séminaire/Logics/Pasted image 20230904102817.png create mode 100644 README.md diff --git a/.obsidian/app.json b/.obsidian/app.json new file mode 100644 index 0000000..bd06f49 --- /dev/null +++ b/.obsidian/app.json @@ -0,0 +1,3 @@ +{ + "mobilePullAction": "editor:save-file" +} \ No newline at end of file diff --git a/.obsidian/appearance.json b/.obsidian/appearance.json new file mode 100644 index 0000000..c8c365d --- /dev/null +++ b/.obsidian/appearance.json @@ -0,0 +1,3 @@ +{ + "accentColor": "" +} \ No newline at end of file diff --git a/.obsidian/community-plugins.json b/.obsidian/community-plugins.json new file mode 100644 index 0000000..64b6e5c --- /dev/null +++ b/.obsidian/community-plugins.json @@ -0,0 +1,5 @@ +[ + "antidote-grammar-checker-integration", + "obsidian-table-generator", + "obsidian-git" +] \ No newline at end of file diff --git a/.obsidian/core-plugins-migration.json b/.obsidian/core-plugins-migration.json new file mode 100644 index 0000000..1d8661f --- /dev/null +++ b/.obsidian/core-plugins-migration.json @@ -0,0 +1,30 @@ +{ + "file-explorer": true, + "global-search": true, + "switcher": true, + "graph": true, + "backlink": true, + "canvas": true, + "outgoing-link": true, + "tag-pane": true, + "page-preview": true, + "daily-notes": true, + "templates": true, + "note-composer": true, + "command-palette": true, + "slash-command": false, + "editor-status": true, + "bookmarks": true, + "markdown-importer": false, + "zk-prefixer": false, + "random-note": false, + "outline": true, + "word-count": true, + "slides": false, + "audio-recorder": false, + "workspaces": false, + "file-recovery": true, + "publish": false, + "sync": false, + "properties": true +} \ No newline at end of file diff --git a/.obsidian/core-plugins.json b/.obsidian/core-plugins.json new file mode 100644 index 0000000..56b44a5 --- /dev/null +++ b/.obsidian/core-plugins.json @@ -0,0 +1,21 @@ +[ + "file-explorer", + "global-search", + "switcher", + "graph", + "backlink", + "canvas", + "outgoing-link", + "tag-pane", + "properties", + "page-preview", + "daily-notes", + "templates", + "note-composer", + "command-palette", + "editor-status", + "bookmarks", + "outline", + "word-count", + "file-recovery" +] \ No newline at end of file diff --git a/.obsidian/graph.json b/.obsidian/graph.json new file mode 100644 index 0000000..e21a18d --- /dev/null +++ b/.obsidian/graph.json @@ -0,0 +1,22 @@ +{ + "collapse-filter": true, + "search": "", + "showTags": false, + "showAttachments": false, + "hideUnresolved": false, + "showOrphans": true, + "collapse-color-groups": true, + "colorGroups": [], + "collapse-display": true, + "showArrow": false, + "textFadeMultiplier": 0, + "nodeSizeMultiplier": 1, + "lineSizeMultiplier": 1, + "collapse-forces": true, + "centerStrength": 0.518713248970312, + "repelStrength": 10, + "linkStrength": 1, + "linkDistance": 250, + "scale": 1, + "close": false +} \ No newline at end of file diff --git a/.obsidian/hotkeys.json b/.obsidian/hotkeys.json new file mode 100644 index 0000000..9e26dfe --- /dev/null +++ b/.obsidian/hotkeys.json @@ -0,0 +1 @@ +{} \ No newline at end of file diff --git a/.obsidian/plugins/antidote-grammar-checker-integration/main.js b/.obsidian/plugins/antidote-grammar-checker-integration/main.js new file mode 100644 index 0000000..3b89ccc --- /dev/null +++ b/.obsidian/plugins/antidote-grammar-checker-integration/main.js @@ -0,0 +1,38 @@ +var R2=Object.create;var ar=Object.defineProperty;var B2=Object.getOwnPropertyDescriptor;var k2=Object.getOwnPropertyNames;var F2=Object.getPrototypeOf,U2=Object.prototype.hasOwnProperty;var xn=t=>ar(t,"__esModule",{value:!0});var _=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),j2=(t,e)=>{xn(t);for(var r in e)ar(t,r,{get:e[r],enumerable:!0})},G2=(t,e,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of k2(e))!U2.call(t,i)&&i!=="default"&&ar(t,i,{get:()=>e[i],enumerable:!(r=B2(e,i))||r.enumerable});return t},ae=t=>G2(xn(ar(t!=null?R2(F2(t)):{},"default",t&&t.__esModule&&"default"in t?{get:()=>t.default,enumerable:!0}:{value:t,enumerable:!0})),t);var _e=(t,e,r)=>new Promise((i,n)=>{var s=l=>{try{f(r.next(l))}catch(p){n(p)}},h=l=>{try{f(r.throw(l))}catch(p){n(p)}},f=l=>l.done?i(l.value):Promise.resolve(l.value).then(s,h);f((r=r.apply(t,e)).next())});var Le=_((IC,On)=>{var H2=Array.isArray;On.exports=H2});var Yr=_((NC,Tn)=>{var z2=typeof global=="object"&&global&&global.Object===Object&&global;Tn.exports=z2});var je=_((PC,An)=>{var W2=Yr(),$2=typeof self=="object"&&self&&self.Object===Object&&self,Z2=W2||$2||Function("return this")();An.exports=Z2});var gt=_((LC,qn)=>{var V2=je(),K2=V2.Symbol;qn.exports=K2});var Ln=_((MC,Pn)=>{var In=gt(),Nn=Object.prototype,J2=Nn.hasOwnProperty,Y2=Nn.toString,Dt=In?In.toStringTag:void 0;function X2(t){var e=J2.call(t,Dt),r=t[Dt];try{t[Dt]=void 0;var i=!0}catch(s){}var n=Y2.call(t);return i&&(e?t[Dt]=r:delete t[Dt]),n}Pn.exports=X2});var Dn=_((DC,Mn)=>{var Q2=Object.prototype,ef=Q2.toString;function tf(t){return ef.call(t)}Mn.exports=tf});var mt=_((RC,kn)=>{var Rn=gt(),rf=Ln(),nf=Dn(),sf="[object Null]",of="[object Undefined]",Bn=Rn?Rn.toStringTag:void 0;function af(t){return t==null?t===void 0?of:sf:Bn&&Bn in Object(t)?rf(t):nf(t)}kn.exports=af});var yt=_((BC,Fn)=>{function uf(t){return t!=null&&typeof t=="object"}Fn.exports=uf});var Ct=_((kC,Un)=>{var lf=mt(),cf=yt(),ff="[object Symbol]";function hf(t){return typeof t=="symbol"||cf(t)&&lf(t)==ff}Un.exports=hf});var lr=_((FC,jn)=>{var pf=Le(),df=Ct(),gf=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,mf=/^\w*$/;function yf(t,e){if(pf(t))return!1;var r=typeof t;return r=="number"||r=="symbol"||r=="boolean"||t==null||df(t)?!0:mf.test(t)||!gf.test(t)||e!=null&&t in Object(e)}jn.exports=yf});var Je=_((UC,Gn)=>{function Cf(t){var e=typeof t;return t!=null&&(e=="object"||e=="function")}Gn.exports=Cf});var Xr=_((jC,Hn)=>{var _f=mt(),vf=Je(),bf="[object AsyncFunction]",xf="[object Function]",Sf="[object GeneratorFunction]",wf="[object Proxy]";function Ef(t){if(!vf(t))return!1;var e=_f(t);return e==xf||e==Sf||e==bf||e==wf}Hn.exports=Ef});var Wn=_((GC,zn)=>{var Of=je(),Tf=Of["__core-js_shared__"];zn.exports=Tf});var Vn=_((HC,Zn)=>{var Qr=Wn(),$n=function(){var t=/[^.]+$/.exec(Qr&&Qr.keys&&Qr.keys.IE_PROTO||"");return t?"Symbol(src)_1."+t:""}();function Af(t){return!!$n&&$n in t}Zn.exports=Af});var ei=_((zC,Kn)=>{var qf=Function.prototype,If=qf.toString;function Nf(t){if(t!=null){try{return If.call(t)}catch(e){}try{return t+""}catch(e){}}return""}Kn.exports=Nf});var Yn=_((WC,Jn)=>{var Pf=Xr(),Lf=Vn(),Mf=Je(),Df=ei(),Rf=/[\\^$.*+?()[\]{}|]/g,Bf=/^\[object .+?Constructor\]$/,kf=Function.prototype,Ff=Object.prototype,Uf=kf.toString,jf=Ff.hasOwnProperty,Gf=RegExp("^"+Uf.call(jf).replace(Rf,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$");function Hf(t){if(!Mf(t)||Lf(t))return!1;var e=Pf(t)?Gf:Bf;return e.test(Df(t))}Jn.exports=Hf});var Qn=_(($C,Xn)=>{function zf(t,e){return t==null?void 0:t[e]}Xn.exports=zf});var Ye=_((ZC,es)=>{var Wf=Yn(),$f=Qn();function Zf(t,e){var r=$f(t,e);return Wf(r)?r:void 0}es.exports=Zf});var Rt=_((VC,ts)=>{var Vf=Ye(),Kf=Vf(Object,"create");ts.exports=Kf});var ns=_((KC,is)=>{var rs=Rt();function Jf(){this.__data__=rs?rs(null):{},this.size=0}is.exports=Jf});var os=_((JC,ss)=>{function Yf(t){var e=this.has(t)&&delete this.__data__[t];return this.size-=e?1:0,e}ss.exports=Yf});var us=_((YC,as)=>{var Xf=Rt(),Qf="__lodash_hash_undefined__",e4=Object.prototype,t4=e4.hasOwnProperty;function r4(t){var e=this.__data__;if(Xf){var r=e[t];return r===Qf?void 0:r}return t4.call(e,t)?e[t]:void 0}as.exports=r4});var cs=_((XC,ls)=>{var i4=Rt(),n4=Object.prototype,s4=n4.hasOwnProperty;function o4(t){var e=this.__data__;return i4?e[t]!==void 0:s4.call(e,t)}ls.exports=o4});var hs=_((QC,fs)=>{var a4=Rt(),u4="__lodash_hash_undefined__";function l4(t,e){var r=this.__data__;return this.size+=this.has(t)?0:1,r[t]=a4&&e===void 0?u4:e,this}fs.exports=l4});var ds=_((e_,ps)=>{var c4=ns(),f4=os(),h4=us(),p4=cs(),d4=hs();function _t(t){var e=-1,r=t==null?0:t.length;for(this.clear();++e{function g4(){this.__data__=[],this.size=0}gs.exports=g4});var Bt=_((r_,ys)=>{function m4(t,e){return t===e||t!==t&&e!==e}ys.exports=m4});var kt=_((i_,Cs)=>{var y4=Bt();function C4(t,e){for(var r=t.length;r--;)if(y4(t[r][0],e))return r;return-1}Cs.exports=C4});var vs=_((n_,_s)=>{var _4=kt(),v4=Array.prototype,b4=v4.splice;function x4(t){var e=this.__data__,r=_4(e,t);if(r<0)return!1;var i=e.length-1;return r==i?e.pop():b4.call(e,r,1),--this.size,!0}_s.exports=x4});var xs=_((s_,bs)=>{var S4=kt();function w4(t){var e=this.__data__,r=S4(e,t);return r<0?void 0:e[r][1]}bs.exports=w4});var ws=_((o_,Ss)=>{var E4=kt();function O4(t){return E4(this.__data__,t)>-1}Ss.exports=O4});var Os=_((a_,Es)=>{var T4=kt();function A4(t,e){var r=this.__data__,i=T4(r,t);return i<0?(++this.size,r.push([t,e])):r[i][1]=e,this}Es.exports=A4});var Ft=_((u_,Ts)=>{var q4=ms(),I4=vs(),N4=xs(),P4=ws(),L4=Os();function vt(t){var e=-1,r=t==null?0:t.length;for(this.clear();++e{var M4=Ye(),D4=je(),R4=M4(D4,"Map");As.exports=R4});var Ns=_((c_,Is)=>{var qs=ds(),B4=Ft(),k4=cr();function F4(){this.size=0,this.__data__={hash:new qs,map:new(k4||B4),string:new qs}}Is.exports=F4});var Ls=_((f_,Ps)=>{function U4(t){var e=typeof t;return e=="string"||e=="number"||e=="symbol"||e=="boolean"?t!=="__proto__":t===null}Ps.exports=U4});var Ut=_((h_,Ms)=>{var j4=Ls();function G4(t,e){var r=t.__data__;return j4(e)?r[typeof e=="string"?"string":"hash"]:r.map}Ms.exports=G4});var Rs=_((p_,Ds)=>{var H4=Ut();function z4(t){var e=H4(this,t).delete(t);return this.size-=e?1:0,e}Ds.exports=z4});var ks=_((d_,Bs)=>{var W4=Ut();function $4(t){return W4(this,t).get(t)}Bs.exports=$4});var Us=_((g_,Fs)=>{var Z4=Ut();function V4(t){return Z4(this,t).has(t)}Fs.exports=V4});var Gs=_((m_,js)=>{var K4=Ut();function J4(t,e){var r=K4(this,t),i=r.size;return r.set(t,e),this.size+=r.size==i?0:1,this}js.exports=J4});var fr=_((y_,Hs)=>{var Y4=Ns(),X4=Rs(),Q4=ks(),e3=Us(),t3=Gs();function bt(t){var e=-1,r=t==null?0:t.length;for(this.clear();++e{var zs=fr(),r3="Expected a function";function ti(t,e){if(typeof t!="function"||e!=null&&typeof e!="function")throw new TypeError(r3);var r=function(){var i=arguments,n=e?e.apply(this,i):i[0],s=r.cache;if(s.has(n))return s.get(n);var h=t.apply(this,i);return r.cache=s.set(n,h)||s,h};return r.cache=new(ti.Cache||zs),r}ti.Cache=zs;Ws.exports=ti});var Vs=_((__,Zs)=>{var i3=$s(),n3=500;function s3(t){var e=i3(t,function(i){return r.size===n3&&r.clear(),i}),r=e.cache;return e}Zs.exports=s3});var Js=_((v_,Ks)=>{var o3=Vs(),a3=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,u3=/\\(\\)?/g,l3=o3(function(t){var e=[];return t.charCodeAt(0)===46&&e.push(""),t.replace(a3,function(r,i,n,s){e.push(n?s.replace(u3,"$1"):i||r)}),e});Ks.exports=l3});var ri=_((b_,Ys)=>{function c3(t,e){for(var r=-1,i=t==null?0:t.length,n=Array(i);++r{var Xs=gt(),f3=ri(),h3=Le(),p3=Ct(),d3=1/0,Qs=Xs?Xs.prototype:void 0,eo=Qs?Qs.toString:void 0;function to(t){if(typeof t=="string")return t;if(h3(t))return f3(t,to)+"";if(p3(t))return eo?eo.call(t):"";var e=t+"";return e=="0"&&1/t==-d3?"-0":e}ro.exports=to});var ot=_((S_,no)=>{var g3=io();function m3(t){return t==null?"":g3(t)}no.exports=m3});var hr=_((w_,so)=>{var y3=Le(),C3=lr(),_3=Js(),v3=ot();function b3(t,e){return y3(t)?t:C3(t,e)?[t]:_3(v3(t))}so.exports=b3});var xt=_((E_,oo)=>{var x3=Ct(),S3=1/0;function w3(t){if(typeof t=="string"||x3(t))return t;var e=t+"";return e=="0"&&1/t==-S3?"-0":e}oo.exports=w3});var pr=_((O_,ao)=>{var E3=hr(),O3=xt();function T3(t,e){e=E3(e,t);for(var r=0,i=e.length;t!=null&&r{var A3=pr();function q3(t,e,r){var i=t==null?void 0:A3(t,e);return i===void 0?r:i}uo.exports=q3});var co=_((A_,lo)=>{var I3=Object.prototype,N3=I3.hasOwnProperty;function P3(t,e){return t!=null&&N3.call(t,e)}lo.exports=P3});var ho=_((q_,fo)=>{var L3=mt(),M3=yt(),D3="[object Arguments]";function R3(t){return M3(t)&&L3(t)==D3}fo.exports=R3});var gr=_((I_,mo)=>{var po=ho(),B3=yt(),go=Object.prototype,k3=go.hasOwnProperty,F3=go.propertyIsEnumerable,U3=po(function(){return arguments}())?po:function(t){return B3(t)&&k3.call(t,"callee")&&!F3.call(t,"callee")};mo.exports=U3});var jt=_((N_,yo)=>{var j3=9007199254740991,G3=/^(?:0|[1-9]\d*)$/;function H3(t,e){var r=typeof t;return e=e??j3,!!e&&(r=="number"||r!="symbol"&&G3.test(t))&&t>-1&&t%1==0&&t{var z3=9007199254740991;function W3(t){return typeof t=="number"&&t>-1&&t%1==0&&t<=z3}Co.exports=W3});var ii=_((L_,_o)=>{var $3=hr(),Z3=gr(),V3=Le(),K3=jt(),J3=mr(),Y3=xt();function X3(t,e,r){e=$3(e,t);for(var i=-1,n=e.length,s=!1;++i{var Q3=co(),e8=ii();function t8(t,e){return t!=null&&e8(t,e,Q3)}vo.exports=t8});var ni=_((D_,xo)=>{var r8=Ye(),i8=function(){try{var t=r8(Object,"defineProperty");return t({},"",{}),t}catch(e){}}();xo.exports=i8});var Eo=_((R_,wo)=>{var So=ni();function n8(t,e,r){e=="__proto__"&&So?So(t,e,{configurable:!0,enumerable:!0,value:r,writable:!0}):t[e]=r}wo.exports=n8});var si=_((B_,Oo)=>{var s8=Eo(),o8=Bt(),a8=Object.prototype,u8=a8.hasOwnProperty;function l8(t,e,r){var i=t[e];(!(u8.call(t,e)&&o8(i,r))||r===void 0&&!(e in t))&&s8(t,e,r)}Oo.exports=l8});var qo=_((k_,Ao)=>{var c8=si(),f8=hr(),h8=jt(),To=Je(),p8=xt();function d8(t,e,r,i){if(!To(t))return t;e=f8(e,t);for(var n=-1,s=e.length,h=s-1,f=t;f!=null&&++n{var g8=qo();function m8(t,e,r){return t==null?t:g8(t,e,r)}Io.exports=m8});var Lo=_((U_,Po)=>{var y8="__lodash_hash_undefined__";function C8(t){return this.__data__.set(t,y8),this}Po.exports=C8});var Do=_((j_,Mo)=>{function _8(t){return this.__data__.has(t)}Mo.exports=_8});var oi=_((G_,Ro)=>{var v8=fr(),b8=Lo(),x8=Do();function yr(t){var e=-1,r=t==null?0:t.length;for(this.__data__=new v8;++e{function S8(t,e,r,i){for(var n=t.length,s=r+(i?1:-1);i?s--:++s{function w8(t){return t!==t}Fo.exports=w8});var Go=_((W_,jo)=>{function E8(t,e,r){for(var i=r-1,n=t.length;++i{var O8=ko(),T8=Uo(),A8=Go();function q8(t,e,r){return e===e?A8(t,e,r):O8(t,T8,r)}Ho.exports=q8});var $o=_((Z_,Wo)=>{var I8=zo();function N8(t,e){var r=t==null?0:t.length;return!!r&&I8(t,e,0)>-1}Wo.exports=N8});var Vo=_((V_,Zo)=>{function P8(t,e,r){for(var i=-1,n=t==null?0:t.length;++i{function L8(t,e){return t.has(e)}Ko.exports=L8});var ui=_((J_,Jo)=>{var M8=Ye(),D8=je(),R8=M8(D8,"Set");Jo.exports=R8});var Xo=_((Y_,Yo)=>{function B8(){}Yo.exports=B8});var Cr=_((X_,Qo)=>{function k8(t){var e=-1,r=Array(t.size);return t.forEach(function(i){r[++e]=i}),r}Qo.exports=k8});var ta=_((Q_,ea)=>{var li=ui(),F8=Xo(),U8=Cr(),j8=1/0,G8=li&&1/U8(new li([,-0]))[1]==j8?function(t){return new li(t)}:F8;ea.exports=G8});var ia=_((ev,ra)=>{var H8=oi(),z8=$o(),W8=Vo(),$8=ai(),Z8=ta(),V8=Cr(),K8=200;function J8(t,e,r){var i=-1,n=z8,s=t.length,h=!0,f=[],l=f;if(r)h=!1,n=W8;else if(s>=K8){var p=e?null:Z8(t);if(p)return V8(p);h=!1,n=$8,l=new H8}else l=e?[]:f;e:for(;++i{var Y8=ia();function X8(t){return t&&t.length?Y8(t):[]}na.exports=X8});var ua=_((nv,aa)=>{function t7(t,e,r){var i=-1,n=t.length;e<0&&(e=-e>n?0:n+e),r=r>n?n:r,r<0&&(r+=n),n=e>r?0:r-e>>>0,e>>>=0;for(var s=Array(n);++i{var r7=ua();function i7(t,e,r){var i=t.length;return r=r===void 0?i:r,!e&&r>=i?t:r7(t,e,r)}la.exports=i7});var ci=_((ov,fa)=>{var n7="\\ud800-\\udfff",s7="\\u0300-\\u036f",o7="\\ufe20-\\ufe2f",a7="\\u20d0-\\u20ff",u7=s7+o7+a7,l7="\\ufe0e\\ufe0f",c7="\\u200d",f7=RegExp("["+c7+n7+u7+l7+"]");function h7(t){return f7.test(t)}fa.exports=h7});var pa=_((av,ha)=>{function p7(t){return t.split("")}ha.exports=p7});var ba=_((uv,va)=>{var da="\\ud800-\\udfff",d7="\\u0300-\\u036f",g7="\\ufe20-\\ufe2f",m7="\\u20d0-\\u20ff",y7=d7+g7+m7,C7="\\ufe0e\\ufe0f",_7="["+da+"]",fi="["+y7+"]",hi="\\ud83c[\\udffb-\\udfff]",v7="(?:"+fi+"|"+hi+")",ga="[^"+da+"]",ma="(?:\\ud83c[\\udde6-\\uddff]){2}",ya="[\\ud800-\\udbff][\\udc00-\\udfff]",b7="\\u200d",Ca=v7+"?",_a="["+C7+"]?",x7="(?:"+b7+"(?:"+[ga,ma,ya].join("|")+")"+_a+Ca+")*",S7=_a+Ca+x7,w7="(?:"+[ga+fi+"?",fi,ma,ya,_7].join("|")+")",E7=RegExp(hi+"(?="+hi+")|"+w7+S7,"g");function O7(t){return t.match(E7)||[]}va.exports=O7});var Sa=_((lv,xa)=>{var T7=pa(),A7=ci(),q7=ba();function I7(t){return A7(t)?q7(t):T7(t)}xa.exports=I7});var Ea=_((cv,wa)=>{var N7=ca(),P7=ci(),L7=Sa(),M7=ot();function D7(t){return function(e){e=M7(e);var r=P7(e)?L7(e):void 0,i=r?r[0]:e.charAt(0),n=r?N7(r,1).join(""):e.slice(1);return i[t]()+n}}wa.exports=D7});var Ta=_((fv,Oa)=>{var R7=Ea(),B7=R7("toUpperCase");Oa.exports=B7});var qa=_((hv,Aa)=>{var k7=ot(),F7=Ta();function U7(t){return F7(k7(t).toLowerCase())}Aa.exports=U7});var Na=_((pv,Ia)=>{function j7(t,e,r,i){var n=-1,s=t==null?0:t.length;for(i&&s&&(r=t[++n]);++n{function G7(t){return function(e){return t==null?void 0:t[e]}}Pa.exports=G7});var Da=_((gv,Ma)=>{var H7=La(),z7={\u00C0:"A",\u00C1:"A",\u00C2:"A",\u00C3:"A",\u00C4:"A",\u00C5:"A",\u00E0:"a",\u00E1:"a",\u00E2:"a",\u00E3:"a",\u00E4:"a",\u00E5:"a",\u00C7:"C",\u00E7:"c",\u00D0:"D",\u00F0:"d",\u00C8:"E",\u00C9:"E",\u00CA:"E",\u00CB:"E",\u00E8:"e",\u00E9:"e",\u00EA:"e",\u00EB:"e",\u00CC:"I",\u00CD:"I",\u00CE:"I",\u00CF:"I",\u00EC:"i",\u00ED:"i",\u00EE:"i",\u00EF:"i",\u00D1:"N",\u00F1:"n",\u00D2:"O",\u00D3:"O",\u00D4:"O",\u00D5:"O",\u00D6:"O",\u00D8:"O",\u00F2:"o",\u00F3:"o",\u00F4:"o",\u00F5:"o",\u00F6:"o",\u00F8:"o",\u00D9:"U",\u00DA:"U",\u00DB:"U",\u00DC:"U",\u00F9:"u",\u00FA:"u",\u00FB:"u",\u00FC:"u",\u00DD:"Y",\u00FD:"y",\u00FF:"y",\u00C6:"Ae",\u00E6:"ae",\u00DE:"Th",\u00FE:"th",\u00DF:"ss",\u0100:"A",\u0102:"A",\u0104:"A",\u0101:"a",\u0103:"a",\u0105:"a",\u0106:"C",\u0108:"C",\u010A:"C",\u010C:"C",\u0107:"c",\u0109:"c",\u010B:"c",\u010D:"c",\u010E:"D",\u0110:"D",\u010F:"d",\u0111:"d",\u0112:"E",\u0114:"E",\u0116:"E",\u0118:"E",\u011A:"E",\u0113:"e",\u0115:"e",\u0117:"e",\u0119:"e",\u011B:"e",\u011C:"G",\u011E:"G",\u0120:"G",\u0122:"G",\u011D:"g",\u011F:"g",\u0121:"g",\u0123:"g",\u0124:"H",\u0126:"H",\u0125:"h",\u0127:"h",\u0128:"I",\u012A:"I",\u012C:"I",\u012E:"I",\u0130:"I",\u0129:"i",\u012B:"i",\u012D:"i",\u012F:"i",\u0131:"i",\u0134:"J",\u0135:"j",\u0136:"K",\u0137:"k",\u0138:"k",\u0139:"L",\u013B:"L",\u013D:"L",\u013F:"L",\u0141:"L",\u013A:"l",\u013C:"l",\u013E:"l",\u0140:"l",\u0142:"l",\u0143:"N",\u0145:"N",\u0147:"N",\u014A:"N",\u0144:"n",\u0146:"n",\u0148:"n",\u014B:"n",\u014C:"O",\u014E:"O",\u0150:"O",\u014D:"o",\u014F:"o",\u0151:"o",\u0154:"R",\u0156:"R",\u0158:"R",\u0155:"r",\u0157:"r",\u0159:"r",\u015A:"S",\u015C:"S",\u015E:"S",\u0160:"S",\u015B:"s",\u015D:"s",\u015F:"s",\u0161:"s",\u0162:"T",\u0164:"T",\u0166:"T",\u0163:"t",\u0165:"t",\u0167:"t",\u0168:"U",\u016A:"U",\u016C:"U",\u016E:"U",\u0170:"U",\u0172:"U",\u0169:"u",\u016B:"u",\u016D:"u",\u016F:"u",\u0171:"u",\u0173:"u",\u0174:"W",\u0175:"w",\u0176:"Y",\u0177:"y",\u0178:"Y",\u0179:"Z",\u017B:"Z",\u017D:"Z",\u017A:"z",\u017C:"z",\u017E:"z",\u0132:"IJ",\u0133:"ij",\u0152:"Oe",\u0153:"oe",\u0149:"'n",\u017F:"s"},W7=H7(z7);Ma.exports=W7});var Ba=_((mv,Ra)=>{var $7=Da(),Z7=ot(),V7=/[\xc0-\xd6\xd8-\xf6\xf8-\xff\u0100-\u017f]/g,K7="\\u0300-\\u036f",J7="\\ufe20-\\ufe2f",Y7="\\u20d0-\\u20ff",X7=K7+J7+Y7,Q7="["+X7+"]",e6=RegExp(Q7,"g");function t6(t){return t=Z7(t),t&&t.replace(V7,$7).replace(e6,"")}Ra.exports=t6});var Fa=_((yv,ka)=>{var r6=/[^\x00-\x2f\x3a-\x40\x5b-\x60\x7b-\x7f]+/g;function i6(t){return t.match(r6)||[]}ka.exports=i6});var ja=_((Cv,Ua)=>{var n6=/[a-z][A-Z]|[A-Z]{2}[a-z]|[0-9][a-zA-Z]|[a-zA-Z][0-9]|[^a-zA-Z0-9 ]/;function s6(t){return n6.test(t)}Ua.exports=s6});var o1=_((_v,s1)=>{var Ga="\\ud800-\\udfff",o6="\\u0300-\\u036f",a6="\\ufe20-\\ufe2f",u6="\\u20d0-\\u20ff",l6=o6+a6+u6,Ha="\\u2700-\\u27bf",za="a-z\\xdf-\\xf6\\xf8-\\xff",c6="\\xac\\xb1\\xd7\\xf7",f6="\\x00-\\x2f\\x3a-\\x40\\x5b-\\x60\\x7b-\\xbf",h6="\\u2000-\\u206f",p6=" \\t\\x0b\\f\\xa0\\ufeff\\n\\r\\u2028\\u2029\\u1680\\u180e\\u2000\\u2001\\u2002\\u2003\\u2004\\u2005\\u2006\\u2007\\u2008\\u2009\\u200a\\u202f\\u205f\\u3000",Wa="A-Z\\xc0-\\xd6\\xd8-\\xde",d6="\\ufe0e\\ufe0f",$a=c6+f6+h6+p6,Za="['\u2019]",Va="["+$a+"]",g6="["+l6+"]",Ka="\\d+",m6="["+Ha+"]",Ja="["+za+"]",Ya="[^"+Ga+$a+Ka+Ha+za+Wa+"]",y6="\\ud83c[\\udffb-\\udfff]",C6="(?:"+g6+"|"+y6+")",_6="[^"+Ga+"]",Xa="(?:\\ud83c[\\udde6-\\uddff]){2}",Qa="[\\ud800-\\udbff][\\udc00-\\udfff]",St="["+Wa+"]",v6="\\u200d",e1="(?:"+Ja+"|"+Ya+")",b6="(?:"+St+"|"+Ya+")",t1="(?:"+Za+"(?:d|ll|m|re|s|t|ve))?",r1="(?:"+Za+"(?:D|LL|M|RE|S|T|VE))?",i1=C6+"?",n1="["+d6+"]?",x6="(?:"+v6+"(?:"+[_6,Xa,Qa].join("|")+")"+n1+i1+")*",S6="\\d*(?:1st|2nd|3rd|(?![123])\\dth)(?=\\b|[A-Z_])",w6="\\d*(?:1ST|2ND|3RD|(?![123])\\dTH)(?=\\b|[a-z_])",E6=n1+i1+x6,O6="(?:"+[m6,Xa,Qa].join("|")+")"+E6,T6=RegExp([St+"?"+Ja+"+"+t1+"(?="+[Va,St,"$"].join("|")+")",b6+"+"+r1+"(?="+[Va,St+e1,"$"].join("|")+")",St+"?"+e1+"+"+t1,St+"+"+r1,w6,S6,Ka,O6].join("|"),"g");function A6(t){return t.match(T6)||[]}s1.exports=A6});var u1=_((vv,a1)=>{var q6=Fa(),I6=ja(),N6=ot(),P6=o1();function L6(t,e,r){return t=N6(t),e=r?void 0:e,e===void 0?I6(t)?P6(t):q6(t):t.match(e)||[]}a1.exports=L6});var c1=_((bv,l1)=>{var M6=Na(),D6=Ba(),R6=u1(),B6="['\u2019]",k6=RegExp(B6,"g");function F6(t){return function(e){return M6(R6(D6(e).replace(k6,"")),t,"")}}l1.exports=F6});var h1=_((xv,f1)=>{var U6=qa(),j6=c1(),G6=j6(function(t,e,r){return e=e.toLowerCase(),t+(r?U6(e):e)});f1.exports=G6});var y1=_((Iv,m1)=>{var W6=9007199254740991,$6=Math.floor;function Z6(t,e){var r="";if(!t||e<1||e>W6)return r;do e%2&&(r+=t),e=$6(e/2),e&&(t+=t);while(e);return r}m1.exports=Z6});var Ht=_((Nv,C1)=>{var V6=Xr(),K6=mr();function J6(t){return t!=null&&K6(t.length)&&!V6(t)}C1.exports=J6});var wr=_((Pv,_1)=>{var Y6=Bt(),X6=Ht(),Q6=jt(),e9=Je();function t9(t,e,r){if(!e9(r))return!1;var i=typeof e;return(i=="number"?X6(r)&&Q6(e,r.length):i=="string"&&e in r)?Y6(r[e],t):!1}_1.exports=t9});var b1=_((Lv,v1)=>{var r9=/\s/;function i9(t){for(var e=t.length;e--&&r9.test(t.charAt(e)););return e}v1.exports=i9});var S1=_((Mv,x1)=>{var n9=b1(),s9=/^\s+/;function o9(t){return t&&t.slice(0,n9(t)+1).replace(s9,"")}x1.exports=o9});var T1=_((Dv,O1)=>{var a9=S1(),w1=Je(),u9=Ct(),E1=0/0,l9=/^[-+]0x[0-9a-f]+$/i,c9=/^0b[01]+$/i,f9=/^0o[0-7]+$/i,h9=parseInt;function p9(t){if(typeof t=="number")return t;if(u9(t))return E1;if(w1(t)){var e=typeof t.valueOf=="function"?t.valueOf():t;t=w1(e)?e+"":e}if(typeof t!="string")return t===0?t:+t;t=a9(t);var r=c9.test(t);return r||f9.test(t)?h9(t.slice(2),r?2:8):l9.test(t)?E1:+t}O1.exports=p9});var yi=_((Rv,q1)=>{var d9=T1(),A1=1/0,g9=17976931348623157e292;function m9(t){if(!t)return t===0?t:0;if(t=d9(t),t===A1||t===-A1){var e=t<0?-1:1;return e*g9}return t===t?t:0}q1.exports=m9});var N1=_((Bv,I1)=>{var y9=yi();function C9(t){var e=y9(t),r=e%1;return e===e?r?e-r:e:0}I1.exports=C9});var L1=_((kv,P1)=>{var _9=y1(),v9=wr(),b9=N1(),x9=ot();function S9(t,e,r){return(r?v9(t,e,r):e===void 0)?e=1:e=b9(e),_9(x9(t),e)}P1.exports=S9});var _i=_((tb,R1)=>{function A9(t,e){for(var r=-1,i=e.length,n=t.length;++r{var B1=gt(),q9=gr(),I9=Le(),k1=B1?B1.isConcatSpreadable:void 0;function N9(t){return I9(t)||q9(t)||!!(k1&&t&&t[k1])}F1.exports=N9});var vi=_((ib,G1)=>{var P9=_i(),L9=U1();function j1(t,e,r,i,n){var s=-1,h=t.length;for(r||(r=L9),n||(n=[]);++s0&&r(f)?e>1?j1(f,e-1,r,i,n):P9(n,f):i||(n[n.length]=f)}return n}G1.exports=j1});var z1=_((nb,H1)=>{var M9=Ft();function D9(){this.__data__=new M9,this.size=0}H1.exports=D9});var $1=_((sb,W1)=>{function R9(t){var e=this.__data__,r=e.delete(t);return this.size=e.size,r}W1.exports=R9});var V1=_((ob,Z1)=>{function B9(t){return this.__data__.get(t)}Z1.exports=B9});var J1=_((ab,K1)=>{function k9(t){return this.__data__.has(t)}K1.exports=k9});var X1=_((ub,Y1)=>{var F9=Ft(),U9=cr(),j9=fr(),G9=200;function H9(t,e){var r=this.__data__;if(r instanceof F9){var i=r.__data__;if(!U9||i.length{var z9=Ft(),W9=z1(),$9=$1(),Z9=V1(),V9=J1(),K9=X1();function Et(t){var e=this.__data__=new z9(t);this.size=e.size}Et.prototype.clear=W9;Et.prototype.delete=$9;Et.prototype.get=Z9;Et.prototype.has=V9;Et.prototype.set=K9;Q1.exports=Et});var tu=_((cb,eu)=>{function J9(t,e){for(var r=-1,i=t==null?0:t.length;++r{var Y9=oi(),X9=tu(),Q9=ai(),e5=1,t5=2;function r5(t,e,r,i,n,s){var h=r&e5,f=t.length,l=e.length;if(f!=l&&!(h&&l>f))return!1;var p=s.get(t),g=s.get(e);if(p&&g)return p==e&&g==t;var x=-1,D=!0,B=r&t5?new Y9:void 0;for(s.set(t,e),s.set(e,t);++x{var i5=je(),n5=i5.Uint8Array;iu.exports=n5});var ou=_((pb,su)=>{function s5(t){var e=-1,r=Array(t.size);return t.forEach(function(i,n){r[++e]=[n,i]}),r}su.exports=s5});var fu=_((db,cu)=>{var au=gt(),uu=nu(),o5=Bt(),a5=xi(),u5=ou(),l5=Cr(),c5=1,f5=2,h5="[object Boolean]",p5="[object Date]",d5="[object Error]",g5="[object Map]",m5="[object Number]",y5="[object RegExp]",C5="[object Set]",_5="[object String]",v5="[object Symbol]",b5="[object ArrayBuffer]",x5="[object DataView]",lu=au?au.prototype:void 0,Si=lu?lu.valueOf:void 0;function S5(t,e,r,i,n,s,h){switch(r){case x5:if(t.byteLength!=e.byteLength||t.byteOffset!=e.byteOffset)return!1;t=t.buffer,e=e.buffer;case b5:return!(t.byteLength!=e.byteLength||!s(new uu(t),new uu(e)));case h5:case p5:case m5:return o5(+t,+e);case d5:return t.name==e.name&&t.message==e.message;case y5:case _5:return t==e+"";case g5:var f=u5;case C5:var l=i&c5;if(f||(f=l5),t.size!=e.size&&!l)return!1;var p=h.get(t);if(p)return p==e;i|=f5,h.set(t,e);var g=a5(f(t),f(e),i,n,s,h);return h.delete(t),g;case v5:if(Si)return Si.call(t)==Si.call(e)}return!1}cu.exports=S5});var pu=_((gb,hu)=>{var w5=_i(),E5=Le();function O5(t,e,r){var i=e(t);return E5(t)?i:w5(i,r(t))}hu.exports=O5});var gu=_((mb,du)=>{function T5(t,e){for(var r=-1,i=t==null?0:t.length,n=0,s=[];++r{function A5(){return[]}mu.exports=A5});var vu=_((Cb,_u)=>{var q5=gu(),I5=yu(),N5=Object.prototype,P5=N5.propertyIsEnumerable,Cu=Object.getOwnPropertySymbols,L5=Cu?function(t){return t==null?[]:(t=Object(t),q5(Cu(t),function(e){return P5.call(t,e)}))}:I5;_u.exports=L5});var xu=_((_b,bu)=>{function M5(t,e){for(var r=-1,i=Array(t);++r{function D5(){return!1}Su.exports=D5});var wi=_((Wt,Ot)=>{var R5=je(),B5=wu(),Eu=typeof Wt=="object"&&Wt&&!Wt.nodeType&&Wt,Ou=Eu&&typeof Ot=="object"&&Ot&&!Ot.nodeType&&Ot,k5=Ou&&Ou.exports===Eu,Tu=k5?R5.Buffer:void 0,F5=Tu?Tu.isBuffer:void 0,U5=F5||B5;Ot.exports=U5});var qu=_((bb,Au)=>{var j5=mt(),G5=mr(),H5=yt(),z5="[object Arguments]",W5="[object Array]",$5="[object Boolean]",Z5="[object Date]",V5="[object Error]",K5="[object Function]",J5="[object Map]",Y5="[object Number]",X5="[object Object]",Q5="[object RegExp]",eh="[object Set]",th="[object String]",rh="[object WeakMap]",ih="[object ArrayBuffer]",nh="[object DataView]",sh="[object Float32Array]",oh="[object Float64Array]",ah="[object Int8Array]",uh="[object Int16Array]",lh="[object Int32Array]",ch="[object Uint8Array]",fh="[object Uint8ClampedArray]",hh="[object Uint16Array]",ph="[object Uint32Array]",se={};se[sh]=se[oh]=se[ah]=se[uh]=se[lh]=se[ch]=se[fh]=se[hh]=se[ph]=!0;se[z5]=se[W5]=se[ih]=se[$5]=se[nh]=se[Z5]=se[V5]=se[K5]=se[J5]=se[Y5]=se[X5]=se[Q5]=se[eh]=se[th]=se[rh]=!1;function dh(t){return H5(t)&&G5(t.length)&&!!se[j5(t)]}Au.exports=dh});var Ei=_((xb,Iu)=>{function gh(t){return function(e){return t(e)}}Iu.exports=gh});var Pu=_((Zt,Tt)=>{var mh=Yr(),Nu=typeof Zt=="object"&&Zt&&!Zt.nodeType&&Zt,$t=Nu&&typeof Tt=="object"&&Tt&&!Tt.nodeType&&Tt,yh=$t&&$t.exports===Nu,Oi=yh&&mh.process,Ch=function(){try{var t=$t&&$t.require&&$t.require("util").types;return t||Oi&&Oi.binding&&Oi.binding("util")}catch(e){}}();Tt.exports=Ch});var Ti=_((Sb,Du)=>{var _h=qu(),vh=Ei(),Lu=Pu(),Mu=Lu&&Lu.isTypedArray,bh=Mu?vh(Mu):_h;Du.exports=bh});var Bu=_((wb,Ru)=>{var xh=xu(),Sh=gr(),wh=Le(),Eh=wi(),Oh=jt(),Th=Ti(),Ah=Object.prototype,qh=Ah.hasOwnProperty;function Ih(t,e){var r=wh(t),i=!r&&Sh(t),n=!r&&!i&&Eh(t),s=!r&&!i&&!n&&Th(t),h=r||i||n||s,f=h?xh(t.length,String):[],l=f.length;for(var p in t)(e||qh.call(t,p))&&!(h&&(p=="length"||n&&(p=="offset"||p=="parent")||s&&(p=="buffer"||p=="byteLength"||p=="byteOffset")||Oh(p,l)))&&f.push(p);return f}Ru.exports=Ih});var Fu=_((Eb,ku)=>{var Nh=Object.prototype;function Ph(t){var e=t&&t.constructor,r=typeof e=="function"&&e.prototype||Nh;return t===r}ku.exports=Ph});var ju=_((Ob,Uu)=>{function Lh(t,e){return function(r){return t(e(r))}}Uu.exports=Lh});var Hu=_((Tb,Gu)=>{var Mh=ju(),Dh=Mh(Object.keys,Object);Gu.exports=Dh});var Wu=_((Ab,zu)=>{var Rh=Fu(),Bh=Hu(),kh=Object.prototype,Fh=kh.hasOwnProperty;function Uh(t){if(!Rh(t))return Bh(t);var e=[];for(var r in Object(t))Fh.call(t,r)&&r!="constructor"&&e.push(r);return e}zu.exports=Uh});var Er=_((qb,$u)=>{var jh=Bu(),Gh=Wu(),Hh=Ht();function zh(t){return Hh(t)?jh(t):Gh(t)}$u.exports=zh});var Vu=_((Ib,Zu)=>{var Wh=pu(),$h=vu(),Zh=Er();function Vh(t){return Wh(t,Zh,$h)}Zu.exports=Vh});var Yu=_((Nb,Ju)=>{var Ku=Vu(),Kh=1,Jh=Object.prototype,Yh=Jh.hasOwnProperty;function Xh(t,e,r,i,n,s){var h=r&Kh,f=Ku(t),l=f.length,p=Ku(e),g=p.length;if(l!=g&&!h)return!1;for(var x=l;x--;){var D=f[x];if(!(h?D in e:Yh.call(e,D)))return!1}var B=s.get(t),R=s.get(e);if(B&&R)return B==e&&R==t;var k=!0;s.set(t,e),s.set(e,t);for(var j=h;++x{var Qh=Ye(),ep=je(),tp=Qh(ep,"DataView");Xu.exports=tp});var t0=_((Lb,e0)=>{var rp=Ye(),ip=je(),np=rp(ip,"Promise");e0.exports=np});var i0=_((Mb,r0)=>{var sp=Ye(),op=je(),ap=sp(op,"WeakMap");r0.exports=ap});var f0=_((Db,c0)=>{var Ai=Qu(),qi=cr(),Ii=t0(),Ni=ui(),Pi=i0(),n0=mt(),At=ei(),s0="[object Map]",up="[object Object]",o0="[object Promise]",a0="[object Set]",u0="[object WeakMap]",l0="[object DataView]",lp=At(Ai),cp=At(qi),fp=At(Ii),hp=At(Ni),pp=At(Pi),ut=n0;(Ai&&ut(new Ai(new ArrayBuffer(1)))!=l0||qi&&ut(new qi)!=s0||Ii&&ut(Ii.resolve())!=o0||Ni&&ut(new Ni)!=a0||Pi&&ut(new Pi)!=u0)&&(ut=function(t){var e=n0(t),r=e==up?t.constructor:void 0,i=r?At(r):"";if(i)switch(i){case lp:return l0;case cp:return s0;case fp:return o0;case hp:return a0;case pp:return u0}return e});c0.exports=ut});var _0=_((Rb,C0)=>{var Li=bi(),dp=xi(),gp=fu(),mp=Yu(),h0=f0(),p0=Le(),d0=wi(),yp=Ti(),Cp=1,g0="[object Arguments]",m0="[object Array]",Or="[object Object]",_p=Object.prototype,y0=_p.hasOwnProperty;function vp(t,e,r,i,n,s){var h=p0(t),f=p0(e),l=h?m0:h0(t),p=f?m0:h0(e);l=l==g0?Or:l,p=p==g0?Or:p;var g=l==Or,x=p==Or,D=l==p;if(D&&d0(t)){if(!d0(e))return!1;h=!0,g=!1}if(D&&!g)return s||(s=new Li),h||yp(t)?dp(t,e,r,i,n,s):gp(t,e,l,r,i,n,s);if(!(r&Cp)){var B=g&&y0.call(t,"__wrapped__"),R=x&&y0.call(e,"__wrapped__");if(B||R){var k=B?t.value():t,j=R?e.value():e;return s||(s=new Li),n(k,j,r,i,s)}}return D?(s||(s=new Li),mp(t,e,r,i,n,s)):!1}C0.exports=vp});var Mi=_((Bb,x0)=>{var bp=_0(),v0=yt();function b0(t,e,r,i,n){return t===e?!0:t==null||e==null||!v0(t)&&!v0(e)?t!==t&&e!==e:bp(t,e,r,i,b0,n)}x0.exports=b0});var w0=_((kb,S0)=>{var xp=bi(),Sp=Mi(),wp=1,Ep=2;function Op(t,e,r,i){var n=r.length,s=n,h=!i;if(t==null)return!s;for(t=Object(t);n--;){var f=r[n];if(h&&f[2]?f[1]!==t[f[0]]:!(f[0]in t))return!1}for(;++n{var Tp=Je();function Ap(t){return t===t&&!Tp(t)}E0.exports=Ap});var T0=_((Ub,O0)=>{var qp=Di(),Ip=Er();function Np(t){for(var e=Ip(t),r=e.length;r--;){var i=e[r],n=t[i];e[r]=[i,n,qp(n)]}return e}O0.exports=Np});var Ri=_((jb,A0)=>{function Pp(t,e){return function(r){return r==null?!1:r[t]===e&&(e!==void 0||t in Object(r))}}A0.exports=Pp});var I0=_((Gb,q0)=>{var Lp=w0(),Mp=T0(),Dp=Ri();function Rp(t){var e=Mp(t);return e.length==1&&e[0][2]?Dp(e[0][0],e[0][1]):function(r){return r===t||Lp(r,t,e)}}q0.exports=Rp});var P0=_((Hb,N0)=>{function Bp(t,e){return t!=null&&e in Object(t)}N0.exports=Bp});var M0=_((zb,L0)=>{var kp=P0(),Fp=ii();function Up(t,e){return t!=null&&Fp(t,e,kp)}L0.exports=Up});var R0=_((Wb,D0)=>{var jp=Mi(),Gp=dr(),Hp=M0(),zp=lr(),Wp=Di(),$p=Ri(),Zp=xt(),Vp=1,Kp=2;function Jp(t,e){return zp(t)&&Wp(e)?$p(Zp(t),e):function(r){var i=Gp(r,t);return i===void 0&&i===e?Hp(r,t):jp(e,i,Vp|Kp)}}D0.exports=Jp});var Vt=_(($b,B0)=>{function Yp(t){return t}B0.exports=Yp});var F0=_((Zb,k0)=>{function Xp(t){return function(e){return e==null?void 0:e[t]}}k0.exports=Xp});var j0=_((Vb,U0)=>{var Qp=pr();function ed(t){return function(e){return Qp(e,t)}}U0.exports=ed});var H0=_((Kb,G0)=>{var td=F0(),rd=j0(),id=lr(),nd=xt();function sd(t){return id(t)?td(nd(t)):rd(t)}G0.exports=sd});var W0=_((Jb,z0)=>{var od=I0(),ad=R0(),ud=Vt(),ld=Le(),cd=H0();function fd(t){return typeof t=="function"?t:t==null?ud:typeof t=="object"?ld(t)?ad(t[0],t[1]):od(t):cd(t)}z0.exports=fd});var Z0=_((Yb,$0)=>{function hd(t){return function(e,r,i){for(var n=-1,s=Object(e),h=i(e),f=h.length;f--;){var l=h[t?f:++n];if(r(s[l],l,s)===!1)break}return e}}$0.exports=hd});var K0=_((Xb,V0)=>{var pd=Z0(),dd=pd();V0.exports=dd});var Y0=_((Qb,J0)=>{var gd=K0(),md=Er();function yd(t,e){return t&&gd(t,e,md)}J0.exports=yd});var Q0=_((ex,X0)=>{var Cd=Ht();function _d(t,e){return function(r,i){if(r==null)return r;if(!Cd(r))return t(r,i);for(var n=r.length,s=e?n:-1,h=Object(r);(e?s--:++s{var vd=Y0(),bd=Q0(),xd=bd(vd);el.exports=xd});var il=_((rx,rl)=>{var Sd=tl(),wd=Ht();function Ed(t,e){var r=-1,i=wd(t)?Array(t.length):[];return Sd(t,function(n,s,h){i[++r]=e(n,s,h)}),i}rl.exports=Ed});var sl=_((ix,nl)=>{function Od(t,e){var r=t.length;for(t.sort(e);r--;)t[r]=t[r].value;return t}nl.exports=Od});var ul=_((nx,al)=>{var ol=Ct();function Td(t,e){if(t!==e){var r=t!==void 0,i=t===null,n=t===t,s=ol(t),h=e!==void 0,f=e===null,l=e===e,p=ol(e);if(!f&&!p&&!s&&t>e||s&&h&&l&&!f&&!p||i&&h&&l||!r&&l||!n)return 1;if(!i&&!s&&!p&&t{var Ad=ul();function qd(t,e,r){for(var i=-1,n=t.criteria,s=e.criteria,h=n.length,f=r.length;++i=f)return l;var p=r[i];return l*(p=="desc"?-1:1)}}return t.index-e.index}ll.exports=qd});var hl=_((ox,fl)=>{var Bi=ri(),Id=pr(),Nd=W0(),Pd=il(),Ld=sl(),Md=Ei(),Dd=cl(),Rd=Vt(),Bd=Le();function kd(t,e,r){e.length?e=Bi(e,function(s){return Bd(s)?function(h){return Id(h,s.length===1?s[0]:s)}:s}):e=[Rd];var i=-1;e=Bi(e,Md(Nd));var n=Pd(t,function(s,h,f){var l=Bi(e,function(p){return p(s)});return{criteria:l,index:++i,value:s}});return Ld(n,function(s,h){return Dd(s,h,r)})}fl.exports=kd});var dl=_((ax,pl)=>{function Fd(t,e,r){switch(r.length){case 0:return t.call(e);case 1:return t.call(e,r[0]);case 2:return t.call(e,r[0],r[1]);case 3:return t.call(e,r[0],r[1],r[2])}return t.apply(e,r)}pl.exports=Fd});var yl=_((ux,ml)=>{var Ud=dl(),gl=Math.max;function jd(t,e,r){return e=gl(e===void 0?t.length-1:e,0),function(){for(var i=arguments,n=-1,s=gl(i.length-e,0),h=Array(s);++n{function Gd(t){return function(){return t}}Cl.exports=Gd});var xl=_((cx,bl)=>{var Hd=_l(),vl=ni(),zd=Vt(),Wd=vl?function(t,e){return vl(t,"toString",{configurable:!0,enumerable:!1,value:Hd(e),writable:!0})}:zd;bl.exports=Wd});var wl=_((fx,Sl)=>{var $d=800,Zd=16,Vd=Date.now;function Kd(t){var e=0,r=0;return function(){var i=Vd(),n=Zd-(i-r);if(r=i,n>0){if(++e>=$d)return arguments[0]}else e=0;return t.apply(void 0,arguments)}}Sl.exports=Kd});var Ol=_((hx,El)=>{var Jd=xl(),Yd=wl(),Xd=Yd(Jd);El.exports=Xd});var Al=_((px,Tl)=>{var Qd=Vt(),eg=yl(),tg=Ol();function rg(t,e){return tg(eg(t,e,Qd),t+"")}Tl.exports=rg});var Nl=_((dx,Il)=>{var ig=vi(),ng=hl(),sg=Al(),ql=wr(),og=sg(function(t,e){if(t==null)return[];var r=e.length;return r>1&&ql(t,e[0],e[1])?e=[]:r>2&&ql(e[0],e[1],e[2])&&(e=[e[0]]),ng(t,ig(e,1),[])});Il.exports=og});var Ll=_((gx,Pl)=>{function ag(t,e,r){for(var i=-1,n=t.length,s=e.length,h={};++i{var ug=si(),lg=Ll();function cg(t,e){return lg(t||[],e||[],ug)}Ml.exports=cg});var Ul=_((Nx,Fl)=>{var hg=vi(),pg=1/0;function dg(t){var e=t==null?0:t.length;return e?hg(t,pg):[]}Fl.exports=dg});var $l=_((Mx,Wl)=>{var mg=Math.ceil,yg=Math.max;function Cg(t,e,r,i){for(var n=-1,s=yg(mg((e-t)/(r||1)),0),h=Array(s);s--;)h[i?s:++n]=t,t+=r;return h}Wl.exports=Cg});var Vl=_((Dx,Zl)=>{var _g=$l(),vg=wr(),Hi=yi();function bg(t){return function(e,r,i){return i&&typeof i!="number"&&vg(e,r,i)&&(r=i=void 0),e=Hi(e),r===void 0?(r=e,e=0):r=Hi(r),i=i===void 0?e{var xg=Vl(),Sg=xg();Kl.exports=Sg});var hc=_((CS,fc)=>{var Ag="Expected a function",Ql="__lodash_hash_undefined__",ec=1/0,qg=9007199254740991,Ig="[object Function]",Ng="[object GeneratorFunction]",Pg="[object Symbol]",Lg=/\.|\[(?:[^[\]]*|(["'])(?:(?!\1)[^\\]|\\.)*?\1)\]/,Mg=/^\w*$/,Dg=/^\./,Rg=/[^.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|$))/g,Bg=/[\\^$.*+?()[\]{}|]/g,kg=/\\(\\)?/g,Fg=/^\[object .+?Constructor\]$/,Ug=/^(?:0|[1-9]\d*)$/,jg=typeof global=="object"&&global&&global.Object===Object&&global,Gg=typeof self=="object"&&self&&self.Object===Object&&self,Vi=jg||Gg||Function("return this")();function Hg(t,e){return t==null?void 0:t[e]}function zg(t){var e=!1;if(t!=null&&typeof t.toString!="function")try{e=!!(t+"")}catch(r){}return e}var Wg=Array.prototype,$g=Function.prototype,tc=Object.prototype,Ki=Vi["__core-js_shared__"],rc=function(){var t=/[^.]+$/.exec(Ki&&Ki.keys&&Ki.keys.IE_PROTO||"");return t?"Symbol(src)_1."+t:""}(),ic=$g.toString,Ir=tc.hasOwnProperty,nc=tc.toString,Zg=RegExp("^"+ic.call(Ir).replace(Bg,"\\$&").replace(/hasOwnProperty|(function).*?(?=\\\()| for .+?(?=\\\])/g,"$1.*?")+"$"),sc=Vi.Symbol,Vg=Wg.splice,Kg=uc(Vi,"Map"),Kt=uc(Object,"create"),oc=sc?sc.prototype:void 0,ac=oc?oc.toString:void 0;function lt(t){var e=-1,r=t?t.length:0;for(this.clear();++e-1}function sm(t,e){var r=this.__data__,i=Nr(r,t);return i<0?r.push([t,e]):r[i][1]=e,this}It.prototype.clear=tm;It.prototype.delete=rm;It.prototype.get=im;It.prototype.has=nm;It.prototype.set=sm;function ct(t){var e=-1,r=t?t.length:0;for(this.clear();++e-1&&t%1==0&&t{"use strict";var{Duplex:ny}=require("stream");function Cc(t){t.emit("close")}function sy(){!this.destroyed&&this._writableState.finished&&this.destroy()}function _c(t){this.removeListener("error",_c),this.destroy(),this.listenerCount("error")===0&&this.emit("error",t)}function oy(t,e){let r=!0,i=new ny({...e,autoDestroy:!1,emitClose:!1,objectMode:!1,writableObjectMode:!1});return t.on("message",function(s,h){let f=!h&&i._readableState.objectMode?s.toString():s;i.push(f)||t.pause()}),t.once("error",function(s){i.destroyed||(r=!1,i.destroy(s))}),t.once("close",function(){i.destroyed||i.push(null)}),i._destroy=function(n,s){if(t.readyState===t.CLOSED){s(n),process.nextTick(Cc,i);return}let h=!1;t.once("error",function(l){h=!0,s(l)}),t.once("close",function(){h||s(n),process.nextTick(Cc,i)}),r&&t.terminate()},i._final=function(n){if(t.readyState===t.CONNECTING){t.once("open",function(){i._final(n)});return}t._socket!==null&&(t._socket._writableState.finished?(n(),i._readableState.endEmitted&&i.destroy()):(t._socket.once("finish",function(){n()}),t.close()))},i._read=function(){t.isPaused&&t.resume()},i._write=function(n,s,h){if(t.readyState===t.CONNECTING){t.once("open",function(){i._write(n,s,h)});return}t.send(n,h)},i.on("end",sy),i.on("error",_c),i}vc.exports=oy});var et=_((NS,xc)=>{"use strict";xc.exports={BINARY_TYPES:["nodebuffer","arraybuffer","fragments"],EMPTY_BUFFER:Buffer.alloc(0),GUID:"258EAFA5-E914-47DA-95CA-C5AB0DC85B11",kForOnEventAttribute:Symbol("kIsForOnEventAttribute"),kListener:Symbol("kListener"),kStatusCode:Symbol("status-code"),kWebSocket:Symbol("websocket"),NOOP:()=>{}}});var Jt=_((PS,Rr)=>{"use strict";var{EMPTY_BUFFER:ay}=et();function uy(t,e){if(t.length===0)return ay;if(t.length===1)return t[0];let r=Buffer.allocUnsafe(e),i=0;for(let n=0;n{"use strict";var Ec=Symbol("kDone"),en=Symbol("kRun"),Oc=class{constructor(e){this[Ec]=()=>{this.pending--,this[en]()},this.concurrency=e||1/0,this.jobs=[],this.pending=0}add(e){this.jobs.push(e),this[en]()}[en](){if(this.pending!==this.concurrency&&this.jobs.length){let e=this.jobs.shift();this.pending++,e(this[Ec])}}};Tc.exports=Oc});var Qt=_((MS,Lc)=>{"use strict";var Yt=require("zlib"),qc=Jt(),cy=Ac(),{kStatusCode:Ic}=et(),fy=Buffer.from([0,0,255,255]),Br=Symbol("permessage-deflate"),$e=Symbol("total-length"),Xt=Symbol("callback"),tt=Symbol("buffers"),kr=Symbol("error"),Fr,Nc=class{constructor(e,r,i){if(this._maxPayload=i|0,this._options=e||{},this._threshold=this._options.threshold!==void 0?this._options.threshold:1024,this._isServer=!!r,this._deflate=null,this._inflate=null,this.params=null,!Fr){let n=this._options.concurrencyLimit!==void 0?this._options.concurrencyLimit:10;Fr=new cy(n)}}static get extensionName(){return"permessage-deflate"}offer(){let e={};return this._options.serverNoContextTakeover&&(e.server_no_context_takeover=!0),this._options.clientNoContextTakeover&&(e.client_no_context_takeover=!0),this._options.serverMaxWindowBits&&(e.server_max_window_bits=this._options.serverMaxWindowBits),this._options.clientMaxWindowBits?e.client_max_window_bits=this._options.clientMaxWindowBits:this._options.clientMaxWindowBits==null&&(e.client_max_window_bits=!0),e}accept(e){return e=this.normalizeParams(e),this.params=this._isServer?this.acceptAsServer(e):this.acceptAsClient(e),this.params}cleanup(){if(this._inflate&&(this._inflate.close(),this._inflate=null),this._deflate){let e=this._deflate[Xt];this._deflate.close(),this._deflate=null,e&&e(new Error("The deflate stream was closed while data was being processed"))}}acceptAsServer(e){let r=this._options,i=e.find(n=>!(r.serverNoContextTakeover===!1&&n.server_no_context_takeover||n.server_max_window_bits&&(r.serverMaxWindowBits===!1||typeof r.serverMaxWindowBits=="number"&&r.serverMaxWindowBits>n.server_max_window_bits)||typeof r.clientMaxWindowBits=="number"&&!n.client_max_window_bits));if(!i)throw new Error("None of the extension offers can be accepted");return r.serverNoContextTakeover&&(i.server_no_context_takeover=!0),r.clientNoContextTakeover&&(i.client_no_context_takeover=!0),typeof r.serverMaxWindowBits=="number"&&(i.server_max_window_bits=r.serverMaxWindowBits),typeof r.clientMaxWindowBits=="number"?i.client_max_window_bits=r.clientMaxWindowBits:(i.client_max_window_bits===!0||r.clientMaxWindowBits===!1)&&delete i.client_max_window_bits,i}acceptAsClient(e){let r=e[0];if(this._options.clientNoContextTakeover===!1&&r.client_no_context_takeover)throw new Error('Unexpected parameter "client_no_context_takeover"');if(!r.client_max_window_bits)typeof this._options.clientMaxWindowBits=="number"&&(r.client_max_window_bits=this._options.clientMaxWindowBits);else if(this._options.clientMaxWindowBits===!1||typeof this._options.clientMaxWindowBits=="number"&&r.client_max_window_bits>this._options.clientMaxWindowBits)throw new Error('Unexpected or invalid parameter "client_max_window_bits"');return r}normalizeParams(e){return e.forEach(r=>{Object.keys(r).forEach(i=>{let n=r[i];if(n.length>1)throw new Error(`Parameter "${i}" must have only a single value`);if(n=n[0],i==="client_max_window_bits"){if(n!==!0){let s=+n;if(!Number.isInteger(s)||s<8||s>15)throw new TypeError(`Invalid value for parameter "${i}": ${n}`);n=s}else if(!this._isServer)throw new TypeError(`Invalid value for parameter "${i}": ${n}`)}else if(i==="server_max_window_bits"){let s=+n;if(!Number.isInteger(s)||s<8||s>15)throw new TypeError(`Invalid value for parameter "${i}": ${n}`);n=s}else if(i==="client_no_context_takeover"||i==="server_no_context_takeover"){if(n!==!0)throw new TypeError(`Invalid value for parameter "${i}": ${n}`)}else throw new Error(`Unknown parameter "${i}"`);r[i]=n})}),e}decompress(e,r,i){Fr.add(n=>{this._decompress(e,r,(s,h)=>{n(),i(s,h)})})}compress(e,r,i){Fr.add(n=>{this._compress(e,r,(s,h)=>{n(),i(s,h)})})}_decompress(e,r,i){let n=this._isServer?"client":"server";if(!this._inflate){let s=`${n}_max_window_bits`,h=typeof this.params[s]!="number"?Yt.Z_DEFAULT_WINDOWBITS:this.params[s];this._inflate=Yt.createInflateRaw({...this._options.zlibInflateOptions,windowBits:h}),this._inflate[Br]=this,this._inflate[$e]=0,this._inflate[tt]=[],this._inflate.on("error",py),this._inflate.on("data",Pc)}this._inflate[Xt]=i,this._inflate.write(e),r&&this._inflate.write(fy),this._inflate.flush(()=>{let s=this._inflate[kr];if(s){this._inflate.close(),this._inflate=null,i(s);return}let h=qc.concat(this._inflate[tt],this._inflate[$e]);this._inflate._readableState.endEmitted?(this._inflate.close(),this._inflate=null):(this._inflate[$e]=0,this._inflate[tt]=[],r&&this.params[`${n}_no_context_takeover`]&&this._inflate.reset()),i(null,h)})}_compress(e,r,i){let n=this._isServer?"server":"client";if(!this._deflate){let s=`${n}_max_window_bits`,h=typeof this.params[s]!="number"?Yt.Z_DEFAULT_WINDOWBITS:this.params[s];this._deflate=Yt.createDeflateRaw({...this._options.zlibDeflateOptions,windowBits:h}),this._deflate[$e]=0,this._deflate[tt]=[],this._deflate.on("data",hy)}this._deflate[Xt]=i,this._deflate.write(e),this._deflate.flush(Yt.Z_SYNC_FLUSH,()=>{if(!this._deflate)return;let s=qc.concat(this._deflate[tt],this._deflate[$e]);r&&(s=s.slice(0,s.length-4)),this._deflate[Xt]=null,this._deflate[$e]=0,this._deflate[tt]=[],r&&this.params[`${n}_no_context_takeover`]&&this._deflate.reset(),i(null,s)})}};Lc.exports=Nc;function hy(t){this[tt].push(t),this[$e]+=t.length}function Pc(t){if(this[$e]+=t.length,this[Br]._maxPayload<1||this[$e]<=this[Br]._maxPayload){this[tt].push(t);return}this[kr]=new RangeError("Max payload size exceeded"),this[kr].code="WS_ERR_UNSUPPORTED_MESSAGE_LENGTH",this[kr][Ic]=1009,this.removeListener("data",Pc),this.reset()}function py(t){this[Br]._inflate=null,t[Ic]=1007,this[Xt](t)}});var er=_((DS,tn)=>{"use strict";var dy=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,0,0,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,0];function gy(t){return t>=1e3&&t<=1014&&t!==1004&&t!==1005&&t!==1006||t>=3e3&&t<=4999}function Mc(t){let e=t.length,r=0;for(;r=e||(t[r+1]&192)!=128||(t[r+2]&192)!=128||t[r]===224&&(t[r+1]&224)==128||t[r]===237&&(t[r+1]&224)==160)return!1;r+=3}else if((t[r]&248)==240){if(r+3>=e||(t[r+1]&192)!=128||(t[r+2]&192)!=128||(t[r+3]&192)!=128||t[r]===240&&(t[r+1]&240)==128||t[r]===244&&t[r+1]>143||t[r]>244)return!1;r+=4}else return!1;return!0}tn.exports={isValidStatusCode:gy,isValidUTF8:Mc,tokenChars:dy};if(!process.env.WS_NO_UTF_8_VALIDATE)try{let t=require("utf-8-validate");tn.exports.isValidUTF8=function(e){return e.length<150?Mc(e):t(e)}}catch(t){}});var sn=_((RS,Gc)=>{"use strict";var{Writable:my}=require("stream"),Dc=Qt(),{BINARY_TYPES:yy,EMPTY_BUFFER:Rc,kStatusCode:Cy,kWebSocket:_y}=et(),{concat:rn,toArrayBuffer:vy,unmask:by}=Jt(),{isValidStatusCode:xy,isValidUTF8:Bc}=er(),tr=0,kc=1,Fc=2,Uc=3,nn=4,Sy=5,jc=class extends my{constructor(e={}){super();this._binaryType=e.binaryType||yy[0],this._extensions=e.extensions||{},this._isServer=!!e.isServer,this._maxPayload=e.maxPayload|0,this._skipUTF8Validation=!!e.skipUTF8Validation,this[_y]=void 0,this._bufferedBytes=0,this._buffers=[],this._compressed=!1,this._payloadLength=0,this._mask=void 0,this._fragmented=0,this._masked=!1,this._fin=!1,this._opcode=0,this._totalPayloadLength=0,this._messageLength=0,this._fragments=[],this._state=tr,this._loop=!1}_write(e,r,i){if(this._opcode===8&&this._state==tr)return i();this._bufferedBytes+=e.length,this._buffers.push(e),this.startLoop(i)}consume(e){if(this._bufferedBytes-=e,e===this._buffers[0].length)return this._buffers.shift();if(e=i.length?r.set(this._buffers.shift(),n):(r.set(new Uint8Array(i.buffer,i.byteOffset,e),n),this._buffers[0]=i.slice(e)),e-=i.length}while(e>0);return r}startLoop(e){let r;this._loop=!0;do switch(this._state){case tr:r=this.getInfo();break;case kc:r=this.getPayloadLength16();break;case Fc:r=this.getPayloadLength64();break;case Uc:this.getMask();break;case nn:r=this.getData(e);break;default:this._loop=!1;return}while(this._loop);e(r)}getInfo(){if(this._bufferedBytes<2){this._loop=!1;return}let e=this.consume(2);if((e[0]&48)!=0)return this._loop=!1,pe(RangeError,"RSV2 and RSV3 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_2_3");let r=(e[0]&64)==64;if(r&&!this._extensions[Dc.extensionName])return this._loop=!1,pe(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(this._fin=(e[0]&128)==128,this._opcode=e[0]&15,this._payloadLength=e[1]&127,this._opcode===0){if(r)return this._loop=!1,pe(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(!this._fragmented)return this._loop=!1,pe(RangeError,"invalid opcode 0",!0,1002,"WS_ERR_INVALID_OPCODE");this._opcode=this._fragmented}else if(this._opcode===1||this._opcode===2){if(this._fragmented)return this._loop=!1,pe(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");this._compressed=r}else if(this._opcode>7&&this._opcode<11){if(!this._fin)return this._loop=!1,pe(RangeError,"FIN must be set",!0,1002,"WS_ERR_EXPECTED_FIN");if(r)return this._loop=!1,pe(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");if(this._payloadLength>125)return this._loop=!1,pe(RangeError,`invalid payload length ${this._payloadLength}`,!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH")}else return this._loop=!1,pe(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");if(!this._fin&&!this._fragmented&&(this._fragmented=this._opcode),this._masked=(e[1]&128)==128,this._isServer){if(!this._masked)return this._loop=!1,pe(RangeError,"MASK must be set",!0,1002,"WS_ERR_EXPECTED_MASK")}else if(this._masked)return this._loop=!1,pe(RangeError,"MASK must be clear",!0,1002,"WS_ERR_UNEXPECTED_MASK");if(this._payloadLength===126)this._state=kc;else if(this._payloadLength===127)this._state=Fc;else return this.haveLength()}getPayloadLength16(){if(this._bufferedBytes<2){this._loop=!1;return}return this._payloadLength=this.consume(2).readUInt16BE(0),this.haveLength()}getPayloadLength64(){if(this._bufferedBytes<8){this._loop=!1;return}let e=this.consume(8),r=e.readUInt32BE(0);return r>Math.pow(2,53-32)-1?(this._loop=!1,pe(RangeError,"Unsupported WebSocket frame: payload length > 2^53 - 1",!1,1009,"WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH")):(this._payloadLength=r*Math.pow(2,32)+e.readUInt32BE(4),this.haveLength())}haveLength(){if(this._payloadLength&&this._opcode<8&&(this._totalPayloadLength+=this._payloadLength,this._totalPayloadLength>this._maxPayload&&this._maxPayload>0))return this._loop=!1,pe(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");this._masked?this._state=Uc:this._state=nn}getMask(){if(this._bufferedBytes<4){this._loop=!1;return}this._mask=this.consume(4),this._state=nn}getData(e){let r=Rc;if(this._payloadLength){if(this._bufferedBytes7)return this.controlMessage(r);if(this._compressed){this._state=Sy,this.decompress(r,e);return}return r.length&&(this._messageLength=this._totalPayloadLength,this._fragments.push(r)),this.dataMessage()}decompress(e,r){this._extensions[Dc.extensionName].decompress(e,this._fin,(n,s)=>{if(n)return r(n);if(s.length){if(this._messageLength+=s.length,this._messageLength>this._maxPayload&&this._maxPayload>0)return r(pe(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH"));this._fragments.push(s)}let h=this.dataMessage();if(h)return r(h);this.startLoop(r)})}dataMessage(){if(this._fin){let e=this._messageLength,r=this._fragments;if(this._totalPayloadLength=0,this._messageLength=0,this._fragmented=0,this._fragments=[],this._opcode===2){let i;this._binaryType==="nodebuffer"?i=rn(r,e):this._binaryType==="arraybuffer"?i=vy(rn(r,e)):i=r,this.emit("message",i,!0)}else{let i=rn(r,e);if(!this._skipUTF8Validation&&!Bc(i))return this._loop=!1,pe(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");this.emit("message",i,!1)}}this._state=tr}controlMessage(e){if(this._opcode===8)if(this._loop=!1,e.length===0)this.emit("conclude",1005,Rc),this.end();else{if(e.length===1)return pe(RangeError,"invalid payload length 1",!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH");{let r=e.readUInt16BE(0);if(!xy(r))return pe(RangeError,`invalid status code ${r}`,!0,1002,"WS_ERR_INVALID_CLOSE_CODE");let i=e.slice(2);if(!this._skipUTF8Validation&&!Bc(i))return pe(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");this.emit("conclude",r,i),this.end()}}else this._opcode===9?this.emit("ping",e):this.emit("pong",e);this._state=tr}};Gc.exports=jc;function pe(t,e,r,i,n){let s=new t(r?`Invalid WebSocket frame: ${e}`:e);return Error.captureStackTrace(s,pe),s.code=n,s[Cy]=i,s}});var on=_((FS,Wc)=>{"use strict";var BS=require("net"),kS=require("tls"),{randomFillSync:wy}=require("crypto"),Hc=Qt(),{EMPTY_BUFFER:Ey}=et(),{isValidStatusCode:Oy}=er(),{mask:zc,toBuffer:Nt}=Jt(),Ue=Symbol("kByteLength"),Ty=Buffer.alloc(4),Ze=class{constructor(e,r,i){this._extensions=r||{},i&&(this._generateMask=i,this._maskBuffer=Buffer.alloc(4)),this._socket=e,this._firstFragment=!0,this._compress=!1,this._bufferedBytes=0,this._deflating=!1,this._queue=[]}static frame(e,r){let i,n=!1,s=2,h=!1;r.mask&&(i=r.maskBuffer||Ty,r.generateMask?r.generateMask(i):wy(i,0,4),h=(i[0]|i[1]|i[2]|i[3])==0,s=6);let f;typeof e=="string"?(!r.mask||h)&&r[Ue]!==void 0?f=r[Ue]:(e=Buffer.from(e),f=e.length):(f=e.length,n=r.mask&&r.readOnly&&!h);let l=f;f>=65536?(s+=8,l=127):f>125&&(s+=2,l=126);let p=Buffer.allocUnsafe(n?f+s:s);return p[0]=r.fin?r.opcode|128:r.opcode,r.rsv1&&(p[0]|=64),p[1]=l,l===126?p.writeUInt16BE(f,2):l===127&&(p[2]=p[3]=0,p.writeUIntBE(f,4,6)),r.mask?(p[1]|=128,p[s-4]=i[0],p[s-3]=i[1],p[s-2]=i[2],p[s-1]=i[3],h?[p,e]:n?(zc(e,i,p,s,f),[p]):(zc(e,i,e,0,f),[p,e])):[p,e]}close(e,r,i,n){let s;if(e===void 0)s=Ey;else{if(typeof e!="number"||!Oy(e))throw new TypeError("First argument must be a valid error code number");if(r===void 0||!r.length)s=Buffer.allocUnsafe(2),s.writeUInt16BE(e,0);else{let f=Buffer.byteLength(r);if(f>123)throw new RangeError("The message must not be greater than 123 bytes");s=Buffer.allocUnsafe(2+f),s.writeUInt16BE(e,0),typeof r=="string"?s.write(r,2):s.set(r,2)}}let h={[Ue]:s.length,fin:!0,generateMask:this._generateMask,mask:i,maskBuffer:this._maskBuffer,opcode:8,readOnly:!1,rsv1:!1};this._deflating?this.enqueue([this.dispatch,s,!1,h,n]):this.sendFrame(Ze.frame(s,h),n)}ping(e,r,i){let n,s;if(typeof e=="string"?(n=Buffer.byteLength(e),s=!1):(e=Nt(e),n=e.length,s=Nt.readOnly),n>125)throw new RangeError("The data size must not be greater than 125 bytes");let h={[Ue]:n,fin:!0,generateMask:this._generateMask,mask:r,maskBuffer:this._maskBuffer,opcode:9,readOnly:s,rsv1:!1};this._deflating?this.enqueue([this.dispatch,e,!1,h,i]):this.sendFrame(Ze.frame(e,h),i)}pong(e,r,i){let n,s;if(typeof e=="string"?(n=Buffer.byteLength(e),s=!1):(e=Nt(e),n=e.length,s=Nt.readOnly),n>125)throw new RangeError("The data size must not be greater than 125 bytes");let h={[Ue]:n,fin:!0,generateMask:this._generateMask,mask:r,maskBuffer:this._maskBuffer,opcode:10,readOnly:s,rsv1:!1};this._deflating?this.enqueue([this.dispatch,e,!1,h,i]):this.sendFrame(Ze.frame(e,h),i)}send(e,r,i){let n=this._extensions[Hc.extensionName],s=r.binary?2:1,h=r.compress,f,l;if(typeof e=="string"?(f=Buffer.byteLength(e),l=!1):(e=Nt(e),f=e.length,l=Nt.readOnly),this._firstFragment?(this._firstFragment=!1,h&&n&&n.params[n._isServer?"server_no_context_takeover":"client_no_context_takeover"]&&(h=f>=n._threshold),this._compress=h):(h=!1,s=0),r.fin&&(this._firstFragment=!0),n){let p={[Ue]:f,fin:r.fin,generateMask:this._generateMask,mask:r.mask,maskBuffer:this._maskBuffer,opcode:s,readOnly:l,rsv1:h};this._deflating?this.enqueue([this.dispatch,e,this._compress,p,i]):this.dispatch(e,this._compress,p,i)}else this.sendFrame(Ze.frame(e,{[Ue]:f,fin:r.fin,generateMask:this._generateMask,mask:r.mask,maskBuffer:this._maskBuffer,opcode:s,readOnly:l,rsv1:!1}),i)}dispatch(e,r,i,n){if(!r){this.sendFrame(Ze.frame(e,i),n);return}let s=this._extensions[Hc.extensionName];this._bufferedBytes+=i[Ue],this._deflating=!0,s.compress(e,i.fin,(h,f)=>{if(this._socket.destroyed){let l=new Error("The socket was closed while data was being compressed");typeof n=="function"&&n(l);for(let p=0;p{"use strict";var{kForOnEventAttribute:rr,kListener:an}=et(),$c=Symbol("kCode"),Zc=Symbol("kData"),Vc=Symbol("kError"),Kc=Symbol("kMessage"),Jc=Symbol("kReason"),Pt=Symbol("kTarget"),Yc=Symbol("kType"),Xc=Symbol("kWasClean"),rt=class{constructor(e){this[Pt]=null,this[Yc]=e}get target(){return this[Pt]}get type(){return this[Yc]}};Object.defineProperty(rt.prototype,"target",{enumerable:!0});Object.defineProperty(rt.prototype,"type",{enumerable:!0});var Lt=class extends rt{constructor(e,r={}){super(e);this[$c]=r.code===void 0?0:r.code,this[Jc]=r.reason===void 0?"":r.reason,this[Xc]=r.wasClean===void 0?!1:r.wasClean}get code(){return this[$c]}get reason(){return this[Jc]}get wasClean(){return this[Xc]}};Object.defineProperty(Lt.prototype,"code",{enumerable:!0});Object.defineProperty(Lt.prototype,"reason",{enumerable:!0});Object.defineProperty(Lt.prototype,"wasClean",{enumerable:!0});var ir=class extends rt{constructor(e,r={}){super(e);this[Vc]=r.error===void 0?null:r.error,this[Kc]=r.message===void 0?"":r.message}get error(){return this[Vc]}get message(){return this[Kc]}};Object.defineProperty(ir.prototype,"error",{enumerable:!0});Object.defineProperty(ir.prototype,"message",{enumerable:!0});var Ur=class extends rt{constructor(e,r={}){super(e);this[Zc]=r.data===void 0?null:r.data}get data(){return this[Zc]}};Object.defineProperty(Ur.prototype,"data",{enumerable:!0});var Ay={addEventListener(t,e,r={}){for(let n of this.listeners(t))if(!r[rr]&&n[an]===e&&!n[rr])return;let i;if(t==="message")i=function(s,h){let f=new Ur("message",{data:h?s:s.toString()});f[Pt]=this,jr(e,this,f)};else if(t==="close")i=function(s,h){let f=new Lt("close",{code:s,reason:h.toString(),wasClean:this._closeFrameReceived&&this._closeFrameSent});f[Pt]=this,jr(e,this,f)};else if(t==="error")i=function(s){let h=new ir("error",{error:s,message:s.message});h[Pt]=this,jr(e,this,h)};else if(t==="open")i=function(){let s=new rt("open");s[Pt]=this,jr(e,this,s)};else return;i[rr]=!!r[rr],i[an]=e,r.once?this.once(t,i):this.on(t,i)},removeEventListener(t,e){for(let r of this.listeners(t))if(r[an]===e&&!r[rr]){this.removeListener(t,r);break}}};Qc.exports={CloseEvent:Lt,ErrorEvent:ir,Event:rt,EventTarget:Ay,MessageEvent:Ur};function jr(t,e,r){typeof t=="object"&&t.handleEvent?t.handleEvent.call(t,r):t.call(e,r)}});var un=_((jS,t2)=>{"use strict";var{tokenChars:nr}=er();function He(t,e,r){t[e]===void 0?t[e]=[r]:t[e].push(r)}function qy(t){let e=Object.create(null),r=Object.create(null),i=!1,n=!1,s=!1,h,f,l=-1,p=-1,g=-1,x=0;for(;x{let r=t[e];return Array.isArray(r)||(r=[r]),r.map(i=>[e].concat(Object.keys(i).map(n=>{let s=i[n];return Array.isArray(s)||(s=[s]),s.map(h=>h===!0?n:`${n}=${h}`).join("; ")})).join("; ")).join(", ")}).join(", ")}t2.exports={format:Iy,parse:qy}});var pn=_((HS,h2)=>{"use strict";var Ny=require("events"),Py=require("https"),Ly=require("http"),r2=require("net"),My=require("tls"),{randomBytes:Dy,createHash:Ry}=require("crypto"),{Readable:GS}=require("stream"),{URL:ln}=require("url"),it=Qt(),By=sn(),ky=on(),{BINARY_TYPES:i2,EMPTY_BUFFER:Gr,GUID:Fy,kForOnEventAttribute:cn,kListener:Uy,kStatusCode:jy,kWebSocket:xe,NOOP:n2}=et(),{EventTarget:{addEventListener:Gy,removeEventListener:Hy}}=e2(),{format:zy,parse:Wy}=un(),{toBuffer:$y}=Jt(),Zy=30*1e3,s2=Symbol("kAborted"),fn=[8,13],Ve=["CONNECTING","OPEN","CLOSING","CLOSED"],Vy=/^[!#$%&'*+\-.0-9A-Z^_`|a-z~]+$/,$=class extends Ny{constructor(e,r,i){super();this._binaryType=i2[0],this._closeCode=1006,this._closeFrameReceived=!1,this._closeFrameSent=!1,this._closeMessage=Gr,this._closeTimer=null,this._extensions={},this._paused=!1,this._protocol="",this._readyState=$.CONNECTING,this._receiver=null,this._sender=null,this._socket=null,e!==null?(this._bufferedAmount=0,this._isServer=!1,this._redirects=0,r===void 0?r=[]:Array.isArray(r)||(typeof r=="object"&&r!==null?(i=r,r=[]):r=[r]),o2(this,e,r,i)):this._isServer=!0}get binaryType(){return this._binaryType}set binaryType(e){!i2.includes(e)||(this._binaryType=e,this._receiver&&(this._receiver._binaryType=e))}get bufferedAmount(){return this._socket?this._socket._writableState.length+this._sender._bufferedBytes:this._bufferedAmount}get extensions(){return Object.keys(this._extensions).join()}get isPaused(){return this._paused}get onclose(){return null}get onerror(){return null}get onopen(){return null}get onmessage(){return null}get protocol(){return this._protocol}get readyState(){return this._readyState}get url(){return this._url}setSocket(e,r,i){let n=new By({binaryType:this.binaryType,extensions:this._extensions,isServer:this._isServer,maxPayload:i.maxPayload,skipUTF8Validation:i.skipUTF8Validation});this._sender=new ky(e,this._extensions,i.generateMask),this._receiver=n,this._socket=e,n[xe]=this,e[xe]=this,n.on("conclude",Yy),n.on("drain",Xy),n.on("error",Qy),n.on("message",eC),n.on("ping",tC),n.on("pong",rC),e.setTimeout(0),e.setNoDelay(),r.length>0&&e.unshift(r),e.on("close",l2),e.on("data",zr),e.on("end",c2),e.on("error",f2),this._readyState=$.OPEN,this.emit("open")}emitClose(){if(!this._socket){this._readyState=$.CLOSED,this.emit("close",this._closeCode,this._closeMessage);return}this._extensions[it.extensionName]&&this._extensions[it.extensionName].cleanup(),this._receiver.removeAllListeners(),this._readyState=$.CLOSED,this.emit("close",this._closeCode,this._closeMessage)}close(e,r){if(this.readyState!==$.CLOSED){if(this.readyState===$.CONNECTING){let i="WebSocket was closed before the connection was established";return Ne(this,this._req,i)}if(this.readyState===$.CLOSING){this._closeFrameSent&&(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end();return}this._readyState=$.CLOSING,this._sender.close(e,r,!this._isServer,i=>{i||(this._closeFrameSent=!0,(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end())}),this._closeTimer=setTimeout(this._socket.destroy.bind(this._socket),Zy)}}pause(){this.readyState===$.CONNECTING||this.readyState===$.CLOSED||(this._paused=!0,this._socket.pause())}ping(e,r,i){if(this.readyState===$.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof e=="function"?(i=e,e=r=void 0):typeof r=="function"&&(i=r,r=void 0),typeof e=="number"&&(e=e.toString()),this.readyState!==$.OPEN){hn(this,e,i);return}r===void 0&&(r=!this._isServer),this._sender.ping(e||Gr,r,i)}pong(e,r,i){if(this.readyState===$.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof e=="function"?(i=e,e=r=void 0):typeof r=="function"&&(i=r,r=void 0),typeof e=="number"&&(e=e.toString()),this.readyState!==$.OPEN){hn(this,e,i);return}r===void 0&&(r=!this._isServer),this._sender.pong(e||Gr,r,i)}resume(){this.readyState===$.CONNECTING||this.readyState===$.CLOSED||(this._paused=!1,this._receiver._writableState.needDrain||this._socket.resume())}send(e,r,i){if(this.readyState===$.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof r=="function"&&(i=r,r={}),typeof e=="number"&&(e=e.toString()),this.readyState!==$.OPEN){hn(this,e,i);return}let n={binary:typeof e!="string",mask:!this._isServer,compress:!0,fin:!0,...r};this._extensions[it.extensionName]||(n.compress=!1),this._sender.send(e||Gr,n,i)}terminate(){if(this.readyState!==$.CLOSED){if(this.readyState===$.CONNECTING){let e="WebSocket was closed before the connection was established";return Ne(this,this._req,e)}this._socket&&(this._readyState=$.CLOSING,this._socket.destroy())}}};Object.defineProperty($,"CONNECTING",{enumerable:!0,value:Ve.indexOf("CONNECTING")});Object.defineProperty($.prototype,"CONNECTING",{enumerable:!0,value:Ve.indexOf("CONNECTING")});Object.defineProperty($,"OPEN",{enumerable:!0,value:Ve.indexOf("OPEN")});Object.defineProperty($.prototype,"OPEN",{enumerable:!0,value:Ve.indexOf("OPEN")});Object.defineProperty($,"CLOSING",{enumerable:!0,value:Ve.indexOf("CLOSING")});Object.defineProperty($.prototype,"CLOSING",{enumerable:!0,value:Ve.indexOf("CLOSING")});Object.defineProperty($,"CLOSED",{enumerable:!0,value:Ve.indexOf("CLOSED")});Object.defineProperty($.prototype,"CLOSED",{enumerable:!0,value:Ve.indexOf("CLOSED")});["binaryType","bufferedAmount","extensions","isPaused","protocol","readyState","url"].forEach(t=>{Object.defineProperty($.prototype,t,{enumerable:!0})});["open","error","close","message"].forEach(t=>{Object.defineProperty($.prototype,`on${t}`,{enumerable:!0,get(){for(let e of this.listeners(t))if(e[cn])return e[Uy];return null},set(e){for(let r of this.listeners(t))if(r[cn]){this.removeListener(t,r);break}typeof e=="function"&&this.addEventListener(t,e,{[cn]:!0})}})});$.prototype.addEventListener=Gy;$.prototype.removeEventListener=Hy;h2.exports=$;function o2(t,e,r,i){let n={protocolVersion:fn[1],maxPayload:100*1024*1024,skipUTF8Validation:!1,perMessageDeflate:!0,followRedirects:!1,maxRedirects:10,...i,createConnection:void 0,socketPath:void 0,hostname:void 0,protocol:void 0,timeout:void 0,method:"GET",host:void 0,path:void 0,port:void 0};if(!fn.includes(n.protocolVersion))throw new RangeError(`Unsupported protocol version: ${n.protocolVersion} (supported versions: ${fn.join(", ")})`);let s;if(e instanceof ln)s=e,t._url=e.href;else{try{s=new ln(e)}catch(k){throw new SyntaxError(`Invalid URL: ${e}`)}t._url=e}let h=s.protocol==="wss:",f=s.protocol==="ws+unix:",l;if(s.protocol!=="ws:"&&!h&&!f?l=`The URL's protocol must be one of "ws:", "wss:", or "ws+unix:"`:f&&!s.pathname?l="The URL's pathname is empty":s.hash&&(l="The URL contains a fragment identifier"),l){let k=new SyntaxError(l);if(t._redirects===0)throw k;Hr(t,k);return}let p=h?443:80,g=Dy(16).toString("base64"),x=h?Py.request:Ly.request,D=new Set,B;if(n.createConnection=h?Jy:Ky,n.defaultPort=n.defaultPort||p,n.port=s.port||p,n.host=s.hostname.startsWith("[")?s.hostname.slice(1,-1):s.hostname,n.headers={...n.headers,"Sec-WebSocket-Version":n.protocolVersion,"Sec-WebSocket-Key":g,Connection:"Upgrade",Upgrade:"websocket"},n.path=s.pathname+s.search,n.timeout=n.handshakeTimeout,n.perMessageDeflate&&(B=new it(n.perMessageDeflate!==!0?n.perMessageDeflate:{},!1,n.maxPayload),n.headers["Sec-WebSocket-Extensions"]=zy({[it.extensionName]:B.offer()})),r.length){for(let k of r){if(typeof k!="string"||!Vy.test(k)||D.has(k))throw new SyntaxError("An invalid or duplicated subprotocol was specified");D.add(k)}n.headers["Sec-WebSocket-Protocol"]=r.join(",")}if(n.origin&&(n.protocolVersion<13?n.headers["Sec-WebSocket-Origin"]=n.origin:n.headers.Origin=n.origin),(s.username||s.password)&&(n.auth=`${s.username}:${s.password}`),f){let k=n.path.split(":");n.socketPath=k[0],n.path=k[1]}let R;if(n.followRedirects){if(t._redirects===0){t._originalIpc=f,t._originalSecure=h,t._originalHostOrSocketPath=f?n.socketPath:s.host;let k=i&&i.headers;if(i={...i,headers:{}},k)for(let[j,Z]of Object.entries(k))i.headers[j.toLowerCase()]=Z}else if(t.listenerCount("redirect")===0){let k=f?t._originalIpc?n.socketPath===t._originalHostOrSocketPath:!1:t._originalIpc?!1:s.host===t._originalHostOrSocketPath;(!k||t._originalSecure&&!h)&&(delete n.headers.authorization,delete n.headers.cookie,k||delete n.headers.host,n.auth=void 0)}n.auth&&!i.headers.authorization&&(i.headers.authorization="Basic "+Buffer.from(n.auth).toString("base64")),R=t._req=x(n),t._redirects&&t.emit("redirect",t.url,R)}else R=t._req=x(n);n.timeout&&R.on("timeout",()=>{Ne(t,R,"Opening handshake has timed out")}),R.on("error",k=>{R===null||R[s2]||(R=t._req=null,Hr(t,k))}),R.on("response",k=>{let j=k.headers.location,Z=k.statusCode;if(j&&n.followRedirects&&Z>=300&&Z<400){if(++t._redirects>n.maxRedirects){Ne(t,R,"Maximum redirects exceeded");return}R.abort();let I;try{I=new ln(j,e)}catch(Y){let X=new SyntaxError(`Invalid URL: ${j}`);Hr(t,X);return}o2(t,I,r,i)}else t.emit("unexpected-response",R,k)||Ne(t,R,`Unexpected server response: ${k.statusCode}`)}),R.on("upgrade",(k,j,Z)=>{if(t.emit("upgrade",k),t.readyState!==$.CONNECTING)return;if(R=t._req=null,k.headers.upgrade.toLowerCase()!=="websocket"){Ne(t,j,"Invalid Upgrade header");return}let I=Ry("sha1").update(g+Fy).digest("base64");if(k.headers["sec-websocket-accept"]!==I){Ne(t,j,"Invalid Sec-WebSocket-Accept header");return}let Y=k.headers["sec-websocket-protocol"],X;if(Y!==void 0?D.size?D.has(Y)||(X="Server sent an invalid subprotocol"):X="Server sent a subprotocol but none was requested":D.size&&(X="Server sent no subprotocol"),X){Ne(t,j,X);return}Y&&(t._protocol=Y);let ue=k.headers["sec-websocket-extensions"];if(ue!==void 0){if(!B){Ne(t,j,"Server sent a Sec-WebSocket-Extensions header but no extension was requested");return}let ie;try{ie=Wy(ue)}catch(u){Ne(t,j,"Invalid Sec-WebSocket-Extensions header");return}let ce=Object.keys(ie);if(ce.length!==1||ce[0]!==it.extensionName){Ne(t,j,"Server indicated an extension that was not requested");return}try{B.accept(ie[it.extensionName])}catch(u){Ne(t,j,"Invalid Sec-WebSocket-Extensions header");return}t._extensions[it.extensionName]=B}t.setSocket(j,Z,{generateMask:n.generateMask,maxPayload:n.maxPayload,skipUTF8Validation:n.skipUTF8Validation})}),R.end()}function Hr(t,e){t._readyState=$.CLOSING,t.emit("error",e),t.emitClose()}function Ky(t){return t.path=t.socketPath,r2.connect(t)}function Jy(t){return t.path=void 0,!t.servername&&t.servername!==""&&(t.servername=r2.isIP(t.host)?"":t.host),My.connect(t)}function Ne(t,e,r){t._readyState=$.CLOSING;let i=new Error(r);Error.captureStackTrace(i,Ne),e.setHeader?(e[s2]=!0,e.abort(),e.socket&&!e.socket.destroyed&&e.socket.destroy(),process.nextTick(Hr,t,i)):(e.destroy(i),e.once("error",t.emit.bind(t,"error")),e.once("close",t.emitClose.bind(t)))}function hn(t,e,r){if(e){let i=$y(e).length;t._socket?t._sender._bufferedBytes+=i:t._bufferedAmount+=i}if(r){let i=new Error(`WebSocket is not open: readyState ${t.readyState} (${Ve[t.readyState]})`);r(i)}}function Yy(t,e){let r=this[xe];r._closeFrameReceived=!0,r._closeMessage=e,r._closeCode=t,r._socket[xe]!==void 0&&(r._socket.removeListener("data",zr),process.nextTick(u2,r._socket),t===1005?r.close():r.close(t,e))}function Xy(){let t=this[xe];t.isPaused||t._socket.resume()}function Qy(t){let e=this[xe];e._socket[xe]!==void 0&&(e._socket.removeListener("data",zr),process.nextTick(u2,e._socket),e.close(t[jy])),e.emit("error",t)}function a2(){this[xe].emitClose()}function eC(t,e){this[xe].emit("message",t,e)}function tC(t){let e=this[xe];e.pong(t,!e._isServer,n2),e.emit("ping",t)}function rC(t){this[xe].emit("pong",t)}function u2(t){t.resume()}function l2(){let t=this[xe];this.removeListener("close",l2),this.removeListener("data",zr),this.removeListener("end",c2),t._readyState=$.CLOSING;let e;!this._readableState.endEmitted&&!t._closeFrameReceived&&!t._receiver._writableState.errorEmitted&&(e=t._socket.read())!==null&&t._receiver.write(e),t._receiver.end(),this[xe]=void 0,clearTimeout(t._closeTimer),t._receiver._writableState.finished||t._receiver._writableState.errorEmitted?t.emitClose():(t._receiver.on("error",a2),t._receiver.on("finish",a2))}function zr(t){this[xe]._receiver.write(t)||this.pause()}function c2(){let t=this[xe];t._readyState=$.CLOSING,t._receiver.end(),this.end()}function f2(){let t=this[xe];this.removeListener("error",f2),this.on("error",n2),t&&(t._readyState=$.CLOSING,this.destroy())}});var d2=_((zS,p2)=>{"use strict";var{tokenChars:iC}=er();function nC(t){let e=new Set,r=-1,i=-1,n=0;for(n;n{"use strict";var sC=require("events"),Wr=require("http"),WS=require("https"),$S=require("net"),ZS=require("tls"),{createHash:oC}=require("crypto"),g2=un(),ft=Qt(),aC=d2(),uC=pn(),{GUID:lC,kWebSocket:cC}=et(),fC=/^[+/0-9A-Za-z]{22}==$/,m2=0,y2=1,C2=2,_2=class extends sC{constructor(e,r){super();if(e={maxPayload:100*1024*1024,skipUTF8Validation:!1,perMessageDeflate:!1,handleProtocols:null,clientTracking:!0,verifyClient:null,noServer:!1,backlog:null,server:null,host:null,path:null,port:null,WebSocket:uC,...e},e.port==null&&!e.server&&!e.noServer||e.port!=null&&(e.server||e.noServer)||e.server&&e.noServer)throw new TypeError('One and only one of the "port", "server", or "noServer" options must be specified');if(e.port!=null?(this._server=Wr.createServer((i,n)=>{let s=Wr.STATUS_CODES[426];n.writeHead(426,{"Content-Length":s.length,"Content-Type":"text/plain"}),n.end(s)}),this._server.listen(e.port,e.host,e.backlog,r)):e.server&&(this._server=e.server),this._server){let i=this.emit.bind(this,"connection");this._removeListeners=hC(this._server,{listening:this.emit.bind(this,"listening"),error:this.emit.bind(this,"error"),upgrade:(n,s,h)=>{this.handleUpgrade(n,s,h,i)}})}e.perMessageDeflate===!0&&(e.perMessageDeflate={}),e.clientTracking&&(this.clients=new Set,this._shouldEmitClose=!1),this.options=e,this._state=m2}address(){if(this.options.noServer)throw new Error('The server is operating in "noServer" mode');return this._server?this._server.address():null}close(e){if(this._state===C2){e&&this.once("close",()=>{e(new Error("The server is not running"))}),process.nextTick(sr,this);return}if(e&&this.once("close",e),this._state!==y2)if(this._state=y2,this.options.noServer||this.options.server)this._server&&(this._removeListeners(),this._removeListeners=this._server=null),this.clients?this.clients.size?this._shouldEmitClose=!0:process.nextTick(sr,this):process.nextTick(sr,this);else{let r=this._server;this._removeListeners(),this._removeListeners=this._server=null,r.close(()=>{sr(this)})}}shouldHandle(e){if(this.options.path){let r=e.url.indexOf("?");if((r!==-1?e.url.slice(0,r):e.url)!==this.options.path)return!1}return!0}handleUpgrade(e,r,i,n){r.on("error",v2);let s=e.headers["sec-websocket-key"],h=+e.headers["sec-websocket-version"];if(e.method!=="GET"){ht(this,e,r,405,"Invalid HTTP method");return}if(e.headers.upgrade.toLowerCase()!=="websocket"){ht(this,e,r,400,"Invalid Upgrade header");return}if(!s||!fC.test(s)){ht(this,e,r,400,"Missing or invalid Sec-WebSocket-Key header");return}if(h!==8&&h!==13){ht(this,e,r,400,"Missing or invalid Sec-WebSocket-Version header");return}if(!this.shouldHandle(e)){or(r,400);return}let f=e.headers["sec-websocket-protocol"],l=new Set;if(f!==void 0)try{l=aC.parse(f)}catch(x){ht(this,e,r,400,"Invalid Sec-WebSocket-Protocol header");return}let p=e.headers["sec-websocket-extensions"],g={};if(this.options.perMessageDeflate&&p!==void 0){let x=new ft(this.options.perMessageDeflate,!0,this.options.maxPayload);try{let D=g2.parse(p);D[ft.extensionName]&&(x.accept(D[ft.extensionName]),g[ft.extensionName]=x)}catch(D){ht(this,e,r,400,"Invalid or unacceptable Sec-WebSocket-Extensions header");return}}if(this.options.verifyClient){let x={origin:e.headers[`${h===8?"sec-websocket-origin":"origin"}`],secure:!!(e.socket.authorized||e.socket.encrypted),req:e};if(this.options.verifyClient.length===2){this.options.verifyClient(x,(D,B,R,k)=>{if(!D)return or(r,B||401,R,k);this.completeUpgrade(g,s,l,e,r,i,n)});return}if(!this.options.verifyClient(x))return or(r,401)}this.completeUpgrade(g,s,l,e,r,i,n)}completeUpgrade(e,r,i,n,s,h,f){if(!s.readable||!s.writable)return s.destroy();if(s[cC])throw new Error("server.handleUpgrade() was called more than once with the same socket, possibly due to a misconfiguration");if(this._state>m2)return or(s,503);let l=oC("sha1").update(r+lC).digest("base64"),p=["HTTP/1.1 101 Switching Protocols","Upgrade: websocket","Connection: Upgrade",`Sec-WebSocket-Accept: ${l}`],g=new this.options.WebSocket(null);if(i.size){let x=this.options.handleProtocols?this.options.handleProtocols(i,n):i.values().next().value;x&&(p.push(`Sec-WebSocket-Protocol: ${x}`),g._protocol=x)}if(e[ft.extensionName]){let x=e[ft.extensionName].params,D=g2.format({[ft.extensionName]:[x]});p.push(`Sec-WebSocket-Extensions: ${D}`),g._extensions=e}this.emit("headers",p,n),s.write(p.concat(`\r +`).join(`\r +`)),s.removeListener("error",v2),g.setSocket(s,h,{maxPayload:this.options.maxPayload,skipUTF8Validation:this.options.skipUTF8Validation}),this.clients&&(this.clients.add(g),g.on("close",()=>{this.clients.delete(g),this._shouldEmitClose&&!this.clients.size&&process.nextTick(sr,this)})),f(g,n)}};b2.exports=_2;function hC(t,e){for(let r of Object.keys(e))t.on(r,e[r]);return function(){for(let i of Object.keys(e))t.removeListener(i,e[i])}}function sr(t){t._state=C2,t.emit("close")}function v2(){this.destroy()}function or(t,e,r,i){r=r||Wr.STATUS_CODES[e],i={Connection:"close","Content-Type":"text/html","Content-Length":Buffer.byteLength(r),...i},t.once("finish",t.destroy),t.end(`HTTP/1.1 ${e} ${Wr.STATUS_CODES[e]}\r +`+Object.keys(i).map(n=>`${n}: ${i[n]}`).join(`\r +`)+`\r +\r +`+r)}function ht(t,e,r,i,n){if(t.listenerCount("wsClientError")){let s=new Error(n);Error.captureStackTrace(s,ht),t.emit("wsClientError",s,r,e)}else or(r,i,n)}});var T2=_((YS,$r)=>{var de=function(t){"use strict";var e=1e7,r=7,i=9007199254740992,n=D(i),s="0123456789abcdefghijklmnopqrstuvwxyz",h=typeof BigInt=="function";function f(o,a,y,b){return typeof o=="undefined"?f[0]:typeof a!="undefined"?+a==10&&!y?G(o):oe(o,a,y,b):G(o)}function l(o,a){this.value=o,this.sign=a,this.isSmall=!1}l.prototype=Object.create(f.prototype);function p(o){this.value=o,this.sign=o<0,this.isSmall=!0}p.prototype=Object.create(f.prototype);function g(o){this.value=o}g.prototype=Object.create(f.prototype);function x(o){return-i0?Math.floor(o):Math.ceil(o)}function Z(o,a){var y=o.length,b=a.length,q=new Array(y),O=0,P=e,N,M;for(M=0;M=P?1:0,q[M]=N-O*P;for(;M0&&q.push(O),q}function I(o,a){return o.length>=a.length?Z(o,a):Z(a,o)}function Y(o,a){var y=o.length,b=new Array(y),q=e,O,P;for(P=0;P0;)b[P++]=a%q,a=Math.floor(a/q);return b}l.prototype.add=function(o){var a=G(o);if(this.sign!==a.sign)return this.subtract(a.negate());var y=this.value,b=a.value;return a.isSmall?new l(Y(y,Math.abs(b)),this.sign):new l(I(y,b),this.sign)},l.prototype.plus=l.prototype.add,p.prototype.add=function(o){var a=G(o),y=this.value;if(y<0!==a.sign)return this.subtract(a.negate());var b=a.value;if(a.isSmall){if(x(y+b))return new p(y+b);b=D(Math.abs(b))}return new l(Y(b,Math.abs(y)),y<0)},p.prototype.plus=p.prototype.add,g.prototype.add=function(o){return new g(this.value+G(o).value)},g.prototype.plus=g.prototype.add;function X(o,a){var y=o.length,b=a.length,q=new Array(y),O=0,P=e,N,M;for(N=0;N=0?b=X(o,a):(b=X(a,o),y=!y),b=B(b),typeof b=="number"?(y&&(b=-b),new p(b)):new l(b,y)}function ie(o,a,y){var b=o.length,q=new Array(b),O=-a,P=e,N,M;for(N=0;N=0)},p.prototype.minus=p.prototype.subtract,g.prototype.subtract=function(o){return new g(this.value-G(o).value)},g.prototype.minus=g.prototype.subtract,l.prototype.negate=function(){return new l(this.value,!this.sign)},p.prototype.negate=function(){var o=this.sign,a=new p(-this.value);return a.sign=!o,a},g.prototype.negate=function(){return new g(-this.value)},l.prototype.abs=function(){return new l(this.value,!1)},p.prototype.abs=function(){return new p(Math.abs(this.value))},g.prototype.abs=function(){return new g(this.value>=0?this.value:-this.value)};function ce(o,a){var y=o.length,b=a.length,q=y+b,O=k(q),P=e,N,M,H,J,W;for(H=0;H0;)b[N++]=O%q,O=Math.floor(O/q);return b}function c(o,a){for(var y=[];a-- >0;)y.push(0);return y.concat(o)}function d(o,a){var y=Math.max(o.length,a.length);if(y<=30)return ce(o,a);y=Math.ceil(y/2);var b=o.slice(y),q=o.slice(0,y),O=a.slice(y),P=a.slice(0,y),N=d(q,P),M=d(b,O),H=d(I(q,b),I(P,O)),J=I(I(N,c(X(X(H,N),M),y)),c(M,2*y));return R(J),J}function v(o,a){return-.012*o-.012*a+15e-6*o*a>0}l.prototype.multiply=function(o){var a=G(o),y=this.value,b=a.value,q=this.sign!==a.sign,O;if(a.isSmall){if(b===0)return f[0];if(b===1)return this;if(b===-1)return this.negate();if(O=Math.abs(b),O=0;W--){for(J=q-1,M[W+b]!==P&&(J=Math.floor((M[W+b]*q+M[W+b-1])/P)),te=0,qe=0,Zr=H.length,Oe=0;Oeb&&(H=(H+1)*P),N=Math.ceil(H/J);do{if(W=u(a,N),E(W,O)<=0)break;N--}while(N);q.push(N),O=X(O,W)}return q.reverse(),[B(q),B(O)]}function w(o,a){var y=o.length,b=k(y),q=e,O,P,N,M;for(N=0,O=y-1;O>=0;--O)M=N*q+o[O],P=j(M/a),N=M-P*a,b[O]=P|0;return[b,N|0]}function A(o,a){var y,b=G(a);if(h)return[new g(o.value/b.value),new g(o.value%b.value)];var q=o.value,O=b.value,P;if(O===0)throw new Error("Cannot divide by zero");if(o.isSmall)return b.isSmall?[new p(j(q/O)),new p(q%O)]:[f[0],o];if(b.isSmall){if(O===1)return[o,f[0]];if(O==-1)return[o.negate(),f[0]];var N=Math.abs(O);if(Na.length?1:-1;for(var y=o.length-1;y>=0;y--)if(o[y]!==a[y])return o[y]>a[y]?1:-1;return 0}l.prototype.compareAbs=function(o){var a=G(o),y=this.value,b=a.value;return a.isSmall?1:E(y,b)},p.prototype.compareAbs=function(o){var a=G(o),y=Math.abs(this.value),b=a.value;return a.isSmall?(b=Math.abs(b),y===b?0:y>b?1:-1):-1},g.prototype.compareAbs=function(o){var a=this.value,y=G(o).value;return a=a>=0?a:-a,y=y>=0?y:-y,a===y?0:a>y?1:-1},l.prototype.compare=function(o){if(o===1/0)return-1;if(o===-1/0)return 1;var a=G(o),y=this.value,b=a.value;return this.sign!==a.sign?a.sign?1:-1:a.isSmall?this.sign?-1:1:E(y,b)*(this.sign?-1:1)},l.prototype.compareTo=l.prototype.compare,p.prototype.compare=function(o){if(o===1/0)return-1;if(o===-1/0)return 1;var a=G(o),y=this.value,b=a.value;return a.isSmall?y==b?0:y>b?1:-1:y<0!==a.sign?y<0?-1:1:y<0?1:-1},p.prototype.compareTo=p.prototype.compare,g.prototype.compare=function(o){if(o===1/0)return-1;if(o===-1/0)return 1;var a=this.value,y=G(o).value;return a===y?0:a>y?1:-1},g.prototype.compareTo=g.prototype.compare,l.prototype.equals=function(o){return this.compare(o)===0},g.prototype.eq=g.prototype.equals=p.prototype.eq=p.prototype.equals=l.prototype.eq=l.prototype.equals,l.prototype.notEquals=function(o){return this.compare(o)!==0},g.prototype.neq=g.prototype.notEquals=p.prototype.neq=p.prototype.notEquals=l.prototype.neq=l.prototype.notEquals,l.prototype.greater=function(o){return this.compare(o)>0},g.prototype.gt=g.prototype.greater=p.prototype.gt=p.prototype.greater=l.prototype.gt=l.prototype.greater,l.prototype.lesser=function(o){return this.compare(o)<0},g.prototype.lt=g.prototype.lesser=p.prototype.lt=p.prototype.lesser=l.prototype.lt=l.prototype.lesser,l.prototype.greaterOrEquals=function(o){return this.compare(o)>=0},g.prototype.geq=g.prototype.greaterOrEquals=p.prototype.geq=p.prototype.greaterOrEquals=l.prototype.geq=l.prototype.greaterOrEquals,l.prototype.lesserOrEquals=function(o){return this.compare(o)<=0},g.prototype.leq=g.prototype.lesserOrEquals=p.prototype.leq=p.prototype.lesserOrEquals=l.prototype.leq=l.prototype.lesserOrEquals,l.prototype.isEven=function(){return(this.value[0]&1)==0},p.prototype.isEven=function(){return(this.value&1)==0},g.prototype.isEven=function(){return(this.value&BigInt(1))===BigInt(0)},l.prototype.isOdd=function(){return(this.value[0]&1)==1},p.prototype.isOdd=function(){return(this.value&1)==1},g.prototype.isOdd=function(){return(this.value&BigInt(1))===BigInt(1)},l.prototype.isPositive=function(){return!this.sign},p.prototype.isPositive=function(){return this.value>0},g.prototype.isPositive=p.prototype.isPositive,l.prototype.isNegative=function(){return this.sign},p.prototype.isNegative=function(){return this.value<0},g.prototype.isNegative=p.prototype.isNegative,l.prototype.isUnit=function(){return!1},p.prototype.isUnit=function(){return Math.abs(this.value)===1},g.prototype.isUnit=function(){return this.abs().value===BigInt(1)},l.prototype.isZero=function(){return!1},p.prototype.isZero=function(){return this.value===0},g.prototype.isZero=function(){return this.value===BigInt(0)},l.prototype.isDivisibleBy=function(o){var a=G(o);return a.isZero()?!1:a.isUnit()?!0:a.compareAbs(2)===0?this.isEven():this.mod(a).isZero()},g.prototype.isDivisibleBy=p.prototype.isDivisibleBy=l.prototype.isDivisibleBy;function L(o){var a=o.abs();if(a.isUnit())return!1;if(a.equals(2)||a.equals(3)||a.equals(5))return!0;if(a.isEven()||a.isDivisibleBy(3)||a.isDivisibleBy(5))return!1;if(a.lesser(49))return!0}function U(o,a){for(var y=o.prev(),b=y,q=0,O,P,N,M;b.isEven();)b=b.divide(2),q++;e:for(N=0;N-i?new p(o-1):new l(n,!0)},g.prototype.prev=function(){return new g(this.value-BigInt(1))};for(var F=[1];2*F[F.length-1]<=e;)F.push(2*F[F.length-1]);var V=F.length,ee=F[V-1];function fe(o){return Math.abs(o)<=e}l.prototype.shiftLeft=function(o){var a=G(o).toJSNumber();if(!fe(a))throw new Error(String(a)+" is too large for shifting.");if(a<0)return this.shiftRight(-a);var y=this;if(y.isZero())return y;for(;a>=V;)y=y.multiply(ee),a-=V-1;return y.multiply(F[a])},g.prototype.shiftLeft=p.prototype.shiftLeft=l.prototype.shiftLeft,l.prototype.shiftRight=function(o){var a,y=G(o).toJSNumber();if(!fe(y))throw new Error(String(y)+" is too large for shifting.");if(y<0)return this.shiftLeft(-y);for(var b=this;y>=V;){if(b.isZero()||b.isNegative()&&b.isUnit())return b;a=A(b,ee),b=a[1].isNegative()?a[0].prev():a[0],y-=V-1}return a=A(b,F[y]),a[1].isNegative()?a[0].prev():a[0]},g.prototype.shiftRight=p.prototype.shiftRight=l.prototype.shiftRight;function K(o,a,y){a=G(a);for(var b=o.isNegative(),q=a.isNegative(),O=b?o.not():o,P=q?a.not():a,N=0,M=0,H=null,J=null,W=[];!O.isZero()||!P.isZero();)H=A(O,ee),N=H[1].toJSNumber(),b&&(N=ee-1-N),J=A(P,ee),M=J[1].toJSNumber(),q&&(M=ee-1-M),O=H[0],P=J[0],W.push(y(N,M));for(var te=y(b?1:0,q?1:0)!==0?de(-1):de(0),qe=W.length-1;qe>=0;qe-=1)te=te.multiply(ee).add(de(W[qe]));return te}l.prototype.not=function(){return this.negate().prev()},g.prototype.not=p.prototype.not=l.prototype.not,l.prototype.and=function(o){return K(this,o,function(a,y){return a&y})},g.prototype.and=p.prototype.and=l.prototype.and,l.prototype.or=function(o){return K(this,o,function(a,y){return a|y})},g.prototype.or=p.prototype.or=l.prototype.or,l.prototype.xor=function(o){return K(this,o,function(a,y){return a^y})},g.prototype.xor=p.prototype.xor=l.prototype.xor;var Q=1<<30,ge=(e&-e)*(e&-e)|Q;function ze(o){var a=o.value,y=typeof a=="number"?a|Q:typeof a=="bigint"?a|BigInt(Q):a[0]+a[1]*e|ge;return y&-y}function pt(o,a){if(a.compareTo(o)<=0){var y=pt(o,a.square(a)),b=y.p,q=y.e,O=b.multiply(a);return O.compareTo(o)<=0?{p:O,e:q*2+1}:{p:b,e:q*2}}return{p:de(1),e:0}}l.prototype.bitLength=function(){var o=this;return o.compareTo(de(0))<0&&(o=o.negate().subtract(de(1))),o.compareTo(de(0))===0?de(0):de(pt(o,de(2)).e).add(de(1))},g.prototype.bitLength=p.prototype.bitLength=l.prototype.bitLength;function dt(o,a){return o=G(o),a=G(a),o.greater(a)?o:a}function we(o,a){return o=G(o),a=G(a),o.lesser(a)?o:a}function Ke(o,a){if(o=G(o).abs(),a=G(a).abs(),o.equals(a))return o;if(o.isZero())return a;if(a.isZero())return o;for(var y=f[1],b,q;o.isEven()&&a.isEven();)b=we(ze(o),ze(a)),o=o.divide(b),a=a.divide(b),y=y.multiply(b);for(;o.isEven();)o=o.divide(ze(o));do{for(;a.isEven();)a=a.divide(ze(a));o.greater(a)&&(q=a,a=o,o=q),a=a.subtract(o)}while(!a.isZero());return y.isUnit()?o:o.multiply(y)}function Ee(o,a){return o=G(o).abs(),a=G(a).abs(),o.divide(Ke(o,a)).multiply(a)}function Ce(o,a,y){o=G(o),a=G(a);var b=y||Math.random,q=we(o,a),O=dt(o,a),P=O.subtract(q).add(1);if(P.isSmall)return q.add(Math.floor(b()*P));for(var N=Mt(P,e).value,M=[],H=!0,J=0;J=P){if(M==="1"&&P===1)continue;throw new Error(M+" is not a valid digit in base "+a+".")}}a=G(a);var H=[],J=o[0]==="-";for(O=J?1:0;O"&&O=0;O--)b=b.add(o[O].times(q)),q=q.times(a);return y?b.negate():b}function M2(o,a){return a=a||s,o"}function Mt(o,a){if(a=de(a),a.isZero()){if(o.isZero())return{value:[0],isNegative:!1};throw new Error("Cannot convert nonzero numbers to base 0.")}if(a.equals(-1)){if(o.isZero())return{value:[0],isNegative:!1};if(o.isNegative())return{value:[].concat.apply([],Array.apply(null,Array(-o.toJSNumber())).map(Array.prototype.valueOf,[1,0])),isNegative:!1};var y=Array.apply(null,Array(o.toJSNumber()-1)).map(Array.prototype.valueOf,[0,1]);return y.unshift([1]),{value:[].concat.apply([],y),isNegative:!1}}var b=!1;if(o.isNegative()&&a.isPositive()&&(b=!0,o=o.abs()),a.isUnit())return o.isZero()?{value:[0],isNegative:!1}:{value:Array.apply(null,Array(o.toJSNumber())).map(Number.prototype.valueOf,1),isNegative:b};for(var q=[],O=o,P;O.isNegative()||O.compareAbs(a)>=0;){P=O.divmod(a),O=P.quotient;var N=P.remainder;N.isNegative()&&(N=a.minus(N).abs(),O=O.next()),q.push(N.toJSNumber())}return q.push(O.toJSNumber()),{value:q.reverse(),isNegative:b}}function vn(o,a,y){var b=Mt(o,a);return(b.isNegative?"-":"")+b.value.map(function(q){return M2(q,y)}).join("")}l.prototype.toArray=function(o){return Mt(this,o)},p.prototype.toArray=function(o){return Mt(this,o)},g.prototype.toArray=function(o){return Mt(this,o)},l.prototype.toString=function(o,a){if(o===t&&(o=10),o!==10)return vn(this,o,a);for(var y=this.value,b=y.length,q=String(y[--b]),O="0000000",P;--b>=0;)P=String(y[b]),q+=O.slice(P.length)+P;var N=this.sign?"-":"";return N+q},p.prototype.toString=function(o,a){return o===t&&(o=10),o!=10?vn(this,o,a):String(this.value)},g.prototype.toString=p.prototype.toString,g.prototype.toJSON=l.prototype.toJSON=p.prototype.toJSON=function(){return this.toString()},l.prototype.valueOf=function(){return parseInt(this.toString(),10)},l.prototype.toJSNumber=l.prototype.valueOf,p.prototype.valueOf=function(){return this.value},p.prototype.toJSNumber=p.prototype.valueOf,g.prototype.valueOf=g.prototype.toJSNumber=function(){return parseInt(this.toString(),10)};function bn(o){if(x(+o)){var a=+o;if(a===j(a))return h?new g(BigInt(a)):new p(a);throw new Error("Invalid integer: "+o)}var y=o[0]==="-";y&&(o=o.slice(1));var b=o.split(/e/i);if(b.length>2)throw new Error("Invalid integer: "+b.join("e"));if(b.length===2){var q=b[1];if(q[0]==="+"&&(q=q.slice(1)),q=+q,q!==j(q)||!x(q))throw new Error("Invalid integer: "+q+" is not a valid exponent.");var O=b[0],P=O.indexOf(".");if(P>=0&&(q-=O.length-P-1,O=O.slice(0,P)+O.slice(P+1)),q<0)throw new Error("Cannot include negative exponent part for integers");O+=new Array(q+1).join("0"),o=O}var N=/^([0-9][0-9]*)$/.test(o);if(!N)throw new Error("Invalid integer: "+o);if(h)return new g(BigInt(y?"-"+o:o));for(var M=[],H=o.length,J=r,W=H-J;H>0;)M.push(+o.slice(W,H)),W-=J,W<0&&(W=0),H-=J;return R(M),new l(M,y)}function D2(o){if(h)return new g(BigInt(o));if(x(o)){if(o!==j(o))throw new Error(o+" is not an integer.");return new p(o)}return bn(o.toString())}function G(o){return typeof o=="number"?D2(o):typeof o=="string"?bn(o):typeof o=="bigint"?new g(o):o}for(var st=0;st<1e3;st++)f[st]=G(st),st>0&&(f[-st]=G(-st));return f.one=f[1],f.zero=f[0],f.minusOne=f[-1],f.max=dt,f.min=we,f.gcd=Ke,f.lcm=Ee,f.isInstance=function(o){return o instanceof l||o instanceof p||o instanceof g},f.randBetween=Ce,f.fromArray=function(o,a,y){return _n(o.map(G),G(a||10),y)},f}();typeof $r!="undefined"&&$r.hasOwnProperty("exports")&&($r.exports=de);typeof define=="function"&&define.amd&&define(function(){return de})});var I2=_(he=>{"use strict";var A2=require("fs"),yC=T2(),nt=!1;he.maxObjectSize=100*1e3*1e3;he.maxObjectCount=32768;var CC=9783072e5,_C=he.UID=function(t){this.UID=t};he.parseFile=function(t,e){return new Promise(function(r,i){function n(s){let h=null,f;try{f=q2(s),r(f)}catch(l){h=l,i(h)}finally{e&&e(h,f)}}if(Buffer.isBuffer(t))return n(t);A2.readFile(t,function(s,h){if(s)return i(s),e(s);n(h)})})};he.parseFileSync=function(t){return Buffer.isBuffer(t)||(t=A2.readFileSync(t)),q2(t)};var q2=he.parseBuffer=function(t){if(t.slice(0,"bplist".length).toString("utf8")!=="bplist")throw new Error("Invalid binary plist. Expected 'bplist' at offset 0.");let r=t.slice(t.length-32,t.length),i=r.readUInt8(6);nt&&console.log("offsetSize: "+i);let n=r.readUInt8(7);nt&&console.log("objectRefSize: "+n);let s=dn(r,8);nt&&console.log("numObjects: "+s);let h=dn(r,16);nt&&console.log("topObject: "+h);let f=dn(r,24);if(nt&&console.log("offsetTableOffset: "+f),s>he.maxObjectCount)throw new Error("maxObjectCount exceeded");let l=[];for(let g=0;g>4,R=D&15;switch(B){case 0:return k();case 1:return Z();case 8:return I();case 2:return Y();case 3:return X();case 4:return ue();case 5:return ie();case 6:return ie(!0);case 10:return ce();case 13:return u();default:throw new Error("Unhandled type 0x"+B.toString(16))}function k(){switch(R){case 0:return null;case 8:return!1;case 9:return!0;case 15:return null;default:throw new Error("Unhandled simple type 0x"+B.toString(16))}}function j(c){let d="",v;for(v=0;v(v<<=8,v|=m&255,v))}throw new Error("Too little heap space available! Wanted to read "+c+" bytes, but only "+he.maxObjectSize+" are available.")}function I(){let c=R+1;if(che.maxObjectSize)throw new Error("Too little heap space available!");let v=[];for(let m=0;mhe.maxObjectSize)throw new Error("Too little heap space available!");nt&&console.log("Parsing dictionary #"+g);let v={};for(let m=0;mCn});var ne=ae(require("obsidian"));var Sn=ae(require("url"));var Kr=class{EspaceFineDisponible(){return!1}JeTraiteLesInsecables(){return!0}},ur=class{constructor(e,r,i,n){this.texte=e,r?this.selDebut=r:this.selDebut=0,i?this.selFin=i:this.selFin=0,this.selFinn([new ur(e,0,0,"0")]));let i=r.map((n,s)=>{let h=n.head,f=n.anchor;return new ur(e,this.PositionAbsolue(h),this.PositionAbsolue(f),s.toString())});return new Promise(n=>n(i))}PeutCorriger(e,r,i,n){if(!this.DocEstDisponible())return!1;let s=this.PositionObsidian(r),h=this.PositionObsidian(i),f=this.mdView.editor.getRange(s,h)==n,l=!0;return f||(h=this.PositionObsidian(i+1),l=this.mdView.editor.getRange(s,h).startsWith(n)),f||l}DocEstDisponible(){let e=!1;return this.mdView.app.workspace.iterateAllLeaves(r=>{e=e||r.view===this.mdView}),e}CorrigeDansTexteur(e,r,i,n,s){let h=this.PositionObsidian(r),f=this.PositionObsidian(i);return new Promise(l=>{this.mdView.editor.replaceRange(n,h,f),l(!0)})}RetourneAuTexteur(){this.MetsFocusSurLeDocument()}MetsFocusSurLeDocument(){let e=!1;if(this.mdView.app.workspace.iterateAllLeaves(i=>{i.view===this.mdView&&(e=i)}),e){this.mdView.app.workspace.revealLeaf(e);return}let r=this.mdView.app.vault.getAbstractFileByPath(this.documentPath);this.mdView.app.workspace.getLeaf(!0).openFile(r)}SelectionneIntervalle(e,r,i){this.MetsFocusSurLeDocument(),this.mdView.editor.setSelection(this.PositionObsidian(r),this.PositionObsidian(i))}};var wn=` + + + + + + + + + + + + + + + + + + + + + +`;var En=` + + + + + + + +`;var Wi=ae(dr()),Xl=ae(bo()),$i=ae(No());var oa=ae(sa()),Q8=(t,e)=>{let r=[],i=[];return r.push(e),e||r.push(t.locale),t.enableFallback&&r.push(t.defaultLocale),r.filter(Boolean).map(n=>n.toString()).forEach(function(n){if(i.includes(n)||i.push(n),!t.enableFallback)return;let s=n.split("-");s.length===3&&i.push(`${s[0]}-${s[1]}`),i.push(s[0])}),(0,oa.default)(i)},_r=class{constructor(e){this.i18n=e,this.registry={},this.register("default",Q8)}register(e,r){if(typeof r!="function"){let i=r;r=()=>i}this.registry[e]=r}get(e){let r=this.registry[e]||this.registry[this.i18n.locale]||this.registry.default;return typeof r=="function"&&(r=r(this.i18n,e)),r instanceof Array||(r=[r]),r}};var e7=(t,e)=>{switch(e){case 0:return["zero","other"];case 1:return["one"];default:return["other"]}},vr=class{constructor(e){this.i18n=e,this.registry={},this.register("default",e7)}register(e,r){this.registry[e]=r}get(e){return this.registry[e]||this.registry[this.i18n.locale]||this.registry.default}};var p1=ae(h1());function Me(t){return t?Object.keys(t).reduce((e,r)=>(e[(0,p1.default)(r)]=t[r],e),{}):{}}function Se(t){return t!=null}function pi(t,e,r){let i=[{scope:e}];if(Se(r.defaults)&&(i=i.concat(r.defaults)),Se(r.defaultValue)){let n=typeof r.defaultValue=="function"?r.defaultValue(t,e,r):r.defaultValue;i.push({message:n}),delete r.defaultValue}return i}var H6=/^-?(?:\d+(?:\.\d*)?|\.\d+)(?:e[+-]?\d+)?$/i,di=Math.ceil,Ge=Math.floor,Te="[BigNumber Error] ",d1=Te+"Number primitive has more than 15 significant digits: ",ke=1e14,z=14,gi=9007199254740991,mi=[1,10,100,1e3,1e4,1e5,1e6,1e7,1e8,1e9,1e10,1e11,1e12,1e13],Xe=1e7,me=1e9;function g1(t){var e,r,i,n=I.prototype={constructor:I,toString:null,valueOf:null},s=new I(1),h=20,f=4,l=-7,p=21,g=-1e7,x=1e7,D=!1,B=1,R=0,k={prefix:"",groupSize:3,secondaryGroupSize:0,groupSeparator:",",decimalSeparator:".",fractionGroupSize:0,fractionGroupSeparator:"\xA0",suffix:""},j="0123456789abcdefghijklmnopqrstuvwxyz",Z=!0;function I(u,c){var d,v,m,S,T,C,w,A,E=this;if(!(E instanceof I))return new I(u,c);if(c==null){if(u&&u._isBigNumber===!0){E.s=u.s,!u.c||u.e>x?E.c=E.e=null:u.e=10;T/=10,S++);S>x?E.c=E.e=null:(E.e=S,E.c=[u]);return}A=String(u)}else{if(!H6.test(A=String(u)))return i(E,A,C);E.s=A.charCodeAt(0)==45?(A=A.slice(1),-1):1}(S=A.indexOf("."))>-1&&(A=A.replace(".","")),(T=A.search(/e/i))>0?(S<0&&(S=T),S+=+A.slice(T+1),A=A.substring(0,T)):S<0&&(S=A.length)}else{if(le(c,2,j.length,"Base"),c==10&&Z)return E=new I(u),ie(E,h+E.e+1,f);if(A=String(u),C=typeof u=="number"){if(u*0!=0)return i(E,A,C,c);if(E.s=1/u<0?(A=A.slice(1),-1):1,I.DEBUG&&A.replace(/^0\.0*|\./,"").length>15)throw Error(d1+u)}else E.s=A.charCodeAt(0)===45?(A=A.slice(1),-1):1;for(d=j.slice(0,c),S=T=0,w=A.length;TS){S=w;continue}}else if(!m&&(A==A.toUpperCase()&&(A=A.toLowerCase())||A==A.toLowerCase()&&(A=A.toUpperCase()))){m=!0,T=-1,S=0;continue}return i(E,String(u),C,c)}C=!1,A=r(A,c,10,E.s),(S=A.indexOf("."))>-1?A=A.replace(".",""):S=A.length}for(T=0;A.charCodeAt(T)===48;T++);for(w=A.length;A.charCodeAt(--w)===48;);if(A=A.slice(T,++w)){if(w-=T,C&&I.DEBUG&&w>15&&(u>gi||u!==Ge(u)))throw Error(d1+E.s*u);if((S=S-T-1)>x)E.c=E.e=null;else if(S=-me&&m<=me&&m===Ge(m)){if(v[0]===0){if(m===0&&v.length===1)return!0;break e}if(c=(m+1)%z,c<1&&(c+=z),String(v[0]).length==c){for(c=0;c=ke||d!==Ge(d))break e;if(d!==0)return!0}}}else if(v===null&&m===null&&(S===null||S===1||S===-1))return!0;throw Error(Te+"Invalid BigNumber: "+u)},I.maximum=I.max=function(){return X(arguments,n.lt)},I.minimum=I.min=function(){return X(arguments,n.gt)},I.random=function(){var u=9007199254740992,c=Math.random()*u&2097151?function(){return Ge(Math.random()*u)}:function(){return(Math.random()*1073741824|0)*8388608+(Math.random()*8388608|0)};return function(d){var v,m,S,T,C,w=0,A=[],E=new I(s);if(d==null?d=h:le(d,0,me),T=di(d/z),D)if(crypto.getRandomValues){for(v=crypto.getRandomValues(new Uint32Array(T*=2));w>>11),C>=9e15?(m=crypto.getRandomValues(new Uint32Array(2)),v[w]=m[0],v[w+1]=m[1]):(A.push(C%1e14),w+=2);w=T/2}else if(crypto.randomBytes){for(v=crypto.randomBytes(T*=7);w=9e15?crypto.randomBytes(7).copy(v,w):(A.push(C%1e14),w+=7);w=T/7}else throw D=!1,Error(Te+"crypto unavailable");if(!D)for(;w=10;C/=10,w++);wm-1&&(C[T+1]==null&&(C[T+1]=0),C[T+1]+=C[T]/m|0,C[T]%=m)}return C.reverse()}return function(d,v,m,S,T){var C,w,A,E,L,U,F,V,ee=d.indexOf("."),fe=h,K=f;for(ee>=0&&(E=R,R=0,d=d.replace(".",""),V=new I(v),U=V.pow(d.length-ee),R=E,V.c=c(We(Re(U.c),U.e,"0"),10,m,u),V.e=V.c.length),F=c(d,v,m,T?(C=j,u):(C=u,j)),A=E=F.length;F[--E]==0;F.pop());if(!F[0])return C.charAt(0);if(ee<0?--A:(U.c=F,U.e=A,U.s=S,U=e(U,V,fe,K,m),F=U.c,L=U.r,A=U.e),w=A+fe+1,ee=F[w],E=m/2,L=L||w<0||F[w+1]!=null,L=K<4?(ee!=null||L)&&(K==0||K==(U.s<0?3:2)):ee>E||ee==E&&(K==4||L||K==6&&F[w-1]&1||K==(U.s<0?8:7)),w<1||!F[0])d=L?We(C.charAt(1),-fe,C.charAt(0)):C.charAt(0);else{if(F.length=w,L)for(--m;++F[--w]>m;)F[w]=0,w||(++A,F=[1].concat(F));for(E=F.length;!F[--E];);for(ee=0,d="";ee<=E;d+=C.charAt(F[ee++]));d=We(d,A,C.charAt(0))}return d}}(),e=function(){function u(v,m,S){var T,C,w,A,E=0,L=v.length,U=m%Xe,F=m/Xe|0;for(v=v.slice();L--;)w=v[L]%Xe,A=v[L]/Xe|0,T=F*w+A*U,C=U*w+T%Xe*Xe+E,E=(C/S|0)+(T/Xe|0)+F*A,v[L]=C%S;return E&&(v=[E].concat(v)),v}function c(v,m,S,T){var C,w;if(S!=T)w=S>T?1:-1;else for(C=w=0;Cm[C]?1:-1;break}return w}function d(v,m,S,T){for(var C=0;S--;)v[S]-=C,C=v[S]1;v.splice(0,1));}return function(v,m,S,T,C){var w,A,E,L,U,F,V,ee,fe,K,Q,ge,ze,pt,dt,we,Ke,Ee=v.s==m.s?1:-1,Ce=v.c,oe=m.c;if(!Ce||!Ce[0]||!oe||!oe[0])return new I(!v.s||!m.s||(Ce?oe&&Ce[0]==oe[0]:!oe)?NaN:Ce&&Ce[0]==0||!oe?Ee*0:Ee/0);for(ee=new I(Ee),fe=ee.c=[],A=v.e-m.e,Ee=S+A+1,C||(C=ke,A=De(v.e/z)-De(m.e/z),Ee=Ee/z|0),E=0;oe[E]==(Ce[E]||0);E++);if(oe[E]>(Ce[E]||0)&&A--,Ee<0)fe.push(1),L=!0;else{for(pt=Ce.length,we=oe.length,E=0,Ee+=2,U=Ge(C/(oe[0]+1)),U>1&&(oe=u(oe,U,C),Ce=u(Ce,U,C),we=oe.length,pt=Ce.length),ze=we,K=Ce.slice(0,we),Q=K.length;Q=C/2&&dt++;do{if(U=0,w=c(oe,K,we,Q),w<0){if(ge=K[0],we!=Q&&(ge=ge*C+(K[1]||0)),U=Ge(ge/dt),U>1)for(U>=C&&(U=C-1),F=u(oe,U,C),V=F.length,Q=K.length;c(F,K,V,Q)==1;)U--,d(F,we=10;Ee/=10,E++);ie(ee,S+(ee.e=E+A*z-1)+1,T,L)}else ee.e=A,ee.r=+L;return ee}}();function Y(u,c,d,v){var m,S,T,C,w;if(d==null?d=f:le(d,0,8),!u.c)return u.toString();if(m=u.c[0],T=u.e,c==null)w=Re(u.c),w=v==1||v==2&&(T<=l||T>=p)?xr(w,T):We(w,T,"0");else if(u=ie(new I(u),c,d),S=u.e,w=Re(u.c),C=w.length,v==1||v==2&&(c<=S||S<=l)){for(;CC){if(--c>0)for(w+=".";c--;w+="0");}else if(c+=S-C,c>0)for(S+1==C&&(w+=".");c--;w+="0");return u.s<0&&m?"-"+w:w}function X(u,c){for(var d,v=1,m=new I(u[0]);v=10;m/=10,v++);return(d=v+d*z-1)>x?u.c=u.e=null:d=10;C/=10,m++);if(S=c-m,S<0)S+=z,T=c,w=L[A=0],E=w/U[m-T-1]%10|0;else if(A=di((S+1)/z),A>=L.length)if(v){for(;L.length<=A;L.push(0));w=E=0,m=1,S%=z,T=S-z+1}else break e;else{for(w=C=L[A],m=1;C>=10;C/=10,m++);S%=z,T=S-z+m,E=T<0?0:w/U[m-T-1]%10|0}if(v=v||c<0||L[A+1]!=null||(T<0?w:w%U[m-T-1]),v=d<4?(E||v)&&(d==0||d==(u.s<0?3:2)):E>5||E==5&&(d==4||v||d==6&&(S>0?T>0?w/U[m-T]:0:L[A-1])%10&1||d==(u.s<0?8:7)),c<1||!L[0])return L.length=0,v?(c-=u.e+1,L[0]=U[(z-c%z)%z],u.e=-c||0):L[0]=u.e=0,u;if(S==0?(L.length=A,C=1,A--):(L.length=A+1,C=U[z-S],L[A]=T>0?Ge(w/U[m-T]%U[T])*C:0),v)for(;;)if(A==0){for(S=1,T=L[0];T>=10;T/=10,S++);for(T=L[0]+=C,C=1;T>=10;T/=10,C++);S!=C&&(u.e++,L[0]==ke&&(L[0]=1));break}else{if(L[A]+=C,L[A]!=ke)break;L[A--]=0,C=1}for(S=L.length;L[--S]===0;L.pop());}u.e>x?u.c=u.e=null:u.e=p?xr(c,d):We(c,d,"0"),u.s<0?"-"+c:c)}return n.absoluteValue=n.abs=function(){var u=new I(this);return u.s<0&&(u.s=1),u},n.comparedTo=function(u,c){return wt(this,new I(u,c))},n.decimalPlaces=n.dp=function(u,c){var d,v,m,S=this;if(u!=null)return le(u,0,me),c==null?c=f:le(c,0,8),ie(new I(S),u+S.e+1,c);if(!(d=S.c))return null;if(v=((m=d.length-1)-De(this.e/z))*z,m=d[m])for(;m%10==0;m/=10,v--);return v<0&&(v=0),v},n.dividedBy=n.div=function(u,c){return e(this,new I(u,c),h,f)},n.dividedToIntegerBy=n.idiv=function(u,c){return e(this,new I(u,c),0,1)},n.exponentiatedBy=n.pow=function(u,c){var d,v,m,S,T,C,w,A,E,L=this;if(u=new I(u),u.c&&!u.isInteger())throw Error(Te+"Exponent not an integer: "+ce(u));if(c!=null&&(c=new I(c)),C=u.e>14,!L.c||!L.c[0]||L.c[0]==1&&!L.e&&L.c.length==1||!u.c||!u.c[0])return E=new I(Math.pow(+ce(L),C?u.s*(2-br(u)):+ce(u))),c?E.mod(c):E;if(w=u.s<0,c){if(c.c?!c.c[0]:!c.s)return new I(NaN);v=!w&&L.isInteger()&&c.isInteger(),v&&(L=L.mod(c))}else{if(u.e>9&&(L.e>0||L.e<-1||(L.e==0?L.c[0]>1||C&&L.c[1]>=24e7:L.c[0]<8e13||C&&L.c[0]<=9999975e7)))return S=L.s<0&&br(u)?-0:0,L.e>-1&&(S=1/S),new I(w?1/S:S);R&&(S=di(R/z+2))}for(C?(d=new I(.5),w&&(u.s=1),A=br(u)):(m=Math.abs(+ce(u)),A=m%2),E=new I(s);;){if(A){if(E=E.times(L),!E.c)break;S?E.c.length>S&&(E.c.length=S):v&&(E=E.mod(c))}if(m){if(m=Ge(m/2),m===0)break;A=m%2}else if(u=u.times(d),ie(u,u.e+1,1),u.e>14)A=br(u);else{if(m=+ce(u),m===0)break;A=m%2}L=L.times(L),S?L.c&&L.c.length>S&&(L.c.length=S):v&&(L=L.mod(c))}return v?E:(w&&(E=s.div(E)),c?E.mod(c):S?ie(E,R,f,T):E)},n.integerValue=function(u){var c=new I(this);return u==null?u=f:le(u,0,8),ie(c,c.e+1,u)},n.isEqualTo=n.eq=function(u,c){return wt(this,new I(u,c))===0},n.isFinite=function(){return!!this.c},n.isGreaterThan=n.gt=function(u,c){return wt(this,new I(u,c))>0},n.isGreaterThanOrEqualTo=n.gte=function(u,c){return(c=wt(this,new I(u,c)))===1||c===0},n.isInteger=function(){return!!this.c&&De(this.e/z)>this.c.length-2},n.isLessThan=n.lt=function(u,c){return wt(this,new I(u,c))<0},n.isLessThanOrEqualTo=n.lte=function(u,c){return(c=wt(this,new I(u,c)))===-1||c===0},n.isNaN=function(){return!this.s},n.isNegative=function(){return this.s<0},n.isPositive=function(){return this.s>0},n.isZero=function(){return!!this.c&&this.c[0]==0},n.minus=function(u,c){var d,v,m,S,T=this,C=T.s;if(u=new I(u,c),c=u.s,!C||!c)return new I(NaN);if(C!=c)return u.s=-c,T.plus(u);var w=T.e/z,A=u.e/z,E=T.c,L=u.c;if(!w||!A){if(!E||!L)return E?(u.s=-c,u):new I(L?T:NaN);if(!E[0]||!L[0])return L[0]?(u.s=-c,u):new I(E[0]?T:f==3?-0:0)}if(w=De(w),A=De(A),E=E.slice(),C=w-A){for((S=C<0)?(C=-C,m=E):(A=w,m=L),m.reverse(),c=C;c--;m.push(0));m.reverse()}else for(v=(S=(C=E.length)<(c=L.length))?C:c,C=c=0;c0)for(;c--;E[d++]=0);for(c=ke-1;v>C;){if(E[--v]=0;){for(d=0,U=ge[m]%fe,F=ge[m]/fe|0,T=w,S=m+T;S>m;)A=Q[--T]%fe,E=Q[T]/fe|0,C=F*A+E*U,A=U*A+C%fe*fe+V[S]+d,d=(A/ee|0)+(C/fe|0)+F*E,V[S--]=A%ee;V[S]=d}return d?++v:V.splice(0,1),ue(u,V,v)},n.negated=function(){var u=new I(this);return u.s=-u.s||null,u},n.plus=function(u,c){var d,v=this,m=v.s;if(u=new I(u,c),c=u.s,!m||!c)return new I(NaN);if(m!=c)return u.s=-c,v.minus(u);var S=v.e/z,T=u.e/z,C=v.c,w=u.c;if(!S||!T){if(!C||!w)return new I(m/0);if(!C[0]||!w[0])return w[0]?u:new I(C[0]?v:m*0)}if(S=De(S),T=De(T),C=C.slice(),m=S-T){for(m>0?(T=S,d=w):(m=-m,d=C),d.reverse();m--;d.push(0));d.reverse()}for(m=C.length,c=w.length,m-c<0&&(d=w,w=C,C=d,c=m),m=0;c;)m=(C[--c]=C[c]+w[c]+m)/ke|0,C[c]=ke===C[c]?0:C[c]%ke;return m&&(C=[m].concat(C),++T),ue(u,C,T)},n.precision=n.sd=function(u,c){var d,v,m,S=this;if(u!=null&&u!==!!u)return le(u,1,me),c==null?c=f:le(c,0,8),ie(new I(S),u,c);if(!(d=S.c))return null;if(m=d.length-1,v=m*z+1,m=d[m]){for(;m%10==0;m/=10,v--);for(m=d[0];m>=10;m/=10,v++);}return u&&S.e+1>v&&(v=S.e+1),v},n.shiftedBy=function(u){return le(u,-gi,gi),this.times("1e"+u)},n.squareRoot=n.sqrt=function(){var u,c,d,v,m,S=this,T=S.c,C=S.s,w=S.e,A=h+4,E=new I("0.5");if(C!==1||!T||!T[0])return new I(!C||C<0&&(!T||T[0])?NaN:T?S:1/0);if(C=Math.sqrt(+ce(S)),C==0||C==1/0?(c=Re(T),(c.length+w)%2==0&&(c+="0"),C=Math.sqrt(+c),w=De((w+1)/2)-(w<0||w%2),C==1/0?c="5e"+w:(c=C.toExponential(),c=c.slice(0,c.indexOf("e")+1)+w),d=new I(c)):d=new I(C+""),d.c[0]){for(w=d.e,C=w+A,C<3&&(C=0);;)if(m=d,d=E.times(m.plus(e(S,m,A,1))),Re(m.c).slice(0,C)===(c=Re(d.c)).slice(0,C))if(d.e0&&V>0){for(S=V%C||C,E=F.substr(0,S);S0&&(E+=A+F.slice(S)),U&&(E="-"+E)}v=L?E+(d.decimalSeparator||"")+((w=+d.fractionGroupSize)?L.replace(new RegExp("\\d{"+w+"}\\B","g"),"$&"+(d.fractionGroupSeparator||"")):L):E}return(d.prefix||"")+v+(d.suffix||"")},n.toFraction=function(u){var c,d,v,m,S,T,C,w,A,E,L,U,F=this,V=F.c;if(u!=null&&(C=new I(u),!C.isInteger()&&(C.c||C.s!==1)||C.lt(s)))throw Error(Te+"Argument "+(C.isInteger()?"out of range: ":"not an integer: ")+ce(C));if(!V)return new I(F);for(c=new I(s),A=d=new I(s),v=w=new I(s),U=Re(V),S=c.e=U.length-F.e-1,c.c[0]=mi[(T=S%z)<0?z+T:T],u=!u||C.comparedTo(c)>0?S>0?c:A:C,T=x,x=1/0,C=new I(U),w.c[0]=0;E=e(C,c,0,1),m=d.plus(E.times(v)),m.comparedTo(u)!=1;)d=v,v=m,A=w.plus(E.times(m=A)),w=m,c=C.minus(E.times(m=c)),C=m;return m=e(u.minus(d),v,0,1),w=w.plus(m.times(A)),d=d.plus(m.times(v)),w.s=A.s=F.s,S=S*2,L=e(A,v,S,f).minus(F).abs().comparedTo(e(w,d,S,f).minus(F).abs())<1?[A,v]:[w,d],x=T,L},n.toNumber=function(){return+ce(this)},n.toPrecision=function(u,c){return u!=null&&le(u,1,me),Y(this,u,c,2)},n.toString=function(u){var c,d=this,v=d.s,m=d.e;return m===null?v?(c="Infinity",v<0&&(c="-"+c)):c="NaN":(u==null?c=m<=l||m>=p?xr(Re(d.c),m):We(Re(d.c),m,"0"):u===10&&Z?(d=ie(new I(d),h+m+1,f),c=We(Re(d.c),d.e,"0")):(le(u,2,j.length,"Base"),c=r(We(Re(d.c),m,"0"),10,u,v,!0)),v<0&&d.c[0]&&(c="-"+c)),c},n.valueOf=n.toJSON=function(){return ce(this)},n._isBigNumber=!0,n[Symbol.toStringTag]="BigNumber",n[Symbol.for("nodejs.util.inspect.custom")]=n.valueOf,t!=null&&I.set(t),I}function De(t){var e=t|0;return t>0||t===e?e:e-1}function Re(t){for(var e,r,i=1,n=t.length,s=t[0]+"";ip^r?1:-1;for(f=(l=n.length)<(p=s.length)?l:p,h=0;hs[h]^r?1:-1;return l==p?0:l>p^r?1:-1}function le(t,e,r,i){if(tr||t!==Ge(t))throw Error(Te+(i||"Argument")+(typeof t=="number"?tr?" out of range: ":" not an integer: ":" not a primitive number: ")+String(t))}function br(t){var e=t.c.length-1;return De(t.e/z)==e&&t.c[e]%2!=0}function xr(t,e){return(t.length>1?t.charAt(0)+"."+t.slice(1):t)+(e<0?"e":"e+")+e}function We(t,e,r){var i,n;if(e<0){for(n=r+".";++e;n+=r);t=n+t}else if(i=t.length,++e>i){for(n=r,e-=i;--e;n+=r);t+=n}else e0?e-w9(t):e}function Qe(t,e){let r=E9(t,e);if(r===null)return t.toString();let i=Gt(e.roundMode);if(r>=0)return t.toFixed(r,i);let n=Math.pow(10,Math.abs(r));return t=new re(t.div(n).toFixed(0,i)).times(n),t.toString()}function O9(t,{formattedNumber:e,unit:r}){return t.replace("%n",e).replace("%u",r)}function T9({significand:t,whole:e,precision:r}){if(e==="0"||r===null)return t;let i=Math.max(0,r-e.length);return(t??"").substr(0,i)}function at(t,e){var r,i,n;let s=new re(t);if(e.raise&&!s.isFinite())throw new Error(`"${t}" is not a valid numeric value`);let h=Qe(s,e),f=new re(h),l=f.lt(0),p=f.isZero(),[g,x]=h.split("."),D=[],B,R=(r=e.format)!==null&&r!==void 0?r:"%n",k=(i=e.negativeFormat)!==null&&i!==void 0?i:`-${R}`,j=l&&!p?k:R;for(g=g.replace("-","");g.length>0;)D.unshift(g.substr(Math.max(0,g.length-3),3)),g=g.substr(0,g.length-3);return g=D.join(""),B=D.join(e.delimiter),e.significant?x=T9({whole:g,significand:x,precision:e.precision}):x=x??(0,M1.default)("0",(n=e.precision)!==null&&n!==void 0?n:0),e.stripInsignificantZeros&&x&&(x=x.replace(/0+$/,"")),s.isNaN()&&(B=t.toString()),x&&s.isFinite()&&(B+=(e.separator||".")+x),O9(j,{formattedNumber:B,unit:e.unit})}function Fe(t,e,r){let i="";return(e instanceof String||typeof e=="string")&&(i=e),e instanceof Array&&(i=e.join(t.defaultSeparator)),r.scope&&(i=[r.scope,i].join(t.defaultSeparator)),i}function Be(t){var e,r;if(t===null)return"null";let i=typeof t;return i!=="object"?i:((r=(e=t==null?void 0:t.constructor)===null||e===void 0?void 0:e.name)===null||r===void 0?void 0:r.toLowerCase())||"object"}function zt(t,e,r){r=Object.keys(r).reduce((n,s)=>(n[t.transformKey(s)]=r[s],n),{});let i=e.match(t.placeholder);if(!i)return e;for(;i.length;){let n,s=i.shift(),h=s.replace(t.placeholder,"$1");Se(r[h])?n=r[h].toString().replace(/\$/gm,"_#$#_"):h in r?n=t.nullPlaceholder(t,s,e,r):n=t.missingPlaceholder(t,s,e,r);let f=new RegExp(s.replace(/\{/gm,"\\{").replace(/\}/gm,"\\}"));e=e.replace(f,n)}return e.replace(/_#\$#_/g,"$")}var D1=ae(dr());function Ae(t,e,r={}){r=Object.assign({},r);let i="locale"in r?r.locale:t.locale,n=Be(i),s=t.locales.get(n==="string"?i:typeof i).slice();e=Fe(t,e,r).split(t.defaultSeparator).map(f=>t.transformKey(f)).join(".");let h=s.map(f=>(0,D1.default)(t.translations,[f,e].join(".")));return h.push(r.defaultValue),h.find(f=>Se(f))}function Ci(t,e){let r=new re(t);if(!r.isFinite())return t.toString();if(!e.delimiterPattern.global)throw new Error(`options.delimiterPattern must be a global regular expression; received ${e.delimiterPattern}`);let[i,n]=r.toString().split(".");return i=i.replace(e.delimiterPattern,s=>`${s}${e.delimiter}`),[i,n].filter(Boolean).join(e.separator)}var Rl=ae(Nl()),Bl=ae(Dl());var ki={"0":"unit","1":"ten","2":"hundred","3":"thousand","6":"million","9":"billion","12":"trillion","15":"quadrillion","-1":"deci","-2":"centi","-3":"mili","-6":"micro","-9":"nano","-12":"pico","-15":"femto"},fg=(0,Bl.default)(Object.values(ki),Object.keys(ki).map(t=>parseInt(t,10)));function Fi(t,e,r){let i={roundMode:r.roundMode,precision:r.precision,significant:r.significant},n;if(Be(r.units)==="string"){let x=r.units;if(n=Ae(t,x),!n)throw new Error(`The scope "${t.locale}${t.defaultSeparator}${Fe(t,x,{})}" couldn't be found`)}else n=r.units;let s=Qe(new re(e),i),h=x=>(0,Rl.default)(Object.keys(x).map(D=>fg[D]),D=>D*-1),f=(x,D)=>{let B=x.isZero()?0:Math.floor(Math.log10(x.abs().toNumber()));return h(D).find(R=>B>=R)||0},l=(x,D)=>{let B=ki[D.toString()];return x[B]||""},p=f(new re(s),n),g=l(n,p);if(s=Qe(new re(s).div(Math.pow(10,p)),i),r.stripInsignificantZeros){let[x,D]=s.split(".");D=(D||"").replace(/0+$/,""),s=x,D&&(s+=`${r.separator}${D}`)}return r.format.replace("%n",s||"0").replace("%u",g).trim()}var kl=["byte","kb","mb","gb","tb","pb","eb"];function Ui(t,e,r){let i=Gt(r.roundMode),n=1024,s=new re(e).abs(),h=s.lt(n),f,l=(R,k)=>{let j=k.length-1,Z=new re(Math.log(R.toNumber())).div(Math.log(n)).integerValue(re.ROUND_DOWN).toNumber();return Math.min(j,Z)},p=R=>`number.human.storage_units.units.${h?"byte":R[g]}`,g=l(s,kl);h?f=s.integerValue():f=new re(Qe(s.div(Math.pow(n,g)),{significant:r.significant,precision:r.precision,roundMode:r.roundMode}));let x=t.translate("number.human.storage_units.format",{defaultValue:"%n %u"}),D=t.translate(p(kl),{count:s.integerValue().toNumber()}),B=f.toFixed(r.precision,i);return r.stripInsignificantZeros&&(B=B.replace(/(\..*?)0+$/,"$1").replace(/\.$/,"")),x.replace("%n",B).replace("%u",D)}function qt(t){if(t instanceof Date)return t;if(typeof t=="number"){let i=new Date;return i.setTime(t),i}let e=new String(t).match(/(\d{4})-(\d{2})-(\d{2})(?:[ T](\d{2}):(\d{2}):(\d{2})(?:[.,](\d{1,3}))?)?(Z|\+00:?00)?/);if(e){let i=e.slice(1,8).map(D=>parseInt(D,10)||0);i[1]-=1;let[n,s,h,f,l,p,g]=i;return e[8]?new Date(Date.UTC(n,s,h,f,l,p,g)):new Date(n,s,h,f,l,p,g)}t.match(/([A-Z][a-z]{2}) ([A-Z][a-z]{2}) (\d+) (\d+:\d+:\d+) ([+-]\d+) (\d+)/)&&new Date().setTime(Date.parse([RegExp.$1,RegExp.$2,RegExp.$3,RegExp.$6,RegExp.$4,RegExp.$5].join(" ")));let r=new Date;return r.setTime(Date.parse(t)),r}function Tr({i18n:t,count:e,scope:r,options:i,baseScope:n}){i=Object.assign({},i);let s,h;if(typeof r=="object"&&r?s=r:s=Ae(t,r,i),!s)return t.missingTranslation.get(r,i);let l=t.pluralization.get(i.locale)(t,e),p=[];for(;l.length;){let g=l.shift();if(Se(s[g])){h=s[g];break}p.push(g)}return Se(h)?(i.count=e,t.interpolate(t,h,i)):t.missingTranslation.get(n.split(t.defaultSeparator).concat([p[0]]),i)}var jl=ae(Le()),Gl=ae(Je()),Hl=ae(Ul()),zl=class{constructor(e){this.target=e}call(){let e=(0,Hl.default)(Object.keys(this.target).map(r=>this.compute(this.target[r],r)));return e.sort(),e}compute(e,r){return!(0,jl.default)(e)&&(0,Gl.default)(e)?Object.keys(e).map(i=>this.compute(e[i],`${r}.${i}`)):r}};function ji(t){return new zl(t).call()}var gg={meridian:{am:"AM",pm:"PM"},dayNames:["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"],abbrDayNames:["Sun","Mon","Tue","Wed","Thu","Fri","Sat"],monthNames:[null,"January","February","March","April","May","June","July","August","September","October","November","December"],abbrMonthNames:[null,"Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"]};function Gi(t,e,r={}){let{abbrDayNames:i,dayNames:n,abbrMonthNames:s,monthNames:h,meridian:f}=Object.assign(Object.assign({},gg),r);if(isNaN(t.getTime()))throw new Error("strftime() requires a valid date object, but received an invalid date.");let l=t.getDay(),p=t.getDate(),g=t.getFullYear(),x=t.getMonth()+1,D=t.getHours(),B=D,R=D>11?"pm":"am",k=t.getSeconds(),j=t.getMinutes(),Z=t.getTimezoneOffset(),I=Math.floor(Math.abs(Z/60)),Y=Math.abs(Z)-I*60,X=(Z>0?"-":"+")+(I.toString().length<2?"0"+I:I)+(Y.toString().length<2?"0"+Y:Y);return B>12?B=B-12:B===0&&(B=12),e=e.replace("%a",i[l]),e=e.replace("%A",n[l]),e=e.replace("%b",s[x]),e=e.replace("%B",h[x]),e=e.replace("%d",p.toString().padStart(2,"0")),e=e.replace("%e",p.toString()),e=e.replace("%-d",p.toString()),e=e.replace("%H",D.toString().padStart(2,"0")),e=e.replace("%-H",D.toString()),e=e.replace("%k",D.toString()),e=e.replace("%I",B.toString().padStart(2,"0")),e=e.replace("%-I",B.toString()),e=e.replace("%l",B.toString()),e=e.replace("%m",x.toString().padStart(2,"0")),e=e.replace("%-m",x.toString()),e=e.replace("%M",j.toString().padStart(2,"0")),e=e.replace("%-M",j.toString()),e=e.replace("%p",f[R]),e=e.replace("%P",f[R].toLowerCase()),e=e.replace("%S",k.toString().padStart(2,"0")),e=e.replace("%-S",k.toString()),e=e.replace("%w",l.toString()),e=e.replace("%y",g.toString().padStart(2,"0").substr(-2)),e=e.replace("%-y",g.toString().padStart(2,"0").substr(-2).replace(/^0+/,"")),e=e.replace("%Y",g.toString()),e=e.replace(/%z/i,X),e}var Yl=ae(Jl());var Ie=(t,e,r)=>r>=t&&r<=e;function zi(t,e,r,i={}){let n=i.scope||"datetime.distance_in_words",s=(ce,u=0)=>t.t(ce,{count:u,scope:n});e=qt(e),r=qt(r);let h=e.getTime()/1e3,f=r.getTime()/1e3;h>f&&([e,r,h,f]=[r,e,f,h]);let l=Math.round(f-h),p=Math.round((f-h)/60),x=p/60/24,D=Math.round(p/60),B=Math.round(x),R=Math.round(B/30);if(Ie(0,1,p))return i.includeSeconds?Ie(0,4,l)?s("less_than_x_seconds",5):Ie(5,9,l)?s("less_than_x_seconds",10):Ie(10,19,l)?s("less_than_x_seconds",20):Ie(20,39,l)?s("half_a_minute"):Ie(40,59,l)?s("less_than_x_minutes",1):s("x_minutes",1):p===0?s("less_than_x_minutes",1):s("x_minutes",p);if(Ie(2,44,p))return s("x_minutes",p);if(Ie(45,89,p))return s("about_x_hours",1);if(Ie(90,1439,p))return s("about_x_hours",D);if(Ie(1440,2519,p))return s("x_days",1);if(Ie(2520,43199,p))return s("x_days",B);if(Ie(43200,86399,p))return s("about_x_months",Math.round(p/43200));if(Ie(86400,525599,p))return s("x_months",R);let k=e.getFullYear();e.getMonth()+1>=3&&(k+=1);let j=r.getFullYear();r.getMonth()+1<3&&(j-=1);let Z=k>j?0:(0,Yl.default)(k,j).filter(ce=>new Date(ce,1,29).getMonth()==1).length,I=525600,Y=Z*1440,X=p-Y,ue=Math.trunc(X/I),ie=parseFloat((X/I-ue).toPrecision(3));return ie<.25?s("about_x_years",ue):ie<.75?s("over_x_years",ue):s("almost_x_years",ue+1)}var wg=function(t,e){e instanceof Array&&(e=e.join(t.defaultSeparator));let r=e.split(t.defaultSeparator).slice(-1)[0];return t.missingTranslationPrefix+r.replace("_"," ").replace(/([a-z])([A-Z])/g,(i,n,s)=>`${n} ${s.toLowerCase()}`)},Eg=(t,e,r)=>{let i=Fe(t,e,r),n="locale"in r?r.locale:t.locale,s=Be(n);return`[missing "${[s=="string"?n:s,i].join(t.defaultSeparator)}" translation]`},Og=(t,e,r)=>{let i=Fe(t,e,r),n=[t.locale,i].join(t.defaultSeparator);throw new Error(`Missing translation: ${n}`)},Ar=class{constructor(e){this.i18n=e,this.registry={},this.register("guess",wg),this.register("message",Eg),this.register("error",Og)}register(e,r){this.registry[e]=r}get(e,r){var i;return this.registry[(i=r.missingBehavior)!==null&&i!==void 0?i:this.i18n.missingBehavior](this.i18n,e,r)}};var Tg=function(t,e,r,i){function n(s){return s instanceof r?s:new r(function(h){h(s)})}return new(r||(r=Promise))(function(s,h){function f(g){try{p(i.next(g))}catch(x){h(x)}}function l(g){try{p(i.throw(g))}catch(x){h(x)}}function p(g){g.done?s(g.value):n(g.value).then(f,l)}p((i=i.apply(t,e||[])).next())})},Zi={defaultLocale:"en",locale:"en",defaultSeparator:".",placeholder:/(?:\{\{|%\{)(.*?)(?:\}\}?)/gm,enableFallback:!1,missingBehavior:"message",missingTranslationPrefix:"",missingPlaceholder:(t,e)=>`[missing "${e}" value]`,nullPlaceholder:(t,e,r,i)=>t.missingPlaceholder(t,e,r,i),transformKey:t=>t},qr=class{constructor(e={},r={}){this._locale=Zi.locale,this._defaultLocale=Zi.defaultLocale,this._version=0,this.onChangeHandlers=[],this.translations={},this.t=this.translate,this.p=this.pluralize,this.l=this.localize,this.distanceOfTimeInWords=this.timeAgoInWords;let{locale:i,enableFallback:n,missingBehavior:s,missingTranslationPrefix:h,missingPlaceholder:f,nullPlaceholder:l,defaultLocale:p,defaultSeparator:g,placeholder:x,transformKey:D}=Object.assign(Object.assign({},Zi),r);this.locale=i,this.defaultLocale=p,this.defaultSeparator=g,this.enableFallback=n,this.locale=i,this.missingBehavior=s,this.missingTranslationPrefix=h,this.missingPlaceholder=f,this.nullPlaceholder=l,this.placeholder=x,this.pluralization=new vr(this),this.locales=new _r(this),this.missingTranslation=new Ar(this),this.transformKey=D,this.interpolate=zt,this.store(e)}store(e){ji(e).forEach(i=>(0,$i.default)(this.translations,i,(0,Wi.default)(e,i))),this.hasChanged()}get locale(){return this._locale||this.defaultLocale||"en"}set locale(e){if(typeof e!="string")throw new Error(`Expected newLocale to be a string; got ${Be(e)}`);let r=this._locale!==e;this._locale=e,r&&this.hasChanged()}get defaultLocale(){return this._defaultLocale||"en"}set defaultLocale(e){if(typeof e!="string")throw new Error(`Expected newLocale to be a string; got ${Be(e)}`);let r=this._defaultLocale!==e;this._defaultLocale=e,r&&this.hasChanged()}translate(e,r){r=Object.assign({},r);let i=pi(this,e,r),n;return i.some(h=>(Se(h.scope)?n=Ae(this,h.scope,r):Se(h.message)&&(n=h.message),n!=null))?(typeof n=="string"?n=this.interpolate(this,n,r):typeof n=="object"&&n&&Se(r.count)&&(n=Tr({i18n:this,count:r.count||0,scope:n,options:r,baseScope:Fe(this,e,r)})),r&&n instanceof Array&&(n=n.map(h=>typeof h=="string"?zt(this,h,r):h)),n):this.missingTranslation.get(e,r)}pluralize(e,r,i){return Tr({i18n:this,count:e,scope:r,options:Object.assign({},i),baseScope:Fe(this,r,i??{})})}localize(e,r,i){if(i=Object.assign({},i),r==null)return"";switch(e){case"currency":return this.numberToCurrency(r);case"number":return at(r,Object.assign({delimiter:",",precision:3,separator:".",significant:!1,stripInsignificantZeros:!1},Ae(this,"number.format")));case"percentage":return this.numberToPercentage(r);default:{let n;return e.match(/^(date|time)/)?n=this.toTime(e,r):n=r.toString(),zt(this,n,i)}}}toTime(e,r){let i=qt(r),n=Ae(this,e);return i.toString().match(/invalid/i)||!n?i.toString():this.strftime(i,n)}numberToCurrency(e,r={}){return at(e,Object.assign(Object.assign(Object.assign({delimiter:",",format:"%u%n",precision:2,separator:".",significant:!1,stripInsignificantZeros:!1,unit:"$"},Me(this.get("number.format"))),Me(this.get("number.currency.format"))),r))}numberToPercentage(e,r={}){return at(e,Object.assign(Object.assign(Object.assign({delimiter:"",format:"%n%",precision:3,stripInsignificantZeros:!1,separator:".",significant:!1},Me(this.get("number.format"))),Me(this.get("number.percentage.format"))),r))}numberToHumanSize(e,r={}){return Ui(this,e,Object.assign(Object.assign(Object.assign({delimiter:"",precision:3,significant:!0,stripInsignificantZeros:!0,units:{billion:"Billion",million:"Million",quadrillion:"Quadrillion",thousand:"Thousand",trillion:"Trillion",unit:""}},Me(this.get("number.human.format"))),Me(this.get("number.human.storage_units"))),r))}numberToHuman(e,r={}){return Fi(this,e,Object.assign(Object.assign(Object.assign({delimiter:"",separator:".",precision:3,significant:!0,stripInsignificantZeros:!0,format:"%n %u",roundMode:"default",units:{billion:"Billion",million:"Million",quadrillion:"Quadrillion",thousand:"Thousand",trillion:"Trillion",unit:""}},Me(this.get("number.human.format"))),Me(this.get("number.human.decimal_units"))),r))}numberToRounded(e,r){return at(e,Object.assign({unit:"",precision:3,significant:!1,separator:".",delimiter:"",stripInsignificantZeros:!1},r))}numberToDelimited(e,r={}){return Ci(e,Object.assign({delimiterPattern:/(\d)(?=(\d\d\d)+(?!\d))/g,delimiter:",",separator:"."},r))}withLocale(e,r){return Tg(this,void 0,void 0,function*(){let i=this.locale;try{this.locale=e,yield r()}finally{this.locale=i}})}strftime(e,r,i={}){return Gi(e,r,Object.assign(Object.assign(Object.assign({},Me(Ae(this,"date"))),{meridian:{am:Ae(this,"time.am")||"AM",pm:Ae(this,"time.pm")||"PM"}}),i))}update(e,r,i={strict:!1}){if(i.strict&&!(0,Xl.default)(this.translations,e))throw new Error(`The path "${e}" is not currently defined`);let n=(0,Wi.default)(this.translations,e),s=Be(n),h=Be(r);if(i.strict&&s!==h)throw new Error(`The current type for "${e}" is "${s}", but you're trying to override it with "${h}"`);let f;h==="object"?f=Object.assign(Object.assign({},n),r):f=r,(0,$i.default)(this.translations,e,f),this.hasChanged()}toSentence(e,r={}){let{wordsConnector:i,twoWordsConnector:n,lastWordConnector:s}=Object.assign(Object.assign({wordsConnector:", ",twoWordsConnector:" and ",lastWordConnector:", and "},Me(Ae(this,"support.array"))),r),h=e.length;switch(h){case 0:return"";case 1:return`${e[0]}`;case 2:return e.join(n);default:return[e.slice(0,h-1).join(i),s,e[h-1]].join("")}}timeAgoInWords(e,r,i={}){return zi(this,e,r,i)}onChange(e){return this.onChangeHandlers.push(e),()=>{this.onChangeHandlers.splice(this.onChangeHandlers.indexOf(e),1)}}get version(){return this._version}formatNumber(e,r){return at(e,r)}get(e){return Ae(this,e)}runCallbacks(){this.onChangeHandlers.forEach(e=>e(this))}hasChanged(){this._version+=1,this.runCallbacks()}};var gc=ae(hc()),Xi=ae(require("obsidian"));var Tm="Antidote Settings",Am="If this plugin is valuable to you, you can help support the maintainer by using one of the buttons below:",qm="Add Corrector Button",Im="Add Corrector All Document Button",Nm="Add Dictionary Button",Pm="Add Guide Button",Lm="Antidote - Corrector",Mm="Antidote - Corrector All Document",Dm="Antidote - Dictionary",Rm="Antidote - Guide",Bm="Correct the whole document with Antidote",km="Correct with Antidote",Fm="Open Antidote dictionary",Um="Open Antidote guide",jm="Unable to communicate with Connectix Agent (Antidote)",pc={"settings.title":Tm,"settings.donation":Am,"settings.corrector.title":qm,"settings.corrector_all.title":Im,"settings.dictionary.title":Nm,"settings.guide.title":Pm,"sidebar.corrector.label":Lm,"sidebar.corrector_all.label":Mm,"sidebar.dictionary.label":Dm,"sidebar.guide.label":Rm,"command.corrector_all.label":Bm,"command.corrector.label":km,"command.dictionary.label":Fm,"command.guide.label":Um,"error.antidote_not_found":jm};var Gm="Param\xE8tres d'Antidote",Hm="Si ce plugin vous est utile, vous pouvez aider \xE0 soutenir le mainteneur en utilisant un des boutons ci-dessous :",zm="Ajouter le bouton Correcteur",Wm="Ajouter le bouton Correcteur : corriger tout le document",$m="Ajouter le bouton Dictionnaire",Zm="Ajouter le bouton Guides",Vm="Antidote - Correcteur",Km="Antidote - Correcteur : corriger tout le document",Jm="Antidote - Dictionnaire",Ym="Antidote - Guides",Xm="Corriger tout le document avec Antidote",Qm="Corriger avec Antidote",ey="Ouvrir le dictionnaire d'Antidote",ty="Ouvrir le guide d'Antidote",ry="Impossible de communiquer avec l'Agent Connectix (Antidote)",dc={"settings.title":Gm,"settings.donation":Hm,"settings.corrector.title":zm,"settings.corrector_all.title":Wm,"settings.dictionary.title":$m,"settings.guide.title":Zm,"sidebar.corrector.label":Vm,"sidebar.corrector_all.label":Km,"sidebar.dictionary.label":Jm,"sidebar.guide.label":Ym,"command.corrector_all.label":Xm,"command.corrector.label":Qm,"command.dictionary.label":ey,"command.guide.label":ty,"error.antidote_not_found":ry};var Mr={en:pc,fr:dc};function iy(t){let e={};return Object.keys(t).forEach(r=>(0,gc.default)(e,r,t[r])),e}var mc={};for(let t in Mr){let e=t;mc[e]=iy(Mr[e])}var Dr=new qr(mc);Dr.defaultLocale="en";Dr.enableFallback=!0;var yc="en";Xi.moment.locale().replace("-","_")in Mr&&(yc=Xi.moment.locale().replace("-","_"));Dr.locale=yc;var ye=(t,e)=>Dr.t(t,e);var pC=ae(bc()),dC=ae(sn()),gC=ae(on()),S2=ae(pn()),mC=ae(x2());var w2=S2.default;var E2=ae(require("child_process"));function O2(t,e){let r=`REG QUERY "${t}" /v ${e}`,i=(0,E2.execSync)(r).toString(),n=i.substring(i.indexOf("REG_"));return n=n.substring(n.indexOf(" ")),n.trim()}var N2=ae(require("fs"));function bC(t,e){for(let r of t)if(r.length==0)return!1;return!0}var gn=class{constructor(e){this.monAgent=e,this.prefs={},this.ws={},this.listePaquetsRecu=new Array(0),this.estInit=!1}Initialise(){return _e(this,null,function*(){if(this.estInit)return!0;let e=yield this.ObtiensReglages();return this.estInit=!0,e})}LanceCorrecteur(){let e={message:"LanceOutil",outilApi:"Correcteur"};this.EnvoieMessage(JSON.stringify(e))}LanceDictionnaire(){let e={message:"LanceOutil",outilApi:"Dictionnaires"};this.EnvoieMessage(JSON.stringify(e))}LanceGuide(){let e={message:"LanceOutil",outilApi:"Guides"};this.EnvoieMessage(JSON.stringify(e))}GereMessage(e){var n,s,h,f,l,p,g,x,D,B,R,k,j;let r={};if(r.idMessage=e.idMessage,e.message=="init")r.titreDocument=(n=this.monAgent)==null?void 0:n.DonneTitreDocument(),r.retourChariot=(s=this.monAgent)==null?void 0:s.DonneRetourDeCharriot(),r.filtreActif=(h=this.monAgent)==null?void 0:h.DonneTypeDocument(),r.permetRetourChariot=(f=this.monAgent)==null?void 0:f.PermetsRetourDeCharriot(),r.permetEspaceInsecable=(l=this.monAgent)==null?void 0:l.JeTraiteLesInsecables(),r.permetEspaceFin=(p=this.monAgent)==null?void 0:p.EspaceFineDisponible(),r.remplaceSansSelection=!0,this.EnvoieMessage(JSON.stringify(r));else if(e.message=="cheminDocument")r.donnee=!((g=this.monAgent)==null?void 0:g.DonneCheminDocument()),this.EnvoieMessage(JSON.stringify(r));else if(e.message=="donneZonesTexte")(x=this.monAgent)==null||x.DonneLesZonesACorriger().then(Z=>{let I=new Array;Z==null||Z.forEach(Y=>{I.push(Y.toJsonAPI())}),r.donnees=I,this.EnvoieMessage(JSON.stringify(r))});else if(e.message=="docEstDisponible")r.donnees=(D=this.monAgent)==null?void 0:D.DocEstDisponible(),this.EnvoieMessage(JSON.stringify(r));else if(e.message=="editionPossible"){let Z=e.donnees.idZone,I=e.donnees.contexte,Y=e.donnees.positionDebut,X=e.donnees.positionFin;r.donnees=(B=this.monAgent)==null?void 0:B.PeutCorriger(Z,Y,X,I),this.EnvoieMessage(JSON.stringify(r))}else if(e.message=="remplace"){let Z=e.donnees.idZone,I=e.donnees.nouvelleChaine,Y=e.donnees.positionRemplacementDebut,X=e.donnees.positionRemplacementFin;(R=this.monAgent)==null||R.CorrigeDansTexteur(Z,Y,X,I,!1).then(()=>{var ue;(ue=this.monAgent)==null||ue.MetsFocusSurLeDocument(),r.donnees=!0,this.EnvoieMessage(JSON.stringify(r))})}else if(e.message=="selectionne"){let Z=e.donnees.idZone,I=e.donnees.positionDebut,Y=e.donnees.positionFin;(k=this.monAgent)==null||k.SelectionneIntervalle(Z,I,Y)}else e.message=="retourneAuDocument"&&((j=this.monAgent)==null||j.RetourneAuTexteur())}DonnePathAgentConsole(){return _e(this,null,function*(){if(process.platform==="darwin"){let e=I2(),r=require("os").homedir(),i;return i=(yield e.parseFile(r+"/Library/Preferences/com.druide.Connectix.plist"))[0].DossierApplication,i+"/Contents/SharedSupport/AgentConnectixConsole"}else{if(process.platform==="linux")return"/usr/local/bin/AgentConnectixConsole";if(process.platform==="win32")return O2("HKEY_LOCAL_MACHINE\\SOFTWARE\\Druide informatique inc.\\Connectix","DossierConnectix")+"AgentConnectixConsole.exe"}return""})}InitWS(){return _e(this,null,function*(){let e=this.prefs.port;this.ws=new w2("ws://127.0.0.1:"+e);let r=this;return this.ws.on("message",s=>{r.RecoisMessage(s)}),this.ws.on("close",()=>{r.estInit=!1}),yield new Promise((s,h)=>{this.ws.on("open",()=>{s(!0)}),this.ws.on("error",f=>{r.estInit=!1,h(f)})})})}Digere(e){if("idPaquet"in e){let r=e.donnees,i=e.totalPaquet,n=e.idPaquet;if(this.listePaquetsRecu.length{r.stdout.on("data",f=>_e(this,null,function*(){let l=f.toString("utf8");this.prefs=JSON.parse(l.substring(l.indexOf("{"),l.length));try{s(yield this.InitWS())}catch(p){h(p)}}))});return r.stdin.write("API"),yield i})}};var mn=new WeakMap;function yn(t,e=!1){if((t==null?void 0:t.getMode())==="source")return mn.has(t)||mn.set(t,new gn(new Jr(t,t.editor.cm.state.lineBreak,e))),mn.get(t);throw Error("Unknown document")}var xC={showCorrectorAllIcon:!0,showCorrectorIcon:!0,showDictionaryIcon:!0,showGuideIcon:!0},Cn=class extends ne.Plugin{constructor(){super(...arguments);this.isloading=!1;this.handleCorrecteur=(e=!1)=>_e(this,null,function*(){let r=this.app.workspace.getActiveViewOfType(ne.MarkdownView);if((r==null?void 0:r.getMode())==="source")try{let i=yn(r,e);try{yield i.Initialise()}catch(n){new ne.Notice(ye("error.antidote_not_found")),console.error(n);return}i.LanceCorrecteur()}catch(i){console.error(i)}});this.handleDictionnaire=()=>_e(this,null,function*(){let e=this.app.workspace.getActiveViewOfType(ne.MarkdownView);if((e==null?void 0:e.getMode())==="source")try{let r=yn(e);try{yield r.Initialise()}catch(i){new ne.Notice(ye("error.antidote_not_found"));return}r.LanceDictionnaire()}catch(r){console.error(r)}});this.handleGuide=()=>_e(this,null,function*(){let e=this.app.workspace.getActiveViewOfType(ne.MarkdownView);if((e==null?void 0:e.getMode())==="source")try{let r=yn(e);try{yield r.Initialise()}catch(i){new ne.Notice(ye("error.antidote_not_found"));return}r.LanceGuide()}catch(r){console.error(r)}})}onload(){return _e(this,null,function*(){yield this.loadSettings(),this.correctorAllStatusBar=this.addStatusBarItem(),this.setCorrectorAllStatusBarReady(),this.correctorAllStatusBar.onClickEvent(()=>{!this.app.workspace.activeEditor||this.handleCorrecteur(!0)}),this.correctorStatusBar=this.addStatusBarItem(),this.setCorrectorStatusBarReady(),this.correctorStatusBar.onClickEvent(()=>{!this.app.workspace.activeEditor||this.handleCorrecteur()}),this.dictionaryStatusBar=this.addStatusBarItem(),this.dictionaryStatusBar.addClass("mod-clickable","antidote-green"),this.dictionaryStatusBar.createSpan({attr:{"aria-label-position":"top","aria-label":ye("sidebar.dictionary.label")}},e=>{(0,ne.setIcon)(e,"book")}),this.dictionaryStatusBar.onClickEvent(()=>{!this.app.workspace.activeEditor||this.handleDictionnaire()}),this.guidesStatusBar=this.addStatusBarItem(),this.guidesStatusBar.addClass("mod-clickable","antidote-orange"),this.guidesStatusBar.createSpan({attr:{"aria-label-position":"top","aria-label":ye("sidebar.guide.label")}},e=>{(0,ne.setIcon)(e,"book")}),this.guidesStatusBar.onClickEvent(()=>{!this.app.workspace.activeEditor||this.handleDictionnaire()}),app.workspace.onLayoutReady(()=>{this.showOrHideIcons()}),this.registerEvent(app.workspace.on("active-leaf-change",e=>{(e==null?void 0:e.view)instanceof ne.MarkdownView&&e.view.getMode()==="source"?this.showStatusBarIcons():this.hideStatusBarIcons()})),this.registerEvent(app.workspace.on("layout-change",()=>{let e=app.workspace.getActiveViewOfType(ne.MarkdownView);(e==null?void 0:e.getMode())==="source"?this.showStatusBarIcons():this.hideStatusBarIcons()})),this.addCommand({id:"antidote-corrector-all",name:ye("command.corrector_all.label"),editorCallback:()=>{!this.app.workspace.activeEditor||this.handleCorrecteur(!0)}}),this.addCommand({id:"antidote-corrector",name:ye("command.corrector.label"),editorCallback:()=>{!this.app.workspace.activeEditor||this.handleCorrecteur()}}),this.addCommand({id:"antidote-dictionary",name:ye("command.dictionary.label"),editorCallback:()=>{!this.app.workspace.activeEditor||this.handleDictionnaire()}}),this.addCommand({id:"antidote-guide",name:ye("command.guide.label"),editorCallback:()=>{!this.app.workspace.activeEditor||this.handleGuide()}}),this.addSettingTab(new P2(this.app,this))})}showOrHideIcons(){let e=app.workspace.getActiveViewOfType(ne.MarkdownView),r=(e==null?void 0:e.getMode())==="source";r&&this.settings.showCorrectorIcon?this.correctorStatusBar.removeClass("hide"):this.correctorStatusBar.addClass("hide"),r&&this.settings.showCorrectorAllIcon?this.correctorAllStatusBar.removeClass("hide"):this.correctorAllStatusBar.addClass("hide"),this.settings.showDictionaryIcon?this.dictionaryStatusBar.removeClass("hide"):this.dictionaryStatusBar.addClass("hide"),this.settings.showGuideIcon?this.guidesStatusBar.removeClass("hide"):this.guidesStatusBar.addClass("hide")}showStatusBarIcons(){this.settings.showCorrectorAllIcon&&this.correctorAllStatusBar.removeClass("hide"),this.settings.showCorrectorIcon&&this.correctorStatusBar.removeClass("hide"),this.settings.showDictionaryIcon&&this.dictionaryStatusBar.removeClass("hide"),this.settings.showGuideIcon&&this.guidesStatusBar.removeClass("hide")}hideStatusBarIcons(){this.correctorAllStatusBar.addClass("hide"),this.correctorStatusBar.addClass("hide"),this.dictionaryStatusBar.addClass("hide"),this.guidesStatusBar.addClass("hide")}setCorrectorStatusBarReady(){this.isloading=!1,this.correctorStatusBar.empty(),this.correctorStatusBar.addClass("mod-clickable","antidote-green"),this.correctorStatusBar.createSpan({attr:{"aria-label-position":"top","aria-label":ye("sidebar.corrector.label")}},e=>{(0,ne.setIcon)(e,"check")})}setCorrectorAllStatusBarReady(){this.isloading=!1,this.correctorAllStatusBar.empty(),this.correctorAllStatusBar.addClass("mod-clickable","antidote-green"),this.correctorAllStatusBar.createSpan({attr:{"aria-label-position":"top","aria-label":ye("sidebar.corrector_all.label")}},e=>{(0,ne.setIcon)(e,"check-circle")})}loadSettings(){return _e(this,null,function*(){this.settings=Object.assign({},xC,yield this.loadData())})}saveSettings(){return _e(this,null,function*(){yield this.saveData(this.settings)})}},P2=class extends ne.PluginSettingTab{constructor(e,r){super(e,r);this.plugin=r}display(){let{containerEl:e}=this;e.empty(),e.addClass("antidote-settings");let r=e.createEl("summary");new ne.Setting(r).setHeading().setName(ye("settings.title")),r.createDiv("collapser").createDiv("handle"),new ne.Setting(e).setName(ye("settings.corrector_all.title")).addToggle(f=>{f.setValue(this.plugin.settings.showCorrectorAllIcon).onChange(l=>_e(this,null,function*(){this.plugin.settings.showCorrectorAllIcon=l,yield this.plugin.saveSettings(),this.plugin.showOrHideIcons()}))}),new ne.Setting(e).setName(ye("settings.corrector.title")).addToggle(f=>{f.setValue(this.plugin.settings.showCorrectorIcon).onChange(l=>_e(this,null,function*(){this.plugin.settings.showCorrectorIcon=l,yield this.plugin.saveSettings(),this.plugin.showOrHideIcons()}))}),new ne.Setting(e).setName(ye("settings.dictionary.title")).addToggle(f=>{f.setValue(this.plugin.settings.showDictionaryIcon).onChange(l=>_e(this,null,function*(){this.plugin.settings.showDictionaryIcon=l,yield this.plugin.saveSettings(),this.plugin.showOrHideIcons()}))}),new ne.Setting(e).setName(ye("settings.guide.title")).addToggle(f=>{f.setValue(this.plugin.settings.showGuideIcon).onChange(l=>_e(this,null,function*(){this.plugin.settings.showGuideIcon=l,yield this.plugin.saveSettings(),this.plugin.showOrHideIcons()}))});let i=e.createEl("section",{cls:"donation-section"}),n=document.createElement("p");n.appendText(ye("settings.donation")),i.appendChild(n);let s=new DOMParser,h=e.createEl("div");h.addClass("antidote-settings-donation"),h.appendChild(L2("https://paypal.me/foetools",s.parseFromString(En,"text/xml").documentElement)),h.appendChild(L2("https://www.buymeacoffee.com/Heziode",s.parseFromString(wn,"text/xml").documentElement)),i.appendChild(h)}},L2=(t,e)=>{let r=document.createElement("a");return r.setAttribute("href",t),r.addClass("donate-button"),r.appendChild(e),r};0&&(module.exports={}); diff --git a/.obsidian/plugins/antidote-grammar-checker-integration/manifest.json b/.obsidian/plugins/antidote-grammar-checker-integration/manifest.json new file mode 100644 index 0000000..300fa75 --- /dev/null +++ b/.obsidian/plugins/antidote-grammar-checker-integration/manifest.json @@ -0,0 +1,11 @@ +{ + "id": "antidote-grammar-checker-integration", + "name": "Antidote Grammar Checker Integration", + "version": "2.1.2", + "minAppVersion": "0.15.0", + "description": "Unofficial integration of Antidote, a powerful English and French grammar checker", + "author": "Heziode", + "authorUrl": "https://github.com/Heziode", + "fundingUrl": "https://www.buymeacoffee.com/Heziode", + "isDesktopOnly": true +} \ No newline at end of file diff --git a/.obsidian/plugins/antidote-grammar-checker-integration/styles.css b/.obsidian/plugins/antidote-grammar-checker-integration/styles.css new file mode 100644 index 0000000..c8300c1 --- /dev/null +++ b/.obsidian/plugins/antidote-grammar-checker-integration/styles.css @@ -0,0 +1 @@ +.spin-loading>svg{animation-name:spin;animation-duration:1s;animation-iteration-count:infinite;animation-timing-function:linear}.antidote-green{color:var(--color-green)!important}.antidote-orange{color:var(--color-orange)!important}.antidote-settings-donation{display:flex;margin-top:2em}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hide{display:none}.antidote-settings>.setting-item{border:0px;padding-bottom:0}.antidote-settings summary{border-bottom:1px solid var(--background-modifier-border)}.donation-section{width:70%;margin:2em auto 0;text-align:center;padding-top:2em;border-top:1px solid var(--background-modifier-border)}.donate-button{margin:auto}.donate-button>svg{margin:auto;height:3em} diff --git a/.obsidian/plugins/obsidian-git/data.json b/.obsidian/plugins/obsidian-git/data.json new file mode 100644 index 0000000..fc5cd41 --- /dev/null +++ b/.obsidian/plugins/obsidian-git/data.json @@ -0,0 +1,55 @@ +{ + "commitMessage": "vault backup: {{date}}", + "commitDateFormat": "YYYY-MM-DD HH:mm:ss", + "autoSaveInterval": 2, + "autoPushInterval": 0, + "autoPullInterval": 0, + "autoPullOnBoot": false, + "disablePush": false, + "pullBeforePush": true, + "disablePopups": false, + "listChangedFilesInMessageBody": false, + "showStatusBar": true, + "updateSubmodules": false, + "syncMethod": "merge", + "customMessageOnAutoBackup": false, + "autoBackupAfterFileChange": true, + "treeStructure": false, + "refreshSourceControl": true, + "basePath": "", + "differentIntervalCommitAndPush": false, + "changedFilesInStatusBar": false, + "showedMobileNotice": true, + "refreshSourceControlTimer": 7000, + "showBranchStatusBar": true, + "setLastSaveToLastCommit": false, + "submoduleRecurseCheckout": false, + "gitDir": "", + "showFileMenu": true, + "lineAuthor": { + "show": false, + "followMovement": "inactive", + "authorDisplay": "initials", + "showCommitHash": false, + "dateTimeFormatOptions": "date", + "dateTimeFormatCustomString": "YYYY-MM-DD HH:mm", + "dateTimeTimezone": "viewer-local", + "coloringMaxAge": "1y", + "colorNew": { + "r": 255, + "g": 150, + "b": 150 + }, + "colorOld": { + "r": 120, + "g": 160, + "b": 255 + }, + "textColorCss": "var(--text-muted)", + "ignoreWhitespace": false, + "gutterSpacingFallbackLength": 5, + "lastShownAuthorDisplay": "initials", + "lastShownDateTimeFormatOptions": "date" + }, + "autoCommitMessage": "vault backup: {{date}}" +} \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-git/main.js b/.obsidian/plugins/obsidian-git/main.js new file mode 100644 index 0000000..dc70752 --- /dev/null +++ b/.obsidian/plugins/obsidian-git/main.js @@ -0,0 +1,44242 @@ +/* +THIS IS A GENERATED/BUNDLED FILE BY ESBUILD +if you want to view the source visit the plugins github repository (https://github.com/denolehov/obsidian-git) +*/ + +var __create = Object.create; +var __defProp = Object.defineProperty; +var __getOwnPropDesc = Object.getOwnPropertyDescriptor; +var __getOwnPropNames = Object.getOwnPropertyNames; +var __getProtoOf = Object.getPrototypeOf; +var __hasOwnProp = Object.prototype.hasOwnProperty; +var __defNormalProp = (obj, key2, value) => key2 in obj ? __defProp(obj, key2, { enumerable: true, configurable: true, writable: true, value }) : obj[key2] = value; +var __esm = (fn, res) => function __init() { + return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res; +}; +var __commonJS = (cb, mod) => function __require() { + return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; +}; +var __export = (target, all) => { + for (var name in all) + __defProp(target, name, { get: all[name], enumerable: true }); +}; +var __copyProps = (to, from, except, desc) => { + if (from && typeof from === "object" || typeof from === "function") { + for (let key2 of __getOwnPropNames(from)) + if (!__hasOwnProp.call(to, key2) && key2 !== except) + __defProp(to, key2, { get: () => from[key2], enumerable: !(desc = __getOwnPropDesc(from, key2)) || desc.enumerable }); + } + return to; +}; +var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( + // If the importer is in node compatibility mode or this is not an ESM + // file that has been converted to a CommonJS file using a Babel- + // compatible transform (i.e. "__esModule" has not been set), then set + // "default" to the CommonJS "module.exports" for node compatibility. + isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, + mod +)); +var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); +var __publicField = (obj, key2, value) => { + __defNormalProp(obj, typeof key2 !== "symbol" ? key2 + "" : key2, value); + return value; +}; + +// node_modules/.pnpm/base64-js@1.5.1/node_modules/base64-js/index.js +var require_base64_js = __commonJS({ + "node_modules/.pnpm/base64-js@1.5.1/node_modules/base64-js/index.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + exports2.byteLength = byteLength; + exports2.toByteArray = toByteArray; + exports2.fromByteArray = fromByteArray; + var lookup = []; + var revLookup = []; + var Arr = typeof Uint8Array !== "undefined" ? Uint8Array : Array; + var code = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; + for (i = 0, len = code.length; i < len; ++i) { + lookup[i] = code[i]; + revLookup[code.charCodeAt(i)] = i; + } + var i; + var len; + revLookup["-".charCodeAt(0)] = 62; + revLookup["_".charCodeAt(0)] = 63; + function getLens(b64) { + var len2 = b64.length; + if (len2 % 4 > 0) { + throw new Error("Invalid string. Length must be a multiple of 4"); + } + var validLen = b64.indexOf("="); + if (validLen === -1) + validLen = len2; + var placeHoldersLen = validLen === len2 ? 0 : 4 - validLen % 4; + return [validLen, placeHoldersLen]; + } + function byteLength(b64) { + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + return (validLen + placeHoldersLen) * 3 / 4 - placeHoldersLen; + } + function _byteLength(b64, validLen, placeHoldersLen) { + return (validLen + placeHoldersLen) * 3 / 4 - placeHoldersLen; + } + function toByteArray(b64) { + var tmp; + var lens = getLens(b64); + var validLen = lens[0]; + var placeHoldersLen = lens[1]; + var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen)); + var curByte = 0; + var len2 = placeHoldersLen > 0 ? validLen - 4 : validLen; + var i2; + for (i2 = 0; i2 < len2; i2 += 4) { + tmp = revLookup[b64.charCodeAt(i2)] << 18 | revLookup[b64.charCodeAt(i2 + 1)] << 12 | revLookup[b64.charCodeAt(i2 + 2)] << 6 | revLookup[b64.charCodeAt(i2 + 3)]; + arr[curByte++] = tmp >> 16 & 255; + arr[curByte++] = tmp >> 8 & 255; + arr[curByte++] = tmp & 255; + } + if (placeHoldersLen === 2) { + tmp = revLookup[b64.charCodeAt(i2)] << 2 | revLookup[b64.charCodeAt(i2 + 1)] >> 4; + arr[curByte++] = tmp & 255; + } + if (placeHoldersLen === 1) { + tmp = revLookup[b64.charCodeAt(i2)] << 10 | revLookup[b64.charCodeAt(i2 + 1)] << 4 | revLookup[b64.charCodeAt(i2 + 2)] >> 2; + arr[curByte++] = tmp >> 8 & 255; + arr[curByte++] = tmp & 255; + } + return arr; + } + function tripletToBase64(num2) { + return lookup[num2 >> 18 & 63] + lookup[num2 >> 12 & 63] + lookup[num2 >> 6 & 63] + lookup[num2 & 63]; + } + function encodeChunk(uint8, start, end) { + var tmp; + var output = []; + for (var i2 = start; i2 < end; i2 += 3) { + tmp = (uint8[i2] << 16 & 16711680) + (uint8[i2 + 1] << 8 & 65280) + (uint8[i2 + 2] & 255); + output.push(tripletToBase64(tmp)); + } + return output.join(""); + } + function fromByteArray(uint8) { + var tmp; + var len2 = uint8.length; + var extraBytes = len2 % 3; + var parts = []; + var maxChunkLength = 16383; + for (var i2 = 0, len22 = len2 - extraBytes; i2 < len22; i2 += maxChunkLength) { + parts.push(encodeChunk(uint8, i2, i2 + maxChunkLength > len22 ? len22 : i2 + maxChunkLength)); + } + if (extraBytes === 1) { + tmp = uint8[len2 - 1]; + parts.push( + lookup[tmp >> 2] + lookup[tmp << 4 & 63] + "==" + ); + } else if (extraBytes === 2) { + tmp = (uint8[len2 - 2] << 8) + uint8[len2 - 1]; + parts.push( + lookup[tmp >> 10] + lookup[tmp >> 4 & 63] + lookup[tmp << 2 & 63] + "=" + ); + } + return parts.join(""); + } + } +}); + +// node_modules/.pnpm/ieee754@1.2.1/node_modules/ieee754/index.js +var require_ieee754 = __commonJS({ + "node_modules/.pnpm/ieee754@1.2.1/node_modules/ieee754/index.js"(exports2) { + init_polyfill_buffer(); + exports2.read = function(buffer2, offset, isLE, mLen, nBytes) { + var e, m; + var eLen = nBytes * 8 - mLen - 1; + var eMax = (1 << eLen) - 1; + var eBias = eMax >> 1; + var nBits = -7; + var i = isLE ? nBytes - 1 : 0; + var d = isLE ? -1 : 1; + var s = buffer2[offset + i]; + i += d; + e = s & (1 << -nBits) - 1; + s >>= -nBits; + nBits += eLen; + for (; nBits > 0; e = e * 256 + buffer2[offset + i], i += d, nBits -= 8) { + } + m = e & (1 << -nBits) - 1; + e >>= -nBits; + nBits += mLen; + for (; nBits > 0; m = m * 256 + buffer2[offset + i], i += d, nBits -= 8) { + } + if (e === 0) { + e = 1 - eBias; + } else if (e === eMax) { + return m ? NaN : (s ? -1 : 1) * Infinity; + } else { + m = m + Math.pow(2, mLen); + e = e - eBias; + } + return (s ? -1 : 1) * m * Math.pow(2, e - mLen); + }; + exports2.write = function(buffer2, value, offset, isLE, mLen, nBytes) { + var e, m, c; + var eLen = nBytes * 8 - mLen - 1; + var eMax = (1 << eLen) - 1; + var eBias = eMax >> 1; + var rt = mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0; + var i = isLE ? 0 : nBytes - 1; + var d = isLE ? 1 : -1; + var s = value < 0 || value === 0 && 1 / value < 0 ? 1 : 0; + value = Math.abs(value); + if (isNaN(value) || value === Infinity) { + m = isNaN(value) ? 1 : 0; + e = eMax; + } else { + e = Math.floor(Math.log(value) / Math.LN2); + if (value * (c = Math.pow(2, -e)) < 1) { + e--; + c *= 2; + } + if (e + eBias >= 1) { + value += rt / c; + } else { + value += rt * Math.pow(2, 1 - eBias); + } + if (value * c >= 2) { + e++; + c /= 2; + } + if (e + eBias >= eMax) { + m = 0; + e = eMax; + } else if (e + eBias >= 1) { + m = (value * c - 1) * Math.pow(2, mLen); + e = e + eBias; + } else { + m = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen); + e = 0; + } + } + for (; mLen >= 8; buffer2[offset + i] = m & 255, i += d, m /= 256, mLen -= 8) { + } + e = e << mLen | m; + eLen += mLen; + for (; eLen > 0; buffer2[offset + i] = e & 255, i += d, e /= 256, eLen -= 8) { + } + buffer2[offset + i - d] |= s * 128; + }; + } +}); + +// node_modules/.pnpm/buffer@6.0.3/node_modules/buffer/index.js +var require_buffer = __commonJS({ + "node_modules/.pnpm/buffer@6.0.3/node_modules/buffer/index.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var base64 = require_base64_js(); + var ieee754 = require_ieee754(); + var customInspectSymbol = typeof Symbol === "function" && typeof Symbol["for"] === "function" ? Symbol["for"]("nodejs.util.inspect.custom") : null; + exports2.Buffer = Buffer2; + exports2.SlowBuffer = SlowBuffer; + exports2.INSPECT_MAX_BYTES = 50; + var K_MAX_LENGTH = 2147483647; + exports2.kMaxLength = K_MAX_LENGTH; + Buffer2.TYPED_ARRAY_SUPPORT = typedArraySupport(); + if (!Buffer2.TYPED_ARRAY_SUPPORT && typeof console !== "undefined" && typeof console.error === "function") { + console.error( + "This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support." + ); + } + function typedArraySupport() { + try { + const arr = new Uint8Array(1); + const proto = { foo: function() { + return 42; + } }; + Object.setPrototypeOf(proto, Uint8Array.prototype); + Object.setPrototypeOf(arr, proto); + return arr.foo() === 42; + } catch (e) { + return false; + } + } + Object.defineProperty(Buffer2.prototype, "parent", { + enumerable: true, + get: function() { + if (!Buffer2.isBuffer(this)) + return void 0; + return this.buffer; + } + }); + Object.defineProperty(Buffer2.prototype, "offset", { + enumerable: true, + get: function() { + if (!Buffer2.isBuffer(this)) + return void 0; + return this.byteOffset; + } + }); + function createBuffer(length) { + if (length > K_MAX_LENGTH) { + throw new RangeError('The value "' + length + '" is invalid for option "size"'); + } + const buf = new Uint8Array(length); + Object.setPrototypeOf(buf, Buffer2.prototype); + return buf; + } + function Buffer2(arg, encodingOrOffset, length) { + if (typeof arg === "number") { + if (typeof encodingOrOffset === "string") { + throw new TypeError( + 'The "string" argument must be of type string. Received type number' + ); + } + return allocUnsafe(arg); + } + return from(arg, encodingOrOffset, length); + } + Buffer2.poolSize = 8192; + function from(value, encodingOrOffset, length) { + if (typeof value === "string") { + return fromString2(value, encodingOrOffset); + } + if (ArrayBuffer.isView(value)) { + return fromArrayView(value); + } + if (value == null) { + throw new TypeError( + "The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value + ); + } + if (isInstance(value, ArrayBuffer) || value && isInstance(value.buffer, ArrayBuffer)) { + return fromArrayBuffer(value, encodingOrOffset, length); + } + if (typeof SharedArrayBuffer !== "undefined" && (isInstance(value, SharedArrayBuffer) || value && isInstance(value.buffer, SharedArrayBuffer))) { + return fromArrayBuffer(value, encodingOrOffset, length); + } + if (typeof value === "number") { + throw new TypeError( + 'The "value" argument must not be of type number. Received type number' + ); + } + const valueOf = value.valueOf && value.valueOf(); + if (valueOf != null && valueOf !== value) { + return Buffer2.from(valueOf, encodingOrOffset, length); + } + const b = fromObject(value); + if (b) + return b; + if (typeof Symbol !== "undefined" && Symbol.toPrimitive != null && typeof value[Symbol.toPrimitive] === "function") { + return Buffer2.from(value[Symbol.toPrimitive]("string"), encodingOrOffset, length); + } + throw new TypeError( + "The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value + ); + } + Buffer2.from = function(value, encodingOrOffset, length) { + return from(value, encodingOrOffset, length); + }; + Object.setPrototypeOf(Buffer2.prototype, Uint8Array.prototype); + Object.setPrototypeOf(Buffer2, Uint8Array); + function assertSize(size) { + if (typeof size !== "number") { + throw new TypeError('"size" argument must be of type number'); + } else if (size < 0) { + throw new RangeError('The value "' + size + '" is invalid for option "size"'); + } + } + function alloc(size, fill, encoding) { + assertSize(size); + if (size <= 0) { + return createBuffer(size); + } + if (fill !== void 0) { + return typeof encoding === "string" ? createBuffer(size).fill(fill, encoding) : createBuffer(size).fill(fill); + } + return createBuffer(size); + } + Buffer2.alloc = function(size, fill, encoding) { + return alloc(size, fill, encoding); + }; + function allocUnsafe(size) { + assertSize(size); + return createBuffer(size < 0 ? 0 : checked(size) | 0); + } + Buffer2.allocUnsafe = function(size) { + return allocUnsafe(size); + }; + Buffer2.allocUnsafeSlow = function(size) { + return allocUnsafe(size); + }; + function fromString2(string, encoding) { + if (typeof encoding !== "string" || encoding === "") { + encoding = "utf8"; + } + if (!Buffer2.isEncoding(encoding)) { + throw new TypeError("Unknown encoding: " + encoding); + } + const length = byteLength(string, encoding) | 0; + let buf = createBuffer(length); + const actual = buf.write(string, encoding); + if (actual !== length) { + buf = buf.slice(0, actual); + } + return buf; + } + function fromArrayLike(array) { + const length = array.length < 0 ? 0 : checked(array.length) | 0; + const buf = createBuffer(length); + for (let i = 0; i < length; i += 1) { + buf[i] = array[i] & 255; + } + return buf; + } + function fromArrayView(arrayView) { + if (isInstance(arrayView, Uint8Array)) { + const copy2 = new Uint8Array(arrayView); + return fromArrayBuffer(copy2.buffer, copy2.byteOffset, copy2.byteLength); + } + return fromArrayLike(arrayView); + } + function fromArrayBuffer(array, byteOffset, length) { + if (byteOffset < 0 || array.byteLength < byteOffset) { + throw new RangeError('"offset" is outside of buffer bounds'); + } + if (array.byteLength < byteOffset + (length || 0)) { + throw new RangeError('"length" is outside of buffer bounds'); + } + let buf; + if (byteOffset === void 0 && length === void 0) { + buf = new Uint8Array(array); + } else if (length === void 0) { + buf = new Uint8Array(array, byteOffset); + } else { + buf = new Uint8Array(array, byteOffset, length); + } + Object.setPrototypeOf(buf, Buffer2.prototype); + return buf; + } + function fromObject(obj) { + if (Buffer2.isBuffer(obj)) { + const len = checked(obj.length) | 0; + const buf = createBuffer(len); + if (buf.length === 0) { + return buf; + } + obj.copy(buf, 0, 0, len); + return buf; + } + if (obj.length !== void 0) { + if (typeof obj.length !== "number" || numberIsNaN(obj.length)) { + return createBuffer(0); + } + return fromArrayLike(obj); + } + if (obj.type === "Buffer" && Array.isArray(obj.data)) { + return fromArrayLike(obj.data); + } + } + function checked(length) { + if (length >= K_MAX_LENGTH) { + throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x" + K_MAX_LENGTH.toString(16) + " bytes"); + } + return length | 0; + } + function SlowBuffer(length) { + if (+length != length) { + length = 0; + } + return Buffer2.alloc(+length); + } + Buffer2.isBuffer = function isBuffer(b) { + return b != null && b._isBuffer === true && b !== Buffer2.prototype; + }; + Buffer2.compare = function compare(a, b) { + if (isInstance(a, Uint8Array)) + a = Buffer2.from(a, a.offset, a.byteLength); + if (isInstance(b, Uint8Array)) + b = Buffer2.from(b, b.offset, b.byteLength); + if (!Buffer2.isBuffer(a) || !Buffer2.isBuffer(b)) { + throw new TypeError( + 'The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array' + ); + } + if (a === b) + return 0; + let x = a.length; + let y = b.length; + for (let i = 0, len = Math.min(x, y); i < len; ++i) { + if (a[i] !== b[i]) { + x = a[i]; + y = b[i]; + break; + } + } + if (x < y) + return -1; + if (y < x) + return 1; + return 0; + }; + Buffer2.isEncoding = function isEncoding(encoding) { + switch (String(encoding).toLowerCase()) { + case "hex": + case "utf8": + case "utf-8": + case "ascii": + case "latin1": + case "binary": + case "base64": + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return true; + default: + return false; + } + }; + Buffer2.concat = function concat(list, length) { + if (!Array.isArray(list)) { + throw new TypeError('"list" argument must be an Array of Buffers'); + } + if (list.length === 0) { + return Buffer2.alloc(0); + } + let i; + if (length === void 0) { + length = 0; + for (i = 0; i < list.length; ++i) { + length += list[i].length; + } + } + const buffer2 = Buffer2.allocUnsafe(length); + let pos = 0; + for (i = 0; i < list.length; ++i) { + let buf = list[i]; + if (isInstance(buf, Uint8Array)) { + if (pos + buf.length > buffer2.length) { + if (!Buffer2.isBuffer(buf)) + buf = Buffer2.from(buf); + buf.copy(buffer2, pos); + } else { + Uint8Array.prototype.set.call( + buffer2, + buf, + pos + ); + } + } else if (!Buffer2.isBuffer(buf)) { + throw new TypeError('"list" argument must be an Array of Buffers'); + } else { + buf.copy(buffer2, pos); + } + pos += buf.length; + } + return buffer2; + }; + function byteLength(string, encoding) { + if (Buffer2.isBuffer(string)) { + return string.length; + } + if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) { + return string.byteLength; + } + if (typeof string !== "string") { + throw new TypeError( + 'The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type ' + typeof string + ); + } + const len = string.length; + const mustMatch = arguments.length > 2 && arguments[2] === true; + if (!mustMatch && len === 0) + return 0; + let loweredCase = false; + for (; ; ) { + switch (encoding) { + case "ascii": + case "latin1": + case "binary": + return len; + case "utf8": + case "utf-8": + return utf8ToBytes(string).length; + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return len * 2; + case "hex": + return len >>> 1; + case "base64": + return base64ToBytes(string).length; + default: + if (loweredCase) { + return mustMatch ? -1 : utf8ToBytes(string).length; + } + encoding = ("" + encoding).toLowerCase(); + loweredCase = true; + } + } + } + Buffer2.byteLength = byteLength; + function slowToString(encoding, start, end) { + let loweredCase = false; + if (start === void 0 || start < 0) { + start = 0; + } + if (start > this.length) { + return ""; + } + if (end === void 0 || end > this.length) { + end = this.length; + } + if (end <= 0) { + return ""; + } + end >>>= 0; + start >>>= 0; + if (end <= start) { + return ""; + } + if (!encoding) + encoding = "utf8"; + while (true) { + switch (encoding) { + case "hex": + return hexSlice(this, start, end); + case "utf8": + case "utf-8": + return utf8Slice(this, start, end); + case "ascii": + return asciiSlice(this, start, end); + case "latin1": + case "binary": + return latin1Slice(this, start, end); + case "base64": + return base64Slice(this, start, end); + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return utf16leSlice(this, start, end); + default: + if (loweredCase) + throw new TypeError("Unknown encoding: " + encoding); + encoding = (encoding + "").toLowerCase(); + loweredCase = true; + } + } + } + Buffer2.prototype._isBuffer = true; + function swap(b, n, m) { + const i = b[n]; + b[n] = b[m]; + b[m] = i; + } + Buffer2.prototype.swap16 = function swap16() { + const len = this.length; + if (len % 2 !== 0) { + throw new RangeError("Buffer size must be a multiple of 16-bits"); + } + for (let i = 0; i < len; i += 2) { + swap(this, i, i + 1); + } + return this; + }; + Buffer2.prototype.swap32 = function swap32() { + const len = this.length; + if (len % 4 !== 0) { + throw new RangeError("Buffer size must be a multiple of 32-bits"); + } + for (let i = 0; i < len; i += 4) { + swap(this, i, i + 3); + swap(this, i + 1, i + 2); + } + return this; + }; + Buffer2.prototype.swap64 = function swap64() { + const len = this.length; + if (len % 8 !== 0) { + throw new RangeError("Buffer size must be a multiple of 64-bits"); + } + for (let i = 0; i < len; i += 8) { + swap(this, i, i + 7); + swap(this, i + 1, i + 6); + swap(this, i + 2, i + 5); + swap(this, i + 3, i + 4); + } + return this; + }; + Buffer2.prototype.toString = function toString() { + const length = this.length; + if (length === 0) + return ""; + if (arguments.length === 0) + return utf8Slice(this, 0, length); + return slowToString.apply(this, arguments); + }; + Buffer2.prototype.toLocaleString = Buffer2.prototype.toString; + Buffer2.prototype.equals = function equals2(b) { + if (!Buffer2.isBuffer(b)) + throw new TypeError("Argument must be a Buffer"); + if (this === b) + return true; + return Buffer2.compare(this, b) === 0; + }; + Buffer2.prototype.inspect = function inspect() { + let str = ""; + const max = exports2.INSPECT_MAX_BYTES; + str = this.toString("hex", 0, max).replace(/(.{2})/g, "$1 ").trim(); + if (this.length > max) + str += " ... "; + return ""; + }; + if (customInspectSymbol) { + Buffer2.prototype[customInspectSymbol] = Buffer2.prototype.inspect; + } + Buffer2.prototype.compare = function compare(target, start, end, thisStart, thisEnd) { + if (isInstance(target, Uint8Array)) { + target = Buffer2.from(target, target.offset, target.byteLength); + } + if (!Buffer2.isBuffer(target)) { + throw new TypeError( + 'The "target" argument must be one of type Buffer or Uint8Array. Received type ' + typeof target + ); + } + if (start === void 0) { + start = 0; + } + if (end === void 0) { + end = target ? target.length : 0; + } + if (thisStart === void 0) { + thisStart = 0; + } + if (thisEnd === void 0) { + thisEnd = this.length; + } + if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) { + throw new RangeError("out of range index"); + } + if (thisStart >= thisEnd && start >= end) { + return 0; + } + if (thisStart >= thisEnd) { + return -1; + } + if (start >= end) { + return 1; + } + start >>>= 0; + end >>>= 0; + thisStart >>>= 0; + thisEnd >>>= 0; + if (this === target) + return 0; + let x = thisEnd - thisStart; + let y = end - start; + const len = Math.min(x, y); + const thisCopy = this.slice(thisStart, thisEnd); + const targetCopy = target.slice(start, end); + for (let i = 0; i < len; ++i) { + if (thisCopy[i] !== targetCopy[i]) { + x = thisCopy[i]; + y = targetCopy[i]; + break; + } + } + if (x < y) + return -1; + if (y < x) + return 1; + return 0; + }; + function bidirectionalIndexOf(buffer2, val, byteOffset, encoding, dir) { + if (buffer2.length === 0) + return -1; + if (typeof byteOffset === "string") { + encoding = byteOffset; + byteOffset = 0; + } else if (byteOffset > 2147483647) { + byteOffset = 2147483647; + } else if (byteOffset < -2147483648) { + byteOffset = -2147483648; + } + byteOffset = +byteOffset; + if (numberIsNaN(byteOffset)) { + byteOffset = dir ? 0 : buffer2.length - 1; + } + if (byteOffset < 0) + byteOffset = buffer2.length + byteOffset; + if (byteOffset >= buffer2.length) { + if (dir) + return -1; + else + byteOffset = buffer2.length - 1; + } else if (byteOffset < 0) { + if (dir) + byteOffset = 0; + else + return -1; + } + if (typeof val === "string") { + val = Buffer2.from(val, encoding); + } + if (Buffer2.isBuffer(val)) { + if (val.length === 0) { + return -1; + } + return arrayIndexOf(buffer2, val, byteOffset, encoding, dir); + } else if (typeof val === "number") { + val = val & 255; + if (typeof Uint8Array.prototype.indexOf === "function") { + if (dir) { + return Uint8Array.prototype.indexOf.call(buffer2, val, byteOffset); + } else { + return Uint8Array.prototype.lastIndexOf.call(buffer2, val, byteOffset); + } + } + return arrayIndexOf(buffer2, [val], byteOffset, encoding, dir); + } + throw new TypeError("val must be string, number or Buffer"); + } + function arrayIndexOf(arr, val, byteOffset, encoding, dir) { + let indexSize = 1; + let arrLength = arr.length; + let valLength = val.length; + if (encoding !== void 0) { + encoding = String(encoding).toLowerCase(); + if (encoding === "ucs2" || encoding === "ucs-2" || encoding === "utf16le" || encoding === "utf-16le") { + if (arr.length < 2 || val.length < 2) { + return -1; + } + indexSize = 2; + arrLength /= 2; + valLength /= 2; + byteOffset /= 2; + } + } + function read(buf, i2) { + if (indexSize === 1) { + return buf[i2]; + } else { + return buf.readUInt16BE(i2 * indexSize); + } + } + let i; + if (dir) { + let foundIndex = -1; + for (i = byteOffset; i < arrLength; i++) { + if (read(arr, i) === read(val, foundIndex === -1 ? 0 : i - foundIndex)) { + if (foundIndex === -1) + foundIndex = i; + if (i - foundIndex + 1 === valLength) + return foundIndex * indexSize; + } else { + if (foundIndex !== -1) + i -= i - foundIndex; + foundIndex = -1; + } + } + } else { + if (byteOffset + valLength > arrLength) + byteOffset = arrLength - valLength; + for (i = byteOffset; i >= 0; i--) { + let found = true; + for (let j = 0; j < valLength; j++) { + if (read(arr, i + j) !== read(val, j)) { + found = false; + break; + } + } + if (found) + return i; + } + } + return -1; + } + Buffer2.prototype.includes = function includes(val, byteOffset, encoding) { + return this.indexOf(val, byteOffset, encoding) !== -1; + }; + Buffer2.prototype.indexOf = function indexOf(val, byteOffset, encoding) { + return bidirectionalIndexOf(this, val, byteOffset, encoding, true); + }; + Buffer2.prototype.lastIndexOf = function lastIndexOf(val, byteOffset, encoding) { + return bidirectionalIndexOf(this, val, byteOffset, encoding, false); + }; + function hexWrite(buf, string, offset, length) { + offset = Number(offset) || 0; + const remaining = buf.length - offset; + if (!length) { + length = remaining; + } else { + length = Number(length); + if (length > remaining) { + length = remaining; + } + } + const strLen = string.length; + if (length > strLen / 2) { + length = strLen / 2; + } + let i; + for (i = 0; i < length; ++i) { + const parsed = parseInt(string.substr(i * 2, 2), 16); + if (numberIsNaN(parsed)) + return i; + buf[offset + i] = parsed; + } + return i; + } + function utf8Write(buf, string, offset, length) { + return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length); + } + function asciiWrite(buf, string, offset, length) { + return blitBuffer(asciiToBytes(string), buf, offset, length); + } + function base64Write(buf, string, offset, length) { + return blitBuffer(base64ToBytes(string), buf, offset, length); + } + function ucs2Write(buf, string, offset, length) { + return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length); + } + Buffer2.prototype.write = function write(string, offset, length, encoding) { + if (offset === void 0) { + encoding = "utf8"; + length = this.length; + offset = 0; + } else if (length === void 0 && typeof offset === "string") { + encoding = offset; + length = this.length; + offset = 0; + } else if (isFinite(offset)) { + offset = offset >>> 0; + if (isFinite(length)) { + length = length >>> 0; + if (encoding === void 0) + encoding = "utf8"; + } else { + encoding = length; + length = void 0; + } + } else { + throw new Error( + "Buffer.write(string, encoding, offset[, length]) is no longer supported" + ); + } + const remaining = this.length - offset; + if (length === void 0 || length > remaining) + length = remaining; + if (string.length > 0 && (length < 0 || offset < 0) || offset > this.length) { + throw new RangeError("Attempt to write outside buffer bounds"); + } + if (!encoding) + encoding = "utf8"; + let loweredCase = false; + for (; ; ) { + switch (encoding) { + case "hex": + return hexWrite(this, string, offset, length); + case "utf8": + case "utf-8": + return utf8Write(this, string, offset, length); + case "ascii": + case "latin1": + case "binary": + return asciiWrite(this, string, offset, length); + case "base64": + return base64Write(this, string, offset, length); + case "ucs2": + case "ucs-2": + case "utf16le": + case "utf-16le": + return ucs2Write(this, string, offset, length); + default: + if (loweredCase) + throw new TypeError("Unknown encoding: " + encoding); + encoding = ("" + encoding).toLowerCase(); + loweredCase = true; + } + } + }; + Buffer2.prototype.toJSON = function toJSON() { + return { + type: "Buffer", + data: Array.prototype.slice.call(this._arr || this, 0) + }; + }; + function base64Slice(buf, start, end) { + if (start === 0 && end === buf.length) { + return base64.fromByteArray(buf); + } else { + return base64.fromByteArray(buf.slice(start, end)); + } + } + function utf8Slice(buf, start, end) { + end = Math.min(buf.length, end); + const res = []; + let i = start; + while (i < end) { + const firstByte = buf[i]; + let codePoint = null; + let bytesPerSequence = firstByte > 239 ? 4 : firstByte > 223 ? 3 : firstByte > 191 ? 2 : 1; + if (i + bytesPerSequence <= end) { + let secondByte, thirdByte, fourthByte, tempCodePoint; + switch (bytesPerSequence) { + case 1: + if (firstByte < 128) { + codePoint = firstByte; + } + break; + case 2: + secondByte = buf[i + 1]; + if ((secondByte & 192) === 128) { + tempCodePoint = (firstByte & 31) << 6 | secondByte & 63; + if (tempCodePoint > 127) { + codePoint = tempCodePoint; + } + } + break; + case 3: + secondByte = buf[i + 1]; + thirdByte = buf[i + 2]; + if ((secondByte & 192) === 128 && (thirdByte & 192) === 128) { + tempCodePoint = (firstByte & 15) << 12 | (secondByte & 63) << 6 | thirdByte & 63; + if (tempCodePoint > 2047 && (tempCodePoint < 55296 || tempCodePoint > 57343)) { + codePoint = tempCodePoint; + } + } + break; + case 4: + secondByte = buf[i + 1]; + thirdByte = buf[i + 2]; + fourthByte = buf[i + 3]; + if ((secondByte & 192) === 128 && (thirdByte & 192) === 128 && (fourthByte & 192) === 128) { + tempCodePoint = (firstByte & 15) << 18 | (secondByte & 63) << 12 | (thirdByte & 63) << 6 | fourthByte & 63; + if (tempCodePoint > 65535 && tempCodePoint < 1114112) { + codePoint = tempCodePoint; + } + } + } + } + if (codePoint === null) { + codePoint = 65533; + bytesPerSequence = 1; + } else if (codePoint > 65535) { + codePoint -= 65536; + res.push(codePoint >>> 10 & 1023 | 55296); + codePoint = 56320 | codePoint & 1023; + } + res.push(codePoint); + i += bytesPerSequence; + } + return decodeCodePointsArray(res); + } + var MAX_ARGUMENTS_LENGTH = 4096; + function decodeCodePointsArray(codePoints) { + const len = codePoints.length; + if (len <= MAX_ARGUMENTS_LENGTH) { + return String.fromCharCode.apply(String, codePoints); + } + let res = ""; + let i = 0; + while (i < len) { + res += String.fromCharCode.apply( + String, + codePoints.slice(i, i += MAX_ARGUMENTS_LENGTH) + ); + } + return res; + } + function asciiSlice(buf, start, end) { + let ret = ""; + end = Math.min(buf.length, end); + for (let i = start; i < end; ++i) { + ret += String.fromCharCode(buf[i] & 127); + } + return ret; + } + function latin1Slice(buf, start, end) { + let ret = ""; + end = Math.min(buf.length, end); + for (let i = start; i < end; ++i) { + ret += String.fromCharCode(buf[i]); + } + return ret; + } + function hexSlice(buf, start, end) { + const len = buf.length; + if (!start || start < 0) + start = 0; + if (!end || end < 0 || end > len) + end = len; + let out = ""; + for (let i = start; i < end; ++i) { + out += hexSliceLookupTable[buf[i]]; + } + return out; + } + function utf16leSlice(buf, start, end) { + const bytes = buf.slice(start, end); + let res = ""; + for (let i = 0; i < bytes.length - 1; i += 2) { + res += String.fromCharCode(bytes[i] + bytes[i + 1] * 256); + } + return res; + } + Buffer2.prototype.slice = function slice(start, end) { + const len = this.length; + start = ~~start; + end = end === void 0 ? len : ~~end; + if (start < 0) { + start += len; + if (start < 0) + start = 0; + } else if (start > len) { + start = len; + } + if (end < 0) { + end += len; + if (end < 0) + end = 0; + } else if (end > len) { + end = len; + } + if (end < start) + end = start; + const newBuf = this.subarray(start, end); + Object.setPrototypeOf(newBuf, Buffer2.prototype); + return newBuf; + }; + function checkOffset(offset, ext, length) { + if (offset % 1 !== 0 || offset < 0) + throw new RangeError("offset is not uint"); + if (offset + ext > length) + throw new RangeError("Trying to access beyond buffer length"); + } + Buffer2.prototype.readUintLE = Buffer2.prototype.readUIntLE = function readUIntLE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) + checkOffset(offset, byteLength2, this.length); + let val = this[offset]; + let mul = 1; + let i = 0; + while (++i < byteLength2 && (mul *= 256)) { + val += this[offset + i] * mul; + } + return val; + }; + Buffer2.prototype.readUintBE = Buffer2.prototype.readUIntBE = function readUIntBE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) { + checkOffset(offset, byteLength2, this.length); + } + let val = this[offset + --byteLength2]; + let mul = 1; + while (byteLength2 > 0 && (mul *= 256)) { + val += this[offset + --byteLength2] * mul; + } + return val; + }; + Buffer2.prototype.readUint8 = Buffer2.prototype.readUInt8 = function readUInt8(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 1, this.length); + return this[offset]; + }; + Buffer2.prototype.readUint16LE = Buffer2.prototype.readUInt16LE = function readUInt16LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + return this[offset] | this[offset + 1] << 8; + }; + Buffer2.prototype.readUint16BE = Buffer2.prototype.readUInt16BE = function readUInt16BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + return this[offset] << 8 | this[offset + 1]; + }; + Buffer2.prototype.readUint32LE = Buffer2.prototype.readUInt32LE = function readUInt32LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return (this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16) + this[offset + 3] * 16777216; + }; + Buffer2.prototype.readUint32BE = Buffer2.prototype.readUInt32BE = function readUInt32BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return this[offset] * 16777216 + (this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]); + }; + Buffer2.prototype.readBigUInt64LE = defineBigIntMethod(function readBigUInt64LE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const lo = first2 + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 24; + const hi = this[++offset] + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + last2 * 2 ** 24; + return BigInt(lo) + (BigInt(hi) << BigInt(32)); + }); + Buffer2.prototype.readBigUInt64BE = defineBigIntMethod(function readBigUInt64BE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const hi = first2 * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + this[++offset]; + const lo = this[++offset] * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + last2; + return (BigInt(hi) << BigInt(32)) + BigInt(lo); + }); + Buffer2.prototype.readIntLE = function readIntLE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) + checkOffset(offset, byteLength2, this.length); + let val = this[offset]; + let mul = 1; + let i = 0; + while (++i < byteLength2 && (mul *= 256)) { + val += this[offset + i] * mul; + } + mul *= 128; + if (val >= mul) + val -= Math.pow(2, 8 * byteLength2); + return val; + }; + Buffer2.prototype.readIntBE = function readIntBE(offset, byteLength2, noAssert) { + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) + checkOffset(offset, byteLength2, this.length); + let i = byteLength2; + let mul = 1; + let val = this[offset + --i]; + while (i > 0 && (mul *= 256)) { + val += this[offset + --i] * mul; + } + mul *= 128; + if (val >= mul) + val -= Math.pow(2, 8 * byteLength2); + return val; + }; + Buffer2.prototype.readInt8 = function readInt8(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 1, this.length); + if (!(this[offset] & 128)) + return this[offset]; + return (255 - this[offset] + 1) * -1; + }; + Buffer2.prototype.readInt16LE = function readInt16LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + const val = this[offset] | this[offset + 1] << 8; + return val & 32768 ? val | 4294901760 : val; + }; + Buffer2.prototype.readInt16BE = function readInt16BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 2, this.length); + const val = this[offset + 1] | this[offset] << 8; + return val & 32768 ? val | 4294901760 : val; + }; + Buffer2.prototype.readInt32LE = function readInt32LE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16 | this[offset + 3] << 24; + }; + Buffer2.prototype.readInt32BE = function readInt32BE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return this[offset] << 24 | this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]; + }; + Buffer2.prototype.readBigInt64LE = defineBigIntMethod(function readBigInt64LE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const val = this[offset + 4] + this[offset + 5] * 2 ** 8 + this[offset + 6] * 2 ** 16 + (last2 << 24); + return (BigInt(val) << BigInt(32)) + BigInt(first2 + this[++offset] * 2 ** 8 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 24); + }); + Buffer2.prototype.readBigInt64BE = defineBigIntMethod(function readBigInt64BE(offset) { + offset = offset >>> 0; + validateNumber(offset, "offset"); + const first2 = this[offset]; + const last2 = this[offset + 7]; + if (first2 === void 0 || last2 === void 0) { + boundsError(offset, this.length - 8); + } + const val = (first2 << 24) + // Overflow + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + this[++offset]; + return (BigInt(val) << BigInt(32)) + BigInt(this[++offset] * 2 ** 24 + this[++offset] * 2 ** 16 + this[++offset] * 2 ** 8 + last2); + }); + Buffer2.prototype.readFloatLE = function readFloatLE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return ieee754.read(this, offset, true, 23, 4); + }; + Buffer2.prototype.readFloatBE = function readFloatBE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 4, this.length); + return ieee754.read(this, offset, false, 23, 4); + }; + Buffer2.prototype.readDoubleLE = function readDoubleLE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 8, this.length); + return ieee754.read(this, offset, true, 52, 8); + }; + Buffer2.prototype.readDoubleBE = function readDoubleBE(offset, noAssert) { + offset = offset >>> 0; + if (!noAssert) + checkOffset(offset, 8, this.length); + return ieee754.read(this, offset, false, 52, 8); + }; + function checkInt(buf, value, offset, ext, max, min) { + if (!Buffer2.isBuffer(buf)) + throw new TypeError('"buffer" argument must be a Buffer instance'); + if (value > max || value < min) + throw new RangeError('"value" argument is out of bounds'); + if (offset + ext > buf.length) + throw new RangeError("Index out of range"); + } + Buffer2.prototype.writeUintLE = Buffer2.prototype.writeUIntLE = function writeUIntLE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) { + const maxBytes = Math.pow(2, 8 * byteLength2) - 1; + checkInt(this, value, offset, byteLength2, maxBytes, 0); + } + let mul = 1; + let i = 0; + this[offset] = value & 255; + while (++i < byteLength2 && (mul *= 256)) { + this[offset + i] = value / mul & 255; + } + return offset + byteLength2; + }; + Buffer2.prototype.writeUintBE = Buffer2.prototype.writeUIntBE = function writeUIntBE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + byteLength2 = byteLength2 >>> 0; + if (!noAssert) { + const maxBytes = Math.pow(2, 8 * byteLength2) - 1; + checkInt(this, value, offset, byteLength2, maxBytes, 0); + } + let i = byteLength2 - 1; + let mul = 1; + this[offset + i] = value & 255; + while (--i >= 0 && (mul *= 256)) { + this[offset + i] = value / mul & 255; + } + return offset + byteLength2; + }; + Buffer2.prototype.writeUint8 = Buffer2.prototype.writeUInt8 = function writeUInt8(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 1, 255, 0); + this[offset] = value & 255; + return offset + 1; + }; + Buffer2.prototype.writeUint16LE = Buffer2.prototype.writeUInt16LE = function writeUInt16LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 65535, 0); + this[offset] = value & 255; + this[offset + 1] = value >>> 8; + return offset + 2; + }; + Buffer2.prototype.writeUint16BE = Buffer2.prototype.writeUInt16BE = function writeUInt16BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 65535, 0); + this[offset] = value >>> 8; + this[offset + 1] = value & 255; + return offset + 2; + }; + Buffer2.prototype.writeUint32LE = Buffer2.prototype.writeUInt32LE = function writeUInt32LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 4294967295, 0); + this[offset + 3] = value >>> 24; + this[offset + 2] = value >>> 16; + this[offset + 1] = value >>> 8; + this[offset] = value & 255; + return offset + 4; + }; + Buffer2.prototype.writeUint32BE = Buffer2.prototype.writeUInt32BE = function writeUInt32BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 4294967295, 0); + this[offset] = value >>> 24; + this[offset + 1] = value >>> 16; + this[offset + 2] = value >>> 8; + this[offset + 3] = value & 255; + return offset + 4; + }; + function wrtBigUInt64LE(buf, value, offset, min, max) { + checkIntBI(value, min, max, buf, offset, 7); + let lo = Number(value & BigInt(4294967295)); + buf[offset++] = lo; + lo = lo >> 8; + buf[offset++] = lo; + lo = lo >> 8; + buf[offset++] = lo; + lo = lo >> 8; + buf[offset++] = lo; + let hi = Number(value >> BigInt(32) & BigInt(4294967295)); + buf[offset++] = hi; + hi = hi >> 8; + buf[offset++] = hi; + hi = hi >> 8; + buf[offset++] = hi; + hi = hi >> 8; + buf[offset++] = hi; + return offset; + } + function wrtBigUInt64BE(buf, value, offset, min, max) { + checkIntBI(value, min, max, buf, offset, 7); + let lo = Number(value & BigInt(4294967295)); + buf[offset + 7] = lo; + lo = lo >> 8; + buf[offset + 6] = lo; + lo = lo >> 8; + buf[offset + 5] = lo; + lo = lo >> 8; + buf[offset + 4] = lo; + let hi = Number(value >> BigInt(32) & BigInt(4294967295)); + buf[offset + 3] = hi; + hi = hi >> 8; + buf[offset + 2] = hi; + hi = hi >> 8; + buf[offset + 1] = hi; + hi = hi >> 8; + buf[offset] = hi; + return offset + 8; + } + Buffer2.prototype.writeBigUInt64LE = defineBigIntMethod(function writeBigUInt64LE(value, offset = 0) { + return wrtBigUInt64LE(this, value, offset, BigInt(0), BigInt("0xffffffffffffffff")); + }); + Buffer2.prototype.writeBigUInt64BE = defineBigIntMethod(function writeBigUInt64BE(value, offset = 0) { + return wrtBigUInt64BE(this, value, offset, BigInt(0), BigInt("0xffffffffffffffff")); + }); + Buffer2.prototype.writeIntLE = function writeIntLE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + const limit = Math.pow(2, 8 * byteLength2 - 1); + checkInt(this, value, offset, byteLength2, limit - 1, -limit); + } + let i = 0; + let mul = 1; + let sub = 0; + this[offset] = value & 255; + while (++i < byteLength2 && (mul *= 256)) { + if (value < 0 && sub === 0 && this[offset + i - 1] !== 0) { + sub = 1; + } + this[offset + i] = (value / mul >> 0) - sub & 255; + } + return offset + byteLength2; + }; + Buffer2.prototype.writeIntBE = function writeIntBE(value, offset, byteLength2, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + const limit = Math.pow(2, 8 * byteLength2 - 1); + checkInt(this, value, offset, byteLength2, limit - 1, -limit); + } + let i = byteLength2 - 1; + let mul = 1; + let sub = 0; + this[offset + i] = value & 255; + while (--i >= 0 && (mul *= 256)) { + if (value < 0 && sub === 0 && this[offset + i + 1] !== 0) { + sub = 1; + } + this[offset + i] = (value / mul >> 0) - sub & 255; + } + return offset + byteLength2; + }; + Buffer2.prototype.writeInt8 = function writeInt8(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 1, 127, -128); + if (value < 0) + value = 255 + value + 1; + this[offset] = value & 255; + return offset + 1; + }; + Buffer2.prototype.writeInt16LE = function writeInt16LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 32767, -32768); + this[offset] = value & 255; + this[offset + 1] = value >>> 8; + return offset + 2; + }; + Buffer2.prototype.writeInt16BE = function writeInt16BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 2, 32767, -32768); + this[offset] = value >>> 8; + this[offset + 1] = value & 255; + return offset + 2; + }; + Buffer2.prototype.writeInt32LE = function writeInt32LE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 2147483647, -2147483648); + this[offset] = value & 255; + this[offset + 1] = value >>> 8; + this[offset + 2] = value >>> 16; + this[offset + 3] = value >>> 24; + return offset + 4; + }; + Buffer2.prototype.writeInt32BE = function writeInt32BE(value, offset, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) + checkInt(this, value, offset, 4, 2147483647, -2147483648); + if (value < 0) + value = 4294967295 + value + 1; + this[offset] = value >>> 24; + this[offset + 1] = value >>> 16; + this[offset + 2] = value >>> 8; + this[offset + 3] = value & 255; + return offset + 4; + }; + Buffer2.prototype.writeBigInt64LE = defineBigIntMethod(function writeBigInt64LE(value, offset = 0) { + return wrtBigUInt64LE(this, value, offset, -BigInt("0x8000000000000000"), BigInt("0x7fffffffffffffff")); + }); + Buffer2.prototype.writeBigInt64BE = defineBigIntMethod(function writeBigInt64BE(value, offset = 0) { + return wrtBigUInt64BE(this, value, offset, -BigInt("0x8000000000000000"), BigInt("0x7fffffffffffffff")); + }); + function checkIEEE754(buf, value, offset, ext, max, min) { + if (offset + ext > buf.length) + throw new RangeError("Index out of range"); + if (offset < 0) + throw new RangeError("Index out of range"); + } + function writeFloat(buf, value, offset, littleEndian, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + checkIEEE754(buf, value, offset, 4, 34028234663852886e22, -34028234663852886e22); + } + ieee754.write(buf, value, offset, littleEndian, 23, 4); + return offset + 4; + } + Buffer2.prototype.writeFloatLE = function writeFloatLE(value, offset, noAssert) { + return writeFloat(this, value, offset, true, noAssert); + }; + Buffer2.prototype.writeFloatBE = function writeFloatBE(value, offset, noAssert) { + return writeFloat(this, value, offset, false, noAssert); + }; + function writeDouble(buf, value, offset, littleEndian, noAssert) { + value = +value; + offset = offset >>> 0; + if (!noAssert) { + checkIEEE754(buf, value, offset, 8, 17976931348623157e292, -17976931348623157e292); + } + ieee754.write(buf, value, offset, littleEndian, 52, 8); + return offset + 8; + } + Buffer2.prototype.writeDoubleLE = function writeDoubleLE(value, offset, noAssert) { + return writeDouble(this, value, offset, true, noAssert); + }; + Buffer2.prototype.writeDoubleBE = function writeDoubleBE(value, offset, noAssert) { + return writeDouble(this, value, offset, false, noAssert); + }; + Buffer2.prototype.copy = function copy2(target, targetStart, start, end) { + if (!Buffer2.isBuffer(target)) + throw new TypeError("argument should be a Buffer"); + if (!start) + start = 0; + if (!end && end !== 0) + end = this.length; + if (targetStart >= target.length) + targetStart = target.length; + if (!targetStart) + targetStart = 0; + if (end > 0 && end < start) + end = start; + if (end === start) + return 0; + if (target.length === 0 || this.length === 0) + return 0; + if (targetStart < 0) { + throw new RangeError("targetStart out of bounds"); + } + if (start < 0 || start >= this.length) + throw new RangeError("Index out of range"); + if (end < 0) + throw new RangeError("sourceEnd out of bounds"); + if (end > this.length) + end = this.length; + if (target.length - targetStart < end - start) { + end = target.length - targetStart + start; + } + const len = end - start; + if (this === target && typeof Uint8Array.prototype.copyWithin === "function") { + this.copyWithin(targetStart, start, end); + } else { + Uint8Array.prototype.set.call( + target, + this.subarray(start, end), + targetStart + ); + } + return len; + }; + Buffer2.prototype.fill = function fill(val, start, end, encoding) { + if (typeof val === "string") { + if (typeof start === "string") { + encoding = start; + start = 0; + end = this.length; + } else if (typeof end === "string") { + encoding = end; + end = this.length; + } + if (encoding !== void 0 && typeof encoding !== "string") { + throw new TypeError("encoding must be a string"); + } + if (typeof encoding === "string" && !Buffer2.isEncoding(encoding)) { + throw new TypeError("Unknown encoding: " + encoding); + } + if (val.length === 1) { + const code = val.charCodeAt(0); + if (encoding === "utf8" && code < 128 || encoding === "latin1") { + val = code; + } + } + } else if (typeof val === "number") { + val = val & 255; + } else if (typeof val === "boolean") { + val = Number(val); + } + if (start < 0 || this.length < start || this.length < end) { + throw new RangeError("Out of range index"); + } + if (end <= start) { + return this; + } + start = start >>> 0; + end = end === void 0 ? this.length : end >>> 0; + if (!val) + val = 0; + let i; + if (typeof val === "number") { + for (i = start; i < end; ++i) { + this[i] = val; + } + } else { + const bytes = Buffer2.isBuffer(val) ? val : Buffer2.from(val, encoding); + const len = bytes.length; + if (len === 0) { + throw new TypeError('The value "' + val + '" is invalid for argument "value"'); + } + for (i = 0; i < end - start; ++i) { + this[i + start] = bytes[i % len]; + } + } + return this; + }; + var errors = {}; + function E(sym, getMessage, Base) { + errors[sym] = class NodeError extends Base { + constructor() { + super(); + Object.defineProperty(this, "message", { + value: getMessage.apply(this, arguments), + writable: true, + configurable: true + }); + this.name = `${this.name} [${sym}]`; + this.stack; + delete this.name; + } + get code() { + return sym; + } + set code(value) { + Object.defineProperty(this, "code", { + configurable: true, + enumerable: true, + value, + writable: true + }); + } + toString() { + return `${this.name} [${sym}]: ${this.message}`; + } + }; + } + E( + "ERR_BUFFER_OUT_OF_BOUNDS", + function(name) { + if (name) { + return `${name} is outside of buffer bounds`; + } + return "Attempt to access memory outside buffer bounds"; + }, + RangeError + ); + E( + "ERR_INVALID_ARG_TYPE", + function(name, actual) { + return `The "${name}" argument must be of type number. Received type ${typeof actual}`; + }, + TypeError + ); + E( + "ERR_OUT_OF_RANGE", + function(str, range, input) { + let msg = `The value of "${str}" is out of range.`; + let received = input; + if (Number.isInteger(input) && Math.abs(input) > 2 ** 32) { + received = addNumericalSeparator(String(input)); + } else if (typeof input === "bigint") { + received = String(input); + if (input > BigInt(2) ** BigInt(32) || input < -(BigInt(2) ** BigInt(32))) { + received = addNumericalSeparator(received); + } + received += "n"; + } + msg += ` It must be ${range}. Received ${received}`; + return msg; + }, + RangeError + ); + function addNumericalSeparator(val) { + let res = ""; + let i = val.length; + const start = val[0] === "-" ? 1 : 0; + for (; i >= start + 4; i -= 3) { + res = `_${val.slice(i - 3, i)}${res}`; + } + return `${val.slice(0, i)}${res}`; + } + function checkBounds(buf, offset, byteLength2) { + validateNumber(offset, "offset"); + if (buf[offset] === void 0 || buf[offset + byteLength2] === void 0) { + boundsError(offset, buf.length - (byteLength2 + 1)); + } + } + function checkIntBI(value, min, max, buf, offset, byteLength2) { + if (value > max || value < min) { + const n = typeof min === "bigint" ? "n" : ""; + let range; + if (byteLength2 > 3) { + if (min === 0 || min === BigInt(0)) { + range = `>= 0${n} and < 2${n} ** ${(byteLength2 + 1) * 8}${n}`; + } else { + range = `>= -(2${n} ** ${(byteLength2 + 1) * 8 - 1}${n}) and < 2 ** ${(byteLength2 + 1) * 8 - 1}${n}`; + } + } else { + range = `>= ${min}${n} and <= ${max}${n}`; + } + throw new errors.ERR_OUT_OF_RANGE("value", range, value); + } + checkBounds(buf, offset, byteLength2); + } + function validateNumber(value, name) { + if (typeof value !== "number") { + throw new errors.ERR_INVALID_ARG_TYPE(name, "number", value); + } + } + function boundsError(value, length, type) { + if (Math.floor(value) !== value) { + validateNumber(value, type); + throw new errors.ERR_OUT_OF_RANGE(type || "offset", "an integer", value); + } + if (length < 0) { + throw new errors.ERR_BUFFER_OUT_OF_BOUNDS(); + } + throw new errors.ERR_OUT_OF_RANGE( + type || "offset", + `>= ${type ? 1 : 0} and <= ${length}`, + value + ); + } + var INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g; + function base64clean(str) { + str = str.split("=")[0]; + str = str.trim().replace(INVALID_BASE64_RE, ""); + if (str.length < 2) + return ""; + while (str.length % 4 !== 0) { + str = str + "="; + } + return str; + } + function utf8ToBytes(string, units) { + units = units || Infinity; + let codePoint; + const length = string.length; + let leadSurrogate = null; + const bytes = []; + for (let i = 0; i < length; ++i) { + codePoint = string.charCodeAt(i); + if (codePoint > 55295 && codePoint < 57344) { + if (!leadSurrogate) { + if (codePoint > 56319) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + continue; + } else if (i + 1 === length) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + continue; + } + leadSurrogate = codePoint; + continue; + } + if (codePoint < 56320) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + leadSurrogate = codePoint; + continue; + } + codePoint = (leadSurrogate - 55296 << 10 | codePoint - 56320) + 65536; + } else if (leadSurrogate) { + if ((units -= 3) > -1) + bytes.push(239, 191, 189); + } + leadSurrogate = null; + if (codePoint < 128) { + if ((units -= 1) < 0) + break; + bytes.push(codePoint); + } else if (codePoint < 2048) { + if ((units -= 2) < 0) + break; + bytes.push( + codePoint >> 6 | 192, + codePoint & 63 | 128 + ); + } else if (codePoint < 65536) { + if ((units -= 3) < 0) + break; + bytes.push( + codePoint >> 12 | 224, + codePoint >> 6 & 63 | 128, + codePoint & 63 | 128 + ); + } else if (codePoint < 1114112) { + if ((units -= 4) < 0) + break; + bytes.push( + codePoint >> 18 | 240, + codePoint >> 12 & 63 | 128, + codePoint >> 6 & 63 | 128, + codePoint & 63 | 128 + ); + } else { + throw new Error("Invalid code point"); + } + } + return bytes; + } + function asciiToBytes(str) { + const byteArray = []; + for (let i = 0; i < str.length; ++i) { + byteArray.push(str.charCodeAt(i) & 255); + } + return byteArray; + } + function utf16leToBytes(str, units) { + let c, hi, lo; + const byteArray = []; + for (let i = 0; i < str.length; ++i) { + if ((units -= 2) < 0) + break; + c = str.charCodeAt(i); + hi = c >> 8; + lo = c % 256; + byteArray.push(lo); + byteArray.push(hi); + } + return byteArray; + } + function base64ToBytes(str) { + return base64.toByteArray(base64clean(str)); + } + function blitBuffer(src, dst, offset, length) { + let i; + for (i = 0; i < length; ++i) { + if (i + offset >= dst.length || i >= src.length) + break; + dst[i + offset] = src[i]; + } + return i; + } + function isInstance(obj, type) { + return obj instanceof type || obj != null && obj.constructor != null && obj.constructor.name != null && obj.constructor.name === type.name; + } + function numberIsNaN(obj) { + return obj !== obj; + } + var hexSliceLookupTable = function() { + const alphabet = "0123456789abcdef"; + const table = new Array(256); + for (let i = 0; i < 16; ++i) { + const i16 = i * 16; + for (let j = 0; j < 16; ++j) { + table[i16 + j] = alphabet[i] + alphabet[j]; + } + } + return table; + }(); + function defineBigIntMethod(fn) { + return typeof BigInt === "undefined" ? BufferBigIntNotDefined : fn; + } + function BufferBigIntNotDefined() { + throw new Error("BigInt not supported"); + } + } +}); + +// polyfill_buffer.js +var import_obsidian, buffer, Buffer; +var init_polyfill_buffer = __esm({ + "polyfill_buffer.js"() { + import_obsidian = require("obsidian"); + if (import_obsidian.Platform.isMobileApp) { + buffer = require_buffer().Buffer; + } else { + buffer = global.Buffer; + } + Buffer = buffer; + } +}); + +// node_modules/.pnpm/async-lock@1.4.0/node_modules/async-lock/lib/index.js +var require_lib = __commonJS({ + "node_modules/.pnpm/async-lock@1.4.0/node_modules/async-lock/lib/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var AsyncLock2 = function(opts) { + opts = opts || {}; + this.Promise = opts.Promise || Promise; + this.queues = /* @__PURE__ */ Object.create(null); + this.domainReentrant = opts.domainReentrant || false; + if (this.domainReentrant) { + if (typeof process === "undefined" || typeof process.domain === "undefined") { + throw new Error( + "Domain-reentrant locks require `process.domain` to exist. Please flip `opts.domainReentrant = false`, use a NodeJS version that still implements Domain, or install a browser polyfill." + ); + } + this.domains = /* @__PURE__ */ Object.create(null); + } + this.timeout = opts.timeout || AsyncLock2.DEFAULT_TIMEOUT; + this.maxOccupationTime = opts.maxOccupationTime || AsyncLock2.DEFAULT_MAX_OCCUPATION_TIME; + this.maxExecutionTime = opts.maxExecutionTime || AsyncLock2.DEFAULT_MAX_EXECUTION_TIME; + if (opts.maxPending === Infinity || Number.isInteger(opts.maxPending) && opts.maxPending >= 0) { + this.maxPending = opts.maxPending; + } else { + this.maxPending = AsyncLock2.DEFAULT_MAX_PENDING; + } + }; + AsyncLock2.DEFAULT_TIMEOUT = 0; + AsyncLock2.DEFAULT_MAX_OCCUPATION_TIME = 0; + AsyncLock2.DEFAULT_MAX_EXECUTION_TIME = 0; + AsyncLock2.DEFAULT_MAX_PENDING = 1e3; + AsyncLock2.prototype.acquire = function(key2, fn, cb, opts) { + if (Array.isArray(key2)) { + return this._acquireBatch(key2, fn, cb, opts); + } + if (typeof fn !== "function") { + throw new Error("You must pass a function to execute"); + } + var deferredResolve = null; + var deferredReject = null; + var deferred2 = null; + if (typeof cb !== "function") { + opts = cb; + cb = null; + deferred2 = new this.Promise(function(resolve, reject) { + deferredResolve = resolve; + deferredReject = reject; + }); + } + opts = opts || {}; + var resolved = false; + var timer = null; + var occupationTimer = null; + var executionTimer = null; + var self2 = this; + var done = function(locked, err, ret) { + if (occupationTimer) { + clearTimeout(occupationTimer); + occupationTimer = null; + } + if (executionTimer) { + clearTimeout(executionTimer); + executionTimer = null; + } + if (locked) { + if (!!self2.queues[key2] && self2.queues[key2].length === 0) { + delete self2.queues[key2]; + } + if (self2.domainReentrant) { + delete self2.domains[key2]; + } + } + if (!resolved) { + if (!deferred2) { + if (typeof cb === "function") { + cb(err, ret); + } + } else { + if (err) { + deferredReject(err); + } else { + deferredResolve(ret); + } + } + resolved = true; + } + if (locked) { + if (!!self2.queues[key2] && self2.queues[key2].length > 0) { + self2.queues[key2].shift()(); + } + } + }; + var exec = function(locked) { + if (resolved) { + return done(locked); + } + if (timer) { + clearTimeout(timer); + timer = null; + } + if (self2.domainReentrant && locked) { + self2.domains[key2] = process.domain; + } + var maxExecutionTime = opts.maxExecutionTime || self2.maxExecutionTime; + if (maxExecutionTime) { + executionTimer = setTimeout(function() { + if (!!self2.queues[key2]) { + done(locked, new Error("Maximum execution time is exceeded " + key2)); + } + }, maxExecutionTime); + } + if (fn.length === 1) { + var called = false; + try { + fn(function(err, ret) { + if (!called) { + called = true; + done(locked, err, ret); + } + }); + } catch (err) { + if (!called) { + called = true; + done(locked, err); + } + } + } else { + self2._promiseTry(function() { + return fn(); + }).then(function(ret) { + done(locked, void 0, ret); + }, function(error) { + done(locked, error); + }); + } + }; + if (self2.domainReentrant && !!process.domain) { + exec = process.domain.bind(exec); + } + if (!self2.queues[key2]) { + self2.queues[key2] = []; + exec(true); + } else if (self2.domainReentrant && !!process.domain && process.domain === self2.domains[key2]) { + exec(false); + } else if (self2.queues[key2].length >= self2.maxPending) { + done(false, new Error("Too many pending tasks in queue " + key2)); + } else { + var taskFn = function() { + exec(true); + }; + if (opts.skipQueue) { + self2.queues[key2].unshift(taskFn); + } else { + self2.queues[key2].push(taskFn); + } + var timeout = opts.timeout || self2.timeout; + if (timeout) { + timer = setTimeout(function() { + timer = null; + done(false, new Error("async-lock timed out in queue " + key2)); + }, timeout); + } + } + var maxOccupationTime = opts.maxOccupationTime || self2.maxOccupationTime; + if (maxOccupationTime) { + occupationTimer = setTimeout(function() { + if (!!self2.queues[key2]) { + done(false, new Error("Maximum occupation time is exceeded in queue " + key2)); + } + }, maxOccupationTime); + } + if (deferred2) { + return deferred2; + } + }; + AsyncLock2.prototype._acquireBatch = function(keys, fn, cb, opts) { + if (typeof cb !== "function") { + opts = cb; + cb = null; + } + var self2 = this; + var getFn = function(key2, fn2) { + return function(cb2) { + self2.acquire(key2, fn2, cb2, opts); + }; + }; + var fnx = keys.reduceRight(function(prev, key2) { + return getFn(key2, prev); + }, fn); + if (typeof cb === "function") { + fnx(cb); + } else { + return new this.Promise(function(resolve, reject) { + if (fnx.length === 1) { + fnx(function(err, ret) { + if (err) { + reject(err); + } else { + resolve(ret); + } + }); + } else { + resolve(fnx()); + } + }); + } + }; + AsyncLock2.prototype.isBusy = function(key2) { + if (!key2) { + return Object.keys(this.queues).length > 0; + } else { + return !!this.queues[key2]; + } + }; + AsyncLock2.prototype._promiseTry = function(fn) { + try { + return this.Promise.resolve(fn()); + } catch (e) { + return this.Promise.reject(e); + } + }; + module2.exports = AsyncLock2; + } +}); + +// node_modules/.pnpm/async-lock@1.4.0/node_modules/async-lock/index.js +var require_async_lock = __commonJS({ + "node_modules/.pnpm/async-lock@1.4.0/node_modules/async-lock/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + module2.exports = require_lib(); + } +}); + +// node_modules/.pnpm/inherits@2.0.4/node_modules/inherits/inherits_browser.js +var require_inherits_browser = __commonJS({ + "node_modules/.pnpm/inherits@2.0.4/node_modules/inherits/inherits_browser.js"(exports2, module2) { + init_polyfill_buffer(); + if (typeof Object.create === "function") { + module2.exports = function inherits(ctor, superCtor) { + if (superCtor) { + ctor.super_ = superCtor; + ctor.prototype = Object.create(superCtor.prototype, { + constructor: { + value: ctor, + enumerable: false, + writable: true, + configurable: true + } + }); + } + }; + } else { + module2.exports = function inherits(ctor, superCtor) { + if (superCtor) { + ctor.super_ = superCtor; + var TempCtor = function() { + }; + TempCtor.prototype = superCtor.prototype; + ctor.prototype = new TempCtor(); + ctor.prototype.constructor = ctor; + } + }; + } + } +}); + +// node_modules/.pnpm/safe-buffer@5.2.1/node_modules/safe-buffer/index.js +var require_safe_buffer = __commonJS({ + "node_modules/.pnpm/safe-buffer@5.2.1/node_modules/safe-buffer/index.js"(exports2, module2) { + init_polyfill_buffer(); + var buffer2 = require_buffer(); + var Buffer2 = buffer2.Buffer; + function copyProps(src, dst) { + for (var key2 in src) { + dst[key2] = src[key2]; + } + } + if (Buffer2.from && Buffer2.alloc && Buffer2.allocUnsafe && Buffer2.allocUnsafeSlow) { + module2.exports = buffer2; + } else { + copyProps(buffer2, exports2); + exports2.Buffer = SafeBuffer; + } + function SafeBuffer(arg, encodingOrOffset, length) { + return Buffer2(arg, encodingOrOffset, length); + } + SafeBuffer.prototype = Object.create(Buffer2.prototype); + copyProps(Buffer2, SafeBuffer); + SafeBuffer.from = function(arg, encodingOrOffset, length) { + if (typeof arg === "number") { + throw new TypeError("Argument must not be a number"); + } + return Buffer2(arg, encodingOrOffset, length); + }; + SafeBuffer.alloc = function(size, fill, encoding) { + if (typeof size !== "number") { + throw new TypeError("Argument must be a number"); + } + var buf = Buffer2(size); + if (fill !== void 0) { + if (typeof encoding === "string") { + buf.fill(fill, encoding); + } else { + buf.fill(fill); + } + } else { + buf.fill(0); + } + return buf; + }; + SafeBuffer.allocUnsafe = function(size) { + if (typeof size !== "number") { + throw new TypeError("Argument must be a number"); + } + return Buffer2(size); + }; + SafeBuffer.allocUnsafeSlow = function(size) { + if (typeof size !== "number") { + throw new TypeError("Argument must be a number"); + } + return buffer2.SlowBuffer(size); + }; + } +}); + +// node_modules/.pnpm/sha.js@2.4.11/node_modules/sha.js/hash.js +var require_hash = __commonJS({ + "node_modules/.pnpm/sha.js@2.4.11/node_modules/sha.js/hash.js"(exports2, module2) { + init_polyfill_buffer(); + var Buffer2 = require_safe_buffer().Buffer; + function Hash2(blockSize, finalSize) { + this._block = Buffer2.alloc(blockSize); + this._finalSize = finalSize; + this._blockSize = blockSize; + this._len = 0; + } + Hash2.prototype.update = function(data, enc) { + if (typeof data === "string") { + enc = enc || "utf8"; + data = Buffer2.from(data, enc); + } + var block = this._block; + var blockSize = this._blockSize; + var length = data.length; + var accum = this._len; + for (var offset = 0; offset < length; ) { + var assigned = accum % blockSize; + var remainder = Math.min(length - offset, blockSize - assigned); + for (var i = 0; i < remainder; i++) { + block[assigned + i] = data[offset + i]; + } + accum += remainder; + offset += remainder; + if (accum % blockSize === 0) { + this._update(block); + } + } + this._len += length; + return this; + }; + Hash2.prototype.digest = function(enc) { + var rem = this._len % this._blockSize; + this._block[rem] = 128; + this._block.fill(0, rem + 1); + if (rem >= this._finalSize) { + this._update(this._block); + this._block.fill(0); + } + var bits = this._len * 8; + if (bits <= 4294967295) { + this._block.writeUInt32BE(bits, this._blockSize - 4); + } else { + var lowBits = (bits & 4294967295) >>> 0; + var highBits = (bits - lowBits) / 4294967296; + this._block.writeUInt32BE(highBits, this._blockSize - 8); + this._block.writeUInt32BE(lowBits, this._blockSize - 4); + } + this._update(this._block); + var hash2 = this._hash(); + return enc ? hash2.toString(enc) : hash2; + }; + Hash2.prototype._update = function() { + throw new Error("_update must be implemented by subclass"); + }; + module2.exports = Hash2; + } +}); + +// node_modules/.pnpm/sha.js@2.4.11/node_modules/sha.js/sha1.js +var require_sha1 = __commonJS({ + "node_modules/.pnpm/sha.js@2.4.11/node_modules/sha.js/sha1.js"(exports2, module2) { + init_polyfill_buffer(); + var inherits = require_inherits_browser(); + var Hash2 = require_hash(); + var Buffer2 = require_safe_buffer().Buffer; + var K2 = [ + 1518500249, + 1859775393, + 2400959708 | 0, + 3395469782 | 0 + ]; + var W = new Array(80); + function Sha1() { + this.init(); + this._w = W; + Hash2.call(this, 64, 56); + } + inherits(Sha1, Hash2); + Sha1.prototype.init = function() { + this._a = 1732584193; + this._b = 4023233417; + this._c = 2562383102; + this._d = 271733878; + this._e = 3285377520; + return this; + }; + function rotl1(num2) { + return num2 << 1 | num2 >>> 31; + } + function rotl5(num2) { + return num2 << 5 | num2 >>> 27; + } + function rotl30(num2) { + return num2 << 30 | num2 >>> 2; + } + function ft(s, b, c, d) { + if (s === 0) + return b & c | ~b & d; + if (s === 2) + return b & c | b & d | c & d; + return b ^ c ^ d; + } + Sha1.prototype._update = function(M) { + var W2 = this._w; + var a = this._a | 0; + var b = this._b | 0; + var c = this._c | 0; + var d = this._d | 0; + var e = this._e | 0; + for (var i = 0; i < 16; ++i) + W2[i] = M.readInt32BE(i * 4); + for (; i < 80; ++i) + W2[i] = rotl1(W2[i - 3] ^ W2[i - 8] ^ W2[i - 14] ^ W2[i - 16]); + for (var j = 0; j < 80; ++j) { + var s = ~~(j / 20); + var t = rotl5(a) + ft(s, b, c, d) + e + W2[j] + K2[s] | 0; + e = d; + d = c; + c = rotl30(b); + b = a; + a = t; + } + this._a = a + this._a | 0; + this._b = b + this._b | 0; + this._c = c + this._c | 0; + this._d = d + this._d | 0; + this._e = e + this._e | 0; + }; + Sha1.prototype._hash = function() { + var H = Buffer2.allocUnsafe(20); + H.writeInt32BE(this._a | 0, 0); + H.writeInt32BE(this._b | 0, 4); + H.writeInt32BE(this._c | 0, 8); + H.writeInt32BE(this._d | 0, 12); + H.writeInt32BE(this._e | 0, 16); + return H; + }; + module2.exports = Sha1; + } +}); + +// node_modules/.pnpm/crc-32@1.2.2/node_modules/crc-32/crc32.js +var require_crc32 = __commonJS({ + "node_modules/.pnpm/crc-32@1.2.2/node_modules/crc-32/crc32.js"(exports2) { + init_polyfill_buffer(); + var CRC32; + (function(factory) { + if (typeof DO_NOT_EXPORT_CRC === "undefined") { + if ("object" === typeof exports2) { + factory(exports2); + } else if ("function" === typeof define && define.amd) { + define(function() { + var module3 = {}; + factory(module3); + return module3; + }); + } else { + factory(CRC32 = {}); + } + } else { + factory(CRC32 = {}); + } + })(function(CRC322) { + CRC322.version = "1.2.2"; + function signed_crc_table() { + var c = 0, table = new Array(256); + for (var n = 0; n != 256; ++n) { + c = n; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + c = c & 1 ? -306674912 ^ c >>> 1 : c >>> 1; + table[n] = c; + } + return typeof Int32Array !== "undefined" ? new Int32Array(table) : table; + } + var T0 = signed_crc_table(); + function slice_by_16_tables(T) { + var c = 0, v = 0, n = 0, table = typeof Int32Array !== "undefined" ? new Int32Array(4096) : new Array(4096); + for (n = 0; n != 256; ++n) + table[n] = T[n]; + for (n = 0; n != 256; ++n) { + v = T[n]; + for (c = 256 + n; c < 4096; c += 256) + v = table[c] = v >>> 8 ^ T[v & 255]; + } + var out = []; + for (n = 1; n != 16; ++n) + out[n - 1] = typeof Int32Array !== "undefined" ? table.subarray(n * 256, n * 256 + 256) : table.slice(n * 256, n * 256 + 256); + return out; + } + var TT = slice_by_16_tables(T0); + var T1 = TT[0], T2 = TT[1], T3 = TT[2], T4 = TT[3], T5 = TT[4]; + var T6 = TT[5], T7 = TT[6], T8 = TT[7], T9 = TT[8], Ta = TT[9]; + var Tb = TT[10], Tc = TT[11], Td = TT[12], Te = TT[13], Tf = TT[14]; + function crc32_bstr(bstr, seed) { + var C = seed ^ -1; + for (var i = 0, L = bstr.length; i < L; ) + C = C >>> 8 ^ T0[(C ^ bstr.charCodeAt(i++)) & 255]; + return ~C; + } + function crc32_buf(B, seed) { + var C = seed ^ -1, L = B.length - 15, i = 0; + for (; i < L; ) + C = Tf[B[i++] ^ C & 255] ^ Te[B[i++] ^ C >> 8 & 255] ^ Td[B[i++] ^ C >> 16 & 255] ^ Tc[B[i++] ^ C >>> 24] ^ Tb[B[i++]] ^ Ta[B[i++]] ^ T9[B[i++]] ^ T8[B[i++]] ^ T7[B[i++]] ^ T6[B[i++]] ^ T5[B[i++]] ^ T4[B[i++]] ^ T3[B[i++]] ^ T2[B[i++]] ^ T1[B[i++]] ^ T0[B[i++]]; + L += 15; + while (i < L) + C = C >>> 8 ^ T0[(C ^ B[i++]) & 255]; + return ~C; + } + function crc32_str(str, seed) { + var C = seed ^ -1; + for (var i = 0, L = str.length, c = 0, d = 0; i < L; ) { + c = str.charCodeAt(i++); + if (c < 128) { + C = C >>> 8 ^ T0[(C ^ c) & 255]; + } else if (c < 2048) { + C = C >>> 8 ^ T0[(C ^ (192 | c >> 6 & 31)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c & 63)) & 255]; + } else if (c >= 55296 && c < 57344) { + c = (c & 1023) + 64; + d = str.charCodeAt(i++) & 1023; + C = C >>> 8 ^ T0[(C ^ (240 | c >> 8 & 7)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c >> 2 & 63)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | d >> 6 & 15 | (c & 3) << 4)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | d & 63)) & 255]; + } else { + C = C >>> 8 ^ T0[(C ^ (224 | c >> 12 & 15)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c >> 6 & 63)) & 255]; + C = C >>> 8 ^ T0[(C ^ (128 | c & 63)) & 255]; + } + } + return ~C; + } + CRC322.table = T0; + CRC322.bstr = crc32_bstr; + CRC322.buf = crc32_buf; + CRC322.str = crc32_str; + }); + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/utils/common.js +var require_common = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/utils/common.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var TYPED_OK = typeof Uint8Array !== "undefined" && typeof Uint16Array !== "undefined" && typeof Int32Array !== "undefined"; + function _has(obj, key2) { + return Object.prototype.hasOwnProperty.call(obj, key2); + } + exports2.assign = function(obj) { + var sources = Array.prototype.slice.call(arguments, 1); + while (sources.length) { + var source = sources.shift(); + if (!source) { + continue; + } + if (typeof source !== "object") { + throw new TypeError(source + "must be non-object"); + } + for (var p in source) { + if (_has(source, p)) { + obj[p] = source[p]; + } + } + } + return obj; + }; + exports2.shrinkBuf = function(buf, size) { + if (buf.length === size) { + return buf; + } + if (buf.subarray) { + return buf.subarray(0, size); + } + buf.length = size; + return buf; + }; + var fnTyped = { + arraySet: function(dest, src, src_offs, len, dest_offs) { + if (src.subarray && dest.subarray) { + dest.set(src.subarray(src_offs, src_offs + len), dest_offs); + return; + } + for (var i = 0; i < len; i++) { + dest[dest_offs + i] = src[src_offs + i]; + } + }, + // Join array of chunks to single array. + flattenChunks: function(chunks) { + var i, l, len, pos, chunk, result; + len = 0; + for (i = 0, l = chunks.length; i < l; i++) { + len += chunks[i].length; + } + result = new Uint8Array(len); + pos = 0; + for (i = 0, l = chunks.length; i < l; i++) { + chunk = chunks[i]; + result.set(chunk, pos); + pos += chunk.length; + } + return result; + } + }; + var fnUntyped = { + arraySet: function(dest, src, src_offs, len, dest_offs) { + for (var i = 0; i < len; i++) { + dest[dest_offs + i] = src[src_offs + i]; + } + }, + // Join array of chunks to single array. + flattenChunks: function(chunks) { + return [].concat.apply([], chunks); + } + }; + exports2.setTyped = function(on) { + if (on) { + exports2.Buf8 = Uint8Array; + exports2.Buf16 = Uint16Array; + exports2.Buf32 = Int32Array; + exports2.assign(exports2, fnTyped); + } else { + exports2.Buf8 = Array; + exports2.Buf16 = Array; + exports2.Buf32 = Array; + exports2.assign(exports2, fnUntyped); + } + }; + exports2.setTyped(TYPED_OK); + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/trees.js +var require_trees = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/trees.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var utils = require_common(); + var Z_FIXED = 4; + var Z_BINARY = 0; + var Z_TEXT = 1; + var Z_UNKNOWN = 2; + function zero(buf) { + var len = buf.length; + while (--len >= 0) { + buf[len] = 0; + } + } + var STORED_BLOCK = 0; + var STATIC_TREES = 1; + var DYN_TREES = 2; + var MIN_MATCH = 3; + var MAX_MATCH = 258; + var LENGTH_CODES = 29; + var LITERALS = 256; + var L_CODES = LITERALS + 1 + LENGTH_CODES; + var D_CODES = 30; + var BL_CODES = 19; + var HEAP_SIZE = 2 * L_CODES + 1; + var MAX_BITS = 15; + var Buf_size = 16; + var MAX_BL_BITS = 7; + var END_BLOCK = 256; + var REP_3_6 = 16; + var REPZ_3_10 = 17; + var REPZ_11_138 = 18; + var extra_lbits = ( + /* extra bits for each length code */ + [0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2, 3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0] + ); + var extra_dbits = ( + /* extra bits for each distance code */ + [0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9, 10, 10, 11, 11, 12, 12, 13, 13] + ); + var extra_blbits = ( + /* extra bits for each bit length code */ + [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 2, 3, 7] + ); + var bl_order = [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15]; + var DIST_CODE_LEN = 512; + var static_ltree = new Array((L_CODES + 2) * 2); + zero(static_ltree); + var static_dtree = new Array(D_CODES * 2); + zero(static_dtree); + var _dist_code = new Array(DIST_CODE_LEN); + zero(_dist_code); + var _length_code = new Array(MAX_MATCH - MIN_MATCH + 1); + zero(_length_code); + var base_length = new Array(LENGTH_CODES); + zero(base_length); + var base_dist = new Array(D_CODES); + zero(base_dist); + function StaticTreeDesc(static_tree, extra_bits, extra_base, elems, max_length) { + this.static_tree = static_tree; + this.extra_bits = extra_bits; + this.extra_base = extra_base; + this.elems = elems; + this.max_length = max_length; + this.has_stree = static_tree && static_tree.length; + } + var static_l_desc; + var static_d_desc; + var static_bl_desc; + function TreeDesc(dyn_tree, stat_desc) { + this.dyn_tree = dyn_tree; + this.max_code = 0; + this.stat_desc = stat_desc; + } + function d_code(dist) { + return dist < 256 ? _dist_code[dist] : _dist_code[256 + (dist >>> 7)]; + } + function put_short(s, w) { + s.pending_buf[s.pending++] = w & 255; + s.pending_buf[s.pending++] = w >>> 8 & 255; + } + function send_bits(s, value, length) { + if (s.bi_valid > Buf_size - length) { + s.bi_buf |= value << s.bi_valid & 65535; + put_short(s, s.bi_buf); + s.bi_buf = value >> Buf_size - s.bi_valid; + s.bi_valid += length - Buf_size; + } else { + s.bi_buf |= value << s.bi_valid & 65535; + s.bi_valid += length; + } + } + function send_code(s, c, tree) { + send_bits( + s, + tree[c * 2], + tree[c * 2 + 1] + /*.Len*/ + ); + } + function bi_reverse(code, len) { + var res = 0; + do { + res |= code & 1; + code >>>= 1; + res <<= 1; + } while (--len > 0); + return res >>> 1; + } + function bi_flush(s) { + if (s.bi_valid === 16) { + put_short(s, s.bi_buf); + s.bi_buf = 0; + s.bi_valid = 0; + } else if (s.bi_valid >= 8) { + s.pending_buf[s.pending++] = s.bi_buf & 255; + s.bi_buf >>= 8; + s.bi_valid -= 8; + } + } + function gen_bitlen(s, desc) { + var tree = desc.dyn_tree; + var max_code = desc.max_code; + var stree = desc.stat_desc.static_tree; + var has_stree = desc.stat_desc.has_stree; + var extra = desc.stat_desc.extra_bits; + var base = desc.stat_desc.extra_base; + var max_length = desc.stat_desc.max_length; + var h; + var n, m; + var bits; + var xbits; + var f; + var overflow = 0; + for (bits = 0; bits <= MAX_BITS; bits++) { + s.bl_count[bits] = 0; + } + tree[s.heap[s.heap_max] * 2 + 1] = 0; + for (h = s.heap_max + 1; h < HEAP_SIZE; h++) { + n = s.heap[h]; + bits = tree[tree[n * 2 + 1] * 2 + 1] + 1; + if (bits > max_length) { + bits = max_length; + overflow++; + } + tree[n * 2 + 1] = bits; + if (n > max_code) { + continue; + } + s.bl_count[bits]++; + xbits = 0; + if (n >= base) { + xbits = extra[n - base]; + } + f = tree[n * 2]; + s.opt_len += f * (bits + xbits); + if (has_stree) { + s.static_len += f * (stree[n * 2 + 1] + xbits); + } + } + if (overflow === 0) { + return; + } + do { + bits = max_length - 1; + while (s.bl_count[bits] === 0) { + bits--; + } + s.bl_count[bits]--; + s.bl_count[bits + 1] += 2; + s.bl_count[max_length]--; + overflow -= 2; + } while (overflow > 0); + for (bits = max_length; bits !== 0; bits--) { + n = s.bl_count[bits]; + while (n !== 0) { + m = s.heap[--h]; + if (m > max_code) { + continue; + } + if (tree[m * 2 + 1] !== bits) { + s.opt_len += (bits - tree[m * 2 + 1]) * tree[m * 2]; + tree[m * 2 + 1] = bits; + } + n--; + } + } + } + function gen_codes(tree, max_code, bl_count) { + var next_code = new Array(MAX_BITS + 1); + var code = 0; + var bits; + var n; + for (bits = 1; bits <= MAX_BITS; bits++) { + next_code[bits] = code = code + bl_count[bits - 1] << 1; + } + for (n = 0; n <= max_code; n++) { + var len = tree[n * 2 + 1]; + if (len === 0) { + continue; + } + tree[n * 2] = bi_reverse(next_code[len]++, len); + } + } + function tr_static_init() { + var n; + var bits; + var length; + var code; + var dist; + var bl_count = new Array(MAX_BITS + 1); + length = 0; + for (code = 0; code < LENGTH_CODES - 1; code++) { + base_length[code] = length; + for (n = 0; n < 1 << extra_lbits[code]; n++) { + _length_code[length++] = code; + } + } + _length_code[length - 1] = code; + dist = 0; + for (code = 0; code < 16; code++) { + base_dist[code] = dist; + for (n = 0; n < 1 << extra_dbits[code]; n++) { + _dist_code[dist++] = code; + } + } + dist >>= 7; + for (; code < D_CODES; code++) { + base_dist[code] = dist << 7; + for (n = 0; n < 1 << extra_dbits[code] - 7; n++) { + _dist_code[256 + dist++] = code; + } + } + for (bits = 0; bits <= MAX_BITS; bits++) { + bl_count[bits] = 0; + } + n = 0; + while (n <= 143) { + static_ltree[n * 2 + 1] = 8; + n++; + bl_count[8]++; + } + while (n <= 255) { + static_ltree[n * 2 + 1] = 9; + n++; + bl_count[9]++; + } + while (n <= 279) { + static_ltree[n * 2 + 1] = 7; + n++; + bl_count[7]++; + } + while (n <= 287) { + static_ltree[n * 2 + 1] = 8; + n++; + bl_count[8]++; + } + gen_codes(static_ltree, L_CODES + 1, bl_count); + for (n = 0; n < D_CODES; n++) { + static_dtree[n * 2 + 1] = 5; + static_dtree[n * 2] = bi_reverse(n, 5); + } + static_l_desc = new StaticTreeDesc(static_ltree, extra_lbits, LITERALS + 1, L_CODES, MAX_BITS); + static_d_desc = new StaticTreeDesc(static_dtree, extra_dbits, 0, D_CODES, MAX_BITS); + static_bl_desc = new StaticTreeDesc(new Array(0), extra_blbits, 0, BL_CODES, MAX_BL_BITS); + } + function init_block(s) { + var n; + for (n = 0; n < L_CODES; n++) { + s.dyn_ltree[n * 2] = 0; + } + for (n = 0; n < D_CODES; n++) { + s.dyn_dtree[n * 2] = 0; + } + for (n = 0; n < BL_CODES; n++) { + s.bl_tree[n * 2] = 0; + } + s.dyn_ltree[END_BLOCK * 2] = 1; + s.opt_len = s.static_len = 0; + s.last_lit = s.matches = 0; + } + function bi_windup(s) { + if (s.bi_valid > 8) { + put_short(s, s.bi_buf); + } else if (s.bi_valid > 0) { + s.pending_buf[s.pending++] = s.bi_buf; + } + s.bi_buf = 0; + s.bi_valid = 0; + } + function copy_block(s, buf, len, header) { + bi_windup(s); + if (header) { + put_short(s, len); + put_short(s, ~len); + } + utils.arraySet(s.pending_buf, s.window, buf, len, s.pending); + s.pending += len; + } + function smaller(tree, n, m, depth) { + var _n2 = n * 2; + var _m2 = m * 2; + return tree[_n2] < tree[_m2] || tree[_n2] === tree[_m2] && depth[n] <= depth[m]; + } + function pqdownheap(s, tree, k) { + var v = s.heap[k]; + var j = k << 1; + while (j <= s.heap_len) { + if (j < s.heap_len && smaller(tree, s.heap[j + 1], s.heap[j], s.depth)) { + j++; + } + if (smaller(tree, v, s.heap[j], s.depth)) { + break; + } + s.heap[k] = s.heap[j]; + k = j; + j <<= 1; + } + s.heap[k] = v; + } + function compress_block(s, ltree, dtree) { + var dist; + var lc; + var lx = 0; + var code; + var extra; + if (s.last_lit !== 0) { + do { + dist = s.pending_buf[s.d_buf + lx * 2] << 8 | s.pending_buf[s.d_buf + lx * 2 + 1]; + lc = s.pending_buf[s.l_buf + lx]; + lx++; + if (dist === 0) { + send_code(s, lc, ltree); + } else { + code = _length_code[lc]; + send_code(s, code + LITERALS + 1, ltree); + extra = extra_lbits[code]; + if (extra !== 0) { + lc -= base_length[code]; + send_bits(s, lc, extra); + } + dist--; + code = d_code(dist); + send_code(s, code, dtree); + extra = extra_dbits[code]; + if (extra !== 0) { + dist -= base_dist[code]; + send_bits(s, dist, extra); + } + } + } while (lx < s.last_lit); + } + send_code(s, END_BLOCK, ltree); + } + function build_tree(s, desc) { + var tree = desc.dyn_tree; + var stree = desc.stat_desc.static_tree; + var has_stree = desc.stat_desc.has_stree; + var elems = desc.stat_desc.elems; + var n, m; + var max_code = -1; + var node; + s.heap_len = 0; + s.heap_max = HEAP_SIZE; + for (n = 0; n < elems; n++) { + if (tree[n * 2] !== 0) { + s.heap[++s.heap_len] = max_code = n; + s.depth[n] = 0; + } else { + tree[n * 2 + 1] = 0; + } + } + while (s.heap_len < 2) { + node = s.heap[++s.heap_len] = max_code < 2 ? ++max_code : 0; + tree[node * 2] = 1; + s.depth[node] = 0; + s.opt_len--; + if (has_stree) { + s.static_len -= stree[node * 2 + 1]; + } + } + desc.max_code = max_code; + for (n = s.heap_len >> 1; n >= 1; n--) { + pqdownheap(s, tree, n); + } + node = elems; + do { + n = s.heap[ + 1 + /*SMALLEST*/ + ]; + s.heap[ + 1 + /*SMALLEST*/ + ] = s.heap[s.heap_len--]; + pqdownheap( + s, + tree, + 1 + /*SMALLEST*/ + ); + m = s.heap[ + 1 + /*SMALLEST*/ + ]; + s.heap[--s.heap_max] = n; + s.heap[--s.heap_max] = m; + tree[node * 2] = tree[n * 2] + tree[m * 2]; + s.depth[node] = (s.depth[n] >= s.depth[m] ? s.depth[n] : s.depth[m]) + 1; + tree[n * 2 + 1] = tree[m * 2 + 1] = node; + s.heap[ + 1 + /*SMALLEST*/ + ] = node++; + pqdownheap( + s, + tree, + 1 + /*SMALLEST*/ + ); + } while (s.heap_len >= 2); + s.heap[--s.heap_max] = s.heap[ + 1 + /*SMALLEST*/ + ]; + gen_bitlen(s, desc); + gen_codes(tree, max_code, s.bl_count); + } + function scan_tree(s, tree, max_code) { + var n; + var prevlen = -1; + var curlen; + var nextlen = tree[0 * 2 + 1]; + var count = 0; + var max_count = 7; + var min_count = 4; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } + tree[(max_code + 1) * 2 + 1] = 65535; + for (n = 0; n <= max_code; n++) { + curlen = nextlen; + nextlen = tree[(n + 1) * 2 + 1]; + if (++count < max_count && curlen === nextlen) { + continue; + } else if (count < min_count) { + s.bl_tree[curlen * 2] += count; + } else if (curlen !== 0) { + if (curlen !== prevlen) { + s.bl_tree[curlen * 2]++; + } + s.bl_tree[REP_3_6 * 2]++; + } else if (count <= 10) { + s.bl_tree[REPZ_3_10 * 2]++; + } else { + s.bl_tree[REPZ_11_138 * 2]++; + } + count = 0; + prevlen = curlen; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } else if (curlen === nextlen) { + max_count = 6; + min_count = 3; + } else { + max_count = 7; + min_count = 4; + } + } + } + function send_tree(s, tree, max_code) { + var n; + var prevlen = -1; + var curlen; + var nextlen = tree[0 * 2 + 1]; + var count = 0; + var max_count = 7; + var min_count = 4; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } + for (n = 0; n <= max_code; n++) { + curlen = nextlen; + nextlen = tree[(n + 1) * 2 + 1]; + if (++count < max_count && curlen === nextlen) { + continue; + } else if (count < min_count) { + do { + send_code(s, curlen, s.bl_tree); + } while (--count !== 0); + } else if (curlen !== 0) { + if (curlen !== prevlen) { + send_code(s, curlen, s.bl_tree); + count--; + } + send_code(s, REP_3_6, s.bl_tree); + send_bits(s, count - 3, 2); + } else if (count <= 10) { + send_code(s, REPZ_3_10, s.bl_tree); + send_bits(s, count - 3, 3); + } else { + send_code(s, REPZ_11_138, s.bl_tree); + send_bits(s, count - 11, 7); + } + count = 0; + prevlen = curlen; + if (nextlen === 0) { + max_count = 138; + min_count = 3; + } else if (curlen === nextlen) { + max_count = 6; + min_count = 3; + } else { + max_count = 7; + min_count = 4; + } + } + } + function build_bl_tree(s) { + var max_blindex; + scan_tree(s, s.dyn_ltree, s.l_desc.max_code); + scan_tree(s, s.dyn_dtree, s.d_desc.max_code); + build_tree(s, s.bl_desc); + for (max_blindex = BL_CODES - 1; max_blindex >= 3; max_blindex--) { + if (s.bl_tree[bl_order[max_blindex] * 2 + 1] !== 0) { + break; + } + } + s.opt_len += 3 * (max_blindex + 1) + 5 + 5 + 4; + return max_blindex; + } + function send_all_trees(s, lcodes, dcodes, blcodes) { + var rank; + send_bits(s, lcodes - 257, 5); + send_bits(s, dcodes - 1, 5); + send_bits(s, blcodes - 4, 4); + for (rank = 0; rank < blcodes; rank++) { + send_bits(s, s.bl_tree[bl_order[rank] * 2 + 1], 3); + } + send_tree(s, s.dyn_ltree, lcodes - 1); + send_tree(s, s.dyn_dtree, dcodes - 1); + } + function detect_data_type(s) { + var black_mask = 4093624447; + var n; + for (n = 0; n <= 31; n++, black_mask >>>= 1) { + if (black_mask & 1 && s.dyn_ltree[n * 2] !== 0) { + return Z_BINARY; + } + } + if (s.dyn_ltree[9 * 2] !== 0 || s.dyn_ltree[10 * 2] !== 0 || s.dyn_ltree[13 * 2] !== 0) { + return Z_TEXT; + } + for (n = 32; n < LITERALS; n++) { + if (s.dyn_ltree[n * 2] !== 0) { + return Z_TEXT; + } + } + return Z_BINARY; + } + var static_init_done = false; + function _tr_init(s) { + if (!static_init_done) { + tr_static_init(); + static_init_done = true; + } + s.l_desc = new TreeDesc(s.dyn_ltree, static_l_desc); + s.d_desc = new TreeDesc(s.dyn_dtree, static_d_desc); + s.bl_desc = new TreeDesc(s.bl_tree, static_bl_desc); + s.bi_buf = 0; + s.bi_valid = 0; + init_block(s); + } + function _tr_stored_block(s, buf, stored_len, last2) { + send_bits(s, (STORED_BLOCK << 1) + (last2 ? 1 : 0), 3); + copy_block(s, buf, stored_len, true); + } + function _tr_align(s) { + send_bits(s, STATIC_TREES << 1, 3); + send_code(s, END_BLOCK, static_ltree); + bi_flush(s); + } + function _tr_flush_block(s, buf, stored_len, last2) { + var opt_lenb, static_lenb; + var max_blindex = 0; + if (s.level > 0) { + if (s.strm.data_type === Z_UNKNOWN) { + s.strm.data_type = detect_data_type(s); + } + build_tree(s, s.l_desc); + build_tree(s, s.d_desc); + max_blindex = build_bl_tree(s); + opt_lenb = s.opt_len + 3 + 7 >>> 3; + static_lenb = s.static_len + 3 + 7 >>> 3; + if (static_lenb <= opt_lenb) { + opt_lenb = static_lenb; + } + } else { + opt_lenb = static_lenb = stored_len + 5; + } + if (stored_len + 4 <= opt_lenb && buf !== -1) { + _tr_stored_block(s, buf, stored_len, last2); + } else if (s.strategy === Z_FIXED || static_lenb === opt_lenb) { + send_bits(s, (STATIC_TREES << 1) + (last2 ? 1 : 0), 3); + compress_block(s, static_ltree, static_dtree); + } else { + send_bits(s, (DYN_TREES << 1) + (last2 ? 1 : 0), 3); + send_all_trees(s, s.l_desc.max_code + 1, s.d_desc.max_code + 1, max_blindex + 1); + compress_block(s, s.dyn_ltree, s.dyn_dtree); + } + init_block(s); + if (last2) { + bi_windup(s); + } + } + function _tr_tally(s, dist, lc) { + s.pending_buf[s.d_buf + s.last_lit * 2] = dist >>> 8 & 255; + s.pending_buf[s.d_buf + s.last_lit * 2 + 1] = dist & 255; + s.pending_buf[s.l_buf + s.last_lit] = lc & 255; + s.last_lit++; + if (dist === 0) { + s.dyn_ltree[lc * 2]++; + } else { + s.matches++; + dist--; + s.dyn_ltree[(_length_code[lc] + LITERALS + 1) * 2]++; + s.dyn_dtree[d_code(dist) * 2]++; + } + return s.last_lit === s.lit_bufsize - 1; + } + exports2._tr_init = _tr_init; + exports2._tr_stored_block = _tr_stored_block; + exports2._tr_flush_block = _tr_flush_block; + exports2._tr_tally = _tr_tally; + exports2._tr_align = _tr_align; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/adler32.js +var require_adler32 = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/adler32.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + function adler32(adler, buf, len, pos) { + var s1 = adler & 65535 | 0, s2 = adler >>> 16 & 65535 | 0, n = 0; + while (len !== 0) { + n = len > 2e3 ? 2e3 : len; + len -= n; + do { + s1 = s1 + buf[pos++] | 0; + s2 = s2 + s1 | 0; + } while (--n); + s1 %= 65521; + s2 %= 65521; + } + return s1 | s2 << 16 | 0; + } + module2.exports = adler32; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/crc32.js +var require_crc322 = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/crc32.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + function makeTable() { + var c, table = []; + for (var n = 0; n < 256; n++) { + c = n; + for (var k = 0; k < 8; k++) { + c = c & 1 ? 3988292384 ^ c >>> 1 : c >>> 1; + } + table[n] = c; + } + return table; + } + var crcTable = makeTable(); + function crc322(crc, buf, len, pos) { + var t = crcTable, end = pos + len; + crc ^= -1; + for (var i = pos; i < end; i++) { + crc = crc >>> 8 ^ t[(crc ^ buf[i]) & 255]; + } + return crc ^ -1; + } + module2.exports = crc322; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/messages.js +var require_messages = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/messages.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + module2.exports = { + 2: "need dictionary", + /* Z_NEED_DICT 2 */ + 1: "stream end", + /* Z_STREAM_END 1 */ + 0: "", + /* Z_OK 0 */ + "-1": "file error", + /* Z_ERRNO (-1) */ + "-2": "stream error", + /* Z_STREAM_ERROR (-2) */ + "-3": "data error", + /* Z_DATA_ERROR (-3) */ + "-4": "insufficient memory", + /* Z_MEM_ERROR (-4) */ + "-5": "buffer error", + /* Z_BUF_ERROR (-5) */ + "-6": "incompatible version" + /* Z_VERSION_ERROR (-6) */ + }; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/deflate.js +var require_deflate = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/deflate.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var utils = require_common(); + var trees = require_trees(); + var adler32 = require_adler32(); + var crc322 = require_crc322(); + var msg = require_messages(); + var Z_NO_FLUSH = 0; + var Z_PARTIAL_FLUSH = 1; + var Z_FULL_FLUSH = 3; + var Z_FINISH = 4; + var Z_BLOCK = 5; + var Z_OK = 0; + var Z_STREAM_END = 1; + var Z_STREAM_ERROR = -2; + var Z_DATA_ERROR = -3; + var Z_BUF_ERROR = -5; + var Z_DEFAULT_COMPRESSION = -1; + var Z_FILTERED = 1; + var Z_HUFFMAN_ONLY = 2; + var Z_RLE = 3; + var Z_FIXED = 4; + var Z_DEFAULT_STRATEGY = 0; + var Z_UNKNOWN = 2; + var Z_DEFLATED = 8; + var MAX_MEM_LEVEL = 9; + var MAX_WBITS = 15; + var DEF_MEM_LEVEL = 8; + var LENGTH_CODES = 29; + var LITERALS = 256; + var L_CODES = LITERALS + 1 + LENGTH_CODES; + var D_CODES = 30; + var BL_CODES = 19; + var HEAP_SIZE = 2 * L_CODES + 1; + var MAX_BITS = 15; + var MIN_MATCH = 3; + var MAX_MATCH = 258; + var MIN_LOOKAHEAD = MAX_MATCH + MIN_MATCH + 1; + var PRESET_DICT = 32; + var INIT_STATE = 42; + var EXTRA_STATE = 69; + var NAME_STATE = 73; + var COMMENT_STATE = 91; + var HCRC_STATE = 103; + var BUSY_STATE = 113; + var FINISH_STATE = 666; + var BS_NEED_MORE = 1; + var BS_BLOCK_DONE = 2; + var BS_FINISH_STARTED = 3; + var BS_FINISH_DONE = 4; + var OS_CODE = 3; + function err(strm, errorCode) { + strm.msg = msg[errorCode]; + return errorCode; + } + function rank(f) { + return (f << 1) - (f > 4 ? 9 : 0); + } + function zero(buf) { + var len = buf.length; + while (--len >= 0) { + buf[len] = 0; + } + } + function flush_pending(strm) { + var s = strm.state; + var len = s.pending; + if (len > strm.avail_out) { + len = strm.avail_out; + } + if (len === 0) { + return; + } + utils.arraySet(strm.output, s.pending_buf, s.pending_out, len, strm.next_out); + strm.next_out += len; + s.pending_out += len; + strm.total_out += len; + strm.avail_out -= len; + s.pending -= len; + if (s.pending === 0) { + s.pending_out = 0; + } + } + function flush_block_only(s, last2) { + trees._tr_flush_block(s, s.block_start >= 0 ? s.block_start : -1, s.strstart - s.block_start, last2); + s.block_start = s.strstart; + flush_pending(s.strm); + } + function put_byte(s, b) { + s.pending_buf[s.pending++] = b; + } + function putShortMSB(s, b) { + s.pending_buf[s.pending++] = b >>> 8 & 255; + s.pending_buf[s.pending++] = b & 255; + } + function read_buf(strm, buf, start, size) { + var len = strm.avail_in; + if (len > size) { + len = size; + } + if (len === 0) { + return 0; + } + strm.avail_in -= len; + utils.arraySet(buf, strm.input, strm.next_in, len, start); + if (strm.state.wrap === 1) { + strm.adler = adler32(strm.adler, buf, len, start); + } else if (strm.state.wrap === 2) { + strm.adler = crc322(strm.adler, buf, len, start); + } + strm.next_in += len; + strm.total_in += len; + return len; + } + function longest_match(s, cur_match) { + var chain_length = s.max_chain_length; + var scan = s.strstart; + var match; + var len; + var best_len = s.prev_length; + var nice_match = s.nice_match; + var limit = s.strstart > s.w_size - MIN_LOOKAHEAD ? s.strstart - (s.w_size - MIN_LOOKAHEAD) : 0; + var _win = s.window; + var wmask = s.w_mask; + var prev = s.prev; + var strend = s.strstart + MAX_MATCH; + var scan_end1 = _win[scan + best_len - 1]; + var scan_end = _win[scan + best_len]; + if (s.prev_length >= s.good_match) { + chain_length >>= 2; + } + if (nice_match > s.lookahead) { + nice_match = s.lookahead; + } + do { + match = cur_match; + if (_win[match + best_len] !== scan_end || _win[match + best_len - 1] !== scan_end1 || _win[match] !== _win[scan] || _win[++match] !== _win[scan + 1]) { + continue; + } + scan += 2; + match++; + do { + } while (_win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && _win[++scan] === _win[++match] && scan < strend); + len = MAX_MATCH - (strend - scan); + scan = strend - MAX_MATCH; + if (len > best_len) { + s.match_start = cur_match; + best_len = len; + if (len >= nice_match) { + break; + } + scan_end1 = _win[scan + best_len - 1]; + scan_end = _win[scan + best_len]; + } + } while ((cur_match = prev[cur_match & wmask]) > limit && --chain_length !== 0); + if (best_len <= s.lookahead) { + return best_len; + } + return s.lookahead; + } + function fill_window(s) { + var _w_size = s.w_size; + var p, n, m, more, str; + do { + more = s.window_size - s.lookahead - s.strstart; + if (s.strstart >= _w_size + (_w_size - MIN_LOOKAHEAD)) { + utils.arraySet(s.window, s.window, _w_size, _w_size, 0); + s.match_start -= _w_size; + s.strstart -= _w_size; + s.block_start -= _w_size; + n = s.hash_size; + p = n; + do { + m = s.head[--p]; + s.head[p] = m >= _w_size ? m - _w_size : 0; + } while (--n); + n = _w_size; + p = n; + do { + m = s.prev[--p]; + s.prev[p] = m >= _w_size ? m - _w_size : 0; + } while (--n); + more += _w_size; + } + if (s.strm.avail_in === 0) { + break; + } + n = read_buf(s.strm, s.window, s.strstart + s.lookahead, more); + s.lookahead += n; + if (s.lookahead + s.insert >= MIN_MATCH) { + str = s.strstart - s.insert; + s.ins_h = s.window[str]; + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[str + 1]) & s.hash_mask; + while (s.insert) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask; + s.prev[str & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = str; + str++; + s.insert--; + if (s.lookahead + s.insert < MIN_MATCH) { + break; + } + } + } + } while (s.lookahead < MIN_LOOKAHEAD && s.strm.avail_in !== 0); + } + function deflate_stored(s, flush2) { + var max_block_size = 65535; + if (max_block_size > s.pending_buf_size - 5) { + max_block_size = s.pending_buf_size - 5; + } + for (; ; ) { + if (s.lookahead <= 1) { + fill_window(s); + if (s.lookahead === 0 && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + s.strstart += s.lookahead; + s.lookahead = 0; + var max_start = s.block_start + max_block_size; + if (s.strstart === 0 || s.strstart >= max_start) { + s.lookahead = s.strstart - max_start; + s.strstart = max_start; + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + if (s.strstart - s.block_start >= s.w_size - MIN_LOOKAHEAD) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = 0; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.strstart > s.block_start) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_NEED_MORE; + } + function deflate_fast(s, flush2) { + var hash_head; + var bflush; + for (; ; ) { + if (s.lookahead < MIN_LOOKAHEAD) { + fill_window(s); + if (s.lookahead < MIN_LOOKAHEAD && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + hash_head = 0; + if (s.lookahead >= MIN_MATCH) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } + if (hash_head !== 0 && s.strstart - hash_head <= s.w_size - MIN_LOOKAHEAD) { + s.match_length = longest_match(s, hash_head); + } + if (s.match_length >= MIN_MATCH) { + bflush = trees._tr_tally(s, s.strstart - s.match_start, s.match_length - MIN_MATCH); + s.lookahead -= s.match_length; + if (s.match_length <= s.max_lazy_match && s.lookahead >= MIN_MATCH) { + s.match_length--; + do { + s.strstart++; + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } while (--s.match_length !== 0); + s.strstart++; + } else { + s.strstart += s.match_length; + s.match_length = 0; + s.ins_h = s.window[s.strstart]; + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + 1]) & s.hash_mask; + } + } else { + bflush = trees._tr_tally(s, 0, s.window[s.strstart]); + s.lookahead--; + s.strstart++; + } + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function deflate_slow(s, flush2) { + var hash_head; + var bflush; + var max_insert; + for (; ; ) { + if (s.lookahead < MIN_LOOKAHEAD) { + fill_window(s); + if (s.lookahead < MIN_LOOKAHEAD && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + hash_head = 0; + if (s.lookahead >= MIN_MATCH) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } + s.prev_length = s.match_length; + s.prev_match = s.match_start; + s.match_length = MIN_MATCH - 1; + if (hash_head !== 0 && s.prev_length < s.max_lazy_match && s.strstart - hash_head <= s.w_size - MIN_LOOKAHEAD) { + s.match_length = longest_match(s, hash_head); + if (s.match_length <= 5 && (s.strategy === Z_FILTERED || s.match_length === MIN_MATCH && s.strstart - s.match_start > 4096)) { + s.match_length = MIN_MATCH - 1; + } + } + if (s.prev_length >= MIN_MATCH && s.match_length <= s.prev_length) { + max_insert = s.strstart + s.lookahead - MIN_MATCH; + bflush = trees._tr_tally(s, s.strstart - 1 - s.prev_match, s.prev_length - MIN_MATCH); + s.lookahead -= s.prev_length - 1; + s.prev_length -= 2; + do { + if (++s.strstart <= max_insert) { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[s.strstart + MIN_MATCH - 1]) & s.hash_mask; + hash_head = s.prev[s.strstart & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = s.strstart; + } + } while (--s.prev_length !== 0); + s.match_available = 0; + s.match_length = MIN_MATCH - 1; + s.strstart++; + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } else if (s.match_available) { + bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]); + if (bflush) { + flush_block_only(s, false); + } + s.strstart++; + s.lookahead--; + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } else { + s.match_available = 1; + s.strstart++; + s.lookahead--; + } + } + if (s.match_available) { + bflush = trees._tr_tally(s, 0, s.window[s.strstart - 1]); + s.match_available = 0; + } + s.insert = s.strstart < MIN_MATCH - 1 ? s.strstart : MIN_MATCH - 1; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function deflate_rle(s, flush2) { + var bflush; + var prev; + var scan, strend; + var _win = s.window; + for (; ; ) { + if (s.lookahead <= MAX_MATCH) { + fill_window(s); + if (s.lookahead <= MAX_MATCH && flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + if (s.lookahead === 0) { + break; + } + } + s.match_length = 0; + if (s.lookahead >= MIN_MATCH && s.strstart > 0) { + scan = s.strstart - 1; + prev = _win[scan]; + if (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan]) { + strend = s.strstart + MAX_MATCH; + do { + } while (prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && prev === _win[++scan] && scan < strend); + s.match_length = MAX_MATCH - (strend - scan); + if (s.match_length > s.lookahead) { + s.match_length = s.lookahead; + } + } + } + if (s.match_length >= MIN_MATCH) { + bflush = trees._tr_tally(s, 1, s.match_length - MIN_MATCH); + s.lookahead -= s.match_length; + s.strstart += s.match_length; + s.match_length = 0; + } else { + bflush = trees._tr_tally(s, 0, s.window[s.strstart]); + s.lookahead--; + s.strstart++; + } + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = 0; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function deflate_huff(s, flush2) { + var bflush; + for (; ; ) { + if (s.lookahead === 0) { + fill_window(s); + if (s.lookahead === 0) { + if (flush2 === Z_NO_FLUSH) { + return BS_NEED_MORE; + } + break; + } + } + s.match_length = 0; + bflush = trees._tr_tally(s, 0, s.window[s.strstart]); + s.lookahead--; + s.strstart++; + if (bflush) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + } + s.insert = 0; + if (flush2 === Z_FINISH) { + flush_block_only(s, true); + if (s.strm.avail_out === 0) { + return BS_FINISH_STARTED; + } + return BS_FINISH_DONE; + } + if (s.last_lit) { + flush_block_only(s, false); + if (s.strm.avail_out === 0) { + return BS_NEED_MORE; + } + } + return BS_BLOCK_DONE; + } + function Config(good_length, max_lazy, nice_length, max_chain, func) { + this.good_length = good_length; + this.max_lazy = max_lazy; + this.nice_length = nice_length; + this.max_chain = max_chain; + this.func = func; + } + var configuration_table; + configuration_table = [ + /* good lazy nice chain */ + new Config(0, 0, 0, 0, deflate_stored), + /* 0 store only */ + new Config(4, 4, 8, 4, deflate_fast), + /* 1 max speed, no lazy matches */ + new Config(4, 5, 16, 8, deflate_fast), + /* 2 */ + new Config(4, 6, 32, 32, deflate_fast), + /* 3 */ + new Config(4, 4, 16, 16, deflate_slow), + /* 4 lazy matches */ + new Config(8, 16, 32, 32, deflate_slow), + /* 5 */ + new Config(8, 16, 128, 128, deflate_slow), + /* 6 */ + new Config(8, 32, 128, 256, deflate_slow), + /* 7 */ + new Config(32, 128, 258, 1024, deflate_slow), + /* 8 */ + new Config(32, 258, 258, 4096, deflate_slow) + /* 9 max compression */ + ]; + function lm_init(s) { + s.window_size = 2 * s.w_size; + zero(s.head); + s.max_lazy_match = configuration_table[s.level].max_lazy; + s.good_match = configuration_table[s.level].good_length; + s.nice_match = configuration_table[s.level].nice_length; + s.max_chain_length = configuration_table[s.level].max_chain; + s.strstart = 0; + s.block_start = 0; + s.lookahead = 0; + s.insert = 0; + s.match_length = s.prev_length = MIN_MATCH - 1; + s.match_available = 0; + s.ins_h = 0; + } + function DeflateState() { + this.strm = null; + this.status = 0; + this.pending_buf = null; + this.pending_buf_size = 0; + this.pending_out = 0; + this.pending = 0; + this.wrap = 0; + this.gzhead = null; + this.gzindex = 0; + this.method = Z_DEFLATED; + this.last_flush = -1; + this.w_size = 0; + this.w_bits = 0; + this.w_mask = 0; + this.window = null; + this.window_size = 0; + this.prev = null; + this.head = null; + this.ins_h = 0; + this.hash_size = 0; + this.hash_bits = 0; + this.hash_mask = 0; + this.hash_shift = 0; + this.block_start = 0; + this.match_length = 0; + this.prev_match = 0; + this.match_available = 0; + this.strstart = 0; + this.match_start = 0; + this.lookahead = 0; + this.prev_length = 0; + this.max_chain_length = 0; + this.max_lazy_match = 0; + this.level = 0; + this.strategy = 0; + this.good_match = 0; + this.nice_match = 0; + this.dyn_ltree = new utils.Buf16(HEAP_SIZE * 2); + this.dyn_dtree = new utils.Buf16((2 * D_CODES + 1) * 2); + this.bl_tree = new utils.Buf16((2 * BL_CODES + 1) * 2); + zero(this.dyn_ltree); + zero(this.dyn_dtree); + zero(this.bl_tree); + this.l_desc = null; + this.d_desc = null; + this.bl_desc = null; + this.bl_count = new utils.Buf16(MAX_BITS + 1); + this.heap = new utils.Buf16(2 * L_CODES + 1); + zero(this.heap); + this.heap_len = 0; + this.heap_max = 0; + this.depth = new utils.Buf16(2 * L_CODES + 1); + zero(this.depth); + this.l_buf = 0; + this.lit_bufsize = 0; + this.last_lit = 0; + this.d_buf = 0; + this.opt_len = 0; + this.static_len = 0; + this.matches = 0; + this.insert = 0; + this.bi_buf = 0; + this.bi_valid = 0; + } + function deflateResetKeep(strm) { + var s; + if (!strm || !strm.state) { + return err(strm, Z_STREAM_ERROR); + } + strm.total_in = strm.total_out = 0; + strm.data_type = Z_UNKNOWN; + s = strm.state; + s.pending = 0; + s.pending_out = 0; + if (s.wrap < 0) { + s.wrap = -s.wrap; + } + s.status = s.wrap ? INIT_STATE : BUSY_STATE; + strm.adler = s.wrap === 2 ? 0 : 1; + s.last_flush = Z_NO_FLUSH; + trees._tr_init(s); + return Z_OK; + } + function deflateReset(strm) { + var ret = deflateResetKeep(strm); + if (ret === Z_OK) { + lm_init(strm.state); + } + return ret; + } + function deflateSetHeader(strm, head) { + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + if (strm.state.wrap !== 2) { + return Z_STREAM_ERROR; + } + strm.state.gzhead = head; + return Z_OK; + } + function deflateInit2(strm, level, method2, windowBits, memLevel, strategy) { + if (!strm) { + return Z_STREAM_ERROR; + } + var wrap = 1; + if (level === Z_DEFAULT_COMPRESSION) { + level = 6; + } + if (windowBits < 0) { + wrap = 0; + windowBits = -windowBits; + } else if (windowBits > 15) { + wrap = 2; + windowBits -= 16; + } + if (memLevel < 1 || memLevel > MAX_MEM_LEVEL || method2 !== Z_DEFLATED || windowBits < 8 || windowBits > 15 || level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED) { + return err(strm, Z_STREAM_ERROR); + } + if (windowBits === 8) { + windowBits = 9; + } + var s = new DeflateState(); + strm.state = s; + s.strm = strm; + s.wrap = wrap; + s.gzhead = null; + s.w_bits = windowBits; + s.w_size = 1 << s.w_bits; + s.w_mask = s.w_size - 1; + s.hash_bits = memLevel + 7; + s.hash_size = 1 << s.hash_bits; + s.hash_mask = s.hash_size - 1; + s.hash_shift = ~~((s.hash_bits + MIN_MATCH - 1) / MIN_MATCH); + s.window = new utils.Buf8(s.w_size * 2); + s.head = new utils.Buf16(s.hash_size); + s.prev = new utils.Buf16(s.w_size); + s.lit_bufsize = 1 << memLevel + 6; + s.pending_buf_size = s.lit_bufsize * 4; + s.pending_buf = new utils.Buf8(s.pending_buf_size); + s.d_buf = 1 * s.lit_bufsize; + s.l_buf = (1 + 2) * s.lit_bufsize; + s.level = level; + s.strategy = strategy; + s.method = method2; + return deflateReset(strm); + } + function deflateInit(strm, level) { + return deflateInit2(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, Z_DEFAULT_STRATEGY); + } + function deflate2(strm, flush2) { + var old_flush, s; + var beg, val; + if (!strm || !strm.state || flush2 > Z_BLOCK || flush2 < 0) { + return strm ? err(strm, Z_STREAM_ERROR) : Z_STREAM_ERROR; + } + s = strm.state; + if (!strm.output || !strm.input && strm.avail_in !== 0 || s.status === FINISH_STATE && flush2 !== Z_FINISH) { + return err(strm, strm.avail_out === 0 ? Z_BUF_ERROR : Z_STREAM_ERROR); + } + s.strm = strm; + old_flush = s.last_flush; + s.last_flush = flush2; + if (s.status === INIT_STATE) { + if (s.wrap === 2) { + strm.adler = 0; + put_byte(s, 31); + put_byte(s, 139); + put_byte(s, 8); + if (!s.gzhead) { + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, 0); + put_byte(s, s.level === 9 ? 2 : s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ? 4 : 0); + put_byte(s, OS_CODE); + s.status = BUSY_STATE; + } else { + put_byte( + s, + (s.gzhead.text ? 1 : 0) + (s.gzhead.hcrc ? 2 : 0) + (!s.gzhead.extra ? 0 : 4) + (!s.gzhead.name ? 0 : 8) + (!s.gzhead.comment ? 0 : 16) + ); + put_byte(s, s.gzhead.time & 255); + put_byte(s, s.gzhead.time >> 8 & 255); + put_byte(s, s.gzhead.time >> 16 & 255); + put_byte(s, s.gzhead.time >> 24 & 255); + put_byte(s, s.level === 9 ? 2 : s.strategy >= Z_HUFFMAN_ONLY || s.level < 2 ? 4 : 0); + put_byte(s, s.gzhead.os & 255); + if (s.gzhead.extra && s.gzhead.extra.length) { + put_byte(s, s.gzhead.extra.length & 255); + put_byte(s, s.gzhead.extra.length >> 8 & 255); + } + if (s.gzhead.hcrc) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending, 0); + } + s.gzindex = 0; + s.status = EXTRA_STATE; + } + } else { + var header = Z_DEFLATED + (s.w_bits - 8 << 4) << 8; + var level_flags = -1; + if (s.strategy >= Z_HUFFMAN_ONLY || s.level < 2) { + level_flags = 0; + } else if (s.level < 6) { + level_flags = 1; + } else if (s.level === 6) { + level_flags = 2; + } else { + level_flags = 3; + } + header |= level_flags << 6; + if (s.strstart !== 0) { + header |= PRESET_DICT; + } + header += 31 - header % 31; + s.status = BUSY_STATE; + putShortMSB(s, header); + if (s.strstart !== 0) { + putShortMSB(s, strm.adler >>> 16); + putShortMSB(s, strm.adler & 65535); + } + strm.adler = 1; + } + } + if (s.status === EXTRA_STATE) { + if (s.gzhead.extra) { + beg = s.pending; + while (s.gzindex < (s.gzhead.extra.length & 65535)) { + if (s.pending === s.pending_buf_size) { + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + flush_pending(strm); + beg = s.pending; + if (s.pending === s.pending_buf_size) { + break; + } + } + put_byte(s, s.gzhead.extra[s.gzindex] & 255); + s.gzindex++; + } + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + if (s.gzindex === s.gzhead.extra.length) { + s.gzindex = 0; + s.status = NAME_STATE; + } + } else { + s.status = NAME_STATE; + } + } + if (s.status === NAME_STATE) { + if (s.gzhead.name) { + beg = s.pending; + do { + if (s.pending === s.pending_buf_size) { + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + flush_pending(strm); + beg = s.pending; + if (s.pending === s.pending_buf_size) { + val = 1; + break; + } + } + if (s.gzindex < s.gzhead.name.length) { + val = s.gzhead.name.charCodeAt(s.gzindex++) & 255; + } else { + val = 0; + } + put_byte(s, val); + } while (val !== 0); + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + if (val === 0) { + s.gzindex = 0; + s.status = COMMENT_STATE; + } + } else { + s.status = COMMENT_STATE; + } + } + if (s.status === COMMENT_STATE) { + if (s.gzhead.comment) { + beg = s.pending; + do { + if (s.pending === s.pending_buf_size) { + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + flush_pending(strm); + beg = s.pending; + if (s.pending === s.pending_buf_size) { + val = 1; + break; + } + } + if (s.gzindex < s.gzhead.comment.length) { + val = s.gzhead.comment.charCodeAt(s.gzindex++) & 255; + } else { + val = 0; + } + put_byte(s, val); + } while (val !== 0); + if (s.gzhead.hcrc && s.pending > beg) { + strm.adler = crc322(strm.adler, s.pending_buf, s.pending - beg, beg); + } + if (val === 0) { + s.status = HCRC_STATE; + } + } else { + s.status = HCRC_STATE; + } + } + if (s.status === HCRC_STATE) { + if (s.gzhead.hcrc) { + if (s.pending + 2 > s.pending_buf_size) { + flush_pending(strm); + } + if (s.pending + 2 <= s.pending_buf_size) { + put_byte(s, strm.adler & 255); + put_byte(s, strm.adler >> 8 & 255); + strm.adler = 0; + s.status = BUSY_STATE; + } + } else { + s.status = BUSY_STATE; + } + } + if (s.pending !== 0) { + flush_pending(strm); + if (strm.avail_out === 0) { + s.last_flush = -1; + return Z_OK; + } + } else if (strm.avail_in === 0 && rank(flush2) <= rank(old_flush) && flush2 !== Z_FINISH) { + return err(strm, Z_BUF_ERROR); + } + if (s.status === FINISH_STATE && strm.avail_in !== 0) { + return err(strm, Z_BUF_ERROR); + } + if (strm.avail_in !== 0 || s.lookahead !== 0 || flush2 !== Z_NO_FLUSH && s.status !== FINISH_STATE) { + var bstate = s.strategy === Z_HUFFMAN_ONLY ? deflate_huff(s, flush2) : s.strategy === Z_RLE ? deflate_rle(s, flush2) : configuration_table[s.level].func(s, flush2); + if (bstate === BS_FINISH_STARTED || bstate === BS_FINISH_DONE) { + s.status = FINISH_STATE; + } + if (bstate === BS_NEED_MORE || bstate === BS_FINISH_STARTED) { + if (strm.avail_out === 0) { + s.last_flush = -1; + } + return Z_OK; + } + if (bstate === BS_BLOCK_DONE) { + if (flush2 === Z_PARTIAL_FLUSH) { + trees._tr_align(s); + } else if (flush2 !== Z_BLOCK) { + trees._tr_stored_block(s, 0, 0, false); + if (flush2 === Z_FULL_FLUSH) { + zero(s.head); + if (s.lookahead === 0) { + s.strstart = 0; + s.block_start = 0; + s.insert = 0; + } + } + } + flush_pending(strm); + if (strm.avail_out === 0) { + s.last_flush = -1; + return Z_OK; + } + } + } + if (flush2 !== Z_FINISH) { + return Z_OK; + } + if (s.wrap <= 0) { + return Z_STREAM_END; + } + if (s.wrap === 2) { + put_byte(s, strm.adler & 255); + put_byte(s, strm.adler >> 8 & 255); + put_byte(s, strm.adler >> 16 & 255); + put_byte(s, strm.adler >> 24 & 255); + put_byte(s, strm.total_in & 255); + put_byte(s, strm.total_in >> 8 & 255); + put_byte(s, strm.total_in >> 16 & 255); + put_byte(s, strm.total_in >> 24 & 255); + } else { + putShortMSB(s, strm.adler >>> 16); + putShortMSB(s, strm.adler & 65535); + } + flush_pending(strm); + if (s.wrap > 0) { + s.wrap = -s.wrap; + } + return s.pending !== 0 ? Z_OK : Z_STREAM_END; + } + function deflateEnd(strm) { + var status2; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + status2 = strm.state.status; + if (status2 !== INIT_STATE && status2 !== EXTRA_STATE && status2 !== NAME_STATE && status2 !== COMMENT_STATE && status2 !== HCRC_STATE && status2 !== BUSY_STATE && status2 !== FINISH_STATE) { + return err(strm, Z_STREAM_ERROR); + } + strm.state = null; + return status2 === BUSY_STATE ? err(strm, Z_DATA_ERROR) : Z_OK; + } + function deflateSetDictionary(strm, dictionary) { + var dictLength = dictionary.length; + var s; + var str, n; + var wrap; + var avail; + var next; + var input; + var tmpDict; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + s = strm.state; + wrap = s.wrap; + if (wrap === 2 || wrap === 1 && s.status !== INIT_STATE || s.lookahead) { + return Z_STREAM_ERROR; + } + if (wrap === 1) { + strm.adler = adler32(strm.adler, dictionary, dictLength, 0); + } + s.wrap = 0; + if (dictLength >= s.w_size) { + if (wrap === 0) { + zero(s.head); + s.strstart = 0; + s.block_start = 0; + s.insert = 0; + } + tmpDict = new utils.Buf8(s.w_size); + utils.arraySet(tmpDict, dictionary, dictLength - s.w_size, s.w_size, 0); + dictionary = tmpDict; + dictLength = s.w_size; + } + avail = strm.avail_in; + next = strm.next_in; + input = strm.input; + strm.avail_in = dictLength; + strm.next_in = 0; + strm.input = dictionary; + fill_window(s); + while (s.lookahead >= MIN_MATCH) { + str = s.strstart; + n = s.lookahead - (MIN_MATCH - 1); + do { + s.ins_h = (s.ins_h << s.hash_shift ^ s.window[str + MIN_MATCH - 1]) & s.hash_mask; + s.prev[str & s.w_mask] = s.head[s.ins_h]; + s.head[s.ins_h] = str; + str++; + } while (--n); + s.strstart = str; + s.lookahead = MIN_MATCH - 1; + fill_window(s); + } + s.strstart += s.lookahead; + s.block_start = s.strstart; + s.insert = s.lookahead; + s.lookahead = 0; + s.match_length = s.prev_length = MIN_MATCH - 1; + s.match_available = 0; + strm.next_in = next; + strm.input = input; + strm.avail_in = avail; + s.wrap = wrap; + return Z_OK; + } + exports2.deflateInit = deflateInit; + exports2.deflateInit2 = deflateInit2; + exports2.deflateReset = deflateReset; + exports2.deflateResetKeep = deflateResetKeep; + exports2.deflateSetHeader = deflateSetHeader; + exports2.deflate = deflate2; + exports2.deflateEnd = deflateEnd; + exports2.deflateSetDictionary = deflateSetDictionary; + exports2.deflateInfo = "pako deflate (from Nodeca project)"; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/utils/strings.js +var require_strings = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/utils/strings.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var utils = require_common(); + var STR_APPLY_OK = true; + var STR_APPLY_UIA_OK = true; + try { + String.fromCharCode.apply(null, [0]); + } catch (__) { + STR_APPLY_OK = false; + } + try { + String.fromCharCode.apply(null, new Uint8Array(1)); + } catch (__) { + STR_APPLY_UIA_OK = false; + } + var _utf8len = new utils.Buf8(256); + for (q = 0; q < 256; q++) { + _utf8len[q] = q >= 252 ? 6 : q >= 248 ? 5 : q >= 240 ? 4 : q >= 224 ? 3 : q >= 192 ? 2 : 1; + } + var q; + _utf8len[254] = _utf8len[254] = 1; + exports2.string2buf = function(str) { + var buf, c, c2, m_pos, i, str_len = str.length, buf_len = 0; + for (m_pos = 0; m_pos < str_len; m_pos++) { + c = str.charCodeAt(m_pos); + if ((c & 64512) === 55296 && m_pos + 1 < str_len) { + c2 = str.charCodeAt(m_pos + 1); + if ((c2 & 64512) === 56320) { + c = 65536 + (c - 55296 << 10) + (c2 - 56320); + m_pos++; + } + } + buf_len += c < 128 ? 1 : c < 2048 ? 2 : c < 65536 ? 3 : 4; + } + buf = new utils.Buf8(buf_len); + for (i = 0, m_pos = 0; i < buf_len; m_pos++) { + c = str.charCodeAt(m_pos); + if ((c & 64512) === 55296 && m_pos + 1 < str_len) { + c2 = str.charCodeAt(m_pos + 1); + if ((c2 & 64512) === 56320) { + c = 65536 + (c - 55296 << 10) + (c2 - 56320); + m_pos++; + } + } + if (c < 128) { + buf[i++] = c; + } else if (c < 2048) { + buf[i++] = 192 | c >>> 6; + buf[i++] = 128 | c & 63; + } else if (c < 65536) { + buf[i++] = 224 | c >>> 12; + buf[i++] = 128 | c >>> 6 & 63; + buf[i++] = 128 | c & 63; + } else { + buf[i++] = 240 | c >>> 18; + buf[i++] = 128 | c >>> 12 & 63; + buf[i++] = 128 | c >>> 6 & 63; + buf[i++] = 128 | c & 63; + } + } + return buf; + }; + function buf2binstring(buf, len) { + if (len < 65534) { + if (buf.subarray && STR_APPLY_UIA_OK || !buf.subarray && STR_APPLY_OK) { + return String.fromCharCode.apply(null, utils.shrinkBuf(buf, len)); + } + } + var result = ""; + for (var i = 0; i < len; i++) { + result += String.fromCharCode(buf[i]); + } + return result; + } + exports2.buf2binstring = function(buf) { + return buf2binstring(buf, buf.length); + }; + exports2.binstring2buf = function(str) { + var buf = new utils.Buf8(str.length); + for (var i = 0, len = buf.length; i < len; i++) { + buf[i] = str.charCodeAt(i); + } + return buf; + }; + exports2.buf2string = function(buf, max) { + var i, out, c, c_len; + var len = max || buf.length; + var utf16buf = new Array(len * 2); + for (out = 0, i = 0; i < len; ) { + c = buf[i++]; + if (c < 128) { + utf16buf[out++] = c; + continue; + } + c_len = _utf8len[c]; + if (c_len > 4) { + utf16buf[out++] = 65533; + i += c_len - 1; + continue; + } + c &= c_len === 2 ? 31 : c_len === 3 ? 15 : 7; + while (c_len > 1 && i < len) { + c = c << 6 | buf[i++] & 63; + c_len--; + } + if (c_len > 1) { + utf16buf[out++] = 65533; + continue; + } + if (c < 65536) { + utf16buf[out++] = c; + } else { + c -= 65536; + utf16buf[out++] = 55296 | c >> 10 & 1023; + utf16buf[out++] = 56320 | c & 1023; + } + } + return buf2binstring(utf16buf, out); + }; + exports2.utf8border = function(buf, max) { + var pos; + max = max || buf.length; + if (max > buf.length) { + max = buf.length; + } + pos = max - 1; + while (pos >= 0 && (buf[pos] & 192) === 128) { + pos--; + } + if (pos < 0) { + return max; + } + if (pos === 0) { + return max; + } + return pos + _utf8len[buf[pos]] > max ? pos : max; + }; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/zstream.js +var require_zstream = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/zstream.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + function ZStream() { + this.input = null; + this.next_in = 0; + this.avail_in = 0; + this.total_in = 0; + this.output = null; + this.next_out = 0; + this.avail_out = 0; + this.total_out = 0; + this.msg = ""; + this.state = null; + this.data_type = 2; + this.adler = 0; + } + module2.exports = ZStream; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/deflate.js +var require_deflate2 = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/deflate.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var zlib_deflate = require_deflate(); + var utils = require_common(); + var strings = require_strings(); + var msg = require_messages(); + var ZStream = require_zstream(); + var toString = Object.prototype.toString; + var Z_NO_FLUSH = 0; + var Z_FINISH = 4; + var Z_OK = 0; + var Z_STREAM_END = 1; + var Z_SYNC_FLUSH = 2; + var Z_DEFAULT_COMPRESSION = -1; + var Z_DEFAULT_STRATEGY = 0; + var Z_DEFLATED = 8; + function Deflate(options) { + if (!(this instanceof Deflate)) + return new Deflate(options); + this.options = utils.assign({ + level: Z_DEFAULT_COMPRESSION, + method: Z_DEFLATED, + chunkSize: 16384, + windowBits: 15, + memLevel: 8, + strategy: Z_DEFAULT_STRATEGY, + to: "" + }, options || {}); + var opt = this.options; + if (opt.raw && opt.windowBits > 0) { + opt.windowBits = -opt.windowBits; + } else if (opt.gzip && opt.windowBits > 0 && opt.windowBits < 16) { + opt.windowBits += 16; + } + this.err = 0; + this.msg = ""; + this.ended = false; + this.chunks = []; + this.strm = new ZStream(); + this.strm.avail_out = 0; + var status2 = zlib_deflate.deflateInit2( + this.strm, + opt.level, + opt.method, + opt.windowBits, + opt.memLevel, + opt.strategy + ); + if (status2 !== Z_OK) { + throw new Error(msg[status2]); + } + if (opt.header) { + zlib_deflate.deflateSetHeader(this.strm, opt.header); + } + if (opt.dictionary) { + var dict; + if (typeof opt.dictionary === "string") { + dict = strings.string2buf(opt.dictionary); + } else if (toString.call(opt.dictionary) === "[object ArrayBuffer]") { + dict = new Uint8Array(opt.dictionary); + } else { + dict = opt.dictionary; + } + status2 = zlib_deflate.deflateSetDictionary(this.strm, dict); + if (status2 !== Z_OK) { + throw new Error(msg[status2]); + } + this._dict_set = true; + } + } + Deflate.prototype.push = function(data, mode) { + var strm = this.strm; + var chunkSize = this.options.chunkSize; + var status2, _mode; + if (this.ended) { + return false; + } + _mode = mode === ~~mode ? mode : mode === true ? Z_FINISH : Z_NO_FLUSH; + if (typeof data === "string") { + strm.input = strings.string2buf(data); + } else if (toString.call(data) === "[object ArrayBuffer]") { + strm.input = new Uint8Array(data); + } else { + strm.input = data; + } + strm.next_in = 0; + strm.avail_in = strm.input.length; + do { + if (strm.avail_out === 0) { + strm.output = new utils.Buf8(chunkSize); + strm.next_out = 0; + strm.avail_out = chunkSize; + } + status2 = zlib_deflate.deflate(strm, _mode); + if (status2 !== Z_STREAM_END && status2 !== Z_OK) { + this.onEnd(status2); + this.ended = true; + return false; + } + if (strm.avail_out === 0 || strm.avail_in === 0 && (_mode === Z_FINISH || _mode === Z_SYNC_FLUSH)) { + if (this.options.to === "string") { + this.onData(strings.buf2binstring(utils.shrinkBuf(strm.output, strm.next_out))); + } else { + this.onData(utils.shrinkBuf(strm.output, strm.next_out)); + } + } + } while ((strm.avail_in > 0 || strm.avail_out === 0) && status2 !== Z_STREAM_END); + if (_mode === Z_FINISH) { + status2 = zlib_deflate.deflateEnd(this.strm); + this.onEnd(status2); + this.ended = true; + return status2 === Z_OK; + } + if (_mode === Z_SYNC_FLUSH) { + this.onEnd(Z_OK); + strm.avail_out = 0; + return true; + } + return true; + }; + Deflate.prototype.onData = function(chunk) { + this.chunks.push(chunk); + }; + Deflate.prototype.onEnd = function(status2) { + if (status2 === Z_OK) { + if (this.options.to === "string") { + this.result = this.chunks.join(""); + } else { + this.result = utils.flattenChunks(this.chunks); + } + } + this.chunks = []; + this.err = status2; + this.msg = this.strm.msg; + }; + function deflate2(input, options) { + var deflator = new Deflate(options); + deflator.push(input, true); + if (deflator.err) { + throw deflator.msg || msg[deflator.err]; + } + return deflator.result; + } + function deflateRaw(input, options) { + options = options || {}; + options.raw = true; + return deflate2(input, options); + } + function gzip(input, options) { + options = options || {}; + options.gzip = true; + return deflate2(input, options); + } + exports2.Deflate = Deflate; + exports2.deflate = deflate2; + exports2.deflateRaw = deflateRaw; + exports2.gzip = gzip; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/inffast.js +var require_inffast = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/inffast.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var BAD = 30; + var TYPE = 12; + module2.exports = function inflate_fast(strm, start) { + var state; + var _in; + var last2; + var _out; + var beg; + var end; + var dmax; + var wsize; + var whave; + var wnext; + var s_window; + var hold; + var bits; + var lcode; + var dcode; + var lmask; + var dmask; + var here; + var op; + var len; + var dist; + var from; + var from_source; + var input, output; + state = strm.state; + _in = strm.next_in; + input = strm.input; + last2 = _in + (strm.avail_in - 5); + _out = strm.next_out; + output = strm.output; + beg = _out - (start - strm.avail_out); + end = _out + (strm.avail_out - 257); + dmax = state.dmax; + wsize = state.wsize; + whave = state.whave; + wnext = state.wnext; + s_window = state.window; + hold = state.hold; + bits = state.bits; + lcode = state.lencode; + dcode = state.distcode; + lmask = (1 << state.lenbits) - 1; + dmask = (1 << state.distbits) - 1; + top: + do { + if (bits < 15) { + hold += input[_in++] << bits; + bits += 8; + hold += input[_in++] << bits; + bits += 8; + } + here = lcode[hold & lmask]; + dolen: + for (; ; ) { + op = here >>> 24; + hold >>>= op; + bits -= op; + op = here >>> 16 & 255; + if (op === 0) { + output[_out++] = here & 65535; + } else if (op & 16) { + len = here & 65535; + op &= 15; + if (op) { + if (bits < op) { + hold += input[_in++] << bits; + bits += 8; + } + len += hold & (1 << op) - 1; + hold >>>= op; + bits -= op; + } + if (bits < 15) { + hold += input[_in++] << bits; + bits += 8; + hold += input[_in++] << bits; + bits += 8; + } + here = dcode[hold & dmask]; + dodist: + for (; ; ) { + op = here >>> 24; + hold >>>= op; + bits -= op; + op = here >>> 16 & 255; + if (op & 16) { + dist = here & 65535; + op &= 15; + if (bits < op) { + hold += input[_in++] << bits; + bits += 8; + if (bits < op) { + hold += input[_in++] << bits; + bits += 8; + } + } + dist += hold & (1 << op) - 1; + if (dist > dmax) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break top; + } + hold >>>= op; + bits -= op; + op = _out - beg; + if (dist > op) { + op = dist - op; + if (op > whave) { + if (state.sane) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break top; + } + } + from = 0; + from_source = s_window; + if (wnext === 0) { + from += wsize - op; + if (op < len) { + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = _out - dist; + from_source = output; + } + } else if (wnext < op) { + from += wsize + wnext - op; + op -= wnext; + if (op < len) { + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = 0; + if (wnext < len) { + op = wnext; + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = _out - dist; + from_source = output; + } + } + } else { + from += wnext - op; + if (op < len) { + len -= op; + do { + output[_out++] = s_window[from++]; + } while (--op); + from = _out - dist; + from_source = output; + } + } + while (len > 2) { + output[_out++] = from_source[from++]; + output[_out++] = from_source[from++]; + output[_out++] = from_source[from++]; + len -= 3; + } + if (len) { + output[_out++] = from_source[from++]; + if (len > 1) { + output[_out++] = from_source[from++]; + } + } + } else { + from = _out - dist; + do { + output[_out++] = output[from++]; + output[_out++] = output[from++]; + output[_out++] = output[from++]; + len -= 3; + } while (len > 2); + if (len) { + output[_out++] = output[from++]; + if (len > 1) { + output[_out++] = output[from++]; + } + } + } + } else if ((op & 64) === 0) { + here = dcode[(here & 65535) + (hold & (1 << op) - 1)]; + continue dodist; + } else { + strm.msg = "invalid distance code"; + state.mode = BAD; + break top; + } + break; + } + } else if ((op & 64) === 0) { + here = lcode[(here & 65535) + (hold & (1 << op) - 1)]; + continue dolen; + } else if (op & 32) { + state.mode = TYPE; + break top; + } else { + strm.msg = "invalid literal/length code"; + state.mode = BAD; + break top; + } + break; + } + } while (_in < last2 && _out < end); + len = bits >> 3; + _in -= len; + bits -= len << 3; + hold &= (1 << bits) - 1; + strm.next_in = _in; + strm.next_out = _out; + strm.avail_in = _in < last2 ? 5 + (last2 - _in) : 5 - (_in - last2); + strm.avail_out = _out < end ? 257 + (end - _out) : 257 - (_out - end); + state.hold = hold; + state.bits = bits; + return; + }; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/inftrees.js +var require_inftrees = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/inftrees.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var utils = require_common(); + var MAXBITS = 15; + var ENOUGH_LENS = 852; + var ENOUGH_DISTS = 592; + var CODES = 0; + var LENS = 1; + var DISTS = 2; + var lbase = [ + /* Length codes 257..285 base */ + 3, + 4, + 5, + 6, + 7, + 8, + 9, + 10, + 11, + 13, + 15, + 17, + 19, + 23, + 27, + 31, + 35, + 43, + 51, + 59, + 67, + 83, + 99, + 115, + 131, + 163, + 195, + 227, + 258, + 0, + 0 + ]; + var lext = [ + /* Length codes 257..285 extra */ + 16, + 16, + 16, + 16, + 16, + 16, + 16, + 16, + 17, + 17, + 17, + 17, + 18, + 18, + 18, + 18, + 19, + 19, + 19, + 19, + 20, + 20, + 20, + 20, + 21, + 21, + 21, + 21, + 16, + 72, + 78 + ]; + var dbase = [ + /* Distance codes 0..29 base */ + 1, + 2, + 3, + 4, + 5, + 7, + 9, + 13, + 17, + 25, + 33, + 49, + 65, + 97, + 129, + 193, + 257, + 385, + 513, + 769, + 1025, + 1537, + 2049, + 3073, + 4097, + 6145, + 8193, + 12289, + 16385, + 24577, + 0, + 0 + ]; + var dext = [ + /* Distance codes 0..29 extra */ + 16, + 16, + 16, + 16, + 17, + 17, + 18, + 18, + 19, + 19, + 20, + 20, + 21, + 21, + 22, + 22, + 23, + 23, + 24, + 24, + 25, + 25, + 26, + 26, + 27, + 27, + 28, + 28, + 29, + 29, + 64, + 64 + ]; + module2.exports = function inflate_table(type, lens, lens_index, codes, table, table_index, work, opts) { + var bits = opts.bits; + var len = 0; + var sym = 0; + var min = 0, max = 0; + var root2 = 0; + var curr = 0; + var drop = 0; + var left = 0; + var used = 0; + var huff = 0; + var incr; + var fill; + var low; + var mask; + var next; + var base = null; + var base_index = 0; + var end; + var count = new utils.Buf16(MAXBITS + 1); + var offs = new utils.Buf16(MAXBITS + 1); + var extra = null; + var extra_index = 0; + var here_bits, here_op, here_val; + for (len = 0; len <= MAXBITS; len++) { + count[len] = 0; + } + for (sym = 0; sym < codes; sym++) { + count[lens[lens_index + sym]]++; + } + root2 = bits; + for (max = MAXBITS; max >= 1; max--) { + if (count[max] !== 0) { + break; + } + } + if (root2 > max) { + root2 = max; + } + if (max === 0) { + table[table_index++] = 1 << 24 | 64 << 16 | 0; + table[table_index++] = 1 << 24 | 64 << 16 | 0; + opts.bits = 1; + return 0; + } + for (min = 1; min < max; min++) { + if (count[min] !== 0) { + break; + } + } + if (root2 < min) { + root2 = min; + } + left = 1; + for (len = 1; len <= MAXBITS; len++) { + left <<= 1; + left -= count[len]; + if (left < 0) { + return -1; + } + } + if (left > 0 && (type === CODES || max !== 1)) { + return -1; + } + offs[1] = 0; + for (len = 1; len < MAXBITS; len++) { + offs[len + 1] = offs[len] + count[len]; + } + for (sym = 0; sym < codes; sym++) { + if (lens[lens_index + sym] !== 0) { + work[offs[lens[lens_index + sym]]++] = sym; + } + } + if (type === CODES) { + base = extra = work; + end = 19; + } else if (type === LENS) { + base = lbase; + base_index -= 257; + extra = lext; + extra_index -= 257; + end = 256; + } else { + base = dbase; + extra = dext; + end = -1; + } + huff = 0; + sym = 0; + len = min; + next = table_index; + curr = root2; + drop = 0; + low = -1; + used = 1 << root2; + mask = used - 1; + if (type === LENS && used > ENOUGH_LENS || type === DISTS && used > ENOUGH_DISTS) { + return 1; + } + for (; ; ) { + here_bits = len - drop; + if (work[sym] < end) { + here_op = 0; + here_val = work[sym]; + } else if (work[sym] > end) { + here_op = extra[extra_index + work[sym]]; + here_val = base[base_index + work[sym]]; + } else { + here_op = 32 + 64; + here_val = 0; + } + incr = 1 << len - drop; + fill = 1 << curr; + min = fill; + do { + fill -= incr; + table[next + (huff >> drop) + fill] = here_bits << 24 | here_op << 16 | here_val | 0; + } while (fill !== 0); + incr = 1 << len - 1; + while (huff & incr) { + incr >>= 1; + } + if (incr !== 0) { + huff &= incr - 1; + huff += incr; + } else { + huff = 0; + } + sym++; + if (--count[len] === 0) { + if (len === max) { + break; + } + len = lens[lens_index + work[sym]]; + } + if (len > root2 && (huff & mask) !== low) { + if (drop === 0) { + drop = root2; + } + next += min; + curr = len - drop; + left = 1 << curr; + while (curr + drop < max) { + left -= count[curr + drop]; + if (left <= 0) { + break; + } + curr++; + left <<= 1; + } + used += 1 << curr; + if (type === LENS && used > ENOUGH_LENS || type === DISTS && used > ENOUGH_DISTS) { + return 1; + } + low = huff & mask; + table[low] = root2 << 24 | curr << 16 | next - table_index | 0; + } + } + if (huff !== 0) { + table[next + huff] = len - drop << 24 | 64 << 16 | 0; + } + opts.bits = root2; + return 0; + }; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/inflate.js +var require_inflate = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/inflate.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var utils = require_common(); + var adler32 = require_adler32(); + var crc322 = require_crc322(); + var inflate_fast = require_inffast(); + var inflate_table = require_inftrees(); + var CODES = 0; + var LENS = 1; + var DISTS = 2; + var Z_FINISH = 4; + var Z_BLOCK = 5; + var Z_TREES = 6; + var Z_OK = 0; + var Z_STREAM_END = 1; + var Z_NEED_DICT = 2; + var Z_STREAM_ERROR = -2; + var Z_DATA_ERROR = -3; + var Z_MEM_ERROR = -4; + var Z_BUF_ERROR = -5; + var Z_DEFLATED = 8; + var HEAD = 1; + var FLAGS = 2; + var TIME = 3; + var OS = 4; + var EXLEN = 5; + var EXTRA2 = 6; + var NAME = 7; + var COMMENT = 8; + var HCRC = 9; + var DICTID = 10; + var DICT = 11; + var TYPE = 12; + var TYPEDO = 13; + var STORED = 14; + var COPY_ = 15; + var COPY = 16; + var TABLE = 17; + var LENLENS = 18; + var CODELENS = 19; + var LEN_ = 20; + var LEN = 21; + var LENEXT = 22; + var DIST = 23; + var DISTEXT = 24; + var MATCH = 25; + var LIT = 26; + var CHECK = 27; + var LENGTH = 28; + var DONE = 29; + var BAD = 30; + var MEM = 31; + var SYNC = 32; + var ENOUGH_LENS = 852; + var ENOUGH_DISTS = 592; + var MAX_WBITS = 15; + var DEF_WBITS = MAX_WBITS; + function zswap32(q) { + return (q >>> 24 & 255) + (q >>> 8 & 65280) + ((q & 65280) << 8) + ((q & 255) << 24); + } + function InflateState() { + this.mode = 0; + this.last = false; + this.wrap = 0; + this.havedict = false; + this.flags = 0; + this.dmax = 0; + this.check = 0; + this.total = 0; + this.head = null; + this.wbits = 0; + this.wsize = 0; + this.whave = 0; + this.wnext = 0; + this.window = null; + this.hold = 0; + this.bits = 0; + this.length = 0; + this.offset = 0; + this.extra = 0; + this.lencode = null; + this.distcode = null; + this.lenbits = 0; + this.distbits = 0; + this.ncode = 0; + this.nlen = 0; + this.ndist = 0; + this.have = 0; + this.next = null; + this.lens = new utils.Buf16(320); + this.work = new utils.Buf16(288); + this.lendyn = null; + this.distdyn = null; + this.sane = 0; + this.back = 0; + this.was = 0; + } + function inflateResetKeep(strm) { + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + strm.total_in = strm.total_out = state.total = 0; + strm.msg = ""; + if (state.wrap) { + strm.adler = state.wrap & 1; + } + state.mode = HEAD; + state.last = 0; + state.havedict = 0; + state.dmax = 32768; + state.head = null; + state.hold = 0; + state.bits = 0; + state.lencode = state.lendyn = new utils.Buf32(ENOUGH_LENS); + state.distcode = state.distdyn = new utils.Buf32(ENOUGH_DISTS); + state.sane = 1; + state.back = -1; + return Z_OK; + } + function inflateReset(strm) { + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + state.wsize = 0; + state.whave = 0; + state.wnext = 0; + return inflateResetKeep(strm); + } + function inflateReset2(strm, windowBits) { + var wrap; + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + if (windowBits < 0) { + wrap = 0; + windowBits = -windowBits; + } else { + wrap = (windowBits >> 4) + 1; + if (windowBits < 48) { + windowBits &= 15; + } + } + if (windowBits && (windowBits < 8 || windowBits > 15)) { + return Z_STREAM_ERROR; + } + if (state.window !== null && state.wbits !== windowBits) { + state.window = null; + } + state.wrap = wrap; + state.wbits = windowBits; + return inflateReset(strm); + } + function inflateInit2(strm, windowBits) { + var ret; + var state; + if (!strm) { + return Z_STREAM_ERROR; + } + state = new InflateState(); + strm.state = state; + state.window = null; + ret = inflateReset2(strm, windowBits); + if (ret !== Z_OK) { + strm.state = null; + } + return ret; + } + function inflateInit(strm) { + return inflateInit2(strm, DEF_WBITS); + } + var virgin = true; + var lenfix; + var distfix; + function fixedtables(state) { + if (virgin) { + var sym; + lenfix = new utils.Buf32(512); + distfix = new utils.Buf32(32); + sym = 0; + while (sym < 144) { + state.lens[sym++] = 8; + } + while (sym < 256) { + state.lens[sym++] = 9; + } + while (sym < 280) { + state.lens[sym++] = 7; + } + while (sym < 288) { + state.lens[sym++] = 8; + } + inflate_table(LENS, state.lens, 0, 288, lenfix, 0, state.work, { bits: 9 }); + sym = 0; + while (sym < 32) { + state.lens[sym++] = 5; + } + inflate_table(DISTS, state.lens, 0, 32, distfix, 0, state.work, { bits: 5 }); + virgin = false; + } + state.lencode = lenfix; + state.lenbits = 9; + state.distcode = distfix; + state.distbits = 5; + } + function updatewindow(strm, src, end, copy2) { + var dist; + var state = strm.state; + if (state.window === null) { + state.wsize = 1 << state.wbits; + state.wnext = 0; + state.whave = 0; + state.window = new utils.Buf8(state.wsize); + } + if (copy2 >= state.wsize) { + utils.arraySet(state.window, src, end - state.wsize, state.wsize, 0); + state.wnext = 0; + state.whave = state.wsize; + } else { + dist = state.wsize - state.wnext; + if (dist > copy2) { + dist = copy2; + } + utils.arraySet(state.window, src, end - copy2, dist, state.wnext); + copy2 -= dist; + if (copy2) { + utils.arraySet(state.window, src, end - copy2, copy2, 0); + state.wnext = copy2; + state.whave = state.wsize; + } else { + state.wnext += dist; + if (state.wnext === state.wsize) { + state.wnext = 0; + } + if (state.whave < state.wsize) { + state.whave += dist; + } + } + } + return 0; + } + function inflate2(strm, flush2) { + var state; + var input, output; + var next; + var put; + var have, left; + var hold; + var bits; + var _in, _out; + var copy2; + var from; + var from_source; + var here = 0; + var here_bits, here_op, here_val; + var last_bits, last_op, last_val; + var len; + var ret; + var hbuf = new utils.Buf8(4); + var opts; + var n; + var order = ( + /* permutation of code lengths */ + [16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15] + ); + if (!strm || !strm.state || !strm.output || !strm.input && strm.avail_in !== 0) { + return Z_STREAM_ERROR; + } + state = strm.state; + if (state.mode === TYPE) { + state.mode = TYPEDO; + } + put = strm.next_out; + output = strm.output; + left = strm.avail_out; + next = strm.next_in; + input = strm.input; + have = strm.avail_in; + hold = state.hold; + bits = state.bits; + _in = have; + _out = left; + ret = Z_OK; + inf_leave: + for (; ; ) { + switch (state.mode) { + case HEAD: + if (state.wrap === 0) { + state.mode = TYPEDO; + break; + } + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (state.wrap & 2 && hold === 35615) { + state.check = 0; + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + hold = 0; + bits = 0; + state.mode = FLAGS; + break; + } + state.flags = 0; + if (state.head) { + state.head.done = false; + } + if (!(state.wrap & 1) || /* check if zlib header allowed */ + (((hold & 255) << 8) + (hold >> 8)) % 31) { + strm.msg = "incorrect header check"; + state.mode = BAD; + break; + } + if ((hold & 15) !== Z_DEFLATED) { + strm.msg = "unknown compression method"; + state.mode = BAD; + break; + } + hold >>>= 4; + bits -= 4; + len = (hold & 15) + 8; + if (state.wbits === 0) { + state.wbits = len; + } else if (len > state.wbits) { + strm.msg = "invalid window size"; + state.mode = BAD; + break; + } + state.dmax = 1 << len; + strm.adler = state.check = 1; + state.mode = hold & 512 ? DICTID : TYPE; + hold = 0; + bits = 0; + break; + case FLAGS: + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.flags = hold; + if ((state.flags & 255) !== Z_DEFLATED) { + strm.msg = "unknown compression method"; + state.mode = BAD; + break; + } + if (state.flags & 57344) { + strm.msg = "unknown header flags set"; + state.mode = BAD; + break; + } + if (state.head) { + state.head.text = hold >> 8 & 1; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + } + hold = 0; + bits = 0; + state.mode = TIME; + case TIME: + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (state.head) { + state.head.time = hold; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + hbuf[2] = hold >>> 16 & 255; + hbuf[3] = hold >>> 24 & 255; + state.check = crc322(state.check, hbuf, 4, 0); + } + hold = 0; + bits = 0; + state.mode = OS; + case OS: + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (state.head) { + state.head.xflags = hold & 255; + state.head.os = hold >> 8; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + } + hold = 0; + bits = 0; + state.mode = EXLEN; + case EXLEN: + if (state.flags & 1024) { + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.length = hold; + if (state.head) { + state.head.extra_len = hold; + } + if (state.flags & 512) { + hbuf[0] = hold & 255; + hbuf[1] = hold >>> 8 & 255; + state.check = crc322(state.check, hbuf, 2, 0); + } + hold = 0; + bits = 0; + } else if (state.head) { + state.head.extra = null; + } + state.mode = EXTRA2; + case EXTRA2: + if (state.flags & 1024) { + copy2 = state.length; + if (copy2 > have) { + copy2 = have; + } + if (copy2) { + if (state.head) { + len = state.head.extra_len - state.length; + if (!state.head.extra) { + state.head.extra = new Array(state.head.extra_len); + } + utils.arraySet( + state.head.extra, + input, + next, + // extra field is limited to 65536 bytes + // - no need for additional size check + copy2, + /*len + copy > state.head.extra_max - len ? state.head.extra_max : copy,*/ + len + ); + } + if (state.flags & 512) { + state.check = crc322(state.check, input, copy2, next); + } + have -= copy2; + next += copy2; + state.length -= copy2; + } + if (state.length) { + break inf_leave; + } + } + state.length = 0; + state.mode = NAME; + case NAME: + if (state.flags & 2048) { + if (have === 0) { + break inf_leave; + } + copy2 = 0; + do { + len = input[next + copy2++]; + if (state.head && len && state.length < 65536) { + state.head.name += String.fromCharCode(len); + } + } while (len && copy2 < have); + if (state.flags & 512) { + state.check = crc322(state.check, input, copy2, next); + } + have -= copy2; + next += copy2; + if (len) { + break inf_leave; + } + } else if (state.head) { + state.head.name = null; + } + state.length = 0; + state.mode = COMMENT; + case COMMENT: + if (state.flags & 4096) { + if (have === 0) { + break inf_leave; + } + copy2 = 0; + do { + len = input[next + copy2++]; + if (state.head && len && state.length < 65536) { + state.head.comment += String.fromCharCode(len); + } + } while (len && copy2 < have); + if (state.flags & 512) { + state.check = crc322(state.check, input, copy2, next); + } + have -= copy2; + next += copy2; + if (len) { + break inf_leave; + } + } else if (state.head) { + state.head.comment = null; + } + state.mode = HCRC; + case HCRC: + if (state.flags & 512) { + while (bits < 16) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (hold !== (state.check & 65535)) { + strm.msg = "header crc mismatch"; + state.mode = BAD; + break; + } + hold = 0; + bits = 0; + } + if (state.head) { + state.head.hcrc = state.flags >> 9 & 1; + state.head.done = true; + } + strm.adler = state.check = 0; + state.mode = TYPE; + break; + case DICTID: + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + strm.adler = state.check = zswap32(hold); + hold = 0; + bits = 0; + state.mode = DICT; + case DICT: + if (state.havedict === 0) { + strm.next_out = put; + strm.avail_out = left; + strm.next_in = next; + strm.avail_in = have; + state.hold = hold; + state.bits = bits; + return Z_NEED_DICT; + } + strm.adler = state.check = 1; + state.mode = TYPE; + case TYPE: + if (flush2 === Z_BLOCK || flush2 === Z_TREES) { + break inf_leave; + } + case TYPEDO: + if (state.last) { + hold >>>= bits & 7; + bits -= bits & 7; + state.mode = CHECK; + break; + } + while (bits < 3) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.last = hold & 1; + hold >>>= 1; + bits -= 1; + switch (hold & 3) { + case 0: + state.mode = STORED; + break; + case 1: + fixedtables(state); + state.mode = LEN_; + if (flush2 === Z_TREES) { + hold >>>= 2; + bits -= 2; + break inf_leave; + } + break; + case 2: + state.mode = TABLE; + break; + case 3: + strm.msg = "invalid block type"; + state.mode = BAD; + } + hold >>>= 2; + bits -= 2; + break; + case STORED: + hold >>>= bits & 7; + bits -= bits & 7; + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if ((hold & 65535) !== (hold >>> 16 ^ 65535)) { + strm.msg = "invalid stored block lengths"; + state.mode = BAD; + break; + } + state.length = hold & 65535; + hold = 0; + bits = 0; + state.mode = COPY_; + if (flush2 === Z_TREES) { + break inf_leave; + } + case COPY_: + state.mode = COPY; + case COPY: + copy2 = state.length; + if (copy2) { + if (copy2 > have) { + copy2 = have; + } + if (copy2 > left) { + copy2 = left; + } + if (copy2 === 0) { + break inf_leave; + } + utils.arraySet(output, input, next, copy2, put); + have -= copy2; + next += copy2; + left -= copy2; + put += copy2; + state.length -= copy2; + break; + } + state.mode = TYPE; + break; + case TABLE: + while (bits < 14) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.nlen = (hold & 31) + 257; + hold >>>= 5; + bits -= 5; + state.ndist = (hold & 31) + 1; + hold >>>= 5; + bits -= 5; + state.ncode = (hold & 15) + 4; + hold >>>= 4; + bits -= 4; + if (state.nlen > 286 || state.ndist > 30) { + strm.msg = "too many length or distance symbols"; + state.mode = BAD; + break; + } + state.have = 0; + state.mode = LENLENS; + case LENLENS: + while (state.have < state.ncode) { + while (bits < 3) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.lens[order[state.have++]] = hold & 7; + hold >>>= 3; + bits -= 3; + } + while (state.have < 19) { + state.lens[order[state.have++]] = 0; + } + state.lencode = state.lendyn; + state.lenbits = 7; + opts = { bits: state.lenbits }; + ret = inflate_table(CODES, state.lens, 0, 19, state.lencode, 0, state.work, opts); + state.lenbits = opts.bits; + if (ret) { + strm.msg = "invalid code lengths set"; + state.mode = BAD; + break; + } + state.have = 0; + state.mode = CODELENS; + case CODELENS: + while (state.have < state.nlen + state.ndist) { + for (; ; ) { + here = state.lencode[hold & (1 << state.lenbits) - 1]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (here_val < 16) { + hold >>>= here_bits; + bits -= here_bits; + state.lens[state.have++] = here_val; + } else { + if (here_val === 16) { + n = here_bits + 2; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= here_bits; + bits -= here_bits; + if (state.have === 0) { + strm.msg = "invalid bit length repeat"; + state.mode = BAD; + break; + } + len = state.lens[state.have - 1]; + copy2 = 3 + (hold & 3); + hold >>>= 2; + bits -= 2; + } else if (here_val === 17) { + n = here_bits + 3; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= here_bits; + bits -= here_bits; + len = 0; + copy2 = 3 + (hold & 7); + hold >>>= 3; + bits -= 3; + } else { + n = here_bits + 7; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= here_bits; + bits -= here_bits; + len = 0; + copy2 = 11 + (hold & 127); + hold >>>= 7; + bits -= 7; + } + if (state.have + copy2 > state.nlen + state.ndist) { + strm.msg = "invalid bit length repeat"; + state.mode = BAD; + break; + } + while (copy2--) { + state.lens[state.have++] = len; + } + } + } + if (state.mode === BAD) { + break; + } + if (state.lens[256] === 0) { + strm.msg = "invalid code -- missing end-of-block"; + state.mode = BAD; + break; + } + state.lenbits = 9; + opts = { bits: state.lenbits }; + ret = inflate_table(LENS, state.lens, 0, state.nlen, state.lencode, 0, state.work, opts); + state.lenbits = opts.bits; + if (ret) { + strm.msg = "invalid literal/lengths set"; + state.mode = BAD; + break; + } + state.distbits = 6; + state.distcode = state.distdyn; + opts = { bits: state.distbits }; + ret = inflate_table(DISTS, state.lens, state.nlen, state.ndist, state.distcode, 0, state.work, opts); + state.distbits = opts.bits; + if (ret) { + strm.msg = "invalid distances set"; + state.mode = BAD; + break; + } + state.mode = LEN_; + if (flush2 === Z_TREES) { + break inf_leave; + } + case LEN_: + state.mode = LEN; + case LEN: + if (have >= 6 && left >= 258) { + strm.next_out = put; + strm.avail_out = left; + strm.next_in = next; + strm.avail_in = have; + state.hold = hold; + state.bits = bits; + inflate_fast(strm, _out); + put = strm.next_out; + output = strm.output; + left = strm.avail_out; + next = strm.next_in; + input = strm.input; + have = strm.avail_in; + hold = state.hold; + bits = state.bits; + if (state.mode === TYPE) { + state.back = -1; + } + break; + } + state.back = 0; + for (; ; ) { + here = state.lencode[hold & (1 << state.lenbits) - 1]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (here_op && (here_op & 240) === 0) { + last_bits = here_bits; + last_op = here_op; + last_val = here_val; + for (; ; ) { + here = state.lencode[last_val + ((hold & (1 << last_bits + last_op) - 1) >> last_bits)]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (last_bits + here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= last_bits; + bits -= last_bits; + state.back += last_bits; + } + hold >>>= here_bits; + bits -= here_bits; + state.back += here_bits; + state.length = here_val; + if (here_op === 0) { + state.mode = LIT; + break; + } + if (here_op & 32) { + state.back = -1; + state.mode = TYPE; + break; + } + if (here_op & 64) { + strm.msg = "invalid literal/length code"; + state.mode = BAD; + break; + } + state.extra = here_op & 15; + state.mode = LENEXT; + case LENEXT: + if (state.extra) { + n = state.extra; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.length += hold & (1 << state.extra) - 1; + hold >>>= state.extra; + bits -= state.extra; + state.back += state.extra; + } + state.was = state.length; + state.mode = DIST; + case DIST: + for (; ; ) { + here = state.distcode[hold & (1 << state.distbits) - 1]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if ((here_op & 240) === 0) { + last_bits = here_bits; + last_op = here_op; + last_val = here_val; + for (; ; ) { + here = state.distcode[last_val + ((hold & (1 << last_bits + last_op) - 1) >> last_bits)]; + here_bits = here >>> 24; + here_op = here >>> 16 & 255; + here_val = here & 65535; + if (last_bits + here_bits <= bits) { + break; + } + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + hold >>>= last_bits; + bits -= last_bits; + state.back += last_bits; + } + hold >>>= here_bits; + bits -= here_bits; + state.back += here_bits; + if (here_op & 64) { + strm.msg = "invalid distance code"; + state.mode = BAD; + break; + } + state.offset = here_val; + state.extra = here_op & 15; + state.mode = DISTEXT; + case DISTEXT: + if (state.extra) { + n = state.extra; + while (bits < n) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + state.offset += hold & (1 << state.extra) - 1; + hold >>>= state.extra; + bits -= state.extra; + state.back += state.extra; + } + if (state.offset > state.dmax) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break; + } + state.mode = MATCH; + case MATCH: + if (left === 0) { + break inf_leave; + } + copy2 = _out - left; + if (state.offset > copy2) { + copy2 = state.offset - copy2; + if (copy2 > state.whave) { + if (state.sane) { + strm.msg = "invalid distance too far back"; + state.mode = BAD; + break; + } + } + if (copy2 > state.wnext) { + copy2 -= state.wnext; + from = state.wsize - copy2; + } else { + from = state.wnext - copy2; + } + if (copy2 > state.length) { + copy2 = state.length; + } + from_source = state.window; + } else { + from_source = output; + from = put - state.offset; + copy2 = state.length; + } + if (copy2 > left) { + copy2 = left; + } + left -= copy2; + state.length -= copy2; + do { + output[put++] = from_source[from++]; + } while (--copy2); + if (state.length === 0) { + state.mode = LEN; + } + break; + case LIT: + if (left === 0) { + break inf_leave; + } + output[put++] = state.length; + left--; + state.mode = LEN; + break; + case CHECK: + if (state.wrap) { + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold |= input[next++] << bits; + bits += 8; + } + _out -= left; + strm.total_out += _out; + state.total += _out; + if (_out) { + strm.adler = state.check = /*UPDATE(state.check, put - _out, _out);*/ + state.flags ? crc322(state.check, output, _out, put - _out) : adler32(state.check, output, _out, put - _out); + } + _out = left; + if ((state.flags ? hold : zswap32(hold)) !== state.check) { + strm.msg = "incorrect data check"; + state.mode = BAD; + break; + } + hold = 0; + bits = 0; + } + state.mode = LENGTH; + case LENGTH: + if (state.wrap && state.flags) { + while (bits < 32) { + if (have === 0) { + break inf_leave; + } + have--; + hold += input[next++] << bits; + bits += 8; + } + if (hold !== (state.total & 4294967295)) { + strm.msg = "incorrect length check"; + state.mode = BAD; + break; + } + hold = 0; + bits = 0; + } + state.mode = DONE; + case DONE: + ret = Z_STREAM_END; + break inf_leave; + case BAD: + ret = Z_DATA_ERROR; + break inf_leave; + case MEM: + return Z_MEM_ERROR; + case SYNC: + default: + return Z_STREAM_ERROR; + } + } + strm.next_out = put; + strm.avail_out = left; + strm.next_in = next; + strm.avail_in = have; + state.hold = hold; + state.bits = bits; + if (state.wsize || _out !== strm.avail_out && state.mode < BAD && (state.mode < CHECK || flush2 !== Z_FINISH)) { + if (updatewindow(strm, strm.output, strm.next_out, _out - strm.avail_out)) { + state.mode = MEM; + return Z_MEM_ERROR; + } + } + _in -= strm.avail_in; + _out -= strm.avail_out; + strm.total_in += _in; + strm.total_out += _out; + state.total += _out; + if (state.wrap && _out) { + strm.adler = state.check = /*UPDATE(state.check, strm.next_out - _out, _out);*/ + state.flags ? crc322(state.check, output, _out, strm.next_out - _out) : adler32(state.check, output, _out, strm.next_out - _out); + } + strm.data_type = state.bits + (state.last ? 64 : 0) + (state.mode === TYPE ? 128 : 0) + (state.mode === LEN_ || state.mode === COPY_ ? 256 : 0); + if ((_in === 0 && _out === 0 || flush2 === Z_FINISH) && ret === Z_OK) { + ret = Z_BUF_ERROR; + } + return ret; + } + function inflateEnd(strm) { + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + var state = strm.state; + if (state.window) { + state.window = null; + } + strm.state = null; + return Z_OK; + } + function inflateGetHeader(strm, head) { + var state; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + if ((state.wrap & 2) === 0) { + return Z_STREAM_ERROR; + } + state.head = head; + head.done = false; + return Z_OK; + } + function inflateSetDictionary(strm, dictionary) { + var dictLength = dictionary.length; + var state; + var dictid; + var ret; + if (!strm || !strm.state) { + return Z_STREAM_ERROR; + } + state = strm.state; + if (state.wrap !== 0 && state.mode !== DICT) { + return Z_STREAM_ERROR; + } + if (state.mode === DICT) { + dictid = 1; + dictid = adler32(dictid, dictionary, dictLength, 0); + if (dictid !== state.check) { + return Z_DATA_ERROR; + } + } + ret = updatewindow(strm, dictionary, dictLength, dictLength); + if (ret) { + state.mode = MEM; + return Z_MEM_ERROR; + } + state.havedict = 1; + return Z_OK; + } + exports2.inflateReset = inflateReset; + exports2.inflateReset2 = inflateReset2; + exports2.inflateResetKeep = inflateResetKeep; + exports2.inflateInit = inflateInit; + exports2.inflateInit2 = inflateInit2; + exports2.inflate = inflate2; + exports2.inflateEnd = inflateEnd; + exports2.inflateGetHeader = inflateGetHeader; + exports2.inflateSetDictionary = inflateSetDictionary; + exports2.inflateInfo = "pako inflate (from Nodeca project)"; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/constants.js +var require_constants = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/constants.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + module2.exports = { + /* Allowed flush values; see deflate() and inflate() below for details */ + Z_NO_FLUSH: 0, + Z_PARTIAL_FLUSH: 1, + Z_SYNC_FLUSH: 2, + Z_FULL_FLUSH: 3, + Z_FINISH: 4, + Z_BLOCK: 5, + Z_TREES: 6, + /* Return codes for the compression/decompression functions. Negative values + * are errors, positive values are used for special but normal events. + */ + Z_OK: 0, + Z_STREAM_END: 1, + Z_NEED_DICT: 2, + Z_ERRNO: -1, + Z_STREAM_ERROR: -2, + Z_DATA_ERROR: -3, + //Z_MEM_ERROR: -4, + Z_BUF_ERROR: -5, + //Z_VERSION_ERROR: -6, + /* compression levels */ + Z_NO_COMPRESSION: 0, + Z_BEST_SPEED: 1, + Z_BEST_COMPRESSION: 9, + Z_DEFAULT_COMPRESSION: -1, + Z_FILTERED: 1, + Z_HUFFMAN_ONLY: 2, + Z_RLE: 3, + Z_FIXED: 4, + Z_DEFAULT_STRATEGY: 0, + /* Possible values of the data_type field (though see inflate()) */ + Z_BINARY: 0, + Z_TEXT: 1, + //Z_ASCII: 1, // = Z_TEXT (deprecated) + Z_UNKNOWN: 2, + /* The deflate compression method */ + Z_DEFLATED: 8 + //Z_NULL: null // Use -1 or null inline, depending on var type + }; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/gzheader.js +var require_gzheader = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/zlib/gzheader.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + function GZheader() { + this.text = 0; + this.time = 0; + this.xflags = 0; + this.os = 0; + this.extra = null; + this.extra_len = 0; + this.name = ""; + this.comment = ""; + this.hcrc = 0; + this.done = false; + } + module2.exports = GZheader; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/inflate.js +var require_inflate2 = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/lib/inflate.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var zlib_inflate = require_inflate(); + var utils = require_common(); + var strings = require_strings(); + var c = require_constants(); + var msg = require_messages(); + var ZStream = require_zstream(); + var GZheader = require_gzheader(); + var toString = Object.prototype.toString; + function Inflate(options) { + if (!(this instanceof Inflate)) + return new Inflate(options); + this.options = utils.assign({ + chunkSize: 16384, + windowBits: 0, + to: "" + }, options || {}); + var opt = this.options; + if (opt.raw && opt.windowBits >= 0 && opt.windowBits < 16) { + opt.windowBits = -opt.windowBits; + if (opt.windowBits === 0) { + opt.windowBits = -15; + } + } + if (opt.windowBits >= 0 && opt.windowBits < 16 && !(options && options.windowBits)) { + opt.windowBits += 32; + } + if (opt.windowBits > 15 && opt.windowBits < 48) { + if ((opt.windowBits & 15) === 0) { + opt.windowBits |= 15; + } + } + this.err = 0; + this.msg = ""; + this.ended = false; + this.chunks = []; + this.strm = new ZStream(); + this.strm.avail_out = 0; + var status2 = zlib_inflate.inflateInit2( + this.strm, + opt.windowBits + ); + if (status2 !== c.Z_OK) { + throw new Error(msg[status2]); + } + this.header = new GZheader(); + zlib_inflate.inflateGetHeader(this.strm, this.header); + if (opt.dictionary) { + if (typeof opt.dictionary === "string") { + opt.dictionary = strings.string2buf(opt.dictionary); + } else if (toString.call(opt.dictionary) === "[object ArrayBuffer]") { + opt.dictionary = new Uint8Array(opt.dictionary); + } + if (opt.raw) { + status2 = zlib_inflate.inflateSetDictionary(this.strm, opt.dictionary); + if (status2 !== c.Z_OK) { + throw new Error(msg[status2]); + } + } + } + } + Inflate.prototype.push = function(data, mode) { + var strm = this.strm; + var chunkSize = this.options.chunkSize; + var dictionary = this.options.dictionary; + var status2, _mode; + var next_out_utf8, tail, utf8str; + var allowBufError = false; + if (this.ended) { + return false; + } + _mode = mode === ~~mode ? mode : mode === true ? c.Z_FINISH : c.Z_NO_FLUSH; + if (typeof data === "string") { + strm.input = strings.binstring2buf(data); + } else if (toString.call(data) === "[object ArrayBuffer]") { + strm.input = new Uint8Array(data); + } else { + strm.input = data; + } + strm.next_in = 0; + strm.avail_in = strm.input.length; + do { + if (strm.avail_out === 0) { + strm.output = new utils.Buf8(chunkSize); + strm.next_out = 0; + strm.avail_out = chunkSize; + } + status2 = zlib_inflate.inflate(strm, c.Z_NO_FLUSH); + if (status2 === c.Z_NEED_DICT && dictionary) { + status2 = zlib_inflate.inflateSetDictionary(this.strm, dictionary); + } + if (status2 === c.Z_BUF_ERROR && allowBufError === true) { + status2 = c.Z_OK; + allowBufError = false; + } + if (status2 !== c.Z_STREAM_END && status2 !== c.Z_OK) { + this.onEnd(status2); + this.ended = true; + return false; + } + if (strm.next_out) { + if (strm.avail_out === 0 || status2 === c.Z_STREAM_END || strm.avail_in === 0 && (_mode === c.Z_FINISH || _mode === c.Z_SYNC_FLUSH)) { + if (this.options.to === "string") { + next_out_utf8 = strings.utf8border(strm.output, strm.next_out); + tail = strm.next_out - next_out_utf8; + utf8str = strings.buf2string(strm.output, next_out_utf8); + strm.next_out = tail; + strm.avail_out = chunkSize - tail; + if (tail) { + utils.arraySet(strm.output, strm.output, next_out_utf8, tail, 0); + } + this.onData(utf8str); + } else { + this.onData(utils.shrinkBuf(strm.output, strm.next_out)); + } + } + } + if (strm.avail_in === 0 && strm.avail_out === 0) { + allowBufError = true; + } + } while ((strm.avail_in > 0 || strm.avail_out === 0) && status2 !== c.Z_STREAM_END); + if (status2 === c.Z_STREAM_END) { + _mode = c.Z_FINISH; + } + if (_mode === c.Z_FINISH) { + status2 = zlib_inflate.inflateEnd(this.strm); + this.onEnd(status2); + this.ended = true; + return status2 === c.Z_OK; + } + if (_mode === c.Z_SYNC_FLUSH) { + this.onEnd(c.Z_OK); + strm.avail_out = 0; + return true; + } + return true; + }; + Inflate.prototype.onData = function(chunk) { + this.chunks.push(chunk); + }; + Inflate.prototype.onEnd = function(status2) { + if (status2 === c.Z_OK) { + if (this.options.to === "string") { + this.result = this.chunks.join(""); + } else { + this.result = utils.flattenChunks(this.chunks); + } + } + this.chunks = []; + this.err = status2; + this.msg = this.strm.msg; + }; + function inflate2(input, options) { + var inflator = new Inflate(options); + inflator.push(input, true); + if (inflator.err) { + throw inflator.msg || msg[inflator.err]; + } + return inflator.result; + } + function inflateRaw(input, options) { + options = options || {}; + options.raw = true; + return inflate2(input, options); + } + exports2.Inflate = Inflate; + exports2.inflate = inflate2; + exports2.inflateRaw = inflateRaw; + exports2.ungzip = inflate2; + } +}); + +// node_modules/.pnpm/pako@1.0.11/node_modules/pako/index.js +var require_pako = __commonJS({ + "node_modules/.pnpm/pako@1.0.11/node_modules/pako/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var assign2 = require_common().assign; + var deflate2 = require_deflate2(); + var inflate2 = require_inflate2(); + var constants = require_constants(); + var pako2 = {}; + assign2(pako2, deflate2, inflate2, constants); + module2.exports = pako2; + } +}); + +// node_modules/.pnpm/pify@4.0.1/node_modules/pify/index.js +var require_pify = __commonJS({ + "node_modules/.pnpm/pify@4.0.1/node_modules/pify/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var processFn = (fn, options) => function(...args) { + const P = options.promiseModule; + return new P((resolve, reject) => { + if (options.multiArgs) { + args.push((...result) => { + if (options.errorFirst) { + if (result[0]) { + reject(result); + } else { + result.shift(); + resolve(result); + } + } else { + resolve(result); + } + }); + } else if (options.errorFirst) { + args.push((error, result) => { + if (error) { + reject(error); + } else { + resolve(result); + } + }); + } else { + args.push(resolve); + } + fn.apply(this, args); + }); + }; + module2.exports = (input, options) => { + options = Object.assign({ + exclude: [/.+(Sync|Stream)$/], + errorFirst: true, + promiseModule: Promise + }, options); + const objType = typeof input; + if (!(input !== null && (objType === "object" || objType === "function"))) { + throw new TypeError(`Expected \`input\` to be a \`Function\` or \`Object\`, got \`${input === null ? "null" : objType}\``); + } + const filter = (key2) => { + const match = (pattern) => typeof pattern === "string" ? key2 === pattern : pattern.test(key2); + return options.include ? options.include.some(match) : !options.exclude.some(match); + }; + let ret; + if (objType === "function") { + ret = function(...args) { + return options.excludeMain ? input(...args) : processFn(input, options).apply(this, args); + }; + } else { + ret = Object.create(Object.getPrototypeOf(input)); + } + for (const key2 in input) { + const property = input[key2]; + ret[key2] = typeof property === "function" && filter(key2) ? processFn(property, options) : property; + } + return ret; + }; + } +}); + +// node_modules/.pnpm/ignore@5.2.4/node_modules/ignore/index.js +var require_ignore = __commonJS({ + "node_modules/.pnpm/ignore@5.2.4/node_modules/ignore/index.js"(exports2, module2) { + init_polyfill_buffer(); + function makeArray(subject) { + return Array.isArray(subject) ? subject : [subject]; + } + var EMPTY = ""; + var SPACE = " "; + var ESCAPE = "\\"; + var REGEX_TEST_BLANK_LINE = /^\s+$/; + var REGEX_INVALID_TRAILING_BACKSLASH = /(?:[^\\]|^)\\$/; + var REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION = /^\\!/; + var REGEX_REPLACE_LEADING_EXCAPED_HASH = /^\\#/; + var REGEX_SPLITALL_CRLF = /\r?\n/g; + var REGEX_TEST_INVALID_PATH = /^\.*\/|^\.+$/; + var SLASH = "/"; + var TMP_KEY_IGNORE = "node-ignore"; + if (typeof Symbol !== "undefined") { + TMP_KEY_IGNORE = Symbol.for("node-ignore"); + } + var KEY_IGNORE = TMP_KEY_IGNORE; + var define2 = (object, key2, value) => Object.defineProperty(object, key2, { value }); + var REGEX_REGEXP_RANGE = /([0-z])-([0-z])/g; + var RETURN_FALSE = () => false; + var sanitizeRange = (range) => range.replace( + REGEX_REGEXP_RANGE, + (match, from, to) => from.charCodeAt(0) <= to.charCodeAt(0) ? match : EMPTY + ); + var cleanRangeBackSlash = (slashes) => { + const { length } = slashes; + return slashes.slice(0, length - length % 2); + }; + var REPLACERS = [ + // > Trailing spaces are ignored unless they are quoted with backslash ("\") + [ + // (a\ ) -> (a ) + // (a ) -> (a) + // (a \ ) -> (a ) + /\\?\s+$/, + (match) => match.indexOf("\\") === 0 ? SPACE : EMPTY + ], + // replace (\ ) with ' ' + [ + /\\\s/g, + () => SPACE + ], + // Escape metacharacters + // which is written down by users but means special for regular expressions. + // > There are 12 characters with special meanings: + // > - the backslash \, + // > - the caret ^, + // > - the dollar sign $, + // > - the period or dot ., + // > - the vertical bar or pipe symbol |, + // > - the question mark ?, + // > - the asterisk or star *, + // > - the plus sign +, + // > - the opening parenthesis (, + // > - the closing parenthesis ), + // > - and the opening square bracket [, + // > - the opening curly brace {, + // > These special characters are often called "metacharacters". + [ + /[\\$.|*+(){^]/g, + (match) => `\\${match}` + ], + [ + // > a question mark (?) matches a single character + /(?!\\)\?/g, + () => "[^/]" + ], + // leading slash + [ + // > A leading slash matches the beginning of the pathname. + // > For example, "/*.c" matches "cat-file.c" but not "mozilla-sha1/sha1.c". + // A leading slash matches the beginning of the pathname + /^\//, + () => "^" + ], + // replace special metacharacter slash after the leading slash + [ + /\//g, + () => "\\/" + ], + [ + // > A leading "**" followed by a slash means match in all directories. + // > For example, "**/foo" matches file or directory "foo" anywhere, + // > the same as pattern "foo". + // > "**/foo/bar" matches file or directory "bar" anywhere that is directly + // > under directory "foo". + // Notice that the '*'s have been replaced as '\\*' + /^\^*\\\*\\\*\\\//, + // '**/foo' <-> 'foo' + () => "^(?:.*\\/)?" + ], + // starting + [ + // there will be no leading '/' + // (which has been replaced by section "leading slash") + // If starts with '**', adding a '^' to the regular expression also works + /^(?=[^^])/, + function startingReplacer() { + return !/\/(?!$)/.test(this) ? "(?:^|\\/)" : "^"; + } + ], + // two globstars + [ + // Use lookahead assertions so that we could match more than one `'/**'` + /\\\/\\\*\\\*(?=\\\/|$)/g, + // Zero, one or several directories + // should not use '*', or it will be replaced by the next replacer + // Check if it is not the last `'/**'` + (_, index2, str) => index2 + 6 < str.length ? "(?:\\/[^\\/]+)*" : "\\/.+" + ], + // normal intermediate wildcards + [ + // Never replace escaped '*' + // ignore rule '\*' will match the path '*' + // 'abc.*/' -> go + // 'abc.*' -> skip this rule, + // coz trailing single wildcard will be handed by [trailing wildcard] + /(^|[^\\]+)(\\\*)+(?=.+)/g, + // '*.js' matches '.js' + // '*.js' doesn't match 'abc' + (_, p1, p2) => { + const unescaped = p2.replace(/\\\*/g, "[^\\/]*"); + return p1 + unescaped; + } + ], + [ + // unescape, revert step 3 except for back slash + // For example, if a user escape a '\\*', + // after step 3, the result will be '\\\\\\*' + /\\\\\\(?=[$.|*+(){^])/g, + () => ESCAPE + ], + [ + // '\\\\' -> '\\' + /\\\\/g, + () => ESCAPE + ], + [ + // > The range notation, e.g. [a-zA-Z], + // > can be used to match one of the characters in a range. + // `\` is escaped by step 3 + /(\\)?\[([^\]/]*?)(\\*)($|\])/g, + (match, leadEscape, range, endEscape, close) => leadEscape === ESCAPE ? `\\[${range}${cleanRangeBackSlash(endEscape)}${close}` : close === "]" ? endEscape.length % 2 === 0 ? `[${sanitizeRange(range)}${endEscape}]` : "[]" : "[]" + ], + // ending + [ + // 'js' will not match 'js.' + // 'ab' will not match 'abc' + /(?:[^*])$/, + // WTF! + // https://git-scm.com/docs/gitignore + // changes in [2.22.1](https://git-scm.com/docs/gitignore/2.22.1) + // which re-fixes #24, #38 + // > If there is a separator at the end of the pattern then the pattern + // > will only match directories, otherwise the pattern can match both + // > files and directories. + // 'js*' will not match 'a.js' + // 'js/' will not match 'a.js' + // 'js' will match 'a.js' and 'a.js/' + (match) => /\/$/.test(match) ? `${match}$` : `${match}(?=$|\\/$)` + ], + // trailing wildcard + [ + /(\^|\\\/)?\\\*$/, + (_, p1) => { + const prefix = p1 ? `${p1}[^/]+` : "[^/]*"; + return `${prefix}(?=$|\\/$)`; + } + ] + ]; + var regexCache = /* @__PURE__ */ Object.create(null); + var makeRegex = (pattern, ignoreCase) => { + let source = regexCache[pattern]; + if (!source) { + source = REPLACERS.reduce( + (prev, current) => prev.replace(current[0], current[1].bind(pattern)), + pattern + ); + regexCache[pattern] = source; + } + return ignoreCase ? new RegExp(source, "i") : new RegExp(source); + }; + var isString = (subject) => typeof subject === "string"; + var checkPattern = (pattern) => pattern && isString(pattern) && !REGEX_TEST_BLANK_LINE.test(pattern) && !REGEX_INVALID_TRAILING_BACKSLASH.test(pattern) && pattern.indexOf("#") !== 0; + var splitPattern = (pattern) => pattern.split(REGEX_SPLITALL_CRLF); + var IgnoreRule = class { + constructor(origin, pattern, negative, regex2) { + this.origin = origin; + this.pattern = pattern; + this.negative = negative; + this.regex = regex2; + } + }; + var createRule = (pattern, ignoreCase) => { + const origin = pattern; + let negative = false; + if (pattern.indexOf("!") === 0) { + negative = true; + pattern = pattern.substr(1); + } + pattern = pattern.replace(REGEX_REPLACE_LEADING_EXCAPED_EXCLAMATION, "!").replace(REGEX_REPLACE_LEADING_EXCAPED_HASH, "#"); + const regex2 = makeRegex(pattern, ignoreCase); + return new IgnoreRule( + origin, + pattern, + negative, + regex2 + ); + }; + var throwError = (message, Ctor) => { + throw new Ctor(message); + }; + var checkPath = (path2, originalPath, doThrow) => { + if (!isString(path2)) { + return doThrow( + `path must be a string, but got \`${originalPath}\``, + TypeError + ); + } + if (!path2) { + return doThrow(`path must not be empty`, TypeError); + } + if (checkPath.isNotRelative(path2)) { + const r = "`path.relative()`d"; + return doThrow( + `path should be a ${r} string, but got "${originalPath}"`, + RangeError + ); + } + return true; + }; + var isNotRelative = (path2) => REGEX_TEST_INVALID_PATH.test(path2); + checkPath.isNotRelative = isNotRelative; + checkPath.convert = (p) => p; + var Ignore = class { + constructor({ + ignorecase = true, + ignoreCase = ignorecase, + allowRelativePaths = false + } = {}) { + define2(this, KEY_IGNORE, true); + this._rules = []; + this._ignoreCase = ignoreCase; + this._allowRelativePaths = allowRelativePaths; + this._initCache(); + } + _initCache() { + this._ignoreCache = /* @__PURE__ */ Object.create(null); + this._testCache = /* @__PURE__ */ Object.create(null); + } + _addPattern(pattern) { + if (pattern && pattern[KEY_IGNORE]) { + this._rules = this._rules.concat(pattern._rules); + this._added = true; + return; + } + if (checkPattern(pattern)) { + const rule = createRule(pattern, this._ignoreCase); + this._added = true; + this._rules.push(rule); + } + } + // @param {Array | string | Ignore} pattern + add(pattern) { + this._added = false; + makeArray( + isString(pattern) ? splitPattern(pattern) : pattern + ).forEach(this._addPattern, this); + if (this._added) { + this._initCache(); + } + return this; + } + // legacy + addPattern(pattern) { + return this.add(pattern); + } + // | ignored : unignored + // negative | 0:0 | 0:1 | 1:0 | 1:1 + // -------- | ------- | ------- | ------- | -------- + // 0 | TEST | TEST | SKIP | X + // 1 | TESTIF | SKIP | TEST | X + // - SKIP: always skip + // - TEST: always test + // - TESTIF: only test if checkUnignored + // - X: that never happen + // @param {boolean} whether should check if the path is unignored, + // setting `checkUnignored` to `false` could reduce additional + // path matching. + // @returns {TestResult} true if a file is ignored + _testOne(path2, checkUnignored) { + let ignored = false; + let unignored = false; + this._rules.forEach((rule) => { + const { negative } = rule; + if (unignored === negative && ignored !== unignored || negative && !ignored && !unignored && !checkUnignored) { + return; + } + const matched = rule.regex.test(path2); + if (matched) { + ignored = !negative; + unignored = negative; + } + }); + return { + ignored, + unignored + }; + } + // @returns {TestResult} + _test(originalPath, cache, checkUnignored, slices) { + const path2 = originalPath && checkPath.convert(originalPath); + checkPath( + path2, + originalPath, + this._allowRelativePaths ? RETURN_FALSE : throwError + ); + return this._t(path2, cache, checkUnignored, slices); + } + _t(path2, cache, checkUnignored, slices) { + if (path2 in cache) { + return cache[path2]; + } + if (!slices) { + slices = path2.split(SLASH); + } + slices.pop(); + if (!slices.length) { + return cache[path2] = this._testOne(path2, checkUnignored); + } + const parent = this._t( + slices.join(SLASH) + SLASH, + cache, + checkUnignored, + slices + ); + return cache[path2] = parent.ignored ? parent : this._testOne(path2, checkUnignored); + } + ignores(path2) { + return this._test(path2, this._ignoreCache, false).ignored; + } + createFilter() { + return (path2) => !this.ignores(path2); + } + filter(paths) { + return makeArray(paths).filter(this.createFilter()); + } + // @returns {TestResult} + test(path2) { + return this._test(path2, this._testCache, true); + } + }; + var factory = (options) => new Ignore(options); + var isPathValid = (path2) => checkPath(path2 && checkPath.convert(path2), path2, RETURN_FALSE); + factory.isPathValid = isPathValid; + factory.default = factory; + module2.exports = factory; + if ( + // Detect `process` so that it can run in browsers. + typeof process !== "undefined" && (process.env && process.env.IGNORE_TEST_WIN32 || process.platform === "win32") + ) { + const makePosix = (str) => /^\\\\\?\\/.test(str) || /["<>|\u0000-\u001F]+/u.test(str) ? str : str.replace(/\\/g, "/"); + checkPath.convert = makePosix; + const REGIX_IS_WINDOWS_PATH_ABSOLUTE = /^[a-z]:\//i; + checkPath.isNotRelative = (path2) => REGIX_IS_WINDOWS_PATH_ABSOLUTE.test(path2) || isNotRelative(path2); + } + } +}); + +// node_modules/.pnpm/clean-git-ref@2.0.1/node_modules/clean-git-ref/lib/index.js +var require_lib2 = __commonJS({ + "node_modules/.pnpm/clean-git-ref@2.0.1/node_modules/clean-git-ref/lib/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + function escapeRegExp(string) { + return string.replace(/[.*+?^${}()|[\]\\]/g, "\\$&"); + } + function replaceAll(str, search, replacement) { + search = search instanceof RegExp ? search : new RegExp(escapeRegExp(search), "g"); + return str.replace(search, replacement); + } + var CleanGitRef = { + clean: function clean(value) { + if (typeof value !== "string") { + throw new Error("Expected a string, received: " + value); + } + value = replaceAll(value, "./", "/"); + value = replaceAll(value, "..", "."); + value = replaceAll(value, " ", "-"); + value = replaceAll(value, /^[~^:?*\\\-]/g, ""); + value = replaceAll(value, /[~^:?*\\]/g, "-"); + value = replaceAll(value, /[~^:?*\\\-]$/g, ""); + value = replaceAll(value, "@{", "-"); + value = replaceAll(value, /\.$/g, ""); + value = replaceAll(value, /\/$/g, ""); + value = replaceAll(value, /\.lock$/g, ""); + return value; + } + }; + module2.exports = CleanGitRef; + } +}); + +// node_modules/.pnpm/diff3@0.0.3/node_modules/diff3/onp.js +var require_onp = __commonJS({ + "node_modules/.pnpm/diff3@0.0.3/node_modules/diff3/onp.js"(exports2, module2) { + init_polyfill_buffer(); + module2.exports = function(a_, b_) { + var a = a_, b = b_, m = a.length, n = b.length, reverse = false, ed = null, offset = m + 1, path2 = [], pathposi = [], ses = [], lcs = "", SES_DELETE = -1, SES_COMMON = 0, SES_ADD = 1; + var tmp1, tmp2; + var init3 = function() { + if (m >= n) { + tmp1 = a; + tmp2 = m; + a = b; + b = tmp1; + m = n; + n = tmp2; + reverse = true; + offset = m + 1; + } + }; + var P = function(x, y, k) { + return { + "x": x, + "y": y, + "k": k + }; + }; + var seselem = function(elem, t) { + return { + "elem": elem, + "t": t + }; + }; + var snake = function(k, p, pp) { + var r, x, y; + if (p > pp) { + r = path2[k - 1 + offset]; + } else { + r = path2[k + 1 + offset]; + } + y = Math.max(p, pp); + x = y - k; + while (x < m && y < n && a[x] === b[y]) { + ++x; + ++y; + } + path2[k + offset] = pathposi.length; + pathposi[pathposi.length] = new P(x, y, r); + return y; + }; + var recordseq = function(epc) { + var x_idx, y_idx, px_idx, py_idx, i; + x_idx = y_idx = 1; + px_idx = py_idx = 0; + for (i = epc.length - 1; i >= 0; --i) { + while (px_idx < epc[i].x || py_idx < epc[i].y) { + if (epc[i].y - epc[i].x > py_idx - px_idx) { + if (reverse) { + ses[ses.length] = new seselem(b[py_idx], SES_DELETE); + } else { + ses[ses.length] = new seselem(b[py_idx], SES_ADD); + } + ++y_idx; + ++py_idx; + } else if (epc[i].y - epc[i].x < py_idx - px_idx) { + if (reverse) { + ses[ses.length] = new seselem(a[px_idx], SES_ADD); + } else { + ses[ses.length] = new seselem(a[px_idx], SES_DELETE); + } + ++x_idx; + ++px_idx; + } else { + ses[ses.length] = new seselem(a[px_idx], SES_COMMON); + lcs += a[px_idx]; + ++x_idx; + ++y_idx; + ++px_idx; + ++py_idx; + } + } + } + }; + init3(); + return { + SES_DELETE: -1, + SES_COMMON: 0, + SES_ADD: 1, + editdistance: function() { + return ed; + }, + getlcs: function() { + return lcs; + }, + getses: function() { + return ses; + }, + compose: function() { + var delta, size, fp, p, r, epc, i, k; + delta = n - m; + size = m + n + 3; + fp = {}; + for (i = 0; i < size; ++i) { + fp[i] = -1; + path2[i] = -1; + } + p = -1; + do { + ++p; + for (k = -p; k <= delta - 1; ++k) { + fp[k + offset] = snake(k, fp[k - 1 + offset] + 1, fp[k + 1 + offset]); + } + for (k = delta + p; k >= delta + 1; --k) { + fp[k + offset] = snake(k, fp[k - 1 + offset] + 1, fp[k + 1 + offset]); + } + fp[delta + offset] = snake(delta, fp[delta - 1 + offset] + 1, fp[delta + 1 + offset]); + } while (fp[delta + offset] !== n); + ed = delta + 2 * p; + r = path2[delta + offset]; + epc = []; + while (r !== -1) { + epc[epc.length] = new P(pathposi[r].x, pathposi[r].y, null); + r = pathposi[r].k; + } + recordseq(epc); + } + }; + }; + } +}); + +// node_modules/.pnpm/diff3@0.0.3/node_modules/diff3/diff3.js +var require_diff3 = __commonJS({ + "node_modules/.pnpm/diff3@0.0.3/node_modules/diff3/diff3.js"(exports2, module2) { + init_polyfill_buffer(); + var onp = require_onp(); + function longestCommonSubsequence(file1, file2) { + var diff2 = new onp(file1, file2); + diff2.compose(); + var ses = diff2.getses(); + var root2; + var prev; + var file1RevIdx = file1.length - 1, file2RevIdx = file2.length - 1; + for (var i = ses.length - 1; i >= 0; --i) { + if (ses[i].t === diff2.SES_COMMON) { + if (prev) { + prev.chain = { + file1index: file1RevIdx, + file2index: file2RevIdx, + chain: null + }; + prev = prev.chain; + } else { + root2 = { + file1index: file1RevIdx, + file2index: file2RevIdx, + chain: null + }; + prev = root2; + } + file1RevIdx--; + file2RevIdx--; + } else if (ses[i].t === diff2.SES_DELETE) { + file1RevIdx--; + } else if (ses[i].t === diff2.SES_ADD) { + file2RevIdx--; + } + } + var tail = { + file1index: -1, + file2index: -1, + chain: null + }; + if (!prev) { + return tail; + } + prev.chain = tail; + return root2; + } + function diffIndices(file1, file2) { + var result = []; + var tail1 = file1.length; + var tail2 = file2.length; + for (var candidate = longestCommonSubsequence(file1, file2); candidate !== null; candidate = candidate.chain) { + var mismatchLength1 = tail1 - candidate.file1index - 1; + var mismatchLength2 = tail2 - candidate.file2index - 1; + tail1 = candidate.file1index; + tail2 = candidate.file2index; + if (mismatchLength1 || mismatchLength2) { + result.push({ + file1: [tail1 + 1, mismatchLength1], + file2: [tail2 + 1, mismatchLength2] + }); + } + } + result.reverse(); + return result; + } + function diff3MergeIndices(a, o, b) { + var i; + var m1 = diffIndices(o, a); + var m2 = diffIndices(o, b); + var hunks = []; + function addHunk(h, side2) { + hunks.push([h.file1[0], side2, h.file1[1], h.file2[0], h.file2[1]]); + } + for (i = 0; i < m1.length; i++) { + addHunk(m1[i], 0); + } + for (i = 0; i < m2.length; i++) { + addHunk(m2[i], 2); + } + hunks.sort(function(x, y) { + return x[0] - y[0]; + }); + var result = []; + var commonOffset = 0; + function copyCommon(targetOffset) { + if (targetOffset > commonOffset) { + result.push([1, commonOffset, targetOffset - commonOffset]); + commonOffset = targetOffset; + } + } + for (var hunkIndex = 0; hunkIndex < hunks.length; hunkIndex++) { + var firstHunkIndex = hunkIndex; + var hunk = hunks[hunkIndex]; + var regionLhs = hunk[0]; + var regionRhs = regionLhs + hunk[2]; + while (hunkIndex < hunks.length - 1) { + var maybeOverlapping = hunks[hunkIndex + 1]; + var maybeLhs = maybeOverlapping[0]; + if (maybeLhs > regionRhs) + break; + regionRhs = Math.max(regionRhs, maybeLhs + maybeOverlapping[2]); + hunkIndex++; + } + copyCommon(regionLhs); + if (firstHunkIndex == hunkIndex) { + if (hunk[4] > 0) { + result.push([hunk[1], hunk[3], hunk[4]]); + } + } else { + var regions = { + 0: [a.length, -1, o.length, -1], + 2: [b.length, -1, o.length, -1] + }; + for (i = firstHunkIndex; i <= hunkIndex; i++) { + hunk = hunks[i]; + var side = hunk[1]; + var r = regions[side]; + var oLhs = hunk[0]; + var oRhs = oLhs + hunk[2]; + var abLhs = hunk[3]; + var abRhs = abLhs + hunk[4]; + r[0] = Math.min(abLhs, r[0]); + r[1] = Math.max(abRhs, r[1]); + r[2] = Math.min(oLhs, r[2]); + r[3] = Math.max(oRhs, r[3]); + } + var aLhs = regions[0][0] + (regionLhs - regions[0][2]); + var aRhs = regions[0][1] + (regionRhs - regions[0][3]); + var bLhs = regions[2][0] + (regionLhs - regions[2][2]); + var bRhs = regions[2][1] + (regionRhs - regions[2][3]); + result.push([ + -1, + aLhs, + aRhs - aLhs, + regionLhs, + regionRhs - regionLhs, + bLhs, + bRhs - bLhs + ]); + } + commonOffset = regionRhs; + } + copyCommon(o.length); + return result; + } + function diff3Merge2(a, o, b) { + var result = []; + var files = [a, o, b]; + var indices = diff3MergeIndices(a, o, b); + var okLines = []; + function flushOk() { + if (okLines.length) { + result.push({ + ok: okLines + }); + } + okLines = []; + } + function pushOk(xs) { + for (var j = 0; j < xs.length; j++) { + okLines.push(xs[j]); + } + } + function isTrueConflict(rec) { + if (rec[2] != rec[6]) + return true; + var aoff = rec[1]; + var boff = rec[5]; + for (var j = 0; j < rec[2]; j++) { + if (a[j + aoff] != b[j + boff]) + return true; + } + return false; + } + for (var i = 0; i < indices.length; i++) { + var x = indices[i]; + var side = x[0]; + if (side == -1) { + if (!isTrueConflict(x)) { + pushOk(files[0].slice(x[1], x[1] + x[2])); + } else { + flushOk(); + result.push({ + conflict: { + a: a.slice(x[1], x[1] + x[2]), + aIndex: x[1], + o: o.slice(x[3], x[3] + x[4]), + oIndex: x[3], + b: b.slice(x[5], x[5] + x[6]), + bIndex: x[5] + } + }); + } + } else { + pushOk(files[side].slice(x[1], x[1] + x[2])); + } + } + flushOk(); + return result; + } + module2.exports = diff3Merge2; + } +}); + +// node_modules/.pnpm/ms@2.1.2/node_modules/ms/index.js +var require_ms = __commonJS({ + "node_modules/.pnpm/ms@2.1.2/node_modules/ms/index.js"(exports2, module2) { + init_polyfill_buffer(); + var s = 1e3; + var m = s * 60; + var h = m * 60; + var d = h * 24; + var w = d * 7; + var y = d * 365.25; + module2.exports = function(val, options) { + options = options || {}; + var type = typeof val; + if (type === "string" && val.length > 0) { + return parse2(val); + } else if (type === "number" && isFinite(val)) { + return options.long ? fmtLong(val) : fmtShort(val); + } + throw new Error( + "val is not a non-empty string or a valid number. val=" + JSON.stringify(val) + ); + }; + function parse2(str) { + str = String(str); + if (str.length > 100) { + return; + } + var match = /^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec( + str + ); + if (!match) { + return; + } + var n = parseFloat(match[1]); + var type = (match[2] || "ms").toLowerCase(); + switch (type) { + case "years": + case "year": + case "yrs": + case "yr": + case "y": + return n * y; + case "weeks": + case "week": + case "w": + return n * w; + case "days": + case "day": + case "d": + return n * d; + case "hours": + case "hour": + case "hrs": + case "hr": + case "h": + return n * h; + case "minutes": + case "minute": + case "mins": + case "min": + case "m": + return n * m; + case "seconds": + case "second": + case "secs": + case "sec": + case "s": + return n * s; + case "milliseconds": + case "millisecond": + case "msecs": + case "msec": + case "ms": + return n; + default: + return void 0; + } + } + function fmtShort(ms) { + var msAbs = Math.abs(ms); + if (msAbs >= d) { + return Math.round(ms / d) + "d"; + } + if (msAbs >= h) { + return Math.round(ms / h) + "h"; + } + if (msAbs >= m) { + return Math.round(ms / m) + "m"; + } + if (msAbs >= s) { + return Math.round(ms / s) + "s"; + } + return ms + "ms"; + } + function fmtLong(ms) { + var msAbs = Math.abs(ms); + if (msAbs >= d) { + return plural(ms, msAbs, d, "day"); + } + if (msAbs >= h) { + return plural(ms, msAbs, h, "hour"); + } + if (msAbs >= m) { + return plural(ms, msAbs, m, "minute"); + } + if (msAbs >= s) { + return plural(ms, msAbs, s, "second"); + } + return ms + " ms"; + } + function plural(ms, msAbs, n, name) { + var isPlural = msAbs >= n * 1.5; + return Math.round(ms / n) + " " + name + (isPlural ? "s" : ""); + } + } +}); + +// node_modules/.pnpm/debug@4.3.4_supports-color@9.4.0/node_modules/debug/src/common.js +var require_common2 = __commonJS({ + "node_modules/.pnpm/debug@4.3.4_supports-color@9.4.0/node_modules/debug/src/common.js"(exports2, module2) { + init_polyfill_buffer(); + function setup(env) { + createDebug.debug = createDebug; + createDebug.default = createDebug; + createDebug.coerce = coerce; + createDebug.disable = disable; + createDebug.enable = enable; + createDebug.enabled = enabled; + createDebug.humanize = require_ms(); + createDebug.destroy = destroy; + Object.keys(env).forEach((key2) => { + createDebug[key2] = env[key2]; + }); + createDebug.names = []; + createDebug.skips = []; + createDebug.formatters = {}; + function selectColor(namespace) { + let hash2 = 0; + for (let i = 0; i < namespace.length; i++) { + hash2 = (hash2 << 5) - hash2 + namespace.charCodeAt(i); + hash2 |= 0; + } + return createDebug.colors[Math.abs(hash2) % createDebug.colors.length]; + } + createDebug.selectColor = selectColor; + function createDebug(namespace) { + let prevTime; + let enableOverride = null; + let namespacesCache; + let enabledCache; + function debug3(...args) { + if (!debug3.enabled) { + return; + } + const self2 = debug3; + const curr = Number(/* @__PURE__ */ new Date()); + const ms = curr - (prevTime || curr); + self2.diff = ms; + self2.prev = prevTime; + self2.curr = curr; + prevTime = curr; + args[0] = createDebug.coerce(args[0]); + if (typeof args[0] !== "string") { + args.unshift("%O"); + } + let index2 = 0; + args[0] = args[0].replace(/%([a-zA-Z%])/g, (match, format) => { + if (match === "%%") { + return "%"; + } + index2++; + const formatter = createDebug.formatters[format]; + if (typeof formatter === "function") { + const val = args[index2]; + match = formatter.call(self2, val); + args.splice(index2, 1); + index2--; + } + return match; + }); + createDebug.formatArgs.call(self2, args); + const logFn = self2.log || createDebug.log; + logFn.apply(self2, args); + } + debug3.namespace = namespace; + debug3.useColors = createDebug.useColors(); + debug3.color = createDebug.selectColor(namespace); + debug3.extend = extend; + debug3.destroy = createDebug.destroy; + Object.defineProperty(debug3, "enabled", { + enumerable: true, + configurable: false, + get: () => { + if (enableOverride !== null) { + return enableOverride; + } + if (namespacesCache !== createDebug.namespaces) { + namespacesCache = createDebug.namespaces; + enabledCache = createDebug.enabled(namespace); + } + return enabledCache; + }, + set: (v) => { + enableOverride = v; + } + }); + if (typeof createDebug.init === "function") { + createDebug.init(debug3); + } + return debug3; + } + function extend(namespace, delimiter) { + const newDebug = createDebug(this.namespace + (typeof delimiter === "undefined" ? ":" : delimiter) + namespace); + newDebug.log = this.log; + return newDebug; + } + function enable(namespaces) { + createDebug.save(namespaces); + createDebug.namespaces = namespaces; + createDebug.names = []; + createDebug.skips = []; + let i; + const split = (typeof namespaces === "string" ? namespaces : "").split(/[\s,]+/); + const len = split.length; + for (i = 0; i < len; i++) { + if (!split[i]) { + continue; + } + namespaces = split[i].replace(/\*/g, ".*?"); + if (namespaces[0] === "-") { + createDebug.skips.push(new RegExp("^" + namespaces.slice(1) + "$")); + } else { + createDebug.names.push(new RegExp("^" + namespaces + "$")); + } + } + } + function disable() { + const namespaces = [ + ...createDebug.names.map(toNamespace), + ...createDebug.skips.map(toNamespace).map((namespace) => "-" + namespace) + ].join(","); + createDebug.enable(""); + return namespaces; + } + function enabled(name) { + if (name[name.length - 1] === "*") { + return true; + } + let i; + let len; + for (i = 0, len = createDebug.skips.length; i < len; i++) { + if (createDebug.skips[i].test(name)) { + return false; + } + } + for (i = 0, len = createDebug.names.length; i < len; i++) { + if (createDebug.names[i].test(name)) { + return true; + } + } + return false; + } + function toNamespace(regexp) { + return regexp.toString().substring(2, regexp.toString().length - 2).replace(/\.\*\?$/, "*"); + } + function coerce(val) { + if (val instanceof Error) { + return val.stack || val.message; + } + return val; + } + function destroy() { + console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."); + } + createDebug.enable(createDebug.load()); + return createDebug; + } + module2.exports = setup; + } +}); + +// node_modules/.pnpm/debug@4.3.4_supports-color@9.4.0/node_modules/debug/src/browser.js +var require_browser = __commonJS({ + "node_modules/.pnpm/debug@4.3.4_supports-color@9.4.0/node_modules/debug/src/browser.js"(exports2, module2) { + init_polyfill_buffer(); + exports2.formatArgs = formatArgs; + exports2.save = save; + exports2.load = load; + exports2.useColors = useColors; + exports2.storage = localstorage(); + exports2.destroy = (() => { + let warned = false; + return () => { + if (!warned) { + warned = true; + console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."); + } + }; + })(); + exports2.colors = [ + "#0000CC", + "#0000FF", + "#0033CC", + "#0033FF", + "#0066CC", + "#0066FF", + "#0099CC", + "#0099FF", + "#00CC00", + "#00CC33", + "#00CC66", + "#00CC99", + "#00CCCC", + "#00CCFF", + "#3300CC", + "#3300FF", + "#3333CC", + "#3333FF", + "#3366CC", + "#3366FF", + "#3399CC", + "#3399FF", + "#33CC00", + "#33CC33", + "#33CC66", + "#33CC99", + "#33CCCC", + "#33CCFF", + "#6600CC", + "#6600FF", + "#6633CC", + "#6633FF", + "#66CC00", + "#66CC33", + "#9900CC", + "#9900FF", + "#9933CC", + "#9933FF", + "#99CC00", + "#99CC33", + "#CC0000", + "#CC0033", + "#CC0066", + "#CC0099", + "#CC00CC", + "#CC00FF", + "#CC3300", + "#CC3333", + "#CC3366", + "#CC3399", + "#CC33CC", + "#CC33FF", + "#CC6600", + "#CC6633", + "#CC9900", + "#CC9933", + "#CCCC00", + "#CCCC33", + "#FF0000", + "#FF0033", + "#FF0066", + "#FF0099", + "#FF00CC", + "#FF00FF", + "#FF3300", + "#FF3333", + "#FF3366", + "#FF3399", + "#FF33CC", + "#FF33FF", + "#FF6600", + "#FF6633", + "#FF9900", + "#FF9933", + "#FFCC00", + "#FFCC33" + ]; + function useColors() { + if (typeof window !== "undefined" && window.process && (window.process.type === "renderer" || window.process.__nwjs)) { + return true; + } + if (typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/)) { + return false; + } + return typeof document !== "undefined" && document.documentElement && document.documentElement.style && document.documentElement.style.WebkitAppearance || // Is firebug? http://stackoverflow.com/a/398120/376773 + typeof window !== "undefined" && window.console && (window.console.firebug || window.console.exception && window.console.table) || // Is firefox >= v31? + // https://developer.mozilla.org/en-US/docs/Tools/Web_Console#Styling_messages + typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/) && parseInt(RegExp.$1, 10) >= 31 || // Double check webkit in userAgent just in case we are in a worker + typeof navigator !== "undefined" && navigator.userAgent && navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/); + } + function formatArgs(args) { + args[0] = (this.useColors ? "%c" : "") + this.namespace + (this.useColors ? " %c" : " ") + args[0] + (this.useColors ? "%c " : " ") + "+" + module2.exports.humanize(this.diff); + if (!this.useColors) { + return; + } + const c = "color: " + this.color; + args.splice(1, 0, c, "color: inherit"); + let index2 = 0; + let lastC = 0; + args[0].replace(/%[a-zA-Z%]/g, (match) => { + if (match === "%%") { + return; + } + index2++; + if (match === "%c") { + lastC = index2; + } + }); + args.splice(lastC, 0, c); + } + exports2.log = console.debug || console.log || (() => { + }); + function save(namespaces) { + try { + if (namespaces) { + exports2.storage.setItem("debug", namespaces); + } else { + exports2.storage.removeItem("debug"); + } + } catch (error) { + } + } + function load() { + let r; + try { + r = exports2.storage.getItem("debug"); + } catch (error) { + } + if (!r && typeof process !== "undefined" && "env" in process) { + r = process.env.DEBUG; + } + return r; + } + function localstorage() { + try { + return localStorage; + } catch (error) { + } + } + module2.exports = require_common2()(exports2); + var { formatters } = module2.exports; + formatters.j = function(v) { + try { + return JSON.stringify(v); + } catch (error) { + return "[UnexpectedJSONParseError]: " + error.message; + } + }; + } +}); + +// node_modules/.pnpm/@kwsites+file-exists@1.1.1_supports-color@9.4.0/node_modules/@kwsites/file-exists/dist/src/index.js +var require_src = __commonJS({ + "node_modules/.pnpm/@kwsites+file-exists@1.1.1_supports-color@9.4.0/node_modules/@kwsites/file-exists/dist/src/index.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + var __importDefault = exports2 && exports2.__importDefault || function(mod) { + return mod && mod.__esModule ? mod : { "default": mod }; + }; + Object.defineProperty(exports2, "__esModule", { value: true }); + var fs_1 = require("fs"); + var debug_1 = __importDefault(require_browser()); + var log2 = debug_1.default("@kwsites/file-exists"); + function check(path2, isFile, isDirectory) { + log2(`checking %s`, path2); + try { + const stat = fs_1.statSync(path2); + if (stat.isFile() && isFile) { + log2(`[OK] path represents a file`); + return true; + } + if (stat.isDirectory() && isDirectory) { + log2(`[OK] path represents a directory`); + return true; + } + log2(`[FAIL] path represents something other than a file or directory`); + return false; + } catch (e) { + if (e.code === "ENOENT") { + log2(`[FAIL] path is not accessible: %o`, e); + return false; + } + log2(`[FATAL] %o`, e); + throw e; + } + } + function exists2(path2, type = exports2.READABLE) { + return check(path2, (type & exports2.FILE) > 0, (type & exports2.FOLDER) > 0); + } + exports2.exists = exists2; + exports2.FILE = 1; + exports2.FOLDER = 2; + exports2.READABLE = exports2.FILE + exports2.FOLDER; + } +}); + +// node_modules/.pnpm/@kwsites+file-exists@1.1.1_supports-color@9.4.0/node_modules/@kwsites/file-exists/dist/index.js +var require_dist = __commonJS({ + "node_modules/.pnpm/@kwsites+file-exists@1.1.1_supports-color@9.4.0/node_modules/@kwsites/file-exists/dist/index.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + function __export3(m) { + for (var p in m) + if (!exports2.hasOwnProperty(p)) + exports2[p] = m[p]; + } + Object.defineProperty(exports2, "__esModule", { value: true }); + __export3(require_src()); + } +}); + +// node_modules/.pnpm/@kwsites+promise-deferred@1.1.1/node_modules/@kwsites/promise-deferred/dist/index.js +var require_dist2 = __commonJS({ + "node_modules/.pnpm/@kwsites+promise-deferred@1.1.1/node_modules/@kwsites/promise-deferred/dist/index.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + Object.defineProperty(exports2, "__esModule", { value: true }); + exports2.createDeferred = exports2.deferred = void 0; + function deferred2() { + let done; + let fail; + let status2 = "pending"; + const promise2 = new Promise((_done, _fail) => { + done = _done; + fail = _fail; + }); + return { + promise: promise2, + done(result) { + if (status2 === "pending") { + status2 = "resolved"; + done(result); + } + }, + fail(error) { + if (status2 === "pending") { + status2 = "rejected"; + fail(error); + } + }, + get fulfilled() { + return status2 !== "pending"; + }, + get status() { + return status2; + } + }; + } + exports2.deferred = deferred2; + exports2.createDeferred = deferred2; + exports2.default = deferred2; + } +}); + +// node_modules/.pnpm/color-name@1.1.4/node_modules/color-name/index.js +var require_color_name = __commonJS({ + "node_modules/.pnpm/color-name@1.1.4/node_modules/color-name/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + module2.exports = { + "aliceblue": [240, 248, 255], + "antiquewhite": [250, 235, 215], + "aqua": [0, 255, 255], + "aquamarine": [127, 255, 212], + "azure": [240, 255, 255], + "beige": [245, 245, 220], + "bisque": [255, 228, 196], + "black": [0, 0, 0], + "blanchedalmond": [255, 235, 205], + "blue": [0, 0, 255], + "blueviolet": [138, 43, 226], + "brown": [165, 42, 42], + "burlywood": [222, 184, 135], + "cadetblue": [95, 158, 160], + "chartreuse": [127, 255, 0], + "chocolate": [210, 105, 30], + "coral": [255, 127, 80], + "cornflowerblue": [100, 149, 237], + "cornsilk": [255, 248, 220], + "crimson": [220, 20, 60], + "cyan": [0, 255, 255], + "darkblue": [0, 0, 139], + "darkcyan": [0, 139, 139], + "darkgoldenrod": [184, 134, 11], + "darkgray": [169, 169, 169], + "darkgreen": [0, 100, 0], + "darkgrey": [169, 169, 169], + "darkkhaki": [189, 183, 107], + "darkmagenta": [139, 0, 139], + "darkolivegreen": [85, 107, 47], + "darkorange": [255, 140, 0], + "darkorchid": [153, 50, 204], + "darkred": [139, 0, 0], + "darksalmon": [233, 150, 122], + "darkseagreen": [143, 188, 143], + "darkslateblue": [72, 61, 139], + "darkslategray": [47, 79, 79], + "darkslategrey": [47, 79, 79], + "darkturquoise": [0, 206, 209], + "darkviolet": [148, 0, 211], + "deeppink": [255, 20, 147], + "deepskyblue": [0, 191, 255], + "dimgray": [105, 105, 105], + "dimgrey": [105, 105, 105], + "dodgerblue": [30, 144, 255], + "firebrick": [178, 34, 34], + "floralwhite": [255, 250, 240], + "forestgreen": [34, 139, 34], + "fuchsia": [255, 0, 255], + "gainsboro": [220, 220, 220], + "ghostwhite": [248, 248, 255], + "gold": [255, 215, 0], + "goldenrod": [218, 165, 32], + "gray": [128, 128, 128], + "green": [0, 128, 0], + "greenyellow": [173, 255, 47], + "grey": [128, 128, 128], + "honeydew": [240, 255, 240], + "hotpink": [255, 105, 180], + "indianred": [205, 92, 92], + "indigo": [75, 0, 130], + "ivory": [255, 255, 240], + "khaki": [240, 230, 140], + "lavender": [230, 230, 250], + "lavenderblush": [255, 240, 245], + "lawngreen": [124, 252, 0], + "lemonchiffon": [255, 250, 205], + "lightblue": [173, 216, 230], + "lightcoral": [240, 128, 128], + "lightcyan": [224, 255, 255], + "lightgoldenrodyellow": [250, 250, 210], + "lightgray": [211, 211, 211], + "lightgreen": [144, 238, 144], + "lightgrey": [211, 211, 211], + "lightpink": [255, 182, 193], + "lightsalmon": [255, 160, 122], + "lightseagreen": [32, 178, 170], + "lightskyblue": [135, 206, 250], + "lightslategray": [119, 136, 153], + "lightslategrey": [119, 136, 153], + "lightsteelblue": [176, 196, 222], + "lightyellow": [255, 255, 224], + "lime": [0, 255, 0], + "limegreen": [50, 205, 50], + "linen": [250, 240, 230], + "magenta": [255, 0, 255], + "maroon": [128, 0, 0], + "mediumaquamarine": [102, 205, 170], + "mediumblue": [0, 0, 205], + "mediumorchid": [186, 85, 211], + "mediumpurple": [147, 112, 219], + "mediumseagreen": [60, 179, 113], + "mediumslateblue": [123, 104, 238], + "mediumspringgreen": [0, 250, 154], + "mediumturquoise": [72, 209, 204], + "mediumvioletred": [199, 21, 133], + "midnightblue": [25, 25, 112], + "mintcream": [245, 255, 250], + "mistyrose": [255, 228, 225], + "moccasin": [255, 228, 181], + "navajowhite": [255, 222, 173], + "navy": [0, 0, 128], + "oldlace": [253, 245, 230], + "olive": [128, 128, 0], + "olivedrab": [107, 142, 35], + "orange": [255, 165, 0], + "orangered": [255, 69, 0], + "orchid": [218, 112, 214], + "palegoldenrod": [238, 232, 170], + "palegreen": [152, 251, 152], + "paleturquoise": [175, 238, 238], + "palevioletred": [219, 112, 147], + "papayawhip": [255, 239, 213], + "peachpuff": [255, 218, 185], + "peru": [205, 133, 63], + "pink": [255, 192, 203], + "plum": [221, 160, 221], + "powderblue": [176, 224, 230], + "purple": [128, 0, 128], + "rebeccapurple": [102, 51, 153], + "red": [255, 0, 0], + "rosybrown": [188, 143, 143], + "royalblue": [65, 105, 225], + "saddlebrown": [139, 69, 19], + "salmon": [250, 128, 114], + "sandybrown": [244, 164, 96], + "seagreen": [46, 139, 87], + "seashell": [255, 245, 238], + "sienna": [160, 82, 45], + "silver": [192, 192, 192], + "skyblue": [135, 206, 235], + "slateblue": [106, 90, 205], + "slategray": [112, 128, 144], + "slategrey": [112, 128, 144], + "snow": [255, 250, 250], + "springgreen": [0, 255, 127], + "steelblue": [70, 130, 180], + "tan": [210, 180, 140], + "teal": [0, 128, 128], + "thistle": [216, 191, 216], + "tomato": [255, 99, 71], + "turquoise": [64, 224, 208], + "violet": [238, 130, 238], + "wheat": [245, 222, 179], + "white": [255, 255, 255], + "whitesmoke": [245, 245, 245], + "yellow": [255, 255, 0], + "yellowgreen": [154, 205, 50] + }; + } +}); + +// node_modules/.pnpm/css-unit-converter@1.1.2/node_modules/css-unit-converter/index.js +var require_css_unit_converter = __commonJS({ + "node_modules/.pnpm/css-unit-converter@1.1.2/node_modules/css-unit-converter/index.js"(exports2, module2) { + init_polyfill_buffer(); + var conversions = { + // length + "px": { + "px": 1, + "cm": 96 / 2.54, + "mm": 96 / 25.4, + "in": 96, + "pt": 96 / 72, + "pc": 16 + }, + "cm": { + "px": 2.54 / 96, + "cm": 1, + "mm": 0.1, + "in": 2.54, + "pt": 2.54 / 72, + "pc": 2.54 / 6 + }, + "mm": { + "px": 25.4 / 96, + "cm": 10, + "mm": 1, + "in": 25.4, + "pt": 25.4 / 72, + "pc": 25.4 / 6 + }, + "in": { + "px": 1 / 96, + "cm": 1 / 2.54, + "mm": 1 / 25.4, + "in": 1, + "pt": 1 / 72, + "pc": 1 / 6 + }, + "pt": { + "px": 0.75, + "cm": 72 / 2.54, + "mm": 72 / 25.4, + "in": 72, + "pt": 1, + "pc": 12 + }, + "pc": { + "px": 6 / 96, + "cm": 6 / 2.54, + "mm": 6 / 25.4, + "in": 6, + "pt": 6 / 72, + "pc": 1 + }, + // angle + "deg": { + "deg": 1, + "grad": 0.9, + "rad": 180 / Math.PI, + "turn": 360 + }, + "grad": { + "deg": 400 / 360, + "grad": 1, + "rad": 200 / Math.PI, + "turn": 400 + }, + "rad": { + "deg": Math.PI / 180, + "grad": Math.PI / 200, + "rad": 1, + "turn": Math.PI * 2 + }, + "turn": { + "deg": 1 / 360, + "grad": 1 / 400, + "rad": 0.5 / Math.PI, + "turn": 1 + }, + // time + "s": { + "s": 1, + "ms": 1 / 1e3 + }, + "ms": { + "s": 1e3, + "ms": 1 + }, + // frequency + "Hz": { + "Hz": 1, + "kHz": 1e3 + }, + "kHz": { + "Hz": 1 / 1e3, + "kHz": 1 + }, + // resolution + "dpi": { + "dpi": 1, + "dpcm": 1 / 2.54, + "dppx": 1 / 96 + }, + "dpcm": { + "dpi": 2.54, + "dpcm": 1, + "dppx": 2.54 / 96 + }, + "dppx": { + "dpi": 96, + "dpcm": 96 / 2.54, + "dppx": 1 + } + }; + module2.exports = function(value, sourceUnit, targetUnit, precision) { + if (!conversions.hasOwnProperty(targetUnit)) + throw new Error("Cannot convert to " + targetUnit); + if (!conversions[targetUnit].hasOwnProperty(sourceUnit)) + throw new Error("Cannot convert from " + sourceUnit + " to " + targetUnit); + var converted = conversions[targetUnit][sourceUnit] * value; + if (precision !== false) { + precision = Math.pow(10, parseInt(precision) || 5); + return Math.round(converted * precision) / precision; + } + return converted; + }; + } +}); + +// node_modules/.pnpm/css-color-converter@2.0.0/node_modules/css-color-converter/lib/index.js +var require_lib3 = __commonJS({ + "node_modules/.pnpm/css-color-converter@2.0.0/node_modules/css-color-converter/lib/index.js"(exports2) { + "use strict"; + init_polyfill_buffer(); + Object.defineProperty(exports2, "__esModule", { + value: true + }); + exports2.fromRgba = fromRgba; + exports2.fromRgb = fromRgb; + exports2.fromHsla = fromHsla; + exports2.fromHsl = fromHsl; + exports2.fromString = fromString2; + exports2["default"] = void 0; + var _colorName = _interopRequireDefault(require_color_name()); + var _cssUnitConverter = _interopRequireDefault(require_css_unit_converter()); + function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { "default": obj }; + } + function _classCallCheck(instance10, Constructor) { + if (!(instance10 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + function _defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + function _createClass(Constructor, protoProps, staticProps) { + if (protoProps) + _defineProperties(Constructor.prototype, protoProps); + if (staticProps) + _defineProperties(Constructor, staticProps); + return Constructor; + } + function _slicedToArray(arr, i) { + return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray2(arr, i) || _nonIterableRest(); + } + function _nonIterableRest() { + throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); + } + function _unsupportedIterableToArray2(o, minLen) { + if (!o) + return; + if (typeof o === "string") + return _arrayLikeToArray2(o, minLen); + var n = Object.prototype.toString.call(o).slice(8, -1); + if (n === "Object" && o.constructor) + n = o.constructor.name; + if (n === "Map" || n === "Set") + return Array.from(o); + if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) + return _arrayLikeToArray2(o, minLen); + } + function _arrayLikeToArray2(arr, len) { + if (len == null || len > arr.length) + len = arr.length; + for (var i = 0, arr2 = new Array(len); i < len; i++) { + arr2[i] = arr[i]; + } + return arr2; + } + function _iterableToArrayLimit(arr, i) { + if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) + return; + var _arr = []; + var _n = true; + var _d = false; + var _e = void 0; + try { + for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { + _arr.push(_s.value); + if (i && _arr.length === i) + break; + } + } catch (err) { + _d = true; + _e = err; + } finally { + try { + if (!_n && _i["return"] != null) + _i["return"](); + } finally { + if (_d) + throw _e; + } + } + return _arr; + } + function _arrayWithHoles(arr) { + if (Array.isArray(arr)) + return arr; + } + var hex = /^#([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})?$/; + var shortHex = /^#([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])([0-9a-fA-F])?$/; + var rgb = /^rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)(?:\s*,\s*(0|1|0?\.\d+|\d+%))?\s*\)$/; + var rgbfn = /^rgba?\(\s*(\d+)\s+(\d+)\s+(\d+)(?:\s*\/\s*(0|1|0?\.\d+|\d+%))?\s*\)$/; + var rgbperc = /^rgba?\(\s*(\d+%)\s*,\s*(\d+%)\s*,\s*(\d+%)(?:\s*,\s*(0|1|0?\.\d+|\d+%))?\s*\)$/; + var rgbpercfn = /^rgba?\(\s*(\d+%)\s+(\d+%)\s+(\d+%)(?:\s*\/\s*(0|1|0?\.\d+|\d+%))?\s*\)$/; + var hsl = /^hsla?\(\s*(\d+)(deg|rad|grad|turn)?\s*,\s*(\d+)%\s*,\s*(\d+)%(?:\s*,\s*(0|1|0?\.\d+|\d+%))?\s*\)$/; + function contains2(haystack, needle) { + return haystack.indexOf(needle) > -1; + } + function rgbToHsl(r, g, b) { + var rprim = r / 255; + var gprim = g / 255; + var bprim = b / 255; + var cmax = Math.max(rprim, gprim, bprim); + var cmin = Math.min(rprim, gprim, bprim); + var delta = cmax - cmin; + var l = (cmax + cmin) / 2; + if (delta === 0) { + return [0, 0, l * 100]; + } + var s = delta / (1 - Math.abs(2 * l - 1)); + var h = function() { + switch (cmax) { + case rprim: { + return (gprim - bprim) / delta % 6; + } + case gprim: { + return (bprim - rprim) / delta + 2; + } + default: { + return (rprim - gprim) / delta + 4; + } + } + }(); + return [h * 60, s * 100, l * 100]; + } + function hslToRgb(h, s, l) { + var hprim = h / 60; + var sprim = s / 100; + var lprim = l / 100; + var c = (1 - Math.abs(2 * lprim - 1)) * sprim; + var x = c * (1 - Math.abs(hprim % 2 - 1)); + var m = lprim - c / 2; + var _ref = function() { + if (hprim < 1) + return [c, x, 0]; + if (hprim < 2) + return [x, c, 0]; + if (hprim < 3) + return [0, c, x]; + if (hprim < 4) + return [0, x, c]; + if (hprim < 5) + return [x, 0, c]; + return [c, 0, x]; + }(), _ref2 = _slicedToArray(_ref, 3), rprim = _ref2[0], gprim = _ref2[1], bprim = _ref2[2]; + return [(rprim + m) * 255, (gprim + m) * 255, (bprim + m) * 255]; + } + var Color = /* @__PURE__ */ function() { + function Color2(_ref3) { + var _ref4 = _slicedToArray(_ref3, 4), r = _ref4[0], g = _ref4[1], b = _ref4[2], a = _ref4[3]; + _classCallCheck(this, Color2); + this.values = [Math.max(Math.min(parseInt(r, 10), 255), 0), Math.max(Math.min(parseInt(g, 10), 255), 0), Math.max(Math.min(parseInt(b, 10), 255), 0), a == null ? 1 : Math.max(Math.min(parseFloat(a), 255), 0)]; + } + _createClass(Color2, [{ + key: "toRgbString", + value: function toRgbString() { + var _this$values = _slicedToArray(this.values, 4), r = _this$values[0], g = _this$values[1], b = _this$values[2], a = _this$values[3]; + if (a === 1) { + return "rgb(".concat(r, ", ").concat(g, ", ").concat(b, ")"); + } + return "rgba(".concat(r, ", ").concat(g, ", ").concat(b, ", ").concat(a, ")"); + } + }, { + key: "toHslString", + value: function toHslString() { + var _this$toHslaArray = this.toHslaArray(), _this$toHslaArray2 = _slicedToArray(_this$toHslaArray, 4), h = _this$toHslaArray2[0], s = _this$toHslaArray2[1], l = _this$toHslaArray2[2], a = _this$toHslaArray2[3]; + if (a === 1) { + return "hsl(".concat(h, ", ").concat(s, "%, ").concat(l, "%)"); + } + return "hsla(".concat(h, ", ").concat(s, "%, ").concat(l, "%, ").concat(a, ")"); + } + }, { + key: "toHexString", + value: function toHexString() { + var _this$values2 = _slicedToArray(this.values, 4), r = _this$values2[0], g = _this$values2[1], b = _this$values2[2], a = _this$values2[3]; + r = Number(r).toString(16).padStart(2, "0"); + g = Number(g).toString(16).padStart(2, "0"); + b = Number(b).toString(16).padStart(2, "0"); + a = a < 1 ? parseInt(a * 255, 10).toString(16).padStart(2, "0") : ""; + return "#".concat(r).concat(g).concat(b).concat(a); + } + }, { + key: "toRgbaArray", + value: function toRgbaArray() { + return this.values; + } + }, { + key: "toHslaArray", + value: function toHslaArray() { + var _this$values3 = _slicedToArray(this.values, 4), r = _this$values3[0], g = _this$values3[1], b = _this$values3[2], a = _this$values3[3]; + var _rgbToHsl = rgbToHsl(r, g, b), _rgbToHsl2 = _slicedToArray(_rgbToHsl, 3), h = _rgbToHsl2[0], s = _rgbToHsl2[1], l = _rgbToHsl2[2]; + return [h, s, l, a]; + } + }]); + return Color2; + }(); + function fromRgba(_ref5) { + var _ref6 = _slicedToArray(_ref5, 4), r = _ref6[0], g = _ref6[1], b = _ref6[2], a = _ref6[3]; + return new Color([r, g, b, a]); + } + function fromRgb(_ref7) { + var _ref8 = _slicedToArray(_ref7, 3), r = _ref8[0], g = _ref8[1], b = _ref8[2]; + return fromRgba([r, g, b, 1]); + } + function fromHsla(_ref9) { + var _ref10 = _slicedToArray(_ref9, 4), h = _ref10[0], s = _ref10[1], l = _ref10[2], a = _ref10[3]; + var _hslToRgb = hslToRgb(h, s, l), _hslToRgb2 = _slicedToArray(_hslToRgb, 3), r = _hslToRgb2[0], g = _hslToRgb2[1], b = _hslToRgb2[2]; + return fromRgba([r, g, b, a]); + } + function fromHsl(_ref11) { + var _ref12 = _slicedToArray(_ref11, 3), h = _ref12[0], s = _ref12[1], l = _ref12[2]; + return fromHsla([h, s, l, 1]); + } + function fromHexString(str) { + var _ref13 = hex.exec(str) || shortHex.exec(str), _ref14 = _slicedToArray(_ref13, 5), r = _ref14[1], g = _ref14[2], b = _ref14[3], a = _ref14[4]; + r = parseInt(r.length < 2 ? r.repeat(2) : r, 16); + g = parseInt(g.length < 2 ? g.repeat(2) : g, 16); + b = parseInt(b.length < 2 ? b.repeat(2) : b, 16); + a = a && (parseInt(a.length < 2 ? a.repeat(2) : a, 16) / 255).toPrecision(1) || 1; + return fromRgba([r, g, b, a]); + } + function fromRgbString(str) { + var _ref15 = rgb.exec(str) || rgbperc.exec(str) || rgbfn.exec(str) || rgbpercfn.exec(str), _ref16 = _slicedToArray(_ref15, 5), r = _ref16[1], g = _ref16[2], b = _ref16[3], a = _ref16[4]; + r = contains2(r, "%") ? parseInt(r, 10) * 255 / 100 : parseInt(r, 10); + g = contains2(g, "%") ? parseInt(g, 10) * 255 / 100 : parseInt(g, 10); + b = contains2(b, "%") > 0 ? parseInt(b, 10) * 255 / 100 : parseInt(b, 10); + a = a === void 0 ? 1 : parseFloat(a) / (contains2(a, "%") ? 100 : 1); + return fromRgba([r, g, b, a]); + } + function fromHslString(str) { + var _hsl$exec = hsl.exec(str), _hsl$exec2 = _slicedToArray(_hsl$exec, 6), h = _hsl$exec2[1], unit = _hsl$exec2[2], s = _hsl$exec2[3], l = _hsl$exec2[4], a = _hsl$exec2[5]; + unit = unit || "deg"; + h = (0, _cssUnitConverter["default"])(parseFloat(h), unit, "deg"); + s = parseFloat(s); + l = parseFloat(l); + a = a === void 0 ? 1 : parseFloat(a) / (contains2(a, "%") ? 100 : 1); + return fromHsla([h, s, l, a]); + } + function fromString2(str) { + if (_colorName["default"][str]) { + return fromRgb(_colorName["default"][str]); + } + if (hex.test(str) || shortHex.test(str)) { + return fromHexString(str); + } + if (rgb.test(str) || rgbperc.test(str) || rgbfn.test(str) || rgbpercfn.test(str)) { + return fromRgbString(str); + } + if (hsl.test(str)) { + return fromHslString(str); + } + return null; + } + var _default = { + fromString: fromString2, + fromRgb, + fromRgba, + fromHsl, + fromHsla + }; + exports2["default"] = _default; + } +}); + +// node_modules/.pnpm/object-keys@1.1.1/node_modules/object-keys/isArguments.js +var require_isArguments = __commonJS({ + "node_modules/.pnpm/object-keys@1.1.1/node_modules/object-keys/isArguments.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var toStr = Object.prototype.toString; + module2.exports = function isArguments(value) { + var str = toStr.call(value); + var isArgs = str === "[object Arguments]"; + if (!isArgs) { + isArgs = str !== "[object Array]" && value !== null && typeof value === "object" && typeof value.length === "number" && value.length >= 0 && toStr.call(value.callee) === "[object Function]"; + } + return isArgs; + }; + } +}); + +// node_modules/.pnpm/object-keys@1.1.1/node_modules/object-keys/implementation.js +var require_implementation = __commonJS({ + "node_modules/.pnpm/object-keys@1.1.1/node_modules/object-keys/implementation.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var keysShim; + if (!Object.keys) { + has = Object.prototype.hasOwnProperty; + toStr = Object.prototype.toString; + isArgs = require_isArguments(); + isEnumerable = Object.prototype.propertyIsEnumerable; + hasDontEnumBug = !isEnumerable.call({ toString: null }, "toString"); + hasProtoEnumBug = isEnumerable.call(function() { + }, "prototype"); + dontEnums = [ + "toString", + "toLocaleString", + "valueOf", + "hasOwnProperty", + "isPrototypeOf", + "propertyIsEnumerable", + "constructor" + ]; + equalsConstructorPrototype = function(o) { + var ctor = o.constructor; + return ctor && ctor.prototype === o; + }; + excludedKeys = { + $applicationCache: true, + $console: true, + $external: true, + $frame: true, + $frameElement: true, + $frames: true, + $innerHeight: true, + $innerWidth: true, + $onmozfullscreenchange: true, + $onmozfullscreenerror: true, + $outerHeight: true, + $outerWidth: true, + $pageXOffset: true, + $pageYOffset: true, + $parent: true, + $scrollLeft: true, + $scrollTop: true, + $scrollX: true, + $scrollY: true, + $self: true, + $webkitIndexedDB: true, + $webkitStorageInfo: true, + $window: true + }; + hasAutomationEqualityBug = function() { + if (typeof window === "undefined") { + return false; + } + for (var k in window) { + try { + if (!excludedKeys["$" + k] && has.call(window, k) && window[k] !== null && typeof window[k] === "object") { + try { + equalsConstructorPrototype(window[k]); + } catch (e) { + return true; + } + } + } catch (e) { + return true; + } + } + return false; + }(); + equalsConstructorPrototypeIfNotBuggy = function(o) { + if (typeof window === "undefined" || !hasAutomationEqualityBug) { + return equalsConstructorPrototype(o); + } + try { + return equalsConstructorPrototype(o); + } catch (e) { + return false; + } + }; + keysShim = function keys(object) { + var isObject2 = object !== null && typeof object === "object"; + var isFunction2 = toStr.call(object) === "[object Function]"; + var isArguments = isArgs(object); + var isString = isObject2 && toStr.call(object) === "[object String]"; + var theKeys = []; + if (!isObject2 && !isFunction2 && !isArguments) { + throw new TypeError("Object.keys called on a non-object"); + } + var skipProto = hasProtoEnumBug && isFunction2; + if (isString && object.length > 0 && !has.call(object, 0)) { + for (var i = 0; i < object.length; ++i) { + theKeys.push(String(i)); + } + } + if (isArguments && object.length > 0) { + for (var j = 0; j < object.length; ++j) { + theKeys.push(String(j)); + } + } else { + for (var name in object) { + if (!(skipProto && name === "prototype") && has.call(object, name)) { + theKeys.push(String(name)); + } + } + } + if (hasDontEnumBug) { + var skipConstructor = equalsConstructorPrototypeIfNotBuggy(object); + for (var k = 0; k < dontEnums.length; ++k) { + if (!(skipConstructor && dontEnums[k] === "constructor") && has.call(object, dontEnums[k])) { + theKeys.push(dontEnums[k]); + } + } + } + return theKeys; + }; + } + var has; + var toStr; + var isArgs; + var isEnumerable; + var hasDontEnumBug; + var hasProtoEnumBug; + var dontEnums; + var equalsConstructorPrototype; + var excludedKeys; + var hasAutomationEqualityBug; + var equalsConstructorPrototypeIfNotBuggy; + module2.exports = keysShim; + } +}); + +// node_modules/.pnpm/object-keys@1.1.1/node_modules/object-keys/index.js +var require_object_keys = __commonJS({ + "node_modules/.pnpm/object-keys@1.1.1/node_modules/object-keys/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var slice = Array.prototype.slice; + var isArgs = require_isArguments(); + var origKeys = Object.keys; + var keysShim = origKeys ? function keys(o) { + return origKeys(o); + } : require_implementation(); + var originalKeys = Object.keys; + keysShim.shim = function shimObjectKeys() { + if (Object.keys) { + var keysWorksWithArguments = function() { + var args = Object.keys(arguments); + return args && args.length === arguments.length; + }(1, 2); + if (!keysWorksWithArguments) { + Object.keys = function keys(object) { + if (isArgs(object)) { + return originalKeys(slice.call(object)); + } + return originalKeys(object); + }; + } + } else { + Object.keys = keysShim; + } + return Object.keys || keysShim; + }; + module2.exports = keysShim; + } +}); + +// node_modules/.pnpm/has-symbols@1.0.3/node_modules/has-symbols/shams.js +var require_shams = __commonJS({ + "node_modules/.pnpm/has-symbols@1.0.3/node_modules/has-symbols/shams.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + module2.exports = function hasSymbols() { + if (typeof Symbol !== "function" || typeof Object.getOwnPropertySymbols !== "function") { + return false; + } + if (typeof Symbol.iterator === "symbol") { + return true; + } + var obj = {}; + var sym = Symbol("test"); + var symObj = Object(sym); + if (typeof sym === "string") { + return false; + } + if (Object.prototype.toString.call(sym) !== "[object Symbol]") { + return false; + } + if (Object.prototype.toString.call(symObj) !== "[object Symbol]") { + return false; + } + var symVal = 42; + obj[sym] = symVal; + for (sym in obj) { + return false; + } + if (typeof Object.keys === "function" && Object.keys(obj).length !== 0) { + return false; + } + if (typeof Object.getOwnPropertyNames === "function" && Object.getOwnPropertyNames(obj).length !== 0) { + return false; + } + var syms = Object.getOwnPropertySymbols(obj); + if (syms.length !== 1 || syms[0] !== sym) { + return false; + } + if (!Object.prototype.propertyIsEnumerable.call(obj, sym)) { + return false; + } + if (typeof Object.getOwnPropertyDescriptor === "function") { + var descriptor = Object.getOwnPropertyDescriptor(obj, sym); + if (descriptor.value !== symVal || descriptor.enumerable !== true) { + return false; + } + } + return true; + }; + } +}); + +// node_modules/.pnpm/has-symbols@1.0.3/node_modules/has-symbols/index.js +var require_has_symbols = __commonJS({ + "node_modules/.pnpm/has-symbols@1.0.3/node_modules/has-symbols/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var origSymbol = typeof Symbol !== "undefined" && Symbol; + var hasSymbolSham = require_shams(); + module2.exports = function hasNativeSymbols() { + if (typeof origSymbol !== "function") { + return false; + } + if (typeof Symbol !== "function") { + return false; + } + if (typeof origSymbol("foo") !== "symbol") { + return false; + } + if (typeof Symbol("bar") !== "symbol") { + return false; + } + return hasSymbolSham(); + }; + } +}); + +// node_modules/.pnpm/has-proto@1.0.1/node_modules/has-proto/index.js +var require_has_proto = __commonJS({ + "node_modules/.pnpm/has-proto@1.0.1/node_modules/has-proto/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var test = { + foo: {} + }; + var $Object = Object; + module2.exports = function hasProto() { + return { __proto__: test }.foo === test.foo && !({ __proto__: null } instanceof $Object); + }; + } +}); + +// node_modules/.pnpm/function-bind@1.1.1/node_modules/function-bind/implementation.js +var require_implementation2 = __commonJS({ + "node_modules/.pnpm/function-bind@1.1.1/node_modules/function-bind/implementation.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var ERROR_MESSAGE = "Function.prototype.bind called on incompatible "; + var slice = Array.prototype.slice; + var toStr = Object.prototype.toString; + var funcType = "[object Function]"; + module2.exports = function bind(that) { + var target = this; + if (typeof target !== "function" || toStr.call(target) !== funcType) { + throw new TypeError(ERROR_MESSAGE + target); + } + var args = slice.call(arguments, 1); + var bound; + var binder = function() { + if (this instanceof bound) { + var result = target.apply( + this, + args.concat(slice.call(arguments)) + ); + if (Object(result) === result) { + return result; + } + return this; + } else { + return target.apply( + that, + args.concat(slice.call(arguments)) + ); + } + }; + var boundLength = Math.max(0, target.length - args.length); + var boundArgs = []; + for (var i = 0; i < boundLength; i++) { + boundArgs.push("$" + i); + } + bound = Function("binder", "return function (" + boundArgs.join(",") + "){ return binder.apply(this,arguments); }")(binder); + if (target.prototype) { + var Empty = function Empty2() { + }; + Empty.prototype = target.prototype; + bound.prototype = new Empty(); + Empty.prototype = null; + } + return bound; + }; + } +}); + +// node_modules/.pnpm/function-bind@1.1.1/node_modules/function-bind/index.js +var require_function_bind = __commonJS({ + "node_modules/.pnpm/function-bind@1.1.1/node_modules/function-bind/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var implementation = require_implementation2(); + module2.exports = Function.prototype.bind || implementation; + } +}); + +// node_modules/.pnpm/has@1.0.3/node_modules/has/src/index.js +var require_src2 = __commonJS({ + "node_modules/.pnpm/has@1.0.3/node_modules/has/src/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var bind = require_function_bind(); + module2.exports = bind.call(Function.call, Object.prototype.hasOwnProperty); + } +}); + +// node_modules/.pnpm/get-intrinsic@1.2.1/node_modules/get-intrinsic/index.js +var require_get_intrinsic = __commonJS({ + "node_modules/.pnpm/get-intrinsic@1.2.1/node_modules/get-intrinsic/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var undefined2; + var $SyntaxError = SyntaxError; + var $Function = Function; + var $TypeError = TypeError; + var getEvalledConstructor = function(expressionSyntax) { + try { + return $Function('"use strict"; return (' + expressionSyntax + ").constructor;")(); + } catch (e) { + } + }; + var $gOPD = Object.getOwnPropertyDescriptor; + if ($gOPD) { + try { + $gOPD({}, ""); + } catch (e) { + $gOPD = null; + } + } + var throwTypeError = function() { + throw new $TypeError(); + }; + var ThrowTypeError = $gOPD ? function() { + try { + arguments.callee; + return throwTypeError; + } catch (calleeThrows) { + try { + return $gOPD(arguments, "callee").get; + } catch (gOPDthrows) { + return throwTypeError; + } + } + }() : throwTypeError; + var hasSymbols = require_has_symbols()(); + var hasProto = require_has_proto()(); + var getProto = Object.getPrototypeOf || (hasProto ? function(x) { + return x.__proto__; + } : null); + var needsEval = {}; + var TypedArray = typeof Uint8Array === "undefined" || !getProto ? undefined2 : getProto(Uint8Array); + var INTRINSICS = { + "%AggregateError%": typeof AggregateError === "undefined" ? undefined2 : AggregateError, + "%Array%": Array, + "%ArrayBuffer%": typeof ArrayBuffer === "undefined" ? undefined2 : ArrayBuffer, + "%ArrayIteratorPrototype%": hasSymbols && getProto ? getProto([][Symbol.iterator]()) : undefined2, + "%AsyncFromSyncIteratorPrototype%": undefined2, + "%AsyncFunction%": needsEval, + "%AsyncGenerator%": needsEval, + "%AsyncGeneratorFunction%": needsEval, + "%AsyncIteratorPrototype%": needsEval, + "%Atomics%": typeof Atomics === "undefined" ? undefined2 : Atomics, + "%BigInt%": typeof BigInt === "undefined" ? undefined2 : BigInt, + "%BigInt64Array%": typeof BigInt64Array === "undefined" ? undefined2 : BigInt64Array, + "%BigUint64Array%": typeof BigUint64Array === "undefined" ? undefined2 : BigUint64Array, + "%Boolean%": Boolean, + "%DataView%": typeof DataView === "undefined" ? undefined2 : DataView, + "%Date%": Date, + "%decodeURI%": decodeURI, + "%decodeURIComponent%": decodeURIComponent, + "%encodeURI%": encodeURI, + "%encodeURIComponent%": encodeURIComponent, + "%Error%": Error, + "%eval%": eval, + // eslint-disable-line no-eval + "%EvalError%": EvalError, + "%Float32Array%": typeof Float32Array === "undefined" ? undefined2 : Float32Array, + "%Float64Array%": typeof Float64Array === "undefined" ? undefined2 : Float64Array, + "%FinalizationRegistry%": typeof FinalizationRegistry === "undefined" ? undefined2 : FinalizationRegistry, + "%Function%": $Function, + "%GeneratorFunction%": needsEval, + "%Int8Array%": typeof Int8Array === "undefined" ? undefined2 : Int8Array, + "%Int16Array%": typeof Int16Array === "undefined" ? undefined2 : Int16Array, + "%Int32Array%": typeof Int32Array === "undefined" ? undefined2 : Int32Array, + "%isFinite%": isFinite, + "%isNaN%": isNaN, + "%IteratorPrototype%": hasSymbols && getProto ? getProto(getProto([][Symbol.iterator]())) : undefined2, + "%JSON%": typeof JSON === "object" ? JSON : undefined2, + "%Map%": typeof Map === "undefined" ? undefined2 : Map, + "%MapIteratorPrototype%": typeof Map === "undefined" || !hasSymbols || !getProto ? undefined2 : getProto((/* @__PURE__ */ new Map())[Symbol.iterator]()), + "%Math%": Math, + "%Number%": Number, + "%Object%": Object, + "%parseFloat%": parseFloat, + "%parseInt%": parseInt, + "%Promise%": typeof Promise === "undefined" ? undefined2 : Promise, + "%Proxy%": typeof Proxy === "undefined" ? undefined2 : Proxy, + "%RangeError%": RangeError, + "%ReferenceError%": ReferenceError, + "%Reflect%": typeof Reflect === "undefined" ? undefined2 : Reflect, + "%RegExp%": RegExp, + "%Set%": typeof Set === "undefined" ? undefined2 : Set, + "%SetIteratorPrototype%": typeof Set === "undefined" || !hasSymbols || !getProto ? undefined2 : getProto((/* @__PURE__ */ new Set())[Symbol.iterator]()), + "%SharedArrayBuffer%": typeof SharedArrayBuffer === "undefined" ? undefined2 : SharedArrayBuffer, + "%String%": String, + "%StringIteratorPrototype%": hasSymbols && getProto ? getProto(""[Symbol.iterator]()) : undefined2, + "%Symbol%": hasSymbols ? Symbol : undefined2, + "%SyntaxError%": $SyntaxError, + "%ThrowTypeError%": ThrowTypeError, + "%TypedArray%": TypedArray, + "%TypeError%": $TypeError, + "%Uint8Array%": typeof Uint8Array === "undefined" ? undefined2 : Uint8Array, + "%Uint8ClampedArray%": typeof Uint8ClampedArray === "undefined" ? undefined2 : Uint8ClampedArray, + "%Uint16Array%": typeof Uint16Array === "undefined" ? undefined2 : Uint16Array, + "%Uint32Array%": typeof Uint32Array === "undefined" ? undefined2 : Uint32Array, + "%URIError%": URIError, + "%WeakMap%": typeof WeakMap === "undefined" ? undefined2 : WeakMap, + "%WeakRef%": typeof WeakRef === "undefined" ? undefined2 : WeakRef, + "%WeakSet%": typeof WeakSet === "undefined" ? undefined2 : WeakSet + }; + if (getProto) { + try { + null.error; + } catch (e) { + errorProto = getProto(getProto(e)); + INTRINSICS["%Error.prototype%"] = errorProto; + } + } + var errorProto; + var doEval = function doEval2(name) { + var value; + if (name === "%AsyncFunction%") { + value = getEvalledConstructor("async function () {}"); + } else if (name === "%GeneratorFunction%") { + value = getEvalledConstructor("function* () {}"); + } else if (name === "%AsyncGeneratorFunction%") { + value = getEvalledConstructor("async function* () {}"); + } else if (name === "%AsyncGenerator%") { + var fn = doEval2("%AsyncGeneratorFunction%"); + if (fn) { + value = fn.prototype; + } + } else if (name === "%AsyncIteratorPrototype%") { + var gen = doEval2("%AsyncGenerator%"); + if (gen && getProto) { + value = getProto(gen.prototype); + } + } + INTRINSICS[name] = value; + return value; + }; + var LEGACY_ALIASES = { + "%ArrayBufferPrototype%": ["ArrayBuffer", "prototype"], + "%ArrayPrototype%": ["Array", "prototype"], + "%ArrayProto_entries%": ["Array", "prototype", "entries"], + "%ArrayProto_forEach%": ["Array", "prototype", "forEach"], + "%ArrayProto_keys%": ["Array", "prototype", "keys"], + "%ArrayProto_values%": ["Array", "prototype", "values"], + "%AsyncFunctionPrototype%": ["AsyncFunction", "prototype"], + "%AsyncGenerator%": ["AsyncGeneratorFunction", "prototype"], + "%AsyncGeneratorPrototype%": ["AsyncGeneratorFunction", "prototype", "prototype"], + "%BooleanPrototype%": ["Boolean", "prototype"], + "%DataViewPrototype%": ["DataView", "prototype"], + "%DatePrototype%": ["Date", "prototype"], + "%ErrorPrototype%": ["Error", "prototype"], + "%EvalErrorPrototype%": ["EvalError", "prototype"], + "%Float32ArrayPrototype%": ["Float32Array", "prototype"], + "%Float64ArrayPrototype%": ["Float64Array", "prototype"], + "%FunctionPrototype%": ["Function", "prototype"], + "%Generator%": ["GeneratorFunction", "prototype"], + "%GeneratorPrototype%": ["GeneratorFunction", "prototype", "prototype"], + "%Int8ArrayPrototype%": ["Int8Array", "prototype"], + "%Int16ArrayPrototype%": ["Int16Array", "prototype"], + "%Int32ArrayPrototype%": ["Int32Array", "prototype"], + "%JSONParse%": ["JSON", "parse"], + "%JSONStringify%": ["JSON", "stringify"], + "%MapPrototype%": ["Map", "prototype"], + "%NumberPrototype%": ["Number", "prototype"], + "%ObjectPrototype%": ["Object", "prototype"], + "%ObjProto_toString%": ["Object", "prototype", "toString"], + "%ObjProto_valueOf%": ["Object", "prototype", "valueOf"], + "%PromisePrototype%": ["Promise", "prototype"], + "%PromiseProto_then%": ["Promise", "prototype", "then"], + "%Promise_all%": ["Promise", "all"], + "%Promise_reject%": ["Promise", "reject"], + "%Promise_resolve%": ["Promise", "resolve"], + "%RangeErrorPrototype%": ["RangeError", "prototype"], + "%ReferenceErrorPrototype%": ["ReferenceError", "prototype"], + "%RegExpPrototype%": ["RegExp", "prototype"], + "%SetPrototype%": ["Set", "prototype"], + "%SharedArrayBufferPrototype%": ["SharedArrayBuffer", "prototype"], + "%StringPrototype%": ["String", "prototype"], + "%SymbolPrototype%": ["Symbol", "prototype"], + "%SyntaxErrorPrototype%": ["SyntaxError", "prototype"], + "%TypedArrayPrototype%": ["TypedArray", "prototype"], + "%TypeErrorPrototype%": ["TypeError", "prototype"], + "%Uint8ArrayPrototype%": ["Uint8Array", "prototype"], + "%Uint8ClampedArrayPrototype%": ["Uint8ClampedArray", "prototype"], + "%Uint16ArrayPrototype%": ["Uint16Array", "prototype"], + "%Uint32ArrayPrototype%": ["Uint32Array", "prototype"], + "%URIErrorPrototype%": ["URIError", "prototype"], + "%WeakMapPrototype%": ["WeakMap", "prototype"], + "%WeakSetPrototype%": ["WeakSet", "prototype"] + }; + var bind = require_function_bind(); + var hasOwn = require_src2(); + var $concat = bind.call(Function.call, Array.prototype.concat); + var $spliceApply = bind.call(Function.apply, Array.prototype.splice); + var $replace = bind.call(Function.call, String.prototype.replace); + var $strSlice = bind.call(Function.call, String.prototype.slice); + var $exec = bind.call(Function.call, RegExp.prototype.exec); + var rePropName = /[^%.[\]]+|\[(?:(-?\d+(?:\.\d+)?)|(["'])((?:(?!\2)[^\\]|\\.)*?)\2)\]|(?=(?:\.|\[\])(?:\.|\[\]|%$))/g; + var reEscapeChar = /\\(\\)?/g; + var stringToPath = function stringToPath2(string) { + var first2 = $strSlice(string, 0, 1); + var last2 = $strSlice(string, -1); + if (first2 === "%" && last2 !== "%") { + throw new $SyntaxError("invalid intrinsic syntax, expected closing `%`"); + } else if (last2 === "%" && first2 !== "%") { + throw new $SyntaxError("invalid intrinsic syntax, expected opening `%`"); + } + var result = []; + $replace(string, rePropName, function(match, number, quote, subString) { + result[result.length] = quote ? $replace(subString, reEscapeChar, "$1") : number || match; + }); + return result; + }; + var getBaseIntrinsic = function getBaseIntrinsic2(name, allowMissing) { + var intrinsicName = name; + var alias; + if (hasOwn(LEGACY_ALIASES, intrinsicName)) { + alias = LEGACY_ALIASES[intrinsicName]; + intrinsicName = "%" + alias[0] + "%"; + } + if (hasOwn(INTRINSICS, intrinsicName)) { + var value = INTRINSICS[intrinsicName]; + if (value === needsEval) { + value = doEval(intrinsicName); + } + if (typeof value === "undefined" && !allowMissing) { + throw new $TypeError("intrinsic " + name + " exists, but is not available. Please file an issue!"); + } + return { + alias, + name: intrinsicName, + value + }; + } + throw new $SyntaxError("intrinsic " + name + " does not exist!"); + }; + module2.exports = function GetIntrinsic(name, allowMissing) { + if (typeof name !== "string" || name.length === 0) { + throw new $TypeError("intrinsic name must be a non-empty string"); + } + if (arguments.length > 1 && typeof allowMissing !== "boolean") { + throw new $TypeError('"allowMissing" argument must be a boolean'); + } + if ($exec(/^%?[^%]*%?$/, name) === null) { + throw new $SyntaxError("`%` may not be present anywhere but at the beginning and end of the intrinsic name"); + } + var parts = stringToPath(name); + var intrinsicBaseName = parts.length > 0 ? parts[0] : ""; + var intrinsic = getBaseIntrinsic("%" + intrinsicBaseName + "%", allowMissing); + var intrinsicRealName = intrinsic.name; + var value = intrinsic.value; + var skipFurtherCaching = false; + var alias = intrinsic.alias; + if (alias) { + intrinsicBaseName = alias[0]; + $spliceApply(parts, $concat([0, 1], alias)); + } + for (var i = 1, isOwn = true; i < parts.length; i += 1) { + var part = parts[i]; + var first2 = $strSlice(part, 0, 1); + var last2 = $strSlice(part, -1); + if ((first2 === '"' || first2 === "'" || first2 === "`" || (last2 === '"' || last2 === "'" || last2 === "`")) && first2 !== last2) { + throw new $SyntaxError("property names with quotes must have matching quotes"); + } + if (part === "constructor" || !isOwn) { + skipFurtherCaching = true; + } + intrinsicBaseName += "." + part; + intrinsicRealName = "%" + intrinsicBaseName + "%"; + if (hasOwn(INTRINSICS, intrinsicRealName)) { + value = INTRINSICS[intrinsicRealName]; + } else if (value != null) { + if (!(part in value)) { + if (!allowMissing) { + throw new $TypeError("base intrinsic for " + name + " exists, but the property is not available."); + } + return void 0; + } + if ($gOPD && i + 1 >= parts.length) { + var desc = $gOPD(value, part); + isOwn = !!desc; + if (isOwn && "get" in desc && !("originalValue" in desc.get)) { + value = desc.get; + } else { + value = value[part]; + } + } else { + isOwn = hasOwn(value, part); + value = value[part]; + } + if (isOwn && !skipFurtherCaching) { + INTRINSICS[intrinsicRealName] = value; + } + } + } + return value; + }; + } +}); + +// node_modules/.pnpm/has-property-descriptors@1.0.0/node_modules/has-property-descriptors/index.js +var require_has_property_descriptors = __commonJS({ + "node_modules/.pnpm/has-property-descriptors@1.0.0/node_modules/has-property-descriptors/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var GetIntrinsic = require_get_intrinsic(); + var $defineProperty = GetIntrinsic("%Object.defineProperty%", true); + var hasPropertyDescriptors = function hasPropertyDescriptors2() { + if ($defineProperty) { + try { + $defineProperty({}, "a", { value: 1 }); + return true; + } catch (e) { + return false; + } + } + return false; + }; + hasPropertyDescriptors.hasArrayLengthDefineBug = function hasArrayLengthDefineBug() { + if (!hasPropertyDescriptors()) { + return null; + } + try { + return $defineProperty([], "length", { value: 1 }).length !== 1; + } catch (e) { + return true; + } + }; + module2.exports = hasPropertyDescriptors; + } +}); + +// node_modules/.pnpm/define-properties@1.2.0/node_modules/define-properties/index.js +var require_define_properties = __commonJS({ + "node_modules/.pnpm/define-properties@1.2.0/node_modules/define-properties/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var keys = require_object_keys(); + var hasSymbols = typeof Symbol === "function" && typeof Symbol("foo") === "symbol"; + var toStr = Object.prototype.toString; + var concat = Array.prototype.concat; + var origDefineProperty = Object.defineProperty; + var isFunction2 = function(fn) { + return typeof fn === "function" && toStr.call(fn) === "[object Function]"; + }; + var hasPropertyDescriptors = require_has_property_descriptors()(); + var supportsDescriptors = origDefineProperty && hasPropertyDescriptors; + var defineProperty = function(object, name, value, predicate) { + if (name in object) { + if (predicate === true) { + if (object[name] === value) { + return; + } + } else if (!isFunction2(predicate) || !predicate()) { + return; + } + } + if (supportsDescriptors) { + origDefineProperty(object, name, { + configurable: true, + enumerable: false, + value, + writable: true + }); + } else { + object[name] = value; + } + }; + var defineProperties = function(object, map) { + var predicates = arguments.length > 2 ? arguments[2] : {}; + var props = keys(map); + if (hasSymbols) { + props = concat.call(props, Object.getOwnPropertySymbols(map)); + } + for (var i = 0; i < props.length; i += 1) { + defineProperty(object, props[i], map[props[i]], predicates[props[i]]); + } + }; + defineProperties.supportsDescriptors = !!supportsDescriptors; + module2.exports = defineProperties; + } +}); + +// node_modules/.pnpm/call-bind@1.0.2/node_modules/call-bind/index.js +var require_call_bind = __commonJS({ + "node_modules/.pnpm/call-bind@1.0.2/node_modules/call-bind/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var bind = require_function_bind(); + var GetIntrinsic = require_get_intrinsic(); + var $apply = GetIntrinsic("%Function.prototype.apply%"); + var $call = GetIntrinsic("%Function.prototype.call%"); + var $reflectApply = GetIntrinsic("%Reflect.apply%", true) || bind.call($call, $apply); + var $gOPD = GetIntrinsic("%Object.getOwnPropertyDescriptor%", true); + var $defineProperty = GetIntrinsic("%Object.defineProperty%", true); + var $max = GetIntrinsic("%Math.max%"); + if ($defineProperty) { + try { + $defineProperty({}, "a", { value: 1 }); + } catch (e) { + $defineProperty = null; + } + } + module2.exports = function callBind(originalFunction) { + var func = $reflectApply(bind, $call, arguments); + if ($gOPD && $defineProperty) { + var desc = $gOPD(func, "length"); + if (desc.configurable) { + $defineProperty( + func, + "length", + { value: 1 + $max(0, originalFunction.length - (arguments.length - 1)) } + ); + } + } + return func; + }; + var applyBind = function applyBind2() { + return $reflectApply(bind, $apply, arguments); + }; + if ($defineProperty) { + $defineProperty(module2.exports, "apply", { value: applyBind }); + } else { + module2.exports.apply = applyBind; + } + } +}); + +// node_modules/.pnpm/call-bind@1.0.2/node_modules/call-bind/callBound.js +var require_callBound = __commonJS({ + "node_modules/.pnpm/call-bind@1.0.2/node_modules/call-bind/callBound.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var GetIntrinsic = require_get_intrinsic(); + var callBind = require_call_bind(); + var $indexOf = callBind(GetIntrinsic("String.prototype.indexOf")); + module2.exports = function callBoundIntrinsic(name, allowMissing) { + var intrinsic = GetIntrinsic(name, !!allowMissing); + if (typeof intrinsic === "function" && $indexOf(name, ".prototype.") > -1) { + return callBind(intrinsic); + } + return intrinsic; + }; + } +}); + +// node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/implementation.js +var require_implementation3 = __commonJS({ + "node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/implementation.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var objectKeys = require_object_keys(); + var hasSymbols = require_shams()(); + var callBound = require_callBound(); + var toObject = Object; + var $push = callBound("Array.prototype.push"); + var $propIsEnumerable = callBound("Object.prototype.propertyIsEnumerable"); + var originalGetSymbols = hasSymbols ? Object.getOwnPropertySymbols : null; + module2.exports = function assign2(target, source1) { + if (target == null) { + throw new TypeError("target must be an object"); + } + var to = toObject(target); + if (arguments.length === 1) { + return to; + } + for (var s = 1; s < arguments.length; ++s) { + var from = toObject(arguments[s]); + var keys = objectKeys(from); + var getSymbols = hasSymbols && (Object.getOwnPropertySymbols || originalGetSymbols); + if (getSymbols) { + var syms = getSymbols(from); + for (var j = 0; j < syms.length; ++j) { + var key2 = syms[j]; + if ($propIsEnumerable(from, key2)) { + $push(keys, key2); + } + } + } + for (var i = 0; i < keys.length; ++i) { + var nextKey = keys[i]; + if ($propIsEnumerable(from, nextKey)) { + var propValue = from[nextKey]; + to[nextKey] = propValue; + } + } + } + return to; + }; + } +}); + +// node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/polyfill.js +var require_polyfill = __commonJS({ + "node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/polyfill.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var implementation = require_implementation3(); + var lacksProperEnumerationOrder = function() { + if (!Object.assign) { + return false; + } + var str = "abcdefghijklmnopqrst"; + var letters = str.split(""); + var map = {}; + for (var i = 0; i < letters.length; ++i) { + map[letters[i]] = letters[i]; + } + var obj = Object.assign({}, map); + var actual = ""; + for (var k in obj) { + actual += k; + } + return str !== actual; + }; + var assignHasPendingExceptions = function() { + if (!Object.assign || !Object.preventExtensions) { + return false; + } + var thrower = Object.preventExtensions({ 1: 2 }); + try { + Object.assign(thrower, "xy"); + } catch (e) { + return thrower[1] === "y"; + } + return false; + }; + module2.exports = function getPolyfill() { + if (!Object.assign) { + return implementation; + } + if (lacksProperEnumerationOrder()) { + return implementation; + } + if (assignHasPendingExceptions()) { + return implementation; + } + return Object.assign; + }; + } +}); + +// node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/shim.js +var require_shim = __commonJS({ + "node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/shim.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var define2 = require_define_properties(); + var getPolyfill = require_polyfill(); + module2.exports = function shimAssign() { + var polyfill = getPolyfill(); + define2( + Object, + { assign: polyfill }, + { assign: function() { + return Object.assign !== polyfill; + } } + ); + return polyfill; + }; + } +}); + +// node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/index.js +var require_object = __commonJS({ + "node_modules/.pnpm/object.assign@4.1.4/node_modules/object.assign/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var defineProperties = require_define_properties(); + var callBind = require_call_bind(); + var implementation = require_implementation3(); + var getPolyfill = require_polyfill(); + var shim = require_shim(); + var polyfill = callBind.apply(getPolyfill()); + var bound = function assign2(target, source1) { + return polyfill(Object, arguments); + }; + defineProperties(bound, { + getPolyfill, + implementation, + shim + }); + module2.exports = bound; + } +}); + +// node_modules/.pnpm/functions-have-names@1.2.3/node_modules/functions-have-names/index.js +var require_functions_have_names = __commonJS({ + "node_modules/.pnpm/functions-have-names@1.2.3/node_modules/functions-have-names/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var functionsHaveNames = function functionsHaveNames2() { + return typeof function f() { + }.name === "string"; + }; + var gOPD = Object.getOwnPropertyDescriptor; + if (gOPD) { + try { + gOPD([], "length"); + } catch (e) { + gOPD = null; + } + } + functionsHaveNames.functionsHaveConfigurableNames = function functionsHaveConfigurableNames() { + if (!functionsHaveNames() || !gOPD) { + return false; + } + var desc = gOPD(function() { + }, "name"); + return !!desc && !!desc.configurable; + }; + var $bind = Function.prototype.bind; + functionsHaveNames.boundFunctionsHaveNames = function boundFunctionsHaveNames() { + return functionsHaveNames() && typeof $bind === "function" && function f() { + }.bind().name !== ""; + }; + module2.exports = functionsHaveNames; + } +}); + +// node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/implementation.js +var require_implementation4 = __commonJS({ + "node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/implementation.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var functionsHaveConfigurableNames = require_functions_have_names().functionsHaveConfigurableNames(); + var $Object = Object; + var $TypeError = TypeError; + module2.exports = function flags() { + if (this != null && this !== $Object(this)) { + throw new $TypeError("RegExp.prototype.flags getter called on non-object"); + } + var result = ""; + if (this.hasIndices) { + result += "d"; + } + if (this.global) { + result += "g"; + } + if (this.ignoreCase) { + result += "i"; + } + if (this.multiline) { + result += "m"; + } + if (this.dotAll) { + result += "s"; + } + if (this.unicode) { + result += "u"; + } + if (this.unicodeSets) { + result += "v"; + } + if (this.sticky) { + result += "y"; + } + return result; + }; + if (functionsHaveConfigurableNames && Object.defineProperty) { + Object.defineProperty(module2.exports, "name", { value: "get flags" }); + } + } +}); + +// node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/polyfill.js +var require_polyfill2 = __commonJS({ + "node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/polyfill.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var implementation = require_implementation4(); + var supportsDescriptors = require_define_properties().supportsDescriptors; + var $gOPD = Object.getOwnPropertyDescriptor; + module2.exports = function getPolyfill() { + if (supportsDescriptors && /a/mig.flags === "gim") { + var descriptor = $gOPD(RegExp.prototype, "flags"); + if (descriptor && typeof descriptor.get === "function" && typeof RegExp.prototype.dotAll === "boolean" && typeof RegExp.prototype.hasIndices === "boolean") { + var calls = ""; + var o = {}; + Object.defineProperty(o, "hasIndices", { + get: function() { + calls += "d"; + } + }); + Object.defineProperty(o, "sticky", { + get: function() { + calls += "y"; + } + }); + if (calls === "dy") { + return descriptor.get; + } + } + } + return implementation; + }; + } +}); + +// node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/shim.js +var require_shim2 = __commonJS({ + "node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/shim.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var supportsDescriptors = require_define_properties().supportsDescriptors; + var getPolyfill = require_polyfill2(); + var gOPD = Object.getOwnPropertyDescriptor; + var defineProperty = Object.defineProperty; + var TypeErr = TypeError; + var getProto = Object.getPrototypeOf; + var regex2 = /a/; + module2.exports = function shimFlags() { + if (!supportsDescriptors || !getProto) { + throw new TypeErr("RegExp.prototype.flags requires a true ES5 environment that supports property descriptors"); + } + var polyfill = getPolyfill(); + var proto = getProto(regex2); + var descriptor = gOPD(proto, "flags"); + if (!descriptor || descriptor.get !== polyfill) { + defineProperty(proto, "flags", { + configurable: true, + enumerable: false, + get: polyfill + }); + } + return polyfill; + }; + } +}); + +// node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/index.js +var require_regexp_prototype = __commonJS({ + "node_modules/.pnpm/regexp.prototype.flags@1.5.0/node_modules/regexp.prototype.flags/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var define2 = require_define_properties(); + var callBind = require_call_bind(); + var implementation = require_implementation4(); + var getPolyfill = require_polyfill2(); + var shim = require_shim2(); + var flagsBound = callBind(getPolyfill()); + define2(flagsBound, { + getPolyfill, + implementation, + shim + }); + module2.exports = flagsBound; + } +}); + +// node_modules/.pnpm/has-tostringtag@1.0.0/node_modules/has-tostringtag/shams.js +var require_shams2 = __commonJS({ + "node_modules/.pnpm/has-tostringtag@1.0.0/node_modules/has-tostringtag/shams.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var hasSymbols = require_shams(); + module2.exports = function hasToStringTagShams() { + return hasSymbols() && !!Symbol.toStringTag; + }; + } +}); + +// node_modules/.pnpm/is-arguments@1.1.1/node_modules/is-arguments/index.js +var require_is_arguments = __commonJS({ + "node_modules/.pnpm/is-arguments@1.1.1/node_modules/is-arguments/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var hasToStringTag = require_shams2()(); + var callBound = require_callBound(); + var $toString = callBound("Object.prototype.toString"); + var isStandardArguments = function isArguments(value) { + if (hasToStringTag && value && typeof value === "object" && Symbol.toStringTag in value) { + return false; + } + return $toString(value) === "[object Arguments]"; + }; + var isLegacyArguments = function isArguments(value) { + if (isStandardArguments(value)) { + return true; + } + return value !== null && typeof value === "object" && typeof value.length === "number" && value.length >= 0 && $toString(value) !== "[object Array]" && $toString(value.callee) === "[object Function]"; + }; + var supportsStandardArguments = function() { + return isStandardArguments(arguments); + }(); + isStandardArguments.isLegacyArguments = isLegacyArguments; + module2.exports = supportsStandardArguments ? isStandardArguments : isLegacyArguments; + } +}); + +// (disabled):node_modules/.pnpm/object-inspect@1.12.3/node_modules/object-inspect/util.inspect +var require_util = __commonJS({ + "(disabled):node_modules/.pnpm/object-inspect@1.12.3/node_modules/object-inspect/util.inspect"() { + init_polyfill_buffer(); + } +}); + +// node_modules/.pnpm/object-inspect@1.12.3/node_modules/object-inspect/index.js +var require_object_inspect = __commonJS({ + "node_modules/.pnpm/object-inspect@1.12.3/node_modules/object-inspect/index.js"(exports2, module2) { + init_polyfill_buffer(); + var hasMap = typeof Map === "function" && Map.prototype; + var mapSizeDescriptor = Object.getOwnPropertyDescriptor && hasMap ? Object.getOwnPropertyDescriptor(Map.prototype, "size") : null; + var mapSize = hasMap && mapSizeDescriptor && typeof mapSizeDescriptor.get === "function" ? mapSizeDescriptor.get : null; + var mapForEach = hasMap && Map.prototype.forEach; + var hasSet = typeof Set === "function" && Set.prototype; + var setSizeDescriptor = Object.getOwnPropertyDescriptor && hasSet ? Object.getOwnPropertyDescriptor(Set.prototype, "size") : null; + var setSize = hasSet && setSizeDescriptor && typeof setSizeDescriptor.get === "function" ? setSizeDescriptor.get : null; + var setForEach = hasSet && Set.prototype.forEach; + var hasWeakMap = typeof WeakMap === "function" && WeakMap.prototype; + var weakMapHas = hasWeakMap ? WeakMap.prototype.has : null; + var hasWeakSet = typeof WeakSet === "function" && WeakSet.prototype; + var weakSetHas = hasWeakSet ? WeakSet.prototype.has : null; + var hasWeakRef = typeof WeakRef === "function" && WeakRef.prototype; + var weakRefDeref = hasWeakRef ? WeakRef.prototype.deref : null; + var booleanValueOf = Boolean.prototype.valueOf; + var objectToString2 = Object.prototype.toString; + var functionToString = Function.prototype.toString; + var $match = String.prototype.match; + var $slice = String.prototype.slice; + var $replace = String.prototype.replace; + var $toUpperCase = String.prototype.toUpperCase; + var $toLowerCase = String.prototype.toLowerCase; + var $test = RegExp.prototype.test; + var $concat = Array.prototype.concat; + var $join = Array.prototype.join; + var $arrSlice = Array.prototype.slice; + var $floor = Math.floor; + var bigIntValueOf = typeof BigInt === "function" ? BigInt.prototype.valueOf : null; + var gOPS = Object.getOwnPropertySymbols; + var symToString = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? Symbol.prototype.toString : null; + var hasShammedSymbols = typeof Symbol === "function" && typeof Symbol.iterator === "object"; + var toStringTag = typeof Symbol === "function" && Symbol.toStringTag && (typeof Symbol.toStringTag === hasShammedSymbols ? "object" : "symbol") ? Symbol.toStringTag : null; + var isEnumerable = Object.prototype.propertyIsEnumerable; + var gPO = (typeof Reflect === "function" ? Reflect.getPrototypeOf : Object.getPrototypeOf) || ([].__proto__ === Array.prototype ? function(O) { + return O.__proto__; + } : null); + function addNumericSeparator(num2, str) { + if (num2 === Infinity || num2 === -Infinity || num2 !== num2 || num2 && num2 > -1e3 && num2 < 1e3 || $test.call(/e/, str)) { + return str; + } + var sepRegex = /[0-9](?=(?:[0-9]{3})+(?![0-9]))/g; + if (typeof num2 === "number") { + var int = num2 < 0 ? -$floor(-num2) : $floor(num2); + if (int !== num2) { + var intStr = String(int); + var dec = $slice.call(str, intStr.length + 1); + return $replace.call(intStr, sepRegex, "$&_") + "." + $replace.call($replace.call(dec, /([0-9]{3})/g, "$&_"), /_$/, ""); + } + } + return $replace.call(str, sepRegex, "$&_"); + } + var utilInspect = require_util(); + var inspectCustom = utilInspect.custom; + var inspectSymbol = isSymbol(inspectCustom) ? inspectCustom : null; + module2.exports = function inspect_(obj, options, depth, seen) { + var opts = options || {}; + if (has(opts, "quoteStyle") && (opts.quoteStyle !== "single" && opts.quoteStyle !== "double")) { + throw new TypeError('option "quoteStyle" must be "single" or "double"'); + } + if (has(opts, "maxStringLength") && (typeof opts.maxStringLength === "number" ? opts.maxStringLength < 0 && opts.maxStringLength !== Infinity : opts.maxStringLength !== null)) { + throw new TypeError('option "maxStringLength", if provided, must be a positive integer, Infinity, or `null`'); + } + var customInspect = has(opts, "customInspect") ? opts.customInspect : true; + if (typeof customInspect !== "boolean" && customInspect !== "symbol") { + throw new TypeError("option \"customInspect\", if provided, must be `true`, `false`, or `'symbol'`"); + } + if (has(opts, "indent") && opts.indent !== null && opts.indent !== " " && !(parseInt(opts.indent, 10) === opts.indent && opts.indent > 0)) { + throw new TypeError('option "indent" must be "\\t", an integer > 0, or `null`'); + } + if (has(opts, "numericSeparator") && typeof opts.numericSeparator !== "boolean") { + throw new TypeError('option "numericSeparator", if provided, must be `true` or `false`'); + } + var numericSeparator = opts.numericSeparator; + if (typeof obj === "undefined") { + return "undefined"; + } + if (obj === null) { + return "null"; + } + if (typeof obj === "boolean") { + return obj ? "true" : "false"; + } + if (typeof obj === "string") { + return inspectString(obj, opts); + } + if (typeof obj === "number") { + if (obj === 0) { + return Infinity / obj > 0 ? "0" : "-0"; + } + var str = String(obj); + return numericSeparator ? addNumericSeparator(obj, str) : str; + } + if (typeof obj === "bigint") { + var bigIntStr = String(obj) + "n"; + return numericSeparator ? addNumericSeparator(obj, bigIntStr) : bigIntStr; + } + var maxDepth = typeof opts.depth === "undefined" ? 5 : opts.depth; + if (typeof depth === "undefined") { + depth = 0; + } + if (depth >= maxDepth && maxDepth > 0 && typeof obj === "object") { + return isArray(obj) ? "[Array]" : "[Object]"; + } + var indent2 = getIndent(opts, depth); + if (typeof seen === "undefined") { + seen = []; + } else if (indexOf(seen, obj) >= 0) { + return "[Circular]"; + } + function inspect(value, from, noIndent) { + if (from) { + seen = $arrSlice.call(seen); + seen.push(from); + } + if (noIndent) { + var newOpts = { + depth: opts.depth + }; + if (has(opts, "quoteStyle")) { + newOpts.quoteStyle = opts.quoteStyle; + } + return inspect_(value, newOpts, depth + 1, seen); + } + return inspect_(value, opts, depth + 1, seen); + } + if (typeof obj === "function" && !isRegExp(obj)) { + var name = nameOf(obj); + var keys = arrObjKeys(obj, inspect); + return "[Function" + (name ? ": " + name : " (anonymous)") + "]" + (keys.length > 0 ? " { " + $join.call(keys, ", ") + " }" : ""); + } + if (isSymbol(obj)) { + var symString = hasShammedSymbols ? $replace.call(String(obj), /^(Symbol\(.*\))_[^)]*$/, "$1") : symToString.call(obj); + return typeof obj === "object" && !hasShammedSymbols ? markBoxed(symString) : symString; + } + if (isElement(obj)) { + var s = "<" + $toLowerCase.call(String(obj.nodeName)); + var attrs = obj.attributes || []; + for (var i = 0; i < attrs.length; i++) { + s += " " + attrs[i].name + "=" + wrapQuotes(quote(attrs[i].value), "double", opts); + } + s += ">"; + if (obj.childNodes && obj.childNodes.length) { + s += "..."; + } + s += ""; + return s; + } + if (isArray(obj)) { + if (obj.length === 0) { + return "[]"; + } + var xs = arrObjKeys(obj, inspect); + if (indent2 && !singleLineValues(xs)) { + return "[" + indentedJoin(xs, indent2) + "]"; + } + return "[ " + $join.call(xs, ", ") + " ]"; + } + if (isError(obj)) { + var parts = arrObjKeys(obj, inspect); + if (!("cause" in Error.prototype) && "cause" in obj && !isEnumerable.call(obj, "cause")) { + return "{ [" + String(obj) + "] " + $join.call($concat.call("[cause]: " + inspect(obj.cause), parts), ", ") + " }"; + } + if (parts.length === 0) { + return "[" + String(obj) + "]"; + } + return "{ [" + String(obj) + "] " + $join.call(parts, ", ") + " }"; + } + if (typeof obj === "object" && customInspect) { + if (inspectSymbol && typeof obj[inspectSymbol] === "function" && utilInspect) { + return utilInspect(obj, { depth: maxDepth - depth }); + } else if (customInspect !== "symbol" && typeof obj.inspect === "function") { + return obj.inspect(); + } + } + if (isMap(obj)) { + var mapParts = []; + if (mapForEach) { + mapForEach.call(obj, function(value, key2) { + mapParts.push(inspect(key2, obj, true) + " => " + inspect(value, obj)); + }); + } + return collectionOf("Map", mapSize.call(obj), mapParts, indent2); + } + if (isSet(obj)) { + var setParts = []; + if (setForEach) { + setForEach.call(obj, function(value) { + setParts.push(inspect(value, obj)); + }); + } + return collectionOf("Set", setSize.call(obj), setParts, indent2); + } + if (isWeakMap(obj)) { + return weakCollectionOf("WeakMap"); + } + if (isWeakSet(obj)) { + return weakCollectionOf("WeakSet"); + } + if (isWeakRef(obj)) { + return weakCollectionOf("WeakRef"); + } + if (isNumber(obj)) { + return markBoxed(inspect(Number(obj))); + } + if (isBigInt(obj)) { + return markBoxed(inspect(bigIntValueOf.call(obj))); + } + if (isBoolean(obj)) { + return markBoxed(booleanValueOf.call(obj)); + } + if (isString(obj)) { + return markBoxed(inspect(String(obj))); + } + if (!isDate(obj) && !isRegExp(obj)) { + var ys = arrObjKeys(obj, inspect); + var isPlainObject = gPO ? gPO(obj) === Object.prototype : obj instanceof Object || obj.constructor === Object; + var protoTag = obj instanceof Object ? "" : "null prototype"; + var stringTag = !isPlainObject && toStringTag && Object(obj) === obj && toStringTag in obj ? $slice.call(toStr(obj), 8, -1) : protoTag ? "Object" : ""; + var constructorTag = isPlainObject || typeof obj.constructor !== "function" ? "" : obj.constructor.name ? obj.constructor.name + " " : ""; + var tag2 = constructorTag + (stringTag || protoTag ? "[" + $join.call($concat.call([], stringTag || [], protoTag || []), ": ") + "] " : ""); + if (ys.length === 0) { + return tag2 + "{}"; + } + if (indent2) { + return tag2 + "{" + indentedJoin(ys, indent2) + "}"; + } + return tag2 + "{ " + $join.call(ys, ", ") + " }"; + } + return String(obj); + }; + function wrapQuotes(s, defaultStyle, opts) { + var quoteChar = (opts.quoteStyle || defaultStyle) === "double" ? '"' : "'"; + return quoteChar + s + quoteChar; + } + function quote(s) { + return $replace.call(String(s), /"/g, """); + } + function isArray(obj) { + return toStr(obj) === "[object Array]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isDate(obj) { + return toStr(obj) === "[object Date]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isRegExp(obj) { + return toStr(obj) === "[object RegExp]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isError(obj) { + return toStr(obj) === "[object Error]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isString(obj) { + return toStr(obj) === "[object String]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isNumber(obj) { + return toStr(obj) === "[object Number]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isBoolean(obj) { + return toStr(obj) === "[object Boolean]" && (!toStringTag || !(typeof obj === "object" && toStringTag in obj)); + } + function isSymbol(obj) { + if (hasShammedSymbols) { + return obj && typeof obj === "object" && obj instanceof Symbol; + } + if (typeof obj === "symbol") { + return true; + } + if (!obj || typeof obj !== "object" || !symToString) { + return false; + } + try { + symToString.call(obj); + return true; + } catch (e) { + } + return false; + } + function isBigInt(obj) { + if (!obj || typeof obj !== "object" || !bigIntValueOf) { + return false; + } + try { + bigIntValueOf.call(obj); + return true; + } catch (e) { + } + return false; + } + var hasOwn = Object.prototype.hasOwnProperty || function(key2) { + return key2 in this; + }; + function has(obj, key2) { + return hasOwn.call(obj, key2); + } + function toStr(obj) { + return objectToString2.call(obj); + } + function nameOf(f) { + if (f.name) { + return f.name; + } + var m = $match.call(functionToString.call(f), /^function\s*([\w$]+)/); + if (m) { + return m[1]; + } + return null; + } + function indexOf(xs, x) { + if (xs.indexOf) { + return xs.indexOf(x); + } + for (var i = 0, l = xs.length; i < l; i++) { + if (xs[i] === x) { + return i; + } + } + return -1; + } + function isMap(x) { + if (!mapSize || !x || typeof x !== "object") { + return false; + } + try { + mapSize.call(x); + try { + setSize.call(x); + } catch (s) { + return true; + } + return x instanceof Map; + } catch (e) { + } + return false; + } + function isWeakMap(x) { + if (!weakMapHas || !x || typeof x !== "object") { + return false; + } + try { + weakMapHas.call(x, weakMapHas); + try { + weakSetHas.call(x, weakSetHas); + } catch (s) { + return true; + } + return x instanceof WeakMap; + } catch (e) { + } + return false; + } + function isWeakRef(x) { + if (!weakRefDeref || !x || typeof x !== "object") { + return false; + } + try { + weakRefDeref.call(x); + return true; + } catch (e) { + } + return false; + } + function isSet(x) { + if (!setSize || !x || typeof x !== "object") { + return false; + } + try { + setSize.call(x); + try { + mapSize.call(x); + } catch (m) { + return true; + } + return x instanceof Set; + } catch (e) { + } + return false; + } + function isWeakSet(x) { + if (!weakSetHas || !x || typeof x !== "object") { + return false; + } + try { + weakSetHas.call(x, weakSetHas); + try { + weakMapHas.call(x, weakMapHas); + } catch (s) { + return true; + } + return x instanceof WeakSet; + } catch (e) { + } + return false; + } + function isElement(x) { + if (!x || typeof x !== "object") { + return false; + } + if (typeof HTMLElement !== "undefined" && x instanceof HTMLElement) { + return true; + } + return typeof x.nodeName === "string" && typeof x.getAttribute === "function"; + } + function inspectString(str, opts) { + if (str.length > opts.maxStringLength) { + var remaining = str.length - opts.maxStringLength; + var trailer = "... " + remaining + " more character" + (remaining > 1 ? "s" : ""); + return inspectString($slice.call(str, 0, opts.maxStringLength), opts) + trailer; + } + var s = $replace.call($replace.call(str, /(['\\])/g, "\\$1"), /[\x00-\x1f]/g, lowbyte); + return wrapQuotes(s, "single", opts); + } + function lowbyte(c) { + var n = c.charCodeAt(0); + var x = { + 8: "b", + 9: "t", + 10: "n", + 12: "f", + 13: "r" + }[n]; + if (x) { + return "\\" + x; + } + return "\\x" + (n < 16 ? "0" : "") + $toUpperCase.call(n.toString(16)); + } + function markBoxed(str) { + return "Object(" + str + ")"; + } + function weakCollectionOf(type) { + return type + " { ? }"; + } + function collectionOf(type, size, entries, indent2) { + var joinedEntries = indent2 ? indentedJoin(entries, indent2) : $join.call(entries, ", "); + return type + " (" + size + ") {" + joinedEntries + "}"; + } + function singleLineValues(xs) { + for (var i = 0; i < xs.length; i++) { + if (indexOf(xs[i], "\n") >= 0) { + return false; + } + } + return true; + } + function getIndent(opts, depth) { + var baseIndent; + if (opts.indent === " ") { + baseIndent = " "; + } else if (typeof opts.indent === "number" && opts.indent > 0) { + baseIndent = $join.call(Array(opts.indent + 1), " "); + } else { + return null; + } + return { + base: baseIndent, + prev: $join.call(Array(depth + 1), baseIndent) + }; + } + function indentedJoin(xs, indent2) { + if (xs.length === 0) { + return ""; + } + var lineJoiner = "\n" + indent2.prev + indent2.base; + return lineJoiner + $join.call(xs, "," + lineJoiner) + "\n" + indent2.prev; + } + function arrObjKeys(obj, inspect) { + var isArr = isArray(obj); + var xs = []; + if (isArr) { + xs.length = obj.length; + for (var i = 0; i < obj.length; i++) { + xs[i] = has(obj, i) ? inspect(obj[i], obj) : ""; + } + } + var syms = typeof gOPS === "function" ? gOPS(obj) : []; + var symMap; + if (hasShammedSymbols) { + symMap = {}; + for (var k = 0; k < syms.length; k++) { + symMap["$" + syms[k]] = syms[k]; + } + } + for (var key2 in obj) { + if (!has(obj, key2)) { + continue; + } + if (isArr && String(Number(key2)) === key2 && key2 < obj.length) { + continue; + } + if (hasShammedSymbols && symMap["$" + key2] instanceof Symbol) { + continue; + } else if ($test.call(/[^\w$]/, key2)) { + xs.push(inspect(key2, obj) + ": " + inspect(obj[key2], obj)); + } else { + xs.push(key2 + ": " + inspect(obj[key2], obj)); + } + } + if (typeof gOPS === "function") { + for (var j = 0; j < syms.length; j++) { + if (isEnumerable.call(obj, syms[j])) { + xs.push("[" + inspect(syms[j]) + "]: " + inspect(obj[syms[j]], obj)); + } + } + } + return xs; + } + } +}); + +// node_modules/.pnpm/side-channel@1.0.4/node_modules/side-channel/index.js +var require_side_channel = __commonJS({ + "node_modules/.pnpm/side-channel@1.0.4/node_modules/side-channel/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var GetIntrinsic = require_get_intrinsic(); + var callBound = require_callBound(); + var inspect = require_object_inspect(); + var $TypeError = GetIntrinsic("%TypeError%"); + var $WeakMap = GetIntrinsic("%WeakMap%", true); + var $Map = GetIntrinsic("%Map%", true); + var $weakMapGet = callBound("WeakMap.prototype.get", true); + var $weakMapSet = callBound("WeakMap.prototype.set", true); + var $weakMapHas = callBound("WeakMap.prototype.has", true); + var $mapGet = callBound("Map.prototype.get", true); + var $mapSet = callBound("Map.prototype.set", true); + var $mapHas = callBound("Map.prototype.has", true); + var listGetNode = function(list, key2) { + for (var prev = list, curr; (curr = prev.next) !== null; prev = curr) { + if (curr.key === key2) { + prev.next = curr.next; + curr.next = list.next; + list.next = curr; + return curr; + } + } + }; + var listGet = function(objects, key2) { + var node = listGetNode(objects, key2); + return node && node.value; + }; + var listSet = function(objects, key2, value) { + var node = listGetNode(objects, key2); + if (node) { + node.value = value; + } else { + objects.next = { + // eslint-disable-line no-param-reassign + key: key2, + next: objects.next, + value + }; + } + }; + var listHas = function(objects, key2) { + return !!listGetNode(objects, key2); + }; + module2.exports = function getSideChannel() { + var $wm; + var $m; + var $o; + var channel = { + assert: function(key2) { + if (!channel.has(key2)) { + throw new $TypeError("Side channel does not contain " + inspect(key2)); + } + }, + get: function(key2) { + if ($WeakMap && key2 && (typeof key2 === "object" || typeof key2 === "function")) { + if ($wm) { + return $weakMapGet($wm, key2); + } + } else if ($Map) { + if ($m) { + return $mapGet($m, key2); + } + } else { + if ($o) { + return listGet($o, key2); + } + } + }, + has: function(key2) { + if ($WeakMap && key2 && (typeof key2 === "object" || typeof key2 === "function")) { + if ($wm) { + return $weakMapHas($wm, key2); + } + } else if ($Map) { + if ($m) { + return $mapHas($m, key2); + } + } else { + if ($o) { + return listHas($o, key2); + } + } + return false; + }, + set: function(key2, value) { + if ($WeakMap && key2 && (typeof key2 === "object" || typeof key2 === "function")) { + if (!$wm) { + $wm = new $WeakMap(); + } + $weakMapSet($wm, key2, value); + } else if ($Map) { + if (!$m) { + $m = new $Map(); + } + $mapSet($m, key2, value); + } else { + if (!$o) { + $o = { key: {}, next: null }; + } + listSet($o, key2, value); + } + } + }; + return channel; + }; + } +}); + +// node_modules/.pnpm/internal-slot@1.0.5/node_modules/internal-slot/index.js +var require_internal_slot = __commonJS({ + "node_modules/.pnpm/internal-slot@1.0.5/node_modules/internal-slot/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var GetIntrinsic = require_get_intrinsic(); + var has = require_src2(); + var channel = require_side_channel()(); + var $TypeError = GetIntrinsic("%TypeError%"); + var SLOT = { + assert: function(O, slot) { + if (!O || typeof O !== "object" && typeof O !== "function") { + throw new $TypeError("`O` is not an object"); + } + if (typeof slot !== "string") { + throw new $TypeError("`slot` must be a string"); + } + channel.assert(O); + if (!SLOT.has(O, slot)) { + throw new $TypeError("`" + slot + "` is not present on `O`"); + } + }, + get: function(O, slot) { + if (!O || typeof O !== "object" && typeof O !== "function") { + throw new $TypeError("`O` is not an object"); + } + if (typeof slot !== "string") { + throw new $TypeError("`slot` must be a string"); + } + var slots = channel.get(O); + return slots && slots["$" + slot]; + }, + has: function(O, slot) { + if (!O || typeof O !== "object" && typeof O !== "function") { + throw new $TypeError("`O` is not an object"); + } + if (typeof slot !== "string") { + throw new $TypeError("`slot` must be a string"); + } + var slots = channel.get(O); + return !!slots && has(slots, "$" + slot); + }, + set: function(O, slot, V) { + if (!O || typeof O !== "object" && typeof O !== "function") { + throw new $TypeError("`O` is not an object"); + } + if (typeof slot !== "string") { + throw new $TypeError("`slot` must be a string"); + } + var slots = channel.get(O); + if (!slots) { + slots = {}; + channel.set(O, slots); + } + slots["$" + slot] = V; + } + }; + if (Object.freeze) { + Object.freeze(SLOT); + } + module2.exports = SLOT; + } +}); + +// node_modules/.pnpm/stop-iteration-iterator@1.0.0/node_modules/stop-iteration-iterator/index.js +var require_stop_iteration_iterator = __commonJS({ + "node_modules/.pnpm/stop-iteration-iterator@1.0.0/node_modules/stop-iteration-iterator/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var SLOT = require_internal_slot(); + var $SyntaxError = SyntaxError; + var $StopIteration = typeof StopIteration === "object" ? StopIteration : null; + module2.exports = function getStopIterationIterator(origIterator) { + if (!$StopIteration) { + throw new $SyntaxError("this environment lacks StopIteration"); + } + SLOT.set(origIterator, "[[Done]]", false); + var siIterator = { + next: function next() { + var iterator = SLOT.get(this, "[[Iterator]]"); + var done = SLOT.get(iterator, "[[Done]]"); + try { + return { + done, + value: done ? void 0 : iterator.next() + }; + } catch (e) { + SLOT.set(iterator, "[[Done]]", true); + if (e !== $StopIteration) { + throw e; + } + return { + done: true, + value: void 0 + }; + } + } + }; + SLOT.set(siIterator, "[[Iterator]]", origIterator); + return siIterator; + }; + } +}); + +// node_modules/.pnpm/isarray@2.0.5/node_modules/isarray/index.js +var require_isarray = __commonJS({ + "node_modules/.pnpm/isarray@2.0.5/node_modules/isarray/index.js"(exports2, module2) { + init_polyfill_buffer(); + var toString = {}.toString; + module2.exports = Array.isArray || function(arr) { + return toString.call(arr) == "[object Array]"; + }; + } +}); + +// node_modules/.pnpm/is-string@1.0.7/node_modules/is-string/index.js +var require_is_string = __commonJS({ + "node_modules/.pnpm/is-string@1.0.7/node_modules/is-string/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var strValue = String.prototype.valueOf; + var tryStringObject = function tryStringObject2(value) { + try { + strValue.call(value); + return true; + } catch (e) { + return false; + } + }; + var toStr = Object.prototype.toString; + var strClass = "[object String]"; + var hasToStringTag = require_shams2()(); + module2.exports = function isString(value) { + if (typeof value === "string") { + return true; + } + if (typeof value !== "object") { + return false; + } + return hasToStringTag ? tryStringObject(value) : toStr.call(value) === strClass; + }; + } +}); + +// node_modules/.pnpm/is-map@2.0.2/node_modules/is-map/index.js +var require_is_map = __commonJS({ + "node_modules/.pnpm/is-map@2.0.2/node_modules/is-map/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var $Map = typeof Map === "function" && Map.prototype ? Map : null; + var $Set = typeof Set === "function" && Set.prototype ? Set : null; + var exported; + if (!$Map) { + exported = function isMap(x) { + return false; + }; + } + var $mapHas = $Map ? Map.prototype.has : null; + var $setHas = $Set ? Set.prototype.has : null; + if (!exported && !$mapHas) { + exported = function isMap(x) { + return false; + }; + } + module2.exports = exported || function isMap(x) { + if (!x || typeof x !== "object") { + return false; + } + try { + $mapHas.call(x); + if ($setHas) { + try { + $setHas.call(x); + } catch (e) { + return true; + } + } + return x instanceof $Map; + } catch (e) { + } + return false; + }; + } +}); + +// node_modules/.pnpm/is-set@2.0.2/node_modules/is-set/index.js +var require_is_set = __commonJS({ + "node_modules/.pnpm/is-set@2.0.2/node_modules/is-set/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var $Map = typeof Map === "function" && Map.prototype ? Map : null; + var $Set = typeof Set === "function" && Set.prototype ? Set : null; + var exported; + if (!$Set) { + exported = function isSet(x) { + return false; + }; + } + var $mapHas = $Map ? Map.prototype.has : null; + var $setHas = $Set ? Set.prototype.has : null; + if (!exported && !$setHas) { + exported = function isSet(x) { + return false; + }; + } + module2.exports = exported || function isSet(x) { + if (!x || typeof x !== "object") { + return false; + } + try { + $setHas.call(x); + if ($mapHas) { + try { + $mapHas.call(x); + } catch (e) { + return true; + } + } + return x instanceof $Set; + } catch (e) { + } + return false; + }; + } +}); + +// node_modules/.pnpm/es-get-iterator@1.1.3/node_modules/es-get-iterator/index.js +var require_es_get_iterator = __commonJS({ + "node_modules/.pnpm/es-get-iterator@1.1.3/node_modules/es-get-iterator/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var isArguments = require_is_arguments(); + var getStopIterationIterator = require_stop_iteration_iterator(); + if (require_has_symbols()() || require_shams()()) { + $iterator = Symbol.iterator; + module2.exports = function getIterator3(iterable) { + if (iterable != null && typeof iterable[$iterator] !== "undefined") { + return iterable[$iterator](); + } + if (isArguments(iterable)) { + return Array.prototype[$iterator].call(iterable); + } + }; + } else { + isArray = require_isarray(); + isString = require_is_string(); + GetIntrinsic = require_get_intrinsic(); + $Map = GetIntrinsic("%Map%", true); + $Set = GetIntrinsic("%Set%", true); + callBound = require_callBound(); + $arrayPush = callBound("Array.prototype.push"); + $charCodeAt = callBound("String.prototype.charCodeAt"); + $stringSlice = callBound("String.prototype.slice"); + advanceStringIndex = function advanceStringIndex2(S, index2) { + var length = S.length; + if (index2 + 1 >= length) { + return index2 + 1; + } + var first2 = $charCodeAt(S, index2); + if (first2 < 55296 || first2 > 56319) { + return index2 + 1; + } + var second = $charCodeAt(S, index2 + 1); + if (second < 56320 || second > 57343) { + return index2 + 1; + } + return index2 + 2; + }; + getArrayIterator = function getArrayIterator2(arraylike) { + var i = 0; + return { + next: function next() { + var done = i >= arraylike.length; + var value; + if (!done) { + value = arraylike[i]; + i += 1; + } + return { + done, + value + }; + } + }; + }; + getNonCollectionIterator = function getNonCollectionIterator2(iterable, noPrimordialCollections) { + if (isArray(iterable) || isArguments(iterable)) { + return getArrayIterator(iterable); + } + if (isString(iterable)) { + var i = 0; + return { + next: function next() { + var nextIndex = advanceStringIndex(iterable, i); + var value = $stringSlice(iterable, i, nextIndex); + i = nextIndex; + return { + done: nextIndex > iterable.length, + value + }; + } + }; + } + if (noPrimordialCollections && typeof iterable["_es6-shim iterator_"] !== "undefined") { + return iterable["_es6-shim iterator_"](); + } + }; + if (!$Map && !$Set) { + module2.exports = function getIterator3(iterable) { + if (iterable != null) { + return getNonCollectionIterator(iterable, true); + } + }; + } else { + isMap = require_is_map(); + isSet = require_is_set(); + $mapForEach = callBound("Map.prototype.forEach", true); + $setForEach = callBound("Set.prototype.forEach", true); + if (typeof process === "undefined" || !process.versions || !process.versions.node) { + $mapIterator = callBound("Map.prototype.iterator", true); + $setIterator = callBound("Set.prototype.iterator", true); + } + $mapAtAtIterator = callBound("Map.prototype.@@iterator", true) || callBound("Map.prototype._es6-shim iterator_", true); + $setAtAtIterator = callBound("Set.prototype.@@iterator", true) || callBound("Set.prototype._es6-shim iterator_", true); + getCollectionIterator = function getCollectionIterator2(iterable) { + if (isMap(iterable)) { + if ($mapIterator) { + return getStopIterationIterator($mapIterator(iterable)); + } + if ($mapAtAtIterator) { + return $mapAtAtIterator(iterable); + } + if ($mapForEach) { + var entries = []; + $mapForEach(iterable, function(v, k) { + $arrayPush(entries, [k, v]); + }); + return getArrayIterator(entries); + } + } + if (isSet(iterable)) { + if ($setIterator) { + return getStopIterationIterator($setIterator(iterable)); + } + if ($setAtAtIterator) { + return $setAtAtIterator(iterable); + } + if ($setForEach) { + var values = []; + $setForEach(iterable, function(v) { + $arrayPush(values, v); + }); + return getArrayIterator(values); + } + } + }; + module2.exports = function getIterator3(iterable) { + return getCollectionIterator(iterable) || getNonCollectionIterator(iterable); + }; + } + } + var $iterator; + var isArray; + var isString; + var GetIntrinsic; + var $Map; + var $Set; + var callBound; + var $arrayPush; + var $charCodeAt; + var $stringSlice; + var advanceStringIndex; + var getArrayIterator; + var getNonCollectionIterator; + var isMap; + var isSet; + var $mapForEach; + var $setForEach; + var $mapIterator; + var $setIterator; + var $mapAtAtIterator; + var $setAtAtIterator; + var getCollectionIterator; + } +}); + +// node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/implementation.js +var require_implementation5 = __commonJS({ + "node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/implementation.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var numberIsNaN = function(value) { + return value !== value; + }; + module2.exports = function is(a, b) { + if (a === 0 && b === 0) { + return 1 / a === 1 / b; + } + if (a === b) { + return true; + } + if (numberIsNaN(a) && numberIsNaN(b)) { + return true; + } + return false; + }; + } +}); + +// node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/polyfill.js +var require_polyfill3 = __commonJS({ + "node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/polyfill.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var implementation = require_implementation5(); + module2.exports = function getPolyfill() { + return typeof Object.is === "function" ? Object.is : implementation; + }; + } +}); + +// node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/shim.js +var require_shim3 = __commonJS({ + "node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/shim.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var getPolyfill = require_polyfill3(); + var define2 = require_define_properties(); + module2.exports = function shimObjectIs() { + var polyfill = getPolyfill(); + define2(Object, { is: polyfill }, { + is: function testObjectIs() { + return Object.is !== polyfill; + } + }); + return polyfill; + }; + } +}); + +// node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/index.js +var require_object_is = __commonJS({ + "node_modules/.pnpm/object-is@1.1.5/node_modules/object-is/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var define2 = require_define_properties(); + var callBind = require_call_bind(); + var implementation = require_implementation5(); + var getPolyfill = require_polyfill3(); + var shim = require_shim3(); + var polyfill = callBind(getPolyfill(), Object); + define2(polyfill, { + getPolyfill, + implementation, + shim + }); + module2.exports = polyfill; + } +}); + +// node_modules/.pnpm/is-callable@1.2.7/node_modules/is-callable/index.js +var require_is_callable = __commonJS({ + "node_modules/.pnpm/is-callable@1.2.7/node_modules/is-callable/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var fnToStr = Function.prototype.toString; + var reflectApply = typeof Reflect === "object" && Reflect !== null && Reflect.apply; + var badArrayLike; + var isCallableMarker; + if (typeof reflectApply === "function" && typeof Object.defineProperty === "function") { + try { + badArrayLike = Object.defineProperty({}, "length", { + get: function() { + throw isCallableMarker; + } + }); + isCallableMarker = {}; + reflectApply(function() { + throw 42; + }, null, badArrayLike); + } catch (_) { + if (_ !== isCallableMarker) { + reflectApply = null; + } + } + } else { + reflectApply = null; + } + var constructorRegex = /^\s*class\b/; + var isES6ClassFn = function isES6ClassFunction(value) { + try { + var fnStr = fnToStr.call(value); + return constructorRegex.test(fnStr); + } catch (e) { + return false; + } + }; + var tryFunctionObject = function tryFunctionToStr(value) { + try { + if (isES6ClassFn(value)) { + return false; + } + fnToStr.call(value); + return true; + } catch (e) { + return false; + } + }; + var toStr = Object.prototype.toString; + var objectClass = "[object Object]"; + var fnClass = "[object Function]"; + var genClass = "[object GeneratorFunction]"; + var ddaClass = "[object HTMLAllCollection]"; + var ddaClass2 = "[object HTML document.all class]"; + var ddaClass3 = "[object HTMLCollection]"; + var hasToStringTag = typeof Symbol === "function" && !!Symbol.toStringTag; + var isIE68 = !(0 in [,]); + var isDDA = function isDocumentDotAll() { + return false; + }; + if (typeof document === "object") { + all = document.all; + if (toStr.call(all) === toStr.call(document.all)) { + isDDA = function isDocumentDotAll(value) { + if ((isIE68 || !value) && (typeof value === "undefined" || typeof value === "object")) { + try { + var str = toStr.call(value); + return (str === ddaClass || str === ddaClass2 || str === ddaClass3 || str === objectClass) && value("") == null; + } catch (e) { + } + } + return false; + }; + } + } + var all; + module2.exports = reflectApply ? function isCallable(value) { + if (isDDA(value)) { + return true; + } + if (!value) { + return false; + } + if (typeof value !== "function" && typeof value !== "object") { + return false; + } + try { + reflectApply(value, null, badArrayLike); + } catch (e) { + if (e !== isCallableMarker) { + return false; + } + } + return !isES6ClassFn(value) && tryFunctionObject(value); + } : function isCallable(value) { + if (isDDA(value)) { + return true; + } + if (!value) { + return false; + } + if (typeof value !== "function" && typeof value !== "object") { + return false; + } + if (hasToStringTag) { + return tryFunctionObject(value); + } + if (isES6ClassFn(value)) { + return false; + } + var strClass = toStr.call(value); + if (strClass !== fnClass && strClass !== genClass && !/^\[object HTML/.test(strClass)) { + return false; + } + return tryFunctionObject(value); + }; + } +}); + +// node_modules/.pnpm/for-each@0.3.3/node_modules/for-each/index.js +var require_for_each = __commonJS({ + "node_modules/.pnpm/for-each@0.3.3/node_modules/for-each/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var isCallable = require_is_callable(); + var toStr = Object.prototype.toString; + var hasOwnProperty = Object.prototype.hasOwnProperty; + var forEachArray = function forEachArray2(array, iterator, receiver) { + for (var i = 0, len = array.length; i < len; i++) { + if (hasOwnProperty.call(array, i)) { + if (receiver == null) { + iterator(array[i], i, array); + } else { + iterator.call(receiver, array[i], i, array); + } + } + } + }; + var forEachString = function forEachString2(string, iterator, receiver) { + for (var i = 0, len = string.length; i < len; i++) { + if (receiver == null) { + iterator(string.charAt(i), i, string); + } else { + iterator.call(receiver, string.charAt(i), i, string); + } + } + }; + var forEachObject = function forEachObject2(object, iterator, receiver) { + for (var k in object) { + if (hasOwnProperty.call(object, k)) { + if (receiver == null) { + iterator(object[k], k, object); + } else { + iterator.call(receiver, object[k], k, object); + } + } + } + }; + var forEach2 = function forEach3(list, iterator, thisArg) { + if (!isCallable(iterator)) { + throw new TypeError("iterator must be a function"); + } + var receiver; + if (arguments.length >= 3) { + receiver = thisArg; + } + if (toStr.call(list) === "[object Array]") { + forEachArray(list, iterator, receiver); + } else if (typeof list === "string") { + forEachString(list, iterator, receiver); + } else { + forEachObject(list, iterator, receiver); + } + }; + module2.exports = forEach2; + } +}); + +// node_modules/.pnpm/available-typed-arrays@1.0.5/node_modules/available-typed-arrays/index.js +var require_available_typed_arrays = __commonJS({ + "node_modules/.pnpm/available-typed-arrays@1.0.5/node_modules/available-typed-arrays/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var possibleNames = [ + "BigInt64Array", + "BigUint64Array", + "Float32Array", + "Float64Array", + "Int16Array", + "Int32Array", + "Int8Array", + "Uint16Array", + "Uint32Array", + "Uint8Array", + "Uint8ClampedArray" + ]; + var g = typeof globalThis === "undefined" ? global : globalThis; + module2.exports = function availableTypedArrays() { + var out = []; + for (var i = 0; i < possibleNames.length; i++) { + if (typeof g[possibleNames[i]] === "function") { + out[out.length] = possibleNames[i]; + } + } + return out; + }; + } +}); + +// node_modules/.pnpm/gopd@1.0.1/node_modules/gopd/index.js +var require_gopd = __commonJS({ + "node_modules/.pnpm/gopd@1.0.1/node_modules/gopd/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var GetIntrinsic = require_get_intrinsic(); + var $gOPD = GetIntrinsic("%Object.getOwnPropertyDescriptor%", true); + if ($gOPD) { + try { + $gOPD([], "length"); + } catch (e) { + $gOPD = null; + } + } + module2.exports = $gOPD; + } +}); + +// node_modules/.pnpm/which-typed-array@1.1.11/node_modules/which-typed-array/index.js +var require_which_typed_array = __commonJS({ + "node_modules/.pnpm/which-typed-array@1.1.11/node_modules/which-typed-array/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var forEach2 = require_for_each(); + var availableTypedArrays = require_available_typed_arrays(); + var callBind = require_call_bind(); + var callBound = require_callBound(); + var gOPD = require_gopd(); + var $toString = callBound("Object.prototype.toString"); + var hasToStringTag = require_shams2()(); + var g = typeof globalThis === "undefined" ? global : globalThis; + var typedArrays = availableTypedArrays(); + var $slice = callBound("String.prototype.slice"); + var getPrototypeOf = Object.getPrototypeOf; + var $indexOf = callBound("Array.prototype.indexOf", true) || function indexOf(array, value) { + for (var i = 0; i < array.length; i += 1) { + if (array[i] === value) { + return i; + } + } + return -1; + }; + var cache = { __proto__: null }; + if (hasToStringTag && gOPD && getPrototypeOf) { + forEach2(typedArrays, function(typedArray) { + var arr = new g[typedArray](); + if (Symbol.toStringTag in arr) { + var proto = getPrototypeOf(arr); + var descriptor = gOPD(proto, Symbol.toStringTag); + if (!descriptor) { + var superProto = getPrototypeOf(proto); + descriptor = gOPD(superProto, Symbol.toStringTag); + } + cache["$" + typedArray] = callBind(descriptor.get); + } + }); + } else { + forEach2(typedArrays, function(typedArray) { + var arr = new g[typedArray](); + cache["$" + typedArray] = callBind(arr.slice); + }); + } + var tryTypedArrays = function tryAllTypedArrays(value) { + var found = false; + forEach2(cache, function(getter, typedArray) { + if (!found) { + try { + if ("$" + getter(value) === typedArray) { + found = $slice(typedArray, 1); + } + } catch (e) { + } + } + }); + return found; + }; + var trySlices = function tryAllSlices(value) { + var found = false; + forEach2(cache, function(getter, name) { + if (!found) { + try { + getter(value); + found = $slice(name, 1); + } catch (e) { + } + } + }); + return found; + }; + module2.exports = function whichTypedArray(value) { + if (!value || typeof value !== "object") { + return false; + } + if (!hasToStringTag) { + var tag2 = $slice($toString(value), 8, -1); + if ($indexOf(typedArrays, tag2) > -1) { + return tag2; + } + if (tag2 !== "Object") { + return false; + } + return trySlices(value); + } + if (!gOPD) { + return null; + } + return tryTypedArrays(value); + }; + } +}); + +// node_modules/.pnpm/is-typed-array@1.1.12/node_modules/is-typed-array/index.js +var require_is_typed_array = __commonJS({ + "node_modules/.pnpm/is-typed-array@1.1.12/node_modules/is-typed-array/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var whichTypedArray = require_which_typed_array(); + module2.exports = function isTypedArray(value) { + return !!whichTypedArray(value); + }; + } +}); + +// node_modules/.pnpm/is-array-buffer@3.0.2/node_modules/is-array-buffer/index.js +var require_is_array_buffer = __commonJS({ + "node_modules/.pnpm/is-array-buffer@3.0.2/node_modules/is-array-buffer/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var callBind = require_call_bind(); + var callBound = require_callBound(); + var GetIntrinsic = require_get_intrinsic(); + var isTypedArray = require_is_typed_array(); + var $ArrayBuffer = GetIntrinsic("ArrayBuffer", true); + var $Float32Array = GetIntrinsic("Float32Array", true); + var $byteLength = callBound("ArrayBuffer.prototype.byteLength", true); + var abSlice = $ArrayBuffer && !$byteLength && new $ArrayBuffer().slice; + var $abSlice = abSlice && callBind(abSlice); + module2.exports = $byteLength || $abSlice ? function isArrayBuffer(obj) { + if (!obj || typeof obj !== "object") { + return false; + } + try { + if ($byteLength) { + $byteLength(obj); + } else { + $abSlice(obj, 0); + } + return true; + } catch (e) { + return false; + } + } : $Float32Array ? function IsArrayBuffer(obj) { + try { + return new $Float32Array(obj).buffer === obj && !isTypedArray(obj); + } catch (e) { + return typeof obj === "object" && e.name === "RangeError"; + } + } : function isArrayBuffer(obj) { + return false; + }; + } +}); + +// node_modules/.pnpm/is-date-object@1.0.5/node_modules/is-date-object/index.js +var require_is_date_object = __commonJS({ + "node_modules/.pnpm/is-date-object@1.0.5/node_modules/is-date-object/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var getDay = Date.prototype.getDay; + var tryDateObject = function tryDateGetDayCall(value) { + try { + getDay.call(value); + return true; + } catch (e) { + return false; + } + }; + var toStr = Object.prototype.toString; + var dateClass = "[object Date]"; + var hasToStringTag = require_shams2()(); + module2.exports = function isDateObject(value) { + if (typeof value !== "object" || value === null) { + return false; + } + return hasToStringTag ? tryDateObject(value) : toStr.call(value) === dateClass; + }; + } +}); + +// node_modules/.pnpm/is-regex@1.1.4/node_modules/is-regex/index.js +var require_is_regex = __commonJS({ + "node_modules/.pnpm/is-regex@1.1.4/node_modules/is-regex/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var callBound = require_callBound(); + var hasToStringTag = require_shams2()(); + var has; + var $exec; + var isRegexMarker; + var badStringifier; + if (hasToStringTag) { + has = callBound("Object.prototype.hasOwnProperty"); + $exec = callBound("RegExp.prototype.exec"); + isRegexMarker = {}; + throwRegexMarker = function() { + throw isRegexMarker; + }; + badStringifier = { + toString: throwRegexMarker, + valueOf: throwRegexMarker + }; + if (typeof Symbol.toPrimitive === "symbol") { + badStringifier[Symbol.toPrimitive] = throwRegexMarker; + } + } + var throwRegexMarker; + var $toString = callBound("Object.prototype.toString"); + var gOPD = Object.getOwnPropertyDescriptor; + var regexClass = "[object RegExp]"; + module2.exports = hasToStringTag ? function isRegex(value) { + if (!value || typeof value !== "object") { + return false; + } + var descriptor = gOPD(value, "lastIndex"); + var hasLastIndexDataProperty = descriptor && has(descriptor, "value"); + if (!hasLastIndexDataProperty) { + return false; + } + try { + $exec(value, badStringifier); + } catch (e) { + return e === isRegexMarker; + } + } : function isRegex(value) { + if (!value || typeof value !== "object" && typeof value !== "function") { + return false; + } + return $toString(value) === regexClass; + }; + } +}); + +// node_modules/.pnpm/is-shared-array-buffer@1.0.2/node_modules/is-shared-array-buffer/index.js +var require_is_shared_array_buffer = __commonJS({ + "node_modules/.pnpm/is-shared-array-buffer@1.0.2/node_modules/is-shared-array-buffer/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var callBound = require_callBound(); + var $byteLength = callBound("SharedArrayBuffer.prototype.byteLength", true); + module2.exports = $byteLength ? function isSharedArrayBuffer(obj) { + if (!obj || typeof obj !== "object") { + return false; + } + try { + $byteLength(obj); + return true; + } catch (e) { + return false; + } + } : function isSharedArrayBuffer(obj) { + return false; + }; + } +}); + +// node_modules/.pnpm/is-number-object@1.0.7/node_modules/is-number-object/index.js +var require_is_number_object = __commonJS({ + "node_modules/.pnpm/is-number-object@1.0.7/node_modules/is-number-object/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var numToStr = Number.prototype.toString; + var tryNumberObject = function tryNumberObject2(value) { + try { + numToStr.call(value); + return true; + } catch (e) { + return false; + } + }; + var toStr = Object.prototype.toString; + var numClass = "[object Number]"; + var hasToStringTag = require_shams2()(); + module2.exports = function isNumberObject(value) { + if (typeof value === "number") { + return true; + } + if (typeof value !== "object") { + return false; + } + return hasToStringTag ? tryNumberObject(value) : toStr.call(value) === numClass; + }; + } +}); + +// node_modules/.pnpm/is-boolean-object@1.1.2/node_modules/is-boolean-object/index.js +var require_is_boolean_object = __commonJS({ + "node_modules/.pnpm/is-boolean-object@1.1.2/node_modules/is-boolean-object/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var callBound = require_callBound(); + var $boolToStr = callBound("Boolean.prototype.toString"); + var $toString = callBound("Object.prototype.toString"); + var tryBooleanObject = function booleanBrandCheck(value) { + try { + $boolToStr(value); + return true; + } catch (e) { + return false; + } + }; + var boolClass = "[object Boolean]"; + var hasToStringTag = require_shams2()(); + module2.exports = function isBoolean(value) { + if (typeof value === "boolean") { + return true; + } + if (value === null || typeof value !== "object") { + return false; + } + return hasToStringTag && Symbol.toStringTag in value ? tryBooleanObject(value) : $toString(value) === boolClass; + }; + } +}); + +// node_modules/.pnpm/is-symbol@1.0.4/node_modules/is-symbol/index.js +var require_is_symbol = __commonJS({ + "node_modules/.pnpm/is-symbol@1.0.4/node_modules/is-symbol/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var toStr = Object.prototype.toString; + var hasSymbols = require_has_symbols()(); + if (hasSymbols) { + symToStr = Symbol.prototype.toString; + symStringRegex = /^Symbol\(.*\)$/; + isSymbolObject = function isRealSymbolObject(value) { + if (typeof value.valueOf() !== "symbol") { + return false; + } + return symStringRegex.test(symToStr.call(value)); + }; + module2.exports = function isSymbol(value) { + if (typeof value === "symbol") { + return true; + } + if (toStr.call(value) !== "[object Symbol]") { + return false; + } + try { + return isSymbolObject(value); + } catch (e) { + return false; + } + }; + } else { + module2.exports = function isSymbol(value) { + return false; + }; + } + var symToStr; + var symStringRegex; + var isSymbolObject; + } +}); + +// node_modules/.pnpm/has-bigints@1.0.2/node_modules/has-bigints/index.js +var require_has_bigints = __commonJS({ + "node_modules/.pnpm/has-bigints@1.0.2/node_modules/has-bigints/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var $BigInt = typeof BigInt !== "undefined" && BigInt; + module2.exports = function hasNativeBigInts() { + return typeof $BigInt === "function" && typeof BigInt === "function" && typeof $BigInt(42) === "bigint" && typeof BigInt(42) === "bigint"; + }; + } +}); + +// node_modules/.pnpm/is-bigint@1.0.4/node_modules/is-bigint/index.js +var require_is_bigint = __commonJS({ + "node_modules/.pnpm/is-bigint@1.0.4/node_modules/is-bigint/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var hasBigInts = require_has_bigints()(); + if (hasBigInts) { + bigIntValueOf = BigInt.prototype.valueOf; + tryBigInt = function tryBigIntObject(value) { + try { + bigIntValueOf.call(value); + return true; + } catch (e) { + } + return false; + }; + module2.exports = function isBigInt(value) { + if (value === null || typeof value === "undefined" || typeof value === "boolean" || typeof value === "string" || typeof value === "number" || typeof value === "symbol" || typeof value === "function") { + return false; + } + if (typeof value === "bigint") { + return true; + } + return tryBigInt(value); + }; + } else { + module2.exports = function isBigInt(value) { + return false; + }; + } + var bigIntValueOf; + var tryBigInt; + } +}); + +// node_modules/.pnpm/which-boxed-primitive@1.0.2/node_modules/which-boxed-primitive/index.js +var require_which_boxed_primitive = __commonJS({ + "node_modules/.pnpm/which-boxed-primitive@1.0.2/node_modules/which-boxed-primitive/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var isString = require_is_string(); + var isNumber = require_is_number_object(); + var isBoolean = require_is_boolean_object(); + var isSymbol = require_is_symbol(); + var isBigInt = require_is_bigint(); + module2.exports = function whichBoxedPrimitive(value) { + if (value == null || typeof value !== "object" && typeof value !== "function") { + return null; + } + if (isString(value)) { + return "String"; + } + if (isNumber(value)) { + return "Number"; + } + if (isBoolean(value)) { + return "Boolean"; + } + if (isSymbol(value)) { + return "Symbol"; + } + if (isBigInt(value)) { + return "BigInt"; + } + }; + } +}); + +// node_modules/.pnpm/is-weakmap@2.0.1/node_modules/is-weakmap/index.js +var require_is_weakmap = __commonJS({ + "node_modules/.pnpm/is-weakmap@2.0.1/node_modules/is-weakmap/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var $WeakMap = typeof WeakMap === "function" && WeakMap.prototype ? WeakMap : null; + var $WeakSet = typeof WeakSet === "function" && WeakSet.prototype ? WeakSet : null; + var exported; + if (!$WeakMap) { + exported = function isWeakMap(x) { + return false; + }; + } + var $mapHas = $WeakMap ? $WeakMap.prototype.has : null; + var $setHas = $WeakSet ? $WeakSet.prototype.has : null; + if (!exported && !$mapHas) { + exported = function isWeakMap(x) { + return false; + }; + } + module2.exports = exported || function isWeakMap(x) { + if (!x || typeof x !== "object") { + return false; + } + try { + $mapHas.call(x, $mapHas); + if ($setHas) { + try { + $setHas.call(x, $setHas); + } catch (e) { + return true; + } + } + return x instanceof $WeakMap; + } catch (e) { + } + return false; + }; + } +}); + +// node_modules/.pnpm/is-weakset@2.0.2/node_modules/is-weakset/index.js +var require_is_weakset = __commonJS({ + "node_modules/.pnpm/is-weakset@2.0.2/node_modules/is-weakset/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var GetIntrinsic = require_get_intrinsic(); + var callBound = require_callBound(); + var $WeakSet = GetIntrinsic("%WeakSet%", true); + var $setHas = callBound("WeakSet.prototype.has", true); + if ($setHas) { + $mapHas = callBound("WeakMap.prototype.has", true); + module2.exports = function isWeakSet(x) { + if (!x || typeof x !== "object") { + return false; + } + try { + $setHas(x, $setHas); + if ($mapHas) { + try { + $mapHas(x, $mapHas); + } catch (e) { + return true; + } + } + return x instanceof $WeakSet; + } catch (e) { + } + return false; + }; + } else { + module2.exports = function isWeakSet(x) { + return false; + }; + } + var $mapHas; + } +}); + +// node_modules/.pnpm/which-collection@1.0.1/node_modules/which-collection/index.js +var require_which_collection = __commonJS({ + "node_modules/.pnpm/which-collection@1.0.1/node_modules/which-collection/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var isMap = require_is_map(); + var isSet = require_is_set(); + var isWeakMap = require_is_weakmap(); + var isWeakSet = require_is_weakset(); + module2.exports = function whichCollection(value) { + if (value && typeof value === "object") { + if (isMap(value)) { + return "Map"; + } + if (isSet(value)) { + return "Set"; + } + if (isWeakMap(value)) { + return "WeakMap"; + } + if (isWeakSet(value)) { + return "WeakSet"; + } + } + return false; + }; + } +}); + +// node_modules/.pnpm/array-buffer-byte-length@1.0.0/node_modules/array-buffer-byte-length/index.js +var require_array_buffer_byte_length = __commonJS({ + "node_modules/.pnpm/array-buffer-byte-length@1.0.0/node_modules/array-buffer-byte-length/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var callBound = require_callBound(); + var $byteLength = callBound("ArrayBuffer.prototype.byteLength", true); + var isArrayBuffer = require_is_array_buffer(); + module2.exports = function byteLength(ab) { + if (!isArrayBuffer(ab)) { + return NaN; + } + return $byteLength ? $byteLength(ab) : ab.byteLength; + }; + } +}); + +// node_modules/.pnpm/deep-equal@2.2.2/node_modules/deep-equal/index.js +var require_deep_equal = __commonJS({ + "node_modules/.pnpm/deep-equal@2.2.2/node_modules/deep-equal/index.js"(exports2, module2) { + "use strict"; + init_polyfill_buffer(); + var assign2 = require_object(); + var callBound = require_callBound(); + var flags = require_regexp_prototype(); + var GetIntrinsic = require_get_intrinsic(); + var getIterator3 = require_es_get_iterator(); + var getSideChannel = require_side_channel(); + var is = require_object_is(); + var isArguments = require_is_arguments(); + var isArray = require_isarray(); + var isArrayBuffer = require_is_array_buffer(); + var isDate = require_is_date_object(); + var isRegex = require_is_regex(); + var isSharedArrayBuffer = require_is_shared_array_buffer(); + var objectKeys = require_object_keys(); + var whichBoxedPrimitive = require_which_boxed_primitive(); + var whichCollection = require_which_collection(); + var whichTypedArray = require_which_typed_array(); + var byteLength = require_array_buffer_byte_length(); + var sabByteLength = callBound("SharedArrayBuffer.prototype.byteLength", true); + var $getTime = callBound("Date.prototype.getTime"); + var gPO = Object.getPrototypeOf; + var $objToString = callBound("Object.prototype.toString"); + var $Set = GetIntrinsic("%Set%", true); + var $mapHas = callBound("Map.prototype.has", true); + var $mapGet = callBound("Map.prototype.get", true); + var $mapSize = callBound("Map.prototype.size", true); + var $setAdd = callBound("Set.prototype.add", true); + var $setDelete = callBound("Set.prototype.delete", true); + var $setHas = callBound("Set.prototype.has", true); + var $setSize = callBound("Set.prototype.size", true); + function setHasEqualElement(set, val1, opts, channel) { + var i = getIterator3(set); + var result; + while ((result = i.next()) && !result.done) { + if (internalDeepEqual(val1, result.value, opts, channel)) { + $setDelete(set, result.value); + return true; + } + } + return false; + } + function findLooseMatchingPrimitives(prim) { + if (typeof prim === "undefined") { + return null; + } + if (typeof prim === "object") { + return void 0; + } + if (typeof prim === "symbol") { + return false; + } + if (typeof prim === "string" || typeof prim === "number") { + return +prim === +prim; + } + return true; + } + function mapMightHaveLoosePrim(a, b, prim, item, opts, channel) { + var altValue = findLooseMatchingPrimitives(prim); + if (altValue != null) { + return altValue; + } + var curB = $mapGet(b, altValue); + var looseOpts = assign2({}, opts, { strict: false }); + if (typeof curB === "undefined" && !$mapHas(b, altValue) || !internalDeepEqual(item, curB, looseOpts, channel)) { + return false; + } + return !$mapHas(a, altValue) && internalDeepEqual(item, curB, looseOpts, channel); + } + function setMightHaveLoosePrim(a, b, prim) { + var altValue = findLooseMatchingPrimitives(prim); + if (altValue != null) { + return altValue; + } + return $setHas(b, altValue) && !$setHas(a, altValue); + } + function mapHasEqualEntry(set, map, key1, item1, opts, channel) { + var i = getIterator3(set); + var result; + var key2; + while ((result = i.next()) && !result.done) { + key2 = result.value; + if ( + // eslint-disable-next-line no-use-before-define + internalDeepEqual(key1, key2, opts, channel) && internalDeepEqual(item1, $mapGet(map, key2), opts, channel) + ) { + $setDelete(set, key2); + return true; + } + } + return false; + } + function internalDeepEqual(actual, expected, options, channel) { + var opts = options || {}; + if (opts.strict ? is(actual, expected) : actual === expected) { + return true; + } + var actualBoxed = whichBoxedPrimitive(actual); + var expectedBoxed = whichBoxedPrimitive(expected); + if (actualBoxed !== expectedBoxed) { + return false; + } + if (!actual || !expected || typeof actual !== "object" && typeof expected !== "object") { + return opts.strict ? is(actual, expected) : actual == expected; + } + var hasActual = channel.has(actual); + var hasExpected = channel.has(expected); + var sentinel; + if (hasActual && hasExpected) { + if (channel.get(actual) === channel.get(expected)) { + return true; + } + } else { + sentinel = {}; + } + if (!hasActual) { + channel.set(actual, sentinel); + } + if (!hasExpected) { + channel.set(expected, sentinel); + } + return objEquiv(actual, expected, opts, channel); + } + function isBuffer(x) { + if (!x || typeof x !== "object" || typeof x.length !== "number") { + return false; + } + if (typeof x.copy !== "function" || typeof x.slice !== "function") { + return false; + } + if (x.length > 0 && typeof x[0] !== "number") { + return false; + } + return !!(x.constructor && x.constructor.isBuffer && x.constructor.isBuffer(x)); + } + function setEquiv(a, b, opts, channel) { + if ($setSize(a) !== $setSize(b)) { + return false; + } + var iA = getIterator3(a); + var iB = getIterator3(b); + var resultA; + var resultB; + var set; + while ((resultA = iA.next()) && !resultA.done) { + if (resultA.value && typeof resultA.value === "object") { + if (!set) { + set = new $Set(); + } + $setAdd(set, resultA.value); + } else if (!$setHas(b, resultA.value)) { + if (opts.strict) { + return false; + } + if (!setMightHaveLoosePrim(a, b, resultA.value)) { + return false; + } + if (!set) { + set = new $Set(); + } + $setAdd(set, resultA.value); + } + } + if (set) { + while ((resultB = iB.next()) && !resultB.done) { + if (resultB.value && typeof resultB.value === "object") { + if (!setHasEqualElement(set, resultB.value, opts.strict, channel)) { + return false; + } + } else if (!opts.strict && !$setHas(a, resultB.value) && !setHasEqualElement(set, resultB.value, opts.strict, channel)) { + return false; + } + } + return $setSize(set) === 0; + } + return true; + } + function mapEquiv(a, b, opts, channel) { + if ($mapSize(a) !== $mapSize(b)) { + return false; + } + var iA = getIterator3(a); + var iB = getIterator3(b); + var resultA; + var resultB; + var set; + var key2; + var item1; + var item2; + while ((resultA = iA.next()) && !resultA.done) { + key2 = resultA.value[0]; + item1 = resultA.value[1]; + if (key2 && typeof key2 === "object") { + if (!set) { + set = new $Set(); + } + $setAdd(set, key2); + } else { + item2 = $mapGet(b, key2); + if (typeof item2 === "undefined" && !$mapHas(b, key2) || !internalDeepEqual(item1, item2, opts, channel)) { + if (opts.strict) { + return false; + } + if (!mapMightHaveLoosePrim(a, b, key2, item1, opts, channel)) { + return false; + } + if (!set) { + set = new $Set(); + } + $setAdd(set, key2); + } + } + } + if (set) { + while ((resultB = iB.next()) && !resultB.done) { + key2 = resultB.value[0]; + item2 = resultB.value[1]; + if (key2 && typeof key2 === "object") { + if (!mapHasEqualEntry(set, a, key2, item2, opts, channel)) { + return false; + } + } else if (!opts.strict && (!a.has(key2) || !internalDeepEqual($mapGet(a, key2), item2, opts, channel)) && !mapHasEqualEntry(set, a, key2, item2, assign2({}, opts, { strict: false }), channel)) { + return false; + } + } + return $setSize(set) === 0; + } + return true; + } + function objEquiv(a, b, opts, channel) { + var i, key2; + if (typeof a !== typeof b) { + return false; + } + if (a == null || b == null) { + return false; + } + if ($objToString(a) !== $objToString(b)) { + return false; + } + if (isArguments(a) !== isArguments(b)) { + return false; + } + var aIsArray = isArray(a); + var bIsArray = isArray(b); + if (aIsArray !== bIsArray) { + return false; + } + var aIsError = a instanceof Error; + var bIsError = b instanceof Error; + if (aIsError !== bIsError) { + return false; + } + if (aIsError || bIsError) { + if (a.name !== b.name || a.message !== b.message) { + return false; + } + } + var aIsRegex = isRegex(a); + var bIsRegex = isRegex(b); + if (aIsRegex !== bIsRegex) { + return false; + } + if ((aIsRegex || bIsRegex) && (a.source !== b.source || flags(a) !== flags(b))) { + return false; + } + var aIsDate = isDate(a); + var bIsDate = isDate(b); + if (aIsDate !== bIsDate) { + return false; + } + if (aIsDate || bIsDate) { + if ($getTime(a) !== $getTime(b)) { + return false; + } + } + if (opts.strict && gPO && gPO(a) !== gPO(b)) { + return false; + } + var aWhich = whichTypedArray(a); + var bWhich = whichTypedArray(b); + if (aWhich !== bWhich) { + return false; + } + if (aWhich || bWhich) { + if (a.length !== b.length) { + return false; + } + for (i = 0; i < a.length; i++) { + if (a[i] !== b[i]) { + return false; + } + } + return true; + } + var aIsBuffer = isBuffer(a); + var bIsBuffer = isBuffer(b); + if (aIsBuffer !== bIsBuffer) { + return false; + } + if (aIsBuffer || bIsBuffer) { + if (a.length !== b.length) { + return false; + } + for (i = 0; i < a.length; i++) { + if (a[i] !== b[i]) { + return false; + } + } + return true; + } + var aIsArrayBuffer = isArrayBuffer(a); + var bIsArrayBuffer = isArrayBuffer(b); + if (aIsArrayBuffer !== bIsArrayBuffer) { + return false; + } + if (aIsArrayBuffer || bIsArrayBuffer) { + if (byteLength(a) !== byteLength(b)) { + return false; + } + return typeof Uint8Array === "function" && internalDeepEqual(new Uint8Array(a), new Uint8Array(b), opts, channel); + } + var aIsSAB = isSharedArrayBuffer(a); + var bIsSAB = isSharedArrayBuffer(b); + if (aIsSAB !== bIsSAB) { + return false; + } + if (aIsSAB || bIsSAB) { + if (sabByteLength(a) !== sabByteLength(b)) { + return false; + } + return typeof Uint8Array === "function" && internalDeepEqual(new Uint8Array(a), new Uint8Array(b), opts, channel); + } + if (typeof a !== typeof b) { + return false; + } + var ka = objectKeys(a); + var kb = objectKeys(b); + if (ka.length !== kb.length) { + return false; + } + ka.sort(); + kb.sort(); + for (i = ka.length - 1; i >= 0; i--) { + if (ka[i] != kb[i]) { + return false; + } + } + for (i = ka.length - 1; i >= 0; i--) { + key2 = ka[i]; + if (!internalDeepEqual(a[key2], b[key2], opts, channel)) { + return false; + } + } + var aCollection = whichCollection(a); + var bCollection = whichCollection(b); + if (aCollection !== bCollection) { + return false; + } + if (aCollection === "Set" || bCollection === "Set") { + return setEquiv(a, b, opts, channel); + } + if (aCollection === "Map") { + return mapEquiv(a, b, opts, channel); + } + return true; + } + module2.exports = function deepEqual2(a, b, opts) { + return internalDeepEqual(a, b, opts, getSideChannel()); + }; + } +}); + +// node_modules/.pnpm/js-sha256@0.9.0/node_modules/js-sha256/src/sha256.js +var require_sha256 = __commonJS({ + "node_modules/.pnpm/js-sha256@0.9.0/node_modules/js-sha256/src/sha256.js"(exports, module) { + init_polyfill_buffer(); + (function() { + "use strict"; + var ERROR = "input is invalid type"; + var WINDOW = typeof window === "object"; + var root = WINDOW ? window : {}; + if (root.JS_SHA256_NO_WINDOW) { + WINDOW = false; + } + var WEB_WORKER = !WINDOW && typeof self === "object"; + var NODE_JS = !root.JS_SHA256_NO_NODE_JS && typeof process === "object" && process.versions && process.versions.node; + if (NODE_JS) { + root = global; + } else if (WEB_WORKER) { + root = self; + } + var COMMON_JS = !root.JS_SHA256_NO_COMMON_JS && typeof module === "object" && module.exports; + var AMD = typeof define === "function" && define.amd; + var ARRAY_BUFFER = !root.JS_SHA256_NO_ARRAY_BUFFER && typeof ArrayBuffer !== "undefined"; + var HEX_CHARS = "0123456789abcdef".split(""); + var EXTRA = [-2147483648, 8388608, 32768, 128]; + var SHIFT = [24, 16, 8, 0]; + var K = [ + 1116352408, + 1899447441, + 3049323471, + 3921009573, + 961987163, + 1508970993, + 2453635748, + 2870763221, + 3624381080, + 310598401, + 607225278, + 1426881987, + 1925078388, + 2162078206, + 2614888103, + 3248222580, + 3835390401, + 4022224774, + 264347078, + 604807628, + 770255983, + 1249150122, + 1555081692, + 1996064986, + 2554220882, + 2821834349, + 2952996808, + 3210313671, + 3336571891, + 3584528711, + 113926993, + 338241895, + 666307205, + 773529912, + 1294757372, + 1396182291, + 1695183700, + 1986661051, + 2177026350, + 2456956037, + 2730485921, + 2820302411, + 3259730800, + 3345764771, + 3516065817, + 3600352804, + 4094571909, + 275423344, + 430227734, + 506948616, + 659060556, + 883997877, + 958139571, + 1322822218, + 1537002063, + 1747873779, + 1955562222, + 2024104815, + 2227730452, + 2361852424, + 2428436474, + 2756734187, + 3204031479, + 3329325298 + ]; + var OUTPUT_TYPES = ["hex", "array", "digest", "arrayBuffer"]; + var blocks = []; + if (root.JS_SHA256_NO_NODE_JS || !Array.isArray) { + Array.isArray = function(obj) { + return Object.prototype.toString.call(obj) === "[object Array]"; + }; + } + if (ARRAY_BUFFER && (root.JS_SHA256_NO_ARRAY_BUFFER_IS_VIEW || !ArrayBuffer.isView)) { + ArrayBuffer.isView = function(obj) { + return typeof obj === "object" && obj.buffer && obj.buffer.constructor === ArrayBuffer; + }; + } + var createOutputMethod = function(outputType, is2242) { + return function(message) { + return new Sha256(is2242, true).update(message)[outputType](); + }; + }; + var createMethod = function(is2242) { + var method2 = createOutputMethod("hex", is2242); + if (NODE_JS) { + method2 = nodeWrap(method2, is2242); + } + method2.create = function() { + return new Sha256(is2242); + }; + method2.update = function(message) { + return method2.create().update(message); + }; + for (var i = 0; i < OUTPUT_TYPES.length; ++i) { + var type = OUTPUT_TYPES[i]; + method2[type] = createOutputMethod(type, is2242); + } + return method2; + }; + var nodeWrap = function(method, is224) { + var crypto = eval("require('crypto')"); + var Buffer = eval("require('buffer').Buffer"); + var algorithm = is224 ? "sha224" : "sha256"; + var nodeMethod = function(message) { + if (typeof message === "string") { + return crypto.createHash(algorithm).update(message, "utf8").digest("hex"); + } else { + if (message === null || message === void 0) { + throw new Error(ERROR); + } else if (message.constructor === ArrayBuffer) { + message = new Uint8Array(message); + } + } + if (Array.isArray(message) || ArrayBuffer.isView(message) || message.constructor === Buffer) { + return crypto.createHash(algorithm).update(new Buffer(message)).digest("hex"); + } else { + return method(message); + } + }; + return nodeMethod; + }; + var createHmacOutputMethod = function(outputType, is2242) { + return function(key2, message) { + return new HmacSha256(key2, is2242, true).update(message)[outputType](); + }; + }; + var createHmacMethod = function(is2242) { + var method2 = createHmacOutputMethod("hex", is2242); + method2.create = function(key2) { + return new HmacSha256(key2, is2242); + }; + method2.update = function(key2, message) { + return method2.create(key2).update(message); + }; + for (var i = 0; i < OUTPUT_TYPES.length; ++i) { + var type = OUTPUT_TYPES[i]; + method2[type] = createHmacOutputMethod(type, is2242); + } + return method2; + }; + function Sha256(is2242, sharedMemory) { + if (sharedMemory) { + blocks[0] = blocks[16] = blocks[1] = blocks[2] = blocks[3] = blocks[4] = blocks[5] = blocks[6] = blocks[7] = blocks[8] = blocks[9] = blocks[10] = blocks[11] = blocks[12] = blocks[13] = blocks[14] = blocks[15] = 0; + this.blocks = blocks; + } else { + this.blocks = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]; + } + if (is2242) { + this.h0 = 3238371032; + this.h1 = 914150663; + this.h2 = 812702999; + this.h3 = 4144912697; + this.h4 = 4290775857; + this.h5 = 1750603025; + this.h6 = 1694076839; + this.h7 = 3204075428; + } else { + this.h0 = 1779033703; + this.h1 = 3144134277; + this.h2 = 1013904242; + this.h3 = 2773480762; + this.h4 = 1359893119; + this.h5 = 2600822924; + this.h6 = 528734635; + this.h7 = 1541459225; + } + this.block = this.start = this.bytes = this.hBytes = 0; + this.finalized = this.hashed = false; + this.first = true; + this.is224 = is2242; + } + Sha256.prototype.update = function(message) { + if (this.finalized) { + return; + } + var notString, type = typeof message; + if (type !== "string") { + if (type === "object") { + if (message === null) { + throw new Error(ERROR); + } else if (ARRAY_BUFFER && message.constructor === ArrayBuffer) { + message = new Uint8Array(message); + } else if (!Array.isArray(message)) { + if (!ARRAY_BUFFER || !ArrayBuffer.isView(message)) { + throw new Error(ERROR); + } + } + } else { + throw new Error(ERROR); + } + notString = true; + } + var code, index2 = 0, i, length = message.length, blocks2 = this.blocks; + while (index2 < length) { + if (this.hashed) { + this.hashed = false; + blocks2[0] = this.block; + blocks2[16] = blocks2[1] = blocks2[2] = blocks2[3] = blocks2[4] = blocks2[5] = blocks2[6] = blocks2[7] = blocks2[8] = blocks2[9] = blocks2[10] = blocks2[11] = blocks2[12] = blocks2[13] = blocks2[14] = blocks2[15] = 0; + } + if (notString) { + for (i = this.start; index2 < length && i < 64; ++index2) { + blocks2[i >> 2] |= message[index2] << SHIFT[i++ & 3]; + } + } else { + for (i = this.start; index2 < length && i < 64; ++index2) { + code = message.charCodeAt(index2); + if (code < 128) { + blocks2[i >> 2] |= code << SHIFT[i++ & 3]; + } else if (code < 2048) { + blocks2[i >> 2] |= (192 | code >> 6) << SHIFT[i++ & 3]; + blocks2[i >> 2] |= (128 | code & 63) << SHIFT[i++ & 3]; + } else if (code < 55296 || code >= 57344) { + blocks2[i >> 2] |= (224 | code >> 12) << SHIFT[i++ & 3]; + blocks2[i >> 2] |= (128 | code >> 6 & 63) << SHIFT[i++ & 3]; + blocks2[i >> 2] |= (128 | code & 63) << SHIFT[i++ & 3]; + } else { + code = 65536 + ((code & 1023) << 10 | message.charCodeAt(++index2) & 1023); + blocks2[i >> 2] |= (240 | code >> 18) << SHIFT[i++ & 3]; + blocks2[i >> 2] |= (128 | code >> 12 & 63) << SHIFT[i++ & 3]; + blocks2[i >> 2] |= (128 | code >> 6 & 63) << SHIFT[i++ & 3]; + blocks2[i >> 2] |= (128 | code & 63) << SHIFT[i++ & 3]; + } + } + } + this.lastByteIndex = i; + this.bytes += i - this.start; + if (i >= 64) { + this.block = blocks2[16]; + this.start = i - 64; + this.hash(); + this.hashed = true; + } else { + this.start = i; + } + } + if (this.bytes > 4294967295) { + this.hBytes += this.bytes / 4294967296 << 0; + this.bytes = this.bytes % 4294967296; + } + return this; + }; + Sha256.prototype.finalize = function() { + if (this.finalized) { + return; + } + this.finalized = true; + var blocks2 = this.blocks, i = this.lastByteIndex; + blocks2[16] = this.block; + blocks2[i >> 2] |= EXTRA[i & 3]; + this.block = blocks2[16]; + if (i >= 56) { + if (!this.hashed) { + this.hash(); + } + blocks2[0] = this.block; + blocks2[16] = blocks2[1] = blocks2[2] = blocks2[3] = blocks2[4] = blocks2[5] = blocks2[6] = blocks2[7] = blocks2[8] = blocks2[9] = blocks2[10] = blocks2[11] = blocks2[12] = blocks2[13] = blocks2[14] = blocks2[15] = 0; + } + blocks2[14] = this.hBytes << 3 | this.bytes >>> 29; + blocks2[15] = this.bytes << 3; + this.hash(); + }; + Sha256.prototype.hash = function() { + var a = this.h0, b = this.h1, c = this.h2, d = this.h3, e = this.h4, f = this.h5, g = this.h6, h = this.h7, blocks2 = this.blocks, j, s0, s1, maj, t1, t2, ch, ab, da, cd, bc; + for (j = 16; j < 64; ++j) { + t1 = blocks2[j - 15]; + s0 = (t1 >>> 7 | t1 << 25) ^ (t1 >>> 18 | t1 << 14) ^ t1 >>> 3; + t1 = blocks2[j - 2]; + s1 = (t1 >>> 17 | t1 << 15) ^ (t1 >>> 19 | t1 << 13) ^ t1 >>> 10; + blocks2[j] = blocks2[j - 16] + s0 + blocks2[j - 7] + s1 << 0; + } + bc = b & c; + for (j = 0; j < 64; j += 4) { + if (this.first) { + if (this.is224) { + ab = 300032; + t1 = blocks2[0] - 1413257819; + h = t1 - 150054599 << 0; + d = t1 + 24177077 << 0; + } else { + ab = 704751109; + t1 = blocks2[0] - 210244248; + h = t1 - 1521486534 << 0; + d = t1 + 143694565 << 0; + } + this.first = false; + } else { + s0 = (a >>> 2 | a << 30) ^ (a >>> 13 | a << 19) ^ (a >>> 22 | a << 10); + s1 = (e >>> 6 | e << 26) ^ (e >>> 11 | e << 21) ^ (e >>> 25 | e << 7); + ab = a & b; + maj = ab ^ a & c ^ bc; + ch = e & f ^ ~e & g; + t1 = h + s1 + ch + K[j] + blocks2[j]; + t2 = s0 + maj; + h = d + t1 << 0; + d = t1 + t2 << 0; + } + s0 = (d >>> 2 | d << 30) ^ (d >>> 13 | d << 19) ^ (d >>> 22 | d << 10); + s1 = (h >>> 6 | h << 26) ^ (h >>> 11 | h << 21) ^ (h >>> 25 | h << 7); + da = d & a; + maj = da ^ d & b ^ ab; + ch = h & e ^ ~h & f; + t1 = g + s1 + ch + K[j + 1] + blocks2[j + 1]; + t2 = s0 + maj; + g = c + t1 << 0; + c = t1 + t2 << 0; + s0 = (c >>> 2 | c << 30) ^ (c >>> 13 | c << 19) ^ (c >>> 22 | c << 10); + s1 = (g >>> 6 | g << 26) ^ (g >>> 11 | g << 21) ^ (g >>> 25 | g << 7); + cd = c & d; + maj = cd ^ c & a ^ da; + ch = g & h ^ ~g & e; + t1 = f + s1 + ch + K[j + 2] + blocks2[j + 2]; + t2 = s0 + maj; + f = b + t1 << 0; + b = t1 + t2 << 0; + s0 = (b >>> 2 | b << 30) ^ (b >>> 13 | b << 19) ^ (b >>> 22 | b << 10); + s1 = (f >>> 6 | f << 26) ^ (f >>> 11 | f << 21) ^ (f >>> 25 | f << 7); + bc = b & c; + maj = bc ^ b & d ^ cd; + ch = f & g ^ ~f & h; + t1 = e + s1 + ch + K[j + 3] + blocks2[j + 3]; + t2 = s0 + maj; + e = a + t1 << 0; + a = t1 + t2 << 0; + } + this.h0 = this.h0 + a << 0; + this.h1 = this.h1 + b << 0; + this.h2 = this.h2 + c << 0; + this.h3 = this.h3 + d << 0; + this.h4 = this.h4 + e << 0; + this.h5 = this.h5 + f << 0; + this.h6 = this.h6 + g << 0; + this.h7 = this.h7 + h << 0; + }; + Sha256.prototype.hex = function() { + this.finalize(); + var h0 = this.h0, h1 = this.h1, h2 = this.h2, h3 = this.h3, h4 = this.h4, h5 = this.h5, h6 = this.h6, h7 = this.h7; + var hex = HEX_CHARS[h0 >> 28 & 15] + HEX_CHARS[h0 >> 24 & 15] + HEX_CHARS[h0 >> 20 & 15] + HEX_CHARS[h0 >> 16 & 15] + HEX_CHARS[h0 >> 12 & 15] + HEX_CHARS[h0 >> 8 & 15] + HEX_CHARS[h0 >> 4 & 15] + HEX_CHARS[h0 & 15] + HEX_CHARS[h1 >> 28 & 15] + HEX_CHARS[h1 >> 24 & 15] + HEX_CHARS[h1 >> 20 & 15] + HEX_CHARS[h1 >> 16 & 15] + HEX_CHARS[h1 >> 12 & 15] + HEX_CHARS[h1 >> 8 & 15] + HEX_CHARS[h1 >> 4 & 15] + HEX_CHARS[h1 & 15] + HEX_CHARS[h2 >> 28 & 15] + HEX_CHARS[h2 >> 24 & 15] + HEX_CHARS[h2 >> 20 & 15] + HEX_CHARS[h2 >> 16 & 15] + HEX_CHARS[h2 >> 12 & 15] + HEX_CHARS[h2 >> 8 & 15] + HEX_CHARS[h2 >> 4 & 15] + HEX_CHARS[h2 & 15] + HEX_CHARS[h3 >> 28 & 15] + HEX_CHARS[h3 >> 24 & 15] + HEX_CHARS[h3 >> 20 & 15] + HEX_CHARS[h3 >> 16 & 15] + HEX_CHARS[h3 >> 12 & 15] + HEX_CHARS[h3 >> 8 & 15] + HEX_CHARS[h3 >> 4 & 15] + HEX_CHARS[h3 & 15] + HEX_CHARS[h4 >> 28 & 15] + HEX_CHARS[h4 >> 24 & 15] + HEX_CHARS[h4 >> 20 & 15] + HEX_CHARS[h4 >> 16 & 15] + HEX_CHARS[h4 >> 12 & 15] + HEX_CHARS[h4 >> 8 & 15] + HEX_CHARS[h4 >> 4 & 15] + HEX_CHARS[h4 & 15] + HEX_CHARS[h5 >> 28 & 15] + HEX_CHARS[h5 >> 24 & 15] + HEX_CHARS[h5 >> 20 & 15] + HEX_CHARS[h5 >> 16 & 15] + HEX_CHARS[h5 >> 12 & 15] + HEX_CHARS[h5 >> 8 & 15] + HEX_CHARS[h5 >> 4 & 15] + HEX_CHARS[h5 & 15] + HEX_CHARS[h6 >> 28 & 15] + HEX_CHARS[h6 >> 24 & 15] + HEX_CHARS[h6 >> 20 & 15] + HEX_CHARS[h6 >> 16 & 15] + HEX_CHARS[h6 >> 12 & 15] + HEX_CHARS[h6 >> 8 & 15] + HEX_CHARS[h6 >> 4 & 15] + HEX_CHARS[h6 & 15]; + if (!this.is224) { + hex += HEX_CHARS[h7 >> 28 & 15] + HEX_CHARS[h7 >> 24 & 15] + HEX_CHARS[h7 >> 20 & 15] + HEX_CHARS[h7 >> 16 & 15] + HEX_CHARS[h7 >> 12 & 15] + HEX_CHARS[h7 >> 8 & 15] + HEX_CHARS[h7 >> 4 & 15] + HEX_CHARS[h7 & 15]; + } + return hex; + }; + Sha256.prototype.toString = Sha256.prototype.hex; + Sha256.prototype.digest = function() { + this.finalize(); + var h0 = this.h0, h1 = this.h1, h2 = this.h2, h3 = this.h3, h4 = this.h4, h5 = this.h5, h6 = this.h6, h7 = this.h7; + var arr = [ + h0 >> 24 & 255, + h0 >> 16 & 255, + h0 >> 8 & 255, + h0 & 255, + h1 >> 24 & 255, + h1 >> 16 & 255, + h1 >> 8 & 255, + h1 & 255, + h2 >> 24 & 255, + h2 >> 16 & 255, + h2 >> 8 & 255, + h2 & 255, + h3 >> 24 & 255, + h3 >> 16 & 255, + h3 >> 8 & 255, + h3 & 255, + h4 >> 24 & 255, + h4 >> 16 & 255, + h4 >> 8 & 255, + h4 & 255, + h5 >> 24 & 255, + h5 >> 16 & 255, + h5 >> 8 & 255, + h5 & 255, + h6 >> 24 & 255, + h6 >> 16 & 255, + h6 >> 8 & 255, + h6 & 255 + ]; + if (!this.is224) { + arr.push(h7 >> 24 & 255, h7 >> 16 & 255, h7 >> 8 & 255, h7 & 255); + } + return arr; + }; + Sha256.prototype.array = Sha256.prototype.digest; + Sha256.prototype.arrayBuffer = function() { + this.finalize(); + var buffer2 = new ArrayBuffer(this.is224 ? 28 : 32); + var dataView = new DataView(buffer2); + dataView.setUint32(0, this.h0); + dataView.setUint32(4, this.h1); + dataView.setUint32(8, this.h2); + dataView.setUint32(12, this.h3); + dataView.setUint32(16, this.h4); + dataView.setUint32(20, this.h5); + dataView.setUint32(24, this.h6); + if (!this.is224) { + dataView.setUint32(28, this.h7); + } + return buffer2; + }; + function HmacSha256(key2, is2242, sharedMemory) { + var i, type = typeof key2; + if (type === "string") { + var bytes = [], length = key2.length, index2 = 0, code; + for (i = 0; i < length; ++i) { + code = key2.charCodeAt(i); + if (code < 128) { + bytes[index2++] = code; + } else if (code < 2048) { + bytes[index2++] = 192 | code >> 6; + bytes[index2++] = 128 | code & 63; + } else if (code < 55296 || code >= 57344) { + bytes[index2++] = 224 | code >> 12; + bytes[index2++] = 128 | code >> 6 & 63; + bytes[index2++] = 128 | code & 63; + } else { + code = 65536 + ((code & 1023) << 10 | key2.charCodeAt(++i) & 1023); + bytes[index2++] = 240 | code >> 18; + bytes[index2++] = 128 | code >> 12 & 63; + bytes[index2++] = 128 | code >> 6 & 63; + bytes[index2++] = 128 | code & 63; + } + } + key2 = bytes; + } else { + if (type === "object") { + if (key2 === null) { + throw new Error(ERROR); + } else if (ARRAY_BUFFER && key2.constructor === ArrayBuffer) { + key2 = new Uint8Array(key2); + } else if (!Array.isArray(key2)) { + if (!ARRAY_BUFFER || !ArrayBuffer.isView(key2)) { + throw new Error(ERROR); + } + } + } else { + throw new Error(ERROR); + } + } + if (key2.length > 64) { + key2 = new Sha256(is2242, true).update(key2).array(); + } + var oKeyPad = [], iKeyPad = []; + for (i = 0; i < 64; ++i) { + var b = key2[i] || 0; + oKeyPad[i] = 92 ^ b; + iKeyPad[i] = 54 ^ b; + } + Sha256.call(this, is2242, sharedMemory); + this.update(iKeyPad); + this.oKeyPad = oKeyPad; + this.inner = true; + this.sharedMemory = sharedMemory; + } + HmacSha256.prototype = new Sha256(); + HmacSha256.prototype.finalize = function() { + Sha256.prototype.finalize.call(this); + if (this.inner) { + this.inner = false; + var innerHash = this.array(); + Sha256.call(this, this.is224, this.sharedMemory); + this.update(this.oKeyPad); + this.update(innerHash); + Sha256.prototype.finalize.call(this); + } + }; + var exports = createMethod(); + exports.sha256 = exports; + exports.sha224 = createMethod(true); + exports.sha256.hmac = createHmacMethod(); + exports.sha224.hmac = createHmacMethod(true); + if (COMMON_JS) { + module.exports = exports; + } else { + root.sha256 = exports.sha256; + root.sha224 = exports.sha224; + if (AMD) { + define(function() { + return exports; + }); + } + } + })(); + } +}); + +// node_modules/.pnpm/hogan.js@3.0.2/node_modules/hogan.js/lib/compiler.js +var require_compiler = __commonJS({ + "node_modules/.pnpm/hogan.js@3.0.2/node_modules/hogan.js/lib/compiler.js"(exports2) { + init_polyfill_buffer(); + (function(Hogan4) { + var rIsWhitespace = /\S/, rQuot = /\"/g, rNewline = /\n/g, rCr = /\r/g, rSlash = /\\/g, rLineSep = /\u2028/, rParagraphSep = /\u2029/; + Hogan4.tags = { + "#": 1, + "^": 2, + "<": 3, + "$": 4, + "/": 5, + "!": 6, + ">": 7, + "=": 8, + "_v": 9, + "{": 10, + "&": 11, + "_t": 12 + }; + Hogan4.scan = function scan(text2, delimiters) { + var len = text2.length, IN_TEXT = 0, IN_TAG_TYPE = 1, IN_TAG = 2, state = IN_TEXT, tagType = null, tag2 = null, buf = "", tokens = [], seenTag = false, i = 0, lineStart = 0, otag = "{{", ctag = "}}"; + function addBuf() { + if (buf.length > 0) { + tokens.push({ tag: "_t", text: new String(buf) }); + buf = ""; + } + } + function lineIsWhitespace() { + var isAllWhitespace = true; + for (var j = lineStart; j < tokens.length; j++) { + isAllWhitespace = Hogan4.tags[tokens[j].tag] < Hogan4.tags["_v"] || tokens[j].tag == "_t" && tokens[j].text.match(rIsWhitespace) === null; + if (!isAllWhitespace) { + return false; + } + } + return isAllWhitespace; + } + function filterLine(haveSeenTag, noNewLine) { + addBuf(); + if (haveSeenTag && lineIsWhitespace()) { + for (var j = lineStart, next; j < tokens.length; j++) { + if (tokens[j].text) { + if ((next = tokens[j + 1]) && next.tag == ">") { + next.indent = tokens[j].text.toString(); + } + tokens.splice(j, 1); + } + } + } else if (!noNewLine) { + tokens.push({ tag: "\n" }); + } + seenTag = false; + lineStart = tokens.length; + } + function changeDelimiters(text3, index2) { + var close = "=" + ctag, closeIndex = text3.indexOf(close, index2), delimiters2 = trim( + text3.substring(text3.indexOf("=", index2) + 1, closeIndex) + ).split(" "); + otag = delimiters2[0]; + ctag = delimiters2[delimiters2.length - 1]; + return closeIndex + close.length - 1; + } + if (delimiters) { + delimiters = delimiters.split(" "); + otag = delimiters[0]; + ctag = delimiters[1]; + } + for (i = 0; i < len; i++) { + if (state == IN_TEXT) { + if (tagChange(otag, text2, i)) { + --i; + addBuf(); + state = IN_TAG_TYPE; + } else { + if (text2.charAt(i) == "\n") { + filterLine(seenTag); + } else { + buf += text2.charAt(i); + } + } + } else if (state == IN_TAG_TYPE) { + i += otag.length - 1; + tag2 = Hogan4.tags[text2.charAt(i + 1)]; + tagType = tag2 ? text2.charAt(i + 1) : "_v"; + if (tagType == "=") { + i = changeDelimiters(text2, i); + state = IN_TEXT; + } else { + if (tag2) { + i++; + } + state = IN_TAG; + } + seenTag = i; + } else { + if (tagChange(ctag, text2, i)) { + tokens.push({ + tag: tagType, + n: trim(buf), + otag, + ctag, + i: tagType == "/" ? seenTag - otag.length : i + ctag.length + }); + buf = ""; + i += ctag.length - 1; + state = IN_TEXT; + if (tagType == "{") { + if (ctag == "}}") { + i++; + } else { + cleanTripleStache(tokens[tokens.length - 1]); + } + } + } else { + buf += text2.charAt(i); + } + } + } + filterLine(seenTag, true); + return tokens; + }; + function cleanTripleStache(token) { + if (token.n.substr(token.n.length - 1) === "}") { + token.n = token.n.substring(0, token.n.length - 1); + } + } + function trim(s) { + if (s.trim) { + return s.trim(); + } + return s.replace(/^\s*|\s*$/g, ""); + } + function tagChange(tag2, text2, index2) { + if (text2.charAt(index2) != tag2.charAt(0)) { + return false; + } + for (var i = 1, l = tag2.length; i < l; i++) { + if (text2.charAt(index2 + i) != tag2.charAt(i)) { + return false; + } + } + return true; + } + var allowedInSuper = { "_t": true, "\n": true, "$": true, "/": true }; + function buildTree(tokens, kind, stack, customTags) { + var instructions = [], opener = null, tail = null, token = null; + tail = stack[stack.length - 1]; + while (tokens.length > 0) { + token = tokens.shift(); + if (tail && tail.tag == "<" && !(token.tag in allowedInSuper)) { + throw new Error("Illegal content in < super tag."); + } + if (Hogan4.tags[token.tag] <= Hogan4.tags["$"] || isOpener(token, customTags)) { + stack.push(token); + token.nodes = buildTree(tokens, token.tag, stack, customTags); + } else if (token.tag == "/") { + if (stack.length === 0) { + throw new Error("Closing tag without opener: /" + token.n); + } + opener = stack.pop(); + if (token.n != opener.n && !isCloser(token.n, opener.n, customTags)) { + throw new Error("Nesting error: " + opener.n + " vs. " + token.n); + } + opener.end = token.i; + return instructions; + } else if (token.tag == "\n") { + token.last = tokens.length == 0 || tokens[0].tag == "\n"; + } + instructions.push(token); + } + if (stack.length > 0) { + throw new Error("missing closing tag: " + stack.pop().n); + } + return instructions; + } + function isOpener(token, tags) { + for (var i = 0, l = tags.length; i < l; i++) { + if (tags[i].o == token.n) { + token.tag = "#"; + return true; + } + } + } + function isCloser(close, open, tags) { + for (var i = 0, l = tags.length; i < l; i++) { + if (tags[i].c == close && tags[i].o == open) { + return true; + } + } + } + function stringifySubstitutions(obj) { + var items = []; + for (var key2 in obj) { + items.push('"' + esc(key2) + '": function(c,p,t,i) {' + obj[key2] + "}"); + } + return "{ " + items.join(",") + " }"; + } + function stringifyPartials(codeObj) { + var partials = []; + for (var key2 in codeObj.partials) { + partials.push('"' + esc(key2) + '":{name:"' + esc(codeObj.partials[key2].name) + '", ' + stringifyPartials(codeObj.partials[key2]) + "}"); + } + return "partials: {" + partials.join(",") + "}, subs: " + stringifySubstitutions(codeObj.subs); + } + Hogan4.stringify = function(codeObj, text2, options) { + return "{code: function (c,p,i) { " + Hogan4.wrapMain(codeObj.code) + " }," + stringifyPartials(codeObj) + "}"; + }; + var serialNo = 0; + Hogan4.generate = function(tree, text2, options) { + serialNo = 0; + var context = { code: "", subs: {}, partials: {} }; + Hogan4.walk(tree, context); + if (options.asString) { + return this.stringify(context, text2, options); + } + return this.makeTemplate(context, text2, options); + }; + Hogan4.wrapMain = function(code) { + return 'var t=this;t.b(i=i||"");' + code + "return t.fl();"; + }; + Hogan4.template = Hogan4.Template; + Hogan4.makeTemplate = function(codeObj, text2, options) { + var template = this.makePartials(codeObj); + template.code = new Function("c", "p", "i", this.wrapMain(codeObj.code)); + return new this.template(template, text2, this, options); + }; + Hogan4.makePartials = function(codeObj) { + var key2, template = { subs: {}, partials: codeObj.partials, name: codeObj.name }; + for (key2 in template.partials) { + template.partials[key2] = this.makePartials(template.partials[key2]); + } + for (key2 in codeObj.subs) { + template.subs[key2] = new Function("c", "p", "t", "i", codeObj.subs[key2]); + } + return template; + }; + function esc(s) { + return s.replace(rSlash, "\\\\").replace(rQuot, '\\"').replace(rNewline, "\\n").replace(rCr, "\\r").replace(rLineSep, "\\u2028").replace(rParagraphSep, "\\u2029"); + } + function chooseMethod(s) { + return ~s.indexOf(".") ? "d" : "f"; + } + function createPartial(node, context) { + var prefix = "<" + (context.prefix || ""); + var sym = prefix + node.n + serialNo++; + context.partials[sym] = { name: node.n, partials: {} }; + context.code += 't.b(t.rp("' + esc(sym) + '",c,p,"' + (node.indent || "") + '"));'; + return sym; + } + Hogan4.codegen = { + "#": function(node, context) { + context.code += "if(t.s(t." + chooseMethod(node.n) + '("' + esc(node.n) + '",c,p,1),c,p,0,' + node.i + "," + node.end + ',"' + node.otag + " " + node.ctag + '")){t.rs(c,p,function(c,p,t){'; + Hogan4.walk(node.nodes, context); + context.code += "});c.pop();}"; + }, + "^": function(node, context) { + context.code += "if(!t.s(t." + chooseMethod(node.n) + '("' + esc(node.n) + '",c,p,1),c,p,1,0,0,"")){'; + Hogan4.walk(node.nodes, context); + context.code += "};"; + }, + ">": createPartial, + "<": function(node, context) { + var ctx = { partials: {}, code: "", subs: {}, inPartial: true }; + Hogan4.walk(node.nodes, ctx); + var template = context.partials[createPartial(node, context)]; + template.subs = ctx.subs; + template.partials = ctx.partials; + }, + "$": function(node, context) { + var ctx = { subs: {}, code: "", partials: context.partials, prefix: node.n }; + Hogan4.walk(node.nodes, ctx); + context.subs[node.n] = ctx.code; + if (!context.inPartial) { + context.code += 't.sub("' + esc(node.n) + '",c,p,i);'; + } + }, + "\n": function(node, context) { + context.code += write('"\\n"' + (node.last ? "" : " + i")); + }, + "_v": function(node, context) { + context.code += "t.b(t.v(t." + chooseMethod(node.n) + '("' + esc(node.n) + '",c,p,0)));'; + }, + "_t": function(node, context) { + context.code += write('"' + esc(node.text) + '"'); + }, + "{": tripleStache, + "&": tripleStache + }; + function tripleStache(node, context) { + context.code += "t.b(t.t(t." + chooseMethod(node.n) + '("' + esc(node.n) + '",c,p,0)));'; + } + function write(s) { + return "t.b(" + s + ");"; + } + Hogan4.walk = function(nodelist, context) { + var func; + for (var i = 0, l = nodelist.length; i < l; i++) { + func = Hogan4.codegen[nodelist[i].tag]; + func && func(nodelist[i], context); + } + return context; + }; + Hogan4.parse = function(tokens, text2, options) { + options = options || {}; + return buildTree(tokens, "", [], options.sectionTags || []); + }; + Hogan4.cache = {}; + Hogan4.cacheKey = function(text2, options) { + return [text2, !!options.asString, !!options.disableLambda, options.delimiters, !!options.modelGet].join("||"); + }; + Hogan4.compile = function(text2, options) { + options = options || {}; + var key2 = Hogan4.cacheKey(text2, options); + var template = this.cache[key2]; + if (template) { + var partials = template.partials; + for (var name in partials) { + delete partials[name].instance; + } + return template; + } + template = this.generate(this.parse(this.scan(text2, options.delimiters), text2, options), text2, options); + return this.cache[key2] = template; + }; + })(typeof exports2 !== "undefined" ? exports2 : Hogan); + } +}); + +// node_modules/.pnpm/hogan.js@3.0.2/node_modules/hogan.js/lib/template.js +var require_template = __commonJS({ + "node_modules/.pnpm/hogan.js@3.0.2/node_modules/hogan.js/lib/template.js"(exports2) { + init_polyfill_buffer(); + var Hogan4 = {}; + (function(Hogan5) { + Hogan5.Template = function(codeObj, text2, compiler, options) { + codeObj = codeObj || {}; + this.r = codeObj.code || this.r; + this.c = compiler; + this.options = options || {}; + this.text = text2 || ""; + this.partials = codeObj.partials || {}; + this.subs = codeObj.subs || {}; + this.buf = ""; + }; + Hogan5.Template.prototype = { + // render: replaced by generated code. + r: function(context, partials, indent2) { + return ""; + }, + // variable escaping + v: hoganEscape, + // triple stache + t: coerceToString, + render: function render2(context, partials, indent2) { + return this.ri([context], partials || {}, indent2); + }, + // render internal -- a hook for overrides that catches partials too + ri: function(context, partials, indent2) { + return this.r(context, partials, indent2); + }, + // ensurePartial + ep: function(symbol, partials) { + var partial = this.partials[symbol]; + var template = partials[partial.name]; + if (partial.instance && partial.base == template) { + return partial.instance; + } + if (typeof template == "string") { + if (!this.c) { + throw new Error("No compiler available."); + } + template = this.c.compile(template, this.options); + } + if (!template) { + return null; + } + this.partials[symbol].base = template; + if (partial.subs) { + if (!partials.stackText) + partials.stackText = {}; + for (key in partial.subs) { + if (!partials.stackText[key]) { + partials.stackText[key] = this.activeSub !== void 0 && partials.stackText[this.activeSub] ? partials.stackText[this.activeSub] : this.text; + } + } + template = createSpecializedPartial( + template, + partial.subs, + partial.partials, + this.stackSubs, + this.stackPartials, + partials.stackText + ); + } + this.partials[symbol].instance = template; + return template; + }, + // tries to find a partial in the current scope and render it + rp: function(symbol, context, partials, indent2) { + var partial = this.ep(symbol, partials); + if (!partial) { + return ""; + } + return partial.ri(context, partials, indent2); + }, + // render a section + rs: function(context, partials, section) { + var tail = context[context.length - 1]; + if (!isArray(tail)) { + section(context, partials, this); + return; + } + for (var i = 0; i < tail.length; i++) { + context.push(tail[i]); + section(context, partials, this); + context.pop(); + } + }, + // maybe start a section + s: function(val, ctx, partials, inverted, start, end, tags) { + var pass; + if (isArray(val) && val.length === 0) { + return false; + } + if (typeof val == "function") { + val = this.ms(val, ctx, partials, inverted, start, end, tags); + } + pass = !!val; + if (!inverted && pass && ctx) { + ctx.push(typeof val == "object" ? val : ctx[ctx.length - 1]); + } + return pass; + }, + // find values with dotted names + d: function(key2, ctx, partials, returnFound) { + var found, names = key2.split("."), val = this.f(names[0], ctx, partials, returnFound), doModelGet = this.options.modelGet, cx = null; + if (key2 === "." && isArray(ctx[ctx.length - 2])) { + val = ctx[ctx.length - 1]; + } else { + for (var i = 1; i < names.length; i++) { + found = findInScope(names[i], val, doModelGet); + if (found !== void 0) { + cx = val; + val = found; + } else { + val = ""; + } + } + } + if (returnFound && !val) { + return false; + } + if (!returnFound && typeof val == "function") { + ctx.push(cx); + val = this.mv(val, ctx, partials); + ctx.pop(); + } + return val; + }, + // find values with normal names + f: function(key2, ctx, partials, returnFound) { + var val = false, v = null, found = false, doModelGet = this.options.modelGet; + for (var i = ctx.length - 1; i >= 0; i--) { + v = ctx[i]; + val = findInScope(key2, v, doModelGet); + if (val !== void 0) { + found = true; + break; + } + } + if (!found) { + return returnFound ? false : ""; + } + if (!returnFound && typeof val == "function") { + val = this.mv(val, ctx, partials); + } + return val; + }, + // higher order templates + ls: function(func, cx, partials, text2, tags) { + var oldTags = this.options.delimiters; + this.options.delimiters = tags; + this.b(this.ct(coerceToString(func.call(cx, text2)), cx, partials)); + this.options.delimiters = oldTags; + return false; + }, + // compile text + ct: function(text2, cx, partials) { + if (this.options.disableLambda) { + throw new Error("Lambda features disabled."); + } + return this.c.compile(text2, this.options).render(cx, partials); + }, + // template result buffering + b: function(s) { + this.buf += s; + }, + fl: function() { + var r = this.buf; + this.buf = ""; + return r; + }, + // method replace section + ms: function(func, ctx, partials, inverted, start, end, tags) { + var textSource, cx = ctx[ctx.length - 1], result = func.call(cx); + if (typeof result == "function") { + if (inverted) { + return true; + } else { + textSource = this.activeSub && this.subsText && this.subsText[this.activeSub] ? this.subsText[this.activeSub] : this.text; + return this.ls(result, cx, partials, textSource.substring(start, end), tags); + } + } + return result; + }, + // method replace variable + mv: function(func, ctx, partials) { + var cx = ctx[ctx.length - 1]; + var result = func.call(cx); + if (typeof result == "function") { + return this.ct(coerceToString(result.call(cx)), cx, partials); + } + return result; + }, + sub: function(name, context, partials, indent2) { + var f = this.subs[name]; + if (f) { + this.activeSub = name; + f(context, partials, this, indent2); + this.activeSub = false; + } + } + }; + function findInScope(key2, scope, doModelGet) { + var val; + if (scope && typeof scope == "object") { + if (scope[key2] !== void 0) { + val = scope[key2]; + } else if (doModelGet && scope.get && typeof scope.get == "function") { + val = scope.get(key2); + } + } + return val; + } + function createSpecializedPartial(instance10, subs, partials, stackSubs, stackPartials, stackText) { + function PartialTemplate() { + } + ; + PartialTemplate.prototype = instance10; + function Substitutions() { + } + ; + Substitutions.prototype = instance10.subs; + var key2; + var partial = new PartialTemplate(); + partial.subs = new Substitutions(); + partial.subsText = {}; + partial.buf = ""; + stackSubs = stackSubs || {}; + partial.stackSubs = stackSubs; + partial.subsText = stackText; + for (key2 in subs) { + if (!stackSubs[key2]) + stackSubs[key2] = subs[key2]; + } + for (key2 in stackSubs) { + partial.subs[key2] = stackSubs[key2]; + } + stackPartials = stackPartials || {}; + partial.stackPartials = stackPartials; + for (key2 in partials) { + if (!stackPartials[key2]) + stackPartials[key2] = partials[key2]; + } + for (key2 in stackPartials) { + partial.partials[key2] = stackPartials[key2]; + } + return partial; + } + var rAmp = /&/g, rLt = //g, rApos = /\'/g, rQuot = /\"/g, hChars = /[&<>\"\']/; + function coerceToString(val) { + return String(val === null || val === void 0 ? "" : val); + } + function hoganEscape(str) { + str = coerceToString(str); + return hChars.test(str) ? str.replace(rAmp, "&").replace(rLt, "<").replace(rGt, ">").replace(rApos, "'").replace(rQuot, """) : str; + } + var isArray = Array.isArray || function(a) { + return Object.prototype.toString.call(a) === "[object Array]"; + }; + })(typeof exports2 !== "undefined" ? exports2 : Hogan4); + } +}); + +// node_modules/.pnpm/hogan.js@3.0.2/node_modules/hogan.js/lib/hogan.js +var require_hogan = __commonJS({ + "node_modules/.pnpm/hogan.js@3.0.2/node_modules/hogan.js/lib/hogan.js"(exports2, module2) { + init_polyfill_buffer(); + var Hogan4 = require_compiler(); + Hogan4.Template = require_template().Template; + Hogan4.template = Hogan4.Template; + module2.exports = Hogan4; + } +}); + +// node_modules/.pnpm/feather-icons@4.29.1/node_modules/feather-icons/dist/feather.js +var require_feather = __commonJS({ + "node_modules/.pnpm/feather-icons@4.29.1/node_modules/feather-icons/dist/feather.js"(exports2, module2) { + init_polyfill_buffer(); + (function webpackUniversalModuleDefinition(root2, factory) { + if (typeof exports2 === "object" && typeof module2 === "object") + module2.exports = factory(); + else if (typeof define === "function" && define.amd) + define([], factory); + else if (typeof exports2 === "object") + exports2["feather"] = factory(); + else + root2["feather"] = factory(); + })(typeof self !== "undefined" ? self : exports2, function() { + return ( + /******/ + function(modules) { + var installedModules = {}; + function __webpack_require__(moduleId) { + if (installedModules[moduleId]) { + return installedModules[moduleId].exports; + } + var module3 = installedModules[moduleId] = { + /******/ + i: moduleId, + /******/ + l: false, + /******/ + exports: {} + /******/ + }; + modules[moduleId].call(module3.exports, module3, module3.exports, __webpack_require__); + module3.l = true; + return module3.exports; + } + __webpack_require__.m = modules; + __webpack_require__.c = installedModules; + __webpack_require__.d = function(exports3, name, getter) { + if (!__webpack_require__.o(exports3, name)) { + Object.defineProperty(exports3, name, { + /******/ + configurable: false, + /******/ + enumerable: true, + /******/ + get: getter + /******/ + }); + } + }; + __webpack_require__.r = function(exports3) { + Object.defineProperty(exports3, "__esModule", { value: true }); + }; + __webpack_require__.n = function(module3) { + var getter = module3 && module3.__esModule ? ( + /******/ + function getDefault() { + return module3["default"]; + } + ) : ( + /******/ + function getModuleExports() { + return module3; + } + ); + __webpack_require__.d(getter, "a", getter); + return getter; + }; + __webpack_require__.o = function(object, property) { + return Object.prototype.hasOwnProperty.call(object, property); + }; + __webpack_require__.p = ""; + return __webpack_require__(__webpack_require__.s = 0); + }({ + /***/ + "./dist/icons.json": ( + /*!*************************!*\ + !*** ./dist/icons.json ***! + \*************************/ + /*! exports provided: activity, airplay, alert-circle, alert-octagon, alert-triangle, align-center, align-justify, align-left, align-right, anchor, aperture, archive, arrow-down-circle, arrow-down-left, arrow-down-right, arrow-down, arrow-left-circle, arrow-left, arrow-right-circle, arrow-right, arrow-up-circle, arrow-up-left, arrow-up-right, arrow-up, at-sign, award, bar-chart-2, bar-chart, battery-charging, battery, bell-off, bell, bluetooth, bold, book-open, book, bookmark, box, briefcase, calendar, camera-off, camera, cast, check-circle, check-square, check, chevron-down, chevron-left, chevron-right, chevron-up, chevrons-down, chevrons-left, chevrons-right, chevrons-up, chrome, circle, clipboard, clock, cloud-drizzle, cloud-lightning, cloud-off, cloud-rain, cloud-snow, cloud, code, codepen, codesandbox, coffee, columns, command, compass, copy, corner-down-left, corner-down-right, corner-left-down, corner-left-up, corner-right-down, corner-right-up, corner-up-left, corner-up-right, cpu, credit-card, crop, crosshair, database, delete, disc, divide-circle, divide-square, divide, dollar-sign, download-cloud, download, dribbble, droplet, edit-2, edit-3, edit, external-link, eye-off, eye, facebook, fast-forward, feather, figma, file-minus, file-plus, file-text, file, film, filter, flag, folder-minus, folder-plus, folder, framer, frown, gift, git-branch, git-commit, git-merge, git-pull-request, github, gitlab, globe, grid, hard-drive, hash, headphones, heart, help-circle, hexagon, home, image, inbox, info, instagram, italic, key, layers, layout, life-buoy, link-2, link, linkedin, list, loader, lock, log-in, log-out, mail, map-pin, map, maximize-2, maximize, meh, menu, message-circle, message-square, mic-off, mic, minimize-2, minimize, minus-circle, minus-square, minus, monitor, moon, more-horizontal, more-vertical, mouse-pointer, move, music, navigation-2, navigation, octagon, package, paperclip, pause-circle, pause, pen-tool, percent, phone-call, phone-forwarded, phone-incoming, phone-missed, phone-off, phone-outgoing, phone, pie-chart, play-circle, play, plus-circle, plus-square, plus, pocket, power, printer, radio, refresh-ccw, refresh-cw, repeat, rewind, rotate-ccw, rotate-cw, rss, save, scissors, search, send, server, settings, share-2, share, shield-off, shield, shopping-bag, shopping-cart, shuffle, sidebar, skip-back, skip-forward, slack, slash, sliders, smartphone, smile, speaker, square, star, stop-circle, sun, sunrise, sunset, table, tablet, tag, target, terminal, thermometer, thumbs-down, thumbs-up, toggle-left, toggle-right, tool, trash-2, trash, trello, trending-down, trending-up, triangle, truck, tv, twitch, twitter, type, umbrella, underline, unlock, upload-cloud, upload, user-check, user-minus, user-plus, user-x, user, users, video-off, video, voicemail, volume-1, volume-2, volume-x, volume, watch, wifi-off, wifi, wind, x-circle, x-octagon, x-square, x, youtube, zap-off, zap, zoom-in, zoom-out, default */ + /***/ + function(module3) { + module3.exports = { "activity": '', "airplay": '', "alert-circle": '', "alert-octagon": '', "alert-triangle": '', "align-center": '', "align-justify": '', "align-left": '', "align-right": '', "anchor": '', "aperture": '', "archive": '', "arrow-down-circle": '', "arrow-down-left": '', "arrow-down-right": '', "arrow-down": '', "arrow-left-circle": '', "arrow-left": '', "arrow-right-circle": '', "arrow-right": '', "arrow-up-circle": '', "arrow-up-left": '', "arrow-up-right": '', "arrow-up": '', "at-sign": '', "award": '', "bar-chart-2": '', "bar-chart": '', "battery-charging": '', "battery": '', "bell-off": '', "bell": '', "bluetooth": '', "bold": '', "book-open": '', "book": '', "bookmark": '', "box": '', "briefcase": '', "calendar": '', "camera-off": '', "camera": '', "cast": '', "check-circle": '', "check-square": '', "check": '', "chevron-down": '', "chevron-left": '', "chevron-right": '', "chevron-up": '', "chevrons-down": '', "chevrons-left": '', "chevrons-right": '', "chevrons-up": '', "chrome": '', "circle": '', "clipboard": '', "clock": '', "cloud-drizzle": '', "cloud-lightning": '', "cloud-off": '', "cloud-rain": '', "cloud-snow": '', "cloud": '', "code": '', "codepen": '', "codesandbox": '', "coffee": '', "columns": '', "command": '', "compass": '', "copy": '', "corner-down-left": '', "corner-down-right": '', "corner-left-down": '', "corner-left-up": '', "corner-right-down": '', "corner-right-up": '', "corner-up-left": '', "corner-up-right": '', "cpu": '', "credit-card": '', "crop": '', "crosshair": '', "database": '', "delete": '', "disc": '', "divide-circle": '', "divide-square": '', "divide": '', "dollar-sign": '', "download-cloud": '', "download": '', "dribbble": '', "droplet": '', "edit-2": '', "edit-3": '', "edit": '', "external-link": '', "eye-off": '', "eye": '', "facebook": '', "fast-forward": '', "feather": '', "figma": '', "file-minus": '', "file-plus": '', "file-text": '', "file": '', "film": '', "filter": '', "flag": '', "folder-minus": '', "folder-plus": '', "folder": '', "framer": '', "frown": '', "gift": '', "git-branch": '', "git-commit": '', "git-merge": '', "git-pull-request": '', "github": '', "gitlab": '', "globe": '', "grid": '', "hard-drive": '', "hash": '', "headphones": '', "heart": '', "help-circle": '', "hexagon": '', "home": '', "image": '', "inbox": '', "info": '', "instagram": '', "italic": '', "key": '', "layers": '', "layout": '', "life-buoy": '', "link-2": '', "link": '', "linkedin": '', "list": '', "loader": '', "lock": '', "log-in": '', "log-out": '', "mail": '', "map-pin": '', "map": '', "maximize-2": '', "maximize": '', "meh": '', "menu": '', "message-circle": '', "message-square": '', "mic-off": '', "mic": '', "minimize-2": '', "minimize": '', "minus-circle": '', "minus-square": '', "minus": '', "monitor": '', "moon": '', "more-horizontal": '', "more-vertical": '', "mouse-pointer": '', "move": '', "music": '', "navigation-2": '', "navigation": '', "octagon": '', "package": '', "paperclip": '', "pause-circle": '', "pause": '', "pen-tool": '', "percent": '', "phone-call": '', "phone-forwarded": '', "phone-incoming": '', "phone-missed": '', "phone-off": '', "phone-outgoing": '', "phone": '', "pie-chart": '', "play-circle": '', "play": '', "plus-circle": '', "plus-square": '', "plus": '', "pocket": '', "power": '', "printer": '', "radio": '', "refresh-ccw": '', "refresh-cw": '', "repeat": '', "rewind": '', "rotate-ccw": '', "rotate-cw": '', "rss": '', "save": '', "scissors": '', "search": '', "send": '', "server": '', "settings": '', "share-2": '', "share": '', "shield-off": '', "shield": '', "shopping-bag": '', "shopping-cart": '', "shuffle": '', "sidebar": '', "skip-back": '', "skip-forward": '', "slack": '', "slash": '', "sliders": '', "smartphone": '', "smile": '', "speaker": '', "square": '', "star": '', "stop-circle": '', "sun": '', "sunrise": '', "sunset": '', "table": '', "tablet": '', "tag": '', "target": '', "terminal": '', "thermometer": '', "thumbs-down": '', "thumbs-up": '', "toggle-left": '', "toggle-right": '', "tool": '', "trash-2": '', "trash": '', "trello": '', "trending-down": '', "trending-up": '', "triangle": '', "truck": '', "tv": '', "twitch": '', "twitter": '', "type": '', "umbrella": '', "underline": '', "unlock": '', "upload-cloud": '', "upload": '', "user-check": '', "user-minus": '', "user-plus": '', "user-x": '', "user": '', "users": '', "video-off": '', "video": '', "voicemail": '', "volume-1": '', "volume-2": '', "volume-x": '', "volume": '', "watch": '', "wifi-off": '', "wifi": '', "wind": '', "x-circle": '', "x-octagon": '', "x-square": '', "x": '', "youtube": '', "zap-off": '', "zap": '', "zoom-in": '', "zoom-out": '' }; + } + ), + /***/ + "./node_modules/classnames/dedupe.js": ( + /*!*******************************************!*\ + !*** ./node_modules/classnames/dedupe.js ***! + \*******************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__; + (function() { + "use strict"; + var classNames = function() { + function StorageObject() { + } + StorageObject.prototype = /* @__PURE__ */ Object.create(null); + function _parseArray(resultSet, array) { + var length = array.length; + for (var i = 0; i < length; ++i) { + _parse(resultSet, array[i]); + } + } + var hasOwn = {}.hasOwnProperty; + function _parseNumber(resultSet, num2) { + resultSet[num2] = true; + } + function _parseObject(resultSet, object) { + for (var k in object) { + if (hasOwn.call(object, k)) { + resultSet[k] = !!object[k]; + } + } + } + var SPACE = /\s+/; + function _parseString(resultSet, str) { + var array = str.split(SPACE); + var length = array.length; + for (var i = 0; i < length; ++i) { + resultSet[array[i]] = true; + } + } + function _parse(resultSet, arg) { + if (!arg) + return; + var argType = typeof arg; + if (argType === "string") { + _parseString(resultSet, arg); + } else if (Array.isArray(arg)) { + _parseArray(resultSet, arg); + } else if (argType === "object") { + _parseObject(resultSet, arg); + } else if (argType === "number") { + _parseNumber(resultSet, arg); + } + } + function _classNames() { + var len = arguments.length; + var args = Array(len); + for (var i = 0; i < len; i++) { + args[i] = arguments[i]; + } + var classSet = new StorageObject(); + _parseArray(classSet, args); + var list = []; + for (var k in classSet) { + if (classSet[k]) { + list.push(k); + } + } + return list.join(" "); + } + return _classNames; + }(); + if (typeof module3 !== "undefined" && module3.exports) { + module3.exports = classNames; + } else if (true) { + !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function() { + return classNames; + }.apply(exports3, __WEBPACK_AMD_DEFINE_ARRAY__), __WEBPACK_AMD_DEFINE_RESULT__ !== void 0 && (module3.exports = __WEBPACK_AMD_DEFINE_RESULT__)); + } else { + } + })(); + } + ), + /***/ + "./node_modules/core-js/es/array/from.js": ( + /*!***********************************************!*\ + !*** ./node_modules/core-js/es/array/from.js ***! + \***********************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + __webpack_require__( + /*! ../../modules/es.string.iterator */ + "./node_modules/core-js/modules/es.string.iterator.js" + ); + __webpack_require__( + /*! ../../modules/es.array.from */ + "./node_modules/core-js/modules/es.array.from.js" + ); + var path2 = __webpack_require__( + /*! ../../internals/path */ + "./node_modules/core-js/internals/path.js" + ); + module3.exports = path2.Array.from; + } + ), + /***/ + "./node_modules/core-js/internals/a-function.js": ( + /*!******************************************************!*\ + !*** ./node_modules/core-js/internals/a-function.js ***! + \******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = function(it) { + if (typeof it != "function") { + throw TypeError(String(it) + " is not a function"); + } + return it; + }; + } + ), + /***/ + "./node_modules/core-js/internals/an-object.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/an-object.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var isObject2 = __webpack_require__( + /*! ../internals/is-object */ + "./node_modules/core-js/internals/is-object.js" + ); + module3.exports = function(it) { + if (!isObject2(it)) { + throw TypeError(String(it) + " is not an object"); + } + return it; + }; + } + ), + /***/ + "./node_modules/core-js/internals/array-from.js": ( + /*!******************************************************!*\ + !*** ./node_modules/core-js/internals/array-from.js ***! + \******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var bind = __webpack_require__( + /*! ../internals/bind-context */ + "./node_modules/core-js/internals/bind-context.js" + ); + var toObject = __webpack_require__( + /*! ../internals/to-object */ + "./node_modules/core-js/internals/to-object.js" + ); + var callWithSafeIterationClosing = __webpack_require__( + /*! ../internals/call-with-safe-iteration-closing */ + "./node_modules/core-js/internals/call-with-safe-iteration-closing.js" + ); + var isArrayIteratorMethod = __webpack_require__( + /*! ../internals/is-array-iterator-method */ + "./node_modules/core-js/internals/is-array-iterator-method.js" + ); + var toLength = __webpack_require__( + /*! ../internals/to-length */ + "./node_modules/core-js/internals/to-length.js" + ); + var createProperty = __webpack_require__( + /*! ../internals/create-property */ + "./node_modules/core-js/internals/create-property.js" + ); + var getIteratorMethod = __webpack_require__( + /*! ../internals/get-iterator-method */ + "./node_modules/core-js/internals/get-iterator-method.js" + ); + module3.exports = function from(arrayLike) { + var O = toObject(arrayLike); + var C = typeof this == "function" ? this : Array; + var argumentsLength = arguments.length; + var mapfn = argumentsLength > 1 ? arguments[1] : void 0; + var mapping = mapfn !== void 0; + var index2 = 0; + var iteratorMethod = getIteratorMethod(O); + var length, result, step, iterator; + if (mapping) + mapfn = bind(mapfn, argumentsLength > 2 ? arguments[2] : void 0, 2); + if (iteratorMethod != void 0 && !(C == Array && isArrayIteratorMethod(iteratorMethod))) { + iterator = iteratorMethod.call(O); + result = new C(); + for (; !(step = iterator.next()).done; index2++) { + createProperty( + result, + index2, + mapping ? callWithSafeIterationClosing(iterator, mapfn, [step.value, index2], true) : step.value + ); + } + } else { + length = toLength(O.length); + result = new C(length); + for (; length > index2; index2++) { + createProperty(result, index2, mapping ? mapfn(O[index2], index2) : O[index2]); + } + } + result.length = index2; + return result; + }; + } + ), + /***/ + "./node_modules/core-js/internals/array-includes.js": ( + /*!**********************************************************!*\ + !*** ./node_modules/core-js/internals/array-includes.js ***! + \**********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var toIndexedObject = __webpack_require__( + /*! ../internals/to-indexed-object */ + "./node_modules/core-js/internals/to-indexed-object.js" + ); + var toLength = __webpack_require__( + /*! ../internals/to-length */ + "./node_modules/core-js/internals/to-length.js" + ); + var toAbsoluteIndex = __webpack_require__( + /*! ../internals/to-absolute-index */ + "./node_modules/core-js/internals/to-absolute-index.js" + ); + module3.exports = function(IS_INCLUDES) { + return function($this, el, fromIndex) { + var O = toIndexedObject($this); + var length = toLength(O.length); + var index2 = toAbsoluteIndex(fromIndex, length); + var value; + if (IS_INCLUDES && el != el) + while (length > index2) { + value = O[index2++]; + if (value != value) + return true; + } + else + for (; length > index2; index2++) + if (IS_INCLUDES || index2 in O) { + if (O[index2] === el) + return IS_INCLUDES || index2 || 0; + } + return !IS_INCLUDES && -1; + }; + }; + } + ), + /***/ + "./node_modules/core-js/internals/bind-context.js": ( + /*!********************************************************!*\ + !*** ./node_modules/core-js/internals/bind-context.js ***! + \********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var aFunction = __webpack_require__( + /*! ../internals/a-function */ + "./node_modules/core-js/internals/a-function.js" + ); + module3.exports = function(fn, that, length) { + aFunction(fn); + if (that === void 0) + return fn; + switch (length) { + case 0: + return function() { + return fn.call(that); + }; + case 1: + return function(a) { + return fn.call(that, a); + }; + case 2: + return function(a, b) { + return fn.call(that, a, b); + }; + case 3: + return function(a, b, c) { + return fn.call(that, a, b, c); + }; + } + return function() { + return fn.apply(that, arguments); + }; + }; + } + ), + /***/ + "./node_modules/core-js/internals/call-with-safe-iteration-closing.js": ( + /*!****************************************************************************!*\ + !*** ./node_modules/core-js/internals/call-with-safe-iteration-closing.js ***! + \****************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var anObject = __webpack_require__( + /*! ../internals/an-object */ + "./node_modules/core-js/internals/an-object.js" + ); + module3.exports = function(iterator, fn, value, ENTRIES) { + try { + return ENTRIES ? fn(anObject(value)[0], value[1]) : fn(value); + } catch (error) { + var returnMethod = iterator["return"]; + if (returnMethod !== void 0) + anObject(returnMethod.call(iterator)); + throw error; + } + }; + } + ), + /***/ + "./node_modules/core-js/internals/check-correctness-of-iteration.js": ( + /*!**************************************************************************!*\ + !*** ./node_modules/core-js/internals/check-correctness-of-iteration.js ***! + \**************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var ITERATOR = wellKnownSymbol("iterator"); + var SAFE_CLOSING = false; + try { + var called = 0; + var iteratorWithReturn = { + next: function() { + return { done: !!called++ }; + }, + "return": function() { + SAFE_CLOSING = true; + } + }; + iteratorWithReturn[ITERATOR] = function() { + return this; + }; + Array.from(iteratorWithReturn, function() { + throw 2; + }); + } catch (error) { + } + module3.exports = function(exec, SKIP_CLOSING) { + if (!SKIP_CLOSING && !SAFE_CLOSING) + return false; + var ITERATION_SUPPORT = false; + try { + var object = {}; + object[ITERATOR] = function() { + return { + next: function() { + return { done: ITERATION_SUPPORT = true }; + } + }; + }; + exec(object); + } catch (error) { + } + return ITERATION_SUPPORT; + }; + } + ), + /***/ + "./node_modules/core-js/internals/classof-raw.js": ( + /*!*******************************************************!*\ + !*** ./node_modules/core-js/internals/classof-raw.js ***! + \*******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + var toString = {}.toString; + module3.exports = function(it) { + return toString.call(it).slice(8, -1); + }; + } + ), + /***/ + "./node_modules/core-js/internals/classof.js": ( + /*!***************************************************!*\ + !*** ./node_modules/core-js/internals/classof.js ***! + \***************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var classofRaw = __webpack_require__( + /*! ../internals/classof-raw */ + "./node_modules/core-js/internals/classof-raw.js" + ); + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var TO_STRING_TAG = wellKnownSymbol("toStringTag"); + var CORRECT_ARGUMENTS = classofRaw(function() { + return arguments; + }()) == "Arguments"; + var tryGet = function(it, key2) { + try { + return it[key2]; + } catch (error) { + } + }; + module3.exports = function(it) { + var O, tag2, result; + return it === void 0 ? "Undefined" : it === null ? "Null" : typeof (tag2 = tryGet(O = Object(it), TO_STRING_TAG)) == "string" ? tag2 : CORRECT_ARGUMENTS ? classofRaw(O) : (result = classofRaw(O)) == "Object" && typeof O.callee == "function" ? "Arguments" : result; + }; + } + ), + /***/ + "./node_modules/core-js/internals/copy-constructor-properties.js": ( + /*!***********************************************************************!*\ + !*** ./node_modules/core-js/internals/copy-constructor-properties.js ***! + \***********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var ownKeys = __webpack_require__( + /*! ../internals/own-keys */ + "./node_modules/core-js/internals/own-keys.js" + ); + var getOwnPropertyDescriptorModule = __webpack_require__( + /*! ../internals/object-get-own-property-descriptor */ + "./node_modules/core-js/internals/object-get-own-property-descriptor.js" + ); + var definePropertyModule = __webpack_require__( + /*! ../internals/object-define-property */ + "./node_modules/core-js/internals/object-define-property.js" + ); + module3.exports = function(target, source) { + var keys = ownKeys(source); + var defineProperty = definePropertyModule.f; + var getOwnPropertyDescriptor = getOwnPropertyDescriptorModule.f; + for (var i = 0; i < keys.length; i++) { + var key2 = keys[i]; + if (!has(target, key2)) + defineProperty(target, key2, getOwnPropertyDescriptor(source, key2)); + } + }; + } + ), + /***/ + "./node_modules/core-js/internals/correct-prototype-getter.js": ( + /*!********************************************************************!*\ + !*** ./node_modules/core-js/internals/correct-prototype-getter.js ***! + \********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var fails = __webpack_require__( + /*! ../internals/fails */ + "./node_modules/core-js/internals/fails.js" + ); + module3.exports = !fails(function() { + function F() { + } + F.prototype.constructor = null; + return Object.getPrototypeOf(new F()) !== F.prototype; + }); + } + ), + /***/ + "./node_modules/core-js/internals/create-iterator-constructor.js": ( + /*!***********************************************************************!*\ + !*** ./node_modules/core-js/internals/create-iterator-constructor.js ***! + \***********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var IteratorPrototype = __webpack_require__( + /*! ../internals/iterators-core */ + "./node_modules/core-js/internals/iterators-core.js" + ).IteratorPrototype; + var create = __webpack_require__( + /*! ../internals/object-create */ + "./node_modules/core-js/internals/object-create.js" + ); + var createPropertyDescriptor = __webpack_require__( + /*! ../internals/create-property-descriptor */ + "./node_modules/core-js/internals/create-property-descriptor.js" + ); + var setToStringTag = __webpack_require__( + /*! ../internals/set-to-string-tag */ + "./node_modules/core-js/internals/set-to-string-tag.js" + ); + var Iterators = __webpack_require__( + /*! ../internals/iterators */ + "./node_modules/core-js/internals/iterators.js" + ); + var returnThis = function() { + return this; + }; + module3.exports = function(IteratorConstructor, NAME, next) { + var TO_STRING_TAG = NAME + " Iterator"; + IteratorConstructor.prototype = create(IteratorPrototype, { next: createPropertyDescriptor(1, next) }); + setToStringTag(IteratorConstructor, TO_STRING_TAG, false, true); + Iterators[TO_STRING_TAG] = returnThis; + return IteratorConstructor; + }; + } + ), + /***/ + "./node_modules/core-js/internals/create-property-descriptor.js": ( + /*!**********************************************************************!*\ + !*** ./node_modules/core-js/internals/create-property-descriptor.js ***! + \**********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = function(bitmap, value) { + return { + enumerable: !(bitmap & 1), + configurable: !(bitmap & 2), + writable: !(bitmap & 4), + value + }; + }; + } + ), + /***/ + "./node_modules/core-js/internals/create-property.js": ( + /*!***********************************************************!*\ + !*** ./node_modules/core-js/internals/create-property.js ***! + \***********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var toPrimitive = __webpack_require__( + /*! ../internals/to-primitive */ + "./node_modules/core-js/internals/to-primitive.js" + ); + var definePropertyModule = __webpack_require__( + /*! ../internals/object-define-property */ + "./node_modules/core-js/internals/object-define-property.js" + ); + var createPropertyDescriptor = __webpack_require__( + /*! ../internals/create-property-descriptor */ + "./node_modules/core-js/internals/create-property-descriptor.js" + ); + module3.exports = function(object, key2, value) { + var propertyKey = toPrimitive(key2); + if (propertyKey in object) + definePropertyModule.f(object, propertyKey, createPropertyDescriptor(0, value)); + else + object[propertyKey] = value; + }; + } + ), + /***/ + "./node_modules/core-js/internals/define-iterator.js": ( + /*!***********************************************************!*\ + !*** ./node_modules/core-js/internals/define-iterator.js ***! + \***********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var $ = __webpack_require__( + /*! ../internals/export */ + "./node_modules/core-js/internals/export.js" + ); + var createIteratorConstructor = __webpack_require__( + /*! ../internals/create-iterator-constructor */ + "./node_modules/core-js/internals/create-iterator-constructor.js" + ); + var getPrototypeOf = __webpack_require__( + /*! ../internals/object-get-prototype-of */ + "./node_modules/core-js/internals/object-get-prototype-of.js" + ); + var setPrototypeOf = __webpack_require__( + /*! ../internals/object-set-prototype-of */ + "./node_modules/core-js/internals/object-set-prototype-of.js" + ); + var setToStringTag = __webpack_require__( + /*! ../internals/set-to-string-tag */ + "./node_modules/core-js/internals/set-to-string-tag.js" + ); + var hide = __webpack_require__( + /*! ../internals/hide */ + "./node_modules/core-js/internals/hide.js" + ); + var redefine = __webpack_require__( + /*! ../internals/redefine */ + "./node_modules/core-js/internals/redefine.js" + ); + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var IS_PURE = __webpack_require__( + /*! ../internals/is-pure */ + "./node_modules/core-js/internals/is-pure.js" + ); + var Iterators = __webpack_require__( + /*! ../internals/iterators */ + "./node_modules/core-js/internals/iterators.js" + ); + var IteratorsCore = __webpack_require__( + /*! ../internals/iterators-core */ + "./node_modules/core-js/internals/iterators-core.js" + ); + var IteratorPrototype = IteratorsCore.IteratorPrototype; + var BUGGY_SAFARI_ITERATORS = IteratorsCore.BUGGY_SAFARI_ITERATORS; + var ITERATOR = wellKnownSymbol("iterator"); + var KEYS = "keys"; + var VALUES = "values"; + var ENTRIES = "entries"; + var returnThis = function() { + return this; + }; + module3.exports = function(Iterable, NAME, IteratorConstructor, next, DEFAULT, IS_SET, FORCED) { + createIteratorConstructor(IteratorConstructor, NAME, next); + var getIterationMethod = function(KIND) { + if (KIND === DEFAULT && defaultIterator) + return defaultIterator; + if (!BUGGY_SAFARI_ITERATORS && KIND in IterablePrototype) + return IterablePrototype[KIND]; + switch (KIND) { + case KEYS: + return function keys() { + return new IteratorConstructor(this, KIND); + }; + case VALUES: + return function values() { + return new IteratorConstructor(this, KIND); + }; + case ENTRIES: + return function entries() { + return new IteratorConstructor(this, KIND); + }; + } + return function() { + return new IteratorConstructor(this); + }; + }; + var TO_STRING_TAG = NAME + " Iterator"; + var INCORRECT_VALUES_NAME = false; + var IterablePrototype = Iterable.prototype; + var nativeIterator = IterablePrototype[ITERATOR] || IterablePrototype["@@iterator"] || DEFAULT && IterablePrototype[DEFAULT]; + var defaultIterator = !BUGGY_SAFARI_ITERATORS && nativeIterator || getIterationMethod(DEFAULT); + var anyNativeIterator = NAME == "Array" ? IterablePrototype.entries || nativeIterator : nativeIterator; + var CurrentIteratorPrototype, methods, KEY; + if (anyNativeIterator) { + CurrentIteratorPrototype = getPrototypeOf(anyNativeIterator.call(new Iterable())); + if (IteratorPrototype !== Object.prototype && CurrentIteratorPrototype.next) { + if (!IS_PURE && getPrototypeOf(CurrentIteratorPrototype) !== IteratorPrototype) { + if (setPrototypeOf) { + setPrototypeOf(CurrentIteratorPrototype, IteratorPrototype); + } else if (typeof CurrentIteratorPrototype[ITERATOR] != "function") { + hide(CurrentIteratorPrototype, ITERATOR, returnThis); + } + } + setToStringTag(CurrentIteratorPrototype, TO_STRING_TAG, true, true); + if (IS_PURE) + Iterators[TO_STRING_TAG] = returnThis; + } + } + if (DEFAULT == VALUES && nativeIterator && nativeIterator.name !== VALUES) { + INCORRECT_VALUES_NAME = true; + defaultIterator = function values() { + return nativeIterator.call(this); + }; + } + if ((!IS_PURE || FORCED) && IterablePrototype[ITERATOR] !== defaultIterator) { + hide(IterablePrototype, ITERATOR, defaultIterator); + } + Iterators[NAME] = defaultIterator; + if (DEFAULT) { + methods = { + values: getIterationMethod(VALUES), + keys: IS_SET ? defaultIterator : getIterationMethod(KEYS), + entries: getIterationMethod(ENTRIES) + }; + if (FORCED) + for (KEY in methods) { + if (BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME || !(KEY in IterablePrototype)) { + redefine(IterablePrototype, KEY, methods[KEY]); + } + } + else + $({ target: NAME, proto: true, forced: BUGGY_SAFARI_ITERATORS || INCORRECT_VALUES_NAME }, methods); + } + return methods; + }; + } + ), + /***/ + "./node_modules/core-js/internals/descriptors.js": ( + /*!*******************************************************!*\ + !*** ./node_modules/core-js/internals/descriptors.js ***! + \*******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var fails = __webpack_require__( + /*! ../internals/fails */ + "./node_modules/core-js/internals/fails.js" + ); + module3.exports = !fails(function() { + return Object.defineProperty({}, "a", { get: function() { + return 7; + } }).a != 7; + }); + } + ), + /***/ + "./node_modules/core-js/internals/document-create-element.js": ( + /*!*******************************************************************!*\ + !*** ./node_modules/core-js/internals/document-create-element.js ***! + \*******************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var isObject2 = __webpack_require__( + /*! ../internals/is-object */ + "./node_modules/core-js/internals/is-object.js" + ); + var document2 = global2.document; + var exist = isObject2(document2) && isObject2(document2.createElement); + module3.exports = function(it) { + return exist ? document2.createElement(it) : {}; + }; + } + ), + /***/ + "./node_modules/core-js/internals/enum-bug-keys.js": ( + /*!*********************************************************!*\ + !*** ./node_modules/core-js/internals/enum-bug-keys.js ***! + \*********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = [ + "constructor", + "hasOwnProperty", + "isPrototypeOf", + "propertyIsEnumerable", + "toLocaleString", + "toString", + "valueOf" + ]; + } + ), + /***/ + "./node_modules/core-js/internals/export.js": ( + /*!**************************************************!*\ + !*** ./node_modules/core-js/internals/export.js ***! + \**************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var getOwnPropertyDescriptor = __webpack_require__( + /*! ../internals/object-get-own-property-descriptor */ + "./node_modules/core-js/internals/object-get-own-property-descriptor.js" + ).f; + var hide = __webpack_require__( + /*! ../internals/hide */ + "./node_modules/core-js/internals/hide.js" + ); + var redefine = __webpack_require__( + /*! ../internals/redefine */ + "./node_modules/core-js/internals/redefine.js" + ); + var setGlobal = __webpack_require__( + /*! ../internals/set-global */ + "./node_modules/core-js/internals/set-global.js" + ); + var copyConstructorProperties = __webpack_require__( + /*! ../internals/copy-constructor-properties */ + "./node_modules/core-js/internals/copy-constructor-properties.js" + ); + var isForced = __webpack_require__( + /*! ../internals/is-forced */ + "./node_modules/core-js/internals/is-forced.js" + ); + module3.exports = function(options, source) { + var TARGET = options.target; + var GLOBAL = options.global; + var STATIC = options.stat; + var FORCED, target, key2, targetProperty, sourceProperty, descriptor; + if (GLOBAL) { + target = global2; + } else if (STATIC) { + target = global2[TARGET] || setGlobal(TARGET, {}); + } else { + target = (global2[TARGET] || {}).prototype; + } + if (target) + for (key2 in source) { + sourceProperty = source[key2]; + if (options.noTargetGet) { + descriptor = getOwnPropertyDescriptor(target, key2); + targetProperty = descriptor && descriptor.value; + } else + targetProperty = target[key2]; + FORCED = isForced(GLOBAL ? key2 : TARGET + (STATIC ? "." : "#") + key2, options.forced); + if (!FORCED && targetProperty !== void 0) { + if (typeof sourceProperty === typeof targetProperty) + continue; + copyConstructorProperties(sourceProperty, targetProperty); + } + if (options.sham || targetProperty && targetProperty.sham) { + hide(sourceProperty, "sham", true); + } + redefine(target, key2, sourceProperty, options); + } + }; + } + ), + /***/ + "./node_modules/core-js/internals/fails.js": ( + /*!*************************************************!*\ + !*** ./node_modules/core-js/internals/fails.js ***! + \*************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = function(exec) { + try { + return !!exec(); + } catch (error) { + return true; + } + }; + } + ), + /***/ + "./node_modules/core-js/internals/function-to-string.js": ( + /*!**************************************************************!*\ + !*** ./node_modules/core-js/internals/function-to-string.js ***! + \**************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var shared = __webpack_require__( + /*! ../internals/shared */ + "./node_modules/core-js/internals/shared.js" + ); + module3.exports = shared("native-function-to-string", Function.toString); + } + ), + /***/ + "./node_modules/core-js/internals/get-iterator-method.js": ( + /*!***************************************************************!*\ + !*** ./node_modules/core-js/internals/get-iterator-method.js ***! + \***************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var classof = __webpack_require__( + /*! ../internals/classof */ + "./node_modules/core-js/internals/classof.js" + ); + var Iterators = __webpack_require__( + /*! ../internals/iterators */ + "./node_modules/core-js/internals/iterators.js" + ); + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var ITERATOR = wellKnownSymbol("iterator"); + module3.exports = function(it) { + if (it != void 0) + return it[ITERATOR] || it["@@iterator"] || Iterators[classof(it)]; + }; + } + ), + /***/ + "./node_modules/core-js/internals/global.js": ( + /*!**************************************************!*\ + !*** ./node_modules/core-js/internals/global.js ***! + \**************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + (function(global2) { + var O = "object"; + var check = function(it) { + return it && it.Math == Math && it; + }; + module3.exports = // eslint-disable-next-line no-undef + check(typeof globalThis == O && globalThis) || check(typeof window == O && window) || check(typeof self == O && self) || check(typeof global2 == O && global2) || // eslint-disable-next-line no-new-func + Function("return this")(); + }).call(this, __webpack_require__( + /*! ./../../webpack/buildin/global.js */ + "./node_modules/webpack/buildin/global.js" + )); + } + ), + /***/ + "./node_modules/core-js/internals/has.js": ( + /*!***********************************************!*\ + !*** ./node_modules/core-js/internals/has.js ***! + \***********************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + var hasOwnProperty = {}.hasOwnProperty; + module3.exports = function(it, key2) { + return hasOwnProperty.call(it, key2); + }; + } + ), + /***/ + "./node_modules/core-js/internals/hidden-keys.js": ( + /*!*******************************************************!*\ + !*** ./node_modules/core-js/internals/hidden-keys.js ***! + \*******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = {}; + } + ), + /***/ + "./node_modules/core-js/internals/hide.js": ( + /*!************************************************!*\ + !*** ./node_modules/core-js/internals/hide.js ***! + \************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var DESCRIPTORS = __webpack_require__( + /*! ../internals/descriptors */ + "./node_modules/core-js/internals/descriptors.js" + ); + var definePropertyModule = __webpack_require__( + /*! ../internals/object-define-property */ + "./node_modules/core-js/internals/object-define-property.js" + ); + var createPropertyDescriptor = __webpack_require__( + /*! ../internals/create-property-descriptor */ + "./node_modules/core-js/internals/create-property-descriptor.js" + ); + module3.exports = DESCRIPTORS ? function(object, key2, value) { + return definePropertyModule.f(object, key2, createPropertyDescriptor(1, value)); + } : function(object, key2, value) { + object[key2] = value; + return object; + }; + } + ), + /***/ + "./node_modules/core-js/internals/html.js": ( + /*!************************************************!*\ + !*** ./node_modules/core-js/internals/html.js ***! + \************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var document2 = global2.document; + module3.exports = document2 && document2.documentElement; + } + ), + /***/ + "./node_modules/core-js/internals/ie8-dom-define.js": ( + /*!**********************************************************!*\ + !*** ./node_modules/core-js/internals/ie8-dom-define.js ***! + \**********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var DESCRIPTORS = __webpack_require__( + /*! ../internals/descriptors */ + "./node_modules/core-js/internals/descriptors.js" + ); + var fails = __webpack_require__( + /*! ../internals/fails */ + "./node_modules/core-js/internals/fails.js" + ); + var createElement = __webpack_require__( + /*! ../internals/document-create-element */ + "./node_modules/core-js/internals/document-create-element.js" + ); + module3.exports = !DESCRIPTORS && !fails(function() { + return Object.defineProperty(createElement("div"), "a", { + get: function() { + return 7; + } + }).a != 7; + }); + } + ), + /***/ + "./node_modules/core-js/internals/indexed-object.js": ( + /*!**********************************************************!*\ + !*** ./node_modules/core-js/internals/indexed-object.js ***! + \**********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var fails = __webpack_require__( + /*! ../internals/fails */ + "./node_modules/core-js/internals/fails.js" + ); + var classof = __webpack_require__( + /*! ../internals/classof-raw */ + "./node_modules/core-js/internals/classof-raw.js" + ); + var split = "".split; + module3.exports = fails(function() { + return !Object("z").propertyIsEnumerable(0); + }) ? function(it) { + return classof(it) == "String" ? split.call(it, "") : Object(it); + } : Object; + } + ), + /***/ + "./node_modules/core-js/internals/internal-state.js": ( + /*!**********************************************************!*\ + !*** ./node_modules/core-js/internals/internal-state.js ***! + \**********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var NATIVE_WEAK_MAP = __webpack_require__( + /*! ../internals/native-weak-map */ + "./node_modules/core-js/internals/native-weak-map.js" + ); + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var isObject2 = __webpack_require__( + /*! ../internals/is-object */ + "./node_modules/core-js/internals/is-object.js" + ); + var hide = __webpack_require__( + /*! ../internals/hide */ + "./node_modules/core-js/internals/hide.js" + ); + var objectHas = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var sharedKey = __webpack_require__( + /*! ../internals/shared-key */ + "./node_modules/core-js/internals/shared-key.js" + ); + var hiddenKeys = __webpack_require__( + /*! ../internals/hidden-keys */ + "./node_modules/core-js/internals/hidden-keys.js" + ); + var WeakMap2 = global2.WeakMap; + var set, get, has; + var enforce = function(it) { + return has(it) ? get(it) : set(it, {}); + }; + var getterFor = function(TYPE) { + return function(it) { + var state; + if (!isObject2(it) || (state = get(it)).type !== TYPE) { + throw TypeError("Incompatible receiver, " + TYPE + " required"); + } + return state; + }; + }; + if (NATIVE_WEAK_MAP) { + var store = new WeakMap2(); + var wmget = store.get; + var wmhas = store.has; + var wmset = store.set; + set = function(it, metadata) { + wmset.call(store, it, metadata); + return metadata; + }; + get = function(it) { + return wmget.call(store, it) || {}; + }; + has = function(it) { + return wmhas.call(store, it); + }; + } else { + var STATE = sharedKey("state"); + hiddenKeys[STATE] = true; + set = function(it, metadata) { + hide(it, STATE, metadata); + return metadata; + }; + get = function(it) { + return objectHas(it, STATE) ? it[STATE] : {}; + }; + has = function(it) { + return objectHas(it, STATE); + }; + } + module3.exports = { + set, + get, + has, + enforce, + getterFor + }; + } + ), + /***/ + "./node_modules/core-js/internals/is-array-iterator-method.js": ( + /*!********************************************************************!*\ + !*** ./node_modules/core-js/internals/is-array-iterator-method.js ***! + \********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var Iterators = __webpack_require__( + /*! ../internals/iterators */ + "./node_modules/core-js/internals/iterators.js" + ); + var ITERATOR = wellKnownSymbol("iterator"); + var ArrayPrototype = Array.prototype; + module3.exports = function(it) { + return it !== void 0 && (Iterators.Array === it || ArrayPrototype[ITERATOR] === it); + }; + } + ), + /***/ + "./node_modules/core-js/internals/is-forced.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/is-forced.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var fails = __webpack_require__( + /*! ../internals/fails */ + "./node_modules/core-js/internals/fails.js" + ); + var replacement = /#|\.prototype\./; + var isForced = function(feature, detection) { + var value = data[normalize2(feature)]; + return value == POLYFILL ? true : value == NATIVE ? false : typeof detection == "function" ? fails(detection) : !!detection; + }; + var normalize2 = isForced.normalize = function(string) { + return String(string).replace(replacement, ".").toLowerCase(); + }; + var data = isForced.data = {}; + var NATIVE = isForced.NATIVE = "N"; + var POLYFILL = isForced.POLYFILL = "P"; + module3.exports = isForced; + } + ), + /***/ + "./node_modules/core-js/internals/is-object.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/is-object.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = function(it) { + return typeof it === "object" ? it !== null : typeof it === "function"; + }; + } + ), + /***/ + "./node_modules/core-js/internals/is-pure.js": ( + /*!***************************************************!*\ + !*** ./node_modules/core-js/internals/is-pure.js ***! + \***************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = false; + } + ), + /***/ + "./node_modules/core-js/internals/iterators-core.js": ( + /*!**********************************************************!*\ + !*** ./node_modules/core-js/internals/iterators-core.js ***! + \**********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var getPrototypeOf = __webpack_require__( + /*! ../internals/object-get-prototype-of */ + "./node_modules/core-js/internals/object-get-prototype-of.js" + ); + var hide = __webpack_require__( + /*! ../internals/hide */ + "./node_modules/core-js/internals/hide.js" + ); + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var IS_PURE = __webpack_require__( + /*! ../internals/is-pure */ + "./node_modules/core-js/internals/is-pure.js" + ); + var ITERATOR = wellKnownSymbol("iterator"); + var BUGGY_SAFARI_ITERATORS = false; + var returnThis = function() { + return this; + }; + var IteratorPrototype, PrototypeOfArrayIteratorPrototype, arrayIterator; + if ([].keys) { + arrayIterator = [].keys(); + if (!("next" in arrayIterator)) + BUGGY_SAFARI_ITERATORS = true; + else { + PrototypeOfArrayIteratorPrototype = getPrototypeOf(getPrototypeOf(arrayIterator)); + if (PrototypeOfArrayIteratorPrototype !== Object.prototype) + IteratorPrototype = PrototypeOfArrayIteratorPrototype; + } + } + if (IteratorPrototype == void 0) + IteratorPrototype = {}; + if (!IS_PURE && !has(IteratorPrototype, ITERATOR)) + hide(IteratorPrototype, ITERATOR, returnThis); + module3.exports = { + IteratorPrototype, + BUGGY_SAFARI_ITERATORS + }; + } + ), + /***/ + "./node_modules/core-js/internals/iterators.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/iterators.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = {}; + } + ), + /***/ + "./node_modules/core-js/internals/native-symbol.js": ( + /*!*********************************************************!*\ + !*** ./node_modules/core-js/internals/native-symbol.js ***! + \*********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var fails = __webpack_require__( + /*! ../internals/fails */ + "./node_modules/core-js/internals/fails.js" + ); + module3.exports = !!Object.getOwnPropertySymbols && !fails(function() { + return !String(Symbol()); + }); + } + ), + /***/ + "./node_modules/core-js/internals/native-weak-map.js": ( + /*!***********************************************************!*\ + !*** ./node_modules/core-js/internals/native-weak-map.js ***! + \***********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var nativeFunctionToString = __webpack_require__( + /*! ../internals/function-to-string */ + "./node_modules/core-js/internals/function-to-string.js" + ); + var WeakMap2 = global2.WeakMap; + module3.exports = typeof WeakMap2 === "function" && /native code/.test(nativeFunctionToString.call(WeakMap2)); + } + ), + /***/ + "./node_modules/core-js/internals/object-create.js": ( + /*!*********************************************************!*\ + !*** ./node_modules/core-js/internals/object-create.js ***! + \*********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var anObject = __webpack_require__( + /*! ../internals/an-object */ + "./node_modules/core-js/internals/an-object.js" + ); + var defineProperties = __webpack_require__( + /*! ../internals/object-define-properties */ + "./node_modules/core-js/internals/object-define-properties.js" + ); + var enumBugKeys = __webpack_require__( + /*! ../internals/enum-bug-keys */ + "./node_modules/core-js/internals/enum-bug-keys.js" + ); + var hiddenKeys = __webpack_require__( + /*! ../internals/hidden-keys */ + "./node_modules/core-js/internals/hidden-keys.js" + ); + var html2 = __webpack_require__( + /*! ../internals/html */ + "./node_modules/core-js/internals/html.js" + ); + var documentCreateElement = __webpack_require__( + /*! ../internals/document-create-element */ + "./node_modules/core-js/internals/document-create-element.js" + ); + var sharedKey = __webpack_require__( + /*! ../internals/shared-key */ + "./node_modules/core-js/internals/shared-key.js" + ); + var IE_PROTO = sharedKey("IE_PROTO"); + var PROTOTYPE = "prototype"; + var Empty = function() { + }; + var createDict = function() { + var iframe = documentCreateElement("iframe"); + var length = enumBugKeys.length; + var lt = "<"; + var script = "script"; + var gt = ">"; + var js = "java" + script + ":"; + var iframeDocument; + iframe.style.display = "none"; + html2.appendChild(iframe); + iframe.src = String(js); + iframeDocument = iframe.contentWindow.document; + iframeDocument.open(); + iframeDocument.write(lt + script + gt + "document.F=Object" + lt + "/" + script + gt); + iframeDocument.close(); + createDict = iframeDocument.F; + while (length--) + delete createDict[PROTOTYPE][enumBugKeys[length]]; + return createDict(); + }; + module3.exports = Object.create || function create(O, Properties) { + var result; + if (O !== null) { + Empty[PROTOTYPE] = anObject(O); + result = new Empty(); + Empty[PROTOTYPE] = null; + result[IE_PROTO] = O; + } else + result = createDict(); + return Properties === void 0 ? result : defineProperties(result, Properties); + }; + hiddenKeys[IE_PROTO] = true; + } + ), + /***/ + "./node_modules/core-js/internals/object-define-properties.js": ( + /*!********************************************************************!*\ + !*** ./node_modules/core-js/internals/object-define-properties.js ***! + \********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var DESCRIPTORS = __webpack_require__( + /*! ../internals/descriptors */ + "./node_modules/core-js/internals/descriptors.js" + ); + var definePropertyModule = __webpack_require__( + /*! ../internals/object-define-property */ + "./node_modules/core-js/internals/object-define-property.js" + ); + var anObject = __webpack_require__( + /*! ../internals/an-object */ + "./node_modules/core-js/internals/an-object.js" + ); + var objectKeys = __webpack_require__( + /*! ../internals/object-keys */ + "./node_modules/core-js/internals/object-keys.js" + ); + module3.exports = DESCRIPTORS ? Object.defineProperties : function defineProperties(O, Properties) { + anObject(O); + var keys = objectKeys(Properties); + var length = keys.length; + var i = 0; + var key2; + while (length > i) + definePropertyModule.f(O, key2 = keys[i++], Properties[key2]); + return O; + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-define-property.js": ( + /*!******************************************************************!*\ + !*** ./node_modules/core-js/internals/object-define-property.js ***! + \******************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var DESCRIPTORS = __webpack_require__( + /*! ../internals/descriptors */ + "./node_modules/core-js/internals/descriptors.js" + ); + var IE8_DOM_DEFINE = __webpack_require__( + /*! ../internals/ie8-dom-define */ + "./node_modules/core-js/internals/ie8-dom-define.js" + ); + var anObject = __webpack_require__( + /*! ../internals/an-object */ + "./node_modules/core-js/internals/an-object.js" + ); + var toPrimitive = __webpack_require__( + /*! ../internals/to-primitive */ + "./node_modules/core-js/internals/to-primitive.js" + ); + var nativeDefineProperty = Object.defineProperty; + exports3.f = DESCRIPTORS ? nativeDefineProperty : function defineProperty(O, P, Attributes) { + anObject(O); + P = toPrimitive(P, true); + anObject(Attributes); + if (IE8_DOM_DEFINE) + try { + return nativeDefineProperty(O, P, Attributes); + } catch (error) { + } + if ("get" in Attributes || "set" in Attributes) + throw TypeError("Accessors not supported"); + if ("value" in Attributes) + O[P] = Attributes.value; + return O; + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-get-own-property-descriptor.js": ( + /*!******************************************************************************!*\ + !*** ./node_modules/core-js/internals/object-get-own-property-descriptor.js ***! + \******************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var DESCRIPTORS = __webpack_require__( + /*! ../internals/descriptors */ + "./node_modules/core-js/internals/descriptors.js" + ); + var propertyIsEnumerableModule = __webpack_require__( + /*! ../internals/object-property-is-enumerable */ + "./node_modules/core-js/internals/object-property-is-enumerable.js" + ); + var createPropertyDescriptor = __webpack_require__( + /*! ../internals/create-property-descriptor */ + "./node_modules/core-js/internals/create-property-descriptor.js" + ); + var toIndexedObject = __webpack_require__( + /*! ../internals/to-indexed-object */ + "./node_modules/core-js/internals/to-indexed-object.js" + ); + var toPrimitive = __webpack_require__( + /*! ../internals/to-primitive */ + "./node_modules/core-js/internals/to-primitive.js" + ); + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var IE8_DOM_DEFINE = __webpack_require__( + /*! ../internals/ie8-dom-define */ + "./node_modules/core-js/internals/ie8-dom-define.js" + ); + var nativeGetOwnPropertyDescriptor = Object.getOwnPropertyDescriptor; + exports3.f = DESCRIPTORS ? nativeGetOwnPropertyDescriptor : function getOwnPropertyDescriptor(O, P) { + O = toIndexedObject(O); + P = toPrimitive(P, true); + if (IE8_DOM_DEFINE) + try { + return nativeGetOwnPropertyDescriptor(O, P); + } catch (error) { + } + if (has(O, P)) + return createPropertyDescriptor(!propertyIsEnumerableModule.f.call(O, P), O[P]); + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-get-own-property-names.js": ( + /*!*************************************************************************!*\ + !*** ./node_modules/core-js/internals/object-get-own-property-names.js ***! + \*************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var internalObjectKeys = __webpack_require__( + /*! ../internals/object-keys-internal */ + "./node_modules/core-js/internals/object-keys-internal.js" + ); + var enumBugKeys = __webpack_require__( + /*! ../internals/enum-bug-keys */ + "./node_modules/core-js/internals/enum-bug-keys.js" + ); + var hiddenKeys = enumBugKeys.concat("length", "prototype"); + exports3.f = Object.getOwnPropertyNames || function getOwnPropertyNames(O) { + return internalObjectKeys(O, hiddenKeys); + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-get-own-property-symbols.js": ( + /*!***************************************************************************!*\ + !*** ./node_modules/core-js/internals/object-get-own-property-symbols.js ***! + \***************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + exports3.f = Object.getOwnPropertySymbols; + } + ), + /***/ + "./node_modules/core-js/internals/object-get-prototype-of.js": ( + /*!*******************************************************************!*\ + !*** ./node_modules/core-js/internals/object-get-prototype-of.js ***! + \*******************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var toObject = __webpack_require__( + /*! ../internals/to-object */ + "./node_modules/core-js/internals/to-object.js" + ); + var sharedKey = __webpack_require__( + /*! ../internals/shared-key */ + "./node_modules/core-js/internals/shared-key.js" + ); + var CORRECT_PROTOTYPE_GETTER = __webpack_require__( + /*! ../internals/correct-prototype-getter */ + "./node_modules/core-js/internals/correct-prototype-getter.js" + ); + var IE_PROTO = sharedKey("IE_PROTO"); + var ObjectPrototype = Object.prototype; + module3.exports = CORRECT_PROTOTYPE_GETTER ? Object.getPrototypeOf : function(O) { + O = toObject(O); + if (has(O, IE_PROTO)) + return O[IE_PROTO]; + if (typeof O.constructor == "function" && O instanceof O.constructor) { + return O.constructor.prototype; + } + return O instanceof Object ? ObjectPrototype : null; + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-keys-internal.js": ( + /*!****************************************************************!*\ + !*** ./node_modules/core-js/internals/object-keys-internal.js ***! + \****************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var toIndexedObject = __webpack_require__( + /*! ../internals/to-indexed-object */ + "./node_modules/core-js/internals/to-indexed-object.js" + ); + var arrayIncludes = __webpack_require__( + /*! ../internals/array-includes */ + "./node_modules/core-js/internals/array-includes.js" + ); + var hiddenKeys = __webpack_require__( + /*! ../internals/hidden-keys */ + "./node_modules/core-js/internals/hidden-keys.js" + ); + var arrayIndexOf = arrayIncludes(false); + module3.exports = function(object, names) { + var O = toIndexedObject(object); + var i = 0; + var result = []; + var key2; + for (key2 in O) + !has(hiddenKeys, key2) && has(O, key2) && result.push(key2); + while (names.length > i) + if (has(O, key2 = names[i++])) { + ~arrayIndexOf(result, key2) || result.push(key2); + } + return result; + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-keys.js": ( + /*!*******************************************************!*\ + !*** ./node_modules/core-js/internals/object-keys.js ***! + \*******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var internalObjectKeys = __webpack_require__( + /*! ../internals/object-keys-internal */ + "./node_modules/core-js/internals/object-keys-internal.js" + ); + var enumBugKeys = __webpack_require__( + /*! ../internals/enum-bug-keys */ + "./node_modules/core-js/internals/enum-bug-keys.js" + ); + module3.exports = Object.keys || function keys(O) { + return internalObjectKeys(O, enumBugKeys); + }; + } + ), + /***/ + "./node_modules/core-js/internals/object-property-is-enumerable.js": ( + /*!*************************************************************************!*\ + !*** ./node_modules/core-js/internals/object-property-is-enumerable.js ***! + \*************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var nativePropertyIsEnumerable = {}.propertyIsEnumerable; + var getOwnPropertyDescriptor = Object.getOwnPropertyDescriptor; + var NASHORN_BUG = getOwnPropertyDescriptor && !nativePropertyIsEnumerable.call({ 1: 2 }, 1); + exports3.f = NASHORN_BUG ? function propertyIsEnumerable(V) { + var descriptor = getOwnPropertyDescriptor(this, V); + return !!descriptor && descriptor.enumerable; + } : nativePropertyIsEnumerable; + } + ), + /***/ + "./node_modules/core-js/internals/object-set-prototype-of.js": ( + /*!*******************************************************************!*\ + !*** ./node_modules/core-js/internals/object-set-prototype-of.js ***! + \*******************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var validateSetPrototypeOfArguments = __webpack_require__( + /*! ../internals/validate-set-prototype-of-arguments */ + "./node_modules/core-js/internals/validate-set-prototype-of-arguments.js" + ); + module3.exports = Object.setPrototypeOf || ("__proto__" in {} ? function() { + var correctSetter = false; + var test = {}; + var setter; + try { + setter = Object.getOwnPropertyDescriptor(Object.prototype, "__proto__").set; + setter.call(test, []); + correctSetter = test instanceof Array; + } catch (error) { + } + return function setPrototypeOf(O, proto) { + validateSetPrototypeOfArguments(O, proto); + if (correctSetter) + setter.call(O, proto); + else + O.__proto__ = proto; + return O; + }; + }() : void 0); + } + ), + /***/ + "./node_modules/core-js/internals/own-keys.js": ( + /*!****************************************************!*\ + !*** ./node_modules/core-js/internals/own-keys.js ***! + \****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var getOwnPropertyNamesModule = __webpack_require__( + /*! ../internals/object-get-own-property-names */ + "./node_modules/core-js/internals/object-get-own-property-names.js" + ); + var getOwnPropertySymbolsModule = __webpack_require__( + /*! ../internals/object-get-own-property-symbols */ + "./node_modules/core-js/internals/object-get-own-property-symbols.js" + ); + var anObject = __webpack_require__( + /*! ../internals/an-object */ + "./node_modules/core-js/internals/an-object.js" + ); + var Reflect2 = global2.Reflect; + module3.exports = Reflect2 && Reflect2.ownKeys || function ownKeys(it) { + var keys = getOwnPropertyNamesModule.f(anObject(it)); + var getOwnPropertySymbols = getOwnPropertySymbolsModule.f; + return getOwnPropertySymbols ? keys.concat(getOwnPropertySymbols(it)) : keys; + }; + } + ), + /***/ + "./node_modules/core-js/internals/path.js": ( + /*!************************************************!*\ + !*** ./node_modules/core-js/internals/path.js ***! + \************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + module3.exports = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + } + ), + /***/ + "./node_modules/core-js/internals/redefine.js": ( + /*!****************************************************!*\ + !*** ./node_modules/core-js/internals/redefine.js ***! + \****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var shared = __webpack_require__( + /*! ../internals/shared */ + "./node_modules/core-js/internals/shared.js" + ); + var hide = __webpack_require__( + /*! ../internals/hide */ + "./node_modules/core-js/internals/hide.js" + ); + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var setGlobal = __webpack_require__( + /*! ../internals/set-global */ + "./node_modules/core-js/internals/set-global.js" + ); + var nativeFunctionToString = __webpack_require__( + /*! ../internals/function-to-string */ + "./node_modules/core-js/internals/function-to-string.js" + ); + var InternalStateModule = __webpack_require__( + /*! ../internals/internal-state */ + "./node_modules/core-js/internals/internal-state.js" + ); + var getInternalState = InternalStateModule.get; + var enforceInternalState = InternalStateModule.enforce; + var TEMPLATE = String(nativeFunctionToString).split("toString"); + shared("inspectSource", function(it) { + return nativeFunctionToString.call(it); + }); + (module3.exports = function(O, key2, value, options) { + var unsafe = options ? !!options.unsafe : false; + var simple2 = options ? !!options.enumerable : false; + var noTargetGet = options ? !!options.noTargetGet : false; + if (typeof value == "function") { + if (typeof key2 == "string" && !has(value, "name")) + hide(value, "name", key2); + enforceInternalState(value).source = TEMPLATE.join(typeof key2 == "string" ? key2 : ""); + } + if (O === global2) { + if (simple2) + O[key2] = value; + else + setGlobal(key2, value); + return; + } else if (!unsafe) { + delete O[key2]; + } else if (!noTargetGet && O[key2]) { + simple2 = true; + } + if (simple2) + O[key2] = value; + else + hide(O, key2, value); + })(Function.prototype, "toString", function toString() { + return typeof this == "function" && getInternalState(this).source || nativeFunctionToString.call(this); + }); + } + ), + /***/ + "./node_modules/core-js/internals/require-object-coercible.js": ( + /*!********************************************************************!*\ + !*** ./node_modules/core-js/internals/require-object-coercible.js ***! + \********************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + module3.exports = function(it) { + if (it == void 0) + throw TypeError("Can't call method on " + it); + return it; + }; + } + ), + /***/ + "./node_modules/core-js/internals/set-global.js": ( + /*!******************************************************!*\ + !*** ./node_modules/core-js/internals/set-global.js ***! + \******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var hide = __webpack_require__( + /*! ../internals/hide */ + "./node_modules/core-js/internals/hide.js" + ); + module3.exports = function(key2, value) { + try { + hide(global2, key2, value); + } catch (error) { + global2[key2] = value; + } + return value; + }; + } + ), + /***/ + "./node_modules/core-js/internals/set-to-string-tag.js": ( + /*!*************************************************************!*\ + !*** ./node_modules/core-js/internals/set-to-string-tag.js ***! + \*************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var defineProperty = __webpack_require__( + /*! ../internals/object-define-property */ + "./node_modules/core-js/internals/object-define-property.js" + ).f; + var has = __webpack_require__( + /*! ../internals/has */ + "./node_modules/core-js/internals/has.js" + ); + var wellKnownSymbol = __webpack_require__( + /*! ../internals/well-known-symbol */ + "./node_modules/core-js/internals/well-known-symbol.js" + ); + var TO_STRING_TAG = wellKnownSymbol("toStringTag"); + module3.exports = function(it, TAG, STATIC) { + if (it && !has(it = STATIC ? it : it.prototype, TO_STRING_TAG)) { + defineProperty(it, TO_STRING_TAG, { configurable: true, value: TAG }); + } + }; + } + ), + /***/ + "./node_modules/core-js/internals/shared-key.js": ( + /*!******************************************************!*\ + !*** ./node_modules/core-js/internals/shared-key.js ***! + \******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var shared = __webpack_require__( + /*! ../internals/shared */ + "./node_modules/core-js/internals/shared.js" + ); + var uid = __webpack_require__( + /*! ../internals/uid */ + "./node_modules/core-js/internals/uid.js" + ); + var keys = shared("keys"); + module3.exports = function(key2) { + return keys[key2] || (keys[key2] = uid(key2)); + }; + } + ), + /***/ + "./node_modules/core-js/internals/shared.js": ( + /*!**************************************************!*\ + !*** ./node_modules/core-js/internals/shared.js ***! + \**************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var setGlobal = __webpack_require__( + /*! ../internals/set-global */ + "./node_modules/core-js/internals/set-global.js" + ); + var IS_PURE = __webpack_require__( + /*! ../internals/is-pure */ + "./node_modules/core-js/internals/is-pure.js" + ); + var SHARED = "__core-js_shared__"; + var store = global2[SHARED] || setGlobal(SHARED, {}); + (module3.exports = function(key2, value) { + return store[key2] || (store[key2] = value !== void 0 ? value : {}); + })("versions", []).push({ + version: "3.1.3", + mode: IS_PURE ? "pure" : "global", + copyright: "\xA9 2019 Denis Pushkarev (zloirock.ru)" + }); + } + ), + /***/ + "./node_modules/core-js/internals/string-at.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/string-at.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var toInteger = __webpack_require__( + /*! ../internals/to-integer */ + "./node_modules/core-js/internals/to-integer.js" + ); + var requireObjectCoercible = __webpack_require__( + /*! ../internals/require-object-coercible */ + "./node_modules/core-js/internals/require-object-coercible.js" + ); + module3.exports = function(that, pos, CONVERT_TO_STRING) { + var S = String(requireObjectCoercible(that)); + var position = toInteger(pos); + var size = S.length; + var first2, second; + if (position < 0 || position >= size) + return CONVERT_TO_STRING ? "" : void 0; + first2 = S.charCodeAt(position); + return first2 < 55296 || first2 > 56319 || position + 1 === size || (second = S.charCodeAt(position + 1)) < 56320 || second > 57343 ? CONVERT_TO_STRING ? S.charAt(position) : first2 : CONVERT_TO_STRING ? S.slice(position, position + 2) : (first2 - 55296 << 10) + (second - 56320) + 65536; + }; + } + ), + /***/ + "./node_modules/core-js/internals/to-absolute-index.js": ( + /*!*************************************************************!*\ + !*** ./node_modules/core-js/internals/to-absolute-index.js ***! + \*************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var toInteger = __webpack_require__( + /*! ../internals/to-integer */ + "./node_modules/core-js/internals/to-integer.js" + ); + var max = Math.max; + var min = Math.min; + module3.exports = function(index2, length) { + var integer = toInteger(index2); + return integer < 0 ? max(integer + length, 0) : min(integer, length); + }; + } + ), + /***/ + "./node_modules/core-js/internals/to-indexed-object.js": ( + /*!*************************************************************!*\ + !*** ./node_modules/core-js/internals/to-indexed-object.js ***! + \*************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var IndexedObject = __webpack_require__( + /*! ../internals/indexed-object */ + "./node_modules/core-js/internals/indexed-object.js" + ); + var requireObjectCoercible = __webpack_require__( + /*! ../internals/require-object-coercible */ + "./node_modules/core-js/internals/require-object-coercible.js" + ); + module3.exports = function(it) { + return IndexedObject(requireObjectCoercible(it)); + }; + } + ), + /***/ + "./node_modules/core-js/internals/to-integer.js": ( + /*!******************************************************!*\ + !*** ./node_modules/core-js/internals/to-integer.js ***! + \******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + var ceil = Math.ceil; + var floor = Math.floor; + module3.exports = function(argument) { + return isNaN(argument = +argument) ? 0 : (argument > 0 ? floor : ceil)(argument); + }; + } + ), + /***/ + "./node_modules/core-js/internals/to-length.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/to-length.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var toInteger = __webpack_require__( + /*! ../internals/to-integer */ + "./node_modules/core-js/internals/to-integer.js" + ); + var min = Math.min; + module3.exports = function(argument) { + return argument > 0 ? min(toInteger(argument), 9007199254740991) : 0; + }; + } + ), + /***/ + "./node_modules/core-js/internals/to-object.js": ( + /*!*****************************************************!*\ + !*** ./node_modules/core-js/internals/to-object.js ***! + \*****************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var requireObjectCoercible = __webpack_require__( + /*! ../internals/require-object-coercible */ + "./node_modules/core-js/internals/require-object-coercible.js" + ); + module3.exports = function(argument) { + return Object(requireObjectCoercible(argument)); + }; + } + ), + /***/ + "./node_modules/core-js/internals/to-primitive.js": ( + /*!********************************************************!*\ + !*** ./node_modules/core-js/internals/to-primitive.js ***! + \********************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var isObject2 = __webpack_require__( + /*! ../internals/is-object */ + "./node_modules/core-js/internals/is-object.js" + ); + module3.exports = function(it, S) { + if (!isObject2(it)) + return it; + var fn, val; + if (S && typeof (fn = it.toString) == "function" && !isObject2(val = fn.call(it))) + return val; + if (typeof (fn = it.valueOf) == "function" && !isObject2(val = fn.call(it))) + return val; + if (!S && typeof (fn = it.toString) == "function" && !isObject2(val = fn.call(it))) + return val; + throw TypeError("Can't convert object to primitive value"); + }; + } + ), + /***/ + "./node_modules/core-js/internals/uid.js": ( + /*!***********************************************!*\ + !*** ./node_modules/core-js/internals/uid.js ***! + \***********************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + var id = 0; + var postfix = Math.random(); + module3.exports = function(key2) { + return "Symbol(".concat(key2 === void 0 ? "" : key2, ")_", (++id + postfix).toString(36)); + }; + } + ), + /***/ + "./node_modules/core-js/internals/validate-set-prototype-of-arguments.js": ( + /*!*******************************************************************************!*\ + !*** ./node_modules/core-js/internals/validate-set-prototype-of-arguments.js ***! + \*******************************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var isObject2 = __webpack_require__( + /*! ../internals/is-object */ + "./node_modules/core-js/internals/is-object.js" + ); + var anObject = __webpack_require__( + /*! ../internals/an-object */ + "./node_modules/core-js/internals/an-object.js" + ); + module3.exports = function(O, proto) { + anObject(O); + if (!isObject2(proto) && proto !== null) { + throw TypeError("Can't set " + String(proto) + " as a prototype"); + } + }; + } + ), + /***/ + "./node_modules/core-js/internals/well-known-symbol.js": ( + /*!*************************************************************!*\ + !*** ./node_modules/core-js/internals/well-known-symbol.js ***! + \*************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var global2 = __webpack_require__( + /*! ../internals/global */ + "./node_modules/core-js/internals/global.js" + ); + var shared = __webpack_require__( + /*! ../internals/shared */ + "./node_modules/core-js/internals/shared.js" + ); + var uid = __webpack_require__( + /*! ../internals/uid */ + "./node_modules/core-js/internals/uid.js" + ); + var NATIVE_SYMBOL = __webpack_require__( + /*! ../internals/native-symbol */ + "./node_modules/core-js/internals/native-symbol.js" + ); + var Symbol2 = global2.Symbol; + var store = shared("wks"); + module3.exports = function(name) { + return store[name] || (store[name] = NATIVE_SYMBOL && Symbol2[name] || (NATIVE_SYMBOL ? Symbol2 : uid)("Symbol." + name)); + }; + } + ), + /***/ + "./node_modules/core-js/modules/es.array.from.js": ( + /*!*******************************************************!*\ + !*** ./node_modules/core-js/modules/es.array.from.js ***! + \*******************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + var $ = __webpack_require__( + /*! ../internals/export */ + "./node_modules/core-js/internals/export.js" + ); + var from = __webpack_require__( + /*! ../internals/array-from */ + "./node_modules/core-js/internals/array-from.js" + ); + var checkCorrectnessOfIteration = __webpack_require__( + /*! ../internals/check-correctness-of-iteration */ + "./node_modules/core-js/internals/check-correctness-of-iteration.js" + ); + var INCORRECT_ITERATION = !checkCorrectnessOfIteration(function(iterable) { + Array.from(iterable); + }); + $({ target: "Array", stat: true, forced: INCORRECT_ITERATION }, { + from + }); + } + ), + /***/ + "./node_modules/core-js/modules/es.string.iterator.js": ( + /*!************************************************************!*\ + !*** ./node_modules/core-js/modules/es.string.iterator.js ***! + \************************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var codePointAt = __webpack_require__( + /*! ../internals/string-at */ + "./node_modules/core-js/internals/string-at.js" + ); + var InternalStateModule = __webpack_require__( + /*! ../internals/internal-state */ + "./node_modules/core-js/internals/internal-state.js" + ); + var defineIterator = __webpack_require__( + /*! ../internals/define-iterator */ + "./node_modules/core-js/internals/define-iterator.js" + ); + var STRING_ITERATOR = "String Iterator"; + var setInternalState = InternalStateModule.set; + var getInternalState = InternalStateModule.getterFor(STRING_ITERATOR); + defineIterator(String, "String", function(iterated) { + setInternalState(this, { + type: STRING_ITERATOR, + string: String(iterated), + index: 0 + }); + }, function next() { + var state = getInternalState(this); + var string = state.string; + var index2 = state.index; + var point; + if (index2 >= string.length) + return { value: void 0, done: true }; + point = codePointAt(string, index2, true); + state.index += point.length; + return { value: point, done: false }; + }); + } + ), + /***/ + "./node_modules/webpack/buildin/global.js": ( + /*!***********************************!*\ + !*** (webpack)/buildin/global.js ***! + \***********************************/ + /*! no static exports found */ + /***/ + function(module3, exports3) { + var g; + g = function() { + return this; + }(); + try { + g = g || Function("return this")() || (1, eval)("this"); + } catch (e) { + if (typeof window === "object") + g = window; + } + module3.exports = g; + } + ), + /***/ + "./src/default-attrs.json": ( + /*!********************************!*\ + !*** ./src/default-attrs.json ***! + \********************************/ + /*! exports provided: xmlns, width, height, viewBox, fill, stroke, stroke-width, stroke-linecap, stroke-linejoin, default */ + /***/ + function(module3) { + module3.exports = { "xmlns": "http://www.w3.org/2000/svg", "width": 24, "height": 24, "viewBox": "0 0 24 24", "fill": "none", "stroke": "currentColor", "stroke-width": 2, "stroke-linecap": "round", "stroke-linejoin": "round" }; + } + ), + /***/ + "./src/icon.js": ( + /*!*********************!*\ + !*** ./src/icon.js ***! + \*********************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + Object.defineProperty(exports3, "__esModule", { + value: true + }); + var _extends = Object.assign || function(target) { + for (var i = 1; i < arguments.length; i++) { + var source = arguments[i]; + for (var key2 in source) { + if (Object.prototype.hasOwnProperty.call(source, key2)) { + target[key2] = source[key2]; + } + } + } + return target; + }; + var _createClass = function() { + function defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) + descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } + } + return function(Constructor, protoProps, staticProps) { + if (protoProps) + defineProperties(Constructor.prototype, protoProps); + if (staticProps) + defineProperties(Constructor, staticProps); + return Constructor; + }; + }(); + var _dedupe = __webpack_require__( + /*! classnames/dedupe */ + "./node_modules/classnames/dedupe.js" + ); + var _dedupe2 = _interopRequireDefault(_dedupe); + var _defaultAttrs = __webpack_require__( + /*! ./default-attrs.json */ + "./src/default-attrs.json" + ); + var _defaultAttrs2 = _interopRequireDefault(_defaultAttrs); + function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { default: obj }; + } + function _classCallCheck(instance10, Constructor) { + if (!(instance10 instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } + } + var Icon = function() { + function Icon2(name, contents) { + var tags = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : []; + _classCallCheck(this, Icon2); + this.name = name; + this.contents = contents; + this.tags = tags; + this.attrs = _extends({}, _defaultAttrs2.default, { class: "feather feather-" + name }); + } + _createClass(Icon2, [{ + key: "toSvg", + value: function toSvg() { + var attrs = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + var combinedAttrs = _extends({}, this.attrs, attrs, { class: (0, _dedupe2.default)(this.attrs.class, attrs.class) }); + return "" + this.contents + ""; + } + /** + * Return string representation of an `Icon`. + * + * Added for backward compatibility. If old code expects `feather.icons.` + * to be a string, `toString()` will get implicitly called. + * + * @returns {string} + */ + }, { + key: "toString", + value: function toString() { + return this.contents; + } + }]); + return Icon2; + }(); + function attrsToString(attrs) { + return Object.keys(attrs).map(function(key2) { + return key2 + '="' + attrs[key2] + '"'; + }).join(" "); + } + exports3.default = Icon; + } + ), + /***/ + "./src/icons.js": ( + /*!**********************!*\ + !*** ./src/icons.js ***! + \**********************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + Object.defineProperty(exports3, "__esModule", { + value: true + }); + var _icon = __webpack_require__( + /*! ./icon */ + "./src/icon.js" + ); + var _icon2 = _interopRequireDefault(_icon); + var _icons = __webpack_require__( + /*! ../dist/icons.json */ + "./dist/icons.json" + ); + var _icons2 = _interopRequireDefault(_icons); + var _tags = __webpack_require__( + /*! ./tags.json */ + "./src/tags.json" + ); + var _tags2 = _interopRequireDefault(_tags); + function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { default: obj }; + } + exports3.default = Object.keys(_icons2.default).map(function(key2) { + return new _icon2.default(key2, _icons2.default[key2], _tags2.default[key2]); + }).reduce(function(object, icon) { + object[icon.name] = icon; + return object; + }, {}); + } + ), + /***/ + "./src/index.js": ( + /*!**********************!*\ + !*** ./src/index.js ***! + \**********************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + var _icons = __webpack_require__( + /*! ./icons */ + "./src/icons.js" + ); + var _icons2 = _interopRequireDefault(_icons); + var _toSvg = __webpack_require__( + /*! ./to-svg */ + "./src/to-svg.js" + ); + var _toSvg2 = _interopRequireDefault(_toSvg); + var _replace = __webpack_require__( + /*! ./replace */ + "./src/replace.js" + ); + var _replace2 = _interopRequireDefault(_replace); + function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { default: obj }; + } + module3.exports = { icons: _icons2.default, toSvg: _toSvg2.default, replace: _replace2.default }; + } + ), + /***/ + "./src/replace.js": ( + /*!************************!*\ + !*** ./src/replace.js ***! + \************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + Object.defineProperty(exports3, "__esModule", { + value: true + }); + var _extends = Object.assign || function(target) { + for (var i = 1; i < arguments.length; i++) { + var source = arguments[i]; + for (var key2 in source) { + if (Object.prototype.hasOwnProperty.call(source, key2)) { + target[key2] = source[key2]; + } + } + } + return target; + }; + var _dedupe = __webpack_require__( + /*! classnames/dedupe */ + "./node_modules/classnames/dedupe.js" + ); + var _dedupe2 = _interopRequireDefault(_dedupe); + var _icons = __webpack_require__( + /*! ./icons */ + "./src/icons.js" + ); + var _icons2 = _interopRequireDefault(_icons); + function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { default: obj }; + } + function replace() { + var attrs = arguments.length > 0 && arguments[0] !== void 0 ? arguments[0] : {}; + if (typeof document === "undefined") { + throw new Error("`feather.replace()` only works in a browser environment."); + } + var elementsToReplace = document.querySelectorAll("[data-feather]"); + Array.from(elementsToReplace).forEach(function(element2) { + return replaceElement(element2, attrs); + }); + } + function replaceElement(element2) { + var attrs = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; + var elementAttrs = getAttrs(element2); + var name = elementAttrs["data-feather"]; + delete elementAttrs["data-feather"]; + var svgString = _icons2.default[name].toSvg(_extends({}, attrs, elementAttrs, { class: (0, _dedupe2.default)(attrs.class, elementAttrs.class) })); + var svgDocument = new DOMParser().parseFromString(svgString, "image/svg+xml"); + var svgElement = svgDocument.querySelector("svg"); + element2.parentNode.replaceChild(svgElement, element2); + } + function getAttrs(element2) { + return Array.from(element2.attributes).reduce(function(attrs, attr2) { + attrs[attr2.name] = attr2.value; + return attrs; + }, {}); + } + exports3.default = replace; + } + ), + /***/ + "./src/tags.json": ( + /*!***********************!*\ + !*** ./src/tags.json ***! + \***********************/ + /*! exports provided: activity, airplay, alert-circle, alert-octagon, alert-triangle, align-center, align-justify, align-left, align-right, anchor, archive, at-sign, award, aperture, bar-chart, bar-chart-2, battery, battery-charging, bell, bell-off, bluetooth, book-open, book, bookmark, box, briefcase, calendar, camera, cast, chevron-down, chevron-up, circle, clipboard, clock, cloud-drizzle, cloud-lightning, cloud-rain, cloud-snow, cloud, codepen, codesandbox, code, coffee, columns, command, compass, copy, corner-down-left, corner-down-right, corner-left-down, corner-left-up, corner-right-down, corner-right-up, corner-up-left, corner-up-right, cpu, credit-card, crop, crosshair, database, delete, disc, dollar-sign, droplet, edit, edit-2, edit-3, eye, eye-off, external-link, facebook, fast-forward, figma, file-minus, file-plus, file-text, film, filter, flag, folder-minus, folder-plus, folder, framer, frown, gift, git-branch, git-commit, git-merge, git-pull-request, github, gitlab, globe, hard-drive, hash, headphones, heart, help-circle, hexagon, home, image, inbox, instagram, key, layers, layout, life-buoy, link, link-2, linkedin, list, lock, log-in, log-out, mail, map-pin, map, maximize, maximize-2, meh, menu, message-circle, message-square, mic-off, mic, minimize, minimize-2, minus, monitor, moon, more-horizontal, more-vertical, mouse-pointer, move, music, navigation, navigation-2, octagon, package, paperclip, pause, pause-circle, pen-tool, percent, phone-call, phone-forwarded, phone-incoming, phone-missed, phone-off, phone-outgoing, phone, play, pie-chart, play-circle, plus, plus-circle, plus-square, pocket, power, printer, radio, refresh-cw, refresh-ccw, repeat, rewind, rotate-ccw, rotate-cw, rss, save, scissors, search, send, settings, share-2, shield, shield-off, shopping-bag, shopping-cart, shuffle, skip-back, skip-forward, slack, slash, sliders, smartphone, smile, speaker, star, stop-circle, sun, sunrise, sunset, tablet, tag, target, terminal, thermometer, thumbs-down, thumbs-up, toggle-left, toggle-right, tool, trash, trash-2, triangle, truck, tv, twitch, twitter, type, umbrella, unlock, user-check, user-minus, user-plus, user-x, user, users, video-off, video, voicemail, volume, volume-1, volume-2, volume-x, watch, wifi-off, wifi, wind, x-circle, x-octagon, x-square, x, youtube, zap-off, zap, zoom-in, zoom-out, default */ + /***/ + function(module3) { + module3.exports = { "activity": ["pulse", "health", "action", "motion"], "airplay": ["stream", "cast", "mirroring"], "alert-circle": ["warning", "alert", "danger"], "alert-octagon": ["warning", "alert", "danger"], "alert-triangle": ["warning", "alert", "danger"], "align-center": ["text alignment", "center"], "align-justify": ["text alignment", "justified"], "align-left": ["text alignment", "left"], "align-right": ["text alignment", "right"], "anchor": [], "archive": ["index", "box"], "at-sign": ["mention", "at", "email", "message"], "award": ["achievement", "badge"], "aperture": ["camera", "photo"], "bar-chart": ["statistics", "diagram", "graph"], "bar-chart-2": ["statistics", "diagram", "graph"], "battery": ["power", "electricity"], "battery-charging": ["power", "electricity"], "bell": ["alarm", "notification", "sound"], "bell-off": ["alarm", "notification", "silent"], "bluetooth": ["wireless"], "book-open": ["read", "library"], "book": ["read", "dictionary", "booklet", "magazine", "library"], "bookmark": ["read", "clip", "marker", "tag"], "box": ["cube"], "briefcase": ["work", "bag", "baggage", "folder"], "calendar": ["date"], "camera": ["photo"], "cast": ["chromecast", "airplay"], "chevron-down": ["expand"], "chevron-up": ["collapse"], "circle": ["off", "zero", "record"], "clipboard": ["copy"], "clock": ["time", "watch", "alarm"], "cloud-drizzle": ["weather", "shower"], "cloud-lightning": ["weather", "bolt"], "cloud-rain": ["weather"], "cloud-snow": ["weather", "blizzard"], "cloud": ["weather"], "codepen": ["logo"], "codesandbox": ["logo"], "code": ["source", "programming"], "coffee": ["drink", "cup", "mug", "tea", "cafe", "hot", "beverage"], "columns": ["layout"], "command": ["keyboard", "cmd", "terminal", "prompt"], "compass": ["navigation", "safari", "travel", "direction"], "copy": ["clone", "duplicate"], "corner-down-left": ["arrow", "return"], "corner-down-right": ["arrow"], "corner-left-down": ["arrow"], "corner-left-up": ["arrow"], "corner-right-down": ["arrow"], "corner-right-up": ["arrow"], "corner-up-left": ["arrow"], "corner-up-right": ["arrow"], "cpu": ["processor", "technology"], "credit-card": ["purchase", "payment", "cc"], "crop": ["photo", "image"], "crosshair": ["aim", "target"], "database": ["storage", "memory"], "delete": ["remove"], "disc": ["album", "cd", "dvd", "music"], "dollar-sign": ["currency", "money", "payment"], "droplet": ["water"], "edit": ["pencil", "change"], "edit-2": ["pencil", "change"], "edit-3": ["pencil", "change"], "eye": ["view", "watch"], "eye-off": ["view", "watch", "hide", "hidden"], "external-link": ["outbound"], "facebook": ["logo", "social"], "fast-forward": ["music"], "figma": ["logo", "design", "tool"], "file-minus": ["delete", "remove", "erase"], "file-plus": ["add", "create", "new"], "file-text": ["data", "txt", "pdf"], "film": ["movie", "video"], "filter": ["funnel", "hopper"], "flag": ["report"], "folder-minus": ["directory"], "folder-plus": ["directory"], "folder": ["directory"], "framer": ["logo", "design", "tool"], "frown": ["emoji", "face", "bad", "sad", "emotion"], "gift": ["present", "box", "birthday", "party"], "git-branch": ["code", "version control"], "git-commit": ["code", "version control"], "git-merge": ["code", "version control"], "git-pull-request": ["code", "version control"], "github": ["logo", "version control"], "gitlab": ["logo", "version control"], "globe": ["world", "browser", "language", "translate"], "hard-drive": ["computer", "server", "memory", "data"], "hash": ["hashtag", "number", "pound"], "headphones": ["music", "audio", "sound"], "heart": ["like", "love", "emotion"], "help-circle": ["question mark"], "hexagon": ["shape", "node.js", "logo"], "home": ["house", "living"], "image": ["picture"], "inbox": ["email"], "instagram": ["logo", "camera"], "key": ["password", "login", "authentication", "secure"], "layers": ["stack"], "layout": ["window", "webpage"], "life-buoy": ["help", "life ring", "support"], "link": ["chain", "url"], "link-2": ["chain", "url"], "linkedin": ["logo", "social media"], "list": ["options"], "lock": ["security", "password", "secure"], "log-in": ["sign in", "arrow", "enter"], "log-out": ["sign out", "arrow", "exit"], "mail": ["email", "message"], "map-pin": ["location", "navigation", "travel", "marker"], "map": ["location", "navigation", "travel"], "maximize": ["fullscreen"], "maximize-2": ["fullscreen", "arrows", "expand"], "meh": ["emoji", "face", "neutral", "emotion"], "menu": ["bars", "navigation", "hamburger"], "message-circle": ["comment", "chat"], "message-square": ["comment", "chat"], "mic-off": ["record", "sound", "mute"], "mic": ["record", "sound", "listen"], "minimize": ["exit fullscreen", "close"], "minimize-2": ["exit fullscreen", "arrows", "close"], "minus": ["subtract"], "monitor": ["tv", "screen", "display"], "moon": ["dark", "night"], "more-horizontal": ["ellipsis"], "more-vertical": ["ellipsis"], "mouse-pointer": ["arrow", "cursor"], "move": ["arrows"], "music": ["note"], "navigation": ["location", "travel"], "navigation-2": ["location", "travel"], "octagon": ["stop"], "package": ["box", "container"], "paperclip": ["attachment"], "pause": ["music", "stop"], "pause-circle": ["music", "audio", "stop"], "pen-tool": ["vector", "drawing"], "percent": ["discount"], "phone-call": ["ring"], "phone-forwarded": ["call"], "phone-incoming": ["call"], "phone-missed": ["call"], "phone-off": ["call", "mute"], "phone-outgoing": ["call"], "phone": ["call"], "play": ["music", "start"], "pie-chart": ["statistics", "diagram"], "play-circle": ["music", "start"], "plus": ["add", "new"], "plus-circle": ["add", "new"], "plus-square": ["add", "new"], "pocket": ["logo", "save"], "power": ["on", "off"], "printer": ["fax", "office", "device"], "radio": ["signal"], "refresh-cw": ["synchronise", "arrows"], "refresh-ccw": ["arrows"], "repeat": ["loop", "arrows"], "rewind": ["music"], "rotate-ccw": ["arrow"], "rotate-cw": ["arrow"], "rss": ["feed", "subscribe"], "save": ["floppy disk"], "scissors": ["cut"], "search": ["find", "magnifier", "magnifying glass"], "send": ["message", "mail", "email", "paper airplane", "paper aeroplane"], "settings": ["cog", "edit", "gear", "preferences"], "share-2": ["network", "connections"], "shield": ["security", "secure"], "shield-off": ["security", "insecure"], "shopping-bag": ["ecommerce", "cart", "purchase", "store"], "shopping-cart": ["ecommerce", "cart", "purchase", "store"], "shuffle": ["music"], "skip-back": ["music"], "skip-forward": ["music"], "slack": ["logo"], "slash": ["ban", "no"], "sliders": ["settings", "controls"], "smartphone": ["cellphone", "device"], "smile": ["emoji", "face", "happy", "good", "emotion"], "speaker": ["audio", "music"], "star": ["bookmark", "favorite", "like"], "stop-circle": ["media", "music"], "sun": ["brightness", "weather", "light"], "sunrise": ["weather", "time", "morning", "day"], "sunset": ["weather", "time", "evening", "night"], "tablet": ["device"], "tag": ["label"], "target": ["logo", "bullseye"], "terminal": ["code", "command line", "prompt"], "thermometer": ["temperature", "celsius", "fahrenheit", "weather"], "thumbs-down": ["dislike", "bad", "emotion"], "thumbs-up": ["like", "good", "emotion"], "toggle-left": ["on", "off", "switch"], "toggle-right": ["on", "off", "switch"], "tool": ["settings", "spanner"], "trash": ["garbage", "delete", "remove", "bin"], "trash-2": ["garbage", "delete", "remove", "bin"], "triangle": ["delta"], "truck": ["delivery", "van", "shipping", "transport", "lorry"], "tv": ["television", "stream"], "twitch": ["logo"], "twitter": ["logo", "social"], "type": ["text"], "umbrella": ["rain", "weather"], "unlock": ["security"], "user-check": ["followed", "subscribed"], "user-minus": ["delete", "remove", "unfollow", "unsubscribe"], "user-plus": ["new", "add", "create", "follow", "subscribe"], "user-x": ["delete", "remove", "unfollow", "unsubscribe", "unavailable"], "user": ["person", "account"], "users": ["group"], "video-off": ["camera", "movie", "film"], "video": ["camera", "movie", "film"], "voicemail": ["phone"], "volume": ["music", "sound", "mute"], "volume-1": ["music", "sound"], "volume-2": ["music", "sound"], "volume-x": ["music", "sound", "mute"], "watch": ["clock", "time"], "wifi-off": ["disabled"], "wifi": ["connection", "signal", "wireless"], "wind": ["weather", "air"], "x-circle": ["cancel", "close", "delete", "remove", "times", "clear"], "x-octagon": ["delete", "stop", "alert", "warning", "times", "clear"], "x-square": ["cancel", "close", "delete", "remove", "times", "clear"], "x": ["cancel", "close", "delete", "remove", "times", "clear"], "youtube": ["logo", "video", "play"], "zap-off": ["flash", "camera", "lightning"], "zap": ["flash", "camera", "lightning"], "zoom-in": ["magnifying glass"], "zoom-out": ["magnifying glass"] }; + } + ), + /***/ + "./src/to-svg.js": ( + /*!***********************!*\ + !*** ./src/to-svg.js ***! + \***********************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + "use strict"; + Object.defineProperty(exports3, "__esModule", { + value: true + }); + var _icons = __webpack_require__( + /*! ./icons */ + "./src/icons.js" + ); + var _icons2 = _interopRequireDefault(_icons); + function _interopRequireDefault(obj) { + return obj && obj.__esModule ? obj : { default: obj }; + } + function toSvg(name) { + var attrs = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {}; + console.warn("feather.toSvg() is deprecated. Please use feather.icons[name].toSvg() instead."); + if (!name) { + throw new Error("The required `key` (icon name) parameter is missing."); + } + if (!_icons2.default[name]) { + throw new Error("No icon matching '" + name + "'. See the complete list of icons at https://feathericons.com"); + } + return _icons2.default[name].toSvg(attrs); + } + exports3.default = toSvg; + } + ), + /***/ + 0: ( + /*!**************************************************!*\ + !*** multi core-js/es/array/from ./src/index.js ***! + \**************************************************/ + /*! no static exports found */ + /***/ + function(module3, exports3, __webpack_require__) { + __webpack_require__( + /*! core-js/es/array/from */ + "./node_modules/core-js/es/array/from.js" + ); + module3.exports = __webpack_require__( + /*! /home/runner/work/feather/feather/src/index.js */ + "./src/index.js" + ); + } + ) + /******/ + }) + ); + }); + } +}); + +// src/main.ts +var main_exports = {}; +__export(main_exports, { + default: () => ObsidianGit +}); +module.exports = __toCommonJS(main_exports); +init_polyfill_buffer(); + +// node_modules/.pnpm/isomorphic-git@1.24.5/node_modules/isomorphic-git/index.js +init_polyfill_buffer(); +var import_async_lock = __toESM(require_async_lock(), 1); +var import_sha1 = __toESM(require_sha1(), 1); +var import_crc_32 = __toESM(require_crc32(), 1); +var import_pako = __toESM(require_pako(), 1); +var import_pify = __toESM(require_pify(), 1); +var import_ignore = __toESM(require_ignore(), 1); +var import_clean_git_ref = __toESM(require_lib2(), 1); +var import_diff3 = __toESM(require_diff3(), 1); +var BaseError = class _BaseError extends Error { + constructor(message) { + super(message); + this.caller = ""; + } + toJSON() { + return { + code: this.code, + data: this.data, + caller: this.caller, + message: this.message, + stack: this.stack + }; + } + fromJSON(json) { + const e = new _BaseError(json.message); + e.code = json.code; + e.data = json.data; + e.caller = json.caller; + e.stack = json.stack; + return e; + } + get isIsomorphicGitError() { + return true; + } +}; +var UnmergedPathsError = class _UnmergedPathsError extends BaseError { + /** + * @param {Array} filepaths + */ + constructor(filepaths) { + super( + `Modifying the index is not possible because you have unmerged files: ${filepaths.toString}. Fix them up in the work tree, and then use 'git add/rm as appropriate to mark resolution and make a commit.` + ); + this.code = this.name = _UnmergedPathsError.code; + this.data = { filepaths }; + } +}; +UnmergedPathsError.code = "UnmergedPathsError"; +var InternalError = class _InternalError extends BaseError { + /** + * @param {string} message + */ + constructor(message) { + super( + `An internal error caused this command to fail. Please file a bug report at https://github.com/isomorphic-git/isomorphic-git/issues with this error message: ${message}` + ); + this.code = this.name = _InternalError.code; + this.data = { message }; + } +}; +InternalError.code = "InternalError"; +var UnsafeFilepathError = class _UnsafeFilepathError extends BaseError { + /** + * @param {string} filepath + */ + constructor(filepath) { + super(`The filepath "${filepath}" contains unsafe character sequences`); + this.code = this.name = _UnsafeFilepathError.code; + this.data = { filepath }; + } +}; +UnsafeFilepathError.code = "UnsafeFilepathError"; +var BufferCursor = class { + constructor(buffer2) { + this.buffer = buffer2; + this._start = 0; + } + eof() { + return this._start >= this.buffer.length; + } + tell() { + return this._start; + } + seek(n) { + this._start = n; + } + slice(n) { + const r = this.buffer.slice(this._start, this._start + n); + this._start += n; + return r; + } + toString(enc, length) { + const r = this.buffer.toString(enc, this._start, this._start + length); + this._start += length; + return r; + } + write(value, length, enc) { + const r = this.buffer.write(value, this._start, length, enc); + this._start += length; + return r; + } + copy(source, start, end) { + const r = source.copy(this.buffer, this._start, start, end); + this._start += r; + return r; + } + readUInt8() { + const r = this.buffer.readUInt8(this._start); + this._start += 1; + return r; + } + writeUInt8(value) { + const r = this.buffer.writeUInt8(value, this._start); + this._start += 1; + return r; + } + readUInt16BE() { + const r = this.buffer.readUInt16BE(this._start); + this._start += 2; + return r; + } + writeUInt16BE(value) { + const r = this.buffer.writeUInt16BE(value, this._start); + this._start += 2; + return r; + } + readUInt32BE() { + const r = this.buffer.readUInt32BE(this._start); + this._start += 4; + return r; + } + writeUInt32BE(value) { + const r = this.buffer.writeUInt32BE(value, this._start); + this._start += 4; + return r; + } +}; +function compareStrings(a, b) { + return -(a < b) || +(a > b); +} +function comparePath(a, b) { + return compareStrings(a.path, b.path); +} +function normalizeMode(mode) { + let type = mode > 0 ? mode >> 12 : 0; + if (type !== 4 && type !== 8 && type !== 10 && type !== 14) { + type = 8; + } + let permissions = mode & 511; + if (permissions & 73) { + permissions = 493; + } else { + permissions = 420; + } + if (type !== 8) + permissions = 0; + return (type << 12) + permissions; +} +var MAX_UINT32 = 2 ** 32; +function SecondsNanoseconds(givenSeconds, givenNanoseconds, milliseconds, date) { + if (givenSeconds !== void 0 && givenNanoseconds !== void 0) { + return [givenSeconds, givenNanoseconds]; + } + if (milliseconds === void 0) { + milliseconds = date.valueOf(); + } + const seconds = Math.floor(milliseconds / 1e3); + const nanoseconds = (milliseconds - seconds * 1e3) * 1e6; + return [seconds, nanoseconds]; +} +function normalizeStats(e) { + const [ctimeSeconds, ctimeNanoseconds] = SecondsNanoseconds( + e.ctimeSeconds, + e.ctimeNanoseconds, + e.ctimeMs, + e.ctime + ); + const [mtimeSeconds, mtimeNanoseconds] = SecondsNanoseconds( + e.mtimeSeconds, + e.mtimeNanoseconds, + e.mtimeMs, + e.mtime + ); + return { + ctimeSeconds: ctimeSeconds % MAX_UINT32, + ctimeNanoseconds: ctimeNanoseconds % MAX_UINT32, + mtimeSeconds: mtimeSeconds % MAX_UINT32, + mtimeNanoseconds: mtimeNanoseconds % MAX_UINT32, + dev: e.dev % MAX_UINT32, + ino: e.ino % MAX_UINT32, + mode: normalizeMode(e.mode % MAX_UINT32), + uid: e.uid % MAX_UINT32, + gid: e.gid % MAX_UINT32, + // size of -1 happens over a BrowserFS HTTP Backend that doesn't serve Content-Length headers + // (like the Karma webserver) because BrowserFS HTTP Backend uses HTTP HEAD requests to do fs.stat + size: e.size > -1 ? e.size % MAX_UINT32 : 0 + }; +} +function toHex(buffer2) { + let hex = ""; + for (const byte of new Uint8Array(buffer2)) { + if (byte < 16) + hex += "0"; + hex += byte.toString(16); + } + return hex; +} +var supportsSubtleSHA1 = null; +async function shasum(buffer2) { + if (supportsSubtleSHA1 === null) { + supportsSubtleSHA1 = await testSubtleSHA1(); + } + return supportsSubtleSHA1 ? subtleSHA1(buffer2) : shasumSync(buffer2); +} +function shasumSync(buffer2) { + return new import_sha1.default().update(buffer2).digest("hex"); +} +async function subtleSHA1(buffer2) { + const hash2 = await crypto.subtle.digest("SHA-1", buffer2); + return toHex(hash2); +} +async function testSubtleSHA1() { + try { + const hash2 = await subtleSHA1(new Uint8Array([])); + if (hash2 === "da39a3ee5e6b4b0d3255bfef95601890afd80709") + return true; + } catch (_) { + } + return false; +} +function parseCacheEntryFlags(bits) { + return { + assumeValid: Boolean(bits & 32768), + extended: Boolean(bits & 16384), + stage: (bits & 12288) >> 12, + nameLength: bits & 4095 + }; +} +function renderCacheEntryFlags(entry) { + const flags = entry.flags; + flags.extended = false; + flags.nameLength = Math.min(Buffer.from(entry.path).length, 4095); + return (flags.assumeValid ? 32768 : 0) + (flags.extended ? 16384 : 0) + ((flags.stage & 3) << 12) + (flags.nameLength & 4095); +} +var GitIndex = class _GitIndex { + /*:: + _entries: Map + _dirty: boolean // Used to determine if index needs to be saved to filesystem + */ + constructor(entries, unmergedPaths) { + this._dirty = false; + this._unmergedPaths = unmergedPaths || /* @__PURE__ */ new Set(); + this._entries = entries || /* @__PURE__ */ new Map(); + } + _addEntry(entry) { + if (entry.flags.stage === 0) { + entry.stages = [entry]; + this._entries.set(entry.path, entry); + this._unmergedPaths.delete(entry.path); + } else { + let existingEntry = this._entries.get(entry.path); + if (!existingEntry) { + this._entries.set(entry.path, entry); + existingEntry = entry; + } + existingEntry.stages[entry.flags.stage] = entry; + this._unmergedPaths.add(entry.path); + } + } + static async from(buffer2) { + if (Buffer.isBuffer(buffer2)) { + return _GitIndex.fromBuffer(buffer2); + } else if (buffer2 === null) { + return new _GitIndex(null); + } else { + throw new InternalError("invalid type passed to GitIndex.from"); + } + } + static async fromBuffer(buffer2) { + if (buffer2.length === 0) { + throw new InternalError("Index file is empty (.git/index)"); + } + const index2 = new _GitIndex(); + const reader = new BufferCursor(buffer2); + const magic = reader.toString("utf8", 4); + if (magic !== "DIRC") { + throw new InternalError(`Invalid dircache magic file number: ${magic}`); + } + const shaComputed = await shasum(buffer2.slice(0, -20)); + const shaClaimed = buffer2.slice(-20).toString("hex"); + if (shaClaimed !== shaComputed) { + throw new InternalError( + `Invalid checksum in GitIndex buffer: expected ${shaClaimed} but saw ${shaComputed}` + ); + } + const version2 = reader.readUInt32BE(); + if (version2 !== 2) { + throw new InternalError(`Unsupported dircache version: ${version2}`); + } + const numEntries = reader.readUInt32BE(); + let i = 0; + while (!reader.eof() && i < numEntries) { + const entry = {}; + entry.ctimeSeconds = reader.readUInt32BE(); + entry.ctimeNanoseconds = reader.readUInt32BE(); + entry.mtimeSeconds = reader.readUInt32BE(); + entry.mtimeNanoseconds = reader.readUInt32BE(); + entry.dev = reader.readUInt32BE(); + entry.ino = reader.readUInt32BE(); + entry.mode = reader.readUInt32BE(); + entry.uid = reader.readUInt32BE(); + entry.gid = reader.readUInt32BE(); + entry.size = reader.readUInt32BE(); + entry.oid = reader.slice(20).toString("hex"); + const flags = reader.readUInt16BE(); + entry.flags = parseCacheEntryFlags(flags); + const pathlength = buffer2.indexOf(0, reader.tell() + 1) - reader.tell(); + if (pathlength < 1) { + throw new InternalError(`Got a path length of: ${pathlength}`); + } + entry.path = reader.toString("utf8", pathlength); + if (entry.path.includes("..\\") || entry.path.includes("../")) { + throw new UnsafeFilepathError(entry.path); + } + let padding = 8 - (reader.tell() - 12) % 8; + if (padding === 0) + padding = 8; + while (padding--) { + const tmp = reader.readUInt8(); + if (tmp !== 0) { + throw new InternalError( + `Expected 1-8 null characters but got '${tmp}' after ${entry.path}` + ); + } else if (reader.eof()) { + throw new InternalError("Unexpected end of file"); + } + } + entry.stages = []; + index2._addEntry(entry); + i++; + } + return index2; + } + get unmergedPaths() { + return [...this._unmergedPaths]; + } + get entries() { + return [...this._entries.values()].sort(comparePath); + } + get entriesMap() { + return this._entries; + } + get entriesFlat() { + return [...this.entries].flatMap((entry) => { + return entry.stages.length > 1 ? entry.stages.filter((x) => x) : entry; + }); + } + *[Symbol.iterator]() { + for (const entry of this.entries) { + yield entry; + } + } + insert({ filepath, stats, oid, stage = 0 }) { + if (!stats) { + stats = { + ctimeSeconds: 0, + ctimeNanoseconds: 0, + mtimeSeconds: 0, + mtimeNanoseconds: 0, + dev: 0, + ino: 0, + mode: 0, + uid: 0, + gid: 0, + size: 0 + }; + } + stats = normalizeStats(stats); + const bfilepath = Buffer.from(filepath); + const entry = { + ctimeSeconds: stats.ctimeSeconds, + ctimeNanoseconds: stats.ctimeNanoseconds, + mtimeSeconds: stats.mtimeSeconds, + mtimeNanoseconds: stats.mtimeNanoseconds, + dev: stats.dev, + ino: stats.ino, + // We provide a fallback value for `mode` here because not all fs + // implementations assign it, but we use it in GitTree. + // '100644' is for a "regular non-executable file" + mode: stats.mode || 33188, + uid: stats.uid, + gid: stats.gid, + size: stats.size, + path: filepath, + oid, + flags: { + assumeValid: false, + extended: false, + stage, + nameLength: bfilepath.length < 4095 ? bfilepath.length : 4095 + }, + stages: [] + }; + this._addEntry(entry); + this._dirty = true; + } + delete({ filepath }) { + if (this._entries.has(filepath)) { + this._entries.delete(filepath); + } else { + for (const key2 of this._entries.keys()) { + if (key2.startsWith(filepath + "/")) { + this._entries.delete(key2); + } + } + } + if (this._unmergedPaths.has(filepath)) { + this._unmergedPaths.delete(filepath); + } + this._dirty = true; + } + clear() { + this._entries.clear(); + this._dirty = true; + } + has({ filepath }) { + return this._entries.has(filepath); + } + render() { + return this.entries.map((entry) => `${entry.mode.toString(8)} ${entry.oid} ${entry.path}`).join("\n"); + } + static async _entryToBuffer(entry) { + const bpath = Buffer.from(entry.path); + const length = Math.ceil((62 + bpath.length + 1) / 8) * 8; + const written = Buffer.alloc(length); + const writer = new BufferCursor(written); + const stat = normalizeStats(entry); + writer.writeUInt32BE(stat.ctimeSeconds); + writer.writeUInt32BE(stat.ctimeNanoseconds); + writer.writeUInt32BE(stat.mtimeSeconds); + writer.writeUInt32BE(stat.mtimeNanoseconds); + writer.writeUInt32BE(stat.dev); + writer.writeUInt32BE(stat.ino); + writer.writeUInt32BE(stat.mode); + writer.writeUInt32BE(stat.uid); + writer.writeUInt32BE(stat.gid); + writer.writeUInt32BE(stat.size); + writer.write(entry.oid, 20, "hex"); + writer.writeUInt16BE(renderCacheEntryFlags(entry)); + writer.write(entry.path, bpath.length, "utf8"); + return written; + } + async toObject() { + const header = Buffer.alloc(12); + const writer = new BufferCursor(header); + writer.write("DIRC", 4, "utf8"); + writer.writeUInt32BE(2); + writer.writeUInt32BE(this.entriesFlat.length); + let entryBuffers = []; + for (const entry of this.entries) { + entryBuffers.push(_GitIndex._entryToBuffer(entry)); + if (entry.stages.length > 1) { + for (const stage of entry.stages) { + if (stage && stage !== entry) { + entryBuffers.push(_GitIndex._entryToBuffer(stage)); + } + } + } + } + entryBuffers = await Promise.all(entryBuffers); + const body = Buffer.concat(entryBuffers); + const main = Buffer.concat([header, body]); + const sum = await shasum(main); + return Buffer.concat([main, Buffer.from(sum, "hex")]); + } +}; +function compareStats(entry, stats) { + const e = normalizeStats(entry); + const s = normalizeStats(stats); + const staleness = e.mode !== s.mode || e.mtimeSeconds !== s.mtimeSeconds || e.ctimeSeconds !== s.ctimeSeconds || e.uid !== s.uid || e.gid !== s.gid || e.ino !== s.ino || e.size !== s.size; + return staleness; +} +var lock = null; +var IndexCache = Symbol("IndexCache"); +function createCache() { + return { + map: /* @__PURE__ */ new Map(), + stats: /* @__PURE__ */ new Map() + }; +} +async function updateCachedIndexFile(fs, filepath, cache) { + const stat = await fs.lstat(filepath); + const rawIndexFile = await fs.read(filepath); + const index2 = await GitIndex.from(rawIndexFile); + cache.map.set(filepath, index2); + cache.stats.set(filepath, stat); +} +async function isIndexStale(fs, filepath, cache) { + const savedStats = cache.stats.get(filepath); + if (savedStats === void 0) + return true; + const currStats = await fs.lstat(filepath); + if (savedStats === null) + return false; + if (currStats === null) + return false; + return compareStats(savedStats, currStats); +} +var GitIndexManager = class { + /** + * + * @param {object} opts + * @param {import('../models/FileSystem.js').FileSystem} opts.fs + * @param {string} opts.gitdir + * @param {object} opts.cache + * @param {bool} opts.allowUnmerged + * @param {function(GitIndex): any} closure + */ + static async acquire({ fs, gitdir, cache, allowUnmerged = true }, closure) { + if (!cache[IndexCache]) + cache[IndexCache] = createCache(); + const filepath = `${gitdir}/index`; + if (lock === null) + lock = new import_async_lock.default({ maxPending: Infinity }); + let result; + let unmergedPaths = []; + await lock.acquire(filepath, async () => { + if (await isIndexStale(fs, filepath, cache[IndexCache])) { + await updateCachedIndexFile(fs, filepath, cache[IndexCache]); + } + const index2 = cache[IndexCache].map.get(filepath); + unmergedPaths = index2.unmergedPaths; + if (unmergedPaths.length && !allowUnmerged) + throw new UnmergedPathsError(unmergedPaths); + result = await closure(index2); + if (index2._dirty) { + const buffer2 = await index2.toObject(); + await fs.write(filepath, buffer2); + cache[IndexCache].stats.set(filepath, await fs.lstat(filepath)); + index2._dirty = false; + } + }); + return result; + } +}; +function basename(path2) { + const last2 = Math.max(path2.lastIndexOf("/"), path2.lastIndexOf("\\")); + if (last2 > -1) { + path2 = path2.slice(last2 + 1); + } + return path2; +} +function dirname(path2) { + const last2 = Math.max(path2.lastIndexOf("/"), path2.lastIndexOf("\\")); + if (last2 === -1) + return "."; + if (last2 === 0) + return "/"; + return path2.slice(0, last2); +} +function flatFileListToDirectoryStructure(files) { + const inodes = /* @__PURE__ */ new Map(); + const mkdir = function(name) { + if (!inodes.has(name)) { + const dir = { + type: "tree", + fullpath: name, + basename: basename(name), + metadata: {}, + children: [] + }; + inodes.set(name, dir); + dir.parent = mkdir(dirname(name)); + if (dir.parent && dir.parent !== dir) + dir.parent.children.push(dir); + } + return inodes.get(name); + }; + const mkfile = function(name, metadata) { + if (!inodes.has(name)) { + const file = { + type: "blob", + fullpath: name, + basename: basename(name), + metadata, + // This recursively generates any missing parent folders. + parent: mkdir(dirname(name)), + children: [] + }; + if (file.parent) + file.parent.children.push(file); + inodes.set(name, file); + } + return inodes.get(name); + }; + mkdir("."); + for (const file of files) { + mkfile(file.path, file); + } + return inodes; +} +function mode2type(mode) { + switch (mode) { + case 16384: + return "tree"; + case 33188: + return "blob"; + case 33261: + return "blob"; + case 40960: + return "blob"; + case 57344: + return "commit"; + } + throw new InternalError(`Unexpected GitTree entry mode: ${mode.toString(8)}`); +} +var GitWalkerIndex = class { + constructor({ fs, gitdir, cache }) { + this.treePromise = GitIndexManager.acquire( + { fs, gitdir, cache }, + async function(index2) { + return flatFileListToDirectoryStructure(index2.entries); + } + ); + const walker = this; + this.ConstructEntry = class StageEntry { + constructor(fullpath) { + this._fullpath = fullpath; + this._type = false; + this._mode = false; + this._stat = false; + this._oid = false; + } + async type() { + return walker.type(this); + } + async mode() { + return walker.mode(this); + } + async stat() { + return walker.stat(this); + } + async content() { + return walker.content(this); + } + async oid() { + return walker.oid(this); + } + }; + } + async readdir(entry) { + const filepath = entry._fullpath; + const tree = await this.treePromise; + const inode = tree.get(filepath); + if (!inode) + return null; + if (inode.type === "blob") + return null; + if (inode.type !== "tree") { + throw new Error(`ENOTDIR: not a directory, scandir '${filepath}'`); + } + const names = inode.children.map((inode2) => inode2.fullpath); + names.sort(compareStrings); + return names; + } + async type(entry) { + if (entry._type === false) { + await entry.stat(); + } + return entry._type; + } + async mode(entry) { + if (entry._mode === false) { + await entry.stat(); + } + return entry._mode; + } + async stat(entry) { + if (entry._stat === false) { + const tree = await this.treePromise; + const inode = tree.get(entry._fullpath); + if (!inode) { + throw new Error( + `ENOENT: no such file or directory, lstat '${entry._fullpath}'` + ); + } + const stats = inode.type === "tree" ? {} : normalizeStats(inode.metadata); + entry._type = inode.type === "tree" ? "tree" : mode2type(stats.mode); + entry._mode = stats.mode; + if (inode.type === "tree") { + entry._stat = void 0; + } else { + entry._stat = stats; + } + } + return entry._stat; + } + async content(_entry) { + } + async oid(entry) { + if (entry._oid === false) { + const tree = await this.treePromise; + const inode = tree.get(entry._fullpath); + entry._oid = inode.metadata.oid; + } + return entry._oid; + } +}; +var GitWalkSymbol = Symbol("GitWalkSymbol"); +function STAGE() { + const o = /* @__PURE__ */ Object.create(null); + Object.defineProperty(o, GitWalkSymbol, { + value: function({ fs, gitdir, cache }) { + return new GitWalkerIndex({ fs, gitdir, cache }); + } + }); + Object.freeze(o); + return o; +} +var NotFoundError = class _NotFoundError extends BaseError { + /** + * @param {string} what + */ + constructor(what) { + super(`Could not find ${what}.`); + this.code = this.name = _NotFoundError.code; + this.data = { what }; + } +}; +NotFoundError.code = "NotFoundError"; +var ObjectTypeError = class _ObjectTypeError extends BaseError { + /** + * @param {string} oid + * @param {'blob'|'commit'|'tag'|'tree'} actual + * @param {'blob'|'commit'|'tag'|'tree'} expected + * @param {string} [filepath] + */ + constructor(oid, actual, expected, filepath) { + super( + `Object ${oid} ${filepath ? `at ${filepath}` : ""}was anticipated to be a ${expected} but it is a ${actual}.` + ); + this.code = this.name = _ObjectTypeError.code; + this.data = { oid, actual, expected, filepath }; + } +}; +ObjectTypeError.code = "ObjectTypeError"; +var InvalidOidError = class _InvalidOidError extends BaseError { + /** + * @param {string} value + */ + constructor(value) { + super(`Expected a 40-char hex object id but saw "${value}".`); + this.code = this.name = _InvalidOidError.code; + this.data = { value }; + } +}; +InvalidOidError.code = "InvalidOidError"; +var NoRefspecError = class _NoRefspecError extends BaseError { + /** + * @param {string} remote + */ + constructor(remote) { + super(`Could not find a fetch refspec for remote "${remote}". Make sure the config file has an entry like the following: +[remote "${remote}"] + fetch = +refs/heads/*:refs/remotes/origin/* +`); + this.code = this.name = _NoRefspecError.code; + this.data = { remote }; + } +}; +NoRefspecError.code = "NoRefspecError"; +var GitPackedRefs = class _GitPackedRefs { + constructor(text2) { + this.refs = /* @__PURE__ */ new Map(); + this.parsedConfig = []; + if (text2) { + let key2 = null; + this.parsedConfig = text2.trim().split("\n").map((line) => { + if (/^\s*#/.test(line)) { + return { line, comment: true }; + } + const i = line.indexOf(" "); + if (line.startsWith("^")) { + const value = line.slice(1); + this.refs.set(key2 + "^{}", value); + return { line, ref: key2, peeled: value }; + } else { + const value = line.slice(0, i); + key2 = line.slice(i + 1); + this.refs.set(key2, value); + return { line, ref: key2, oid: value }; + } + }); + } + return this; + } + static from(text2) { + return new _GitPackedRefs(text2); + } + delete(ref) { + this.parsedConfig = this.parsedConfig.filter((entry) => entry.ref !== ref); + this.refs.delete(ref); + } + toString() { + return this.parsedConfig.map(({ line }) => line).join("\n") + "\n"; + } +}; +var GitRefSpec = class _GitRefSpec { + constructor({ remotePath, localPath, force, matchPrefix }) { + Object.assign(this, { + remotePath, + localPath, + force, + matchPrefix + }); + } + static from(refspec) { + const [ + forceMatch, + remotePath, + remoteGlobMatch, + localPath, + localGlobMatch + ] = refspec.match(/^(\+?)(.*?)(\*?):(.*?)(\*?)$/).slice(1); + const force = forceMatch === "+"; + const remoteIsGlob = remoteGlobMatch === "*"; + const localIsGlob = localGlobMatch === "*"; + if (remoteIsGlob !== localIsGlob) { + throw new InternalError("Invalid refspec"); + } + return new _GitRefSpec({ + remotePath, + localPath, + force, + matchPrefix: remoteIsGlob + }); + } + translate(remoteBranch) { + if (this.matchPrefix) { + if (remoteBranch.startsWith(this.remotePath)) { + return this.localPath + remoteBranch.replace(this.remotePath, ""); + } + } else { + if (remoteBranch === this.remotePath) + return this.localPath; + } + return null; + } + reverseTranslate(localBranch) { + if (this.matchPrefix) { + if (localBranch.startsWith(this.localPath)) { + return this.remotePath + localBranch.replace(this.localPath, ""); + } + } else { + if (localBranch === this.localPath) + return this.remotePath; + } + return null; + } +}; +var GitRefSpecSet = class _GitRefSpecSet { + constructor(rules = []) { + this.rules = rules; + } + static from(refspecs) { + const rules = []; + for (const refspec of refspecs) { + rules.push(GitRefSpec.from(refspec)); + } + return new _GitRefSpecSet(rules); + } + add(refspec) { + const rule = GitRefSpec.from(refspec); + this.rules.push(rule); + } + translate(remoteRefs) { + const result = []; + for (const rule of this.rules) { + for (const remoteRef of remoteRefs) { + const localRef = rule.translate(remoteRef); + if (localRef) { + result.push([remoteRef, localRef]); + } + } + } + return result; + } + translateOne(remoteRef) { + let result = null; + for (const rule of this.rules) { + const localRef = rule.translate(remoteRef); + if (localRef) { + result = localRef; + } + } + return result; + } + localNamespaces() { + return this.rules.filter((rule) => rule.matchPrefix).map((rule) => rule.localPath.replace(/\/$/, "")); + } +}; +function compareRefNames(a, b) { + const _a2 = a.replace(/\^\{\}$/, ""); + const _b = b.replace(/\^\{\}$/, ""); + const tmp = -(_a2 < _b) || +(_a2 > _b); + if (tmp === 0) { + return a.endsWith("^{}") ? 1 : -1; + } + return tmp; +} +function normalizePath(path2) { + return path2.replace(/\/\.\//g, "/").replace(/\/{2,}/g, "/").replace(/^\/\.$/, "/").replace(/^\.\/$/, ".").replace(/^\.\//, "").replace(/\/\.$/, "").replace(/(.+)\/$/, "$1").replace(/^$/, "."); +} +function join(...parts) { + return normalizePath(parts.map(normalizePath).join("/")); +} +var num = (val) => { + val = val.toLowerCase(); + let n = parseInt(val); + if (val.endsWith("k")) + n *= 1024; + if (val.endsWith("m")) + n *= 1024 * 1024; + if (val.endsWith("g")) + n *= 1024 * 1024 * 1024; + return n; +}; +var bool = (val) => { + val = val.trim().toLowerCase(); + if (val === "true" || val === "yes" || val === "on") + return true; + if (val === "false" || val === "no" || val === "off") + return false; + throw Error( + `Expected 'true', 'false', 'yes', 'no', 'on', or 'off', but got ${val}` + ); +}; +var schema = { + core: { + filemode: bool, + bare: bool, + logallrefupdates: bool, + symlinks: bool, + ignorecase: bool, + bigFileThreshold: num + } +}; +var SECTION_LINE_REGEX = /^\[([A-Za-z0-9-.]+)(?: "(.*)")?\]$/; +var SECTION_REGEX = /^[A-Za-z0-9-.]+$/; +var VARIABLE_LINE_REGEX = /^([A-Za-z][A-Za-z-]*)(?: *= *(.*))?$/; +var VARIABLE_NAME_REGEX = /^[A-Za-z][A-Za-z-]*$/; +var VARIABLE_VALUE_COMMENT_REGEX = /^(.*?)( *[#;].*)$/; +var extractSectionLine = (line) => { + const matches = SECTION_LINE_REGEX.exec(line); + if (matches != null) { + const [section, subsection] = matches.slice(1); + return [section, subsection]; + } + return null; +}; +var extractVariableLine = (line) => { + const matches = VARIABLE_LINE_REGEX.exec(line); + if (matches != null) { + const [name, rawValue = "true"] = matches.slice(1); + const valueWithoutComments = removeComments(rawValue); + const valueWithoutQuotes = removeQuotes(valueWithoutComments); + return [name, valueWithoutQuotes]; + } + return null; +}; +var removeComments = (rawValue) => { + const commentMatches = VARIABLE_VALUE_COMMENT_REGEX.exec(rawValue); + if (commentMatches == null) { + return rawValue; + } + const [valueWithoutComment, comment] = commentMatches.slice(1); + if (hasOddNumberOfQuotes(valueWithoutComment) && hasOddNumberOfQuotes(comment)) { + return `${valueWithoutComment}${comment}`; + } + return valueWithoutComment; +}; +var hasOddNumberOfQuotes = (text2) => { + const numberOfQuotes = (text2.match(/(?:^|[^\\])"/g) || []).length; + return numberOfQuotes % 2 !== 0; +}; +var removeQuotes = (text2) => { + return text2.split("").reduce((newText, c, idx, text3) => { + const isQuote = c === '"' && text3[idx - 1] !== "\\"; + const isEscapeForQuote = c === "\\" && text3[idx + 1] === '"'; + if (isQuote || isEscapeForQuote) { + return newText; + } + return newText + c; + }, ""); +}; +var lower = (text2) => { + return text2 != null ? text2.toLowerCase() : null; +}; +var getPath = (section, subsection, name) => { + return [lower(section), subsection, lower(name)].filter((a) => a != null).join("."); +}; +var normalizePath$1 = (path2) => { + const pathSegments = path2.split("."); + const section = pathSegments.shift(); + const name = pathSegments.pop(); + const subsection = pathSegments.length ? pathSegments.join(".") : void 0; + return { + section, + subsection, + name, + path: getPath(section, subsection, name), + sectionPath: getPath(section, subsection, null) + }; +}; +var findLastIndex = (array, callback) => { + return array.reduce((lastIndex, item, index2) => { + return callback(item) ? index2 : lastIndex; + }, -1); +}; +var GitConfig = class _GitConfig { + constructor(text2) { + let section = null; + let subsection = null; + this.parsedConfig = text2.split("\n").map((line) => { + let name = null; + let value = null; + const trimmedLine = line.trim(); + const extractedSection = extractSectionLine(trimmedLine); + const isSection = extractedSection != null; + if (isSection) { + ; + [section, subsection] = extractedSection; + } else { + const extractedVariable = extractVariableLine(trimmedLine); + const isVariable = extractedVariable != null; + if (isVariable) { + ; + [name, value] = extractedVariable; + } + } + const path2 = getPath(section, subsection, name); + return { line, isSection, section, subsection, name, value, path: path2 }; + }); + } + static from(text2) { + return new _GitConfig(text2); + } + async get(path2, getall = false) { + const normalizedPath = normalizePath$1(path2).path; + const allValues = this.parsedConfig.filter((config) => config.path === normalizedPath).map(({ section, name, value }) => { + const fn = schema[section] && schema[section][name]; + return fn ? fn(value) : value; + }); + return getall ? allValues : allValues.pop(); + } + async getall(path2) { + return this.get(path2, true); + } + async getSubsections(section) { + return this.parsedConfig.filter((config) => config.section === section && config.isSection).map((config) => config.subsection); + } + async deleteSection(section, subsection) { + this.parsedConfig = this.parsedConfig.filter( + (config) => !(config.section === section && config.subsection === subsection) + ); + } + async append(path2, value) { + return this.set(path2, value, true); + } + async set(path2, value, append3 = false) { + const { + section, + subsection, + name, + path: normalizedPath, + sectionPath + } = normalizePath$1(path2); + const configIndex = findLastIndex( + this.parsedConfig, + (config) => config.path === normalizedPath + ); + if (value == null) { + if (configIndex !== -1) { + this.parsedConfig.splice(configIndex, 1); + } + } else { + if (configIndex !== -1) { + const config = this.parsedConfig[configIndex]; + const modifiedConfig = Object.assign({}, config, { + name, + value, + modified: true + }); + if (append3) { + this.parsedConfig.splice(configIndex + 1, 0, modifiedConfig); + } else { + this.parsedConfig[configIndex] = modifiedConfig; + } + } else { + const sectionIndex = this.parsedConfig.findIndex( + (config) => config.path === sectionPath + ); + const newConfig = { + section, + subsection, + name, + value, + modified: true, + path: normalizedPath + }; + if (SECTION_REGEX.test(section) && VARIABLE_NAME_REGEX.test(name)) { + if (sectionIndex >= 0) { + this.parsedConfig.splice(sectionIndex + 1, 0, newConfig); + } else { + const newSection = { + section, + subsection, + modified: true, + path: sectionPath + }; + this.parsedConfig.push(newSection, newConfig); + } + } + } + } + } + toString() { + return this.parsedConfig.map(({ line, section, subsection, name, value, modified: modified2 = false }) => { + if (!modified2) { + return line; + } + if (name != null && value != null) { + if (typeof value === "string" && /[#;]/.test(value)) { + return ` ${name} = "${value}"`; + } + return ` ${name} = ${value}`; + } + if (subsection != null) { + return `[${section} "${subsection}"]`; + } + return `[${section}]`; + }).join("\n"); + } +}; +var GitConfigManager = class { + static async get({ fs, gitdir }) { + const text2 = await fs.read(`${gitdir}/config`, { encoding: "utf8" }); + return GitConfig.from(text2); + } + static async save({ fs, gitdir, config }) { + await fs.write(`${gitdir}/config`, config.toString(), { + encoding: "utf8" + }); + } +}; +var refpaths = (ref) => [ + `${ref}`, + `refs/${ref}`, + `refs/tags/${ref}`, + `refs/heads/${ref}`, + `refs/remotes/${ref}`, + `refs/remotes/${ref}/HEAD` +]; +var GIT_FILES = ["config", "description", "index", "shallow", "commondir"]; +var GitRefManager = class _GitRefManager { + static async updateRemoteRefs({ + fs, + gitdir, + remote, + refs, + symrefs, + tags, + refspecs = void 0, + prune = false, + pruneTags = false + }) { + for (const value of refs.values()) { + if (!value.match(/[0-9a-f]{40}/)) { + throw new InvalidOidError(value); + } + } + const config = await GitConfigManager.get({ fs, gitdir }); + if (!refspecs) { + refspecs = await config.getall(`remote.${remote}.fetch`); + if (refspecs.length === 0) { + throw new NoRefspecError(remote); + } + refspecs.unshift(`+HEAD:refs/remotes/${remote}/HEAD`); + } + const refspec = GitRefSpecSet.from(refspecs); + const actualRefsToWrite = /* @__PURE__ */ new Map(); + if (pruneTags) { + const tags2 = await _GitRefManager.listRefs({ + fs, + gitdir, + filepath: "refs/tags" + }); + await _GitRefManager.deleteRefs({ + fs, + gitdir, + refs: tags2.map((tag2) => `refs/tags/${tag2}`) + }); + } + if (tags) { + for (const serverRef of refs.keys()) { + if (serverRef.startsWith("refs/tags") && !serverRef.endsWith("^{}")) { + if (!await _GitRefManager.exists({ fs, gitdir, ref: serverRef })) { + const oid = refs.get(serverRef); + actualRefsToWrite.set(serverRef, oid); + } + } + } + } + const refTranslations = refspec.translate([...refs.keys()]); + for (const [serverRef, translatedRef] of refTranslations) { + const value = refs.get(serverRef); + actualRefsToWrite.set(translatedRef, value); + } + const symrefTranslations = refspec.translate([...symrefs.keys()]); + for (const [serverRef, translatedRef] of symrefTranslations) { + const value = symrefs.get(serverRef); + const symtarget = refspec.translateOne(value); + if (symtarget) { + actualRefsToWrite.set(translatedRef, `ref: ${symtarget}`); + } + } + const pruned = []; + if (prune) { + for (const filepath of refspec.localNamespaces()) { + const refs2 = (await _GitRefManager.listRefs({ + fs, + gitdir, + filepath + })).map((file) => `${filepath}/${file}`); + for (const ref of refs2) { + if (!actualRefsToWrite.has(ref)) { + pruned.push(ref); + } + } + } + if (pruned.length > 0) { + await _GitRefManager.deleteRefs({ fs, gitdir, refs: pruned }); + } + } + for (const [key2, value] of actualRefsToWrite) { + await fs.write(join(gitdir, key2), `${value.trim()} +`, "utf8"); + } + return { pruned }; + } + // TODO: make this less crude? + static async writeRef({ fs, gitdir, ref, value }) { + if (!value.match(/[0-9a-f]{40}/)) { + throw new InvalidOidError(value); + } + await fs.write(join(gitdir, ref), `${value.trim()} +`, "utf8"); + } + static async writeSymbolicRef({ fs, gitdir, ref, value }) { + await fs.write(join(gitdir, ref), `ref: ${value.trim()} +`, "utf8"); + } + static async deleteRef({ fs, gitdir, ref }) { + return _GitRefManager.deleteRefs({ fs, gitdir, refs: [ref] }); + } + static async deleteRefs({ fs, gitdir, refs }) { + await Promise.all(refs.map((ref) => fs.rm(join(gitdir, ref)))); + let text2 = await fs.read(`${gitdir}/packed-refs`, { encoding: "utf8" }); + const packed = GitPackedRefs.from(text2); + const beforeSize = packed.refs.size; + for (const ref of refs) { + if (packed.refs.has(ref)) { + packed.delete(ref); + } + } + if (packed.refs.size < beforeSize) { + text2 = packed.toString(); + await fs.write(`${gitdir}/packed-refs`, text2, { encoding: "utf8" }); + } + } + /** + * @param {object} args + * @param {import('../models/FileSystem.js').FileSystem} args.fs + * @param {string} args.gitdir + * @param {string} args.ref + * @param {number} [args.depth] + * @returns {Promise} + */ + static async resolve({ fs, gitdir, ref, depth = void 0 }) { + if (depth !== void 0) { + depth--; + if (depth === -1) { + return ref; + } + } + let sha; + if (ref.startsWith("ref: ")) { + ref = ref.slice("ref: ".length); + return _GitRefManager.resolve({ fs, gitdir, ref, depth }); + } + if (ref.length === 40 && /[0-9a-f]{40}/.test(ref)) { + return ref; + } + const packedMap = await _GitRefManager.packedRefs({ fs, gitdir }); + const allpaths = refpaths(ref).filter((p) => !GIT_FILES.includes(p)); + for (const ref2 of allpaths) { + sha = await fs.read(`${gitdir}/${ref2}`, { encoding: "utf8" }) || packedMap.get(ref2); + if (sha) { + return _GitRefManager.resolve({ fs, gitdir, ref: sha.trim(), depth }); + } + } + throw new NotFoundError(ref); + } + static async exists({ fs, gitdir, ref }) { + try { + await _GitRefManager.expand({ fs, gitdir, ref }); + return true; + } catch (err) { + return false; + } + } + static async expand({ fs, gitdir, ref }) { + if (ref.length === 40 && /[0-9a-f]{40}/.test(ref)) { + return ref; + } + const packedMap = await _GitRefManager.packedRefs({ fs, gitdir }); + const allpaths = refpaths(ref); + for (const ref2 of allpaths) { + if (await fs.exists(`${gitdir}/${ref2}`)) + return ref2; + if (packedMap.has(ref2)) + return ref2; + } + throw new NotFoundError(ref); + } + static async expandAgainstMap({ ref, map }) { + const allpaths = refpaths(ref); + for (const ref2 of allpaths) { + if (await map.has(ref2)) + return ref2; + } + throw new NotFoundError(ref); + } + static resolveAgainstMap({ ref, fullref = ref, depth = void 0, map }) { + if (depth !== void 0) { + depth--; + if (depth === -1) { + return { fullref, oid: ref }; + } + } + if (ref.startsWith("ref: ")) { + ref = ref.slice("ref: ".length); + return _GitRefManager.resolveAgainstMap({ ref, fullref, depth, map }); + } + if (ref.length === 40 && /[0-9a-f]{40}/.test(ref)) { + return { fullref, oid: ref }; + } + const allpaths = refpaths(ref); + for (const ref2 of allpaths) { + const sha = map.get(ref2); + if (sha) { + return _GitRefManager.resolveAgainstMap({ + ref: sha.trim(), + fullref: ref2, + depth, + map + }); + } + } + throw new NotFoundError(ref); + } + static async packedRefs({ fs, gitdir }) { + const text2 = await fs.read(`${gitdir}/packed-refs`, { encoding: "utf8" }); + const packed = GitPackedRefs.from(text2); + return packed.refs; + } + // List all the refs that match the `filepath` prefix + static async listRefs({ fs, gitdir, filepath }) { + const packedMap = _GitRefManager.packedRefs({ fs, gitdir }); + let files = null; + try { + files = await fs.readdirDeep(`${gitdir}/${filepath}`); + files = files.map((x) => x.replace(`${gitdir}/${filepath}/`, "")); + } catch (err) { + files = []; + } + for (let key2 of (await packedMap).keys()) { + if (key2.startsWith(filepath)) { + key2 = key2.replace(filepath + "/", ""); + if (!files.includes(key2)) { + files.push(key2); + } + } + } + files.sort(compareRefNames); + return files; + } + static async listBranches({ fs, gitdir, remote }) { + if (remote) { + return _GitRefManager.listRefs({ + fs, + gitdir, + filepath: `refs/remotes/${remote}` + }); + } else { + return _GitRefManager.listRefs({ fs, gitdir, filepath: `refs/heads` }); + } + } + static async listTags({ fs, gitdir }) { + const tags = await _GitRefManager.listRefs({ + fs, + gitdir, + filepath: `refs/tags` + }); + return tags.filter((x) => !x.endsWith("^{}")); + } +}; +function compareTreeEntryPath(a, b) { + return compareStrings(appendSlashIfDir(a), appendSlashIfDir(b)); +} +function appendSlashIfDir(entry) { + return entry.mode === "040000" ? entry.path + "/" : entry.path; +} +function mode2type$1(mode) { + switch (mode) { + case "040000": + return "tree"; + case "100644": + return "blob"; + case "100755": + return "blob"; + case "120000": + return "blob"; + case "160000": + return "commit"; + } + throw new InternalError(`Unexpected GitTree entry mode: ${mode}`); +} +function parseBuffer(buffer2) { + const _entries = []; + let cursor = 0; + while (cursor < buffer2.length) { + const space2 = buffer2.indexOf(32, cursor); + if (space2 === -1) { + throw new InternalError( + `GitTree: Error parsing buffer at byte location ${cursor}: Could not find the next space character.` + ); + } + const nullchar = buffer2.indexOf(0, cursor); + if (nullchar === -1) { + throw new InternalError( + `GitTree: Error parsing buffer at byte location ${cursor}: Could not find the next null character.` + ); + } + let mode = buffer2.slice(cursor, space2).toString("utf8"); + if (mode === "40000") + mode = "040000"; + const type = mode2type$1(mode); + const path2 = buffer2.slice(space2 + 1, nullchar).toString("utf8"); + if (path2.includes("\\") || path2.includes("/")) { + throw new UnsafeFilepathError(path2); + } + const oid = buffer2.slice(nullchar + 1, nullchar + 21).toString("hex"); + cursor = nullchar + 21; + _entries.push({ mode, path: path2, oid, type }); + } + return _entries; +} +function limitModeToAllowed(mode) { + if (typeof mode === "number") { + mode = mode.toString(8); + } + if (mode.match(/^0?4.*/)) + return "040000"; + if (mode.match(/^1006.*/)) + return "100644"; + if (mode.match(/^1007.*/)) + return "100755"; + if (mode.match(/^120.*/)) + return "120000"; + if (mode.match(/^160.*/)) + return "160000"; + throw new InternalError(`Could not understand file mode: ${mode}`); +} +function nudgeIntoShape(entry) { + if (!entry.oid && entry.sha) { + entry.oid = entry.sha; + } + entry.mode = limitModeToAllowed(entry.mode); + if (!entry.type) { + entry.type = mode2type$1(entry.mode); + } + return entry; +} +var GitTree = class _GitTree { + constructor(entries) { + if (Buffer.isBuffer(entries)) { + this._entries = parseBuffer(entries); + } else if (Array.isArray(entries)) { + this._entries = entries.map(nudgeIntoShape); + } else { + throw new InternalError("invalid type passed to GitTree constructor"); + } + this._entries.sort(comparePath); + } + static from(tree) { + return new _GitTree(tree); + } + render() { + return this._entries.map((entry) => `${entry.mode} ${entry.type} ${entry.oid} ${entry.path}`).join("\n"); + } + toObject() { + const entries = [...this._entries]; + entries.sort(compareTreeEntryPath); + return Buffer.concat( + entries.map((entry) => { + const mode = Buffer.from(entry.mode.replace(/^0/, "")); + const space2 = Buffer.from(" "); + const path2 = Buffer.from(entry.path, "utf8"); + const nullchar = Buffer.from([0]); + const oid = Buffer.from(entry.oid, "hex"); + return Buffer.concat([mode, space2, path2, nullchar, oid]); + }) + ); + } + /** + * @returns {TreeEntry[]} + */ + entries() { + return this._entries; + } + *[Symbol.iterator]() { + for (const entry of this._entries) { + yield entry; + } + } +}; +var GitObject = class { + static wrap({ type, object }) { + return Buffer.concat([ + Buffer.from(`${type} ${object.byteLength.toString()}\0`), + Buffer.from(object) + ]); + } + static unwrap(buffer2) { + const s = buffer2.indexOf(32); + const i = buffer2.indexOf(0); + const type = buffer2.slice(0, s).toString("utf8"); + const length = buffer2.slice(s + 1, i).toString("utf8"); + const actualLength = buffer2.length - (i + 1); + if (parseInt(length) !== actualLength) { + throw new InternalError( + `Length mismatch: expected ${length} bytes but got ${actualLength} instead.` + ); + } + return { + type, + object: Buffer.from(buffer2.slice(i + 1)) + }; + } +}; +async function readObjectLoose({ fs, gitdir, oid }) { + const source = `objects/${oid.slice(0, 2)}/${oid.slice(2)}`; + const file = await fs.read(`${gitdir}/${source}`); + if (!file) { + return null; + } + return { object: file, format: "deflated", source }; +} +function applyDelta(delta, source) { + const reader = new BufferCursor(delta); + const sourceSize = readVarIntLE(reader); + if (sourceSize !== source.byteLength) { + throw new InternalError( + `applyDelta expected source buffer to be ${sourceSize} bytes but the provided buffer was ${source.length} bytes` + ); + } + const targetSize = readVarIntLE(reader); + let target; + const firstOp = readOp(reader, source); + if (firstOp.byteLength === targetSize) { + target = firstOp; + } else { + target = Buffer.alloc(targetSize); + const writer = new BufferCursor(target); + writer.copy(firstOp); + while (!reader.eof()) { + writer.copy(readOp(reader, source)); + } + const tell = writer.tell(); + if (targetSize !== tell) { + throw new InternalError( + `applyDelta expected target buffer to be ${targetSize} bytes but the resulting buffer was ${tell} bytes` + ); + } + } + return target; +} +function readVarIntLE(reader) { + let result = 0; + let shift = 0; + let byte = null; + do { + byte = reader.readUInt8(); + result |= (byte & 127) << shift; + shift += 7; + } while (byte & 128); + return result; +} +function readCompactLE(reader, flags, size) { + let result = 0; + let shift = 0; + while (size--) { + if (flags & 1) { + result |= reader.readUInt8() << shift; + } + flags >>= 1; + shift += 8; + } + return result; +} +function readOp(reader, source) { + const byte = reader.readUInt8(); + const COPY = 128; + const OFFS = 15; + const SIZE = 112; + if (byte & COPY) { + const offset = readCompactLE(reader, byte & OFFS, 4); + let size = readCompactLE(reader, (byte & SIZE) >> 4, 3); + if (size === 0) + size = 65536; + return source.slice(offset, offset + size); + } else { + return reader.slice(byte); + } +} +function fromValue(value) { + let queue = [value]; + return { + next() { + return Promise.resolve({ done: queue.length === 0, value: queue.pop() }); + }, + return() { + queue = []; + return {}; + }, + [Symbol.asyncIterator]() { + return this; + } + }; +} +function getIterator(iterable) { + if (iterable[Symbol.asyncIterator]) { + return iterable[Symbol.asyncIterator](); + } + if (iterable[Symbol.iterator]) { + return iterable[Symbol.iterator](); + } + if (iterable.next) { + return iterable; + } + return fromValue(iterable); +} +var StreamReader = class { + constructor(stream) { + this.stream = getIterator(stream); + this.buffer = null; + this.cursor = 0; + this.undoCursor = 0; + this.started = false; + this._ended = false; + this._discardedBytes = 0; + } + eof() { + return this._ended && this.cursor === this.buffer.length; + } + tell() { + return this._discardedBytes + this.cursor; + } + async byte() { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor === this.buffer.length) { + await this._loadnext(); + if (this._ended) + return; + } + this._moveCursor(1); + return this.buffer[this.undoCursor]; + } + async chunk() { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor === this.buffer.length) { + await this._loadnext(); + if (this._ended) + return; + } + this._moveCursor(this.buffer.length); + return this.buffer.slice(this.undoCursor, this.cursor); + } + async read(n) { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor + n > this.buffer.length) { + this._trim(); + await this._accumulate(n); + } + this._moveCursor(n); + return this.buffer.slice(this.undoCursor, this.cursor); + } + async skip(n) { + if (this.eof()) + return; + if (!this.started) + await this._init(); + if (this.cursor + n > this.buffer.length) { + this._trim(); + await this._accumulate(n); + } + this._moveCursor(n); + } + async undo() { + this.cursor = this.undoCursor; + } + async _next() { + this.started = true; + let { done, value } = await this.stream.next(); + if (done) { + this._ended = true; + } + if (value) { + value = Buffer.from(value); + } + return value; + } + _trim() { + this.buffer = this.buffer.slice(this.undoCursor); + this.cursor -= this.undoCursor; + this._discardedBytes += this.undoCursor; + this.undoCursor = 0; + } + _moveCursor(n) { + this.undoCursor = this.cursor; + this.cursor += n; + if (this.cursor > this.buffer.length) { + this.cursor = this.buffer.length; + } + } + async _accumulate(n) { + if (this._ended) + return; + const buffers = [this.buffer]; + while (this.cursor + n > lengthBuffers(buffers)) { + const nextbuffer = await this._next(); + if (this._ended) + break; + buffers.push(nextbuffer); + } + this.buffer = Buffer.concat(buffers); + } + async _loadnext() { + this._discardedBytes += this.buffer.length; + this.undoCursor = 0; + this.cursor = 0; + this.buffer = await this._next(); + } + async _init() { + this.buffer = await this._next(); + } +}; +function lengthBuffers(buffers) { + return buffers.reduce((acc, buffer2) => acc + buffer2.length, 0); +} +async function listpack(stream, onData) { + const reader = new StreamReader(stream); + let PACK = await reader.read(4); + PACK = PACK.toString("utf8"); + if (PACK !== "PACK") { + throw new InternalError(`Invalid PACK header '${PACK}'`); + } + let version2 = await reader.read(4); + version2 = version2.readUInt32BE(0); + if (version2 !== 2) { + throw new InternalError(`Invalid packfile version: ${version2}`); + } + let numObjects = await reader.read(4); + numObjects = numObjects.readUInt32BE(0); + if (numObjects < 1) + return; + while (!reader.eof() && numObjects--) { + const offset = reader.tell(); + const { type, length, ofs, reference } = await parseHeader(reader); + const inflator = new import_pako.default.Inflate(); + while (!inflator.result) { + const chunk = await reader.chunk(); + if (!chunk) + break; + inflator.push(chunk, false); + if (inflator.err) { + throw new InternalError(`Pako error: ${inflator.msg}`); + } + if (inflator.result) { + if (inflator.result.length !== length) { + throw new InternalError( + `Inflated object size is different from that stated in packfile.` + ); + } + await reader.undo(); + await reader.read(chunk.length - inflator.strm.avail_in); + const end = reader.tell(); + await onData({ + data: inflator.result, + type, + num: numObjects, + offset, + end, + reference, + ofs + }); + } + } + } +} +async function parseHeader(reader) { + let byte = await reader.byte(); + const type = byte >> 4 & 7; + let length = byte & 15; + if (byte & 128) { + let shift = 4; + do { + byte = await reader.byte(); + length |= (byte & 127) << shift; + shift += 7; + } while (byte & 128); + } + let ofs; + let reference; + if (type === 6) { + let shift = 0; + ofs = 0; + const bytes = []; + do { + byte = await reader.byte(); + ofs |= (byte & 127) << shift; + shift += 7; + bytes.push(byte); + } while (byte & 128); + reference = Buffer.from(bytes); + } + if (type === 7) { + const buf = await reader.read(20); + reference = buf; + } + return { type, length, ofs, reference }; +} +var supportsDecompressionStream = false; +async function inflate(buffer2) { + if (supportsDecompressionStream === null) { + supportsDecompressionStream = testDecompressionStream(); + } + return supportsDecompressionStream ? browserInflate(buffer2) : import_pako.default.inflate(buffer2); +} +async function browserInflate(buffer2) { + const ds = new DecompressionStream("deflate"); + const d = new Blob([buffer2]).stream().pipeThrough(ds); + return new Uint8Array(await new Response(d).arrayBuffer()); +} +function testDecompressionStream() { + try { + const ds = new DecompressionStream("deflate"); + if (ds) + return true; + } catch (_) { + } + return false; +} +function decodeVarInt(reader) { + const bytes = []; + let byte = 0; + let multibyte = 0; + do { + byte = reader.readUInt8(); + const lastSeven = byte & 127; + bytes.push(lastSeven); + multibyte = byte & 128; + } while (multibyte); + return bytes.reduce((a, b) => a + 1 << 7 | b, -1); +} +function otherVarIntDecode(reader, startWith) { + let result = startWith; + let shift = 4; + let byte = null; + do { + byte = reader.readUInt8(); + result |= (byte & 127) << shift; + shift += 7; + } while (byte & 128); + return result; +} +var GitPackIndex = class _GitPackIndex { + constructor(stuff) { + Object.assign(this, stuff); + this.offsetCache = {}; + } + static async fromIdx({ idx, getExternalRefDelta }) { + const reader = new BufferCursor(idx); + const magic = reader.slice(4).toString("hex"); + if (magic !== "ff744f63") { + return; + } + const version2 = reader.readUInt32BE(); + if (version2 !== 2) { + throw new InternalError( + `Unable to read version ${version2} packfile IDX. (Only version 2 supported)` + ); + } + if (idx.byteLength > 2048 * 1024 * 1024) { + throw new InternalError( + `To keep implementation simple, I haven't implemented the layer 5 feature needed to support packfiles > 2GB in size.` + ); + } + reader.seek(reader.tell() + 4 * 255); + const size = reader.readUInt32BE(); + const hashes = []; + for (let i = 0; i < size; i++) { + const hash2 = reader.slice(20).toString("hex"); + hashes[i] = hash2; + } + reader.seek(reader.tell() + 4 * size); + const offsets = /* @__PURE__ */ new Map(); + for (let i = 0; i < size; i++) { + offsets.set(hashes[i], reader.readUInt32BE()); + } + const packfileSha = reader.slice(20).toString("hex"); + return new _GitPackIndex({ + hashes, + crcs: {}, + offsets, + packfileSha, + getExternalRefDelta + }); + } + static async fromPack({ pack, getExternalRefDelta, onProgress }) { + const listpackTypes = { + 1: "commit", + 2: "tree", + 3: "blob", + 4: "tag", + 6: "ofs-delta", + 7: "ref-delta" + }; + const offsetToObject = {}; + const packfileSha = pack.slice(-20).toString("hex"); + const hashes = []; + const crcs = {}; + const offsets = /* @__PURE__ */ new Map(); + let totalObjectCount = null; + let lastPercent = null; + await listpack([pack], async ({ data, type, reference, offset, num: num2 }) => { + if (totalObjectCount === null) + totalObjectCount = num2; + const percent = Math.floor( + (totalObjectCount - num2) * 100 / totalObjectCount + ); + if (percent !== lastPercent) { + if (onProgress) { + await onProgress({ + phase: "Receiving objects", + loaded: totalObjectCount - num2, + total: totalObjectCount + }); + } + } + lastPercent = percent; + type = listpackTypes[type]; + if (["commit", "tree", "blob", "tag"].includes(type)) { + offsetToObject[offset] = { + type, + offset + }; + } else if (type === "ofs-delta") { + offsetToObject[offset] = { + type, + offset + }; + } else if (type === "ref-delta") { + offsetToObject[offset] = { + type, + offset + }; + } + }); + const offsetArray = Object.keys(offsetToObject).map(Number); + for (const [i, start] of offsetArray.entries()) { + const end = i + 1 === offsetArray.length ? pack.byteLength - 20 : offsetArray[i + 1]; + const o = offsetToObject[start]; + const crc = import_crc_32.default.buf(pack.slice(start, end)) >>> 0; + o.end = end; + o.crc = crc; + } + const p = new _GitPackIndex({ + pack: Promise.resolve(pack), + packfileSha, + crcs, + hashes, + offsets, + getExternalRefDelta + }); + lastPercent = null; + let count = 0; + const objectsByDepth = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]; + for (let offset in offsetToObject) { + offset = Number(offset); + const percent = Math.floor(count * 100 / totalObjectCount); + if (percent !== lastPercent) { + if (onProgress) { + await onProgress({ + phase: "Resolving deltas", + loaded: count, + total: totalObjectCount + }); + } + } + count++; + lastPercent = percent; + const o = offsetToObject[offset]; + if (o.oid) + continue; + try { + p.readDepth = 0; + p.externalReadDepth = 0; + const { type, object } = await p.readSlice({ start: offset }); + objectsByDepth[p.readDepth] += 1; + const oid = await shasum(GitObject.wrap({ type, object })); + o.oid = oid; + hashes.push(oid); + offsets.set(oid, offset); + crcs[oid] = o.crc; + } catch (err) { + continue; + } + } + hashes.sort(); + return p; + } + async toBuffer() { + const buffers = []; + const write = (str, encoding) => { + buffers.push(Buffer.from(str, encoding)); + }; + write("ff744f63", "hex"); + write("00000002", "hex"); + const fanoutBuffer = new BufferCursor(Buffer.alloc(256 * 4)); + for (let i = 0; i < 256; i++) { + let count = 0; + for (const hash2 of this.hashes) { + if (parseInt(hash2.slice(0, 2), 16) <= i) + count++; + } + fanoutBuffer.writeUInt32BE(count); + } + buffers.push(fanoutBuffer.buffer); + for (const hash2 of this.hashes) { + write(hash2, "hex"); + } + const crcsBuffer = new BufferCursor(Buffer.alloc(this.hashes.length * 4)); + for (const hash2 of this.hashes) { + crcsBuffer.writeUInt32BE(this.crcs[hash2]); + } + buffers.push(crcsBuffer.buffer); + const offsetsBuffer = new BufferCursor(Buffer.alloc(this.hashes.length * 4)); + for (const hash2 of this.hashes) { + offsetsBuffer.writeUInt32BE(this.offsets.get(hash2)); + } + buffers.push(offsetsBuffer.buffer); + write(this.packfileSha, "hex"); + const totalBuffer = Buffer.concat(buffers); + const sha = await shasum(totalBuffer); + const shaBuffer = Buffer.alloc(20); + shaBuffer.write(sha, "hex"); + return Buffer.concat([totalBuffer, shaBuffer]); + } + async load({ pack }) { + this.pack = pack; + } + async unload() { + this.pack = null; + } + async read({ oid }) { + if (!this.offsets.get(oid)) { + if (this.getExternalRefDelta) { + this.externalReadDepth++; + return this.getExternalRefDelta(oid); + } else { + throw new InternalError(`Could not read object ${oid} from packfile`); + } + } + const start = this.offsets.get(oid); + return this.readSlice({ start }); + } + async readSlice({ start }) { + if (this.offsetCache[start]) { + return Object.assign({}, this.offsetCache[start]); + } + this.readDepth++; + const types2 = { + 16: "commit", + 32: "tree", + 48: "blob", + 64: "tag", + 96: "ofs_delta", + 112: "ref_delta" + }; + if (!this.pack) { + throw new InternalError( + "Tried to read from a GitPackIndex with no packfile loaded into memory" + ); + } + const raw = (await this.pack).slice(start); + const reader = new BufferCursor(raw); + const byte = reader.readUInt8(); + const btype = byte & 112; + let type = types2[btype]; + if (type === void 0) { + throw new InternalError("Unrecognized type: 0b" + btype.toString(2)); + } + const lastFour = byte & 15; + let length = lastFour; + const multibyte = byte & 128; + if (multibyte) { + length = otherVarIntDecode(reader, lastFour); + } + let base = null; + let object = null; + if (type === "ofs_delta") { + const offset = decodeVarInt(reader); + const baseOffset = start - offset; + ({ object: base, type } = await this.readSlice({ start: baseOffset })); + } + if (type === "ref_delta") { + const oid = reader.slice(20).toString("hex"); + ({ object: base, type } = await this.read({ oid })); + } + const buffer2 = raw.slice(reader.tell()); + object = Buffer.from(await inflate(buffer2)); + if (object.byteLength !== length) { + throw new InternalError( + `Packfile told us object would have length ${length} but it had length ${object.byteLength}` + ); + } + if (base) { + object = Buffer.from(applyDelta(object, base)); + } + if (this.readDepth > 3) { + this.offsetCache[start] = { type, object }; + } + return { type, format: "content", object }; + } +}; +var PackfileCache = Symbol("PackfileCache"); +async function loadPackIndex({ + fs, + filename, + getExternalRefDelta, + emitter, + emitterPrefix +}) { + const idx = await fs.read(filename); + return GitPackIndex.fromIdx({ idx, getExternalRefDelta }); +} +function readPackIndex({ + fs, + cache, + filename, + getExternalRefDelta, + emitter, + emitterPrefix +}) { + if (!cache[PackfileCache]) + cache[PackfileCache] = /* @__PURE__ */ new Map(); + let p = cache[PackfileCache].get(filename); + if (!p) { + p = loadPackIndex({ + fs, + filename, + getExternalRefDelta, + emitter, + emitterPrefix + }); + cache[PackfileCache].set(filename, p); + } + return p; +} +async function readObjectPacked({ + fs, + cache, + gitdir, + oid, + format = "content", + getExternalRefDelta +}) { + let list = await fs.readdir(join(gitdir, "objects/pack")); + list = list.filter((x) => x.endsWith(".idx")); + for (const filename of list) { + const indexFile = `${gitdir}/objects/pack/${filename}`; + const p = await readPackIndex({ + fs, + cache, + filename: indexFile, + getExternalRefDelta + }); + if (p.error) + throw new InternalError(p.error); + if (p.offsets.has(oid)) { + if (!p.pack) { + const packFile = indexFile.replace(/idx$/, "pack"); + p.pack = fs.read(packFile); + } + const result = await p.read({ oid, getExternalRefDelta }); + result.format = "content"; + result.source = `objects/pack/${filename.replace(/idx$/, "pack")}`; + return result; + } + } + return null; +} +async function _readObject({ + fs, + cache, + gitdir, + oid, + format = "content" +}) { + const getExternalRefDelta = (oid2) => _readObject({ fs, cache, gitdir, oid: oid2 }); + let result; + if (oid === "4b825dc642cb6eb9a060e54bf8d69288fbee4904") { + result = { format: "wrapped", object: Buffer.from(`tree 0\0`) }; + } + if (!result) { + result = await readObjectLoose({ fs, gitdir, oid }); + } + if (!result) { + result = await readObjectPacked({ + fs, + cache, + gitdir, + oid, + getExternalRefDelta + }); + } + if (!result) { + throw new NotFoundError(oid); + } + if (format === "deflated") { + return result; + } + if (result.format === "deflated") { + result.object = Buffer.from(await inflate(result.object)); + result.format = "wrapped"; + } + if (result.format === "wrapped") { + if (format === "wrapped" && result.format === "wrapped") { + return result; + } + const sha = await shasum(result.object); + if (sha !== oid) { + throw new InternalError( + `SHA check failed! Expected ${oid}, computed ${sha}` + ); + } + const { object, type } = GitObject.unwrap(result.object); + result.type = type; + result.object = object; + result.format = "content"; + } + if (result.format === "content") { + if (format === "content") + return result; + return; + } + throw new InternalError(`invalid format "${result.format}"`); +} +var AlreadyExistsError = class _AlreadyExistsError extends BaseError { + /** + * @param {'note'|'remote'|'tag'|'branch'} noun + * @param {string} where + * @param {boolean} canForce + */ + constructor(noun, where, canForce = true) { + super( + `Failed to create ${noun} at ${where} because it already exists.${canForce ? ` (Hint: use 'force: true' parameter to overwrite existing ${noun}.)` : ""}` + ); + this.code = this.name = _AlreadyExistsError.code; + this.data = { noun, where, canForce }; + } +}; +AlreadyExistsError.code = "AlreadyExistsError"; +var AmbiguousError = class _AmbiguousError extends BaseError { + /** + * @param {'oids'|'refs'} nouns + * @param {string} short + * @param {string[]} matches + */ + constructor(nouns, short, matches) { + super( + `Found multiple ${nouns} matching "${short}" (${matches.join( + ", " + )}). Use a longer abbreviation length to disambiguate them.` + ); + this.code = this.name = _AmbiguousError.code; + this.data = { nouns, short, matches }; + } +}; +AmbiguousError.code = "AmbiguousError"; +var CheckoutConflictError = class _CheckoutConflictError extends BaseError { + /** + * @param {string[]} filepaths + */ + constructor(filepaths) { + super( + `Your local changes to the following files would be overwritten by checkout: ${filepaths.join( + ", " + )}` + ); + this.code = this.name = _CheckoutConflictError.code; + this.data = { filepaths }; + } +}; +CheckoutConflictError.code = "CheckoutConflictError"; +var CommitNotFetchedError = class _CommitNotFetchedError extends BaseError { + /** + * @param {string} ref + * @param {string} oid + */ + constructor(ref, oid) { + super( + `Failed to checkout "${ref}" because commit ${oid} is not available locally. Do a git fetch to make the branch available locally.` + ); + this.code = this.name = _CommitNotFetchedError.code; + this.data = { ref, oid }; + } +}; +CommitNotFetchedError.code = "CommitNotFetchedError"; +var EmptyServerResponseError = class _EmptyServerResponseError extends BaseError { + constructor() { + super(`Empty response from git server.`); + this.code = this.name = _EmptyServerResponseError.code; + this.data = {}; + } +}; +EmptyServerResponseError.code = "EmptyServerResponseError"; +var FastForwardError = class _FastForwardError extends BaseError { + constructor() { + super(`A simple fast-forward merge was not possible.`); + this.code = this.name = _FastForwardError.code; + this.data = {}; + } +}; +FastForwardError.code = "FastForwardError"; +var GitPushError = class _GitPushError extends BaseError { + /** + * @param {string} prettyDetails + * @param {PushResult} result + */ + constructor(prettyDetails, result) { + super(`One or more branches were not updated: ${prettyDetails}`); + this.code = this.name = _GitPushError.code; + this.data = { prettyDetails, result }; + } +}; +GitPushError.code = "GitPushError"; +var HttpError = class _HttpError extends BaseError { + /** + * @param {number} statusCode + * @param {string} statusMessage + * @param {string} response + */ + constructor(statusCode, statusMessage, response) { + super(`HTTP Error: ${statusCode} ${statusMessage}`); + this.code = this.name = _HttpError.code; + this.data = { statusCode, statusMessage, response }; + } +}; +HttpError.code = "HttpError"; +var InvalidFilepathError = class _InvalidFilepathError extends BaseError { + /** + * @param {'leading-slash'|'trailing-slash'|'directory'} [reason] + */ + constructor(reason) { + let message = "invalid filepath"; + if (reason === "leading-slash" || reason === "trailing-slash") { + message = `"filepath" parameter should not include leading or trailing directory separators because these can cause problems on some platforms.`; + } else if (reason === "directory") { + message = `"filepath" should not be a directory.`; + } + super(message); + this.code = this.name = _InvalidFilepathError.code; + this.data = { reason }; + } +}; +InvalidFilepathError.code = "InvalidFilepathError"; +var InvalidRefNameError = class _InvalidRefNameError extends BaseError { + /** + * @param {string} ref + * @param {string} suggestion + * @param {boolean} canForce + */ + constructor(ref, suggestion) { + super( + `"${ref}" would be an invalid git reference. (Hint: a valid alternative would be "${suggestion}".)` + ); + this.code = this.name = _InvalidRefNameError.code; + this.data = { ref, suggestion }; + } +}; +InvalidRefNameError.code = "InvalidRefNameError"; +var MaxDepthError = class _MaxDepthError extends BaseError { + /** + * @param {number} depth + */ + constructor(depth) { + super(`Maximum search depth of ${depth} exceeded.`); + this.code = this.name = _MaxDepthError.code; + this.data = { depth }; + } +}; +MaxDepthError.code = "MaxDepthError"; +var MergeNotSupportedError = class _MergeNotSupportedError extends BaseError { + constructor() { + super(`Merges with conflicts are not supported yet.`); + this.code = this.name = _MergeNotSupportedError.code; + this.data = {}; + } +}; +MergeNotSupportedError.code = "MergeNotSupportedError"; +var MergeConflictError = class _MergeConflictError extends BaseError { + /** + * @param {Array} filepaths + */ + constructor(filepaths) { + super( + `Automatic merge failed with one or more merge conflicts in the following files: ${filepaths.toString()}. Fix conflicts then commit the result.` + ); + this.code = this.name = _MergeConflictError.code; + this.data = { filepaths }; + } +}; +MergeConflictError.code = "MergeConflictError"; +var MissingNameError = class _MissingNameError extends BaseError { + /** + * @param {'author'|'committer'|'tagger'} role + */ + constructor(role) { + super( + `No name was provided for ${role} in the argument or in the .git/config file.` + ); + this.code = this.name = _MissingNameError.code; + this.data = { role }; + } +}; +MissingNameError.code = "MissingNameError"; +var MissingParameterError = class _MissingParameterError extends BaseError { + /** + * @param {string} parameter + */ + constructor(parameter) { + super( + `The function requires a "${parameter}" parameter but none was provided.` + ); + this.code = this.name = _MissingParameterError.code; + this.data = { parameter }; + } +}; +MissingParameterError.code = "MissingParameterError"; +var MultipleGitError = class _MultipleGitError extends BaseError { + /** + * @param {Error[]} errors + * @param {string} message + */ + constructor(errors) { + super( + `There are multiple errors that were thrown by the method. Please refer to the "errors" property to see more` + ); + this.code = this.name = _MultipleGitError.code; + this.data = { errors }; + this.errors = errors; + } +}; +MultipleGitError.code = "MultipleGitError"; +var ParseError = class _ParseError extends BaseError { + /** + * @param {string} expected + * @param {string} actual + */ + constructor(expected, actual) { + super(`Expected "${expected}" but received "${actual}".`); + this.code = this.name = _ParseError.code; + this.data = { expected, actual }; + } +}; +ParseError.code = "ParseError"; +var PushRejectedError = class _PushRejectedError extends BaseError { + /** + * @param {'not-fast-forward'|'tag-exists'} reason + */ + constructor(reason) { + let message = ""; + if (reason === "not-fast-forward") { + message = " because it was not a simple fast-forward"; + } else if (reason === "tag-exists") { + message = " because tag already exists"; + } + super(`Push rejected${message}. Use "force: true" to override.`); + this.code = this.name = _PushRejectedError.code; + this.data = { reason }; + } +}; +PushRejectedError.code = "PushRejectedError"; +var RemoteCapabilityError = class _RemoteCapabilityError extends BaseError { + /** + * @param {'shallow'|'deepen-since'|'deepen-not'|'deepen-relative'} capability + * @param {'depth'|'since'|'exclude'|'relative'} parameter + */ + constructor(capability, parameter) { + super( + `Remote does not support the "${capability}" so the "${parameter}" parameter cannot be used.` + ); + this.code = this.name = _RemoteCapabilityError.code; + this.data = { capability, parameter }; + } +}; +RemoteCapabilityError.code = "RemoteCapabilityError"; +var SmartHttpError = class _SmartHttpError extends BaseError { + /** + * @param {string} preview + * @param {string} response + */ + constructor(preview, response) { + super( + `Remote did not reply using the "smart" HTTP protocol. Expected "001e# service=git-upload-pack" but received: ${preview}` + ); + this.code = this.name = _SmartHttpError.code; + this.data = { preview, response }; + } +}; +SmartHttpError.code = "SmartHttpError"; +var UnknownTransportError = class _UnknownTransportError extends BaseError { + /** + * @param {string} url + * @param {string} transport + * @param {string} [suggestion] + */ + constructor(url, transport, suggestion) { + super( + `Git remote "${url}" uses an unrecognized transport protocol: "${transport}"` + ); + this.code = this.name = _UnknownTransportError.code; + this.data = { url, transport, suggestion }; + } +}; +UnknownTransportError.code = "UnknownTransportError"; +var UrlParseError = class _UrlParseError extends BaseError { + /** + * @param {string} url + */ + constructor(url) { + super(`Cannot parse remote URL: "${url}"`); + this.code = this.name = _UrlParseError.code; + this.data = { url }; + } +}; +UrlParseError.code = "UrlParseError"; +var UserCanceledError = class _UserCanceledError extends BaseError { + constructor() { + super(`The operation was canceled.`); + this.code = this.name = _UserCanceledError.code; + this.data = {}; + } +}; +UserCanceledError.code = "UserCanceledError"; +var IndexResetError = class _IndexResetError extends BaseError { + /** + * @param {Array} filepaths + */ + constructor(filepath) { + super( + `Could not merge index: Entry for '${filepath}' is not up to date. Either reset the index entry to HEAD, or stage your unstaged chages.` + ); + this.code = this.name = _IndexResetError.code; + this.data = { filepath }; + } +}; +IndexResetError.code = "IndexResetError"; +var Errors = /* @__PURE__ */ Object.freeze({ + __proto__: null, + AlreadyExistsError, + AmbiguousError, + CheckoutConflictError, + CommitNotFetchedError, + EmptyServerResponseError, + FastForwardError, + GitPushError, + HttpError, + InternalError, + InvalidFilepathError, + InvalidOidError, + InvalidRefNameError, + MaxDepthError, + MergeNotSupportedError, + MergeConflictError, + MissingNameError, + MissingParameterError, + MultipleGitError, + NoRefspecError, + NotFoundError, + ObjectTypeError, + ParseError, + PushRejectedError, + RemoteCapabilityError, + SmartHttpError, + UnknownTransportError, + UnsafeFilepathError, + UrlParseError, + UserCanceledError, + UnmergedPathsError, + IndexResetError +}); +function formatAuthor({ name, email, timestamp, timezoneOffset }) { + timezoneOffset = formatTimezoneOffset(timezoneOffset); + return `${name} <${email}> ${timestamp} ${timezoneOffset}`; +} +function formatTimezoneOffset(minutes) { + const sign = simpleSign(negateExceptForZero(minutes)); + minutes = Math.abs(minutes); + const hours = Math.floor(minutes / 60); + minutes -= hours * 60; + let strHours = String(hours); + let strMinutes = String(minutes); + if (strHours.length < 2) + strHours = "0" + strHours; + if (strMinutes.length < 2) + strMinutes = "0" + strMinutes; + return (sign === -1 ? "-" : "+") + strHours + strMinutes; +} +function simpleSign(n) { + return Math.sign(n) || (Object.is(n, -0) ? -1 : 1); +} +function negateExceptForZero(n) { + return n === 0 ? n : -n; +} +function normalizeNewlines(str) { + str = str.replace(/\r/g, ""); + str = str.replace(/^\n+/, ""); + str = str.replace(/\n+$/, "") + "\n"; + return str; +} +function parseAuthor(author) { + const [, name, email, timestamp, offset] = author.match( + /^(.*) <(.*)> (.*) (.*)$/ + ); + return { + name, + email, + timestamp: Number(timestamp), + timezoneOffset: parseTimezoneOffset(offset) + }; +} +function parseTimezoneOffset(offset) { + let [, sign, hours, minutes] = offset.match(/(\+|-)(\d\d)(\d\d)/); + minutes = (sign === "+" ? 1 : -1) * (Number(hours) * 60 + Number(minutes)); + return negateExceptForZero$1(minutes); +} +function negateExceptForZero$1(n) { + return n === 0 ? n : -n; +} +var GitAnnotatedTag = class _GitAnnotatedTag { + constructor(tag2) { + if (typeof tag2 === "string") { + this._tag = tag2; + } else if (Buffer.isBuffer(tag2)) { + this._tag = tag2.toString("utf8"); + } else if (typeof tag2 === "object") { + this._tag = _GitAnnotatedTag.render(tag2); + } else { + throw new InternalError( + "invalid type passed to GitAnnotatedTag constructor" + ); + } + } + static from(tag2) { + return new _GitAnnotatedTag(tag2); + } + static render(obj) { + return `object ${obj.object} +type ${obj.type} +tag ${obj.tag} +tagger ${formatAuthor(obj.tagger)} + +${obj.message} +${obj.gpgsig ? obj.gpgsig : ""}`; + } + justHeaders() { + return this._tag.slice(0, this._tag.indexOf("\n\n")); + } + message() { + const tag2 = this.withoutSignature(); + return tag2.slice(tag2.indexOf("\n\n") + 2); + } + parse() { + return Object.assign(this.headers(), { + message: this.message(), + gpgsig: this.gpgsig() + }); + } + render() { + return this._tag; + } + headers() { + const headers = this.justHeaders().split("\n"); + const hs = []; + for (const h of headers) { + if (h[0] === " ") { + hs[hs.length - 1] += "\n" + h.slice(1); + } else { + hs.push(h); + } + } + const obj = {}; + for (const h of hs) { + const key2 = h.slice(0, h.indexOf(" ")); + const value = h.slice(h.indexOf(" ") + 1); + if (Array.isArray(obj[key2])) { + obj[key2].push(value); + } else { + obj[key2] = value; + } + } + if (obj.tagger) { + obj.tagger = parseAuthor(obj.tagger); + } + if (obj.committer) { + obj.committer = parseAuthor(obj.committer); + } + return obj; + } + withoutSignature() { + const tag2 = normalizeNewlines(this._tag); + if (tag2.indexOf("\n-----BEGIN PGP SIGNATURE-----") === -1) + return tag2; + return tag2.slice(0, tag2.lastIndexOf("\n-----BEGIN PGP SIGNATURE-----")); + } + gpgsig() { + if (this._tag.indexOf("\n-----BEGIN PGP SIGNATURE-----") === -1) + return; + const signature = this._tag.slice( + this._tag.indexOf("-----BEGIN PGP SIGNATURE-----"), + this._tag.indexOf("-----END PGP SIGNATURE-----") + "-----END PGP SIGNATURE-----".length + ); + return normalizeNewlines(signature); + } + payload() { + return this.withoutSignature() + "\n"; + } + toObject() { + return Buffer.from(this._tag, "utf8"); + } + static async sign(tag2, sign, secretKey) { + const payload = tag2.payload(); + let { signature } = await sign({ payload, secretKey }); + signature = normalizeNewlines(signature); + const signedTag = payload + signature; + return _GitAnnotatedTag.from(signedTag); + } +}; +function indent(str) { + return str.trim().split("\n").map((x) => " " + x).join("\n") + "\n"; +} +function outdent(str) { + return str.split("\n").map((x) => x.replace(/^ /, "")).join("\n"); +} +var GitCommit = class _GitCommit { + constructor(commit2) { + if (typeof commit2 === "string") { + this._commit = commit2; + } else if (Buffer.isBuffer(commit2)) { + this._commit = commit2.toString("utf8"); + } else if (typeof commit2 === "object") { + this._commit = _GitCommit.render(commit2); + } else { + throw new InternalError("invalid type passed to GitCommit constructor"); + } + } + static fromPayloadSignature({ payload, signature }) { + const headers = _GitCommit.justHeaders(payload); + const message = _GitCommit.justMessage(payload); + const commit2 = normalizeNewlines( + headers + "\ngpgsig" + indent(signature) + "\n" + message + ); + return new _GitCommit(commit2); + } + static from(commit2) { + return new _GitCommit(commit2); + } + toObject() { + return Buffer.from(this._commit, "utf8"); + } + // Todo: allow setting the headers and message + headers() { + return this.parseHeaders(); + } + // Todo: allow setting the headers and message + message() { + return _GitCommit.justMessage(this._commit); + } + parse() { + return Object.assign({ message: this.message() }, this.headers()); + } + static justMessage(commit2) { + return normalizeNewlines(commit2.slice(commit2.indexOf("\n\n") + 2)); + } + static justHeaders(commit2) { + return commit2.slice(0, commit2.indexOf("\n\n")); + } + parseHeaders() { + const headers = _GitCommit.justHeaders(this._commit).split("\n"); + const hs = []; + for (const h of headers) { + if (h[0] === " ") { + hs[hs.length - 1] += "\n" + h.slice(1); + } else { + hs.push(h); + } + } + const obj = { + parent: [] + }; + for (const h of hs) { + const key2 = h.slice(0, h.indexOf(" ")); + const value = h.slice(h.indexOf(" ") + 1); + if (Array.isArray(obj[key2])) { + obj[key2].push(value); + } else { + obj[key2] = value; + } + } + if (obj.author) { + obj.author = parseAuthor(obj.author); + } + if (obj.committer) { + obj.committer = parseAuthor(obj.committer); + } + return obj; + } + static renderHeaders(obj) { + let headers = ""; + if (obj.tree) { + headers += `tree ${obj.tree} +`; + } else { + headers += `tree 4b825dc642cb6eb9a060e54bf8d69288fbee4904 +`; + } + if (obj.parent) { + if (obj.parent.length === void 0) { + throw new InternalError(`commit 'parent' property should be an array`); + } + for (const p of obj.parent) { + headers += `parent ${p} +`; + } + } + const author = obj.author; + headers += `author ${formatAuthor(author)} +`; + const committer = obj.committer || obj.author; + headers += `committer ${formatAuthor(committer)} +`; + if (obj.gpgsig) { + headers += "gpgsig" + indent(obj.gpgsig); + } + return headers; + } + static render(obj) { + return _GitCommit.renderHeaders(obj) + "\n" + normalizeNewlines(obj.message); + } + render() { + return this._commit; + } + withoutSignature() { + const commit2 = normalizeNewlines(this._commit); + if (commit2.indexOf("\ngpgsig") === -1) + return commit2; + const headers = commit2.slice(0, commit2.indexOf("\ngpgsig")); + const message = commit2.slice( + commit2.indexOf("-----END PGP SIGNATURE-----\n") + "-----END PGP SIGNATURE-----\n".length + ); + return normalizeNewlines(headers + "\n" + message); + } + isolateSignature() { + const signature = this._commit.slice( + this._commit.indexOf("-----BEGIN PGP SIGNATURE-----"), + this._commit.indexOf("-----END PGP SIGNATURE-----") + "-----END PGP SIGNATURE-----".length + ); + return outdent(signature); + } + static async sign(commit2, sign, secretKey) { + const payload = commit2.withoutSignature(); + const message = _GitCommit.justMessage(commit2._commit); + let { signature } = await sign({ payload, secretKey }); + signature = normalizeNewlines(signature); + const headers = _GitCommit.justHeaders(commit2._commit); + const signedCommit = headers + "\ngpgsig" + indent(signature) + "\n" + message; + return _GitCommit.from(signedCommit); + } +}; +async function resolveTree({ fs, cache, gitdir, oid }) { + if (oid === "4b825dc642cb6eb9a060e54bf8d69288fbee4904") { + return { tree: GitTree.from([]), oid }; + } + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + oid = GitAnnotatedTag.from(object).parse().object; + return resolveTree({ fs, cache, gitdir, oid }); + } + if (type === "commit") { + oid = GitCommit.from(object).parse().tree; + return resolveTree({ fs, cache, gitdir, oid }); + } + if (type !== "tree") { + throw new ObjectTypeError(oid, type, "tree"); + } + return { tree: GitTree.from(object), oid }; +} +var GitWalkerRepo = class { + constructor({ fs, gitdir, ref, cache }) { + this.fs = fs; + this.cache = cache; + this.gitdir = gitdir; + this.mapPromise = (async () => { + const map = /* @__PURE__ */ new Map(); + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref }); + } catch (e) { + if (e instanceof NotFoundError) { + oid = "4b825dc642cb6eb9a060e54bf8d69288fbee4904"; + } + } + const tree = await resolveTree({ fs, cache: this.cache, gitdir, oid }); + tree.type = "tree"; + tree.mode = "40000"; + map.set(".", tree); + return map; + })(); + const walker = this; + this.ConstructEntry = class TreeEntry { + constructor(fullpath) { + this._fullpath = fullpath; + this._type = false; + this._mode = false; + this._stat = false; + this._content = false; + this._oid = false; + } + async type() { + return walker.type(this); + } + async mode() { + return walker.mode(this); + } + async stat() { + return walker.stat(this); + } + async content() { + return walker.content(this); + } + async oid() { + return walker.oid(this); + } + }; + } + async readdir(entry) { + const filepath = entry._fullpath; + const { fs, cache, gitdir } = this; + const map = await this.mapPromise; + const obj = map.get(filepath); + if (!obj) + throw new Error(`No obj for ${filepath}`); + const oid = obj.oid; + if (!oid) + throw new Error(`No oid for obj ${JSON.stringify(obj)}`); + if (obj.type !== "tree") { + return null; + } + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type !== obj.type) { + throw new ObjectTypeError(oid, type, obj.type); + } + const tree = GitTree.from(object); + for (const entry2 of tree) { + map.set(join(filepath, entry2.path), entry2); + } + return tree.entries().map((entry2) => join(filepath, entry2.path)); + } + async type(entry) { + if (entry._type === false) { + const map = await this.mapPromise; + const { type } = map.get(entry._fullpath); + entry._type = type; + } + return entry._type; + } + async mode(entry) { + if (entry._mode === false) { + const map = await this.mapPromise; + const { mode } = map.get(entry._fullpath); + entry._mode = normalizeMode(parseInt(mode, 8)); + } + return entry._mode; + } + async stat(_entry) { + } + async content(entry) { + if (entry._content === false) { + const map = await this.mapPromise; + const { fs, cache, gitdir } = this; + const obj = map.get(entry._fullpath); + const oid = obj.oid; + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type !== "blob") { + entry._content = void 0; + } else { + entry._content = new Uint8Array(object); + } + } + return entry._content; + } + async oid(entry) { + if (entry._oid === false) { + const map = await this.mapPromise; + const obj = map.get(entry._fullpath); + entry._oid = obj.oid; + } + return entry._oid; + } +}; +function TREE({ ref = "HEAD" } = {}) { + const o = /* @__PURE__ */ Object.create(null); + Object.defineProperty(o, GitWalkSymbol, { + value: function({ fs, gitdir, cache }) { + return new GitWalkerRepo({ fs, gitdir, ref, cache }); + } + }); + Object.freeze(o); + return o; +} +var GitWalkerFs = class { + constructor({ fs, dir, gitdir, cache }) { + this.fs = fs; + this.cache = cache; + this.dir = dir; + this.gitdir = gitdir; + const walker = this; + this.ConstructEntry = class WorkdirEntry { + constructor(fullpath) { + this._fullpath = fullpath; + this._type = false; + this._mode = false; + this._stat = false; + this._content = false; + this._oid = false; + } + async type() { + return walker.type(this); + } + async mode() { + return walker.mode(this); + } + async stat() { + return walker.stat(this); + } + async content() { + return walker.content(this); + } + async oid() { + return walker.oid(this); + } + }; + } + async readdir(entry) { + const filepath = entry._fullpath; + const { fs, dir } = this; + const names = await fs.readdir(join(dir, filepath)); + if (names === null) + return null; + return names.map((name) => join(filepath, name)); + } + async type(entry) { + if (entry._type === false) { + await entry.stat(); + } + return entry._type; + } + async mode(entry) { + if (entry._mode === false) { + await entry.stat(); + } + return entry._mode; + } + async stat(entry) { + if (entry._stat === false) { + const { fs, dir } = this; + let stat = await fs.lstat(`${dir}/${entry._fullpath}`); + if (!stat) { + throw new Error( + `ENOENT: no such file or directory, lstat '${entry._fullpath}'` + ); + } + let type = stat.isDirectory() ? "tree" : "blob"; + if (type === "blob" && !stat.isFile() && !stat.isSymbolicLink()) { + type = "special"; + } + entry._type = type; + stat = normalizeStats(stat); + entry._mode = stat.mode; + if (stat.size === -1 && entry._actualSize) { + stat.size = entry._actualSize; + } + entry._stat = stat; + } + return entry._stat; + } + async content(entry) { + if (entry._content === false) { + const { fs, dir } = this; + if (await entry.type() === "tree") { + entry._content = void 0; + } else { + const content = await fs.read(`${dir}/${entry._fullpath}`); + entry._actualSize = content.length; + if (entry._stat && entry._stat.size === -1) { + entry._stat.size = entry._actualSize; + } + entry._content = new Uint8Array(content); + } + } + return entry._content; + } + async oid(entry) { + if (entry._oid === false) { + const { fs, gitdir, cache } = this; + let oid; + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + const stage = index2.entriesMap.get(entry._fullpath); + const stats = await entry.stat(); + if (!stage || compareStats(stats, stage)) { + const content = await entry.content(); + if (content === void 0) { + oid = void 0; + } else { + oid = await shasum( + GitObject.wrap({ type: "blob", object: await entry.content() }) + ); + if (stage && oid === stage.oid && stats.mode === stage.mode && compareStats(stats, stage)) { + index2.insert({ + filepath: entry._fullpath, + stats, + oid + }); + } + } + } else { + oid = stage.oid; + } + }); + entry._oid = oid; + } + return entry._oid; + } +}; +function WORKDIR() { + const o = /* @__PURE__ */ Object.create(null); + Object.defineProperty(o, GitWalkSymbol, { + value: function({ fs, dir, gitdir, cache }) { + return new GitWalkerFs({ fs, dir, gitdir, cache }); + } + }); + Object.freeze(o); + return o; +} +function arrayRange(start, end) { + const length = end - start; + return Array.from({ length }, (_, i) => start + i); +} +var flat = typeof Array.prototype.flat === "undefined" ? (entries) => entries.reduce((acc, x) => acc.concat(x), []) : (entries) => entries.flat(); +var RunningMinimum = class { + constructor() { + this.value = null; + } + consider(value) { + if (value === null || value === void 0) + return; + if (this.value === null) { + this.value = value; + } else if (value < this.value) { + this.value = value; + } + } + reset() { + this.value = null; + } +}; +function* unionOfIterators(sets) { + const min = new RunningMinimum(); + let minimum; + const heads = []; + const numsets = sets.length; + for (let i = 0; i < numsets; i++) { + heads[i] = sets[i].next().value; + if (heads[i] !== void 0) { + min.consider(heads[i]); + } + } + if (min.value === null) + return; + while (true) { + const result = []; + minimum = min.value; + min.reset(); + for (let i = 0; i < numsets; i++) { + if (heads[i] !== void 0 && heads[i] === minimum) { + result[i] = heads[i]; + heads[i] = sets[i].next().value; + } else { + result[i] = null; + } + if (heads[i] !== void 0) { + min.consider(heads[i]); + } + } + yield result; + if (min.value === null) + return; + } +} +async function _walk({ + fs, + cache, + dir, + gitdir, + trees, + // @ts-ignore + map = async (_, entry) => entry, + // The default reducer is a flatmap that filters out undefineds. + reduce = async (parent, children2) => { + const flatten = flat(children2); + if (parent !== void 0) + flatten.unshift(parent); + return flatten; + }, + // The default iterate function walks all children concurrently + iterate = (walk2, children2) => Promise.all([...children2].map(walk2)) +}) { + const walkers = trees.map( + (proxy) => proxy[GitWalkSymbol]({ fs, dir, gitdir, cache }) + ); + const root2 = new Array(walkers.length).fill("."); + const range = arrayRange(0, walkers.length); + const unionWalkerFromReaddir = async (entries) => { + range.map((i) => { + entries[i] = entries[i] && new walkers[i].ConstructEntry(entries[i]); + }); + const subdirs = await Promise.all( + range.map((i) => entries[i] ? walkers[i].readdir(entries[i]) : []) + ); + const iterators = subdirs.map((array) => array === null ? [] : array).map((array) => array[Symbol.iterator]()); + return { + entries, + children: unionOfIterators(iterators) + }; + }; + const walk2 = async (root3) => { + const { entries, children: children2 } = await unionWalkerFromReaddir(root3); + const fullpath = entries.find((entry) => entry && entry._fullpath)._fullpath; + const parent = await map(fullpath, entries); + if (parent !== null) { + let walkedChildren = await iterate(walk2, children2); + walkedChildren = walkedChildren.filter((x) => x !== void 0); + return reduce(parent, walkedChildren); + } + }; + return walk2(root2); +} +async function rmRecursive(fs, filepath) { + const entries = await fs.readdir(filepath); + if (entries == null) { + await fs.rm(filepath); + } else if (entries.length) { + await Promise.all( + entries.map((entry) => { + const subpath = join(filepath, entry); + return fs.lstat(subpath).then((stat) => { + if (!stat) + return; + return stat.isDirectory() ? rmRecursive(fs, subpath) : fs.rm(subpath); + }); + }) + ).then(() => fs.rmdir(filepath)); + } else { + await fs.rmdir(filepath); + } +} +function isPromiseLike(obj) { + return isObject(obj) && isFunction(obj.then) && isFunction(obj.catch); +} +function isObject(obj) { + return obj && typeof obj === "object"; +} +function isFunction(obj) { + return typeof obj === "function"; +} +function isPromiseFs(fs) { + const test = (targetFs) => { + try { + return targetFs.readFile().catch((e) => e); + } catch (e) { + return e; + } + }; + return isPromiseLike(test(fs)); +} +var commands = [ + "readFile", + "writeFile", + "mkdir", + "rmdir", + "unlink", + "stat", + "lstat", + "readdir", + "readlink", + "symlink" +]; +function bindFs(target, fs) { + if (isPromiseFs(fs)) { + for (const command of commands) { + target[`_${command}`] = fs[command].bind(fs); + } + } else { + for (const command of commands) { + target[`_${command}`] = (0, import_pify.default)(fs[command].bind(fs)); + } + } + if (isPromiseFs(fs)) { + if (fs.rm) + target._rm = fs.rm.bind(fs); + else if (fs.rmdir.length > 1) + target._rm = fs.rmdir.bind(fs); + else + target._rm = rmRecursive.bind(null, target); + } else { + if (fs.rm) + target._rm = (0, import_pify.default)(fs.rm.bind(fs)); + else if (fs.rmdir.length > 2) + target._rm = (0, import_pify.default)(fs.rmdir.bind(fs)); + else + target._rm = rmRecursive.bind(null, target); + } +} +var FileSystem = class { + constructor(fs) { + if (typeof fs._original_unwrapped_fs !== "undefined") + return fs; + const promises = Object.getOwnPropertyDescriptor(fs, "promises"); + if (promises && promises.enumerable) { + bindFs(this, fs.promises); + } else { + bindFs(this, fs); + } + this._original_unwrapped_fs = fs; + } + /** + * Return true if a file exists, false if it doesn't exist. + * Rethrows errors that aren't related to file existance. + */ + async exists(filepath, options = {}) { + try { + await this._stat(filepath); + return true; + } catch (err) { + if (err.code === "ENOENT" || err.code === "ENOTDIR") { + return false; + } else { + console.log('Unhandled error in "FileSystem.exists()" function', err); + throw err; + } + } + } + /** + * Return the contents of a file if it exists, otherwise returns null. + * + * @param {string} filepath + * @param {object} [options] + * + * @returns {Promise} + */ + async read(filepath, options = {}) { + try { + let buffer2 = await this._readFile(filepath, options); + if (typeof buffer2 !== "string") { + buffer2 = Buffer.from(buffer2); + } + return buffer2; + } catch (err) { + return null; + } + } + /** + * Write a file (creating missing directories if need be) without throwing errors. + * + * @param {string} filepath + * @param {Buffer|Uint8Array|string} contents + * @param {object|string} [options] + */ + async write(filepath, contents, options = {}) { + try { + await this._writeFile(filepath, contents, options); + return; + } catch (err) { + await this.mkdir(dirname(filepath)); + await this._writeFile(filepath, contents, options); + } + } + /** + * Make a directory (or series of nested directories) without throwing an error if it already exists. + */ + async mkdir(filepath, _selfCall = false) { + try { + await this._mkdir(filepath); + return; + } catch (err) { + if (err === null) + return; + if (err.code === "EEXIST") + return; + if (_selfCall) + throw err; + if (err.code === "ENOENT") { + const parent = dirname(filepath); + if (parent === "." || parent === "/" || parent === filepath) + throw err; + await this.mkdir(parent); + await this.mkdir(filepath, true); + } + } + } + /** + * Delete a file without throwing an error if it is already deleted. + */ + async rm(filepath) { + try { + await this._unlink(filepath); + } catch (err) { + if (err.code !== "ENOENT") + throw err; + } + } + /** + * Delete a directory without throwing an error if it is already deleted. + */ + async rmdir(filepath, opts) { + try { + if (opts && opts.recursive) { + await this._rm(filepath, opts); + } else { + await this._rmdir(filepath); + } + } catch (err) { + if (err.code !== "ENOENT") + throw err; + } + } + /** + * Read a directory without throwing an error is the directory doesn't exist + */ + async readdir(filepath) { + try { + const names = await this._readdir(filepath); + names.sort(compareStrings); + return names; + } catch (err) { + if (err.code === "ENOTDIR") + return null; + return []; + } + } + /** + * Return a flast list of all the files nested inside a directory + * + * Based on an elegant concurrent recursive solution from SO + * https://stackoverflow.com/a/45130990/2168416 + */ + async readdirDeep(dir) { + const subdirs = await this._readdir(dir); + const files = await Promise.all( + subdirs.map(async (subdir) => { + const res = dir + "/" + subdir; + return (await this._stat(res)).isDirectory() ? this.readdirDeep(res) : res; + }) + ); + return files.reduce((a, f) => a.concat(f), []); + } + /** + * Return the Stats of a file/symlink if it exists, otherwise returns null. + * Rethrows errors that aren't related to file existance. + */ + async lstat(filename) { + try { + const stats = await this._lstat(filename); + return stats; + } catch (err) { + if (err.code === "ENOENT") { + return null; + } + throw err; + } + } + /** + * Reads the contents of a symlink if it exists, otherwise returns null. + * Rethrows errors that aren't related to file existance. + */ + async readlink(filename, opts = { encoding: "buffer" }) { + try { + const link = await this._readlink(filename, opts); + return Buffer.isBuffer(link) ? link : Buffer.from(link); + } catch (err) { + if (err.code === "ENOENT") { + return null; + } + throw err; + } + } + /** + * Write the contents of buffer to a symlink. + */ + async writelink(filename, buffer2) { + return this._symlink(buffer2.toString("utf8"), filename); + } +}; +function assertParameter(name, value) { + if (value === void 0) { + throw new MissingParameterError(name); + } +} +async function modified(entry, base) { + if (!entry && !base) + return false; + if (entry && !base) + return true; + if (!entry && base) + return true; + if (await entry.type() === "tree" && await base.type() === "tree") { + return false; + } + if (await entry.type() === await base.type() && await entry.mode() === await base.mode() && await entry.oid() === await base.oid()) { + return false; + } + return true; +} +async function abortMerge({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + commit: commit2 = "HEAD", + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + const fs = new FileSystem(_fs); + const trees = [TREE({ ref: commit2 }), WORKDIR(), STAGE()]; + let unmergedPaths = []; + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + unmergedPaths = index2.unmergedPaths; + }); + const results = await _walk({ + fs, + cache, + dir, + gitdir, + trees, + map: async function(path2, [head, workdir, index2]) { + const staged = !await modified(workdir, index2); + const unmerged = unmergedPaths.includes(path2); + const unmodified = !await modified(index2, head); + if (staged || unmerged) { + return head ? { + path: path2, + mode: await head.mode(), + oid: await head.oid(), + type: await head.type(), + content: await head.content() + } : void 0; + } + if (unmodified) + return false; + else + throw new IndexResetError(path2); + } + }); + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + for (const entry of results) { + if (entry === false) + continue; + if (!entry) { + await fs.rmdir(`${dir}/${entry.path}`, { recursive: true }); + index2.delete({ filepath: entry.path }); + continue; + } + if (entry.type === "blob") { + const content = new TextDecoder().decode(entry.content); + await fs.write(`${dir}/${entry.path}`, content, { mode: entry.mode }); + index2.insert({ + filepath: entry.path, + oid: entry.oid, + stage: 0 + }); + } + } + }); + } catch (err) { + err.caller = "git.abortMerge"; + throw err; + } +} +var GitIgnoreManager = class { + static async isIgnored({ fs, dir, gitdir = join(dir, ".git"), filepath }) { + if (basename(filepath) === ".git") + return true; + if (filepath === ".") + return false; + let excludes = ""; + const excludesFile = join(gitdir, "info", "exclude"); + if (await fs.exists(excludesFile)) { + excludes = await fs.read(excludesFile, "utf8"); + } + const pairs = [ + { + gitignore: join(dir, ".gitignore"), + filepath + } + ]; + const pieces = filepath.split("/").filter(Boolean); + for (let i = 1; i < pieces.length; i++) { + const folder = pieces.slice(0, i).join("/"); + const file = pieces.slice(i).join("/"); + pairs.push({ + gitignore: join(dir, folder, ".gitignore"), + filepath: file + }); + } + let ignoredStatus = false; + for (const p of pairs) { + let file; + try { + file = await fs.read(p.gitignore, "utf8"); + } catch (err) { + if (err.code === "NOENT") + continue; + } + const ign = (0, import_ignore.default)().add(excludes); + ign.add(file); + const parentdir = dirname(p.filepath); + if (parentdir !== "." && ign.ignores(parentdir)) + return true; + if (ignoredStatus) { + ignoredStatus = !ign.test(p.filepath).unignored; + } else { + ignoredStatus = ign.test(p.filepath).ignored; + } + } + return ignoredStatus; + } +}; +async function writeObjectLoose({ fs, gitdir, object, format, oid }) { + if (format !== "deflated") { + throw new InternalError( + "GitObjectStoreLoose expects objects to write to be in deflated format" + ); + } + const source = `objects/${oid.slice(0, 2)}/${oid.slice(2)}`; + const filepath = `${gitdir}/${source}`; + if (!await fs.exists(filepath)) + await fs.write(filepath, object); +} +var supportsCompressionStream = null; +async function deflate(buffer2) { + if (supportsCompressionStream === null) { + supportsCompressionStream = testCompressionStream(); + } + return supportsCompressionStream ? browserDeflate(buffer2) : import_pako.default.deflate(buffer2); +} +async function browserDeflate(buffer2) { + const cs = new CompressionStream("deflate"); + const c = new Blob([buffer2]).stream().pipeThrough(cs); + return new Uint8Array(await new Response(c).arrayBuffer()); +} +function testCompressionStream() { + try { + const cs = new CompressionStream("deflate"); + new Blob([]).stream(); + if (cs) + return true; + } catch (_) { + } + return false; +} +async function _writeObject({ + fs, + gitdir, + type, + object, + format = "content", + oid = void 0, + dryRun = false +}) { + if (format !== "deflated") { + if (format !== "wrapped") { + object = GitObject.wrap({ type, object }); + } + oid = await shasum(object); + object = Buffer.from(await deflate(object)); + } + if (!dryRun) { + await writeObjectLoose({ fs, gitdir, object, format: "deflated", oid }); + } + return oid; +} +function posixifyPathBuffer(buffer2) { + let idx; + while (~(idx = buffer2.indexOf(92))) + buffer2[idx] = 47; + return buffer2; +} +async function add({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {}, + force = false, + parallel = true +}) { + try { + assertParameter("fs", _fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + await GitIndexManager.acquire({ fs, gitdir, cache }, async (index2) => { + return addToIndex({ + dir, + gitdir, + fs, + filepath, + index: index2, + force, + parallel + }); + }); + } catch (err) { + err.caller = "git.add"; + throw err; + } +} +async function addToIndex({ + dir, + gitdir, + fs, + filepath, + index: index2, + force, + parallel +}) { + filepath = Array.isArray(filepath) ? filepath : [filepath]; + const promises = filepath.map(async (currentFilepath) => { + if (!force) { + const ignored = await GitIgnoreManager.isIgnored({ + fs, + dir, + gitdir, + filepath: currentFilepath + }); + if (ignored) + return; + } + const stats = await fs.lstat(join(dir, currentFilepath)); + if (!stats) + throw new NotFoundError(currentFilepath); + if (stats.isDirectory()) { + const children2 = await fs.readdir(join(dir, currentFilepath)); + if (parallel) { + const promises2 = children2.map( + (child) => addToIndex({ + dir, + gitdir, + fs, + filepath: [join(currentFilepath, child)], + index: index2, + force, + parallel + }) + ); + await Promise.all(promises2); + } else { + for (const child of children2) { + await addToIndex({ + dir, + gitdir, + fs, + filepath: [join(currentFilepath, child)], + index: index2, + force, + parallel + }); + } + } + } else { + const object = stats.isSymbolicLink() ? await fs.readlink(join(dir, currentFilepath)).then(posixifyPathBuffer) : await fs.read(join(dir, currentFilepath)); + if (object === null) + throw new NotFoundError(currentFilepath); + const oid = await _writeObject({ fs, gitdir, type: "blob", object }); + index2.insert({ filepath: currentFilepath, stats, oid }); + } + }); + const settledPromises = await Promise.allSettled(promises); + const rejectedPromises = settledPromises.filter((settle) => settle.status === "rejected").map((settle) => settle.reason); + if (rejectedPromises.length > 1) { + throw new MultipleGitError(rejectedPromises); + } + if (rejectedPromises.length === 1) { + throw rejectedPromises[0]; + } + const fulfilledPromises = settledPromises.filter((settle) => settle.status === "fulfilled" && settle.value).map((settle) => settle.value); + return fulfilledPromises; +} +async function _commit({ + fs, + cache, + onSign, + gitdir, + message, + author, + committer, + signingKey, + dryRun = false, + noUpdateBranch = false, + ref, + parent, + tree +}) { + if (!ref) { + ref = await GitRefManager.resolve({ + fs, + gitdir, + ref: "HEAD", + depth: 2 + }); + } + return GitIndexManager.acquire( + { fs, gitdir, cache, allowUnmerged: false }, + async function(index2) { + const inodes = flatFileListToDirectoryStructure(index2.entries); + const inode = inodes.get("."); + if (!tree) { + tree = await constructTree({ fs, gitdir, inode, dryRun }); + } + if (!parent) { + try { + parent = [ + await GitRefManager.resolve({ + fs, + gitdir, + ref + }) + ]; + } catch (err) { + parent = []; + } + } else { + parent = await Promise.all( + parent.map((p) => { + return GitRefManager.resolve({ fs, gitdir, ref: p }); + }) + ); + } + let comm = GitCommit.from({ + tree, + parent, + author, + committer, + message + }); + if (signingKey) { + comm = await GitCommit.sign(comm, onSign, signingKey); + } + const oid = await _writeObject({ + fs, + gitdir, + type: "commit", + object: comm.toObject(), + dryRun + }); + if (!noUpdateBranch && !dryRun) { + await GitRefManager.writeRef({ + fs, + gitdir, + ref, + value: oid + }); + } + return oid; + } + ); +} +async function constructTree({ fs, gitdir, inode, dryRun }) { + const children2 = inode.children; + for (const inode2 of children2) { + if (inode2.type === "tree") { + inode2.metadata.mode = "040000"; + inode2.metadata.oid = await constructTree({ fs, gitdir, inode: inode2, dryRun }); + } + } + const entries = children2.map((inode2) => ({ + mode: inode2.metadata.mode, + path: inode2.basename, + oid: inode2.metadata.oid, + type: inode2.type + })); + const tree = GitTree.from(entries); + const oid = await _writeObject({ + fs, + gitdir, + type: "tree", + object: tree.toObject(), + dryRun + }); + return oid; +} +async function resolveFilepath({ fs, cache, gitdir, oid, filepath }) { + if (filepath.startsWith("/")) { + throw new InvalidFilepathError("leading-slash"); + } else if (filepath.endsWith("/")) { + throw new InvalidFilepathError("trailing-slash"); + } + const _oid = oid; + const result = await resolveTree({ fs, cache, gitdir, oid }); + const tree = result.tree; + if (filepath === "") { + oid = result.oid; + } else { + const pathArray = filepath.split("/"); + oid = await _resolveFilepath({ + fs, + cache, + gitdir, + tree, + pathArray, + oid: _oid, + filepath + }); + } + return oid; +} +async function _resolveFilepath({ + fs, + cache, + gitdir, + tree, + pathArray, + oid, + filepath +}) { + const name = pathArray.shift(); + for (const entry of tree) { + if (entry.path === name) { + if (pathArray.length === 0) { + return entry.oid; + } else { + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid: entry.oid + }); + if (type !== "tree") { + throw new ObjectTypeError(oid, type, "tree", filepath); + } + tree = GitTree.from(object); + return _resolveFilepath({ + fs, + cache, + gitdir, + tree, + pathArray, + oid, + filepath + }); + } + } + } + throw new NotFoundError(`file or directory found at "${oid}:${filepath}"`); +} +async function _readTree({ + fs, + cache, + gitdir, + oid, + filepath = void 0 +}) { + if (filepath !== void 0) { + oid = await resolveFilepath({ fs, cache, gitdir, oid, filepath }); + } + const { tree, oid: treeOid } = await resolveTree({ fs, cache, gitdir, oid }); + const result = { + oid: treeOid, + tree: tree.entries() + }; + return result; +} +async function _writeTree({ fs, gitdir, tree }) { + const object = GitTree.from(tree).toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "tree", + object, + format: "content" + }); + return oid; +} +async function _addNote({ + fs, + cache, + onSign, + gitdir, + ref, + oid, + note, + force, + author, + committer, + signingKey +}) { + let parent; + try { + parent = await GitRefManager.resolve({ gitdir, fs, ref }); + } catch (err) { + if (!(err instanceof NotFoundError)) { + throw err; + } + } + const result = await _readTree({ + fs, + cache, + gitdir, + oid: parent || "4b825dc642cb6eb9a060e54bf8d69288fbee4904" + }); + let tree = result.tree; + if (force) { + tree = tree.filter((entry) => entry.path !== oid); + } else { + for (const entry of tree) { + if (entry.path === oid) { + throw new AlreadyExistsError("note", oid); + } + } + } + if (typeof note === "string") { + note = Buffer.from(note, "utf8"); + } + const noteOid = await _writeObject({ + fs, + gitdir, + type: "blob", + object: note, + format: "content" + }); + tree.push({ mode: "100644", path: oid, oid: noteOid, type: "blob" }); + const treeOid = await _writeTree({ + fs, + gitdir, + tree + }); + const commitOid = await _commit({ + fs, + cache, + onSign, + gitdir, + ref, + tree: treeOid, + parent: parent && [parent], + message: `Note added by 'isomorphic-git addNote' +`, + author, + committer, + signingKey + }); + return commitOid; +} +async function _getConfig({ fs, gitdir, path: path2 }) { + const config = await GitConfigManager.get({ fs, gitdir }); + return config.get(path2); +} +async function normalizeAuthorObject({ fs, gitdir, author = {} }) { + let { name, email, timestamp, timezoneOffset } = author; + name = name || await _getConfig({ fs, gitdir, path: "user.name" }); + email = email || await _getConfig({ fs, gitdir, path: "user.email" }) || ""; + if (name === void 0) { + return void 0; + } + timestamp = timestamp != null ? timestamp : Math.floor(Date.now() / 1e3); + timezoneOffset = timezoneOffset != null ? timezoneOffset : new Date(timestamp * 1e3).getTimezoneOffset(); + return { name, email, timestamp, timezoneOffset }; +} +async function normalizeCommitterObject({ + fs, + gitdir, + author, + committer +}) { + committer = Object.assign({}, committer || author); + if (author) { + committer.timestamp = committer.timestamp || author.timestamp; + committer.timezoneOffset = committer.timezoneOffset || author.timezoneOffset; + } + committer = await normalizeAuthorObject({ fs, gitdir, author: committer }); + return committer; +} +async function addNote({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + oid, + note, + force, + author: _author, + committer: _committer, + signingKey, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + assertParameter("note", note); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _addNote({ + fs: new FileSystem(fs), + cache, + onSign, + gitdir, + ref, + oid, + note, + force, + author, + committer, + signingKey + }); + } catch (err) { + err.caller = "git.addNote"; + throw err; + } +} +async function _addRemote({ fs, gitdir, remote, url, force }) { + if (remote !== import_clean_git_ref.default.clean(remote)) { + throw new InvalidRefNameError(remote, import_clean_git_ref.default.clean(remote)); + } + const config = await GitConfigManager.get({ fs, gitdir }); + if (!force) { + const remoteNames = await config.getSubsections("remote"); + if (remoteNames.includes(remote)) { + if (url !== await config.get(`remote.${remote}.url`)) { + throw new AlreadyExistsError("remote", remote); + } + } + } + await config.set(`remote.${remote}.url`, url); + await config.set( + `remote.${remote}.fetch`, + `+refs/heads/*:refs/remotes/${remote}/*` + ); + await GitConfigManager.save({ fs, gitdir, config }); +} +async function addRemote({ + fs, + dir, + gitdir = join(dir, ".git"), + remote, + url, + force = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("remote", remote); + assertParameter("url", url); + return await _addRemote({ + fs: new FileSystem(fs), + gitdir, + remote, + url, + force + }); + } catch (err) { + err.caller = "git.addRemote"; + throw err; + } +} +async function _annotatedTag({ + fs, + cache, + onSign, + gitdir, + ref, + tagger, + message = ref, + gpgsig, + object, + signingKey, + force = false +}) { + ref = ref.startsWith("refs/tags/") ? ref : `refs/tags/${ref}`; + if (!force && await GitRefManager.exists({ fs, gitdir, ref })) { + throw new AlreadyExistsError("tag", ref); + } + const oid = await GitRefManager.resolve({ + fs, + gitdir, + ref: object || "HEAD" + }); + const { type } = await _readObject({ fs, cache, gitdir, oid }); + let tagObject = GitAnnotatedTag.from({ + object: oid, + type, + tag: ref.replace("refs/tags/", ""), + tagger, + message, + gpgsig + }); + if (signingKey) { + tagObject = await GitAnnotatedTag.sign(tagObject, onSign, signingKey); + } + const value = await _writeObject({ + fs, + gitdir, + type: "tag", + object: tagObject.toObject() + }); + await GitRefManager.writeRef({ fs, gitdir, ref, value }); +} +async function annotatedTag({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ref, + tagger: _tagger, + message = ref, + gpgsig, + object, + signingKey, + force = false, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const tagger = await normalizeAuthorObject({ fs, gitdir, author: _tagger }); + if (!tagger) + throw new MissingNameError("tagger"); + return await _annotatedTag({ + fs, + cache, + onSign, + gitdir, + ref, + tagger, + message, + gpgsig, + object, + signingKey, + force + }); + } catch (err) { + err.caller = "git.annotatedTag"; + throw err; + } +} +async function _branch({ + fs, + gitdir, + ref, + object, + checkout: checkout2 = false, + force = false +}) { + if (ref !== import_clean_git_ref.default.clean(ref)) { + throw new InvalidRefNameError(ref, import_clean_git_ref.default.clean(ref)); + } + const fullref = `refs/heads/${ref}`; + if (!force) { + const exist = await GitRefManager.exists({ fs, gitdir, ref: fullref }); + if (exist) { + throw new AlreadyExistsError("branch", ref, false); + } + } + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref: object || "HEAD" }); + } catch (e) { + } + if (oid) { + await GitRefManager.writeRef({ fs, gitdir, ref: fullref, value: oid }); + } + if (checkout2) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref: "HEAD", + value: fullref + }); + } +} +async function branch({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + object, + checkout: checkout2 = false, + force = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await _branch({ + fs: new FileSystem(fs), + gitdir, + ref, + object, + checkout: checkout2, + force + }); + } catch (err) { + err.caller = "git.branch"; + throw err; + } +} +var worthWalking = (filepath, root2) => { + if (filepath === "." || root2 == null || root2.length === 0 || root2 === ".") { + return true; + } + if (root2.length >= filepath.length) { + return root2.startsWith(filepath); + } else { + return filepath.startsWith(root2); + } +}; +async function _checkout({ + fs, + cache, + onProgress, + dir, + gitdir, + remote, + ref, + filepaths, + noCheckout, + noUpdateHead, + dryRun, + force, + track = true +}) { + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref }); + } catch (err) { + if (ref === "HEAD") + throw err; + const remoteRef = `${remote}/${ref}`; + oid = await GitRefManager.resolve({ + fs, + gitdir, + ref: remoteRef + }); + if (track) { + const config = await GitConfigManager.get({ fs, gitdir }); + await config.set(`branch.${ref}.remote`, remote); + await config.set(`branch.${ref}.merge`, `refs/heads/${ref}`); + await GitConfigManager.save({ fs, gitdir, config }); + } + await GitRefManager.writeRef({ + fs, + gitdir, + ref: `refs/heads/${ref}`, + value: oid + }); + } + if (!noCheckout) { + let ops; + try { + ops = await analyze({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + force, + filepaths + }); + } catch (err) { + if (err instanceof NotFoundError && err.data.what === oid) { + throw new CommitNotFetchedError(ref, oid); + } else { + throw err; + } + } + const conflicts2 = ops.filter(([method2]) => method2 === "conflict").map(([method2, fullpath]) => fullpath); + if (conflicts2.length > 0) { + throw new CheckoutConflictError(conflicts2); + } + const errors = ops.filter(([method2]) => method2 === "error").map(([method2, fullpath]) => fullpath); + if (errors.length > 0) { + throw new InternalError(errors.join(", ")); + } + if (dryRun) { + return; + } + let count = 0; + const total = ops.length; + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + await Promise.all( + ops.filter( + ([method2]) => method2 === "delete" || method2 === "delete-index" + ).map(async function([method2, fullpath]) { + const filepath = `${dir}/${fullpath}`; + if (method2 === "delete") { + await fs.rm(filepath); + } + index2.delete({ filepath: fullpath }); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + }) + ); + }); + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + for (const [method2, fullpath] of ops) { + if (method2 === "rmdir" || method2 === "rmdir-index") { + const filepath = `${dir}/${fullpath}`; + try { + if (method2 === "rmdir-index") { + index2.delete({ filepath: fullpath }); + } + await fs.rmdir(filepath); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + } catch (e) { + if (e.code === "ENOTEMPTY") { + console.log( + `Did not delete ${fullpath} because directory is not empty` + ); + } else { + throw e; + } + } + } + } + }); + await Promise.all( + ops.filter(([method2]) => method2 === "mkdir" || method2 === "mkdir-index").map(async function([_, fullpath]) { + const filepath = `${dir}/${fullpath}`; + await fs.mkdir(filepath); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + }) + ); + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + await Promise.all( + ops.filter( + ([method2]) => method2 === "create" || method2 === "create-index" || method2 === "update" || method2 === "mkdir-index" + ).map(async function([method2, fullpath, oid2, mode, chmod]) { + const filepath = `${dir}/${fullpath}`; + try { + if (method2 !== "create-index" && method2 !== "mkdir-index") { + const { object } = await _readObject({ fs, cache, gitdir, oid: oid2 }); + if (chmod) { + await fs.rm(filepath); + } + if (mode === 33188) { + await fs.write(filepath, object); + } else if (mode === 33261) { + await fs.write(filepath, object, { mode: 511 }); + } else if (mode === 40960) { + await fs.writelink(filepath, object); + } else { + throw new InternalError( + `Invalid mode 0o${mode.toString(8)} detected in blob ${oid2}` + ); + } + } + const stats = await fs.lstat(filepath); + if (mode === 33261) { + stats.mode = 493; + } + if (method2 === "mkdir-index") { + stats.mode = 57344; + } + index2.insert({ + filepath: fullpath, + stats, + oid: oid2 + }); + if (onProgress) { + await onProgress({ + phase: "Updating workdir", + loaded: ++count, + total + }); + } + } catch (e) { + console.log(e); + } + }) + ); + }); + } + if (!noUpdateHead) { + const fullRef = await GitRefManager.expand({ fs, gitdir, ref }); + if (fullRef.startsWith("refs/heads")) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref: "HEAD", + value: fullRef + }); + } else { + await GitRefManager.writeRef({ fs, gitdir, ref: "HEAD", value: oid }); + } + } +} +async function analyze({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + force, + filepaths +}) { + let count = 0; + return _walk({ + fs, + cache, + dir, + gitdir, + trees: [TREE({ ref }), WORKDIR(), STAGE()], + map: async function(fullpath, [commit2, workdir, stage]) { + if (fullpath === ".") + return; + if (filepaths && !filepaths.some((base) => worthWalking(fullpath, base))) { + return null; + } + if (onProgress) { + await onProgress({ phase: "Analyzing workdir", loaded: ++count }); + } + const key2 = [!!stage, !!commit2, !!workdir].map(Number).join(""); + switch (key2) { + case "000": + return; + case "001": + if (force && filepaths && filepaths.includes(fullpath)) { + return ["delete", fullpath]; + } + return; + case "010": { + switch (await commit2.type()) { + case "tree": { + return ["mkdir", fullpath]; + } + case "blob": { + return [ + "create", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + case "commit": { + return [ + "mkdir-index", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + default: { + return [ + "error", + `new entry Unhandled type ${await commit2.type()}` + ]; + } + } + } + case "011": { + switch (`${await commit2.type()}-${await workdir.type()}`) { + case "tree-tree": { + return; + } + case "tree-blob": + case "blob-tree": { + return ["conflict", fullpath]; + } + case "blob-blob": { + if (await commit2.oid() !== await workdir.oid()) { + if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + await commit2.mode() !== await workdir.mode() + ]; + } else { + return ["conflict", fullpath]; + } + } else { + if (await commit2.mode() !== await workdir.mode()) { + if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + true + ]; + } else { + return ["conflict", fullpath]; + } + } else { + return [ + "create-index", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + } + } + case "commit-tree": { + return; + } + case "commit-blob": { + return ["conflict", fullpath]; + } + default: { + return ["error", `new entry Unhandled type ${commit2.type}`]; + } + } + } + case "100": { + return ["delete-index", fullpath]; + } + case "101": { + switch (await stage.type()) { + case "tree": { + return ["rmdir", fullpath]; + } + case "blob": { + if (await stage.oid() !== await workdir.oid()) { + if (force) { + return ["delete", fullpath]; + } else { + return ["conflict", fullpath]; + } + } else { + return ["delete", fullpath]; + } + } + case "commit": { + return ["rmdir-index", fullpath]; + } + default: { + return [ + "error", + `delete entry Unhandled type ${await stage.type()}` + ]; + } + } + } + case "110": + case "111": { + switch (`${await stage.type()}-${await commit2.type()}`) { + case "tree-tree": { + return; + } + case "blob-blob": { + if (await stage.oid() === await commit2.oid() && await stage.mode() === await commit2.mode() && !force) { + return; + } + if (workdir) { + if (await workdir.oid() !== await stage.oid() && await workdir.oid() !== await commit2.oid()) { + if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + await commit2.mode() !== await workdir.mode() + ]; + } else { + return ["conflict", fullpath]; + } + } + } else if (force) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + await commit2.mode() !== await stage.mode() + ]; + } + if (await commit2.mode() !== await stage.mode()) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + true + ]; + } + if (await commit2.oid() !== await stage.oid()) { + return [ + "update", + fullpath, + await commit2.oid(), + await commit2.mode(), + false + ]; + } else { + return; + } + } + case "tree-blob": { + return ["update-dir-to-blob", fullpath, await commit2.oid()]; + } + case "blob-tree": { + return ["update-blob-to-tree", fullpath]; + } + case "commit-commit": { + return [ + "mkdir-index", + fullpath, + await commit2.oid(), + await commit2.mode() + ]; + } + default: { + return [ + "error", + `update entry Unhandled type ${await stage.type()}-${await commit2.type()}` + ]; + } + } + } + } + }, + // Modify the default flat mapping + reduce: async function(parent, children2) { + children2 = flat(children2); + if (!parent) { + return children2; + } else if (parent && parent[0] === "rmdir") { + children2.push(parent); + return children2; + } else { + children2.unshift(parent); + return children2; + } + } + }); +} +async function checkout({ + fs, + onProgress, + dir, + gitdir = join(dir, ".git"), + remote = "origin", + ref: _ref, + filepaths, + noCheckout = false, + noUpdateHead = _ref === void 0, + dryRun = false, + force = false, + track = true, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + const ref = _ref || "HEAD"; + return await _checkout({ + fs: new FileSystem(fs), + cache, + onProgress, + dir, + gitdir, + remote, + ref, + filepaths, + noCheckout, + noUpdateHead, + dryRun, + force, + track + }); + } catch (err) { + err.caller = "git.checkout"; + throw err; + } +} +var abbreviateRx = new RegExp("^refs/(heads/|tags/|remotes/)?(.*)"); +function abbreviateRef(ref) { + const match = abbreviateRx.exec(ref); + if (match) { + if (match[1] === "remotes/" && ref.endsWith("/HEAD")) { + return match[2].slice(0, -5); + } else { + return match[2]; + } + } + return ref; +} +async function _currentBranch({ + fs, + gitdir, + fullname = false, + test = false +}) { + const ref = await GitRefManager.resolve({ + fs, + gitdir, + ref: "HEAD", + depth: 2 + }); + if (test) { + try { + await GitRefManager.resolve({ fs, gitdir, ref }); + } catch (_) { + return; + } + } + if (!ref.startsWith("refs/")) + return; + return fullname ? ref : abbreviateRef(ref); +} +function translateSSHtoHTTP(url) { + url = url.replace(/^git@([^:]+):/, "https://$1/"); + url = url.replace(/^ssh:\/\//, "https://"); + return url; +} +function calculateBasicAuthHeader({ username = "", password = "" }) { + return `Basic ${Buffer.from(`${username}:${password}`).toString("base64")}`; +} +async function forAwait(iterable, cb) { + const iter = getIterator(iterable); + while (true) { + const { value, done } = await iter.next(); + if (value) + await cb(value); + if (done) + break; + } + if (iter.return) + iter.return(); +} +async function collect(iterable) { + let size = 0; + const buffers = []; + await forAwait(iterable, (value) => { + buffers.push(value); + size += value.byteLength; + }); + const result = new Uint8Array(size); + let nextIndex = 0; + for (const buffer2 of buffers) { + result.set(buffer2, nextIndex); + nextIndex += buffer2.byteLength; + } + return result; +} +function extractAuthFromUrl(url) { + let userpass = url.match(/^https?:\/\/([^/]+)@/); + if (userpass == null) + return { url, auth: {} }; + userpass = userpass[1]; + const [username, password] = userpass.split(":"); + url = url.replace(`${userpass}@`, ""); + return { url, auth: { username, password } }; +} +function padHex(b, n) { + const s = n.toString(16); + return "0".repeat(b - s.length) + s; +} +var GitPktLine = class { + static flush() { + return Buffer.from("0000", "utf8"); + } + static delim() { + return Buffer.from("0001", "utf8"); + } + static encode(line) { + if (typeof line === "string") { + line = Buffer.from(line); + } + const length = line.length + 4; + const hexlength = padHex(4, length); + return Buffer.concat([Buffer.from(hexlength, "utf8"), line]); + } + static streamReader(stream) { + const reader = new StreamReader(stream); + return async function read() { + try { + let length = await reader.read(4); + if (length == null) + return true; + length = parseInt(length.toString("utf8"), 16); + if (length === 0) + return null; + if (length === 1) + return null; + const buffer2 = await reader.read(length - 4); + if (buffer2 == null) + return true; + return buffer2; + } catch (err) { + console.log("error", err); + return true; + } + }; + } +}; +async function parseCapabilitiesV2(read) { + const capabilities2 = {}; + let line; + while (true) { + line = await read(); + if (line === true) + break; + if (line === null) + continue; + line = line.toString("utf8").replace(/\n$/, ""); + const i = line.indexOf("="); + if (i > -1) { + const key2 = line.slice(0, i); + const value = line.slice(i + 1); + capabilities2[key2] = value; + } else { + capabilities2[line] = true; + } + } + return { protocolVersion: 2, capabilities2 }; +} +async function parseRefsAdResponse(stream, { service }) { + const capabilities = /* @__PURE__ */ new Set(); + const refs = /* @__PURE__ */ new Map(); + const symrefs = /* @__PURE__ */ new Map(); + const read = GitPktLine.streamReader(stream); + let lineOne = await read(); + while (lineOne === null) + lineOne = await read(); + if (lineOne === true) + throw new EmptyServerResponseError(); + if (lineOne.includes("version 2")) { + return parseCapabilitiesV2(read); + } + if (lineOne.toString("utf8").replace(/\n$/, "") !== `# service=${service}`) { + throw new ParseError(`# service=${service}\\n`, lineOne.toString("utf8")); + } + let lineTwo = await read(); + while (lineTwo === null) + lineTwo = await read(); + if (lineTwo === true) + return { capabilities, refs, symrefs }; + lineTwo = lineTwo.toString("utf8"); + if (lineTwo.includes("version 2")) { + return parseCapabilitiesV2(read); + } + const [firstRef, capabilitiesLine] = splitAndAssert(lineTwo, "\0", "\\x00"); + capabilitiesLine.split(" ").map((x) => capabilities.add(x)); + const [ref, name] = splitAndAssert(firstRef, " ", " "); + refs.set(name, ref); + while (true) { + const line = await read(); + if (line === true) + break; + if (line !== null) { + const [ref2, name2] = splitAndAssert(line.toString("utf8"), " ", " "); + refs.set(name2, ref2); + } + } + for (const cap of capabilities) { + if (cap.startsWith("symref=")) { + const m = cap.match(/symref=([^:]+):(.*)/); + if (m.length === 3) { + symrefs.set(m[1], m[2]); + } + } + } + return { protocolVersion: 1, capabilities, refs, symrefs }; +} +function splitAndAssert(line, sep2, expected) { + const split = line.trim().split(sep2); + if (split.length !== 2) { + throw new ParseError( + `Two strings separated by '${expected}'`, + line.toString("utf8") + ); + } + return split; +} +var corsProxify = (corsProxy, url) => corsProxy.endsWith("?") ? `${corsProxy}${url}` : `${corsProxy}/${url.replace(/^https?:\/\//, "")}`; +var updateHeaders = (headers, auth) => { + if (auth.username || auth.password) { + headers.Authorization = calculateBasicAuthHeader(auth); + } + if (auth.headers) { + Object.assign(headers, auth.headers); + } +}; +var stringifyBody = async (res) => { + try { + const data = Buffer.from(await collect(res.body)); + const response = data.toString("utf8"); + const preview = response.length < 256 ? response : response.slice(0, 256) + "..."; + return { preview, response, data }; + } catch (e) { + return {}; + } +}; +var GitRemoteHTTP = class { + static async capabilities() { + return ["discover", "connect"]; + } + /** + * @param {Object} args + * @param {HttpClient} args.http + * @param {ProgressCallback} [args.onProgress] + * @param {AuthCallback} [args.onAuth] + * @param {AuthFailureCallback} [args.onAuthFailure] + * @param {AuthSuccessCallback} [args.onAuthSuccess] + * @param {string} [args.corsProxy] + * @param {string} args.service + * @param {string} args.url + * @param {Object} args.headers + * @param {1 | 2} args.protocolVersion - Git Protocol Version + */ + static async discover({ + http, + onProgress, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service, + url: _origUrl, + headers, + protocolVersion + }) { + let { url, auth } = extractAuthFromUrl(_origUrl); + const proxifiedURL = corsProxy ? corsProxify(corsProxy, url) : url; + if (auth.username || auth.password) { + headers.Authorization = calculateBasicAuthHeader(auth); + } + if (protocolVersion === 2) { + headers["Git-Protocol"] = "version=2"; + } + let res; + let tryAgain; + let providedAuthBefore = false; + do { + res = await http.request({ + onProgress, + method: "GET", + url: `${proxifiedURL}/info/refs?service=${service}`, + headers + }); + tryAgain = false; + if (res.statusCode === 401 || res.statusCode === 203) { + const getAuth = providedAuthBefore ? onAuthFailure : onAuth; + if (getAuth) { + auth = await getAuth(url, { + ...auth, + headers: { ...headers } + }); + if (auth && auth.cancel) { + throw new UserCanceledError(); + } else if (auth) { + updateHeaders(headers, auth); + providedAuthBefore = true; + tryAgain = true; + } + } + } else if (res.statusCode === 200 && providedAuthBefore && onAuthSuccess) { + await onAuthSuccess(url, auth); + } + } while (tryAgain); + if (res.statusCode !== 200) { + const { response } = await stringifyBody(res); + throw new HttpError(res.statusCode, res.statusMessage, response); + } + if (res.headers["content-type"] === `application/x-${service}-advertisement`) { + const remoteHTTP = await parseRefsAdResponse(res.body, { service }); + remoteHTTP.auth = auth; + return remoteHTTP; + } else { + const { preview, response, data } = await stringifyBody(res); + try { + const remoteHTTP = await parseRefsAdResponse([data], { service }); + remoteHTTP.auth = auth; + return remoteHTTP; + } catch (e) { + throw new SmartHttpError(preview, response); + } + } + } + /** + * @param {Object} args + * @param {HttpClient} args.http + * @param {ProgressCallback} [args.onProgress] + * @param {string} [args.corsProxy] + * @param {string} args.service + * @param {string} args.url + * @param {Object} [args.headers] + * @param {any} args.body + * @param {any} args.auth + */ + static async connect({ + http, + onProgress, + corsProxy, + service, + url, + auth, + body, + headers + }) { + const urlAuth = extractAuthFromUrl(url); + if (urlAuth) + url = urlAuth.url; + if (corsProxy) + url = corsProxify(corsProxy, url); + headers["content-type"] = `application/x-${service}-request`; + headers.accept = `application/x-${service}-result`; + updateHeaders(headers, auth); + const res = await http.request({ + onProgress, + method: "POST", + url: `${url}/${service}`, + body, + headers + }); + if (res.statusCode !== 200) { + const { response } = stringifyBody(res); + throw new HttpError(res.statusCode, res.statusMessage, response); + } + return res; + } +}; +function parseRemoteUrl({ url }) { + if (url.startsWith("git@")) { + return { + transport: "ssh", + address: url + }; + } + const matches = url.match(/(\w+)(:\/\/|::)(.*)/); + if (matches === null) + return; + if (matches[2] === "://") { + return { + transport: matches[1], + address: matches[0] + }; + } + if (matches[2] === "::") { + return { + transport: matches[1], + address: matches[3] + }; + } +} +var GitRemoteManager = class { + static getRemoteHelperFor({ url }) { + const remoteHelpers = /* @__PURE__ */ new Map(); + remoteHelpers.set("http", GitRemoteHTTP); + remoteHelpers.set("https", GitRemoteHTTP); + const parts = parseRemoteUrl({ url }); + if (!parts) { + throw new UrlParseError(url); + } + if (remoteHelpers.has(parts.transport)) { + return remoteHelpers.get(parts.transport); + } + throw new UnknownTransportError( + url, + parts.transport, + parts.transport === "ssh" ? translateSSHtoHTTP(url) : void 0 + ); + } +}; +var lock$1 = null; +var GitShallowManager = class { + static async read({ fs, gitdir }) { + if (lock$1 === null) + lock$1 = new import_async_lock.default(); + const filepath = join(gitdir, "shallow"); + const oids = /* @__PURE__ */ new Set(); + await lock$1.acquire(filepath, async function() { + const text2 = await fs.read(filepath, { encoding: "utf8" }); + if (text2 === null) + return oids; + if (text2.trim() === "") + return oids; + text2.trim().split("\n").map((oid) => oids.add(oid)); + }); + return oids; + } + static async write({ fs, gitdir, oids }) { + if (lock$1 === null) + lock$1 = new import_async_lock.default(); + const filepath = join(gitdir, "shallow"); + if (oids.size > 0) { + const text2 = [...oids].join("\n") + "\n"; + await lock$1.acquire(filepath, async function() { + await fs.write(filepath, text2, { + encoding: "utf8" + }); + }); + } else { + await lock$1.acquire(filepath, async function() { + await fs.rm(filepath); + }); + } + } +}; +async function hasObjectLoose({ fs, gitdir, oid }) { + const source = `objects/${oid.slice(0, 2)}/${oid.slice(2)}`; + return fs.exists(`${gitdir}/${source}`); +} +async function hasObjectPacked({ + fs, + cache, + gitdir, + oid, + getExternalRefDelta +}) { + let list = await fs.readdir(join(gitdir, "objects/pack")); + list = list.filter((x) => x.endsWith(".idx")); + for (const filename of list) { + const indexFile = `${gitdir}/objects/pack/${filename}`; + const p = await readPackIndex({ + fs, + cache, + filename: indexFile, + getExternalRefDelta + }); + if (p.error) + throw new InternalError(p.error); + if (p.offsets.has(oid)) { + return true; + } + } + return false; +} +async function hasObject({ + fs, + cache, + gitdir, + oid, + format = "content" +}) { + const getExternalRefDelta = (oid2) => _readObject({ fs, cache, gitdir, oid: oid2 }); + let result = await hasObjectLoose({ fs, gitdir, oid }); + if (!result) { + result = await hasObjectPacked({ + fs, + cache, + gitdir, + oid, + getExternalRefDelta + }); + } + return result; +} +function emptyPackfile(pack) { + const pheader = "5041434b"; + const version2 = "00000002"; + const obCount = "00000000"; + const header = pheader + version2 + obCount; + return pack.slice(0, 12).toString("hex") === header; +} +function filterCapabilities(server, client) { + const serverNames = server.map((cap) => cap.split("=", 1)[0]); + return client.filter((cap) => { + const name = cap.split("=", 1)[0]; + return serverNames.includes(name); + }); +} +var pkg = { + name: "isomorphic-git", + version: "1.24.5", + agent: "git/isomorphic-git@1.24.5" +}; +var FIFO = class { + constructor() { + this._queue = []; + } + write(chunk) { + if (this._ended) { + throw Error("You cannot write to a FIFO that has already been ended!"); + } + if (this._waiting) { + const resolve = this._waiting; + this._waiting = null; + resolve({ value: chunk }); + } else { + this._queue.push(chunk); + } + } + end() { + this._ended = true; + if (this._waiting) { + const resolve = this._waiting; + this._waiting = null; + resolve({ done: true }); + } + } + destroy(err) { + this._ended = true; + this.error = err; + } + async next() { + if (this._queue.length > 0) { + return { value: this._queue.shift() }; + } + if (this._ended) { + return { done: true }; + } + if (this._waiting) { + throw Error( + "You cannot call read until the previous call to read has returned!" + ); + } + return new Promise((resolve) => { + this._waiting = resolve; + }); + } +}; +function findSplit(str) { + const r = str.indexOf("\r"); + const n = str.indexOf("\n"); + if (r === -1 && n === -1) + return -1; + if (r === -1) + return n + 1; + if (n === -1) + return r + 1; + if (n === r + 1) + return n + 1; + return Math.min(r, n) + 1; +} +function splitLines(input) { + const output = new FIFO(); + let tmp = ""; + (async () => { + await forAwait(input, (chunk) => { + chunk = chunk.toString("utf8"); + tmp += chunk; + while (true) { + const i = findSplit(tmp); + if (i === -1) + break; + output.write(tmp.slice(0, i)); + tmp = tmp.slice(i); + } + }); + if (tmp.length > 0) { + output.write(tmp); + } + output.end(); + })(); + return output; +} +var GitSideBand = class { + static demux(input) { + const read = GitPktLine.streamReader(input); + const packetlines = new FIFO(); + const packfile = new FIFO(); + const progress = new FIFO(); + const nextBit = async function() { + const line = await read(); + if (line === null) + return nextBit(); + if (line === true) { + packetlines.end(); + progress.end(); + packfile.end(); + return; + } + switch (line[0]) { + case 1: { + packfile.write(line.slice(1)); + break; + } + case 2: { + progress.write(line.slice(1)); + break; + } + case 3: { + const error = line.slice(1); + progress.write(error); + packfile.destroy(new Error(error.toString("utf8"))); + return; + } + default: { + packetlines.write(line.slice(0)); + } + } + nextBit(); + }; + nextBit(); + return { + packetlines, + packfile, + progress + }; + } + // static mux ({ + // protocol, // 'side-band' or 'side-band-64k' + // packetlines, + // packfile, + // progress, + // error + // }) { + // const MAX_PACKET_LENGTH = protocol === 'side-band-64k' ? 999 : 65519 + // let output = new PassThrough() + // packetlines.on('data', data => { + // if (data === null) { + // output.write(GitPktLine.flush()) + // } else { + // output.write(GitPktLine.encode(data)) + // } + // }) + // let packfileWasEmpty = true + // let packfileEnded = false + // let progressEnded = false + // let errorEnded = false + // let goodbye = Buffer.concat([ + // GitPktLine.encode(Buffer.from('010A', 'hex')), + // GitPktLine.flush() + // ]) + // packfile + // .on('data', data => { + // packfileWasEmpty = false + // const buffers = splitBuffer(data, MAX_PACKET_LENGTH) + // for (const buffer of buffers) { + // output.write( + // GitPktLine.encode(Buffer.concat([Buffer.from('01', 'hex'), buffer])) + // ) + // } + // }) + // .on('end', () => { + // packfileEnded = true + // if (!packfileWasEmpty) output.write(goodbye) + // if (progressEnded && errorEnded) output.end() + // }) + // progress + // .on('data', data => { + // const buffers = splitBuffer(data, MAX_PACKET_LENGTH) + // for (const buffer of buffers) { + // output.write( + // GitPktLine.encode(Buffer.concat([Buffer.from('02', 'hex'), buffer])) + // ) + // } + // }) + // .on('end', () => { + // progressEnded = true + // if (packfileEnded && errorEnded) output.end() + // }) + // error + // .on('data', data => { + // const buffers = splitBuffer(data, MAX_PACKET_LENGTH) + // for (const buffer of buffers) { + // output.write( + // GitPktLine.encode(Buffer.concat([Buffer.from('03', 'hex'), buffer])) + // ) + // } + // }) + // .on('end', () => { + // errorEnded = true + // if (progressEnded && packfileEnded) output.end() + // }) + // return output + // } +}; +async function parseUploadPackResponse(stream) { + const { packetlines, packfile, progress } = GitSideBand.demux(stream); + const shallows = []; + const unshallows = []; + const acks = []; + let nak = false; + let done = false; + return new Promise((resolve, reject) => { + forAwait(packetlines, (data) => { + const line = data.toString("utf8").trim(); + if (line.startsWith("shallow")) { + const oid = line.slice(-41).trim(); + if (oid.length !== 40) { + reject(new InvalidOidError(oid)); + } + shallows.push(oid); + } else if (line.startsWith("unshallow")) { + const oid = line.slice(-41).trim(); + if (oid.length !== 40) { + reject(new InvalidOidError(oid)); + } + unshallows.push(oid); + } else if (line.startsWith("ACK")) { + const [, oid, status2] = line.split(" "); + acks.push({ oid, status: status2 }); + if (!status2) + done = true; + } else if (line.startsWith("NAK")) { + nak = true; + done = true; + } + if (done) { + resolve({ shallows, unshallows, acks, nak, packfile, progress }); + } + }); + }); +} +function writeUploadPackRequest({ + capabilities = [], + wants = [], + haves = [], + shallows = [], + depth = null, + since = null, + exclude = [] +}) { + const packstream = []; + wants = [...new Set(wants)]; + let firstLineCapabilities = ` ${capabilities.join(" ")}`; + for (const oid of wants) { + packstream.push(GitPktLine.encode(`want ${oid}${firstLineCapabilities} +`)); + firstLineCapabilities = ""; + } + for (const oid of shallows) { + packstream.push(GitPktLine.encode(`shallow ${oid} +`)); + } + if (depth !== null) { + packstream.push(GitPktLine.encode(`deepen ${depth} +`)); + } + if (since !== null) { + packstream.push( + GitPktLine.encode(`deepen-since ${Math.floor(since.valueOf() / 1e3)} +`) + ); + } + for (const oid of exclude) { + packstream.push(GitPktLine.encode(`deepen-not ${oid} +`)); + } + packstream.push(GitPktLine.flush()); + for (const oid of haves) { + packstream.push(GitPktLine.encode(`have ${oid} +`)); + } + packstream.push(GitPktLine.encode(`done +`)); + return packstream; +} +async function _fetch({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref: _ref, + remoteRef: _remoteRef, + remote: _remote, + url: _url, + corsProxy, + depth = null, + since = null, + exclude = [], + relative: relative2 = false, + tags = false, + singleBranch = false, + headers = {}, + prune = false, + pruneTags = false +}) { + const ref = _ref || await _currentBranch({ fs, gitdir, test: true }); + const config = await GitConfigManager.get({ fs, gitdir }); + const remote = _remote || ref && await config.get(`branch.${ref}.remote`) || "origin"; + const url = _url || await config.get(`remote.${remote}.url`); + if (typeof url === "undefined") { + throw new MissingParameterError("remote OR url"); + } + const remoteRef = _remoteRef || ref && await config.get(`branch.${ref}.merge`) || _ref || "HEAD"; + if (corsProxy === void 0) { + corsProxy = await config.get("http.corsProxy"); + } + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const remoteHTTP = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: "git-upload-pack", + url, + headers, + protocolVersion: 1 + }); + const auth = remoteHTTP.auth; + const remoteRefs = remoteHTTP.refs; + if (remoteRefs.size === 0) { + return { + defaultBranch: null, + fetchHead: null, + fetchHeadDescription: null + }; + } + if (depth !== null && !remoteHTTP.capabilities.has("shallow")) { + throw new RemoteCapabilityError("shallow", "depth"); + } + if (since !== null && !remoteHTTP.capabilities.has("deepen-since")) { + throw new RemoteCapabilityError("deepen-since", "since"); + } + if (exclude.length > 0 && !remoteHTTP.capabilities.has("deepen-not")) { + throw new RemoteCapabilityError("deepen-not", "exclude"); + } + if (relative2 === true && !remoteHTTP.capabilities.has("deepen-relative")) { + throw new RemoteCapabilityError("deepen-relative", "relative"); + } + const { oid, fullref } = GitRefManager.resolveAgainstMap({ + ref: remoteRef, + map: remoteRefs + }); + for (const remoteRef2 of remoteRefs.keys()) { + if (remoteRef2 === fullref || remoteRef2 === "HEAD" || remoteRef2.startsWith("refs/heads/") || tags && remoteRef2.startsWith("refs/tags/")) { + continue; + } + remoteRefs.delete(remoteRef2); + } + const capabilities = filterCapabilities( + [...remoteHTTP.capabilities], + [ + "multi_ack_detailed", + "no-done", + "side-band-64k", + // Note: I removed 'thin-pack' option since our code doesn't "fatten" packfiles, + // which is necessary for compatibility with git. It was the cause of mysterious + // 'fatal: pack has [x] unresolved deltas' errors that plagued us for some time. + // isomorphic-git is perfectly happy with thin packfiles in .git/objects/pack but + // canonical git it turns out is NOT. + "ofs-delta", + `agent=${pkg.agent}` + ] + ); + if (relative2) + capabilities.push("deepen-relative"); + const wants = singleBranch ? [oid] : remoteRefs.values(); + const haveRefs = singleBranch ? [ref] : await GitRefManager.listRefs({ + fs, + gitdir, + filepath: `refs` + }); + let haves = []; + for (let ref2 of haveRefs) { + try { + ref2 = await GitRefManager.expand({ fs, gitdir, ref: ref2 }); + const oid2 = await GitRefManager.resolve({ fs, gitdir, ref: ref2 }); + if (await hasObject({ fs, cache, gitdir, oid: oid2 })) { + haves.push(oid2); + } + } catch (err) { + } + } + haves = [...new Set(haves)]; + const oids = await GitShallowManager.read({ fs, gitdir }); + const shallows = remoteHTTP.capabilities.has("shallow") ? [...oids] : []; + const packstream = writeUploadPackRequest({ + capabilities, + wants, + haves, + shallows, + depth, + since, + exclude + }); + const packbuffer = Buffer.from(await collect(packstream)); + const raw = await GitRemoteHTTP2.connect({ + http, + onProgress, + corsProxy, + service: "git-upload-pack", + url, + auth, + body: [packbuffer], + headers + }); + const response = await parseUploadPackResponse(raw.body); + if (raw.headers) { + response.headers = raw.headers; + } + for (const oid2 of response.shallows) { + if (!oids.has(oid2)) { + try { + const { object } = await _readObject({ fs, cache, gitdir, oid: oid2 }); + const commit2 = new GitCommit(object); + const hasParents = await Promise.all( + commit2.headers().parent.map((oid3) => hasObject({ fs, cache, gitdir, oid: oid3 })) + ); + const haveAllParents = hasParents.length === 0 || hasParents.every((has) => has); + if (!haveAllParents) { + oids.add(oid2); + } + } catch (err) { + oids.add(oid2); + } + } + } + for (const oid2 of response.unshallows) { + oids.delete(oid2); + } + await GitShallowManager.write({ fs, gitdir, oids }); + if (singleBranch) { + const refs = /* @__PURE__ */ new Map([[fullref, oid]]); + const symrefs = /* @__PURE__ */ new Map(); + let bail = 10; + let key2 = fullref; + while (bail--) { + const value = remoteHTTP.symrefs.get(key2); + if (value === void 0) + break; + symrefs.set(key2, value); + key2 = value; + } + const realRef = remoteRefs.get(key2); + if (realRef) { + refs.set(key2, realRef); + } + const { pruned } = await GitRefManager.updateRemoteRefs({ + fs, + gitdir, + remote, + refs, + symrefs, + tags, + prune + }); + if (prune) { + response.pruned = pruned; + } + } else { + const { pruned } = await GitRefManager.updateRemoteRefs({ + fs, + gitdir, + remote, + refs: remoteRefs, + symrefs: remoteHTTP.symrefs, + tags, + prune, + pruneTags + }); + if (prune) { + response.pruned = pruned; + } + } + response.HEAD = remoteHTTP.symrefs.get("HEAD"); + if (response.HEAD === void 0) { + const { oid: oid2 } = GitRefManager.resolveAgainstMap({ + ref: "HEAD", + map: remoteRefs + }); + for (const [key2, value] of remoteRefs.entries()) { + if (key2 !== "HEAD" && value === oid2) { + response.HEAD = key2; + break; + } + } + } + const noun = fullref.startsWith("refs/tags") ? "tag" : "branch"; + response.FETCH_HEAD = { + oid, + description: `${noun} '${abbreviateRef(fullref)}' of ${url}` + }; + if (onProgress || onMessage) { + const lines = splitLines(response.progress); + forAwait(lines, async (line) => { + if (onMessage) + await onMessage(line); + if (onProgress) { + const matches = line.match(/([^:]*).*\((\d+?)\/(\d+?)\)/); + if (matches) { + await onProgress({ + phase: matches[1].trim(), + loaded: parseInt(matches[2], 10), + total: parseInt(matches[3], 10) + }); + } + } + }); + } + const packfile = Buffer.from(await collect(response.packfile)); + const packfileSha = packfile.slice(-20).toString("hex"); + const res = { + defaultBranch: response.HEAD, + fetchHead: response.FETCH_HEAD.oid, + fetchHeadDescription: response.FETCH_HEAD.description + }; + if (response.headers) { + res.headers = response.headers; + } + if (prune) { + res.pruned = response.pruned; + } + if (packfileSha !== "" && !emptyPackfile(packfile)) { + res.packfile = `objects/pack/pack-${packfileSha}.pack`; + const fullpath = join(gitdir, res.packfile); + await fs.write(fullpath, packfile); + const getExternalRefDelta = (oid2) => _readObject({ fs, cache, gitdir, oid: oid2 }); + const idx = await GitPackIndex.fromPack({ + pack: packfile, + getExternalRefDelta, + onProgress + }); + await fs.write(fullpath.replace(/\.pack$/, ".idx"), await idx.toBuffer()); + } + return res; +} +async function _init({ + fs, + bare = false, + dir, + gitdir = bare ? dir : join(dir, ".git"), + defaultBranch = "master" +}) { + if (await fs.exists(gitdir + "/config")) + return; + let folders = [ + "hooks", + "info", + "objects/info", + "objects/pack", + "refs/heads", + "refs/tags" + ]; + folders = folders.map((dir2) => gitdir + "/" + dir2); + for (const folder of folders) { + await fs.mkdir(folder); + } + await fs.write( + gitdir + "/config", + `[core] + repositoryformatversion = 0 + filemode = false + bare = ${bare} +` + (bare ? "" : " logallrefupdates = true\n") + " symlinks = false\n ignorecase = true\n" + ); + await fs.write(gitdir + "/HEAD", `ref: refs/heads/${defaultBranch} +`); +} +async function _clone({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + url, + corsProxy, + ref, + remote, + depth, + since, + exclude, + relative: relative2, + singleBranch, + noCheckout, + noTags, + headers +}) { + try { + await _init({ fs, gitdir }); + await _addRemote({ fs, gitdir, remote, url, force: false }); + if (corsProxy) { + const config = await GitConfigManager.get({ fs, gitdir }); + await config.set(`http.corsProxy`, corsProxy); + await GitConfigManager.save({ fs, gitdir, config }); + } + const { defaultBranch, fetchHead } = await _fetch({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref, + remote, + corsProxy, + depth, + since, + exclude, + relative: relative2, + singleBranch, + headers, + tags: !noTags + }); + if (fetchHead === null) + return; + ref = ref || defaultBranch; + ref = ref.replace("refs/heads/", ""); + await _checkout({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + remote, + noCheckout + }); + } catch (err) { + await fs.rmdir(gitdir, { recursive: true, maxRetries: 10 }).catch(() => void 0); + throw err; + } +} +async function clone({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + url, + corsProxy = void 0, + ref = void 0, + remote = "origin", + depth = void 0, + since = void 0, + exclude = [], + relative: relative2 = false, + singleBranch = false, + noCheckout = false, + noTags = false, + headers = {}, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + if (!noCheckout) { + assertParameter("dir", dir); + } + assertParameter("url", url); + return await _clone({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + url, + corsProxy, + ref, + remote, + depth, + since, + exclude, + relative: relative2, + singleBranch, + noCheckout, + noTags, + headers + }); + } catch (err) { + err.caller = "git.clone"; + throw err; + } +} +async function commit({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + message, + author: _author, + committer: _committer, + signingKey, + dryRun = false, + noUpdateBranch = false, + ref, + parent, + tree, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("message", message); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _commit({ + fs, + cache, + onSign, + gitdir, + message, + author, + committer, + signingKey, + dryRun, + noUpdateBranch, + ref, + parent, + tree + }); + } catch (err) { + err.caller = "git.commit"; + throw err; + } +} +async function currentBranch({ + fs, + dir, + gitdir = join(dir, ".git"), + fullname = false, + test = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return await _currentBranch({ + fs: new FileSystem(fs), + gitdir, + fullname, + test + }); + } catch (err) { + err.caller = "git.currentBranch"; + throw err; + } +} +async function _deleteBranch({ fs, gitdir, ref }) { + ref = ref.startsWith("refs/heads/") ? ref : `refs/heads/${ref}`; + const exist = await GitRefManager.exists({ fs, gitdir, ref }); + if (!exist) { + throw new NotFoundError(ref); + } + const fullRef = await GitRefManager.expand({ fs, gitdir, ref }); + const currentRef = await _currentBranch({ fs, gitdir, fullname: true }); + if (fullRef === currentRef) { + const value = await GitRefManager.resolve({ fs, gitdir, ref: fullRef }); + await GitRefManager.writeRef({ fs, gitdir, ref: "HEAD", value }); + } + await GitRefManager.deleteRef({ fs, gitdir, ref: fullRef }); +} +async function deleteBranch({ + fs, + dir, + gitdir = join(dir, ".git"), + ref +}) { + try { + assertParameter("fs", fs); + assertParameter("ref", ref); + return await _deleteBranch({ + fs: new FileSystem(fs), + gitdir, + ref + }); + } catch (err) { + err.caller = "git.deleteBranch"; + throw err; + } +} +async function deleteRef({ fs, dir, gitdir = join(dir, ".git"), ref }) { + try { + assertParameter("fs", fs); + assertParameter("ref", ref); + await GitRefManager.deleteRef({ fs: new FileSystem(fs), gitdir, ref }); + } catch (err) { + err.caller = "git.deleteRef"; + throw err; + } +} +async function _deleteRemote({ fs, gitdir, remote }) { + const config = await GitConfigManager.get({ fs, gitdir }); + await config.deleteSection("remote", remote); + await GitConfigManager.save({ fs, gitdir, config }); +} +async function deleteRemote({ + fs, + dir, + gitdir = join(dir, ".git"), + remote +}) { + try { + assertParameter("fs", fs); + assertParameter("remote", remote); + return await _deleteRemote({ + fs: new FileSystem(fs), + gitdir, + remote + }); + } catch (err) { + err.caller = "git.deleteRemote"; + throw err; + } +} +async function _deleteTag({ fs, gitdir, ref }) { + ref = ref.startsWith("refs/tags/") ? ref : `refs/tags/${ref}`; + await GitRefManager.deleteRef({ fs, gitdir, ref }); +} +async function deleteTag({ fs, dir, gitdir = join(dir, ".git"), ref }) { + try { + assertParameter("fs", fs); + assertParameter("ref", ref); + return await _deleteTag({ + fs: new FileSystem(fs), + gitdir, + ref + }); + } catch (err) { + err.caller = "git.deleteTag"; + throw err; + } +} +async function expandOidLoose({ fs, gitdir, oid: short }) { + const prefix = short.slice(0, 2); + const objectsSuffixes = await fs.readdir(`${gitdir}/objects/${prefix}`); + return objectsSuffixes.map((suffix) => `${prefix}${suffix}`).filter((_oid) => _oid.startsWith(short)); +} +async function expandOidPacked({ + fs, + cache, + gitdir, + oid: short, + getExternalRefDelta +}) { + const results = []; + let list = await fs.readdir(join(gitdir, "objects/pack")); + list = list.filter((x) => x.endsWith(".idx")); + for (const filename of list) { + const indexFile = `${gitdir}/objects/pack/${filename}`; + const p = await readPackIndex({ + fs, + cache, + filename: indexFile, + getExternalRefDelta + }); + if (p.error) + throw new InternalError(p.error); + for (const oid of p.offsets.keys()) { + if (oid.startsWith(short)) + results.push(oid); + } + } + return results; +} +async function _expandOid({ fs, cache, gitdir, oid: short }) { + const getExternalRefDelta = (oid) => _readObject({ fs, cache, gitdir, oid }); + const results = await expandOidLoose({ fs, gitdir, oid: short }); + const packedOids = await expandOidPacked({ + fs, + cache, + gitdir, + oid: short, + getExternalRefDelta + }); + for (const packedOid of packedOids) { + if (results.indexOf(packedOid) === -1) { + results.push(packedOid); + } + } + if (results.length === 1) { + return results[0]; + } + if (results.length > 1) { + throw new AmbiguousError("oids", short, results); + } + throw new NotFoundError(`an object matching "${short}"`); +} +async function expandOid({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _expandOid({ + fs: new FileSystem(fs), + cache, + gitdir, + oid + }); + } catch (err) { + err.caller = "git.expandOid"; + throw err; + } +} +async function expandRef({ fs, dir, gitdir = join(dir, ".git"), ref }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await GitRefManager.expand({ + fs: new FileSystem(fs), + gitdir, + ref + }); + } catch (err) { + err.caller = "git.expandRef"; + throw err; + } +} +async function _findMergeBase({ fs, cache, gitdir, oids }) { + const visits = {}; + const passes = oids.length; + let heads = oids.map((oid, index2) => ({ index: index2, oid })); + while (heads.length) { + const result = /* @__PURE__ */ new Set(); + for (const { oid, index: index2 } of heads) { + if (!visits[oid]) + visits[oid] = /* @__PURE__ */ new Set(); + visits[oid].add(index2); + if (visits[oid].size === passes) { + result.add(oid); + } + } + if (result.size > 0) { + return [...result]; + } + const newheads = /* @__PURE__ */ new Map(); + for (const { oid, index: index2 } of heads) { + try { + const { object } = await _readObject({ fs, cache, gitdir, oid }); + const commit2 = GitCommit.from(object); + const { parent } = commit2.parseHeaders(); + for (const oid2 of parent) { + if (!visits[oid2] || !visits[oid2].has(index2)) { + newheads.set(oid2 + ":" + index2, { oid: oid2, index: index2 }); + } + } + } catch (err) { + } + } + heads = Array.from(newheads.values()); + } + return []; +} +var LINEBREAKS = /^.*(\r?\n|$)/gm; +function mergeFile({ branches, contents }) { + const ourName = branches[1]; + const theirName = branches[2]; + const baseContent = contents[0]; + const ourContent = contents[1]; + const theirContent = contents[2]; + const ours = ourContent.match(LINEBREAKS); + const base = baseContent.match(LINEBREAKS); + const theirs = theirContent.match(LINEBREAKS); + const result = (0, import_diff3.default)(ours, base, theirs); + const markerSize = 7; + let mergedText = ""; + let cleanMerge = true; + for (const item of result) { + if (item.ok) { + mergedText += item.ok.join(""); + } + if (item.conflict) { + cleanMerge = false; + mergedText += `${"<".repeat(markerSize)} ${ourName} +`; + mergedText += item.conflict.a.join(""); + mergedText += `${"=".repeat(markerSize)} +`; + mergedText += item.conflict.b.join(""); + mergedText += `${">".repeat(markerSize)} ${theirName} +`; + } + } + return { cleanMerge, mergedText }; +} +async function mergeTree({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + index: index2, + ourOid, + baseOid, + theirOid, + ourName = "ours", + baseName = "base", + theirName = "theirs", + dryRun = false, + abortOnConflict = true, + mergeDriver +}) { + const ourTree = TREE({ ref: ourOid }); + const baseTree = TREE({ ref: baseOid }); + const theirTree = TREE({ ref: theirOid }); + const unmergedFiles = []; + const results = await _walk({ + fs, + cache, + dir, + gitdir, + trees: [ourTree, baseTree, theirTree], + map: async function(filepath, [ours, base, theirs]) { + const path2 = basename(filepath); + const ourChange = await modified(ours, base); + const theirChange = await modified(theirs, base); + switch (`${ourChange}-${theirChange}`) { + case "false-false": { + return { + mode: await base.mode(), + path: path2, + oid: await base.oid(), + type: await base.type() + }; + } + case "false-true": { + return theirs ? { + mode: await theirs.mode(), + path: path2, + oid: await theirs.oid(), + type: await theirs.type() + } : void 0; + } + case "true-false": { + return ours ? { + mode: await ours.mode(), + path: path2, + oid: await ours.oid(), + type: await ours.type() + } : void 0; + } + case "true-true": { + if (ours && base && theirs && await ours.type() === "blob" && await base.type() === "blob" && await theirs.type() === "blob") { + return mergeBlobs({ + fs, + gitdir, + path: path2, + ours, + base, + theirs, + ourName, + baseName, + theirName, + mergeDriver + }).then(async (r) => { + if (!r.cleanMerge) { + unmergedFiles.push(filepath); + if (!abortOnConflict) { + const baseOid2 = await base.oid(); + const ourOid2 = await ours.oid(); + const theirOid2 = await theirs.oid(); + index2.delete({ filepath }); + index2.insert({ filepath, oid: baseOid2, stage: 1 }); + index2.insert({ filepath, oid: ourOid2, stage: 2 }); + index2.insert({ filepath, oid: theirOid2, stage: 3 }); + } + } else if (!abortOnConflict) { + index2.insert({ filepath, oid: r.mergeResult.oid, stage: 0 }); + } + return r.mergeResult; + }); + } + throw new MergeNotSupportedError(); + } + } + }, + /** + * @param {TreeEntry} [parent] + * @param {Array} children + */ + reduce: unmergedFiles.length !== 0 && (!dir || abortOnConflict) ? void 0 : async (parent, children2) => { + const entries = children2.filter(Boolean); + if (!parent) + return; + if (parent && parent.type === "tree" && entries.length === 0) + return; + if (entries.length > 0) { + const tree = new GitTree(entries); + const object = tree.toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "tree", + object, + dryRun + }); + parent.oid = oid; + } + return parent; + } + }); + if (unmergedFiles.length !== 0) { + if (dir && !abortOnConflict) { + await _walk({ + fs, + cache, + dir, + gitdir, + trees: [TREE({ ref: results.oid })], + map: async function(filepath, [entry]) { + const path2 = `${dir}/${filepath}`; + if (await entry.type() === "blob") { + const mode = await entry.mode(); + const content = new TextDecoder().decode(await entry.content()); + await fs.write(path2, content, { mode }); + } + return true; + } + }); + } + return new MergeConflictError(unmergedFiles); + } + return results.oid; +} +async function mergeBlobs({ + fs, + gitdir, + path: path2, + ours, + base, + theirs, + ourName, + theirName, + baseName, + dryRun, + mergeDriver = mergeFile +}) { + const type = "blob"; + const mode = await base.mode() === await ours.mode() ? await theirs.mode() : await ours.mode(); + if (await ours.oid() === await theirs.oid()) { + return { + cleanMerge: true, + mergeResult: { mode, path: path2, oid: await ours.oid(), type } + }; + } + if (await ours.oid() === await base.oid()) { + return { + cleanMerge: true, + mergeResult: { mode, path: path2, oid: await theirs.oid(), type } + }; + } + if (await theirs.oid() === await base.oid()) { + return { + cleanMerge: true, + mergeResult: { mode, path: path2, oid: await ours.oid(), type } + }; + } + const ourContent = Buffer.from(await ours.content()).toString("utf8"); + const baseContent = Buffer.from(await base.content()).toString("utf8"); + const theirContent = Buffer.from(await theirs.content()).toString("utf8"); + const { mergedText, cleanMerge } = await mergeDriver({ + branches: [baseName, ourName, theirName], + contents: [baseContent, ourContent, theirContent], + path: path2 + }); + const oid = await _writeObject({ + fs, + gitdir, + type: "blob", + object: Buffer.from(mergedText, "utf8"), + dryRun + }); + return { cleanMerge, mergeResult: { mode, path: path2, oid, type } }; +} +async function _merge({ + fs, + cache, + dir, + gitdir, + ours, + theirs, + fastForward: fastForward2 = true, + fastForwardOnly = false, + dryRun = false, + noUpdateBranch = false, + abortOnConflict = true, + message, + author, + committer, + signingKey, + onSign, + mergeDriver +}) { + if (ours === void 0) { + ours = await _currentBranch({ fs, gitdir, fullname: true }); + } + ours = await GitRefManager.expand({ + fs, + gitdir, + ref: ours + }); + theirs = await GitRefManager.expand({ + fs, + gitdir, + ref: theirs + }); + const ourOid = await GitRefManager.resolve({ + fs, + gitdir, + ref: ours + }); + const theirOid = await GitRefManager.resolve({ + fs, + gitdir, + ref: theirs + }); + const baseOids = await _findMergeBase({ + fs, + cache, + gitdir, + oids: [ourOid, theirOid] + }); + if (baseOids.length !== 1) { + throw new MergeNotSupportedError(); + } + const baseOid = baseOids[0]; + if (baseOid === theirOid) { + return { + oid: ourOid, + alreadyMerged: true + }; + } + if (fastForward2 && baseOid === ourOid) { + if (!dryRun && !noUpdateBranch) { + await GitRefManager.writeRef({ fs, gitdir, ref: ours, value: theirOid }); + } + return { + oid: theirOid, + fastForward: true + }; + } else { + if (fastForwardOnly) { + throw new FastForwardError(); + } + const tree = await GitIndexManager.acquire( + { fs, gitdir, cache, allowUnmerged: false }, + async (index2) => { + return mergeTree({ + fs, + cache, + dir, + gitdir, + index: index2, + ourOid, + theirOid, + baseOid, + ourName: abbreviateRef(ours), + baseName: "base", + theirName: abbreviateRef(theirs), + dryRun, + abortOnConflict, + mergeDriver + }); + } + ); + if (tree instanceof MergeConflictError) + throw tree; + if (!message) { + message = `Merge branch '${abbreviateRef(theirs)}' into ${abbreviateRef( + ours + )}`; + } + const oid = await _commit({ + fs, + cache, + gitdir, + message, + ref: ours, + tree, + parent: [ourOid, theirOid], + author, + committer, + signingKey, + onSign, + dryRun, + noUpdateBranch + }); + return { + oid, + tree, + mergeCommit: true + }; + } +} +async function _pull({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + ref, + url, + remote, + remoteRef, + prune, + pruneTags, + fastForward: fastForward2, + fastForwardOnly, + corsProxy, + singleBranch, + headers, + author, + committer, + signingKey +}) { + try { + if (!ref) { + const head = await _currentBranch({ fs, gitdir }); + if (!head) { + throw new MissingParameterError("ref"); + } + ref = head; + } + const { fetchHead, fetchHeadDescription } = await _fetch({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + corsProxy, + ref, + url, + remote, + remoteRef, + singleBranch, + headers, + prune, + pruneTags + }); + await _merge({ + fs, + cache, + gitdir, + ours: ref, + theirs: fetchHead, + fastForward: fastForward2, + fastForwardOnly, + message: `Merge ${fetchHeadDescription}`, + author, + committer, + signingKey, + dryRun: false, + noUpdateBranch: false + }); + await _checkout({ + fs, + cache, + onProgress, + dir, + gitdir, + ref, + remote, + noCheckout: false + }); + } catch (err) { + err.caller = "git.pull"; + throw err; + } +} +async function fastForward({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + url, + remote, + remoteRef, + corsProxy, + singleBranch, + headers = {}, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + const thisWillNotBeUsed = { + name: "", + email: "", + timestamp: Date.now(), + timezoneOffset: 0 + }; + return await _pull({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + ref, + url, + remote, + remoteRef, + fastForwardOnly: true, + corsProxy, + singleBranch, + headers, + author: thisWillNotBeUsed, + committer: thisWillNotBeUsed + }); + } catch (err) { + err.caller = "git.fastForward"; + throw err; + } +} +async function fetch({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + remote, + remoteRef, + url, + corsProxy, + depth = null, + since = null, + exclude = [], + relative: relative2 = false, + tags = false, + singleBranch = false, + headers = {}, + prune = false, + pruneTags = false, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + return await _fetch({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref, + remote, + remoteRef, + url, + corsProxy, + depth, + since, + exclude, + relative: relative2, + tags, + singleBranch, + headers, + prune, + pruneTags + }); + } catch (err) { + err.caller = "git.fetch"; + throw err; + } +} +async function findMergeBase({ + fs, + dir, + gitdir = join(dir, ".git"), + oids, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oids", oids); + return await _findMergeBase({ + fs: new FileSystem(fs), + cache, + gitdir, + oids + }); + } catch (err) { + err.caller = "git.findMergeBase"; + throw err; + } +} +async function _findRoot({ fs, filepath }) { + if (await fs.exists(join(filepath, ".git"))) { + return filepath; + } else { + const parent = dirname(filepath); + if (parent === filepath) { + throw new NotFoundError(`git root for ${filepath}`); + } + return _findRoot({ fs, filepath: parent }); + } +} +async function findRoot({ fs, filepath }) { + try { + assertParameter("fs", fs); + assertParameter("filepath", filepath); + return await _findRoot({ fs: new FileSystem(fs), filepath }); + } catch (err) { + err.caller = "git.findRoot"; + throw err; + } +} +async function getConfig({ fs, dir, gitdir = join(dir, ".git"), path: path2 }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("path", path2); + return await _getConfig({ + fs: new FileSystem(fs), + gitdir, + path: path2 + }); + } catch (err) { + err.caller = "git.getConfig"; + throw err; + } +} +async function _getConfigAll({ fs, gitdir, path: path2 }) { + const config = await GitConfigManager.get({ fs, gitdir }); + return config.getall(path2); +} +async function getConfigAll({ + fs, + dir, + gitdir = join(dir, ".git"), + path: path2 +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("path", path2); + return await _getConfigAll({ + fs: new FileSystem(fs), + gitdir, + path: path2 + }); + } catch (err) { + err.caller = "git.getConfigAll"; + throw err; + } +} +async function getRemoteInfo({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + url, + headers = {}, + forPush = false +}) { + try { + assertParameter("http", http); + assertParameter("url", url); + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const remote = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + headers, + protocolVersion: 1 + }); + const result = { + capabilities: [...remote.capabilities] + }; + for (const [ref, oid] of remote.refs) { + const parts = ref.split("/"); + const last2 = parts.pop(); + let o = result; + for (const part of parts) { + o[part] = o[part] || {}; + o = o[part]; + } + o[last2] = oid; + } + for (const [symref, ref] of remote.symrefs) { + const parts = symref.split("/"); + const last2 = parts.pop(); + let o = result; + for (const part of parts) { + o[part] = o[part] || {}; + o = o[part]; + } + o[last2] = ref; + } + return result; + } catch (err) { + err.caller = "git.getRemoteInfo"; + throw err; + } +} +function formatInfoRefs(remote, prefix, symrefs, peelTags) { + const refs = []; + for (const [key2, value] of remote.refs) { + if (prefix && !key2.startsWith(prefix)) + continue; + if (key2.endsWith("^{}")) { + if (peelTags) { + const _key = key2.replace("^{}", ""); + const last2 = refs[refs.length - 1]; + const r = last2.ref === _key ? last2 : refs.find((x) => x.ref === _key); + if (r === void 0) { + throw new Error("I did not expect this to happen"); + } + r.peeled = value; + } + continue; + } + const ref = { ref: key2, oid: value }; + if (symrefs) { + if (remote.symrefs.has(key2)) { + ref.target = remote.symrefs.get(key2); + } + } + refs.push(ref); + } + return refs; +} +async function getRemoteInfo2({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + url, + headers = {}, + forPush = false, + protocolVersion = 2 +}) { + try { + assertParameter("http", http); + assertParameter("url", url); + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const remote = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + headers, + protocolVersion + }); + if (remote.protocolVersion === 2) { + return { + protocolVersion: remote.protocolVersion, + capabilities: remote.capabilities2 + }; + } + const capabilities = {}; + for (const cap of remote.capabilities) { + const [key2, value] = cap.split("="); + if (value) { + capabilities[key2] = value; + } else { + capabilities[key2] = true; + } + } + return { + protocolVersion: 1, + capabilities, + refs: formatInfoRefs(remote, void 0, true, true) + }; + } catch (err) { + err.caller = "git.getRemoteInfo2"; + throw err; + } +} +async function hashObject({ + type, + object, + format = "content", + oid = void 0 +}) { + if (format !== "deflated") { + if (format !== "wrapped") { + object = GitObject.wrap({ type, object }); + } + oid = await shasum(object); + } + return { oid, object }; +} +async function hashBlob({ object }) { + try { + assertParameter("object", object); + if (typeof object === "string") { + object = Buffer.from(object, "utf8"); + } else { + object = Buffer.from(object); + } + const type = "blob"; + const { oid, object: _object } = await hashObject({ + type: "blob", + format: "content", + object + }); + return { oid, type, object: new Uint8Array(_object), format: "wrapped" }; + } catch (err) { + err.caller = "git.hashBlob"; + throw err; + } +} +async function _indexPack({ + fs, + cache, + onProgress, + dir, + gitdir, + filepath +}) { + try { + filepath = join(dir, filepath); + const pack = await fs.read(filepath); + const getExternalRefDelta = (oid) => _readObject({ fs, cache, gitdir, oid }); + const idx = await GitPackIndex.fromPack({ + pack, + getExternalRefDelta, + onProgress + }); + await fs.write(filepath.replace(/\.pack$/, ".idx"), await idx.toBuffer()); + return { + oids: [...idx.hashes] + }; + } catch (err) { + err.caller = "git.indexPack"; + throw err; + } +} +async function indexPack({ + fs, + onProgress, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("dir", dir); + assertParameter("gitdir", dir); + assertParameter("filepath", filepath); + return await _indexPack({ + fs: new FileSystem(fs), + cache, + onProgress, + dir, + gitdir, + filepath + }); + } catch (err) { + err.caller = "git.indexPack"; + throw err; + } +} +async function init({ + fs, + bare = false, + dir, + gitdir = bare ? dir : join(dir, ".git"), + defaultBranch = "master" +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + if (!bare) { + assertParameter("dir", dir); + } + return await _init({ + fs: new FileSystem(fs), + bare, + dir, + gitdir, + defaultBranch + }); + } catch (err) { + err.caller = "git.init"; + throw err; + } +} +async function _isDescendent({ + fs, + cache, + gitdir, + oid, + ancestor, + depth +}) { + const shallows = await GitShallowManager.read({ fs, gitdir }); + if (!oid) { + throw new MissingParameterError("oid"); + } + if (!ancestor) { + throw new MissingParameterError("ancestor"); + } + if (oid === ancestor) + return false; + const queue = [oid]; + const visited = /* @__PURE__ */ new Set(); + let searchdepth = 0; + while (queue.length) { + if (searchdepth++ === depth) { + throw new MaxDepthError(depth); + } + const oid2 = queue.shift(); + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid: oid2 + }); + if (type !== "commit") { + throw new ObjectTypeError(oid2, type, "commit"); + } + const commit2 = GitCommit.from(object).parse(); + for (const parent of commit2.parent) { + if (parent === ancestor) + return true; + } + if (!shallows.has(oid2)) { + for (const parent of commit2.parent) { + if (!visited.has(parent)) { + queue.push(parent); + visited.add(parent); + } + } + } + } + return false; +} +async function isDescendent({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + ancestor, + depth = -1, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + assertParameter("ancestor", ancestor); + return await _isDescendent({ + fs: new FileSystem(fs), + cache, + gitdir, + oid, + ancestor, + depth + }); + } catch (err) { + err.caller = "git.isDescendent"; + throw err; + } +} +async function isIgnored({ + fs, + dir, + gitdir = join(dir, ".git"), + filepath +}) { + try { + assertParameter("fs", fs); + assertParameter("dir", dir); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + return GitIgnoreManager.isIgnored({ + fs: new FileSystem(fs), + dir, + gitdir, + filepath + }); + } catch (err) { + err.caller = "git.isIgnored"; + throw err; + } +} +async function listBranches({ + fs, + dir, + gitdir = join(dir, ".git"), + remote +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return GitRefManager.listBranches({ + fs: new FileSystem(fs), + gitdir, + remote + }); + } catch (err) { + err.caller = "git.listBranches"; + throw err; + } +} +async function _listFiles({ fs, gitdir, ref, cache }) { + if (ref) { + const oid = await GitRefManager.resolve({ gitdir, fs, ref }); + const filenames = []; + await accumulateFilesFromOid({ + fs, + cache, + gitdir, + oid, + filenames, + prefix: "" + }); + return filenames; + } else { + return GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + return index2.entries.map((x) => x.path); + }); + } +} +async function accumulateFilesFromOid({ + fs, + cache, + gitdir, + oid, + filenames, + prefix +}) { + const { tree } = await _readTree({ fs, cache, gitdir, oid }); + for (const entry of tree) { + if (entry.type === "tree") { + await accumulateFilesFromOid({ + fs, + cache, + gitdir, + oid: entry.oid, + filenames, + prefix: join(prefix, entry.path) + }); + } else { + filenames.push(join(prefix, entry.path)); + } + } +} +async function listFiles({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return await _listFiles({ + fs: new FileSystem(fs), + cache, + gitdir, + ref + }); + } catch (err) { + err.caller = "git.listFiles"; + throw err; + } +} +async function _listNotes({ fs, cache, gitdir, ref }) { + let parent; + try { + parent = await GitRefManager.resolve({ gitdir, fs, ref }); + } catch (err) { + if (err instanceof NotFoundError) { + return []; + } + } + const result = await _readTree({ + fs, + cache, + gitdir, + oid: parent + }); + const notes = result.tree.map((entry) => ({ + target: entry.path, + note: entry.oid + })); + return notes; +} +async function listNotes({ + fs, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await _listNotes({ + fs: new FileSystem(fs), + cache, + gitdir, + ref + }); + } catch (err) { + err.caller = "git.listNotes"; + throw err; + } +} +async function _listRemotes({ fs, gitdir }) { + const config = await GitConfigManager.get({ fs, gitdir }); + const remoteNames = await config.getSubsections("remote"); + const remotes = Promise.all( + remoteNames.map(async (remote) => { + const url = await config.get(`remote.${remote}.url`); + return { remote, url }; + }) + ); + return remotes; +} +async function listRemotes({ fs, dir, gitdir = join(dir, ".git") }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return await _listRemotes({ + fs: new FileSystem(fs), + gitdir + }); + } catch (err) { + err.caller = "git.listRemotes"; + throw err; + } +} +async function parseListRefsResponse(stream) { + const read = GitPktLine.streamReader(stream); + const refs = []; + let line; + while (true) { + line = await read(); + if (line === true) + break; + if (line === null) + continue; + line = line.toString("utf8").replace(/\n$/, ""); + const [oid, ref, ...attrs] = line.split(" "); + const r = { ref, oid }; + for (const attr2 of attrs) { + const [name, value] = attr2.split(":"); + if (name === "symref-target") { + r.target = value; + } else if (name === "peeled") { + r.peeled = value; + } + } + refs.push(r); + } + return refs; +} +async function writeListRefsRequest({ prefix, symrefs, peelTags }) { + const packstream = []; + packstream.push(GitPktLine.encode("command=ls-refs\n")); + packstream.push(GitPktLine.encode(`agent=${pkg.agent} +`)); + if (peelTags || symrefs || prefix) { + packstream.push(GitPktLine.delim()); + } + if (peelTags) + packstream.push(GitPktLine.encode("peel")); + if (symrefs) + packstream.push(GitPktLine.encode("symrefs")); + if (prefix) + packstream.push(GitPktLine.encode(`ref-prefix ${prefix}`)); + packstream.push(GitPktLine.flush()); + return packstream; +} +async function listServerRefs({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + url, + headers = {}, + forPush = false, + protocolVersion = 2, + prefix, + symrefs, + peelTags +}) { + try { + assertParameter("http", http); + assertParameter("url", url); + const remote = await GitRemoteHTTP.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + headers, + protocolVersion + }); + if (remote.protocolVersion === 1) { + return formatInfoRefs(remote, prefix, symrefs, peelTags); + } + const body = await writeListRefsRequest({ prefix, symrefs, peelTags }); + const res = await GitRemoteHTTP.connect({ + http, + auth: remote.auth, + headers, + corsProxy, + service: forPush ? "git-receive-pack" : "git-upload-pack", + url, + body + }); + return parseListRefsResponse(res.body); + } catch (err) { + err.caller = "git.listServerRefs"; + throw err; + } +} +async function listTags({ fs, dir, gitdir = join(dir, ".git") }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + return GitRefManager.listTags({ fs: new FileSystem(fs), gitdir }); + } catch (err) { + err.caller = "git.listTags"; + throw err; + } +} +async function resolveCommit({ fs, cache, gitdir, oid }) { + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + oid = GitAnnotatedTag.from(object).parse().object; + return resolveCommit({ fs, cache, gitdir, oid }); + } + if (type !== "commit") { + throw new ObjectTypeError(oid, type, "commit"); + } + return { commit: GitCommit.from(object), oid }; +} +async function _readCommit({ fs, cache, gitdir, oid }) { + const { commit: commit2, oid: commitOid } = await resolveCommit({ + fs, + cache, + gitdir, + oid + }); + const result = { + oid: commitOid, + commit: commit2.parse(), + payload: commit2.withoutSignature() + }; + return result; +} +function compareAge(a, b) { + return a.committer.timestamp - b.committer.timestamp; +} +var EMPTY_OID = "e69de29bb2d1d6434b8b29ae775ad8c2e48c5391"; +async function resolveFileIdInTree({ fs, cache, gitdir, oid, fileId }) { + if (fileId === EMPTY_OID) + return; + const _oid = oid; + let filepath; + const result = await resolveTree({ fs, cache, gitdir, oid }); + const tree = result.tree; + if (fileId === result.oid) { + filepath = result.path; + } else { + filepath = await _resolveFileId({ + fs, + cache, + gitdir, + tree, + fileId, + oid: _oid + }); + if (Array.isArray(filepath)) { + if (filepath.length === 0) + filepath = void 0; + else if (filepath.length === 1) + filepath = filepath[0]; + } + } + return filepath; +} +async function _resolveFileId({ + fs, + cache, + gitdir, + tree, + fileId, + oid, + filepaths = [], + parentPath = "" +}) { + const walks = tree.entries().map(function(entry) { + let result; + if (entry.oid === fileId) { + result = join(parentPath, entry.path); + filepaths.push(result); + } else if (entry.type === "tree") { + result = _readObject({ + fs, + cache, + gitdir, + oid: entry.oid + }).then(function({ object }) { + return _resolveFileId({ + fs, + cache, + gitdir, + tree: GitTree.from(object), + fileId, + oid, + filepaths, + parentPath: join(parentPath, entry.path) + }); + }); + } + return result; + }); + await Promise.all(walks); + return filepaths; +} +async function _log({ + fs, + cache, + gitdir, + filepath, + ref, + depth, + since, + force, + follow +}) { + const sinceTimestamp = typeof since === "undefined" ? void 0 : Math.floor(since.valueOf() / 1e3); + const commits = []; + const shallowCommits = await GitShallowManager.read({ fs, gitdir }); + const oid = await GitRefManager.resolve({ fs, gitdir, ref }); + const tips = [await _readCommit({ fs, cache, gitdir, oid })]; + let lastFileOid; + let lastCommit; + let isOk; + function endCommit(commit2) { + if (isOk && filepath) + commits.push(commit2); + } + while (tips.length > 0) { + const commit2 = tips.pop(); + if (sinceTimestamp !== void 0 && commit2.commit.committer.timestamp <= sinceTimestamp) { + break; + } + if (filepath) { + let vFileOid; + try { + vFileOid = await resolveFilepath({ + fs, + cache, + gitdir, + oid: commit2.commit.tree, + filepath + }); + if (lastCommit && lastFileOid !== vFileOid) { + commits.push(lastCommit); + } + lastFileOid = vFileOid; + lastCommit = commit2; + isOk = true; + } catch (e) { + if (e instanceof NotFoundError) { + let found = follow && lastFileOid; + if (found) { + found = await resolveFileIdInTree({ + fs, + cache, + gitdir, + oid: commit2.commit.tree, + fileId: lastFileOid + }); + if (found) { + if (Array.isArray(found)) { + if (lastCommit) { + const lastFound = await resolveFileIdInTree({ + fs, + cache, + gitdir, + oid: lastCommit.commit.tree, + fileId: lastFileOid + }); + if (Array.isArray(lastFound)) { + found = found.filter((p) => lastFound.indexOf(p) === -1); + if (found.length === 1) { + found = found[0]; + filepath = found; + if (lastCommit) + commits.push(lastCommit); + } else { + found = false; + if (lastCommit) + commits.push(lastCommit); + break; + } + } + } + } else { + filepath = found; + if (lastCommit) + commits.push(lastCommit); + } + } + } + if (!found) { + if (isOk && lastFileOid) { + commits.push(lastCommit); + if (!force) + break; + } + if (!force && !follow) + throw e; + } + lastCommit = commit2; + isOk = false; + } else + throw e; + } + } else { + commits.push(commit2); + } + if (depth !== void 0 && commits.length === depth) { + endCommit(commit2); + break; + } + if (!shallowCommits.has(commit2.oid)) { + for (const oid2 of commit2.commit.parent) { + const commit3 = await _readCommit({ fs, cache, gitdir, oid: oid2 }); + if (!tips.map((commit4) => commit4.oid).includes(commit3.oid)) { + tips.push(commit3); + } + } + } + if (tips.length === 0) { + endCommit(commit2); + } + tips.sort((a, b) => compareAge(a.commit, b.commit)); + } + return commits; +} +async function log({ + fs, + dir, + gitdir = join(dir, ".git"), + filepath, + ref = "HEAD", + depth, + since, + // Date + force, + follow, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + return await _log({ + fs: new FileSystem(fs), + cache, + gitdir, + filepath, + ref, + depth, + since, + force, + follow + }); + } catch (err) { + err.caller = "git.log"; + throw err; + } +} +async function merge({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ours, + theirs, + fastForward: fastForward2 = true, + fastForwardOnly = false, + dryRun = false, + noUpdateBranch = false, + abortOnConflict = true, + message, + author: _author, + committer: _committer, + signingKey, + cache = {}, + mergeDriver +}) { + try { + assertParameter("fs", _fs); + if (signingKey) { + assertParameter("onSign", onSign); + } + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author && (!fastForwardOnly || !fastForward2)) { + throw new MissingNameError("author"); + } + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer && (!fastForwardOnly || !fastForward2)) { + throw new MissingNameError("committer"); + } + return await _merge({ + fs, + cache, + dir, + gitdir, + ours, + theirs, + fastForward: fastForward2, + fastForwardOnly, + dryRun, + noUpdateBranch, + abortOnConflict, + message, + author, + committer, + signingKey, + onSign, + mergeDriver + }); + } catch (err) { + err.caller = "git.merge"; + throw err; + } +} +var types = { + commit: 16, + tree: 32, + blob: 48, + tag: 64, + ofs_delta: 96, + ref_delta: 112 +}; +async function _pack({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + oids +}) { + const hash2 = new import_sha1.default(); + const outputStream = []; + function write(chunk, enc) { + const buff = Buffer.from(chunk, enc); + outputStream.push(buff); + hash2.update(buff); + } + async function writeObject2({ stype, object }) { + const type = types[stype]; + let length = object.length; + let multibyte = length > 15 ? 128 : 0; + const lastFour = length & 15; + length = length >>> 4; + let byte = (multibyte | type | lastFour).toString(16); + write(byte, "hex"); + while (multibyte) { + multibyte = length > 127 ? 128 : 0; + byte = multibyte | length & 127; + write(padHex(2, byte), "hex"); + length = length >>> 7; + } + write(Buffer.from(await deflate(object))); + } + write("PACK"); + write("00000002", "hex"); + write(padHex(8, oids.length), "hex"); + for (const oid of oids) { + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + await writeObject2({ write, object, stype: type }); + } + const digest = hash2.digest(); + outputStream.push(digest); + return outputStream; +} +async function _packObjects({ fs, cache, gitdir, oids, write }) { + const buffers = await _pack({ fs, cache, gitdir, oids }); + const packfile = Buffer.from(await collect(buffers)); + const packfileSha = packfile.slice(-20).toString("hex"); + const filename = `pack-${packfileSha}.pack`; + if (write) { + await fs.write(join(gitdir, `objects/pack/${filename}`), packfile); + return { filename }; + } + return { + filename, + packfile: new Uint8Array(packfile) + }; +} +async function packObjects({ + fs, + dir, + gitdir = join(dir, ".git"), + oids, + write = false, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oids", oids); + return await _packObjects({ + fs: new FileSystem(fs), + cache, + gitdir, + oids, + write + }); + } catch (err) { + err.caller = "git.packObjects"; + throw err; + } +} +async function pull({ + fs: _fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + url, + remote, + remoteRef, + prune = false, + pruneTags = false, + fastForward: fastForward2 = true, + fastForwardOnly = false, + corsProxy, + singleBranch, + headers = {}, + author: _author, + committer: _committer, + signingKey, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _pull({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir, + ref, + url, + remote, + remoteRef, + fastForward: fastForward2, + fastForwardOnly, + corsProxy, + singleBranch, + headers, + author, + committer, + signingKey, + prune, + pruneTags + }); + } catch (err) { + err.caller = "git.pull"; + throw err; + } +} +async function listCommitsAndTags({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + start, + finish +}) { + const shallows = await GitShallowManager.read({ fs, gitdir }); + const startingSet = /* @__PURE__ */ new Set(); + const finishingSet = /* @__PURE__ */ new Set(); + for (const ref of start) { + startingSet.add(await GitRefManager.resolve({ fs, gitdir, ref })); + } + for (const ref of finish) { + try { + const oid = await GitRefManager.resolve({ fs, gitdir, ref }); + finishingSet.add(oid); + } catch (err) { + } + } + const visited = /* @__PURE__ */ new Set(); + async function walk2(oid) { + visited.add(oid); + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + const tag2 = GitAnnotatedTag.from(object); + const commit2 = tag2.headers().object; + return walk2(commit2); + } + if (type !== "commit") { + throw new ObjectTypeError(oid, type, "commit"); + } + if (!shallows.has(oid)) { + const commit2 = GitCommit.from(object); + const parents = commit2.headers().parent; + for (oid of parents) { + if (!finishingSet.has(oid) && !visited.has(oid)) { + await walk2(oid); + } + } + } + } + for (const oid of startingSet) { + await walk2(oid); + } + return visited; +} +async function listObjects({ + fs, + cache, + dir, + gitdir = join(dir, ".git"), + oids +}) { + const visited = /* @__PURE__ */ new Set(); + async function walk2(oid) { + if (visited.has(oid)) + return; + visited.add(oid); + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + const tag2 = GitAnnotatedTag.from(object); + const obj = tag2.headers().object; + await walk2(obj); + } else if (type === "commit") { + const commit2 = GitCommit.from(object); + const tree = commit2.headers().tree; + await walk2(tree); + } else if (type === "tree") { + const tree = GitTree.from(object); + for (const entry of tree) { + if (entry.type === "blob") { + visited.add(entry.oid); + } + if (entry.type === "tree") { + await walk2(entry.oid); + } + } + } + } + for (const oid of oids) { + await walk2(oid); + } + return visited; +} +async function parseReceivePackResponse(packfile) { + const result = {}; + let response = ""; + const read = GitPktLine.streamReader(packfile); + let line = await read(); + while (line !== true) { + if (line !== null) + response += line.toString("utf8") + "\n"; + line = await read(); + } + const lines = response.toString("utf8").split("\n"); + line = lines.shift(); + if (!line.startsWith("unpack ")) { + throw new ParseError('unpack ok" or "unpack [error message]', line); + } + result.ok = line === "unpack ok"; + if (!result.ok) { + result.error = line.slice("unpack ".length); + } + result.refs = {}; + for (const line2 of lines) { + if (line2.trim() === "") + continue; + const status2 = line2.slice(0, 2); + const refAndMessage = line2.slice(3); + let space2 = refAndMessage.indexOf(" "); + if (space2 === -1) + space2 = refAndMessage.length; + const ref = refAndMessage.slice(0, space2); + const error = refAndMessage.slice(space2 + 1); + result.refs[ref] = { + ok: status2 === "ok", + error + }; + } + return result; +} +async function writeReceivePackRequest({ + capabilities = [], + triplets = [] +}) { + const packstream = []; + let capsFirstLine = `\0 ${capabilities.join(" ")}`; + for (const trip of triplets) { + packstream.push( + GitPktLine.encode( + `${trip.oldoid} ${trip.oid} ${trip.fullRef}${capsFirstLine} +` + ) + ); + capsFirstLine = ""; + } + packstream.push(GitPktLine.flush()); + return packstream; +} +async function _push({ + fs, + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref: _ref, + remoteRef: _remoteRef, + remote, + url: _url, + force = false, + delete: _delete = false, + corsProxy, + headers = {} +}) { + const ref = _ref || await _currentBranch({ fs, gitdir }); + if (typeof ref === "undefined") { + throw new MissingParameterError("ref"); + } + const config = await GitConfigManager.get({ fs, gitdir }); + remote = remote || await config.get(`branch.${ref}.pushRemote`) || await config.get("remote.pushDefault") || await config.get(`branch.${ref}.remote`) || "origin"; + const url = _url || await config.get(`remote.${remote}.pushurl`) || await config.get(`remote.${remote}.url`); + if (typeof url === "undefined") { + throw new MissingParameterError("remote OR url"); + } + const remoteRef = _remoteRef || await config.get(`branch.${ref}.merge`); + if (typeof url === "undefined") { + throw new MissingParameterError("remoteRef"); + } + if (corsProxy === void 0) { + corsProxy = await config.get("http.corsProxy"); + } + const fullRef = await GitRefManager.expand({ fs, gitdir, ref }); + const oid = _delete ? "0000000000000000000000000000000000000000" : await GitRefManager.resolve({ fs, gitdir, ref: fullRef }); + const GitRemoteHTTP2 = GitRemoteManager.getRemoteHelperFor({ url }); + const httpRemote = await GitRemoteHTTP2.discover({ + http, + onAuth, + onAuthSuccess, + onAuthFailure, + corsProxy, + service: "git-receive-pack", + url, + headers, + protocolVersion: 1 + }); + const auth = httpRemote.auth; + let fullRemoteRef; + if (!remoteRef) { + fullRemoteRef = fullRef; + } else { + try { + fullRemoteRef = await GitRefManager.expandAgainstMap({ + ref: remoteRef, + map: httpRemote.refs + }); + } catch (err) { + if (err instanceof NotFoundError) { + fullRemoteRef = remoteRef.startsWith("refs/") ? remoteRef : `refs/heads/${remoteRef}`; + } else { + throw err; + } + } + } + const oldoid = httpRemote.refs.get(fullRemoteRef) || "0000000000000000000000000000000000000000"; + const thinPack = !httpRemote.capabilities.has("no-thin"); + let objects = /* @__PURE__ */ new Set(); + if (!_delete) { + const finish = [...httpRemote.refs.values()]; + let skipObjects = /* @__PURE__ */ new Set(); + if (oldoid !== "0000000000000000000000000000000000000000") { + const mergebase = await _findMergeBase({ + fs, + cache, + gitdir, + oids: [oid, oldoid] + }); + for (const oid2 of mergebase) + finish.push(oid2); + if (thinPack) { + skipObjects = await listObjects({ fs, cache, gitdir, oids: mergebase }); + } + } + if (!finish.includes(oid)) { + const commits = await listCommitsAndTags({ + fs, + cache, + gitdir, + start: [oid], + finish + }); + objects = await listObjects({ fs, cache, gitdir, oids: commits }); + } + if (thinPack) { + try { + const ref2 = await GitRefManager.resolve({ + fs, + gitdir, + ref: `refs/remotes/${remote}/HEAD`, + depth: 2 + }); + const { oid: oid2 } = await GitRefManager.resolveAgainstMap({ + ref: ref2.replace(`refs/remotes/${remote}/`, ""), + fullref: ref2, + map: httpRemote.refs + }); + const oids = [oid2]; + for (const oid3 of await listObjects({ fs, cache, gitdir, oids })) { + skipObjects.add(oid3); + } + } catch (e) { + } + for (const oid2 of skipObjects) { + objects.delete(oid2); + } + } + if (oid === oldoid) + force = true; + if (!force) { + if (fullRef.startsWith("refs/tags") && oldoid !== "0000000000000000000000000000000000000000") { + throw new PushRejectedError("tag-exists"); + } + if (oid !== "0000000000000000000000000000000000000000" && oldoid !== "0000000000000000000000000000000000000000" && !await _isDescendent({ + fs, + cache, + gitdir, + oid, + ancestor: oldoid, + depth: -1 + })) { + throw new PushRejectedError("not-fast-forward"); + } + } + } + const capabilities = filterCapabilities( + [...httpRemote.capabilities], + ["report-status", "side-band-64k", `agent=${pkg.agent}`] + ); + const packstream1 = await writeReceivePackRequest({ + capabilities, + triplets: [{ oldoid, oid, fullRef: fullRemoteRef }] + }); + const packstream2 = _delete ? [] : await _pack({ + fs, + cache, + gitdir, + oids: [...objects] + }); + const res = await GitRemoteHTTP2.connect({ + http, + onProgress, + corsProxy, + service: "git-receive-pack", + url, + auth, + headers, + body: [...packstream1, ...packstream2] + }); + const { packfile, progress } = await GitSideBand.demux(res.body); + if (onMessage) { + const lines = splitLines(progress); + forAwait(lines, async (line) => { + await onMessage(line); + }); + } + const result = await parseReceivePackResponse(packfile); + if (res.headers) { + result.headers = res.headers; + } + if (remote && result.ok && result.refs[fullRemoteRef].ok) { + const ref2 = `refs/remotes/${remote}/${fullRemoteRef.replace( + "refs/heads", + "" + )}`; + if (_delete) { + await GitRefManager.deleteRef({ fs, gitdir, ref: ref2 }); + } else { + await GitRefManager.writeRef({ fs, gitdir, ref: ref2, value: oid }); + } + } + if (result.ok && Object.values(result.refs).every((result2) => result2.ok)) { + return result; + } else { + const prettyDetails = Object.entries(result.refs).filter(([k, v]) => !v.ok).map(([k, v]) => ` + - ${k}: ${v.error}`).join(""); + throw new GitPushError(prettyDetails, result); + } +} +async function push({ + fs, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + dir, + gitdir = join(dir, ".git"), + ref, + remoteRef, + remote = "origin", + url, + force = false, + delete: _delete = false, + corsProxy, + headers = {}, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("http", http); + assertParameter("gitdir", gitdir); + return await _push({ + fs: new FileSystem(fs), + cache, + http, + onProgress, + onMessage, + onAuth, + onAuthSuccess, + onAuthFailure, + gitdir, + ref, + remoteRef, + remote, + url, + force, + delete: _delete, + corsProxy, + headers + }); + } catch (err) { + err.caller = "git.push"; + throw err; + } +} +async function resolveBlob({ fs, cache, gitdir, oid }) { + const { type, object } = await _readObject({ fs, cache, gitdir, oid }); + if (type === "tag") { + oid = GitAnnotatedTag.from(object).parse().object; + return resolveBlob({ fs, cache, gitdir, oid }); + } + if (type !== "blob") { + throw new ObjectTypeError(oid, type, "blob"); + } + return { oid, blob: new Uint8Array(object) }; +} +async function _readBlob({ + fs, + cache, + gitdir, + oid, + filepath = void 0 +}) { + if (filepath !== void 0) { + oid = await resolveFilepath({ fs, cache, gitdir, oid, filepath }); + } + const blob = await resolveBlob({ + fs, + cache, + gitdir, + oid + }); + return blob; +} +async function readBlob({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + filepath, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readBlob({ + fs: new FileSystem(fs), + cache, + gitdir, + oid, + filepath + }); + } catch (err) { + err.caller = "git.readBlob"; + throw err; + } +} +async function readCommit({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readCommit({ + fs: new FileSystem(fs), + cache, + gitdir, + oid + }); + } catch (err) { + err.caller = "git.readCommit"; + throw err; + } +} +async function _readNote({ + fs, + cache, + gitdir, + ref = "refs/notes/commits", + oid +}) { + const parent = await GitRefManager.resolve({ gitdir, fs, ref }); + const { blob } = await _readBlob({ + fs, + cache, + gitdir, + oid: parent, + filepath: oid + }); + return blob; +} +async function readNote({ + fs, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + assertParameter("oid", oid); + return await _readNote({ + fs: new FileSystem(fs), + cache, + gitdir, + ref, + oid + }); + } catch (err) { + err.caller = "git.readNote"; + throw err; + } +} +async function readObject({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + oid, + format = "parsed", + filepath = void 0, + encoding = void 0, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + const fs = new FileSystem(_fs); + if (filepath !== void 0) { + oid = await resolveFilepath({ + fs, + cache, + gitdir, + oid, + filepath + }); + } + const _format = format === "parsed" ? "content" : format; + const result = await _readObject({ + fs, + cache, + gitdir, + oid, + format: _format + }); + result.oid = oid; + if (format === "parsed") { + result.format = "parsed"; + switch (result.type) { + case "commit": + result.object = GitCommit.from(result.object).parse(); + break; + case "tree": + result.object = GitTree.from(result.object).entries(); + break; + case "blob": + if (encoding) { + result.object = result.object.toString(encoding); + } else { + result.object = new Uint8Array(result.object); + result.format = "content"; + } + break; + case "tag": + result.object = GitAnnotatedTag.from(result.object).parse(); + break; + default: + throw new ObjectTypeError( + result.oid, + result.type, + "blob|commit|tag|tree" + ); + } + } else if (result.format === "deflated" || result.format === "wrapped") { + result.type = result.format; + } + return result; + } catch (err) { + err.caller = "git.readObject"; + throw err; + } +} +async function _readTag({ fs, cache, gitdir, oid }) { + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid, + format: "content" + }); + if (type !== "tag") { + throw new ObjectTypeError(oid, type, "tag"); + } + const tag2 = GitAnnotatedTag.from(object); + const result = { + oid, + tag: tag2.parse(), + payload: tag2.payload() + }; + return result; +} +async function readTag({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readTag({ + fs: new FileSystem(fs), + cache, + gitdir, + oid + }); + } catch (err) { + err.caller = "git.readTag"; + throw err; + } +} +async function readTree({ + fs, + dir, + gitdir = join(dir, ".git"), + oid, + filepath = void 0, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + return await _readTree({ + fs: new FileSystem(fs), + cache, + gitdir, + oid, + filepath + }); + } catch (err) { + err.caller = "git.readTree"; + throw err; + } +} +async function remove({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + await GitIndexManager.acquire( + { fs: new FileSystem(_fs), gitdir, cache }, + async function(index2) { + index2.delete({ filepath }); + } + ); + } catch (err) { + err.caller = "git.remove"; + throw err; + } +} +async function _removeNote({ + fs, + cache, + onSign, + gitdir, + ref = "refs/notes/commits", + oid, + author, + committer, + signingKey +}) { + let parent; + try { + parent = await GitRefManager.resolve({ gitdir, fs, ref }); + } catch (err) { + if (!(err instanceof NotFoundError)) { + throw err; + } + } + const result = await _readTree({ + fs, + gitdir, + oid: parent || "4b825dc642cb6eb9a060e54bf8d69288fbee4904" + }); + let tree = result.tree; + tree = tree.filter((entry) => entry.path !== oid); + const treeOid = await _writeTree({ + fs, + gitdir, + tree + }); + const commitOid = await _commit({ + fs, + cache, + onSign, + gitdir, + ref, + tree: treeOid, + parent: parent && [parent], + message: `Note removed by 'isomorphic-git removeNote' +`, + author, + committer, + signingKey + }); + return commitOid; +} +async function removeNote({ + fs: _fs, + onSign, + dir, + gitdir = join(dir, ".git"), + ref = "refs/notes/commits", + oid, + author: _author, + committer: _committer, + signingKey, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("oid", oid); + const fs = new FileSystem(_fs); + const author = await normalizeAuthorObject({ fs, gitdir, author: _author }); + if (!author) + throw new MissingNameError("author"); + const committer = await normalizeCommitterObject({ + fs, + gitdir, + author, + committer: _committer + }); + if (!committer) + throw new MissingNameError("committer"); + return await _removeNote({ + fs, + cache, + onSign, + gitdir, + ref, + oid, + author, + committer, + signingKey + }); + } catch (err) { + err.caller = "git.removeNote"; + throw err; + } +} +async function _renameBranch({ + fs, + gitdir, + oldref, + ref, + checkout: checkout2 = false +}) { + if (ref !== import_clean_git_ref.default.clean(ref)) { + throw new InvalidRefNameError(ref, import_clean_git_ref.default.clean(ref)); + } + if (oldref !== import_clean_git_ref.default.clean(oldref)) { + throw new InvalidRefNameError(oldref, import_clean_git_ref.default.clean(oldref)); + } + const fulloldref = `refs/heads/${oldref}`; + const fullnewref = `refs/heads/${ref}`; + const newexist = await GitRefManager.exists({ fs, gitdir, ref: fullnewref }); + if (newexist) { + throw new AlreadyExistsError("branch", ref, false); + } + const value = await GitRefManager.resolve({ + fs, + gitdir, + ref: fulloldref, + depth: 1 + }); + await GitRefManager.writeRef({ fs, gitdir, ref: fullnewref, value }); + await GitRefManager.deleteRef({ fs, gitdir, ref: fulloldref }); + const fullCurrentBranchRef = await _currentBranch({ + fs, + gitdir, + fullname: true + }); + const isCurrentBranch = fullCurrentBranchRef === fulloldref; + if (checkout2 || isCurrentBranch) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref: "HEAD", + value: fullnewref + }); + } +} +async function renameBranch({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + oldref, + checkout: checkout2 = false +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + assertParameter("oldref", oldref); + return await _renameBranch({ + fs: new FileSystem(fs), + gitdir, + ref, + oldref, + checkout: checkout2 + }); + } catch (err) { + err.caller = "git.renameBranch"; + throw err; + } +} +async function hashObject$1({ gitdir, type, object }) { + return shasum(GitObject.wrap({ type, object })); +} +async function resetIndex({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + ref, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + let oid; + let workdirOid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref: ref || "HEAD" }); + } catch (e) { + if (ref) { + throw e; + } + } + if (oid) { + try { + oid = await resolveFilepath({ + fs, + cache, + gitdir, + oid, + filepath + }); + } catch (e) { + oid = null; + } + } + let stats = { + ctime: /* @__PURE__ */ new Date(0), + mtime: /* @__PURE__ */ new Date(0), + dev: 0, + ino: 0, + mode: 0, + uid: 0, + gid: 0, + size: 0 + }; + const object = dir && await fs.read(join(dir, filepath)); + if (object) { + workdirOid = await hashObject$1({ + gitdir, + type: "blob", + object + }); + if (oid === workdirOid) { + stats = await fs.lstat(join(dir, filepath)); + } + } + await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + index2.delete({ filepath }); + if (oid) { + index2.insert({ filepath, stats, oid }); + } + }); + } catch (err) { + err.caller = "git.reset"; + throw err; + } +} +async function resolveRef({ + fs, + dir, + gitdir = join(dir, ".git"), + ref, + depth +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + const oid = await GitRefManager.resolve({ + fs: new FileSystem(fs), + gitdir, + ref, + depth + }); + return oid; + } catch (err) { + err.caller = "git.resolveRef"; + throw err; + } +} +async function setConfig({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + path: path2, + value, + append: append3 = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("path", path2); + const fs = new FileSystem(_fs); + const config = await GitConfigManager.get({ fs, gitdir }); + if (append3) { + await config.append(path2, value); + } else { + await config.set(path2, value); + } + await GitConfigManager.save({ fs, gitdir, config }); + } catch (err) { + err.caller = "git.setConfig"; + throw err; + } +} +async function status({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + filepath, + cache = {} +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + const ignored = await GitIgnoreManager.isIgnored({ + fs, + gitdir, + dir, + filepath + }); + if (ignored) { + return "ignored"; + } + const headTree = await getHeadTree({ fs, cache, gitdir }); + const treeOid = await getOidAtPath({ + fs, + cache, + gitdir, + tree: headTree, + path: filepath + }); + const indexEntry = await GitIndexManager.acquire( + { fs, gitdir, cache }, + async function(index2) { + for (const entry of index2) { + if (entry.path === filepath) + return entry; + } + return null; + } + ); + const stats = await fs.lstat(join(dir, filepath)); + const H = treeOid !== null; + const I = indexEntry !== null; + const W = stats !== null; + const getWorkdirOid = async () => { + if (I && !compareStats(indexEntry, stats)) { + return indexEntry.oid; + } else { + const object = await fs.read(join(dir, filepath)); + const workdirOid = await hashObject$1({ + gitdir, + type: "blob", + object + }); + if (I && indexEntry.oid === workdirOid) { + if (stats.size !== -1) { + GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + index2.insert({ filepath, stats, oid: workdirOid }); + }); + } + } + return workdirOid; + } + }; + if (!H && !W && !I) + return "absent"; + if (!H && !W && I) + return "*absent"; + if (!H && W && !I) + return "*added"; + if (!H && W && I) { + const workdirOid = await getWorkdirOid(); + return workdirOid === indexEntry.oid ? "added" : "*added"; + } + if (H && !W && !I) + return "deleted"; + if (H && !W && I) { + return treeOid === indexEntry.oid ? "*deleted" : "*deleted"; + } + if (H && W && !I) { + const workdirOid = await getWorkdirOid(); + return workdirOid === treeOid ? "*undeleted" : "*undeletemodified"; + } + if (H && W && I) { + const workdirOid = await getWorkdirOid(); + if (workdirOid === treeOid) { + return workdirOid === indexEntry.oid ? "unmodified" : "*unmodified"; + } else { + return workdirOid === indexEntry.oid ? "modified" : "*modified"; + } + } + } catch (err) { + err.caller = "git.status"; + throw err; + } +} +async function getOidAtPath({ fs, cache, gitdir, tree, path: path2 }) { + if (typeof path2 === "string") + path2 = path2.split("/"); + const dirname3 = path2.shift(); + for (const entry of tree) { + if (entry.path === dirname3) { + if (path2.length === 0) { + return entry.oid; + } + const { type, object } = await _readObject({ + fs, + cache, + gitdir, + oid: entry.oid + }); + if (type === "tree") { + const tree2 = GitTree.from(object); + return getOidAtPath({ fs, cache, gitdir, tree: tree2, path: path2 }); + } + if (type === "blob") { + throw new ObjectTypeError(entry.oid, type, "blob", path2.join("/")); + } + } + } + return null; +} +async function getHeadTree({ fs, cache, gitdir }) { + let oid; + try { + oid = await GitRefManager.resolve({ fs, gitdir, ref: "HEAD" }); + } catch (e) { + if (e instanceof NotFoundError) { + return []; + } + } + const { tree } = await _readTree({ fs, cache, gitdir, oid }); + return tree; +} +async function statusMatrix({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + ref = "HEAD", + filepaths = ["."], + filter, + cache = {}, + ignored: shouldIgnore = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + const fs = new FileSystem(_fs); + return await _walk({ + fs, + cache, + dir, + gitdir, + trees: [TREE({ ref }), WORKDIR(), STAGE()], + map: async function(filepath, [head, workdir, stage]) { + if (!head && !stage && workdir) { + if (!shouldIgnore) { + const isIgnored2 = await GitIgnoreManager.isIgnored({ + fs, + dir, + filepath + }); + if (isIgnored2) { + return null; + } + } + } + if (!filepaths.some((base) => worthWalking(filepath, base))) { + return null; + } + if (filter) { + if (!filter(filepath)) + return; + } + const [headType, workdirType, stageType] = await Promise.all([ + head && head.type(), + workdir && workdir.type(), + stage && stage.type() + ]); + const isBlob = [headType, workdirType, stageType].includes("blob"); + if ((headType === "tree" || headType === "special") && !isBlob) + return; + if (headType === "commit") + return null; + if ((workdirType === "tree" || workdirType === "special") && !isBlob) + return; + if (stageType === "commit") + return null; + if ((stageType === "tree" || stageType === "special") && !isBlob) + return; + const headOid = headType === "blob" ? await head.oid() : void 0; + const stageOid = stageType === "blob" ? await stage.oid() : void 0; + let workdirOid; + if (headType !== "blob" && workdirType === "blob" && stageType !== "blob") { + workdirOid = "42"; + } else if (workdirType === "blob") { + workdirOid = await workdir.oid(); + } + const entry = [void 0, headOid, workdirOid, stageOid]; + const result = entry.map((value) => entry.indexOf(value)); + result.shift(); + return [filepath, ...result]; + } + }); + } catch (err) { + err.caller = "git.statusMatrix"; + throw err; + } +} +async function tag({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + ref, + object, + force = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + const fs = new FileSystem(_fs); + if (ref === void 0) { + throw new MissingParameterError("ref"); + } + ref = ref.startsWith("refs/tags/") ? ref : `refs/tags/${ref}`; + const value = await GitRefManager.resolve({ + fs, + gitdir, + ref: object || "HEAD" + }); + if (!force && await GitRefManager.exists({ fs, gitdir, ref })) { + throw new AlreadyExistsError("tag", ref); + } + await GitRefManager.writeRef({ fs, gitdir, ref, value }); + } catch (err) { + err.caller = "git.tag"; + throw err; + } +} +async function updateIndex({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + cache = {}, + filepath, + oid, + mode, + add: add2, + remove: remove3, + force +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("filepath", filepath); + const fs = new FileSystem(_fs); + if (remove3) { + return await GitIndexManager.acquire( + { fs, gitdir, cache }, + async function(index2) { + let fileStats2; + if (!force) { + fileStats2 = await fs.lstat(join(dir, filepath)); + if (fileStats2) { + if (fileStats2.isDirectory()) { + throw new InvalidFilepathError("directory"); + } + return; + } + } + if (index2.has({ filepath })) { + index2.delete({ + filepath + }); + } + } + ); + } + let fileStats; + if (!oid) { + fileStats = await fs.lstat(join(dir, filepath)); + if (!fileStats) { + throw new NotFoundError( + `file at "${filepath}" on disk and "remove" not set` + ); + } + if (fileStats.isDirectory()) { + throw new InvalidFilepathError("directory"); + } + } + return await GitIndexManager.acquire({ fs, gitdir, cache }, async function(index2) { + if (!add2 && !index2.has({ filepath })) { + throw new NotFoundError( + `file at "${filepath}" in index and "add" not set` + ); + } + let stats = { + ctime: /* @__PURE__ */ new Date(0), + mtime: /* @__PURE__ */ new Date(0), + dev: 0, + ino: 0, + mode, + uid: 0, + gid: 0, + size: 0 + }; + if (!oid) { + stats = fileStats; + const object = stats.isSymbolicLink() ? await fs.readlink(join(dir, filepath)) : await fs.read(join(dir, filepath)); + oid = await _writeObject({ + fs, + gitdir, + type: "blob", + format: "content", + object + }); + } + index2.insert({ + filepath, + oid, + stats + }); + return oid; + }); + } catch (err) { + err.caller = "git.updateIndex"; + throw err; + } +} +function version() { + try { + return pkg.version; + } catch (err) { + err.caller = "git.version"; + throw err; + } +} +async function walk({ + fs, + dir, + gitdir = join(dir, ".git"), + trees, + map, + reduce, + iterate, + cache = {} +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("trees", trees); + return await _walk({ + fs: new FileSystem(fs), + cache, + dir, + gitdir, + trees, + map, + reduce, + iterate + }); + } catch (err) { + err.caller = "git.walk"; + throw err; + } +} +async function writeBlob({ fs, dir, gitdir = join(dir, ".git"), blob }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("blob", blob); + return await _writeObject({ + fs: new FileSystem(fs), + gitdir, + type: "blob", + object: blob, + format: "content" + }); + } catch (err) { + err.caller = "git.writeBlob"; + throw err; + } +} +async function _writeCommit({ fs, gitdir, commit: commit2 }) { + const object = GitCommit.from(commit2).toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "commit", + object, + format: "content" + }); + return oid; +} +async function writeCommit({ + fs, + dir, + gitdir = join(dir, ".git"), + commit: commit2 +}) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("commit", commit2); + return await _writeCommit({ + fs: new FileSystem(fs), + gitdir, + commit: commit2 + }); + } catch (err) { + err.caller = "git.writeCommit"; + throw err; + } +} +async function writeObject({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + type, + object, + format = "parsed", + oid, + encoding = void 0 +}) { + try { + const fs = new FileSystem(_fs); + if (format === "parsed") { + switch (type) { + case "commit": + object = GitCommit.from(object).toObject(); + break; + case "tree": + object = GitTree.from(object).toObject(); + break; + case "blob": + object = Buffer.from(object, encoding); + break; + case "tag": + object = GitAnnotatedTag.from(object).toObject(); + break; + default: + throw new ObjectTypeError(oid || "", type, "blob|commit|tag|tree"); + } + format = "content"; + } + oid = await _writeObject({ + fs, + gitdir, + type, + object, + oid, + format + }); + return oid; + } catch (err) { + err.caller = "git.writeObject"; + throw err; + } +} +async function writeRef({ + fs: _fs, + dir, + gitdir = join(dir, ".git"), + ref, + value, + force = false, + symbolic = false +}) { + try { + assertParameter("fs", _fs); + assertParameter("gitdir", gitdir); + assertParameter("ref", ref); + assertParameter("value", value); + const fs = new FileSystem(_fs); + if (ref !== import_clean_git_ref.default.clean(ref)) { + throw new InvalidRefNameError(ref, import_clean_git_ref.default.clean(ref)); + } + if (!force && await GitRefManager.exists({ fs, gitdir, ref })) { + throw new AlreadyExistsError("ref", ref); + } + if (symbolic) { + await GitRefManager.writeSymbolicRef({ + fs, + gitdir, + ref, + value + }); + } else { + value = await GitRefManager.resolve({ + fs, + gitdir, + ref: value + }); + await GitRefManager.writeRef({ + fs, + gitdir, + ref, + value + }); + } + } catch (err) { + err.caller = "git.writeRef"; + throw err; + } +} +async function _writeTag({ fs, gitdir, tag: tag2 }) { + const object = GitAnnotatedTag.from(tag2).toObject(); + const oid = await _writeObject({ + fs, + gitdir, + type: "tag", + object, + format: "content" + }); + return oid; +} +async function writeTag({ fs, dir, gitdir = join(dir, ".git"), tag: tag2 }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("tag", tag2); + return await _writeTag({ + fs: new FileSystem(fs), + gitdir, + tag: tag2 + }); + } catch (err) { + err.caller = "git.writeTag"; + throw err; + } +} +async function writeTree({ fs, dir, gitdir = join(dir, ".git"), tree }) { + try { + assertParameter("fs", fs); + assertParameter("gitdir", gitdir); + assertParameter("tree", tree); + return await _writeTree({ + fs: new FileSystem(fs), + gitdir, + tree + }); + } catch (err) { + err.caller = "git.writeTree"; + throw err; + } +} +var index = { + Errors, + STAGE, + TREE, + WORKDIR, + add, + abortMerge, + addNote, + addRemote, + annotatedTag, + branch, + checkout, + clone, + commit, + getConfig, + getConfigAll, + setConfig, + currentBranch, + deleteBranch, + deleteRef, + deleteRemote, + deleteTag, + expandOid, + expandRef, + fastForward, + fetch, + findMergeBase, + findRoot, + getRemoteInfo, + getRemoteInfo2, + hashBlob, + indexPack, + init, + isDescendent, + isIgnored, + listBranches, + listFiles, + listNotes, + listRemotes, + listServerRefs, + listTags, + log, + merge, + packObjects, + pull, + push, + readBlob, + readCommit, + readNote, + readObject, + readTag, + readTree, + remove, + removeNote, + renameBranch, + resetIndex, + updateIndex, + resolveRef, + status, + statusMatrix, + tag, + version, + walk, + writeBlob, + writeCommit, + writeObject, + writeRef, + writeTag, + writeTree +}; +var isomorphic_git_default = index; + +// src/main.ts +var import_obsidian30 = require("obsidian"); + +// src/lineAuthor/lineAuthorIntegration.ts +init_polyfill_buffer(); +var import_obsidian12 = require("obsidian"); + +// src/gitManager/simpleGit.ts +init_polyfill_buffer(); +var import_child_process2 = require("child_process"); +var import_debug2 = __toESM(require_browser()); +var import_obsidian4 = require("obsidian"); +var path = __toESM(require("path")); +var import_path = require("path"); + +// node_modules/.pnpm/github.com+Vinzent03+git-js@6b9a2d899bc8256e38a1d6f0b8a88116ba2bf56a_supports-color@9.4.0_rdkutdaeyye3o67thmklazfzta/node_modules/simple-git/dist/esm/index.js +init_polyfill_buffer(); +var import_file_exists = __toESM(require_dist(), 1); +var import_debug = __toESM(require_browser(), 1); +var import_child_process = require("child_process"); +var import_promise_deferred = __toESM(require_dist2(), 1); +var import_promise_deferred2 = __toESM(require_dist2(), 1); +var __defProp2 = Object.defineProperty; +var __defProps = Object.defineProperties; +var __getOwnPropDesc2 = Object.getOwnPropertyDescriptor; +var __getOwnPropDescs = Object.getOwnPropertyDescriptors; +var __getOwnPropNames2 = Object.getOwnPropertyNames; +var __getOwnPropSymbols = Object.getOwnPropertySymbols; +var __hasOwnProp2 = Object.prototype.hasOwnProperty; +var __propIsEnum = Object.prototype.propertyIsEnumerable; +var __defNormalProp2 = (obj, key2, value) => key2 in obj ? __defProp2(obj, key2, { enumerable: true, configurable: true, writable: true, value }) : obj[key2] = value; +var __spreadValues = (a, b) => { + for (var prop in b || (b = {})) + if (__hasOwnProp2.call(b, prop)) + __defNormalProp2(a, prop, b[prop]); + if (__getOwnPropSymbols) + for (var prop of __getOwnPropSymbols(b)) { + if (__propIsEnum.call(b, prop)) + __defNormalProp2(a, prop, b[prop]); + } + return a; +}; +var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b)); +var __markAsModule = (target) => __defProp2(target, "__esModule", { value: true }); +var __esm2 = (fn, res) => function __init() { + return fn && (res = (0, fn[__getOwnPropNames2(fn)[0]])(fn = 0)), res; +}; +var __commonJS2 = (cb, mod) => function __require() { + return mod || (0, cb[__getOwnPropNames2(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports; +}; +var __export2 = (target, all) => { + for (var name in all) + __defProp2(target, name, { get: all[name], enumerable: true }); +}; +var __reExport = (target, module2, copyDefault, desc) => { + if (module2 && typeof module2 === "object" || typeof module2 === "function") { + for (let key2 of __getOwnPropNames2(module2)) + if (!__hasOwnProp2.call(target, key2) && (copyDefault || key2 !== "default")) + __defProp2(target, key2, { get: () => module2[key2], enumerable: !(desc = __getOwnPropDesc2(module2, key2)) || desc.enumerable }); + } + return target; +}; +var __toCommonJS2 = /* @__PURE__ */ ((cache) => { + return (module2, temp) => { + return cache && cache.get(module2) || (temp = __reExport(__markAsModule({}), module2, 1), cache && cache.set(module2, temp), temp); + }; +})(typeof WeakMap !== "undefined" ? /* @__PURE__ */ new WeakMap() : 0); +var __async = (__this, __arguments, generator) => { + return new Promise((resolve, reject) => { + var fulfilled = (value) => { + try { + step(generator.next(value)); + } catch (e) { + reject(e); + } + }; + var rejected = (value) => { + try { + step(generator.throw(value)); + } catch (e) { + reject(e); + } + }; + var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected); + step((generator = generator.apply(__this, __arguments)).next()); + }); +}; +var GitError; +var init_git_error = __esm2({ + "src/lib/errors/git-error.ts"() { + GitError = class extends Error { + constructor(task, message) { + super(message); + this.task = task; + Object.setPrototypeOf(this, new.target.prototype); + } + }; + } +}); +var GitResponseError; +var init_git_response_error = __esm2({ + "src/lib/errors/git-response-error.ts"() { + init_git_error(); + GitResponseError = class extends GitError { + constructor(git, message) { + super(void 0, message || String(git)); + this.git = git; + } + }; + } +}); +var TaskConfigurationError; +var init_task_configuration_error = __esm2({ + "src/lib/errors/task-configuration-error.ts"() { + init_git_error(); + TaskConfigurationError = class extends GitError { + constructor(message) { + super(void 0, message); + } + }; + } +}); +function asFunction(source) { + return typeof source === "function" ? source : NOOP; +} +function isUserFunction(source) { + return typeof source === "function" && source !== NOOP; +} +function splitOn(input, char) { + const index2 = input.indexOf(char); + if (index2 <= 0) { + return [input, ""]; + } + return [input.substr(0, index2), input.substr(index2 + 1)]; +} +function first(input, offset = 0) { + return isArrayLike(input) && input.length > offset ? input[offset] : void 0; +} +function last(input, offset = 0) { + if (isArrayLike(input) && input.length > offset) { + return input[input.length - 1 - offset]; + } +} +function isArrayLike(input) { + return !!(input && typeof input.length === "number"); +} +function toLinesWithContent(input = "", trimmed2 = true, separator2 = "\n") { + return input.split(separator2).reduce((output, line) => { + const lineContent = trimmed2 ? line.trim() : line; + if (lineContent) { + output.push(lineContent); + } + return output; + }, []); +} +function forEachLineWithContent(input, callback) { + return toLinesWithContent(input, true).map((line) => callback(line)); +} +function folderExists(path2) { + return (0, import_file_exists.exists)(path2, import_file_exists.FOLDER); +} +function append(target, item) { + if (Array.isArray(target)) { + if (!target.includes(item)) { + target.push(item); + } + } else { + target.add(item); + } + return item; +} +function including(target, item) { + if (Array.isArray(target) && !target.includes(item)) { + target.push(item); + } + return target; +} +function remove2(target, item) { + if (Array.isArray(target)) { + const index2 = target.indexOf(item); + if (index2 >= 0) { + target.splice(index2, 1); + } + } else { + target.delete(item); + } + return item; +} +function asArray(source) { + return Array.isArray(source) ? source : [source]; +} +function asStringArray(source) { + return asArray(source).map(String); +} +function asNumber(source, onNaN = 0) { + if (source == null) { + return onNaN; + } + const num2 = parseInt(source, 10); + return isNaN(num2) ? onNaN : num2; +} +function prefixedArray(input, prefix) { + const output = []; + for (let i = 0, max = input.length; i < max; i++) { + output.push(prefix, input[i]); + } + return output; +} +function bufferToString(input) { + return (Array.isArray(input) ? Buffer.concat(input) : input).toString("utf-8"); +} +function pick(source, properties) { + return Object.assign({}, ...properties.map((property) => property in source ? { [property]: source[property] } : {})); +} +function delay(duration = 0) { + return new Promise((done) => setTimeout(done, duration)); +} +var NULL; +var NOOP; +var objectToString; +var init_util = __esm2({ + "src/lib/utils/util.ts"() { + NULL = "\0"; + NOOP = () => { + }; + objectToString = Object.prototype.toString.call.bind(Object.prototype.toString); + } +}); +function filterType(input, filter, def) { + if (filter(input)) { + return input; + } + return arguments.length > 2 ? def : void 0; +} +function filterPrimitives(input, omit) { + return /number|string|boolean/.test(typeof input) && (!omit || !omit.includes(typeof input)); +} +function filterPlainObject(input) { + return !!input && objectToString(input) === "[object Object]"; +} +function filterFunction(input) { + return typeof input === "function"; +} +var filterArray; +var filterString; +var filterStringArray; +var filterStringOrStringArray; +var filterHasLength; +var init_argument_filters = __esm2({ + "src/lib/utils/argument-filters.ts"() { + init_util(); + filterArray = (input) => { + return Array.isArray(input); + }; + filterString = (input) => { + return typeof input === "string"; + }; + filterStringArray = (input) => { + return Array.isArray(input) && input.every(filterString); + }; + filterStringOrStringArray = (input) => { + return filterString(input) || Array.isArray(input) && input.every(filterString); + }; + filterHasLength = (input) => { + if (input == null || "number|boolean|function".includes(typeof input)) { + return false; + } + return Array.isArray(input) || typeof input === "string" || typeof input.length === "number"; + }; + } +}); +var ExitCodes; +var init_exit_codes = __esm2({ + "src/lib/utils/exit-codes.ts"() { + ExitCodes = /* @__PURE__ */ ((ExitCodes2) => { + ExitCodes2[ExitCodes2["SUCCESS"] = 0] = "SUCCESS"; + ExitCodes2[ExitCodes2["ERROR"] = 1] = "ERROR"; + ExitCodes2[ExitCodes2["NOT_FOUND"] = -2] = "NOT_FOUND"; + ExitCodes2[ExitCodes2["UNCLEAN"] = 128] = "UNCLEAN"; + return ExitCodes2; + })(ExitCodes || {}); + } +}); +var GitOutputStreams; +var init_git_output_streams = __esm2({ + "src/lib/utils/git-output-streams.ts"() { + GitOutputStreams = class { + constructor(stdOut, stdErr) { + this.stdOut = stdOut; + this.stdErr = stdErr; + } + asStrings() { + return new GitOutputStreams(this.stdOut.toString("utf8"), this.stdErr.toString("utf8")); + } + }; + } +}); +var LineParser; +var RemoteLineParser; +var init_line_parser = __esm2({ + "src/lib/utils/line-parser.ts"() { + LineParser = class { + constructor(regExp, useMatches) { + this.matches = []; + this.parse = (line, target) => { + this.resetMatches(); + if (!this._regExp.every((reg, index2) => this.addMatch(reg, index2, line(index2)))) { + return false; + } + return this.useMatches(target, this.prepareMatches()) !== false; + }; + this._regExp = Array.isArray(regExp) ? regExp : [regExp]; + if (useMatches) { + this.useMatches = useMatches; + } + } + useMatches(target, match) { + throw new Error(`LineParser:useMatches not implemented`); + } + resetMatches() { + this.matches.length = 0; + } + prepareMatches() { + return this.matches; + } + addMatch(reg, index2, line) { + const matched = line && reg.exec(line); + if (matched) { + this.pushMatch(index2, matched); + } + return !!matched; + } + pushMatch(_index, matched) { + this.matches.push(...matched.slice(1)); + } + }; + RemoteLineParser = class extends LineParser { + addMatch(reg, index2, line) { + return /^remote:\s/.test(String(line)) && super.addMatch(reg, index2, line); + } + pushMatch(index2, matched) { + if (index2 > 0 || matched.length > 1) { + super.pushMatch(index2, matched); + } + } + }; + } +}); +function createInstanceConfig(...options) { + const baseDir = process.cwd(); + const config = Object.assign(__spreadValues({ baseDir }, defaultOptions), ...options.filter((o) => typeof o === "object" && o)); + config.baseDir = config.baseDir || baseDir; + config.trimmed = config.trimmed === true; + return config; +} +var defaultOptions; +var init_simple_git_options = __esm2({ + "src/lib/utils/simple-git-options.ts"() { + defaultOptions = { + binary: "git", + maxConcurrentProcesses: 5, + config: [], + trimmed: false + }; + } +}); +function appendTaskOptions(options, commands2 = []) { + if (!filterPlainObject(options)) { + return commands2; + } + return Object.keys(options).reduce((commands22, key2) => { + const value = options[key2]; + if (filterPrimitives(value, ["boolean"])) { + commands22.push(key2 + "=" + value); + } else { + commands22.push(key2); + } + return commands22; + }, commands2); +} +function getTrailingOptions(args, initialPrimitive = 0, objectOnly = false) { + const command = []; + for (let i = 0, max = initialPrimitive < 0 ? args.length : initialPrimitive; i < max; i++) { + if ("string|number".includes(typeof args[i])) { + command.push(String(args[i])); + } + } + appendTaskOptions(trailingOptionsArgument(args), command); + if (!objectOnly) { + command.push(...trailingArrayArgument(args)); + } + return command; +} +function trailingArrayArgument(args) { + const hasTrailingCallback = typeof last(args) === "function"; + return filterType(last(args, hasTrailingCallback ? 1 : 0), filterArray, []); +} +function trailingOptionsArgument(args) { + const hasTrailingCallback = filterFunction(last(args)); + return filterType(last(args, hasTrailingCallback ? 1 : 0), filterPlainObject); +} +function trailingFunctionArgument(args, includeNoop = true) { + const callback = asFunction(last(args)); + return includeNoop || isUserFunction(callback) ? callback : void 0; +} +var init_task_options = __esm2({ + "src/lib/utils/task-options.ts"() { + init_argument_filters(); + init_util(); + } +}); +function callTaskParser(parser3, streams) { + return parser3(streams.stdOut, streams.stdErr); +} +function parseStringResponse(result, parsers12, texts, trim = true) { + asArray(texts).forEach((text2) => { + for (let lines = toLinesWithContent(text2, trim), i = 0, max = lines.length; i < max; i++) { + const line = (offset = 0) => { + if (i + offset >= max) { + return; + } + return lines[i + offset]; + }; + parsers12.some(({ parse: parse2 }) => parse2(line, result)); + } + }); + return result; +} +var init_task_parser = __esm2({ + "src/lib/utils/task-parser.ts"() { + init_util(); + } +}); +var utils_exports = {}; +__export2(utils_exports, { + ExitCodes: () => ExitCodes, + GitOutputStreams: () => GitOutputStreams, + LineParser: () => LineParser, + NOOP: () => NOOP, + NULL: () => NULL, + RemoteLineParser: () => RemoteLineParser, + append: () => append, + appendTaskOptions: () => appendTaskOptions, + asArray: () => asArray, + asFunction: () => asFunction, + asNumber: () => asNumber, + asStringArray: () => asStringArray, + bufferToString: () => bufferToString, + callTaskParser: () => callTaskParser, + createInstanceConfig: () => createInstanceConfig, + delay: () => delay, + filterArray: () => filterArray, + filterFunction: () => filterFunction, + filterHasLength: () => filterHasLength, + filterPlainObject: () => filterPlainObject, + filterPrimitives: () => filterPrimitives, + filterString: () => filterString, + filterStringArray: () => filterStringArray, + filterStringOrStringArray: () => filterStringOrStringArray, + filterType: () => filterType, + first: () => first, + folderExists: () => folderExists, + forEachLineWithContent: () => forEachLineWithContent, + getTrailingOptions: () => getTrailingOptions, + including: () => including, + isUserFunction: () => isUserFunction, + last: () => last, + objectToString: () => objectToString, + parseStringResponse: () => parseStringResponse, + pick: () => pick, + prefixedArray: () => prefixedArray, + remove: () => remove2, + splitOn: () => splitOn, + toLinesWithContent: () => toLinesWithContent, + trailingFunctionArgument: () => trailingFunctionArgument, + trailingOptionsArgument: () => trailingOptionsArgument +}); +var init_utils = __esm2({ + "src/lib/utils/index.ts"() { + init_argument_filters(); + init_exit_codes(); + init_git_output_streams(); + init_line_parser(); + init_simple_git_options(); + init_task_options(); + init_task_parser(); + init_util(); + } +}); +var check_is_repo_exports = {}; +__export2(check_is_repo_exports, { + CheckRepoActions: () => CheckRepoActions, + checkIsBareRepoTask: () => checkIsBareRepoTask, + checkIsRepoRootTask: () => checkIsRepoRootTask, + checkIsRepoTask: () => checkIsRepoTask +}); +function checkIsRepoTask(action) { + switch (action) { + case "bare": + return checkIsBareRepoTask(); + case "root": + return checkIsRepoRootTask(); + } + const commands2 = ["rev-parse", "--is-inside-work-tree"]; + return { + commands: commands2, + format: "utf-8", + onError, + parser + }; +} +function checkIsRepoRootTask() { + const commands2 = ["rev-parse", "--git-dir"]; + return { + commands: commands2, + format: "utf-8", + onError, + parser(path2) { + return /^\.(git)?$/.test(path2.trim()); + } + }; +} +function checkIsBareRepoTask() { + const commands2 = ["rev-parse", "--is-bare-repository"]; + return { + commands: commands2, + format: "utf-8", + onError, + parser + }; +} +function isNotRepoMessage(error) { + return /(Not a git repository|Kein Git-Repository)/i.test(String(error)); +} +var CheckRepoActions; +var onError; +var parser; +var init_check_is_repo = __esm2({ + "src/lib/tasks/check-is-repo.ts"() { + init_utils(); + CheckRepoActions = /* @__PURE__ */ ((CheckRepoActions2) => { + CheckRepoActions2["BARE"] = "bare"; + CheckRepoActions2["IN_TREE"] = "tree"; + CheckRepoActions2["IS_REPO_ROOT"] = "root"; + return CheckRepoActions2; + })(CheckRepoActions || {}); + onError = ({ exitCode }, error, done, fail) => { + if (exitCode === 128 && isNotRepoMessage(error)) { + return done(Buffer.from("false")); + } + fail(error); + }; + parser = (text2) => { + return text2.trim() === "true"; + }; + } +}); +function cleanSummaryParser(dryRun, text2) { + const summary = new CleanResponse(dryRun); + const regexp = dryRun ? dryRunRemovalRegexp : removalRegexp; + toLinesWithContent(text2).forEach((line) => { + const removed = line.replace(regexp, ""); + summary.paths.push(removed); + (isFolderRegexp.test(removed) ? summary.folders : summary.files).push(removed); + }); + return summary; +} +var CleanResponse; +var removalRegexp; +var dryRunRemovalRegexp; +var isFolderRegexp; +var init_CleanSummary = __esm2({ + "src/lib/responses/CleanSummary.ts"() { + init_utils(); + CleanResponse = class { + constructor(dryRun) { + this.dryRun = dryRun; + this.paths = []; + this.files = []; + this.folders = []; + } + }; + removalRegexp = /^[a-z]+\s*/i; + dryRunRemovalRegexp = /^[a-z]+\s+[a-z]+\s*/i; + isFolderRegexp = /\/$/; + } +}); +var task_exports = {}; +__export2(task_exports, { + EMPTY_COMMANDS: () => EMPTY_COMMANDS, + adhocExecTask: () => adhocExecTask, + configurationErrorTask: () => configurationErrorTask, + isBufferTask: () => isBufferTask, + isEmptyTask: () => isEmptyTask, + straightThroughBufferTask: () => straightThroughBufferTask, + straightThroughStringTask: () => straightThroughStringTask +}); +function adhocExecTask(parser3) { + return { + commands: EMPTY_COMMANDS, + format: "empty", + parser: parser3 + }; +} +function configurationErrorTask(error) { + return { + commands: EMPTY_COMMANDS, + format: "empty", + parser() { + throw typeof error === "string" ? new TaskConfigurationError(error) : error; + } + }; +} +function straightThroughStringTask(commands2, trimmed2 = false) { + return { + commands: commands2, + format: "utf-8", + parser(text2) { + return trimmed2 ? String(text2).trim() : text2; + } + }; +} +function straightThroughBufferTask(commands2) { + return { + commands: commands2, + format: "buffer", + parser(buffer2) { + return buffer2; + } + }; +} +function isBufferTask(task) { + return task.format === "buffer"; +} +function isEmptyTask(task) { + return task.format === "empty" || !task.commands.length; +} +var EMPTY_COMMANDS; +var init_task = __esm2({ + "src/lib/tasks/task.ts"() { + init_task_configuration_error(); + EMPTY_COMMANDS = []; + } +}); +var clean_exports = {}; +__export2(clean_exports, { + CONFIG_ERROR_INTERACTIVE_MODE: () => CONFIG_ERROR_INTERACTIVE_MODE, + CONFIG_ERROR_MODE_REQUIRED: () => CONFIG_ERROR_MODE_REQUIRED, + CONFIG_ERROR_UNKNOWN_OPTION: () => CONFIG_ERROR_UNKNOWN_OPTION, + CleanOptions: () => CleanOptions, + cleanTask: () => cleanTask, + cleanWithOptionsTask: () => cleanWithOptionsTask, + isCleanOptionsArray: () => isCleanOptionsArray +}); +function cleanWithOptionsTask(mode, customArgs) { + const { cleanMode, options, valid } = getCleanOptions(mode); + if (!cleanMode) { + return configurationErrorTask(CONFIG_ERROR_MODE_REQUIRED); + } + if (!valid.options) { + return configurationErrorTask(CONFIG_ERROR_UNKNOWN_OPTION + JSON.stringify(mode)); + } + options.push(...customArgs); + if (options.some(isInteractiveMode)) { + return configurationErrorTask(CONFIG_ERROR_INTERACTIVE_MODE); + } + return cleanTask(cleanMode, options); +} +function cleanTask(mode, customArgs) { + const commands2 = ["clean", `-${mode}`, ...customArgs]; + return { + commands: commands2, + format: "utf-8", + parser(text2) { + return cleanSummaryParser(mode === "n", text2); + } + }; +} +function isCleanOptionsArray(input) { + return Array.isArray(input) && input.every((test) => CleanOptionValues.has(test)); +} +function getCleanOptions(input) { + let cleanMode; + let options = []; + let valid = { cleanMode: false, options: true }; + input.replace(/[^a-z]i/g, "").split("").forEach((char) => { + if (isCleanMode(char)) { + cleanMode = char; + valid.cleanMode = true; + } else { + valid.options = valid.options && isKnownOption(options[options.length] = `-${char}`); + } + }); + return { + cleanMode, + options, + valid + }; +} +function isCleanMode(cleanMode) { + return cleanMode === "f" || cleanMode === "n"; +} +function isKnownOption(option) { + return /^-[a-z]$/i.test(option) && CleanOptionValues.has(option.charAt(1)); +} +function isInteractiveMode(option) { + if (/^-[^\-]/.test(option)) { + return option.indexOf("i") > 0; + } + return option === "--interactive"; +} +var CONFIG_ERROR_INTERACTIVE_MODE; +var CONFIG_ERROR_MODE_REQUIRED; +var CONFIG_ERROR_UNKNOWN_OPTION; +var CleanOptions; +var CleanOptionValues; +var init_clean = __esm2({ + "src/lib/tasks/clean.ts"() { + init_CleanSummary(); + init_utils(); + init_task(); + CONFIG_ERROR_INTERACTIVE_MODE = "Git clean interactive mode is not supported"; + CONFIG_ERROR_MODE_REQUIRED = 'Git clean mode parameter ("n" or "f") is required'; + CONFIG_ERROR_UNKNOWN_OPTION = "Git clean unknown option found in: "; + CleanOptions = /* @__PURE__ */ ((CleanOptions2) => { + CleanOptions2["DRY_RUN"] = "n"; + CleanOptions2["FORCE"] = "f"; + CleanOptions2["IGNORED_INCLUDED"] = "x"; + CleanOptions2["IGNORED_ONLY"] = "X"; + CleanOptions2["EXCLUDING"] = "e"; + CleanOptions2["QUIET"] = "q"; + CleanOptions2["RECURSIVE"] = "d"; + return CleanOptions2; + })(CleanOptions || {}); + CleanOptionValues = /* @__PURE__ */ new Set([ + "i", + ...asStringArray(Object.values(CleanOptions)) + ]); + } +}); +function configListParser(text2) { + const config = new ConfigList(); + for (const item of configParser(text2)) { + config.addValue(item.file, String(item.key), item.value); + } + return config; +} +function configGetParser(text2, key2) { + let value = null; + const values = []; + const scopes = /* @__PURE__ */ new Map(); + for (const item of configParser(text2, key2)) { + if (item.key !== key2) { + continue; + } + values.push(value = item.value); + if (!scopes.has(item.file)) { + scopes.set(item.file, []); + } + scopes.get(item.file).push(value); + } + return { + key: key2, + paths: Array.from(scopes.keys()), + scopes, + value, + values + }; +} +function configFilePath(filePath) { + return filePath.replace(/^(file):/, ""); +} +function* configParser(text2, requestedKey = null) { + const lines = text2.split("\0"); + for (let i = 0, max = lines.length - 1; i < max; ) { + const file = configFilePath(lines[i++]); + let value = lines[i++]; + let key2 = requestedKey; + if (value.includes("\n")) { + const line = splitOn(value, "\n"); + key2 = line[0]; + value = line[1]; + } + yield { file, key: key2, value }; + } +} +var ConfigList; +var init_ConfigList = __esm2({ + "src/lib/responses/ConfigList.ts"() { + init_utils(); + ConfigList = class { + constructor() { + this.files = []; + this.values = /* @__PURE__ */ Object.create(null); + } + get all() { + if (!this._all) { + this._all = this.files.reduce((all, file) => { + return Object.assign(all, this.values[file]); + }, {}); + } + return this._all; + } + addFile(file) { + if (!(file in this.values)) { + const latest = last(this.files); + this.values[file] = latest ? Object.create(this.values[latest]) : {}; + this.files.push(file); + } + return this.values[file]; + } + addValue(file, key2, value) { + const values = this.addFile(file); + if (!values.hasOwnProperty(key2)) { + values[key2] = value; + } else if (Array.isArray(values[key2])) { + values[key2].push(value); + } else { + values[key2] = [values[key2], value]; + } + this._all = void 0; + } + }; + } +}); +function asConfigScope(scope, fallback) { + if (typeof scope === "string" && GitConfigScope.hasOwnProperty(scope)) { + return scope; + } + return fallback; +} +function addConfigTask(key2, value, append22, scope) { + const commands2 = ["config", `--${scope}`]; + if (append22) { + commands2.push("--add"); + } + commands2.push(key2, value); + return { + commands: commands2, + format: "utf-8", + parser(text2) { + return text2; + } + }; +} +function getConfigTask(key2, scope) { + const commands2 = ["config", "--null", "--show-origin", "--get-all", key2]; + if (scope) { + commands2.splice(1, 0, `--${scope}`); + } + return { + commands: commands2, + format: "utf-8", + parser(text2) { + return configGetParser(text2, key2); + } + }; +} +function listConfigTask(scope) { + const commands2 = ["config", "--list", "--show-origin", "--null"]; + if (scope) { + commands2.push(`--${scope}`); + } + return { + commands: commands2, + format: "utf-8", + parser(text2) { + return configListParser(text2); + } + }; +} +function config_default() { + return { + addConfig(key2, value, ...rest) { + return this._runTask(addConfigTask(key2, value, rest[0] === true, asConfigScope( + rest[1], + "local" + /* local */ + )), trailingFunctionArgument(arguments)); + }, + getConfig(key2, scope) { + return this._runTask(getConfigTask(key2, asConfigScope(scope, void 0)), trailingFunctionArgument(arguments)); + }, + listConfig(...rest) { + return this._runTask(listConfigTask(asConfigScope(rest[0], void 0)), trailingFunctionArgument(arguments)); + } + }; +} +var GitConfigScope; +var init_config = __esm2({ + "src/lib/tasks/config.ts"() { + init_ConfigList(); + init_utils(); + GitConfigScope = /* @__PURE__ */ ((GitConfigScope2) => { + GitConfigScope2["system"] = "system"; + GitConfigScope2["global"] = "global"; + GitConfigScope2["local"] = "local"; + GitConfigScope2["worktree"] = "worktree"; + return GitConfigScope2; + })(GitConfigScope || {}); + } +}); +function grepQueryBuilder(...params) { + return new GrepQuery().param(...params); +} +function parseGrep(grep) { + const paths = /* @__PURE__ */ new Set(); + const results = {}; + forEachLineWithContent(grep, (input) => { + const [path2, line, preview] = input.split(NULL); + paths.add(path2); + (results[path2] = results[path2] || []).push({ + line: asNumber(line), + path: path2, + preview + }); + }); + return { + paths, + results + }; +} +function grep_default() { + return { + grep(searchTerm) { + const then = trailingFunctionArgument(arguments); + const options = getTrailingOptions(arguments); + for (const option of disallowedOptions) { + if (options.includes(option)) { + return this._runTask(configurationErrorTask(`git.grep: use of "${option}" is not supported.`), then); + } + } + if (typeof searchTerm === "string") { + searchTerm = grepQueryBuilder().param(searchTerm); + } + const commands2 = ["grep", "--null", "-n", "--full-name", ...options, ...searchTerm]; + return this._runTask({ + commands: commands2, + format: "utf-8", + parser(stdOut) { + return parseGrep(stdOut); + } + }, then); + } + }; +} +var disallowedOptions; +var Query; +var _a; +var GrepQuery; +var init_grep = __esm2({ + "src/lib/tasks/grep.ts"() { + init_utils(); + init_task(); + disallowedOptions = ["-h"]; + Query = Symbol("grepQuery"); + GrepQuery = class { + constructor() { + this[_a] = []; + } + *[(_a = Query, Symbol.iterator)]() { + for (const query of this[Query]) { + yield query; + } + } + and(...and) { + and.length && this[Query].push("--and", "(", ...prefixedArray(and, "-e"), ")"); + return this; + } + param(...param) { + this[Query].push(...prefixedArray(param, "-e")); + return this; + } + }; + } +}); +var reset_exports = {}; +__export2(reset_exports, { + ResetMode: () => ResetMode, + getResetMode: () => getResetMode, + resetTask: () => resetTask +}); +function resetTask(mode, customArgs) { + const commands2 = ["reset"]; + if (isValidResetMode(mode)) { + commands2.push(`--${mode}`); + } + commands2.push(...customArgs); + return straightThroughStringTask(commands2); +} +function getResetMode(mode) { + if (isValidResetMode(mode)) { + return mode; + } + switch (typeof mode) { + case "string": + case "undefined": + return "soft"; + } + return; +} +function isValidResetMode(mode) { + return ResetModes.includes(mode); +} +var ResetMode; +var ResetModes; +var init_reset = __esm2({ + "src/lib/tasks/reset.ts"() { + init_task(); + ResetMode = /* @__PURE__ */ ((ResetMode2) => { + ResetMode2["MIXED"] = "mixed"; + ResetMode2["SOFT"] = "soft"; + ResetMode2["HARD"] = "hard"; + ResetMode2["MERGE"] = "merge"; + ResetMode2["KEEP"] = "keep"; + return ResetMode2; + })(ResetMode || {}); + ResetModes = Array.from(Object.values(ResetMode)); + } +}); +function createLog() { + return (0, import_debug.default)("simple-git"); +} +function prefixedLogger(to, prefix, forward) { + if (!prefix || !String(prefix).replace(/\s*/, "")) { + return !forward ? to : (message, ...args) => { + to(message, ...args); + forward(message, ...args); + }; + } + return (message, ...args) => { + to(`%s ${message}`, prefix, ...args); + if (forward) { + forward(message, ...args); + } + }; +} +function childLoggerName(name, childDebugger, { namespace: parentNamespace }) { + if (typeof name === "string") { + return name; + } + const childNamespace = childDebugger && childDebugger.namespace || ""; + if (childNamespace.startsWith(parentNamespace)) { + return childNamespace.substr(parentNamespace.length + 1); + } + return childNamespace || parentNamespace; +} +function createLogger(label, verbose, initialStep, infoDebugger = createLog()) { + const labelPrefix = label && `[${label}]` || ""; + const spawned = []; + const debugDebugger = typeof verbose === "string" ? infoDebugger.extend(verbose) : verbose; + const key2 = childLoggerName(filterType(verbose, filterString), debugDebugger, infoDebugger); + return step(initialStep); + function sibling(name, initial) { + return append(spawned, createLogger(label, key2.replace(/^[^:]+/, name), initial, infoDebugger)); + } + function step(phase) { + const stepPrefix = phase && `[${phase}]` || ""; + const debug22 = debugDebugger && prefixedLogger(debugDebugger, stepPrefix) || NOOP; + const info = prefixedLogger(infoDebugger, `${labelPrefix} ${stepPrefix}`, debug22); + return Object.assign(debugDebugger ? debug22 : info, { + label, + sibling, + info, + step + }); + } +} +var init_git_logger = __esm2({ + "src/lib/git-logger.ts"() { + init_utils(); + import_debug.default.formatters.L = (value) => String(filterHasLength(value) ? value.length : "-"); + import_debug.default.formatters.B = (value) => { + if (Buffer.isBuffer(value)) { + return value.toString("utf8"); + } + return objectToString(value); + }; + } +}); +var _TasksPendingQueue; +var TasksPendingQueue; +var init_tasks_pending_queue = __esm2({ + "src/lib/runners/tasks-pending-queue.ts"() { + init_git_error(); + init_git_logger(); + _TasksPendingQueue = class { + constructor(logLabel = "GitExecutor") { + this.logLabel = logLabel; + this._queue = /* @__PURE__ */ new Map(); + } + withProgress(task) { + return this._queue.get(task); + } + createProgress(task) { + const name = _TasksPendingQueue.getName(task.commands[0]); + const logger = createLogger(this.logLabel, name); + return { + task, + logger, + name + }; + } + push(task) { + const progress = this.createProgress(task); + progress.logger("Adding task to the queue, commands = %o", task.commands); + this._queue.set(task, progress); + return progress; + } + fatal(err) { + for (const [task, { logger }] of Array.from(this._queue.entries())) { + if (task === err.task) { + logger.info(`Failed %o`, err); + logger(`Fatal exception, any as-yet un-started tasks run through this executor will not be attempted`); + } else { + logger.info(`A fatal exception occurred in a previous task, the queue has been purged: %o`, err.message); + } + this.complete(task); + } + if (this._queue.size !== 0) { + throw new Error(`Queue size should be zero after fatal: ${this._queue.size}`); + } + } + complete(task) { + const progress = this.withProgress(task); + if (progress) { + this._queue.delete(task); + } + } + attempt(task) { + const progress = this.withProgress(task); + if (!progress) { + throw new GitError(void 0, "TasksPendingQueue: attempt called for an unknown task"); + } + progress.logger("Starting task"); + return progress; + } + static getName(name = "empty") { + return `task:${name}:${++_TasksPendingQueue.counter}`; + } + }; + TasksPendingQueue = _TasksPendingQueue; + TasksPendingQueue.counter = 0; + } +}); +function pluginContext(task, commands2) { + return { + method: first(task.commands) || "", + commands: commands2 + }; +} +function onErrorReceived(target, logger) { + return (err) => { + logger(`[ERROR] child process exception %o`, err); + target.push(Buffer.from(String(err.stack), "ascii")); + }; +} +function onDataReceived(target, name, logger, output) { + return (buffer2) => { + logger(`%s received %L bytes`, name, buffer2); + output(`%B`, buffer2); + target.push(buffer2); + }; +} +var GitExecutorChain; +var init_git_executor_chain = __esm2({ + "src/lib/runners/git-executor-chain.ts"() { + init_git_error(); + init_task(); + init_utils(); + init_tasks_pending_queue(); + GitExecutorChain = class { + constructor(_executor, _scheduler, _plugins) { + this._executor = _executor; + this._scheduler = _scheduler; + this._plugins = _plugins; + this._chain = Promise.resolve(); + this._queue = new TasksPendingQueue(); + } + get binary() { + return this._executor.binary; + } + get cwd() { + return this._cwd || this._executor.cwd; + } + set cwd(cwd) { + this._cwd = cwd; + } + get env() { + return this._executor.env; + } + get outputHandler() { + return this._executor.outputHandler; + } + chain() { + return this; + } + push(task) { + this._queue.push(task); + return this._chain = this._chain.then(() => this.attemptTask(task)); + } + attemptTask(task) { + return __async(this, null, function* () { + const onScheduleComplete = yield this._scheduler.next(); + const onQueueComplete = () => this._queue.complete(task); + try { + const { logger } = this._queue.attempt(task); + return yield isEmptyTask(task) ? this.attemptEmptyTask(task, logger) : this.attemptRemoteTask(task, logger); + } catch (e) { + throw this.onFatalException(task, e); + } finally { + onQueueComplete(); + onScheduleComplete(); + } + }); + } + onFatalException(task, e) { + const gitError = e instanceof GitError ? Object.assign(e, { task }) : new GitError(task, e && String(e)); + this._chain = Promise.resolve(); + this._queue.fatal(gitError); + return gitError; + } + attemptRemoteTask(task, logger) { + return __async(this, null, function* () { + const args = this._plugins.exec("spawn.args", [...task.commands], pluginContext(task, task.commands)); + const raw = yield this.gitResponse(task, this.binary, args, this.outputHandler, logger.step("SPAWN")); + const outputStreams = yield this.handleTaskData(task, args, raw, logger.step("HANDLE")); + logger(`passing response to task's parser as a %s`, task.format); + if (isBufferTask(task)) { + return callTaskParser(task.parser, outputStreams); + } + return callTaskParser(task.parser, outputStreams.asStrings()); + }); + } + attemptEmptyTask(task, logger) { + return __async(this, null, function* () { + logger(`empty task bypassing child process to call to task's parser`); + return task.parser(this); + }); + } + handleTaskData(task, args, result, logger) { + const { exitCode, rejection, stdOut, stdErr } = result; + return new Promise((done, fail) => { + logger(`Preparing to handle process response exitCode=%d stdOut=`, exitCode); + const { error } = this._plugins.exec("task.error", { error: rejection }, __spreadValues(__spreadValues({}, pluginContext(task, args)), result)); + if (error && task.onError) { + logger.info(`exitCode=%s handling with custom error handler`); + return task.onError(result, error, (newStdOut) => { + logger.info(`custom error handler treated as success`); + logger(`custom error returned a %s`, objectToString(newStdOut)); + done(new GitOutputStreams(Array.isArray(newStdOut) ? Buffer.concat(newStdOut) : newStdOut, Buffer.concat(stdErr))); + }, fail); + } + if (error) { + logger.info(`handling as error: exitCode=%s stdErr=%s rejection=%o`, exitCode, stdErr.length, rejection); + return fail(error); + } + logger.info(`retrieving task output complete`); + done(new GitOutputStreams(Buffer.concat(stdOut), Buffer.concat(stdErr))); + }); + } + gitResponse(task, command, args, outputHandler, logger) { + return __async(this, null, function* () { + const outputLogger = logger.sibling("output"); + const spawnOptions = this._plugins.exec("spawn.options", { + cwd: this.cwd, + env: this.env, + windowsHide: true + }, pluginContext(task, task.commands)); + return new Promise((done) => { + const stdOut = []; + const stdErr = []; + logger.info(`%s %o`, command, args); + logger("%O", spawnOptions); + let rejection = this._beforeSpawn(task, args); + if (rejection) { + return done({ + stdOut, + stdErr, + exitCode: 9901, + rejection + }); + } + this._plugins.exec("spawn.before", void 0, __spreadProps(__spreadValues({}, pluginContext(task, args)), { + kill(reason) { + rejection = reason || rejection; + } + })); + const spawned = (0, import_child_process.spawn)(command, args, spawnOptions); + spawned.stdout.on("data", onDataReceived(stdOut, "stdOut", logger, outputLogger.step("stdOut"))); + spawned.stderr.on("data", onDataReceived(stdErr, "stdErr", logger, outputLogger.step("stdErr"))); + spawned.on("error", onErrorReceived(stdErr, logger)); + if (outputHandler) { + logger(`Passing child process stdOut/stdErr to custom outputHandler`); + outputHandler(command, spawned.stdout, spawned.stderr, [...args]); + } + this._plugins.exec("spawn.after", void 0, __spreadProps(__spreadValues({}, pluginContext(task, args)), { + spawned, + close(exitCode, reason) { + done({ + stdOut, + stdErr, + exitCode, + rejection: rejection || reason + }); + }, + kill(reason) { + if (spawned.killed) { + return; + } + rejection = reason; + spawned.kill("SIGINT"); + } + })); + }); + }); + } + _beforeSpawn(task, args) { + let rejection; + this._plugins.exec("spawn.before", void 0, __spreadProps(__spreadValues({}, pluginContext(task, args)), { + kill(reason) { + rejection = reason || rejection; + } + })); + return rejection; + } + }; + } +}); +var git_executor_exports = {}; +__export2(git_executor_exports, { + GitExecutor: () => GitExecutor +}); +var GitExecutor; +var init_git_executor = __esm2({ + "src/lib/runners/git-executor.ts"() { + init_git_executor_chain(); + GitExecutor = class { + constructor(binary = "git", cwd, _scheduler, _plugins) { + this.binary = binary; + this.cwd = cwd; + this._scheduler = _scheduler; + this._plugins = _plugins; + this._chain = new GitExecutorChain(this, this._scheduler, this._plugins); + } + chain() { + return new GitExecutorChain(this, this._scheduler, this._plugins); + } + push(task) { + return this._chain.push(task); + } + }; + } +}); +function taskCallback(task, response, callback = NOOP) { + const onSuccess = (data) => { + callback(null, data); + }; + const onError2 = (err) => { + if ((err == null ? void 0 : err.task) === task) { + callback(err instanceof GitResponseError ? addDeprecationNoticeToError(err) : err, void 0); + } + }; + response.then(onSuccess, onError2); +} +function addDeprecationNoticeToError(err) { + let log2 = (name) => { + console.warn(`simple-git deprecation notice: accessing GitResponseError.${name} should be GitResponseError.git.${name}, this will no longer be available in version 3`); + log2 = NOOP; + }; + return Object.create(err, Object.getOwnPropertyNames(err.git).reduce(descriptorReducer, {})); + function descriptorReducer(all, name) { + if (name in err) { + return all; + } + all[name] = { + enumerable: false, + configurable: false, + get() { + log2(name); + return err.git[name]; + } + }; + return all; + } +} +var init_task_callback = __esm2({ + "src/lib/task-callback.ts"() { + init_git_response_error(); + init_utils(); + } +}); +function changeWorkingDirectoryTask(directory, root2) { + return adhocExecTask((instance10) => { + if (!folderExists(directory)) { + throw new Error(`Git.cwd: cannot change to non-directory "${directory}"`); + } + return (root2 || instance10).cwd = directory; + }); +} +var init_change_working_directory = __esm2({ + "src/lib/tasks/change-working-directory.ts"() { + init_utils(); + init_task(); + } +}); +function checkoutTask(args) { + const commands2 = ["checkout", ...args]; + if (commands2[1] === "-b" && commands2.includes("-B")) { + commands2[1] = remove2(commands2, "-B"); + } + return straightThroughStringTask(commands2); +} +function checkout_default() { + return { + checkout() { + return this._runTask(checkoutTask(getTrailingOptions(arguments, 1)), trailingFunctionArgument(arguments)); + }, + checkoutBranch(branchName, startPoint) { + return this._runTask(checkoutTask(["-b", branchName, startPoint, ...getTrailingOptions(arguments)]), trailingFunctionArgument(arguments)); + }, + checkoutLocalBranch(branchName) { + return this._runTask(checkoutTask(["-b", branchName, ...getTrailingOptions(arguments)]), trailingFunctionArgument(arguments)); + } + }; +} +var init_checkout = __esm2({ + "src/lib/tasks/checkout.ts"() { + init_utils(); + init_task(); + } +}); +function parseCommitResult(stdOut) { + const result = { + author: null, + branch: "", + commit: "", + root: false, + summary: { + changes: 0, + insertions: 0, + deletions: 0 + } + }; + return parseStringResponse(result, parsers, stdOut); +} +var parsers; +var init_parse_commit = __esm2({ + "src/lib/parsers/parse-commit.ts"() { + init_utils(); + parsers = [ + new LineParser(/^\[([^\s]+)( \([^)]+\))? ([^\]]+)/, (result, [branch2, root2, commit2]) => { + result.branch = branch2; + result.commit = commit2; + result.root = !!root2; + }), + new LineParser(/\s*Author:\s(.+)/i, (result, [author]) => { + const parts = author.split("<"); + const email = parts.pop(); + if (!email || !email.includes("@")) { + return; + } + result.author = { + email: email.substr(0, email.length - 1), + name: parts.join("<").trim() + }; + }), + new LineParser(/(\d+)[^,]*(?:,\s*(\d+)[^,]*)(?:,\s*(\d+))/g, (result, [changes, insertions, deletions]) => { + result.summary.changes = parseInt(changes, 10) || 0; + result.summary.insertions = parseInt(insertions, 10) || 0; + result.summary.deletions = parseInt(deletions, 10) || 0; + }), + new LineParser(/^(\d+)[^,]*(?:,\s*(\d+)[^(]+\(([+-]))?/, (result, [changes, lines, direction]) => { + result.summary.changes = parseInt(changes, 10) || 0; + const count = parseInt(lines, 10) || 0; + if (direction === "-") { + result.summary.deletions = count; + } else if (direction === "+") { + result.summary.insertions = count; + } + }) + ]; + } +}); +function commitTask(message, files, customArgs) { + const commands2 = [ + "-c", + "core.abbrev=40", + "commit", + ...prefixedArray(message, "-m"), + ...files, + ...customArgs + ]; + return { + commands: commands2, + format: "utf-8", + parser: parseCommitResult + }; +} +function commit_default() { + return { + commit(message, ...rest) { + const next = trailingFunctionArgument(arguments); + const task = rejectDeprecatedSignatures(message) || commitTask(asArray(message), asArray(filterType(rest[0], filterStringOrStringArray, [])), [...filterType(rest[1], filterArray, []), ...getTrailingOptions(arguments, 0, true)]); + return this._runTask(task, next); + } + }; + function rejectDeprecatedSignatures(message) { + return !filterStringOrStringArray(message) && configurationErrorTask(`git.commit: requires the commit message to be supplied as a string/string[]`); + } +} +var init_commit = __esm2({ + "src/lib/tasks/commit.ts"() { + init_parse_commit(); + init_utils(); + init_task(); + } +}); +function hashObjectTask(filePath, write) { + const commands2 = ["hash-object", filePath]; + if (write) { + commands2.push("-w"); + } + return straightThroughStringTask(commands2, true); +} +var init_hash_object = __esm2({ + "src/lib/tasks/hash-object.ts"() { + init_task(); + } +}); +function parseInit(bare, path2, text2) { + const response = String(text2).trim(); + let result; + if (result = initResponseRegex.exec(response)) { + return new InitSummary(bare, path2, false, result[1]); + } + if (result = reInitResponseRegex.exec(response)) { + return new InitSummary(bare, path2, true, result[1]); + } + let gitDir = ""; + const tokens = response.split(" "); + while (tokens.length) { + const token = tokens.shift(); + if (token === "in") { + gitDir = tokens.join(" "); + break; + } + } + return new InitSummary(bare, path2, /^re/i.test(response), gitDir); +} +var InitSummary; +var initResponseRegex; +var reInitResponseRegex; +var init_InitSummary = __esm2({ + "src/lib/responses/InitSummary.ts"() { + InitSummary = class { + constructor(bare, path2, existing, gitDir) { + this.bare = bare; + this.path = path2; + this.existing = existing; + this.gitDir = gitDir; + } + }; + initResponseRegex = /^Init.+ repository in (.+)$/; + reInitResponseRegex = /^Rein.+ in (.+)$/; + } +}); +function hasBareCommand(command) { + return command.includes(bareCommand); +} +function initTask(bare = false, path2, customArgs) { + const commands2 = ["init", ...customArgs]; + if (bare && !hasBareCommand(commands2)) { + commands2.splice(1, 0, bareCommand); + } + return { + commands: commands2, + format: "utf-8", + parser(text2) { + return parseInit(commands2.includes("--bare"), path2, text2); + } + }; +} +var bareCommand; +var init_init = __esm2({ + "src/lib/tasks/init.ts"() { + init_InitSummary(); + bareCommand = "--bare"; + } +}); +function logFormatFromCommand(customArgs) { + for (let i = 0; i < customArgs.length; i++) { + const format = logFormatRegex.exec(customArgs[i]); + if (format) { + return `--${format[1]}`; + } + } + return ""; +} +function isLogFormat(customArg) { + return logFormatRegex.test(customArg); +} +var logFormatRegex; +var init_log_format = __esm2({ + "src/lib/args/log-format.ts"() { + logFormatRegex = /^--(stat|numstat|name-only|name-status)(=|$)/; + } +}); +var DiffSummary; +var init_DiffSummary = __esm2({ + "src/lib/responses/DiffSummary.ts"() { + DiffSummary = class { + constructor() { + this.changed = 0; + this.deletions = 0; + this.insertions = 0; + this.files = []; + } + }; + } +}); +function getDiffParser(format = "") { + const parser3 = diffSummaryParsers[format]; + return (stdOut) => parseStringResponse(new DiffSummary(), parser3, stdOut, false); +} +var statParser; +var numStatParser; +var nameOnlyParser; +var nameStatusParser; +var diffSummaryParsers; +var init_parse_diff_summary = __esm2({ + "src/lib/parsers/parse-diff-summary.ts"() { + init_log_format(); + init_DiffSummary(); + init_utils(); + statParser = [ + new LineParser(/(.+)\s+\|\s+(\d+)(\s+[+\-]+)?$/, (result, [file, changes, alterations = ""]) => { + result.files.push({ + file: file.trim(), + changes: asNumber(changes), + insertions: alterations.replace(/[^+]/g, "").length, + deletions: alterations.replace(/[^-]/g, "").length, + binary: false + }); + }), + new LineParser(/(.+) \|\s+Bin ([0-9.]+) -> ([0-9.]+) ([a-z]+)/, (result, [file, before, after]) => { + result.files.push({ + file: file.trim(), + before: asNumber(before), + after: asNumber(after), + binary: true + }); + }), + new LineParser(/(\d+) files? changed\s*((?:, \d+ [^,]+){0,2})/, (result, [changed, summary]) => { + const inserted = /(\d+) i/.exec(summary); + const deleted = /(\d+) d/.exec(summary); + result.changed = asNumber(changed); + result.insertions = asNumber(inserted == null ? void 0 : inserted[1]); + result.deletions = asNumber(deleted == null ? void 0 : deleted[1]); + }) + ]; + numStatParser = [ + new LineParser(/(\d+)\t(\d+)\t(.+)$/, (result, [changesInsert, changesDelete, file]) => { + const insertions = asNumber(changesInsert); + const deletions = asNumber(changesDelete); + result.changed++; + result.insertions += insertions; + result.deletions += deletions; + result.files.push({ + file, + changes: insertions + deletions, + insertions, + deletions, + binary: false + }); + }), + new LineParser(/-\t-\t(.+)$/, (result, [file]) => { + result.changed++; + result.files.push({ + file, + after: 0, + before: 0, + binary: true + }); + }) + ]; + nameOnlyParser = [ + new LineParser(/(.+)$/, (result, [file]) => { + result.changed++; + result.files.push({ + file, + changes: 0, + insertions: 0, + deletions: 0, + binary: false + }); + }) + ]; + nameStatusParser = [ + new LineParser(/([ACDMRTUXB])([0-9][0-9][0-9])?\t(.[^\t]+)\t?(.*)?$/, (result, [status2, _similarity, from, to]) => { + result.changed++; + result.files.push({ + file: to != null ? to : from, + changes: 0, + status: status2, + insertions: 0, + deletions: 0, + binary: false + }); + }) + ]; + diffSummaryParsers = { + [ + "" + /* NONE */ + ]: statParser, + [ + "--stat" + /* STAT */ + ]: statParser, + [ + "--numstat" + /* NUM_STAT */ + ]: numStatParser, + [ + "--name-status" + /* NAME_STATUS */ + ]: nameStatusParser, + [ + "--name-only" + /* NAME_ONLY */ + ]: nameOnlyParser + }; + } +}); +function lineBuilder(tokens, fields) { + return fields.reduce((line, field, index2) => { + line[field] = tokens[index2] || ""; + return line; + }, /* @__PURE__ */ Object.create({ diff: null })); +} +function createListLogSummaryParser(splitter = SPLITTER, fields = defaultFieldNames, logFormat = "") { + const parseDiffResult = getDiffParser(logFormat); + return function(stdOut) { + const all = toLinesWithContent(stdOut, true, START_BOUNDARY).map(function(item) { + const lineDetail = item.trim().split(COMMIT_BOUNDARY); + const listLogLine = lineBuilder(lineDetail[0].trim().split(splitter), fields); + if (lineDetail.length > 1 && !!lineDetail[1].trim()) { + listLogLine.diff = parseDiffResult(lineDetail[1]); + } + return listLogLine; + }); + return { + all, + latest: all.length && all[0] || null, + total: all.length + }; + }; +} +var START_BOUNDARY; +var COMMIT_BOUNDARY; +var SPLITTER; +var defaultFieldNames; +var init_parse_list_log_summary = __esm2({ + "src/lib/parsers/parse-list-log-summary.ts"() { + init_utils(); + init_parse_diff_summary(); + init_log_format(); + START_BOUNDARY = "\xF2\xF2\xF2\xF2\xF2\xF2 "; + COMMIT_BOUNDARY = " \xF2\xF2"; + SPLITTER = " \xF2 "; + defaultFieldNames = ["hash", "date", "message", "refs", "author_name", "author_email"]; + } +}); +var diff_exports = {}; +__export2(diff_exports, { + diffSummaryTask: () => diffSummaryTask, + validateLogFormatConfig: () => validateLogFormatConfig +}); +function diffSummaryTask(customArgs) { + let logFormat = logFormatFromCommand(customArgs); + const commands2 = ["diff"]; + if (logFormat === "") { + logFormat = "--stat"; + commands2.push("--stat=4096"); + } + commands2.push(...customArgs); + return validateLogFormatConfig(commands2) || { + commands: commands2, + format: "utf-8", + parser: getDiffParser(logFormat) + }; +} +function validateLogFormatConfig(customArgs) { + const flags = customArgs.filter(isLogFormat); + if (flags.length > 1) { + return configurationErrorTask(`Summary flags are mutually exclusive - pick one of ${flags.join(",")}`); + } + if (flags.length && customArgs.includes("-z")) { + return configurationErrorTask(`Summary flag ${flags} parsing is not compatible with null termination option '-z'`); + } +} +var init_diff = __esm2({ + "src/lib/tasks/diff.ts"() { + init_log_format(); + init_parse_diff_summary(); + init_task(); + } +}); +function prettyFormat(format, splitter) { + const fields = []; + const formatStr = []; + Object.keys(format).forEach((field) => { + fields.push(field); + formatStr.push(String(format[field])); + }); + return [fields, formatStr.join(splitter)]; +} +function userOptions(input) { + return Object.keys(input).reduce((out, key2) => { + if (!(key2 in excludeOptions)) { + out[key2] = input[key2]; + } + return out; + }, {}); +} +function parseLogOptions(opt = {}, customArgs = []) { + const splitter = filterType(opt.splitter, filterString, SPLITTER); + const format = !filterPrimitives(opt.format) && opt.format ? opt.format : { + hash: "%H", + date: opt.strictDate === false ? "%ai" : "%aI", + message: "%s", + refs: "%D", + body: opt.multiLine ? "%B" : "%b", + author_name: opt.mailMap !== false ? "%aN" : "%an", + author_email: opt.mailMap !== false ? "%aE" : "%ae" + }; + const [fields, formatStr] = prettyFormat(format, splitter); + const suffix = []; + const command = [ + `--pretty=format:${START_BOUNDARY}${formatStr}${COMMIT_BOUNDARY}`, + ...customArgs + ]; + const maxCount = opt.n || opt["max-count"] || opt.maxCount; + if (maxCount) { + command.push(`--max-count=${maxCount}`); + } + if (opt.from || opt.to) { + const rangeOperator = opt.symmetric !== false ? "..." : ".."; + suffix.push(`${opt.from || ""}${rangeOperator}${opt.to || ""}`); + } + if (filterString(opt.file)) { + suffix.push("--follow", opt.file); + } + appendTaskOptions(userOptions(opt), command); + return { + fields, + splitter, + commands: [...command, ...suffix] + }; +} +function logTask(splitter, fields, customArgs) { + const parser3 = createListLogSummaryParser(splitter, fields, logFormatFromCommand(customArgs)); + return { + commands: ["log", ...customArgs], + format: "utf-8", + parser: parser3 + }; +} +function log_default() { + return { + log(...rest) { + const next = trailingFunctionArgument(arguments); + const options = parseLogOptions(trailingOptionsArgument(arguments), filterType(arguments[0], filterArray)); + const task = rejectDeprecatedSignatures(...rest) || validateLogFormatConfig(options.commands) || createLogTask(options); + return this._runTask(task, next); + } + }; + function createLogTask(options) { + return logTask(options.splitter, options.fields, options.commands); + } + function rejectDeprecatedSignatures(from, to) { + return filterString(from) && filterString(to) && configurationErrorTask(`git.log(string, string) should be replaced with git.log({ from: string, to: string })`); + } +} +var excludeOptions; +var init_log = __esm2({ + "src/lib/tasks/log.ts"() { + init_log_format(); + init_parse_list_log_summary(); + init_utils(); + init_task(); + init_diff(); + excludeOptions = /* @__PURE__ */ ((excludeOptions2) => { + excludeOptions2[excludeOptions2["--pretty"] = 0] = "--pretty"; + excludeOptions2[excludeOptions2["max-count"] = 1] = "max-count"; + excludeOptions2[excludeOptions2["maxCount"] = 2] = "maxCount"; + excludeOptions2[excludeOptions2["n"] = 3] = "n"; + excludeOptions2[excludeOptions2["file"] = 4] = "file"; + excludeOptions2[excludeOptions2["format"] = 5] = "format"; + excludeOptions2[excludeOptions2["from"] = 6] = "from"; + excludeOptions2[excludeOptions2["to"] = 7] = "to"; + excludeOptions2[excludeOptions2["splitter"] = 8] = "splitter"; + excludeOptions2[excludeOptions2["symmetric"] = 9] = "symmetric"; + excludeOptions2[excludeOptions2["mailMap"] = 10] = "mailMap"; + excludeOptions2[excludeOptions2["multiLine"] = 11] = "multiLine"; + excludeOptions2[excludeOptions2["strictDate"] = 12] = "strictDate"; + return excludeOptions2; + })(excludeOptions || {}); + } +}); +var MergeSummaryConflict; +var MergeSummaryDetail; +var init_MergeSummary = __esm2({ + "src/lib/responses/MergeSummary.ts"() { + MergeSummaryConflict = class { + constructor(reason, file = null, meta) { + this.reason = reason; + this.file = file; + this.meta = meta; + } + toString() { + return `${this.file}:${this.reason}`; + } + }; + MergeSummaryDetail = class { + constructor() { + this.conflicts = []; + this.merges = []; + this.result = "success"; + } + get failed() { + return this.conflicts.length > 0; + } + get reason() { + return this.result; + } + toString() { + if (this.conflicts.length) { + return `CONFLICTS: ${this.conflicts.join(", ")}`; + } + return "OK"; + } + }; + } +}); +var PullSummary; +var PullFailedSummary; +var init_PullSummary = __esm2({ + "src/lib/responses/PullSummary.ts"() { + PullSummary = class { + constructor() { + this.remoteMessages = { + all: [] + }; + this.created = []; + this.deleted = []; + this.files = []; + this.deletions = {}; + this.insertions = {}; + this.summary = { + changes: 0, + deletions: 0, + insertions: 0 + }; + } + }; + PullFailedSummary = class { + constructor() { + this.remote = ""; + this.hash = { + local: "", + remote: "" + }; + this.branch = { + local: "", + remote: "" + }; + this.message = ""; + } + toString() { + return this.message; + } + }; + } +}); +function objectEnumerationResult(remoteMessages) { + return remoteMessages.objects = remoteMessages.objects || { + compressing: 0, + counting: 0, + enumerating: 0, + packReused: 0, + reused: { count: 0, delta: 0 }, + total: { count: 0, delta: 0 } + }; +} +function asObjectCount(source) { + const count = /^\s*(\d+)/.exec(source); + const delta = /delta (\d+)/i.exec(source); + return { + count: asNumber(count && count[1] || "0"), + delta: asNumber(delta && delta[1] || "0") + }; +} +var remoteMessagesObjectParsers; +var init_parse_remote_objects = __esm2({ + "src/lib/parsers/parse-remote-objects.ts"() { + init_utils(); + remoteMessagesObjectParsers = [ + new RemoteLineParser(/^remote:\s*(enumerating|counting|compressing) objects: (\d+),/i, (result, [action, count]) => { + const key2 = action.toLowerCase(); + const enumeration = objectEnumerationResult(result.remoteMessages); + Object.assign(enumeration, { [key2]: asNumber(count) }); + }), + new RemoteLineParser(/^remote:\s*(enumerating|counting|compressing) objects: \d+% \(\d+\/(\d+)\),/i, (result, [action, count]) => { + const key2 = action.toLowerCase(); + const enumeration = objectEnumerationResult(result.remoteMessages); + Object.assign(enumeration, { [key2]: asNumber(count) }); + }), + new RemoteLineParser(/total ([^,]+), reused ([^,]+), pack-reused (\d+)/i, (result, [total, reused, packReused]) => { + const objects = objectEnumerationResult(result.remoteMessages); + objects.total = asObjectCount(total); + objects.reused = asObjectCount(reused); + objects.packReused = asNumber(packReused); + }) + ]; + } +}); +function parseRemoteMessages(_stdOut, stdErr) { + return parseStringResponse({ remoteMessages: new RemoteMessageSummary() }, parsers2, stdErr); +} +var parsers2; +var RemoteMessageSummary; +var init_parse_remote_messages = __esm2({ + "src/lib/parsers/parse-remote-messages.ts"() { + init_utils(); + init_parse_remote_objects(); + parsers2 = [ + new RemoteLineParser(/^remote:\s*(.+)$/, (result, [text2]) => { + result.remoteMessages.all.push(text2.trim()); + return false; + }), + ...remoteMessagesObjectParsers, + new RemoteLineParser([/create a (?:pull|merge) request/i, /\s(https?:\/\/\S+)$/], (result, [pullRequestUrl]) => { + result.remoteMessages.pullRequestUrl = pullRequestUrl; + }), + new RemoteLineParser([/found (\d+) vulnerabilities.+\(([^)]+)\)/i, /\s(https?:\/\/\S+)$/], (result, [count, summary, url]) => { + result.remoteMessages.vulnerabilities = { + count: asNumber(count), + summary, + url + }; + }) + ]; + RemoteMessageSummary = class { + constructor() { + this.all = []; + } + }; + } +}); +function parsePullErrorResult(stdOut, stdErr) { + const pullError = parseStringResponse(new PullFailedSummary(), errorParsers, [stdOut, stdErr]); + return pullError.message && pullError; +} +var FILE_UPDATE_REGEX; +var SUMMARY_REGEX; +var ACTION_REGEX; +var parsers3; +var errorParsers; +var parsePullDetail; +var parsePullResult; +var init_parse_pull = __esm2({ + "src/lib/parsers/parse-pull.ts"() { + init_PullSummary(); + init_utils(); + init_parse_remote_messages(); + FILE_UPDATE_REGEX = /^\s*(.+?)\s+\|\s+\d+\s*(\+*)(-*)/; + SUMMARY_REGEX = /(\d+)\D+((\d+)\D+\(\+\))?(\D+(\d+)\D+\(-\))?/; + ACTION_REGEX = /^(create|delete) mode \d+ (.+)/; + parsers3 = [ + new LineParser(FILE_UPDATE_REGEX, (result, [file, insertions, deletions]) => { + result.files.push(file); + if (insertions) { + result.insertions[file] = insertions.length; + } + if (deletions) { + result.deletions[file] = deletions.length; + } + }), + new LineParser(SUMMARY_REGEX, (result, [changes, , insertions, , deletions]) => { + if (insertions !== void 0 || deletions !== void 0) { + result.summary.changes = +changes || 0; + result.summary.insertions = +insertions || 0; + result.summary.deletions = +deletions || 0; + return true; + } + return false; + }), + new LineParser(ACTION_REGEX, (result, [action, file]) => { + append(result.files, file); + append(action === "create" ? result.created : result.deleted, file); + }) + ]; + errorParsers = [ + new LineParser(/^from\s(.+)$/i, (result, [remote]) => void (result.remote = remote)), + new LineParser(/^fatal:\s(.+)$/, (result, [message]) => void (result.message = message)), + new LineParser(/([a-z0-9]+)\.\.([a-z0-9]+)\s+(\S+)\s+->\s+(\S+)$/, (result, [hashLocal, hashRemote, branchLocal, branchRemote]) => { + result.branch.local = branchLocal; + result.hash.local = hashLocal; + result.branch.remote = branchRemote; + result.hash.remote = hashRemote; + }) + ]; + parsePullDetail = (stdOut, stdErr) => { + return parseStringResponse(new PullSummary(), parsers3, [stdOut, stdErr]); + }; + parsePullResult = (stdOut, stdErr) => { + return Object.assign(new PullSummary(), parsePullDetail(stdOut, stdErr), parseRemoteMessages(stdOut, stdErr)); + }; + } +}); +var parsers4; +var parseMergeResult; +var parseMergeDetail; +var init_parse_merge = __esm2({ + "src/lib/parsers/parse-merge.ts"() { + init_MergeSummary(); + init_utils(); + init_parse_pull(); + parsers4 = [ + new LineParser(/^Auto-merging\s+(.+)$/, (summary, [autoMerge]) => { + summary.merges.push(autoMerge); + }), + new LineParser(/^CONFLICT\s+\((.+)\): Merge conflict in (.+)$/, (summary, [reason, file]) => { + summary.conflicts.push(new MergeSummaryConflict(reason, file)); + }), + new LineParser(/^CONFLICT\s+\((.+\/delete)\): (.+) deleted in (.+) and/, (summary, [reason, file, deleteRef2]) => { + summary.conflicts.push(new MergeSummaryConflict(reason, file, { deleteRef: deleteRef2 })); + }), + new LineParser(/^CONFLICT\s+\((.+)\):/, (summary, [reason]) => { + summary.conflicts.push(new MergeSummaryConflict(reason, null)); + }), + new LineParser(/^Automatic merge failed;\s+(.+)$/, (summary, [result]) => { + summary.result = result; + }) + ]; + parseMergeResult = (stdOut, stdErr) => { + return Object.assign(parseMergeDetail(stdOut, stdErr), parsePullResult(stdOut, stdErr)); + }; + parseMergeDetail = (stdOut) => { + return parseStringResponse(new MergeSummaryDetail(), parsers4, stdOut); + }; + } +}); +function mergeTask(customArgs) { + if (!customArgs.length) { + return configurationErrorTask("Git.merge requires at least one option"); + } + return { + commands: ["merge", ...customArgs], + format: "utf-8", + parser(stdOut, stdErr) { + const merge2 = parseMergeResult(stdOut, stdErr); + if (merge2.failed) { + throw new GitResponseError(merge2); + } + return merge2; + } + }; +} +var init_merge = __esm2({ + "src/lib/tasks/merge.ts"() { + init_git_response_error(); + init_parse_merge(); + init_task(); + } +}); +function pushResultPushedItem(local, remote, status2) { + const deleted = status2.includes("deleted"); + const tag2 = status2.includes("tag") || /^refs\/tags/.test(local); + const alreadyUpdated = !status2.includes("new"); + return { + deleted, + tag: tag2, + branch: !tag2, + new: !alreadyUpdated, + alreadyUpdated, + local, + remote + }; +} +var parsers5; +var parsePushResult; +var parsePushDetail; +var init_parse_push = __esm2({ + "src/lib/parsers/parse-push.ts"() { + init_utils(); + init_parse_remote_messages(); + parsers5 = [ + new LineParser(/^Pushing to (.+)$/, (result, [repo]) => { + result.repo = repo; + }), + new LineParser(/^updating local tracking ref '(.+)'/, (result, [local]) => { + result.ref = __spreadProps(__spreadValues({}, result.ref || {}), { + local + }); + }), + new LineParser(/^[=*-]\s+([^:]+):(\S+)\s+\[(.+)]$/, (result, [local, remote, type]) => { + result.pushed.push(pushResultPushedItem(local, remote, type)); + }), + new LineParser(/^Branch '([^']+)' set up to track remote branch '([^']+)' from '([^']+)'/, (result, [local, remote, remoteName]) => { + result.branch = __spreadProps(__spreadValues({}, result.branch || {}), { + local, + remote, + remoteName + }); + }), + new LineParser(/^([^:]+):(\S+)\s+([a-z0-9]+)\.\.([a-z0-9]+)$/, (result, [local, remote, from, to]) => { + result.update = { + head: { + local, + remote + }, + hash: { + from, + to + } + }; + }) + ]; + parsePushResult = (stdOut, stdErr) => { + const pushDetail = parsePushDetail(stdOut, stdErr); + const responseDetail = parseRemoteMessages(stdOut, stdErr); + return __spreadValues(__spreadValues({}, pushDetail), responseDetail); + }; + parsePushDetail = (stdOut, stdErr) => { + return parseStringResponse({ pushed: [] }, parsers5, [stdOut, stdErr]); + }; + } +}); +var push_exports = {}; +__export2(push_exports, { + pushTagsTask: () => pushTagsTask, + pushTask: () => pushTask +}); +function pushTagsTask(ref = {}, customArgs) { + append(customArgs, "--tags"); + return pushTask(ref, customArgs); +} +function pushTask(ref = {}, customArgs) { + const commands2 = ["push", ...customArgs]; + if (ref.branch) { + commands2.splice(1, 0, ref.branch); + } + if (ref.remote) { + commands2.splice(1, 0, ref.remote); + } + remove2(commands2, "-v"); + append(commands2, "--verbose"); + append(commands2, "--porcelain"); + return { + commands: commands2, + format: "utf-8", + parser: parsePushResult + }; +} +var init_push = __esm2({ + "src/lib/tasks/push.ts"() { + init_parse_push(); + init_utils(); + } +}); +var fromPathRegex; +var FileStatusSummary; +var init_FileStatusSummary = __esm2({ + "src/lib/responses/FileStatusSummary.ts"() { + fromPathRegex = /^(.+) -> (.+)$/; + FileStatusSummary = class { + constructor(path2, index2, working_dir) { + this.path = path2; + this.index = index2; + this.working_dir = working_dir; + if (index2 + working_dir === "R") { + const detail = fromPathRegex.exec(path2) || [null, path2, path2]; + this.from = detail[1] || ""; + this.path = detail[2] || ""; + } + } + }; + } +}); +function renamedFile(line) { + const [to, from] = line.split(NULL); + return { + from: from || to, + to + }; +} +function parser2(indexX, indexY, handler) { + return [`${indexX}${indexY}`, handler]; +} +function conflicts(indexX, ...indexY) { + return indexY.map((y) => parser2(indexX, y, (result, file) => append(result.conflicted, file))); +} +function splitLine(result, lineStr) { + const trimmed2 = lineStr.trim(); + switch (" ") { + case trimmed2.charAt(2): + return data(trimmed2.charAt(0), trimmed2.charAt(1), trimmed2.substr(3)); + case trimmed2.charAt(1): + return data(" ", trimmed2.charAt(0), trimmed2.substr(2)); + default: + return; + } + function data(index2, workingDir, path2) { + const raw = `${index2}${workingDir}`; + const handler = parsers6.get(raw); + if (handler) { + handler(result, path2); + } + if (raw !== "##" && raw !== "!!") { + result.files.push(new FileStatusSummary(path2.replace(/\0.+$/, ""), index2, workingDir)); + } + } +} +var StatusSummary; +var parsers6; +var parseStatusSummary; +var init_StatusSummary = __esm2({ + "src/lib/responses/StatusSummary.ts"() { + init_utils(); + init_FileStatusSummary(); + StatusSummary = class { + constructor() { + this.not_added = []; + this.conflicted = []; + this.created = []; + this.deleted = []; + this.ignored = void 0; + this.modified = []; + this.renamed = []; + this.files = []; + this.staged = []; + this.ahead = 0; + this.behind = 0; + this.current = null; + this.tracking = null; + this.detached = false; + this.isClean = () => { + return !this.files.length; + }; + } + }; + parsers6 = new Map([ + parser2(" ", "A", (result, file) => append(result.created, file)), + parser2(" ", "D", (result, file) => append(result.deleted, file)), + parser2(" ", "M", (result, file) => append(result.modified, file)), + parser2("A", " ", (result, file) => append(result.created, file) && append(result.staged, file)), + parser2("A", "M", (result, file) => append(result.created, file) && append(result.staged, file) && append(result.modified, file)), + parser2("D", " ", (result, file) => append(result.deleted, file) && append(result.staged, file)), + parser2("M", " ", (result, file) => append(result.modified, file) && append(result.staged, file)), + parser2("M", "M", (result, file) => append(result.modified, file) && append(result.staged, file)), + parser2("R", " ", (result, file) => { + append(result.renamed, renamedFile(file)); + }), + parser2("R", "M", (result, file) => { + const renamed = renamedFile(file); + append(result.renamed, renamed); + append(result.modified, renamed.to); + }), + parser2("!", "!", (_result, _file) => { + append(_result.ignored = _result.ignored || [], _file); + }), + parser2("?", "?", (result, file) => append(result.not_added, file)), + ...conflicts( + "A", + "A", + "U" + /* UNMERGED */ + ), + ...conflicts( + "D", + "D", + "U" + /* UNMERGED */ + ), + ...conflicts( + "U", + "A", + "D", + "U" + /* UNMERGED */ + ), + [ + "##", + (result, line) => { + const aheadReg = /ahead (\d+)/; + const behindReg = /behind (\d+)/; + const currentReg = /^(.+?(?=(?:\.{3}|\s|$)))/; + const trackingReg = /\.{3}(\S*)/; + const onEmptyBranchReg = /\son\s([\S]+)$/; + let regexResult; + regexResult = aheadReg.exec(line); + result.ahead = regexResult && +regexResult[1] || 0; + regexResult = behindReg.exec(line); + result.behind = regexResult && +regexResult[1] || 0; + regexResult = currentReg.exec(line); + result.current = regexResult && regexResult[1]; + regexResult = trackingReg.exec(line); + result.tracking = regexResult && regexResult[1]; + regexResult = onEmptyBranchReg.exec(line); + result.current = regexResult && regexResult[1] || result.current; + result.detached = /\(no branch\)/.test(line); + } + ] + ]); + parseStatusSummary = function(text2) { + const lines = text2.split(NULL); + const status2 = new StatusSummary(); + for (let i = 0, l = lines.length; i < l; ) { + let line = lines[i++].trim(); + if (!line) { + continue; + } + if (line.charAt(0) === "R") { + line += NULL + (lines[i++] || ""); + } + splitLine(status2, line); + } + return status2; + }; + } +}); +function statusTask(customArgs) { + const commands2 = [ + "status", + "--porcelain", + "-b", + "-u", + "--null", + ...customArgs.filter((arg) => !ignoredOptions.includes(arg)) + ]; + return { + format: "utf-8", + commands: commands2, + parser(text2) { + return parseStatusSummary(text2); + } + }; +} +var ignoredOptions; +var init_status = __esm2({ + "src/lib/tasks/status.ts"() { + init_StatusSummary(); + ignoredOptions = ["--null", "-z"]; + } +}); +function versionResponse(major = 0, minor = 0, patch = 0, agent = "", installed = true) { + return Object.defineProperty({ + major, + minor, + patch, + agent, + installed + }, "toString", { + value() { + return `${this.major}.${this.minor}.${this.patch}`; + }, + configurable: false, + enumerable: false + }); +} +function notInstalledResponse() { + return versionResponse(0, 0, 0, "", false); +} +function version_default() { + return { + version() { + return this._runTask({ + commands: ["--version"], + format: "utf-8", + parser: versionParser, + onError(result, error, done, fail) { + if (result.exitCode === -2) { + return done(Buffer.from(NOT_INSTALLED)); + } + fail(error); + } + }); + } + }; +} +function versionParser(stdOut) { + if (stdOut === NOT_INSTALLED) { + return notInstalledResponse(); + } + return parseStringResponse(versionResponse(0, 0, 0, stdOut), parsers7, stdOut); +} +var NOT_INSTALLED; +var parsers7; +var init_version = __esm2({ + "src/lib/tasks/version.ts"() { + init_utils(); + NOT_INSTALLED = "installed=false"; + parsers7 = [ + new LineParser(/version (\d+)\.(\d+)\.(\d+)(?:\s*\((.+)\))?/, (result, [major, minor, patch, agent = ""]) => { + Object.assign(result, versionResponse(asNumber(major), asNumber(minor), asNumber(patch), agent)); + }), + new LineParser(/version (\d+)\.(\d+)\.(\D+)(.+)?$/, (result, [major, minor, patch, agent = ""]) => { + Object.assign(result, versionResponse(asNumber(major), asNumber(minor), patch, agent)); + }) + ]; + } +}); +var simple_git_api_exports = {}; +__export2(simple_git_api_exports, { + SimpleGitApi: () => SimpleGitApi +}); +var SimpleGitApi; +var init_simple_git_api = __esm2({ + "src/lib/simple-git-api.ts"() { + init_task_callback(); + init_change_working_directory(); + init_checkout(); + init_commit(); + init_config(); + init_grep(); + init_hash_object(); + init_init(); + init_log(); + init_merge(); + init_push(); + init_status(); + init_task(); + init_version(); + init_utils(); + SimpleGitApi = class { + constructor(_executor) { + this._executor = _executor; + } + _runTask(task, then) { + const chain = this._executor.chain(); + const promise2 = chain.push(task); + if (then) { + taskCallback(task, promise2, then); + } + return Object.create(this, { + then: { value: promise2.then.bind(promise2) }, + catch: { value: promise2.catch.bind(promise2) }, + _executor: { value: chain } + }); + } + add(files) { + return this._runTask(straightThroughStringTask(["add", ...asArray(files)]), trailingFunctionArgument(arguments)); + } + cwd(directory) { + const next = trailingFunctionArgument(arguments); + if (typeof directory === "string") { + return this._runTask(changeWorkingDirectoryTask(directory, this._executor), next); + } + if (typeof (directory == null ? void 0 : directory.path) === "string") { + return this._runTask(changeWorkingDirectoryTask(directory.path, directory.root && this._executor || void 0), next); + } + return this._runTask(configurationErrorTask("Git.cwd: workingDirectory must be supplied as a string"), next); + } + hashObject(path2, write) { + return this._runTask(hashObjectTask(path2, write === true), trailingFunctionArgument(arguments)); + } + init(bare) { + return this._runTask(initTask(bare === true, this._executor.cwd, getTrailingOptions(arguments)), trailingFunctionArgument(arguments)); + } + merge() { + return this._runTask(mergeTask(getTrailingOptions(arguments)), trailingFunctionArgument(arguments)); + } + mergeFromTo(remote, branch2) { + if (!(filterString(remote) && filterString(branch2))) { + return this._runTask(configurationErrorTask(`Git.mergeFromTo requires that the 'remote' and 'branch' arguments are supplied as strings`)); + } + return this._runTask(mergeTask([remote, branch2, ...getTrailingOptions(arguments)]), trailingFunctionArgument(arguments, false)); + } + outputHandler(handler) { + this._executor.outputHandler = handler; + return this; + } + push() { + const task = pushTask({ + remote: filterType(arguments[0], filterString), + branch: filterType(arguments[1], filterString) + }, getTrailingOptions(arguments)); + return this._runTask(task, trailingFunctionArgument(arguments)); + } + stash() { + return this._runTask(straightThroughStringTask(["stash", ...getTrailingOptions(arguments)]), trailingFunctionArgument(arguments)); + } + status() { + return this._runTask(statusTask(getTrailingOptions(arguments)), trailingFunctionArgument(arguments)); + } + }; + Object.assign(SimpleGitApi.prototype, checkout_default(), commit_default(), config_default(), grep_default(), log_default(), version_default()); + } +}); +var scheduler_exports = {}; +__export2(scheduler_exports, { + Scheduler: () => Scheduler +}); +var createScheduledTask; +var Scheduler; +var init_scheduler = __esm2({ + "src/lib/runners/scheduler.ts"() { + init_utils(); + init_git_logger(); + createScheduledTask = (() => { + let id = 0; + return () => { + id++; + const { promise: promise2, done } = (0, import_promise_deferred.createDeferred)(); + return { + promise: promise2, + done, + id + }; + }; + })(); + Scheduler = class { + constructor(concurrency = 2) { + this.concurrency = concurrency; + this.logger = createLogger("", "scheduler"); + this.pending = []; + this.running = []; + this.logger(`Constructed, concurrency=%s`, concurrency); + } + schedule() { + if (!this.pending.length || this.running.length >= this.concurrency) { + this.logger(`Schedule attempt ignored, pending=%s running=%s concurrency=%s`, this.pending.length, this.running.length, this.concurrency); + return; + } + const task = append(this.running, this.pending.shift()); + this.logger(`Attempting id=%s`, task.id); + task.done(() => { + this.logger(`Completing id=`, task.id); + remove2(this.running, task); + this.schedule(); + }); + } + next() { + const { promise: promise2, id } = append(this.pending, createScheduledTask()); + this.logger(`Scheduling id=%s`, id); + this.schedule(); + return promise2; + } + }; + } +}); +var apply_patch_exports = {}; +__export2(apply_patch_exports, { + applyPatchTask: () => applyPatchTask +}); +function applyPatchTask(patches, customArgs) { + return straightThroughStringTask(["apply", ...customArgs, ...patches]); +} +var init_apply_patch = __esm2({ + "src/lib/tasks/apply-patch.ts"() { + init_task(); + } +}); +function branchDeletionSuccess(branch2, hash2) { + return { + branch: branch2, + hash: hash2, + success: true + }; +} +function branchDeletionFailure(branch2) { + return { + branch: branch2, + hash: null, + success: false + }; +} +var BranchDeletionBatch; +var init_BranchDeleteSummary = __esm2({ + "src/lib/responses/BranchDeleteSummary.ts"() { + BranchDeletionBatch = class { + constructor() { + this.all = []; + this.branches = {}; + this.errors = []; + } + get success() { + return !this.errors.length; + } + }; + } +}); +function hasBranchDeletionError(data, processExitCode) { + return processExitCode === 1 && deleteErrorRegex.test(data); +} +var deleteSuccessRegex; +var deleteErrorRegex; +var parsers8; +var parseBranchDeletions; +var init_parse_branch_delete = __esm2({ + "src/lib/parsers/parse-branch-delete.ts"() { + init_BranchDeleteSummary(); + init_utils(); + deleteSuccessRegex = /(\S+)\s+\(\S+\s([^)]+)\)/; + deleteErrorRegex = /^error[^']+'([^']+)'/m; + parsers8 = [ + new LineParser(deleteSuccessRegex, (result, [branch2, hash2]) => { + const deletion = branchDeletionSuccess(branch2, hash2); + result.all.push(deletion); + result.branches[branch2] = deletion; + }), + new LineParser(deleteErrorRegex, (result, [branch2]) => { + const deletion = branchDeletionFailure(branch2); + result.errors.push(deletion); + result.all.push(deletion); + result.branches[branch2] = deletion; + }) + ]; + parseBranchDeletions = (stdOut, stdErr) => { + return parseStringResponse(new BranchDeletionBatch(), parsers8, [stdOut, stdErr]); + }; + } +}); +var BranchSummaryResult; +var init_BranchSummary = __esm2({ + "src/lib/responses/BranchSummary.ts"() { + BranchSummaryResult = class { + constructor() { + this.all = []; + this.branches = {}; + this.current = ""; + this.detached = false; + } + push(status2, detached, name, commit2, label) { + if (status2 === "*") { + this.detached = detached; + this.current = name; + } + this.all.push(name); + this.branches[name] = { + current: status2 === "*", + linkedWorkTree: status2 === "+", + name, + commit: commit2, + label + }; + } + }; + } +}); +function branchStatus(input) { + return input ? input.charAt(0) : ""; +} +function parseBranchSummary(stdOut) { + return parseStringResponse(new BranchSummaryResult(), parsers9, stdOut); +} +var parsers9; +var init_parse_branch = __esm2({ + "src/lib/parsers/parse-branch.ts"() { + init_BranchSummary(); + init_utils(); + parsers9 = [ + new LineParser(/^([*+]\s)?\((?:HEAD )?detached (?:from|at) (\S+)\)\s+([a-z0-9]+)\s(.*)$/, (result, [current, name, commit2, label]) => { + result.push(branchStatus(current), true, name, commit2, label); + }), + new LineParser(/^([*+]\s)?(\S+)\s+([a-z0-9]+)\s?(.*)$/s, (result, [current, name, commit2, label]) => { + result.push(branchStatus(current), false, name, commit2, label); + }) + ]; + } +}); +var branch_exports = {}; +__export2(branch_exports, { + branchLocalTask: () => branchLocalTask, + branchTask: () => branchTask, + containsDeleteBranchCommand: () => containsDeleteBranchCommand, + deleteBranchTask: () => deleteBranchTask, + deleteBranchesTask: () => deleteBranchesTask +}); +function containsDeleteBranchCommand(commands2) { + const deleteCommands = ["-d", "-D", "--delete"]; + return commands2.some((command) => deleteCommands.includes(command)); +} +function branchTask(customArgs) { + const isDelete = containsDeleteBranchCommand(customArgs); + const commands2 = ["branch", ...customArgs]; + if (commands2.length === 1) { + commands2.push("-a"); + } + if (!commands2.includes("-v")) { + commands2.splice(1, 0, "-v"); + } + return { + format: "utf-8", + commands: commands2, + parser(stdOut, stdErr) { + if (isDelete) { + return parseBranchDeletions(stdOut, stdErr).all[0]; + } + return parseBranchSummary(stdOut); + } + }; +} +function branchLocalTask() { + const parser3 = parseBranchSummary; + return { + format: "utf-8", + commands: ["branch", "-v"], + parser: parser3 + }; +} +function deleteBranchesTask(branches, forceDelete = false) { + return { + format: "utf-8", + commands: ["branch", "-v", forceDelete ? "-D" : "-d", ...branches], + parser(stdOut, stdErr) { + return parseBranchDeletions(stdOut, stdErr); + }, + onError({ exitCode, stdOut }, error, done, fail) { + if (!hasBranchDeletionError(String(error), exitCode)) { + return fail(error); + } + done(stdOut); + } + }; +} +function deleteBranchTask(branch2, forceDelete = false) { + const task = { + format: "utf-8", + commands: ["branch", "-v", forceDelete ? "-D" : "-d", branch2], + parser(stdOut, stdErr) { + return parseBranchDeletions(stdOut, stdErr).branches[branch2]; + }, + onError({ exitCode, stdErr, stdOut }, error, _, fail) { + if (!hasBranchDeletionError(String(error), exitCode)) { + return fail(error); + } + throw new GitResponseError(task.parser(bufferToString(stdOut), bufferToString(stdErr)), String(error)); + } + }; + return task; +} +var init_branch = __esm2({ + "src/lib/tasks/branch.ts"() { + init_git_response_error(); + init_parse_branch_delete(); + init_parse_branch(); + init_utils(); + } +}); +var parseCheckIgnore; +var init_CheckIgnore = __esm2({ + "src/lib/responses/CheckIgnore.ts"() { + parseCheckIgnore = (text2) => { + return text2.split(/\n/g).map((line) => line.trim()).filter((file) => !!file); + }; + } +}); +var check_ignore_exports = {}; +__export2(check_ignore_exports, { + checkIgnoreTask: () => checkIgnoreTask +}); +function checkIgnoreTask(paths) { + return { + commands: ["check-ignore", ...paths], + format: "utf-8", + parser: parseCheckIgnore + }; +} +var init_check_ignore = __esm2({ + "src/lib/tasks/check-ignore.ts"() { + init_CheckIgnore(); + } +}); +var clone_exports = {}; +__export2(clone_exports, { + cloneMirrorTask: () => cloneMirrorTask, + cloneTask: () => cloneTask +}); +function disallowedCommand(command) { + return /^--upload-pack(=|$)/.test(command); +} +function cloneTask(repo, directory, customArgs) { + const commands2 = ["clone", ...customArgs]; + filterString(repo) && commands2.push(repo); + filterString(directory) && commands2.push(directory); + const banned = commands2.find(disallowedCommand); + if (banned) { + return configurationErrorTask(`git.fetch: potential exploit argument blocked.`); + } + return straightThroughStringTask(commands2); +} +function cloneMirrorTask(repo, directory, customArgs) { + append(customArgs, "--mirror"); + return cloneTask(repo, directory, customArgs); +} +var init_clone = __esm2({ + "src/lib/tasks/clone.ts"() { + init_task(); + init_utils(); + } +}); +function parseFetchResult(stdOut, stdErr) { + const result = { + raw: stdOut, + remote: null, + branches: [], + tags: [], + updated: [], + deleted: [] + }; + return parseStringResponse(result, parsers10, [stdOut, stdErr]); +} +var parsers10; +var init_parse_fetch = __esm2({ + "src/lib/parsers/parse-fetch.ts"() { + init_utils(); + parsers10 = [ + new LineParser(/From (.+)$/, (result, [remote]) => { + result.remote = remote; + }), + new LineParser(/\* \[new branch]\s+(\S+)\s*-> (.+)$/, (result, [name, tracking]) => { + result.branches.push({ + name, + tracking + }); + }), + new LineParser(/\* \[new tag]\s+(\S+)\s*-> (.+)$/, (result, [name, tracking]) => { + result.tags.push({ + name, + tracking + }); + }), + new LineParser(/- \[deleted]\s+\S+\s*-> (.+)$/, (result, [tracking]) => { + result.deleted.push({ + tracking + }); + }), + new LineParser(/\s*([^.]+)\.\.(\S+)\s+(\S+)\s*-> (.+)$/, (result, [from, to, name, tracking]) => { + result.updated.push({ + name, + tracking, + to, + from + }); + }) + ]; + } +}); +var fetch_exports = {}; +__export2(fetch_exports, { + fetchTask: () => fetchTask +}); +function disallowedCommand2(command) { + return /^--upload-pack(=|$)/.test(command); +} +function fetchTask(remote, branch2, customArgs) { + const commands2 = ["fetch", ...customArgs]; + if (remote && branch2) { + commands2.push(remote, branch2); + } + const banned = commands2.find(disallowedCommand2); + if (banned) { + return configurationErrorTask(`git.fetch: potential exploit argument blocked.`); + } + return { + commands: commands2, + format: "utf-8", + parser: parseFetchResult + }; +} +var init_fetch = __esm2({ + "src/lib/tasks/fetch.ts"() { + init_parse_fetch(); + init_task(); + } +}); +function parseMoveResult(stdOut) { + return parseStringResponse({ moves: [] }, parsers11, stdOut); +} +var parsers11; +var init_parse_move = __esm2({ + "src/lib/parsers/parse-move.ts"() { + init_utils(); + parsers11 = [ + new LineParser(/^Renaming (.+) to (.+)$/, (result, [from, to]) => { + result.moves.push({ from, to }); + }) + ]; + } +}); +var move_exports = {}; +__export2(move_exports, { + moveTask: () => moveTask +}); +function moveTask(from, to) { + return { + commands: ["mv", "-v", ...asArray(from), to], + format: "utf-8", + parser: parseMoveResult + }; +} +var init_move = __esm2({ + "src/lib/tasks/move.ts"() { + init_parse_move(); + init_utils(); + } +}); +var pull_exports = {}; +__export2(pull_exports, { + pullTask: () => pullTask +}); +function pullTask(remote, branch2, customArgs) { + const commands2 = ["pull", ...customArgs]; + if (remote && branch2) { + commands2.splice(1, 0, remote, branch2); + } + return { + commands: commands2, + format: "utf-8", + parser(stdOut, stdErr) { + return parsePullResult(stdOut, stdErr); + }, + onError(result, _error, _done, fail) { + const pullError = parsePullErrorResult(bufferToString(result.stdOut), bufferToString(result.stdErr)); + if (pullError) { + return fail(new GitResponseError(pullError)); + } + fail(_error); + } + }; +} +var init_pull = __esm2({ + "src/lib/tasks/pull.ts"() { + init_git_response_error(); + init_parse_pull(); + init_utils(); + } +}); +function parseGetRemotes(text2) { + const remotes = {}; + forEach(text2, ([name]) => remotes[name] = { name }); + return Object.values(remotes); +} +function parseGetRemotesVerbose(text2) { + const remotes = {}; + forEach(text2, ([name, url, purpose]) => { + if (!remotes.hasOwnProperty(name)) { + remotes[name] = { + name, + refs: { fetch: "", push: "" } + }; + } + if (purpose && url) { + remotes[name].refs[purpose.replace(/[^a-z]/g, "")] = url; + } + }); + return Object.values(remotes); +} +function forEach(text2, handler) { + forEachLineWithContent(text2, (line) => handler(line.split(/\s+/))); +} +var init_GetRemoteSummary = __esm2({ + "src/lib/responses/GetRemoteSummary.ts"() { + init_utils(); + } +}); +var remote_exports = {}; +__export2(remote_exports, { + addRemoteTask: () => addRemoteTask, + getRemotesTask: () => getRemotesTask, + listRemotesTask: () => listRemotesTask, + remoteTask: () => remoteTask, + removeRemoteTask: () => removeRemoteTask +}); +function addRemoteTask(remoteName, remoteRepo, customArgs = []) { + return straightThroughStringTask(["remote", "add", ...customArgs, remoteName, remoteRepo]); +} +function getRemotesTask(verbose) { + const commands2 = ["remote"]; + if (verbose) { + commands2.push("-v"); + } + return { + commands: commands2, + format: "utf-8", + parser: verbose ? parseGetRemotesVerbose : parseGetRemotes + }; +} +function listRemotesTask(customArgs = []) { + const commands2 = [...customArgs]; + if (commands2[0] !== "ls-remote") { + commands2.unshift("ls-remote"); + } + return straightThroughStringTask(commands2); +} +function remoteTask(customArgs = []) { + const commands2 = [...customArgs]; + if (commands2[0] !== "remote") { + commands2.unshift("remote"); + } + return straightThroughStringTask(commands2); +} +function removeRemoteTask(remoteName) { + return straightThroughStringTask(["remote", "remove", remoteName]); +} +var init_remote = __esm2({ + "src/lib/tasks/remote.ts"() { + init_GetRemoteSummary(); + init_task(); + } +}); +var stash_list_exports = {}; +__export2(stash_list_exports, { + stashListTask: () => stashListTask +}); +function stashListTask(opt = {}, customArgs) { + const options = parseLogOptions(opt); + const commands2 = ["stash", "list", ...options.commands, ...customArgs]; + const parser3 = createListLogSummaryParser(options.splitter, options.fields, logFormatFromCommand(commands2)); + return validateLogFormatConfig(commands2) || { + commands: commands2, + format: "utf-8", + parser: parser3 + }; +} +var init_stash_list = __esm2({ + "src/lib/tasks/stash-list.ts"() { + init_log_format(); + init_parse_list_log_summary(); + init_diff(); + init_log(); + } +}); +var sub_module_exports = {}; +__export2(sub_module_exports, { + addSubModuleTask: () => addSubModuleTask, + initSubModuleTask: () => initSubModuleTask, + subModuleTask: () => subModuleTask, + updateSubModuleTask: () => updateSubModuleTask +}); +function addSubModuleTask(repo, path2) { + return subModuleTask(["add", repo, path2]); +} +function initSubModuleTask(customArgs) { + return subModuleTask(["init", ...customArgs]); +} +function subModuleTask(customArgs) { + const commands2 = [...customArgs]; + if (commands2[0] !== "submodule") { + commands2.unshift("submodule"); + } + return straightThroughStringTask(commands2); +} +function updateSubModuleTask(customArgs) { + return subModuleTask(["update", ...customArgs]); +} +var init_sub_module = __esm2({ + "src/lib/tasks/sub-module.ts"() { + init_task(); + } +}); +function singleSorted(a, b) { + const aIsNum = isNaN(a); + const bIsNum = isNaN(b); + if (aIsNum !== bIsNum) { + return aIsNum ? 1 : -1; + } + return aIsNum ? sorted(a, b) : 0; +} +function sorted(a, b) { + return a === b ? 0 : a > b ? 1 : -1; +} +function trimmed(input) { + return input.trim(); +} +function toNumber(input) { + if (typeof input === "string") { + return parseInt(input.replace(/^\D+/g, ""), 10) || 0; + } + return 0; +} +var TagList; +var parseTagList; +var init_TagList = __esm2({ + "src/lib/responses/TagList.ts"() { + TagList = class { + constructor(all, latest) { + this.all = all; + this.latest = latest; + } + }; + parseTagList = function(data, customSort = false) { + const tags = data.split("\n").map(trimmed).filter(Boolean); + if (!customSort) { + tags.sort(function(tagA, tagB) { + const partsA = tagA.split("."); + const partsB = tagB.split("."); + if (partsA.length === 1 || partsB.length === 1) { + return singleSorted(toNumber(partsA[0]), toNumber(partsB[0])); + } + for (let i = 0, l = Math.max(partsA.length, partsB.length); i < l; i++) { + const diff2 = sorted(toNumber(partsA[i]), toNumber(partsB[i])); + if (diff2) { + return diff2; + } + } + return 0; + }); + } + const latest = customSort ? tags[0] : [...tags].reverse().find((tag2) => tag2.indexOf(".") >= 0); + return new TagList(tags, latest); + }; + } +}); +var tag_exports = {}; +__export2(tag_exports, { + addAnnotatedTagTask: () => addAnnotatedTagTask, + addTagTask: () => addTagTask, + tagListTask: () => tagListTask +}); +function tagListTask(customArgs = []) { + const hasCustomSort = customArgs.some((option) => /^--sort=/.test(option)); + return { + format: "utf-8", + commands: ["tag", "-l", ...customArgs], + parser(text2) { + return parseTagList(text2, hasCustomSort); + } + }; +} +function addTagTask(name) { + return { + format: "utf-8", + commands: ["tag", name], + parser() { + return { name }; + } + }; +} +function addAnnotatedTagTask(name, tagMessage) { + return { + format: "utf-8", + commands: ["tag", "-a", "-m", tagMessage, name], + parser() { + return { name }; + } + }; +} +var init_tag = __esm2({ + "src/lib/tasks/tag.ts"() { + init_TagList(); + } +}); +var require_git = __commonJS2({ + "src/git.js"(exports2, module2) { + var { GitExecutor: GitExecutor2 } = (init_git_executor(), __toCommonJS2(git_executor_exports)); + var { SimpleGitApi: SimpleGitApi2 } = (init_simple_git_api(), __toCommonJS2(simple_git_api_exports)); + var { Scheduler: Scheduler2 } = (init_scheduler(), __toCommonJS2(scheduler_exports)); + var { configurationErrorTask: configurationErrorTask2 } = (init_task(), __toCommonJS2(task_exports)); + var { + asArray: asArray2, + filterArray: filterArray2, + filterPrimitives: filterPrimitives2, + filterString: filterString2, + filterStringOrStringArray: filterStringOrStringArray2, + filterType: filterType2, + getTrailingOptions: getTrailingOptions2, + trailingFunctionArgument: trailingFunctionArgument2, + trailingOptionsArgument: trailingOptionsArgument2 + } = (init_utils(), __toCommonJS2(utils_exports)); + var { applyPatchTask: applyPatchTask2 } = (init_apply_patch(), __toCommonJS2(apply_patch_exports)); + var { + branchTask: branchTask2, + branchLocalTask: branchLocalTask2, + deleteBranchesTask: deleteBranchesTask2, + deleteBranchTask: deleteBranchTask2 + } = (init_branch(), __toCommonJS2(branch_exports)); + var { checkIgnoreTask: checkIgnoreTask2 } = (init_check_ignore(), __toCommonJS2(check_ignore_exports)); + var { checkIsRepoTask: checkIsRepoTask2 } = (init_check_is_repo(), __toCommonJS2(check_is_repo_exports)); + var { cloneTask: cloneTask2, cloneMirrorTask: cloneMirrorTask2 } = (init_clone(), __toCommonJS2(clone_exports)); + var { cleanWithOptionsTask: cleanWithOptionsTask2, isCleanOptionsArray: isCleanOptionsArray2 } = (init_clean(), __toCommonJS2(clean_exports)); + var { diffSummaryTask: diffSummaryTask2 } = (init_diff(), __toCommonJS2(diff_exports)); + var { fetchTask: fetchTask2 } = (init_fetch(), __toCommonJS2(fetch_exports)); + var { moveTask: moveTask2 } = (init_move(), __toCommonJS2(move_exports)); + var { pullTask: pullTask2 } = (init_pull(), __toCommonJS2(pull_exports)); + var { pushTagsTask: pushTagsTask2 } = (init_push(), __toCommonJS2(push_exports)); + var { + addRemoteTask: addRemoteTask2, + getRemotesTask: getRemotesTask2, + listRemotesTask: listRemotesTask2, + remoteTask: remoteTask2, + removeRemoteTask: removeRemoteTask2 + } = (init_remote(), __toCommonJS2(remote_exports)); + var { getResetMode: getResetMode2, resetTask: resetTask2 } = (init_reset(), __toCommonJS2(reset_exports)); + var { stashListTask: stashListTask2 } = (init_stash_list(), __toCommonJS2(stash_list_exports)); + var { + addSubModuleTask: addSubModuleTask2, + initSubModuleTask: initSubModuleTask2, + subModuleTask: subModuleTask2, + updateSubModuleTask: updateSubModuleTask2 + } = (init_sub_module(), __toCommonJS2(sub_module_exports)); + var { addAnnotatedTagTask: addAnnotatedTagTask2, addTagTask: addTagTask2, tagListTask: tagListTask2 } = (init_tag(), __toCommonJS2(tag_exports)); + var { straightThroughBufferTask: straightThroughBufferTask2, straightThroughStringTask: straightThroughStringTask2 } = (init_task(), __toCommonJS2(task_exports)); + function Git2(options, plugins) { + this._executor = new GitExecutor2(options.binary, options.baseDir, new Scheduler2(options.maxConcurrentProcesses), plugins); + this._trimmed = options.trimmed; + } + (Git2.prototype = Object.create(SimpleGitApi2.prototype)).constructor = Git2; + Git2.prototype.customBinary = function(command) { + this._executor.binary = command; + return this; + }; + Git2.prototype.env = function(name, value) { + if (arguments.length === 1 && typeof name === "object") { + this._executor.env = name; + } else { + (this._executor.env = this._executor.env || {})[name] = value; + } + return this; + }; + Git2.prototype.stashList = function(options) { + return this._runTask(stashListTask2(trailingOptionsArgument2(arguments) || {}, filterArray2(options) && options || []), trailingFunctionArgument2(arguments)); + }; + function createCloneTask(api, task, repoPath, localPath) { + if (typeof repoPath !== "string") { + return configurationErrorTask2(`git.${api}() requires a string 'repoPath'`); + } + return task(repoPath, filterType2(localPath, filterString2), getTrailingOptions2(arguments)); + } + Git2.prototype.clone = function() { + return this._runTask(createCloneTask("clone", cloneTask2, ...arguments), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.mirror = function() { + return this._runTask(createCloneTask("mirror", cloneMirrorTask2, ...arguments), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.mv = function(from, to) { + return this._runTask(moveTask2(from, to), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.checkoutLatestTag = function(then) { + var git = this; + return this.pull(function() { + git.tags(function(err, tags) { + git.checkout(tags.latest, then); + }); + }); + }; + Git2.prototype.pull = function(remote, branch2, options, then) { + return this._runTask(pullTask2(filterType2(remote, filterString2), filterType2(branch2, filterString2), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.fetch = function(remote, branch2) { + return this._runTask(fetchTask2(filterType2(remote, filterString2), filterType2(branch2, filterString2), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.silent = function(silence) { + console.warn("simple-git deprecation notice: git.silent: logging should be configured using the `debug` library / `DEBUG` environment variable, this will be an error in version 3"); + return this; + }; + Git2.prototype.tags = function(options, then) { + return this._runTask(tagListTask2(getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.rebase = function() { + return this._runTask(straightThroughStringTask2(["rebase", ...getTrailingOptions2(arguments)]), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.reset = function(mode) { + return this._runTask(resetTask2(getResetMode2(mode), getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.revert = function(commit2) { + const next = trailingFunctionArgument2(arguments); + if (typeof commit2 !== "string") { + return this._runTask(configurationErrorTask2("Commit must be a string"), next); + } + return this._runTask(straightThroughStringTask2(["revert", ...getTrailingOptions2(arguments, 0, true), commit2]), next); + }; + Git2.prototype.addTag = function(name) { + const task = typeof name === "string" ? addTagTask2(name) : configurationErrorTask2("Git.addTag requires a tag name"); + return this._runTask(task, trailingFunctionArgument2(arguments)); + }; + Git2.prototype.addAnnotatedTag = function(tagName, tagMessage) { + return this._runTask(addAnnotatedTagTask2(tagName, tagMessage), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.deleteLocalBranch = function(branchName, forceDelete, then) { + return this._runTask(deleteBranchTask2(branchName, typeof forceDelete === "boolean" ? forceDelete : false), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.deleteLocalBranches = function(branchNames, forceDelete, then) { + return this._runTask(deleteBranchesTask2(branchNames, typeof forceDelete === "boolean" ? forceDelete : false), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.branch = function(options, then) { + return this._runTask(branchTask2(getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.branchLocal = function(then) { + return this._runTask(branchLocalTask2(), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.raw = function(commands2) { + const createRestCommands = !Array.isArray(commands2); + const command = [].slice.call(createRestCommands ? arguments : commands2, 0); + for (let i = 0; i < command.length && createRestCommands; i++) { + if (!filterPrimitives2(command[i])) { + command.splice(i, command.length - i); + break; + } + } + command.push(...getTrailingOptions2(arguments, 0, true)); + var next = trailingFunctionArgument2(arguments); + if (!command.length) { + return this._runTask(configurationErrorTask2("Raw: must supply one or more command to execute"), next); + } + return this._runTask(straightThroughStringTask2(command, this._trimmed), next); + }; + Git2.prototype.submoduleAdd = function(repo, path2, then) { + return this._runTask(addSubModuleTask2(repo, path2), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.submoduleUpdate = function(args, then) { + return this._runTask(updateSubModuleTask2(getTrailingOptions2(arguments, true)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.submoduleInit = function(args, then) { + return this._runTask(initSubModuleTask2(getTrailingOptions2(arguments, true)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.subModule = function(options, then) { + return this._runTask(subModuleTask2(getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.listRemote = function() { + return this._runTask(listRemotesTask2(getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.addRemote = function(remoteName, remoteRepo, then) { + return this._runTask(addRemoteTask2(remoteName, remoteRepo, getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.removeRemote = function(remoteName, then) { + return this._runTask(removeRemoteTask2(remoteName), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.getRemotes = function(verbose, then) { + return this._runTask(getRemotesTask2(verbose === true), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.remote = function(options, then) { + return this._runTask(remoteTask2(getTrailingOptions2(arguments)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.tag = function(options, then) { + const command = getTrailingOptions2(arguments); + if (command[0] !== "tag") { + command.unshift("tag"); + } + return this._runTask(straightThroughStringTask2(command), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.updateServerInfo = function(then) { + return this._runTask(straightThroughStringTask2(["update-server-info"]), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.pushTags = function(remote, then) { + const task = pushTagsTask2({ remote: filterType2(remote, filterString2) }, getTrailingOptions2(arguments)); + return this._runTask(task, trailingFunctionArgument2(arguments)); + }; + Git2.prototype.rm = function(files) { + return this._runTask(straightThroughStringTask2(["rm", "-f", ...asArray2(files)]), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.rmKeepLocal = function(files) { + return this._runTask(straightThroughStringTask2(["rm", "--cached", ...asArray2(files)]), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.catFile = function(options, then) { + return this._catFile("utf-8", arguments); + }; + Git2.prototype.binaryCatFile = function() { + return this._catFile("buffer", arguments); + }; + Git2.prototype._catFile = function(format, args) { + var handler = trailingFunctionArgument2(args); + var command = ["cat-file"]; + var options = args[0]; + if (typeof options === "string") { + return this._runTask(configurationErrorTask2("Git.catFile: options must be supplied as an array of strings"), handler); + } + if (Array.isArray(options)) { + command.push.apply(command, options); + } + const task = format === "buffer" ? straightThroughBufferTask2(command) : straightThroughStringTask2(command); + return this._runTask(task, handler); + }; + Git2.prototype.diff = function(options, then) { + const task = filterString2(options) ? configurationErrorTask2("git.diff: supplying options as a single string is no longer supported, switch to an array of strings") : straightThroughStringTask2(["diff", ...getTrailingOptions2(arguments)]); + return this._runTask(task, trailingFunctionArgument2(arguments)); + }; + Git2.prototype.diffSummary = function() { + return this._runTask(diffSummaryTask2(getTrailingOptions2(arguments, 1)), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.applyPatch = function(patches) { + const task = !filterStringOrStringArray2(patches) ? configurationErrorTask2(`git.applyPatch requires one or more string patches as the first argument`) : applyPatchTask2(asArray2(patches), getTrailingOptions2([].slice.call(arguments, 1))); + return this._runTask(task, trailingFunctionArgument2(arguments)); + }; + Git2.prototype.revparse = function() { + const commands2 = ["rev-parse", ...getTrailingOptions2(arguments, true)]; + return this._runTask(straightThroughStringTask2(commands2, true), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.show = function(options, then) { + return this._runTask(straightThroughStringTask2(["show", ...getTrailingOptions2(arguments, 1)]), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.clean = function(mode, options, then) { + const usingCleanOptionsArray = isCleanOptionsArray2(mode); + const cleanMode = usingCleanOptionsArray && mode.join("") || filterType2(mode, filterString2) || ""; + const customArgs = getTrailingOptions2([].slice.call(arguments, usingCleanOptionsArray ? 1 : 0)); + return this._runTask(cleanWithOptionsTask2(cleanMode, customArgs), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.exec = function(then) { + const task = { + commands: [], + format: "utf-8", + parser() { + if (typeof then === "function") { + then(); + } + } + }; + return this._runTask(task); + }; + Git2.prototype.clearQueue = function() { + return this; + }; + Git2.prototype.checkIgnore = function(pathnames, then) { + return this._runTask(checkIgnoreTask2(asArray2(filterType2(pathnames, filterStringOrStringArray2, []))), trailingFunctionArgument2(arguments)); + }; + Git2.prototype.checkIsRepo = function(checkType, then) { + return this._runTask(checkIsRepoTask2(filterType2(checkType, filterString2)), trailingFunctionArgument2(arguments)); + }; + module2.exports = Git2; + } +}); +init_git_error(); +var GitConstructError = class extends GitError { + constructor(config, message) { + super(void 0, message); + this.config = config; + } +}; +init_git_error(); +init_git_error(); +var GitPluginError = class extends GitError { + constructor(task, plugin, message) { + super(task, message); + this.task = task; + this.plugin = plugin; + Object.setPrototypeOf(this, new.target.prototype); + } +}; +init_git_response_error(); +init_task_configuration_error(); +init_check_is_repo(); +init_clean(); +init_config(); +init_grep(); +init_reset(); +function abortPlugin(signal) { + if (!signal) { + return; + } + const onSpawnAfter = { + type: "spawn.after", + action(_data, context) { + function kill() { + context.kill(new GitPluginError(void 0, "abort", "Abort signal received")); + } + signal.addEventListener("abort", kill); + context.spawned.on("close", () => signal.removeEventListener("abort", kill)); + } + }; + const onSpawnBefore = { + type: "spawn.before", + action(_data, context) { + if (signal.aborted) { + context.kill(new GitPluginError(void 0, "abort", "Abort already signaled")); + } + } + }; + return [onSpawnBefore, onSpawnAfter]; +} +function isConfigSwitch(arg) { + return typeof arg === "string" && arg.trim().toLowerCase() === "-c"; +} +function preventProtocolOverride(arg, next) { + if (!isConfigSwitch(arg)) { + return; + } + if (!/^\s*protocol(.[a-z]+)?.allow/.test(next)) { + return; + } + throw new GitPluginError(void 0, "unsafe", "Configuring protocol.allow is not permitted without enabling allowUnsafeExtProtocol"); +} +function preventUploadPack(arg, method2) { + if (/^\s*--(upload|receive)-pack/.test(arg)) { + throw new GitPluginError(void 0, "unsafe", `Use of --upload-pack or --receive-pack is not permitted without enabling allowUnsafePack`); + } + if (method2 === "clone" && /^\s*-u\b/.test(arg)) { + throw new GitPluginError(void 0, "unsafe", `Use of clone with option -u is not permitted without enabling allowUnsafePack`); + } + if (method2 === "push" && /^\s*--exec\b/.test(arg)) { + throw new GitPluginError(void 0, "unsafe", `Use of push with option --exec is not permitted without enabling allowUnsafePack`); + } +} +function blockUnsafeOperationsPlugin({ + allowUnsafeProtocolOverride = false, + allowUnsafePack = false +} = {}) { + return { + type: "spawn.args", + action(args, context) { + args.forEach((current, index2) => { + const next = index2 < args.length ? args[index2 + 1] : ""; + allowUnsafeProtocolOverride || preventProtocolOverride(current, next); + allowUnsafePack || preventUploadPack(current, context.method); + }); + return args; + } + }; +} +init_utils(); +function commandConfigPrefixingPlugin(configuration) { + const prefix = prefixedArray(configuration, "-c"); + return { + type: "spawn.args", + action(data) { + return [...prefix, ...data]; + } + }; +} +init_utils(); +var never = (0, import_promise_deferred2.deferred)().promise; +function completionDetectionPlugin({ + onClose = true, + onExit = 50 +} = {}) { + function createEvents() { + let exitCode = -1; + const events = { + close: (0, import_promise_deferred2.deferred)(), + closeTimeout: (0, import_promise_deferred2.deferred)(), + exit: (0, import_promise_deferred2.deferred)(), + exitTimeout: (0, import_promise_deferred2.deferred)() + }; + const result = Promise.race([ + onClose === false ? never : events.closeTimeout.promise, + onExit === false ? never : events.exitTimeout.promise + ]); + configureTimeout(onClose, events.close, events.closeTimeout); + configureTimeout(onExit, events.exit, events.exitTimeout); + return { + close(code) { + exitCode = code; + events.close.done(); + }, + exit(code) { + exitCode = code; + events.exit.done(); + }, + get exitCode() { + return exitCode; + }, + result + }; + } + function configureTimeout(flag, event, timeout) { + if (flag === false) { + return; + } + (flag === true ? event.promise : event.promise.then(() => delay(flag))).then(timeout.done); + } + return { + type: "spawn.after", + action(_0, _1) { + return __async(this, arguments, function* (_data, { spawned, close }) { + var _a2, _b; + const events = createEvents(); + let deferClose = true; + let quickClose = () => void (deferClose = false); + (_a2 = spawned.stdout) == null ? void 0 : _a2.on("data", quickClose); + (_b = spawned.stderr) == null ? void 0 : _b.on("data", quickClose); + spawned.on("error", quickClose); + spawned.on("close", (code) => events.close(code)); + spawned.on("exit", (code) => events.exit(code)); + try { + yield events.result; + if (deferClose) { + yield delay(50); + } + close(events.exitCode); + } catch (err) { + close(events.exitCode, err); + } + }); + } + }; +} +init_git_error(); +function isTaskError(result) { + return !!(result.exitCode && result.stdErr.length); +} +function getErrorMessage(result) { + return Buffer.concat([...result.stdOut, ...result.stdErr]); +} +function errorDetectionHandler(overwrite = false, isError = isTaskError, errorMessage = getErrorMessage) { + return (error, result) => { + if (!overwrite && error || !isError(result)) { + return error; + } + return errorMessage(result); + }; +} +function errorDetectionPlugin(config) { + return { + type: "task.error", + action(data, context) { + const error = config(data.error, { + stdErr: context.stdErr, + stdOut: context.stdOut, + exitCode: context.exitCode + }); + if (Buffer.isBuffer(error)) { + return { error: new GitError(void 0, error.toString("utf-8")) }; + } + return { + error + }; + } + }; +} +init_utils(); +var PluginStore = class { + constructor() { + this.plugins = /* @__PURE__ */ new Set(); + } + add(plugin) { + const plugins = []; + asArray(plugin).forEach((plugin2) => plugin2 && this.plugins.add(append(plugins, plugin2))); + return () => { + plugins.forEach((plugin2) => this.plugins.delete(plugin2)); + }; + } + exec(type, data, context) { + let output = data; + const contextual = Object.freeze(Object.create(context)); + for (const plugin of this.plugins) { + if (plugin.type === type) { + output = plugin.action(output, contextual); + } + } + return output; + } +}; +init_utils(); +function progressMonitorPlugin(progress) { + const progressCommand = "--progress"; + const progressMethods = ["checkout", "clone", "fetch", "pull", "push"]; + const onProgress = { + type: "spawn.after", + action(_data, context) { + var _a2; + if (!context.commands.includes(progressCommand)) { + return; + } + (_a2 = context.spawned.stderr) == null ? void 0 : _a2.on("data", (chunk) => { + const message = /^([\s\S]+?):\s*(\d+)% \((\d+)\/(\d+)\)/.exec(chunk.toString("utf8")); + if (!message) { + return; + } + progress({ + method: context.method, + stage: progressEventStage(message[1]), + progress: asNumber(message[2]), + processed: asNumber(message[3]), + total: asNumber(message[4]) + }); + }); + } + }; + const onArgs = { + type: "spawn.args", + action(args, context) { + if (!progressMethods.includes(context.method)) { + return args; + } + return including(args, progressCommand); + } + }; + return [onArgs, onProgress]; +} +function progressEventStage(input) { + return String(input.toLowerCase().split(" ", 1)) || "unknown"; +} +init_utils(); +function spawnOptionsPlugin(spawnOptions) { + const options = pick(spawnOptions, ["uid", "gid"]); + return { + type: "spawn.options", + action(data) { + return __spreadValues(__spreadValues({}, options), data); + } + }; +} +function timeoutPlugin({ + block, + stdErr = true, + stdOut = true +}) { + if (block > 0) { + return { + type: "spawn.after", + action(_data, context) { + var _a2, _b; + let timeout; + function wait3() { + timeout && clearTimeout(timeout); + timeout = setTimeout(kill, block); + } + function stop() { + var _a3, _b2; + (_a3 = context.spawned.stdout) == null ? void 0 : _a3.off("data", wait3); + (_b2 = context.spawned.stderr) == null ? void 0 : _b2.off("data", wait3); + context.spawned.off("exit", stop); + context.spawned.off("close", stop); + timeout && clearTimeout(timeout); + } + function kill() { + stop(); + context.kill(new GitPluginError(void 0, "timeout", `block timeout reached`)); + } + stdOut && ((_a2 = context.spawned.stdout) == null ? void 0 : _a2.on("data", wait3)); + stdErr && ((_b = context.spawned.stderr) == null ? void 0 : _b.on("data", wait3)); + context.spawned.on("exit", stop); + context.spawned.on("close", stop); + wait3(); + } + }; + } +} +init_utils(); +var Git = require_git(); +function gitInstanceFactory(baseDir, options) { + const plugins = new PluginStore(); + const config = createInstanceConfig(baseDir && (typeof baseDir === "string" ? { baseDir } : baseDir) || {}, options); + if (!folderExists(config.baseDir)) { + throw new GitConstructError(config, `Cannot use simple-git on a directory that does not exist`); + } + if (Array.isArray(config.config)) { + plugins.add(commandConfigPrefixingPlugin(config.config)); + } + plugins.add(blockUnsafeOperationsPlugin(config.unsafe)); + plugins.add(completionDetectionPlugin(config.completion)); + config.abort && plugins.add(abortPlugin(config.abort)); + config.progress && plugins.add(progressMonitorPlugin(config.progress)); + config.timeout && plugins.add(timeoutPlugin(config.timeout)); + config.spawnOptions && plugins.add(spawnOptionsPlugin(config.spawnOptions)); + plugins.add(errorDetectionPlugin(errorDetectionHandler(true))); + config.errors && plugins.add(errorDetectionPlugin(config.errors)); + return new Git(config, plugins); +} +init_git_response_error(); +var esm_default = gitInstanceFactory; + +// src/constants.ts +init_polyfill_buffer(); +var import_obsidian2 = require("obsidian"); +var DATE_FORMAT = "YYYY-MM-DD"; +var DATE_TIME_FORMAT_MINUTES = `${DATE_FORMAT} HH:mm`; +var DATE_TIME_FORMAT_SECONDS = `${DATE_FORMAT} HH:mm:ss`; +var GIT_LINE_AUTHORING_MOVEMENT_DETECTION_MINIMAL_LENGTH = 40; +var DEFAULT_SETTINGS = { + commitMessage: "vault backup: {{date}}", + commitDateFormat: DATE_TIME_FORMAT_SECONDS, + autoSaveInterval: 0, + autoPushInterval: 0, + autoPullInterval: 0, + autoPullOnBoot: false, + disablePush: false, + pullBeforePush: true, + disablePopups: false, + listChangedFilesInMessageBody: false, + showStatusBar: true, + updateSubmodules: false, + syncMethod: "merge", + customMessageOnAutoBackup: false, + autoBackupAfterFileChange: false, + treeStructure: false, + refreshSourceControl: import_obsidian2.Platform.isDesktopApp, + basePath: "", + differentIntervalCommitAndPush: false, + changedFilesInStatusBar: false, + showedMobileNotice: false, + refreshSourceControlTimer: 7e3, + showBranchStatusBar: true, + setLastSaveToLastCommit: false, + submoduleRecurseCheckout: false, + gitDir: "", + showFileMenu: true, + lineAuthor: { + show: false, + followMovement: "inactive", + authorDisplay: "initials", + showCommitHash: false, + dateTimeFormatOptions: "date", + dateTimeFormatCustomString: DATE_TIME_FORMAT_MINUTES, + dateTimeTimezone: "viewer-local", + coloringMaxAge: "1y", + // colors were picked via: + // https://color.adobe.com/de/create/color-accessibility + colorNew: { r: 255, g: 150, b: 150 }, + colorOld: { r: 120, g: 160, b: 255 }, + textColorCss: "var(--text-muted)", + // more pronounced than line numbers, but less than the content text + ignoreWhitespace: false, + gutterSpacingFallbackLength: 5 + } +}; +var SOURCE_CONTROL_VIEW_CONFIG = { + type: "git-view", + name: "Source Control", + icon: "git-pull-request" +}; +var HISTORY_VIEW_CONFIG = { + type: "git-history-view", + name: "History", + icon: "history" +}; +var DIFF_VIEW_CONFIG = { + type: "diff-view", + name: "Diff View", + icon: "git-pull-request" +}; + +// src/types.ts +init_polyfill_buffer(); +function mergeSettingsByPriority(low, high) { + const lineAuthor = Object.assign({}, low.lineAuthor, high.lineAuthor); + return Object.assign({}, low, high, { lineAuthor }); +} + +// src/utils.ts +init_polyfill_buffer(); +var cssColorConverter = __toESM(require_lib3()); +var import_deep_equal = __toESM(require_deep_equal()); +var import_obsidian3 = require("obsidian"); +var worthWalking2 = (filepath, root2) => { + if (filepath === "." || root2 == null || root2.length === 0 || root2 === ".") { + return true; + } + if (root2.length >= filepath.length) { + return root2.startsWith(filepath); + } else { + return filepath.startsWith(root2); + } +}; +function getNewLeaf(event) { + let leaf; + if (event) { + if (event.button === 0 || event.button === 1) { + const type = import_obsidian3.Keymap.isModEvent(event); + leaf = app.workspace.getLeaf(type); + } + } else { + leaf = app.workspace.getLeaf(false); + } + return leaf; +} +function impossibleBranch(x) { + throw new Error("Impossible branch: " + x); +} +function rgbToString(rgb) { + return `rgb(${rgb.r},${rgb.g},${rgb.b})`; +} +function convertToRgb(str) { + var _a2; + const color = (_a2 = cssColorConverter.fromString(str)) == null ? void 0 : _a2.toRgbaArray(); + if (color === void 0) { + return void 0; + } + const [r, g, b] = color; + return { r, g, b }; +} +function momentToEpochSeconds(instant) { + return instant.diff(import_obsidian3.moment.unix(0), "seconds"); +} +function median(array) { + if (array.length === 0) + return void 0; + return array.slice().sort()[Math.floor(array.length / 2)]; +} +function strictDeepEqual(a, b) { + return (0, import_deep_equal.default)(a, b, { strict: true }); +} +function resizeToLength(original, desiredLength, fillChar) { + if (original.length <= desiredLength) { + const prefix = new Array(desiredLength - original.length).fill(fillChar).join(""); + return prefix + original; + } else { + return original.substring(original.length - desiredLength); + } +} +function prefixOfLengthAsWhitespace(toBeRenderedText, whitespacePrefixLength) { + if (whitespacePrefixLength <= 0) + return toBeRenderedText; + const whitespacePrefix = new Array(whitespacePrefixLength).fill(" ").join(""); + const originalSuffix = toBeRenderedText.substring( + whitespacePrefixLength, + toBeRenderedText.length + ); + return whitespacePrefix + originalSuffix; +} +function between(l, x, r) { + return l <= x && x <= r; +} +function splitRemoteBranch(remoteBranch) { + const [remote, ...branch2] = remoteBranch.split("/"); + return [remote, branch2.length === 0 ? void 0 : branch2.join("/")]; +} +function getDisplayPath(path2) { + if (path2.endsWith("/")) + return path2; + return path2.split("/").last().replace(".md", ""); +} + +// src/gitManager/gitManager.ts +init_polyfill_buffer(); +var GitManager = class { + constructor(plugin) { + this.plugin = plugin; + this.app = plugin.app; + } + getVaultPath(path2) { + if (this.plugin.settings.basePath) { + return this.plugin.settings.basePath + "/" + path2; + } else { + return path2; + } + } + asRepositoryRelativePath(path2, relativeToVault) { + return relativeToVault && this.plugin.settings.basePath.length > 0 ? path2.substring(this.plugin.settings.basePath.length + 1) : path2; + } + _getTreeStructure(children2, beginLength = 0) { + const list = []; + children2 = [...children2]; + while (children2.length > 0) { + const first2 = children2.first(); + const restPath = first2.path.substring(beginLength); + if (restPath.contains("/")) { + const title = restPath.substring(0, restPath.indexOf("/")); + const childrenWithSameTitle = children2.filter((item) => { + return item.path.substring(beginLength).startsWith(title + "/"); + }); + childrenWithSameTitle.forEach((item) => children2.remove(item)); + const path2 = first2.path.substring( + 0, + restPath.indexOf("/") + beginLength + ); + list.push({ + title, + path: path2, + vaultPath: this.getVaultPath(path2), + children: this._getTreeStructure( + childrenWithSameTitle, + (beginLength > 0 ? beginLength + title.length : title.length) + 1 + ) + }); + } else { + list.push({ + title: restPath, + data: first2, + path: first2.path, + vaultPath: this.getVaultPath(first2.path) + }); + children2.remove(first2); + } + } + return list; + } + /* + * Sorts the children and simplifies the title + * If a node only contains another subdirectory, that subdirectory is moved up one level and integrated into the parent node + */ + simplify(tree) { + var _a2, _b, _c, _d; + for (const node of tree) { + while (true) { + const singleChild = ((_a2 = node.children) == null ? void 0 : _a2.length) == 1; + const singleChildIsDir = ((_c = (_b = node.children) == null ? void 0 : _b.first()) == null ? void 0 : _c.data) == void 0; + if (!(node.children != void 0 && singleChild && singleChildIsDir)) + break; + const child = node.children.first(); + node.title += "/" + child.title; + node.data = child.data; + node.path = child.path; + node.vaultPath = child.vaultPath; + node.children = child.children; + } + if (node.children != void 0) { + this.simplify(node.children); + } + (_d = node.children) == null ? void 0 : _d.sort((a, b) => { + const dirCompare = (b.data == void 0 ? 1 : 0) - (a.data == void 0 ? 1 : 0); + if (dirCompare != 0) { + return dirCompare; + } else { + return a.title.localeCompare(b.title); + } + }); + } + return tree.sort((a, b) => { + const dirCompare = (b.data == void 0 ? 1 : 0) - (a.data == void 0 ? 1 : 0); + if (dirCompare != 0) { + return dirCompare; + } else { + return a.title.localeCompare(b.title); + } + }); + } + getTreeStructure(children2) { + const tree = this._getTreeStructure(children2); + const res = this.simplify(tree); + return res; + } + async formatCommitMessage(template) { + let status2; + if (template.includes("{{numFiles}}")) { + status2 = await this.status(); + const numFiles = status2.staged.length; + template = template.replace("{{numFiles}}", String(numFiles)); + } + if (template.includes("{{hostname}}")) { + const hostname = this.plugin.localStorage.getHostname() || ""; + template = template.replace("{{hostname}}", hostname); + } + if (template.includes("{{files}}")) { + status2 = status2 != null ? status2 : await this.status(); + const changeset = {}; + status2.staged.forEach((value) => { + if (value.index in changeset) { + changeset[value.index].push(value.path); + } else { + changeset[value.index] = [value.path]; + } + }); + const chunks = []; + for (const [action, files2] of Object.entries(changeset)) { + chunks.push(action + " " + files2.join(" ")); + } + const files = chunks.join(", "); + template = template.replace("{{files}}", files); + } + const moment5 = window.moment; + template = template.replace( + "{{date}}", + moment5().format(this.plugin.settings.commitDateFormat) + ); + if (this.plugin.settings.listChangedFilesInMessageBody) { + template = template + "\n\nAffected files:\n" + (status2 != null ? status2 : await this.status()).staged.map((e) => e.path).join("\n"); + } + return template; + } +}; + +// src/gitManager/simpleGit.ts +var SimpleGit = class extends GitManager { + constructor(plugin) { + super(plugin); + } + async setGitInstance(ignoreError = false) { + if (this.isGitInstalled()) { + const adapter = this.app.vault.adapter; + const path2 = adapter.getBasePath(); + let basePath = path2; + if (this.plugin.settings.basePath) { + const exists2 = await adapter.exists( + (0, import_obsidian4.normalizePath)(this.plugin.settings.basePath) + ); + if (exists2) { + basePath = path2 + import_path.sep + this.plugin.settings.basePath; + } else if (!ignoreError) { + new import_obsidian4.Notice("ObsidianGit: Base path does not exist"); + } + } + this.git = esm_default({ + baseDir: basePath, + binary: this.plugin.localStorage.getGitPath() || void 0, + config: ["core.quotepath=off"] + }); + const pathPaths = this.plugin.localStorage.getPATHPaths(); + const envVars = this.plugin.localStorage.getEnvVars(); + const gitDir = this.plugin.settings.gitDir; + if (pathPaths.length > 0) { + const path3 = process.env["PATH"] + ":" + pathPaths.join(":"); + process.env["PATH"] = path3; + } + if (gitDir) { + process.env["GIT_DIR"] = gitDir; + } + for (const envVar of envVars) { + const [key2, value] = envVar.split("="); + process.env[key2] = value; + } + import_debug2.default.enable("simple-git"); + if (await this.git.checkIsRepo()) { + await this.git.cwd(await this.git.revparse("--show-toplevel")); + } + } + } + async status() { + this.plugin.setState(1 /* status */); + const status2 = await this.git.status((err) => this.onError(err)); + this.plugin.setState(0 /* idle */); + return { + changed: status2.files.filter((e) => e.working_dir !== " ").map((e) => { + const res = this.formatPath(e); + return { + path: res.path, + from: res.from, + working_dir: e.working_dir === "?" ? "U" : e.working_dir, + vault_path: this.getVaultPath(res.path) + }; + }), + staged: status2.files.filter((e) => e.index !== " " && e.index != "?").map((e) => { + const res = this.formatPath(e, e.index === "R"); + return { + path: res.path, + from: res.from, + index: e.index, + vault_path: this.getVaultPath(res.path) + }; + }), + conflicted: status2.conflicted.map( + (path2) => this.formatPath({ path: path2 }).path + ) + }; + } + async submoduleAwareHeadRevisonInContainingDirectory(filepath) { + const repoPath = this.asRepositoryRelativePath(filepath, true); + const containingDirectory = path.dirname(repoPath); + const args = ["-C", containingDirectory, "rev-parse", "HEAD"]; + const result = this.git.raw(args); + result.catch( + (err) => console.warn("obsidian-git: rev-parse error:", err) + ); + return result; + } + async getSubmodulePaths() { + return new Promise(async (resolve) => { + this.git.outputHandler(async (cmd, stdout, stderr, args) => { + if (!(args.contains("submodule") && args.contains("foreach"))) { + return; + } + let body = ""; + const root2 = this.app.vault.adapter.getBasePath() + (this.plugin.settings.basePath ? "/" + this.plugin.settings.basePath : ""); + stdout.on("data", (chunk) => { + body += chunk.toString("utf8"); + }); + stdout.on("end", async () => { + const submods = body.split("\n"); + const strippedSubmods = submods.map((i) => { + const submod = i.match(/'([^']*)'/); + if (submod != void 0) { + return root2 + "/" + submod[1] + import_path.sep; + } + }).filter((i) => !!i); + strippedSubmods.reverse(); + resolve(strippedSubmods); + }); + }); + await this.git.subModule(["foreach", "--recursive", ""]); + this.git.outputHandler(() => { + }); + }); + } + //Remove wrong `"` like "My file.md" + formatPath(path2, renamed = false) { + function format(path3) { + if (path3 == void 0) + return void 0; + if (path3.startsWith('"') && path3.endsWith('"')) { + return path3.substring(1, path3.length - 1); + } else { + return path3; + } + } + if (renamed) { + return { + from: format(path2.from), + path: format(path2.path) + }; + } else { + return { + path: format(path2.path) + }; + } + } + async blame(path2, trackMovement, ignoreWhitespace) { + path2 = this.asRepositoryRelativePath(path2, true); + if (!await this.isTracked(path2)) + return "untracked"; + const inSubmodule = await this.getSubmoduleOfFile(path2); + const args = inSubmodule ? ["-C", inSubmodule.submodule] : []; + const relativePath = inSubmodule ? inSubmodule.relativeFilepath : path2; + args.push("blame", "--porcelain"); + if (ignoreWhitespace) + args.push("-w"); + const trackCArg = `-C${GIT_LINE_AUTHORING_MOVEMENT_DETECTION_MINIMAL_LENGTH}`; + switch (trackMovement) { + case "inactive": + break; + case "same-commit": + args.push("-C", trackCArg); + break; + case "all-commits": + args.push("-C", "-C", trackCArg); + break; + default: + impossibleBranch(trackMovement); + } + args.push("--", relativePath); + const rawBlame = await this.git.raw( + args, + (err) => err && console.warn("git-blame", err) + ); + return parseBlame(rawBlame); + } + async isTracked(path2) { + const inSubmodule = await this.getSubmoduleOfFile(path2); + const args = inSubmodule ? ["-C", inSubmodule.submodule] : []; + const relativePath = inSubmodule ? inSubmodule.relativeFilepath : path2; + args.push("ls-files", "--", relativePath); + return this.git.raw(args, (err) => err && console.warn("ls-files", err)).then((x) => x.trim() !== ""); + } + async commitAll({ message }) { + if (this.plugin.settings.updateSubmodules) { + this.plugin.setState(4 /* commit */); + const submodulePaths = await this.getSubmodulePaths(); + for (const item of submodulePaths) { + await this.git.cwd({ path: item, root: false }).add("-A", (err) => this.onError(err)); + await this.git.cwd({ path: item, root: false }).commit( + await this.formatCommitMessage(message), + (err) => this.onError(err) + ); + } + } + this.plugin.setState(3 /* add */); + await this.git.add("-A", (err) => this.onError(err)); + this.plugin.setState(4 /* commit */); + const res = await this.git.commit( + await this.formatCommitMessage(message), + (err) => this.onError(err) + ); + dispatchEvent(new CustomEvent("git-head-update")); + return res.summary.changes; + } + async commit(message) { + this.plugin.setState(4 /* commit */); + const res = (await this.git.commit( + await this.formatCommitMessage(message), + (err) => this.onError(err) + )).summary.changes; + dispatchEvent(new CustomEvent("git-head-update")); + this.plugin.setState(0 /* idle */); + return res; + } + async stage(path2, relativeToVault) { + this.plugin.setState(3 /* add */); + path2 = this.asRepositoryRelativePath(path2, relativeToVault); + await this.git.add(["--", path2], (err) => this.onError(err)); + this.plugin.setState(0 /* idle */); + } + async stageAll({ dir }) { + this.plugin.setState(3 /* add */); + await this.git.add(dir != null ? dir : "-A", (err) => this.onError(err)); + this.plugin.setState(0 /* idle */); + } + async unstageAll({ dir }) { + this.plugin.setState(3 /* add */); + await this.git.reset( + dir != void 0 ? ["--", dir] : [], + (err) => this.onError(err) + ); + this.plugin.setState(0 /* idle */); + } + async unstage(path2, relativeToVault) { + this.plugin.setState(3 /* add */); + path2 = this.asRepositoryRelativePath(path2, relativeToVault); + await this.git.reset(["--", path2], (err) => this.onError(err)); + this.plugin.setState(0 /* idle */); + } + async discard(filepath) { + this.plugin.setState(3 /* add */); + await this.git.checkout(["--", filepath], (err) => this.onError(err)); + this.plugin.setState(0 /* idle */); + } + async hashObject(filepath) { + filepath = this.asRepositoryRelativePath(filepath, true); + const inSubmodule = await this.getSubmoduleOfFile(filepath); + const args = inSubmodule ? ["-C", inSubmodule.submodule] : []; + const relativeFilepath = inSubmodule ? inSubmodule.relativeFilepath : filepath; + args.push("hash-object", "--", relativeFilepath); + const revision = this.git.raw(args); + revision.catch( + (err) => err && console.warn("obsidian-git. hash-object failed:", err == null ? void 0 : err.message) + ); + return revision; + } + async discardAll({ dir }) { + return this.discard(dir != null ? dir : "."); + } + async pull() { + this.plugin.setState(2 /* pull */); + if (this.plugin.settings.updateSubmodules) + await this.git.subModule( + ["update", "--remote", "--merge", "--recursive"], + (err) => this.onError(err) + ); + const branchInfo = await this.branchInfo(); + const localCommit = await this.git.revparse( + [branchInfo.current], + (err) => this.onError(err) + ); + await this.git.fetch((err) => this.onError(err)); + const upstreamCommit = await this.git.revparse( + [branchInfo.tracking], + (err) => this.onError(err) + ); + if (localCommit !== upstreamCommit) { + if (this.plugin.settings.syncMethod === "merge" || this.plugin.settings.syncMethod === "rebase") { + try { + switch (this.plugin.settings.syncMethod) { + case "merge": + await this.git.merge([branchInfo.tracking]); + break; + case "rebase": + await this.git.rebase([branchInfo.tracking]); + } + } catch (err) { + this.plugin.displayError( + `Pull failed (${this.plugin.settings.syncMethod}): ${err.message}` + ); + return; + } + } else if (this.plugin.settings.syncMethod === "reset") { + try { + await this.git.raw( + [ + "update-ref", + `refs/heads/${branchInfo.current}`, + upstreamCommit + ], + (err) => this.onError(err) + ); + await this.unstageAll({}); + } catch (err) { + this.plugin.displayError( + `Sync failed (${this.plugin.settings.syncMethod}): ${err.message}` + ); + } + } + dispatchEvent(new CustomEvent("git-head-update")); + const afterMergeCommit = await this.git.revparse( + [branchInfo.current], + (err) => this.onError(err) + ); + const filesChanged = await this.git.diff([ + `${localCommit}..${afterMergeCommit}`, + "--name-only" + ]); + return filesChanged.split(/\r\n|\r|\n/).filter((value) => value.length > 0).map((e) => { + return { + path: e, + working_dir: "P", + vault_path: this.getVaultPath(e) + }; + }); + } else { + return []; + } + } + async push() { + this.plugin.setState(1 /* status */); + const status2 = await this.git.status(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const remoteChangedFiles = (await this.git.diffSummary( + [currentBranch2, trackingBranch, "--"], + (err) => this.onError(err) + )).changed; + this.plugin.setState(5 /* push */); + if (this.plugin.settings.updateSubmodules) { + await this.git.env({ ...process.env, OBSIDIAN_GIT: 1 }).subModule( + [ + "foreach", + "--recursive", + `tracking=$(git for-each-ref --format='%(upstream:short)' "$(git symbolic-ref -q HEAD)"); echo $tracking; if [ ! -z "$(git diff --shortstat $tracking)" ]; then git push; fi` + ], + (err) => this.onError(err) + ); + } + await this.git.env({ ...process.env, OBSIDIAN_GIT: 1 }).push((err) => this.onError(err)); + return remoteChangedFiles; + } + async getUnpushedCommits() { + const status2 = await this.git.status(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + if (trackingBranch == null || currentBranch2 == null) { + return 0; + } + const remoteChangedFiles = (await this.git.diffSummary( + [currentBranch2, trackingBranch, "--"], + (err) => this.onError(err) + )).changed; + return remoteChangedFiles; + } + async canPush() { + if (this.plugin.settings.updateSubmodules === true) { + return true; + } + const status2 = await this.git.status((err) => this.onError(err)); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const remoteChangedFiles = (await this.git.diffSummary([currentBranch2, trackingBranch, "--"])).changed; + return remoteChangedFiles !== 0; + } + async checkRequirements() { + if (!this.isGitInstalled()) { + return "missing-git"; + } + if (!await this.git.checkIsRepo()) { + return "missing-repo"; + } + return "valid"; + } + async branchInfo() { + const status2 = await this.git.status((err) => this.onError(err)); + const branches = await this.git.branch( + ["--no-color"], + (err) => this.onError(err) + ); + return { + current: status2.current || void 0, + tracking: status2.tracking || void 0, + branches: branches.all + }; + } + async getRemoteUrl(remote) { + return await this.git.remote( + ["get-url", remote], + (err, url) => this.onError(err) + ) || void 0; + } + // https://github.com/kometenstaub/obsidian-version-history-diff/issues/3 + async log(file, relativeToVault = true, limit) { + let path2; + if (file) { + path2 = this.asRepositoryRelativePath(file, relativeToVault); + } + const res = await this.git.log( + { + file: path2, + maxCount: limit, + "-m": null, + "--name-status": null + }, + (err) => this.onError(err) + ); + return res.all.map((e) => { + var _a2, _b, _c, _d; + return { + ...e, + refs: e.refs.split(", "), + diff: { + ...e.diff, + files: (_b = (_a2 = e.diff) == null ? void 0 : _a2.files.map((f) => ({ + ...f, + status: f.status, + path: f.file, + hash: e.hash, + vault_path: this.getVaultPath(f.file) + }))) != null ? _b : [] + }, + fileName: (_d = (_c = e.diff) == null ? void 0 : _c.files.first()) == null ? void 0 : _d.file + }; + }); + } + async show(commitHash, file, relativeToVault = true) { + const path2 = this.asRepositoryRelativePath(file, relativeToVault); + return this.git.show( + [commitHash + ":" + path2], + (err) => this.onError(err) + ); + } + async checkout(branch2, remote) { + if (remote) { + branch2 = `${remote}/${branch2}`; + } + await this.git.checkout(branch2, (err) => this.onError(err)); + if (this.plugin.settings.submoduleRecurseCheckout) { + const submodulePaths = await this.getSubmodulePaths(); + for (const submodulePath of submodulePaths) { + const branchSummary = await this.git.cwd({ path: submodulePath, root: false }).branch(); + if (Object.keys(branchSummary.branches).includes(branch2)) { + await this.git.cwd({ path: submodulePath, root: false }).checkout(branch2, (err) => this.onError(err)); + } + } + } + } + async createBranch(branch2) { + await this.git.checkout(["-b", branch2], (err) => this.onError(err)); + } + async deleteBranch(branch2, force) { + await this.git.branch( + [force ? "-D" : "-d", branch2], + (err) => this.onError(err) + ); + } + async branchIsMerged(branch2) { + const notMergedBranches = await this.git.branch( + ["--no-merged"], + (err) => this.onError(err) + ); + return !notMergedBranches.all.contains(branch2); + } + async init() { + await this.git.init(false, (err) => this.onError(err)); + } + async clone(url, dir, depth) { + await this.git.clone( + url, + path.join( + this.app.vault.adapter.getBasePath(), + dir + ), + depth ? ["--depth", `${depth}`] : [], + (err) => this.onError(err) + ); + } + async setConfig(path2, value) { + if (value == void 0) { + await this.git.raw(["config", "--local", "--unset", path2]); + } else { + await this.git.addConfig(path2, value, (err) => this.onError(err)); + } + } + async getConfig(path2) { + const config = await this.git.listConfig( + "local", + (err) => this.onError(err) + ); + return config.all[path2]; + } + async fetch(remote) { + await this.git.fetch( + remote != void 0 ? [remote] : [], + (err) => this.onError(err) + ); + } + async setRemote(name, url) { + if ((await this.getRemotes()).includes(name)) + await this.git.remote( + ["set-url", name, url], + (err) => this.onError(err) + ); + else { + await this.git.remote( + ["add", name, url], + (err) => this.onError(err) + ); + } + } + async getRemoteBranches(remote) { + const res = await this.git.branch( + ["-r", "--list", `${remote}*`], + (err) => this.onError(err) + ); + console.log(remote); + console.log(res); + const list = []; + for (const item in res.branches) { + list.push(res.branches[item].name); + } + return list; + } + async getRemotes() { + const res = await this.git.remote([], (err) => this.onError(err)); + if (res) { + return res.trim().split("\n"); + } else { + return []; + } + } + async removeRemote(remoteName) { + await this.git.removeRemote(remoteName); + } + async updateUpstreamBranch(remoteBranch) { + try { + await this.git.branch(["--set-upstream-to", remoteBranch]); + } catch (e) { + console.error(e); + try { + await this.git.branch(["--set-upstream", remoteBranch]); + } catch (e2) { + console.error(e2); + await this.git.push( + // A type error occurs here because the third element could be undefined. + // However, it is unlikely to be undefined due to the `remoteBranch`'s format, and error handling is in place. + // Therefore, we temporarily ignore the error. + // @ts-ignore + ["--set-upstream", ...splitRemoteBranch(remoteBranch)], + (err) => this.onError(err) + ); + } + } + } + updateGitPath(gitPath) { + this.setGitInstance(); + } + updateBasePath(basePath) { + this.setGitInstance(true); + } + async getDiffString(filePath, stagedChanges = false, hash2) { + if (stagedChanges) + return await this.git.diff(["--cached", "--", filePath]); + if (hash2) + return await this.git.show([`${hash2}`, "--", filePath]); + else + return await this.git.diff(["--", filePath]); + } + async diff(file, commit1, commit2) { + return await this.git.diff([`${commit1}..${commit2}`, "--", file]); + } + async getSubmoduleOfFile(repositoryRelativeFile) { + let submoduleRoot = await this.git.raw( + [ + "-C", + path.dirname(repositoryRelativeFile), + "rev-parse", + "--show-toplevel" + ], + (err) => err && console.warn("get-submodule-of-file", err == null ? void 0 : err.message) + ); + submoduleRoot = submoduleRoot.trim(); + const superProject = await this.git.raw( + [ + "-C", + path.dirname(repositoryRelativeFile), + "rev-parse", + "--show-superproject-working-tree" + ], + (err) => err && console.warn("get-submodule-of-file", err == null ? void 0 : err.message) + ); + if (superProject.trim() === "") { + return void 0; + } + const fsAdapter = this.app.vault.adapter; + const absolutePath = fsAdapter.getFullPath( + path.normalize(repositoryRelativeFile) + ); + const newRelativePath = path.relative(submoduleRoot, absolutePath); + return { submodule: submoduleRoot, relativeFilepath: newRelativePath }; + } + async getLastCommitTime() { + const res = await this.git.log({ n: 1 }, (err) => this.onError(err)); + if (res != null && res.latest != null) { + return new Date(res.latest.date); + } + } + isGitInstalled() { + const command = (0, import_child_process2.spawnSync)( + this.plugin.localStorage.getGitPath() || "git", + ["--version"], + { + stdio: "ignore" + } + ); + if (command.error) { + console.error(command.error); + return false; + } + return true; + } + onError(error) { + if (error) { + const networkFailure = error.message.contains("Could not resolve host") || error.message.match( + /ssh: connect to host .*? port .*?: Operation timed out/ + ) || error.message.match( + /ssh: connect to host .*? port .*?: Network is unreachable/ + ); + if (!networkFailure) { + this.plugin.displayError(error.message); + this.plugin.setState(0 /* idle */); + } else if (!this.plugin.offlineMode) { + this.plugin.displayError( + "Git: Going into offline mode. Future network errors will no longer be displayed.", + 2e3 + ); + } + if (networkFailure) { + this.plugin.offlineMode = true; + this.plugin.setState(0 /* idle */); + } + } + } +}; +var zeroCommit = { + hash: "000000", + isZeroCommit: true, + summary: "" +}; +function parseBlame(blameOutputUnnormalized) { + const blameOutput = blameOutputUnnormalized.replace("\r\n", "\n"); + const blameLines = blameOutput.split("\n"); + const result = { + commits: /* @__PURE__ */ new Map(), + hashPerLine: [void 0], + // one-based indices + originalFileLineNrPerLine: [void 0], + finalFileLineNrPerLine: [void 0], + groupSizePerStartingLine: /* @__PURE__ */ new Map() + }; + let line = 1; + for (let bi = 0; bi < blameLines.length; ) { + if (startsWithNonWhitespace(blameLines[bi])) { + const lineInfo = blameLines[bi].split(" "); + const commitHash = parseLineInfoInto(lineInfo, line, result); + bi++; + for (; startsWithNonWhitespace(blameLines[bi]); bi++) { + const spaceSeparatedHeaderValues = blameLines[bi].split(" "); + parseHeaderInto(spaceSeparatedHeaderValues, result, line); + } + finalizeBlameCommitInfo(result.commits.get(commitHash)); + line += 1; + } else if (blameLines[bi] === "" && bi === blameLines.length - 1) { + } else { + throw Error( + `Expected non-whitespace line or EOF, but found: ${blameLines[bi]}` + ); + } + bi++; + } + return result; +} +function parseLineInfoInto(lineInfo, line, result) { + const hash2 = lineInfo[0]; + result.hashPerLine.push(hash2); + result.originalFileLineNrPerLine.push(parseInt(lineInfo[1])); + result.finalFileLineNrPerLine.push(parseInt(lineInfo[2])); + lineInfo.length >= 4 && result.groupSizePerStartingLine.set(line, parseInt(lineInfo[3])); + if (parseInt(lineInfo[2]) !== line) { + throw Error( + `git-blame output is out of order: ${line} vs ${lineInfo[2]}` + ); + } + return hash2; +} +function parseHeaderInto(header, out, line) { + const key2 = header[0]; + const value = header.slice(1).join(" "); + const commitHash = out.hashPerLine[line]; + const commit2 = out.commits.get(commitHash) || { + hash: commitHash, + author: {}, + committer: {}, + previous: {} + }; + switch (key2) { + case "summary": + commit2.summary = value; + break; + case "author": + commit2.author.name = value; + break; + case "author-mail": + commit2.author.email = removeEmailBrackets(value); + break; + case "author-time": + commit2.author.epochSeconds = parseInt(value); + break; + case "author-tz": + commit2.author.tz = value; + break; + case "committer": + commit2.committer.name = value; + break; + case "committer-mail": + commit2.committer.email = removeEmailBrackets(value); + break; + case "committer-time": + commit2.committer.epochSeconds = parseInt(value); + break; + case "committer-tz": + commit2.committer.tz = value; + break; + case "previous": + commit2.previous.commitHash = value; + break; + case "filename": + commit2.previous.filename = value; + break; + } + out.commits.set(commitHash, commit2); +} +function finalizeBlameCommitInfo(commit2) { + if (commit2.summary === void 0) { + throw Error(`Summary not provided for commit: ${commit2.hash}`); + } + if (isUndefinedOrEmptyObject(commit2.author)) { + commit2.author = void 0; + } + if (isUndefinedOrEmptyObject(commit2.committer)) { + commit2.committer = void 0; + } + if (isUndefinedOrEmptyObject(commit2.previous)) { + commit2.previous = void 0; + } + commit2.isZeroCommit = Boolean(commit2.hash.match(/^0*$/)); +} +function isUndefinedOrEmptyObject(obj) { + return !obj || Object.keys(obj).length === 0; +} +function startsWithNonWhitespace(str) { + return str.length > 0 && str[0].trim() === str[0]; +} +function removeEmailBrackets(gitEmail) { + const prefixCleaned = gitEmail.startsWith("<") ? gitEmail.substring(1) : gitEmail; + return prefixCleaned.endsWith(">") ? prefixCleaned.substring(0, prefixCleaned.length - 1) : prefixCleaned; +} + +// src/lineAuthor/lineAuthorProvider.ts +init_polyfill_buffer(); +var import_state4 = require("@codemirror/state"); + +// src/lineAuthor/control.ts +init_polyfill_buffer(); +var import_state2 = require("@codemirror/state"); +var import_obsidian9 = require("obsidian"); + +// src/lineAuthor/eventsPerFilepath.ts +init_polyfill_buffer(); +var SECONDS = 1e3; +var REMOVE_STALES_FREQUENCY = 60 * SECONDS; +var EventsPerFilePath = class { + constructor() { + this.eventsPerFilepath = /* @__PURE__ */ new Map(); + this.startRemoveStalesSubscribersInterval(); + } + /** + * Run the {@link handler} on the subscribers to {@link filepath}. + */ + ifFilepathDefinedTransformSubscribers(filepath, handler) { + if (!filepath) + return; + this.ensureInitialized(filepath); + return handler(this.eventsPerFilepath.get(filepath)); + } + forEachSubscriber(handler) { + this.eventsPerFilepath.forEach((subs) => subs.forEach(handler)); + } + ensureInitialized(filepath) { + if (!this.eventsPerFilepath.get(filepath)) + this.eventsPerFilepath.set(filepath, /* @__PURE__ */ new Set()); + } + startRemoveStalesSubscribersInterval() { + this.removeStalesSubscribersTimer = window.setInterval( + () => this == null ? void 0 : this.forEachSubscriber((las) => las == null ? void 0 : las.removeIfStale()), + REMOVE_STALES_FREQUENCY + ); + } + clear() { + window.clearInterval(this.removeStalesSubscribersTimer); + this.eventsPerFilepath.clear(); + } +}; +var eventsPerFilePathSingleton = new EventsPerFilePath(); + +// src/lineAuthor/model.ts +init_polyfill_buffer(); +var import_state = require("@codemirror/state"); +var import_js_sha256 = __toESM(require_sha256()); + +// src/setting/settings.ts +init_polyfill_buffer(); +var import_obsidian8 = require("obsidian"); + +// src/gitManager/isomorphicGit.ts +init_polyfill_buffer(); + +// node_modules/.pnpm/diff@5.1.0/node_modules/diff/lib/index.mjs +init_polyfill_buffer(); +function Diff() { +} +Diff.prototype = { + diff: function diff(oldString, newString) { + var options = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : {}; + var callback = options.callback; + if (typeof options === "function") { + callback = options; + options = {}; + } + this.options = options; + var self2 = this; + function done(value) { + if (callback) { + setTimeout(function() { + callback(void 0, value); + }, 0); + return true; + } else { + return value; + } + } + oldString = this.castInput(oldString); + newString = this.castInput(newString); + oldString = this.removeEmpty(this.tokenize(oldString)); + newString = this.removeEmpty(this.tokenize(newString)); + var newLen = newString.length, oldLen = oldString.length; + var editLength = 1; + var maxEditLength = newLen + oldLen; + if (options.maxEditLength) { + maxEditLength = Math.min(maxEditLength, options.maxEditLength); + } + var bestPath = [{ + newPos: -1, + components: [] + }]; + var oldPos = this.extractCommon(bestPath[0], newString, oldString, 0); + if (bestPath[0].newPos + 1 >= newLen && oldPos + 1 >= oldLen) { + return done([{ + value: this.join(newString), + count: newString.length + }]); + } + function execEditLength() { + for (var diagonalPath = -1 * editLength; diagonalPath <= editLength; diagonalPath += 2) { + var basePath = void 0; + var addPath = bestPath[diagonalPath - 1], removePath = bestPath[diagonalPath + 1], _oldPos = (removePath ? removePath.newPos : 0) - diagonalPath; + if (addPath) { + bestPath[diagonalPath - 1] = void 0; + } + var canAdd = addPath && addPath.newPos + 1 < newLen, canRemove = removePath && 0 <= _oldPos && _oldPos < oldLen; + if (!canAdd && !canRemove) { + bestPath[diagonalPath] = void 0; + continue; + } + if (!canAdd || canRemove && addPath.newPos < removePath.newPos) { + basePath = clonePath(removePath); + self2.pushComponent(basePath.components, void 0, true); + } else { + basePath = addPath; + basePath.newPos++; + self2.pushComponent(basePath.components, true, void 0); + } + _oldPos = self2.extractCommon(basePath, newString, oldString, diagonalPath); + if (basePath.newPos + 1 >= newLen && _oldPos + 1 >= oldLen) { + return done(buildValues(self2, basePath.components, newString, oldString, self2.useLongestToken)); + } else { + bestPath[diagonalPath] = basePath; + } + } + editLength++; + } + if (callback) { + (function exec() { + setTimeout(function() { + if (editLength > maxEditLength) { + return callback(); + } + if (!execEditLength()) { + exec(); + } + }, 0); + })(); + } else { + while (editLength <= maxEditLength) { + var ret = execEditLength(); + if (ret) { + return ret; + } + } + } + }, + pushComponent: function pushComponent(components, added, removed) { + var last2 = components[components.length - 1]; + if (last2 && last2.added === added && last2.removed === removed) { + components[components.length - 1] = { + count: last2.count + 1, + added, + removed + }; + } else { + components.push({ + count: 1, + added, + removed + }); + } + }, + extractCommon: function extractCommon(basePath, newString, oldString, diagonalPath) { + var newLen = newString.length, oldLen = oldString.length, newPos = basePath.newPos, oldPos = newPos - diagonalPath, commonCount = 0; + while (newPos + 1 < newLen && oldPos + 1 < oldLen && this.equals(newString[newPos + 1], oldString[oldPos + 1])) { + newPos++; + oldPos++; + commonCount++; + } + if (commonCount) { + basePath.components.push({ + count: commonCount + }); + } + basePath.newPos = newPos; + return oldPos; + }, + equals: function equals(left, right) { + if (this.options.comparator) { + return this.options.comparator(left, right); + } else { + return left === right || this.options.ignoreCase && left.toLowerCase() === right.toLowerCase(); + } + }, + removeEmpty: function removeEmpty(array) { + var ret = []; + for (var i = 0; i < array.length; i++) { + if (array[i]) { + ret.push(array[i]); + } + } + return ret; + }, + castInput: function castInput(value) { + return value; + }, + tokenize: function tokenize(value) { + return value.split(""); + }, + join: function join3(chars) { + return chars.join(""); + } +}; +function buildValues(diff2, components, newString, oldString, useLongestToken) { + var componentPos = 0, componentLen = components.length, newPos = 0, oldPos = 0; + for (; componentPos < componentLen; componentPos++) { + var component = components[componentPos]; + if (!component.removed) { + if (!component.added && useLongestToken) { + var value = newString.slice(newPos, newPos + component.count); + value = value.map(function(value2, i) { + var oldValue = oldString[oldPos + i]; + return oldValue.length > value2.length ? oldValue : value2; + }); + component.value = diff2.join(value); + } else { + component.value = diff2.join(newString.slice(newPos, newPos + component.count)); + } + newPos += component.count; + if (!component.added) { + oldPos += component.count; + } + } else { + component.value = diff2.join(oldString.slice(oldPos, oldPos + component.count)); + oldPos += component.count; + if (componentPos && components[componentPos - 1].added) { + var tmp = components[componentPos - 1]; + components[componentPos - 1] = components[componentPos]; + components[componentPos] = tmp; + } + } + } + var lastComponent = components[componentLen - 1]; + if (componentLen > 1 && typeof lastComponent.value === "string" && (lastComponent.added || lastComponent.removed) && diff2.equals("", lastComponent.value)) { + components[componentLen - 2].value += lastComponent.value; + components.pop(); + } + return components; +} +function clonePath(path2) { + return { + newPos: path2.newPos, + components: path2.components.slice(0) + }; +} +var characterDiff = new Diff(); +function diffChars(oldStr, newStr, options) { + return characterDiff.diff(oldStr, newStr, options); +} +var extendedWordChars = /^[A-Za-z\xC0-\u02C6\u02C8-\u02D7\u02DE-\u02FF\u1E00-\u1EFF]+$/; +var reWhitespace = /\S/; +var wordDiff = new Diff(); +wordDiff.equals = function(left, right) { + if (this.options.ignoreCase) { + left = left.toLowerCase(); + right = right.toLowerCase(); + } + return left === right || this.options.ignoreWhitespace && !reWhitespace.test(left) && !reWhitespace.test(right); +}; +wordDiff.tokenize = function(value) { + var tokens = value.split(/([^\S\r\n]+|[()[\]{}'"\r\n]|\b)/); + for (var i = 0; i < tokens.length - 1; i++) { + if (!tokens[i + 1] && tokens[i + 2] && extendedWordChars.test(tokens[i]) && extendedWordChars.test(tokens[i + 2])) { + tokens[i] += tokens[i + 2]; + tokens.splice(i + 1, 2); + i--; + } + } + return tokens; +}; +function diffWordsWithSpace(oldStr, newStr, options) { + return wordDiff.diff(oldStr, newStr, options); +} +var lineDiff = new Diff(); +lineDiff.tokenize = function(value) { + var retLines = [], linesAndNewlines = value.split(/(\n|\r\n)/); + if (!linesAndNewlines[linesAndNewlines.length - 1]) { + linesAndNewlines.pop(); + } + for (var i = 0; i < linesAndNewlines.length; i++) { + var line = linesAndNewlines[i]; + if (i % 2 && !this.options.newlineIsToken) { + retLines[retLines.length - 1] += line; + } else { + if (this.options.ignoreWhitespace) { + line = line.trim(); + } + retLines.push(line); + } + } + return retLines; +}; +function diffLines(oldStr, newStr, callback) { + return lineDiff.diff(oldStr, newStr, callback); +} +var sentenceDiff = new Diff(); +sentenceDiff.tokenize = function(value) { + return value.split(/(\S.+?[.!?])(?=\s+|$)/); +}; +var cssDiff = new Diff(); +cssDiff.tokenize = function(value) { + return value.split(/([{}:;,]|\s+)/); +}; +function _typeof(obj) { + "@babel/helpers - typeof"; + if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { + _typeof = function(obj2) { + return typeof obj2; + }; + } else { + _typeof = function(obj2) { + return obj2 && typeof Symbol === "function" && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2; + }; + } + return _typeof(obj); +} +function _toConsumableArray(arr) { + return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); +} +function _arrayWithoutHoles(arr) { + if (Array.isArray(arr)) + return _arrayLikeToArray(arr); +} +function _iterableToArray(iter) { + if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) + return Array.from(iter); +} +function _unsupportedIterableToArray(o, minLen) { + if (!o) + return; + if (typeof o === "string") + return _arrayLikeToArray(o, minLen); + var n = Object.prototype.toString.call(o).slice(8, -1); + if (n === "Object" && o.constructor) + n = o.constructor.name; + if (n === "Map" || n === "Set") + return Array.from(o); + if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) + return _arrayLikeToArray(o, minLen); +} +function _arrayLikeToArray(arr, len) { + if (len == null || len > arr.length) + len = arr.length; + for (var i = 0, arr2 = new Array(len); i < len; i++) + arr2[i] = arr[i]; + return arr2; +} +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); +} +var objectPrototypeToString = Object.prototype.toString; +var jsonDiff = new Diff(); +jsonDiff.useLongestToken = true; +jsonDiff.tokenize = lineDiff.tokenize; +jsonDiff.castInput = function(value) { + var _this$options = this.options, undefinedReplacement = _this$options.undefinedReplacement, _this$options$stringi = _this$options.stringifyReplacer, stringifyReplacer = _this$options$stringi === void 0 ? function(k, v) { + return typeof v === "undefined" ? undefinedReplacement : v; + } : _this$options$stringi; + return typeof value === "string" ? value : JSON.stringify(canonicalize(value, null, null, stringifyReplacer), stringifyReplacer, " "); +}; +jsonDiff.equals = function(left, right) { + return Diff.prototype.equals.call(jsonDiff, left.replace(/,([\r\n])/g, "$1"), right.replace(/,([\r\n])/g, "$1")); +}; +function canonicalize(obj, stack, replacementStack, replacer, key2) { + stack = stack || []; + replacementStack = replacementStack || []; + if (replacer) { + obj = replacer(key2, obj); + } + var i; + for (i = 0; i < stack.length; i += 1) { + if (stack[i] === obj) { + return replacementStack[i]; + } + } + var canonicalizedObj; + if ("[object Array]" === objectPrototypeToString.call(obj)) { + stack.push(obj); + canonicalizedObj = new Array(obj.length); + replacementStack.push(canonicalizedObj); + for (i = 0; i < obj.length; i += 1) { + canonicalizedObj[i] = canonicalize(obj[i], stack, replacementStack, replacer, key2); + } + stack.pop(); + replacementStack.pop(); + return canonicalizedObj; + } + if (obj && obj.toJSON) { + obj = obj.toJSON(); + } + if (_typeof(obj) === "object" && obj !== null) { + stack.push(obj); + canonicalizedObj = {}; + replacementStack.push(canonicalizedObj); + var sortedKeys = [], _key; + for (_key in obj) { + if (obj.hasOwnProperty(_key)) { + sortedKeys.push(_key); + } + } + sortedKeys.sort(); + for (i = 0; i < sortedKeys.length; i += 1) { + _key = sortedKeys[i]; + canonicalizedObj[_key] = canonicalize(obj[_key], stack, replacementStack, replacer, _key); + } + stack.pop(); + replacementStack.pop(); + } else { + canonicalizedObj = obj; + } + return canonicalizedObj; +} +var arrayDiff = new Diff(); +arrayDiff.tokenize = function(value) { + return value.slice(); +}; +arrayDiff.join = arrayDiff.removeEmpty = function(value) { + return value; +}; +function structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { + if (!options) { + options = {}; + } + if (typeof options.context === "undefined") { + options.context = 4; + } + var diff2 = diffLines(oldStr, newStr, options); + if (!diff2) { + return; + } + diff2.push({ + value: "", + lines: [] + }); + function contextLines(lines) { + return lines.map(function(entry) { + return " " + entry; + }); + } + var hunks = []; + var oldRangeStart = 0, newRangeStart = 0, curRange = [], oldLine = 1, newLine = 1; + var _loop = function _loop2(i2) { + var current = diff2[i2], lines = current.lines || current.value.replace(/\n$/, "").split("\n"); + current.lines = lines; + if (current.added || current.removed) { + var _curRange; + if (!oldRangeStart) { + var prev = diff2[i2 - 1]; + oldRangeStart = oldLine; + newRangeStart = newLine; + if (prev) { + curRange = options.context > 0 ? contextLines(prev.lines.slice(-options.context)) : []; + oldRangeStart -= curRange.length; + newRangeStart -= curRange.length; + } + } + (_curRange = curRange).push.apply(_curRange, _toConsumableArray(lines.map(function(entry) { + return (current.added ? "+" : "-") + entry; + }))); + if (current.added) { + newLine += lines.length; + } else { + oldLine += lines.length; + } + } else { + if (oldRangeStart) { + if (lines.length <= options.context * 2 && i2 < diff2.length - 2) { + var _curRange2; + (_curRange2 = curRange).push.apply(_curRange2, _toConsumableArray(contextLines(lines))); + } else { + var _curRange3; + var contextSize = Math.min(lines.length, options.context); + (_curRange3 = curRange).push.apply(_curRange3, _toConsumableArray(contextLines(lines.slice(0, contextSize)))); + var hunk = { + oldStart: oldRangeStart, + oldLines: oldLine - oldRangeStart + contextSize, + newStart: newRangeStart, + newLines: newLine - newRangeStart + contextSize, + lines: curRange + }; + if (i2 >= diff2.length - 2 && lines.length <= options.context) { + var oldEOFNewline = /\n$/.test(oldStr); + var newEOFNewline = /\n$/.test(newStr); + var noNlBeforeAdds = lines.length == 0 && curRange.length > hunk.oldLines; + if (!oldEOFNewline && noNlBeforeAdds && oldStr.length > 0) { + curRange.splice(hunk.oldLines, 0, "\\ No newline at end of file"); + } + if (!oldEOFNewline && !noNlBeforeAdds || !newEOFNewline) { + curRange.push("\\ No newline at end of file"); + } + } + hunks.push(hunk); + oldRangeStart = 0; + newRangeStart = 0; + curRange = []; + } + } + oldLine += lines.length; + newLine += lines.length; + } + }; + for (var i = 0; i < diff2.length; i++) { + _loop(i); + } + return { + oldFileName, + newFileName, + oldHeader, + newHeader, + hunks + }; +} +function formatPatch(diff2) { + var ret = []; + if (diff2.oldFileName == diff2.newFileName) { + ret.push("Index: " + diff2.oldFileName); + } + ret.push("==================================================================="); + ret.push("--- " + diff2.oldFileName + (typeof diff2.oldHeader === "undefined" ? "" : " " + diff2.oldHeader)); + ret.push("+++ " + diff2.newFileName + (typeof diff2.newHeader === "undefined" ? "" : " " + diff2.newHeader)); + for (var i = 0; i < diff2.hunks.length; i++) { + var hunk = diff2.hunks[i]; + if (hunk.oldLines === 0) { + hunk.oldStart -= 1; + } + if (hunk.newLines === 0) { + hunk.newStart -= 1; + } + ret.push("@@ -" + hunk.oldStart + "," + hunk.oldLines + " +" + hunk.newStart + "," + hunk.newLines + " @@"); + ret.push.apply(ret, hunk.lines); + } + return ret.join("\n") + "\n"; +} +function createTwoFilesPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options) { + return formatPatch(structuredPatch(oldFileName, newFileName, oldStr, newStr, oldHeader, newHeader, options)); +} +function createPatch(fileName, oldStr, newStr, oldHeader, newHeader, options) { + return createTwoFilesPatch(fileName, fileName, oldStr, newStr, oldHeader, newHeader, options); +} + +// src/gitManager/isomorphicGit.ts +var import_obsidian7 = require("obsidian"); + +// src/ui/modals/generalModal.ts +init_polyfill_buffer(); +var import_obsidian5 = require("obsidian"); +var generalModalConfigDefaults = { + options: [], + placeholder: "", + allowEmpty: false, + onlySelection: false, + initialValue: void 0 +}; +var GeneralModal = class extends import_obsidian5.SuggestModal { + constructor(config) { + super(app); + this.config = { ...generalModalConfigDefaults, ...config }; + this.setPlaceholder(this.config.placeholder); + } + open() { + super.open(); + if (this.config.initialValue != void 0) { + this.inputEl.value = this.config.initialValue; + this.inputEl.dispatchEvent(new Event("input")); + } + return new Promise((resolve) => { + this.resolve = resolve; + }); + } + selectSuggestion(value, evt) { + if (this.resolve) { + let res; + if (this.config.allowEmpty && value === " ") + res = ""; + else if (value === "...") + res = void 0; + else + res = value; + this.resolve(res); + } + super.selectSuggestion(value, evt); + } + onClose() { + if (this.resolve) + this.resolve(void 0); + } + getSuggestions(query) { + if (this.config.onlySelection) { + return this.config.options; + } else if (this.config.allowEmpty) { + return [query.length > 0 ? query : " ", ...this.config.options]; + } else { + return [query.length > 0 ? query : "...", ...this.config.options]; + } + } + renderSuggestion(value, el) { + el.setText(value); + } + onChooseSuggestion(item, evt) { + } +}; + +// src/gitManager/myAdapter.ts +init_polyfill_buffer(); +var import_obsidian6 = require("obsidian"); +var MyAdapter = class { + constructor(vault, plugin) { + this.plugin = plugin; + this.promises = {}; + this.adapter = vault.adapter; + this.vault = vault; + this.lastBasePath = this.plugin.settings.basePath; + this.promises.readFile = this.readFile.bind(this); + this.promises.writeFile = this.writeFile.bind(this); + this.promises.readdir = this.readdir.bind(this); + this.promises.mkdir = this.mkdir.bind(this); + this.promises.rmdir = this.rmdir.bind(this); + this.promises.stat = this.stat.bind(this); + this.promises.unlink = this.unlink.bind(this); + this.promises.lstat = this.lstat.bind(this); + this.promises.readlink = this.readlink.bind(this); + this.promises.symlink = this.symlink.bind(this); + } + async readFile(path2, opts) { + var _a2; + this.maybeLog("Read: " + path2 + JSON.stringify(opts)); + if (opts == "utf8" || opts.encoding == "utf8") { + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian6.TFile) { + this.maybeLog("Reuse"); + return this.vault.read(file); + } else { + return this.adapter.read(path2); + } + } else { + if (path2.endsWith(this.gitDir + "/index")) { + if (this.plugin.settings.basePath != this.lastBasePath) { + this.clearIndex(); + this.lastBasePath = this.plugin.settings.basePath; + return this.adapter.readBinary(path2); + } + return (_a2 = this.index) != null ? _a2 : this.adapter.readBinary(path2); + } + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian6.TFile) { + this.maybeLog("Reuse"); + return this.vault.readBinary(file); + } else { + return this.adapter.readBinary(path2); + } + } + } + async writeFile(path2, data) { + this.maybeLog("Write: " + path2); + if (typeof data === "string") { + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian6.TFile) { + return this.vault.modify(file, data); + } else { + return this.adapter.write(path2, data); + } + } else { + if (path2.endsWith(this.gitDir + "/index")) { + this.index = data; + this.indexmtime = Date.now(); + } else { + const file = this.vault.getAbstractFileByPath(path2); + if (file instanceof import_obsidian6.TFile) { + return this.vault.modifyBinary(file, data); + } else { + return this.adapter.writeBinary(path2, data); + } + } + } + } + async readdir(path2) { + if (path2 === ".") + path2 = "/"; + const res = await this.adapter.list(path2); + const all = [...res.files, ...res.folders]; + let formattedAll; + if (path2 !== "/") { + formattedAll = all.map( + (e) => (0, import_obsidian6.normalizePath)(e.substring(path2.length)) + ); + } else { + formattedAll = all; + } + return formattedAll; + } + async mkdir(path2) { + return this.adapter.mkdir(path2); + } + async rmdir(path2, opts) { + var _a2, _b; + return this.adapter.rmdir(path2, (_b = (_a2 = opts == null ? void 0 : opts.options) == null ? void 0 : _a2.recursive) != null ? _b : false); + } + async stat(path2) { + if (path2.endsWith(this.gitDir + "/index")) { + if (this.index !== void 0 && this.indexctime != void 0 && this.indexmtime != void 0) { + return { + isFile: () => true, + isDirectory: () => false, + isSymbolicLink: () => false, + size: this.index.length, + type: "file", + ctimeMs: this.indexctime, + mtimeMs: this.indexmtime + }; + } else { + const stat = await this.adapter.stat(path2); + if (stat == void 0) { + throw { code: "ENOENT" }; + } + this.indexctime = stat.ctime; + this.indexmtime = stat.mtime; + return { + ctimeMs: stat.ctime, + mtimeMs: stat.mtime, + size: stat.size, + type: "file", + isFile: () => true, + isDirectory: () => false, + isSymbolicLink: () => false + }; + } + } + if (path2 === ".") + path2 = "/"; + const file = this.vault.getAbstractFileByPath(path2); + this.maybeLog("Stat: " + path2); + if (file instanceof import_obsidian6.TFile) { + this.maybeLog("Reuse stat"); + return { + ctimeMs: file.stat.ctime, + mtimeMs: file.stat.mtime, + size: file.stat.size, + type: "file", + isFile: () => true, + isDirectory: () => false, + isSymbolicLink: () => false + }; + } else { + const stat = await this.adapter.stat(path2); + if (stat) { + return { + ctimeMs: stat.ctime, + mtimeMs: stat.mtime, + size: stat.size, + type: stat.type === "folder" ? "directory" : stat.type, + isFile: () => stat.type === "file", + isDirectory: () => stat.type === "folder", + isSymbolicLink: () => false + }; + } else { + throw { code: "ENOENT" }; + } + } + } + async unlink(path2) { + return this.adapter.remove(path2); + } + async lstat(path2) { + return this.stat(path2); + } + async readlink(path2) { + throw new Error(`readlink of (${path2}) is not implemented.`); + } + async symlink(path2) { + throw new Error(`symlink of (${path2}) is not implemented.`); + } + async saveAndClear() { + if (this.index !== void 0) { + await this.adapter.writeBinary( + this.plugin.gitManager.getVaultPath(this.gitDir + "/index"), + this.index, + { + ctime: this.indexctime, + mtime: this.indexmtime + } + ); + } + this.clearIndex(); + } + clearIndex() { + this.index = void 0; + this.indexctime = void 0; + this.indexmtime = void 0; + } + get gitDir() { + return this.plugin.settings.gitDir || ".git"; + } + maybeLog(text2) { + } +}; + +// src/gitManager/isomorphicGit.ts +var IsomorphicGit = class extends GitManager { + constructor(plugin) { + super(plugin); + this.FILE = 0; + this.HEAD = 1; + this.WORKDIR = 2; + this.STAGE = 3; + // Mapping from statusMatrix to git status codes based off git status --short + // See: https://isomorphic-git.org/docs/en/statusMatrix + this.status_mapping = { + "000": " ", + "003": "AD", + "020": "??", + "022": "A ", + "023": "AM", + "100": "D ", + "101": " D", + "103": "MD", + "110": "DA", + // Technically, two files: first one is deleted "D " and second one is untracked "??" + "111": " ", + "113": "MM", + "120": "DA", + // Same as "110" + "121": " M", + "122": "M ", + "123": "MM" + }; + this.noticeLength = 999999; + this.fs = new MyAdapter(this.app.vault, this.plugin); + } + getRepo() { + return { + fs: this.fs, + dir: this.plugin.settings.basePath, + gitdir: this.plugin.settings.gitDir || void 0, + onAuth: () => { + var _a2, _b; + return { + username: (_a2 = this.plugin.localStorage.getUsername()) != null ? _a2 : void 0, + password: (_b = this.plugin.localStorage.getPassword()) != null ? _b : void 0 + }; + }, + onAuthFailure: async () => { + new import_obsidian7.Notice( + "Authentication failed. Please try with different credentials" + ); + const username = await new GeneralModal({ + placeholder: "Specify your username" + }).open(); + if (username) { + const password = await new GeneralModal({ + placeholder: "Specify your password/personal access token" + }).open(); + if (password) { + this.plugin.localStorage.setUsername(username); + this.plugin.localStorage.setPassword(password); + return { + username, + password + }; + } + } + return { cancel: true }; + }, + http: { + async request({ + url, + method: method2, + headers, + body + }) { + if (body) { + body = await collect2(body); + body = body.buffer; + } + const res = await (0, import_obsidian7.requestUrl)({ + url, + method: method2, + headers, + body, + throw: false + }); + return { + url, + method: method2, + headers: res.headers, + body: [new Uint8Array(res.arrayBuffer)], + statusCode: res.status, + statusMessage: res.status.toString() + }; + } + } + }; + } + async wrapFS(call) { + try { + const res = await call; + await this.fs.saveAndClear(); + return res; + } catch (error) { + await this.fs.saveAndClear(); + throw error; + } + } + async status() { + let notice; + const timeout = window.setTimeout(function() { + notice = new import_obsidian7.Notice( + "This takes longer: Getting status", + this.noticeLength + ); + }, 2e4); + try { + this.plugin.setState(1 /* status */); + const status2 = (await this.wrapFS(isomorphic_git_default.statusMatrix({ ...this.getRepo() }))).map((row) => this.getFileStatusResult(row)); + const changed = status2.filter( + (fileStatus) => fileStatus.working_dir !== " " + ); + const staged = status2.filter( + (fileStatus) => fileStatus.index !== " " && fileStatus.index !== "U" + ); + const conflicted = []; + window.clearTimeout(timeout); + notice == null ? void 0 : notice.hide(); + return { changed, staged, conflicted }; + } catch (error) { + window.clearTimeout(timeout); + notice == null ? void 0 : notice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async commitAll({ + message, + status: status2, + unstagedFiles + }) { + try { + await this.checkAuthorInfo(); + await this.stageAll({ status: status2, unstagedFiles }); + return this.commit(message); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async commit(message) { + try { + await this.checkAuthorInfo(); + this.plugin.setState(4 /* commit */); + const formatMessage = await this.formatCommitMessage(message); + const hadConflict = this.plugin.localStorage.getConflict() === "true"; + let parent = void 0; + if (hadConflict) { + const branchInfo = await this.branchInfo(); + parent = [branchInfo.current, branchInfo.tracking]; + } + await this.wrapFS( + isomorphic_git_default.commit({ + ...this.getRepo(), + message: formatMessage, + parent + }) + ); + this.plugin.localStorage.setConflict("false"); + return; + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async stage(filepath, relativeToVault) { + const gitPath = this.asRepositoryRelativePath( + filepath, + relativeToVault + ); + let vaultPath; + if (relativeToVault) { + vaultPath = filepath; + } else { + vaultPath = this.getVaultPath(filepath); + } + try { + this.plugin.setState(3 /* add */); + if (await this.app.vault.adapter.exists(vaultPath)) { + await this.wrapFS( + isomorphic_git_default.add({ ...this.getRepo(), filepath: gitPath }) + ); + } else { + await this.wrapFS( + isomorphic_git_default.remove({ ...this.getRepo(), filepath: gitPath }) + ); + } + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async stageAll({ + dir, + status: status2, + unstagedFiles + }) { + try { + if (status2) { + await Promise.all( + status2.changed.map( + (file) => file.working_dir !== "D" ? this.wrapFS( + isomorphic_git_default.add({ + ...this.getRepo(), + filepath: file.path + }) + ) : isomorphic_git_default.remove({ + ...this.getRepo(), + filepath: file.path + }) + ) + ); + } else { + const filesToStage = unstagedFiles != null ? unstagedFiles : await this.getUnstagedFiles(dir != null ? dir : "."); + await Promise.all( + filesToStage.map( + ({ filepath, deleted }) => deleted ? isomorphic_git_default.remove({ ...this.getRepo(), filepath }) : this.wrapFS( + isomorphic_git_default.add({ ...this.getRepo(), filepath }) + ) + ) + ); + } + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async unstage(filepath, relativeToVault) { + try { + this.plugin.setState(3 /* add */); + filepath = this.asRepositoryRelativePath(filepath, relativeToVault); + await this.wrapFS( + isomorphic_git_default.resetIndex({ ...this.getRepo(), filepath }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async unstageAll({ + dir, + status: status2 + }) { + try { + let staged; + if (status2) { + staged = status2.staged.map((file) => file.path); + } else { + const res = await this.getStagedFiles(dir != null ? dir : "."); + staged = res.map(({ filepath }) => filepath); + } + await this.wrapFS( + Promise.all( + staged.map( + (file) => isomorphic_git_default.resetIndex({ ...this.getRepo(), filepath: file }) + ) + ) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async discard(filepath) { + try { + this.plugin.setState(3 /* add */); + await this.wrapFS( + isomorphic_git_default.checkout({ + ...this.getRepo(), + filepaths: [filepath], + force: true + }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async discardAll({ + dir, + status: status2 + }) { + let files = []; + if (status2) { + if (dir != void 0) { + files = status2.changed.filter((file) => file.path.startsWith(dir)).map((file) => file.path); + } else { + files = status2.changed.map((file) => file.path); + } + } else { + files = (await this.getUnstagedFiles(dir)).map( + ({ filepath }) => filepath + ); + } + try { + await this.wrapFS( + isomorphic_git_default.checkout({ + ...this.getRepo(), + filepaths: files, + force: true + }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + getProgressText(action, event) { + let out = `${action} progress:`; + if (event.phase) { + out = `${out} ${event.phase}:`; + } + if (event.loaded) { + out = `${out} ${event.loaded}`; + if (event.total) { + out = `${out} of ${event.total}`; + } + } + return out; + } + resolveRef(ref) { + return this.wrapFS(isomorphic_git_default.resolveRef({ ...this.getRepo(), ref })); + } + async pull() { + const progressNotice = this.showNotice("Initializing pull"); + try { + this.plugin.setState(2 /* pull */); + const localCommit = await this.resolveRef("HEAD"); + await this.fetch(); + const branchInfo = await this.branchInfo(); + await this.checkAuthorInfo(); + const mergeRes = await this.wrapFS( + isomorphic_git_default.merge({ + ...this.getRepo(), + ours: branchInfo.current, + theirs: branchInfo.tracking, + abortOnConflict: false + }) + ); + if (!mergeRes.alreadyMerged) { + await this.wrapFS( + isomorphic_git_default.checkout({ + ...this.getRepo(), + ref: branchInfo.current, + onProgress: (progress) => { + if (progressNotice !== void 0) { + progressNotice.noticeEl.innerText = this.getProgressText("Checkout", progress); + } + }, + remote: branchInfo.remote + }) + ); + } + progressNotice == null ? void 0 : progressNotice.hide(); + const upstreamCommit = await this.resolveRef("HEAD"); + const changedFiles = await this.getFileChangesCount( + localCommit, + upstreamCommit + ); + this.showNotice("Finished pull", false); + return changedFiles.map((file) => ({ + path: file.path, + working_dir: "P", + index: "P", + vault_path: this.getVaultPath(file.path) + })); + } catch (error) { + progressNotice == null ? void 0 : progressNotice.hide(); + if (error instanceof Errors.MergeConflictError) { + this.plugin.handleConflict( + error.data.filepaths.map((file) => this.getVaultPath(file)) + ); + } + this.plugin.displayError(error); + throw error; + } + } + async push() { + if (!await this.canPush()) { + return 0; + } + const progressNotice = this.showNotice("Initializing push"); + try { + this.plugin.setState(1 /* status */); + const status2 = await this.branchInfo(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const numChangedFiles = (await this.getFileChangesCount(currentBranch2, trackingBranch)).length; + this.plugin.setState(5 /* push */); + await this.wrapFS( + isomorphic_git_default.push({ + ...this.getRepo(), + onProgress: (progress) => { + if (progressNotice !== void 0) { + progressNotice.noticeEl.innerText = this.getProgressText("Pushing", progress); + } + } + }) + ); + progressNotice == null ? void 0 : progressNotice.hide(); + return numChangedFiles; + } catch (error) { + progressNotice == null ? void 0 : progressNotice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async getUnpushedCommits() { + const status2 = await this.branchInfo(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + if (trackingBranch == null || currentBranch2 == null) { + return 0; + } + const localCommit = await this.resolveRef(currentBranch2); + const upstreamCommit = await this.resolveRef(trackingBranch); + const changedFiles = await this.getFileChangesCount( + localCommit, + upstreamCommit + ); + return changedFiles.length; + } + async canPush() { + const status2 = await this.branchInfo(); + const trackingBranch = status2.tracking; + const currentBranch2 = status2.current; + const current = await this.resolveRef(currentBranch2); + const tracking = await this.resolveRef(trackingBranch); + return current != tracking; + } + async checkRequirements() { + const headExists = await this.plugin.app.vault.adapter.exists( + `${this.getRepo().dir}/.git/HEAD` + ); + return headExists ? "valid" : "missing-repo"; + } + async branchInfo() { + var _a2, _b; + try { + const current = await isomorphic_git_default.currentBranch(this.getRepo()) || ""; + const branches = await isomorphic_git_default.listBranches(this.getRepo()); + const remote = (_a2 = await this.getConfig(`branch.${current}.remote`)) != null ? _a2 : "origin"; + const trackingBranch = (_b = await this.getConfig(`branch.${current}.merge`)) == null ? void 0 : _b.split("refs/heads")[1]; + const tracking = trackingBranch ? remote + trackingBranch : void 0; + return { + current, + tracking, + branches, + remote + }; + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async getCurrentRemote() { + var _a2; + const current = await isomorphic_git_default.currentBranch(this.getRepo()) || ""; + const remote = (_a2 = await this.getConfig(`branch.${current}.remote`)) != null ? _a2 : "origin"; + return remote; + } + async checkout(branch2, remote) { + try { + return this.wrapFS( + isomorphic_git_default.checkout({ + ...this.getRepo(), + ref: branch2, + force: !!remote, + remote + }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async createBranch(branch2) { + try { + await this.wrapFS( + isomorphic_git_default.branch({ ...this.getRepo(), ref: branch2, checkout: true }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async deleteBranch(branch2) { + try { + await this.wrapFS( + isomorphic_git_default.deleteBranch({ ...this.getRepo(), ref: branch2 }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async branchIsMerged(branch2) { + return true; + } + async init() { + try { + await this.wrapFS(isomorphic_git_default.init(this.getRepo())); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async clone(url, dir, depth) { + const progressNotice = this.showNotice("Initializing clone"); + try { + await this.wrapFS( + isomorphic_git_default.clone({ + ...this.getRepo(), + dir, + url, + depth, + onProgress: (progress) => { + if (progressNotice !== void 0) { + progressNotice.noticeEl.innerText = this.getProgressText("Cloning", progress); + } + } + }) + ); + progressNotice == null ? void 0 : progressNotice.hide(); + } catch (error) { + progressNotice == null ? void 0 : progressNotice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async setConfig(path2, value) { + try { + return this.wrapFS( + isomorphic_git_default.setConfig({ + ...this.getRepo(), + path: path2, + value + }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async getConfig(path2) { + try { + return this.wrapFS( + isomorphic_git_default.getConfig({ + ...this.getRepo(), + path: path2 + }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async fetch(remote) { + const progressNotice = this.showNotice("Initializing fetch"); + try { + const args = { + ...this.getRepo(), + onProgress: (progress) => { + if (progressNotice !== void 0) { + progressNotice.noticeEl.innerText = this.getProgressText("Fetching", progress); + } + }, + remote: remote != null ? remote : await this.getCurrentRemote() + }; + await this.wrapFS(isomorphic_git_default.fetch(args)); + progressNotice == null ? void 0 : progressNotice.hide(); + } catch (error) { + this.plugin.displayError(error); + progressNotice == null ? void 0 : progressNotice.hide(); + throw error; + } + } + async setRemote(name, url) { + try { + await this.wrapFS( + isomorphic_git_default.addRemote({ + ...this.getRepo(), + remote: name, + url, + force: true + }) + ); + } catch (error) { + this.plugin.displayError(error); + throw error; + } + } + async getRemoteBranches(remote) { + let remoteBranches = []; + remoteBranches.push( + ...await this.wrapFS( + isomorphic_git_default.listBranches({ ...this.getRepo(), remote }) + ) + ); + remoteBranches.remove("HEAD"); + remoteBranches = remoteBranches.map((e) => `${remote}/${e}`); + return remoteBranches; + } + async getRemotes() { + return (await this.wrapFS(isomorphic_git_default.listRemotes({ ...this.getRepo() }))).map( + (remoteUrl) => remoteUrl.remote + ); + } + async removeRemote(remoteName) { + await this.wrapFS( + isomorphic_git_default.deleteRemote({ ...this.getRepo(), remote: remoteName }) + ); + } + async getRemoteUrl(remote) { + var _a2; + return (_a2 = (await this.wrapFS(isomorphic_git_default.listRemotes({ ...this.getRepo() }))).filter((item) => item.remote == remote)[0]) == null ? void 0 : _a2.url; + } + async log(_, __ = true, limit) { + const logs = await this.wrapFS( + isomorphic_git_default.log({ ...this.getRepo(), depth: limit }) + ); + return Promise.all( + logs.map(async (log2) => { + const completeMessage = log2.commit.message.split("\n\n"); + return { + message: completeMessage[0], + body: completeMessage.slice(1).join("\n\n"), + date: new Date( + log2.commit.committer.timestamp + ).toDateString(), + diff: { + changed: 0, + files: (await this.getFileChangesCount( + log2.commit.parent.first(), + log2.oid + )).map((item) => { + return { + path: item.path, + status: item.type, + vault_path: this.getVaultPath(item.path), + hash: log2.oid, + binary: void 0 + }; + }) + }, + hash: log2.oid, + refs: [] + }; + }) + ); + } + updateBasePath(basePath) { + this.getRepo().dir = basePath; + } + async updateUpstreamBranch(remoteBranch) { + const [remote, branch2] = splitRemoteBranch(remoteBranch); + const branchInfo = await this.branchInfo(); + await this.setConfig( + `branch.${branchInfo.current}.merge`, + `refs/heads/${branch2}` + ); + await this.setConfig(`branch.${branch2}.remote`, remote); + } + updateGitPath(gitPath) { + return; + } + async getFileChangesCount(commitHash1, commitHash2) { + return this.walkDifference({ + walkers: [ + isomorphic_git_default.TREE({ ref: commitHash1 }), + isomorphic_git_default.TREE({ ref: commitHash2 }) + ] + }); + } + async walkDifference({ + walkers, + dir: base + }) { + const res = await this.wrapFS( + isomorphic_git_default.walk({ + ...this.getRepo(), + trees: walkers, + map: async function(filepath, [A, B]) { + if (!worthWalking2(filepath, base)) { + return null; + } + if (await (A == null ? void 0 : A.type()) === "tree" || await (B == null ? void 0 : B.type()) === "tree") { + return; + } + const Aoid = await (A == null ? void 0 : A.oid()); + const Boid = await (B == null ? void 0 : B.oid()); + let type = "equal"; + if (Aoid !== Boid) { + type = "M"; + } + if (Aoid === void 0) { + type = "A"; + } + if (Boid === void 0) { + type = "D"; + } + if (Aoid === void 0 && Boid === void 0) { + console.log("Something weird happened:"); + console.log(A); + console.log(B); + } + if (type === "equal") { + return; + } + return { + path: filepath, + type + }; + } + }) + ); + return res; + } + async getStagedFiles(dir = ".") { + const res = await this.walkDifference({ + walkers: [isomorphic_git_default.TREE({ ref: "HEAD" }), isomorphic_git_default.STAGE()], + dir + }); + return res.map((file) => { + return { + vault_path: this.getVaultPath(file.path), + filepath: file.path + }; + }); + } + async getUnstagedFiles(base = ".") { + let notice; + const timeout = window.setTimeout(function() { + notice = new import_obsidian7.Notice( + "This takes longer: Getting status", + this.noticeLength + ); + }, 2e4); + try { + const repo = this.getRepo(); + const res = await this.wrapFS( + //Modified from `git.statusMatrix` + isomorphic_git_default.walk({ + ...repo, + trees: [isomorphic_git_default.WORKDIR(), isomorphic_git_default.STAGE()], + map: async function(filepath, [workdir, stage]) { + if (!stage && workdir) { + const isIgnored2 = await isomorphic_git_default.isIgnored({ + ...repo, + filepath + }); + if (isIgnored2) { + return null; + } + } + if (!worthWalking2(filepath, base)) { + return null; + } + const [workdirType, stageType] = await Promise.all([ + workdir && workdir.type(), + stage && stage.type() + ]); + const isBlob = [workdirType, stageType].includes( + "blob" + ); + if ((workdirType === "tree" || workdirType === "special") && !isBlob) + return; + if (stageType === "commit") + return null; + if ((stageType === "tree" || stageType === "special") && !isBlob) + return; + const stageOid = stageType === "blob" ? await stage.oid() : void 0; + let workdirOid; + if (workdirType === "blob" && stageType !== "blob") { + workdirOid = "42"; + } else if (workdirType === "blob") { + workdirOid = await workdir.oid(); + } + if (!workdirOid) { + return { + filepath, + deleted: true + }; + } + if (workdirOid !== stageOid) { + return { + filepath, + deleted: false + }; + } + return null; + } + }) + ); + window.clearTimeout(timeout); + notice == null ? void 0 : notice.hide(); + return res; + } catch (error) { + window.clearTimeout(timeout); + notice == null ? void 0 : notice.hide(); + this.plugin.displayError(error); + throw error; + } + } + async getDiffString(filePath, stagedChanges = false, hash2) { + const vaultPath = this.getVaultPath(filePath); + const map = async (file, [A]) => { + if (filePath == file) { + const oid = await A.oid(); + const contents = await isomorphic_git_default.readBlob({ + ...this.getRepo(), + oid + }); + return contents.blob; + } + }; + if (hash2) { + const commitContent = await readBlob({ + ...this.getRepo(), + filepath: filePath, + oid: hash2 + }).then((headBlob) => new TextDecoder().decode(headBlob.blob)).catch((err) => { + if (err instanceof isomorphic_git_default.Errors.NotFoundError) + return void 0; + throw err; + }); + const commit2 = await isomorphic_git_default.readCommit({ + ...this.getRepo(), + oid: hash2 + }); + const previousContent = await readBlob({ + ...this.getRepo(), + filepath: filePath, + oid: commit2.commit.parent.first() + }).then((headBlob) => new TextDecoder().decode(headBlob.blob)).catch((err) => { + if (err instanceof isomorphic_git_default.Errors.NotFoundError) + return void 0; + throw err; + }); + const diff2 = createPatch( + vaultPath, + previousContent != null ? previousContent : "", + commitContent != null ? commitContent : "" + ); + return diff2; + } + const stagedBlob = (await isomorphic_git_default.walk({ + ...this.getRepo(), + trees: [isomorphic_git_default.STAGE()], + map + })).first(); + const stagedContent = new TextDecoder().decode(stagedBlob); + if (stagedChanges) { + const headContent = await this.resolveRef("HEAD").then( + (oid) => readBlob({ + ...this.getRepo(), + filepath: filePath, + oid + }) + ).then((headBlob) => new TextDecoder().decode(headBlob.blob)).catch((err) => { + if (err instanceof isomorphic_git_default.Errors.NotFoundError) + return void 0; + throw err; + }); + const diff2 = createPatch( + vaultPath, + headContent != null ? headContent : "", + stagedContent + ); + return diff2; + } else { + let workdirContent; + if (await app.vault.adapter.exists(vaultPath)) { + workdirContent = await app.vault.adapter.read(vaultPath); + } else { + workdirContent = ""; + } + const diff2 = createPatch(vaultPath, stagedContent, workdirContent); + return diff2; + } + } + async getLastCommitTime() { + const repo = this.getRepo(); + const oid = await this.resolveRef("HEAD"); + const commit2 = await isomorphic_git_default.readCommit({ ...repo, oid }); + const date = commit2.commit.committer.timestamp; + return new Date(date * 1e3); + } + getFileStatusResult(row) { + const status2 = this.status_mapping[`${row[this.HEAD]}${row[this.WORKDIR]}${row[this.STAGE]}`]; + return { + index: status2[0] == "?" ? "U" : status2[0], + working_dir: status2[1] == "?" ? "U" : status2[1], + path: row[this.FILE], + vault_path: this.getVaultPath(row[this.FILE]) + }; + } + async checkAuthorInfo() { + const name = await this.getConfig("user.name"); + const email = await this.getConfig("user.email"); + if (!name || !email) { + throw "Git author information is not set. Please set it in the settings."; + } + } + showNotice(message, infinity = true) { + if (!this.plugin.settings.disablePopups) { + return new import_obsidian7.Notice( + message, + infinity ? this.noticeLength : void 0 + ); + } + } +}; +function fromValue2(value) { + let queue = [value]; + return { + next() { + return Promise.resolve({ + done: queue.length === 0, + value: queue.pop() + }); + }, + return() { + queue = []; + return {}; + }, + [Symbol.asyncIterator]() { + return this; + } + }; +} +function getIterator2(iterable) { + if (iterable[Symbol.asyncIterator]) { + return iterable[Symbol.asyncIterator](); + } + if (iterable[Symbol.iterator]) { + return iterable[Symbol.iterator](); + } + if (iterable.next) { + return iterable; + } + return fromValue2(iterable); +} +async function forAwait2(iterable, cb) { + const iter = getIterator2(iterable); + while (true) { + const { value, done } = await iter.next(); + if (value) + await cb(value); + if (done) + break; + } + if (iter.return) + iter.return(); +} +async function collect2(iterable) { + let size = 0; + const buffers = []; + await forAwait2(iterable, (value) => { + buffers.push(value); + size += value.byteLength; + }); + const result = new Uint8Array(size); + let nextIndex = 0; + for (const buffer2 of buffers) { + result.set(buffer2, nextIndex); + nextIndex += buffer2.byteLength; + } + return result; +} + +// src/setting/settings.ts +var FORMAT_STRING_REFERENCE_URL = "https://momentjs.com/docs/#/parsing/string-format/"; +var LINE_AUTHOR_FEATURE_WIKI_LINK = "https://publish.obsidian.md/git-doc/Line+Authoring"; +var ObsidianGitSettingsTab = class extends import_obsidian8.PluginSettingTab { + constructor() { + super(...arguments); + this.lineAuthorColorSettings = /* @__PURE__ */ new Map(); + } + // narrow type from PluginSettingTab.plugin + get settings() { + return this.plugin.settings; + } + display() { + const { containerEl } = this; + const plugin = this.plugin; + const commitOrBackup = plugin.settings.differentIntervalCommitAndPush ? "commit" : "backup"; + const gitReady = plugin.gitReady; + containerEl.empty(); + containerEl.createEl("h2", { text: "Git Backup settings" }); + if (!gitReady) { + containerEl.createEl("p", { + text: "Git is not ready. When all settings are correct you can configure auto backup, etc." + }); + } + if (gitReady) { + containerEl.createEl("br"); + containerEl.createEl("h3", { text: "Automatic" }); + new import_obsidian8.Setting(containerEl).setName("Split automatic commit and push").setDesc("Enable to use separate timer for commit and push").addToggle( + (toggle) => toggle.setValue( + plugin.settings.differentIntervalCommitAndPush + ).onChange((value) => { + plugin.settings.differentIntervalCommitAndPush = value; + plugin.saveSettings(); + plugin.clearAutoBackup(); + plugin.clearAutoPush(); + if (plugin.settings.autoSaveInterval > 0) { + plugin.startAutoBackup( + plugin.settings.autoSaveInterval + ); + } + if (value && plugin.settings.autoPushInterval > 0) { + plugin.startAutoPush( + plugin.settings.autoPushInterval + ); + } + this.display(); + }) + ); + new import_obsidian8.Setting(containerEl).setName(`Vault ${commitOrBackup} interval (minutes)`).setDesc( + `${plugin.settings.differentIntervalCommitAndPush ? "Commit" : "Commit and push"} changes every X minutes. Set to 0 (default) to disable. (See below setting for further configuration!)` + ).addText( + (text2) => text2.setValue(String(plugin.settings.autoSaveInterval)).onChange((value) => { + if (!isNaN(Number(value))) { + plugin.settings.autoSaveInterval = Number(value); + plugin.saveSettings(); + if (plugin.settings.autoSaveInterval > 0) { + plugin.clearAutoBackup(); + plugin.startAutoBackup( + plugin.settings.autoSaveInterval + ); + new import_obsidian8.Notice( + `Automatic ${commitOrBackup} enabled! Every ${plugin.settings.autoSaveInterval} minutes.` + ); + } else if (plugin.settings.autoSaveInterval <= 0) { + plugin.clearAutoBackup() && new import_obsidian8.Notice( + `Automatic ${commitOrBackup} disabled!` + ); + } + } else { + new import_obsidian8.Notice("Please specify a valid number."); + } + }) + ); + if (!plugin.settings.setLastSaveToLastCommit) + new import_obsidian8.Setting(containerEl).setName(`Auto Backup after stop editing any file`).setDesc( + `Requires the ${commitOrBackup} interval not to be 0. If turned on, do auto ${commitOrBackup} every ${plugin.settings.autoSaveInterval} minutes after stop editing any file. This also prevents auto ${commitOrBackup} while editing a file. If turned off, it's independent from the last change.` + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.autoBackupAfterFileChange).onChange((value) => { + plugin.settings.autoBackupAfterFileChange = value; + this.display(); + plugin.saveSettings(); + plugin.clearAutoBackup(); + if (plugin.settings.autoSaveInterval > 0) { + plugin.startAutoBackup( + plugin.settings.autoSaveInterval + ); + } + }) + ); + if (!plugin.settings.autoBackupAfterFileChange) + new import_obsidian8.Setting(containerEl).setName(`Auto ${commitOrBackup} after latest commit`).setDesc( + `If turned on, set last auto ${commitOrBackup} time to latest commit` + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.setLastSaveToLastCommit).onChange(async (value) => { + plugin.settings.setLastSaveToLastCommit = value; + plugin.saveSettings(); + this.display(); + plugin.clearAutoBackup(); + await plugin.setUpAutoBackup(); + }) + ); + if (plugin.settings.differentIntervalCommitAndPush) { + new import_obsidian8.Setting(containerEl).setName(`Vault push interval (minutes)`).setDesc( + "Push changes every X minutes. Set to 0 (default) to disable." + ).addText( + (text2) => text2.setValue(String(plugin.settings.autoPushInterval)).onChange((value) => { + if (!isNaN(Number(value))) { + plugin.settings.autoPushInterval = Number(value); + plugin.saveSettings(); + if (plugin.settings.autoPushInterval > 0) { + plugin.clearAutoPush(); + plugin.startAutoPush( + plugin.settings.autoPushInterval + ); + new import_obsidian8.Notice( + `Automatic push enabled! Every ${plugin.settings.autoPushInterval} minutes.` + ); + } else if (plugin.settings.autoPushInterval <= 0) { + plugin.clearAutoPush() && new import_obsidian8.Notice( + "Automatic push disabled!" + ); + } + } else { + new import_obsidian8.Notice( + "Please specify a valid number." + ); + } + }) + ); + } + new import_obsidian8.Setting(containerEl).setName("Auto pull interval (minutes)").setDesc( + "Pull changes every X minutes. Set to 0 (default) to disable." + ).addText( + (text2) => text2.setValue(String(plugin.settings.autoPullInterval)).onChange((value) => { + if (!isNaN(Number(value))) { + plugin.settings.autoPullInterval = Number(value); + plugin.saveSettings(); + if (plugin.settings.autoPullInterval > 0) { + plugin.clearAutoPull(); + plugin.startAutoPull( + plugin.settings.autoPullInterval + ); + new import_obsidian8.Notice( + `Automatic pull enabled! Every ${plugin.settings.autoPullInterval} minutes.` + ); + } else if (plugin.settings.autoPullInterval <= 0) { + plugin.clearAutoPull() && new import_obsidian8.Notice("Automatic pull disabled!"); + } + } else { + new import_obsidian8.Notice("Please specify a valid number."); + } + }) + ); + new import_obsidian8.Setting(containerEl).setName("Specify custom commit message on auto backup").setDesc("You will get a pop up to specify your message").addToggle( + (toggle) => toggle.setValue(plugin.settings.customMessageOnAutoBackup).onChange((value) => { + plugin.settings.customMessageOnAutoBackup = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Commit message on auto backup/commit").setDesc( + "Available placeholders: {{date}} (see below), {{hostname}} (see below), {{numFiles}} (number of changed files in the commit) and {{files}} (changed files in commit message)" + ).addTextArea( + (text2) => text2.setPlaceholder("vault backup: {{date}}").setValue(plugin.settings.autoCommitMessage).onChange((value) => { + plugin.settings.autoCommitMessage = value; + plugin.saveSettings(); + }) + ); + containerEl.createEl("br"); + containerEl.createEl("h3", { text: "Commit message" }); + new import_obsidian8.Setting(containerEl).setName("Commit message on manual backup/commit").setDesc( + "Available placeholders: {{date}} (see below), {{hostname}} (see below), {{numFiles}} (number of changed files in the commit) and {{files}} (changed files in commit message)" + ).addTextArea( + (text2) => text2.setPlaceholder("vault backup: {{date}}").setValue( + plugin.settings.commitMessage ? plugin.settings.commitMessage : "" + ).onChange((value) => { + plugin.settings.commitMessage = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("{{date}} placeholder format").setDesc( + `Specify custom date format. E.g. "${DATE_TIME_FORMAT_SECONDS}"` + ).addText( + (text2) => text2.setPlaceholder(plugin.settings.commitDateFormat).setValue(plugin.settings.commitDateFormat).onChange(async (value) => { + plugin.settings.commitDateFormat = value; + await plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("{{hostname}} placeholder replacement").setDesc("Specify custom hostname for every device.").addText( + (text2) => { + var _a2; + return text2.setValue((_a2 = plugin.localStorage.getHostname()) != null ? _a2 : "").onChange(async (value) => { + plugin.localStorage.setHostname(value); + }); + } + ); + new import_obsidian8.Setting(containerEl).setName("Preview commit message").addButton( + (button) => button.setButtonText("Preview").onClick(async () => { + const commitMessagePreview = await plugin.gitManager.formatCommitMessage( + plugin.settings.commitMessage + ); + new import_obsidian8.Notice(`${commitMessagePreview}`); + }) + ); + new import_obsidian8.Setting(containerEl).setName("List filenames affected by commit in the commit body").addToggle( + (toggle) => toggle.setValue(plugin.settings.listChangedFilesInMessageBody).onChange((value) => { + plugin.settings.listChangedFilesInMessageBody = value; + plugin.saveSettings(); + }) + ); + containerEl.createEl("br"); + containerEl.createEl("h3", { text: "Backup" }); + if (plugin.gitManager instanceof SimpleGit) + new import_obsidian8.Setting(containerEl).setName("Sync Method").setDesc( + "Selects the method used for handling new changes found in your remote git repository." + ).addDropdown((dropdown) => { + const options = { + merge: "Merge", + rebase: "Rebase", + reset: "Other sync service (Only updates the HEAD without touching the working directory)" + }; + dropdown.addOptions(options); + dropdown.setValue(plugin.settings.syncMethod); + dropdown.onChange(async (option) => { + plugin.settings.syncMethod = option; + plugin.saveSettings(); + }); + }); + new import_obsidian8.Setting(containerEl).setName("Pull updates on startup").setDesc("Automatically pull updates when Obsidian starts").addToggle( + (toggle) => toggle.setValue(plugin.settings.autoPullOnBoot).onChange((value) => { + plugin.settings.autoPullOnBoot = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Push on backup").setDesc("Disable to only commit changes").addToggle( + (toggle) => toggle.setValue(!plugin.settings.disablePush).onChange((value) => { + plugin.settings.disablePush = !value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Pull changes before push").setDesc("Commit -> pull -> push (Only if pushing is enabled)").addToggle( + (toggle) => toggle.setValue(plugin.settings.pullBeforePush).onChange((value) => { + plugin.settings.pullBeforePush = value; + plugin.saveSettings(); + }) + ); + if (plugin.gitManager instanceof SimpleGit) { + containerEl.createEl("br"); + containerEl.createEl("h3", { text: "Line author information" }); + this.addLineAuthorInfoSettings(); + } + } + containerEl.createEl("br"); + containerEl.createEl("h3", { text: "Miscellaneous" }); + new import_obsidian8.Setting(containerEl).setName( + "Automatically refresh Source Control View on file changes" + ).setDesc( + "On slower machines this may cause lags. If so, just disable this option" + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.refreshSourceControl).onChange((value) => { + plugin.settings.refreshSourceControl = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Source Control View refresh interval").setDesc( + "Milliseconds to wait after file change before refreshing the Source Control View" + ).addText( + (toggle) => toggle.setValue( + plugin.settings.refreshSourceControlTimer.toString() + ).setPlaceholder("7000").onChange((value) => { + plugin.settings.refreshSourceControlTimer = Math.max( + parseInt(value), + 500 + ); + plugin.saveSettings(); + plugin.setRefreshDebouncer(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Disable notifications").setDesc( + "Disable notifications for git operations to minimize distraction (refer to status bar for updates). Errors are still shown as notifications even if you enable this setting" + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.disablePopups).onChange((value) => { + plugin.settings.disablePopups = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Show status bar").setDesc( + "Obsidian must be restarted for the changes to take affect" + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.showStatusBar).onChange((value) => { + plugin.settings.showStatusBar = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Show stage/unstage button in file menu").addToggle( + (toggle) => toggle.setValue(plugin.settings.showFileMenu).onChange((value) => { + plugin.settings.showFileMenu = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Show branch status bar").setDesc( + "Obsidian must be restarted for the changes to take affect" + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.showBranchStatusBar).onChange((value) => { + plugin.settings.showBranchStatusBar = value; + plugin.saveSettings(); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Show changes files count in status bar").addToggle( + (toggle) => toggle.setValue(plugin.settings.changedFilesInStatusBar).onChange((value) => { + plugin.settings.changedFilesInStatusBar = value; + plugin.saveSettings(); + }) + ); + containerEl.createEl("br"); + if (plugin.gitManager instanceof IsomorphicGit) { + containerEl.createEl("h3", { + text: "Authentication/Commit Author" + }); + } else { + containerEl.createEl("h3", { text: "Commit Author" }); + } + if (plugin.gitManager instanceof IsomorphicGit) + new import_obsidian8.Setting(containerEl).setName( + "Username on your git server. E.g. your username on GitHub" + ).addText((cb) => { + var _a2; + cb.setValue((_a2 = plugin.localStorage.getUsername()) != null ? _a2 : ""); + cb.onChange((value) => { + plugin.localStorage.setUsername(value); + }); + }); + if (plugin.gitManager instanceof IsomorphicGit) + new import_obsidian8.Setting(containerEl).setName("Password/Personal access token").setDesc( + "Type in your password. You won't be able to see it again." + ).addText((cb) => { + cb.inputEl.autocapitalize = "off"; + cb.inputEl.autocomplete = "off"; + cb.inputEl.spellcheck = false; + cb.onChange((value) => { + plugin.localStorage.setPassword(value); + }); + }); + if (plugin.gitReady) + new import_obsidian8.Setting(containerEl).setName("Author name for commit").addText(async (cb) => { + cb.setValue(await plugin.gitManager.getConfig("user.name")); + cb.onChange((value) => { + plugin.gitManager.setConfig( + "user.name", + value == "" ? void 0 : value + ); + }); + }); + if (plugin.gitReady) + new import_obsidian8.Setting(containerEl).setName("Author email for commit").addText(async (cb) => { + cb.setValue( + await plugin.gitManager.getConfig("user.email") + ); + cb.onChange((value) => { + plugin.gitManager.setConfig( + "user.email", + value == "" ? void 0 : value + ); + }); + }); + containerEl.createEl("br"); + containerEl.createEl("h3", { text: "Advanced" }); + if (plugin.gitManager instanceof SimpleGit) { + new import_obsidian8.Setting(containerEl).setName("Update submodules").setDesc( + '"Create backup" and "pull" takes care of submodules. Missing features: Conflicted files, count of pulled/pushed/committed files. Tracking branch needs to be set for each submodule' + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.updateSubmodules).onChange((value) => { + plugin.settings.updateSubmodules = value; + plugin.saveSettings(); + }) + ); + if (plugin.settings.updateSubmodules) { + new import_obsidian8.Setting(containerEl).setName("Submodule recurse checkout/switch").setDesc( + "Whenever a checkout happens on the root repository, recurse the checkout on the submodules (if the branches exist)." + ).addToggle( + (toggle) => toggle.setValue(plugin.settings.submoduleRecurseCheckout).onChange((value) => { + plugin.settings.submoduleRecurseCheckout = value; + plugin.saveSettings(); + }) + ); + } + } + if (plugin.gitManager instanceof SimpleGit) + new import_obsidian8.Setting(containerEl).setName("Custom Git binary path").addText((cb) => { + var _a2; + cb.setValue((_a2 = plugin.localStorage.getGitPath()) != null ? _a2 : ""); + cb.setPlaceholder("git"); + cb.onChange((value) => { + plugin.localStorage.setGitPath(value); + plugin.gitManager.updateGitPath(value || "git"); + }); + }); + if (plugin.gitManager instanceof SimpleGit) + new import_obsidian8.Setting(containerEl).setName("Additional environment variables").setDesc( + "Use each line for a new environment variable in the format KEY=VALUE" + ).addTextArea((cb) => { + cb.setPlaceholder("GIT_DIR=/path/to/git/dir"); + cb.setValue(plugin.localStorage.getEnvVars().join("\n")); + cb.onChange((value) => { + plugin.localStorage.setEnvVars(value.split("\n")); + }); + }); + if (plugin.gitManager instanceof SimpleGit) + new import_obsidian8.Setting(containerEl).setName("Additional PATH environment variable paths").setDesc("Use each line for one path").addTextArea((cb) => { + cb.setValue(plugin.localStorage.getPATHPaths().join("\n")); + cb.onChange((value) => { + plugin.localStorage.setPATHPaths(value.split("\n")); + }); + }); + if (plugin.gitManager instanceof SimpleGit) + new import_obsidian8.Setting(containerEl).setName("Reload with new environment variables").setDesc( + "Removing previously added environment variables will not take effect until Obsidian is restarted." + ).addButton((cb) => { + cb.setButtonText("Reload"); + cb.setCta(); + cb.onClick(() => { + plugin.gitManager.setGitInstance(); + }); + }); + new import_obsidian8.Setting(containerEl).setName("Custom base path (Git repository path)").setDesc( + ` + Sets the relative path to the vault from which the Git binary should be executed. + Mostly used to set the path to the Git repository, which is only required if the Git repository is below the vault root directory. Use "\\" instead of "/" on Windows. + ` + ).addText((cb) => { + cb.setValue(plugin.settings.basePath); + cb.setPlaceholder("directory/directory-with-git-repo"); + cb.onChange((value) => { + plugin.settings.basePath = value; + plugin.saveSettings(); + plugin.gitManager.updateBasePath(value || ""); + }); + }); + new import_obsidian8.Setting(containerEl).setName("Custom Git directory path (Instead of '.git')").setDesc( + `Requires restart of Obsidian to take effect. Use "\\" instead of "/" on Windows.` + ).addText((cb) => { + cb.setValue(plugin.settings.gitDir); + cb.setPlaceholder(".git"); + cb.onChange((value) => { + plugin.settings.gitDir = value; + plugin.saveSettings(); + }); + }); + new import_obsidian8.Setting(containerEl).setName("Disable on this device").addToggle( + (toggle) => toggle.setValue(plugin.localStorage.getPluginDisabled()).onChange((value) => { + plugin.localStorage.setPluginDisabled(value); + if (value) { + plugin.unloadPlugin(); + } else { + plugin.loadPlugin(); + } + new import_obsidian8.Notice( + "Obsidian must be restarted for the changes to take affect" + ); + }) + ); + new import_obsidian8.Setting(containerEl).setName("Donate").setDesc( + "If you like this Plugin, consider donating to support continued development." + ).addButton((bt) => { + bt.buttonEl.outerHTML = "Buy Me a Coffee at ko-fi.com"; + }); + const info = containerEl.createDiv(); + info.setAttr("align", "center"); + info.setText( + "Debugging and logging:\nYou can always see the logs of this and every other plugin by opening the console with" + ); + const keys = containerEl.createDiv(); + keys.setAttr("align", "center"); + keys.addClass("obsidian-git-shortcuts"); + if (import_obsidian8.Platform.isMacOS === true) { + keys.createEl("kbd", { text: "CMD (\u2318) + OPTION (\u2325) + I" }); + } else { + keys.createEl("kbd", { text: "CTRL + SHIFT + I" }); + } + } + configureLineAuthorShowStatus(show) { + this.settings.lineAuthor.show = show; + this.plugin.saveSettings(); + if (show) + this.plugin.lineAuthoringFeature.activateFeature(); + else + this.plugin.lineAuthoringFeature.deactivateFeature(); + } + /** + * Persists the setting {@link key} with value {@link value} and + * refreshes the line author info views. + */ + lineAuthorSettingHandler(key2, value) { + this.settings.lineAuthor[key2] = value; + this.plugin.saveSettings(); + this.plugin.lineAuthoringFeature.refreshLineAuthorViews(); + } + /** + * Ensure, that certain last shown values are persisten in the settings. + * + * Necessary for the line author info gutter context menus. + */ + beforeSaveSettings() { + const laSettings = this.settings.lineAuthor; + if (laSettings.authorDisplay !== "hide") { + laSettings.lastShownAuthorDisplay = laSettings.authorDisplay; + } + if (laSettings.dateTimeFormatOptions !== "hide") { + laSettings.lastShownDateTimeFormatOptions = laSettings.dateTimeFormatOptions; + } + } + addLineAuthorInfoSettings() { + const baseLineAuthorInfoSetting = new import_obsidian8.Setting(this.containerEl).setName( + "Show commit authoring information next to each line" + ); + if (!this.plugin.lineAuthoringFeature.isAvailableOnCurrentPlatform()) { + baseLineAuthorInfoSetting.setDesc("Only available on desktop currently.").setDisabled(true); + } + baseLineAuthorInfoSetting.descEl.innerHTML = ` + Feature guide and quick examples
+ The commit hash, author name and authoring date can all be individually toggled.
Hide everything, to only show the age-colored sidebar.`; + baseLineAuthorInfoSetting.addToggle( + (toggle) => toggle.setValue(this.settings.lineAuthor.show).onChange((value) => { + this.configureLineAuthorShowStatus(value); + this.display(); + }) + ); + if (this.settings.lineAuthor.show) { + const trackMovement = new import_obsidian8.Setting(this.containerEl).setName("Follow movement and copies across files and commits").setDesc("").addDropdown((dropdown) => { + dropdown.addOptions({ + inactive: "Do not follow (default)", + "same-commit": "Follow within same commit", + "all-commits": "Follow within all commits (maybe slow)" + }); + dropdown.setValue(this.settings.lineAuthor.followMovement); + dropdown.onChange( + (value) => this.lineAuthorSettingHandler("followMovement", value) + ); + }); + trackMovement.descEl.innerHTML = ` + By default (deactivated), each line only shows the newest commit where it was changed. +
+ With same commit, cut-copy-paste-ing of text is followed within the same commit and the original commit of authoring will be shown. +
+ With all commits, cut-copy-paste-ing text inbetween multiple commits will be detected. +
+ It uses git-blame and + for matches (at least ${GIT_LINE_AUTHORING_MOVEMENT_DETECTION_MINIMAL_LENGTH} characters) within the same (or all) commit(s), the originating commit's information is shown.`; + new import_obsidian8.Setting(this.containerEl).setName("Show commit hash").addToggle((tgl) => { + tgl.setValue(this.settings.lineAuthor.showCommitHash); + tgl.onChange( + async (value) => this.lineAuthorSettingHandler("showCommitHash", value) + ); + }); + new import_obsidian8.Setting(this.containerEl).setName("Author name display").setDesc("If and how the author is displayed").addDropdown((dropdown) => { + const options = { + hide: "Hide", + initials: "Initials (default)", + "first name": "First name", + "last name": "Last name", + full: "Full name" + }; + dropdown.addOptions(options); + dropdown.setValue(this.settings.lineAuthor.authorDisplay); + dropdown.onChange( + async (value) => this.lineAuthorSettingHandler("authorDisplay", value) + ); + }); + new import_obsidian8.Setting(this.containerEl).setName("Authoring date display").setDesc( + "If and how the date and time of authoring the line is displayed" + ).addDropdown((dropdown) => { + const options = { + hide: "Hide", + date: "Date (default)", + datetime: "Date and time", + "natural language": "Natural language", + custom: "Custom" + }; + dropdown.addOptions(options); + dropdown.setValue( + this.settings.lineAuthor.dateTimeFormatOptions + ); + dropdown.onChange( + async (value) => { + this.lineAuthorSettingHandler( + "dateTimeFormatOptions", + value + ); + this.display(); + } + ); + }); + if (this.settings.lineAuthor.dateTimeFormatOptions === "custom") { + const dateTimeFormatCustomStringSetting = new import_obsidian8.Setting( + this.containerEl + ); + dateTimeFormatCustomStringSetting.setName("Custom authoring date format").addText((cb) => { + cb.setValue( + this.settings.lineAuthor.dateTimeFormatCustomString + ); + cb.setPlaceholder("YYYY-MM-DD HH:mm"); + cb.onChange((value) => { + this.lineAuthorSettingHandler( + "dateTimeFormatCustomString", + value + ); + dateTimeFormatCustomStringSetting.descEl.innerHTML = this.previewCustomDateTimeDescriptionHtml( + value + ); + }); + }); + dateTimeFormatCustomStringSetting.descEl.innerHTML = this.previewCustomDateTimeDescriptionHtml( + this.settings.lineAuthor.dateTimeFormatCustomString + ); + } + new import_obsidian8.Setting(this.containerEl).setName("Authoring date display timezone").addDropdown((dropdown) => { + const options = { + "viewer-local": "My local (default)", + "author-local": "Author's local", + utc0000: "UTC+0000/Z" + }; + dropdown.addOptions(options); + dropdown.setValue( + this.settings.lineAuthor.dateTimeTimezone + ); + dropdown.onChange( + async (value) => this.lineAuthorSettingHandler("dateTimeTimezone", value) + ); + }).descEl.innerHTML = ` + The time-zone in which the authoring date should be shown. + Either your local time-zone (default), + the author's time-zone during commit creation or + UTC\xB100:00. + `; + const oldestAgeSetting = new import_obsidian8.Setting(this.containerEl).setName( + "Oldest age in coloring" + ); + oldestAgeSetting.descEl.innerHTML = this.previewOldestAgeDescriptionHtml( + this.settings.lineAuthor.coloringMaxAge + )[0]; + oldestAgeSetting.addText((text2) => { + text2.setPlaceholder("1y"); + text2.setValue(this.settings.lineAuthor.coloringMaxAge); + text2.onChange((value) => { + const [preview, valid] = this.previewOldestAgeDescriptionHtml(value); + oldestAgeSetting.descEl.innerHTML = preview; + if (valid) { + this.lineAuthorSettingHandler("coloringMaxAge", value); + this.refreshColorSettingsName("oldest"); + } + }); + }); + this.createColorSetting("newest"); + this.createColorSetting("oldest"); + new import_obsidian8.Setting(this.containerEl).setName("Text color").addText((field) => { + field.setValue(this.settings.lineAuthor.textColorCss); + field.onChange((value) => { + this.lineAuthorSettingHandler("textColorCss", value); + }); + }).descEl.innerHTML = ` + The CSS color of the gutter text.
+ + It is higly recommended to use + + CSS variables + defined by themes + (e.g.
var(--text-muted)
or +
var(--text-on-accent)
, + because they automatically adapt to theme changes.
+ + See: + List of available CSS variables in Obsidian + + `; + new import_obsidian8.Setting(this.containerEl).setName("Ignore whitespace and newlines in changes").addToggle((tgl) => { + tgl.setValue(this.settings.lineAuthor.ignoreWhitespace); + tgl.onChange( + (value) => this.lineAuthorSettingHandler("ignoreWhitespace", value) + ); + }).descEl.innerHTML = ` + Whitespace and newlines are interpreted as + part of the document and in changes + by default (hence not ignored). + This makes the last line being shown as 'changed' + when a new subsequent line is added, + even if the previously last line's text is the same. +
+ If you don't care about purely-whitespace changes + (e.g. list nesting / quote indentation changes), + then activating this will provide more meaningful change detection. + `; + } + } + createColorSetting(which) { + const setting = new import_obsidian8.Setting(this.containerEl).setName("").addText((text2) => { + const color = pickColor(which, this.settings.lineAuthor); + const defaultColor = pickColor( + which, + DEFAULT_SETTINGS.lineAuthor + ); + text2.setPlaceholder(rgbToString(defaultColor)); + text2.setValue(rgbToString(color)); + text2.onChange((colorNew) => { + const rgb = convertToRgb(colorNew); + if (rgb !== void 0) { + const key2 = which === "newest" ? "colorNew" : "colorOld"; + this.lineAuthorSettingHandler(key2, rgb); + } + this.refreshColorSettingsDesc(which, rgb); + }); + }); + this.lineAuthorColorSettings.set(which, setting); + this.refreshColorSettingsName(which); + this.refreshColorSettingsDesc( + which, + pickColor(which, this.settings.lineAuthor) + ); + } + refreshColorSettingsName(which) { + const settingsDom = this.lineAuthorColorSettings.get(which); + if (settingsDom) { + const whichDescriber = which === "oldest" ? `oldest (${this.settings.lineAuthor.coloringMaxAge} or older)` : "newest"; + settingsDom.nameEl.innerText = `Color for ${whichDescriber} commits`; + } + } + refreshColorSettingsDesc(which, rgb) { + const settingsDom = this.lineAuthorColorSettings.get(which); + if (settingsDom) { + settingsDom.descEl.innerHTML = this.colorSettingPreviewDescHtml( + which, + this.settings.lineAuthor, + rgb !== void 0 + ); + } + } + colorSettingPreviewDescHtml(which, laSettings, colorIsValid) { + const rgbStr = colorIsValid ? previewColor(which, laSettings) : `rgba(127,127,127,0.3)`; + const today = import_obsidian8.moment.unix(import_obsidian8.moment.now() / 1e3).format("YYYY-MM-DD"); + const text2 = colorIsValid ? `abcdef Author Name ${today}` : "invalid color"; + const preview = `
${text2}
`; + return `Supports 'rgb(r,g,b)', 'hsl(h,s,l)', hex (#) and + named colors (e.g. 'black', 'purple'). Color preview: ${preview}`; + } + previewCustomDateTimeDescriptionHtml(dateTimeFormatCustomString) { + const formattedDateTime = (0, import_obsidian8.moment)().format(dateTimeFormatCustomString); + return `
Format string to display the authoring date.
Currently: ${formattedDateTime}`; + } + previewOldestAgeDescriptionHtml(coloringMaxAge) { + const duration = parseColoringMaxAgeDuration(coloringMaxAge); + const durationString = duration !== void 0 ? `${duration.asDays()} days` : "invalid!"; + return [ + `The oldest age in the line author coloring. Everything older will have the same color. +
Smallest valid age is "1d". Currently: ${durationString}`, + duration + ]; + } +}; +function pickColor(which, las) { + return which === "oldest" ? las.colorOld : las.colorNew; +} +function parseColoringMaxAgeDuration(durationString) { + const duration = import_obsidian8.moment.duration("P" + durationString.toUpperCase()); + return duration.isValid() && duration.asDays() && duration.asDays() >= 1 ? duration : void 0; +} + +// src/lineAuthor/model.ts +function lineAuthoringId(head, objHash, path2) { + if (head === void 0 || objHash === void 0 || path2 === void 0) { + return void 0; + } + return `head${head}-obj${objHash}-path${path2}`; +} +var LineAuthoringContainerType = import_state.Annotation.define(); +function newComputationResultAsTransaction(key2, la, state) { + return state.update({ + annotations: LineAuthoringContainerType.of({ + key: key2, + la, + lineOffsetsFromUnsavedChanges: /* @__PURE__ */ new Map() + }) + }); +} +function getLineAuthorAnnotation(tr) { + return tr.annotation(LineAuthoringContainerType); +} +var lineAuthorState = import_state.StateField.define({ + create: (_state) => void 0, + /** + * The state can be updated from either an annotated transaction containing + * the newest line authoring (for the saved document) - or from + * unsaved changes of the document as the user is actively typing in the editor. + * + * In the first case, we take the new line authoring and discard anything we had remembered + * from unsaved changes. In the second case, we use the unsaved changes in {@link enrichUnsavedChanges} to pre-compute information to immediately update the + * line author gutter without needing to wait until the document is saved and the + * line authoring is properly computed. + */ + update: (previous, transaction) => { + var _a2; + return (_a2 = getLineAuthorAnnotation(transaction)) != null ? _a2 : enrichUnsavedChanges(transaction, previous); + }, + // compare cache keys. + // equality rate is >= 95% :) + // hence avoids recomputation of views + compare: (l, r) => (l == null ? void 0 : l.key) === (r == null ? void 0 : r.key) +}); +function laStateDigest(laState) { + var _a2; + const digest = import_js_sha256.sha256.create(); + if (!laState) + return digest; + const { la, key: key2, lineOffsetsFromUnsavedChanges } = laState; + digest.update(la === "untracked" ? "t" : "f"); + digest.update(key2); + for (const [k, v] of (_a2 = lineOffsetsFromUnsavedChanges.entries()) != null ? _a2 : []) + digest.update([k, v]); + return digest; +} +var latestSettings = { + get: void 0, + save: void 0 +}; +function provideSettingsAccess(settingsGetter, settingsSetter) { + latestSettings.get = settingsGetter; + latestSettings.save = settingsSetter; +} +function maxAgeInDaysFromSettings(settings) { + var _a2, _b; + return (_b = (_a2 = parseColoringMaxAgeDuration(settings.coloringMaxAge)) == null ? void 0 : _a2.asDays()) != null ? _b : parseColoringMaxAgeDuration( + DEFAULT_SETTINGS.lineAuthor.coloringMaxAge + ).asDays(); +} +function enrichUnsavedChanges(tr, prev) { + if (!prev) + return void 0; + if (!tr.changes.empty) { + tr.changes.iterChanges((fromA, toA, fromB, toB) => { + var _a2; + const oldDoc = tr.startState.doc; + const { newDoc } = tr; + const beforeFrom = oldDoc.lineAt(fromA).number; + const beforeTo = oldDoc.lineAt(toA).number; + const afterFrom = newDoc.lineAt(fromB).number; + const afterTo = newDoc.lineAt(toB).number; + const beforeLen = beforeTo - beforeFrom + 1; + const afterLen = afterTo - afterFrom + 1; + for (let afterI = afterFrom; afterI <= afterTo; afterI++) { + let offset = (_a2 = prev.lineOffsetsFromUnsavedChanges.get(afterI)) != null ? _a2 : 0; + const isLastLine = afterTo === afterI; + const changeInNumberOfLines = afterLen - beforeLen; + if (isLastLine) + offset += changeInNumberOfLines; + prev.lineOffsetsFromUnsavedChanges.set(afterI, offset); + } + }); + } + return prev; +} + +// src/lineAuthor/control.ts +var LineAuthoringSubscriber = class { + // remember path to detect and adapt to renames + constructor(state) { + this.state = state; + this.subscribeMe(); + } + async notifyLineAuthoring(id, la) { + if (this.view === void 0) { + console.warn( + `Obsidian Git: View is not defined for editor cache key. Unforeseen situation. id: ${id}` + ); + return; + } + const state = this.view.state; + const transaction = newComputationResultAsTransaction(id, la, state); + this.view.dispatch(transaction); + } + updateToNewState(state) { + const filepathChanged = this.lastSeenPath && this.filepath != this.lastSeenPath; + this.state = state; + if (filepathChanged) { + this.unsubscribeMe(this.lastSeenPath); + this.subscribeMe(); + } + return this; + } + removeIfStale() { + if (this.view.destroyed) { + this.unsubscribeMe(this.lastSeenPath); + } + } + subscribeMe() { + if (this.filepath === void 0) + return; + eventsPerFilePathSingleton.ifFilepathDefinedTransformSubscribers( + this.filepath, + (subs) => subs.add(this) + ); + this.lastSeenPath = this.filepath; + } + unsubscribeMe(oldFilepath) { + eventsPerFilePathSingleton.ifFilepathDefinedTransformSubscribers( + oldFilepath, + (subs) => subs.delete(this) + ); + } + get filepath() { + var _a2, _b; + return (_b = (_a2 = this.state.field(import_obsidian9.editorViewField)) == null ? void 0 : _a2.file) == null ? void 0 : _b.path; + } + get view() { + return this.state.field(import_obsidian9.editorEditorField); + } +}; +var subscribeNewEditor = import_state2.StateField.define({ + create: (state) => new LineAuthoringSubscriber(state), + update: (v, transaction) => v.updateToNewState(transaction.state), + compare: (a, b) => a === b +}); + +// src/lineAuthor/view/cache.ts +init_polyfill_buffer(); +function clearViewCache() { + longestRenderedGutter = void 0; + renderedAgeInDaysForAdaptiveInitialColoring = []; + ageIdx = 0; + gutterInstances.clear(); + gutterMarkersRangeSet.clear(); + attachedGutterElements.clear(); +} +var longestRenderedGutter = void 0; +var getLongestRenderedGutter = () => longestRenderedGutter; +function conditionallyUpdateLongestRenderedGutter(gutter2, text2) { + var _a2; + const length = text2.length; + if (length < ((_a2 = longestRenderedGutter == null ? void 0 : longestRenderedGutter.length) != null ? _a2 : 0)) + return; + longestRenderedGutter = { gutter: gutter2, length, text: text2 }; + const settings = latestSettings.get(); + if (length !== settings.gutterSpacingFallbackLength) { + settings.gutterSpacingFallbackLength = length; + latestSettings.save(settings); + } +} +var renderedAgeInDaysForAdaptiveInitialColoring = []; +var ADAPTIVE_INITIAL_COLORING_AGE_CACHE_SIZE = 15; +var ageIdx = 0; +function recordRenderedAgeInDays(age) { + renderedAgeInDaysForAdaptiveInitialColoring[ageIdx] = age; + ageIdx = (ageIdx + 1) % ADAPTIVE_INITIAL_COLORING_AGE_CACHE_SIZE; +} +function computeAdaptiveInitialColoringAgeInDays() { + return median(renderedAgeInDaysForAdaptiveInitialColoring); +} +var gutterInstances = /* @__PURE__ */ new Map(); +var gutterMarkersRangeSet = /* @__PURE__ */ new Map(); +var attachedGutterElements = /* @__PURE__ */ new Set(); + +// src/lineAuthor/view/view.ts +init_polyfill_buffer(); +var import_state3 = require("@codemirror/state"); +var import_view2 = require("@codemirror/view"); + +// src/lineAuthor/view/gutter/gutter.ts +init_polyfill_buffer(); +var import_view = require("@codemirror/view"); +var import_js_sha2562 = __toESM(require_sha256()); +var import_obsidian10 = require("obsidian"); + +// src/lineAuthor/view/contextMenu.ts +init_polyfill_buffer(); + +// src/lineAuthor/view/gutter/gutterElementSearch.ts +init_polyfill_buffer(); +var mouseXY = { x: -10, y: -10 }; +function prepareGutterSearchForContextMenuHandling() { + if (mouseXY.x === -10) { + window.addEventListener("mousedown", (e) => { + mouseXY.x = e.clientX; + mouseXY.y = e.clientY; + }); + } +} +function findGutterElementUnderMouse() { + for (const elt of attachedGutterElements) { + if (contains(elt, mouseXY)) + return elt; + } +} +function contains(elt, pt) { + const { x, y, width, height } = elt.getBoundingClientRect(); + return x <= pt.x && pt.x <= x + width && y <= pt.y && pt.y <= y + height; +} + +// src/pluginGlobalRef.ts +init_polyfill_buffer(); +var pluginRef = {}; + +// src/lineAuthor/view/contextMenu.ts +var COMMIT_ATTR = "data-commit"; +function handleContextMenu(menu, editor, _mdv) { + if (editor.hasFocus()) + return; + const gutterElement = findGutterElementUnderMouse(); + if (!gutterElement) + return; + const info = getCommitInfo(gutterElement); + if (!info) + return; + if (!info.isZeroCommit && !info.isWaitingGutter) { + addCopyHashMenuItem(info, menu); + } + addConfigurableLineAuthorSettings("showCommitHash", menu); + addConfigurableLineAuthorSettings("authorDisplay", menu); + addConfigurableLineAuthorSettings("dateTimeFormatOptions", menu); +} +function addCopyHashMenuItem(commit2, menu) { + menu.addItem( + (item) => item.setTitle("Copy commit hash").setIcon("copy").setSection("obs-git-line-author-copy").onClick((_e) => navigator.clipboard.writeText(commit2.hash)) + ); +} +function addConfigurableLineAuthorSettings(key2, menu) { + var _a2, _b; + let title; + let actionNewValue; + const settings = pluginRef.plugin.settings.lineAuthor; + const currentValue = settings[key2]; + const currentlyShown = typeof currentValue === "boolean" ? currentValue : currentValue !== "hide"; + const defaultValue = DEFAULT_SETTINGS.lineAuthor[key2]; + if (key2 === "showCommitHash") { + title = "Show commit hash"; + actionNewValue = !currentValue; + } else if (key2 === "authorDisplay") { + const showOption = (_a2 = settings.lastShownAuthorDisplay) != null ? _a2 : defaultValue; + title = "Show author " + (currentlyShown ? currentValue : showOption); + actionNewValue = currentlyShown ? "hide" : showOption; + } else if (key2 === "dateTimeFormatOptions") { + const showOption = (_b = settings.lastShownDateTimeFormatOptions) != null ? _b : defaultValue; + title = "Show " + (currentlyShown ? currentValue : showOption); + title += !title.contains("date") ? " date" : ""; + actionNewValue = currentlyShown ? "hide" : showOption; + } else { + impossibleBranch(key2); + } + menu.addItem( + (item) => item.setTitle(title).setSection("obs-git-line-author-configure").setChecked(currentlyShown).onClick( + (_e) => { + var _a3, _b2; + return (_b2 = (_a3 = pluginRef.plugin) == null ? void 0 : _a3.settingsTab) == null ? void 0 : _b2.lineAuthorSettingHandler( + key2, + actionNewValue + ); + } + ) + ); +} +function enrichCommitInfoForContextMenu(commit2, isWaitingGutter, elt) { + elt.setAttr( + COMMIT_ATTR, + JSON.stringify({ + hash: commit2.hash, + isZeroCommit: commit2.isZeroCommit, + isWaitingGutter + }) + ); +} +function getCommitInfo(elt) { + const commitInfoStr = elt.getAttr(COMMIT_ATTR); + return commitInfoStr ? JSON.parse(commitInfoStr) : void 0; +} + +// src/lineAuthor/view/gutter/coloring.ts +init_polyfill_buffer(); +function previewColor(which, settings) { + return which === "oldest" ? coloringBasedOnCommitAge(0, false, settings).color : coloringBasedOnCommitAge(void 0, true, settings).color; +} +function coloringBasedOnCommitAge(commitAuthorEpochSeonds, isZeroCommit, settings) { + const maxAgeInDays = maxAgeInDaysFromSettings(settings); + const epochSecondsNow = Date.now() / 1e3; + const authoringEpochSeconds = commitAuthorEpochSeonds != null ? commitAuthorEpochSeonds : 0; + const secondsSinceCommit = isZeroCommit ? 0 : epochSecondsNow - authoringEpochSeconds; + const daysSinceCommit = secondsSinceCommit / 60 / 60 / 24; + const x = Math.pow( + Math.clamp(daysSinceCommit / maxAgeInDays, 0, 1), + 1 / 2.3 + ); + const dark = isDarkMode(); + const color0 = settings.colorNew; + const color1 = settings.colorOld; + const scaling = dark ? 0.4 : 1; + const r = lin(color0.r, color1.r, x) * scaling; + const g = lin(color0.g, color1.g, x) * scaling; + const b = lin(color0.b, color1.b, x) * scaling; + const a = dark ? 0.75 : 0.25; + return { color: `rgba(${r},${g},${b},${a})`, daysSinceCommit }; +} +function lin(z0, z1, x) { + return z0 + (z1 - z0) * x; +} +function isDarkMode() { + const obsidian = window == null ? void 0 : window.app; + return (obsidian == null ? void 0 : obsidian.getTheme()) === "obsidian"; +} +function setTextColorCssBasedOnSetting(settings) { + document.body.style.setProperty( + "--obs-git-gutter-text", + settings.textColorCss + ); +} + +// src/lineAuthor/view/gutter/commitChoice.ts +init_polyfill_buffer(); +function chooseNewestCommit(lineAuthoring, startLine, endLine) { + let newest = void 0; + for (let line = startLine; line <= endLine; line++) { + const currentHash = lineAuthoring.hashPerLine[line]; + const currentCommit = lineAuthoring.commits.get(currentHash); + if (!newest || currentCommit.isZeroCommit || isNewerThan(currentCommit, newest)) { + newest = currentCommit; + } + } + return newest; +} +function isNewerThan(left, right) { + var _a2, _b, _c, _d; + const l = (_b = (_a2 = left.author) == null ? void 0 : _a2.epochSeconds) != null ? _b : 0; + const r = (_d = (_c = right.author) == null ? void 0 : _c.epochSeconds) != null ? _d : 0; + return l > r; +} + +// src/lineAuthor/view/gutter/gutter.ts +var VALUE_NOT_FOUND_FALLBACK = "-"; +var NEW_CHANGE_CHARACTER = "+"; +var NEW_CHANGE_NUMBER_OF_CHARACTERS = 3; +var DIFFERING_AUTHOR_COMMITTER_MARKER = "*"; +var NON_WHITESPACE_REGEXP = /\S/g; +var UNINTRUSIVE_CHARACTER_FOR_WAITING_RENDERING = "%"; +var TextGutter = class extends import_view.GutterMarker { + constructor(text2) { + super(); + this.text = text2; + } + eq(other) { + return this.text === (other == null ? void 0 : other.text); + } + toDOM() { + return document.createTextNode(this.text); + } + destroy(dom) { + if (!document.body.contains(dom)) + dom.remove(); + } +}; +var LineAuthoringGutter = class extends import_view.GutterMarker { + /** + * **This should only be called {@link lineAuthoringGutterMarker}!** + * + * We want to avoid creating the same instance multiple times for improved performance. + */ + constructor(lineAuthoring, startLine, endLine, key2, settings, options) { + super(); + this.lineAuthoring = lineAuthoring; + this.startLine = startLine; + this.endLine = endLine; + this.key = key2; + this.settings = settings; + this.options = options; + this.point = false; + this.elementClass = "obs-git-blame-gutter"; + } + // Equality used by CodeMirror for optimisations + eq(other) { + return this.key === (other == null ? void 0 : other.key) && this.startLine === (other == null ? void 0 : other.startLine) && this.endLine === (other == null ? void 0 : other.endLine) && (this == null ? void 0 : this.options) === (other == null ? void 0 : other.options); + } + /** + * Renders to a Html node. + * + * It choses the newest commit within the line-range, + * renders it, makes adjustments for fake-commits and finally warps + * it into HTML. + * + * The DOM is actually precomputed with {@link computeDom}, + * which provides a finaliser to run before the DOM is handed over to CodeMirror. + * This is done, because this method is called frequently. It is called, + * whenever a gutter gets into the viewport and needs to be rendered. + * + * The age in days is recorded via {@link recordRenderedAgeInDays} to enable adaptive coloring. + */ + toDOM() { + var _a2; + this.precomputedDomProvider = (_a2 = this.precomputedDomProvider) != null ? _a2 : this.computeDom(); + return this.precomputedDomProvider(); + } + destroy(dom) { + if (!document.body.contains(dom)) { + dom.remove(); + attachedGutterElements.delete(dom); + } + } + /** + * Prepares the DOM for this gutter. + */ + computeDom() { + const commit2 = chooseNewestCommit( + this.lineAuthoring, + this.startLine, + this.endLine + ); + let toBeRenderedText = commit2.isZeroCommit ? "" : this.renderNonZeroCommit(commit2); + const isTrueCommit = !commit2.isZeroCommit && this.options !== "waiting-for-result"; + if (isTrueCommit) { + conditionallyUpdateLongestRenderedGutter(this, toBeRenderedText); + } else { + toBeRenderedText = this.adaptTextForFakeCommit( + commit2, + toBeRenderedText, + this.options + ); + } + const domProvider = this.createHtmlNode( + commit2, + toBeRenderedText, + this.options === "waiting-for-result" + ); + return domProvider; + } + createHtmlNode(commit2, text2, isWaitingGutter) { + var _a2; + const templateElt = window.createDiv(); + templateElt.innerText = text2; + const { color, daysSinceCommit } = coloringBasedOnCommitAge( + (_a2 = commit2 == null ? void 0 : commit2.author) == null ? void 0 : _a2.epochSeconds, + commit2 == null ? void 0 : commit2.isZeroCommit, + this.settings + ); + templateElt.style.backgroundColor = color; + enrichCommitInfoForContextMenu(commit2, isWaitingGutter, templateElt); + function prepareForDomAttachment() { + const elt = templateElt.cloneNode(true); + attachedGutterElements.add(elt); + if (!isWaitingGutter) + recordRenderedAgeInDays(daysSinceCommit); + return elt; + } + return prepareForDomAttachment; + } + renderNonZeroCommit(commit2) { + const optionalShortHash = this.settings.showCommitHash ? this.renderHash(commit2) : ""; + const optionalAuthorName = this.settings.authorDisplay === "hide" ? "" : `${this.renderAuthorName( + commit2, + this.settings.authorDisplay + )}`; + const optionalAuthoringDate = this.settings.dateTimeFormatOptions === "hide" ? "" : `${this.renderAuthoringDate( + commit2, + this.settings.dateTimeFormatOptions, + this.settings.dateTimeFormatCustomString, + this.settings.dateTimeTimezone + )}`; + const parts = [ + optionalShortHash, + optionalAuthorName, + optionalAuthoringDate + ]; + return parts.filter((x) => x.length >= 1).join(" "); + } + renderHash(nonZeroCommit) { + return nonZeroCommit.hash.substring(0, 6); + } + renderAuthorName(nonZeroCommit, authorDisplay) { + var _a2, _b, _c, _d; + const name = (_b = (_a2 = nonZeroCommit == null ? void 0 : nonZeroCommit.author) == null ? void 0 : _a2.name) != null ? _b : ""; + const words = name.split(" ").filter((word) => word.length >= 1); + let rendered; + switch (authorDisplay) { + case "initials": + rendered = words.map((word) => word[0].toUpperCase()).join(""); + break; + case "first name": + rendered = (_c = words.first()) != null ? _c : VALUE_NOT_FOUND_FALLBACK; + break; + case "last name": + rendered = (_d = words.last()) != null ? _d : VALUE_NOT_FOUND_FALLBACK; + break; + case "full": + rendered = name; + break; + default: + return impossibleBranch(authorDisplay); + } + if (!strictDeepEqual(nonZeroCommit == null ? void 0 : nonZeroCommit.author, nonZeroCommit == null ? void 0 : nonZeroCommit.committer)) { + rendered = rendered + DIFFERING_AUTHOR_COMMITTER_MARKER; + } + return rendered; + } + renderAuthoringDate(nonZeroCommit, dateTimeFormatOptions, dateTimeFormatCustomString, dateTimeTimezone) { + var _a2; + const FALLBACK_COMMIT_DATE = "?"; + if (((_a2 = nonZeroCommit == null ? void 0 : nonZeroCommit.author) == null ? void 0 : _a2.epochSeconds) === void 0) + return FALLBACK_COMMIT_DATE; + let dateTimeFormatting; + switch (dateTimeFormatOptions) { + case "date": + dateTimeFormatting = DATE_FORMAT; + break; + case "datetime": + dateTimeFormatting = DATE_TIME_FORMAT_MINUTES; + break; + case "custom": + dateTimeFormatting = dateTimeFormatCustomString; + break; + case "natural language": + dateTimeFormatting = (time) => { + const diff2 = time.diff((0, import_obsidian10.moment)()); + const addFluentSuffix = true; + return import_obsidian10.moment.duration(diff2).humanize(addFluentSuffix); + }; + break; + default: + return impossibleBranch(dateTimeFormatOptions); + } + let authoringDate = import_obsidian10.moment.unix( + nonZeroCommit.author.epochSeconds + ); + switch (dateTimeTimezone) { + case "viewer-local": + break; + case "author-local": + authoringDate = authoringDate.utcOffset( + nonZeroCommit.author.tz + ); + dateTimeFormatting += " Z"; + break; + case "utc0000": + authoringDate = authoringDate.utc(); + dateTimeFormatting += "[Z]"; + break; + default: + return impossibleBranch(dateTimeTimezone); + } + if (typeof dateTimeFormatting === "string") { + return authoringDate.format(dateTimeFormatting); + } else { + return dateTimeFormatting(authoringDate); + } + } + adaptTextForFakeCommit(commit2, toBeRenderedText, options) { + var _a2, _b, _c, _d; + const original = (_b = (_a2 = getLongestRenderedGutter()) == null ? void 0 : _a2.text) != null ? _b : toBeRenderedText; + const fillCharacter = options !== "waiting-for-result" && commit2.isZeroCommit ? NEW_CHANGE_CHARACTER : UNINTRUSIVE_CHARACTER_FOR_WAITING_RENDERING; + toBeRenderedText = original.replace( + NON_WHITESPACE_REGEXP, + fillCharacter + ); + const desiredTextLength = (_d = (_c = latestSettings.get()) == null ? void 0 : _c.gutterSpacingFallbackLength) != null ? _d : toBeRenderedText.length; + toBeRenderedText = resizeToLength( + toBeRenderedText, + desiredTextLength, + fillCharacter + ); + if (options !== "waiting-for-result" && commit2.isZeroCommit) { + const numberOfLastCharactersToKeep = Math.min( + desiredTextLength, + NEW_CHANGE_NUMBER_OF_CHARACTERS + ); + toBeRenderedText = prefixOfLengthAsWhitespace( + toBeRenderedText, + desiredTextLength - numberOfLastCharactersToKeep + ); + } + return toBeRenderedText; + } +}; +function lineAuthoringGutterMarker(la, startLine, endLine, key2, settings, options) { + const digest = import_js_sha2562.sha256.create(); + digest.update(Object.values(settings).join(",")); + digest.update(`s${startLine}-e${endLine}-k${key2}-o${options}`); + const cacheKey = digest.hex(); + const cached = gutterInstances.get(cacheKey); + if (cached) + return cached; + const result = new LineAuthoringGutter( + la, + startLine, + endLine, + key2, + settings, + options + ); + gutterInstances.set(cacheKey, result); + return result; +} + +// src/lineAuthor/view/gutter/initial.ts +init_polyfill_buffer(); +var import_obsidian11 = require("obsidian"); +function initialSpacingGutter() { + var _a2, _b; + const length = (_b = (_a2 = latestSettings.get()) == null ? void 0 : _a2.gutterSpacingFallbackLength) != null ? _b : DEFAULT_SETTINGS.lineAuthor.gutterSpacingFallbackLength; + return new TextGutter(Array(length).fill("-").join("")); +} +function initialLineAuthoringGutter(settings) { + const { lineAuthoring, ageForInitialRender } = adaptiveInitialColoredWaitingLineAuthoring(settings); + return lineAuthoringGutterMarker( + lineAuthoring, + 1, + 1, + "initialGutter" + ageForInitialRender, + // use a age coloring based cache key + settings, + "waiting-for-result" + ); +} +function adaptiveInitialColoredWaitingLineAuthoring(settings) { + var _a2; + const ageForInitialRender = (_a2 = computeAdaptiveInitialColoringAgeInDays()) != null ? _a2 : maxAgeInDaysFromSettings(settings) * 0.25; + const slightlyOlderAgeForInitialRender = (0, import_obsidian11.moment)().add( + -ageForInitialRender, + "days" + ); + const dummyAuthor = { + name: "", + epochSeconds: momentToEpochSeconds(slightlyOlderAgeForInitialRender), + tz: "+0000" + }; + const dummyCommit = { + hash: "waiting-for-result", + author: dummyAuthor, + committer: dummyAuthor, + isZeroCommit: false + }; + return { + lineAuthoring: { + hashPerLine: [void 0, "waiting-for-result"], + commits: /* @__PURE__ */ new Map([["waiting-for-result", dummyCommit]]) + }, + ageForInitialRender + }; +} + +// src/lineAuthor/view/gutter/untrackedFile.ts +init_polyfill_buffer(); +function newUntrackedFileGutter(key2, settings) { + const dummyLineAuthoring = { + hashPerLine: [void 0, "000000"], + commits: /* @__PURE__ */ new Map([["000000", zeroCommit]]) + }; + return lineAuthoringGutterMarker(dummyLineAuthoring, 1, 1, key2, settings); +} + +// src/lineAuthor/view/view.ts +var UNDISPLAYED = new TextGutter(""); +var lineAuthorGutter = (0, import_view2.gutter)({ + class: "line-author-gutter-container", + markers(view) { + const lineAuthoring = view.state.field(lineAuthorState, false); + return lineAuthoringGutterMarkersRangeSet(view, lineAuthoring); + }, + lineMarkerChange(update2) { + const newLineAuthoringId = laStateDigest( + update2.state.field(lineAuthorState) + ); + const oldLineAuthoringId = laStateDigest( + update2.startState.field(lineAuthorState) + ); + return oldLineAuthoringId !== newLineAuthoringId; + }, + renderEmptyElements: true, + initialSpacer: (view) => { + temporaryWorkaroundGutterSpacingForRenderedLineAuthoring(view); + return initialSpacingGutter(); + }, + updateSpacer: (_sp, update2) => { + var _a2, _b; + temporaryWorkaroundGutterSpacingForRenderedLineAuthoring(update2.view); + return (_b = (_a2 = getLongestRenderedGutter()) == null ? void 0 : _a2.gutter) != null ? _b : initialSpacingGutter(); + } +}); +function lineAuthoringGutterMarkersRangeSet(view, optLA) { + const digest = laStateDigest(optLA); + const doc = view.state.doc; + const lineBlockEndPos = /* @__PURE__ */ new Map(); + for (let line = 1; line <= doc.lines; line++) { + const from = doc.line(line).from; + const to = view.lineBlockAt(from).to; + lineBlockEndPos.set(line, [from, to]); + digest.update([from, to, 0]); + } + const laSettings = latestSettings.get(); + digest.update("s" + Object.values(latestSettings).join(",")); + const cacheKey = digest.hex(); + const cached = gutterMarkersRangeSet.get(cacheKey); + if (cached) + return cached; + const { result, allowCache } = computeLineAuthoringGutterMarkersRangeSet( + doc, + lineBlockEndPos, + laSettings, + optLA + ); + if (allowCache) + gutterMarkersRangeSet.set(cacheKey, result); + return result; +} +function computeLineAuthoringGutterMarkersRangeSet(doc, blocksPerLine, settings, optLA) { + let allowCache = true; + const docLastLine = doc.lines; + const ranges = []; + function add2(from, to, gutter2) { + return ranges.push(gutter2.range(from, to)); + } + const lineFrom = computeLineMappingForUnsavedChanges(docLastLine, optLA); + const emptyDoc = doc.length === 0; + const lastLineIsEmpty = doc.iterLines(docLastLine, docLastLine + 1).next().value === ""; + for (let startLine = 1; startLine <= docLastLine; startLine++) { + const [from, to] = blocksPerLine.get(startLine); + const endLine = doc.lineAt(to).number; + if (emptyDoc) { + add2(from, to, UNDISPLAYED); + continue; + } + if (startLine === docLastLine && lastLineIsEmpty) { + add2(from, to, UNDISPLAYED); + continue; + } + if (optLA === void 0) { + add2(from, to, initialLineAuthoringGutter(settings)); + allowCache = false; + continue; + } + const { key: key2, la } = optLA; + if (la === "untracked") { + add2(from, to, newUntrackedFileGutter(la, settings)); + continue; + } + const lastAuthorLine = la.hashPerLine.length - 1; + const laStartLine = lineFrom[startLine]; + const laEndLine = lineFrom[endLine]; + if (laEndLine && laEndLine > lastAuthorLine) { + add2(from, to, UNDISPLAYED); + } + if (laStartLine !== void 0 && between(1, laStartLine, lastAuthorLine) && laEndLine !== void 0 && between(1, laEndLine, lastAuthorLine)) { + add2( + from, + to, + lineAuthoringGutterMarker( + la, + laStartLine, + laEndLine, + key2, + settings + ) + ); + continue; + } + if (lastAuthorLine < 1) { + add2(from, to, initialLineAuthoringGutter(settings)); + allowCache = false; + continue; + } + const start = Math.clamp(laStartLine != null ? laStartLine : startLine, 1, lastAuthorLine); + const end = Math.clamp(laEndLine != null ? laEndLine : endLine, 1, lastAuthorLine); + add2( + from, + to, + lineAuthoringGutterMarker( + la, + start, + end, + key2 + "computing", + settings, + "waiting-for-result" + ) + ); + } + return { result: import_state3.RangeSet.of( + ranges, + /* sort = */ + true + ), allowCache }; +} +function computeLineMappingForUnsavedChanges(docLastLine, optLA) { + if (!(optLA == null ? void 0 : optLA.lineOffsetsFromUnsavedChanges)) { + return Array.from(new Array(docLastLine + 1), (ln) => ln); + } + const lineFrom = [void 0]; + let cumulativeLineOffset = 0; + for (let ln = 1; ln <= docLastLine; ln++) { + const unsavedChanges = optLA.lineOffsetsFromUnsavedChanges.get(ln); + cumulativeLineOffset += unsavedChanges != null ? unsavedChanges : 0; + lineFrom[ln] = unsavedChanges === void 0 ? ln - cumulativeLineOffset : void 0; + } + return lineFrom; +} +function temporaryWorkaroundGutterSpacingForRenderedLineAuthoring(view) { + const guttersContainers = view.dom.querySelectorAll( + ".cm-gutters" + ); + guttersContainers.forEach((cont) => { + if (!(cont == null ? void 0 : cont.style)) + return; + if (!cont.style.marginLeft) { + cont.style.marginLeft = "unset"; + } + }); +} + +// src/lineAuthor/lineAuthorProvider.ts +var LineAuthorProvider = class { + constructor(plugin) { + this.plugin = plugin; + /** + * Saves all computed line authoring results. + * + * See {@link LineAuthoringId} + */ + this.lineAuthorings = /* @__PURE__ */ new Map(); + } + async trackChanged(file) { + this.trackChangedHelper(file).catch((reason) => { + console.warn("Obsidian Git: Error in trackChanged." + reason); + return Promise.reject(reason); + }); + } + async trackChangedHelper(file) { + if (!file) + return; + if (file.path === void 0) { + console.warn( + "Obsidian Git: Attempted to track change of undefined filepath. Unforeseen situation." + ); + return; + } + this.computeLineAuthorInfo(file.path); + } + destroy() { + this.lineAuthorings.clear(); + eventsPerFilePathSingleton.clear(); + clearViewCache(); + } + async computeLineAuthorInfo(filepath) { + const gitManager = this.plugin.lineAuthoringFeature.isAvailableOnCurrentPlatform().gitManager; + const headRevision = await gitManager.submoduleAwareHeadRevisonInContainingDirectory( + filepath + ); + const fileHash = await gitManager.hashObject(filepath); + const key2 = lineAuthoringId(headRevision, fileHash, filepath); + if (key2 === void 0) { + return; + } + if (this.lineAuthorings.has(key2)) { + } else { + const gitAuthorResult = await gitManager.blame( + filepath, + this.plugin.settings.lineAuthor.followMovement, + this.plugin.settings.lineAuthor.ignoreWhitespace + ); + this.lineAuthorings.set(key2, gitAuthorResult); + } + this.notifyComputationResultToSubscribers(filepath, key2); + } + notifyComputationResultToSubscribers(filepath, key2) { + eventsPerFilePathSingleton.ifFilepathDefinedTransformSubscribers( + filepath, + async (subs) => subs.forEach( + (sub) => sub.notifyLineAuthoring(key2, this.lineAuthorings.get(key2)) + ) + ); + } +}; +var enabledLineAuthorInfoExtensions = import_state4.Prec.high([ + subscribeNewEditor, + lineAuthorState, + lineAuthorGutter +]); + +// src/lineAuthor/lineAuthorIntegration.ts +var LineAuthoringFeature = class { + constructor(plg) { + this.plg = plg; + this.codeMirrorExtensions = []; + this.handleWorkspaceLeaf = (leaf) => { + const obsView = leaf == null ? void 0 : leaf.view; + const file = obsView == null ? void 0 : obsView.file; + if (!this.lineAuthorInfoProvider) { + console.warn( + "Obsidian Git: undefined lineAuthorInfoProvider. Unexpected situation." + ); + return; + } + if (file === void 0 || (obsView == null ? void 0 : obsView.allowNoFile) === true) + return; + this.lineAuthorInfoProvider.trackChanged(file); + }; + } + // ========================= INIT and DE-INIT ========================== + onLoadPlugin() { + this.plg.registerEditorExtension(this.codeMirrorExtensions); + provideSettingsAccess( + () => this.plg.settings.lineAuthor, + (laSettings) => { + this.plg.settings.lineAuthor = laSettings; + this.plg.saveSettings(); + } + ); + } + conditionallyActivateBySettings() { + if (this.plg.settings.lineAuthor.show) { + this.activateFeature(); + } + } + activateFeature() { + try { + if (!this.isAvailableOnCurrentPlatform()) + return; + setTextColorCssBasedOnSetting(this.plg.settings.lineAuthor); + this.lineAuthorInfoProvider = new LineAuthorProvider(this.plg); + this.createEventHandlers(); + this.activateCodeMirrorExtensions(); + console.log(this.plg.manifest.name + ": Enabled line authoring."); + } catch (e) { + console.warn( + "Obsidian Git: Error while loading line authoring feature.", + e + ); + this.deactivateFeature(); + } + } + /** + * Deactivates the feature. This function is very defensive, as it is also + * called to cleanup, if a critical error in the line authoring has occurred. + */ + deactivateFeature() { + var _a2; + this.destroyEventHandlers(); + this.deactivateCodeMirrorExtensions(); + (_a2 = this.lineAuthorInfoProvider) == null ? void 0 : _a2.destroy(); + this.lineAuthorInfoProvider = void 0; + console.log(this.plg.manifest.name + ": Disabled line authoring."); + } + isAvailableOnCurrentPlatform() { + return { + available: this.plg.useSimpleGit && import_obsidian12.Platform.isDesktopApp, + gitManager: this.plg.gitManager instanceof SimpleGit ? this.plg.gitManager : void 0 + }; + } + // ========================= REFRESH ========================== + refreshLineAuthorViews() { + if (this.plg.settings.lineAuthor.show) { + this.deactivateFeature(); + this.activateFeature(); + } + } + // ========================= CODEMIRROR EXTENSIONS ========================== + activateCodeMirrorExtensions() { + this.codeMirrorExtensions.push(enabledLineAuthorInfoExtensions); + this.plg.app.workspace.updateOptions(); + this.plg.app.workspace.iterateAllLeaves(this.handleWorkspaceLeaf); + } + deactivateCodeMirrorExtensions() { + for (const ext of this.codeMirrorExtensions) { + this.codeMirrorExtensions.remove(ext); + } + this.plg.app.workspace.updateOptions(); + } + // ========================= HANDLERS ========================== + createEventHandlers() { + this.gutterContextMenuEvent = this.createGutterContextMenuHandler(); + this.fileOpenEvent = this.createFileOpenEvent(); + this.workspaceLeafChangeEvent = this.createWorkspaceLeafChangeEvent(); + this.fileModificationEvent = this.createVaultFileModificationHandler(); + this.refreshOnCssChangeEvent = this.createCssRefreshHandler(); + this.fileRenameEvent = this.createFileRenameEvent(); + prepareGutterSearchForContextMenuHandling(); + this.plg.registerEvent(this.gutterContextMenuEvent); + this.plg.registerEvent(this.refreshOnCssChangeEvent); + this.plg.registerEvent(this.fileOpenEvent); + this.plg.registerEvent(this.workspaceLeafChangeEvent); + this.plg.registerEvent(this.fileModificationEvent); + this.plg.registerEvent(this.fileRenameEvent); + } + destroyEventHandlers() { + this.plg.app.workspace.offref(this.refreshOnCssChangeEvent); + this.plg.app.workspace.offref(this.fileOpenEvent); + this.plg.app.workspace.offref(this.workspaceLeafChangeEvent); + this.plg.app.workspace.offref(this.refreshOnCssChangeEvent); + this.plg.app.vault.offref(this.fileRenameEvent); + this.plg.app.workspace.offref(this.gutterContextMenuEvent); + } + createFileOpenEvent() { + return this.plg.app.workspace.on( + "file-open", + (file) => { + var _a2; + return (_a2 = this.lineAuthorInfoProvider) == null ? void 0 : _a2.trackChanged(file); + } + ); + } + createWorkspaceLeafChangeEvent() { + return this.plg.app.workspace.on( + "active-leaf-change", + this.handleWorkspaceLeaf + ); + } + createFileRenameEvent() { + return this.plg.app.vault.on( + "rename", + (file, _old) => { + var _a2; + return file instanceof import_obsidian12.TFile && ((_a2 = this.lineAuthorInfoProvider) == null ? void 0 : _a2.trackChanged(file)); + } + ); + } + createVaultFileModificationHandler() { + return this.plg.app.vault.on( + "modify", + (anyPath) => { + var _a2; + return anyPath instanceof import_obsidian12.TFile && ((_a2 = this.lineAuthorInfoProvider) == null ? void 0 : _a2.trackChanged(anyPath)); + } + ); + } + createCssRefreshHandler() { + return this.plg.app.workspace.on( + "css-change", + () => this.refreshLineAuthorViews() + ); + } + createGutterContextMenuHandler() { + return this.plg.app.workspace.on("editor-menu", handleContextMenu); + } +}; + +// src/promiseQueue.ts +init_polyfill_buffer(); +var PromiseQueue = class { + constructor() { + this.tasks = []; + } + addTask(task) { + this.tasks.push(task); + if (this.tasks.length === 1) { + this.handleTask(); + } + } + async handleTask() { + if (this.tasks.length > 0) { + this.tasks[0]().finally(() => { + this.tasks.shift(); + this.handleTask(); + }); + } + } +}; + +// src/statusBar.ts +init_polyfill_buffer(); +var import_obsidian13 = require("obsidian"); +var StatusBar = class { + constructor(statusBarEl, plugin) { + this.statusBarEl = statusBarEl; + this.plugin = plugin; + this.messages = []; + this.base = "obsidian-git-statusbar-"; + this.statusBarEl.setAttribute("aria-label-position", "top"); + addEventListener("git-refresh", this.refreshCommitTimestamp.bind(this)); + } + displayMessage(message, timeout) { + this.messages.push({ + message: `Git: ${message.slice(0, 100)}`, + timeout + }); + this.display(); + } + display() { + if (this.messages.length > 0 && !this.currentMessage) { + this.currentMessage = this.messages.shift(); + this.statusBarEl.addClass(this.base + "message"); + this.statusBarEl.ariaLabel = ""; + this.statusBarEl.setText(this.currentMessage.message); + this.lastMessageTimestamp = Date.now(); + } else if (this.currentMessage) { + const messageAge = Date.now() - this.lastMessageTimestamp; + if (messageAge >= this.currentMessage.timeout) { + this.currentMessage = null; + this.lastMessageTimestamp = null; + } + } else { + this.displayState(); + } + } + displayState() { + if (this.statusBarEl.getText().length > 3 || !this.statusBarEl.hasChildNodes()) { + this.statusBarEl.empty(); + this.iconEl = this.statusBarEl.createDiv(); + this.textEl = this.statusBarEl.createDiv(); + this.textEl.style.float = "right"; + this.textEl.style.marginLeft = "5px"; + this.iconEl.style.float = "left"; + } + switch (this.plugin.state) { + case 0 /* idle */: + this.displayFromNow(); + break; + case 1 /* status */: + this.statusBarEl.ariaLabel = "Checking repository status..."; + (0, import_obsidian13.setIcon)(this.iconEl, "refresh-cw"); + this.statusBarEl.addClass(this.base + "status"); + break; + case 3 /* add */: + this.statusBarEl.ariaLabel = "Adding files..."; + (0, import_obsidian13.setIcon)(this.iconEl, "refresh-w"); + this.statusBarEl.addClass(this.base + "add"); + break; + case 4 /* commit */: + this.statusBarEl.ariaLabel = "Committing changes..."; + (0, import_obsidian13.setIcon)(this.iconEl, "git-commit"); + this.statusBarEl.addClass(this.base + "commit"); + break; + case 5 /* push */: + this.statusBarEl.ariaLabel = "Pushing changes..."; + (0, import_obsidian13.setIcon)(this.iconEl, "upload"); + this.statusBarEl.addClass(this.base + "push"); + break; + case 2 /* pull */: + this.statusBarEl.ariaLabel = "Pulling changes..."; + (0, import_obsidian13.setIcon)(this.iconEl, "download"); + this.statusBarEl.addClass(this.base + "pull"); + break; + case 6 /* conflicted */: + this.statusBarEl.ariaLabel = "You have conflict files..."; + (0, import_obsidian13.setIcon)(this.iconEl, "alert-circle"); + this.statusBarEl.addClass(this.base + "conflict"); + break; + default: + this.statusBarEl.ariaLabel = "Failed on initialization!"; + (0, import_obsidian13.setIcon)(this.iconEl, "alert-triangle"); + this.statusBarEl.addClass(this.base + "failed-init"); + break; + } + } + displayFromNow() { + var _a2; + const timestamp = this.lastCommitTimestamp; + if (timestamp) { + const moment5 = window.moment; + const fromNow = moment5(timestamp).fromNow(); + this.statusBarEl.ariaLabel = `${this.plugin.offlineMode ? "Offline: " : ""}Last Commit: ${fromNow}`; + if ((_a2 = this.unPushedCommits) != null ? _a2 : 0 > 0) { + this.statusBarEl.ariaLabel += ` +(${this.unPushedCommits} unpushed commits)`; + } + } else { + this.statusBarEl.ariaLabel = this.plugin.offlineMode ? "Git is offline" : "Git is ready"; + } + if (this.plugin.offlineMode) { + (0, import_obsidian13.setIcon)(this.iconEl, "globe"); + } else { + (0, import_obsidian13.setIcon)(this.iconEl, "check"); + } + if (this.plugin.settings.changedFilesInStatusBar && this.plugin.cachedStatus) { + this.textEl.setText( + this.plugin.cachedStatus.changed.length.toString() + ); + } + this.statusBarEl.addClass(this.base + "idle"); + } + async refreshCommitTimestamp() { + this.lastCommitTimestamp = await this.plugin.gitManager.getLastCommitTime(); + this.unPushedCommits = await this.plugin.gitManager.getUnpushedCommits(); + } +}; + +// src/ui/modals/changedFilesModal.ts +init_polyfill_buffer(); +var import_obsidian14 = require("obsidian"); +var ChangedFilesModal = class extends import_obsidian14.FuzzySuggestModal { + constructor(plugin, changedFiles) { + super(plugin.app); + this.plugin = plugin; + this.changedFiles = changedFiles; + this.setPlaceholder( + "Not supported files will be opened by default app!" + ); + } + getItems() { + return this.changedFiles; + } + getItemText(item) { + if (item.index == "U" && item.working_dir == "U") { + return `Untracked | ${item.vault_path}`; + } + let working_dir = ""; + let index2 = ""; + if (item.working_dir != " ") + working_dir = `Working dir: ${item.working_dir} `; + if (item.index != " ") + index2 = `Index: ${item.index}`; + return `${working_dir}${index2} | ${item.vault_path}`; + } + onChooseItem(item, _) { + if (this.plugin.app.metadataCache.getFirstLinkpathDest( + item.vault_path, + "" + ) == null) { + this.app.openWithDefaultApp(item.vault_path); + } else { + this.plugin.app.workspace.openLinkText(item.vault_path, "/"); + } + } +}; + +// src/ui/modals/customMessageModal.ts +init_polyfill_buffer(); +var import_obsidian15 = require("obsidian"); +var CustomMessageModal = class extends import_obsidian15.SuggestModal { + constructor(plugin, fromAutoBackup) { + super(plugin.app); + this.fromAutoBackup = fromAutoBackup; + this.resolve = null; + this.plugin = plugin; + this.setPlaceholder( + "Type your message and select optional the version with the added date." + ); + } + open() { + super.open(); + return new Promise((resolve) => { + this.resolve = resolve; + }); + } + onClose() { + if (this.resolve) + this.resolve(void 0); + } + selectSuggestion(value, evt) { + if (this.resolve) + this.resolve(value); + super.selectSuggestion(value, evt); + } + getSuggestions(query) { + const date = window.moment().format(this.plugin.settings.commitDateFormat); + if (query == "") + query = "..."; + return [query, `${date}: ${query}`, `${query}: ${date}`]; + } + renderSuggestion(value, el) { + el.innerText = value; + } + onChooseSuggestion(item, _) { + } +}; + +// src/openInGitHub.ts +init_polyfill_buffer(); +var import_obsidian16 = require("obsidian"); +async function openLineInGitHub(editor, file, manager) { + const data = await getData(manager); + if (data.result === "failure") { + new import_obsidian16.Notice(data.reason); + return; + } + const { isGitHub, branch: branch2, repo, user } = data; + if (isGitHub) { + const path2 = manager.asRepositoryRelativePath(file.path, true); + const from = editor.getCursor("from").line + 1; + const to = editor.getCursor("to").line + 1; + if (from === to) { + window.open( + `https://github.com/${user}/${repo}/blob/${branch2}/${path2}?plain=1#L${from}` + ); + } else { + window.open( + `https://github.com/${user}/${repo}/blob/${branch2}/${path2}?plain=1#L${from}-L${to}` + ); + } + } else { + new import_obsidian16.Notice("It seems like you are not using GitHub"); + } +} +async function openHistoryInGitHub(file, manager) { + const data = await getData(manager); + if (data.result === "failure") { + new import_obsidian16.Notice(data.reason); + return; + } + const { isGitHub, branch: branch2, repo, user } = data; + const path2 = manager.asRepositoryRelativePath(file.path, true); + if (isGitHub) { + window.open( + `https://github.com/${user}/${repo}/commits/${branch2}/${path2}` + ); + } else { + new import_obsidian16.Notice("It seems like you are not using GitHub"); + } +} +async function getData(manager) { + const branchInfo = await manager.branchInfo(); + const remoteBranch = branchInfo.tracking; + const branch2 = branchInfo.current; + if (remoteBranch == null) { + return { + result: "failure", + reason: "Remote branch is not configured" + }; + } + if (branch2 == null) { + return { + result: "failure", + reason: "Failed to get current branch name" + }; + } + const remote = remoteBranch.substring(0, remoteBranch.indexOf("/")); + const remoteUrl = await manager.getConfig( + `remote.${remote}.url` + ); + const [isGitHub, httpsUser, httpsRepo, sshUser, sshRepo] = remoteUrl.match( + /(?:^https:\/\/github\.com\/(.*)\/(.*)\.git$)|(?:^git@github\.com:(.*)\/(.*)\.git$)/ + ); + return { + result: "success", + isGitHub: !!isGitHub, + repo: httpsRepo || sshRepo, + user: httpsUser || sshUser, + branch: branch2 + }; +} + +// src/setting/localStorageSettings.ts +init_polyfill_buffer(); +var LocalStorageSettings = class { + constructor(plugin) { + this.plugin = plugin; + this.prefix = this.plugin.manifest.id + ":"; + } + migrate() { + const keys = [ + "password", + "hostname", + "conflict", + "lastAutoPull", + "lastAutoBackup", + "lastAutoPush", + "gitPath", + "pluginDisabled" + ]; + for (const key2 of keys) { + const old = localStorage.getItem(this.prefix + key2); + if (app.loadLocalStorage(this.prefix + key2) == null && old != null) { + if (old != null) { + app.saveLocalStorage(this.prefix + key2, old); + localStorage.removeItem(this.prefix + key2); + } + } + } + } + getPassword() { + return app.loadLocalStorage(this.prefix + "password"); + } + setPassword(value) { + return app.saveLocalStorage(this.prefix + "password", value); + } + getUsername() { + return app.loadLocalStorage(this.prefix + "username"); + } + setUsername(value) { + return app.saveLocalStorage(this.prefix + "username", value); + } + getHostname() { + return app.loadLocalStorage(this.prefix + "hostname"); + } + setHostname(value) { + return app.saveLocalStorage(this.prefix + "hostname", value); + } + getConflict() { + return app.loadLocalStorage(this.prefix + "conflict"); + } + setConflict(value) { + return app.saveLocalStorage(this.prefix + "conflict", value); + } + getLastAutoPull() { + return app.loadLocalStorage(this.prefix + "lastAutoPull"); + } + setLastAutoPull(value) { + return app.saveLocalStorage(this.prefix + "lastAutoPull", value); + } + getLastAutoBackup() { + return app.loadLocalStorage(this.prefix + "lastAutoBackup"); + } + setLastAutoBackup(value) { + return app.saveLocalStorage(this.prefix + "lastAutoBackup", value); + } + getLastAutoPush() { + return app.loadLocalStorage(this.prefix + "lastAutoPush"); + } + setLastAutoPush(value) { + return app.saveLocalStorage(this.prefix + "lastAutoPush", value); + } + getGitPath() { + return app.loadLocalStorage(this.prefix + "gitPath"); + } + setGitPath(value) { + return app.saveLocalStorage(this.prefix + "gitPath", value); + } + getPATHPaths() { + var _a2, _b; + return (_b = (_a2 = app.loadLocalStorage(this.prefix + "PATHPaths")) == null ? void 0 : _a2.split(":")) != null ? _b : []; + } + setPATHPaths(value) { + return app.saveLocalStorage(this.prefix + "PATHPaths", value.join(":")); + } + getEnvVars() { + var _a2; + return JSON.parse( + (_a2 = app.loadLocalStorage(this.prefix + "envVars")) != null ? _a2 : "[]" + ); + } + setEnvVars(value) { + return app.saveLocalStorage( + this.prefix + "envVars", + JSON.stringify(value) + ); + } + getPluginDisabled() { + return app.loadLocalStorage(this.prefix + "pluginDisabled") == "true"; + } + setPluginDisabled(value) { + return app.saveLocalStorage(this.prefix + "pluginDisabled", `${value}`); + } +}; + +// src/ui/diff/diffView.ts +init_polyfill_buffer(); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/diff2html.js +init_polyfill_buffer(); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/diff-parser.js +init_polyfill_buffer(); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/types.js +init_polyfill_buffer(); +var LineType; +(function(LineType2) { + LineType2["INSERT"] = "insert"; + LineType2["DELETE"] = "delete"; + LineType2["CONTEXT"] = "context"; +})(LineType || (LineType = {})); +var OutputFormatType = { + LINE_BY_LINE: "line-by-line", + SIDE_BY_SIDE: "side-by-side" +}; +var LineMatchingType = { + LINES: "lines", + WORDS: "words", + NONE: "none" +}; +var DiffStyleType = { + WORD: "word", + CHAR: "char" +}; + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/utils.js +init_polyfill_buffer(); +var specials = [ + "-", + "[", + "]", + "/", + "{", + "}", + "(", + ")", + "*", + "+", + "?", + ".", + "\\", + "^", + "$", + "|" +]; +var regex = RegExp("[" + specials.join("\\") + "]", "g"); +function escapeForRegExp(str) { + return str.replace(regex, "\\$&"); +} +function unifyPath(path2) { + return path2 ? path2.replace(/\\/g, "/") : path2; +} +function hashCode(text2) { + let i, chr, len; + let hash2 = 0; + for (i = 0, len = text2.length; i < len; i++) { + chr = text2.charCodeAt(i); + hash2 = (hash2 << 5) - hash2 + chr; + hash2 |= 0; + } + return hash2; +} + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/diff-parser.js +function getExtension(filename, language) { + const filenameParts = filename.split("."); + return filenameParts.length > 1 ? filenameParts[filenameParts.length - 1] : language; +} +function startsWithAny(str, prefixes) { + return prefixes.reduce((startsWith, prefix) => startsWith || str.startsWith(prefix), false); +} +var baseDiffFilenamePrefixes = ["a/", "b/", "i/", "w/", "c/", "o/"]; +function getFilename(line, linePrefix, extraPrefix) { + const prefixes = extraPrefix !== void 0 ? [...baseDiffFilenamePrefixes, extraPrefix] : baseDiffFilenamePrefixes; + const FilenameRegExp = linePrefix ? new RegExp(`^${escapeForRegExp(linePrefix)} "?(.+?)"?$`) : new RegExp('^"?(.+?)"?$'); + const [, filename = ""] = FilenameRegExp.exec(line) || []; + const matchingPrefix = prefixes.find((p) => filename.indexOf(p) === 0); + const fnameWithoutPrefix = matchingPrefix ? filename.slice(matchingPrefix.length) : filename; + return fnameWithoutPrefix.replace(/\s+\d{4}-\d{2}-\d{2} \d{2}:\d{2}:\d{2}(?:\.\d+)? [+-]\d{4}.*$/, ""); +} +function getSrcFilename(line, srcPrefix) { + return getFilename(line, "---", srcPrefix); +} +function getDstFilename(line, dstPrefix) { + return getFilename(line, "+++", dstPrefix); +} +function parse(diffInput, config = {}) { + const files = []; + let currentFile = null; + let currentBlock = null; + let oldLine = null; + let oldLine2 = null; + let newLine = null; + let possibleOldName = null; + let possibleNewName = null; + const oldFileNameHeader = "--- "; + const newFileNameHeader = "+++ "; + const hunkHeaderPrefix = "@@"; + const oldMode = /^old mode (\d{6})/; + const newMode = /^new mode (\d{6})/; + const deletedFileMode = /^deleted file mode (\d{6})/; + const newFileMode = /^new file mode (\d{6})/; + const copyFrom = /^copy from "?(.+)"?/; + const copyTo = /^copy to "?(.+)"?/; + const renameFrom = /^rename from "?(.+)"?/; + const renameTo = /^rename to "?(.+)"?/; + const similarityIndex = /^similarity index (\d+)%/; + const dissimilarityIndex = /^dissimilarity index (\d+)%/; + const index2 = /^index ([\da-z]+)\.\.([\da-z]+)\s*(\d{6})?/; + const binaryFiles = /^Binary files (.*) and (.*) differ/; + const binaryDiff = /^GIT binary patch/; + const combinedIndex = /^index ([\da-z]+),([\da-z]+)\.\.([\da-z]+)/; + const combinedMode = /^mode (\d{6}),(\d{6})\.\.(\d{6})/; + const combinedNewFile = /^new file mode (\d{6})/; + const combinedDeletedFile = /^deleted file mode (\d{6}),(\d{6})/; + const diffLines2 = diffInput.replace(/\\ No newline at end of file/g, "").replace(/\r\n?/g, "\n").split("\n"); + function saveBlock() { + if (currentBlock !== null && currentFile !== null) { + currentFile.blocks.push(currentBlock); + currentBlock = null; + } + } + function saveFile() { + if (currentFile !== null) { + if (!currentFile.oldName && possibleOldName !== null) { + currentFile.oldName = possibleOldName; + } + if (!currentFile.newName && possibleNewName !== null) { + currentFile.newName = possibleNewName; + } + if (currentFile.newName) { + files.push(currentFile); + currentFile = null; + } + } + possibleOldName = null; + possibleNewName = null; + } + function startFile() { + saveBlock(); + saveFile(); + currentFile = { + blocks: [], + deletedLines: 0, + addedLines: 0 + }; + } + function startBlock(line) { + saveBlock(); + let values; + if (currentFile !== null) { + if (values = /^@@ -(\d+)(?:,\d+)? \+(\d+)(?:,\d+)? @@.*/.exec(line)) { + currentFile.isCombined = false; + oldLine = parseInt(values[1], 10); + newLine = parseInt(values[2], 10); + } else if (values = /^@@@ -(\d+)(?:,\d+)? -(\d+)(?:,\d+)? \+(\d+)(?:,\d+)? @@@.*/.exec(line)) { + currentFile.isCombined = true; + oldLine = parseInt(values[1], 10); + oldLine2 = parseInt(values[2], 10); + newLine = parseInt(values[3], 10); + } else { + if (line.startsWith(hunkHeaderPrefix)) { + console.error("Failed to parse lines, starting in 0!"); + } + oldLine = 0; + newLine = 0; + currentFile.isCombined = false; + } + } + currentBlock = { + lines: [], + oldStartLine: oldLine, + oldStartLine2: oldLine2, + newStartLine: newLine, + header: line + }; + } + function createLine(line) { + if (currentFile === null || currentBlock === null || oldLine === null || newLine === null) + return; + const currentLine = { + content: line + }; + const addedPrefixes = currentFile.isCombined ? ["+ ", " +", "++"] : ["+"]; + const deletedPrefixes = currentFile.isCombined ? ["- ", " -", "--"] : ["-"]; + if (startsWithAny(line, addedPrefixes)) { + currentFile.addedLines++; + currentLine.type = LineType.INSERT; + currentLine.oldNumber = void 0; + currentLine.newNumber = newLine++; + } else if (startsWithAny(line, deletedPrefixes)) { + currentFile.deletedLines++; + currentLine.type = LineType.DELETE; + currentLine.oldNumber = oldLine++; + currentLine.newNumber = void 0; + } else { + currentLine.type = LineType.CONTEXT; + currentLine.oldNumber = oldLine++; + currentLine.newNumber = newLine++; + } + currentBlock.lines.push(currentLine); + } + function existHunkHeader(line, lineIdx) { + let idx = lineIdx; + while (idx < diffLines2.length - 3) { + if (line.startsWith("diff")) { + return false; + } + if (diffLines2[idx].startsWith(oldFileNameHeader) && diffLines2[idx + 1].startsWith(newFileNameHeader) && diffLines2[idx + 2].startsWith(hunkHeaderPrefix)) { + return true; + } + idx++; + } + return false; + } + diffLines2.forEach((line, lineIndex) => { + if (!line || line.startsWith("*")) { + return; + } + let values; + const prevLine = diffLines2[lineIndex - 1]; + const nxtLine = diffLines2[lineIndex + 1]; + const afterNxtLine = diffLines2[lineIndex + 2]; + if (line.startsWith("diff --git") || line.startsWith("diff --combined")) { + startFile(); + const gitDiffStart = /^diff --git "?([a-ciow]\/.+)"? "?([a-ciow]\/.+)"?/; + if (values = gitDiffStart.exec(line)) { + possibleOldName = getFilename(values[1], void 0, config.dstPrefix); + possibleNewName = getFilename(values[2], void 0, config.srcPrefix); + } + if (currentFile === null) { + throw new Error("Where is my file !!!"); + } + currentFile.isGitDiff = true; + return; + } + if (line.startsWith("Binary files") && !(currentFile === null || currentFile === void 0 ? void 0 : currentFile.isGitDiff)) { + startFile(); + const unixDiffBinaryStart = /^Binary files "?([a-ciow]\/.+)"? and "?([a-ciow]\/.+)"? differ/; + if (values = unixDiffBinaryStart.exec(line)) { + possibleOldName = getFilename(values[1], void 0, config.dstPrefix); + possibleNewName = getFilename(values[2], void 0, config.srcPrefix); + } + if (currentFile === null) { + throw new Error("Where is my file !!!"); + } + currentFile.isBinary = true; + return; + } + if (!currentFile || !currentFile.isGitDiff && currentFile && line.startsWith(oldFileNameHeader) && nxtLine.startsWith(newFileNameHeader) && afterNxtLine.startsWith(hunkHeaderPrefix)) { + startFile(); + } + if (currentFile === null || currentFile === void 0 ? void 0 : currentFile.isTooBig) { + return; + } + if (currentFile && (typeof config.diffMaxChanges === "number" && currentFile.addedLines + currentFile.deletedLines > config.diffMaxChanges || typeof config.diffMaxLineLength === "number" && line.length > config.diffMaxLineLength)) { + currentFile.isTooBig = true; + currentFile.addedLines = 0; + currentFile.deletedLines = 0; + currentFile.blocks = []; + currentBlock = null; + const message = typeof config.diffTooBigMessage === "function" ? config.diffTooBigMessage(files.length) : "Diff too big to be displayed"; + startBlock(message); + return; + } + if (line.startsWith(oldFileNameHeader) && nxtLine.startsWith(newFileNameHeader) || line.startsWith(newFileNameHeader) && prevLine.startsWith(oldFileNameHeader)) { + if (currentFile && !currentFile.oldName && line.startsWith("--- ") && (values = getSrcFilename(line, config.srcPrefix))) { + currentFile.oldName = values; + currentFile.language = getExtension(currentFile.oldName, currentFile.language); + return; + } + if (currentFile && !currentFile.newName && line.startsWith("+++ ") && (values = getDstFilename(line, config.dstPrefix))) { + currentFile.newName = values; + currentFile.language = getExtension(currentFile.newName, currentFile.language); + return; + } + } + if (currentFile && (line.startsWith(hunkHeaderPrefix) || currentFile.isGitDiff && currentFile.oldName && currentFile.newName && !currentBlock)) { + startBlock(line); + return; + } + if (currentBlock && (line.startsWith("+") || line.startsWith("-") || line.startsWith(" "))) { + createLine(line); + return; + } + const doesNotExistHunkHeader = !existHunkHeader(line, lineIndex); + if (currentFile === null) { + throw new Error("Where is my file !!!"); + } + if (values = oldMode.exec(line)) { + currentFile.oldMode = values[1]; + } else if (values = newMode.exec(line)) { + currentFile.newMode = values[1]; + } else if (values = deletedFileMode.exec(line)) { + currentFile.deletedFileMode = values[1]; + currentFile.isDeleted = true; + } else if (values = newFileMode.exec(line)) { + currentFile.newFileMode = values[1]; + currentFile.isNew = true; + } else if (values = copyFrom.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.oldName = values[1]; + } + currentFile.isCopy = true; + } else if (values = copyTo.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.newName = values[1]; + } + currentFile.isCopy = true; + } else if (values = renameFrom.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.oldName = values[1]; + } + currentFile.isRename = true; + } else if (values = renameTo.exec(line)) { + if (doesNotExistHunkHeader) { + currentFile.newName = values[1]; + } + currentFile.isRename = true; + } else if (values = binaryFiles.exec(line)) { + currentFile.isBinary = true; + currentFile.oldName = getFilename(values[1], void 0, config.srcPrefix); + currentFile.newName = getFilename(values[2], void 0, config.dstPrefix); + startBlock("Binary file"); + } else if (binaryDiff.test(line)) { + currentFile.isBinary = true; + startBlock(line); + } else if (values = similarityIndex.exec(line)) { + currentFile.unchangedPercentage = parseInt(values[1], 10); + } else if (values = dissimilarityIndex.exec(line)) { + currentFile.changedPercentage = parseInt(values[1], 10); + } else if (values = index2.exec(line)) { + currentFile.checksumBefore = values[1]; + currentFile.checksumAfter = values[2]; + values[3] && (currentFile.mode = values[3]); + } else if (values = combinedIndex.exec(line)) { + currentFile.checksumBefore = [values[2], values[3]]; + currentFile.checksumAfter = values[1]; + } else if (values = combinedMode.exec(line)) { + currentFile.oldMode = [values[2], values[3]]; + currentFile.newMode = values[1]; + } else if (values = combinedNewFile.exec(line)) { + currentFile.newFileMode = values[1]; + currentFile.isNew = true; + } else if (values = combinedDeletedFile.exec(line)) { + currentFile.deletedFileMode = values[1]; + currentFile.isDeleted = true; + } + }); + saveBlock(); + saveFile(); + return files; +} + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/file-list-renderer.js +init_polyfill_buffer(); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/render-utils.js +init_polyfill_buffer(); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/rematch.js +init_polyfill_buffer(); +function levenshtein(a, b) { + if (a.length === 0) { + return b.length; + } + if (b.length === 0) { + return a.length; + } + const matrix = []; + let i; + for (i = 0; i <= b.length; i++) { + matrix[i] = [i]; + } + let j; + for (j = 0; j <= a.length; j++) { + matrix[0][j] = j; + } + for (i = 1; i <= b.length; i++) { + for (j = 1; j <= a.length; j++) { + if (b.charAt(i - 1) === a.charAt(j - 1)) { + matrix[i][j] = matrix[i - 1][j - 1]; + } else { + matrix[i][j] = Math.min(matrix[i - 1][j - 1] + 1, Math.min(matrix[i][j - 1] + 1, matrix[i - 1][j] + 1)); + } + } + } + return matrix[b.length][a.length]; +} +function newDistanceFn(str) { + return (x, y) => { + const xValue = str(x).trim(); + const yValue = str(y).trim(); + const lev = levenshtein(xValue, yValue); + return lev / (xValue.length + yValue.length); + }; +} +function newMatcherFn(distance2) { + function findBestMatch(a, b, cache = /* @__PURE__ */ new Map()) { + let bestMatchDist = Infinity; + let bestMatch; + for (let i = 0; i < a.length; ++i) { + for (let j = 0; j < b.length; ++j) { + const cacheKey = JSON.stringify([a[i], b[j]]); + let md; + if (!(cache.has(cacheKey) && (md = cache.get(cacheKey)))) { + md = distance2(a[i], b[j]); + cache.set(cacheKey, md); + } + if (md < bestMatchDist) { + bestMatchDist = md; + bestMatch = { indexA: i, indexB: j, score: bestMatchDist }; + } + } + } + return bestMatch; + } + function group(a, b, level = 0, cache = /* @__PURE__ */ new Map()) { + const bm = findBestMatch(a, b, cache); + if (!bm || a.length + b.length < 3) { + return [[a, b]]; + } + const a1 = a.slice(0, bm.indexA); + const b1 = b.slice(0, bm.indexB); + const aMatch = [a[bm.indexA]]; + const bMatch = [b[bm.indexB]]; + const tailA = bm.indexA + 1; + const tailB = bm.indexB + 1; + const a2 = a.slice(tailA); + const b2 = b.slice(tailB); + const group1 = group(a1, b1, level + 1, cache); + const groupMatch = group(aMatch, bMatch, level + 1, cache); + const group2 = group(a2, b2, level + 1, cache); + let result = groupMatch; + if (bm.indexA > 0 || bm.indexB > 0) { + result = group1.concat(result); + } + if (a.length > tailA || b.length > tailB) { + result = result.concat(group2); + } + return result; + } + return group; +} + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/render-utils.js +var CSSLineClass = { + INSERTS: "d2h-ins", + DELETES: "d2h-del", + CONTEXT: "d2h-cntx", + INFO: "d2h-info", + INSERT_CHANGES: "d2h-ins d2h-change", + DELETE_CHANGES: "d2h-del d2h-change" +}; +var defaultRenderConfig = { + matching: LineMatchingType.NONE, + matchWordsThreshold: 0.25, + maxLineLengthHighlight: 1e4, + diffStyle: DiffStyleType.WORD +}; +var separator = "/"; +var distance = newDistanceFn((change) => change.value); +var matcher = newMatcherFn(distance); +function isDevNullName(name) { + return name.indexOf("dev/null") !== -1; +} +function removeInsElements(line) { + return line.replace(/(]*>((.|\n)*?)<\/ins>)/g, ""); +} +function removeDelElements(line) { + return line.replace(/(]*>((.|\n)*?)<\/del>)/g, ""); +} +function toCSSClass(lineType) { + switch (lineType) { + case LineType.CONTEXT: + return CSSLineClass.CONTEXT; + case LineType.INSERT: + return CSSLineClass.INSERTS; + case LineType.DELETE: + return CSSLineClass.DELETES; + } +} +function prefixLength(isCombined) { + return isCombined ? 2 : 1; +} +function escapeForHtml(str) { + return str.slice(0).replace(/&/g, "&").replace(//g, ">").replace(/"/g, """).replace(/'/g, "'").replace(/\//g, "/"); +} +function deconstructLine(line, isCombined, escape = true) { + const indexToSplit = prefixLength(isCombined); + return { + prefix: line.substring(0, indexToSplit), + content: escape ? escapeForHtml(line.substring(indexToSplit)) : line.substring(indexToSplit) + }; +} +function filenameDiff(file) { + const oldFilename = unifyPath(file.oldName); + const newFilename = unifyPath(file.newName); + if (oldFilename !== newFilename && !isDevNullName(oldFilename) && !isDevNullName(newFilename)) { + const prefixPaths = []; + const suffixPaths = []; + const oldFilenameParts = oldFilename.split(separator); + const newFilenameParts = newFilename.split(separator); + const oldFilenamePartsSize = oldFilenameParts.length; + const newFilenamePartsSize = newFilenameParts.length; + let i = 0; + let j = oldFilenamePartsSize - 1; + let k = newFilenamePartsSize - 1; + while (i < j && i < k) { + if (oldFilenameParts[i] === newFilenameParts[i]) { + prefixPaths.push(newFilenameParts[i]); + i += 1; + } else { + break; + } + } + while (j > i && k > i) { + if (oldFilenameParts[j] === newFilenameParts[k]) { + suffixPaths.unshift(newFilenameParts[k]); + j -= 1; + k -= 1; + } else { + break; + } + } + const finalPrefix = prefixPaths.join(separator); + const finalSuffix = suffixPaths.join(separator); + const oldRemainingPath = oldFilenameParts.slice(i, j + 1).join(separator); + const newRemainingPath = newFilenameParts.slice(i, k + 1).join(separator); + if (finalPrefix.length && finalSuffix.length) { + return finalPrefix + separator + "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}" + separator + finalSuffix; + } else if (finalPrefix.length) { + return finalPrefix + separator + "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}"; + } else if (finalSuffix.length) { + return "{" + oldRemainingPath + " \u2192 " + newRemainingPath + "}" + separator + finalSuffix; + } + return oldFilename + " \u2192 " + newFilename; + } else if (!isDevNullName(newFilename)) { + return newFilename; + } else { + return oldFilename; + } +} +function getHtmlId(file) { + return `d2h-${hashCode(filenameDiff(file)).toString().slice(-6)}`; +} +function getFileIcon(file) { + let templateName = "file-changed"; + if (file.isRename) { + templateName = "file-renamed"; + } else if (file.isCopy) { + templateName = "file-renamed"; + } else if (file.isNew) { + templateName = "file-added"; + } else if (file.isDeleted) { + templateName = "file-deleted"; + } else if (file.newName !== file.oldName) { + templateName = "file-renamed"; + } + return templateName; +} +function diffHighlight(diffLine1, diffLine2, isCombined, config = {}) { + const { matching, maxLineLengthHighlight, matchWordsThreshold, diffStyle } = Object.assign(Object.assign({}, defaultRenderConfig), config); + const line1 = deconstructLine(diffLine1, isCombined, false); + const line2 = deconstructLine(diffLine2, isCombined, false); + if (line1.content.length > maxLineLengthHighlight || line2.content.length > maxLineLengthHighlight) { + return { + oldLine: { + prefix: line1.prefix, + content: escapeForHtml(line1.content) + }, + newLine: { + prefix: line2.prefix, + content: escapeForHtml(line2.content) + } + }; + } + const diff2 = diffStyle === "char" ? diffChars(line1.content, line2.content) : diffWordsWithSpace(line1.content, line2.content); + const changedWords = []; + if (diffStyle === "word" && matching === "words") { + const removed = diff2.filter((element2) => element2.removed); + const added = diff2.filter((element2) => element2.added); + const chunks = matcher(added, removed); + chunks.forEach((chunk) => { + if (chunk[0].length === 1 && chunk[1].length === 1) { + const dist = distance(chunk[0][0], chunk[1][0]); + if (dist < matchWordsThreshold) { + changedWords.push(chunk[0][0]); + changedWords.push(chunk[1][0]); + } + } + }); + } + const highlightedLine = diff2.reduce((highlightedLine2, part) => { + const elemType = part.added ? "ins" : part.removed ? "del" : null; + const addClass = changedWords.indexOf(part) > -1 ? ' class="d2h-change"' : ""; + const escapedValue = escapeForHtml(part.value); + return elemType !== null ? `${highlightedLine2}<${elemType}${addClass}>${escapedValue}` : `${highlightedLine2}${escapedValue}`; + }, ""); + return { + oldLine: { + prefix: line1.prefix, + content: removeInsElements(highlightedLine) + }, + newLine: { + prefix: line2.prefix, + content: removeDelElements(highlightedLine) + } + }; +} + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/file-list-renderer.js +var baseTemplatesPath = "file-summary"; +var iconsBaseTemplatesPath = "icon"; +function render(diffFiles, hoganUtils) { + const files = diffFiles.map((file) => hoganUtils.render(baseTemplatesPath, "line", { + fileHtmlId: getHtmlId(file), + oldName: file.oldName, + newName: file.newName, + fileName: filenameDiff(file), + deletedLines: "-" + file.deletedLines, + addedLines: "+" + file.addedLines + }, { + fileIcon: hoganUtils.template(iconsBaseTemplatesPath, getFileIcon(file)) + })).join("\n"); + return hoganUtils.render(baseTemplatesPath, "wrapper", { + filesNumber: diffFiles.length, + files + }); +} + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/line-by-line-renderer.js +init_polyfill_buffer(); +var defaultLineByLineRendererConfig = Object.assign(Object.assign({}, defaultRenderConfig), { renderNothingWhenEmpty: false, matchingMaxComparisons: 2500, maxLineSizeInBlockForComparison: 200 }); +var genericTemplatesPath = "generic"; +var baseTemplatesPath2 = "line-by-line"; +var iconsBaseTemplatesPath2 = "icon"; +var tagsBaseTemplatesPath = "tag"; +var LineByLineRenderer = class { + constructor(hoganUtils, config = {}) { + this.hoganUtils = hoganUtils; + this.config = Object.assign(Object.assign({}, defaultLineByLineRendererConfig), config); + } + render(diffFiles) { + const diffsHtml = diffFiles.map((file) => { + let diffs; + if (file.blocks.length) { + diffs = this.generateFileHtml(file); + } else { + diffs = this.generateEmptyDiff(); + } + return this.makeFileDiffHtml(file, diffs); + }).join("\n"); + return this.hoganUtils.render(genericTemplatesPath, "wrapper", { content: diffsHtml }); + } + makeFileDiffHtml(file, diffs) { + if (this.config.renderNothingWhenEmpty && Array.isArray(file.blocks) && file.blocks.length === 0) + return ""; + const fileDiffTemplate = this.hoganUtils.template(baseTemplatesPath2, "file-diff"); + const filePathTemplate = this.hoganUtils.template(genericTemplatesPath, "file-path"); + const fileIconTemplate = this.hoganUtils.template(iconsBaseTemplatesPath2, "file"); + const fileTagTemplate = this.hoganUtils.template(tagsBaseTemplatesPath, getFileIcon(file)); + return fileDiffTemplate.render({ + file, + fileHtmlId: getHtmlId(file), + diffs, + filePath: filePathTemplate.render({ + fileDiffName: filenameDiff(file) + }, { + fileIcon: fileIconTemplate, + fileTag: fileTagTemplate + }) + }); + } + generateEmptyDiff() { + return this.hoganUtils.render(genericTemplatesPath, "empty-diff", { + contentClass: "d2h-code-line", + CSSLineClass + }); + } + generateFileHtml(file) { + const matcher2 = newMatcherFn(newDistanceFn((e) => deconstructLine(e.content, file.isCombined).content)); + return file.blocks.map((block) => { + let lines = this.hoganUtils.render(genericTemplatesPath, "block-header", { + CSSLineClass, + blockHeader: file.isTooBig ? block.header : escapeForHtml(block.header), + lineClass: "d2h-code-linenumber", + contentClass: "d2h-code-line" + }); + this.applyLineGroupping(block).forEach(([contextLines, oldLines, newLines]) => { + if (oldLines.length && newLines.length && !contextLines.length) { + this.applyRematchMatching(oldLines, newLines, matcher2).map(([oldLines2, newLines2]) => { + const { left, right } = this.processChangedLines(file, file.isCombined, oldLines2, newLines2); + lines += left; + lines += right; + }); + } else if (contextLines.length) { + contextLines.forEach((line) => { + const { prefix, content } = deconstructLine(line.content, file.isCombined); + lines += this.generateSingleLineHtml(file, { + type: CSSLineClass.CONTEXT, + prefix, + content, + oldNumber: line.oldNumber, + newNumber: line.newNumber + }); + }); + } else if (oldLines.length || newLines.length) { + const { left, right } = this.processChangedLines(file, file.isCombined, oldLines, newLines); + lines += left; + lines += right; + } else { + console.error("Unknown state reached while processing groups of lines", contextLines, oldLines, newLines); + } + }); + return lines; + }).join("\n"); + } + applyLineGroupping(block) { + const blockLinesGroups = []; + let oldLines = []; + let newLines = []; + for (let i = 0; i < block.lines.length; i++) { + const diffLine = block.lines[i]; + if (diffLine.type !== LineType.INSERT && newLines.length || diffLine.type === LineType.CONTEXT && oldLines.length > 0) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + if (diffLine.type === LineType.CONTEXT) { + blockLinesGroups.push([[diffLine], [], []]); + } else if (diffLine.type === LineType.INSERT && oldLines.length === 0) { + blockLinesGroups.push([[], [], [diffLine]]); + } else if (diffLine.type === LineType.INSERT && oldLines.length > 0) { + newLines.push(diffLine); + } else if (diffLine.type === LineType.DELETE) { + oldLines.push(diffLine); + } + } + if (oldLines.length || newLines.length) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + return blockLinesGroups; + } + applyRematchMatching(oldLines, newLines, matcher2) { + const comparisons = oldLines.length * newLines.length; + const maxLineSizeInBlock = Math.max.apply(null, [0].concat(oldLines.concat(newLines).map((elem) => elem.content.length))); + const doMatching = comparisons < this.config.matchingMaxComparisons && maxLineSizeInBlock < this.config.maxLineSizeInBlockForComparison && (this.config.matching === "lines" || this.config.matching === "words"); + return doMatching ? matcher2(oldLines, newLines) : [[oldLines, newLines]]; + } + processChangedLines(file, isCombined, oldLines, newLines) { + const fileHtml = { + right: "", + left: "" + }; + const maxLinesNumber = Math.max(oldLines.length, newLines.length); + for (let i = 0; i < maxLinesNumber; i++) { + const oldLine = oldLines[i]; + const newLine = newLines[i]; + const diff2 = oldLine !== void 0 && newLine !== void 0 ? diffHighlight(oldLine.content, newLine.content, isCombined, this.config) : void 0; + const preparedOldLine = oldLine !== void 0 && oldLine.oldNumber !== void 0 ? Object.assign(Object.assign({}, diff2 !== void 0 ? { + prefix: diff2.oldLine.prefix, + content: diff2.oldLine.content, + type: CSSLineClass.DELETE_CHANGES + } : Object.assign(Object.assign({}, deconstructLine(oldLine.content, isCombined)), { type: toCSSClass(oldLine.type) })), { oldNumber: oldLine.oldNumber, newNumber: oldLine.newNumber }) : void 0; + const preparedNewLine = newLine !== void 0 && newLine.newNumber !== void 0 ? Object.assign(Object.assign({}, diff2 !== void 0 ? { + prefix: diff2.newLine.prefix, + content: diff2.newLine.content, + type: CSSLineClass.INSERT_CHANGES + } : Object.assign(Object.assign({}, deconstructLine(newLine.content, isCombined)), { type: toCSSClass(newLine.type) })), { oldNumber: newLine.oldNumber, newNumber: newLine.newNumber }) : void 0; + const { left, right } = this.generateLineHtml(file, preparedOldLine, preparedNewLine); + fileHtml.left += left; + fileHtml.right += right; + } + return fileHtml; + } + generateLineHtml(file, oldLine, newLine) { + return { + left: this.generateSingleLineHtml(file, oldLine), + right: this.generateSingleLineHtml(file, newLine) + }; + } + generateSingleLineHtml(file, line) { + if (line === void 0) + return ""; + const lineNumberHtml = this.hoganUtils.render(baseTemplatesPath2, "numbers", { + oldNumber: line.oldNumber || "", + newNumber: line.newNumber || "" + }); + return this.hoganUtils.render(genericTemplatesPath, "line", { + type: line.type, + lineClass: "d2h-code-linenumber", + contentClass: "d2h-code-line", + prefix: line.prefix === " " ? " " : line.prefix, + content: line.content, + lineNumber: lineNumberHtml, + line, + file + }); + } +}; + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/side-by-side-renderer.js +init_polyfill_buffer(); +var defaultSideBySideRendererConfig = Object.assign(Object.assign({}, defaultRenderConfig), { renderNothingWhenEmpty: false, matchingMaxComparisons: 2500, maxLineSizeInBlockForComparison: 200 }); +var genericTemplatesPath2 = "generic"; +var baseTemplatesPath3 = "side-by-side"; +var iconsBaseTemplatesPath3 = "icon"; +var tagsBaseTemplatesPath2 = "tag"; +var SideBySideRenderer = class { + constructor(hoganUtils, config = {}) { + this.hoganUtils = hoganUtils; + this.config = Object.assign(Object.assign({}, defaultSideBySideRendererConfig), config); + } + render(diffFiles) { + const diffsHtml = diffFiles.map((file) => { + let diffs; + if (file.blocks.length) { + diffs = this.generateFileHtml(file); + } else { + diffs = this.generateEmptyDiff(); + } + return this.makeFileDiffHtml(file, diffs); + }).join("\n"); + return this.hoganUtils.render(genericTemplatesPath2, "wrapper", { content: diffsHtml }); + } + makeFileDiffHtml(file, diffs) { + if (this.config.renderNothingWhenEmpty && Array.isArray(file.blocks) && file.blocks.length === 0) + return ""; + const fileDiffTemplate = this.hoganUtils.template(baseTemplatesPath3, "file-diff"); + const filePathTemplate = this.hoganUtils.template(genericTemplatesPath2, "file-path"); + const fileIconTemplate = this.hoganUtils.template(iconsBaseTemplatesPath3, "file"); + const fileTagTemplate = this.hoganUtils.template(tagsBaseTemplatesPath2, getFileIcon(file)); + return fileDiffTemplate.render({ + file, + fileHtmlId: getHtmlId(file), + diffs, + filePath: filePathTemplate.render({ + fileDiffName: filenameDiff(file) + }, { + fileIcon: fileIconTemplate, + fileTag: fileTagTemplate + }) + }); + } + generateEmptyDiff() { + return { + right: "", + left: this.hoganUtils.render(genericTemplatesPath2, "empty-diff", { + contentClass: "d2h-code-side-line", + CSSLineClass + }) + }; + } + generateFileHtml(file) { + const matcher2 = newMatcherFn(newDistanceFn((e) => deconstructLine(e.content, file.isCombined).content)); + return file.blocks.map((block) => { + const fileHtml = { + left: this.makeHeaderHtml(block.header, file), + right: this.makeHeaderHtml("") + }; + this.applyLineGroupping(block).forEach(([contextLines, oldLines, newLines]) => { + if (oldLines.length && newLines.length && !contextLines.length) { + this.applyRematchMatching(oldLines, newLines, matcher2).map(([oldLines2, newLines2]) => { + const { left, right } = this.processChangedLines(file.isCombined, oldLines2, newLines2); + fileHtml.left += left; + fileHtml.right += right; + }); + } else if (contextLines.length) { + contextLines.forEach((line) => { + const { prefix, content } = deconstructLine(line.content, file.isCombined); + const { left, right } = this.generateLineHtml({ + type: CSSLineClass.CONTEXT, + prefix, + content, + number: line.oldNumber + }, { + type: CSSLineClass.CONTEXT, + prefix, + content, + number: line.newNumber + }); + fileHtml.left += left; + fileHtml.right += right; + }); + } else if (oldLines.length || newLines.length) { + const { left, right } = this.processChangedLines(file.isCombined, oldLines, newLines); + fileHtml.left += left; + fileHtml.right += right; + } else { + console.error("Unknown state reached while processing groups of lines", contextLines, oldLines, newLines); + } + }); + return fileHtml; + }).reduce((accomulated, html2) => { + return { left: accomulated.left + html2.left, right: accomulated.right + html2.right }; + }, { left: "", right: "" }); + } + applyLineGroupping(block) { + const blockLinesGroups = []; + let oldLines = []; + let newLines = []; + for (let i = 0; i < block.lines.length; i++) { + const diffLine = block.lines[i]; + if (diffLine.type !== LineType.INSERT && newLines.length || diffLine.type === LineType.CONTEXT && oldLines.length > 0) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + if (diffLine.type === LineType.CONTEXT) { + blockLinesGroups.push([[diffLine], [], []]); + } else if (diffLine.type === LineType.INSERT && oldLines.length === 0) { + blockLinesGroups.push([[], [], [diffLine]]); + } else if (diffLine.type === LineType.INSERT && oldLines.length > 0) { + newLines.push(diffLine); + } else if (diffLine.type === LineType.DELETE) { + oldLines.push(diffLine); + } + } + if (oldLines.length || newLines.length) { + blockLinesGroups.push([[], oldLines, newLines]); + oldLines = []; + newLines = []; + } + return blockLinesGroups; + } + applyRematchMatching(oldLines, newLines, matcher2) { + const comparisons = oldLines.length * newLines.length; + const maxLineSizeInBlock = Math.max.apply(null, [0].concat(oldLines.concat(newLines).map((elem) => elem.content.length))); + const doMatching = comparisons < this.config.matchingMaxComparisons && maxLineSizeInBlock < this.config.maxLineSizeInBlockForComparison && (this.config.matching === "lines" || this.config.matching === "words"); + return doMatching ? matcher2(oldLines, newLines) : [[oldLines, newLines]]; + } + makeHeaderHtml(blockHeader, file) { + return this.hoganUtils.render(genericTemplatesPath2, "block-header", { + CSSLineClass, + blockHeader: (file === null || file === void 0 ? void 0 : file.isTooBig) ? blockHeader : escapeForHtml(blockHeader), + lineClass: "d2h-code-side-linenumber", + contentClass: "d2h-code-side-line" + }); + } + processChangedLines(isCombined, oldLines, newLines) { + const fileHtml = { + right: "", + left: "" + }; + const maxLinesNumber = Math.max(oldLines.length, newLines.length); + for (let i = 0; i < maxLinesNumber; i++) { + const oldLine = oldLines[i]; + const newLine = newLines[i]; + const diff2 = oldLine !== void 0 && newLine !== void 0 ? diffHighlight(oldLine.content, newLine.content, isCombined, this.config) : void 0; + const preparedOldLine = oldLine !== void 0 && oldLine.oldNumber !== void 0 ? Object.assign(Object.assign({}, diff2 !== void 0 ? { + prefix: diff2.oldLine.prefix, + content: diff2.oldLine.content, + type: CSSLineClass.DELETE_CHANGES + } : Object.assign(Object.assign({}, deconstructLine(oldLine.content, isCombined)), { type: toCSSClass(oldLine.type) })), { number: oldLine.oldNumber }) : void 0; + const preparedNewLine = newLine !== void 0 && newLine.newNumber !== void 0 ? Object.assign(Object.assign({}, diff2 !== void 0 ? { + prefix: diff2.newLine.prefix, + content: diff2.newLine.content, + type: CSSLineClass.INSERT_CHANGES + } : Object.assign(Object.assign({}, deconstructLine(newLine.content, isCombined)), { type: toCSSClass(newLine.type) })), { number: newLine.newNumber }) : void 0; + const { left, right } = this.generateLineHtml(preparedOldLine, preparedNewLine); + fileHtml.left += left; + fileHtml.right += right; + } + return fileHtml; + } + generateLineHtml(oldLine, newLine) { + return { + left: this.generateSingleHtml(oldLine), + right: this.generateSingleHtml(newLine) + }; + } + generateSingleHtml(line) { + const lineClass = "d2h-code-side-linenumber"; + const contentClass = "d2h-code-side-line"; + return this.hoganUtils.render(genericTemplatesPath2, "line", { + type: (line === null || line === void 0 ? void 0 : line.type) || `${CSSLineClass.CONTEXT} d2h-emptyplaceholder`, + lineClass: line !== void 0 ? lineClass : `${lineClass} d2h-code-side-emptyplaceholder`, + contentClass: line !== void 0 ? contentClass : `${contentClass} d2h-code-side-emptyplaceholder`, + prefix: (line === null || line === void 0 ? void 0 : line.prefix) === " " ? " " : line === null || line === void 0 ? void 0 : line.prefix, + content: line === null || line === void 0 ? void 0 : line.content, + lineNumber: line === null || line === void 0 ? void 0 : line.number + }); + } +}; + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/hoganjs-utils.js +init_polyfill_buffer(); +var Hogan3 = __toESM(require_hogan()); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/diff2html-templates.js +init_polyfill_buffer(); +var Hogan2 = __toESM(require_hogan()); +var defaultTemplates = {}; +defaultTemplates["file-summary-line"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
  • '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(t.rp("'); + t.b(t.v(t.f("fileName", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b(t.v(t.f("addedLines", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b(t.v(t.f("deletedLines", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
  • "); + return t.fl(); +}, partials: { "'); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' Files changed ('); + t.b(t.v(t.f("filesNumber", c, p, 0))); + t.b(")"); + t.b("\n" + i); + t.b(' hide'); + t.b("\n" + i); + t.b(' show'); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
      '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("files", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-block-header"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b('
    '); + if (t.s(t.f("blockHeader", c, p, 1), c, p, 0, 156, 173, "{{ }}")) { + t.rs(c, p, function(c2, p2, t2) { + t2.b(t2.t(t2.f("blockHeader", c2, p2, 0))); + }); + c.pop(); + } + if (!t.s(t.f("blockHeader", c, p, 1), c, p, 1, 0, 0, "")) { + t.b(" "); + } + ; + t.b("
    "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-empty-diff"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b(""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(" File without changes"); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-file-path"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b(''); + t.b("\n" + i); + t.b(t.rp("'); + t.b(t.v(t.f("fileDiffName", c, p, 0))); + t.b(""); + t.b("\n" + i); + t.b(t.rp(""); + t.b("\n" + i); + t.b('"); + return t.fl(); +}, partials: { ""); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("lineNumber", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + if (t.s(t.f("prefix", c, p, 1), c, p, 0, 162, 238, "{{ }}")) { + t.rs(c, p, function(c2, p2, t2) { + t2.b(' '); + t2.b(t2.t(t2.f("prefix", c2, p2, 0))); + t2.b(""); + t2.b("\n" + i); + }); + c.pop(); + } + if (!t.s(t.f("prefix", c, p, 1), c, p, 1, 0, 0, "")) { + t.b('  '); + t.b("\n" + i); + } + ; + if (t.s(t.f("content", c, p, 1), c, p, 0, 371, 445, "{{ }}")) { + t.rs(c, p, function(c2, p2, t2) { + t2.b(' '); + t2.b(t2.t(t2.f("content", c2, p2, 0))); + t2.b(""); + t2.b("\n" + i); + }); + c.pop(); + } + if (!t.s(t.f("content", c, p, 1), c, p, 1, 0, 0, "")) { + t.b('
    '); + t.b("\n" + i); + } + ; + t.b("
    "); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b(""); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["generic-wrapper"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("content", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-added"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-changed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-deleted"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file-renamed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["icon-file"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('"); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["line-by-line-file-diff"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("filePath", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("diffs", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["line-by-line-numbers"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b(t.v(t.f("oldNumber", c, p, 0))); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b(t.v(t.f("newNumber", c, p, 0))); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["side-by-side-file-diff"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.f("filePath", c, p, 0))); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.d("diffs.left", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b('
    '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(' '); + t.b("\n" + i); + t.b(" "); + t.b(t.t(t.d("diffs.right", c, p, 0))); + t.b("\n" + i); + t.b(" "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + t.b("\n" + i); + t.b("
    "); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-added"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('ADDED'); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-changed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('CHANGED'); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-deleted"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('DELETED'); + return t.fl(); +}, partials: {}, subs: {} }); +defaultTemplates["tag-file-renamed"] = new Hogan2.Template({ code: function(c, p, i) { + var t = this; + t.b(i = i || ""); + t.b('RENAMED'); + return t.fl(); +}, partials: {}, subs: {} }); + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/hoganjs-utils.js +var HoganJsUtils = class { + constructor({ compiledTemplates = {}, rawTemplates = {} }) { + const compiledRawTemplates = Object.entries(rawTemplates).reduce((previousTemplates, [name, templateString]) => { + const compiledTemplate = Hogan3.compile(templateString, { asString: false }); + return Object.assign(Object.assign({}, previousTemplates), { [name]: compiledTemplate }); + }, {}); + this.preCompiledTemplates = Object.assign(Object.assign(Object.assign({}, defaultTemplates), compiledTemplates), compiledRawTemplates); + } + static compile(templateString) { + return Hogan3.compile(templateString, { asString: false }); + } + render(namespace, view, params, partials, indent2) { + const templateKey = this.templateKey(namespace, view); + try { + const template = this.preCompiledTemplates[templateKey]; + return template.render(params, partials, indent2); + } catch (e) { + throw new Error(`Could not find template to render '${templateKey}'`); + } + } + template(namespace, view) { + return this.preCompiledTemplates[this.templateKey(namespace, view)]; + } + templateKey(namespace, view) { + return `${namespace}-${view}`; + } +}; + +// node_modules/.pnpm/diff2html@3.4.41/node_modules/diff2html/lib-esm/diff2html.js +var defaultDiff2HtmlConfig = Object.assign(Object.assign(Object.assign({}, defaultLineByLineRendererConfig), defaultSideBySideRendererConfig), { outputFormat: OutputFormatType.LINE_BY_LINE, drawFileList: true }); +function html(diffInput, configuration = {}) { + const config = Object.assign(Object.assign({}, defaultDiff2HtmlConfig), configuration); + const diffJson = typeof diffInput === "string" ? parse(diffInput, config) : diffInput; + const hoganUtils = new HoganJsUtils(config); + const fileList = config.drawFileList ? render(diffJson, hoganUtils) : ""; + const diffOutput = config.outputFormat === "side-by-side" ? new SideBySideRenderer(hoganUtils, config).render(diffJson) : new LineByLineRenderer(hoganUtils, config).render(diffJson); + return fileList + diffOutput; +} + +// src/ui/diff/diffView.ts +var import_obsidian17 = require("obsidian"); +var DiffView = class extends import_obsidian17.ItemView { + constructor(leaf, plugin) { + super(leaf); + this.plugin = plugin; + this.gettingDiff = false; + this.gitRefreshBind = this.refresh.bind(this); + this.gitViewRefreshBind = this.refresh.bind(this); + this.parser = new DOMParser(); + this.navigation = true; + addEventListener("git-refresh", this.gitRefreshBind); + addEventListener("git-view-refresh", this.gitViewRefreshBind); + } + getViewType() { + return DIFF_VIEW_CONFIG.type; + } + getDisplayText() { + var _a2; + if (((_a2 = this.state) == null ? void 0 : _a2.file) != null) { + let fileName = this.state.file.split("/").last(); + if (fileName == null ? void 0 : fileName.endsWith(".md")) + fileName = fileName.slice(0, -3); + return DIFF_VIEW_CONFIG.name + ` (${fileName})`; + } + return DIFF_VIEW_CONFIG.name; + } + getIcon() { + return DIFF_VIEW_CONFIG.icon; + } + async setState(state, result) { + this.state = state; + if (import_obsidian17.Platform.isMobile) { + this.leaf.view.titleEl.textContent = this.getDisplayText(); + } + await this.refresh(); + } + getState() { + return this.state; + } + onClose() { + removeEventListener("git-refresh", this.gitRefreshBind); + removeEventListener("git-view-refresh", this.gitViewRefreshBind); + return super.onClose(); + } + onOpen() { + this.refresh(); + return super.onOpen(); + } + async refresh() { + var _a2; + if (((_a2 = this.state) == null ? void 0 : _a2.file) && !this.gettingDiff && this.plugin.gitManager) { + this.gettingDiff = true; + try { + let diff2 = await this.plugin.gitManager.getDiffString( + this.state.file, + this.state.staged, + this.state.hash + ); + this.contentEl.empty(); + if (!diff2) { + if (this.plugin.gitManager instanceof SimpleGit && await this.plugin.gitManager.isTracked( + this.state.file + )) { + diff2 = [ + `--- ${this.state.file}`, + `+++ ${this.state.file}`, + "" + ].join("\n"); + } else { + const content = await this.app.vault.adapter.read( + this.plugin.gitManager.getVaultPath(this.state.file) + ); + const header = `--- /dev/null ++++ ${this.state.file} +@@ -0,0 +1,${content.split("\n").length} @@`; + diff2 = [ + ...header.split("\n"), + ...content.split("\n").map((line) => `+${line}`) + ].join("\n"); + } + } + const diffEl = this.parser.parseFromString(html(diff2), "text/html").querySelector(".d2h-file-diff"); + this.contentEl.append(diffEl); + } finally { + this.gettingDiff = false; + } + } + } +}; + +// src/ui/history/historyView.ts +init_polyfill_buffer(); +var import_obsidian20 = require("obsidian"); + +// src/ui/history/historyView.svelte +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/index.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/animations.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/utils.js +init_polyfill_buffer(); +function noop() { +} +var identity = (x) => x; +function run(fn) { + return fn(); +} +function blank_object() { + return /* @__PURE__ */ Object.create(null); +} +function run_all(fns) { + fns.forEach(run); +} +function is_function(thing) { + return typeof thing === "function"; +} +function safe_not_equal(a, b) { + return a != a ? b == b : a !== b || a && typeof a === "object" || typeof a === "function"; +} +function is_empty(obj) { + return Object.keys(obj).length === 0; +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/environment.js +init_polyfill_buffer(); +var is_client = typeof window !== "undefined"; +var now = is_client ? () => window.performance.now() : () => Date.now(); +var raf = is_client ? (cb) => requestAnimationFrame(cb) : noop; + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/loop.js +init_polyfill_buffer(); +var tasks = /* @__PURE__ */ new Set(); +function run_tasks(now2) { + tasks.forEach((task) => { + if (!task.c(now2)) { + tasks.delete(task); + task.f(); + } + }); + if (tasks.size !== 0) + raf(run_tasks); +} +function loop(callback) { + let task; + if (tasks.size === 0) + raf(run_tasks); + return { + promise: new Promise((fulfill) => { + tasks.add(task = { c: callback, f: fulfill }); + }), + abort() { + tasks.delete(task); + } + }; +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/style_manager.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/dom.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/ResizeObserverSingleton.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/globals.js +init_polyfill_buffer(); +var globals = typeof window !== "undefined" ? window : typeof globalThis !== "undefined" ? globalThis : ( + // @ts-ignore Node typings have this + global +); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/ResizeObserverSingleton.js +var ResizeObserverSingleton = class _ResizeObserverSingleton { + /** @param {ResizeObserverOptions} options */ + constructor(options) { + /** + * @private + * @readonly + * @type {WeakMap} + */ + __publicField(this, "_listeners", "WeakMap" in globals ? /* @__PURE__ */ new WeakMap() : void 0); + /** + * @private + * @type {ResizeObserver} + */ + __publicField(this, "_observer"); + /** @type {ResizeObserverOptions} */ + __publicField(this, "options"); + this.options = options; + } + /** + * @param {Element} element + * @param {import('./private.js').Listener} listener + * @returns {() => void} + */ + observe(element2, listener) { + this._listeners.set(element2, listener); + this._getObserver().observe(element2, this.options); + return () => { + this._listeners.delete(element2); + this._observer.unobserve(element2); + }; + } + /** + * @private + */ + _getObserver() { + var _a2; + return (_a2 = this._observer) != null ? _a2 : this._observer = new ResizeObserver((entries) => { + var _a3; + for (const entry of entries) { + _ResizeObserverSingleton.entries.set(entry.target, entry); + (_a3 = this._listeners.get(entry.target)) == null ? void 0 : _a3(entry); + } + }); + } +}; +ResizeObserverSingleton.entries = "WeakMap" in globals ? /* @__PURE__ */ new WeakMap() : void 0; + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/dom.js +var is_hydrating = false; +function start_hydrating() { + is_hydrating = true; +} +function end_hydrating() { + is_hydrating = false; +} +function append2(target, node) { + target.appendChild(node); +} +function append_styles(target, style_sheet_id, styles) { + const append_styles_to = get_root_for_style(target); + if (!append_styles_to.getElementById(style_sheet_id)) { + const style = element("style"); + style.id = style_sheet_id; + style.textContent = styles; + append_stylesheet(append_styles_to, style); + } +} +function get_root_for_style(node) { + if (!node) + return document; + const root2 = node.getRootNode ? node.getRootNode() : node.ownerDocument; + if (root2 && /** @type {ShadowRoot} */ + root2.host) { + return ( + /** @type {ShadowRoot} */ + root2 + ); + } + return node.ownerDocument; +} +function append_empty_stylesheet(node) { + const style_element = element("style"); + style_element.textContent = "/* empty */"; + append_stylesheet(get_root_for_style(node), style_element); + return style_element.sheet; +} +function append_stylesheet(node, style) { + append2( + /** @type {Document} */ + node.head || node, + style + ); + return style.sheet; +} +function insert(target, node, anchor) { + target.insertBefore(node, anchor || null); +} +function detach(node) { + if (node.parentNode) { + node.parentNode.removeChild(node); + } +} +function destroy_each(iterations, detaching) { + for (let i = 0; i < iterations.length; i += 1) { + if (iterations[i]) + iterations[i].d(detaching); + } +} +function element(name) { + return document.createElement(name); +} +function text(data) { + return document.createTextNode(data); +} +function space() { + return text(" "); +} +function empty() { + return text(""); +} +function listen(node, event, handler, options) { + node.addEventListener(event, handler, options); + return () => node.removeEventListener(event, handler, options); +} +function stop_propagation(fn) { + return function(event) { + event.stopPropagation(); + return fn.call(this, event); + }; +} +function attr(node, attribute, value) { + if (value == null) + node.removeAttribute(attribute); + else if (node.getAttribute(attribute) !== value) + node.setAttribute(attribute, value); +} +function children(element2) { + return Array.from(element2.childNodes); +} +function set_data(text2, data) { + data = "" + data; + if (text2.data === data) + return; + text2.data = /** @type {string} */ + data; +} +function set_input_value(input, value) { + input.value = value == null ? "" : value; +} +function set_style(node, key2, value, important) { + if (value == null) { + node.style.removeProperty(key2); + } else { + node.style.setProperty(key2, value, important ? "important" : ""); + } +} +function toggle_class(element2, name, toggle) { + element2.classList.toggle(name, !!toggle); +} +function custom_event(type, detail, { bubbles = false, cancelable = false } = {}) { + return new CustomEvent(type, { detail, bubbles, cancelable }); +} +function get_custom_elements_slots(element2) { + const result = {}; + element2.childNodes.forEach( + /** @param {Element} node */ + (node) => { + result[node.slot || "default"] = true; + } + ); + return result; +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/style_manager.js +var managed_styles = /* @__PURE__ */ new Map(); +var active = 0; +function hash(str) { + let hash2 = 5381; + let i = str.length; + while (i--) + hash2 = (hash2 << 5) - hash2 ^ str.charCodeAt(i); + return hash2 >>> 0; +} +function create_style_information(doc, node) { + const info = { stylesheet: append_empty_stylesheet(node), rules: {} }; + managed_styles.set(doc, info); + return info; +} +function create_rule(node, a, b, duration, delay2, ease, fn, uid = 0) { + const step = 16.666 / duration; + let keyframes = "{\n"; + for (let p = 0; p <= 1; p += step) { + const t = a + (b - a) * ease(p); + keyframes += p * 100 + `%{${fn(t, 1 - t)}} +`; + } + const rule = keyframes + `100% {${fn(b, 1 - b)}} +}`; + const name = `__svelte_${hash(rule)}_${uid}`; + const doc = get_root_for_style(node); + const { stylesheet, rules } = managed_styles.get(doc) || create_style_information(doc, node); + if (!rules[name]) { + rules[name] = true; + stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length); + } + const animation = node.style.animation || ""; + node.style.animation = `${animation ? `${animation}, ` : ""}${name} ${duration}ms linear ${delay2}ms 1 both`; + active += 1; + return name; +} +function delete_rule(node, name) { + const previous = (node.style.animation || "").split(", "); + const next = previous.filter( + name ? (anim) => anim.indexOf(name) < 0 : (anim) => anim.indexOf("__svelte") === -1 + // remove all Svelte animations + ); + const deleted = previous.length - next.length; + if (deleted) { + node.style.animation = next.join(", "); + active -= deleted; + if (!active) + clear_rules(); + } +} +function clear_rules() { + raf(() => { + if (active) + return; + managed_styles.forEach((info) => { + const { ownerNode } = info.stylesheet; + if (ownerNode) + detach(ownerNode); + }); + managed_styles.clear(); + }); +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/await_block.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/transitions.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/scheduler.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/lifecycle.js +init_polyfill_buffer(); +var current_component; +function set_current_component(component) { + current_component = component; +} +function get_current_component() { + if (!current_component) + throw new Error("Function called outside component initialization"); + return current_component; +} +function onDestroy(fn) { + get_current_component().$$.on_destroy.push(fn); +} +function bubble(component, event) { + const callbacks = component.$$.callbacks[event.type]; + if (callbacks) { + callbacks.slice().forEach((fn) => fn.call(this, event)); + } +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/scheduler.js +var dirty_components = []; +var binding_callbacks = []; +var render_callbacks = []; +var flush_callbacks = []; +var resolved_promise = /* @__PURE__ */ Promise.resolve(); +var update_scheduled = false; +function schedule_update() { + if (!update_scheduled) { + update_scheduled = true; + resolved_promise.then(flush); + } +} +function add_render_callback(fn) { + render_callbacks.push(fn); +} +var seen_callbacks = /* @__PURE__ */ new Set(); +var flushidx = 0; +function flush() { + if (flushidx !== 0) { + return; + } + const saved_component = current_component; + do { + try { + while (flushidx < dirty_components.length) { + const component = dirty_components[flushidx]; + flushidx++; + set_current_component(component); + update(component.$$); + } + } catch (e) { + dirty_components.length = 0; + flushidx = 0; + throw e; + } + set_current_component(null); + dirty_components.length = 0; + flushidx = 0; + while (binding_callbacks.length) + binding_callbacks.pop()(); + for (let i = 0; i < render_callbacks.length; i += 1) { + const callback = render_callbacks[i]; + if (!seen_callbacks.has(callback)) { + seen_callbacks.add(callback); + callback(); + } + } + render_callbacks.length = 0; + } while (dirty_components.length); + while (flush_callbacks.length) { + flush_callbacks.pop()(); + } + update_scheduled = false; + seen_callbacks.clear(); + set_current_component(saved_component); +} +function update($$) { + if ($$.fragment !== null) { + $$.update(); + run_all($$.before_update); + const dirty = $$.dirty; + $$.dirty = [-1]; + $$.fragment && $$.fragment.p($$.ctx, dirty); + $$.after_update.forEach(add_render_callback); + } +} +function flush_render_callbacks(fns) { + const filtered = []; + const targets = []; + render_callbacks.forEach((c) => fns.indexOf(c) === -1 ? filtered.push(c) : targets.push(c)); + targets.forEach((c) => c()); + render_callbacks = filtered; +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/transitions.js +var promise; +function wait() { + if (!promise) { + promise = Promise.resolve(); + promise.then(() => { + promise = null; + }); + } + return promise; +} +function dispatch(node, direction, kind) { + node.dispatchEvent(custom_event(`${direction ? "intro" : "outro"}${kind}`)); +} +var outroing = /* @__PURE__ */ new Set(); +var outros; +function group_outros() { + outros = { + r: 0, + c: [], + p: outros + // parent group + }; +} +function check_outros() { + if (!outros.r) { + run_all(outros.c); + } + outros = outros.p; +} +function transition_in(block, local) { + if (block && block.i) { + outroing.delete(block); + block.i(local); + } +} +function transition_out(block, local, detach2, callback) { + if (block && block.o) { + if (outroing.has(block)) + return; + outroing.add(block); + outros.c.push(() => { + outroing.delete(block); + if (callback) { + if (detach2) + block.d(1); + callback(); + } + }); + block.o(local); + } else if (callback) { + callback(); + } +} +var null_transition = { duration: 0 }; +function create_bidirectional_transition(node, fn, params, intro) { + const options = { direction: "both" }; + let config = fn(node, params, options); + let t = intro ? 0 : 1; + let running_program = null; + let pending_program = null; + let animation_name = null; + let original_inert_value; + function clear_animation() { + if (animation_name) + delete_rule(node, animation_name); + } + function init3(program, duration) { + const d = ( + /** @type {Program['d']} */ + program.b - t + ); + duration *= Math.abs(d); + return { + a: t, + b: program.b, + d, + duration, + start: program.start, + end: program.start + duration, + group: program.group + }; + } + function go(b) { + const { + delay: delay2 = 0, + duration = 300, + easing = identity, + tick: tick2 = noop, + css + } = config || null_transition; + const program = { + start: now() + delay2, + b + }; + if (!b) { + program.group = outros; + outros.r += 1; + } + if ("inert" in node) { + if (b) { + if (original_inert_value !== void 0) { + node.inert = original_inert_value; + } + } else { + original_inert_value = /** @type {HTMLElement} */ + node.inert; + node.inert = true; + } + } + if (running_program || pending_program) { + pending_program = program; + } else { + if (css) { + clear_animation(); + animation_name = create_rule(node, t, b, duration, delay2, easing, css); + } + if (b) + tick2(0, 1); + running_program = init3(program, duration); + add_render_callback(() => dispatch(node, b, "start")); + loop((now2) => { + if (pending_program && now2 > pending_program.start) { + running_program = init3(pending_program, duration); + pending_program = null; + dispatch(node, running_program.b, "start"); + if (css) { + clear_animation(); + animation_name = create_rule( + node, + t, + running_program.b, + running_program.duration, + 0, + easing, + config.css + ); + } + } + if (running_program) { + if (now2 >= running_program.end) { + tick2(t = running_program.b, 1 - t); + dispatch(node, running_program.b, "end"); + if (!pending_program) { + if (running_program.b) { + clear_animation(); + } else { + if (!--running_program.group.r) + run_all(running_program.group.c); + } + } + running_program = null; + } else if (now2 >= running_program.start) { + const p = now2 - running_program.start; + t = running_program.a + running_program.d * easing(p / running_program.duration); + tick2(t, 1 - t); + } + } + return !!(running_program || pending_program); + }); + } + } + return { + run(b) { + if (is_function(config)) { + wait().then(() => { + const opts = { direction: b ? "in" : "out" }; + config = config(opts); + go(b); + }); + } else { + go(b); + } + }, + end() { + clear_animation(); + running_program = pending_program = null; + } + }; +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/each.js +init_polyfill_buffer(); +function ensure_array_like(array_like_or_iterator) { + return (array_like_or_iterator == null ? void 0 : array_like_or_iterator.length) !== void 0 ? array_like_or_iterator : Array.from(array_like_or_iterator); +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/spread.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/ssr.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/shared/boolean_attributes.js +init_polyfill_buffer(); +var _boolean_attributes = ( + /** @type {const} */ + [ + "allowfullscreen", + "allowpaymentrequest", + "async", + "autofocus", + "autoplay", + "checked", + "controls", + "default", + "defer", + "disabled", + "formnovalidate", + "hidden", + "inert", + "ismap", + "loop", + "multiple", + "muted", + "nomodule", + "novalidate", + "open", + "playsinline", + "readonly", + "required", + "reversed", + "selected" + ] +); +var boolean_attributes = /* @__PURE__ */ new Set([..._boolean_attributes]); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/shared/utils/names.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/Component.js +init_polyfill_buffer(); +function create_component(block) { + block && block.c(); +} +function mount_component(component, target, anchor) { + const { fragment, after_update } = component.$$; + fragment && fragment.m(target, anchor); + add_render_callback(() => { + const new_on_destroy = component.$$.on_mount.map(run).filter(is_function); + if (component.$$.on_destroy) { + component.$$.on_destroy.push(...new_on_destroy); + } else { + run_all(new_on_destroy); + } + component.$$.on_mount = []; + }); + after_update.forEach(add_render_callback); +} +function destroy_component(component, detaching) { + const $$ = component.$$; + if ($$.fragment !== null) { + flush_render_callbacks($$.after_update); + run_all($$.on_destroy); + $$.fragment && $$.fragment.d(detaching); + $$.on_destroy = $$.fragment = null; + $$.ctx = []; + } +} +function make_dirty(component, i) { + if (component.$$.dirty[0] === -1) { + dirty_components.push(component); + schedule_update(); + component.$$.dirty.fill(0); + } + component.$$.dirty[i / 31 | 0] |= 1 << i % 31; +} +function init2(component, options, instance10, create_fragment10, not_equal, props, append_styles2, dirty = [-1]) { + const parent_component = current_component; + set_current_component(component); + const $$ = component.$$ = { + fragment: null, + ctx: [], + // state + props, + update: noop, + not_equal, + bound: blank_object(), + // lifecycle + on_mount: [], + on_destroy: [], + on_disconnect: [], + before_update: [], + after_update: [], + context: new Map(options.context || (parent_component ? parent_component.$$.context : [])), + // everything else + callbacks: blank_object(), + dirty, + skip_bound: false, + root: options.target || parent_component.$$.root + }; + append_styles2 && append_styles2($$.root); + let ready = false; + $$.ctx = instance10 ? instance10(component, options.props || {}, (i, ret, ...rest) => { + const value = rest.length ? rest[0] : ret; + if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) { + if (!$$.skip_bound && $$.bound[i]) + $$.bound[i](value); + if (ready) + make_dirty(component, i); + } + return ret; + }) : []; + $$.update(); + ready = true; + run_all($$.before_update); + $$.fragment = create_fragment10 ? create_fragment10($$.ctx) : false; + if (options.target) { + if (options.hydrate) { + start_hydrating(); + const nodes = children(options.target); + $$.fragment && $$.fragment.l(nodes); + nodes.forEach(detach); + } else { + $$.fragment && $$.fragment.c(); + } + if (options.intro) + transition_in(component.$$.fragment); + mount_component(component, options.target, options.anchor); + end_hydrating(); + flush(); + } + set_current_component(parent_component); +} +var SvelteElement; +if (typeof HTMLElement === "function") { + SvelteElement = class extends HTMLElement { + constructor($$componentCtor, $$slots, use_shadow_dom) { + super(); + /** The Svelte component constructor */ + __publicField(this, "$$ctor"); + /** Slots */ + __publicField(this, "$$s"); + /** The Svelte component instance */ + __publicField(this, "$$c"); + /** Whether or not the custom element is connected */ + __publicField(this, "$$cn", false); + /** Component props data */ + __publicField(this, "$$d", {}); + /** `true` if currently in the process of reflecting component props back to attributes */ + __publicField(this, "$$r", false); + /** @type {Record} Props definition (name, reflected, type etc) */ + __publicField(this, "$$p_d", {}); + /** @type {Record} Event listeners */ + __publicField(this, "$$l", {}); + /** @type {Map} Event listener unsubscribe functions */ + __publicField(this, "$$l_u", /* @__PURE__ */ new Map()); + this.$$ctor = $$componentCtor; + this.$$s = $$slots; + if (use_shadow_dom) { + this.attachShadow({ mode: "open" }); + } + } + addEventListener(type, listener, options) { + this.$$l[type] = this.$$l[type] || []; + this.$$l[type].push(listener); + if (this.$$c) { + const unsub = this.$$c.$on(type, listener); + this.$$l_u.set(listener, unsub); + } + super.addEventListener(type, listener, options); + } + removeEventListener(type, listener, options) { + super.removeEventListener(type, listener, options); + if (this.$$c) { + const unsub = this.$$l_u.get(listener); + if (unsub) { + unsub(); + this.$$l_u.delete(listener); + } + } + } + async connectedCallback() { + this.$$cn = true; + if (!this.$$c) { + let create_slot = function(name) { + return () => { + let node; + const obj = { + c: function create() { + node = element("slot"); + if (name !== "default") { + attr(node, "name", name); + } + }, + /** + * @param {HTMLElement} target + * @param {HTMLElement} [anchor] + */ + m: function mount(target, anchor) { + insert(target, node, anchor); + }, + d: function destroy(detaching) { + if (detaching) { + detach(node); + } + } + }; + return obj; + }; + }; + await Promise.resolve(); + if (!this.$$cn) { + return; + } + const $$slots = {}; + const existing_slots = get_custom_elements_slots(this); + for (const name of this.$$s) { + if (name in existing_slots) { + $$slots[name] = [create_slot(name)]; + } + } + for (const attribute of this.attributes) { + const name = this.$$g_p(attribute.name); + if (!(name in this.$$d)) { + this.$$d[name] = get_custom_element_value(name, attribute.value, this.$$p_d, "toProp"); + } + } + this.$$c = new this.$$ctor({ + target: this.shadowRoot || this, + props: { + ...this.$$d, + $$slots, + $$scope: { + ctx: [] + } + } + }); + const reflect_attributes = () => { + this.$$r = true; + for (const key2 in this.$$p_d) { + this.$$d[key2] = this.$$c.$$.ctx[this.$$c.$$.props[key2]]; + if (this.$$p_d[key2].reflect) { + const attribute_value = get_custom_element_value( + key2, + this.$$d[key2], + this.$$p_d, + "toAttribute" + ); + if (attribute_value == null) { + this.removeAttribute(key2); + } else { + this.setAttribute(this.$$p_d[key2].attribute || key2, attribute_value); + } + } + } + this.$$r = false; + }; + this.$$c.$$.after_update.push(reflect_attributes); + reflect_attributes(); + for (const type in this.$$l) { + for (const listener of this.$$l[type]) { + const unsub = this.$$c.$on(type, listener); + this.$$l_u.set(listener, unsub); + } + } + this.$$l = {}; + } + } + // We don't need this when working within Svelte code, but for compatibility of people using this outside of Svelte + // and setting attributes through setAttribute etc, this is helpful + attributeChangedCallback(attr2, _oldValue, newValue) { + var _a2; + if (this.$$r) + return; + attr2 = this.$$g_p(attr2); + this.$$d[attr2] = get_custom_element_value(attr2, newValue, this.$$p_d, "toProp"); + (_a2 = this.$$c) == null ? void 0 : _a2.$set({ [attr2]: this.$$d[attr2] }); + } + disconnectedCallback() { + this.$$cn = false; + Promise.resolve().then(() => { + if (!this.$$cn) { + this.$$c.$destroy(); + this.$$c = void 0; + } + }); + } + $$g_p(attribute_name) { + return Object.keys(this.$$p_d).find( + (key2) => this.$$p_d[key2].attribute === attribute_name || !this.$$p_d[key2].attribute && key2.toLowerCase() === attribute_name + ) || attribute_name; + } + }; +} +function get_custom_element_value(prop, value, props_definition, transform) { + var _a2; + const type = (_a2 = props_definition[prop]) == null ? void 0 : _a2.type; + value = type === "Boolean" && typeof value !== "boolean" ? value != null : value; + if (!transform || !props_definition[prop]) { + return value; + } else if (transform === "toAttribute") { + switch (type) { + case "Object": + case "Array": + return value == null ? null : JSON.stringify(value); + case "Boolean": + return value ? "" : null; + case "Number": + return value == null ? null : value; + default: + return value; + } + } else { + switch (type) { + case "Object": + case "Array": + return value && JSON.parse(value); + case "Boolean": + return value; + case "Number": + return value != null ? +value : value; + default: + return value; + } + } +} +var SvelteComponent = class { + constructor() { + /** + * ### PRIVATE API + * + * Do not use, may change at any time + * + * @type {any} + */ + __publicField(this, "$$"); + /** + * ### PRIVATE API + * + * Do not use, may change at any time + * + * @type {any} + */ + __publicField(this, "$$set"); + } + /** @returns {void} */ + $destroy() { + destroy_component(this, 1); + this.$destroy = noop; + } + /** + * @template {Extract} K + * @param {K} type + * @param {((e: Events[K]) => void) | null | undefined} callback + * @returns {() => void} + */ + $on(type, callback) { + if (!is_function(callback)) { + return noop; + } + const callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []); + callbacks.push(callback); + return () => { + const index2 = callbacks.indexOf(callback); + if (index2 !== -1) + callbacks.splice(index2, 1); + }; + } + /** + * @param {Partial} props + * @returns {void} + */ + $set(props) { + if (this.$$set && !is_empty(props)) { + this.$$.skip_bound = true; + this.$$set(props); + this.$$.skip_bound = false; + } + } +}; + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/dev.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/shared/version.js +init_polyfill_buffer(); +var PUBLIC_VERSION = "4"; + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/internal/disclose-version/index.js +init_polyfill_buffer(); +if (typeof window !== "undefined") + (window.__svelte || (window.__svelte = { v: /* @__PURE__ */ new Set() })).v.add(PUBLIC_VERSION); + +// node_modules/.pnpm/tslib@2.6.2/node_modules/tslib/tslib.es6.mjs +init_polyfill_buffer(); +function __awaiter(thisArg, _arguments, P, generator) { + function adopt(value) { + return value instanceof P ? value : new P(function(resolve) { + resolve(value); + }); + } + return new (P || (P = Promise))(function(resolve, reject) { + function fulfilled(value) { + try { + step(generator.next(value)); + } catch (e) { + reject(e); + } + } + function rejected(value) { + try { + step(generator["throw"](value)); + } catch (e) { + reject(e); + } + } + function step(result) { + result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); + } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +} + +// src/ui/history/historyView.svelte +var import_obsidian19 = require("obsidian"); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/index.js +init_polyfill_buffer(); + +// src/ui/history/components/logComponent.svelte +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/transition/index.js +init_polyfill_buffer(); + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/easing/index.js +init_polyfill_buffer(); +function cubicOut(t) { + const f = t - 1; + return f * f * f + 1; +} + +// node_modules/.pnpm/svelte@4.2.0/node_modules/svelte/src/runtime/transition/index.js +function slide(node, { delay: delay2 = 0, duration = 400, easing = cubicOut, axis = "y" } = {}) { + const style = getComputedStyle(node); + const opacity = +style.opacity; + const primary_property = axis === "y" ? "height" : "width"; + const primary_property_value = parseFloat(style[primary_property]); + const secondary_properties = axis === "y" ? ["top", "bottom"] : ["left", "right"]; + const capitalized_secondary_properties = secondary_properties.map( + (e) => `${e[0].toUpperCase()}${e.slice(1)}` + ); + const padding_start_value = parseFloat(style[`padding${capitalized_secondary_properties[0]}`]); + const padding_end_value = parseFloat(style[`padding${capitalized_secondary_properties[1]}`]); + const margin_start_value = parseFloat(style[`margin${capitalized_secondary_properties[0]}`]); + const margin_end_value = parseFloat(style[`margin${capitalized_secondary_properties[1]}`]); + const border_width_start_value = parseFloat( + style[`border${capitalized_secondary_properties[0]}Width`] + ); + const border_width_end_value = parseFloat( + style[`border${capitalized_secondary_properties[1]}Width`] + ); + return { + delay: delay2, + duration, + easing, + css: (t) => `overflow: hidden;opacity: ${Math.min(t * 20, 1) * opacity};${primary_property}: ${t * primary_property_value}px;padding-${secondary_properties[0]}: ${t * padding_start_value}px;padding-${secondary_properties[1]}: ${t * padding_end_value}px;margin-${secondary_properties[0]}: ${t * margin_start_value}px;margin-${secondary_properties[1]}: ${t * margin_end_value}px;border-${secondary_properties[0]}-width: ${t * border_width_start_value}px;border-${secondary_properties[1]}-width: ${t * border_width_end_value}px;` + }; +} + +// src/ui/history/components/logFileComponent.svelte +init_polyfill_buffer(); +var import_obsidian18 = require("obsidian"); +function add_css(target) { + append_styles(target, "svelte-1wbh8tp", "main.svelte-1wbh8tp .nav-file-title.svelte-1wbh8tp{align-items:center}"); +} +function create_if_block(ctx) { + let div; + let mounted; + let dispose; + return { + c() { + div = element("div"); + attr(div, "data-icon", "go-to-file"); + attr(div, "aria-label", "Open File"); + attr(div, "class", "clickable-icon"); + }, + m(target, anchor) { + insert(target, div, anchor); + ctx[7](div); + if (!mounted) { + dispose = [ + listen(div, "auxclick", stop_propagation( + /*open*/ + ctx[4] + )), + listen(div, "click", stop_propagation( + /*open*/ + ctx[4] + )) + ]; + mounted = true; + } + }, + p: noop, + d(detaching) { + if (detaching) { + detach(div); + } + ctx[7](null); + mounted = false; + run_all(dispose); + } + }; +} +function create_fragment(ctx) { + let main; + let div3; + let div0; + let t0_value = getDisplayPath( + /*diff*/ + ctx[0].vault_path + ) + ""; + let t0; + let t1; + let div2; + let div1; + let show_if = ( + /*view*/ + ctx[1].app.vault.getAbstractFileByPath( + /*diff*/ + ctx[0].vault_path + ) + ); + let t2; + let span; + let t3_value = ( + /*diff*/ + ctx[0].status + "" + ); + let t3; + let span_data_type_value; + let div3_data_path_value; + let div3_aria_label_value; + let mounted; + let dispose; + let if_block = show_if && create_if_block(ctx); + return { + c() { + var _a2, _b; + main = element("main"); + div3 = element("div"); + div0 = element("div"); + t0 = text(t0_value); + t1 = space(); + div2 = element("div"); + div1 = element("div"); + if (if_block) + if_block.c(); + t2 = space(); + span = element("span"); + t3 = text(t3_value); + attr(div0, "class", "tree-item-inner nav-file-title-content"); + attr(div1, "class", "buttons"); + attr(span, "class", "type"); + attr(span, "data-type", span_data_type_value = /*diff*/ + ctx[0].status); + attr(div2, "class", "git-tools"); + attr(div3, "class", "tree-item-self is-clickable nav-file-title svelte-1wbh8tp"); + attr(div3, "data-path", div3_data_path_value = /*diff*/ + ctx[0].vault_path); + attr( + div3, + "aria-label-position", + /*side*/ + ctx[3] + ); + attr(div3, "aria-label", div3_aria_label_value = /*diff*/ + ctx[0].vault_path); + toggle_class( + div3, + "is-active", + /*view*/ + ((_a2 = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _a2.file) == /*diff*/ + ctx[0].vault_path && /*view*/ + ((_b = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _b.hash) + ); + attr(main, "class", "tree-item nav-file svelte-1wbh8tp"); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div3); + append2(div3, div0); + append2(div0, t0); + append2(div3, t1); + append2(div3, div2); + append2(div2, div1); + if (if_block) + if_block.m(div1, null); + append2(div2, t2); + append2(div2, span); + append2(span, t3); + if (!mounted) { + dispose = [ + listen(main, "click", stop_propagation( + /*showDiff*/ + ctx[5] + )), + listen(main, "auxclick", stop_propagation( + /*showDiff*/ + ctx[5] + )), + listen( + main, + "focus", + /*focus_handler*/ + ctx[6] + ) + ]; + mounted = true; + } + }, + p(ctx2, [dirty]) { + var _a2, _b; + if (dirty & /*diff*/ + 1 && t0_value !== (t0_value = getDisplayPath( + /*diff*/ + ctx2[0].vault_path + ) + "")) + set_data(t0, t0_value); + if (dirty & /*view, diff*/ + 3) + show_if = /*view*/ + ctx2[1].app.vault.getAbstractFileByPath( + /*diff*/ + ctx2[0].vault_path + ); + if (show_if) { + if (if_block) { + if_block.p(ctx2, dirty); + } else { + if_block = create_if_block(ctx2); + if_block.c(); + if_block.m(div1, null); + } + } else if (if_block) { + if_block.d(1); + if_block = null; + } + if (dirty & /*diff*/ + 1 && t3_value !== (t3_value = /*diff*/ + ctx2[0].status + "")) + set_data(t3, t3_value); + if (dirty & /*diff*/ + 1 && span_data_type_value !== (span_data_type_value = /*diff*/ + ctx2[0].status)) { + attr(span, "data-type", span_data_type_value); + } + if (dirty & /*diff*/ + 1 && div3_data_path_value !== (div3_data_path_value = /*diff*/ + ctx2[0].vault_path)) { + attr(div3, "data-path", div3_data_path_value); + } + if (dirty & /*side*/ + 8) { + attr( + div3, + "aria-label-position", + /*side*/ + ctx2[3] + ); + } + if (dirty & /*diff*/ + 1 && div3_aria_label_value !== (div3_aria_label_value = /*diff*/ + ctx2[0].vault_path)) { + attr(div3, "aria-label", div3_aria_label_value); + } + if (dirty & /*view, diff*/ + 3) { + toggle_class( + div3, + "is-active", + /*view*/ + ((_a2 = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _a2.file) == /*diff*/ + ctx2[0].vault_path && /*view*/ + ((_b = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _b.hash) + ); + } + }, + i: noop, + o: noop, + d(detaching) { + if (detaching) { + detach(main); + } + if (if_block) + if_block.d(); + mounted = false; + run_all(dispose); + } + }; +} +function instance($$self, $$props, $$invalidate) { + let side; + let { diff: diff2 } = $$props; + let { view } = $$props; + let buttons = []; + window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian18.setIcon)(b, b.getAttr("data-icon"))), 0); + function open(event) { + var _a2; + const file = view.app.vault.getAbstractFileByPath(diff2.vault_path); + if (file instanceof import_obsidian18.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); + } + } + function showDiff(event) { + var _a2; + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.setViewState({ + type: DIFF_VIEW_CONFIG.type, + active: true, + state: { + file: diff2.path, + staged: false, + hash: diff2.hash + } + }); + } + function focus_handler(event) { + bubble.call(this, $$self, event); + } + function div_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[0] = $$value; + $$invalidate(2, buttons); + }); + } + $$self.$$set = ($$props2) => { + if ("diff" in $$props2) + $$invalidate(0, diff2 = $$props2.diff); + if ("view" in $$props2) + $$invalidate(1, view = $$props2.view); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*view*/ + 2) { + $: + $$invalidate(3, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [diff2, view, buttons, side, open, showDiff, focus_handler, div_binding]; +} +var LogFileComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance, create_fragment, safe_not_equal, { diff: 0, view: 1 }, add_css); + } +}; +var logFileComponent_default = LogFileComponent; + +// src/ui/history/components/logTreeComponent.svelte +init_polyfill_buffer(); +function add_css2(target) { + append_styles(target, "svelte-1lnl15d", "main.svelte-1lnl15d .nav-folder-title-content.svelte-1lnl15d{display:flex;align-items:center}"); +} +function get_each_context(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[8] = list[i]; + return child_ctx; +} +function create_else_block(ctx) { + let div4; + let div3; + let div0; + let t0; + let div1; + let t1; + let div2; + let t2_value = ( + /*entity*/ + ctx[8].title + "" + ); + let t2; + let div3_aria_label_value; + let t3; + let t4; + let current; + let mounted; + let dispose; + function click_handler() { + return ( + /*click_handler*/ + ctx[7]( + /*entity*/ + ctx[8] + ) + ); + } + let if_block = !/*closed*/ + ctx[4][ + /*entity*/ + ctx[8].title + ] && create_if_block_1(ctx); + return { + c() { + div4 = element("div"); + div3 = element("div"); + div0 = element("div"); + t0 = space(); + div1 = element("div"); + div1.innerHTML = ``; + t1 = space(); + div2 = element("div"); + t2 = text(t2_value); + t3 = space(); + if (if_block) + if_block.c(); + t4 = space(); + attr(div0, "data-icon", "folder"); + set_style(div0, "padding-right", "5px"); + set_style(div0, "display", "flex"); + attr(div1, "class", "tree-item-icon nav-folder-collapse-indicator collapse-icon"); + toggle_class( + div1, + "is-collapsed", + /*closed*/ + ctx[4][ + /*entity*/ + ctx[8].title + ] + ); + attr(div2, "class", "tree-item-inner nav-folder-title-content svelte-1lnl15d"); + attr(div3, "class", "tree-item-self is-clickable nav-folder-title"); + attr( + div3, + "aria-label-position", + /*side*/ + ctx[5] + ); + attr(div3, "aria-label", div3_aria_label_value = /*entity*/ + ctx[8].vaultPath); + attr(div4, "class", "tree-item nav-folder"); + toggle_class( + div4, + "is-collapsed", + /*closed*/ + ctx[4][ + /*entity*/ + ctx[8].title + ] + ); + }, + m(target, anchor) { + insert(target, div4, anchor); + append2(div4, div3); + append2(div3, div0); + append2(div3, t0); + append2(div3, div1); + append2(div3, t1); + append2(div3, div2); + append2(div2, t2); + append2(div4, t3); + if (if_block) + if_block.m(div4, null); + append2(div4, t4); + current = true; + if (!mounted) { + dispose = listen(div3, "click", click_handler); + mounted = true; + } + }, + p(new_ctx, dirty) { + ctx = new_ctx; + if (!current || dirty & /*closed, hierarchy*/ + 17) { + toggle_class( + div1, + "is-collapsed", + /*closed*/ + ctx[4][ + /*entity*/ + ctx[8].title + ] + ); + } + if ((!current || dirty & /*hierarchy*/ + 1) && t2_value !== (t2_value = /*entity*/ + ctx[8].title + "")) + set_data(t2, t2_value); + if (!current || dirty & /*side*/ + 32) { + attr( + div3, + "aria-label-position", + /*side*/ + ctx[5] + ); + } + if (!current || dirty & /*hierarchy*/ + 1 && div3_aria_label_value !== (div3_aria_label_value = /*entity*/ + ctx[8].vaultPath)) { + attr(div3, "aria-label", div3_aria_label_value); + } + if (!/*closed*/ + ctx[4][ + /*entity*/ + ctx[8].title + ]) { + if (if_block) { + if_block.p(ctx, dirty); + if (dirty & /*closed, hierarchy*/ + 17) { + transition_in(if_block, 1); + } + } else { + if_block = create_if_block_1(ctx); + if_block.c(); + transition_in(if_block, 1); + if_block.m(div4, t4); + } + } else if (if_block) { + group_outros(); + transition_out(if_block, 1, 1, () => { + if_block = null; + }); + check_outros(); + } + if (!current || dirty & /*closed, hierarchy*/ + 17) { + toggle_class( + div4, + "is-collapsed", + /*closed*/ + ctx[4][ + /*entity*/ + ctx[8].title + ] + ); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + current = true; + }, + o(local) { + transition_out(if_block); + current = false; + }, + d(detaching) { + if (detaching) { + detach(div4); + } + if (if_block) + if_block.d(); + mounted = false; + dispose(); + } + }; +} +function create_if_block2(ctx) { + let div; + let logfilecomponent; + let t; + let current; + logfilecomponent = new logFileComponent_default({ + props: { + diff: ( + /*entity*/ + ctx[8].data + ), + view: ( + /*view*/ + ctx[2] + ) + } + }); + return { + c() { + div = element("div"); + create_component(logfilecomponent.$$.fragment); + t = space(); + }, + m(target, anchor) { + insert(target, div, anchor); + mount_component(logfilecomponent, div, null); + append2(div, t); + current = true; + }, + p(ctx2, dirty) { + const logfilecomponent_changes = {}; + if (dirty & /*hierarchy*/ + 1) + logfilecomponent_changes.diff = /*entity*/ + ctx2[8].data; + if (dirty & /*view*/ + 4) + logfilecomponent_changes.view = /*view*/ + ctx2[2]; + logfilecomponent.$set(logfilecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(logfilecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(logfilecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + destroy_component(logfilecomponent); + } + }; +} +function create_if_block_1(ctx) { + let div; + let logtreecomponent; + let div_transition; + let current; + logtreecomponent = new LogTreeComponent({ + props: { + hierarchy: ( + /*entity*/ + ctx[8] + ), + plugin: ( + /*plugin*/ + ctx[1] + ), + view: ( + /*view*/ + ctx[2] + ) + } + }); + return { + c() { + div = element("div"); + create_component(logtreecomponent.$$.fragment); + attr(div, "class", "tree-item-children nav-folder-children"); + }, + m(target, anchor) { + insert(target, div, anchor); + mount_component(logtreecomponent, div, null); + current = true; + }, + p(ctx2, dirty) { + const logtreecomponent_changes = {}; + if (dirty & /*hierarchy*/ + 1) + logtreecomponent_changes.hierarchy = /*entity*/ + ctx2[8]; + if (dirty & /*plugin*/ + 2) + logtreecomponent_changes.plugin = /*plugin*/ + ctx2[1]; + if (dirty & /*view*/ + 4) + logtreecomponent_changes.view = /*view*/ + ctx2[2]; + logtreecomponent.$set(logtreecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(logtreecomponent.$$.fragment, local); + if (local) { + add_render_callback(() => { + if (!current) + return; + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); + div_transition.run(1); + }); + } + current = true; + }, + o(local) { + transition_out(logtreecomponent.$$.fragment, local); + if (local) { + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); + div_transition.run(0); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + destroy_component(logtreecomponent); + if (detaching && div_transition) + div_transition.end(); + } + }; +} +function create_each_block(ctx) { + let current_block_type_index; + let if_block; + let if_block_anchor; + let current; + const if_block_creators = [create_if_block2, create_else_block]; + const if_blocks = []; + function select_block_type(ctx2, dirty) { + if ( + /*entity*/ + ctx2[8].data + ) + return 0; + return 1; + } + current_block_type_index = select_block_type(ctx, -1); + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + return { + c() { + if_block.c(); + if_block_anchor = empty(); + }, + m(target, anchor) { + if_blocks[current_block_type_index].m(target, anchor); + insert(target, if_block_anchor, anchor); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } else { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(if_block_anchor.parentNode, if_block_anchor); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + current = true; + }, + o(local) { + transition_out(if_block); + current = false; + }, + d(detaching) { + if (detaching) { + detach(if_block_anchor); + } + if_blocks[current_block_type_index].d(detaching); + } + }; +} +function create_fragment2(ctx) { + let main; + let current; + let each_value = ensure_array_like( + /*hierarchy*/ + ctx[0].children + ); + let each_blocks = []; + for (let i = 0; i < each_value.length; i += 1) { + each_blocks[i] = create_each_block(get_each_context(ctx, each_value, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + main = element("main"); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + attr(main, "class", "svelte-1lnl15d"); + toggle_class( + main, + "topLevel", + /*topLevel*/ + ctx[3] + ); + }, + m(target, anchor) { + insert(target, main, anchor); + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(main, null); + } + } + current = true; + }, + p(ctx2, [dirty]) { + if (dirty & /*hierarchy, view, closed, plugin, side, fold*/ + 119) { + each_value = ensure_array_like( + /*hierarchy*/ + ctx2[0].children + ); + let i; + for (i = 0; i < each_value.length; i += 1) { + const child_ctx = get_each_context(ctx2, each_value, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(main, null); + } + } + group_outros(); + for (i = each_value.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + if (!current || dirty & /*topLevel*/ + 8) { + toggle_class( + main, + "topLevel", + /*topLevel*/ + ctx2[3] + ); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(main); + } + destroy_each(each_blocks, detaching); + } + }; +} +function instance2($$self, $$props, $$invalidate) { + let side; + let { hierarchy } = $$props; + let { plugin } = $$props; + let { view } = $$props; + let { topLevel = false } = $$props; + const closed = {}; + function fold(item) { + $$invalidate(4, closed[item.title] = !closed[item.title], closed); + } + const click_handler = (entity) => fold(entity); + $$self.$$set = ($$props2) => { + if ("hierarchy" in $$props2) + $$invalidate(0, hierarchy = $$props2.hierarchy); + if ("plugin" in $$props2) + $$invalidate(1, plugin = $$props2.plugin); + if ("view" in $$props2) + $$invalidate(2, view = $$props2.view); + if ("topLevel" in $$props2) + $$invalidate(3, topLevel = $$props2.topLevel); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*view*/ + 4) { + $: + $$invalidate(5, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [hierarchy, plugin, view, topLevel, closed, side, fold, click_handler]; +} +var LogTreeComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2( + this, + options, + instance2, + create_fragment2, + safe_not_equal, + { + hierarchy: 0, + plugin: 1, + view: 2, + topLevel: 3 + }, + add_css2 + ); + } +}; +var logTreeComponent_default = LogTreeComponent; + +// src/ui/history/components/logComponent.svelte +function add_css3(target) { + append_styles(target, "svelte-1t6egnt", ".git-ref.svelte-1t6egnt{color:var(--text-accent)}"); +} +function get_each_context2(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[8] = list[i]; + return child_ctx; +} +function create_if_block_2(ctx) { + let div; + let t_value = ( + /*log*/ + ctx[0].refs.join(", ") + "" + ); + let t; + return { + c() { + div = element("div"); + t = text(t_value); + attr(div, "class", "git-ref svelte-1t6egnt"); + }, + m(target, anchor) { + insert(target, div, anchor); + append2(div, t); + }, + p(ctx2, dirty) { + if (dirty & /*log*/ + 1 && t_value !== (t_value = /*log*/ + ctx2[0].refs.join(", ") + "")) + set_data(t, t_value); + }, + d(detaching) { + if (detaching) { + detach(div); + } + } + }; +} +function create_if_block3(ctx) { + let div; + let current_block_type_index; + let if_block; + let div_transition; + let current; + const if_block_creators = [create_if_block_12, create_else_block2]; + const if_blocks = []; + function select_block_type(ctx2, dirty) { + if ( + /*showTree*/ + ctx2[2] + ) + return 0; + return 1; + } + current_block_type_index = select_block_type(ctx, -1); + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + return { + c() { + div = element("div"); + if_block.c(); + attr(div, "class", "tree-item-children nav-folder-children"); + }, + m(target, anchor) { + insert(target, div, anchor); + if_blocks[current_block_type_index].m(div, null); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } else { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(div, null); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + if (local) { + add_render_callback(() => { + if (!current) + return; + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); + div_transition.run(1); + }); + } + current = true; + }, + o(local) { + transition_out(if_block); + if (local) { + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); + div_transition.run(0); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + if_blocks[current_block_type_index].d(); + if (detaching && div_transition) + div_transition.end(); + } + }; +} +function create_else_block2(ctx) { + let each_1_anchor; + let current; + let each_value = ensure_array_like( + /*log*/ + ctx[0].diff.files + ); + let each_blocks = []; + for (let i = 0; i < each_value.length; i += 1) { + each_blocks[i] = create_each_block2(get_each_context2(ctx, each_value, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + each_1_anchor = empty(); + }, + m(target, anchor) { + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(target, anchor); + } + } + insert(target, each_1_anchor, anchor); + current = true; + }, + p(ctx2, dirty) { + if (dirty & /*view, log*/ + 3) { + each_value = ensure_array_like( + /*log*/ + ctx2[0].diff.files + ); + let i; + for (i = 0; i < each_value.length; i += 1) { + const child_ctx = get_each_context2(ctx2, each_value, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block2(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(each_1_anchor.parentNode, each_1_anchor); + } + } + group_outros(); + for (i = each_value.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(each_1_anchor); + } + destroy_each(each_blocks, detaching); + } + }; +} +function create_if_block_12(ctx) { + let logtreecomponent; + let current; + logtreecomponent = new logTreeComponent_default({ + props: { + hierarchy: ( + /*logsHierarchy*/ + ctx[6] + ), + plugin: ( + /*plugin*/ + ctx[3] + ), + view: ( + /*view*/ + ctx[1] + ), + topLevel: true + } + }); + return { + c() { + create_component(logtreecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(logtreecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const logtreecomponent_changes = {}; + if (dirty & /*logsHierarchy*/ + 64) + logtreecomponent_changes.hierarchy = /*logsHierarchy*/ + ctx2[6]; + if (dirty & /*plugin*/ + 8) + logtreecomponent_changes.plugin = /*plugin*/ + ctx2[3]; + if (dirty & /*view*/ + 2) + logtreecomponent_changes.view = /*view*/ + ctx2[1]; + logtreecomponent.$set(logtreecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(logtreecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(logtreecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(logtreecomponent, detaching); + } + }; +} +function create_each_block2(ctx) { + let logfilecomponent; + let current; + logfilecomponent = new logFileComponent_default({ + props: { + view: ( + /*view*/ + ctx[1] + ), + diff: ( + /*file*/ + ctx[8] + ) + } + }); + return { + c() { + create_component(logfilecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(logfilecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const logfilecomponent_changes = {}; + if (dirty & /*view*/ + 2) + logfilecomponent_changes.view = /*view*/ + ctx2[1]; + if (dirty & /*log*/ + 1) + logfilecomponent_changes.diff = /*file*/ + ctx2[8]; + logfilecomponent.$set(logfilecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(logfilecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(logfilecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(logfilecomponent, detaching); + } + }; +} +function create_fragment3(ctx) { + let main; + let div4; + let div3; + let div0; + let t0; + let div2; + let t1; + let div1; + let t2_value = ( + /*log*/ + ctx[0].message + "" + ); + let t2; + let div1_aria_label_value; + let t3; + let current; + let mounted; + let dispose; + let if_block0 = ( + /*log*/ + ctx[0].refs.length > 0 && create_if_block_2(ctx) + ); + let if_block1 = !/*isCollapsed*/ + ctx[4] && create_if_block3(ctx); + return { + c() { + main = element("main"); + div4 = element("div"); + div3 = element("div"); + div0 = element("div"); + div0.innerHTML = ``; + t0 = space(); + div2 = element("div"); + if (if_block0) + if_block0.c(); + t1 = space(); + div1 = element("div"); + t2 = text(t2_value); + t3 = space(); + if (if_block1) + if_block1.c(); + attr(div0, "class", "tree-item-icon nav-folder-collapse-indicator collapse-icon"); + toggle_class( + div0, + "is-collapsed", + /*isCollapsed*/ + ctx[4] + ); + attr(div1, "class", "tree-item-inner nav-folder-title-content"); + attr(div1, "aria-label", div1_aria_label_value = /*log*/ + ctx[0].message); + attr( + div1, + "aria-label-position", + /*side*/ + ctx[5] + ); + attr(div3, "class", "tree-item-self is-clickable nav-folder-title"); + attr(div4, "class", "tree-item nav-folder"); + toggle_class( + div4, + "is-collapsed", + /*isCollapsed*/ + ctx[4] + ); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div4); + append2(div4, div3); + append2(div3, div0); + append2(div3, t0); + append2(div3, div2); + if (if_block0) + if_block0.m(div2, null); + append2(div2, t1); + append2(div2, div1); + append2(div1, t2); + append2(div4, t3); + if (if_block1) + if_block1.m(div4, null); + current = true; + if (!mounted) { + dispose = listen( + div3, + "click", + /*click_handler*/ + ctx[7] + ); + mounted = true; + } + }, + p(ctx2, [dirty]) { + if (!current || dirty & /*isCollapsed*/ + 16) { + toggle_class( + div0, + "is-collapsed", + /*isCollapsed*/ + ctx2[4] + ); + } + if ( + /*log*/ + ctx2[0].refs.length > 0 + ) { + if (if_block0) { + if_block0.p(ctx2, dirty); + } else { + if_block0 = create_if_block_2(ctx2); + if_block0.c(); + if_block0.m(div2, t1); + } + } else if (if_block0) { + if_block0.d(1); + if_block0 = null; + } + if ((!current || dirty & /*log*/ + 1) && t2_value !== (t2_value = /*log*/ + ctx2[0].message + "")) + set_data(t2, t2_value); + if (!current || dirty & /*log*/ + 1 && div1_aria_label_value !== (div1_aria_label_value = /*log*/ + ctx2[0].message)) { + attr(div1, "aria-label", div1_aria_label_value); + } + if (!current || dirty & /*side*/ + 32) { + attr( + div1, + "aria-label-position", + /*side*/ + ctx2[5] + ); + } + if (!/*isCollapsed*/ + ctx2[4]) { + if (if_block1) { + if_block1.p(ctx2, dirty); + if (dirty & /*isCollapsed*/ + 16) { + transition_in(if_block1, 1); + } + } else { + if_block1 = create_if_block3(ctx2); + if_block1.c(); + transition_in(if_block1, 1); + if_block1.m(div4, null); + } + } else if (if_block1) { + group_outros(); + transition_out(if_block1, 1, 1, () => { + if_block1 = null; + }); + check_outros(); + } + if (!current || dirty & /*isCollapsed*/ + 16) { + toggle_class( + div4, + "is-collapsed", + /*isCollapsed*/ + ctx2[4] + ); + } + }, + i(local) { + if (current) + return; + transition_in(if_block1); + current = true; + }, + o(local) { + transition_out(if_block1); + current = false; + }, + d(detaching) { + if (detaching) { + detach(main); + } + if (if_block0) + if_block0.d(); + if (if_block1) + if_block1.d(); + mounted = false; + dispose(); + } + }; +} +function instance3($$self, $$props, $$invalidate) { + let logsHierarchy; + let side; + let { log: log2 } = $$props; + let { view } = $$props; + let { showTree } = $$props; + let { plugin } = $$props; + let isCollapsed = true; + const click_handler = () => $$invalidate(4, isCollapsed = !isCollapsed); + $$self.$$set = ($$props2) => { + if ("log" in $$props2) + $$invalidate(0, log2 = $$props2.log); + if ("view" in $$props2) + $$invalidate(1, view = $$props2.view); + if ("showTree" in $$props2) + $$invalidate(2, showTree = $$props2.showTree); + if ("plugin" in $$props2) + $$invalidate(3, plugin = $$props2.plugin); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*plugin, log*/ + 9) { + $: + $$invalidate(6, logsHierarchy = { + title: "", + path: "", + vaultPath: "", + children: plugin.gitManager.getTreeStructure(log2.diff.files) + }); + } + if ($$self.$$.dirty & /*view*/ + 2) { + $: + $$invalidate(5, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [log2, view, showTree, plugin, isCollapsed, side, logsHierarchy, click_handler]; +} +var LogComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance3, create_fragment3, safe_not_equal, { log: 0, view: 1, showTree: 2, plugin: 3 }, add_css3); + } +}; +var logComponent_default = LogComponent; + +// src/ui/history/historyView.svelte +function get_each_context3(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[11] = list[i]; + return child_ctx; +} +function create_if_block4(ctx) { + let div1; + let div0; + let current; + let each_value = ensure_array_like( + /*logs*/ + ctx[6] + ); + let each_blocks = []; + for (let i = 0; i < each_value.length; i += 1) { + each_blocks[i] = create_each_block3(get_each_context3(ctx, each_value, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + div1 = element("div"); + div0 = element("div"); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + attr(div0, "class", "tree-item-children nav-folder-children"); + attr(div1, "class", "tree-item nav-folder mod-root"); + }, + m(target, anchor) { + insert(target, div1, anchor); + append2(div1, div0); + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(div0, null); + } + } + current = true; + }, + p(ctx2, dirty) { + if (dirty & /*view, showTree, logs, plugin*/ + 71) { + each_value = ensure_array_like( + /*logs*/ + ctx2[6] + ); + let i; + for (i = 0; i < each_value.length; i += 1) { + const child_ctx = get_each_context3(ctx2, each_value, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block3(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(div0, null); + } + } + group_outros(); + for (i = each_value.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div1); + } + destroy_each(each_blocks, detaching); + } + }; +} +function create_each_block3(ctx) { + let logcomponent; + let current; + logcomponent = new logComponent_default({ + props: { + view: ( + /*view*/ + ctx[1] + ), + showTree: ( + /*showTree*/ + ctx[2] + ), + log: ( + /*log*/ + ctx[11] + ), + plugin: ( + /*plugin*/ + ctx[0] + ) + } + }); + return { + c() { + create_component(logcomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(logcomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const logcomponent_changes = {}; + if (dirty & /*view*/ + 2) + logcomponent_changes.view = /*view*/ + ctx2[1]; + if (dirty & /*showTree*/ + 4) + logcomponent_changes.showTree = /*showTree*/ + ctx2[2]; + if (dirty & /*logs*/ + 64) + logcomponent_changes.log = /*log*/ + ctx2[11]; + if (dirty & /*plugin*/ + 1) + logcomponent_changes.plugin = /*plugin*/ + ctx2[0]; + logcomponent.$set(logcomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(logcomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(logcomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(logcomponent, detaching); + } + }; +} +function create_fragment4(ctx) { + let main; + let div3; + let div2; + let div0; + let t0; + let div1; + let t1; + let div4; + let current; + let mounted; + let dispose; + let if_block = ( + /*logs*/ + ctx[6] && create_if_block4(ctx) + ); + return { + c() { + main = element("main"); + div3 = element("div"); + div2 = element("div"); + div0 = element("div"); + t0 = space(); + div1 = element("div"); + t1 = space(); + div4 = element("div"); + if (if_block) + if_block.c(); + attr(div0, "id", "layoutChange"); + attr(div0, "class", "clickable-icon nav-action-button"); + attr(div0, "aria-label", "Change Layout"); + attr(div1, "id", "refresh"); + attr(div1, "class", "clickable-icon nav-action-button"); + attr(div1, "data-icon", "refresh-cw"); + attr(div1, "aria-label", "Refresh"); + set_style(div1, "margin", "1px"); + toggle_class( + div1, + "loading", + /*loading*/ + ctx[4] + ); + attr(div2, "class", "nav-buttons-container"); + attr(div3, "class", "nav-header"); + attr(div4, "class", "nav-files-container"); + set_style(div4, "position", "relative"); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div3); + append2(div3, div2); + append2(div2, div0); + ctx[7](div0); + append2(div2, t0); + append2(div2, div1); + ctx[9](div1); + append2(main, t1); + append2(main, div4); + if (if_block) + if_block.m(div4, null); + current = true; + if (!mounted) { + dispose = [ + listen( + div0, + "click", + /*click_handler*/ + ctx[8] + ), + listen(div1, "click", triggerRefresh) + ]; + mounted = true; + } + }, + p(ctx2, [dirty]) { + if (!current || dirty & /*loading*/ + 16) { + toggle_class( + div1, + "loading", + /*loading*/ + ctx2[4] + ); + } + if ( + /*logs*/ + ctx2[6] + ) { + if (if_block) { + if_block.p(ctx2, dirty); + if (dirty & /*logs*/ + 64) { + transition_in(if_block, 1); + } + } else { + if_block = create_if_block4(ctx2); + if_block.c(); + transition_in(if_block, 1); + if_block.m(div4, null); + } + } else if (if_block) { + group_outros(); + transition_out(if_block, 1, 1, () => { + if_block = null; + }); + check_outros(); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + current = true; + }, + o(local) { + transition_out(if_block); + current = false; + }, + d(detaching) { + if (detaching) { + detach(main); + } + ctx[7](null); + ctx[9](null); + if (if_block) + if_block.d(); + mounted = false; + run_all(dispose); + } + }; +} +function triggerRefresh() { + dispatchEvent(new CustomEvent("git-refresh")); +} +function instance4($$self, $$props, $$invalidate) { + let { plugin } = $$props; + let { view } = $$props; + let loading; + let buttons = []; + let logs; + let showTree = plugin.settings.treeStructure; + let layoutBtn; + addEventListener("git-view-refresh", refresh); + plugin.app.workspace.onLayoutReady(() => { + window.setTimeout( + () => { + buttons.forEach((btn) => (0, import_obsidian19.setIcon)(btn, btn.getAttr("data-icon"), 16)); + (0, import_obsidian19.setIcon)(layoutBtn, showTree ? "list" : "folder", 16); + }, + 0 + ); + }); + onDestroy(() => { + removeEventListener("git-view-refresh", refresh); + }); + function refresh() { + return __awaiter(this, void 0, void 0, function* () { + $$invalidate(4, loading = true); + const isSimpleGit = plugin.gitManager instanceof SimpleGit; + $$invalidate(6, logs = yield plugin.gitManager.log(void 0, false, isSimpleGit ? 50 : 10)); + $$invalidate(4, loading = false); + }); + } + function div0_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + layoutBtn = $$value; + $$invalidate(3, layoutBtn); + }); + } + const click_handler = () => { + $$invalidate(2, showTree = !showTree); + $$invalidate(0, plugin.settings.treeStructure = showTree, plugin); + plugin.saveSettings(); + }; + function div1_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[6] = $$value; + $$invalidate(5, buttons); + }); + } + $$self.$$set = ($$props2) => { + if ("plugin" in $$props2) + $$invalidate(0, plugin = $$props2.plugin); + if ("view" in $$props2) + $$invalidate(1, view = $$props2.view); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*layoutBtn, showTree*/ + 12) { + $: { + if (layoutBtn) { + layoutBtn.empty(); + (0, import_obsidian19.setIcon)(layoutBtn, showTree ? "list" : "folder", 16); + } + } + } + }; + return [ + plugin, + view, + showTree, + layoutBtn, + loading, + buttons, + logs, + div0_binding, + click_handler, + div1_binding + ]; +} +var HistoryView = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance4, create_fragment4, safe_not_equal, { plugin: 0, view: 1 }); + } +}; +var historyView_default = HistoryView; + +// src/ui/history/historyView.ts +var HistoryView2 = class extends import_obsidian20.ItemView { + constructor(leaf, plugin) { + super(leaf); + this.plugin = plugin; + this.hoverPopover = null; + } + getViewType() { + return HISTORY_VIEW_CONFIG.type; + } + getDisplayText() { + return HISTORY_VIEW_CONFIG.name; + } + getIcon() { + return HISTORY_VIEW_CONFIG.icon; + } + onClose() { + return super.onClose(); + } + onOpen() { + this._view = new historyView_default({ + target: this.contentEl, + props: { + plugin: this.plugin, + view: this + } + }); + return super.onOpen(); + } +}; + +// src/ui/modals/branchModal.ts +init_polyfill_buffer(); +var import_obsidian21 = require("obsidian"); +var BranchModal = class extends import_obsidian21.FuzzySuggestModal { + constructor(branches) { + super(app); + this.branches = branches; + this.setPlaceholder("Select branch to checkout"); + } + getItems() { + return this.branches; + } + getItemText(item) { + return item; + } + onChooseItem(item, evt) { + this.resolve(item); + } + open() { + super.open(); + return new Promise((resolve) => { + this.resolve = resolve; + }); + } + async onClose() { + await new Promise((resolve) => setTimeout(resolve, 10)); + if (this.resolve) + this.resolve(void 0); + } +}; + +// src/ui/modals/ignoreModal.ts +init_polyfill_buffer(); +var import_obsidian22 = require("obsidian"); +var IgnoreModal = class extends import_obsidian22.Modal { + constructor(app2, content) { + super(app2); + this.content = content; + this.resolve = null; + } + open() { + super.open(); + return new Promise((resolve) => { + this.resolve = resolve; + }); + } + onOpen() { + const { contentEl, titleEl } = this; + titleEl.setText("Edit .gitignore"); + const div = contentEl.createDiv(); + const text2 = div.createEl("textarea", { + text: this.content, + cls: ["obsidian-git-textarea"], + attr: { rows: 10, cols: 30, wrap: "off" } + }); + div.createEl("button", { + cls: ["mod-cta", "obsidian-git-center-button"], + text: "Save" + }).addEventListener("click", async () => { + this.resolve(text2.value); + this.close(); + }); + } + onClose() { + const { contentEl } = this; + this.resolve(void 0); + contentEl.empty(); + } +}; + +// src/ui/sourceControl/sourceControl.ts +init_polyfill_buffer(); +var import_obsidian29 = require("obsidian"); + +// src/ui/sourceControl/sourceControl.svelte +init_polyfill_buffer(); +var import_obsidian28 = require("obsidian"); + +// src/ui/modals/discardModal.ts +init_polyfill_buffer(); +var import_obsidian23 = require("obsidian"); +var DiscardModal = class extends import_obsidian23.Modal { + constructor(app2, deletion, filename) { + super(app2); + this.deletion = deletion; + this.filename = filename; + this.resolve = null; + } + myOpen() { + this.open(); + return new Promise((resolve) => { + this.resolve = resolve; + }); + } + onOpen() { + const { contentEl, titleEl } = this; + titleEl.setText(`${this.deletion ? "Delete" : "Discard"} this file?`); + contentEl.createEl("p").setText( + `Do you really want to ${this.deletion ? "delete" : "discard the changes of"} "${this.filename}"` + ); + const div = contentEl.createDiv({ cls: "modal-button-container" }); + const discard = div.createEl("button", { + cls: "mod-warning", + text: this.deletion ? "Delete" : "Discard" + }); + discard.addEventListener("click", async () => { + if (this.resolve) + this.resolve(true); + this.close(); + }); + discard.addEventListener("keypress", async () => { + if (this.resolve) + this.resolve(true); + this.close(); + }); + const close = div.createEl("button", { + text: "Cancel" + }); + close.addEventListener("click", () => { + if (this.resolve) + this.resolve(false); + return this.close(); + }); + close.addEventListener("keypress", () => { + if (this.resolve) + this.resolve(false); + return this.close(); + }); + } + onClose() { + const { contentEl } = this; + contentEl.empty(); + } +}; + +// src/ui/sourceControl/components/fileComponent.svelte +init_polyfill_buffer(); +var import_obsidian25 = require("obsidian"); + +// node_modules/.pnpm/github.com+Vinzent03+obsidian-community-lib@e663de4f95c879b40613090da78ea599ff621d24_@codemir_kbfcpig3uak7df3ohthcqq53p4/node_modules/obsidian-community-lib/dist/index.js +init_polyfill_buffer(); + +// node_modules/.pnpm/github.com+Vinzent03+obsidian-community-lib@e663de4f95c879b40613090da78ea599ff621d24_@codemir_kbfcpig3uak7df3ohthcqq53p4/node_modules/obsidian-community-lib/dist/utils.js +init_polyfill_buffer(); +var feather = __toESM(require_feather()); +var import_obsidian24 = require("obsidian"); +function hoverPreview(event, view, to) { + const targetEl = event.target; + app.workspace.trigger("hover-link", { + event, + source: view.getViewType(), + hoverParent: view, + targetEl, + linktext: to + }); +} + +// src/ui/sourceControl/components/fileComponent.svelte +function add_css4(target) { + append_styles(target, "svelte-1wbh8tp", "main.svelte-1wbh8tp .nav-file-title.svelte-1wbh8tp{align-items:center}"); +} +function create_if_block5(ctx) { + let div; + let mounted; + let dispose; + return { + c() { + div = element("div"); + attr(div, "data-icon", "go-to-file"); + attr(div, "aria-label", "Open File"); + attr(div, "class", "clickable-icon"); + }, + m(target, anchor) { + insert(target, div, anchor); + ctx[11](div); + if (!mounted) { + dispose = [ + listen(div, "auxclick", stop_propagation( + /*open*/ + ctx[5] + )), + listen(div, "click", stop_propagation( + /*open*/ + ctx[5] + )) + ]; + mounted = true; + } + }, + p: noop, + d(detaching) { + if (detaching) { + detach(div); + } + ctx[11](null); + mounted = false; + run_all(dispose); + } + }; +} +function create_fragment5(ctx) { + let main; + let div6; + let div0; + let t0_value = getDisplayPath( + /*change*/ + ctx[0].vault_path + ) + ""; + let t0; + let t1; + let div5; + let div3; + let show_if = ( + /*view*/ + ctx[1].app.vault.getAbstractFileByPath( + /*change*/ + ctx[0].vault_path + ) + ); + let t2; + let div1; + let t3; + let div2; + let t4; + let div4; + let t5_value = ( + /*change*/ + ctx[0].working_dir + "" + ); + let t5; + let div4_data_type_value; + let div6_data_path_value; + let div6_aria_label_value; + let mounted; + let dispose; + let if_block = show_if && create_if_block5(ctx); + return { + c() { + var _a2, _b, _c; + main = element("main"); + div6 = element("div"); + div0 = element("div"); + t0 = text(t0_value); + t1 = space(); + div5 = element("div"); + div3 = element("div"); + if (if_block) + if_block.c(); + t2 = space(); + div1 = element("div"); + t3 = space(); + div2 = element("div"); + t4 = space(); + div4 = element("div"); + t5 = text(t5_value); + attr(div0, "class", "tree-item-inner nav-file-title-content"); + attr(div1, "data-icon", "undo"); + attr(div1, "aria-label", "Discard"); + attr(div1, "class", "clickable-icon"); + attr(div2, "data-icon", "plus"); + attr(div2, "aria-label", "Stage"); + attr(div2, "class", "clickable-icon"); + attr(div3, "class", "buttons"); + attr(div4, "class", "type"); + attr(div4, "data-type", div4_data_type_value = /*change*/ + ctx[0].working_dir); + attr(div5, "class", "git-tools"); + attr(div6, "class", "tree-item-self is-clickable nav-file-title svelte-1wbh8tp"); + attr(div6, "data-path", div6_data_path_value = /*change*/ + ctx[0].vault_path); + attr( + div6, + "aria-label-position", + /*side*/ + ctx[3] + ); + attr(div6, "aria-label", div6_aria_label_value = /*change*/ + ctx[0].vault_path); + toggle_class( + div6, + "is-active", + /*view*/ + ((_a2 = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _a2.file) == /*change*/ + ctx[0].vault_path && !/*view*/ + ((_b = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _b.hash) && !/*view*/ + ((_c = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _c.staged) + ); + attr(main, "class", "tree-item nav-file svelte-1wbh8tp"); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div6); + append2(div6, div0); + append2(div0, t0); + append2(div6, t1); + append2(div6, div5); + append2(div5, div3); + if (if_block) + if_block.m(div3, null); + append2(div3, t2); + append2(div3, div1); + ctx[12](div1); + append2(div3, t3); + append2(div3, div2); + ctx[13](div2); + append2(div5, t4); + append2(div5, div4); + append2(div4, t5); + if (!mounted) { + dispose = [ + listen(div1, "click", stop_propagation( + /*discard*/ + ctx[8] + )), + listen(div2, "click", stop_propagation( + /*stage*/ + ctx[6] + )), + listen( + main, + "mouseover", + /*hover*/ + ctx[4] + ), + listen(main, "click", stop_propagation( + /*showDiff*/ + ctx[7] + )), + listen(main, "auxclick", stop_propagation( + /*showDiff*/ + ctx[7] + )), + listen( + main, + "focus", + /*focus_handler*/ + ctx[10] + ) + ]; + mounted = true; + } + }, + p(ctx2, [dirty]) { + var _a2, _b, _c; + if (dirty & /*change*/ + 1 && t0_value !== (t0_value = getDisplayPath( + /*change*/ + ctx2[0].vault_path + ) + "")) + set_data(t0, t0_value); + if (dirty & /*view, change*/ + 3) + show_if = /*view*/ + ctx2[1].app.vault.getAbstractFileByPath( + /*change*/ + ctx2[0].vault_path + ); + if (show_if) { + if (if_block) { + if_block.p(ctx2, dirty); + } else { + if_block = create_if_block5(ctx2); + if_block.c(); + if_block.m(div3, t2); + } + } else if (if_block) { + if_block.d(1); + if_block = null; + } + if (dirty & /*change*/ + 1 && t5_value !== (t5_value = /*change*/ + ctx2[0].working_dir + "")) + set_data(t5, t5_value); + if (dirty & /*change*/ + 1 && div4_data_type_value !== (div4_data_type_value = /*change*/ + ctx2[0].working_dir)) { + attr(div4, "data-type", div4_data_type_value); + } + if (dirty & /*change*/ + 1 && div6_data_path_value !== (div6_data_path_value = /*change*/ + ctx2[0].vault_path)) { + attr(div6, "data-path", div6_data_path_value); + } + if (dirty & /*side*/ + 8) { + attr( + div6, + "aria-label-position", + /*side*/ + ctx2[3] + ); + } + if (dirty & /*change*/ + 1 && div6_aria_label_value !== (div6_aria_label_value = /*change*/ + ctx2[0].vault_path)) { + attr(div6, "aria-label", div6_aria_label_value); + } + if (dirty & /*view, change*/ + 3) { + toggle_class( + div6, + "is-active", + /*view*/ + ((_a2 = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _a2.file) == /*change*/ + ctx2[0].vault_path && !/*view*/ + ((_b = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _b.hash) && !/*view*/ + ((_c = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _c.staged) + ); + } + }, + i: noop, + o: noop, + d(detaching) { + if (detaching) { + detach(main); + } + if (if_block) + if_block.d(); + ctx[12](null); + ctx[13](null); + mounted = false; + run_all(dispose); + } + }; +} +function instance5($$self, $$props, $$invalidate) { + let side; + let { change } = $$props; + let { view } = $$props; + let { manager } = $$props; + let buttons = []; + window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian25.setIcon)(b, b.getAttr("data-icon"))), 0); + function hover(event) { + if (app.vault.getAbstractFileByPath(change.vault_path)) { + hoverPreview(event, view, change.vault_path); + } + } + function open(event) { + var _a2; + const file = view.app.vault.getAbstractFileByPath(change.vault_path); + console.log(event); + if (file instanceof import_obsidian25.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); + } + } + function stage() { + manager.stage(change.path, false).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + function showDiff(event) { + var _a2; + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.setViewState({ + type: DIFF_VIEW_CONFIG.type, + active: true, + state: { file: change.path, staged: false } + }); + } + function discard() { + const deleteFile = change.working_dir == "U"; + new DiscardModal(view.app, deleteFile, change.vault_path).myOpen().then((shouldDiscard) => { + if (shouldDiscard === true) { + if (deleteFile) { + view.app.vault.adapter.remove(change.vault_path).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } else { + manager.discard(change.path).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + } + }); + } + function focus_handler(event) { + bubble.call(this, $$self, event); + } + function div_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[1] = $$value; + $$invalidate(2, buttons); + }); + } + function div1_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[0] = $$value; + $$invalidate(2, buttons); + }); + } + function div2_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[2] = $$value; + $$invalidate(2, buttons); + }); + } + $$self.$$set = ($$props2) => { + if ("change" in $$props2) + $$invalidate(0, change = $$props2.change); + if ("view" in $$props2) + $$invalidate(1, view = $$props2.view); + if ("manager" in $$props2) + $$invalidate(9, manager = $$props2.manager); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*view*/ + 2) { + $: + $$invalidate(3, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [ + change, + view, + buttons, + side, + hover, + open, + stage, + showDiff, + discard, + manager, + focus_handler, + div_binding, + div1_binding, + div2_binding + ]; +} +var FileComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance5, create_fragment5, safe_not_equal, { change: 0, view: 1, manager: 9 }, add_css4); + } +}; +var fileComponent_default = FileComponent; + +// src/ui/sourceControl/components/pulledFileComponent.svelte +init_polyfill_buffer(); +var import_obsidian26 = require("obsidian"); +function add_css5(target) { + append_styles(target, "svelte-1wbh8tp", "main.svelte-1wbh8tp .nav-file-title.svelte-1wbh8tp{align-items:center}"); +} +function create_fragment6(ctx) { + let main; + let div2; + let div0; + let t0_value = getDisplayPath( + /*change*/ + ctx[0].vault_path + ) + ""; + let t0; + let t1; + let div1; + let span; + let t2_value = ( + /*change*/ + ctx[0].working_dir + "" + ); + let t2; + let span_data_type_value; + let div2_data_path_value; + let div2_aria_label_value; + let mounted; + let dispose; + return { + c() { + main = element("main"); + div2 = element("div"); + div0 = element("div"); + t0 = text(t0_value); + t1 = space(); + div1 = element("div"); + span = element("span"); + t2 = text(t2_value); + attr(div0, "class", "tree-item-inner nav-file-title-content"); + attr(span, "class", "type"); + attr(span, "data-type", span_data_type_value = /*change*/ + ctx[0].working_dir); + attr(div1, "class", "git-tools"); + attr(div2, "class", "tree-item-self is-clickable nav-file-title svelte-1wbh8tp"); + attr(div2, "data-path", div2_data_path_value = /*change*/ + ctx[0].vault_path); + attr( + div2, + "aria-label-position", + /*side*/ + ctx[1] + ); + attr(div2, "aria-label", div2_aria_label_value = /*change*/ + ctx[0].vault_path); + attr(main, "class", "tree-item nav-file svelte-1wbh8tp"); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div2); + append2(div2, div0); + append2(div0, t0); + append2(div2, t1); + append2(div2, div1); + append2(div1, span); + append2(span, t2); + if (!mounted) { + dispose = [ + listen( + main, + "mouseover", + /*hover*/ + ctx[2] + ), + listen(main, "click", stop_propagation( + /*open*/ + ctx[3] + )), + listen(main, "auxclick", stop_propagation( + /*open*/ + ctx[3] + )), + listen( + main, + "focus", + /*focus_handler*/ + ctx[5] + ) + ]; + mounted = true; + } + }, + p(ctx2, [dirty]) { + if (dirty & /*change*/ + 1 && t0_value !== (t0_value = getDisplayPath( + /*change*/ + ctx2[0].vault_path + ) + "")) + set_data(t0, t0_value); + if (dirty & /*change*/ + 1 && t2_value !== (t2_value = /*change*/ + ctx2[0].working_dir + "")) + set_data(t2, t2_value); + if (dirty & /*change*/ + 1 && span_data_type_value !== (span_data_type_value = /*change*/ + ctx2[0].working_dir)) { + attr(span, "data-type", span_data_type_value); + } + if (dirty & /*change*/ + 1 && div2_data_path_value !== (div2_data_path_value = /*change*/ + ctx2[0].vault_path)) { + attr(div2, "data-path", div2_data_path_value); + } + if (dirty & /*side*/ + 2) { + attr( + div2, + "aria-label-position", + /*side*/ + ctx2[1] + ); + } + if (dirty & /*change*/ + 1 && div2_aria_label_value !== (div2_aria_label_value = /*change*/ + ctx2[0].vault_path)) { + attr(div2, "aria-label", div2_aria_label_value); + } + }, + i: noop, + o: noop, + d(detaching) { + if (detaching) { + detach(main); + } + mounted = false; + run_all(dispose); + } + }; +} +function instance6($$self, $$props, $$invalidate) { + let side; + let { change } = $$props; + let { view } = $$props; + function hover(event) { + if (app.vault.getAbstractFileByPath(change.vault_path)) { + hoverPreview(event, view, change.vault_path); + } + } + function open(event) { + var _a2; + const file = view.app.vault.getAbstractFileByPath(change.vault_path); + if (file instanceof import_obsidian26.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); + } + } + function focus_handler(event) { + bubble.call(this, $$self, event); + } + $$self.$$set = ($$props2) => { + if ("change" in $$props2) + $$invalidate(0, change = $$props2.change); + if ("view" in $$props2) + $$invalidate(4, view = $$props2.view); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*view*/ + 16) { + $: + $$invalidate(1, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [change, side, hover, open, view, focus_handler]; +} +var PulledFileComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance6, create_fragment6, safe_not_equal, { change: 0, view: 4 }, add_css5); + } +}; +var pulledFileComponent_default = PulledFileComponent; + +// src/ui/sourceControl/components/stagedFileComponent.svelte +init_polyfill_buffer(); +var import_obsidian27 = require("obsidian"); +function add_css6(target) { + append_styles(target, "svelte-1wbh8tp", "main.svelte-1wbh8tp .nav-file-title.svelte-1wbh8tp{align-items:center}"); +} +function create_if_block6(ctx) { + let div; + let mounted; + let dispose; + return { + c() { + div = element("div"); + attr(div, "data-icon", "go-to-file"); + attr(div, "aria-label", "Open File"); + attr(div, "class", "clickable-icon"); + }, + m(target, anchor) { + insert(target, div, anchor); + ctx[10](div); + if (!mounted) { + dispose = listen(div, "click", stop_propagation( + /*open*/ + ctx[5] + )); + mounted = true; + } + }, + p: noop, + d(detaching) { + if (detaching) { + detach(div); + } + ctx[10](null); + mounted = false; + dispose(); + } + }; +} +function create_fragment7(ctx) { + let main; + let div5; + let div0; + let t0_value = getDisplayPath( + /*change*/ + ctx[0].vault_path + ) + ""; + let t0; + let t1; + let div4; + let div2; + let show_if = ( + /*view*/ + ctx[1].app.vault.getAbstractFileByPath( + /*change*/ + ctx[0].vault_path + ) + ); + let t2; + let div1; + let t3; + let div3; + let t4_value = ( + /*change*/ + ctx[0].index + "" + ); + let t4; + let div3_data_type_value; + let div5_data_path_value; + let div5_aria_label_value; + let mounted; + let dispose; + let if_block = show_if && create_if_block6(ctx); + return { + c() { + var _a2, _b, _c; + main = element("main"); + div5 = element("div"); + div0 = element("div"); + t0 = text(t0_value); + t1 = space(); + div4 = element("div"); + div2 = element("div"); + if (if_block) + if_block.c(); + t2 = space(); + div1 = element("div"); + t3 = space(); + div3 = element("div"); + t4 = text(t4_value); + attr(div0, "class", "tree-item-inner nav-file-title-content"); + attr(div1, "data-icon", "minus"); + attr(div1, "aria-label", "Unstage"); + attr(div1, "class", "clickable-icon"); + attr(div2, "class", "buttons"); + attr(div3, "class", "type"); + attr(div3, "data-type", div3_data_type_value = /*change*/ + ctx[0].index); + attr(div4, "class", "git-tools"); + attr(div5, "class", "tree-item-self is-clickable nav-file-title svelte-1wbh8tp"); + attr(div5, "data-path", div5_data_path_value = /*change*/ + ctx[0].vault_path); + attr( + div5, + "aria-label-position", + /*side*/ + ctx[3] + ); + attr(div5, "aria-label", div5_aria_label_value = /*change*/ + ctx[0].vault_path); + toggle_class( + div5, + "is-active", + /*view*/ + ((_a2 = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _a2.file) == /*change*/ + ctx[0].vault_path && !/*view*/ + ((_b = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _b.hash) && /*view*/ + ((_c = ctx[1].plugin.lastDiffViewState) == null ? void 0 : _c.staged) + ); + attr(main, "class", "tree-item nav-file svelte-1wbh8tp"); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div5); + append2(div5, div0); + append2(div0, t0); + append2(div5, t1); + append2(div5, div4); + append2(div4, div2); + if (if_block) + if_block.m(div2, null); + append2(div2, t2); + append2(div2, div1); + ctx[11](div1); + append2(div4, t3); + append2(div4, div3); + append2(div3, t4); + if (!mounted) { + dispose = [ + listen(div1, "click", stop_propagation( + /*unstage*/ + ctx[7] + )), + listen( + main, + "mouseover", + /*hover*/ + ctx[4] + ), + listen( + main, + "focus", + /*focus_handler*/ + ctx[9] + ), + listen(main, "click", stop_propagation( + /*showDiff*/ + ctx[6] + )), + listen(main, "auxclick", stop_propagation( + /*showDiff*/ + ctx[6] + )) + ]; + mounted = true; + } + }, + p(ctx2, [dirty]) { + var _a2, _b, _c; + if (dirty & /*change*/ + 1 && t0_value !== (t0_value = getDisplayPath( + /*change*/ + ctx2[0].vault_path + ) + "")) + set_data(t0, t0_value); + if (dirty & /*view, change*/ + 3) + show_if = /*view*/ + ctx2[1].app.vault.getAbstractFileByPath( + /*change*/ + ctx2[0].vault_path + ); + if (show_if) { + if (if_block) { + if_block.p(ctx2, dirty); + } else { + if_block = create_if_block6(ctx2); + if_block.c(); + if_block.m(div2, t2); + } + } else if (if_block) { + if_block.d(1); + if_block = null; + } + if (dirty & /*change*/ + 1 && t4_value !== (t4_value = /*change*/ + ctx2[0].index + "")) + set_data(t4, t4_value); + if (dirty & /*change*/ + 1 && div3_data_type_value !== (div3_data_type_value = /*change*/ + ctx2[0].index)) { + attr(div3, "data-type", div3_data_type_value); + } + if (dirty & /*change*/ + 1 && div5_data_path_value !== (div5_data_path_value = /*change*/ + ctx2[0].vault_path)) { + attr(div5, "data-path", div5_data_path_value); + } + if (dirty & /*side*/ + 8) { + attr( + div5, + "aria-label-position", + /*side*/ + ctx2[3] + ); + } + if (dirty & /*change*/ + 1 && div5_aria_label_value !== (div5_aria_label_value = /*change*/ + ctx2[0].vault_path)) { + attr(div5, "aria-label", div5_aria_label_value); + } + if (dirty & /*view, change*/ + 3) { + toggle_class( + div5, + "is-active", + /*view*/ + ((_a2 = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _a2.file) == /*change*/ + ctx2[0].vault_path && !/*view*/ + ((_b = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _b.hash) && /*view*/ + ((_c = ctx2[1].plugin.lastDiffViewState) == null ? void 0 : _c.staged) + ); + } + }, + i: noop, + o: noop, + d(detaching) { + if (detaching) { + detach(main); + } + if (if_block) + if_block.d(); + ctx[11](null); + mounted = false; + run_all(dispose); + } + }; +} +function instance7($$self, $$props, $$invalidate) { + let formattedPath; + let side; + let { change } = $$props; + let { view } = $$props; + let { manager } = $$props; + let buttons = []; + window.setTimeout(() => buttons.forEach((b) => (0, import_obsidian27.setIcon)(b, b.getAttr("data-icon"), 16)), 0); + function hover(event) { + if (app.vault.getAbstractFileByPath(change.vault_path)) { + hoverPreview(event, view, change.vault_path); + } + } + function open(event) { + var _a2; + const file = view.app.vault.getAbstractFileByPath(change.vault_path); + if (file instanceof import_obsidian27.TFile) { + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.openFile(file); + } + } + function showDiff(event) { + var _a2; + (_a2 = getNewLeaf(event)) === null || _a2 === void 0 ? void 0 : _a2.setViewState({ + type: DIFF_VIEW_CONFIG.type, + active: true, + state: { file: change.path, staged: true } + }); + } + function unstage() { + manager.unstage(change.path, false).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + function focus_handler(event) { + bubble.call(this, $$self, event); + } + function div_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[1] = $$value; + $$invalidate(2, buttons); + }); + } + function div1_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[0] = $$value; + $$invalidate(2, buttons); + }); + } + $$self.$$set = ($$props2) => { + if ("change" in $$props2) + $$invalidate(0, change = $$props2.change); + if ("view" in $$props2) + $$invalidate(1, view = $$props2.view); + if ("manager" in $$props2) + $$invalidate(8, manager = $$props2.manager); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*change*/ + 1) { + $: + formattedPath = change.vault_path; + } + if ($$self.$$.dirty & /*view*/ + 2) { + $: + $$invalidate(3, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [ + change, + view, + buttons, + side, + hover, + open, + showDiff, + unstage, + manager, + focus_handler, + div_binding, + div1_binding + ]; +} +var StagedFileComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance7, create_fragment7, safe_not_equal, { change: 0, view: 1, manager: 8 }, add_css6); + } +}; +var stagedFileComponent_default = StagedFileComponent; + +// src/ui/sourceControl/components/treeComponent.svelte +init_polyfill_buffer(); +function add_css7(target) { + append_styles(target, "svelte-hup5mn", "main.svelte-hup5mn .nav-folder-title.svelte-hup5mn{align-items:center}"); +} +function get_each_context4(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[15] = list[i]; + return child_ctx; +} +function create_else_block3(ctx) { + let div7; + let div6; + let div0; + let t0; + let div1; + let t1; + let div2; + let t2_value = ( + /*entity*/ + ctx[15].title + "" + ); + let t2; + let t3; + let div5; + let div4; + let t4; + let div3; + let div6_aria_label_value; + let t5; + let t6; + let current; + let mounted; + let dispose; + function select_block_type_2(ctx2, dirty) { + if ( + /*fileType*/ + ctx2[3] == 0 /* staged */ + ) + return create_if_block_5; + return create_else_block_1; + } + let current_block_type = select_block_type_2(ctx, -1); + let if_block0 = current_block_type(ctx); + let if_block1 = !/*closed*/ + ctx[5][ + /*entity*/ + ctx[15].title + ] && create_if_block_4(ctx); + function click_handler_3() { + return ( + /*click_handler_3*/ + ctx[14]( + /*entity*/ + ctx[15] + ) + ); + } + return { + c() { + div7 = element("div"); + div6 = element("div"); + div0 = element("div"); + t0 = space(); + div1 = element("div"); + div1.innerHTML = ``; + t1 = space(); + div2 = element("div"); + t2 = text(t2_value); + t3 = space(); + div5 = element("div"); + div4 = element("div"); + if_block0.c(); + t4 = space(); + div3 = element("div"); + t5 = space(); + if (if_block1) + if_block1.c(); + t6 = space(); + attr(div0, "data-icon", "folder"); + set_style(div0, "padding-right", "5px"); + set_style(div0, "display", "flex"); + attr(div1, "class", "tree-item-icon nav-folder-collapse-indicator collapse-icon"); + toggle_class( + div1, + "is-collapsed", + /*closed*/ + ctx[5][ + /*entity*/ + ctx[15].title + ] + ); + attr(div2, "class", "tree-item-inner nav-folder-title-content"); + set_style(div3, "width", "11px"); + attr(div4, "class", "buttons"); + attr(div5, "class", "git-tools"); + attr(div6, "class", "tree-item-self is-clickable nav-folder-title svelte-hup5mn"); + attr( + div6, + "aria-label-position", + /*side*/ + ctx[6] + ); + attr(div6, "aria-label", div6_aria_label_value = /*entity*/ + ctx[15].vaultPath); + attr(div7, "class", "tree-item nav-folder"); + toggle_class( + div7, + "is-collapsed", + /*closed*/ + ctx[5][ + /*entity*/ + ctx[15].title + ] + ); + }, + m(target, anchor) { + insert(target, div7, anchor); + append2(div7, div6); + append2(div6, div0); + append2(div6, t0); + append2(div6, div1); + append2(div6, t1); + append2(div6, div2); + append2(div2, t2); + append2(div6, t3); + append2(div6, div5); + append2(div5, div4); + if_block0.m(div4, null); + append2(div4, t4); + append2(div4, div3); + append2(div7, t5); + if (if_block1) + if_block1.m(div7, null); + append2(div7, t6); + current = true; + if (!mounted) { + dispose = listen(div7, "click", click_handler_3); + mounted = true; + } + }, + p(new_ctx, dirty) { + ctx = new_ctx; + if (!current || dirty & /*closed, hierarchy*/ + 33) { + toggle_class( + div1, + "is-collapsed", + /*closed*/ + ctx[5][ + /*entity*/ + ctx[15].title + ] + ); + } + if ((!current || dirty & /*hierarchy*/ + 1) && t2_value !== (t2_value = /*entity*/ + ctx[15].title + "")) + set_data(t2, t2_value); + if (current_block_type === (current_block_type = select_block_type_2(ctx, dirty)) && if_block0) { + if_block0.p(ctx, dirty); + } else { + if_block0.d(1); + if_block0 = current_block_type(ctx); + if (if_block0) { + if_block0.c(); + if_block0.m(div4, t4); + } + } + if (!current || dirty & /*side*/ + 64) { + attr( + div6, + "aria-label-position", + /*side*/ + ctx[6] + ); + } + if (!current || dirty & /*hierarchy*/ + 1 && div6_aria_label_value !== (div6_aria_label_value = /*entity*/ + ctx[15].vaultPath)) { + attr(div6, "aria-label", div6_aria_label_value); + } + if (!/*closed*/ + ctx[5][ + /*entity*/ + ctx[15].title + ]) { + if (if_block1) { + if_block1.p(ctx, dirty); + if (dirty & /*closed, hierarchy*/ + 33) { + transition_in(if_block1, 1); + } + } else { + if_block1 = create_if_block_4(ctx); + if_block1.c(); + transition_in(if_block1, 1); + if_block1.m(div7, t6); + } + } else if (if_block1) { + group_outros(); + transition_out(if_block1, 1, 1, () => { + if_block1 = null; + }); + check_outros(); + } + if (!current || dirty & /*closed, hierarchy*/ + 33) { + toggle_class( + div7, + "is-collapsed", + /*closed*/ + ctx[5][ + /*entity*/ + ctx[15].title + ] + ); + } + }, + i(local) { + if (current) + return; + transition_in(if_block1); + current = true; + }, + o(local) { + transition_out(if_block1); + current = false; + }, + d(detaching) { + if (detaching) { + detach(div7); + } + if_block0.d(); + if (if_block1) + if_block1.d(); + mounted = false; + dispose(); + } + }; +} +function create_if_block7(ctx) { + let div; + let current_block_type_index; + let if_block; + let t; + let current; + const if_block_creators = [create_if_block_13, create_if_block_22, create_if_block_3]; + const if_blocks = []; + function select_block_type_1(ctx2, dirty) { + if ( + /*fileType*/ + ctx2[3] == 0 /* staged */ + ) + return 0; + if ( + /*fileType*/ + ctx2[3] == 1 /* changed */ + ) + return 1; + if ( + /*fileType*/ + ctx2[3] == 2 /* pulled */ + ) + return 2; + return -1; + } + if (~(current_block_type_index = select_block_type_1(ctx, -1))) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + } + return { + c() { + div = element("div"); + if (if_block) + if_block.c(); + t = space(); + }, + m(target, anchor) { + insert(target, div, anchor); + if (~current_block_type_index) { + if_blocks[current_block_type_index].m(div, null); + } + append2(div, t); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type_1(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if (~current_block_type_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } + } else { + if (if_block) { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + } + if (~current_block_type_index) { + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(div, t); + } else { + if_block = null; + } + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + current = true; + }, + o(local) { + transition_out(if_block); + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + if (~current_block_type_index) { + if_blocks[current_block_type_index].d(); + } + } + }; +} +function create_else_block_1(ctx) { + let div0; + let t; + let div1; + let mounted; + let dispose; + function click_handler_1() { + return ( + /*click_handler_1*/ + ctx[12]( + /*entity*/ + ctx[15] + ) + ); + } + function click_handler_2() { + return ( + /*click_handler_2*/ + ctx[13]( + /*entity*/ + ctx[15] + ) + ); + } + return { + c() { + div0 = element("div"); + div0.innerHTML = ``; + t = space(); + div1 = element("div"); + div1.innerHTML = ``; + attr(div0, "data-icon", "undo"); + attr(div0, "aria-label", "Discard"); + attr(div0, "class", "clickable-icon"); + attr(div1, "data-icon", "plus"); + attr(div1, "aria-label", "Stage"); + attr(div1, "class", "clickable-icon"); + }, + m(target, anchor) { + insert(target, div0, anchor); + insert(target, t, anchor); + insert(target, div1, anchor); + if (!mounted) { + dispose = [ + listen(div0, "click", stop_propagation(click_handler_1)), + listen(div1, "click", stop_propagation(click_handler_2)) + ]; + mounted = true; + } + }, + p(new_ctx, dirty) { + ctx = new_ctx; + }, + d(detaching) { + if (detaching) { + detach(div0); + detach(t); + detach(div1); + } + mounted = false; + run_all(dispose); + } + }; +} +function create_if_block_5(ctx) { + let div; + let mounted; + let dispose; + function click_handler() { + return ( + /*click_handler*/ + ctx[11]( + /*entity*/ + ctx[15] + ) + ); + } + return { + c() { + div = element("div"); + div.innerHTML = ``; + attr(div, "data-icon", "minus"); + attr(div, "aria-label", "Unstage"); + attr(div, "class", "clickable-icon"); + }, + m(target, anchor) { + insert(target, div, anchor); + if (!mounted) { + dispose = listen(div, "click", stop_propagation(click_handler)); + mounted = true; + } + }, + p(new_ctx, dirty) { + ctx = new_ctx; + }, + d(detaching) { + if (detaching) { + detach(div); + } + mounted = false; + dispose(); + } + }; +} +function create_if_block_4(ctx) { + let div; + let treecomponent; + let div_transition; + let current; + treecomponent = new TreeComponent({ + props: { + hierarchy: ( + /*entity*/ + ctx[15] + ), + plugin: ( + /*plugin*/ + ctx[1] + ), + view: ( + /*view*/ + ctx[2] + ), + fileType: ( + /*fileType*/ + ctx[3] + ) + } + }); + return { + c() { + div = element("div"); + create_component(treecomponent.$$.fragment); + attr(div, "class", "tree-item-children nav-folder-children"); + }, + m(target, anchor) { + insert(target, div, anchor); + mount_component(treecomponent, div, null); + current = true; + }, + p(ctx2, dirty) { + const treecomponent_changes = {}; + if (dirty & /*hierarchy*/ + 1) + treecomponent_changes.hierarchy = /*entity*/ + ctx2[15]; + if (dirty & /*plugin*/ + 2) + treecomponent_changes.plugin = /*plugin*/ + ctx2[1]; + if (dirty & /*view*/ + 4) + treecomponent_changes.view = /*view*/ + ctx2[2]; + if (dirty & /*fileType*/ + 8) + treecomponent_changes.fileType = /*fileType*/ + ctx2[3]; + treecomponent.$set(treecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(treecomponent.$$.fragment, local); + if (local) { + add_render_callback(() => { + if (!current) + return; + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); + div_transition.run(1); + }); + } + current = true; + }, + o(local) { + transition_out(treecomponent.$$.fragment, local); + if (local) { + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); + div_transition.run(0); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + destroy_component(treecomponent); + if (detaching && div_transition) + div_transition.end(); + } + }; +} +function create_if_block_3(ctx) { + let pulledfilecomponent; + let current; + pulledfilecomponent = new pulledFileComponent_default({ + props: { + change: ( + /*entity*/ + ctx[15].data + ), + view: ( + /*view*/ + ctx[2] + ) + } + }); + return { + c() { + create_component(pulledfilecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(pulledfilecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const pulledfilecomponent_changes = {}; + if (dirty & /*hierarchy*/ + 1) + pulledfilecomponent_changes.change = /*entity*/ + ctx2[15].data; + if (dirty & /*view*/ + 4) + pulledfilecomponent_changes.view = /*view*/ + ctx2[2]; + pulledfilecomponent.$set(pulledfilecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(pulledfilecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(pulledfilecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(pulledfilecomponent, detaching); + } + }; +} +function create_if_block_22(ctx) { + let filecomponent; + let current; + filecomponent = new fileComponent_default({ + props: { + change: ( + /*entity*/ + ctx[15].data + ), + manager: ( + /*plugin*/ + ctx[1].gitManager + ), + view: ( + /*view*/ + ctx[2] + ) + } + }); + return { + c() { + create_component(filecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(filecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const filecomponent_changes = {}; + if (dirty & /*hierarchy*/ + 1) + filecomponent_changes.change = /*entity*/ + ctx2[15].data; + if (dirty & /*plugin*/ + 2) + filecomponent_changes.manager = /*plugin*/ + ctx2[1].gitManager; + if (dirty & /*view*/ + 4) + filecomponent_changes.view = /*view*/ + ctx2[2]; + filecomponent.$set(filecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(filecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(filecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(filecomponent, detaching); + } + }; +} +function create_if_block_13(ctx) { + let stagedfilecomponent; + let current; + stagedfilecomponent = new stagedFileComponent_default({ + props: { + change: ( + /*entity*/ + ctx[15].data + ), + manager: ( + /*plugin*/ + ctx[1].gitManager + ), + view: ( + /*view*/ + ctx[2] + ) + } + }); + return { + c() { + create_component(stagedfilecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(stagedfilecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const stagedfilecomponent_changes = {}; + if (dirty & /*hierarchy*/ + 1) + stagedfilecomponent_changes.change = /*entity*/ + ctx2[15].data; + if (dirty & /*plugin*/ + 2) + stagedfilecomponent_changes.manager = /*plugin*/ + ctx2[1].gitManager; + if (dirty & /*view*/ + 4) + stagedfilecomponent_changes.view = /*view*/ + ctx2[2]; + stagedfilecomponent.$set(stagedfilecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(stagedfilecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(stagedfilecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(stagedfilecomponent, detaching); + } + }; +} +function create_each_block4(ctx) { + let current_block_type_index; + let if_block; + let if_block_anchor; + let current; + const if_block_creators = [create_if_block7, create_else_block3]; + const if_blocks = []; + function select_block_type(ctx2, dirty) { + if ( + /*entity*/ + ctx2[15].data + ) + return 0; + return 1; + } + current_block_type_index = select_block_type(ctx, -1); + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + return { + c() { + if_block.c(); + if_block_anchor = empty(); + }, + m(target, anchor) { + if_blocks[current_block_type_index].m(target, anchor); + insert(target, if_block_anchor, anchor); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } else { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(if_block_anchor.parentNode, if_block_anchor); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + current = true; + }, + o(local) { + transition_out(if_block); + current = false; + }, + d(detaching) { + if (detaching) { + detach(if_block_anchor); + } + if_blocks[current_block_type_index].d(detaching); + } + }; +} +function create_fragment8(ctx) { + let main; + let current; + let each_value = ensure_array_like( + /*hierarchy*/ + ctx[0].children + ); + let each_blocks = []; + for (let i = 0; i < each_value.length; i += 1) { + each_blocks[i] = create_each_block4(get_each_context4(ctx, each_value, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + main = element("main"); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + attr(main, "class", "svelte-hup5mn"); + toggle_class( + main, + "topLevel", + /*topLevel*/ + ctx[4] + ); + }, + m(target, anchor) { + insert(target, main, anchor); + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(main, null); + } + } + current = true; + }, + p(ctx2, [dirty]) { + if (dirty & /*hierarchy, plugin, view, fileType, closed, fold, side, unstage, stage, discard*/ + 2031) { + each_value = ensure_array_like( + /*hierarchy*/ + ctx2[0].children + ); + let i; + for (i = 0; i < each_value.length; i += 1) { + const child_ctx = get_each_context4(ctx2, each_value, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block4(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(main, null); + } + } + group_outros(); + for (i = each_value.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + if (!current || dirty & /*topLevel*/ + 16) { + toggle_class( + main, + "topLevel", + /*topLevel*/ + ctx2[4] + ); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(main); + } + destroy_each(each_blocks, detaching); + } + }; +} +function instance8($$self, $$props, $$invalidate) { + let side; + let { hierarchy } = $$props; + let { plugin } = $$props; + let { view } = $$props; + let { fileType } = $$props; + let { topLevel = false } = $$props; + const closed = {}; + function stage(path2) { + plugin.gitManager.stageAll({ dir: path2 }).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + function unstage(path2) { + plugin.gitManager.unstageAll({ dir: path2 }).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + function discard(item) { + new DiscardModal(view.app, false, item.vaultPath).myOpen().then((shouldDiscard) => { + if (shouldDiscard === true) { + plugin.gitManager.discardAll({ + dir: item.path, + status: plugin.cachedStatus + }).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + }); + } + }); + } + function fold(item) { + $$invalidate(5, closed[item.title] = !closed[item.title], closed); + } + const click_handler = (entity) => unstage(entity.path); + const click_handler_1 = (entity) => discard(entity); + const click_handler_2 = (entity) => stage(entity.path); + const click_handler_3 = (entity) => fold(entity); + $$self.$$set = ($$props2) => { + if ("hierarchy" in $$props2) + $$invalidate(0, hierarchy = $$props2.hierarchy); + if ("plugin" in $$props2) + $$invalidate(1, plugin = $$props2.plugin); + if ("view" in $$props2) + $$invalidate(2, view = $$props2.view); + if ("fileType" in $$props2) + $$invalidate(3, fileType = $$props2.fileType); + if ("topLevel" in $$props2) + $$invalidate(4, topLevel = $$props2.topLevel); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty & /*view*/ + 4) { + $: + $$invalidate(6, side = view.leaf.getRoot().side == "left" ? "right" : "left"); + } + }; + return [ + hierarchy, + plugin, + view, + fileType, + topLevel, + closed, + side, + stage, + unstage, + discard, + fold, + click_handler, + click_handler_1, + click_handler_2, + click_handler_3 + ]; +} +var TreeComponent = class extends SvelteComponent { + constructor(options) { + super(); + init2( + this, + options, + instance8, + create_fragment8, + safe_not_equal, + { + hierarchy: 0, + plugin: 1, + view: 2, + fileType: 3, + topLevel: 4 + }, + add_css7 + ); + } +}; +var treeComponent_default = TreeComponent; + +// src/ui/sourceControl/sourceControl.svelte +function add_css8(target) { + append_styles(target, "svelte-1bvmxec", `.commit-msg-input.svelte-1bvmxec.svelte-1bvmxec{width:100%;overflow:hidden;resize:none;padding:7px 5px;background-color:var(--background-modifier-form-field)}.git-commit-msg.svelte-1bvmxec.svelte-1bvmxec{position:relative;padding:0;width:calc(100% - var(--size-4-8));margin:4px auto}main.svelte-1bvmxec .git-tools .files-count.svelte-1bvmxec{padding-left:var(--size-2-1);width:11px;display:flex;align-items:center;justify-content:center}.nav-folder-title.svelte-1bvmxec.svelte-1bvmxec{align-items:center}.git-commit-msg-clear-button.svelte-1bvmxec.svelte-1bvmxec{position:absolute;background:transparent;border-radius:50%;color:var(--search-clear-button-color);cursor:var(--cursor);top:-4px;right:2px;bottom:0px;line-height:0;height:var(--input-height);width:28px;margin:auto;padding:0 0;text-align:center;display:flex;justify-content:center;align-items:center;transition:color 0.15s ease-in-out}.git-commit-msg-clear-button.svelte-1bvmxec.svelte-1bvmxec:after{content:"";height:var(--search-clear-button-size);width:var(--search-clear-button-size);display:block;background-color:currentColor;-webkit-mask-image:url("data:image/svg+xml,");-webkit-mask-repeat:no-repeat}`); +} +function get_each_context5(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[40] = list[i]; + return child_ctx; +} +function get_each_context_1(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[40] = list[i]; + return child_ctx; +} +function get_each_context_2(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[45] = list[i]; + return child_ctx; +} +function create_if_block_8(ctx) { + let div; + let div_aria_label_value; + let mounted; + let dispose; + return { + c() { + div = element("div"); + attr(div, "class", "git-commit-msg-clear-button svelte-1bvmxec"); + attr(div, "aria-label", div_aria_label_value = "Clear"); + }, + m(target, anchor) { + insert(target, div, anchor); + if (!mounted) { + dispose = listen( + div, + "click", + /*click_handler_1*/ + ctx[33] + ); + mounted = true; + } + }, + p: noop, + d(detaching) { + if (detaching) { + detach(div); + } + mounted = false; + dispose(); + } + }; +} +function create_if_block8(ctx) { + let div18; + let div17; + let div7; + let div6; + let div0; + let t0; + let div1; + let t2; + let div5; + let div3; + let div2; + let t3; + let div4; + let t4_value = ( + /*status*/ + ctx[6].staged.length + "" + ); + let t4; + let t5; + let t6; + let div16; + let div15; + let div8; + let t7; + let div9; + let t9; + let div14; + let div12; + let div10; + let t10; + let div11; + let t11; + let div13; + let t12_value = ( + /*status*/ + ctx[6].changed.length + "" + ); + let t12; + let t13; + let t14; + let current; + let mounted; + let dispose; + let if_block0 = ( + /*stagedOpen*/ + ctx[13] && create_if_block_6(ctx) + ); + let if_block1 = ( + /*changesOpen*/ + ctx[12] && create_if_block_42(ctx) + ); + let if_block2 = ( + /*lastPulledFiles*/ + ctx[7].length > 0 && create_if_block_14(ctx) + ); + return { + c() { + div18 = element("div"); + div17 = element("div"); + div7 = element("div"); + div6 = element("div"); + div0 = element("div"); + div0.innerHTML = ``; + t0 = space(); + div1 = element("div"); + div1.textContent = "Staged Changes"; + t2 = space(); + div5 = element("div"); + div3 = element("div"); + div2 = element("div"); + div2.innerHTML = ``; + t3 = space(); + div4 = element("div"); + t4 = text(t4_value); + t5 = space(); + if (if_block0) + if_block0.c(); + t6 = space(); + div16 = element("div"); + div15 = element("div"); + div8 = element("div"); + div8.innerHTML = ``; + t7 = space(); + div9 = element("div"); + div9.textContent = "Changes"; + t9 = space(); + div14 = element("div"); + div12 = element("div"); + div10 = element("div"); + div10.innerHTML = ``; + t10 = space(); + div11 = element("div"); + div11.innerHTML = ``; + t11 = space(); + div13 = element("div"); + t12 = text(t12_value); + t13 = space(); + if (if_block1) + if_block1.c(); + t14 = space(); + if (if_block2) + if_block2.c(); + attr(div0, "class", "tree-item-icon nav-folder-collapse-indicator collapse-icon"); + toggle_class(div0, "is-collapsed", !/*stagedOpen*/ + ctx[13]); + attr(div1, "class", "tree-item-inner nav-folder-title-content"); + attr(div2, "data-icon", "minus"); + attr(div2, "aria-label", "Unstage"); + attr(div2, "class", "clickable-icon"); + attr(div3, "class", "buttons"); + attr(div4, "class", "files-count svelte-1bvmxec"); + attr(div5, "class", "git-tools"); + attr(div6, "class", "tree-item-self is-clickable nav-folder-title svelte-1bvmxec"); + attr(div7, "class", "staged tree-item nav-folder"); + toggle_class(div7, "is-collapsed", !/*stagedOpen*/ + ctx[13]); + attr(div8, "class", "tree-item-icon nav-folder-collapse-indicator collapse-icon"); + toggle_class(div8, "is-collapsed", !/*changesOpen*/ + ctx[12]); + attr(div9, "class", "tree-item-inner nav-folder-title-content"); + attr(div10, "data-icon", "undo"); + attr(div10, "aria-label", "Discard"); + attr(div10, "class", "clickable-icon"); + attr(div11, "data-icon", "plus"); + attr(div11, "aria-label", "Stage"); + attr(div11, "class", "clickable-icon"); + attr(div12, "class", "buttons"); + attr(div13, "class", "files-count svelte-1bvmxec"); + attr(div14, "class", "git-tools"); + attr(div15, "class", "tree-item-self is-clickable nav-folder-title svelte-1bvmxec"); + attr(div16, "class", "changes tree-item nav-folder"); + toggle_class(div16, "is-collapsed", !/*changesOpen*/ + ctx[12]); + attr(div17, "class", "tree-item-children nav-folder-children"); + attr(div18, "class", "tree-item nav-folder mod-root"); + }, + m(target, anchor) { + insert(target, div18, anchor); + append2(div18, div17); + append2(div17, div7); + append2(div7, div6); + append2(div6, div0); + append2(div6, t0); + append2(div6, div1); + append2(div6, t2); + append2(div6, div5); + append2(div5, div3); + append2(div3, div2); + ctx[34](div2); + append2(div5, t3); + append2(div5, div4); + append2(div4, t4); + append2(div7, t5); + if (if_block0) + if_block0.m(div7, null); + append2(div17, t6); + append2(div17, div16); + append2(div16, div15); + append2(div15, div8); + append2(div15, t7); + append2(div15, div9); + append2(div15, t9); + append2(div15, div14); + append2(div14, div12); + append2(div12, div10); + append2(div12, t10); + append2(div12, div11); + ctx[36](div11); + append2(div14, t11); + append2(div14, div13); + append2(div13, t12); + append2(div16, t13); + if (if_block1) + if_block1.m(div16, null); + append2(div17, t14); + if (if_block2) + if_block2.m(div17, null); + current = true; + if (!mounted) { + dispose = [ + listen(div2, "click", stop_propagation( + /*unstageAll*/ + ctx[19] + )), + listen( + div6, + "click", + /*click_handler_2*/ + ctx[35] + ), + listen(div10, "click", stop_propagation( + /*discard*/ + ctx[22] + )), + listen(div11, "click", stop_propagation( + /*stageAll*/ + ctx[18] + )), + listen( + div15, + "click", + /*click_handler_3*/ + ctx[37] + ) + ]; + mounted = true; + } + }, + p(ctx2, dirty) { + if (!current || dirty[0] & /*stagedOpen*/ + 8192) { + toggle_class(div0, "is-collapsed", !/*stagedOpen*/ + ctx2[13]); + } + if ((!current || dirty[0] & /*status*/ + 64) && t4_value !== (t4_value = /*status*/ + ctx2[6].staged.length + "")) + set_data(t4, t4_value); + if ( + /*stagedOpen*/ + ctx2[13] + ) { + if (if_block0) { + if_block0.p(ctx2, dirty); + if (dirty[0] & /*stagedOpen*/ + 8192) { + transition_in(if_block0, 1); + } + } else { + if_block0 = create_if_block_6(ctx2); + if_block0.c(); + transition_in(if_block0, 1); + if_block0.m(div7, null); + } + } else if (if_block0) { + group_outros(); + transition_out(if_block0, 1, 1, () => { + if_block0 = null; + }); + check_outros(); + } + if (!current || dirty[0] & /*stagedOpen*/ + 8192) { + toggle_class(div7, "is-collapsed", !/*stagedOpen*/ + ctx2[13]); + } + if (!current || dirty[0] & /*changesOpen*/ + 4096) { + toggle_class(div8, "is-collapsed", !/*changesOpen*/ + ctx2[12]); + } + if ((!current || dirty[0] & /*status*/ + 64) && t12_value !== (t12_value = /*status*/ + ctx2[6].changed.length + "")) + set_data(t12, t12_value); + if ( + /*changesOpen*/ + ctx2[12] + ) { + if (if_block1) { + if_block1.p(ctx2, dirty); + if (dirty[0] & /*changesOpen*/ + 4096) { + transition_in(if_block1, 1); + } + } else { + if_block1 = create_if_block_42(ctx2); + if_block1.c(); + transition_in(if_block1, 1); + if_block1.m(div16, null); + } + } else if (if_block1) { + group_outros(); + transition_out(if_block1, 1, 1, () => { + if_block1 = null; + }); + check_outros(); + } + if (!current || dirty[0] & /*changesOpen*/ + 4096) { + toggle_class(div16, "is-collapsed", !/*changesOpen*/ + ctx2[12]); + } + if ( + /*lastPulledFiles*/ + ctx2[7].length > 0 + ) { + if (if_block2) { + if_block2.p(ctx2, dirty); + if (dirty[0] & /*lastPulledFiles*/ + 128) { + transition_in(if_block2, 1); + } + } else { + if_block2 = create_if_block_14(ctx2); + if_block2.c(); + transition_in(if_block2, 1); + if_block2.m(div17, null); + } + } else if (if_block2) { + group_outros(); + transition_out(if_block2, 1, 1, () => { + if_block2 = null; + }); + check_outros(); + } + }, + i(local) { + if (current) + return; + transition_in(if_block0); + transition_in(if_block1); + transition_in(if_block2); + current = true; + }, + o(local) { + transition_out(if_block0); + transition_out(if_block1); + transition_out(if_block2); + current = false; + }, + d(detaching) { + if (detaching) { + detach(div18); + } + ctx[34](null); + if (if_block0) + if_block0.d(); + ctx[36](null); + if (if_block1) + if_block1.d(); + if (if_block2) + if_block2.d(); + mounted = false; + run_all(dispose); + } + }; +} +function create_if_block_6(ctx) { + let div; + let current_block_type_index; + let if_block; + let div_transition; + let current; + const if_block_creators = [create_if_block_7, create_else_block_2]; + const if_blocks = []; + function select_block_type(ctx2, dirty) { + if ( + /*showTree*/ + ctx2[3] + ) + return 0; + return 1; + } + current_block_type_index = select_block_type(ctx, [-1, -1]); + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + return { + c() { + div = element("div"); + if_block.c(); + attr(div, "class", "tree-item-children nav-folder-children"); + }, + m(target, anchor) { + insert(target, div, anchor); + if_blocks[current_block_type_index].m(div, null); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } else { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(div, null); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + if (local) { + add_render_callback(() => { + if (!current) + return; + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); + div_transition.run(1); + }); + } + current = true; + }, + o(local) { + transition_out(if_block); + if (local) { + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); + div_transition.run(0); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + if_blocks[current_block_type_index].d(); + if (detaching && div_transition) + div_transition.end(); + } + }; +} +function create_else_block_2(ctx) { + let each_1_anchor; + let current; + let each_value_2 = ensure_array_like( + /*status*/ + ctx[6].staged + ); + let each_blocks = []; + for (let i = 0; i < each_value_2.length; i += 1) { + each_blocks[i] = create_each_block_2(get_each_context_2(ctx, each_value_2, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + each_1_anchor = empty(); + }, + m(target, anchor) { + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(target, anchor); + } + } + insert(target, each_1_anchor, anchor); + current = true; + }, + p(ctx2, dirty) { + if (dirty[0] & /*status, view, plugin*/ + 67) { + each_value_2 = ensure_array_like( + /*status*/ + ctx2[6].staged + ); + let i; + for (i = 0; i < each_value_2.length; i += 1) { + const child_ctx = get_each_context_2(ctx2, each_value_2, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block_2(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(each_1_anchor.parentNode, each_1_anchor); + } + } + group_outros(); + for (i = each_value_2.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value_2.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(each_1_anchor); + } + destroy_each(each_blocks, detaching); + } + }; +} +function create_if_block_7(ctx) { + let treecomponent; + let current; + treecomponent = new treeComponent_default({ + props: { + hierarchy: ( + /*stagedHierarchy*/ + ctx[10] + ), + plugin: ( + /*plugin*/ + ctx[0] + ), + view: ( + /*view*/ + ctx[1] + ), + fileType: 0 /* staged */, + topLevel: true + } + }); + return { + c() { + create_component(treecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(treecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const treecomponent_changes = {}; + if (dirty[0] & /*stagedHierarchy*/ + 1024) + treecomponent_changes.hierarchy = /*stagedHierarchy*/ + ctx2[10]; + if (dirty[0] & /*plugin*/ + 1) + treecomponent_changes.plugin = /*plugin*/ + ctx2[0]; + if (dirty[0] & /*view*/ + 2) + treecomponent_changes.view = /*view*/ + ctx2[1]; + treecomponent.$set(treecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(treecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(treecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(treecomponent, detaching); + } + }; +} +function create_each_block_2(ctx) { + let stagedfilecomponent; + let current; + stagedfilecomponent = new stagedFileComponent_default({ + props: { + change: ( + /*stagedFile*/ + ctx[45] + ), + view: ( + /*view*/ + ctx[1] + ), + manager: ( + /*plugin*/ + ctx[0].gitManager + ) + } + }); + return { + c() { + create_component(stagedfilecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(stagedfilecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const stagedfilecomponent_changes = {}; + if (dirty[0] & /*status*/ + 64) + stagedfilecomponent_changes.change = /*stagedFile*/ + ctx2[45]; + if (dirty[0] & /*view*/ + 2) + stagedfilecomponent_changes.view = /*view*/ + ctx2[1]; + if (dirty[0] & /*plugin*/ + 1) + stagedfilecomponent_changes.manager = /*plugin*/ + ctx2[0].gitManager; + stagedfilecomponent.$set(stagedfilecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(stagedfilecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(stagedfilecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(stagedfilecomponent, detaching); + } + }; +} +function create_if_block_42(ctx) { + let div; + let current_block_type_index; + let if_block; + let div_transition; + let current; + const if_block_creators = [create_if_block_52, create_else_block_12]; + const if_blocks = []; + function select_block_type_1(ctx2, dirty) { + if ( + /*showTree*/ + ctx2[3] + ) + return 0; + return 1; + } + current_block_type_index = select_block_type_1(ctx, [-1, -1]); + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + return { + c() { + div = element("div"); + if_block.c(); + attr(div, "class", "tree-item-children nav-folder-children"); + }, + m(target, anchor) { + insert(target, div, anchor); + if_blocks[current_block_type_index].m(div, null); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type_1(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } else { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(div, null); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + if (local) { + add_render_callback(() => { + if (!current) + return; + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); + div_transition.run(1); + }); + } + current = true; + }, + o(local) { + transition_out(if_block); + if (local) { + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); + div_transition.run(0); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + if_blocks[current_block_type_index].d(); + if (detaching && div_transition) + div_transition.end(); + } + }; +} +function create_else_block_12(ctx) { + let each_1_anchor; + let current; + let each_value_1 = ensure_array_like( + /*status*/ + ctx[6].changed + ); + let each_blocks = []; + for (let i = 0; i < each_value_1.length; i += 1) { + each_blocks[i] = create_each_block_1(get_each_context_1(ctx, each_value_1, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + each_1_anchor = empty(); + }, + m(target, anchor) { + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(target, anchor); + } + } + insert(target, each_1_anchor, anchor); + current = true; + }, + p(ctx2, dirty) { + if (dirty[0] & /*status, view, plugin*/ + 67) { + each_value_1 = ensure_array_like( + /*status*/ + ctx2[6].changed + ); + let i; + for (i = 0; i < each_value_1.length; i += 1) { + const child_ctx = get_each_context_1(ctx2, each_value_1, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block_1(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(each_1_anchor.parentNode, each_1_anchor); + } + } + group_outros(); + for (i = each_value_1.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value_1.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(each_1_anchor); + } + destroy_each(each_blocks, detaching); + } + }; +} +function create_if_block_52(ctx) { + let treecomponent; + let current; + treecomponent = new treeComponent_default({ + props: { + hierarchy: ( + /*changeHierarchy*/ + ctx[9] + ), + plugin: ( + /*plugin*/ + ctx[0] + ), + view: ( + /*view*/ + ctx[1] + ), + fileType: 1 /* changed */, + topLevel: true + } + }); + return { + c() { + create_component(treecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(treecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const treecomponent_changes = {}; + if (dirty[0] & /*changeHierarchy*/ + 512) + treecomponent_changes.hierarchy = /*changeHierarchy*/ + ctx2[9]; + if (dirty[0] & /*plugin*/ + 1) + treecomponent_changes.plugin = /*plugin*/ + ctx2[0]; + if (dirty[0] & /*view*/ + 2) + treecomponent_changes.view = /*view*/ + ctx2[1]; + treecomponent.$set(treecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(treecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(treecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(treecomponent, detaching); + } + }; +} +function create_each_block_1(ctx) { + let filecomponent; + let current; + filecomponent = new fileComponent_default({ + props: { + change: ( + /*change*/ + ctx[40] + ), + view: ( + /*view*/ + ctx[1] + ), + manager: ( + /*plugin*/ + ctx[0].gitManager + ) + } + }); + filecomponent.$on("git-refresh", triggerRefresh2); + return { + c() { + create_component(filecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(filecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const filecomponent_changes = {}; + if (dirty[0] & /*status*/ + 64) + filecomponent_changes.change = /*change*/ + ctx2[40]; + if (dirty[0] & /*view*/ + 2) + filecomponent_changes.view = /*view*/ + ctx2[1]; + if (dirty[0] & /*plugin*/ + 1) + filecomponent_changes.manager = /*plugin*/ + ctx2[0].gitManager; + filecomponent.$set(filecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(filecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(filecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(filecomponent, detaching); + } + }; +} +function create_if_block_14(ctx) { + let div3; + let div2; + let div0; + let t0; + let div1; + let t2; + let span; + let t3_value = ( + /*lastPulledFiles*/ + ctx[7].length + "" + ); + let t3; + let t4; + let current; + let mounted; + let dispose; + let if_block = ( + /*lastPulledFilesOpen*/ + ctx[14] && create_if_block_23(ctx) + ); + return { + c() { + div3 = element("div"); + div2 = element("div"); + div0 = element("div"); + div0.innerHTML = ``; + t0 = space(); + div1 = element("div"); + div1.textContent = "Recently Pulled Files"; + t2 = space(); + span = element("span"); + t3 = text(t3_value); + t4 = space(); + if (if_block) + if_block.c(); + attr(div0, "class", "tree-item-icon nav-folder-collapse-indicator collapse-icon"); + attr(div1, "class", "tree-item-inner nav-folder-title-content"); + attr(span, "class", "tree-item-flair"); + attr(div2, "class", "tree-item-self is-clickable nav-folder-title svelte-1bvmxec"); + attr(div3, "class", "pulled nav-folder"); + toggle_class(div3, "is-collapsed", !/*lastPulledFilesOpen*/ + ctx[14]); + }, + m(target, anchor) { + insert(target, div3, anchor); + append2(div3, div2); + append2(div2, div0); + append2(div2, t0); + append2(div2, div1); + append2(div2, t2); + append2(div2, span); + append2(span, t3); + append2(div3, t4); + if (if_block) + if_block.m(div3, null); + current = true; + if (!mounted) { + dispose = listen( + div2, + "click", + /*click_handler_4*/ + ctx[38] + ); + mounted = true; + } + }, + p(ctx2, dirty) { + if ((!current || dirty[0] & /*lastPulledFiles*/ + 128) && t3_value !== (t3_value = /*lastPulledFiles*/ + ctx2[7].length + "")) + set_data(t3, t3_value); + if ( + /*lastPulledFilesOpen*/ + ctx2[14] + ) { + if (if_block) { + if_block.p(ctx2, dirty); + if (dirty[0] & /*lastPulledFilesOpen*/ + 16384) { + transition_in(if_block, 1); + } + } else { + if_block = create_if_block_23(ctx2); + if_block.c(); + transition_in(if_block, 1); + if_block.m(div3, null); + } + } else if (if_block) { + group_outros(); + transition_out(if_block, 1, 1, () => { + if_block = null; + }); + check_outros(); + } + if (!current || dirty[0] & /*lastPulledFilesOpen*/ + 16384) { + toggle_class(div3, "is-collapsed", !/*lastPulledFilesOpen*/ + ctx2[14]); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + current = true; + }, + o(local) { + transition_out(if_block); + current = false; + }, + d(detaching) { + if (detaching) { + detach(div3); + } + if (if_block) + if_block.d(); + mounted = false; + dispose(); + } + }; +} +function create_if_block_23(ctx) { + let div; + let current_block_type_index; + let if_block; + let div_transition; + let current; + const if_block_creators = [create_if_block_32, create_else_block4]; + const if_blocks = []; + function select_block_type_2(ctx2, dirty) { + if ( + /*showTree*/ + ctx2[3] + ) + return 0; + return 1; + } + current_block_type_index = select_block_type_2(ctx, [-1, -1]); + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx); + return { + c() { + div = element("div"); + if_block.c(); + attr(div, "class", "tree-item-children nav-folder-children"); + }, + m(target, anchor) { + insert(target, div, anchor); + if_blocks[current_block_type_index].m(div, null); + current = true; + }, + p(ctx2, dirty) { + let previous_block_index = current_block_type_index; + current_block_type_index = select_block_type_2(ctx2, dirty); + if (current_block_type_index === previous_block_index) { + if_blocks[current_block_type_index].p(ctx2, dirty); + } else { + group_outros(); + transition_out(if_blocks[previous_block_index], 1, 1, () => { + if_blocks[previous_block_index] = null; + }); + check_outros(); + if_block = if_blocks[current_block_type_index]; + if (!if_block) { + if_block = if_blocks[current_block_type_index] = if_block_creators[current_block_type_index](ctx2); + if_block.c(); + } else { + if_block.p(ctx2, dirty); + } + transition_in(if_block, 1); + if_block.m(div, null); + } + }, + i(local) { + if (current) + return; + transition_in(if_block); + if (local) { + add_render_callback(() => { + if (!current) + return; + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, true); + div_transition.run(1); + }); + } + current = true; + }, + o(local) { + transition_out(if_block); + if (local) { + if (!div_transition) + div_transition = create_bidirectional_transition(div, slide, { duration: 150 }, false); + div_transition.run(0); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(div); + } + if_blocks[current_block_type_index].d(); + if (detaching && div_transition) + div_transition.end(); + } + }; +} +function create_else_block4(ctx) { + let each_1_anchor; + let current; + let each_value = ensure_array_like( + /*lastPulledFiles*/ + ctx[7] + ); + let each_blocks = []; + for (let i = 0; i < each_value.length; i += 1) { + each_blocks[i] = create_each_block5(get_each_context5(ctx, each_value, i)); + } + const out = (i) => transition_out(each_blocks[i], 1, 1, () => { + each_blocks[i] = null; + }); + return { + c() { + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + each_1_anchor = empty(); + }, + m(target, anchor) { + for (let i = 0; i < each_blocks.length; i += 1) { + if (each_blocks[i]) { + each_blocks[i].m(target, anchor); + } + } + insert(target, each_1_anchor, anchor); + current = true; + }, + p(ctx2, dirty) { + if (dirty[0] & /*lastPulledFiles, view*/ + 130) { + each_value = ensure_array_like( + /*lastPulledFiles*/ + ctx2[7] + ); + let i; + for (i = 0; i < each_value.length; i += 1) { + const child_ctx = get_each_context5(ctx2, each_value, i); + if (each_blocks[i]) { + each_blocks[i].p(child_ctx, dirty); + transition_in(each_blocks[i], 1); + } else { + each_blocks[i] = create_each_block5(child_ctx); + each_blocks[i].c(); + transition_in(each_blocks[i], 1); + each_blocks[i].m(each_1_anchor.parentNode, each_1_anchor); + } + } + group_outros(); + for (i = each_value.length; i < each_blocks.length; i += 1) { + out(i); + } + check_outros(); + } + }, + i(local) { + if (current) + return; + for (let i = 0; i < each_value.length; i += 1) { + transition_in(each_blocks[i]); + } + current = true; + }, + o(local) { + each_blocks = each_blocks.filter(Boolean); + for (let i = 0; i < each_blocks.length; i += 1) { + transition_out(each_blocks[i]); + } + current = false; + }, + d(detaching) { + if (detaching) { + detach(each_1_anchor); + } + destroy_each(each_blocks, detaching); + } + }; +} +function create_if_block_32(ctx) { + let treecomponent; + let current; + treecomponent = new treeComponent_default({ + props: { + hierarchy: ( + /*lastPulledFilesHierarchy*/ + ctx[11] + ), + plugin: ( + /*plugin*/ + ctx[0] + ), + view: ( + /*view*/ + ctx[1] + ), + fileType: 2 /* pulled */, + topLevel: true + } + }); + return { + c() { + create_component(treecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(treecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const treecomponent_changes = {}; + if (dirty[0] & /*lastPulledFilesHierarchy*/ + 2048) + treecomponent_changes.hierarchy = /*lastPulledFilesHierarchy*/ + ctx2[11]; + if (dirty[0] & /*plugin*/ + 1) + treecomponent_changes.plugin = /*plugin*/ + ctx2[0]; + if (dirty[0] & /*view*/ + 2) + treecomponent_changes.view = /*view*/ + ctx2[1]; + treecomponent.$set(treecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(treecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(treecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(treecomponent, detaching); + } + }; +} +function create_each_block5(ctx) { + let pulledfilecomponent; + let current; + pulledfilecomponent = new pulledFileComponent_default({ + props: { + change: ( + /*change*/ + ctx[40] + ), + view: ( + /*view*/ + ctx[1] + ) + } + }); + pulledfilecomponent.$on("git-refresh", triggerRefresh2); + return { + c() { + create_component(pulledfilecomponent.$$.fragment); + }, + m(target, anchor) { + mount_component(pulledfilecomponent, target, anchor); + current = true; + }, + p(ctx2, dirty) { + const pulledfilecomponent_changes = {}; + if (dirty[0] & /*lastPulledFiles*/ + 128) + pulledfilecomponent_changes.change = /*change*/ + ctx2[40]; + if (dirty[0] & /*view*/ + 2) + pulledfilecomponent_changes.view = /*view*/ + ctx2[1]; + pulledfilecomponent.$set(pulledfilecomponent_changes); + }, + i(local) { + if (current) + return; + transition_in(pulledfilecomponent.$$.fragment, local); + current = true; + }, + o(local) { + transition_out(pulledfilecomponent.$$.fragment, local); + current = false; + }, + d(detaching) { + destroy_component(pulledfilecomponent, detaching); + } + }; +} +function create_fragment9(ctx) { + let main; + let div9; + let div8; + let div0; + let t0; + let div1; + let t1; + let div2; + let t2; + let div3; + let t3; + let div4; + let t4; + let div5; + let t5; + let div6; + let t6; + let div7; + let t7; + let div10; + let textarea; + let t8; + let t9; + let div11; + let main_data_type_value; + let current; + let mounted; + let dispose; + let if_block0 = ( + /*commitMessage*/ + ctx[2] && create_if_block_8(ctx) + ); + let if_block1 = ( + /*status*/ + ctx[6] && /*stagedHierarchy*/ + ctx[10] && /*changeHierarchy*/ + ctx[9] && create_if_block8(ctx) + ); + return { + c() { + main = element("main"); + div9 = element("div"); + div8 = element("div"); + div0 = element("div"); + t0 = space(); + div1 = element("div"); + t1 = space(); + div2 = element("div"); + t2 = space(); + div3 = element("div"); + t3 = space(); + div4 = element("div"); + t4 = space(); + div5 = element("div"); + t5 = space(); + div6 = element("div"); + t6 = space(); + div7 = element("div"); + t7 = space(); + div10 = element("div"); + textarea = element("textarea"); + t8 = space(); + if (if_block0) + if_block0.c(); + t9 = space(); + div11 = element("div"); + if (if_block1) + if_block1.c(); + attr(div0, "id", "backup-btn"); + attr(div0, "data-icon", "arrow-up-circle"); + attr(div0, "class", "clickable-icon nav-action-button"); + attr(div0, "aria-label", "Backup"); + attr(div1, "id", "commit-btn"); + attr(div1, "data-icon", "check"); + attr(div1, "class", "clickable-icon nav-action-button"); + attr(div1, "aria-label", "Commit"); + attr(div2, "id", "stage-all"); + attr(div2, "class", "clickable-icon nav-action-button"); + attr(div2, "data-icon", "plus-circle"); + attr(div2, "aria-label", "Stage all"); + attr(div3, "id", "unstage-all"); + attr(div3, "class", "clickable-icon nav-action-button"); + attr(div3, "data-icon", "minus-circle"); + attr(div3, "aria-label", "Unstage all"); + attr(div4, "id", "push"); + attr(div4, "class", "clickable-icon nav-action-button"); + attr(div4, "data-icon", "upload"); + attr(div4, "aria-label", "Push"); + attr(div5, "id", "pull"); + attr(div5, "class", "clickable-icon nav-action-button"); + attr(div5, "data-icon", "download"); + attr(div5, "aria-label", "Pull"); + attr(div6, "id", "layoutChange"); + attr(div6, "class", "clickable-icon nav-action-button"); + attr(div6, "aria-label", "Change Layout"); + attr(div7, "id", "refresh"); + attr(div7, "class", "clickable-icon nav-action-button"); + attr(div7, "data-icon", "refresh-cw"); + attr(div7, "aria-label", "Refresh"); + set_style(div7, "margin", "1px"); + toggle_class( + div7, + "loading", + /*loading*/ + ctx[5] + ); + attr(div8, "class", "nav-buttons-container"); + attr(div9, "class", "nav-header"); + attr( + textarea, + "rows", + /*rows*/ + ctx[15] + ); + attr(textarea, "class", "commit-msg-input svelte-1bvmxec"); + attr(textarea, "spellcheck", "true"); + attr(textarea, "placeholder", "Commit Message"); + attr(div10, "class", "git-commit-msg svelte-1bvmxec"); + attr(div11, "class", "nav-files-container"); + set_style(div11, "position", "relative"); + attr(main, "data-type", main_data_type_value = SOURCE_CONTROL_VIEW_CONFIG.type); + attr(main, "class", "svelte-1bvmxec"); + }, + m(target, anchor) { + insert(target, main, anchor); + append2(main, div9); + append2(div9, div8); + append2(div8, div0); + ctx[23](div0); + append2(div8, t0); + append2(div8, div1); + ctx[24](div1); + append2(div8, t1); + append2(div8, div2); + ctx[25](div2); + append2(div8, t2); + append2(div8, div3); + ctx[26](div3); + append2(div8, t3); + append2(div8, div4); + ctx[27](div4); + append2(div8, t4); + append2(div8, div5); + ctx[28](div5); + append2(div8, t5); + append2(div8, div6); + ctx[29](div6); + append2(div8, t6); + append2(div8, div7); + ctx[31](div7); + append2(main, t7); + append2(main, div10); + append2(div10, textarea); + set_input_value( + textarea, + /*commitMessage*/ + ctx[2] + ); + append2(div10, t8); + if (if_block0) + if_block0.m(div10, null); + append2(main, t9); + append2(main, div11); + if (if_block1) + if_block1.m(div11, null); + current = true; + if (!mounted) { + dispose = [ + listen( + div0, + "click", + /*backup*/ + ctx[17] + ), + listen( + div1, + "click", + /*commit*/ + ctx[16] + ), + listen( + div2, + "click", + /*stageAll*/ + ctx[18] + ), + listen( + div3, + "click", + /*unstageAll*/ + ctx[19] + ), + listen( + div4, + "click", + /*push*/ + ctx[20] + ), + listen( + div5, + "click", + /*pull*/ + ctx[21] + ), + listen( + div6, + "click", + /*click_handler*/ + ctx[30] + ), + listen(div7, "click", triggerRefresh2), + listen( + textarea, + "input", + /*textarea_input_handler*/ + ctx[32] + ) + ]; + mounted = true; + } + }, + p(ctx2, dirty) { + if (!current || dirty[0] & /*loading*/ + 32) { + toggle_class( + div7, + "loading", + /*loading*/ + ctx2[5] + ); + } + if (!current || dirty[0] & /*rows*/ + 32768) { + attr( + textarea, + "rows", + /*rows*/ + ctx2[15] + ); + } + if (dirty[0] & /*commitMessage*/ + 4) { + set_input_value( + textarea, + /*commitMessage*/ + ctx2[2] + ); + } + if ( + /*commitMessage*/ + ctx2[2] + ) { + if (if_block0) { + if_block0.p(ctx2, dirty); + } else { + if_block0 = create_if_block_8(ctx2); + if_block0.c(); + if_block0.m(div10, null); + } + } else if (if_block0) { + if_block0.d(1); + if_block0 = null; + } + if ( + /*status*/ + ctx2[6] && /*stagedHierarchy*/ + ctx2[10] && /*changeHierarchy*/ + ctx2[9] + ) { + if (if_block1) { + if_block1.p(ctx2, dirty); + if (dirty[0] & /*status, stagedHierarchy, changeHierarchy*/ + 1600) { + transition_in(if_block1, 1); + } + } else { + if_block1 = create_if_block8(ctx2); + if_block1.c(); + transition_in(if_block1, 1); + if_block1.m(div11, null); + } + } else if (if_block1) { + group_outros(); + transition_out(if_block1, 1, 1, () => { + if_block1 = null; + }); + check_outros(); + } + }, + i(local) { + if (current) + return; + transition_in(if_block1); + current = true; + }, + o(local) { + transition_out(if_block1); + current = false; + }, + d(detaching) { + if (detaching) { + detach(main); + } + ctx[23](null); + ctx[24](null); + ctx[25](null); + ctx[26](null); + ctx[27](null); + ctx[28](null); + ctx[29](null); + ctx[31](null); + if (if_block0) + if_block0.d(); + if (if_block1) + if_block1.d(); + mounted = false; + run_all(dispose); + } + }; +} +function triggerRefresh2() { + dispatchEvent(new CustomEvent("git-refresh")); +} +function instance9($$self, $$props, $$invalidate) { + let rows; + let { plugin } = $$props; + let { view } = $$props; + let loading; + let status2; + let lastPulledFiles = []; + let commitMessage = plugin.settings.commitMessage; + let buttons = []; + let changeHierarchy; + let stagedHierarchy; + let lastPulledFilesHierarchy; + let changesOpen = true; + let stagedOpen = true; + let lastPulledFilesOpen = true; + let showTree = plugin.settings.treeStructure; + let layoutBtn; + addEventListener("git-view-refresh", refresh); + plugin.app.workspace.onLayoutReady(() => { + window.setTimeout( + () => { + buttons.forEach((btn) => (0, import_obsidian28.setIcon)(btn, btn.getAttr("data-icon"))); + (0, import_obsidian28.setIcon)(layoutBtn, showTree ? "list" : "folder"); + }, + 0 + ); + }); + onDestroy(() => { + removeEventListener("git-view-refresh", refresh); + }); + function commit2() { + return __awaiter(this, void 0, void 0, function* () { + $$invalidate(5, loading = true); + if (status2) { + if (yield plugin.hasTooBigFiles(status2.staged)) { + plugin.setState(0 /* idle */); + return false; + } + plugin.promiseQueue.addTask(() => plugin.gitManager.commit(commitMessage).then(() => { + if (commitMessage !== plugin.settings.commitMessage) { + $$invalidate(2, commitMessage = ""); + } + plugin.setUpAutoBackup(); + }).finally(triggerRefresh2)); + } + }); + } + function backup() { + return __awaiter(this, void 0, void 0, function* () { + $$invalidate(5, loading = true); + if (status2) { + plugin.promiseQueue.addTask(() => plugin.createBackup(false, false, commitMessage).then(() => { + if (commitMessage !== plugin.settings.commitMessage) { + $$invalidate(2, commitMessage = ""); + } + }).finally(triggerRefresh2)); + } + }); + } + function refresh() { + return __awaiter(this, void 0, void 0, function* () { + if (!plugin.gitReady) { + $$invalidate(6, status2 = void 0); + return; + } + const unPushedCommits = yield plugin.gitManager.getUnpushedCommits(); + buttons.forEach((btn) => { + var _a2, _b; + if (import_obsidian28.Platform.isMobile) { + btn.removeClass("button-border"); + if (btn.id == "push" && unPushedCommits > 0) { + btn.addClass("button-border"); + } + } else { + (_a2 = btn.firstElementChild) === null || _a2 === void 0 ? void 0 : _a2.removeAttribute("color"); + if (btn.id == "push" && unPushedCommits > 0) { + (_b = btn.firstElementChild) === null || _b === void 0 ? void 0 : _b.setAttr("color", "var(--text-accent)"); + } + } + }); + $$invalidate(6, status2 = plugin.cachedStatus); + if (plugin.lastPulledFiles && plugin.lastPulledFiles != lastPulledFiles) { + $$invalidate(7, lastPulledFiles = plugin.lastPulledFiles); + $$invalidate(11, lastPulledFilesHierarchy = { + title: "", + path: "", + vaultPath: "", + children: plugin.gitManager.getTreeStructure(lastPulledFiles) + }); + } + if (status2) { + const sort = (a, b) => { + return a.vault_path.split("/").last().localeCompare(getDisplayPath(b.vault_path)); + }; + status2.changed.sort(sort); + status2.staged.sort(sort); + if (status2.changed.length + status2.staged.length > 500) { + $$invalidate(6, status2 = void 0); + if (!plugin.loading) { + plugin.displayError("Too many changes to display"); + } + } else { + $$invalidate(9, changeHierarchy = { + title: "", + path: "", + vaultPath: "", + children: plugin.gitManager.getTreeStructure(status2.changed) + }); + $$invalidate(10, stagedHierarchy = { + title: "", + path: "", + vaultPath: "", + children: plugin.gitManager.getTreeStructure(status2.staged) + }); + } + } else { + $$invalidate(9, changeHierarchy = void 0); + $$invalidate(10, stagedHierarchy = void 0); + } + $$invalidate(5, loading = plugin.loading); + }); + } + function stageAll() { + $$invalidate(5, loading = true); + plugin.promiseQueue.addTask(() => plugin.gitManager.stageAll({ status: status2 }).finally(triggerRefresh2)); + } + function unstageAll() { + $$invalidate(5, loading = true); + plugin.promiseQueue.addTask(() => plugin.gitManager.unstageAll({ status: status2 }).finally(triggerRefresh2)); + } + function push2() { + $$invalidate(5, loading = true); + plugin.promiseQueue.addTask(() => plugin.push().finally(triggerRefresh2)); + } + function pull2() { + $$invalidate(5, loading = true); + plugin.promiseQueue.addTask(() => plugin.pullChangesFromRemote().finally(triggerRefresh2)); + } + function discard() { + new DiscardModal(view.app, false, plugin.gitManager.getVaultPath("/")).myOpen().then((shouldDiscard) => { + if (shouldDiscard === true) { + plugin.promiseQueue.addTask(() => plugin.gitManager.discardAll({ status: plugin.cachedStatus }).finally(() => { + dispatchEvent(new CustomEvent("git-refresh")); + })); + } + }); + } + function div0_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[5] = $$value; + $$invalidate(8, buttons); + }); + } + function div1_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[0] = $$value; + $$invalidate(8, buttons); + }); + } + function div2_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[1] = $$value; + $$invalidate(8, buttons); + }); + } + function div3_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[2] = $$value; + $$invalidate(8, buttons); + }); + } + function div4_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[3] = $$value; + $$invalidate(8, buttons); + }); + } + function div5_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[4] = $$value; + $$invalidate(8, buttons); + }); + } + function div6_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + layoutBtn = $$value; + $$invalidate(4, layoutBtn); + }); + } + const click_handler = () => { + $$invalidate(3, showTree = !showTree); + $$invalidate(0, plugin.settings.treeStructure = showTree, plugin); + plugin.saveSettings(); + }; + function div7_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[6] = $$value; + $$invalidate(8, buttons); + }); + } + function textarea_input_handler() { + commitMessage = this.value; + $$invalidate(2, commitMessage); + } + const click_handler_1 = () => $$invalidate(2, commitMessage = ""); + function div2_binding_1($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[8] = $$value; + $$invalidate(8, buttons); + }); + } + const click_handler_2 = () => $$invalidate(13, stagedOpen = !stagedOpen); + function div11_binding($$value) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + buttons[9] = $$value; + $$invalidate(8, buttons); + }); + } + const click_handler_3 = () => $$invalidate(12, changesOpen = !changesOpen); + const click_handler_4 = () => $$invalidate(14, lastPulledFilesOpen = !lastPulledFilesOpen); + $$self.$$set = ($$props2) => { + if ("plugin" in $$props2) + $$invalidate(0, plugin = $$props2.plugin); + if ("view" in $$props2) + $$invalidate(1, view = $$props2.view); + }; + $$self.$$.update = () => { + if ($$self.$$.dirty[0] & /*layoutBtn, showTree*/ + 24) { + $: { + if (layoutBtn) { + layoutBtn.empty(); + (0, import_obsidian28.setIcon)(layoutBtn, showTree ? "list" : "folder"); + } + } + } + if ($$self.$$.dirty[0] & /*commitMessage*/ + 4) { + $: + $$invalidate(15, rows = (commitMessage.match(/\n/g) || []).length + 1 || 1); + } + }; + return [ + plugin, + view, + commitMessage, + showTree, + layoutBtn, + loading, + status2, + lastPulledFiles, + buttons, + changeHierarchy, + stagedHierarchy, + lastPulledFilesHierarchy, + changesOpen, + stagedOpen, + lastPulledFilesOpen, + rows, + commit2, + backup, + stageAll, + unstageAll, + push2, + pull2, + discard, + div0_binding, + div1_binding, + div2_binding, + div3_binding, + div4_binding, + div5_binding, + div6_binding, + click_handler, + div7_binding, + textarea_input_handler, + click_handler_1, + div2_binding_1, + click_handler_2, + div11_binding, + click_handler_3, + click_handler_4 + ]; +} +var SourceControl = class extends SvelteComponent { + constructor(options) { + super(); + init2(this, options, instance9, create_fragment9, safe_not_equal, { plugin: 0, view: 1 }, add_css8, [-1, -1]); + } +}; +var sourceControl_default = SourceControl; + +// src/ui/sourceControl/sourceControl.ts +var GitView = class extends import_obsidian29.ItemView { + constructor(leaf, plugin) { + super(leaf); + this.plugin = plugin; + this.hoverPopover = null; + } + getViewType() { + return SOURCE_CONTROL_VIEW_CONFIG.type; + } + getDisplayText() { + return SOURCE_CONTROL_VIEW_CONFIG.name; + } + getIcon() { + return SOURCE_CONTROL_VIEW_CONFIG.icon; + } + onClose() { + return super.onClose(); + } + onOpen() { + this._view = new sourceControl_default({ + target: this.contentEl, + props: { + plugin: this.plugin, + view: this + } + }); + return super.onOpen(); + } +}; + +// src/ui/statusBar/branchStatusBar.ts +init_polyfill_buffer(); +var BranchStatusBar = class { + constructor(statusBarEl, plugin) { + this.statusBarEl = statusBarEl; + this.plugin = plugin; + this.statusBarEl.addClass("mod-clickable"); + this.statusBarEl.onClickEvent((e) => { + this.plugin.switchBranch(); + }); + } + async display() { + if (this.plugin.gitReady) { + const branchInfo = await this.plugin.gitManager.branchInfo(); + if (branchInfo.current != void 0) { + this.statusBarEl.setText(branchInfo.current); + } else { + this.statusBarEl.empty(); + } + } else { + this.statusBarEl.empty(); + } + } +}; + +// src/main.ts +var ObsidianGit = class extends import_obsidian30.Plugin { + constructor() { + super(...arguments); + this.gitReady = false; + this.promiseQueue = new PromiseQueue(); + this.conflictOutputFile = "conflict-files-obsidian-git.md"; + this.offlineMode = false; + this.loading = false; + this.lineAuthoringFeature = new LineAuthoringFeature(this); + } + setState(state) { + var _a2; + this.state = state; + (_a2 = this.statusBar) == null ? void 0 : _a2.display(); + } + async updateCachedStatus() { + this.cachedStatus = await this.gitManager.status(); + return this.cachedStatus; + } + async refresh() { + const gitView = this.app.workspace.getLeavesOfType( + SOURCE_CONTROL_VIEW_CONFIG.type + ); + const historyView = this.app.workspace.getLeavesOfType( + HISTORY_VIEW_CONFIG.type + ); + if (this.settings.changedFilesInStatusBar || gitView.length > 0 || historyView.length > 0) { + this.loading = true; + dispatchEvent(new CustomEvent("git-view-refresh")); + await this.updateCachedStatus(); + this.loading = false; + dispatchEvent(new CustomEvent("git-view-refresh")); + } + } + async refreshUpdatedHead() { + this.lineAuthoringFeature.refreshLineAuthorViews(); + } + async onload() { + console.log("loading " + this.manifest.name + " plugin"); + pluginRef.plugin = this; + this.localStorage = new LocalStorageSettings(this); + this.localStorage.migrate(); + await this.loadSettings(); + this.migrateSettings(); + this.settingsTab = new ObsidianGitSettingsTab(this.app, this); + this.addSettingTab(this.settingsTab); + if (!this.localStorage.getPluginDisabled()) { + this.loadPlugin(); + } + } + async loadPlugin() { + addEventListener("git-refresh", this.refresh.bind(this)); + addEventListener("git-head-update", this.refreshUpdatedHead.bind(this)); + this.registerView(SOURCE_CONTROL_VIEW_CONFIG.type, (leaf) => { + return new GitView(leaf, this); + }); + this.registerView(HISTORY_VIEW_CONFIG.type, (leaf) => { + return new HistoryView2(leaf, this); + }); + this.registerView(DIFF_VIEW_CONFIG.type, (leaf) => { + return new DiffView(leaf, this); + }); + this.lineAuthoringFeature.onLoadPlugin(); + this.app.workspace.registerHoverLinkSource( + SOURCE_CONTROL_VIEW_CONFIG.type, + { + display: "Git View", + defaultMod: true + } + ); + this.setRefreshDebouncer(); + this.addCommand({ + id: "edit-gitignore", + name: "Edit .gitignore", + callback: async () => { + const path2 = this.gitManager.getVaultPath(".gitignore"); + if (!await this.app.vault.adapter.exists(path2)) { + this.app.vault.adapter.write(path2, ""); + } + const content = await this.app.vault.adapter.read(path2); + const modal = new IgnoreModal(this.app, content); + const res = await modal.open(); + if (res !== void 0) { + await this.app.vault.adapter.write(path2, res); + this.refresh(); + } + } + }); + this.addCommand({ + id: "open-git-view", + name: "Open source control view", + callback: async () => { + const leafs = this.app.workspace.getLeavesOfType( + SOURCE_CONTROL_VIEW_CONFIG.type + ); + let leaf; + if (leafs.length === 0) { + leaf = this.app.workspace.getRightLeaf(false); + await leaf.setViewState({ + type: SOURCE_CONTROL_VIEW_CONFIG.type + }); + } else { + leaf = leafs.first(); + } + this.app.workspace.revealLeaf(leaf); + dispatchEvent(new CustomEvent("git-refresh")); + } + }); + this.addCommand({ + id: "open-history-view", + name: "Open history view", + callback: async () => { + const leafs = this.app.workspace.getLeavesOfType( + HISTORY_VIEW_CONFIG.type + ); + let leaf; + if (leafs.length === 0) { + leaf = this.app.workspace.getRightLeaf(false); + await leaf.setViewState({ + type: HISTORY_VIEW_CONFIG.type + }); + } else { + leaf = leafs.first(); + } + this.app.workspace.revealLeaf(leaf); + dispatchEvent(new CustomEvent("git-refresh")); + } + }); + this.addCommand({ + id: "open-diff-view", + name: "Open diff view", + checkCallback: (checking) => { + var _a2; + const file = this.app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + (_a2 = getNewLeaf()) == null ? void 0 : _a2.setViewState({ + type: DIFF_VIEW_CONFIG.type, + active: true, + state: { + staged: false, + file: this.gitManager.asRepositoryRelativePath( + file.path, + true + ) + } + }); + } + } + }); + this.addCommand({ + id: "view-file-on-github", + name: "Open file on GitHub", + editorCallback: (editor, { file }) => { + if (file) + return openLineInGitHub(editor, file, this.gitManager); + } + }); + this.addCommand({ + id: "view-history-on-github", + name: "Open file history on GitHub", + editorCallback: (_, { file }) => { + if (file) + return openHistoryInGitHub(file, this.gitManager); + } + }); + this.addCommand({ + id: "pull", + name: "Pull", + callback: () => this.promiseQueue.addTask(() => this.pullChangesFromRemote()) + }); + this.addCommand({ + id: "fetch", + name: "fetch", + callback: () => this.promiseQueue.addTask(() => this.fetch()) + }); + this.addCommand({ + id: "switch-to-remote-branch", + name: "Switch to remote branch", + callback: () => this.promiseQueue.addTask(() => this.switchRemoteBranch()) + }); + this.addCommand({ + id: "add-to-gitignore", + name: "Add file to gitignore", + checkCallback: (checking) => { + const file = app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + app.vault.adapter.append( + this.gitManager.getVaultPath(".gitignore"), + "\n" + this.gitManager.asRepositoryRelativePath( + file.path, + true + ) + ).then(() => { + this.refresh(); + }); + } + } + }); + this.addCommand({ + id: "push", + name: "Create backup", + callback: () => this.promiseQueue.addTask(() => this.createBackup(false)) + }); + this.addCommand({ + id: "backup-and-close", + name: "Create backup and close", + callback: () => this.promiseQueue.addTask(async () => { + await this.createBackup(false); + window.close(); + }) + }); + this.addCommand({ + id: "commit-push-specified-message", + name: "Create backup with specific message", + callback: () => this.promiseQueue.addTask(() => this.createBackup(false, true)) + }); + this.addCommand({ + id: "commit", + name: "Commit all changes", + callback: () => this.promiseQueue.addTask( + () => this.commit({ fromAutoBackup: false }) + ) + }); + this.addCommand({ + id: "commit-specified-message", + name: "Commit all changes with specific message", + callback: () => this.promiseQueue.addTask( + () => this.commit({ + fromAutoBackup: false, + requestCustomMessage: true + }) + ) + }); + this.addCommand({ + id: "commit-staged", + name: "Commit staged", + callback: () => this.promiseQueue.addTask( + () => this.commit({ + fromAutoBackup: false, + requestCustomMessage: false, + onlyStaged: true + }) + ) + }); + this.addCommand({ + id: "commit-staged-specified-message", + name: "Commit staged with specific message", + callback: () => this.promiseQueue.addTask( + () => this.commit({ + fromAutoBackup: false, + requestCustomMessage: true, + onlyStaged: true + }) + ) + }); + this.addCommand({ + id: "push2", + name: "Push", + callback: () => this.promiseQueue.addTask(() => this.push()) + }); + this.addCommand({ + id: "stage-current-file", + name: "Stage current file", + checkCallback: (checking) => { + const file = this.app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + this.promiseQueue.addTask(() => this.stageFile(file)); + } + } + }); + this.addCommand({ + id: "unstage-current-file", + name: "Unstage current file", + checkCallback: (checking) => { + const file = this.app.workspace.getActiveFile(); + if (checking) { + return file !== null; + } else { + this.promiseQueue.addTask(() => this.unstageFile(file)); + } + } + }); + this.addCommand({ + id: "edit-remotes", + name: "Edit remotes", + callback: async () => this.editRemotes() + }); + this.addCommand({ + id: "remove-remote", + name: "Remove remote", + callback: async () => this.removeRemote() + }); + this.addCommand({ + id: "delete-repo", + name: "CAUTION: Delete repository", + callback: async () => { + const repoExists = await this.app.vault.adapter.exists( + `${this.settings.basePath}/.git` + ); + if (repoExists) { + const modal = new GeneralModal({ + options: ["NO", "YES"], + placeholder: "Do you really want to delete the repository (.git directory)? This action cannot be undone.", + onlySelection: true + }); + const shouldDelete = await modal.open() === "YES"; + if (shouldDelete) { + await this.app.vault.adapter.rmdir( + `${this.settings.basePath}/.git`, + true + ); + new import_obsidian30.Notice( + "Successfully deleted repository. Reloading plugin..." + ); + this.unloadPlugin(); + this.init(); + } + } else { + new import_obsidian30.Notice("No repository found"); + } + } + }); + this.addCommand({ + id: "init-repo", + name: "Initialize a new repo", + callback: async () => this.createNewRepo() + }); + this.addCommand({ + id: "clone-repo", + name: "Clone an existing remote repo", + callback: async () => this.cloneNewRepo() + }); + this.addCommand({ + id: "list-changed-files", + name: "List changed files", + callback: async () => { + if (!await this.isAllInitialized()) + return; + const status2 = await this.gitManager.status(); + this.setState(0 /* idle */); + if (status2.changed.length + status2.staged.length > 500) { + this.displayError("Too many changes to display"); + return; + } + new ChangedFilesModal(this, status2.changed).open(); + } + }); + this.addCommand({ + id: "switch-branch", + name: "Switch branch", + callback: () => { + this.switchBranch(); + } + }); + this.addCommand({ + id: "create-branch", + name: "Create new branch", + callback: () => { + this.createBranch(); + } + }); + this.addCommand({ + id: "delete-branch", + name: "Delete branch", + callback: () => { + this.deleteBranch(); + } + }); + this.addCommand({ + id: "discard-all", + name: "CAUTION: Discard all changes", + callback: async () => { + if (!await this.isAllInitialized()) + return false; + const modal = new GeneralModal({ + options: ["NO", "YES"], + placeholder: "Do you want to discard all changes to tracked files? This action cannot be undone.", + onlySelection: true + }); + const shouldDiscardAll = await modal.open() === "YES"; + if (shouldDiscardAll) { + this.promiseQueue.addTask(() => this.discardAll()); + } + } + }); + this.addCommand({ + id: "toggle-line-author-info", + name: "Toggle line author information", + callback: () => { + var _a2; + return (_a2 = this.settingsTab) == null ? void 0 : _a2.configureLineAuthorShowStatus( + !this.settings.lineAuthor.show + ); + } + }); + this.registerEvent( + this.app.workspace.on("file-menu", (menu, file, source) => { + this.handleFileMenu(menu, file, source); + }) + ); + if (this.settings.showStatusBar) { + const statusBarEl = this.addStatusBarItem(); + this.statusBar = new StatusBar(statusBarEl, this); + this.registerInterval( + window.setInterval(() => { + var _a2; + return (_a2 = this.statusBar) == null ? void 0 : _a2.display(); + }, 1e3) + ); + } + if (import_obsidian30.Platform.isDesktop && this.settings.showBranchStatusBar) { + const branchStatusBarEl = this.addStatusBarItem(); + this.branchBar = new BranchStatusBar(branchStatusBarEl, this); + this.registerInterval( + window.setInterval(() => { + var _a2; + return (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + }, 6e4) + ); + } + this.app.workspace.onLayoutReady(() => this.init()); + } + setRefreshDebouncer() { + var _a2; + (_a2 = this.debRefresh) == null ? void 0 : _a2.cancel(); + this.debRefresh = (0, import_obsidian30.debounce)( + () => { + if (this.settings.refreshSourceControl) { + this.refresh(); + } + }, + this.settings.refreshSourceControlTimer, + true + ); + } + async showNotices() { + const length = 1e4; + if (this.manifest.id === "obsidian-git" && import_obsidian30.Platform.isDesktopApp && !this.settings.showedMobileNotice) { + new import_obsidian30.Notice( + "Obsidian Git is now available on mobile! Please read the plugin's README for more information.", + length + ); + this.settings.showedMobileNotice = true; + await this.saveSettings(); + } + if (this.manifest.id === "obsidian-git-isomorphic") { + new import_obsidian30.Notice( + "Obsidian Git Mobile is now deprecated. Please uninstall it and install Obsidian Git instead.", + length + ); + } + } + handleFileMenu(menu, file, source) { + if (!this.settings.showFileMenu) + return; + if (source !== "file-explorer-context-menu") { + return; + } + if (!file) { + return; + } + if (!this.gitReady) + return; + menu.addItem((item) => { + item.setTitle(`Git: Stage`).setIcon("plus-circle").setSection("action").onClick((_) => { + this.promiseQueue.addTask(async () => { + if (file instanceof import_obsidian30.TFile) { + await this.gitManager.stage(file.path, true); + } else { + await this.gitManager.stageAll({ + dir: this.gitManager.asRepositoryRelativePath( + file.path, + true + ) + }); + } + this.displayMessage(`Staged ${file.path}`); + }); + }); + }); + menu.addItem((item) => { + item.setTitle(`Git: Unstage`).setIcon("minus-circle").setSection("action").onClick((_) => { + this.promiseQueue.addTask(async () => { + if (file instanceof import_obsidian30.TFile) { + await this.gitManager.unstage(file.path, true); + } else { + await this.gitManager.unstageAll({ + dir: this.gitManager.asRepositoryRelativePath( + file.path, + true + ) + }); + } + this.displayMessage(`Unstaged ${file.path}`); + }); + }); + }); + } + async migrateSettings() { + if (this.settings.mergeOnPull != void 0) { + this.settings.syncMethod = this.settings.mergeOnPull ? "merge" : "rebase"; + this.settings.mergeOnPull = void 0; + await this.saveSettings(); + } + if (this.settings.autoCommitMessage === void 0) { + this.settings.autoCommitMessage = this.settings.commitMessage; + await this.saveSettings(); + } + if (this.settings.gitPath != void 0) { + this.localStorage.setGitPath(this.settings.gitPath); + this.settings.gitPath = void 0; + await this.saveSettings(); + } + if (this.settings.username != void 0) { + this.localStorage.setPassword(this.settings.username); + this.settings.username = void 0; + await this.saveSettings(); + } + } + unloadPlugin() { + this.gitReady = false; + dispatchEvent(new CustomEvent("git-refresh")); + this.lineAuthoringFeature.deactivateFeature(); + this.clearAutoPull(); + this.clearAutoPush(); + this.clearAutoBackup(); + removeEventListener("git-refresh", this.refresh.bind(this)); + removeEventListener( + "git-head-update", + this.refreshUpdatedHead.bind(this) + ); + this.app.workspace.offref(this.openEvent); + this.app.metadataCache.offref(this.modifyEvent); + this.app.metadataCache.offref(this.deleteEvent); + this.app.metadataCache.offref(this.createEvent); + this.app.metadataCache.offref(this.renameEvent); + this.debRefresh.cancel(); + } + async onunload() { + this.app.workspace.unregisterHoverLinkSource( + SOURCE_CONTROL_VIEW_CONFIG.type + ); + this.unloadPlugin(); + console.log("unloading " + this.manifest.name + " plugin"); + } + async loadSettings() { + let data = await this.loadData(); + if (data == void 0) { + data = { showedMobileNotice: true }; + } + this.settings = mergeSettingsByPriority(DEFAULT_SETTINGS, data); + } + async saveSettings() { + var _a2; + (_a2 = this.settingsTab) == null ? void 0 : _a2.beforeSaveSettings(); + await this.saveData(this.settings); + } + saveLastAuto(date, mode) { + if (mode === "backup") { + this.localStorage.setLastAutoBackup(date.toString()); + } else if (mode === "pull") { + this.localStorage.setLastAutoPull(date.toString()); + } else if (mode === "push") { + this.localStorage.setLastAutoPush(date.toString()); + } + } + loadLastAuto() { + var _a2, _b, _c; + return { + backup: new Date((_a2 = this.localStorage.getLastAutoBackup()) != null ? _a2 : ""), + pull: new Date((_b = this.localStorage.getLastAutoPull()) != null ? _b : ""), + push: new Date((_c = this.localStorage.getLastAutoPush()) != null ? _c : "") + }; + } + get useSimpleGit() { + return import_obsidian30.Platform.isDesktopApp; + } + async init() { + var _a2; + this.showNotices(); + try { + if (this.useSimpleGit) { + this.gitManager = new SimpleGit(this); + await this.gitManager.setGitInstance(); + } else { + this.gitManager = new IsomorphicGit(this); + } + const result = await this.gitManager.checkRequirements(); + switch (result) { + case "missing-git": + this.displayError("Cannot run git command"); + break; + case "missing-repo": + new import_obsidian30.Notice( + "Can't find a valid git repository. Please create one via the given command or clone an existing repo.", + 1e4 + ); + break; + case "valid": + this.gitReady = true; + this.setState(0 /* idle */); + this.openEvent = this.app.workspace.on( + "active-leaf-change", + (leaf) => this.handleViewActiveState(leaf) + ); + this.modifyEvent = this.app.vault.on("modify", () => { + this.debRefresh(); + }); + this.deleteEvent = this.app.vault.on("delete", () => { + this.debRefresh(); + }); + this.createEvent = this.app.vault.on("create", () => { + this.debRefresh(); + }); + this.renameEvent = this.app.vault.on("rename", () => { + this.debRefresh(); + }); + this.registerEvent(this.modifyEvent); + this.registerEvent(this.deleteEvent); + this.registerEvent(this.createEvent); + this.registerEvent(this.renameEvent); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + this.lineAuthoringFeature.conditionallyActivateBySettings(); + dispatchEvent(new CustomEvent("git-refresh")); + if (this.settings.autoPullOnBoot) { + this.promiseQueue.addTask( + () => this.pullChangesFromRemote() + ); + } + this.setUpAutos(); + break; + default: + console.log( + "Something weird happened. The 'checkRequirements' result is " + result + ); + } + } catch (error) { + this.displayError(error); + console.error(error); + } + } + async createNewRepo() { + await this.gitManager.init(); + new import_obsidian30.Notice("Initialized new repo"); + await this.init(); + } + async cloneNewRepo() { + const modal = new GeneralModal({ placeholder: "Enter remote URL" }); + const url = await modal.open(); + if (url) { + const confirmOption = "Vault Root"; + let dir = await new GeneralModal({ + options: this.gitManager instanceof IsomorphicGit ? [confirmOption] : [], + placeholder: "Enter directory for clone. It needs to be empty or not existent.", + allowEmpty: this.gitManager instanceof IsomorphicGit + }).open(); + if (dir !== void 0) { + if (dir === confirmOption) { + dir = "."; + } + dir = (0, import_obsidian30.normalizePath)(dir); + if (dir === "/") { + dir = "."; + } + if (dir === ".") { + const modal2 = new GeneralModal({ + options: ["NO", "YES"], + placeholder: `Does your remote repo contain a ${app.vault.configDir} directory at the root?`, + onlySelection: true + }); + const containsConflictDir = await modal2.open(); + if (containsConflictDir === void 0) { + new import_obsidian30.Notice("Aborted clone"); + return; + } else if (containsConflictDir === "YES") { + const confirmOption2 = "DELETE ALL YOUR LOCAL CONFIG AND PLUGINS"; + const modal3 = new GeneralModal({ + options: ["Abort clone", confirmOption2], + placeholder: `To avoid conflicts, the local ${app.vault.configDir} directory needs to be deleted.`, + onlySelection: true + }); + const shouldDelete = await modal3.open() === confirmOption2; + if (shouldDelete) { + await this.app.vault.adapter.rmdir( + app.vault.configDir, + true + ); + } else { + new import_obsidian30.Notice("Aborted clone"); + return; + } + } + } + const depth = await new GeneralModal({ + placeholder: "Specify depth of clone. Leave empty for full clone.", + allowEmpty: true + }).open(); + let depthInt = void 0; + if (depth !== "") { + depthInt = parseInt(depth); + if (isNaN(depthInt)) { + new import_obsidian30.Notice("Invalid depth. Aborting clone."); + return; + } + } + new import_obsidian30.Notice(`Cloning new repo into "${dir}"`); + const oldBase = this.settings.basePath; + const customDir = dir && dir !== "."; + if (customDir) { + this.settings.basePath = dir; + } + try { + await this.gitManager.clone(url, dir, depthInt); + } catch (error) { + this.settings.basePath = oldBase; + this.saveSettings(); + throw error; + } + new import_obsidian30.Notice("Cloned new repo."); + new import_obsidian30.Notice("Please restart Obsidian"); + if (customDir) { + this.saveSettings(); + } + } + } + } + /** + * Retries to call `this.init()` if necessary, otherwise returns directly + * @returns true if `this.gitManager` is ready to be used, false if not. + */ + async isAllInitialized() { + if (!this.gitReady) { + await this.init(); + } + return this.gitReady; + } + ///Used for command + async pullChangesFromRemote() { + if (!await this.isAllInitialized()) + return; + const filesUpdated = await this.pull(); + this.setUpAutoBackup(); + if (!filesUpdated) { + this.displayMessage("Everything is up-to-date"); + } + if (this.gitManager instanceof SimpleGit) { + const status2 = await this.gitManager.status(); + if (status2.conflicted.length > 0) { + this.displayError( + `You have conflicts in ${status2.conflicted.length} ${status2.conflicted.length == 1 ? "file" : "files"}` + ); + this.handleConflict(status2.conflicted); + } + } + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(0 /* idle */); + } + async createBackup(fromAutoBackup, requestCustomMessage = false, commitMessage) { + if (!await this.isAllInitialized()) + return; + if (this.settings.syncMethod == "reset" && this.settings.pullBeforePush) { + await this.pull(); + } + if (!await this.commit({ + fromAutoBackup, + requestCustomMessage, + commitMessage + })) + return; + if (!this.settings.disablePush) { + if (await this.gitManager.canPush()) { + if (this.settings.syncMethod != "reset" && this.settings.pullBeforePush) { + await this.pull(); + } + await this.push(); + } else { + this.displayMessage("No changes to push"); + } + } + this.setState(0 /* idle */); + } + // Returns true if commit was successfully + async commit({ + fromAutoBackup, + requestCustomMessage = false, + onlyStaged = false, + commitMessage + }) { + if (!await this.isAllInitialized()) + return false; + let hadConflict = this.localStorage.getConflict() === "true"; + let changedFiles; + let status2; + let unstagedFiles; + if (this.gitManager instanceof SimpleGit) { + this.mayDeleteConflictFile(); + status2 = await this.updateCachedStatus(); + if (status2.conflicted.length == 0) { + this.localStorage.setConflict("false"); + hadConflict = false; + } + if (fromAutoBackup && status2.conflicted.length > 0) { + this.displayError( + `Did not commit, because you have conflicts in ${status2.conflicted.length} ${status2.conflicted.length == 1 ? "file" : "files"}. Please resolve them and commit per command.` + ); + this.handleConflict(status2.conflicted); + return false; + } + changedFiles = [...status2.changed, ...status2.staged]; + } else if (fromAutoBackup && hadConflict) { + this.setState(6 /* conflicted */); + this.displayError( + `Did not commit, because you have conflicts. Please resolve them and commit per command.` + ); + return false; + } else if (hadConflict) { + await this.mayDeleteConflictFile(); + status2 = await this.updateCachedStatus(); + changedFiles = [...status2.changed, ...status2.staged]; + } else { + if (onlyStaged) { + changedFiles = await this.gitManager.getStagedFiles(); + } else { + unstagedFiles = await this.gitManager.getUnstagedFiles(); + changedFiles = unstagedFiles.map(({ filepath }) => ({ + vault_path: this.gitManager.getVaultPath(filepath) + })); + } + } + if (await this.hasTooBigFiles(changedFiles)) { + this.setState(0 /* idle */); + return false; + } + if (changedFiles.length !== 0 || hadConflict) { + let cmtMessage = commitMessage != null ? commitMessage : commitMessage = fromAutoBackup ? this.settings.autoCommitMessage : this.settings.commitMessage; + if (fromAutoBackup && this.settings.customMessageOnAutoBackup || requestCustomMessage) { + if (!this.settings.disablePopups && fromAutoBackup) { + new import_obsidian30.Notice( + "Auto backup: Please enter a custom commit message. Leave empty to abort" + ); + } + const tempMessage = await new CustomMessageModal( + this, + true + ).open(); + if (tempMessage != void 0 && tempMessage != "" && tempMessage != "...") { + cmtMessage = tempMessage; + } else { + this.setState(0 /* idle */); + return false; + } + } + let committedFiles; + if (onlyStaged) { + committedFiles = await this.gitManager.commit(cmtMessage); + } else { + committedFiles = await this.gitManager.commitAll({ + message: cmtMessage, + status: status2, + unstagedFiles + }); + } + if (this.gitManager instanceof SimpleGit) { + if ((await this.updateCachedStatus()).conflicted.length == 0) { + this.localStorage.setConflict("false"); + } + } + let roughly = false; + if (committedFiles === void 0) { + roughly = true; + committedFiles = changedFiles.length; + } + this.setUpAutoBackup(); + this.displayMessage( + `Committed${roughly ? " approx." : ""} ${committedFiles} ${committedFiles == 1 ? "file" : "files"}` + ); + } else { + this.displayMessage("No changes to commit"); + } + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(0 /* idle */); + return true; + } + async hasTooBigFiles(files) { + const branchInfo = await this.gitManager.branchInfo(); + const remote = branchInfo.tracking ? splitRemoteBranch(branchInfo.tracking)[0] : null; + if (remote) { + const remoteUrl = await this.gitManager.getRemoteUrl(remote); + if (remoteUrl == null ? void 0 : remoteUrl.includes("github.com")) { + const tooBigFiles = files.filter((f) => { + const file = this.app.vault.getAbstractFileByPath( + f.vault_path + ); + if (file instanceof import_obsidian30.TFile) { + return file.stat.size >= 1e8; + } + return false; + }); + if (tooBigFiles.length > 0) { + this.displayError( + `Did not commit, because following files are too big: ${tooBigFiles.map( + (e) => e.vault_path + )}. Please remove them.` + ); + return true; + } + } + } + return false; + } + async push() { + if (!await this.isAllInitialized()) + return false; + if (!await this.remotesAreSet()) { + return false; + } + const hadConflict = this.localStorage.getConflict() === "true"; + if (this.gitManager instanceof SimpleGit) + await this.mayDeleteConflictFile(); + let status2; + if (this.gitManager instanceof SimpleGit && (status2 = await this.updateCachedStatus()).conflicted.length > 0) { + this.displayError( + `Cannot push. You have conflicts in ${status2.conflicted.length} ${status2.conflicted.length == 1 ? "file" : "files"}` + ); + this.handleConflict(status2.conflicted); + return false; + } else if (this.gitManager instanceof IsomorphicGit && hadConflict) { + this.displayError(`Cannot push. You have conflicts`); + this.setState(6 /* conflicted */); + return false; + } + { + console.log("Pushing...."); + const pushedFiles = await this.gitManager.push(); + console.log("Pushed!", pushedFiles); + if (pushedFiles > 0) { + this.displayMessage( + `Pushed ${pushedFiles} ${pushedFiles == 1 ? "file" : "files"} to remote` + ); + } else { + this.displayMessage(`No changes to push`); + } + this.offlineMode = false; + this.setState(0 /* idle */); + dispatchEvent(new CustomEvent("git-refresh")); + return true; + } + } + /// Used for internals + /// Returns whether the pull added a commit or not. + async pull() { + if (!await this.remotesAreSet()) { + return false; + } + const pulledFiles = await this.gitManager.pull() || []; + this.offlineMode = false; + if (pulledFiles.length > 0) { + this.displayMessage( + `Pulled ${pulledFiles.length} ${pulledFiles.length == 1 ? "file" : "files"} from remote` + ); + this.lastPulledFiles = pulledFiles; + } + return pulledFiles.length != 0; + } + async fetch() { + if (!await this.remotesAreSet()) { + return; + } + await this.gitManager.fetch(); + this.displayMessage(`Fetched from remote`); + this.offlineMode = false; + dispatchEvent(new CustomEvent("git-refresh")); + } + async mayDeleteConflictFile() { + const file = this.app.vault.getAbstractFileByPath( + this.conflictOutputFile + ); + if (file) { + this.app.workspace.iterateAllLeaves((leaf) => { + if (leaf.view instanceof import_obsidian30.MarkdownView && leaf.view.file.path == file.path) { + leaf.detach(); + } + }); + await this.app.vault.delete(file); + } + } + async stageFile(file) { + if (!await this.isAllInitialized()) + return false; + await this.gitManager.stage(file.path, true); + this.displayMessage(`Staged ${file.path}`); + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(0 /* idle */); + return true; + } + async unstageFile(file) { + if (!await this.isAllInitialized()) + return false; + await this.gitManager.unstage(file.path, true); + this.displayMessage(`Unstaged ${file.path}`); + dispatchEvent(new CustomEvent("git-refresh")); + this.setState(0 /* idle */); + return true; + } + async switchBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const branchInfo = await this.gitManager.branchInfo(); + const selectedBranch = await new BranchModal( + branchInfo.branches + ).open(); + if (selectedBranch != void 0) { + await this.gitManager.checkout(selectedBranch); + this.displayMessage(`Switched to ${selectedBranch}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return selectedBranch; + } + } + async switchRemoteBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const selectedBranch = await this.selectRemoteBranch() || ""; + const [remote, branch2] = splitRemoteBranch(selectedBranch); + if (branch2 != void 0 && remote != void 0) { + await this.gitManager.checkout(branch2, remote); + this.displayMessage(`Switched to ${selectedBranch}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return selectedBranch; + } + } + async createBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const newBranch = await new GeneralModal({ + placeholder: "Create new branch" + }).open(); + if (newBranch != void 0) { + await this.gitManager.createBranch(newBranch); + this.displayMessage(`Created new branch ${newBranch}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return newBranch; + } + } + async deleteBranch() { + var _a2; + if (!await this.isAllInitialized()) + return; + const branchInfo = await this.gitManager.branchInfo(); + if (branchInfo.current) + branchInfo.branches.remove(branchInfo.current); + const branch2 = await new GeneralModal({ + options: branchInfo.branches, + placeholder: "Delete branch", + onlySelection: true + }).open(); + if (branch2 != void 0) { + let force = false; + const merged = await this.gitManager.branchIsMerged(branch2); + if (!merged) { + const forceAnswer = await new GeneralModal({ + options: ["YES", "NO"], + placeholder: "This branch isn't merged into HEAD. Force delete?", + onlySelection: true + }).open(); + if (forceAnswer !== "YES") { + return; + } + force = forceAnswer === "YES"; + } + await this.gitManager.deleteBranch(branch2, force); + this.displayMessage(`Deleted branch ${branch2}`); + (_a2 = this.branchBar) == null ? void 0 : _a2.display(); + return branch2; + } + } + async remotesAreSet() { + if (!(await this.gitManager.branchInfo()).tracking) { + new import_obsidian30.Notice("No upstream branch is set. Please select one."); + const remoteBranch = await this.selectRemoteBranch(); + if (remoteBranch == void 0) { + this.displayError("Aborted. No upstream-branch is set!", 1e4); + this.setState(0 /* idle */); + return false; + } else { + await this.gitManager.updateUpstreamBranch(remoteBranch); + return true; + } + } + return true; + } + async setUpAutoBackup() { + if (this.settings.setLastSaveToLastCommit) { + this.clearAutoBackup(); + const lastCommitDate = await this.gitManager.getLastCommitTime(); + if (lastCommitDate) { + this.localStorage.setLastAutoBackup(lastCommitDate.toString()); + } + } + if (!this.timeoutIDBackup && !this.onFileModifyEventRef) { + const lastAutos = await this.loadLastAuto(); + if (this.settings.autoSaveInterval > 0) { + const now2 = /* @__PURE__ */ new Date(); + const diff2 = this.settings.autoSaveInterval - Math.round( + (now2.getTime() - lastAutos.backup.getTime()) / 1e3 / 60 + ); + this.startAutoBackup(diff2 <= 0 ? 0 : diff2); + } + } + } + async setUpAutos() { + this.setUpAutoBackup(); + const lastAutos = await this.loadLastAuto(); + if (this.settings.differentIntervalCommitAndPush && this.settings.autoPushInterval > 0) { + const now2 = /* @__PURE__ */ new Date(); + const diff2 = this.settings.autoPushInterval - Math.round( + (now2.getTime() - lastAutos.push.getTime()) / 1e3 / 60 + ); + this.startAutoPush(diff2 <= 0 ? 0 : diff2); + } + if (this.settings.autoPullInterval > 0) { + const now2 = /* @__PURE__ */ new Date(); + const diff2 = this.settings.autoPullInterval - Math.round( + (now2.getTime() - lastAutos.pull.getTime()) / 1e3 / 60 + ); + this.startAutoPull(diff2 <= 0 ? 0 : diff2); + } + } + async discardAll() { + await this.gitManager.discardAll({ + status: this.cachedStatus + }); + new import_obsidian30.Notice( + "All local changes have been discarded. New files remain untouched." + ); + } + clearAutos() { + this.clearAutoBackup(); + this.clearAutoPush(); + this.clearAutoPull(); + } + startAutoBackup(minutes) { + let time = (minutes != null ? minutes : this.settings.autoSaveInterval) * 6e4; + if (this.settings.autoBackupAfterFileChange) { + if (minutes === 0) { + this.doAutoBackup(); + } else { + this.onFileModifyEventRef = this.app.vault.on( + "modify", + () => this.autoBackupDebouncer() + ); + this.autoBackupDebouncer = (0, import_obsidian30.debounce)( + () => this.doAutoBackup(), + time, + true + ); + } + } else { + if (time > 2147483647) + time = 2147483647; + this.timeoutIDBackup = window.setTimeout( + () => this.doAutoBackup(), + time + ); + } + } + // This is used for both auto backup and commit + doAutoBackup() { + this.promiseQueue.addTask(() => { + if (this.settings.differentIntervalCommitAndPush) { + return this.commit({ fromAutoBackup: true }); + } else { + return this.createBackup(true); + } + }); + this.saveLastAuto(/* @__PURE__ */ new Date(), "backup"); + this.saveSettings(); + this.startAutoBackup(); + } + startAutoPull(minutes) { + let time = (minutes != null ? minutes : this.settings.autoPullInterval) * 6e4; + if (time > 2147483647) + time = 2147483647; + this.timeoutIDPull = window.setTimeout(() => { + this.promiseQueue.addTask(() => this.pullChangesFromRemote()); + this.saveLastAuto(/* @__PURE__ */ new Date(), "pull"); + this.saveSettings(); + this.startAutoPull(); + }, time); + } + startAutoPush(minutes) { + let time = (minutes != null ? minutes : this.settings.autoPushInterval) * 6e4; + if (time > 2147483647) + time = 2147483647; + this.timeoutIDPush = window.setTimeout(() => { + this.promiseQueue.addTask(() => this.push()); + this.saveLastAuto(/* @__PURE__ */ new Date(), "push"); + this.saveSettings(); + this.startAutoPush(); + }, time); + } + clearAutoBackup() { + var _a2; + let wasActive = false; + if (this.timeoutIDBackup) { + window.clearTimeout(this.timeoutIDBackup); + this.timeoutIDBackup = void 0; + wasActive = true; + } + if (this.onFileModifyEventRef) { + (_a2 = this.autoBackupDebouncer) == null ? void 0 : _a2.cancel(); + this.app.vault.offref(this.onFileModifyEventRef); + this.onFileModifyEventRef = void 0; + wasActive = true; + } + return wasActive; + } + clearAutoPull() { + if (this.timeoutIDPull) { + window.clearTimeout(this.timeoutIDPull); + this.timeoutIDPull = void 0; + return true; + } + return false; + } + clearAutoPush() { + if (this.timeoutIDPush) { + window.clearTimeout(this.timeoutIDPush); + this.timeoutIDPush = void 0; + return true; + } + return false; + } + async handleConflict(conflicted) { + this.setState(6 /* conflicted */); + this.localStorage.setConflict("true"); + let lines; + if (conflicted !== void 0) { + lines = [ + "# Conflicts", + "Please resolve them and commit them using the commands `Obsidian Git: Commit all changes` followed by `Obsidian Git: Push`", + "(This file will automatically be deleted before commit)", + "[[#Additional Instructions]] available below file list", + "", + ...conflicted.map((e) => { + const file = this.app.vault.getAbstractFileByPath(e); + if (file instanceof import_obsidian30.TFile) { + const link = this.app.metadataCache.fileToLinktext( + file, + "/" + ); + return `- [[${link}]]`; + } else { + return `- Not a file: ${e}`; + } + }), + ` +# Additional Instructions +I strongly recommend to use "Source mode" for viewing the conflicted files. For simple conflicts, in each file listed above replace every occurrence of the following text blocks with the desired text. + +\`\`\`diff +<<<<<<< HEAD + File changes in local repository +======= + File changes in remote repository +>>>>>>> origin/main +\`\`\`` + ]; + } + this.writeAndOpenFile(lines == null ? void 0 : lines.join("\n")); + } + async editRemotes() { + if (!await this.isAllInitialized()) + return; + const remotes = await this.gitManager.getRemotes(); + const nameModal = new GeneralModal({ + options: remotes, + placeholder: "Select or create a new remote by typing its name and selecting it" + }); + const remoteName = await nameModal.open(); + if (remoteName) { + const oldUrl = await this.gitManager.getRemoteUrl(remoteName); + const urlModal = new GeneralModal({ initialValue: oldUrl }); + const remoteURL = await urlModal.open(); + if (remoteURL) { + await this.gitManager.setRemote(remoteName, remoteURL); + return remoteName; + } + } + } + async selectRemoteBranch() { + let remotes = await this.gitManager.getRemotes(); + let selectedRemote; + if (remotes.length === 0) { + selectedRemote = await this.editRemotes(); + if (selectedRemote == void 0) { + remotes = await this.gitManager.getRemotes(); + } + } + const nameModal = new GeneralModal({ + options: remotes, + placeholder: "Select or create a new remote by typing its name and selecting it" + }); + const remoteName = selectedRemote != null ? selectedRemote : await nameModal.open(); + if (remoteName) { + this.displayMessage("Fetching remote branches"); + await this.gitManager.fetch(remoteName); + const branches = await this.gitManager.getRemoteBranches( + remoteName + ); + const branchModal = new GeneralModal({ + options: branches, + placeholder: "Select or create a new remote branch by typing its name and selecting it" + }); + return await branchModal.open(); + } + } + async removeRemote() { + if (!await this.isAllInitialized()) + return; + const remotes = await this.gitManager.getRemotes(); + const nameModal = new GeneralModal({ + options: remotes, + placeholder: "Select a remote" + }); + const remoteName = await nameModal.open(); + if (remoteName) { + this.gitManager.removeRemote(remoteName); + } + } + async writeAndOpenFile(text2) { + if (text2 !== void 0) { + await this.app.vault.adapter.write(this.conflictOutputFile, text2); + } + let fileIsAlreadyOpened = false; + this.app.workspace.iterateAllLeaves((leaf) => { + if (leaf.getDisplayText() != "" && this.conflictOutputFile.startsWith(leaf.getDisplayText())) { + fileIsAlreadyOpened = true; + } + }); + if (!fileIsAlreadyOpened) { + this.app.workspace.openLinkText(this.conflictOutputFile, "/", true); + } + } + handleViewActiveState(leaf) { + var _a2, _b; + if (!(leaf == null ? void 0 : leaf.view.getState().file)) + return; + const sourceControlLeaf = this.app.workspace.getLeavesOfType(SOURCE_CONTROL_VIEW_CONFIG.type).first(); + const historyLeaf = this.app.workspace.getLeavesOfType(HISTORY_VIEW_CONFIG.type).first(); + (_a2 = sourceControlLeaf == null ? void 0 : sourceControlLeaf.view.containerEl.querySelector(`div.nav-file-title.is-active`)) == null ? void 0 : _a2.removeClass("is-active"); + (_b = historyLeaf == null ? void 0 : historyLeaf.view.containerEl.querySelector(`div.nav-file-title.is-active`)) == null ? void 0 : _b.removeClass("is-active"); + if ((leaf == null ? void 0 : leaf.view) instanceof DiffView) { + const path2 = leaf.view.state.file; + this.lastDiffViewState = leaf.view.getState(); + let el; + if (sourceControlLeaf && leaf.view.state.staged) { + el = sourceControlLeaf.view.containerEl.querySelector( + `div.staged div.nav-file-title[data-path='${path2}']` + ); + } else if (sourceControlLeaf && leaf.view.state.staged === false && !leaf.view.state.hash) { + el = sourceControlLeaf.view.containerEl.querySelector( + `div.changes div.nav-file-title[data-path='${path2}']` + ); + } else if (historyLeaf && leaf.view.state.hash) { + el = historyLeaf.view.containerEl.querySelector( + `div.nav-file-title[data-path='${path2}']` + ); + } + el == null ? void 0 : el.addClass("is-active"); + } else { + this.lastDiffViewState = void 0; + } + } + // region: displaying / formatting messages + displayMessage(message, timeout = 4 * 1e3) { + var _a2; + (_a2 = this.statusBar) == null ? void 0 : _a2.displayMessage(message.toLowerCase(), timeout); + if (!this.settings.disablePopups) { + new import_obsidian30.Notice(message, 5 * 1e3); + } + console.log(`git obsidian message: ${message}`); + } + displayError(message, timeout = 10 * 1e3) { + var _a2; + if (message instanceof Errors.UserCanceledError) { + new import_obsidian30.Notice("Aborted"); + return; + } + message = message.toString(); + new import_obsidian30.Notice(message, timeout); + console.log(`git obsidian error: ${message}`); + (_a2 = this.statusBar) == null ? void 0 : _a2.displayMessage(message.toLowerCase(), timeout); + } +}; +/*! Bundled license information: + +ieee754/index.js: + (*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh *) + +buffer/index.js: + (*! + * The buffer module from node.js, for the browser. + * + * @author Feross Aboukhadijeh + * @license MIT + *) + +safe-buffer/index.js: + (*! safe-buffer. MIT License. Feross Aboukhadijeh *) + +crc-32/crc32.js: + (*! crc32.js (C) 2014-present SheetJS -- http://sheetjs.com *) + +js-sha256/src/sha256.js: + (** + * [js-sha256]{@link https://github.com/emn178/js-sha256} + * + * @version 0.9.0 + * @author Chen, Yi-Cyuan [emn178@gmail.com] + * @copyright Chen, Yi-Cyuan 2014-2017 + * @license MIT + *) + +feather-icons/dist/feather.js: + (*! + Copyright (c) 2016 Jed Watson. + Licensed under the MIT License (MIT), see + http://jedwatson.github.io/classnames + *) +*/ diff --git a/.obsidian/plugins/obsidian-git/manifest.json b/.obsidian/plugins/obsidian-git/manifest.json new file mode 100644 index 0000000..a771a54 --- /dev/null +++ b/.obsidian/plugins/obsidian-git/manifest.json @@ -0,0 +1,9 @@ +{ + "id": "obsidian-git", + "name": "Obsidian Git", + "description": "Backup your vault with Git.", + "isDesktopOnly": false, + "fundingUrl": "https://ko-fi.com/vinzent", + "js": "main.js", + "version": "2.22.0" +} diff --git a/.obsidian/plugins/obsidian-git/styles.css b/.obsidian/plugins/obsidian-git/styles.css new file mode 100644 index 0000000..c1d5065 --- /dev/null +++ b/.obsidian/plugins/obsidian-git/styles.css @@ -0,0 +1,512 @@ +@keyframes loading { + 0% { + transform: rotate(0deg); + } + + 100% { + transform: rotate(360deg); + } +} + +.workspace-leaf-content[data-type='git-view'] .button-border { + border: 2px solid var(--interactive-accent); + border-radius: var(--radius-s); +} + +.workspace-leaf-content[data-type='git-view'] .view-content { + padding: 0; +} + +.workspace-leaf-content[data-type='git-history-view'] .view-content { + padding: 0; +} + +.loading>svg { + animation: 2s linear infinite loading; + transform-origin: 50% 50%; + display: inline-block; +} + +.obsidian-git-center { + margin: auto; + text-align: center; + width: 50%; +} + +.obsidian-git-textarea { + display: block; + margin-left: auto; + margin-right: auto; +} + +.obsidian-git-center-button { + display: block; + margin: 20px auto; +} + +.tooltip.mod-left { + overflow-wrap: break-word; +} + +.tooltip.mod-right { + overflow-wrap: break-word; +} +.git-tools { + display: flex; + margin-left: auto; +} +.git-tools .type { + padding-left: var(--size-2-1); + display: flex; + align-items: center; + justify-content: center; + width: 11px; +} + +.git-tools .type[data-type="M"] { + color: orange; +} +.git-tools .type[data-type="D"] { + color: red; +} +.git-tools .buttons { + display: flex; +} +.git-tools .buttons > * { + padding: 0 0; + height: auto; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-d-none { + display: none; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-wrapper { + text-align: left; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-header { + background-color: var(--background-primary); + border-bottom: 1px solid var(--interactive-accent); + font-family: var(--font-monospace); + height: 35px; + padding: 5px 10px; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-header, +.workspace-leaf-content[data-type="diff-view"] .d2h-file-stats { + display: -webkit-box; + display: -ms-flexbox; + display: flex; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-stats { + font-size: 14px; + margin-left: auto; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-lines-added { + border: 1px solid #b4e2b4; + border-radius: 5px 0 0 5px; + color: #399839; + padding: 2px; + text-align: right; + vertical-align: middle; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-lines-deleted { + border: 1px solid #e9aeae; + border-radius: 0 5px 5px 0; + color: #c33; + margin-left: 1px; + padding: 2px; + text-align: left; + vertical-align: middle; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-name-wrapper { + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + display: -webkit-box; + display: -ms-flexbox; + display: flex; + font-size: 15px; + width: 100%; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-name { + overflow-x: hidden; + text-overflow: ellipsis; + white-space: nowrap; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-wrapper { + border: 1px solid var(--background-modifier-border); + border-radius: 3px; + margin-bottom: 1em; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-collapse { + -webkit-box-pack: end; + -ms-flex-pack: end; + -webkit-box-align: center; + -ms-flex-align: center; + align-items: center; + border: 1px solid var(--background-modifier-border); + border-radius: 3px; + cursor: pointer; + display: none; + font-size: 12px; + justify-content: flex-end; + padding: 4px 8px; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-collapse.d2h-selected { + background-color: #c8e1ff; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-collapse-input { + margin: 0 4px 0 0; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-diff-table { + border-collapse: collapse; + font-family: Menlo, Consolas, monospace; + font-size: 13px; + width: 100%; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-files-diff { + width: 100%; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-diff { + overflow-y: hidden; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-side-diff { + display: inline-block; + margin-bottom: -8px; + margin-right: -4px; + overflow-x: scroll; + overflow-y: hidden; + width: 50%; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line { + padding: 0 8em; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line { + display: inline-block; + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; + white-space: nowrap; + width: 100%; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line { + padding: 0 4.5em; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line-ctn { + word-wrap: normal; + background: none; + display: inline-block; + padding: 0; + -webkit-user-select: text; + -moz-user-select: text; + -ms-user-select: text; + user-select: text; + vertical-align: middle; + white-space: pre; + width: 100%; +} + +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-line del, +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line del { + background-color: #ffb6ba; +} + +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-line del, +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line del { + background-color: #8d232881; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line del, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line ins, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line del, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line ins { + border-radius: 0.2em; + display: inline-block; + margin-top: -1px; + text-decoration: none; + vertical-align: middle; +} + +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-line ins, +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line ins { + background-color: #97f295; + text-align: left; +} + +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-line ins, +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-code-side-line ins { + background-color: #1d921996; + text-align: left; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line-prefix { + word-wrap: normal; + background: none; + display: inline; + padding: 0; + white-space: pre; +} + +.workspace-leaf-content[data-type="diff-view"] .line-num1 { + float: left; +} + +.workspace-leaf-content[data-type="diff-view"] .line-num1, +.workspace-leaf-content[data-type="diff-view"] .line-num2 { + -webkit-box-sizing: border-box; + box-sizing: border-box; + overflow: hidden; + padding: 0 0.5em; + text-overflow: ellipsis; + width: 3.5em; +} + +.workspace-leaf-content[data-type="diff-view"] .line-num2 { + float: right; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber { + background-color: var(--background-primary); + border: solid var(--background-modifier-border); + border-width: 0 1px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: var(--text-muted); + cursor: pointer; + display: inline-block; + position: absolute; + text-align: right; + width: 7.5em; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber:after { + content: "\200b"; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber { + background-color: var(--background-primary); + border: solid var(--background-modifier-border); + border-width: 0 1px; + -webkit-box-sizing: border-box; + box-sizing: border-box; + color: var(--text-muted); + cursor: pointer; + display: inline-block; + overflow: hidden; + padding: 0 0.5em; + position: absolute; + text-align: right; + text-overflow: ellipsis; + width: 4em; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-diff-tbody tr { + position: relative; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber:after { + content: "\200b"; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-emptyplaceholder, +.workspace-leaf-content[data-type="diff-view"] .d2h-emptyplaceholder { + background-color: var(--background-primary); + border-color: var(--background-modifier-border); +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-line-prefix, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber, +.workspace-leaf-content[data-type="diff-view"] .d2h-emptyplaceholder { + -webkit-user-select: none; + -moz-user-select: none; + -ms-user-select: none; + user-select: none; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-code-linenumber, +.workspace-leaf-content[data-type="diff-view"] .d2h-code-side-linenumber { + direction: rtl; +} + +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-del { + background-color: #fee8e9; + border-color: #e9aeae; +} + +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-ins { + background-color: #dfd; + border-color: #b4e2b4; +} + +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-del { + background-color: #521b1d83; + border-color: #691d1d73; +} + +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-ins { + background-color: rgba(30, 71, 30, 0.5); + border-color: #13501381; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-info { + background-color: var(--background-primary); + border-color: var(--background-modifier-border); + color: var(--text-normal); +} + +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-del.d2h-change { + background-color: #fdf2d0; +} + +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-del.d2h-change { + background-color: #55492480; +} + +.theme-light .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-ins.d2h-change { + background-color: #ded; +} + +.theme-dark .workspace-leaf-content[data-type="diff-view"] .d2h-file-diff .d2h-ins.d2h-change { + background-color: rgba(37, 78, 37, 0.418); +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list-wrapper { + margin-bottom: 10px; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list-wrapper a { + color: #3572b0; + text-decoration: none; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list-wrapper a:visited { + color: #3572b0; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list-header { + text-align: left; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list-title { + font-weight: 700; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list-line { + display: -webkit-box; + display: -ms-flexbox; + display: flex; + text-align: left; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list { + display: block; + list-style: none; + margin: 0; + padding: 0; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list>li { + border-bottom: 1px solid var(--background-modifier-border); + margin: 0; + padding: 5px 10px; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-list>li:last-child { + border-bottom: none; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-file-switch { + cursor: pointer; + display: none; + font-size: 10px; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-icon { + fill: currentColor; + margin-right: 10px; + vertical-align: middle; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-deleted { + color: #c33; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-added { + color: #399839; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-changed { + color: #d0b44c; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-moved { + color: #3572b0; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-tag { + background-color: var(--background-primary); + display: -webkit-box; + display: -ms-flexbox; + display: flex; + font-size: 10px; + margin-left: 5px; + padding: 0 2px; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-deleted-tag { + border: 2px solid #c33; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-added-tag { + border: 1px solid #399839; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-changed-tag { + border: 1px solid #d0b44c; +} + +.workspace-leaf-content[data-type="diff-view"] .d2h-moved-tag { + border: 1px solid #3572b0; +} + +/* ====================== Line Authoring Information ====================== */ + +.cm-gutterElement.obs-git-blame-gutter { + /* Add background color to spacing inbetween and around the gutter for better aesthetics */ + border-width: 0px 2px 0.2px 2px; + border-style: solid; + border-color: var(--background-secondary); + background-color: var(--background-secondary); +} + +.cm-gutterElement.obs-git-blame-gutter > div, .line-author-settings-preview { + /* delegate text color to settings */ + color: var(--obs-git-gutter-text); + font-family: monospace; + height: 100%; /* ensure, that age-based background color occupies entire parent */ + text-align: right; + padding: 0px 6px 0px 6px; + white-space: pre; /* Keep spaces and do not collapse them. */ +} diff --git a/.obsidian/plugins/obsidian-table-generator/data.json b/.obsidian/plugins/obsidian-table-generator/data.json new file mode 100644 index 0000000..5d97ab6 --- /dev/null +++ b/.obsidian/plugins/obsidian-table-generator/data.json @@ -0,0 +1,7 @@ +{ + "rowCount": 8, + "columnCount": 8, + "defaultAlignment": "center", + "defaultCardWidth": 160, + "defaultCardHeight": 160 +} \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-table-generator/main.js b/.obsidian/plugins/obsidian-table-generator/main.js new file mode 100644 index 0000000..5861552 --- /dev/null +++ b/.obsidian/plugins/obsidian-table-generator/main.js @@ -0,0 +1,2461 @@ +"use strict"; +var __defProp = Object.defineProperty; +var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; +var __publicField = (obj, key, value) => { + __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value); + return value; +}; +const obsidian = require("obsidian"); +function noop() { +} +function assign(tar, src) { + for (const k in src) + tar[k] = src[k]; + return tar; +} +function add_location(element2, file2, line, column, char) { + element2.__svelte_meta = { + loc: { file: file2, line, column, char } + }; +} +function run(fn) { + return fn(); +} +function blank_object() { + return /* @__PURE__ */ Object.create(null); +} +function run_all(fns) { + fns.forEach(run); +} +function is_function(thing) { + return typeof thing === "function"; +} +function safe_not_equal(a, b) { + return a != a ? b == b : a !== b || (a && typeof a === "object" || typeof a === "function"); +} +function is_empty(obj) { + return Object.keys(obj).length === 0; +} +function create_slot(definition, ctx, $$scope, fn) { + if (definition) { + const slot_ctx = get_slot_context(definition, ctx, $$scope, fn); + return definition[0](slot_ctx); + } +} +function get_slot_context(definition, ctx, $$scope, fn) { + return definition[1] && fn ? assign($$scope.ctx.slice(), definition[1](fn(ctx))) : $$scope.ctx; +} +function get_slot_changes(definition, $$scope, dirty, fn) { + if (definition[2] && fn) { + const lets = definition[2](fn(dirty)); + if ($$scope.dirty === void 0) { + return lets; + } + if (typeof lets === "object") { + const merged = []; + const len = Math.max($$scope.dirty.length, lets.length); + for (let i = 0; i < len; i += 1) { + merged[i] = $$scope.dirty[i] | lets[i]; + } + return merged; + } + return $$scope.dirty | lets; + } + return $$scope.dirty; +} +function update_slot_base(slot, slot_definition, ctx, $$scope, slot_changes, get_slot_context_fn) { + if (slot_changes) { + const slot_context = get_slot_context(slot_definition, ctx, $$scope, get_slot_context_fn); + slot.p(slot_context, slot_changes); + } +} +function get_all_dirty_from_scope($$scope) { + if ($$scope.ctx.length > 32) { + const dirty = []; + const length = $$scope.ctx.length / 32; + for (let i = 0; i < length; i++) { + dirty[i] = -1; + } + return dirty; + } + return -1; +} +function append(target, node) { + target.appendChild(node); +} +function insert(target, node, anchor) { + target.insertBefore(node, anchor || null); +} +function detach(node) { + node.parentNode.removeChild(node); +} +function element(name) { + return document.createElement(name); +} +function text(data) { + return document.createTextNode(data); +} +function space() { + return text(" "); +} +function empty() { + return text(""); +} +function listen(node, event, handler, options) { + node.addEventListener(event, handler, options); + return () => node.removeEventListener(event, handler, options); +} +function attr(node, attribute, value) { + if (value == null) + node.removeAttribute(attribute); + else if (node.getAttribute(attribute) !== value) + node.setAttribute(attribute, value); +} +function children(element2) { + return Array.from(element2.childNodes); +} +function set_input_value(input, value) { + input.value = value == null ? "" : value; +} +function set_style(node, key, value, important) { + if (value === null) { + node.style.removeProperty(key); + } else { + node.style.setProperty(key, value, important ? "important" : ""); + } +} +function toggle_class(element2, name, toggle) { + element2.classList[toggle ? "add" : "remove"](name); +} +function custom_event(type, detail, { bubbles = false, cancelable = false } = {}) { + const e = document.createEvent("CustomEvent"); + e.initCustomEvent(type, bubbles, cancelable, detail); + return e; +} +let current_component; +function set_current_component(component) { + current_component = component; +} +function get_current_component() { + if (!current_component) + throw new Error("Function called outside component initialization"); + return current_component; +} +function onMount(fn) { + get_current_component().$$.on_mount.push(fn); +} +function createEventDispatcher() { + const component = get_current_component(); + return (type, detail, { cancelable = false } = {}) => { + const callbacks = component.$$.callbacks[type]; + if (callbacks) { + const event = custom_event(type, detail, { cancelable }); + callbacks.slice().forEach((fn) => { + fn.call(component, event); + }); + return !event.defaultPrevented; + } + return true; + }; +} +const dirty_components = []; +const binding_callbacks = []; +const render_callbacks = []; +const flush_callbacks = []; +const resolved_promise = Promise.resolve(); +let update_scheduled = false; +function schedule_update() { + if (!update_scheduled) { + update_scheduled = true; + resolved_promise.then(flush); + } +} +function add_render_callback(fn) { + render_callbacks.push(fn); +} +function add_flush_callback(fn) { + flush_callbacks.push(fn); +} +const seen_callbacks = /* @__PURE__ */ new Set(); +let flushidx = 0; +function flush() { + const saved_component = current_component; + do { + while (flushidx < dirty_components.length) { + const component = dirty_components[flushidx]; + flushidx++; + set_current_component(component); + update(component.$$); + } + set_current_component(null); + dirty_components.length = 0; + flushidx = 0; + while (binding_callbacks.length) + binding_callbacks.pop()(); + for (let i = 0; i < render_callbacks.length; i += 1) { + const callback = render_callbacks[i]; + if (!seen_callbacks.has(callback)) { + seen_callbacks.add(callback); + callback(); + } + } + render_callbacks.length = 0; + } while (dirty_components.length); + while (flush_callbacks.length) { + flush_callbacks.pop()(); + } + update_scheduled = false; + seen_callbacks.clear(); + set_current_component(saved_component); +} +function update($$) { + if ($$.fragment !== null) { + $$.update(); + run_all($$.before_update); + const dirty = $$.dirty; + $$.dirty = [-1]; + $$.fragment && $$.fragment.p($$.ctx, dirty); + $$.after_update.forEach(add_render_callback); + } +} +const outroing = /* @__PURE__ */ new Set(); +let outros; +function transition_in(block, local) { + if (block && block.i) { + outroing.delete(block); + block.i(local); + } +} +function transition_out(block, local, detach2, callback) { + if (block && block.o) { + if (outroing.has(block)) + return; + outroing.add(block); + outros.c.push(() => { + outroing.delete(block); + if (callback) { + if (detach2) + block.d(1); + callback(); + } + }); + block.o(local); + } else if (callback) { + callback(); + } +} +const globals = typeof window !== "undefined" ? window : typeof globalThis !== "undefined" ? globalThis : global; +function destroy_block(block, lookup) { + block.d(1); + lookup.delete(block.key); +} +function update_keyed_each(old_blocks, dirty, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block2, next, get_context) { + let o = old_blocks.length; + let n = list.length; + let i = o; + const old_indexes = {}; + while (i--) + old_indexes[old_blocks[i].key] = i; + const new_blocks = []; + const new_lookup = /* @__PURE__ */ new Map(); + const deltas = /* @__PURE__ */ new Map(); + i = n; + while (i--) { + const child_ctx = get_context(ctx, list, i); + const key = get_key(child_ctx); + let block = lookup.get(key); + if (!block) { + block = create_each_block2(key, child_ctx); + block.c(); + } else if (dynamic) { + block.p(child_ctx, dirty); + } + new_lookup.set(key, new_blocks[i] = block); + if (key in old_indexes) + deltas.set(key, Math.abs(i - old_indexes[key])); + } + const will_move = /* @__PURE__ */ new Set(); + const did_move = /* @__PURE__ */ new Set(); + function insert2(block) { + transition_in(block, 1); + block.m(node, next); + lookup.set(block.key, block); + next = block.first; + n--; + } + while (o && n) { + const new_block = new_blocks[n - 1]; + const old_block = old_blocks[o - 1]; + const new_key = new_block.key; + const old_key = old_block.key; + if (new_block === old_block) { + next = new_block.first; + o--; + n--; + } else if (!new_lookup.has(old_key)) { + destroy(old_block, lookup); + o--; + } else if (!lookup.has(new_key) || will_move.has(new_key)) { + insert2(new_block); + } else if (did_move.has(old_key)) { + o--; + } else if (deltas.get(new_key) > deltas.get(old_key)) { + did_move.add(new_key); + insert2(new_block); + } else { + will_move.add(old_key); + o--; + } + } + while (o--) { + const old_block = old_blocks[o]; + if (!new_lookup.has(old_block.key)) + destroy(old_block, lookup); + } + while (n) + insert2(new_blocks[n - 1]); + return new_blocks; +} +function validate_each_keys(ctx, list, get_context, get_key) { + const keys = /* @__PURE__ */ new Set(); + for (let i = 0; i < list.length; i++) { + const key = get_key(get_context(ctx, list, i)); + if (keys.has(key)) { + throw new Error("Cannot have duplicate keys in a keyed each"); + } + keys.add(key); + } +} +function bind(component, name, callback) { + const index = component.$$.props[name]; + if (index !== void 0) { + component.$$.bound[index] = callback; + callback(component.$$.ctx[index]); + } +} +function create_component(block) { + block && block.c(); +} +function mount_component(component, target, anchor, customElement) { + const { fragment, on_mount, on_destroy, after_update } = component.$$; + fragment && fragment.m(target, anchor); + if (!customElement) { + add_render_callback(() => { + const new_on_destroy = on_mount.map(run).filter(is_function); + if (on_destroy) { + on_destroy.push(...new_on_destroy); + } else { + run_all(new_on_destroy); + } + component.$$.on_mount = []; + }); + } + after_update.forEach(add_render_callback); +} +function destroy_component(component, detaching) { + const $$ = component.$$; + if ($$.fragment !== null) { + run_all($$.on_destroy); + $$.fragment && $$.fragment.d(detaching); + $$.on_destroy = $$.fragment = null; + $$.ctx = []; + } +} +function make_dirty(component, i) { + if (component.$$.dirty[0] === -1) { + dirty_components.push(component); + schedule_update(); + component.$$.dirty.fill(0); + } + component.$$.dirty[i / 31 | 0] |= 1 << i % 31; +} +function init(component, options, instance2, create_fragment2, not_equal, props, append_styles, dirty = [-1]) { + const parent_component = current_component; + set_current_component(component); + const $$ = component.$$ = { + fragment: null, + ctx: null, + props, + update: noop, + not_equal, + bound: blank_object(), + on_mount: [], + on_destroy: [], + on_disconnect: [], + before_update: [], + after_update: [], + context: new Map(options.context || (parent_component ? parent_component.$$.context : [])), + callbacks: blank_object(), + dirty, + skip_bound: false, + root: options.target || parent_component.$$.root + }; + append_styles && append_styles($$.root); + let ready = false; + $$.ctx = instance2 ? instance2(component, options.props || {}, (i, ret, ...rest) => { + const value = rest.length ? rest[0] : ret; + if ($$.ctx && not_equal($$.ctx[i], $$.ctx[i] = value)) { + if (!$$.skip_bound && $$.bound[i]) + $$.bound[i](value); + if (ready) + make_dirty(component, i); + } + return ret; + }) : []; + $$.update(); + ready = true; + run_all($$.before_update); + $$.fragment = create_fragment2 ? create_fragment2($$.ctx) : false; + if (options.target) { + if (options.hydrate) { + const nodes = children(options.target); + $$.fragment && $$.fragment.l(nodes); + nodes.forEach(detach); + } else { + $$.fragment && $$.fragment.c(); + } + if (options.intro) + transition_in(component.$$.fragment); + mount_component(component, options.target, options.anchor, options.customElement); + flush(); + } + set_current_component(parent_component); +} +class SvelteComponent { + $destroy() { + destroy_component(this, 1); + this.$destroy = noop; + } + $on(type, callback) { + const callbacks = this.$$.callbacks[type] || (this.$$.callbacks[type] = []); + callbacks.push(callback); + return () => { + const index = callbacks.indexOf(callback); + if (index !== -1) + callbacks.splice(index, 1); + }; + } + $set($$props) { + if (this.$$set && !is_empty($$props)) { + this.$$.skip_bound = true; + this.$$set($$props); + this.$$.skip_bound = false; + } + } +} +function dispatch_dev(type, detail) { + document.dispatchEvent(custom_event(type, Object.assign({ version: "3.50.1" }, detail), { bubbles: true })); +} +function append_dev(target, node) { + dispatch_dev("SvelteDOMInsert", { target, node }); + append(target, node); +} +function insert_dev(target, node, anchor) { + dispatch_dev("SvelteDOMInsert", { target, node, anchor }); + insert(target, node, anchor); +} +function detach_dev(node) { + dispatch_dev("SvelteDOMRemove", { node }); + detach(node); +} +function listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) { + const modifiers = options === true ? ["capture"] : options ? Array.from(Object.keys(options)) : []; + if (has_prevent_default) + modifiers.push("preventDefault"); + if (has_stop_propagation) + modifiers.push("stopPropagation"); + dispatch_dev("SvelteDOMAddEventListener", { node, event, handler, modifiers }); + const dispose = listen(node, event, handler, options); + return () => { + dispatch_dev("SvelteDOMRemoveEventListener", { node, event, handler, modifiers }); + dispose(); + }; +} +function attr_dev(node, attribute, value) { + attr(node, attribute, value); + if (value == null) + dispatch_dev("SvelteDOMRemoveAttribute", { node, attribute }); + else + dispatch_dev("SvelteDOMSetAttribute", { node, attribute, value }); +} +function set_data_dev(text2, data) { + data = "" + data; + if (text2.wholeText === data) + return; + dispatch_dev("SvelteDOMSetData", { node: text2, data }); + text2.data = data; +} +function validate_each_argument(arg) { + if (typeof arg !== "string" && !(arg && typeof arg === "object" && "length" in arg)) { + let msg = "{#each} only iterates over array-like objects."; + if (typeof Symbol === "function" && arg && Symbol.iterator in arg) { + msg += " You can use a spread to convert this iterable into an array."; + } + throw new Error(msg); + } +} +function validate_slots(name, slot, keys) { + for (const slot_key of Object.keys(slot)) { + if (!~keys.indexOf(slot_key)) { + console.warn(`<${name}> received an unexpected slot "${slot_key}".`); + } + } +} +class SvelteComponentDev extends SvelteComponent { + constructor(options) { + if (!options || !options.target && !options.$$inline) { + throw new Error("'target' is a required option"); + } + super(); + } + $destroy() { + super.$destroy(); + this.$destroy = () => { + console.warn("Component was already destroyed"); + }; + } + $capture_state() { + } + $inject_state() { + } +} +function __awaiter(thisArg, _arguments, P, generator) { + function adopt(value) { + return value instanceof P ? value : new P(function(resolve) { + resolve(value); + }); + } + return new (P || (P = Promise))(function(resolve, reject) { + function fulfilled(value) { + try { + step(generator.next(value)); + } catch (e) { + reject(e); + } + } + function rejected(value) { + try { + step(generator["throw"](value)); + } catch (e) { + reject(e); + } + } + function step(result) { + result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); + } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +} +const Table_svelte_svelte_type_style_lang = ""; +const file$3 = "E:/obdev/.obsidian/plugins/Obsidian-Table-Generator/src/ui/basic/Table.svelte"; +function get_each_context$1(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[20] = list[i]; + child_ctx[22] = i; + return child_ctx; +} +function get_each_context_1(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[20] = list[i]; + child_ctx[24] = i; + return child_ctx; +} +function create_each_block_1(key_1, ctx) { + let div; + let mounted; + let dispose; + function mouseenter_handler() { + return ctx[12](ctx[22], ctx[24]); + } + function click_handler() { + return ctx[13](ctx[22], ctx[24]); + } + const block = { + key: key_1, + first: null, + c: function create() { + div = element("div"); + attr_dev(div, "class", "table-generator-cell s-VU35bhriycJk"); + toggle_class(div, "active", ctx[0][ctx[22]][ctx[24]]); + add_location(div, file$3, 43, 12, 1276); + this.first = div; + }, + m: function mount(target, anchor) { + insert_dev(target, div, anchor); + if (!mounted) { + dispose = [ + listen_dev(div, "mouseenter", mouseenter_handler, false, false, false), + listen_dev(div, "click", click_handler, false, false, false) + ]; + mounted = true; + } + }, + p: function update2(new_ctx, dirty) { + ctx = new_ctx; + if (dirty & 9) { + toggle_class(div, "active", ctx[0][ctx[22]][ctx[24]]); + } + }, + d: function destroy(detaching) { + if (detaching) + detach_dev(div); + mounted = false; + run_all(dispose); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_each_block_1.name, + type: "each", + source: "(43:8) {#each {length: grid[1]} as _, j (j)}", + ctx + }); + return block; +} +function create_each_block$1(key_1, ctx) { + let first; + let each_blocks = []; + let each_1_lookup = /* @__PURE__ */ new Map(); + let each_1_anchor; + let each_value_1 = { length: ctx[3][1] }; + validate_each_argument(each_value_1); + const get_key = (ctx2) => ctx2[24]; + validate_each_keys(ctx, each_value_1, get_each_context_1, get_key); + for (let i = 0; i < each_value_1.length; i += 1) { + let child_ctx = get_each_context_1(ctx, each_value_1, i); + let key = get_key(child_ctx); + each_1_lookup.set(key, each_blocks[i] = create_each_block_1(key, child_ctx)); + } + const block = { + key: key_1, + first: null, + c: function create() { + first = empty(); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + each_1_anchor = empty(); + this.first = first; + }, + m: function mount(target, anchor) { + insert_dev(target, first, anchor); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].m(target, anchor); + } + insert_dev(target, each_1_anchor, anchor); + }, + p: function update2(new_ctx, dirty) { + ctx = new_ctx; + if (dirty & 89) { + each_value_1 = { length: ctx[3][1] }; + validate_each_argument(each_value_1); + validate_each_keys(ctx, each_value_1, get_each_context_1, get_key); + each_blocks = update_keyed_each(each_blocks, dirty, get_key, 1, ctx, each_value_1, each_1_lookup, each_1_anchor.parentNode, destroy_block, create_each_block_1, each_1_anchor, get_each_context_1); + } + }, + d: function destroy(detaching) { + if (detaching) + detach_dev(first); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].d(detaching); + } + if (detaching) + detach_dev(each_1_anchor); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_each_block$1.name, + type: "each", + source: "(42:4) {#each {length: grid[0]} as _, i (i)}", + ctx + }); + return block; +} +function create_fragment$5(ctx) { + let div; + let each_blocks = []; + let each_1_lookup = /* @__PURE__ */ new Map(); + let mounted; + let dispose; + let each_value = { length: ctx[3][0] }; + validate_each_argument(each_value); + const get_key = (ctx2) => ctx2[22]; + validate_each_keys(ctx, each_value, get_each_context$1, get_key); + for (let i = 0; i < each_value.length; i += 1) { + let child_ctx = get_each_context$1(ctx, each_value, i); + let key = get_key(child_ctx); + each_1_lookup.set(key, each_blocks[i] = create_each_block$1(key, child_ctx)); + } + const block = { + c: function create() { + div = element("div"); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + attr_dev(div, "class", "table-container s-VU35bhriycJk"); + set_style(div, "grid-template-rows", ctx[1], false); + set_style(div, "grid-template-columns", ctx[2], false); + add_location(div, file$3, 39, 0, 1014); + }, + l: function claim(nodes) { + throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option"); + }, + m: function mount(target, anchor) { + insert_dev(target, div, anchor); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].m(div, null); + } + if (!mounted) { + dispose = [ + listen_dev(div, "mouseleave", ctx[14], false, false, false), + listen_dev(div, "blur", ctx[15], false, false, false) + ]; + mounted = true; + } + }, + p: function update2(ctx2, [dirty]) { + if (dirty & 89) { + each_value = { length: ctx2[3][0] }; + validate_each_argument(each_value); + validate_each_keys(ctx2, each_value, get_each_context$1, get_key); + each_blocks = update_keyed_each(each_blocks, dirty, get_key, 1, ctx2, each_value, each_1_lookup, div, destroy_block, create_each_block$1, null, get_each_context$1); + } + if (dirty & 2) { + set_style(div, "grid-template-rows", ctx2[1], false); + } + if (dirty & 4) { + set_style(div, "grid-template-columns", ctx2[2], false); + } + }, + i: noop, + o: noop, + d: function destroy(detaching) { + if (detaching) + detach_dev(div); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].d(); + } + mounted = false; + run_all(dispose); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_fragment$5.name, + type: "component", + source: "", + ctx + }); + return block; +} +function instance$5($$self, $$props, $$invalidate) { + let col; + let row; + let is_active; + let { $$slots: slots = {}, $$scope } = $$props; + validate_slots("Table", slots, []); + let { plugin } = $$props; + let { rowNum = 8 } = $$props; + let { colNum = 8 } = $$props; + let { hoverTableEnd } = $$props; + let { insertTable } = $$props; + let grid = [rowNum, colNum]; + let start = []; + let end = []; + function hover(i, j) { + start = [0, 0]; + end = [i, j]; + $$invalidate(7, hoverTableEnd = [i + 1, j + 1]); + checkActive(end); + } + function unHover() { + start = end = [-1, -1]; + setTimeout( + () => { + $$invalidate(7, hoverTableEnd = [0, 0]); + checkActive(end); + }, + 1e3 + ); + } + function click(i, j) { + if (j === 0) + return; + insertTable([i + 1, j + 1]); + plugin.hideTable(); + } + function isInRange([i, j], [i2, j2]) { + return (i - start[0]) * (i - i2) <= 0 && (j - start[1]) * (j - j2) <= 0; + } + function checkActive(end2) { + $$invalidate(0, is_active = is_active.map((a, i) => a.map((_, j) => isInRange([i, j], end2)))); + } + const writable_props = ["plugin", "rowNum", "colNum", "hoverTableEnd", "insertTable"]; + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== "$$" && key !== "slot") + console.warn(` was created with unknown prop '${key}'`); + }); + const mouseenter_handler = (i, j) => hover(i, j); + const click_handler = (i, j) => click(i, j); + const mouseleave_handler = () => unHover(); + const blur_handler = () => unHover(); + $$self.$$set = ($$props2) => { + if ("plugin" in $$props2) + $$invalidate(8, plugin = $$props2.plugin); + if ("rowNum" in $$props2) + $$invalidate(9, rowNum = $$props2.rowNum); + if ("colNum" in $$props2) + $$invalidate(10, colNum = $$props2.colNum); + if ("hoverTableEnd" in $$props2) + $$invalidate(7, hoverTableEnd = $$props2.hoverTableEnd); + if ("insertTable" in $$props2) + $$invalidate(11, insertTable = $$props2.insertTable); + }; + $$self.$capture_state = () => ({ + plugin, + rowNum, + colNum, + hoverTableEnd, + insertTable, + grid, + start, + end, + hover, + unHover, + click, + isInRange, + checkActive, + is_active, + row, + col + }); + $$self.$inject_state = ($$props2) => { + if ("plugin" in $$props2) + $$invalidate(8, plugin = $$props2.plugin); + if ("rowNum" in $$props2) + $$invalidate(9, rowNum = $$props2.rowNum); + if ("colNum" in $$props2) + $$invalidate(10, colNum = $$props2.colNum); + if ("hoverTableEnd" in $$props2) + $$invalidate(7, hoverTableEnd = $$props2.hoverTableEnd); + if ("insertTable" in $$props2) + $$invalidate(11, insertTable = $$props2.insertTable); + if ("grid" in $$props2) + $$invalidate(3, grid = $$props2.grid); + if ("start" in $$props2) + start = $$props2.start; + if ("end" in $$props2) + end = $$props2.end; + if ("is_active" in $$props2) + $$invalidate(0, is_active = $$props2.is_active); + if ("row" in $$props2) + $$invalidate(1, row = $$props2.row); + if ("col" in $$props2) + $$invalidate(2, col = $$props2.col); + }; + if ($$props && "$$inject" in $$props) { + $$self.$inject_state($$props.$$inject); + } + $$invalidate(2, col = `repeat(${grid[1]}, 1fr)`); + $$invalidate(1, row = `repeat(${grid[0]}, 1fr)`); + $$invalidate(0, is_active = Array(grid[0]).fill(0).map((_) => Array(grid[1]).fill(false))); + return [ + is_active, + row, + col, + grid, + hover, + unHover, + click, + hoverTableEnd, + plugin, + rowNum, + colNum, + insertTable, + mouseenter_handler, + click_handler, + mouseleave_handler, + blur_handler + ]; +} +class Table extends SvelteComponentDev { + constructor(options) { + super(options); + init(this, options, instance$5, create_fragment$5, safe_not_equal, { + plugin: 8, + rowNum: 9, + colNum: 10, + hoverTableEnd: 7, + insertTable: 11 + }); + dispatch_dev("SvelteRegisterComponent", { + component: this, + tagName: "Table", + options, + id: create_fragment$5.name + }); + const { ctx } = this.$$; + const props = options.props || {}; + if (ctx[8] === void 0 && !("plugin" in props)) { + console.warn("
    was created without expected prop 'plugin'"); + } + if (ctx[7] === void 0 && !("hoverTableEnd" in props)) { + console.warn("
    was created without expected prop 'hoverTableEnd'"); + } + if (ctx[11] === void 0 && !("insertTable" in props)) { + console.warn("
    was created without expected prop 'insertTable'"); + } + } + get plugin() { + throw new Error("
    : Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set plugin(value) { + throw new Error("
    : Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get rowNum() { + throw new Error("
    : Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set rowNum(value) { + throw new Error("
    : Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get colNum() { + throw new Error("
    : Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set colNum(value) { + throw new Error("
    : Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get hoverTableEnd() { + throw new Error("
    : Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set hoverTableEnd(value) { + throw new Error("
    : Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get insertTable() { + throw new Error("
    : Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set insertTable(value) { + throw new Error("
    : Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } +} +const TableGeneratorComponent_svelte_svelte_type_style_lang = ""; +const file$2 = "E:/obdev/.obsidian/plugins/Obsidian-Table-Generator/src/ui/basic/TableGeneratorComponent.svelte"; +const get_sizeControls_slot_changes = (dirty) => ({}); +const get_sizeControls_slot_context = (ctx) => ({}); +const get_headerControls_slot_changes = (dirty) => ({}); +const get_headerControls_slot_context = (ctx) => ({}); +function create_fragment$4(ctx) { + let div5; + let div1; + let div0; + let t0; + let t1; + let t2; + let table; + let updating_hoverTableEnd; + let t3; + let div4; + let div2; + let t4; + let input0; + let t5; + let div3; + let t6; + let input1; + let t7; + let t8; + let button; + let current; + let mounted; + let dispose; + const headerControls_slot_template = ctx[8].headerControls; + const headerControls_slot = create_slot(headerControls_slot_template, ctx, ctx[7], get_headerControls_slot_context); + function table_hoverTableEnd_binding(value) { + ctx[9](value); + } + let table_props = { + rowNum: ctx[6].rowNum, + colNum: ctx[6].colNum, + insertTable: ctx[2], + plugin: ctx[1] + }; + if (ctx[3] !== void 0) { + table_props.hoverTableEnd = ctx[3]; + } + table = new Table({ props: table_props, $$inline: true }); + binding_callbacks.push(() => bind(table, "hoverTableEnd", table_hoverTableEnd_binding)); + const sizeControls_slot_template = ctx[8].sizeControls; + const sizeControls_slot = create_slot(sizeControls_slot_template, ctx, ctx[7], get_sizeControls_slot_context); + const block = { + c: function create() { + div5 = element("div"); + div1 = element("div"); + div0 = element("div"); + t0 = text(ctx[0]); + t1 = space(); + if (headerControls_slot) + headerControls_slot.c(); + t2 = space(); + create_component(table.$$.fragment); + t3 = space(); + div4 = element("div"); + div2 = element("div"); + t4 = text("ROW:\r\n "); + input0 = element("input"); + t5 = space(); + div3 = element("div"); + t6 = text("COL:\r\n "); + input1 = element("input"); + t7 = space(); + if (sizeControls_slot) + sizeControls_slot.c(); + t8 = space(); + button = element("button"); + button.textContent = "Insert"; + attr_dev(div0, "class", "H1 s-YxLKubgSvLDy"); + add_location(div0, file$2, 31, 8, 927); + attr_dev(div1, "class", "table-generator-header s-YxLKubgSvLDy"); + add_location(div1, file$2, 30, 4, 881); + attr_dev(input0, "class", "row-input s-YxLKubgSvLDy"); + add_location(input0, file$2, 41, 12, 1302); + attr_dev(div2, "class", "input-table-generator-row s-YxLKubgSvLDy"); + add_location(div2, file$2, 39, 8, 1231); + attr_dev(input1, "class", "col-input s-YxLKubgSvLDy"); + add_location(input1, file$2, 45, 12, 1445); + attr_dev(div3, "class", "input-table-generator-col s-YxLKubgSvLDy"); + add_location(div3, file$2, 43, 8, 1374); + attr_dev(div4, "class", "input-table-generator s-YxLKubgSvLDy"); + add_location(div4, file$2, 38, 4, 1186); + attr_dev(button, "class", "s-YxLKubgSvLDy"); + add_location(button, file$2, 49, 4, 1564); + attr_dev(div5, "class", "table-generator s-YxLKubgSvLDy"); + add_location(div5, file$2, 29, 0, 846); + }, + l: function claim(nodes) { + throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option"); + }, + m: function mount(target, anchor) { + insert_dev(target, div5, anchor); + append_dev(div5, div1); + append_dev(div1, div0); + append_dev(div0, t0); + append_dev(div1, t1); + if (headerControls_slot) { + headerControls_slot.m(div1, null); + } + append_dev(div5, t2); + mount_component(table, div5, null); + append_dev(div5, t3); + append_dev(div5, div4); + append_dev(div4, div2); + append_dev(div2, t4); + append_dev(div2, input0); + set_input_value(input0, ctx[4]); + append_dev(div4, t5); + append_dev(div4, div3); + append_dev(div3, t6); + append_dev(div3, input1); + set_input_value(input1, ctx[5]); + append_dev(div5, t7); + if (sizeControls_slot) { + sizeControls_slot.m(div5, null); + } + append_dev(div5, t8); + append_dev(div5, button); + current = true; + if (!mounted) { + dispose = [ + listen_dev(input0, "input", ctx[10]), + listen_dev(input1, "input", ctx[11]), + listen_dev(button, "click", ctx[12], false, false, false) + ]; + mounted = true; + } + }, + p: function update2(ctx2, [dirty]) { + if (!current || dirty & 1) + set_data_dev(t0, ctx2[0]); + if (headerControls_slot) { + if (headerControls_slot.p && (!current || dirty & 128)) { + update_slot_base( + headerControls_slot, + headerControls_slot_template, + ctx2, + ctx2[7], + !current ? get_all_dirty_from_scope(ctx2[7]) : get_slot_changes(headerControls_slot_template, ctx2[7], dirty, get_headerControls_slot_changes), + get_headerControls_slot_context + ); + } + } + const table_changes = {}; + if (dirty & 4) + table_changes.insertTable = ctx2[2]; + if (dirty & 2) + table_changes.plugin = ctx2[1]; + if (!updating_hoverTableEnd && dirty & 8) { + updating_hoverTableEnd = true; + table_changes.hoverTableEnd = ctx2[3]; + add_flush_callback(() => updating_hoverTableEnd = false); + } + table.$set(table_changes); + if (dirty & 16 && input0.value !== ctx2[4]) { + set_input_value(input0, ctx2[4]); + } + if (dirty & 32 && input1.value !== ctx2[5]) { + set_input_value(input1, ctx2[5]); + } + if (sizeControls_slot) { + if (sizeControls_slot.p && (!current || dirty & 128)) { + update_slot_base( + sizeControls_slot, + sizeControls_slot_template, + ctx2, + ctx2[7], + !current ? get_all_dirty_from_scope(ctx2[7]) : get_slot_changes(sizeControls_slot_template, ctx2[7], dirty, get_sizeControls_slot_changes), + get_sizeControls_slot_context + ); + } + } + }, + i: function intro(local) { + if (current) + return; + transition_in(headerControls_slot, local); + transition_in(table.$$.fragment, local); + transition_in(sizeControls_slot, local); + current = true; + }, + o: function outro(local) { + transition_out(headerControls_slot, local); + transition_out(table.$$.fragment, local); + transition_out(sizeControls_slot, local); + current = false; + }, + d: function destroy(detaching) { + if (detaching) + detach_dev(div5); + if (headerControls_slot) + headerControls_slot.d(detaching); + destroy_component(table); + if (sizeControls_slot) + sizeControls_slot.d(detaching); + mounted = false; + run_all(dispose); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_fragment$4.name, + type: "component", + source: "", + ctx + }); + return block; +} +function instance$4($$self, $$props, $$invalidate) { + let { $$slots: slots = {}, $$scope } = $$props; + validate_slots("TableGeneratorComponent", slots, ["headerControls", "sizeControls"]); + var _a, _b; + let { title } = $$props; + let { plugin } = $$props; + let { onInsert } = $$props; + let hoverTableEnd; + let gridRow; + let gridCol; + let settings = { + rowNum: (_a = plugin === null || plugin === void 0 ? void 0 : plugin.settings.rowCount) !== null && _a !== void 0 ? _a : 8, + colNum: (_b = plugin === null || plugin === void 0 ? void 0 : plugin.settings.columnCount) !== null && _b !== void 0 ? _b : 8 + }; + function setRowAndCol(end) { + if (end.length === 0) { + $$invalidate(4, gridRow = 0); + $$invalidate(5, gridCol = 0); + return; + } + if (!(hoverTableEnd[0] === 0 && hoverTableEnd[1] === 0)) { + $$invalidate(4, gridRow = hoverTableEnd[0]); + $$invalidate(5, gridCol = hoverTableEnd[1]); + } + } + const writable_props = ["title", "plugin", "onInsert"]; + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== "$$" && key !== "slot") + console.warn(` was created with unknown prop '${key}'`); + }); + function table_hoverTableEnd_binding(value) { + hoverTableEnd = value; + $$invalidate(3, hoverTableEnd); + } + function input0_input_handler() { + gridRow = this.value; + $$invalidate(4, gridRow); + } + function input1_input_handler() { + gridCol = this.value; + $$invalidate(5, gridCol); + } + const click_handler = () => { + if (/^\d+$/.test(gridRow.toString()) && /^\d+$/.test(gridCol.toString())) { + onInsert([gridRow, gridCol]); + } else { + new obsidian.Notice("Please enter a valid number"); + } + }; + $$self.$$set = ($$props2) => { + if ("title" in $$props2) + $$invalidate(0, title = $$props2.title); + if ("plugin" in $$props2) + $$invalidate(1, plugin = $$props2.plugin); + if ("onInsert" in $$props2) + $$invalidate(2, onInsert = $$props2.onInsert); + if ("$$scope" in $$props2) + $$invalidate(7, $$scope = $$props2.$$scope); + }; + $$self.$capture_state = () => ({ + _a, + _b, + Table, + Notice: obsidian.Notice, + title, + plugin, + onInsert, + hoverTableEnd, + gridRow, + gridCol, + settings, + setRowAndCol + }); + $$self.$inject_state = ($$props2) => { + if ("_a" in $$props2) + _a = $$props2._a; + if ("_b" in $$props2) + _b = $$props2._b; + if ("title" in $$props2) + $$invalidate(0, title = $$props2.title); + if ("plugin" in $$props2) + $$invalidate(1, plugin = $$props2.plugin); + if ("onInsert" in $$props2) + $$invalidate(2, onInsert = $$props2.onInsert); + if ("hoverTableEnd" in $$props2) + $$invalidate(3, hoverTableEnd = $$props2.hoverTableEnd); + if ("gridRow" in $$props2) + $$invalidate(4, gridRow = $$props2.gridRow); + if ("gridCol" in $$props2) + $$invalidate(5, gridCol = $$props2.gridCol); + if ("settings" in $$props2) + $$invalidate(6, settings = $$props2.settings); + }; + if ($$props && "$$inject" in $$props) { + $$self.$inject_state($$props.$$inject); + } + $$self.$$.update = () => { + if ($$self.$$.dirty & 8) { + if (hoverTableEnd) { + setRowAndCol(hoverTableEnd); + } + } + }; + return [ + title, + plugin, + onInsert, + hoverTableEnd, + gridRow, + gridCol, + settings, + $$scope, + slots, + table_hoverTableEnd_binding, + input0_input_handler, + input1_input_handler, + click_handler + ]; +} +class TableGeneratorComponent extends SvelteComponentDev { + constructor(options) { + super(options); + init(this, options, instance$4, create_fragment$4, safe_not_equal, { title: 0, plugin: 1, onInsert: 2 }); + dispatch_dev("SvelteRegisterComponent", { + component: this, + tagName: "TableGeneratorComponent", + options, + id: create_fragment$4.name + }); + const { ctx } = this.$$; + const props = options.props || {}; + if (ctx[0] === void 0 && !("title" in props)) { + console.warn(" was created without expected prop 'title'"); + } + if (ctx[1] === void 0 && !("plugin" in props)) { + console.warn(" was created without expected prop 'plugin'"); + } + if (ctx[2] === void 0 && !("onInsert" in props)) { + console.warn(" was created without expected prop 'onInsert'"); + } + } + get title() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set title(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get plugin() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set plugin(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get onInsert() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set onInsert(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } +} +const alignLineText = (align) => { + switch (align) { + case "left": + return "|:-----"; + case "center": + return "|:----:"; + case "right": + return "|-----:"; + default: + return ""; + } +}; +const generateMarkdownTable = (selectedGrid, align) => { + let table = ""; + let secondLine = ""; + let normalLine = ""; + const alignText = alignLineText(align); + if (selectedGrid.length === 0) + return table; + for (let i = 0; i < Number(selectedGrid[1]); i++) { + secondLine += alignText; + } + for (let i = 0; i < Number(selectedGrid[1]); i++) { + normalLine += "| "; + } + if (!selectedGrid[0]) { + table = normalLine + "|\n" + secondLine + "|\n"; + return table; + } + for (let i = 0; i < Number(selectedGrid[0]) + 1; i++) { + if (!i) + table = table + normalLine + "|\n"; + if (i === 1) + table = table + secondLine + "|\n"; + if (i > 1) + table = table + normalLine + "|\n"; + } + return table.trim(); +}; +function checkBlankLine(editor, line) { + const getLine = editor.getLine(line); + if (getLine.trim().length > 0) + return false; + return true; +} +const AlignItems_svelte_svelte_type_style_lang = ""; +const file$1 = "E:/obdev/.obsidian/plugins/Obsidian-Table-Generator/src/ui/basic/AlignItems.svelte"; +function get_each_context(ctx, list, i) { + const child_ctx = ctx.slice(); + child_ctx[7] = list[i]; + child_ctx[8] = list; + child_ctx[9] = i; + return child_ctx; +} +function create_each_block(key_1, ctx) { + let div; + let alignment = ctx[7]; + let mounted; + let dispose; + const assign_div = () => ctx[4](div, alignment); + const unassign_div = () => ctx[4](null, alignment); + function click_handler() { + return ctx[5](ctx[7]); + } + const block = { + key: key_1, + first: null, + c: function create() { + div = element("div"); + attr_dev(div, "class", "table-generator-align-icon s-XNB-qso0yOHJ"); + toggle_class(div, "active", ctx[0] === ctx[7]); + add_location(div, file$1, 19, 8, 598); + this.first = div; + }, + m: function mount(target, anchor) { + insert_dev(target, div, anchor); + assign_div(); + if (!mounted) { + dispose = listen_dev(div, "click", click_handler, false, false, false); + mounted = true; + } + }, + p: function update2(new_ctx, dirty) { + ctx = new_ctx; + if (alignment !== ctx[7]) { + unassign_div(); + alignment = ctx[7]; + assign_div(); + } + if (dirty & 5) { + toggle_class(div, "active", ctx[0] === ctx[7]); + } + }, + d: function destroy(detaching) { + if (detaching) + detach_dev(div); + unassign_div(); + mounted = false; + dispose(); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_each_block.name, + type: "each", + source: "(19:4) {#each alignments as alignment (alignment)}", + ctx + }); + return block; +} +function create_fragment$3(ctx) { + let div; + let each_blocks = []; + let each_1_lookup = /* @__PURE__ */ new Map(); + let each_value = ctx[2]; + validate_each_argument(each_value); + const get_key = (ctx2) => ctx2[7]; + validate_each_keys(ctx, each_value, get_each_context, get_key); + for (let i = 0; i < each_value.length; i += 1) { + let child_ctx = get_each_context(ctx, each_value, i); + let key = get_key(child_ctx); + each_1_lookup.set(key, each_blocks[i] = create_each_block(key, child_ctx)); + } + const block = { + c: function create() { + div = element("div"); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].c(); + } + attr_dev(div, "class", "table-generator-align-group s-XNB-qso0yOHJ"); + add_location(div, file$1, 17, 0, 498); + }, + l: function claim(nodes) { + throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option"); + }, + m: function mount(target, anchor) { + insert_dev(target, div, anchor); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].m(div, null); + } + }, + p: function update2(ctx2, [dirty]) { + if (dirty & 15) { + each_value = ctx2[2]; + validate_each_argument(each_value); + validate_each_keys(ctx2, each_value, get_each_context, get_key); + each_blocks = update_keyed_each(each_blocks, dirty, get_key, 1, ctx2, each_value, each_1_lookup, div, destroy_block, create_each_block, null, get_each_context); + } + }, + i: noop, + o: noop, + d: function destroy(detaching) { + if (detaching) + detach_dev(div); + for (let i = 0; i < each_blocks.length; i += 1) { + each_blocks[i].d(); + } + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_fragment$3.name, + type: "component", + source: "", + ctx + }); + return block; +} +function instance$3($$self, $$props, $$invalidate) { + let { $$slots: slots = {}, $$scope } = $$props; + validate_slots("AlignItems", slots, []); + let { align = "left" } = $$props; + const dispatch = createEventDispatcher(); + const alignments = ["left", "center", "right"]; + let refs = {}; + onMount(() => { + obsidian.setIcon(refs["left"], "align-left"); + obsidian.setIcon(refs["center"], "align-center"); + obsidian.setIcon(refs["right"], "align-right"); + }); + function click(update2) { + $$invalidate(0, align = update2); + dispatch("update", align); + } + const writable_props = ["align"]; + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== "$$" && key !== "slot") + console.warn(` was created with unknown prop '${key}'`); + }); + function div_binding($$value, alignment) { + binding_callbacks[$$value ? "unshift" : "push"](() => { + refs[alignment] = $$value; + $$invalidate(1, refs); + }); + } + const click_handler = (alignment) => click(alignment); + $$self.$$set = ($$props2) => { + if ("align" in $$props2) + $$invalidate(0, align = $$props2.align); + }; + $$self.$capture_state = () => ({ + onMount, + createEventDispatcher, + setIcon: obsidian.setIcon, + align, + dispatch, + alignments, + refs, + click + }); + $$self.$inject_state = ($$props2) => { + if ("align" in $$props2) + $$invalidate(0, align = $$props2.align); + if ("refs" in $$props2) + $$invalidate(1, refs = $$props2.refs); + }; + if ($$props && "$$inject" in $$props) { + $$self.$inject_state($$props.$$inject); + } + return [align, refs, alignments, click, div_binding, click_handler]; +} +class AlignItems extends SvelteComponentDev { + constructor(options) { + super(options); + init(this, options, instance$3, create_fragment$3, safe_not_equal, { align: 0 }); + dispatch_dev("SvelteRegisterComponent", { + component: this, + tagName: "AlignItems", + options, + id: create_fragment$3.name + }); + } + get align() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set align(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } +} +function create_headerControls_slot(ctx) { + let alignitems; + let current; + alignitems = new AlignItems({ + props: { + align: ctx[1], + slot: "headerControls" + }, + $$inline: true + }); + alignitems.$on("update", ctx[2]); + const block = { + c: function create() { + create_component(alignitems.$$.fragment); + }, + m: function mount(target, anchor) { + mount_component(alignitems, target, anchor); + current = true; + }, + p: function update2(ctx2, dirty) { + const alignitems_changes = {}; + if (dirty & 2) + alignitems_changes.align = ctx2[1]; + alignitems.$set(alignitems_changes); + }, + i: function intro(local) { + if (current) + return; + transition_in(alignitems.$$.fragment, local); + current = true; + }, + o: function outro(local) { + transition_out(alignitems.$$.fragment, local); + current = false; + }, + d: function destroy(detaching) { + destroy_component(alignitems, detaching); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_headerControls_slot.name, + type: "slot", + source: "(47:4) ", + ctx + }); + return block; +} +function create_fragment$2(ctx) { + let tablegeneratorcomponent; + let current; + tablegeneratorcomponent = new TableGeneratorComponent({ + props: { + title: "Table Generator", + plugin: ctx[0], + onInsert: ctx[3], + $$slots: { + headerControls: [create_headerControls_slot] + }, + $$scope: { ctx } + }, + $$inline: true + }); + const block = { + c: function create() { + create_component(tablegeneratorcomponent.$$.fragment); + }, + l: function claim(nodes) { + throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option"); + }, + m: function mount(target, anchor) { + mount_component(tablegeneratorcomponent, target, anchor); + current = true; + }, + p: function update2(ctx2, [dirty]) { + const tablegeneratorcomponent_changes = {}; + if (dirty & 1) + tablegeneratorcomponent_changes.plugin = ctx2[0]; + if (dirty & 66) { + tablegeneratorcomponent_changes.$$scope = { dirty, ctx: ctx2 }; + } + tablegeneratorcomponent.$set(tablegeneratorcomponent_changes); + }, + i: function intro(local) { + if (current) + return; + transition_in(tablegeneratorcomponent.$$.fragment, local); + current = true; + }, + o: function outro(local) { + transition_out(tablegeneratorcomponent.$$.fragment, local); + current = false; + }, + d: function destroy(detaching) { + destroy_component(tablegeneratorcomponent, detaching); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_fragment$2.name, + type: "component", + source: "", + ctx + }); + return block; +} +function instance$2($$self, $$props, $$invalidate) { + let { $$slots: slots = {}, $$scope } = $$props; + validate_slots("TableGenerator", slots, []); + var _a; + let { editor } = $$props; + let { plugin } = $$props; + let currentAlign = (_a = plugin === null || plugin === void 0 ? void 0 : plugin.settings.defaultAlignment) !== null && _a !== void 0 ? _a : "left"; + function handleAlignModeUpdate(event) { + var _a2; + return __awaiter(this, void 0, void 0, function* () { + $$invalidate(1, currentAlign = event.detail); + (_a2 = plugin === null || plugin === void 0 ? void 0 : plugin.settings) === null || _a2 === void 0 ? void 0 : _a2.defaultAlignment = currentAlign; + yield plugin === null || plugin === void 0 ? void 0 : plugin.saveSettings(); + }); + } + function insertTable(selectedGrid) { + if (selectedGrid.length === 0 || selectedGrid[1] < 2) + return; + const basicTable = generateMarkdownTable(selectedGrid, currentAlign); + let markdownTable = basicTable; + const cursor = editor.getCursor("from"); + const line = editor.getLine(cursor.line); + if (cursor.line !== 0 && line.trim().length !== 0) { + markdownTable = "\n" + markdownTable; + } + if (cursor.line !== editor.lastLine() && !checkBlankLine(editor, cursor.line + 1)) { + markdownTable = markdownTable + "\n"; + } else if (cursor.line === editor.lastLine()) { + markdownTable = "\n" + markdownTable; + } + if (line.trim().length > 0) { + editor.replaceRange(markdownTable, { line: cursor.line + 1, ch: 0 }, { line: cursor.line + 1, ch: 0 }); + } else { + editor.replaceRange(markdownTable, { line: cursor.line, ch: 0 }, { line: cursor.line, ch: 0 }); + } + } + const writable_props = ["editor", "plugin"]; + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== "$$" && key !== "slot") + console.warn(` was created with unknown prop '${key}'`); + }); + $$self.$$set = ($$props2) => { + if ("editor" in $$props2) + $$invalidate(4, editor = $$props2.editor); + if ("plugin" in $$props2) + $$invalidate(0, plugin = $$props2.plugin); + }; + $$self.$capture_state = () => ({ + _a, + __awaiter, + TableGeneratorComponent, + checkBlankLine, + generateMarkdownTable, + AlignItems, + editor, + plugin, + currentAlign, + handleAlignModeUpdate, + insertTable + }); + $$self.$inject_state = ($$props2) => { + if ("_a" in $$props2) + _a = $$props2._a; + if ("editor" in $$props2) + $$invalidate(4, editor = $$props2.editor); + if ("plugin" in $$props2) + $$invalidate(0, plugin = $$props2.plugin); + if ("currentAlign" in $$props2) + $$invalidate(1, currentAlign = $$props2.currentAlign); + }; + if ($$props && "$$inject" in $$props) { + $$self.$inject_state($$props.$$inject); + } + return [plugin, currentAlign, handleAlignModeUpdate, insertTable, editor]; +} +class TableGenerator extends SvelteComponentDev { + constructor(options) { + super(options); + init(this, options, instance$2, create_fragment$2, safe_not_equal, { editor: 4, plugin: 0 }); + dispatch_dev("SvelteRegisterComponent", { + component: this, + tagName: "TableGenerator", + options, + id: create_fragment$2.name + }); + const { ctx } = this.$$; + const props = options.props || {}; + if (ctx[4] === void 0 && !("editor" in props)) { + console.warn(" was created without expected prop 'editor'"); + } + if (ctx[0] === void 0 && !("plugin" in props)) { + console.warn(" was created without expected prop 'plugin'"); + } + } + get editor() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set editor(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get plugin() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set plugin(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } +} +const tableGeneratorDefault = ""; +function getLineHeight(editor, pos) { + const lineInfo = editor.cm.state.doc.lineAt(pos); + const lineDOM = editor.cm.domAtPos(lineInfo.from); + return lineDOM.node.offsetHeight; +} +const random = (e) => { + const t = []; + for (let n = 0; n < e; n++) { + t.push((16 * Math.random() | 0).toString(16)); + } + return t.join(""); +}; +function reverseCalculation(n, t) { + const r = t.scale; + const cx = t.canvasRect.cx; + const cy = t.canvasRect.cy; + const x = t.x; + const y = t.y; + const eClientX = (n.x - x) * r + cx; + const eClientY = (n.y - y) * r + cy; + return { + clientX: eClientX, + clientY: eClientY + }; +} +function calculateEditor(editor, tableGeneratorBoard) { + var _a, _b, _c, _d; + if (!tableGeneratorBoard) + return; + const cursor = editor.getCursor("from"); + let coords; + if (editor.cursorCoords) { + coords = editor.cursorCoords(true, "window"); + } else if (editor.coordsAtPos) { + const offset = editor.posToOffset(cursor); + coords = (_c = (_b = (_a = editor.cm).coordsAtPos) == null ? void 0 : _b.call(_a, offset)) != null ? _c : editor.coordsAtPos(offset); + } else { + return; + } + const lineHeight = getLineHeight(editor, editor.posToOffset(cursor)); + const calculateTop = ((_d = obsidian.requireApiVersion("0.15.0") ? activeDocument : document) == null ? void 0 : _d.body.getBoundingClientRect().height) - (coords.top || 0) - (coords.height || lineHeight); + return { + top: calculateTop || 0, + left: coords.left || 0, + bottom: coords.bottom || 0, + height: coords.height || lineHeight + }; +} +function around(obj, factories) { + const removers = Object.keys(factories).map((key) => around1(obj, key, factories[key])); + return removers.length === 1 ? removers[0] : function() { + removers.forEach((r) => r()); + }; +} +function around1(obj, method, createWrapper) { + const original = obj[method], hadOwn = obj.hasOwnProperty(method); + let current = createWrapper(original); + if (original) + Object.setPrototypeOf(current, original); + Object.setPrototypeOf(wrapper, current); + obj[method] = wrapper; + return remove; + function wrapper(...args) { + if (current === original && obj[method] === wrapper) + remove(); + return current.apply(this, args); + } + function remove() { + if (obj[method] === wrapper) { + if (hadOwn) + obj[method] = original; + else + delete obj[method]; + } + if (current === original) + return; + current = original; + Object.setPrototypeOf(wrapper, original || Function); + } +} +const SizeControls_svelte_svelte_type_style_lang = ""; +const file = "E:/obdev/.obsidian/plugins/Obsidian-Table-Generator/src/ui/basic/SizeControls.svelte"; +function create_fragment$1(ctx) { + let div2; + let div0; + let t0; + let input0; + let t1; + let div1; + let t2; + let input1; + let mounted; + let dispose; + const block = { + c: function create() { + div2 = element("div"); + div0 = element("div"); + t0 = text("H:\r\n "); + input0 = element("input"); + t1 = space(); + div1 = element("div"); + t2 = text("W:\r\n "); + input1 = element("input"); + attr_dev(input0, "class", "height-input s-b7dfVi8Mj3e3"); + add_location(input0, file, 12, 8, 374); + attr_dev(div0, "class", "input-table-generator-height s-b7dfVi8Mj3e3"); + add_location(div0, file, 10, 4, 310); + attr_dev(input1, "class", "width-input s-b7dfVi8Mj3e3"); + add_location(input1, file, 16, 8, 503); + attr_dev(div1, "class", "input-table-generator-width s-b7dfVi8Mj3e3"); + add_location(div1, file, 14, 4, 440); + attr_dev(div2, "class", "input-table-generator s-b7dfVi8Mj3e3"); + add_location(div2, file, 9, 0, 269); + }, + l: function claim(nodes) { + throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option"); + }, + m: function mount(target, anchor) { + insert_dev(target, div2, anchor); + append_dev(div2, div0); + append_dev(div0, t0); + append_dev(div0, input0); + set_input_value(input0, ctx[0]); + append_dev(div2, t1); + append_dev(div2, div1); + append_dev(div1, t2); + append_dev(div1, input1); + set_input_value(input1, ctx[1]); + if (!mounted) { + dispose = [ + listen_dev(input0, "input", ctx[2]), + listen_dev(input1, "input", ctx[3]) + ]; + mounted = true; + } + }, + p: function update2(ctx2, [dirty]) { + if (dirty & 1 && input0.value !== ctx2[0]) { + set_input_value(input0, ctx2[0]); + } + if (dirty & 2 && input1.value !== ctx2[1]) { + set_input_value(input1, ctx2[1]); + } + }, + i: noop, + o: noop, + d: function destroy(detaching) { + if (detaching) + detach_dev(div2); + mounted = false; + run_all(dispose); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_fragment$1.name, + type: "component", + source: "", + ctx + }); + return block; +} +function instance$1($$self, $$props, $$invalidate) { + let { $$slots: slots = {}, $$scope } = $$props; + validate_slots("SizeControls", slots, []); + const dispatch = createEventDispatcher(); + let { height = 160 } = $$props; + let { width = 160 } = $$props; + const writable_props = ["height", "width"]; + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== "$$" && key !== "slot") + console.warn(` was created with unknown prop '${key}'`); + }); + function input0_input_handler() { + height = this.value; + $$invalidate(0, height); + } + function input1_input_handler() { + width = this.value; + $$invalidate(1, width); + } + $$self.$$set = ($$props2) => { + if ("height" in $$props2) + $$invalidate(0, height = $$props2.height); + if ("width" in $$props2) + $$invalidate(1, width = $$props2.width); + }; + $$self.$capture_state = () => ({ + createEventDispatcher, + dispatch, + height, + width + }); + $$self.$inject_state = ($$props2) => { + if ("height" in $$props2) + $$invalidate(0, height = $$props2.height); + if ("width" in $$props2) + $$invalidate(1, width = $$props2.width); + }; + if ($$props && "$$inject" in $$props) { + $$self.$inject_state($$props.$$inject); + } + $$self.$$.update = () => { + if ($$self.$$.dirty & 3) { + dispatch("sizeUpdate", { height, width }); + } + }; + return [height, width, input0_input_handler, input1_input_handler]; +} +class SizeControls extends SvelteComponentDev { + constructor(options) { + super(options); + init(this, options, instance$1, create_fragment$1, safe_not_equal, { height: 0, width: 1 }); + dispatch_dev("SvelteRegisterComponent", { + component: this, + tagName: "SizeControls", + options, + id: create_fragment$1.name + }); + } + get height() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set height(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get width() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set width(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } +} +const { console: console_1 } = globals; +function create_sizeControls_slot(ctx) { + let sizecontrols; + let current; + sizecontrols = new SizeControls({ + props: { + slot: "sizeControls", + width: ctx[1], + height: ctx[2] + }, + $$inline: true + }); + sizecontrols.$on("sizeUpdate", ctx[3]); + const block = { + c: function create() { + create_component(sizecontrols.$$.fragment); + }, + m: function mount(target, anchor) { + mount_component(sizecontrols, target, anchor); + current = true; + }, + p: function update2(ctx2, dirty) { + const sizecontrols_changes = {}; + if (dirty & 2) + sizecontrols_changes.width = ctx2[1]; + if (dirty & 4) + sizecontrols_changes.height = ctx2[2]; + sizecontrols.$set(sizecontrols_changes); + }, + i: function intro(local) { + if (current) + return; + transition_in(sizecontrols.$$.fragment, local); + current = true; + }, + o: function outro(local) { + transition_out(sizecontrols.$$.fragment, local); + current = false; + }, + d: function destroy(detaching) { + destroy_component(sizecontrols, detaching); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_sizeControls_slot.name, + type: "slot", + source: "(47:4) ", + ctx + }); + return block; +} +function create_fragment(ctx) { + let tablegeneratorcomponent; + let current; + tablegeneratorcomponent = new TableGeneratorComponent({ + props: { + title: "Card Generator", + plugin: ctx[0], + onInsert: ctx[4], + $$slots: { sizeControls: [create_sizeControls_slot] }, + $$scope: { ctx } + }, + $$inline: true + }); + const block = { + c: function create() { + create_component(tablegeneratorcomponent.$$.fragment); + }, + l: function claim(nodes) { + throw new Error("options.hydrate only works if the component was compiled with the `hydratable: true` option"); + }, + m: function mount(target, anchor) { + mount_component(tablegeneratorcomponent, target, anchor); + current = true; + }, + p: function update2(ctx2, [dirty]) { + const tablegeneratorcomponent_changes = {}; + if (dirty & 1) + tablegeneratorcomponent_changes.plugin = ctx2[0]; + if (dirty & 134) { + tablegeneratorcomponent_changes.$$scope = { dirty, ctx: ctx2 }; + } + tablegeneratorcomponent.$set(tablegeneratorcomponent_changes); + }, + i: function intro(local) { + if (current) + return; + transition_in(tablegeneratorcomponent.$$.fragment, local); + current = true; + }, + o: function outro(local) { + transition_out(tablegeneratorcomponent.$$.fragment, local); + current = false; + }, + d: function destroy(detaching) { + destroy_component(tablegeneratorcomponent, detaching); + } + }; + dispatch_dev("SvelteRegisterBlock", { + block, + id: create_fragment.name, + type: "component", + source: "", + ctx + }); + return block; +} +function instance($$self, $$props, $$invalidate) { + let { $$slots: slots = {}, $$scope } = $$props; + validate_slots("CardGenerator", slots, []); + let { canvas } = $$props; + let { coords } = $$props; + let { plugin } = $$props; + let width = plugin.settings.defaultCardWidth || 160; + let height = plugin.settings.defaultCardHeight || 160; + function handleSizeUpdate(event) { + $$invalidate(2, height = parseInt(event.detail.height, 10)); + $$invalidate(1, width = parseInt(event.detail.width, 10)); + $$invalidate(0, plugin.settings.defaultCardHeight = height, plugin); + $$invalidate(0, plugin.settings.defaultCardWidth = width, plugin); + plugin.saveSettings(); + } + function insertTable(selectedGrid) { + return __awaiter(this, void 0, void 0, function* () { + if (selectedGrid.length === 0 || selectedGrid[1] < 2) + return; + const canvasFile = yield plugin.app.vault.cachedRead(canvas.view.file); + const canvasFileData = JSON.parse(canvasFile); + console.log(selectedGrid); + for (let i = 0; i < selectedGrid[0]; i++) { + for (let j = 0; j < selectedGrid[1]; j++) { + canvasFileData.nodes.push({ + id: random(16), + x: coords.x + j * (width + 10) + 40, + y: coords.y + i * (height + 10) + 40, + width, + height, + type: "text", + text: "" + }); + } + } + console.log(canvasFileData); + setTimeout( + () => { + canvas.setData(canvasFileData); + canvas.requestSave(); + }, + 100 + ); + }); + } + const writable_props = ["canvas", "coords", "plugin"]; + Object.keys($$props).forEach((key) => { + if (!~writable_props.indexOf(key) && key.slice(0, 2) !== "$$" && key !== "slot") + console_1.warn(` was created with unknown prop '${key}'`); + }); + $$self.$$set = ($$props2) => { + if ("canvas" in $$props2) + $$invalidate(5, canvas = $$props2.canvas); + if ("coords" in $$props2) + $$invalidate(6, coords = $$props2.coords); + if ("plugin" in $$props2) + $$invalidate(0, plugin = $$props2.plugin); + }; + $$self.$capture_state = () => ({ + __awaiter, + random, + TableGeneratorComponent, + SizeControls, + canvas, + coords, + plugin, + width, + height, + handleSizeUpdate, + insertTable + }); + $$self.$inject_state = ($$props2) => { + if ("canvas" in $$props2) + $$invalidate(5, canvas = $$props2.canvas); + if ("coords" in $$props2) + $$invalidate(6, coords = $$props2.coords); + if ("plugin" in $$props2) + $$invalidate(0, plugin = $$props2.plugin); + if ("width" in $$props2) + $$invalidate(1, width = $$props2.width); + if ("height" in $$props2) + $$invalidate(2, height = $$props2.height); + }; + if ($$props && "$$inject" in $$props) { + $$self.$inject_state($$props.$$inject); + } + return [plugin, width, height, handleSizeUpdate, insertTable, canvas, coords]; +} +class CardGenerator extends SvelteComponentDev { + constructor(options) { + super(options); + init(this, options, instance, create_fragment, safe_not_equal, { canvas: 5, coords: 6, plugin: 0 }); + dispatch_dev("SvelteRegisterComponent", { + component: this, + tagName: "CardGenerator", + options, + id: create_fragment.name + }); + const { ctx } = this.$$; + const props = options.props || {}; + if (ctx[5] === void 0 && !("canvas" in props)) { + console_1.warn(" was created without expected prop 'canvas'"); + } + if (ctx[6] === void 0 && !("coords" in props)) { + console_1.warn(" was created without expected prop 'coords'"); + } + if (ctx[0] === void 0 && !("plugin" in props)) { + console_1.warn(" was created without expected prop 'plugin'"); + } + } + get canvas() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set canvas(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get coords() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set coords(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } + get plugin() { + throw new Error(": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''"); + } + set plugin(value) { + throw new Error(": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''"); + } +} +function setTableGeneratorMenuPosition(tableGeneratorBoard, coords, displayMode) { + if (!tableGeneratorBoard) + return; + setTimeout(() => { + tableGeneratorBoard.style.display = "block"; + switch (displayMode) { + case "canvas": + tableGeneratorBoard.style.top = `${coords.top}px`; + tableGeneratorBoard.style.left = `${coords.left}px`; + break; + case "editor": + tableGeneratorBoard.style.transform = `translate(${coords.left}px,-${coords.top}px`; + break; + } + }); +} +function handleHideTableGeneratorMenu(evt, tableGeneratorEl) { + var _a; + const target = evt.target; + if (!tableGeneratorEl || !target) + return; + if (target.classList.contains("table-generator-menu") || ((_a = target.parentElement) == null ? void 0 : _a.classList.contains("table-generator-menu")) || target.tagName == "BUTTON") + return; + if (tableGeneratorEl == null ? void 0 : tableGeneratorEl.contains(target)) + return; + if (!document.body.contains(tableGeneratorEl)) + return; + tableGeneratorEl.detach(); +} +const DEFAULT_SETTINGS = { + rowCount: 8, + columnCount: 8, + defaultAlignment: "left", + defaultCardWidth: 160, + defaultCardHeight: 160 +}; +class TableGeneratorPlugin extends obsidian.Plugin { + constructor() { + super(...arguments); + __publicField(this, "tableGeneratorEl", null); + __publicField(this, "tableGeneratorComponent"); + __publicField(this, "settings"); + } + async onload() { + this.registerEvent( + this.app.workspace.on("editor-menu", (menu, editor, view) => this.handleCreateTableGeneratorInMenu(menu, editor, view)) + ); + await this.registerSettings(); + this.registerDomEvent(window, "click", (evt) => handleHideTableGeneratorMenu(evt, this.tableGeneratorEl)); + if (obsidian.requireApiVersion("0.15.0")) + this.registerTableGeneratorMenu(); + this.registerCommands(); + this.registerCanvasMenu(); + } + hideTable() { + var _a; + (_a = this.tableGeneratorEl) == null ? void 0 : _a.detach(); + } + handleCreateTableGeneratorInMenu(menu, editor, view) { + menu.addItem((item) => { + const itemDom = item.dom; + itemDom.addClass("table-generator-menu"); + item.setTitle("Add Markdown Table").setIcon("table").setSection("action").onClick(async () => { + this.createGeneratorMenu("table", { editor }, this); + const coords = calculateEditor(editor, this.tableGeneratorEl); + if (!coords) + return; + setTableGeneratorMenuPosition(this.tableGeneratorEl, coords, "editor"); + }); + }); + } + createGeneratorMenu(type, context, plugin) { + var _a; + if (this.tableGeneratorEl) + this.tableGeneratorEl.detach(); + this.tableGeneratorEl = (_a = obsidian.requireApiVersion("0.15.0") ? activeDocument : document) == null ? void 0 : _a.body.createEl("div", { cls: "table-generator-view" }); + this.tableGeneratorEl.hide(); + if (type === "table") { + this.tableGeneratorComponent = new TableGenerator({ + target: this.tableGeneratorEl, + props: { editor: context.editor, plugin } + }); + } else if (type === "card") { + this.tableGeneratorComponent = new CardGenerator({ + target: this.tableGeneratorEl, + props: { canvas: context.canvas, coords: context.coords, plugin } + }); + } + } + async registerSettings() { + await this.loadSettings(); + this.addSettingTab(new TableGeneratorSettingTab(this.app, this)); + this.registerInterval( + window.setTimeout(() => { + this.saveSettings(); + }, 100) + ); + } + registerCanvasMenu() { + const createCardTable = (canvas, e, t, a) => { + const { top, left } = e.dom.getBoundingClientRect(); + const data = reverseCalculation(t, canvas); + console.log(data); + setTimeout(() => { + this.createGeneratorMenu("card", { canvas, coords: t }, this); + setTableGeneratorMenuPosition(this.tableGeneratorEl, { top, left, bottom: 0, height: 0 }, "canvas"); + }, 0); + }; + const patchNode = () => { + var _a; + const canvasView = (_a = this.app.workspace.getLeavesOfType("canvas").first()) == null ? void 0 : _a.view; + const canvas = canvasView == null ? void 0 : canvasView.canvas; + if (!canvas) + return false; + const uninstaller = around(canvas.constructor.prototype, { + showCreationMenu: (next) => function(e, t, a) { + const result = next.call(this, e, t, a); + e.addSeparator().addItem((item) => { + item.setSection("create").setTitle("Add Card Table").setIcon("table").onClick(async () => { + createCardTable(this, e, t); + }); + }); + return result; + } + }); + this.register(uninstaller); + console.log("Obsidian-Canvas-MindMap: canvas node patched"); + return true; + }; + this.app.workspace.onLayoutReady(() => { + if (!patchNode()) { + const evt = this.app.workspace.on("layout-change", () => { + patchNode() && this.app.workspace.offref(evt); + }); + this.registerEvent(evt); + } + }); + } + registerCommands() { + this.addCommand({ + id: "create-table-genertator", + name: "Create Table Generator", + editorCallback: (editor, view) => { + var _a; + if ((_a = obsidian.requireApiVersion("0.15.0") ? activeDocument : document) == null ? void 0 : _a.body.contains(this.tableGeneratorEl)) + return; + this.createGeneratorMenu("table", { editor }, this); + const coords = calculateEditor(editor, this.tableGeneratorEl); + if (!coords) + return; + setTableGeneratorMenuPosition(this.tableGeneratorEl, coords, "editor"); + } + }); + } + registerTableGeneratorMenu() { + this.app.workspace.on("window-open", (leaf) => { + this.registerDomEvent(leaf.doc, "click", (evt) => { + var _a, _b; + const target = evt.target; + if (!this.tableGeneratorEl || !target) + return; + if (target.classList.contains("table-generator-menu") || ((_a = target.parentElement) == null ? void 0 : _a.classList.contains("table-generator-menu")) || target.tagName == "BUTTON") + return; + if ((_b = this.tableGeneratorEl) == null ? void 0 : _b.contains(target)) + return; + if (!activeDocument.body.contains(this.tableGeneratorEl)) + return; + this.tableGeneratorEl.detach(); + }); + }); + } + onunload() { + if (this.tableGeneratorEl) { + this.tableGeneratorComponent.$destroy(); + this.tableGeneratorEl.detach(); + } + } + async loadSettings() { + this.settings = Object.assign({}, DEFAULT_SETTINGS, await this.loadData()); + } + async saveSettings() { + await this.saveData(this.settings); + } +} +class TableGeneratorSettingTab extends obsidian.PluginSettingTab { + constructor(app, plugin) { + super(app, plugin); + __publicField(this, "plugin"); + this.plugin = plugin; + } + display() { + const { containerEl } = this; + containerEl.empty(); + containerEl.createEl("h2", { text: "Table Generator" }); + let rowText; + new obsidian.Setting(containerEl).setName("Row Count").setDesc("The number of rows in the table").addSlider( + (slider) => slider.setLimits(2, 12, 1).setValue(this.plugin.settings.rowCount).onChange(async (value) => { + rowText.innerText = ` ${value.toString()}`; + this.plugin.settings.rowCount = value; + }) + ).settingEl.createDiv("", (el) => { + rowText = el; + el.className = "table-generator-setting-text"; + el.innerText = ` ${this.plugin.settings.rowCount.toString()}`; + }); + let columnText; + new obsidian.Setting(containerEl).setName("Columns Count").setDesc("The number of columns in the table").addSlider( + (slider) => slider.setLimits(2, 12, 1).setValue(this.plugin.settings.columnCount).onChange(async (value) => { + columnText.innerText = ` ${value.toString()}`; + this.plugin.settings.columnCount = value; + }) + ).settingEl.createDiv("", (el) => { + columnText = el; + el.className = "table-generator-setting-text"; + el.innerText = ` ${this.plugin.settings.columnCount.toString()}`; + }); + this.containerEl.createEl("h2", { text: "Say Thank You" }); + new obsidian.Setting(containerEl).setName("Donate").setDesc("If you like this plugin, consider donating to support continued development:").addButton((bt) => { + bt.buttonEl.outerHTML = ``; + }); + } +} +module.exports = TableGeneratorPlugin; +//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFpbi5qcyIsInNvdXJjZXMiOlsibm9kZV9tb2R1bGVzLy5wbnBtL3N2ZWx0ZUAzLjUwLjEvbm9kZV9tb2R1bGVzL3N2ZWx0ZS9pbnRlcm5hbC9pbmRleC5tanMiLCJub2RlX21vZHVsZXMvLnBucG0vdHNsaWJAMi40LjAvbm9kZV9tb2R1bGVzL3RzbGliL3RzbGliLmVzNi5qcyIsInNyYy91aS9iYXNpYy9UYWJsZS5zdmVsdGUiLCJzcmMvdWkvYmFzaWMvVGFibGVHZW5lcmF0b3JDb21wb25lbnQuc3ZlbHRlIiwic3JjL3V0aWxzL21hcmtkb3duVGFibGUudHMiLCJzcmMvdWkvYmFzaWMvQWxpZ25JdGVtcy5zdmVsdGUiLCJzcmMvdWkvVGFibGVHZW5lcmF0b3Iuc3ZlbHRlIiwic3JjL3V0aWxzL3RhYmxlUE9TLnRzIiwibm9kZV9tb2R1bGVzLy5wbnBtL21vbmtleS1hcm91bmRAMi4zLjAvbm9kZV9tb2R1bGVzL21vbmtleS1hcm91bmQvbWpzL2luZGV4LmpzIiwic3JjL3VpL2Jhc2ljL1NpemVDb250cm9scy5zdmVsdGUiLCJzcmMvdWkvQ2FyZEdlbmVyYXRvci5zdmVsdGUiLCJzcmMvdXRpbHMvdGFibGVET00udHMiLCJzcmMvdGFibGVHZW5lcmF0b3JJbmRleC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJmdW5jdGlvbiBub29wKCkgeyB9XG5jb25zdCBpZGVudGl0eSA9IHggPT4geDtcbmZ1bmN0aW9uIGFzc2lnbih0YXIsIHNyYykge1xuICAgIC8vIEB0cy1pZ25vcmVcbiAgICBmb3IgKGNvbnN0IGsgaW4gc3JjKVxuICAgICAgICB0YXJba10gPSBzcmNba107XG4gICAgcmV0dXJuIHRhcjtcbn1cbmZ1bmN0aW9uIGlzX3Byb21pc2UodmFsdWUpIHtcbiAgICByZXR1cm4gdmFsdWUgJiYgdHlwZW9mIHZhbHVlID09PSAnb2JqZWN0JyAmJiB0eXBlb2YgdmFsdWUudGhlbiA9PT0gJ2Z1bmN0aW9uJztcbn1cbmZ1bmN0aW9uIGFkZF9sb2NhdGlvbihlbGVtZW50LCBmaWxlLCBsaW5lLCBjb2x1bW4sIGNoYXIpIHtcbiAgICBlbGVtZW50Ll9fc3ZlbHRlX21ldGEgPSB7XG4gICAgICAgIGxvYzogeyBmaWxlLCBsaW5lLCBjb2x1bW4sIGNoYXIgfVxuICAgIH07XG59XG5mdW5jdGlvbiBydW4oZm4pIHtcbiAgICByZXR1cm4gZm4oKTtcbn1cbmZ1bmN0aW9uIGJsYW5rX29iamVjdCgpIHtcbiAgICByZXR1cm4gT2JqZWN0LmNyZWF0ZShudWxsKTtcbn1cbmZ1bmN0aW9uIHJ1bl9hbGwoZm5zKSB7XG4gICAgZm5zLmZvckVhY2gocnVuKTtcbn1cbmZ1bmN0aW9uIGlzX2Z1bmN0aW9uKHRoaW5nKSB7XG4gICAgcmV0dXJuIHR5cGVvZiB0aGluZyA9PT0gJ2Z1bmN0aW9uJztcbn1cbmZ1bmN0aW9uIHNhZmVfbm90X2VxdWFsKGEsIGIpIHtcbiAgICByZXR1cm4gYSAhPSBhID8gYiA9PSBiIDogYSAhPT0gYiB8fCAoKGEgJiYgdHlwZW9mIGEgPT09ICdvYmplY3QnKSB8fCB0eXBlb2YgYSA9PT0gJ2Z1bmN0aW9uJyk7XG59XG5sZXQgc3JjX3VybF9lcXVhbF9hbmNob3I7XG5mdW5jdGlvbiBzcmNfdXJsX2VxdWFsKGVsZW1lbnRfc3JjLCB1cmwpIHtcbiAgICBpZiAoIXNyY191cmxfZXF1YWxfYW5jaG9yKSB7XG4gICAgICAgIHNyY191cmxfZXF1YWxfYW5jaG9yID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnYScpO1xuICAgIH1cbiAgICBzcmNfdXJsX2VxdWFsX2FuY2hvci5ocmVmID0gdXJsO1xuICAgIHJldHVybiBlbGVtZW50X3NyYyA9PT0gc3JjX3VybF9lcXVhbF9hbmNob3IuaHJlZjtcbn1cbmZ1bmN0aW9uIG5vdF9lcXVhbChhLCBiKSB7XG4gICAgcmV0dXJuIGEgIT0gYSA/IGIgPT0gYiA6IGEgIT09IGI7XG59XG5mdW5jdGlvbiBpc19lbXB0eShvYmopIHtcbiAgICByZXR1cm4gT2JqZWN0LmtleXMob2JqKS5sZW5ndGggPT09IDA7XG59XG5mdW5jdGlvbiB2YWxpZGF0ZV9zdG9yZShzdG9yZSwgbmFtZSkge1xuICAgIGlmIChzdG9yZSAhPSBudWxsICYmIHR5cGVvZiBzdG9yZS5zdWJzY3JpYmUgIT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGAnJHtuYW1lfScgaXMgbm90IGEgc3RvcmUgd2l0aCBhICdzdWJzY3JpYmUnIG1ldGhvZGApO1xuICAgIH1cbn1cbmZ1bmN0aW9uIHN1YnNjcmliZShzdG9yZSwgLi4uY2FsbGJhY2tzKSB7XG4gICAgaWYgKHN0b3JlID09IG51bGwpIHtcbiAgICAgICAgcmV0dXJuIG5vb3A7XG4gICAgfVxuICAgIGNvbnN0IHVuc3ViID0gc3RvcmUuc3Vic2NyaWJlKC4uLmNhbGxiYWNrcyk7XG4gICAgcmV0dXJuIHVuc3ViLnVuc3Vic2NyaWJlID8gKCkgPT4gdW5zdWIudW5zdWJzY3JpYmUoKSA6IHVuc3ViO1xufVxuZnVuY3Rpb24gZ2V0X3N0b3JlX3ZhbHVlKHN0b3JlKSB7XG4gICAgbGV0IHZhbHVlO1xuICAgIHN1YnNjcmliZShzdG9yZSwgXyA9PiB2YWx1ZSA9IF8pKCk7XG4gICAgcmV0dXJuIHZhbHVlO1xufVxuZnVuY3Rpb24gY29tcG9uZW50X3N1YnNjcmliZShjb21wb25lbnQsIHN0b3JlLCBjYWxsYmFjaykge1xuICAgIGNvbXBvbmVudC4kJC5vbl9kZXN0cm95LnB1c2goc3Vic2NyaWJlKHN0b3JlLCBjYWxsYmFjaykpO1xufVxuZnVuY3Rpb24gY3JlYXRlX3Nsb3QoZGVmaW5pdGlvbiwgY3R4LCAkJHNjb3BlLCBmbikge1xuICAgIGlmIChkZWZpbml0aW9uKSB7XG4gICAgICAgIGNvbnN0IHNsb3RfY3R4ID0gZ2V0X3Nsb3RfY29udGV4dChkZWZpbml0aW9uLCBjdHgsICQkc2NvcGUsIGZuKTtcbiAgICAgICAgcmV0dXJuIGRlZmluaXRpb25bMF0oc2xvdF9jdHgpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIGdldF9zbG90X2NvbnRleHQoZGVmaW5pdGlvbiwgY3R4LCAkJHNjb3BlLCBmbikge1xuICAgIHJldHVybiBkZWZpbml0aW9uWzFdICYmIGZuXG4gICAgICAgID8gYXNzaWduKCQkc2NvcGUuY3R4LnNsaWNlKCksIGRlZmluaXRpb25bMV0oZm4oY3R4KSkpXG4gICAgICAgIDogJCRzY29wZS5jdHg7XG59XG5mdW5jdGlvbiBnZXRfc2xvdF9jaGFuZ2VzKGRlZmluaXRpb24sICQkc2NvcGUsIGRpcnR5LCBmbikge1xuICAgIGlmIChkZWZpbml0aW9uWzJdICYmIGZuKSB7XG4gICAgICAgIGNvbnN0IGxldHMgPSBkZWZpbml0aW9uWzJdKGZuKGRpcnR5KSk7XG4gICAgICAgIGlmICgkJHNjb3BlLmRpcnR5ID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICAgIHJldHVybiBsZXRzO1xuICAgICAgICB9XG4gICAgICAgIGlmICh0eXBlb2YgbGV0cyA9PT0gJ29iamVjdCcpIHtcbiAgICAgICAgICAgIGNvbnN0IG1lcmdlZCA9IFtdO1xuICAgICAgICAgICAgY29uc3QgbGVuID0gTWF0aC5tYXgoJCRzY29wZS5kaXJ0eS5sZW5ndGgsIGxldHMubGVuZ3RoKTtcbiAgICAgICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbGVuOyBpICs9IDEpIHtcbiAgICAgICAgICAgICAgICBtZXJnZWRbaV0gPSAkJHNjb3BlLmRpcnR5W2ldIHwgbGV0c1tpXTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiBtZXJnZWQ7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuICQkc2NvcGUuZGlydHkgfCBsZXRzO1xuICAgIH1cbiAgICByZXR1cm4gJCRzY29wZS5kaXJ0eTtcbn1cbmZ1bmN0aW9uIHVwZGF0ZV9zbG90X2Jhc2Uoc2xvdCwgc2xvdF9kZWZpbml0aW9uLCBjdHgsICQkc2NvcGUsIHNsb3RfY2hhbmdlcywgZ2V0X3Nsb3RfY29udGV4dF9mbikge1xuICAgIGlmIChzbG90X2NoYW5nZXMpIHtcbiAgICAgICAgY29uc3Qgc2xvdF9jb250ZXh0ID0gZ2V0X3Nsb3RfY29udGV4dChzbG90X2RlZmluaXRpb24sIGN0eCwgJCRzY29wZSwgZ2V0X3Nsb3RfY29udGV4dF9mbik7XG4gICAgICAgIHNsb3QucChzbG90X2NvbnRleHQsIHNsb3RfY2hhbmdlcyk7XG4gICAgfVxufVxuZnVuY3Rpb24gdXBkYXRlX3Nsb3Qoc2xvdCwgc2xvdF9kZWZpbml0aW9uLCBjdHgsICQkc2NvcGUsIGRpcnR5LCBnZXRfc2xvdF9jaGFuZ2VzX2ZuLCBnZXRfc2xvdF9jb250ZXh0X2ZuKSB7XG4gICAgY29uc3Qgc2xvdF9jaGFuZ2VzID0gZ2V0X3Nsb3RfY2hhbmdlcyhzbG90X2RlZmluaXRpb24sICQkc2NvcGUsIGRpcnR5LCBnZXRfc2xvdF9jaGFuZ2VzX2ZuKTtcbiAgICB1cGRhdGVfc2xvdF9iYXNlKHNsb3QsIHNsb3RfZGVmaW5pdGlvbiwgY3R4LCAkJHNjb3BlLCBzbG90X2NoYW5nZXMsIGdldF9zbG90X2NvbnRleHRfZm4pO1xufVxuZnVuY3Rpb24gZ2V0X2FsbF9kaXJ0eV9mcm9tX3Njb3BlKCQkc2NvcGUpIHtcbiAgICBpZiAoJCRzY29wZS5jdHgubGVuZ3RoID4gMzIpIHtcbiAgICAgICAgY29uc3QgZGlydHkgPSBbXTtcbiAgICAgICAgY29uc3QgbGVuZ3RoID0gJCRzY29wZS5jdHgubGVuZ3RoIC8gMzI7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgbGVuZ3RoOyBpKyspIHtcbiAgICAgICAgICAgIGRpcnR5W2ldID0gLTE7XG4gICAgICAgIH1cbiAgICAgICAgcmV0dXJuIGRpcnR5O1xuICAgIH1cbiAgICByZXR1cm4gLTE7XG59XG5mdW5jdGlvbiBleGNsdWRlX2ludGVybmFsX3Byb3BzKHByb3BzKSB7XG4gICAgY29uc3QgcmVzdWx0ID0ge307XG4gICAgZm9yIChjb25zdCBrIGluIHByb3BzKVxuICAgICAgICBpZiAoa1swXSAhPT0gJyQnKVxuICAgICAgICAgICAgcmVzdWx0W2tdID0gcHJvcHNba107XG4gICAgcmV0dXJuIHJlc3VsdDtcbn1cbmZ1bmN0aW9uIGNvbXB1dGVfcmVzdF9wcm9wcyhwcm9wcywga2V5cykge1xuICAgIGNvbnN0IHJlc3QgPSB7fTtcbiAgICBrZXlzID0gbmV3IFNldChrZXlzKTtcbiAgICBmb3IgKGNvbnN0IGsgaW4gcHJvcHMpXG4gICAgICAgIGlmICgha2V5cy5oYXMoaykgJiYga1swXSAhPT0gJyQnKVxuICAgICAgICAgICAgcmVzdFtrXSA9IHByb3BzW2tdO1xuICAgIHJldHVybiByZXN0O1xufVxuZnVuY3Rpb24gY29tcHV0ZV9zbG90cyhzbG90cykge1xuICAgIGNvbnN0IHJlc3VsdCA9IHt9O1xuICAgIGZvciAoY29uc3Qga2V5IGluIHNsb3RzKSB7XG4gICAgICAgIHJlc3VsdFtrZXldID0gdHJ1ZTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbn1cbmZ1bmN0aW9uIG9uY2UoZm4pIHtcbiAgICBsZXQgcmFuID0gZmFsc2U7XG4gICAgcmV0dXJuIGZ1bmN0aW9uICguLi5hcmdzKSB7XG4gICAgICAgIGlmIChyYW4pXG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIHJhbiA9IHRydWU7XG4gICAgICAgIGZuLmNhbGwodGhpcywgLi4uYXJncyk7XG4gICAgfTtcbn1cbmZ1bmN0aW9uIG51bGxfdG9fZW1wdHkodmFsdWUpIHtcbiAgICByZXR1cm4gdmFsdWUgPT0gbnVsbCA/ICcnIDogdmFsdWU7XG59XG5mdW5jdGlvbiBzZXRfc3RvcmVfdmFsdWUoc3RvcmUsIHJldCwgdmFsdWUpIHtcbiAgICBzdG9yZS5zZXQodmFsdWUpO1xuICAgIHJldHVybiByZXQ7XG59XG5jb25zdCBoYXNfcHJvcCA9IChvYmosIHByb3ApID0+IE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChvYmosIHByb3ApO1xuZnVuY3Rpb24gYWN0aW9uX2Rlc3Ryb3llcihhY3Rpb25fcmVzdWx0KSB7XG4gICAgcmV0dXJuIGFjdGlvbl9yZXN1bHQgJiYgaXNfZnVuY3Rpb24oYWN0aW9uX3Jlc3VsdC5kZXN0cm95KSA/IGFjdGlvbl9yZXN1bHQuZGVzdHJveSA6IG5vb3A7XG59XG5cbmNvbnN0IGlzX2NsaWVudCA9IHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnO1xubGV0IG5vdyA9IGlzX2NsaWVudFxuICAgID8gKCkgPT4gd2luZG93LnBlcmZvcm1hbmNlLm5vdygpXG4gICAgOiAoKSA9PiBEYXRlLm5vdygpO1xubGV0IHJhZiA9IGlzX2NsaWVudCA/IGNiID0+IHJlcXVlc3RBbmltYXRpb25GcmFtZShjYikgOiBub29wO1xuLy8gdXNlZCBpbnRlcm5hbGx5IGZvciB0ZXN0aW5nXG5mdW5jdGlvbiBzZXRfbm93KGZuKSB7XG4gICAgbm93ID0gZm47XG59XG5mdW5jdGlvbiBzZXRfcmFmKGZuKSB7XG4gICAgcmFmID0gZm47XG59XG5cbmNvbnN0IHRhc2tzID0gbmV3IFNldCgpO1xuZnVuY3Rpb24gcnVuX3Rhc2tzKG5vdykge1xuICAgIHRhc2tzLmZvckVhY2godGFzayA9PiB7XG4gICAgICAgIGlmICghdGFzay5jKG5vdykpIHtcbiAgICAgICAgICAgIHRhc2tzLmRlbGV0ZSh0YXNrKTtcbiAgICAgICAgICAgIHRhc2suZigpO1xuICAgICAgICB9XG4gICAgfSk7XG4gICAgaWYgKHRhc2tzLnNpemUgIT09IDApXG4gICAgICAgIHJhZihydW5fdGFza3MpO1xufVxuLyoqXG4gKiBGb3IgdGVzdGluZyBwdXJwb3NlcyBvbmx5IVxuICovXG5mdW5jdGlvbiBjbGVhcl9sb29wcygpIHtcbiAgICB0YXNrcy5jbGVhcigpO1xufVxuLyoqXG4gKiBDcmVhdGVzIGEgbmV3IHRhc2sgdGhhdCBydW5zIG9uIGVhY2ggcmFmIGZyYW1lXG4gKiB1bnRpbCBpdCByZXR1cm5zIGEgZmFsc3kgdmFsdWUgb3IgaXMgYWJvcnRlZFxuICovXG5mdW5jdGlvbiBsb29wKGNhbGxiYWNrKSB7XG4gICAgbGV0IHRhc2s7XG4gICAgaWYgKHRhc2tzLnNpemUgPT09IDApXG4gICAgICAgIHJhZihydW5fdGFza3MpO1xuICAgIHJldHVybiB7XG4gICAgICAgIHByb21pc2U6IG5ldyBQcm9taXNlKGZ1bGZpbGwgPT4ge1xuICAgICAgICAgICAgdGFza3MuYWRkKHRhc2sgPSB7IGM6IGNhbGxiYWNrLCBmOiBmdWxmaWxsIH0pO1xuICAgICAgICB9KSxcbiAgICAgICAgYWJvcnQoKSB7XG4gICAgICAgICAgICB0YXNrcy5kZWxldGUodGFzayk7XG4gICAgICAgIH1cbiAgICB9O1xufVxuXG4vLyBUcmFjayB3aGljaCBub2RlcyBhcmUgY2xhaW1lZCBkdXJpbmcgaHlkcmF0aW9uLiBVbmNsYWltZWQgbm9kZXMgY2FuIHRoZW4gYmUgcmVtb3ZlZCBmcm9tIHRoZSBET01cbi8vIGF0IHRoZSBlbmQgb2YgaHlkcmF0aW9uIHdpdGhvdXQgdG91Y2hpbmcgdGhlIHJlbWFpbmluZyBub2Rlcy5cbmxldCBpc19oeWRyYXRpbmcgPSBmYWxzZTtcbmZ1bmN0aW9uIHN0YXJ0X2h5ZHJhdGluZygpIHtcbiAgICBpc19oeWRyYXRpbmcgPSB0cnVlO1xufVxuZnVuY3Rpb24gZW5kX2h5ZHJhdGluZygpIHtcbiAgICBpc19oeWRyYXRpbmcgPSBmYWxzZTtcbn1cbmZ1bmN0aW9uIHVwcGVyX2JvdW5kKGxvdywgaGlnaCwga2V5LCB2YWx1ZSkge1xuICAgIC8vIFJldHVybiBmaXJzdCBpbmRleCBvZiB2YWx1ZSBsYXJnZXIgdGhhbiBpbnB1dCB2YWx1ZSBpbiB0aGUgcmFuZ2UgW2xvdywgaGlnaClcbiAgICB3aGlsZSAobG93IDwgaGlnaCkge1xuICAgICAgICBjb25zdCBtaWQgPSBsb3cgKyAoKGhpZ2ggLSBsb3cpID4+IDEpO1xuICAgICAgICBpZiAoa2V5KG1pZCkgPD0gdmFsdWUpIHtcbiAgICAgICAgICAgIGxvdyA9IG1pZCArIDE7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICBoaWdoID0gbWlkO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBsb3c7XG59XG5mdW5jdGlvbiBpbml0X2h5ZHJhdGUodGFyZ2V0KSB7XG4gICAgaWYgKHRhcmdldC5oeWRyYXRlX2luaXQpXG4gICAgICAgIHJldHVybjtcbiAgICB0YXJnZXQuaHlkcmF0ZV9pbml0ID0gdHJ1ZTtcbiAgICAvLyBXZSBrbm93IHRoYXQgYWxsIGNoaWxkcmVuIGhhdmUgY2xhaW1fb3JkZXIgdmFsdWVzIHNpbmNlIHRoZSB1bmNsYWltZWQgaGF2ZSBiZWVuIGRldGFjaGVkIGlmIHRhcmdldCBpcyBub3QgPGhlYWQ+XG4gICAgbGV0IGNoaWxkcmVuID0gdGFyZ2V0LmNoaWxkTm9kZXM7XG4gICAgLy8gSWYgdGFyZ2V0IGlzIDxoZWFkPiwgdGhlcmUgbWF5IGJlIGNoaWxkcmVuIHdpdGhvdXQgY2xhaW1fb3JkZXJcbiAgICBpZiAodGFyZ2V0Lm5vZGVOYW1lID09PSAnSEVBRCcpIHtcbiAgICAgICAgY29uc3QgbXlDaGlsZHJlbiA9IFtdO1xuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IGNoaWxkcmVuLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBjb25zdCBub2RlID0gY2hpbGRyZW5baV07XG4gICAgICAgICAgICBpZiAobm9kZS5jbGFpbV9vcmRlciAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgICAgbXlDaGlsZHJlbi5wdXNoKG5vZGUpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIGNoaWxkcmVuID0gbXlDaGlsZHJlbjtcbiAgICB9XG4gICAgLypcbiAgICAqIFJlb3JkZXIgY2xhaW1lZCBjaGlsZHJlbiBvcHRpbWFsbHkuXG4gICAgKiBXZSBjYW4gcmVvcmRlciBjbGFpbWVkIGNoaWxkcmVuIG9wdGltYWxseSBieSBmaW5kaW5nIHRoZSBsb25nZXN0IHN1YnNlcXVlbmNlIG9mXG4gICAgKiBub2RlcyB0aGF0IGFyZSBhbHJlYWR5IGNsYWltZWQgaW4gb3JkZXIgYW5kIG9ubHkgbW92aW5nIHRoZSByZXN0LiBUaGUgbG9uZ2VzdFxuICAgICogc3Vic2VxdWVuY2Ugc3Vic2VxdWVuY2Ugb2Ygbm9kZXMgdGhhdCBhcmUgY2xhaW1lZCBpbiBvcmRlciBjYW4gYmUgZm91bmQgYnlcbiAgICAqIGNvbXB1dGluZyB0aGUgbG9uZ2VzdCBpbmNyZWFzaW5nIHN1YnNlcXVlbmNlIG9mIC5jbGFpbV9vcmRlciB2YWx1ZXMuXG4gICAgKlxuICAgICogVGhpcyBhbGdvcml0aG0gaXMgb3B0aW1hbCBpbiBnZW5lcmF0aW5nIHRoZSBsZWFzdCBhbW91bnQgb2YgcmVvcmRlciBvcGVyYXRpb25zXG4gICAgKiBwb3NzaWJsZS5cbiAgICAqXG4gICAgKiBQcm9vZjpcbiAgICAqIFdlIGtub3cgdGhhdCwgZ2l2ZW4gYSBzZXQgb2YgcmVvcmRlcmluZyBvcGVyYXRpb25zLCB0aGUgbm9kZXMgdGhhdCBkbyBub3QgbW92ZVxuICAgICogYWx3YXlzIGZvcm0gYW4gaW5jcmVhc2luZyBzdWJzZXF1ZW5jZSwgc2luY2UgdGhleSBkbyBub3QgbW92ZSBhbW9uZyBlYWNoIG90aGVyXG4gICAgKiBtZWFuaW5nIHRoYXQgdGhleSBtdXN0IGJlIGFscmVhZHkgb3JkZXJlZCBhbW9uZyBlYWNoIG90aGVyLiBUaHVzLCB0aGUgbWF4aW1hbFxuICAgICogc2V0IG9mIG5vZGVzIHRoYXQgZG8gbm90IG1vdmUgZm9ybSBhIGxvbmdlc3QgaW5jcmVhc2luZyBzdWJzZXF1ZW5jZS5cbiAgICAqL1xuICAgIC8vIENvbXB1dGUgbG9uZ2VzdCBpbmNyZWFzaW5nIHN1YnNlcXVlbmNlXG4gICAgLy8gbTogc3Vic2VxdWVuY2UgbGVuZ3RoIGogPT4gaW5kZXggayBvZiBzbWFsbGVzdCB2YWx1ZSB0aGF0IGVuZHMgYW4gaW5jcmVhc2luZyBzdWJzZXF1ZW5jZSBvZiBsZW5ndGggalxuICAgIGNvbnN0IG0gPSBuZXcgSW50MzJBcnJheShjaGlsZHJlbi5sZW5ndGggKyAxKTtcbiAgICAvLyBQcmVkZWNlc3NvciBpbmRpY2VzICsgMVxuICAgIGNvbnN0IHAgPSBuZXcgSW50MzJBcnJheShjaGlsZHJlbi5sZW5ndGgpO1xuICAgIG1bMF0gPSAtMTtcbiAgICBsZXQgbG9uZ2VzdCA9IDA7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBjaGlsZHJlbi5sZW5ndGg7IGkrKykge1xuICAgICAgICBjb25zdCBjdXJyZW50ID0gY2hpbGRyZW5baV0uY2xhaW1fb3JkZXI7XG4gICAgICAgIC8vIEZpbmQgdGhlIGxhcmdlc3Qgc3Vic2VxdWVuY2UgbGVuZ3RoIHN1Y2ggdGhhdCBpdCBlbmRzIGluIGEgdmFsdWUgbGVzcyB0aGFuIG91ciBjdXJyZW50IHZhbHVlXG4gICAgICAgIC8vIHVwcGVyX2JvdW5kIHJldHVybnMgZmlyc3QgZ3JlYXRlciB2YWx1ZSwgc28gd2Ugc3VidHJhY3Qgb25lXG4gICAgICAgIC8vIHdpdGggZmFzdCBwYXRoIGZvciB3aGVuIHdlIGFyZSBvbiB0aGUgY3VycmVudCBsb25nZXN0IHN1YnNlcXVlbmNlXG4gICAgICAgIGNvbnN0IHNlcUxlbiA9ICgobG9uZ2VzdCA+IDAgJiYgY2hpbGRyZW5bbVtsb25nZXN0XV0uY2xhaW1fb3JkZXIgPD0gY3VycmVudCkgPyBsb25nZXN0ICsgMSA6IHVwcGVyX2JvdW5kKDEsIGxvbmdlc3QsIGlkeCA9PiBjaGlsZHJlblttW2lkeF1dLmNsYWltX29yZGVyLCBjdXJyZW50KSkgLSAxO1xuICAgICAgICBwW2ldID0gbVtzZXFMZW5dICsgMTtcbiAgICAgICAgY29uc3QgbmV3TGVuID0gc2VxTGVuICsgMTtcbiAgICAgICAgLy8gV2UgY2FuIGd1YXJhbnRlZSB0aGF0IGN1cnJlbnQgaXMgdGhlIHNtYWxsZXN0IHZhbHVlLiBPdGhlcndpc2UsIHdlIHdvdWxkIGhhdmUgZ2VuZXJhdGVkIGEgbG9uZ2VyIHNlcXVlbmNlLlxuICAgICAgICBtW25ld0xlbl0gPSBpO1xuICAgICAgICBsb25nZXN0ID0gTWF0aC5tYXgobmV3TGVuLCBsb25nZXN0KTtcbiAgICB9XG4gICAgLy8gVGhlIGxvbmdlc3QgaW5jcmVhc2luZyBzdWJzZXF1ZW5jZSBvZiBub2RlcyAoaW5pdGlhbGx5IHJldmVyc2VkKVxuICAgIGNvbnN0IGxpcyA9IFtdO1xuICAgIC8vIFRoZSByZXN0IG9mIHRoZSBub2Rlcywgbm9kZXMgdGhhdCB3aWxsIGJlIG1vdmVkXG4gICAgY29uc3QgdG9Nb3ZlID0gW107XG4gICAgbGV0IGxhc3QgPSBjaGlsZHJlbi5sZW5ndGggLSAxO1xuICAgIGZvciAobGV0IGN1ciA9IG1bbG9uZ2VzdF0gKyAxOyBjdXIgIT0gMDsgY3VyID0gcFtjdXIgLSAxXSkge1xuICAgICAgICBsaXMucHVzaChjaGlsZHJlbltjdXIgLSAxXSk7XG4gICAgICAgIGZvciAoOyBsYXN0ID49IGN1cjsgbGFzdC0tKSB7XG4gICAgICAgICAgICB0b01vdmUucHVzaChjaGlsZHJlbltsYXN0XSk7XG4gICAgICAgIH1cbiAgICAgICAgbGFzdC0tO1xuICAgIH1cbiAgICBmb3IgKDsgbGFzdCA+PSAwOyBsYXN0LS0pIHtcbiAgICAgICAgdG9Nb3ZlLnB1c2goY2hpbGRyZW5bbGFzdF0pO1xuICAgIH1cbiAgICBsaXMucmV2ZXJzZSgpO1xuICAgIC8vIFdlIHNvcnQgdGhlIG5vZGVzIGJlaW5nIG1vdmVkIHRvIGd1YXJhbnRlZSB0aGF0IHRoZWlyIGluc2VydGlvbiBvcmRlciBtYXRjaGVzIHRoZSBjbGFpbSBvcmRlclxuICAgIHRvTW92ZS5zb3J0KChhLCBiKSA9PiBhLmNsYWltX29yZGVyIC0gYi5jbGFpbV9vcmRlcik7XG4gICAgLy8gRmluYWxseSwgd2UgbW92ZSB0aGUgbm9kZXNcbiAgICBmb3IgKGxldCBpID0gMCwgaiA9IDA7IGkgPCB0b01vdmUubGVuZ3RoOyBpKyspIHtcbiAgICAgICAgd2hpbGUgKGogPCBsaXMubGVuZ3RoICYmIHRvTW92ZVtpXS5jbGFpbV9vcmRlciA+PSBsaXNbal0uY2xhaW1fb3JkZXIpIHtcbiAgICAgICAgICAgIGorKztcbiAgICAgICAgfVxuICAgICAgICBjb25zdCBhbmNob3IgPSBqIDwgbGlzLmxlbmd0aCA/IGxpc1tqXSA6IG51bGw7XG4gICAgICAgIHRhcmdldC5pbnNlcnRCZWZvcmUodG9Nb3ZlW2ldLCBhbmNob3IpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIGFwcGVuZCh0YXJnZXQsIG5vZGUpIHtcbiAgICB0YXJnZXQuYXBwZW5kQ2hpbGQobm9kZSk7XG59XG5mdW5jdGlvbiBhcHBlbmRfc3R5bGVzKHRhcmdldCwgc3R5bGVfc2hlZXRfaWQsIHN0eWxlcykge1xuICAgIGNvbnN0IGFwcGVuZF9zdHlsZXNfdG8gPSBnZXRfcm9vdF9mb3Jfc3R5bGUodGFyZ2V0KTtcbiAgICBpZiAoIWFwcGVuZF9zdHlsZXNfdG8uZ2V0RWxlbWVudEJ5SWQoc3R5bGVfc2hlZXRfaWQpKSB7XG4gICAgICAgIGNvbnN0IHN0eWxlID0gZWxlbWVudCgnc3R5bGUnKTtcbiAgICAgICAgc3R5bGUuaWQgPSBzdHlsZV9zaGVldF9pZDtcbiAgICAgICAgc3R5bGUudGV4dENvbnRlbnQgPSBzdHlsZXM7XG4gICAgICAgIGFwcGVuZF9zdHlsZXNoZWV0KGFwcGVuZF9zdHlsZXNfdG8sIHN0eWxlKTtcbiAgICB9XG59XG5mdW5jdGlvbiBnZXRfcm9vdF9mb3Jfc3R5bGUobm9kZSkge1xuICAgIGlmICghbm9kZSlcbiAgICAgICAgcmV0dXJuIGRvY3VtZW50O1xuICAgIGNvbnN0IHJvb3QgPSBub2RlLmdldFJvb3ROb2RlID8gbm9kZS5nZXRSb290Tm9kZSgpIDogbm9kZS5vd25lckRvY3VtZW50O1xuICAgIGlmIChyb290ICYmIHJvb3QuaG9zdCkge1xuICAgICAgICByZXR1cm4gcm9vdDtcbiAgICB9XG4gICAgcmV0dXJuIG5vZGUub3duZXJEb2N1bWVudDtcbn1cbmZ1bmN0aW9uIGFwcGVuZF9lbXB0eV9zdHlsZXNoZWV0KG5vZGUpIHtcbiAgICBjb25zdCBzdHlsZV9lbGVtZW50ID0gZWxlbWVudCgnc3R5bGUnKTtcbiAgICBhcHBlbmRfc3R5bGVzaGVldChnZXRfcm9vdF9mb3Jfc3R5bGUobm9kZSksIHN0eWxlX2VsZW1lbnQpO1xuICAgIHJldHVybiBzdHlsZV9lbGVtZW50LnNoZWV0O1xufVxuZnVuY3Rpb24gYXBwZW5kX3N0eWxlc2hlZXQobm9kZSwgc3R5bGUpIHtcbiAgICBhcHBlbmQobm9kZS5oZWFkIHx8IG5vZGUsIHN0eWxlKTtcbiAgICByZXR1cm4gc3R5bGUuc2hlZXQ7XG59XG5mdW5jdGlvbiBhcHBlbmRfaHlkcmF0aW9uKHRhcmdldCwgbm9kZSkge1xuICAgIGlmIChpc19oeWRyYXRpbmcpIHtcbiAgICAgICAgaW5pdF9oeWRyYXRlKHRhcmdldCk7XG4gICAgICAgIGlmICgodGFyZ2V0LmFjdHVhbF9lbmRfY2hpbGQgPT09IHVuZGVmaW5lZCkgfHwgKCh0YXJnZXQuYWN0dWFsX2VuZF9jaGlsZCAhPT0gbnVsbCkgJiYgKHRhcmdldC5hY3R1YWxfZW5kX2NoaWxkLnBhcmVudE5vZGUgIT09IHRhcmdldCkpKSB7XG4gICAgICAgICAgICB0YXJnZXQuYWN0dWFsX2VuZF9jaGlsZCA9IHRhcmdldC5maXJzdENoaWxkO1xuICAgICAgICB9XG4gICAgICAgIC8vIFNraXAgbm9kZXMgb2YgdW5kZWZpbmVkIG9yZGVyaW5nXG4gICAgICAgIHdoaWxlICgodGFyZ2V0LmFjdHVhbF9lbmRfY2hpbGQgIT09IG51bGwpICYmICh0YXJnZXQuYWN0dWFsX2VuZF9jaGlsZC5jbGFpbV9vcmRlciA9PT0gdW5kZWZpbmVkKSkge1xuICAgICAgICAgICAgdGFyZ2V0LmFjdHVhbF9lbmRfY2hpbGQgPSB0YXJnZXQuYWN0dWFsX2VuZF9jaGlsZC5uZXh0U2libGluZztcbiAgICAgICAgfVxuICAgICAgICBpZiAobm9kZSAhPT0gdGFyZ2V0LmFjdHVhbF9lbmRfY2hpbGQpIHtcbiAgICAgICAgICAgIC8vIFdlIG9ubHkgaW5zZXJ0IGlmIHRoZSBvcmRlcmluZyBvZiB0aGlzIG5vZGUgc2hvdWxkIGJlIG1vZGlmaWVkIG9yIHRoZSBwYXJlbnQgbm9kZSBpcyBub3QgdGFyZ2V0XG4gICAgICAgICAgICBpZiAobm9kZS5jbGFpbV9vcmRlciAhPT0gdW5kZWZpbmVkIHx8IG5vZGUucGFyZW50Tm9kZSAhPT0gdGFyZ2V0KSB7XG4gICAgICAgICAgICAgICAgdGFyZ2V0Lmluc2VydEJlZm9yZShub2RlLCB0YXJnZXQuYWN0dWFsX2VuZF9jaGlsZCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICB0YXJnZXQuYWN0dWFsX2VuZF9jaGlsZCA9IG5vZGUubmV4dFNpYmxpbmc7XG4gICAgICAgIH1cbiAgICB9XG4gICAgZWxzZSBpZiAobm9kZS5wYXJlbnROb2RlICE9PSB0YXJnZXQgfHwgbm9kZS5uZXh0U2libGluZyAhPT0gbnVsbCkge1xuICAgICAgICB0YXJnZXQuYXBwZW5kQ2hpbGQobm9kZSk7XG4gICAgfVxufVxuZnVuY3Rpb24gaW5zZXJ0KHRhcmdldCwgbm9kZSwgYW5jaG9yKSB7XG4gICAgdGFyZ2V0Lmluc2VydEJlZm9yZShub2RlLCBhbmNob3IgfHwgbnVsbCk7XG59XG5mdW5jdGlvbiBpbnNlcnRfaHlkcmF0aW9uKHRhcmdldCwgbm9kZSwgYW5jaG9yKSB7XG4gICAgaWYgKGlzX2h5ZHJhdGluZyAmJiAhYW5jaG9yKSB7XG4gICAgICAgIGFwcGVuZF9oeWRyYXRpb24odGFyZ2V0LCBub2RlKTtcbiAgICB9XG4gICAgZWxzZSBpZiAobm9kZS5wYXJlbnROb2RlICE9PSB0YXJnZXQgfHwgbm9kZS5uZXh0U2libGluZyAhPSBhbmNob3IpIHtcbiAgICAgICAgdGFyZ2V0Lmluc2VydEJlZm9yZShub2RlLCBhbmNob3IgfHwgbnVsbCk7XG4gICAgfVxufVxuZnVuY3Rpb24gZGV0YWNoKG5vZGUpIHtcbiAgICBub2RlLnBhcmVudE5vZGUucmVtb3ZlQ2hpbGQobm9kZSk7XG59XG5mdW5jdGlvbiBkZXN0cm95X2VhY2goaXRlcmF0aW9ucywgZGV0YWNoaW5nKSB7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBpdGVyYXRpb25zLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgIGlmIChpdGVyYXRpb25zW2ldKVxuICAgICAgICAgICAgaXRlcmF0aW9uc1tpXS5kKGRldGFjaGluZyk7XG4gICAgfVxufVxuZnVuY3Rpb24gZWxlbWVudChuYW1lKSB7XG4gICAgcmV0dXJuIGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQobmFtZSk7XG59XG5mdW5jdGlvbiBlbGVtZW50X2lzKG5hbWUsIGlzKSB7XG4gICAgcmV0dXJuIGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQobmFtZSwgeyBpcyB9KTtcbn1cbmZ1bmN0aW9uIG9iamVjdF93aXRob3V0X3Byb3BlcnRpZXMob2JqLCBleGNsdWRlKSB7XG4gICAgY29uc3QgdGFyZ2V0ID0ge307XG4gICAgZm9yIChjb25zdCBrIGluIG9iaikge1xuICAgICAgICBpZiAoaGFzX3Byb3Aob2JqLCBrKVxuICAgICAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICAgICAgJiYgZXhjbHVkZS5pbmRleE9mKGspID09PSAtMSkge1xuICAgICAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICAgICAgdGFyZ2V0W2tdID0gb2JqW2tdO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiB0YXJnZXQ7XG59XG5mdW5jdGlvbiBzdmdfZWxlbWVudChuYW1lKSB7XG4gICAgcmV0dXJuIGRvY3VtZW50LmNyZWF0ZUVsZW1lbnROUygnaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmcnLCBuYW1lKTtcbn1cbmZ1bmN0aW9uIHRleHQoZGF0YSkge1xuICAgIHJldHVybiBkb2N1bWVudC5jcmVhdGVUZXh0Tm9kZShkYXRhKTtcbn1cbmZ1bmN0aW9uIHNwYWNlKCkge1xuICAgIHJldHVybiB0ZXh0KCcgJyk7XG59XG5mdW5jdGlvbiBlbXB0eSgpIHtcbiAgICByZXR1cm4gdGV4dCgnJyk7XG59XG5mdW5jdGlvbiBsaXN0ZW4obm9kZSwgZXZlbnQsIGhhbmRsZXIsIG9wdGlvbnMpIHtcbiAgICBub2RlLmFkZEV2ZW50TGlzdGVuZXIoZXZlbnQsIGhhbmRsZXIsIG9wdGlvbnMpO1xuICAgIHJldHVybiAoKSA9PiBub2RlLnJlbW92ZUV2ZW50TGlzdGVuZXIoZXZlbnQsIGhhbmRsZXIsIG9wdGlvbnMpO1xufVxuZnVuY3Rpb24gcHJldmVudF9kZWZhdWx0KGZuKSB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uIChldmVudCkge1xuICAgICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIHJldHVybiBmbi5jYWxsKHRoaXMsIGV2ZW50KTtcbiAgICB9O1xufVxuZnVuY3Rpb24gc3RvcF9wcm9wYWdhdGlvbihmbikge1xuICAgIHJldHVybiBmdW5jdGlvbiAoZXZlbnQpIHtcbiAgICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgcmV0dXJuIGZuLmNhbGwodGhpcywgZXZlbnQpO1xuICAgIH07XG59XG5mdW5jdGlvbiBzZWxmKGZuKSB7XG4gICAgcmV0dXJuIGZ1bmN0aW9uIChldmVudCkge1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIGlmIChldmVudC50YXJnZXQgPT09IHRoaXMpXG4gICAgICAgICAgICBmbi5jYWxsKHRoaXMsIGV2ZW50KTtcbiAgICB9O1xufVxuZnVuY3Rpb24gdHJ1c3RlZChmbikge1xuICAgIHJldHVybiBmdW5jdGlvbiAoZXZlbnQpIHtcbiAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICBpZiAoZXZlbnQuaXNUcnVzdGVkKVxuICAgICAgICAgICAgZm4uY2FsbCh0aGlzLCBldmVudCk7XG4gICAgfTtcbn1cbmZ1bmN0aW9uIGF0dHIobm9kZSwgYXR0cmlidXRlLCB2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSA9PSBudWxsKVxuICAgICAgICBub2RlLnJlbW92ZUF0dHJpYnV0ZShhdHRyaWJ1dGUpO1xuICAgIGVsc2UgaWYgKG5vZGUuZ2V0QXR0cmlidXRlKGF0dHJpYnV0ZSkgIT09IHZhbHVlKVxuICAgICAgICBub2RlLnNldEF0dHJpYnV0ZShhdHRyaWJ1dGUsIHZhbHVlKTtcbn1cbmZ1bmN0aW9uIHNldF9hdHRyaWJ1dGVzKG5vZGUsIGF0dHJpYnV0ZXMpIHtcbiAgICAvLyBAdHMtaWdub3JlXG4gICAgY29uc3QgZGVzY3JpcHRvcnMgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9ycyhub2RlLl9fcHJvdG9fXyk7XG4gICAgZm9yIChjb25zdCBrZXkgaW4gYXR0cmlidXRlcykge1xuICAgICAgICBpZiAoYXR0cmlidXRlc1trZXldID09IG51bGwpIHtcbiAgICAgICAgICAgIG5vZGUucmVtb3ZlQXR0cmlidXRlKGtleSk7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoa2V5ID09PSAnc3R5bGUnKSB7XG4gICAgICAgICAgICBub2RlLnN0eWxlLmNzc1RleHQgPSBhdHRyaWJ1dGVzW2tleV07XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoa2V5ID09PSAnX192YWx1ZScpIHtcbiAgICAgICAgICAgIG5vZGUudmFsdWUgPSBub2RlW2tleV0gPSBhdHRyaWJ1dGVzW2tleV07XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoZGVzY3JpcHRvcnNba2V5XSAmJiBkZXNjcmlwdG9yc1trZXldLnNldCkge1xuICAgICAgICAgICAgbm9kZVtrZXldID0gYXR0cmlidXRlc1trZXldO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgYXR0cihub2RlLCBrZXksIGF0dHJpYnV0ZXNba2V5XSk7XG4gICAgICAgIH1cbiAgICB9XG59XG5mdW5jdGlvbiBzZXRfc3ZnX2F0dHJpYnV0ZXMobm9kZSwgYXR0cmlidXRlcykge1xuICAgIGZvciAoY29uc3Qga2V5IGluIGF0dHJpYnV0ZXMpIHtcbiAgICAgICAgYXR0cihub2RlLCBrZXksIGF0dHJpYnV0ZXNba2V5XSk7XG4gICAgfVxufVxuZnVuY3Rpb24gc2V0X2N1c3RvbV9lbGVtZW50X2RhdGEobm9kZSwgcHJvcCwgdmFsdWUpIHtcbiAgICBpZiAocHJvcCBpbiBub2RlKSB7XG4gICAgICAgIG5vZGVbcHJvcF0gPSB0eXBlb2Ygbm9kZVtwcm9wXSA9PT0gJ2Jvb2xlYW4nICYmIHZhbHVlID09PSAnJyA/IHRydWUgOiB2YWx1ZTtcbiAgICB9XG4gICAgZWxzZSB7XG4gICAgICAgIGF0dHIobm9kZSwgcHJvcCwgdmFsdWUpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIHhsaW5rX2F0dHIobm9kZSwgYXR0cmlidXRlLCB2YWx1ZSkge1xuICAgIG5vZGUuc2V0QXR0cmlidXRlTlMoJ2h0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsnLCBhdHRyaWJ1dGUsIHZhbHVlKTtcbn1cbmZ1bmN0aW9uIGdldF9iaW5kaW5nX2dyb3VwX3ZhbHVlKGdyb3VwLCBfX3ZhbHVlLCBjaGVja2VkKSB7XG4gICAgY29uc3QgdmFsdWUgPSBuZXcgU2V0KCk7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBncm91cC5sZW5ndGg7IGkgKz0gMSkge1xuICAgICAgICBpZiAoZ3JvdXBbaV0uY2hlY2tlZClcbiAgICAgICAgICAgIHZhbHVlLmFkZChncm91cFtpXS5fX3ZhbHVlKTtcbiAgICB9XG4gICAgaWYgKCFjaGVja2VkKSB7XG4gICAgICAgIHZhbHVlLmRlbGV0ZShfX3ZhbHVlKTtcbiAgICB9XG4gICAgcmV0dXJuIEFycmF5LmZyb20odmFsdWUpO1xufVxuZnVuY3Rpb24gdG9fbnVtYmVyKHZhbHVlKSB7XG4gICAgcmV0dXJuIHZhbHVlID09PSAnJyA/IG51bGwgOiArdmFsdWU7XG59XG5mdW5jdGlvbiB0aW1lX3Jhbmdlc190b19hcnJheShyYW5nZXMpIHtcbiAgICBjb25zdCBhcnJheSA9IFtdO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgcmFuZ2VzLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgIGFycmF5LnB1c2goeyBzdGFydDogcmFuZ2VzLnN0YXJ0KGkpLCBlbmQ6IHJhbmdlcy5lbmQoaSkgfSk7XG4gICAgfVxuICAgIHJldHVybiBhcnJheTtcbn1cbmZ1bmN0aW9uIGNoaWxkcmVuKGVsZW1lbnQpIHtcbiAgICByZXR1cm4gQXJyYXkuZnJvbShlbGVtZW50LmNoaWxkTm9kZXMpO1xufVxuZnVuY3Rpb24gaW5pdF9jbGFpbV9pbmZvKG5vZGVzKSB7XG4gICAgaWYgKG5vZGVzLmNsYWltX2luZm8gPT09IHVuZGVmaW5lZCkge1xuICAgICAgICBub2Rlcy5jbGFpbV9pbmZvID0geyBsYXN0X2luZGV4OiAwLCB0b3RhbF9jbGFpbWVkOiAwIH07XG4gICAgfVxufVxuZnVuY3Rpb24gY2xhaW1fbm9kZShub2RlcywgcHJlZGljYXRlLCBwcm9jZXNzTm9kZSwgY3JlYXRlTm9kZSwgZG9udFVwZGF0ZUxhc3RJbmRleCA9IGZhbHNlKSB7XG4gICAgLy8gVHJ5IHRvIGZpbmQgbm9kZXMgaW4gYW4gb3JkZXIgc3VjaCB0aGF0IHdlIGxlbmd0aGVuIHRoZSBsb25nZXN0IGluY3JlYXNpbmcgc3Vic2VxdWVuY2VcbiAgICBpbml0X2NsYWltX2luZm8obm9kZXMpO1xuICAgIGNvbnN0IHJlc3VsdE5vZGUgPSAoKCkgPT4ge1xuICAgICAgICAvLyBXZSBmaXJzdCB0cnkgdG8gZmluZCBhbiBlbGVtZW50IGFmdGVyIHRoZSBwcmV2aW91cyBvbmVcbiAgICAgICAgZm9yIChsZXQgaSA9IG5vZGVzLmNsYWltX2luZm8ubGFzdF9pbmRleDsgaSA8IG5vZGVzLmxlbmd0aDsgaSsrKSB7XG4gICAgICAgICAgICBjb25zdCBub2RlID0gbm9kZXNbaV07XG4gICAgICAgICAgICBpZiAocHJlZGljYXRlKG5vZGUpKSB7XG4gICAgICAgICAgICAgICAgY29uc3QgcmVwbGFjZW1lbnQgPSBwcm9jZXNzTm9kZShub2RlKTtcbiAgICAgICAgICAgICAgICBpZiAocmVwbGFjZW1lbnQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgICAgICAgICBub2Rlcy5zcGxpY2UoaSwgMSk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICBub2Rlc1tpXSA9IHJlcGxhY2VtZW50O1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBpZiAoIWRvbnRVcGRhdGVMYXN0SW5kZXgpIHtcbiAgICAgICAgICAgICAgICAgICAgbm9kZXMuY2xhaW1faW5mby5sYXN0X2luZGV4ID0gaTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuIG5vZGU7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgLy8gT3RoZXJ3aXNlLCB3ZSB0cnkgdG8gZmluZCBvbmUgYmVmb3JlXG4gICAgICAgIC8vIFdlIGl0ZXJhdGUgaW4gcmV2ZXJzZSBzbyB0aGF0IHdlIGRvbid0IGdvIHRvbyBmYXIgYmFja1xuICAgICAgICBmb3IgKGxldCBpID0gbm9kZXMuY2xhaW1faW5mby5sYXN0X2luZGV4IC0gMTsgaSA+PSAwOyBpLS0pIHtcbiAgICAgICAgICAgIGNvbnN0IG5vZGUgPSBub2Rlc1tpXTtcbiAgICAgICAgICAgIGlmIChwcmVkaWNhdGUobm9kZSkpIHtcbiAgICAgICAgICAgICAgICBjb25zdCByZXBsYWNlbWVudCA9IHByb2Nlc3NOb2RlKG5vZGUpO1xuICAgICAgICAgICAgICAgIGlmIChyZXBsYWNlbWVudCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgICAgICAgIG5vZGVzLnNwbGljZShpLCAxKTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIG5vZGVzW2ldID0gcmVwbGFjZW1lbnQ7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGlmICghZG9udFVwZGF0ZUxhc3RJbmRleCkge1xuICAgICAgICAgICAgICAgICAgICBub2Rlcy5jbGFpbV9pbmZvLmxhc3RfaW5kZXggPSBpO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBlbHNlIGlmIChyZXBsYWNlbWVudCA9PT0gdW5kZWZpbmVkKSB7XG4gICAgICAgICAgICAgICAgICAgIC8vIFNpbmNlIHdlIHNwbGljZWQgYmVmb3JlIHRoZSBsYXN0X2luZGV4LCB3ZSBkZWNyZWFzZSBpdFxuICAgICAgICAgICAgICAgICAgICBub2Rlcy5jbGFpbV9pbmZvLmxhc3RfaW5kZXgtLTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuIG5vZGU7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgLy8gSWYgd2UgY2FuJ3QgZmluZCBhbnkgbWF0Y2hpbmcgbm9kZSwgd2UgY3JlYXRlIGEgbmV3IG9uZVxuICAgICAgICByZXR1cm4gY3JlYXRlTm9kZSgpO1xuICAgIH0pKCk7XG4gICAgcmVzdWx0Tm9kZS5jbGFpbV9vcmRlciA9IG5vZGVzLmNsYWltX2luZm8udG90YWxfY2xhaW1lZDtcbiAgICBub2Rlcy5jbGFpbV9pbmZvLnRvdGFsX2NsYWltZWQgKz0gMTtcbiAgICByZXR1cm4gcmVzdWx0Tm9kZTtcbn1cbmZ1bmN0aW9uIGNsYWltX2VsZW1lbnRfYmFzZShub2RlcywgbmFtZSwgYXR0cmlidXRlcywgY3JlYXRlX2VsZW1lbnQpIHtcbiAgICByZXR1cm4gY2xhaW1fbm9kZShub2RlcywgKG5vZGUpID0+IG5vZGUubm9kZU5hbWUgPT09IG5hbWUsIChub2RlKSA9PiB7XG4gICAgICAgIGNvbnN0IHJlbW92ZSA9IFtdO1xuICAgICAgICBmb3IgKGxldCBqID0gMDsgaiA8IG5vZGUuYXR0cmlidXRlcy5sZW5ndGg7IGorKykge1xuICAgICAgICAgICAgY29uc3QgYXR0cmlidXRlID0gbm9kZS5hdHRyaWJ1dGVzW2pdO1xuICAgICAgICAgICAgaWYgKCFhdHRyaWJ1dGVzW2F0dHJpYnV0ZS5uYW1lXSkge1xuICAgICAgICAgICAgICAgIHJlbW92ZS5wdXNoKGF0dHJpYnV0ZS5uYW1lKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICByZW1vdmUuZm9yRWFjaCh2ID0+IG5vZGUucmVtb3ZlQXR0cmlidXRlKHYpKTtcbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgICB9LCAoKSA9PiBjcmVhdGVfZWxlbWVudChuYW1lKSk7XG59XG5mdW5jdGlvbiBjbGFpbV9lbGVtZW50KG5vZGVzLCBuYW1lLCBhdHRyaWJ1dGVzKSB7XG4gICAgcmV0dXJuIGNsYWltX2VsZW1lbnRfYmFzZShub2RlcywgbmFtZSwgYXR0cmlidXRlcywgZWxlbWVudCk7XG59XG5mdW5jdGlvbiBjbGFpbV9zdmdfZWxlbWVudChub2RlcywgbmFtZSwgYXR0cmlidXRlcykge1xuICAgIHJldHVybiBjbGFpbV9lbGVtZW50X2Jhc2Uobm9kZXMsIG5hbWUsIGF0dHJpYnV0ZXMsIHN2Z19lbGVtZW50KTtcbn1cbmZ1bmN0aW9uIGNsYWltX3RleHQobm9kZXMsIGRhdGEpIHtcbiAgICByZXR1cm4gY2xhaW1fbm9kZShub2RlcywgKG5vZGUpID0+IG5vZGUubm9kZVR5cGUgPT09IDMsIChub2RlKSA9PiB7XG4gICAgICAgIGNvbnN0IGRhdGFTdHIgPSAnJyArIGRhdGE7XG4gICAgICAgIGlmIChub2RlLmRhdGEuc3RhcnRzV2l0aChkYXRhU3RyKSkge1xuICAgICAgICAgICAgaWYgKG5vZGUuZGF0YS5sZW5ndGggIT09IGRhdGFTdHIubGVuZ3RoKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIG5vZGUuc3BsaXRUZXh0KGRhdGFTdHIubGVuZ3RoKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgIG5vZGUuZGF0YSA9IGRhdGFTdHI7XG4gICAgICAgIH1cbiAgICB9LCAoKSA9PiB0ZXh0KGRhdGEpLCB0cnVlIC8vIFRleHQgbm9kZXMgc2hvdWxkIG5vdCB1cGRhdGUgbGFzdCBpbmRleCBzaW5jZSBpdCBpcyBsaWtlbHkgbm90IHdvcnRoIGl0IHRvIGVsaW1pbmF0ZSBhbiBpbmNyZWFzaW5nIHN1YnNlcXVlbmNlIG9mIGFjdHVhbCBlbGVtZW50c1xuICAgICk7XG59XG5mdW5jdGlvbiBjbGFpbV9zcGFjZShub2Rlcykge1xuICAgIHJldHVybiBjbGFpbV90ZXh0KG5vZGVzLCAnICcpO1xufVxuZnVuY3Rpb24gZmluZF9jb21tZW50KG5vZGVzLCB0ZXh0LCBzdGFydCkge1xuICAgIGZvciAobGV0IGkgPSBzdGFydDsgaSA8IG5vZGVzLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgIGNvbnN0IG5vZGUgPSBub2Rlc1tpXTtcbiAgICAgICAgaWYgKG5vZGUubm9kZVR5cGUgPT09IDggLyogY29tbWVudCBub2RlICovICYmIG5vZGUudGV4dENvbnRlbnQudHJpbSgpID09PSB0ZXh0KSB7XG4gICAgICAgICAgICByZXR1cm4gaTtcbiAgICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gbm9kZXMubGVuZ3RoO1xufVxuZnVuY3Rpb24gY2xhaW1faHRtbF90YWcobm9kZXMsIGlzX3N2Zykge1xuICAgIC8vIGZpbmQgaHRtbCBvcGVuaW5nIHRhZ1xuICAgIGNvbnN0IHN0YXJ0X2luZGV4ID0gZmluZF9jb21tZW50KG5vZGVzLCAnSFRNTF9UQUdfU1RBUlQnLCAwKTtcbiAgICBjb25zdCBlbmRfaW5kZXggPSBmaW5kX2NvbW1lbnQobm9kZXMsICdIVE1MX1RBR19FTkQnLCBzdGFydF9pbmRleCk7XG4gICAgaWYgKHN0YXJ0X2luZGV4ID09PSBlbmRfaW5kZXgpIHtcbiAgICAgICAgcmV0dXJuIG5ldyBIdG1sVGFnSHlkcmF0aW9uKHVuZGVmaW5lZCwgaXNfc3ZnKTtcbiAgICB9XG4gICAgaW5pdF9jbGFpbV9pbmZvKG5vZGVzKTtcbiAgICBjb25zdCBodG1sX3RhZ19ub2RlcyA9IG5vZGVzLnNwbGljZShzdGFydF9pbmRleCwgZW5kX2luZGV4IC0gc3RhcnRfaW5kZXggKyAxKTtcbiAgICBkZXRhY2goaHRtbF90YWdfbm9kZXNbMF0pO1xuICAgIGRldGFjaChodG1sX3RhZ19ub2Rlc1todG1sX3RhZ19ub2Rlcy5sZW5ndGggLSAxXSk7XG4gICAgY29uc3QgY2xhaW1lZF9ub2RlcyA9IGh0bWxfdGFnX25vZGVzLnNsaWNlKDEsIGh0bWxfdGFnX25vZGVzLmxlbmd0aCAtIDEpO1xuICAgIGZvciAoY29uc3QgbiBvZiBjbGFpbWVkX25vZGVzKSB7XG4gICAgICAgIG4uY2xhaW1fb3JkZXIgPSBub2Rlcy5jbGFpbV9pbmZvLnRvdGFsX2NsYWltZWQ7XG4gICAgICAgIG5vZGVzLmNsYWltX2luZm8udG90YWxfY2xhaW1lZCArPSAxO1xuICAgIH1cbiAgICByZXR1cm4gbmV3IEh0bWxUYWdIeWRyYXRpb24oY2xhaW1lZF9ub2RlcywgaXNfc3ZnKTtcbn1cbmZ1bmN0aW9uIHNldF9kYXRhKHRleHQsIGRhdGEpIHtcbiAgICBkYXRhID0gJycgKyBkYXRhO1xuICAgIGlmICh0ZXh0Lndob2xlVGV4dCAhPT0gZGF0YSlcbiAgICAgICAgdGV4dC5kYXRhID0gZGF0YTtcbn1cbmZ1bmN0aW9uIHNldF9pbnB1dF92YWx1ZShpbnB1dCwgdmFsdWUpIHtcbiAgICBpbnB1dC52YWx1ZSA9IHZhbHVlID09IG51bGwgPyAnJyA6IHZhbHVlO1xufVxuZnVuY3Rpb24gc2V0X2lucHV0X3R5cGUoaW5wdXQsIHR5cGUpIHtcbiAgICB0cnkge1xuICAgICAgICBpbnB1dC50eXBlID0gdHlwZTtcbiAgICB9XG4gICAgY2F0Y2ggKGUpIHtcbiAgICAgICAgLy8gZG8gbm90aGluZ1xuICAgIH1cbn1cbmZ1bmN0aW9uIHNldF9zdHlsZShub2RlLCBrZXksIHZhbHVlLCBpbXBvcnRhbnQpIHtcbiAgICBpZiAodmFsdWUgPT09IG51bGwpIHtcbiAgICAgICAgbm9kZS5zdHlsZS5yZW1vdmVQcm9wZXJ0eShrZXkpO1xuICAgIH1cbiAgICBlbHNlIHtcbiAgICAgICAgbm9kZS5zdHlsZS5zZXRQcm9wZXJ0eShrZXksIHZhbHVlLCBpbXBvcnRhbnQgPyAnaW1wb3J0YW50JyA6ICcnKTtcbiAgICB9XG59XG5mdW5jdGlvbiBzZWxlY3Rfb3B0aW9uKHNlbGVjdCwgdmFsdWUpIHtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHNlbGVjdC5vcHRpb25zLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgIGNvbnN0IG9wdGlvbiA9IHNlbGVjdC5vcHRpb25zW2ldO1xuICAgICAgICBpZiAob3B0aW9uLl9fdmFsdWUgPT09IHZhbHVlKSB7XG4gICAgICAgICAgICBvcHRpb24uc2VsZWN0ZWQgPSB0cnVlO1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG4gICAgfVxuICAgIHNlbGVjdC5zZWxlY3RlZEluZGV4ID0gLTE7IC8vIG5vIG9wdGlvbiBzaG91bGQgYmUgc2VsZWN0ZWRcbn1cbmZ1bmN0aW9uIHNlbGVjdF9vcHRpb25zKHNlbGVjdCwgdmFsdWUpIHtcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IHNlbGVjdC5vcHRpb25zLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgIGNvbnN0IG9wdGlvbiA9IHNlbGVjdC5vcHRpb25zW2ldO1xuICAgICAgICBvcHRpb24uc2VsZWN0ZWQgPSB+dmFsdWUuaW5kZXhPZihvcHRpb24uX192YWx1ZSk7XG4gICAgfVxufVxuZnVuY3Rpb24gc2VsZWN0X3ZhbHVlKHNlbGVjdCkge1xuICAgIGNvbnN0IHNlbGVjdGVkX29wdGlvbiA9IHNlbGVjdC5xdWVyeVNlbGVjdG9yKCc6Y2hlY2tlZCcpIHx8IHNlbGVjdC5vcHRpb25zWzBdO1xuICAgIHJldHVybiBzZWxlY3RlZF9vcHRpb24gJiYgc2VsZWN0ZWRfb3B0aW9uLl9fdmFsdWU7XG59XG5mdW5jdGlvbiBzZWxlY3RfbXVsdGlwbGVfdmFsdWUoc2VsZWN0KSB7XG4gICAgcmV0dXJuIFtdLm1hcC5jYWxsKHNlbGVjdC5xdWVyeVNlbGVjdG9yQWxsKCc6Y2hlY2tlZCcpLCBvcHRpb24gPT4gb3B0aW9uLl9fdmFsdWUpO1xufVxuLy8gdW5mb3J0dW5hdGVseSB0aGlzIGNhbid0IGJlIGEgY29uc3RhbnQgYXMgdGhhdCB3b3VsZG4ndCBiZSB0cmVlLXNoYWtlYWJsZVxuLy8gc28gd2UgY2FjaGUgdGhlIHJlc3VsdCBpbnN0ZWFkXG5sZXQgY3Jvc3NvcmlnaW47XG5mdW5jdGlvbiBpc19jcm9zc29yaWdpbigpIHtcbiAgICBpZiAoY3Jvc3NvcmlnaW4gPT09IHVuZGVmaW5lZCkge1xuICAgICAgICBjcm9zc29yaWdpbiA9IGZhbHNlO1xuICAgICAgICB0cnkge1xuICAgICAgICAgICAgaWYgKHR5cGVvZiB3aW5kb3cgIT09ICd1bmRlZmluZWQnICYmIHdpbmRvdy5wYXJlbnQpIHtcbiAgICAgICAgICAgICAgICB2b2lkIHdpbmRvdy5wYXJlbnQuZG9jdW1lbnQ7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgICAgICBjcm9zc29yaWdpbiA9IHRydWU7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIGNyb3Nzb3JpZ2luO1xufVxuZnVuY3Rpb24gYWRkX3Jlc2l6ZV9saXN0ZW5lcihub2RlLCBmbikge1xuICAgIGNvbnN0IGNvbXB1dGVkX3N0eWxlID0gZ2V0Q29tcHV0ZWRTdHlsZShub2RlKTtcbiAgICBpZiAoY29tcHV0ZWRfc3R5bGUucG9zaXRpb24gPT09ICdzdGF0aWMnKSB7XG4gICAgICAgIG5vZGUuc3R5bGUucG9zaXRpb24gPSAncmVsYXRpdmUnO1xuICAgIH1cbiAgICBjb25zdCBpZnJhbWUgPSBlbGVtZW50KCdpZnJhbWUnKTtcbiAgICBpZnJhbWUuc2V0QXR0cmlidXRlKCdzdHlsZScsICdkaXNwbGF5OiBibG9jazsgcG9zaXRpb246IGFic29sdXRlOyB0b3A6IDA7IGxlZnQ6IDA7IHdpZHRoOiAxMDAlOyBoZWlnaHQ6IDEwMCU7ICcgK1xuICAgICAgICAnb3ZlcmZsb3c6IGhpZGRlbjsgYm9yZGVyOiAwOyBvcGFjaXR5OiAwOyBwb2ludGVyLWV2ZW50czogbm9uZTsgei1pbmRleDogLTE7Jyk7XG4gICAgaWZyYW1lLnNldEF0dHJpYnV0ZSgnYXJpYS1oaWRkZW4nLCAndHJ1ZScpO1xuICAgIGlmcmFtZS50YWJJbmRleCA9IC0xO1xuICAgIGNvbnN0IGNyb3Nzb3JpZ2luID0gaXNfY3Jvc3NvcmlnaW4oKTtcbiAgICBsZXQgdW5zdWJzY3JpYmU7XG4gICAgaWYgKGNyb3Nzb3JpZ2luKSB7XG4gICAgICAgIGlmcmFtZS5zcmMgPSBcImRhdGE6dGV4dC9odG1sLDxzY3JpcHQ+b25yZXNpemU9ZnVuY3Rpb24oKXtwYXJlbnQucG9zdE1lc3NhZ2UoMCwnKicpfTwvc2NyaXB0PlwiO1xuICAgICAgICB1bnN1YnNjcmliZSA9IGxpc3Rlbih3aW5kb3csICdtZXNzYWdlJywgKGV2ZW50KSA9PiB7XG4gICAgICAgICAgICBpZiAoZXZlbnQuc291cmNlID09PSBpZnJhbWUuY29udGVudFdpbmRvdylcbiAgICAgICAgICAgICAgICBmbigpO1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgZWxzZSB7XG4gICAgICAgIGlmcmFtZS5zcmMgPSAnYWJvdXQ6YmxhbmsnO1xuICAgICAgICBpZnJhbWUub25sb2FkID0gKCkgPT4ge1xuICAgICAgICAgICAgdW5zdWJzY3JpYmUgPSBsaXN0ZW4oaWZyYW1lLmNvbnRlbnRXaW5kb3csICdyZXNpemUnLCBmbik7XG4gICAgICAgIH07XG4gICAgfVxuICAgIGFwcGVuZChub2RlLCBpZnJhbWUpO1xuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgIGlmIChjcm9zc29yaWdpbikge1xuICAgICAgICAgICAgdW5zdWJzY3JpYmUoKTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIGlmICh1bnN1YnNjcmliZSAmJiBpZnJhbWUuY29udGVudFdpbmRvdykge1xuICAgICAgICAgICAgdW5zdWJzY3JpYmUoKTtcbiAgICAgICAgfVxuICAgICAgICBkZXRhY2goaWZyYW1lKTtcbiAgICB9O1xufVxuZnVuY3Rpb24gdG9nZ2xlX2NsYXNzKGVsZW1lbnQsIG5hbWUsIHRvZ2dsZSkge1xuICAgIGVsZW1lbnQuY2xhc3NMaXN0W3RvZ2dsZSA/ICdhZGQnIDogJ3JlbW92ZSddKG5hbWUpO1xufVxuZnVuY3Rpb24gY3VzdG9tX2V2ZW50KHR5cGUsIGRldGFpbCwgeyBidWJibGVzID0gZmFsc2UsIGNhbmNlbGFibGUgPSBmYWxzZSB9ID0ge30pIHtcbiAgICBjb25zdCBlID0gZG9jdW1lbnQuY3JlYXRlRXZlbnQoJ0N1c3RvbUV2ZW50Jyk7XG4gICAgZS5pbml0Q3VzdG9tRXZlbnQodHlwZSwgYnViYmxlcywgY2FuY2VsYWJsZSwgZGV0YWlsKTtcbiAgICByZXR1cm4gZTtcbn1cbmZ1bmN0aW9uIHF1ZXJ5X3NlbGVjdG9yX2FsbChzZWxlY3RvciwgcGFyZW50ID0gZG9jdW1lbnQuYm9keSkge1xuICAgIHJldHVybiBBcnJheS5mcm9tKHBhcmVudC5xdWVyeVNlbGVjdG9yQWxsKHNlbGVjdG9yKSk7XG59XG5jbGFzcyBIdG1sVGFnIHtcbiAgICBjb25zdHJ1Y3Rvcihpc19zdmcgPSBmYWxzZSkge1xuICAgICAgICB0aGlzLmlzX3N2ZyA9IGZhbHNlO1xuICAgICAgICB0aGlzLmlzX3N2ZyA9IGlzX3N2ZztcbiAgICAgICAgdGhpcy5lID0gdGhpcy5uID0gbnVsbDtcbiAgICB9XG4gICAgYyhodG1sKSB7XG4gICAgICAgIHRoaXMuaChodG1sKTtcbiAgICB9XG4gICAgbShodG1sLCB0YXJnZXQsIGFuY2hvciA9IG51bGwpIHtcbiAgICAgICAgaWYgKCF0aGlzLmUpIHtcbiAgICAgICAgICAgIGlmICh0aGlzLmlzX3N2ZylcbiAgICAgICAgICAgICAgICB0aGlzLmUgPSBzdmdfZWxlbWVudCh0YXJnZXQubm9kZU5hbWUpO1xuICAgICAgICAgICAgZWxzZVxuICAgICAgICAgICAgICAgIHRoaXMuZSA9IGVsZW1lbnQodGFyZ2V0Lm5vZGVOYW1lKTtcbiAgICAgICAgICAgIHRoaXMudCA9IHRhcmdldDtcbiAgICAgICAgICAgIHRoaXMuYyhodG1sKTtcbiAgICAgICAgfVxuICAgICAgICB0aGlzLmkoYW5jaG9yKTtcbiAgICB9XG4gICAgaChodG1sKSB7XG4gICAgICAgIHRoaXMuZS5pbm5lckhUTUwgPSBodG1sO1xuICAgICAgICB0aGlzLm4gPSBBcnJheS5mcm9tKHRoaXMuZS5jaGlsZE5vZGVzKTtcbiAgICB9XG4gICAgaShhbmNob3IpIHtcbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCB0aGlzLm4ubGVuZ3RoOyBpICs9IDEpIHtcbiAgICAgICAgICAgIGluc2VydCh0aGlzLnQsIHRoaXMubltpXSwgYW5jaG9yKTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBwKGh0bWwpIHtcbiAgICAgICAgdGhpcy5kKCk7XG4gICAgICAgIHRoaXMuaChodG1sKTtcbiAgICAgICAgdGhpcy5pKHRoaXMuYSk7XG4gICAgfVxuICAgIGQoKSB7XG4gICAgICAgIHRoaXMubi5mb3JFYWNoKGRldGFjaCk7XG4gICAgfVxufVxuY2xhc3MgSHRtbFRhZ0h5ZHJhdGlvbiBleHRlbmRzIEh0bWxUYWcge1xuICAgIGNvbnN0cnVjdG9yKGNsYWltZWRfbm9kZXMsIGlzX3N2ZyA9IGZhbHNlKSB7XG4gICAgICAgIHN1cGVyKGlzX3N2Zyk7XG4gICAgICAgIHRoaXMuZSA9IHRoaXMubiA9IG51bGw7XG4gICAgICAgIHRoaXMubCA9IGNsYWltZWRfbm9kZXM7XG4gICAgfVxuICAgIGMoaHRtbCkge1xuICAgICAgICBpZiAodGhpcy5sKSB7XG4gICAgICAgICAgICB0aGlzLm4gPSB0aGlzLmw7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICBzdXBlci5jKGh0bWwpO1xuICAgICAgICB9XG4gICAgfVxuICAgIGkoYW5jaG9yKSB7XG4gICAgICAgIGZvciAobGV0IGkgPSAwOyBpIDwgdGhpcy5uLmxlbmd0aDsgaSArPSAxKSB7XG4gICAgICAgICAgICBpbnNlcnRfaHlkcmF0aW9uKHRoaXMudCwgdGhpcy5uW2ldLCBhbmNob3IpO1xuICAgICAgICB9XG4gICAgfVxufVxuZnVuY3Rpb24gYXR0cmlidXRlX3RvX29iamVjdChhdHRyaWJ1dGVzKSB7XG4gICAgY29uc3QgcmVzdWx0ID0ge307XG4gICAgZm9yIChjb25zdCBhdHRyaWJ1dGUgb2YgYXR0cmlidXRlcykge1xuICAgICAgICByZXN1bHRbYXR0cmlidXRlLm5hbWVdID0gYXR0cmlidXRlLnZhbHVlO1xuICAgIH1cbiAgICByZXR1cm4gcmVzdWx0O1xufVxuZnVuY3Rpb24gZ2V0X2N1c3RvbV9lbGVtZW50c19zbG90cyhlbGVtZW50KSB7XG4gICAgY29uc3QgcmVzdWx0ID0ge307XG4gICAgZWxlbWVudC5jaGlsZE5vZGVzLmZvckVhY2goKG5vZGUpID0+IHtcbiAgICAgICAgcmVzdWx0W25vZGUuc2xvdCB8fCAnZGVmYXVsdCddID0gdHJ1ZTtcbiAgICB9KTtcbiAgICByZXR1cm4gcmVzdWx0O1xufVxuXG4vLyB3ZSBuZWVkIHRvIHN0b3JlIHRoZSBpbmZvcm1hdGlvbiBmb3IgbXVsdGlwbGUgZG9jdW1lbnRzIGJlY2F1c2UgYSBTdmVsdGUgYXBwbGljYXRpb24gY291bGQgYWxzbyBjb250YWluIGlmcmFtZXNcbi8vIGh0dHBzOi8vZ2l0aHViLmNvbS9zdmVsdGVqcy9zdmVsdGUvaXNzdWVzLzM2MjRcbmNvbnN0IG1hbmFnZWRfc3R5bGVzID0gbmV3IE1hcCgpO1xubGV0IGFjdGl2ZSA9IDA7XG4vLyBodHRwczovL2dpdGh1Yi5jb20vZGFya3NreWFwcC9zdHJpbmctaGFzaC9ibG9iL21hc3Rlci9pbmRleC5qc1xuZnVuY3Rpb24gaGFzaChzdHIpIHtcbiAgICBsZXQgaGFzaCA9IDUzODE7XG4gICAgbGV0IGkgPSBzdHIubGVuZ3RoO1xuICAgIHdoaWxlIChpLS0pXG4gICAgICAgIGhhc2ggPSAoKGhhc2ggPDwgNSkgLSBoYXNoKSBeIHN0ci5jaGFyQ29kZUF0KGkpO1xuICAgIHJldHVybiBoYXNoID4+PiAwO1xufVxuZnVuY3Rpb24gY3JlYXRlX3N0eWxlX2luZm9ybWF0aW9uKGRvYywgbm9kZSkge1xuICAgIGNvbnN0IGluZm8gPSB7IHN0eWxlc2hlZXQ6IGFwcGVuZF9lbXB0eV9zdHlsZXNoZWV0KG5vZGUpLCBydWxlczoge30gfTtcbiAgICBtYW5hZ2VkX3N0eWxlcy5zZXQoZG9jLCBpbmZvKTtcbiAgICByZXR1cm4gaW5mbztcbn1cbmZ1bmN0aW9uIGNyZWF0ZV9ydWxlKG5vZGUsIGEsIGIsIGR1cmF0aW9uLCBkZWxheSwgZWFzZSwgZm4sIHVpZCA9IDApIHtcbiAgICBjb25zdCBzdGVwID0gMTYuNjY2IC8gZHVyYXRpb247XG4gICAgbGV0IGtleWZyYW1lcyA9ICd7XFxuJztcbiAgICBmb3IgKGxldCBwID0gMDsgcCA8PSAxOyBwICs9IHN0ZXApIHtcbiAgICAgICAgY29uc3QgdCA9IGEgKyAoYiAtIGEpICogZWFzZShwKTtcbiAgICAgICAga2V5ZnJhbWVzICs9IHAgKiAxMDAgKyBgJXske2ZuKHQsIDEgLSB0KX19XFxuYDtcbiAgICB9XG4gICAgY29uc3QgcnVsZSA9IGtleWZyYW1lcyArIGAxMDAlIHske2ZuKGIsIDEgLSBiKX19XFxufWA7XG4gICAgY29uc3QgbmFtZSA9IGBfX3N2ZWx0ZV8ke2hhc2gocnVsZSl9XyR7dWlkfWA7XG4gICAgY29uc3QgZG9jID0gZ2V0X3Jvb3RfZm9yX3N0eWxlKG5vZGUpO1xuICAgIGNvbnN0IHsgc3R5bGVzaGVldCwgcnVsZXMgfSA9IG1hbmFnZWRfc3R5bGVzLmdldChkb2MpIHx8IGNyZWF0ZV9zdHlsZV9pbmZvcm1hdGlvbihkb2MsIG5vZGUpO1xuICAgIGlmICghcnVsZXNbbmFtZV0pIHtcbiAgICAgICAgcnVsZXNbbmFtZV0gPSB0cnVlO1xuICAgICAgICBzdHlsZXNoZWV0Lmluc2VydFJ1bGUoYEBrZXlmcmFtZXMgJHtuYW1lfSAke3J1bGV9YCwgc3R5bGVzaGVldC5jc3NSdWxlcy5sZW5ndGgpO1xuICAgIH1cbiAgICBjb25zdCBhbmltYXRpb24gPSBub2RlLnN0eWxlLmFuaW1hdGlvbiB8fCAnJztcbiAgICBub2RlLnN0eWxlLmFuaW1hdGlvbiA9IGAke2FuaW1hdGlvbiA/IGAke2FuaW1hdGlvbn0sIGAgOiAnJ30ke25hbWV9ICR7ZHVyYXRpb259bXMgbGluZWFyICR7ZGVsYXl9bXMgMSBib3RoYDtcbiAgICBhY3RpdmUgKz0gMTtcbiAgICByZXR1cm4gbmFtZTtcbn1cbmZ1bmN0aW9uIGRlbGV0ZV9ydWxlKG5vZGUsIG5hbWUpIHtcbiAgICBjb25zdCBwcmV2aW91cyA9IChub2RlLnN0eWxlLmFuaW1hdGlvbiB8fCAnJykuc3BsaXQoJywgJyk7XG4gICAgY29uc3QgbmV4dCA9IHByZXZpb3VzLmZpbHRlcihuYW1lXG4gICAgICAgID8gYW5pbSA9PiBhbmltLmluZGV4T2YobmFtZSkgPCAwIC8vIHJlbW92ZSBzcGVjaWZpYyBhbmltYXRpb25cbiAgICAgICAgOiBhbmltID0+IGFuaW0uaW5kZXhPZignX19zdmVsdGUnKSA9PT0gLTEgLy8gcmVtb3ZlIGFsbCBTdmVsdGUgYW5pbWF0aW9uc1xuICAgICk7XG4gICAgY29uc3QgZGVsZXRlZCA9IHByZXZpb3VzLmxlbmd0aCAtIG5leHQubGVuZ3RoO1xuICAgIGlmIChkZWxldGVkKSB7XG4gICAgICAgIG5vZGUuc3R5bGUuYW5pbWF0aW9uID0gbmV4dC5qb2luKCcsICcpO1xuICAgICAgICBhY3RpdmUgLT0gZGVsZXRlZDtcbiAgICAgICAgaWYgKCFhY3RpdmUpXG4gICAgICAgICAgICBjbGVhcl9ydWxlcygpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIGNsZWFyX3J1bGVzKCkge1xuICAgIHJhZigoKSA9PiB7XG4gICAgICAgIGlmIChhY3RpdmUpXG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIG1hbmFnZWRfc3R5bGVzLmZvckVhY2goaW5mbyA9PiB7XG4gICAgICAgICAgICBjb25zdCB7IG93bmVyTm9kZSB9ID0gaW5mby5zdHlsZXNoZWV0O1xuICAgICAgICAgICAgLy8gdGhlcmUgaXMgbm8gb3duZXJOb2RlIGlmIGl0IHJ1bnMgb24ganNkb20uXG4gICAgICAgICAgICBpZiAob3duZXJOb2RlKVxuICAgICAgICAgICAgICAgIGRldGFjaChvd25lck5vZGUpO1xuICAgICAgICB9KTtcbiAgICAgICAgbWFuYWdlZF9zdHlsZXMuY2xlYXIoKTtcbiAgICB9KTtcbn1cblxuZnVuY3Rpb24gY3JlYXRlX2FuaW1hdGlvbihub2RlLCBmcm9tLCBmbiwgcGFyYW1zKSB7XG4gICAgaWYgKCFmcm9tKVxuICAgICAgICByZXR1cm4gbm9vcDtcbiAgICBjb25zdCB0byA9IG5vZGUuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgaWYgKGZyb20ubGVmdCA9PT0gdG8ubGVmdCAmJiBmcm9tLnJpZ2h0ID09PSB0by5yaWdodCAmJiBmcm9tLnRvcCA9PT0gdG8udG9wICYmIGZyb20uYm90dG9tID09PSB0by5ib3R0b20pXG4gICAgICAgIHJldHVybiBub29wO1xuICAgIGNvbnN0IHsgZGVsYXkgPSAwLCBkdXJhdGlvbiA9IDMwMCwgZWFzaW5nID0gaWRlbnRpdHksIFxuICAgIC8vIEB0cy1pZ25vcmUgdG9kbzogc2hvdWxkIHRoaXMgYmUgc2VwYXJhdGVkIGZyb20gZGVzdHJ1Y3R1cmluZz8gT3Igc3RhcnQvZW5kIGFkZGVkIHRvIHB1YmxpYyBhcGkgYW5kIGRvY3VtZW50YXRpb24/XG4gICAgc3RhcnQ6IHN0YXJ0X3RpbWUgPSBub3coKSArIGRlbGF5LCBcbiAgICAvLyBAdHMtaWdub3JlIHRvZG86XG4gICAgZW5kID0gc3RhcnRfdGltZSArIGR1cmF0aW9uLCB0aWNrID0gbm9vcCwgY3NzIH0gPSBmbihub2RlLCB7IGZyb20sIHRvIH0sIHBhcmFtcyk7XG4gICAgbGV0IHJ1bm5pbmcgPSB0cnVlO1xuICAgIGxldCBzdGFydGVkID0gZmFsc2U7XG4gICAgbGV0IG5hbWU7XG4gICAgZnVuY3Rpb24gc3RhcnQoKSB7XG4gICAgICAgIGlmIChjc3MpIHtcbiAgICAgICAgICAgIG5hbWUgPSBjcmVhdGVfcnVsZShub2RlLCAwLCAxLCBkdXJhdGlvbiwgZGVsYXksIGVhc2luZywgY3NzKTtcbiAgICAgICAgfVxuICAgICAgICBpZiAoIWRlbGF5KSB7XG4gICAgICAgICAgICBzdGFydGVkID0gdHJ1ZTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBmdW5jdGlvbiBzdG9wKCkge1xuICAgICAgICBpZiAoY3NzKVxuICAgICAgICAgICAgZGVsZXRlX3J1bGUobm9kZSwgbmFtZSk7XG4gICAgICAgIHJ1bm5pbmcgPSBmYWxzZTtcbiAgICB9XG4gICAgbG9vcChub3cgPT4ge1xuICAgICAgICBpZiAoIXN0YXJ0ZWQgJiYgbm93ID49IHN0YXJ0X3RpbWUpIHtcbiAgICAgICAgICAgIHN0YXJ0ZWQgPSB0cnVlO1xuICAgICAgICB9XG4gICAgICAgIGlmIChzdGFydGVkICYmIG5vdyA+PSBlbmQpIHtcbiAgICAgICAgICAgIHRpY2soMSwgMCk7XG4gICAgICAgICAgICBzdG9wKCk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKCFydW5uaW5nKSB7XG4gICAgICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHN0YXJ0ZWQpIHtcbiAgICAgICAgICAgIGNvbnN0IHAgPSBub3cgLSBzdGFydF90aW1lO1xuICAgICAgICAgICAgY29uc3QgdCA9IDAgKyAxICogZWFzaW5nKHAgLyBkdXJhdGlvbik7XG4gICAgICAgICAgICB0aWNrKHQsIDEgLSB0KTtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9KTtcbiAgICBzdGFydCgpO1xuICAgIHRpY2soMCwgMSk7XG4gICAgcmV0dXJuIHN0b3A7XG59XG5mdW5jdGlvbiBmaXhfcG9zaXRpb24obm9kZSkge1xuICAgIGNvbnN0IHN0eWxlID0gZ2V0Q29tcHV0ZWRTdHlsZShub2RlKTtcbiAgICBpZiAoc3R5bGUucG9zaXRpb24gIT09ICdhYnNvbHV0ZScgJiYgc3R5bGUucG9zaXRpb24gIT09ICdmaXhlZCcpIHtcbiAgICAgICAgY29uc3QgeyB3aWR0aCwgaGVpZ2h0IH0gPSBzdHlsZTtcbiAgICAgICAgY29uc3QgYSA9IG5vZGUuZ2V0Qm91bmRpbmdDbGllbnRSZWN0KCk7XG4gICAgICAgIG5vZGUuc3R5bGUucG9zaXRpb24gPSAnYWJzb2x1dGUnO1xuICAgICAgICBub2RlLnN0eWxlLndpZHRoID0gd2lkdGg7XG4gICAgICAgIG5vZGUuc3R5bGUuaGVpZ2h0ID0gaGVpZ2h0O1xuICAgICAgICBhZGRfdHJhbnNmb3JtKG5vZGUsIGEpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIGFkZF90cmFuc2Zvcm0obm9kZSwgYSkge1xuICAgIGNvbnN0IGIgPSBub2RlLmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgIGlmIChhLmxlZnQgIT09IGIubGVmdCB8fCBhLnRvcCAhPT0gYi50b3ApIHtcbiAgICAgICAgY29uc3Qgc3R5bGUgPSBnZXRDb21wdXRlZFN0eWxlKG5vZGUpO1xuICAgICAgICBjb25zdCB0cmFuc2Zvcm0gPSBzdHlsZS50cmFuc2Zvcm0gPT09ICdub25lJyA/ICcnIDogc3R5bGUudHJhbnNmb3JtO1xuICAgICAgICBub2RlLnN0eWxlLnRyYW5zZm9ybSA9IGAke3RyYW5zZm9ybX0gdHJhbnNsYXRlKCR7YS5sZWZ0IC0gYi5sZWZ0fXB4LCAke2EudG9wIC0gYi50b3B9cHgpYDtcbiAgICB9XG59XG5cbmxldCBjdXJyZW50X2NvbXBvbmVudDtcbmZ1bmN0aW9uIHNldF9jdXJyZW50X2NvbXBvbmVudChjb21wb25lbnQpIHtcbiAgICBjdXJyZW50X2NvbXBvbmVudCA9IGNvbXBvbmVudDtcbn1cbmZ1bmN0aW9uIGdldF9jdXJyZW50X2NvbXBvbmVudCgpIHtcbiAgICBpZiAoIWN1cnJlbnRfY29tcG9uZW50KVxuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Z1bmN0aW9uIGNhbGxlZCBvdXRzaWRlIGNvbXBvbmVudCBpbml0aWFsaXphdGlvbicpO1xuICAgIHJldHVybiBjdXJyZW50X2NvbXBvbmVudDtcbn1cbmZ1bmN0aW9uIGJlZm9yZVVwZGF0ZShmbikge1xuICAgIGdldF9jdXJyZW50X2NvbXBvbmVudCgpLiQkLmJlZm9yZV91cGRhdGUucHVzaChmbik7XG59XG5mdW5jdGlvbiBvbk1vdW50KGZuKSB7XG4gICAgZ2V0X2N1cnJlbnRfY29tcG9uZW50KCkuJCQub25fbW91bnQucHVzaChmbik7XG59XG5mdW5jdGlvbiBhZnRlclVwZGF0ZShmbikge1xuICAgIGdldF9jdXJyZW50X2NvbXBvbmVudCgpLiQkLmFmdGVyX3VwZGF0ZS5wdXNoKGZuKTtcbn1cbmZ1bmN0aW9uIG9uRGVzdHJveShmbikge1xuICAgIGdldF9jdXJyZW50X2NvbXBvbmVudCgpLiQkLm9uX2Rlc3Ryb3kucHVzaChmbik7XG59XG5mdW5jdGlvbiBjcmVhdGVFdmVudERpc3BhdGNoZXIoKSB7XG4gICAgY29uc3QgY29tcG9uZW50ID0gZ2V0X2N1cnJlbnRfY29tcG9uZW50KCk7XG4gICAgcmV0dXJuICh0eXBlLCBkZXRhaWwsIHsgY2FuY2VsYWJsZSA9IGZhbHNlIH0gPSB7fSkgPT4ge1xuICAgICAgICBjb25zdCBjYWxsYmFja3MgPSBjb21wb25lbnQuJCQuY2FsbGJhY2tzW3R5cGVdO1xuICAgICAgICBpZiAoY2FsbGJhY2tzKSB7XG4gICAgICAgICAgICAvLyBUT0RPIGFyZSB0aGVyZSBzaXR1YXRpb25zIHdoZXJlIGV2ZW50cyBjb3VsZCBiZSBkaXNwYXRjaGVkXG4gICAgICAgICAgICAvLyBpbiBhIHNlcnZlciAobm9uLURPTSkgZW52aXJvbm1lbnQ/XG4gICAgICAgICAgICBjb25zdCBldmVudCA9IGN1c3RvbV9ldmVudCh0eXBlLCBkZXRhaWwsIHsgY2FuY2VsYWJsZSB9KTtcbiAgICAgICAgICAgIGNhbGxiYWNrcy5zbGljZSgpLmZvckVhY2goZm4gPT4ge1xuICAgICAgICAgICAgICAgIGZuLmNhbGwoY29tcG9uZW50LCBldmVudCk7XG4gICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIHJldHVybiAhZXZlbnQuZGVmYXVsdFByZXZlbnRlZDtcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9O1xufVxuZnVuY3Rpb24gc2V0Q29udGV4dChrZXksIGNvbnRleHQpIHtcbiAgICBnZXRfY3VycmVudF9jb21wb25lbnQoKS4kJC5jb250ZXh0LnNldChrZXksIGNvbnRleHQpO1xuICAgIHJldHVybiBjb250ZXh0O1xufVxuZnVuY3Rpb24gZ2V0Q29udGV4dChrZXkpIHtcbiAgICByZXR1cm4gZ2V0X2N1cnJlbnRfY29tcG9uZW50KCkuJCQuY29udGV4dC5nZXQoa2V5KTtcbn1cbmZ1bmN0aW9uIGdldEFsbENvbnRleHRzKCkge1xuICAgIHJldHVybiBnZXRfY3VycmVudF9jb21wb25lbnQoKS4kJC5jb250ZXh0O1xufVxuZnVuY3Rpb24gaGFzQ29udGV4dChrZXkpIHtcbiAgICByZXR1cm4gZ2V0X2N1cnJlbnRfY29tcG9uZW50KCkuJCQuY29udGV4dC5oYXMoa2V5KTtcbn1cbi8vIFRPRE8gZmlndXJlIG91dCBpZiB3ZSBzdGlsbCB3YW50IHRvIHN1cHBvcnRcbi8vIHNob3J0aGFuZCBldmVudHMsIG9yIGlmIHdlIHdhbnQgdG8gaW1wbGVtZW50XG4vLyBhIHJlYWwgYnViYmxpbmcgbWVjaGFuaXNtXG5mdW5jdGlvbiBidWJibGUoY29tcG9uZW50LCBldmVudCkge1xuICAgIGNvbnN0IGNhbGxiYWNrcyA9IGNvbXBvbmVudC4kJC5jYWxsYmFja3NbZXZlbnQudHlwZV07XG4gICAgaWYgKGNhbGxiYWNrcykge1xuICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgIGNhbGxiYWNrcy5zbGljZSgpLmZvckVhY2goZm4gPT4gZm4uY2FsbCh0aGlzLCBldmVudCkpO1xuICAgIH1cbn1cblxuY29uc3QgZGlydHlfY29tcG9uZW50cyA9IFtdO1xuY29uc3QgaW50cm9zID0geyBlbmFibGVkOiBmYWxzZSB9O1xuY29uc3QgYmluZGluZ19jYWxsYmFja3MgPSBbXTtcbmNvbnN0IHJlbmRlcl9jYWxsYmFja3MgPSBbXTtcbmNvbnN0IGZsdXNoX2NhbGxiYWNrcyA9IFtdO1xuY29uc3QgcmVzb2x2ZWRfcHJvbWlzZSA9IFByb21pc2UucmVzb2x2ZSgpO1xubGV0IHVwZGF0ZV9zY2hlZHVsZWQgPSBmYWxzZTtcbmZ1bmN0aW9uIHNjaGVkdWxlX3VwZGF0ZSgpIHtcbiAgICBpZiAoIXVwZGF0ZV9zY2hlZHVsZWQpIHtcbiAgICAgICAgdXBkYXRlX3NjaGVkdWxlZCA9IHRydWU7XG4gICAgICAgIHJlc29sdmVkX3Byb21pc2UudGhlbihmbHVzaCk7XG4gICAgfVxufVxuZnVuY3Rpb24gdGljaygpIHtcbiAgICBzY2hlZHVsZV91cGRhdGUoKTtcbiAgICByZXR1cm4gcmVzb2x2ZWRfcHJvbWlzZTtcbn1cbmZ1bmN0aW9uIGFkZF9yZW5kZXJfY2FsbGJhY2soZm4pIHtcbiAgICByZW5kZXJfY2FsbGJhY2tzLnB1c2goZm4pO1xufVxuZnVuY3Rpb24gYWRkX2ZsdXNoX2NhbGxiYWNrKGZuKSB7XG4gICAgZmx1c2hfY2FsbGJhY2tzLnB1c2goZm4pO1xufVxuLy8gZmx1c2goKSBjYWxscyBjYWxsYmFja3MgaW4gdGhpcyBvcmRlcjpcbi8vIDEuIEFsbCBiZWZvcmVVcGRhdGUgY2FsbGJhY2tzLCBpbiBvcmRlcjogcGFyZW50cyBiZWZvcmUgY2hpbGRyZW5cbi8vIDIuIEFsbCBiaW5kOnRoaXMgY2FsbGJhY2tzLCBpbiByZXZlcnNlIG9yZGVyOiBjaGlsZHJlbiBiZWZvcmUgcGFyZW50cy5cbi8vIDMuIEFsbCBhZnRlclVwZGF0ZSBjYWxsYmFja3MsIGluIG9yZGVyOiBwYXJlbnRzIGJlZm9yZSBjaGlsZHJlbi4gRVhDRVBUXG4vLyAgICBmb3IgYWZ0ZXJVcGRhdGVzIGNhbGxlZCBkdXJpbmcgdGhlIGluaXRpYWwgb25Nb3VudCwgd2hpY2ggYXJlIGNhbGxlZCBpblxuLy8gICAgcmV2ZXJzZSBvcmRlcjogY2hpbGRyZW4gYmVmb3JlIHBhcmVudHMuXG4vLyBTaW5jZSBjYWxsYmFja3MgbWlnaHQgdXBkYXRlIGNvbXBvbmVudCB2YWx1ZXMsIHdoaWNoIGNvdWxkIHRyaWdnZXIgYW5vdGhlclxuLy8gY2FsbCB0byBmbHVzaCgpLCB0aGUgZm9sbG93aW5nIHN0ZXBzIGd1YXJkIGFnYWluc3QgdGhpczpcbi8vIDEuIER1cmluZyBiZWZvcmVVcGRhdGUsIGFueSB1cGRhdGVkIGNvbXBvbmVudHMgd2lsbCBiZSBhZGRlZCB0byB0aGVcbi8vICAgIGRpcnR5X2NvbXBvbmVudHMgYXJyYXkgYW5kIHdpbGwgY2F1c2UgYSByZWVudHJhbnQgY2FsbCB0byBmbHVzaCgpLiBCZWNhdXNlXG4vLyAgICB0aGUgZmx1c2ggaW5kZXggaXMga2VwdCBvdXRzaWRlIHRoZSBmdW5jdGlvbiwgdGhlIHJlZW50cmFudCBjYWxsIHdpbGwgcGlja1xuLy8gICAgdXAgd2hlcmUgdGhlIGVhcmxpZXIgY2FsbCBsZWZ0IG9mZiBhbmQgZ28gdGhyb3VnaCBhbGwgZGlydHkgY29tcG9uZW50cy4gVGhlXG4vLyAgICBjdXJyZW50X2NvbXBvbmVudCB2YWx1ZSBpcyBzYXZlZCBhbmQgcmVzdG9yZWQgc28gdGhhdCB0aGUgcmVlbnRyYW50IGNhbGwgd2lsbFxuLy8gICAgbm90IGludGVyZmVyZSB3aXRoIHRoZSBcInBhcmVudFwiIGZsdXNoKCkgY2FsbC5cbi8vIDIuIGJpbmQ6dGhpcyBjYWxsYmFja3MgY2Fubm90IHRyaWdnZXIgbmV3IGZsdXNoKCkgY2FsbHMuXG4vLyAzLiBEdXJpbmcgYWZ0ZXJVcGRhdGUsIGFueSB1cGRhdGVkIGNvbXBvbmVudHMgd2lsbCBOT1QgaGF2ZSB0aGVpciBhZnRlclVwZGF0ZVxuLy8gICAgY2FsbGJhY2sgY2FsbGVkIGEgc2Vjb25kIHRpbWU7IHRoZSBzZWVuX2NhbGxiYWNrcyBzZXQsIG91dHNpZGUgdGhlIGZsdXNoKClcbi8vICAgIGZ1bmN0aW9uLCBndWFyYW50ZWVzIHRoaXMgYmVoYXZpb3IuXG5jb25zdCBzZWVuX2NhbGxiYWNrcyA9IG5ldyBTZXQoKTtcbmxldCBmbHVzaGlkeCA9IDA7IC8vIERvICpub3QqIG1vdmUgdGhpcyBpbnNpZGUgdGhlIGZsdXNoKCkgZnVuY3Rpb25cbmZ1bmN0aW9uIGZsdXNoKCkge1xuICAgIGNvbnN0IHNhdmVkX2NvbXBvbmVudCA9IGN1cnJlbnRfY29tcG9uZW50O1xuICAgIGRvIHtcbiAgICAgICAgLy8gZmlyc3QsIGNhbGwgYmVmb3JlVXBkYXRlIGZ1bmN0aW9uc1xuICAgICAgICAvLyBhbmQgdXBkYXRlIGNvbXBvbmVudHNcbiAgICAgICAgd2hpbGUgKGZsdXNoaWR4IDwgZGlydHlfY29tcG9uZW50cy5sZW5ndGgpIHtcbiAgICAgICAgICAgIGNvbnN0IGNvbXBvbmVudCA9IGRpcnR5X2NvbXBvbmVudHNbZmx1c2hpZHhdO1xuICAgICAgICAgICAgZmx1c2hpZHgrKztcbiAgICAgICAgICAgIHNldF9jdXJyZW50X2NvbXBvbmVudChjb21wb25lbnQpO1xuICAgICAgICAgICAgdXBkYXRlKGNvbXBvbmVudC4kJCk7XG4gICAgICAgIH1cbiAgICAgICAgc2V0X2N1cnJlbnRfY29tcG9uZW50KG51bGwpO1xuICAgICAgICBkaXJ0eV9jb21wb25lbnRzLmxlbmd0aCA9IDA7XG4gICAgICAgIGZsdXNoaWR4ID0gMDtcbiAgICAgICAgd2hpbGUgKGJpbmRpbmdfY2FsbGJhY2tzLmxlbmd0aClcbiAgICAgICAgICAgIGJpbmRpbmdfY2FsbGJhY2tzLnBvcCgpKCk7XG4gICAgICAgIC8vIHRoZW4sIG9uY2UgY29tcG9uZW50cyBhcmUgdXBkYXRlZCwgY2FsbFxuICAgICAgICAvLyBhZnRlclVwZGF0ZSBmdW5jdGlvbnMuIFRoaXMgbWF5IGNhdXNlXG4gICAgICAgIC8vIHN1YnNlcXVlbnQgdXBkYXRlcy4uLlxuICAgICAgICBmb3IgKGxldCBpID0gMDsgaSA8IHJlbmRlcl9jYWxsYmFja3MubGVuZ3RoOyBpICs9IDEpIHtcbiAgICAgICAgICAgIGNvbnN0IGNhbGxiYWNrID0gcmVuZGVyX2NhbGxiYWNrc1tpXTtcbiAgICAgICAgICAgIGlmICghc2Vlbl9jYWxsYmFja3MuaGFzKGNhbGxiYWNrKSkge1xuICAgICAgICAgICAgICAgIC8vIC4uLnNvIGd1YXJkIGFnYWluc3QgaW5maW5pdGUgbG9vcHNcbiAgICAgICAgICAgICAgICBzZWVuX2NhbGxiYWNrcy5hZGQoY2FsbGJhY2spO1xuICAgICAgICAgICAgICAgIGNhbGxiYWNrKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgcmVuZGVyX2NhbGxiYWNrcy5sZW5ndGggPSAwO1xuICAgIH0gd2hpbGUgKGRpcnR5X2NvbXBvbmVudHMubGVuZ3RoKTtcbiAgICB3aGlsZSAoZmx1c2hfY2FsbGJhY2tzLmxlbmd0aCkge1xuICAgICAgICBmbHVzaF9jYWxsYmFja3MucG9wKCkoKTtcbiAgICB9XG4gICAgdXBkYXRlX3NjaGVkdWxlZCA9IGZhbHNlO1xuICAgIHNlZW5fY2FsbGJhY2tzLmNsZWFyKCk7XG4gICAgc2V0X2N1cnJlbnRfY29tcG9uZW50KHNhdmVkX2NvbXBvbmVudCk7XG59XG5mdW5jdGlvbiB1cGRhdGUoJCQpIHtcbiAgICBpZiAoJCQuZnJhZ21lbnQgIT09IG51bGwpIHtcbiAgICAgICAgJCQudXBkYXRlKCk7XG4gICAgICAgIHJ1bl9hbGwoJCQuYmVmb3JlX3VwZGF0ZSk7XG4gICAgICAgIGNvbnN0IGRpcnR5ID0gJCQuZGlydHk7XG4gICAgICAgICQkLmRpcnR5ID0gWy0xXTtcbiAgICAgICAgJCQuZnJhZ21lbnQgJiYgJCQuZnJhZ21lbnQucCgkJC5jdHgsIGRpcnR5KTtcbiAgICAgICAgJCQuYWZ0ZXJfdXBkYXRlLmZvckVhY2goYWRkX3JlbmRlcl9jYWxsYmFjayk7XG4gICAgfVxufVxuXG5sZXQgcHJvbWlzZTtcbmZ1bmN0aW9uIHdhaXQoKSB7XG4gICAgaWYgKCFwcm9taXNlKSB7XG4gICAgICAgIHByb21pc2UgPSBQcm9taXNlLnJlc29sdmUoKTtcbiAgICAgICAgcHJvbWlzZS50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIHByb21pc2UgPSBudWxsO1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgcmV0dXJuIHByb21pc2U7XG59XG5mdW5jdGlvbiBkaXNwYXRjaChub2RlLCBkaXJlY3Rpb24sIGtpbmQpIHtcbiAgICBub2RlLmRpc3BhdGNoRXZlbnQoY3VzdG9tX2V2ZW50KGAke2RpcmVjdGlvbiA/ICdpbnRybycgOiAnb3V0cm8nfSR7a2luZH1gKSk7XG59XG5jb25zdCBvdXRyb2luZyA9IG5ldyBTZXQoKTtcbmxldCBvdXRyb3M7XG5mdW5jdGlvbiBncm91cF9vdXRyb3MoKSB7XG4gICAgb3V0cm9zID0ge1xuICAgICAgICByOiAwLFxuICAgICAgICBjOiBbXSxcbiAgICAgICAgcDogb3V0cm9zIC8vIHBhcmVudCBncm91cFxuICAgIH07XG59XG5mdW5jdGlvbiBjaGVja19vdXRyb3MoKSB7XG4gICAgaWYgKCFvdXRyb3Mucikge1xuICAgICAgICBydW5fYWxsKG91dHJvcy5jKTtcbiAgICB9XG4gICAgb3V0cm9zID0gb3V0cm9zLnA7XG59XG5mdW5jdGlvbiB0cmFuc2l0aW9uX2luKGJsb2NrLCBsb2NhbCkge1xuICAgIGlmIChibG9jayAmJiBibG9jay5pKSB7XG4gICAgICAgIG91dHJvaW5nLmRlbGV0ZShibG9jayk7XG4gICAgICAgIGJsb2NrLmkobG9jYWwpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIHRyYW5zaXRpb25fb3V0KGJsb2NrLCBsb2NhbCwgZGV0YWNoLCBjYWxsYmFjaykge1xuICAgIGlmIChibG9jayAmJiBibG9jay5vKSB7XG4gICAgICAgIGlmIChvdXRyb2luZy5oYXMoYmxvY2spKVxuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICBvdXRyb2luZy5hZGQoYmxvY2spO1xuICAgICAgICBvdXRyb3MuYy5wdXNoKCgpID0+IHtcbiAgICAgICAgICAgIG91dHJvaW5nLmRlbGV0ZShibG9jayk7XG4gICAgICAgICAgICBpZiAoY2FsbGJhY2spIHtcbiAgICAgICAgICAgICAgICBpZiAoZGV0YWNoKVxuICAgICAgICAgICAgICAgICAgICBibG9jay5kKDEpO1xuICAgICAgICAgICAgICAgIGNhbGxiYWNrKCk7XG4gICAgICAgICAgICB9XG4gICAgICAgIH0pO1xuICAgICAgICBibG9jay5vKGxvY2FsKTtcbiAgICB9XG4gICAgZWxzZSBpZiAoY2FsbGJhY2spIHtcbiAgICAgICAgY2FsbGJhY2soKTtcbiAgICB9XG59XG5jb25zdCBudWxsX3RyYW5zaXRpb24gPSB7IGR1cmF0aW9uOiAwIH07XG5mdW5jdGlvbiBjcmVhdGVfaW5fdHJhbnNpdGlvbihub2RlLCBmbiwgcGFyYW1zKSB7XG4gICAgbGV0IGNvbmZpZyA9IGZuKG5vZGUsIHBhcmFtcyk7XG4gICAgbGV0IHJ1bm5pbmcgPSBmYWxzZTtcbiAgICBsZXQgYW5pbWF0aW9uX25hbWU7XG4gICAgbGV0IHRhc2s7XG4gICAgbGV0IHVpZCA9IDA7XG4gICAgZnVuY3Rpb24gY2xlYW51cCgpIHtcbiAgICAgICAgaWYgKGFuaW1hdGlvbl9uYW1lKVxuICAgICAgICAgICAgZGVsZXRlX3J1bGUobm9kZSwgYW5pbWF0aW9uX25hbWUpO1xuICAgIH1cbiAgICBmdW5jdGlvbiBnbygpIHtcbiAgICAgICAgY29uc3QgeyBkZWxheSA9IDAsIGR1cmF0aW9uID0gMzAwLCBlYXNpbmcgPSBpZGVudGl0eSwgdGljayA9IG5vb3AsIGNzcyB9ID0gY29uZmlnIHx8IG51bGxfdHJhbnNpdGlvbjtcbiAgICAgICAgaWYgKGNzcylcbiAgICAgICAgICAgIGFuaW1hdGlvbl9uYW1lID0gY3JlYXRlX3J1bGUobm9kZSwgMCwgMSwgZHVyYXRpb24sIGRlbGF5LCBlYXNpbmcsIGNzcywgdWlkKyspO1xuICAgICAgICB0aWNrKDAsIDEpO1xuICAgICAgICBjb25zdCBzdGFydF90aW1lID0gbm93KCkgKyBkZWxheTtcbiAgICAgICAgY29uc3QgZW5kX3RpbWUgPSBzdGFydF90aW1lICsgZHVyYXRpb247XG4gICAgICAgIGlmICh0YXNrKVxuICAgICAgICAgICAgdGFzay5hYm9ydCgpO1xuICAgICAgICBydW5uaW5nID0gdHJ1ZTtcbiAgICAgICAgYWRkX3JlbmRlcl9jYWxsYmFjaygoKSA9PiBkaXNwYXRjaChub2RlLCB0cnVlLCAnc3RhcnQnKSk7XG4gICAgICAgIHRhc2sgPSBsb29wKG5vdyA9PiB7XG4gICAgICAgICAgICBpZiAocnVubmluZykge1xuICAgICAgICAgICAgICAgIGlmIChub3cgPj0gZW5kX3RpbWUpIHtcbiAgICAgICAgICAgICAgICAgICAgdGljaygxLCAwKTtcbiAgICAgICAgICAgICAgICAgICAgZGlzcGF0Y2gobm9kZSwgdHJ1ZSwgJ2VuZCcpO1xuICAgICAgICAgICAgICAgICAgICBjbGVhbnVwKCk7XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBydW5uaW5nID0gZmFsc2U7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIGlmIChub3cgPj0gc3RhcnRfdGltZSkge1xuICAgICAgICAgICAgICAgICAgICBjb25zdCB0ID0gZWFzaW5nKChub3cgLSBzdGFydF90aW1lKSAvIGR1cmF0aW9uKTtcbiAgICAgICAgICAgICAgICAgICAgdGljayh0LCAxIC0gdCk7XG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuICAgICAgICAgICAgcmV0dXJuIHJ1bm5pbmc7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICBsZXQgc3RhcnRlZCA9IGZhbHNlO1xuICAgIHJldHVybiB7XG4gICAgICAgIHN0YXJ0KCkge1xuICAgICAgICAgICAgaWYgKHN0YXJ0ZWQpXG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgc3RhcnRlZCA9IHRydWU7XG4gICAgICAgICAgICBkZWxldGVfcnVsZShub2RlKTtcbiAgICAgICAgICAgIGlmIChpc19mdW5jdGlvbihjb25maWcpKSB7XG4gICAgICAgICAgICAgICAgY29uZmlnID0gY29uZmlnKCk7XG4gICAgICAgICAgICAgICAgd2FpdCgpLnRoZW4oZ28pO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAgICAgZ28oKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSxcbiAgICAgICAgaW52YWxpZGF0ZSgpIHtcbiAgICAgICAgICAgIHN0YXJ0ZWQgPSBmYWxzZTtcbiAgICAgICAgfSxcbiAgICAgICAgZW5kKCkge1xuICAgICAgICAgICAgaWYgKHJ1bm5pbmcpIHtcbiAgICAgICAgICAgICAgICBjbGVhbnVwKCk7XG4gICAgICAgICAgICAgICAgcnVubmluZyA9IGZhbHNlO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfTtcbn1cbmZ1bmN0aW9uIGNyZWF0ZV9vdXRfdHJhbnNpdGlvbihub2RlLCBmbiwgcGFyYW1zKSB7XG4gICAgbGV0IGNvbmZpZyA9IGZuKG5vZGUsIHBhcmFtcyk7XG4gICAgbGV0IHJ1bm5pbmcgPSB0cnVlO1xuICAgIGxldCBhbmltYXRpb25fbmFtZTtcbiAgICBjb25zdCBncm91cCA9IG91dHJvcztcbiAgICBncm91cC5yICs9IDE7XG4gICAgZnVuY3Rpb24gZ28oKSB7XG4gICAgICAgIGNvbnN0IHsgZGVsYXkgPSAwLCBkdXJhdGlvbiA9IDMwMCwgZWFzaW5nID0gaWRlbnRpdHksIHRpY2sgPSBub29wLCBjc3MgfSA9IGNvbmZpZyB8fCBudWxsX3RyYW5zaXRpb247XG4gICAgICAgIGlmIChjc3MpXG4gICAgICAgICAgICBhbmltYXRpb25fbmFtZSA9IGNyZWF0ZV9ydWxlKG5vZGUsIDEsIDAsIGR1cmF0aW9uLCBkZWxheSwgZWFzaW5nLCBjc3MpO1xuICAgICAgICBjb25zdCBzdGFydF90aW1lID0gbm93KCkgKyBkZWxheTtcbiAgICAgICAgY29uc3QgZW5kX3RpbWUgPSBzdGFydF90aW1lICsgZHVyYXRpb247XG4gICAgICAgIGFkZF9yZW5kZXJfY2FsbGJhY2soKCkgPT4gZGlzcGF0Y2gobm9kZSwgZmFsc2UsICdzdGFydCcpKTtcbiAgICAgICAgbG9vcChub3cgPT4ge1xuICAgICAgICAgICAgaWYgKHJ1bm5pbmcpIHtcbiAgICAgICAgICAgICAgICBpZiAobm93ID49IGVuZF90aW1lKSB7XG4gICAgICAgICAgICAgICAgICAgIHRpY2soMCwgMSk7XG4gICAgICAgICAgICAgICAgICAgIGRpc3BhdGNoKG5vZGUsIGZhbHNlLCAnZW5kJyk7XG4gICAgICAgICAgICAgICAgICAgIGlmICghLS1ncm91cC5yKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAvLyB0aGlzIHdpbGwgcmVzdWx0IGluIGBlbmQoKWAgYmVpbmcgY2FsbGVkLFxuICAgICAgICAgICAgICAgICAgICAgICAgLy8gc28gd2UgZG9uJ3QgbmVlZCB0byBjbGVhbiB1cCBoZXJlXG4gICAgICAgICAgICAgICAgICAgICAgICBydW5fYWxsKGdyb3VwLmMpO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgaWYgKG5vdyA+PSBzdGFydF90aW1lKSB7XG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IHQgPSBlYXNpbmcoKG5vdyAtIHN0YXJ0X3RpbWUpIC8gZHVyYXRpb24pO1xuICAgICAgICAgICAgICAgICAgICB0aWNrKDEgLSB0LCB0KTtcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gcnVubmluZztcbiAgICAgICAgfSk7XG4gICAgfVxuICAgIGlmIChpc19mdW5jdGlvbihjb25maWcpKSB7XG4gICAgICAgIHdhaXQoKS50aGVuKCgpID0+IHtcbiAgICAgICAgICAgIC8vIEB0cy1pZ25vcmVcbiAgICAgICAgICAgIGNvbmZpZyA9IGNvbmZpZygpO1xuICAgICAgICAgICAgZ28oKTtcbiAgICAgICAgfSk7XG4gICAgfVxuICAgIGVsc2Uge1xuICAgICAgICBnbygpO1xuICAgIH1cbiAgICByZXR1cm4ge1xuICAgICAgICBlbmQocmVzZXQpIHtcbiAgICAgICAgICAgIGlmIChyZXNldCAmJiBjb25maWcudGljaykge1xuICAgICAgICAgICAgICAgIGNvbmZpZy50aWNrKDEsIDApO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKHJ1bm5pbmcpIHtcbiAgICAgICAgICAgICAgICBpZiAoYW5pbWF0aW9uX25hbWUpXG4gICAgICAgICAgICAgICAgICAgIGRlbGV0ZV9ydWxlKG5vZGUsIGFuaW1hdGlvbl9uYW1lKTtcbiAgICAgICAgICAgICAgICBydW5uaW5nID0gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9O1xufVxuZnVuY3Rpb24gY3JlYXRlX2JpZGlyZWN0aW9uYWxfdHJhbnNpdGlvbihub2RlLCBmbiwgcGFyYW1zLCBpbnRybykge1xuICAgIGxldCBjb25maWcgPSBmbihub2RlLCBwYXJhbXMpO1xuICAgIGxldCB0ID0gaW50cm8gPyAwIDogMTtcbiAgICBsZXQgcnVubmluZ19wcm9ncmFtID0gbnVsbDtcbiAgICBsZXQgcGVuZGluZ19wcm9ncmFtID0gbnVsbDtcbiAgICBsZXQgYW5pbWF0aW9uX25hbWUgPSBudWxsO1xuICAgIGZ1bmN0aW9uIGNsZWFyX2FuaW1hdGlvbigpIHtcbiAgICAgICAgaWYgKGFuaW1hdGlvbl9uYW1lKVxuICAgICAgICAgICAgZGVsZXRlX3J1bGUobm9kZSwgYW5pbWF0aW9uX25hbWUpO1xuICAgIH1cbiAgICBmdW5jdGlvbiBpbml0KHByb2dyYW0sIGR1cmF0aW9uKSB7XG4gICAgICAgIGNvbnN0IGQgPSAocHJvZ3JhbS5iIC0gdCk7XG4gICAgICAgIGR1cmF0aW9uICo9IE1hdGguYWJzKGQpO1xuICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgYTogdCxcbiAgICAgICAgICAgIGI6IHByb2dyYW0uYixcbiAgICAgICAgICAgIGQsXG4gICAgICAgICAgICBkdXJhdGlvbixcbiAgICAgICAgICAgIHN0YXJ0OiBwcm9ncmFtLnN0YXJ0LFxuICAgICAgICAgICAgZW5kOiBwcm9ncmFtLnN0YXJ0ICsgZHVyYXRpb24sXG4gICAgICAgICAgICBncm91cDogcHJvZ3JhbS5ncm91cFxuICAgICAgICB9O1xuICAgIH1cbiAgICBmdW5jdGlvbiBnbyhiKSB7XG4gICAgICAgIGNvbnN0IHsgZGVsYXkgPSAwLCBkdXJhdGlvbiA9IDMwMCwgZWFzaW5nID0gaWRlbnRpdHksIHRpY2sgPSBub29wLCBjc3MgfSA9IGNvbmZpZyB8fCBudWxsX3RyYW5zaXRpb247XG4gICAgICAgIGNvbnN0IHByb2dyYW0gPSB7XG4gICAgICAgICAgICBzdGFydDogbm93KCkgKyBkZWxheSxcbiAgICAgICAgICAgIGJcbiAgICAgICAgfTtcbiAgICAgICAgaWYgKCFiKSB7XG4gICAgICAgICAgICAvLyBAdHMtaWdub3JlIHRvZG86IGltcHJvdmUgdHlwaW5nc1xuICAgICAgICAgICAgcHJvZ3JhbS5ncm91cCA9IG91dHJvcztcbiAgICAgICAgICAgIG91dHJvcy5yICs9IDE7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHJ1bm5pbmdfcHJvZ3JhbSB8fCBwZW5kaW5nX3Byb2dyYW0pIHtcbiAgICAgICAgICAgIHBlbmRpbmdfcHJvZ3JhbSA9IHByb2dyYW07XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICAvLyBpZiB0aGlzIGlzIGFuIGludHJvLCBhbmQgdGhlcmUncyBhIGRlbGF5LCB3ZSBuZWVkIHRvIGRvXG4gICAgICAgICAgICAvLyBhbiBpbml0aWFsIHRpY2sgYW5kL29yIGFwcGx5IENTUyBhbmltYXRpb24gaW1tZWRpYXRlbHlcbiAgICAgICAgICAgIGlmIChjc3MpIHtcbiAgICAgICAgICAgICAgICBjbGVhcl9hbmltYXRpb24oKTtcbiAgICAgICAgICAgICAgICBhbmltYXRpb25fbmFtZSA9IGNyZWF0ZV9ydWxlKG5vZGUsIHQsIGIsIGR1cmF0aW9uLCBkZWxheSwgZWFzaW5nLCBjc3MpO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgaWYgKGIpXG4gICAgICAgICAgICAgICAgdGljaygwLCAxKTtcbiAgICAgICAgICAgIHJ1bm5pbmdfcHJvZ3JhbSA9IGluaXQocHJvZ3JhbSwgZHVyYXRpb24pO1xuICAgICAgICAgICAgYWRkX3JlbmRlcl9jYWxsYmFjaygoKSA9PiBkaXNwYXRjaChub2RlLCBiLCAnc3RhcnQnKSk7XG4gICAgICAgICAgICBsb29wKG5vdyA9PiB7XG4gICAgICAgICAgICAgICAgaWYgKHBlbmRpbmdfcHJvZ3JhbSAmJiBub3cgPiBwZW5kaW5nX3Byb2dyYW0uc3RhcnQpIHtcbiAgICAgICAgICAgICAgICAgICAgcnVubmluZ19wcm9ncmFtID0gaW5pdChwZW5kaW5nX3Byb2dyYW0sIGR1cmF0aW9uKTtcbiAgICAgICAgICAgICAgICAgICAgcGVuZGluZ19wcm9ncmFtID0gbnVsbDtcbiAgICAgICAgICAgICAgICAgICAgZGlzcGF0Y2gobm9kZSwgcnVubmluZ19wcm9ncmFtLmIsICdzdGFydCcpO1xuICAgICAgICAgICAgICAgICAgICBpZiAoY3NzKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICBjbGVhcl9hbmltYXRpb24oKTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGFuaW1hdGlvbl9uYW1lID0gY3JlYXRlX3J1bGUobm9kZSwgdCwgcnVubmluZ19wcm9ncmFtLmIsIHJ1bm5pbmdfcHJvZ3JhbS5kdXJhdGlvbiwgMCwgZWFzaW5nLCBjb25maWcuY3NzKTtcbiAgICAgICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICBpZiAocnVubmluZ19wcm9ncmFtKSB7XG4gICAgICAgICAgICAgICAgICAgIGlmIChub3cgPj0gcnVubmluZ19wcm9ncmFtLmVuZCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgdGljayh0ID0gcnVubmluZ19wcm9ncmFtLmIsIDEgLSB0KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGRpc3BhdGNoKG5vZGUsIHJ1bm5pbmdfcHJvZ3JhbS5iLCAnZW5kJyk7XG4gICAgICAgICAgICAgICAgICAgICAgICBpZiAoIXBlbmRpbmdfcHJvZ3JhbSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8vIHdlJ3JlIGRvbmVcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAocnVubmluZ19wcm9ncmFtLmIpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLy8gaW50cm8g4oCUIHdlIGNhbiB0aWR5IHVwIGltbWVkaWF0ZWx5XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGNsZWFyX2FuaW1hdGlvbigpO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLy8gb3V0cm8g4oCUIG5lZWRzIHRvIGJlIGNvb3JkaW5hdGVkXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmICghLS1ydW5uaW5nX3Byb2dyYW0uZ3JvdXAucilcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHJ1bl9hbGwocnVubmluZ19wcm9ncmFtLmdyb3VwLmMpO1xuICAgICAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgICAgIHJ1bm5pbmdfcHJvZ3JhbSA9IG51bGw7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICAgICAgZWxzZSBpZiAobm93ID49IHJ1bm5pbmdfcHJvZ3JhbS5zdGFydCkge1xuICAgICAgICAgICAgICAgICAgICAgICAgY29uc3QgcCA9IG5vdyAtIHJ1bm5pbmdfcHJvZ3JhbS5zdGFydDtcbiAgICAgICAgICAgICAgICAgICAgICAgIHQgPSBydW5uaW5nX3Byb2dyYW0uYSArIHJ1bm5pbmdfcHJvZ3JhbS5kICogZWFzaW5nKHAgLyBydW5uaW5nX3Byb2dyYW0uZHVyYXRpb24pO1xuICAgICAgICAgICAgICAgICAgICAgICAgdGljayh0LCAxIC0gdCk7XG4gICAgICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgcmV0dXJuICEhKHJ1bm5pbmdfcHJvZ3JhbSB8fCBwZW5kaW5nX3Byb2dyYW0pO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH1cbiAgICB9XG4gICAgcmV0dXJuIHtcbiAgICAgICAgcnVuKGIpIHtcbiAgICAgICAgICAgIGlmIChpc19mdW5jdGlvbihjb25maWcpKSB7XG4gICAgICAgICAgICAgICAgd2FpdCgpLnRoZW4oKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICAvLyBAdHMtaWdub3JlXG4gICAgICAgICAgICAgICAgICAgIGNvbmZpZyA9IGNvbmZpZygpO1xuICAgICAgICAgICAgICAgICAgICBnbyhiKTtcbiAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgICAgIGdvKGIpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9LFxuICAgICAgICBlbmQoKSB7XG4gICAgICAgICAgICBjbGVhcl9hbmltYXRpb24oKTtcbiAgICAgICAgICAgIHJ1bm5pbmdfcHJvZ3JhbSA9IHBlbmRpbmdfcHJvZ3JhbSA9IG51bGw7XG4gICAgICAgIH1cbiAgICB9O1xufVxuXG5mdW5jdGlvbiBoYW5kbGVfcHJvbWlzZShwcm9taXNlLCBpbmZvKSB7XG4gICAgY29uc3QgdG9rZW4gPSBpbmZvLnRva2VuID0ge307XG4gICAgZnVuY3Rpb24gdXBkYXRlKHR5cGUsIGluZGV4LCBrZXksIHZhbHVlKSB7XG4gICAgICAgIGlmIChpbmZvLnRva2VuICE9PSB0b2tlbilcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgaW5mby5yZXNvbHZlZCA9IHZhbHVlO1xuICAgICAgICBsZXQgY2hpbGRfY3R4ID0gaW5mby5jdHg7XG4gICAgICAgIGlmIChrZXkgIT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgICAgY2hpbGRfY3R4ID0gY2hpbGRfY3R4LnNsaWNlKCk7XG4gICAgICAgICAgICBjaGlsZF9jdHhba2V5XSA9IHZhbHVlO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGJsb2NrID0gdHlwZSAmJiAoaW5mby5jdXJyZW50ID0gdHlwZSkoY2hpbGRfY3R4KTtcbiAgICAgICAgbGV0IG5lZWRzX2ZsdXNoID0gZmFsc2U7XG4gICAgICAgIGlmIChpbmZvLmJsb2NrKSB7XG4gICAgICAgICAgICBpZiAoaW5mby5ibG9ja3MpIHtcbiAgICAgICAgICAgICAgICBpbmZvLmJsb2Nrcy5mb3JFYWNoKChibG9jaywgaSkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBpZiAoaSAhPT0gaW5kZXggJiYgYmxvY2spIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIGdyb3VwX291dHJvcygpO1xuICAgICAgICAgICAgICAgICAgICAgICAgdHJhbnNpdGlvbl9vdXQoYmxvY2ssIDEsIDEsICgpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICBpZiAoaW5mby5ibG9ja3NbaV0gPT09IGJsb2NrKSB7XG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGluZm8uYmxvY2tzW2ldID0gbnVsbDtcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcbiAgICAgICAgICAgICAgICAgICAgICAgIGNoZWNrX291dHJvcygpO1xuICAgICAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgICAgICBpbmZvLmJsb2NrLmQoMSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICBibG9jay5jKCk7XG4gICAgICAgICAgICB0cmFuc2l0aW9uX2luKGJsb2NrLCAxKTtcbiAgICAgICAgICAgIGJsb2NrLm0oaW5mby5tb3VudCgpLCBpbmZvLmFuY2hvcik7XG4gICAgICAgICAgICBuZWVkc19mbHVzaCA9IHRydWU7XG4gICAgICAgIH1cbiAgICAgICAgaW5mby5ibG9jayA9IGJsb2NrO1xuICAgICAgICBpZiAoaW5mby5ibG9ja3MpXG4gICAgICAgICAgICBpbmZvLmJsb2Nrc1tpbmRleF0gPSBibG9jaztcbiAgICAgICAgaWYgKG5lZWRzX2ZsdXNoKSB7XG4gICAgICAgICAgICBmbHVzaCgpO1xuICAgICAgICB9XG4gICAgfVxuICAgIGlmIChpc19wcm9taXNlKHByb21pc2UpKSB7XG4gICAgICAgIGNvbnN0IGN1cnJlbnRfY29tcG9uZW50ID0gZ2V0X2N1cnJlbnRfY29tcG9uZW50KCk7XG4gICAgICAgIHByb21pc2UudGhlbih2YWx1ZSA9PiB7XG4gICAgICAgICAgICBzZXRfY3VycmVudF9jb21wb25lbnQoY3VycmVudF9jb21wb25lbnQpO1xuICAgICAgICAgICAgdXBkYXRlKGluZm8udGhlbiwgMSwgaW5mby52YWx1ZSwgdmFsdWUpO1xuICAgICAgICAgICAgc2V0X2N1cnJlbnRfY29tcG9uZW50KG51bGwpO1xuICAgICAgICB9LCBlcnJvciA9PiB7XG4gICAgICAgICAgICBzZXRfY3VycmVudF9jb21wb25lbnQoY3VycmVudF9jb21wb25lbnQpO1xuICAgICAgICAgICAgdXBkYXRlKGluZm8uY2F0Y2gsIDIsIGluZm8uZXJyb3IsIGVycm9yKTtcbiAgICAgICAgICAgIHNldF9jdXJyZW50X2NvbXBvbmVudChudWxsKTtcbiAgICAgICAgICAgIGlmICghaW5mby5oYXNDYXRjaCkge1xuICAgICAgICAgICAgICAgIHRocm93IGVycm9yO1xuICAgICAgICAgICAgfVxuICAgICAgICB9KTtcbiAgICAgICAgLy8gaWYgd2UgcHJldmlvdXNseSBoYWQgYSB0aGVuL2NhdGNoIGJsb2NrLCBkZXN0cm95IGl0XG4gICAgICAgIGlmIChpbmZvLmN1cnJlbnQgIT09IGluZm8ucGVuZGluZykge1xuICAgICAgICAgICAgdXBkYXRlKGluZm8ucGVuZGluZywgMCk7XG4gICAgICAgICAgICByZXR1cm4gdHJ1ZTtcbiAgICAgICAgfVxuICAgIH1cbiAgICBlbHNlIHtcbiAgICAgICAgaWYgKGluZm8uY3VycmVudCAhPT0gaW5mby50aGVuKSB7XG4gICAgICAgICAgICB1cGRhdGUoaW5mby50aGVuLCAxLCBpbmZvLnZhbHVlLCBwcm9taXNlKTtcbiAgICAgICAgICAgIHJldHVybiB0cnVlO1xuICAgICAgICB9XG4gICAgICAgIGluZm8ucmVzb2x2ZWQgPSBwcm9taXNlO1xuICAgIH1cbn1cbmZ1bmN0aW9uIHVwZGF0ZV9hd2FpdF9ibG9ja19icmFuY2goaW5mbywgY3R4LCBkaXJ0eSkge1xuICAgIGNvbnN0IGNoaWxkX2N0eCA9IGN0eC5zbGljZSgpO1xuICAgIGNvbnN0IHsgcmVzb2x2ZWQgfSA9IGluZm87XG4gICAgaWYgKGluZm8uY3VycmVudCA9PT0gaW5mby50aGVuKSB7XG4gICAgICAgIGNoaWxkX2N0eFtpbmZvLnZhbHVlXSA9IHJlc29sdmVkO1xuICAgIH1cbiAgICBpZiAoaW5mby5jdXJyZW50ID09PSBpbmZvLmNhdGNoKSB7XG4gICAgICAgIGNoaWxkX2N0eFtpbmZvLmVycm9yXSA9IHJlc29sdmVkO1xuICAgIH1cbiAgICBpbmZvLmJsb2NrLnAoY2hpbGRfY3R4LCBkaXJ0eSk7XG59XG5cbmNvbnN0IGdsb2JhbHMgPSAodHlwZW9mIHdpbmRvdyAhPT0gJ3VuZGVmaW5lZCdcbiAgICA/IHdpbmRvd1xuICAgIDogdHlwZW9mIGdsb2JhbFRoaXMgIT09ICd1bmRlZmluZWQnXG4gICAgICAgID8gZ2xvYmFsVGhpc1xuICAgICAgICA6IGdsb2JhbCk7XG5cbmZ1bmN0aW9uIGRlc3Ryb3lfYmxvY2soYmxvY2ssIGxvb2t1cCkge1xuICAgIGJsb2NrLmQoMSk7XG4gICAgbG9va3VwLmRlbGV0ZShibG9jay5rZXkpO1xufVxuZnVuY3Rpb24gb3V0cm9fYW5kX2Rlc3Ryb3lfYmxvY2soYmxvY2ssIGxvb2t1cCkge1xuICAgIHRyYW5zaXRpb25fb3V0KGJsb2NrLCAxLCAxLCAoKSA9PiB7XG4gICAgICAgIGxvb2t1cC5kZWxldGUoYmxvY2sua2V5KTtcbiAgICB9KTtcbn1cbmZ1bmN0aW9uIGZpeF9hbmRfZGVzdHJveV9ibG9jayhibG9jaywgbG9va3VwKSB7XG4gICAgYmxvY2suZigpO1xuICAgIGRlc3Ryb3lfYmxvY2soYmxvY2ssIGxvb2t1cCk7XG59XG5mdW5jdGlvbiBmaXhfYW5kX291dHJvX2FuZF9kZXN0cm95X2Jsb2NrKGJsb2NrLCBsb29rdXApIHtcbiAgICBibG9jay5mKCk7XG4gICAgb3V0cm9fYW5kX2Rlc3Ryb3lfYmxvY2soYmxvY2ssIGxvb2t1cCk7XG59XG5mdW5jdGlvbiB1cGRhdGVfa2V5ZWRfZWFjaChvbGRfYmxvY2tzLCBkaXJ0eSwgZ2V0X2tleSwgZHluYW1pYywgY3R4LCBsaXN0LCBsb29rdXAsIG5vZGUsIGRlc3Ryb3ksIGNyZWF0ZV9lYWNoX2Jsb2NrLCBuZXh0LCBnZXRfY29udGV4dCkge1xuICAgIGxldCBvID0gb2xkX2Jsb2Nrcy5sZW5ndGg7XG4gICAgbGV0IG4gPSBsaXN0Lmxlbmd0aDtcbiAgICBsZXQgaSA9IG87XG4gICAgY29uc3Qgb2xkX2luZGV4ZXMgPSB7fTtcbiAgICB3aGlsZSAoaS0tKVxuICAgICAgICBvbGRfaW5kZXhlc1tvbGRfYmxvY2tzW2ldLmtleV0gPSBpO1xuICAgIGNvbnN0IG5ld19ibG9ja3MgPSBbXTtcbiAgICBjb25zdCBuZXdfbG9va3VwID0gbmV3IE1hcCgpO1xuICAgIGNvbnN0IGRlbHRhcyA9IG5ldyBNYXAoKTtcbiAgICBpID0gbjtcbiAgICB3aGlsZSAoaS0tKSB7XG4gICAgICAgIGNvbnN0IGNoaWxkX2N0eCA9IGdldF9jb250ZXh0KGN0eCwgbGlzdCwgaSk7XG4gICAgICAgIGNvbnN0IGtleSA9IGdldF9rZXkoY2hpbGRfY3R4KTtcbiAgICAgICAgbGV0IGJsb2NrID0gbG9va3VwLmdldChrZXkpO1xuICAgICAgICBpZiAoIWJsb2NrKSB7XG4gICAgICAgICAgICBibG9jayA9IGNyZWF0ZV9lYWNoX2Jsb2NrKGtleSwgY2hpbGRfY3R4KTtcbiAgICAgICAgICAgIGJsb2NrLmMoKTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIGlmIChkeW5hbWljKSB7XG4gICAgICAgICAgICBibG9jay5wKGNoaWxkX2N0eCwgZGlydHkpO1xuICAgICAgICB9XG4gICAgICAgIG5ld19sb29rdXAuc2V0KGtleSwgbmV3X2Jsb2Nrc1tpXSA9IGJsb2NrKTtcbiAgICAgICAgaWYgKGtleSBpbiBvbGRfaW5kZXhlcylcbiAgICAgICAgICAgIGRlbHRhcy5zZXQoa2V5LCBNYXRoLmFicyhpIC0gb2xkX2luZGV4ZXNba2V5XSkpO1xuICAgIH1cbiAgICBjb25zdCB3aWxsX21vdmUgPSBuZXcgU2V0KCk7XG4gICAgY29uc3QgZGlkX21vdmUgPSBuZXcgU2V0KCk7XG4gICAgZnVuY3Rpb24gaW5zZXJ0KGJsb2NrKSB7XG4gICAgICAgIHRyYW5zaXRpb25faW4oYmxvY2ssIDEpO1xuICAgICAgICBibG9jay5tKG5vZGUsIG5leHQpO1xuICAgICAgICBsb29rdXAuc2V0KGJsb2NrLmtleSwgYmxvY2spO1xuICAgICAgICBuZXh0ID0gYmxvY2suZmlyc3Q7XG4gICAgICAgIG4tLTtcbiAgICB9XG4gICAgd2hpbGUgKG8gJiYgbikge1xuICAgICAgICBjb25zdCBuZXdfYmxvY2sgPSBuZXdfYmxvY2tzW24gLSAxXTtcbiAgICAgICAgY29uc3Qgb2xkX2Jsb2NrID0gb2xkX2Jsb2Nrc1tvIC0gMV07XG4gICAgICAgIGNvbnN0IG5ld19rZXkgPSBuZXdfYmxvY2sua2V5O1xuICAgICAgICBjb25zdCBvbGRfa2V5ID0gb2xkX2Jsb2NrLmtleTtcbiAgICAgICAgaWYgKG5ld19ibG9jayA9PT0gb2xkX2Jsb2NrKSB7XG4gICAgICAgICAgICAvLyBkbyBub3RoaW5nXG4gICAgICAgICAgICBuZXh0ID0gbmV3X2Jsb2NrLmZpcnN0O1xuICAgICAgICAgICAgby0tO1xuICAgICAgICAgICAgbi0tO1xuICAgICAgICB9XG4gICAgICAgIGVsc2UgaWYgKCFuZXdfbG9va3VwLmhhcyhvbGRfa2V5KSkge1xuICAgICAgICAgICAgLy8gcmVtb3ZlIG9sZCBibG9ja1xuICAgICAgICAgICAgZGVzdHJveShvbGRfYmxvY2ssIGxvb2t1cCk7XG4gICAgICAgICAgICBvLS07XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoIWxvb2t1cC5oYXMobmV3X2tleSkgfHwgd2lsbF9tb3ZlLmhhcyhuZXdfa2V5KSkge1xuICAgICAgICAgICAgaW5zZXJ0KG5ld19ibG9jayk7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoZGlkX21vdmUuaGFzKG9sZF9rZXkpKSB7XG4gICAgICAgICAgICBvLS07XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAoZGVsdGFzLmdldChuZXdfa2V5KSA+IGRlbHRhcy5nZXQob2xkX2tleSkpIHtcbiAgICAgICAgICAgIGRpZF9tb3ZlLmFkZChuZXdfa2V5KTtcbiAgICAgICAgICAgIGluc2VydChuZXdfYmxvY2spO1xuICAgICAgICB9XG4gICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgd2lsbF9tb3ZlLmFkZChvbGRfa2V5KTtcbiAgICAgICAgICAgIG8tLTtcbiAgICAgICAgfVxuICAgIH1cbiAgICB3aGlsZSAoby0tKSB7XG4gICAgICAgIGNvbnN0IG9sZF9ibG9jayA9IG9sZF9ibG9ja3Nbb107XG4gICAgICAgIGlmICghbmV3X2xvb2t1cC5oYXMob2xkX2Jsb2NrLmtleSkpXG4gICAgICAgICAgICBkZXN0cm95KG9sZF9ibG9jaywgbG9va3VwKTtcbiAgICB9XG4gICAgd2hpbGUgKG4pXG4gICAgICAgIGluc2VydChuZXdfYmxvY2tzW24gLSAxXSk7XG4gICAgcmV0dXJuIG5ld19ibG9ja3M7XG59XG5mdW5jdGlvbiB2YWxpZGF0ZV9lYWNoX2tleXMoY3R4LCBsaXN0LCBnZXRfY29udGV4dCwgZ2V0X2tleSkge1xuICAgIGNvbnN0IGtleXMgPSBuZXcgU2V0KCk7XG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBsaXN0Lmxlbmd0aDsgaSsrKSB7XG4gICAgICAgIGNvbnN0IGtleSA9IGdldF9rZXkoZ2V0X2NvbnRleHQoY3R4LCBsaXN0LCBpKSk7XG4gICAgICAgIGlmIChrZXlzLmhhcyhrZXkpKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Nhbm5vdCBoYXZlIGR1cGxpY2F0ZSBrZXlzIGluIGEga2V5ZWQgZWFjaCcpO1xuICAgICAgICB9XG4gICAgICAgIGtleXMuYWRkKGtleSk7XG4gICAgfVxufVxuXG5mdW5jdGlvbiBnZXRfc3ByZWFkX3VwZGF0ZShsZXZlbHMsIHVwZGF0ZXMpIHtcbiAgICBjb25zdCB1cGRhdGUgPSB7fTtcbiAgICBjb25zdCB0b19udWxsX291dCA9IHt9O1xuICAgIGNvbnN0IGFjY291bnRlZF9mb3IgPSB7ICQkc2NvcGU6IDEgfTtcbiAgICBsZXQgaSA9IGxldmVscy5sZW5ndGg7XG4gICAgd2hpbGUgKGktLSkge1xuICAgICAgICBjb25zdCBvID0gbGV2ZWxzW2ldO1xuICAgICAgICBjb25zdCBuID0gdXBkYXRlc1tpXTtcbiAgICAgICAgaWYgKG4pIHtcbiAgICAgICAgICAgIGZvciAoY29uc3Qga2V5IGluIG8pIHtcbiAgICAgICAgICAgICAgICBpZiAoIShrZXkgaW4gbikpXG4gICAgICAgICAgICAgICAgICAgIHRvX251bGxfb3V0W2tleV0gPSAxO1xuICAgICAgICAgICAgfVxuICAgICAgICAgICAgZm9yIChjb25zdCBrZXkgaW4gbikge1xuICAgICAgICAgICAgICAgIGlmICghYWNjb3VudGVkX2ZvcltrZXldKSB7XG4gICAgICAgICAgICAgICAgICAgIHVwZGF0ZVtrZXldID0gbltrZXldO1xuICAgICAgICAgICAgICAgICAgICBhY2NvdW50ZWRfZm9yW2tleV0gPSAxO1xuICAgICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGxldmVsc1tpXSA9IG47XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICBmb3IgKGNvbnN0IGtleSBpbiBvKSB7XG4gICAgICAgICAgICAgICAgYWNjb3VudGVkX2ZvcltrZXldID0gMTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgIH1cbiAgICBmb3IgKGNvbnN0IGtleSBpbiB0b19udWxsX291dCkge1xuICAgICAgICBpZiAoIShrZXkgaW4gdXBkYXRlKSlcbiAgICAgICAgICAgIHVwZGF0ZVtrZXldID0gdW5kZWZpbmVkO1xuICAgIH1cbiAgICByZXR1cm4gdXBkYXRlO1xufVxuZnVuY3Rpb24gZ2V0X3NwcmVhZF9vYmplY3Qoc3ByZWFkX3Byb3BzKSB7XG4gICAgcmV0dXJuIHR5cGVvZiBzcHJlYWRfcHJvcHMgPT09ICdvYmplY3QnICYmIHNwcmVhZF9wcm9wcyAhPT0gbnVsbCA/IHNwcmVhZF9wcm9wcyA6IHt9O1xufVxuXG4vLyBzb3VyY2U6IGh0dHBzOi8vaHRtbC5zcGVjLndoYXR3Zy5vcmcvbXVsdGlwYWdlL2luZGljZXMuaHRtbFxuY29uc3QgYm9vbGVhbl9hdHRyaWJ1dGVzID0gbmV3IFNldChbXG4gICAgJ2FsbG93ZnVsbHNjcmVlbicsXG4gICAgJ2FsbG93cGF5bWVudHJlcXVlc3QnLFxuICAgICdhc3luYycsXG4gICAgJ2F1dG9mb2N1cycsXG4gICAgJ2F1dG9wbGF5JyxcbiAgICAnY2hlY2tlZCcsXG4gICAgJ2NvbnRyb2xzJyxcbiAgICAnZGVmYXVsdCcsXG4gICAgJ2RlZmVyJyxcbiAgICAnZGlzYWJsZWQnLFxuICAgICdmb3Jtbm92YWxpZGF0ZScsXG4gICAgJ2hpZGRlbicsXG4gICAgJ2lzbWFwJyxcbiAgICAnbG9vcCcsXG4gICAgJ211bHRpcGxlJyxcbiAgICAnbXV0ZWQnLFxuICAgICdub21vZHVsZScsXG4gICAgJ25vdmFsaWRhdGUnLFxuICAgICdvcGVuJyxcbiAgICAncGxheXNpbmxpbmUnLFxuICAgICdyZWFkb25seScsXG4gICAgJ3JlcXVpcmVkJyxcbiAgICAncmV2ZXJzZWQnLFxuICAgICdzZWxlY3RlZCdcbl0pO1xuXG4vKiogcmVnZXggb2YgYWxsIGh0bWwgdm9pZCBlbGVtZW50IG5hbWVzICovXG5jb25zdCB2b2lkX2VsZW1lbnRfbmFtZXMgPSAvXig/OmFyZWF8YmFzZXxicnxjb2x8Y29tbWFuZHxlbWJlZHxocnxpbWd8aW5wdXR8a2V5Z2VufGxpbmt8bWV0YXxwYXJhbXxzb3VyY2V8dHJhY2t8d2JyKSQvO1xuZnVuY3Rpb24gaXNfdm9pZChuYW1lKSB7XG4gICAgcmV0dXJuIHZvaWRfZWxlbWVudF9uYW1lcy50ZXN0KG5hbWUpIHx8IG5hbWUudG9Mb3dlckNhc2UoKSA9PT0gJyFkb2N0eXBlJztcbn1cblxuY29uc3QgaW52YWxpZF9hdHRyaWJ1dGVfbmFtZV9jaGFyYWN0ZXIgPSAvW1xccydcIj4vPVxcdXtGREQwfS1cXHV7RkRFRn1cXHV7RkZGRX1cXHV7RkZGRn1cXHV7MUZGRkV9XFx1ezFGRkZGfVxcdXsyRkZGRX1cXHV7MkZGRkZ9XFx1ezNGRkZFfVxcdXszRkZGRn1cXHV7NEZGRkV9XFx1ezRGRkZGfVxcdXs1RkZGRX1cXHV7NUZGRkZ9XFx1ezZGRkZFfVxcdXs2RkZGRn1cXHV7N0ZGRkV9XFx1ezdGRkZGfVxcdXs4RkZGRX1cXHV7OEZGRkZ9XFx1ezlGRkZFfVxcdXs5RkZGRn1cXHV7QUZGRkV9XFx1e0FGRkZGfVxcdXtCRkZGRX1cXHV7QkZGRkZ9XFx1e0NGRkZFfVxcdXtDRkZGRn1cXHV7REZGRkV9XFx1e0RGRkZGfVxcdXtFRkZGRX1cXHV7RUZGRkZ9XFx1e0ZGRkZFfVxcdXtGRkZGRn1cXHV7MTBGRkZFfVxcdXsxMEZGRkZ9XS91O1xuLy8gaHR0cHM6Ly9odG1sLnNwZWMud2hhdHdnLm9yZy9tdWx0aXBhZ2Uvc3ludGF4Lmh0bWwjYXR0cmlidXRlcy0yXG4vLyBodHRwczovL2luZnJhLnNwZWMud2hhdHdnLm9yZy8jbm9uY2hhcmFjdGVyXG5mdW5jdGlvbiBzcHJlYWQoYXJncywgYXR0cnNfdG9fYWRkKSB7XG4gICAgY29uc3QgYXR0cmlidXRlcyA9IE9iamVjdC5hc3NpZ24oe30sIC4uLmFyZ3MpO1xuICAgIGlmIChhdHRyc190b19hZGQpIHtcbiAgICAgICAgY29uc3QgY2xhc3Nlc190b19hZGQgPSBhdHRyc190b19hZGQuY2xhc3NlcztcbiAgICAgICAgY29uc3Qgc3R5bGVzX3RvX2FkZCA9IGF0dHJzX3RvX2FkZC5zdHlsZXM7XG4gICAgICAgIGlmIChjbGFzc2VzX3RvX2FkZCkge1xuICAgICAgICAgICAgaWYgKGF0dHJpYnV0ZXMuY2xhc3MgPT0gbnVsbCkge1xuICAgICAgICAgICAgICAgIGF0dHJpYnV0ZXMuY2xhc3MgPSBjbGFzc2VzX3RvX2FkZDtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgICAgIGF0dHJpYnV0ZXMuY2xhc3MgKz0gJyAnICsgY2xhc3Nlc190b19hZGQ7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICAgICAgaWYgKHN0eWxlc190b19hZGQpIHtcbiAgICAgICAgICAgIGlmIChhdHRyaWJ1dGVzLnN0eWxlID09IG51bGwpIHtcbiAgICAgICAgICAgICAgICBhdHRyaWJ1dGVzLnN0eWxlID0gc3R5bGVfb2JqZWN0X3RvX3N0cmluZyhzdHlsZXNfdG9fYWRkKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgICAgIGF0dHJpYnV0ZXMuc3R5bGUgPSBzdHlsZV9vYmplY3RfdG9fc3RyaW5nKG1lcmdlX3Nzcl9zdHlsZXMoYXR0cmlidXRlcy5zdHlsZSwgc3R5bGVzX3RvX2FkZCkpO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgfVxuICAgIGxldCBzdHIgPSAnJztcbiAgICBPYmplY3Qua2V5cyhhdHRyaWJ1dGVzKS5mb3JFYWNoKG5hbWUgPT4ge1xuICAgICAgICBpZiAoaW52YWxpZF9hdHRyaWJ1dGVfbmFtZV9jaGFyYWN0ZXIudGVzdChuYW1lKSlcbiAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBhdHRyaWJ1dGVzW25hbWVdO1xuICAgICAgICBpZiAodmFsdWUgPT09IHRydWUpXG4gICAgICAgICAgICBzdHIgKz0gJyAnICsgbmFtZTtcbiAgICAgICAgZWxzZSBpZiAoYm9vbGVhbl9hdHRyaWJ1dGVzLmhhcyhuYW1lLnRvTG93ZXJDYXNlKCkpKSB7XG4gICAgICAgICAgICBpZiAodmFsdWUpXG4gICAgICAgICAgICAgICAgc3RyICs9ICcgJyArIG5hbWU7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSBpZiAodmFsdWUgIT0gbnVsbCkge1xuICAgICAgICAgICAgc3RyICs9IGAgJHtuYW1lfT1cIiR7dmFsdWV9XCJgO1xuICAgICAgICB9XG4gICAgfSk7XG4gICAgcmV0dXJuIHN0cjtcbn1cbmZ1bmN0aW9uIG1lcmdlX3Nzcl9zdHlsZXMoc3R5bGVfYXR0cmlidXRlLCBzdHlsZV9kaXJlY3RpdmUpIHtcbiAgICBjb25zdCBzdHlsZV9vYmplY3QgPSB7fTtcbiAgICBmb3IgKGNvbnN0IGluZGl2aWR1YWxfc3R5bGUgb2Ygc3R5bGVfYXR0cmlidXRlLnNwbGl0KCc7JykpIHtcbiAgICAgICAgY29uc3QgY29sb25faW5kZXggPSBpbmRpdmlkdWFsX3N0eWxlLmluZGV4T2YoJzonKTtcbiAgICAgICAgY29uc3QgbmFtZSA9IGluZGl2aWR1YWxfc3R5bGUuc2xpY2UoMCwgY29sb25faW5kZXgpLnRyaW0oKTtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBpbmRpdmlkdWFsX3N0eWxlLnNsaWNlKGNvbG9uX2luZGV4ICsgMSkudHJpbSgpO1xuICAgICAgICBpZiAoIW5hbWUpXG4gICAgICAgICAgICBjb250aW51ZTtcbiAgICAgICAgc3R5bGVfb2JqZWN0W25hbWVdID0gdmFsdWU7XG4gICAgfVxuICAgIGZvciAoY29uc3QgbmFtZSBpbiBzdHlsZV9kaXJlY3RpdmUpIHtcbiAgICAgICAgY29uc3QgdmFsdWUgPSBzdHlsZV9kaXJlY3RpdmVbbmFtZV07XG4gICAgICAgIGlmICh2YWx1ZSkge1xuICAgICAgICAgICAgc3R5bGVfb2JqZWN0W25hbWVdID0gdmFsdWU7XG4gICAgICAgIH1cbiAgICAgICAgZWxzZSB7XG4gICAgICAgICAgICBkZWxldGUgc3R5bGVfb2JqZWN0W25hbWVdO1xuICAgICAgICB9XG4gICAgfVxuICAgIHJldHVybiBzdHlsZV9vYmplY3Q7XG59XG5jb25zdCBBVFRSX1JFR0VYID0gL1smXCJdL2c7XG5jb25zdCBDT05URU5UX1JFR0VYID0gL1smPF0vZztcbi8qKlxuICogTm90ZTogdGhpcyBtZXRob2QgaXMgcGVyZm9ybWFuY2Ugc2Vuc2l0aXZlIGFuZCBoYXMgYmVlbiBvcHRpbWl6ZWRcbiAqIGh0dHBzOi8vZ2l0aHViLmNvbS9zdmVsdGVqcy9zdmVsdGUvcHVsbC81NzAxXG4gKi9cbmZ1bmN0aW9uIGVzY2FwZSh2YWx1ZSwgaXNfYXR0ciA9IGZhbHNlKSB7XG4gICAgY29uc3Qgc3RyID0gU3RyaW5nKHZhbHVlKTtcbiAgICBjb25zdCBwYXR0ZXJuID0gaXNfYXR0ciA/IEFUVFJfUkVHRVggOiBDT05URU5UX1JFR0VYO1xuICAgIHBhdHRlcm4ubGFzdEluZGV4ID0gMDtcbiAgICBsZXQgZXNjYXBlZCA9ICcnO1xuICAgIGxldCBsYXN0ID0gMDtcbiAgICB3aGlsZSAocGF0dGVybi50ZXN0KHN0cikpIHtcbiAgICAgICAgY29uc3QgaSA9IHBhdHRlcm4ubGFzdEluZGV4IC0gMTtcbiAgICAgICAgY29uc3QgY2ggPSBzdHJbaV07XG4gICAgICAgIGVzY2FwZWQgKz0gc3RyLnN1YnN0cmluZyhsYXN0LCBpKSArIChjaCA9PT0gJyYnID8gJyZhbXA7JyA6IChjaCA9PT0gJ1wiJyA/ICcmcXVvdDsnIDogJyZsdDsnKSk7XG4gICAgICAgIGxhc3QgPSBpICsgMTtcbiAgICB9XG4gICAgcmV0dXJuIGVzY2FwZWQgKyBzdHIuc3Vic3RyaW5nKGxhc3QpO1xufVxuZnVuY3Rpb24gZXNjYXBlX2F0dHJpYnV0ZV92YWx1ZSh2YWx1ZSkge1xuICAgIC8vIGtlZXAgYm9vbGVhbnMsIG51bGwsIGFuZCB1bmRlZmluZWQgZm9yIHRoZSBzYWtlIG9mIGBzcHJlYWRgXG4gICAgY29uc3Qgc2hvdWxkX2VzY2FwZSA9IHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycgfHwgKHZhbHVlICYmIHR5cGVvZiB2YWx1ZSA9PT0gJ29iamVjdCcpO1xuICAgIHJldHVybiBzaG91bGRfZXNjYXBlID8gZXNjYXBlKHZhbHVlLCB0cnVlKSA6IHZhbHVlO1xufVxuZnVuY3Rpb24gZXNjYXBlX29iamVjdChvYmopIHtcbiAgICBjb25zdCByZXN1bHQgPSB7fTtcbiAgICBmb3IgKGNvbnN0IGtleSBpbiBvYmopIHtcbiAgICAgICAgcmVzdWx0W2tleV0gPSBlc2NhcGVfYXR0cmlidXRlX3ZhbHVlKG9ialtrZXldKTtcbiAgICB9XG4gICAgcmV0dXJuIHJlc3VsdDtcbn1cbmZ1bmN0aW9uIGVhY2goaXRlbXMsIGZuKSB7XG4gICAgbGV0IHN0ciA9ICcnO1xuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgaXRlbXMubGVuZ3RoOyBpICs9IDEpIHtcbiAgICAgICAgc3RyICs9IGZuKGl0ZW1zW2ldLCBpKTtcbiAgICB9XG4gICAgcmV0dXJuIHN0cjtcbn1cbmNvbnN0IG1pc3NpbmdfY29tcG9uZW50ID0ge1xuICAgICQkcmVuZGVyOiAoKSA9PiAnJ1xufTtcbmZ1bmN0aW9uIHZhbGlkYXRlX2NvbXBvbmVudChjb21wb25lbnQsIG5hbWUpIHtcbiAgICBpZiAoIWNvbXBvbmVudCB8fCAhY29tcG9uZW50LiQkcmVuZGVyKSB7XG4gICAgICAgIGlmIChuYW1lID09PSAnc3ZlbHRlOmNvbXBvbmVudCcpXG4gICAgICAgICAgICBuYW1lICs9ICcgdGhpcz17Li4ufSc7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihgPCR7bmFtZX0+IGlzIG5vdCBhIHZhbGlkIFNTUiBjb21wb25lbnQuIFlvdSBtYXkgbmVlZCB0byByZXZpZXcgeW91ciBidWlsZCBjb25maWcgdG8gZW5zdXJlIHRoYXQgZGVwZW5kZW5jaWVzIGFyZSBjb21waWxlZCwgcmF0aGVyIHRoYW4gaW1wb3J0ZWQgYXMgcHJlLWNvbXBpbGVkIG1vZHVsZXNgKTtcbiAgICB9XG4gICAgcmV0dXJuIGNvbXBvbmVudDtcbn1cbmZ1bmN0aW9uIGRlYnVnKGZpbGUsIGxpbmUsIGNvbHVtbiwgdmFsdWVzKSB7XG4gICAgY29uc29sZS5sb2coYHtAZGVidWd9ICR7ZmlsZSA/IGZpbGUgKyAnICcgOiAnJ30oJHtsaW5lfToke2NvbHVtbn0pYCk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICAgIGNvbnNvbGUubG9nKHZhbHVlcyk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICAgIHJldHVybiAnJztcbn1cbmxldCBvbl9kZXN0cm95O1xuZnVuY3Rpb24gY3JlYXRlX3Nzcl9jb21wb25lbnQoZm4pIHtcbiAgICBmdW5jdGlvbiAkJHJlbmRlcihyZXN1bHQsIHByb3BzLCBiaW5kaW5ncywgc2xvdHMsIGNvbnRleHQpIHtcbiAgICAgICAgY29uc3QgcGFyZW50X2NvbXBvbmVudCA9IGN1cnJlbnRfY29tcG9uZW50O1xuICAgICAgICBjb25zdCAkJCA9IHtcbiAgICAgICAgICAgIG9uX2Rlc3Ryb3ksXG4gICAgICAgICAgICBjb250ZXh0OiBuZXcgTWFwKGNvbnRleHQgfHwgKHBhcmVudF9jb21wb25lbnQgPyBwYXJlbnRfY29tcG9uZW50LiQkLmNvbnRleHQgOiBbXSkpLFxuICAgICAgICAgICAgLy8gdGhlc2Ugd2lsbCBiZSBpbW1lZGlhdGVseSBkaXNjYXJkZWRcbiAgICAgICAgICAgIG9uX21vdW50OiBbXSxcbiAgICAgICAgICAgIGJlZm9yZV91cGRhdGU6IFtdLFxuICAgICAgICAgICAgYWZ0ZXJfdXBkYXRlOiBbXSxcbiAgICAgICAgICAgIGNhbGxiYWNrczogYmxhbmtfb2JqZWN0KClcbiAgICAgICAgfTtcbiAgICAgICAgc2V0X2N1cnJlbnRfY29tcG9uZW50KHsgJCQgfSk7XG4gICAgICAgIGNvbnN0IGh0bWwgPSBmbihyZXN1bHQsIHByb3BzLCBiaW5kaW5ncywgc2xvdHMpO1xuICAgICAgICBzZXRfY3VycmVudF9jb21wb25lbnQocGFyZW50X2NvbXBvbmVudCk7XG4gICAgICAgIHJldHVybiBodG1sO1xuICAgIH1cbiAgICByZXR1cm4ge1xuICAgICAgICByZW5kZXI6IChwcm9wcyA9IHt9LCB7ICQkc2xvdHMgPSB7fSwgY29udGV4dCA9IG5ldyBNYXAoKSB9ID0ge30pID0+IHtcbiAgICAgICAgICAgIG9uX2Rlc3Ryb3kgPSBbXTtcbiAgICAgICAgICAgIGNvbnN0IHJlc3VsdCA9IHsgdGl0bGU6ICcnLCBoZWFkOiAnJywgY3NzOiBuZXcgU2V0KCkgfTtcbiAgICAgICAgICAgIGNvbnN0IGh0bWwgPSAkJHJlbmRlcihyZXN1bHQsIHByb3BzLCB7fSwgJCRzbG90cywgY29udGV4dCk7XG4gICAgICAgICAgICBydW5fYWxsKG9uX2Rlc3Ryb3kpO1xuICAgICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgICAgICBodG1sLFxuICAgICAgICAgICAgICAgIGNzczoge1xuICAgICAgICAgICAgICAgICAgICBjb2RlOiBBcnJheS5mcm9tKHJlc3VsdC5jc3MpLm1hcChjc3MgPT4gY3NzLmNvZGUpLmpvaW4oJ1xcbicpLFxuICAgICAgICAgICAgICAgICAgICBtYXA6IG51bGwgLy8gVE9ET1xuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgICAgaGVhZDogcmVzdWx0LnRpdGxlICsgcmVzdWx0LmhlYWRcbiAgICAgICAgICAgIH07XG4gICAgICAgIH0sXG4gICAgICAgICQkcmVuZGVyXG4gICAgfTtcbn1cbmZ1bmN0aW9uIGFkZF9hdHRyaWJ1dGUobmFtZSwgdmFsdWUsIGJvb2xlYW4pIHtcbiAgICBpZiAodmFsdWUgPT0gbnVsbCB8fCAoYm9vbGVhbiAmJiAhdmFsdWUpKVxuICAgICAgICByZXR1cm4gJyc7XG4gICAgY29uc3QgYXNzaWdubWVudCA9IChib29sZWFuICYmIHZhbHVlID09PSB0cnVlKSA/ICcnIDogYD1cIiR7ZXNjYXBlKHZhbHVlLCB0cnVlKX1cImA7XG4gICAgcmV0dXJuIGAgJHtuYW1lfSR7YXNzaWdubWVudH1gO1xufVxuZnVuY3Rpb24gYWRkX2NsYXNzZXMoY2xhc3Nlcykge1xuICAgIHJldHVybiBjbGFzc2VzID8gYCBjbGFzcz1cIiR7Y2xhc3Nlc31cImAgOiAnJztcbn1cbmZ1bmN0aW9uIHN0eWxlX29iamVjdF90b19zdHJpbmcoc3R5bGVfb2JqZWN0KSB7XG4gICAgcmV0dXJuIE9iamVjdC5rZXlzKHN0eWxlX29iamVjdClcbiAgICAgICAgLmZpbHRlcihrZXkgPT4gc3R5bGVfb2JqZWN0W2tleV0pXG4gICAgICAgIC5tYXAoa2V5ID0+IGAke2tleX06ICR7c3R5bGVfb2JqZWN0W2tleV19O2ApXG4gICAgICAgIC5qb2luKCcgJyk7XG59XG5mdW5jdGlvbiBhZGRfc3R5bGVzKHN0eWxlX29iamVjdCkge1xuICAgIGNvbnN0IHN0eWxlcyA9IHN0eWxlX29iamVjdF90b19zdHJpbmcoc3R5bGVfb2JqZWN0KTtcbiAgICByZXR1cm4gc3R5bGVzID8gYCBzdHlsZT1cIiR7c3R5bGVzfVwiYCA6ICcnO1xufVxuXG5mdW5jdGlvbiBiaW5kKGNvbXBvbmVudCwgbmFtZSwgY2FsbGJhY2spIHtcbiAgICBjb25zdCBpbmRleCA9IGNvbXBvbmVudC4kJC5wcm9wc1tuYW1lXTtcbiAgICBpZiAoaW5kZXggIT09IHVuZGVmaW5lZCkge1xuICAgICAgICBjb21wb25lbnQuJCQuYm91bmRbaW5kZXhdID0gY2FsbGJhY2s7XG4gICAgICAgIGNhbGxiYWNrKGNvbXBvbmVudC4kJC5jdHhbaW5kZXhdKTtcbiAgICB9XG59XG5mdW5jdGlvbiBjcmVhdGVfY29tcG9uZW50KGJsb2NrKSB7XG4gICAgYmxvY2sgJiYgYmxvY2suYygpO1xufVxuZnVuY3Rpb24gY2xhaW1fY29tcG9uZW50KGJsb2NrLCBwYXJlbnRfbm9kZXMpIHtcbiAgICBibG9jayAmJiBibG9jay5sKHBhcmVudF9ub2Rlcyk7XG59XG5mdW5jdGlvbiBtb3VudF9jb21wb25lbnQoY29tcG9uZW50LCB0YXJnZXQsIGFuY2hvciwgY3VzdG9tRWxlbWVudCkge1xuICAgIGNvbnN0IHsgZnJhZ21lbnQsIG9uX21vdW50LCBvbl9kZXN0cm95LCBhZnRlcl91cGRhdGUgfSA9IGNvbXBvbmVudC4kJDtcbiAgICBmcmFnbWVudCAmJiBmcmFnbWVudC5tKHRhcmdldCwgYW5jaG9yKTtcbiAgICBpZiAoIWN1c3RvbUVsZW1lbnQpIHtcbiAgICAgICAgLy8gb25Nb3VudCBoYXBwZW5zIGJlZm9yZSB0aGUgaW5pdGlhbCBhZnRlclVwZGF0ZVxuICAgICAgICBhZGRfcmVuZGVyX2NhbGxiYWNrKCgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IG5ld19vbl9kZXN0cm95ID0gb25fbW91bnQubWFwKHJ1bikuZmlsdGVyKGlzX2Z1bmN0aW9uKTtcbiAgICAgICAgICAgIGlmIChvbl9kZXN0cm95KSB7XG4gICAgICAgICAgICAgICAgb25fZGVzdHJveS5wdXNoKC4uLm5ld19vbl9kZXN0cm95KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGVsc2Uge1xuICAgICAgICAgICAgICAgIC8vIEVkZ2UgY2FzZSAtIGNvbXBvbmVudCB3YXMgZGVzdHJveWVkIGltbWVkaWF0ZWx5LFxuICAgICAgICAgICAgICAgIC8vIG1vc3QgbGlrZWx5IGFzIGEgcmVzdWx0IG9mIGEgYmluZGluZyBpbml0aWFsaXNpbmdcbiAgICAgICAgICAgICAgICBydW5fYWxsKG5ld19vbl9kZXN0cm95KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIGNvbXBvbmVudC4kJC5vbl9tb3VudCA9IFtdO1xuICAgICAgICB9KTtcbiAgICB9XG4gICAgYWZ0ZXJfdXBkYXRlLmZvckVhY2goYWRkX3JlbmRlcl9jYWxsYmFjayk7XG59XG5mdW5jdGlvbiBkZXN0cm95X2NvbXBvbmVudChjb21wb25lbnQsIGRldGFjaGluZykge1xuICAgIGNvbnN0ICQkID0gY29tcG9uZW50LiQkO1xuICAgIGlmICgkJC5mcmFnbWVudCAhPT0gbnVsbCkge1xuICAgICAgICBydW5fYWxsKCQkLm9uX2Rlc3Ryb3kpO1xuICAgICAgICAkJC5mcmFnbWVudCAmJiAkJC5mcmFnbWVudC5kKGRldGFjaGluZyk7XG4gICAgICAgIC8vIFRPRE8gbnVsbCBvdXQgb3RoZXIgcmVmcywgaW5jbHVkaW5nIGNvbXBvbmVudC4kJCAoYnV0IG5lZWQgdG9cbiAgICAgICAgLy8gcHJlc2VydmUgZmluYWwgc3RhdGU/KVxuICAgICAgICAkJC5vbl9kZXN0cm95ID0gJCQuZnJhZ21lbnQgPSBudWxsO1xuICAgICAgICAkJC5jdHggPSBbXTtcbiAgICB9XG59XG5mdW5jdGlvbiBtYWtlX2RpcnR5KGNvbXBvbmVudCwgaSkge1xuICAgIGlmIChjb21wb25lbnQuJCQuZGlydHlbMF0gPT09IC0xKSB7XG4gICAgICAgIGRpcnR5X2NvbXBvbmVudHMucHVzaChjb21wb25lbnQpO1xuICAgICAgICBzY2hlZHVsZV91cGRhdGUoKTtcbiAgICAgICAgY29tcG9uZW50LiQkLmRpcnR5LmZpbGwoMCk7XG4gICAgfVxuICAgIGNvbXBvbmVudC4kJC5kaXJ0eVsoaSAvIDMxKSB8IDBdIHw9ICgxIDw8IChpICUgMzEpKTtcbn1cbmZ1bmN0aW9uIGluaXQoY29tcG9uZW50LCBvcHRpb25zLCBpbnN0YW5jZSwgY3JlYXRlX2ZyYWdtZW50LCBub3RfZXF1YWwsIHByb3BzLCBhcHBlbmRfc3R5bGVzLCBkaXJ0eSA9IFstMV0pIHtcbiAgICBjb25zdCBwYXJlbnRfY29tcG9uZW50ID0gY3VycmVudF9jb21wb25lbnQ7XG4gICAgc2V0X2N1cnJlbnRfY29tcG9uZW50KGNvbXBvbmVudCk7XG4gICAgY29uc3QgJCQgPSBjb21wb25lbnQuJCQgPSB7XG4gICAgICAgIGZyYWdtZW50OiBudWxsLFxuICAgICAgICBjdHg6IG51bGwsXG4gICAgICAgIC8vIHN0YXRlXG4gICAgICAgIHByb3BzLFxuICAgICAgICB1cGRhdGU6IG5vb3AsXG4gICAgICAgIG5vdF9lcXVhbCxcbiAgICAgICAgYm91bmQ6IGJsYW5rX29iamVjdCgpLFxuICAgICAgICAvLyBsaWZlY3ljbGVcbiAgICAgICAgb25fbW91bnQ6IFtdLFxuICAgICAgICBvbl9kZXN0cm95OiBbXSxcbiAgICAgICAgb25fZGlzY29ubmVjdDogW10sXG4gICAgICAgIGJlZm9yZV91cGRhdGU6IFtdLFxuICAgICAgICBhZnRlcl91cGRhdGU6IFtdLFxuICAgICAgICBjb250ZXh0OiBuZXcgTWFwKG9wdGlvbnMuY29udGV4dCB8fCAocGFyZW50X2NvbXBvbmVudCA/IHBhcmVudF9jb21wb25lbnQuJCQuY29udGV4dCA6IFtdKSksXG4gICAgICAgIC8vIGV2ZXJ5dGhpbmcgZWxzZVxuICAgICAgICBjYWxsYmFja3M6IGJsYW5rX29iamVjdCgpLFxuICAgICAgICBkaXJ0eSxcbiAgICAgICAgc2tpcF9ib3VuZDogZmFsc2UsXG4gICAgICAgIHJvb3Q6IG9wdGlvbnMudGFyZ2V0IHx8IHBhcmVudF9jb21wb25lbnQuJCQucm9vdFxuICAgIH07XG4gICAgYXBwZW5kX3N0eWxlcyAmJiBhcHBlbmRfc3R5bGVzKCQkLnJvb3QpO1xuICAgIGxldCByZWFkeSA9IGZhbHNlO1xuICAgICQkLmN0eCA9IGluc3RhbmNlXG4gICAgICAgID8gaW5zdGFuY2UoY29tcG9uZW50LCBvcHRpb25zLnByb3BzIHx8IHt9LCAoaSwgcmV0LCAuLi5yZXN0KSA9PiB7XG4gICAgICAgICAgICBjb25zdCB2YWx1ZSA9IHJlc3QubGVuZ3RoID8gcmVzdFswXSA6IHJldDtcbiAgICAgICAgICAgIGlmICgkJC5jdHggJiYgbm90X2VxdWFsKCQkLmN0eFtpXSwgJCQuY3R4W2ldID0gdmFsdWUpKSB7XG4gICAgICAgICAgICAgICAgaWYgKCEkJC5za2lwX2JvdW5kICYmICQkLmJvdW5kW2ldKVxuICAgICAgICAgICAgICAgICAgICAkJC5ib3VuZFtpXSh2YWx1ZSk7XG4gICAgICAgICAgICAgICAgaWYgKHJlYWR5KVxuICAgICAgICAgICAgICAgICAgICBtYWtlX2RpcnR5KGNvbXBvbmVudCwgaSk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICByZXR1cm4gcmV0O1xuICAgICAgICB9KVxuICAgICAgICA6IFtdO1xuICAgICQkLnVwZGF0ZSgpO1xuICAgIHJlYWR5ID0gdHJ1ZTtcbiAgICBydW5fYWxsKCQkLmJlZm9yZV91cGRhdGUpO1xuICAgIC8vIGBmYWxzZWAgYXMgYSBzcGVjaWFsIGNhc2Ugb2Ygbm8gRE9NIGNvbXBvbmVudFxuICAgICQkLmZyYWdtZW50ID0gY3JlYXRlX2ZyYWdtZW50ID8gY3JlYXRlX2ZyYWdtZW50KCQkLmN0eCkgOiBmYWxzZTtcbiAgICBpZiAob3B0aW9ucy50YXJnZXQpIHtcbiAgICAgICAgaWYgKG9wdGlvbnMuaHlkcmF0ZSkge1xuICAgICAgICAgICAgc3RhcnRfaHlkcmF0aW5nKCk7XG4gICAgICAgICAgICBjb25zdCBub2RlcyA9IGNoaWxkcmVuKG9wdGlvbnMudGFyZ2V0KTtcbiAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgICAgICAgICAkJC5mcmFnbWVudCAmJiAkJC5mcmFnbWVudC5sKG5vZGVzKTtcbiAgICAgICAgICAgIG5vZGVzLmZvckVhY2goZGV0YWNoKTtcbiAgICAgICAgfVxuICAgICAgICBlbHNlIHtcbiAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tbm9uLW51bGwtYXNzZXJ0aW9uXG4gICAgICAgICAgICAkJC5mcmFnbWVudCAmJiAkJC5mcmFnbWVudC5jKCk7XG4gICAgICAgIH1cbiAgICAgICAgaWYgKG9wdGlvbnMuaW50cm8pXG4gICAgICAgICAgICB0cmFuc2l0aW9uX2luKGNvbXBvbmVudC4kJC5mcmFnbWVudCk7XG4gICAgICAgIG1vdW50X2NvbXBvbmVudChjb21wb25lbnQsIG9wdGlvbnMudGFyZ2V0LCBvcHRpb25zLmFuY2hvciwgb3B0aW9ucy5jdXN0b21FbGVtZW50KTtcbiAgICAgICAgZW5kX2h5ZHJhdGluZygpO1xuICAgICAgICBmbHVzaCgpO1xuICAgIH1cbiAgICBzZXRfY3VycmVudF9jb21wb25lbnQocGFyZW50X2NvbXBvbmVudCk7XG59XG5sZXQgU3ZlbHRlRWxlbWVudDtcbmlmICh0eXBlb2YgSFRNTEVsZW1lbnQgPT09ICdmdW5jdGlvbicpIHtcbiAgICBTdmVsdGVFbGVtZW50ID0gY2xhc3MgZXh0ZW5kcyBIVE1MRWxlbWVudCB7XG4gICAgICAgIGNvbnN0cnVjdG9yKCkge1xuICAgICAgICAgICAgc3VwZXIoKTtcbiAgICAgICAgICAgIHRoaXMuYXR0YWNoU2hhZG93KHsgbW9kZTogJ29wZW4nIH0pO1xuICAgICAgICB9XG4gICAgICAgIGNvbm5lY3RlZENhbGxiYWNrKCkge1xuICAgICAgICAgICAgY29uc3QgeyBvbl9tb3VudCB9ID0gdGhpcy4kJDtcbiAgICAgICAgICAgIHRoaXMuJCQub25fZGlzY29ubmVjdCA9IG9uX21vdW50Lm1hcChydW4pLmZpbHRlcihpc19mdW5jdGlvbik7XG4gICAgICAgICAgICAvLyBAdHMtaWdub3JlIHRvZG86IGltcHJvdmUgdHlwaW5nc1xuICAgICAgICAgICAgZm9yIChjb25zdCBrZXkgaW4gdGhpcy4kJC5zbG90dGVkKSB7XG4gICAgICAgICAgICAgICAgLy8gQHRzLWlnbm9yZSB0b2RvOiBpbXByb3ZlIHR5cGluZ3NcbiAgICAgICAgICAgICAgICB0aGlzLmFwcGVuZENoaWxkKHRoaXMuJCQuc2xvdHRlZFtrZXldKTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfVxuICAgICAgICBhdHRyaWJ1dGVDaGFuZ2VkQ2FsbGJhY2soYXR0ciwgX29sZFZhbHVlLCBuZXdWYWx1ZSkge1xuICAgICAgICAgICAgdGhpc1thdHRyXSA9IG5ld1ZhbHVlO1xuICAgICAgICB9XG4gICAgICAgIGRpc2Nvbm5lY3RlZENhbGxiYWNrKCkge1xuICAgICAgICAgICAgcnVuX2FsbCh0aGlzLiQkLm9uX2Rpc2Nvbm5lY3QpO1xuICAgICAgICB9XG4gICAgICAgICRkZXN0cm95KCkge1xuICAgICAgICAgICAgZGVzdHJveV9jb21wb25lbnQodGhpcywgMSk7XG4gICAgICAgICAgICB0aGlzLiRkZXN0cm95ID0gbm9vcDtcbiAgICAgICAgfVxuICAgICAgICAkb24odHlwZSwgY2FsbGJhY2spIHtcbiAgICAgICAgICAgIC8vIFRPRE8gc2hvdWxkIHRoaXMgZGVsZWdhdGUgdG8gYWRkRXZlbnRMaXN0ZW5lcj9cbiAgICAgICAgICAgIGNvbnN0IGNhbGxiYWNrcyA9ICh0aGlzLiQkLmNhbGxiYWNrc1t0eXBlXSB8fCAodGhpcy4kJC5jYWxsYmFja3NbdHlwZV0gPSBbXSkpO1xuICAgICAgICAgICAgY2FsbGJhY2tzLnB1c2goY2FsbGJhY2spO1xuICAgICAgICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCBpbmRleCA9IGNhbGxiYWNrcy5pbmRleE9mKGNhbGxiYWNrKTtcbiAgICAgICAgICAgICAgICBpZiAoaW5kZXggIT09IC0xKVxuICAgICAgICAgICAgICAgICAgICBjYWxsYmFja3Muc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgICAgIH07XG4gICAgICAgIH1cbiAgICAgICAgJHNldCgkJHByb3BzKSB7XG4gICAgICAgICAgICBpZiAodGhpcy4kJHNldCAmJiAhaXNfZW1wdHkoJCRwcm9wcykpIHtcbiAgICAgICAgICAgICAgICB0aGlzLiQkLnNraXBfYm91bmQgPSB0cnVlO1xuICAgICAgICAgICAgICAgIHRoaXMuJCRzZXQoJCRwcm9wcyk7XG4gICAgICAgICAgICAgICAgdGhpcy4kJC5za2lwX2JvdW5kID0gZmFsc2U7XG4gICAgICAgICAgICB9XG4gICAgICAgIH1cbiAgICB9O1xufVxuLyoqXG4gKiBCYXNlIGNsYXNzIGZvciBTdmVsdGUgY29tcG9uZW50cy4gVXNlZCB3aGVuIGRldj1mYWxzZS5cbiAqL1xuY2xhc3MgU3ZlbHRlQ29tcG9uZW50IHtcbiAgICAkZGVzdHJveSgpIHtcbiAgICAgICAgZGVzdHJveV9jb21wb25lbnQodGhpcywgMSk7XG4gICAgICAgIHRoaXMuJGRlc3Ryb3kgPSBub29wO1xuICAgIH1cbiAgICAkb24odHlwZSwgY2FsbGJhY2spIHtcbiAgICAgICAgY29uc3QgY2FsbGJhY2tzID0gKHRoaXMuJCQuY2FsbGJhY2tzW3R5cGVdIHx8ICh0aGlzLiQkLmNhbGxiYWNrc1t0eXBlXSA9IFtdKSk7XG4gICAgICAgIGNhbGxiYWNrcy5wdXNoKGNhbGxiYWNrKTtcbiAgICAgICAgcmV0dXJuICgpID0+IHtcbiAgICAgICAgICAgIGNvbnN0IGluZGV4ID0gY2FsbGJhY2tzLmluZGV4T2YoY2FsbGJhY2spO1xuICAgICAgICAgICAgaWYgKGluZGV4ICE9PSAtMSlcbiAgICAgICAgICAgICAgICBjYWxsYmFja3Muc3BsaWNlKGluZGV4LCAxKTtcbiAgICAgICAgfTtcbiAgICB9XG4gICAgJHNldCgkJHByb3BzKSB7XG4gICAgICAgIGlmICh0aGlzLiQkc2V0ICYmICFpc19lbXB0eSgkJHByb3BzKSkge1xuICAgICAgICAgICAgdGhpcy4kJC5za2lwX2JvdW5kID0gdHJ1ZTtcbiAgICAgICAgICAgIHRoaXMuJCRzZXQoJCRwcm9wcyk7XG4gICAgICAgICAgICB0aGlzLiQkLnNraXBfYm91bmQgPSBmYWxzZTtcbiAgICAgICAgfVxuICAgIH1cbn1cblxuZnVuY3Rpb24gZGlzcGF0Y2hfZGV2KHR5cGUsIGRldGFpbCkge1xuICAgIGRvY3VtZW50LmRpc3BhdGNoRXZlbnQoY3VzdG9tX2V2ZW50KHR5cGUsIE9iamVjdC5hc3NpZ24oeyB2ZXJzaW9uOiAnMy41MC4xJyB9LCBkZXRhaWwpLCB7IGJ1YmJsZXM6IHRydWUgfSkpO1xufVxuZnVuY3Rpb24gYXBwZW5kX2Rldih0YXJnZXQsIG5vZGUpIHtcbiAgICBkaXNwYXRjaF9kZXYoJ1N2ZWx0ZURPTUluc2VydCcsIHsgdGFyZ2V0LCBub2RlIH0pO1xuICAgIGFwcGVuZCh0YXJnZXQsIG5vZGUpO1xufVxuZnVuY3Rpb24gYXBwZW5kX2h5ZHJhdGlvbl9kZXYodGFyZ2V0LCBub2RlKSB7XG4gICAgZGlzcGF0Y2hfZGV2KCdTdmVsdGVET01JbnNlcnQnLCB7IHRhcmdldCwgbm9kZSB9KTtcbiAgICBhcHBlbmRfaHlkcmF0aW9uKHRhcmdldCwgbm9kZSk7XG59XG5mdW5jdGlvbiBpbnNlcnRfZGV2KHRhcmdldCwgbm9kZSwgYW5jaG9yKSB7XG4gICAgZGlzcGF0Y2hfZGV2KCdTdmVsdGVET01JbnNlcnQnLCB7IHRhcmdldCwgbm9kZSwgYW5jaG9yIH0pO1xuICAgIGluc2VydCh0YXJnZXQsIG5vZGUsIGFuY2hvcik7XG59XG5mdW5jdGlvbiBpbnNlcnRfaHlkcmF0aW9uX2Rldih0YXJnZXQsIG5vZGUsIGFuY2hvcikge1xuICAgIGRpc3BhdGNoX2RldignU3ZlbHRlRE9NSW5zZXJ0JywgeyB0YXJnZXQsIG5vZGUsIGFuY2hvciB9KTtcbiAgICBpbnNlcnRfaHlkcmF0aW9uKHRhcmdldCwgbm9kZSwgYW5jaG9yKTtcbn1cbmZ1bmN0aW9uIGRldGFjaF9kZXYobm9kZSkge1xuICAgIGRpc3BhdGNoX2RldignU3ZlbHRlRE9NUmVtb3ZlJywgeyBub2RlIH0pO1xuICAgIGRldGFjaChub2RlKTtcbn1cbmZ1bmN0aW9uIGRldGFjaF9iZXR3ZWVuX2RldihiZWZvcmUsIGFmdGVyKSB7XG4gICAgd2hpbGUgKGJlZm9yZS5uZXh0U2libGluZyAmJiBiZWZvcmUubmV4dFNpYmxpbmcgIT09IGFmdGVyKSB7XG4gICAgICAgIGRldGFjaF9kZXYoYmVmb3JlLm5leHRTaWJsaW5nKTtcbiAgICB9XG59XG5mdW5jdGlvbiBkZXRhY2hfYmVmb3JlX2RldihhZnRlcikge1xuICAgIHdoaWxlIChhZnRlci5wcmV2aW91c1NpYmxpbmcpIHtcbiAgICAgICAgZGV0YWNoX2RldihhZnRlci5wcmV2aW91c1NpYmxpbmcpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIGRldGFjaF9hZnRlcl9kZXYoYmVmb3JlKSB7XG4gICAgd2hpbGUgKGJlZm9yZS5uZXh0U2libGluZykge1xuICAgICAgICBkZXRhY2hfZGV2KGJlZm9yZS5uZXh0U2libGluZyk7XG4gICAgfVxufVxuZnVuY3Rpb24gbGlzdGVuX2Rldihub2RlLCBldmVudCwgaGFuZGxlciwgb3B0aW9ucywgaGFzX3ByZXZlbnRfZGVmYXVsdCwgaGFzX3N0b3BfcHJvcGFnYXRpb24pIHtcbiAgICBjb25zdCBtb2RpZmllcnMgPSBvcHRpb25zID09PSB0cnVlID8gWydjYXB0dXJlJ10gOiBvcHRpb25zID8gQXJyYXkuZnJvbShPYmplY3Qua2V5cyhvcHRpb25zKSkgOiBbXTtcbiAgICBpZiAoaGFzX3ByZXZlbnRfZGVmYXVsdClcbiAgICAgICAgbW9kaWZpZXJzLnB1c2goJ3ByZXZlbnREZWZhdWx0Jyk7XG4gICAgaWYgKGhhc19zdG9wX3Byb3BhZ2F0aW9uKVxuICAgICAgICBtb2RpZmllcnMucHVzaCgnc3RvcFByb3BhZ2F0aW9uJyk7XG4gICAgZGlzcGF0Y2hfZGV2KCdTdmVsdGVET01BZGRFdmVudExpc3RlbmVyJywgeyBub2RlLCBldmVudCwgaGFuZGxlciwgbW9kaWZpZXJzIH0pO1xuICAgIGNvbnN0IGRpc3Bvc2UgPSBsaXN0ZW4obm9kZSwgZXZlbnQsIGhhbmRsZXIsIG9wdGlvbnMpO1xuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICAgIGRpc3BhdGNoX2RldignU3ZlbHRlRE9NUmVtb3ZlRXZlbnRMaXN0ZW5lcicsIHsgbm9kZSwgZXZlbnQsIGhhbmRsZXIsIG1vZGlmaWVycyB9KTtcbiAgICAgICAgZGlzcG9zZSgpO1xuICAgIH07XG59XG5mdW5jdGlvbiBhdHRyX2Rldihub2RlLCBhdHRyaWJ1dGUsIHZhbHVlKSB7XG4gICAgYXR0cihub2RlLCBhdHRyaWJ1dGUsIHZhbHVlKTtcbiAgICBpZiAodmFsdWUgPT0gbnVsbClcbiAgICAgICAgZGlzcGF0Y2hfZGV2KCdTdmVsdGVET01SZW1vdmVBdHRyaWJ1dGUnLCB7IG5vZGUsIGF0dHJpYnV0ZSB9KTtcbiAgICBlbHNlXG4gICAgICAgIGRpc3BhdGNoX2RldignU3ZlbHRlRE9NU2V0QXR0cmlidXRlJywgeyBub2RlLCBhdHRyaWJ1dGUsIHZhbHVlIH0pO1xufVxuZnVuY3Rpb24gcHJvcF9kZXYobm9kZSwgcHJvcGVydHksIHZhbHVlKSB7XG4gICAgbm9kZVtwcm9wZXJ0eV0gPSB2YWx1ZTtcbiAgICBkaXNwYXRjaF9kZXYoJ1N2ZWx0ZURPTVNldFByb3BlcnR5JywgeyBub2RlLCBwcm9wZXJ0eSwgdmFsdWUgfSk7XG59XG5mdW5jdGlvbiBkYXRhc2V0X2Rldihub2RlLCBwcm9wZXJ0eSwgdmFsdWUpIHtcbiAgICBub2RlLmRhdGFzZXRbcHJvcGVydHldID0gdmFsdWU7XG4gICAgZGlzcGF0Y2hfZGV2KCdTdmVsdGVET01TZXREYXRhc2V0JywgeyBub2RlLCBwcm9wZXJ0eSwgdmFsdWUgfSk7XG59XG5mdW5jdGlvbiBzZXRfZGF0YV9kZXYodGV4dCwgZGF0YSkge1xuICAgIGRhdGEgPSAnJyArIGRhdGE7XG4gICAgaWYgKHRleHQud2hvbGVUZXh0ID09PSBkYXRhKVxuICAgICAgICByZXR1cm47XG4gICAgZGlzcGF0Y2hfZGV2KCdTdmVsdGVET01TZXREYXRhJywgeyBub2RlOiB0ZXh0LCBkYXRhIH0pO1xuICAgIHRleHQuZGF0YSA9IGRhdGE7XG59XG5mdW5jdGlvbiB2YWxpZGF0ZV9lYWNoX2FyZ3VtZW50KGFyZykge1xuICAgIGlmICh0eXBlb2YgYXJnICE9PSAnc3RyaW5nJyAmJiAhKGFyZyAmJiB0eXBlb2YgYXJnID09PSAnb2JqZWN0JyAmJiAnbGVuZ3RoJyBpbiBhcmcpKSB7XG4gICAgICAgIGxldCBtc2cgPSAneyNlYWNofSBvbmx5IGl0ZXJhdGVzIG92ZXIgYXJyYXktbGlrZSBvYmplY3RzLic7XG4gICAgICAgIGlmICh0eXBlb2YgU3ltYm9sID09PSAnZnVuY3Rpb24nICYmIGFyZyAmJiBTeW1ib2wuaXRlcmF0b3IgaW4gYXJnKSB7XG4gICAgICAgICAgICBtc2cgKz0gJyBZb3UgY2FuIHVzZSBhIHNwcmVhZCB0byBjb252ZXJ0IHRoaXMgaXRlcmFibGUgaW50byBhbiBhcnJheS4nO1xuICAgICAgICB9XG4gICAgICAgIHRocm93IG5ldyBFcnJvcihtc2cpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIHZhbGlkYXRlX3Nsb3RzKG5hbWUsIHNsb3QsIGtleXMpIHtcbiAgICBmb3IgKGNvbnN0IHNsb3Rfa2V5IG9mIE9iamVjdC5rZXlzKHNsb3QpKSB7XG4gICAgICAgIGlmICghfmtleXMuaW5kZXhPZihzbG90X2tleSkpIHtcbiAgICAgICAgICAgIGNvbnNvbGUud2FybihgPCR7bmFtZX0+IHJlY2VpdmVkIGFuIHVuZXhwZWN0ZWQgc2xvdCBcIiR7c2xvdF9rZXl9XCIuYCk7XG4gICAgICAgIH1cbiAgICB9XG59XG5mdW5jdGlvbiB2YWxpZGF0ZV9keW5hbWljX2VsZW1lbnQodGFnKSB7XG4gICAgY29uc3QgaXNfc3RyaW5nID0gdHlwZW9mIHRhZyA9PT0gJ3N0cmluZyc7XG4gICAgaWYgKHRhZyAmJiAhaXNfc3RyaW5nKSB7XG4gICAgICAgIHRocm93IG5ldyBFcnJvcignPHN2ZWx0ZTplbGVtZW50PiBleHBlY3RzIFwidGhpc1wiIGF0dHJpYnV0ZSB0byBiZSBhIHN0cmluZy4nKTtcbiAgICB9XG59XG5mdW5jdGlvbiB2YWxpZGF0ZV92b2lkX2R5bmFtaWNfZWxlbWVudCh0YWcpIHtcbiAgICBpZiAodGFnICYmIGlzX3ZvaWQodGFnKSkge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYDxzdmVsdGU6ZWxlbWVudCB0aGlzPVwiJHt0YWd9XCI+IGlzIHNlbGYtY2xvc2luZyBhbmQgY2Fubm90IGhhdmUgY29udGVudC5gKTtcbiAgICB9XG59XG4vKipcbiAqIEJhc2UgY2xhc3MgZm9yIFN2ZWx0ZSBjb21wb25lbnRzIHdpdGggc29tZSBtaW5vciBkZXYtZW5oYW5jZW1lbnRzLiBVc2VkIHdoZW4gZGV2PXRydWUuXG4gKi9cbmNsYXNzIFN2ZWx0ZUNvbXBvbmVudERldiBleHRlbmRzIFN2ZWx0ZUNvbXBvbmVudCB7XG4gICAgY29uc3RydWN0b3Iob3B0aW9ucykge1xuICAgICAgICBpZiAoIW9wdGlvbnMgfHwgKCFvcHRpb25zLnRhcmdldCAmJiAhb3B0aW9ucy4kJGlubGluZSkpIHtcbiAgICAgICAgICAgIHRocm93IG5ldyBFcnJvcihcIid0YXJnZXQnIGlzIGEgcmVxdWlyZWQgb3B0aW9uXCIpO1xuICAgICAgICB9XG4gICAgICAgIHN1cGVyKCk7XG4gICAgfVxuICAgICRkZXN0cm95KCkge1xuICAgICAgICBzdXBlci4kZGVzdHJveSgpO1xuICAgICAgICB0aGlzLiRkZXN0cm95ID0gKCkgPT4ge1xuICAgICAgICAgICAgY29uc29sZS53YXJuKCdDb21wb25lbnQgd2FzIGFscmVhZHkgZGVzdHJveWVkJyk7IC8vIGVzbGludC1kaXNhYmxlLWxpbmUgbm8tY29uc29sZVxuICAgICAgICB9O1xuICAgIH1cbiAgICAkY2FwdHVyZV9zdGF0ZSgpIHsgfVxuICAgICRpbmplY3Rfc3RhdGUoKSB7IH1cbn1cbi8qKlxuICogQmFzZSBjbGFzcyB0byBjcmVhdGUgc3Ryb25nbHkgdHlwZWQgU3ZlbHRlIGNvbXBvbmVudHMuXG4gKiBUaGlzIG9ubHkgZXhpc3RzIGZvciB0eXBpbmcgcHVycG9zZXMgYW5kIHNob3VsZCBiZSB1c2VkIGluIGAuZC50c2AgZmlsZXMuXG4gKlxuICogIyMjIEV4YW1wbGU6XG4gKlxuICogWW91IGhhdmUgY29tcG9uZW50IGxpYnJhcnkgb24gbnBtIGNhbGxlZCBgY29tcG9uZW50LWxpYnJhcnlgLCBmcm9tIHdoaWNoXG4gKiB5b3UgZXhwb3J0IGEgY29tcG9uZW50IGNhbGxlZCBgTXlDb21wb25lbnRgLiBGb3IgU3ZlbHRlK1R5cGVTY3JpcHQgdXNlcnMsXG4gKiB5b3Ugd2FudCB0byBwcm92aWRlIHR5cGluZ3MuIFRoZXJlZm9yZSB5b3UgY3JlYXRlIGEgYGluZGV4LmQudHNgOlxuICogYGBgdHNcbiAqIGltcG9ydCB7IFN2ZWx0ZUNvbXBvbmVudFR5cGVkIH0gZnJvbSBcInN2ZWx0ZVwiO1xuICogZXhwb3J0IGNsYXNzIE15Q29tcG9uZW50IGV4dGVuZHMgU3ZlbHRlQ29tcG9uZW50VHlwZWQ8e2Zvbzogc3RyaW5nfT4ge31cbiAqIGBgYFxuICogVHlwaW5nIHRoaXMgbWFrZXMgaXQgcG9zc2libGUgZm9yIElERXMgbGlrZSBWUyBDb2RlIHdpdGggdGhlIFN2ZWx0ZSBleHRlbnNpb25cbiAqIHRvIHByb3ZpZGUgaW50ZWxsaXNlbnNlIGFuZCB0byB1c2UgdGhlIGNvbXBvbmVudCBsaWtlIHRoaXMgaW4gYSBTdmVsdGUgZmlsZVxuICogd2l0aCBUeXBlU2NyaXB0OlxuICogYGBgc3ZlbHRlXG4gKiA8c2NyaXB0IGxhbmc9XCJ0c1wiPlxuICogXHRpbXBvcnQgeyBNeUNvbXBvbmVudCB9IGZyb20gXCJjb21wb25lbnQtbGlicmFyeVwiO1xuICogPC9zY3JpcHQ+XG4gKiA8TXlDb21wb25lbnQgZm9vPXsnYmFyJ30gLz5cbiAqIGBgYFxuICpcbiAqICMjIyMgV2h5IG5vdCBtYWtlIHRoaXMgcGFydCBvZiBgU3ZlbHRlQ29tcG9uZW50KERldilgP1xuICogQmVjYXVzZVxuICogYGBgdHNcbiAqIGNsYXNzIEFTdWJjbGFzc09mU3ZlbHRlQ29tcG9uZW50IGV4dGVuZHMgU3ZlbHRlQ29tcG9uZW50PHtmb286IHN0cmluZ30+IHt9XG4gKiBjb25zdCBjb21wb25lbnQ6IHR5cGVvZiBTdmVsdGVDb21wb25lbnQgPSBBU3ViY2xhc3NPZlN2ZWx0ZUNvbXBvbmVudDtcbiAqIGBgYFxuICogd2lsbCB0aHJvdyBhIHR5cGUgZXJyb3IsIHNvIHdlIG5lZWQgdG8gc2VwYXJhdGUgdGhlIG1vcmUgc3RyaWN0bHkgdHlwZWQgY2xhc3MuXG4gKi9cbmNsYXNzIFN2ZWx0ZUNvbXBvbmVudFR5cGVkIGV4dGVuZHMgU3ZlbHRlQ29tcG9uZW50RGV2IHtcbiAgICBjb25zdHJ1Y3RvcihvcHRpb25zKSB7XG4gICAgICAgIHN1cGVyKG9wdGlvbnMpO1xuICAgIH1cbn1cbmZ1bmN0aW9uIGxvb3BfZ3VhcmQodGltZW91dCkge1xuICAgIGNvbnN0IHN0YXJ0ID0gRGF0ZS5ub3coKTtcbiAgICByZXR1cm4gKCkgPT4ge1xuICAgICAgICBpZiAoRGF0ZS5ub3coKSAtIHN0YXJ0ID4gdGltZW91dCkge1xuICAgICAgICAgICAgdGhyb3cgbmV3IEVycm9yKCdJbmZpbml0ZSBsb29wIGRldGVjdGVkJyk7XG4gICAgICAgIH1cbiAgICB9O1xufVxuXG5leHBvcnQgeyBIdG1sVGFnLCBIdG1sVGFnSHlkcmF0aW9uLCBTdmVsdGVDb21wb25lbnQsIFN2ZWx0ZUNvbXBvbmVudERldiwgU3ZlbHRlQ29tcG9uZW50VHlwZWQsIFN2ZWx0ZUVsZW1lbnQsIGFjdGlvbl9kZXN0cm95ZXIsIGFkZF9hdHRyaWJ1dGUsIGFkZF9jbGFzc2VzLCBhZGRfZmx1c2hfY2FsbGJhY2ssIGFkZF9sb2NhdGlvbiwgYWRkX3JlbmRlcl9jYWxsYmFjaywgYWRkX3Jlc2l6ZV9saXN0ZW5lciwgYWRkX3N0eWxlcywgYWRkX3RyYW5zZm9ybSwgYWZ0ZXJVcGRhdGUsIGFwcGVuZCwgYXBwZW5kX2RldiwgYXBwZW5kX2VtcHR5X3N0eWxlc2hlZXQsIGFwcGVuZF9oeWRyYXRpb24sIGFwcGVuZF9oeWRyYXRpb25fZGV2LCBhcHBlbmRfc3R5bGVzLCBhc3NpZ24sIGF0dHIsIGF0dHJfZGV2LCBhdHRyaWJ1dGVfdG9fb2JqZWN0LCBiZWZvcmVVcGRhdGUsIGJpbmQsIGJpbmRpbmdfY2FsbGJhY2tzLCBibGFua19vYmplY3QsIGJ1YmJsZSwgY2hlY2tfb3V0cm9zLCBjaGlsZHJlbiwgY2xhaW1fY29tcG9uZW50LCBjbGFpbV9lbGVtZW50LCBjbGFpbV9odG1sX3RhZywgY2xhaW1fc3BhY2UsIGNsYWltX3N2Z19lbGVtZW50LCBjbGFpbV90ZXh0LCBjbGVhcl9sb29wcywgY29tcG9uZW50X3N1YnNjcmliZSwgY29tcHV0ZV9yZXN0X3Byb3BzLCBjb21wdXRlX3Nsb3RzLCBjcmVhdGVFdmVudERpc3BhdGNoZXIsIGNyZWF0ZV9hbmltYXRpb24sIGNyZWF0ZV9iaWRpcmVjdGlvbmFsX3RyYW5zaXRpb24sIGNyZWF0ZV9jb21wb25lbnQsIGNyZWF0ZV9pbl90cmFuc2l0aW9uLCBjcmVhdGVfb3V0X3RyYW5zaXRpb24sIGNyZWF0ZV9zbG90LCBjcmVhdGVfc3NyX2NvbXBvbmVudCwgY3VycmVudF9jb21wb25lbnQsIGN1c3RvbV9ldmVudCwgZGF0YXNldF9kZXYsIGRlYnVnLCBkZXN0cm95X2Jsb2NrLCBkZXN0cm95X2NvbXBvbmVudCwgZGVzdHJveV9lYWNoLCBkZXRhY2gsIGRldGFjaF9hZnRlcl9kZXYsIGRldGFjaF9iZWZvcmVfZGV2LCBkZXRhY2hfYmV0d2Vlbl9kZXYsIGRldGFjaF9kZXYsIGRpcnR5X2NvbXBvbmVudHMsIGRpc3BhdGNoX2RldiwgZWFjaCwgZWxlbWVudCwgZWxlbWVudF9pcywgZW1wdHksIGVuZF9oeWRyYXRpbmcsIGVzY2FwZSwgZXNjYXBlX2F0dHJpYnV0ZV92YWx1ZSwgZXNjYXBlX29iamVjdCwgZXhjbHVkZV9pbnRlcm5hbF9wcm9wcywgZml4X2FuZF9kZXN0cm95X2Jsb2NrLCBmaXhfYW5kX291dHJvX2FuZF9kZXN0cm95X2Jsb2NrLCBmaXhfcG9zaXRpb24sIGZsdXNoLCBnZXRBbGxDb250ZXh0cywgZ2V0Q29udGV4dCwgZ2V0X2FsbF9kaXJ0eV9mcm9tX3Njb3BlLCBnZXRfYmluZGluZ19ncm91cF92YWx1ZSwgZ2V0X2N1cnJlbnRfY29tcG9uZW50LCBnZXRfY3VzdG9tX2VsZW1lbnRzX3Nsb3RzLCBnZXRfcm9vdF9mb3Jfc3R5bGUsIGdldF9zbG90X2NoYW5nZXMsIGdldF9zcHJlYWRfb2JqZWN0LCBnZXRfc3ByZWFkX3VwZGF0ZSwgZ2V0X3N0b3JlX3ZhbHVlLCBnbG9iYWxzLCBncm91cF9vdXRyb3MsIGhhbmRsZV9wcm9taXNlLCBoYXNDb250ZXh0LCBoYXNfcHJvcCwgaWRlbnRpdHksIGluaXQsIGluc2VydCwgaW5zZXJ0X2RldiwgaW5zZXJ0X2h5ZHJhdGlvbiwgaW5zZXJ0X2h5ZHJhdGlvbl9kZXYsIGludHJvcywgaW52YWxpZF9hdHRyaWJ1dGVfbmFtZV9jaGFyYWN0ZXIsIGlzX2NsaWVudCwgaXNfY3Jvc3NvcmlnaW4sIGlzX2VtcHR5LCBpc19mdW5jdGlvbiwgaXNfcHJvbWlzZSwgaXNfdm9pZCwgbGlzdGVuLCBsaXN0ZW5fZGV2LCBsb29wLCBsb29wX2d1YXJkLCBtZXJnZV9zc3Jfc3R5bGVzLCBtaXNzaW5nX2NvbXBvbmVudCwgbW91bnRfY29tcG9uZW50LCBub29wLCBub3RfZXF1YWwsIG5vdywgbnVsbF90b19lbXB0eSwgb2JqZWN0X3dpdGhvdXRfcHJvcGVydGllcywgb25EZXN0cm95LCBvbk1vdW50LCBvbmNlLCBvdXRyb19hbmRfZGVzdHJveV9ibG9jaywgcHJldmVudF9kZWZhdWx0LCBwcm9wX2RldiwgcXVlcnlfc2VsZWN0b3JfYWxsLCByYWYsIHJ1biwgcnVuX2FsbCwgc2FmZV9ub3RfZXF1YWwsIHNjaGVkdWxlX3VwZGF0ZSwgc2VsZWN0X211bHRpcGxlX3ZhbHVlLCBzZWxlY3Rfb3B0aW9uLCBzZWxlY3Rfb3B0aW9ucywgc2VsZWN0X3ZhbHVlLCBzZWxmLCBzZXRDb250ZXh0LCBzZXRfYXR0cmlidXRlcywgc2V0X2N1cnJlbnRfY29tcG9uZW50LCBzZXRfY3VzdG9tX2VsZW1lbnRfZGF0YSwgc2V0X2RhdGEsIHNldF9kYXRhX2Rldiwgc2V0X2lucHV0X3R5cGUsIHNldF9pbnB1dF92YWx1ZSwgc2V0X25vdywgc2V0X3JhZiwgc2V0X3N0b3JlX3ZhbHVlLCBzZXRfc3R5bGUsIHNldF9zdmdfYXR0cmlidXRlcywgc3BhY2UsIHNwcmVhZCwgc3JjX3VybF9lcXVhbCwgc3RhcnRfaHlkcmF0aW5nLCBzdG9wX3Byb3BhZ2F0aW9uLCBzdWJzY3JpYmUsIHN2Z19lbGVtZW50LCB0ZXh0LCB0aWNrLCB0aW1lX3Jhbmdlc190b19hcnJheSwgdG9fbnVtYmVyLCB0b2dnbGVfY2xhc3MsIHRyYW5zaXRpb25faW4sIHRyYW5zaXRpb25fb3V0LCB0cnVzdGVkLCB1cGRhdGVfYXdhaXRfYmxvY2tfYnJhbmNoLCB1cGRhdGVfa2V5ZWRfZWFjaCwgdXBkYXRlX3Nsb3QsIHVwZGF0ZV9zbG90X2Jhc2UsIHZhbGlkYXRlX2NvbXBvbmVudCwgdmFsaWRhdGVfZHluYW1pY19lbGVtZW50LCB2YWxpZGF0ZV9lYWNoX2FyZ3VtZW50LCB2YWxpZGF0ZV9lYWNoX2tleXMsIHZhbGlkYXRlX3Nsb3RzLCB2YWxpZGF0ZV9zdG9yZSwgdmFsaWRhdGVfdm9pZF9keW5hbWljX2VsZW1lbnQsIHhsaW5rX2F0dHIgfTtcbiIsIi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcclxuQ29weXJpZ2h0IChjKSBNaWNyb3NvZnQgQ29ycG9yYXRpb24uXHJcblxyXG5QZXJtaXNzaW9uIHRvIHVzZSwgY29weSwgbW9kaWZ5LCBhbmQvb3IgZGlzdHJpYnV0ZSB0aGlzIHNvZnR3YXJlIGZvciBhbnlcclxucHVycG9zZSB3aXRoIG9yIHdpdGhvdXQgZmVlIGlzIGhlcmVieSBncmFudGVkLlxyXG5cclxuVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEIFwiQVMgSVNcIiBBTkQgVEhFIEFVVEhPUiBESVNDTEFJTVMgQUxMIFdBUlJBTlRJRVMgV0lUSFxyXG5SRUdBUkQgVE8gVEhJUyBTT0ZUV0FSRSBJTkNMVURJTkcgQUxMIElNUExJRUQgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFlcclxuQU5EIEZJVE5FU1MuIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBBVVRIT1IgQkUgTElBQkxFIEZPUiBBTlkgU1BFQ0lBTCwgRElSRUNULFxyXG5JTkRJUkVDVCwgT1IgQ09OU0VRVUVOVElBTCBEQU1BR0VTIE9SIEFOWSBEQU1BR0VTIFdIQVRTT0VWRVIgUkVTVUxUSU5HIEZST01cclxuTE9TUyBPRiBVU0UsIERBVEEgT1IgUFJPRklUUywgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIE5FR0xJR0VOQ0UgT1JcclxuT1RIRVIgVE9SVElPVVMgQUNUSU9OLCBBUklTSU5HIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFVTRSBPUlxyXG5QRVJGT1JNQU5DRSBPRiBUSElTIFNPRlRXQVJFLlxyXG4qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiAqL1xyXG4vKiBnbG9iYWwgUmVmbGVjdCwgUHJvbWlzZSAqL1xyXG5cclxudmFyIGV4dGVuZFN0YXRpY3MgPSBmdW5jdGlvbihkLCBiKSB7XHJcbiAgICBleHRlbmRTdGF0aWNzID0gT2JqZWN0LnNldFByb3RvdHlwZU9mIHx8XHJcbiAgICAgICAgKHsgX19wcm90b19fOiBbXSB9IGluc3RhbmNlb2YgQXJyYXkgJiYgZnVuY3Rpb24gKGQsIGIpIHsgZC5fX3Byb3RvX18gPSBiOyB9KSB8fFxyXG4gICAgICAgIGZ1bmN0aW9uIChkLCBiKSB7IGZvciAodmFyIHAgaW4gYikgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChiLCBwKSkgZFtwXSA9IGJbcF07IH07XHJcbiAgICByZXR1cm4gZXh0ZW5kU3RhdGljcyhkLCBiKTtcclxufTtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX2V4dGVuZHMoZCwgYikge1xyXG4gICAgaWYgKHR5cGVvZiBiICE9PSBcImZ1bmN0aW9uXCIgJiYgYiAhPT0gbnVsbClcclxuICAgICAgICB0aHJvdyBuZXcgVHlwZUVycm9yKFwiQ2xhc3MgZXh0ZW5kcyB2YWx1ZSBcIiArIFN0cmluZyhiKSArIFwiIGlzIG5vdCBhIGNvbnN0cnVjdG9yIG9yIG51bGxcIik7XHJcbiAgICBleHRlbmRTdGF0aWNzKGQsIGIpO1xyXG4gICAgZnVuY3Rpb24gX18oKSB7IHRoaXMuY29uc3RydWN0b3IgPSBkOyB9XHJcbiAgICBkLnByb3RvdHlwZSA9IGIgPT09IG51bGwgPyBPYmplY3QuY3JlYXRlKGIpIDogKF9fLnByb3RvdHlwZSA9IGIucHJvdG90eXBlLCBuZXcgX18oKSk7XHJcbn1cclxuXHJcbmV4cG9ydCB2YXIgX19hc3NpZ24gPSBmdW5jdGlvbigpIHtcclxuICAgIF9fYXNzaWduID0gT2JqZWN0LmFzc2lnbiB8fCBmdW5jdGlvbiBfX2Fzc2lnbih0KSB7XHJcbiAgICAgICAgZm9yICh2YXIgcywgaSA9IDEsIG4gPSBhcmd1bWVudHMubGVuZ3RoOyBpIDwgbjsgaSsrKSB7XHJcbiAgICAgICAgICAgIHMgPSBhcmd1bWVudHNbaV07XHJcbiAgICAgICAgICAgIGZvciAodmFyIHAgaW4gcykgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChzLCBwKSkgdFtwXSA9IHNbcF07XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIF9fYXNzaWduLmFwcGx5KHRoaXMsIGFyZ3VtZW50cyk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX3Jlc3QocywgZSkge1xyXG4gICAgdmFyIHQgPSB7fTtcclxuICAgIGZvciAodmFyIHAgaW4gcykgaWYgKE9iamVjdC5wcm90b3R5cGUuaGFzT3duUHJvcGVydHkuY2FsbChzLCBwKSAmJiBlLmluZGV4T2YocCkgPCAwKVxyXG4gICAgICAgIHRbcF0gPSBzW3BdO1xyXG4gICAgaWYgKHMgIT0gbnVsbCAmJiB0eXBlb2YgT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyA9PT0gXCJmdW5jdGlvblwiKVxyXG4gICAgICAgIGZvciAodmFyIGkgPSAwLCBwID0gT2JqZWN0LmdldE93blByb3BlcnR5U3ltYm9scyhzKTsgaSA8IHAubGVuZ3RoOyBpKyspIHtcclxuICAgICAgICAgICAgaWYgKGUuaW5kZXhPZihwW2ldKSA8IDAgJiYgT2JqZWN0LnByb3RvdHlwZS5wcm9wZXJ0eUlzRW51bWVyYWJsZS5jYWxsKHMsIHBbaV0pKVxyXG4gICAgICAgICAgICAgICAgdFtwW2ldXSA9IHNbcFtpXV07XHJcbiAgICAgICAgfVxyXG4gICAgcmV0dXJuIHQ7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX2RlY29yYXRlKGRlY29yYXRvcnMsIHRhcmdldCwga2V5LCBkZXNjKSB7XHJcbiAgICB2YXIgYyA9IGFyZ3VtZW50cy5sZW5ndGgsIHIgPSBjIDwgMyA/IHRhcmdldCA6IGRlc2MgPT09IG51bGwgPyBkZXNjID0gT2JqZWN0LmdldE93blByb3BlcnR5RGVzY3JpcHRvcih0YXJnZXQsIGtleSkgOiBkZXNjLCBkO1xyXG4gICAgaWYgKHR5cGVvZiBSZWZsZWN0ID09PSBcIm9iamVjdFwiICYmIHR5cGVvZiBSZWZsZWN0LmRlY29yYXRlID09PSBcImZ1bmN0aW9uXCIpIHIgPSBSZWZsZWN0LmRlY29yYXRlKGRlY29yYXRvcnMsIHRhcmdldCwga2V5LCBkZXNjKTtcclxuICAgIGVsc2UgZm9yICh2YXIgaSA9IGRlY29yYXRvcnMubGVuZ3RoIC0gMTsgaSA+PSAwOyBpLS0pIGlmIChkID0gZGVjb3JhdG9yc1tpXSkgciA9IChjIDwgMyA/IGQocikgOiBjID4gMyA/IGQodGFyZ2V0LCBrZXksIHIpIDogZCh0YXJnZXQsIGtleSkpIHx8IHI7XHJcbiAgICByZXR1cm4gYyA+IDMgJiYgciAmJiBPYmplY3QuZGVmaW5lUHJvcGVydHkodGFyZ2V0LCBrZXksIHIpLCByO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gX19wYXJhbShwYXJhbUluZGV4LCBkZWNvcmF0b3IpIHtcclxuICAgIHJldHVybiBmdW5jdGlvbiAodGFyZ2V0LCBrZXkpIHsgZGVjb3JhdG9yKHRhcmdldCwga2V5LCBwYXJhbUluZGV4KTsgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gX19tZXRhZGF0YShtZXRhZGF0YUtleSwgbWV0YWRhdGFWYWx1ZSkge1xyXG4gICAgaWYgKHR5cGVvZiBSZWZsZWN0ID09PSBcIm9iamVjdFwiICYmIHR5cGVvZiBSZWZsZWN0Lm1ldGFkYXRhID09PSBcImZ1bmN0aW9uXCIpIHJldHVybiBSZWZsZWN0Lm1ldGFkYXRhKG1ldGFkYXRhS2V5LCBtZXRhZGF0YVZhbHVlKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fYXdhaXRlcih0aGlzQXJnLCBfYXJndW1lbnRzLCBQLCBnZW5lcmF0b3IpIHtcclxuICAgIGZ1bmN0aW9uIGFkb3B0KHZhbHVlKSB7IHJldHVybiB2YWx1ZSBpbnN0YW5jZW9mIFAgPyB2YWx1ZSA6IG5ldyBQKGZ1bmN0aW9uIChyZXNvbHZlKSB7IHJlc29sdmUodmFsdWUpOyB9KTsgfVxyXG4gICAgcmV0dXJuIG5ldyAoUCB8fCAoUCA9IFByb21pc2UpKShmdW5jdGlvbiAocmVzb2x2ZSwgcmVqZWN0KSB7XHJcbiAgICAgICAgZnVuY3Rpb24gZnVsZmlsbGVkKHZhbHVlKSB7IHRyeSB7IHN0ZXAoZ2VuZXJhdG9yLm5leHQodmFsdWUpKTsgfSBjYXRjaCAoZSkgeyByZWplY3QoZSk7IH0gfVxyXG4gICAgICAgIGZ1bmN0aW9uIHJlamVjdGVkKHZhbHVlKSB7IHRyeSB7IHN0ZXAoZ2VuZXJhdG9yW1widGhyb3dcIl0odmFsdWUpKTsgfSBjYXRjaCAoZSkgeyByZWplY3QoZSk7IH0gfVxyXG4gICAgICAgIGZ1bmN0aW9uIHN0ZXAocmVzdWx0KSB7IHJlc3VsdC5kb25lID8gcmVzb2x2ZShyZXN1bHQudmFsdWUpIDogYWRvcHQocmVzdWx0LnZhbHVlKS50aGVuKGZ1bGZpbGxlZCwgcmVqZWN0ZWQpOyB9XHJcbiAgICAgICAgc3RlcCgoZ2VuZXJhdG9yID0gZ2VuZXJhdG9yLmFwcGx5KHRoaXNBcmcsIF9hcmd1bWVudHMgfHwgW10pKS5uZXh0KCkpO1xyXG4gICAgfSk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX2dlbmVyYXRvcih0aGlzQXJnLCBib2R5KSB7XHJcbiAgICB2YXIgXyA9IHsgbGFiZWw6IDAsIHNlbnQ6IGZ1bmN0aW9uKCkgeyBpZiAodFswXSAmIDEpIHRocm93IHRbMV07IHJldHVybiB0WzFdOyB9LCB0cnlzOiBbXSwgb3BzOiBbXSB9LCBmLCB5LCB0LCBnO1xyXG4gICAgcmV0dXJuIGcgPSB7IG5leHQ6IHZlcmIoMCksIFwidGhyb3dcIjogdmVyYigxKSwgXCJyZXR1cm5cIjogdmVyYigyKSB9LCB0eXBlb2YgU3ltYm9sID09PSBcImZ1bmN0aW9uXCIgJiYgKGdbU3ltYm9sLml0ZXJhdG9yXSA9IGZ1bmN0aW9uKCkgeyByZXR1cm4gdGhpczsgfSksIGc7XHJcbiAgICBmdW5jdGlvbiB2ZXJiKG4pIHsgcmV0dXJuIGZ1bmN0aW9uICh2KSB7IHJldHVybiBzdGVwKFtuLCB2XSk7IH07IH1cclxuICAgIGZ1bmN0aW9uIHN0ZXAob3ApIHtcclxuICAgICAgICBpZiAoZikgdGhyb3cgbmV3IFR5cGVFcnJvcihcIkdlbmVyYXRvciBpcyBhbHJlYWR5IGV4ZWN1dGluZy5cIik7XHJcbiAgICAgICAgd2hpbGUgKF8pIHRyeSB7XHJcbiAgICAgICAgICAgIGlmIChmID0gMSwgeSAmJiAodCA9IG9wWzBdICYgMiA/IHlbXCJyZXR1cm5cIl0gOiBvcFswXSA/IHlbXCJ0aHJvd1wiXSB8fCAoKHQgPSB5W1wicmV0dXJuXCJdKSAmJiB0LmNhbGwoeSksIDApIDogeS5uZXh0KSAmJiAhKHQgPSB0LmNhbGwoeSwgb3BbMV0pKS5kb25lKSByZXR1cm4gdDtcclxuICAgICAgICAgICAgaWYgKHkgPSAwLCB0KSBvcCA9IFtvcFswXSAmIDIsIHQudmFsdWVdO1xyXG4gICAgICAgICAgICBzd2l0Y2ggKG9wWzBdKSB7XHJcbiAgICAgICAgICAgICAgICBjYXNlIDA6IGNhc2UgMTogdCA9IG9wOyBicmVhaztcclxuICAgICAgICAgICAgICAgIGNhc2UgNDogXy5sYWJlbCsrOyByZXR1cm4geyB2YWx1ZTogb3BbMV0sIGRvbmU6IGZhbHNlIH07XHJcbiAgICAgICAgICAgICAgICBjYXNlIDU6IF8ubGFiZWwrKzsgeSA9IG9wWzFdOyBvcCA9IFswXTsgY29udGludWU7XHJcbiAgICAgICAgICAgICAgICBjYXNlIDc6IG9wID0gXy5vcHMucG9wKCk7IF8udHJ5cy5wb3AoKTsgY29udGludWU7XHJcbiAgICAgICAgICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICAgICAgICAgIGlmICghKHQgPSBfLnRyeXMsIHQgPSB0Lmxlbmd0aCA+IDAgJiYgdFt0Lmxlbmd0aCAtIDFdKSAmJiAob3BbMF0gPT09IDYgfHwgb3BbMF0gPT09IDIpKSB7IF8gPSAwOyBjb250aW51ZTsgfVxyXG4gICAgICAgICAgICAgICAgICAgIGlmIChvcFswXSA9PT0gMyAmJiAoIXQgfHwgKG9wWzFdID4gdFswXSAmJiBvcFsxXSA8IHRbM10pKSkgeyBfLmxhYmVsID0gb3BbMV07IGJyZWFrOyB9XHJcbiAgICAgICAgICAgICAgICAgICAgaWYgKG9wWzBdID09PSA2ICYmIF8ubGFiZWwgPCB0WzFdKSB7IF8ubGFiZWwgPSB0WzFdOyB0ID0gb3A7IGJyZWFrOyB9XHJcbiAgICAgICAgICAgICAgICAgICAgaWYgKHQgJiYgXy5sYWJlbCA8IHRbMl0pIHsgXy5sYWJlbCA9IHRbMl07IF8ub3BzLnB1c2gob3ApOyBicmVhazsgfVxyXG4gICAgICAgICAgICAgICAgICAgIGlmICh0WzJdKSBfLm9wcy5wb3AoKTtcclxuICAgICAgICAgICAgICAgICAgICBfLnRyeXMucG9wKCk7IGNvbnRpbnVlO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIG9wID0gYm9keS5jYWxsKHRoaXNBcmcsIF8pO1xyXG4gICAgICAgIH0gY2F0Y2ggKGUpIHsgb3AgPSBbNiwgZV07IHkgPSAwOyB9IGZpbmFsbHkgeyBmID0gdCA9IDA7IH1cclxuICAgICAgICBpZiAob3BbMF0gJiA1KSB0aHJvdyBvcFsxXTsgcmV0dXJuIHsgdmFsdWU6IG9wWzBdID8gb3BbMV0gOiB2b2lkIDAsIGRvbmU6IHRydWUgfTtcclxuICAgIH1cclxufVxyXG5cclxuZXhwb3J0IHZhciBfX2NyZWF0ZUJpbmRpbmcgPSBPYmplY3QuY3JlYXRlID8gKGZ1bmN0aW9uKG8sIG0sIGssIGsyKSB7XHJcbiAgICBpZiAoazIgPT09IHVuZGVmaW5lZCkgazIgPSBrO1xyXG4gICAgdmFyIGRlc2MgPSBPYmplY3QuZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yKG0sIGspO1xyXG4gICAgaWYgKCFkZXNjIHx8IChcImdldFwiIGluIGRlc2MgPyAhbS5fX2VzTW9kdWxlIDogZGVzYy53cml0YWJsZSB8fCBkZXNjLmNvbmZpZ3VyYWJsZSkpIHtcclxuICAgICAgICBkZXNjID0geyBlbnVtZXJhYmxlOiB0cnVlLCBnZXQ6IGZ1bmN0aW9uKCkgeyByZXR1cm4gbVtrXTsgfSB9O1xyXG4gICAgfVxyXG4gICAgT2JqZWN0LmRlZmluZVByb3BlcnR5KG8sIGsyLCBkZXNjKTtcclxufSkgOiAoZnVuY3Rpb24obywgbSwgaywgazIpIHtcclxuICAgIGlmIChrMiA9PT0gdW5kZWZpbmVkKSBrMiA9IGs7XHJcbiAgICBvW2syXSA9IG1ba107XHJcbn0pO1xyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fZXhwb3J0U3RhcihtLCBvKSB7XHJcbiAgICBmb3IgKHZhciBwIGluIG0pIGlmIChwICE9PSBcImRlZmF1bHRcIiAmJiAhT2JqZWN0LnByb3RvdHlwZS5oYXNPd25Qcm9wZXJ0eS5jYWxsKG8sIHApKSBfX2NyZWF0ZUJpbmRpbmcobywgbSwgcCk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX3ZhbHVlcyhvKSB7XHJcbiAgICB2YXIgcyA9IHR5cGVvZiBTeW1ib2wgPT09IFwiZnVuY3Rpb25cIiAmJiBTeW1ib2wuaXRlcmF0b3IsIG0gPSBzICYmIG9bc10sIGkgPSAwO1xyXG4gICAgaWYgKG0pIHJldHVybiBtLmNhbGwobyk7XHJcbiAgICBpZiAobyAmJiB0eXBlb2Ygby5sZW5ndGggPT09IFwibnVtYmVyXCIpIHJldHVybiB7XHJcbiAgICAgICAgbmV4dDogZnVuY3Rpb24gKCkge1xyXG4gICAgICAgICAgICBpZiAobyAmJiBpID49IG8ubGVuZ3RoKSBvID0gdm9pZCAwO1xyXG4gICAgICAgICAgICByZXR1cm4geyB2YWx1ZTogbyAmJiBvW2krK10sIGRvbmU6ICFvIH07XHJcbiAgICAgICAgfVxyXG4gICAgfTtcclxuICAgIHRocm93IG5ldyBUeXBlRXJyb3IocyA/IFwiT2JqZWN0IGlzIG5vdCBpdGVyYWJsZS5cIiA6IFwiU3ltYm9sLml0ZXJhdG9yIGlzIG5vdCBkZWZpbmVkLlwiKTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fcmVhZChvLCBuKSB7XHJcbiAgICB2YXIgbSA9IHR5cGVvZiBTeW1ib2wgPT09IFwiZnVuY3Rpb25cIiAmJiBvW1N5bWJvbC5pdGVyYXRvcl07XHJcbiAgICBpZiAoIW0pIHJldHVybiBvO1xyXG4gICAgdmFyIGkgPSBtLmNhbGwobyksIHIsIGFyID0gW10sIGU7XHJcbiAgICB0cnkge1xyXG4gICAgICAgIHdoaWxlICgobiA9PT0gdm9pZCAwIHx8IG4tLSA+IDApICYmICEociA9IGkubmV4dCgpKS5kb25lKSBhci5wdXNoKHIudmFsdWUpO1xyXG4gICAgfVxyXG4gICAgY2F0Y2ggKGVycm9yKSB7IGUgPSB7IGVycm9yOiBlcnJvciB9OyB9XHJcbiAgICBmaW5hbGx5IHtcclxuICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICBpZiAociAmJiAhci5kb25lICYmIChtID0gaVtcInJldHVyblwiXSkpIG0uY2FsbChpKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgZmluYWxseSB7IGlmIChlKSB0aHJvdyBlLmVycm9yOyB9XHJcbiAgICB9XHJcbiAgICByZXR1cm4gYXI7XHJcbn1cclxuXHJcbi8qKiBAZGVwcmVjYXRlZCAqL1xyXG5leHBvcnQgZnVuY3Rpb24gX19zcHJlYWQoKSB7XHJcbiAgICBmb3IgKHZhciBhciA9IFtdLCBpID0gMDsgaSA8IGFyZ3VtZW50cy5sZW5ndGg7IGkrKylcclxuICAgICAgICBhciA9IGFyLmNvbmNhdChfX3JlYWQoYXJndW1lbnRzW2ldKSk7XHJcbiAgICByZXR1cm4gYXI7XHJcbn1cclxuXHJcbi8qKiBAZGVwcmVjYXRlZCAqL1xyXG5leHBvcnQgZnVuY3Rpb24gX19zcHJlYWRBcnJheXMoKSB7XHJcbiAgICBmb3IgKHZhciBzID0gMCwgaSA9IDAsIGlsID0gYXJndW1lbnRzLmxlbmd0aDsgaSA8IGlsOyBpKyspIHMgKz0gYXJndW1lbnRzW2ldLmxlbmd0aDtcclxuICAgIGZvciAodmFyIHIgPSBBcnJheShzKSwgayA9IDAsIGkgPSAwOyBpIDwgaWw7IGkrKylcclxuICAgICAgICBmb3IgKHZhciBhID0gYXJndW1lbnRzW2ldLCBqID0gMCwgamwgPSBhLmxlbmd0aDsgaiA8IGpsOyBqKyssIGsrKylcclxuICAgICAgICAgICAgcltrXSA9IGFbal07XHJcbiAgICByZXR1cm4gcjtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fc3ByZWFkQXJyYXkodG8sIGZyb20sIHBhY2spIHtcclxuICAgIGlmIChwYWNrIHx8IGFyZ3VtZW50cy5sZW5ndGggPT09IDIpIGZvciAodmFyIGkgPSAwLCBsID0gZnJvbS5sZW5ndGgsIGFyOyBpIDwgbDsgaSsrKSB7XHJcbiAgICAgICAgaWYgKGFyIHx8ICEoaSBpbiBmcm9tKSkge1xyXG4gICAgICAgICAgICBpZiAoIWFyKSBhciA9IEFycmF5LnByb3RvdHlwZS5zbGljZS5jYWxsKGZyb20sIDAsIGkpO1xyXG4gICAgICAgICAgICBhcltpXSA9IGZyb21baV07XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHRvLmNvbmNhdChhciB8fCBBcnJheS5wcm90b3R5cGUuc2xpY2UuY2FsbChmcm9tKSk7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX2F3YWl0KHYpIHtcclxuICAgIHJldHVybiB0aGlzIGluc3RhbmNlb2YgX19hd2FpdCA/ICh0aGlzLnYgPSB2LCB0aGlzKSA6IG5ldyBfX2F3YWl0KHYpO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gX19hc3luY0dlbmVyYXRvcih0aGlzQXJnLCBfYXJndW1lbnRzLCBnZW5lcmF0b3IpIHtcclxuICAgIGlmICghU3ltYm9sLmFzeW5jSXRlcmF0b3IpIHRocm93IG5ldyBUeXBlRXJyb3IoXCJTeW1ib2wuYXN5bmNJdGVyYXRvciBpcyBub3QgZGVmaW5lZC5cIik7XHJcbiAgICB2YXIgZyA9IGdlbmVyYXRvci5hcHBseSh0aGlzQXJnLCBfYXJndW1lbnRzIHx8IFtdKSwgaSwgcSA9IFtdO1xyXG4gICAgcmV0dXJuIGkgPSB7fSwgdmVyYihcIm5leHRcIiksIHZlcmIoXCJ0aHJvd1wiKSwgdmVyYihcInJldHVyblwiKSwgaVtTeW1ib2wuYXN5bmNJdGVyYXRvcl0gPSBmdW5jdGlvbiAoKSB7IHJldHVybiB0aGlzOyB9LCBpO1xyXG4gICAgZnVuY3Rpb24gdmVyYihuKSB7IGlmIChnW25dKSBpW25dID0gZnVuY3Rpb24gKHYpIHsgcmV0dXJuIG5ldyBQcm9taXNlKGZ1bmN0aW9uIChhLCBiKSB7IHEucHVzaChbbiwgdiwgYSwgYl0pID4gMSB8fCByZXN1bWUobiwgdik7IH0pOyB9OyB9XHJcbiAgICBmdW5jdGlvbiByZXN1bWUobiwgdikgeyB0cnkgeyBzdGVwKGdbbl0odikpOyB9IGNhdGNoIChlKSB7IHNldHRsZShxWzBdWzNdLCBlKTsgfSB9XHJcbiAgICBmdW5jdGlvbiBzdGVwKHIpIHsgci52YWx1ZSBpbnN0YW5jZW9mIF9fYXdhaXQgPyBQcm9taXNlLnJlc29sdmUoci52YWx1ZS52KS50aGVuKGZ1bGZpbGwsIHJlamVjdCkgOiBzZXR0bGUocVswXVsyXSwgcik7IH1cclxuICAgIGZ1bmN0aW9uIGZ1bGZpbGwodmFsdWUpIHsgcmVzdW1lKFwibmV4dFwiLCB2YWx1ZSk7IH1cclxuICAgIGZ1bmN0aW9uIHJlamVjdCh2YWx1ZSkgeyByZXN1bWUoXCJ0aHJvd1wiLCB2YWx1ZSk7IH1cclxuICAgIGZ1bmN0aW9uIHNldHRsZShmLCB2KSB7IGlmIChmKHYpLCBxLnNoaWZ0KCksIHEubGVuZ3RoKSByZXN1bWUocVswXVswXSwgcVswXVsxXSk7IH1cclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fYXN5bmNEZWxlZ2F0b3Iobykge1xyXG4gICAgdmFyIGksIHA7XHJcbiAgICByZXR1cm4gaSA9IHt9LCB2ZXJiKFwibmV4dFwiKSwgdmVyYihcInRocm93XCIsIGZ1bmN0aW9uIChlKSB7IHRocm93IGU7IH0pLCB2ZXJiKFwicmV0dXJuXCIpLCBpW1N5bWJvbC5pdGVyYXRvcl0gPSBmdW5jdGlvbiAoKSB7IHJldHVybiB0aGlzOyB9LCBpO1xyXG4gICAgZnVuY3Rpb24gdmVyYihuLCBmKSB7IGlbbl0gPSBvW25dID8gZnVuY3Rpb24gKHYpIHsgcmV0dXJuIChwID0gIXApID8geyB2YWx1ZTogX19hd2FpdChvW25dKHYpKSwgZG9uZTogbiA9PT0gXCJyZXR1cm5cIiB9IDogZiA/IGYodikgOiB2OyB9IDogZjsgfVxyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gX19hc3luY1ZhbHVlcyhvKSB7XHJcbiAgICBpZiAoIVN5bWJvbC5hc3luY0l0ZXJhdG9yKSB0aHJvdyBuZXcgVHlwZUVycm9yKFwiU3ltYm9sLmFzeW5jSXRlcmF0b3IgaXMgbm90IGRlZmluZWQuXCIpO1xyXG4gICAgdmFyIG0gPSBvW1N5bWJvbC5hc3luY0l0ZXJhdG9yXSwgaTtcclxuICAgIHJldHVybiBtID8gbS5jYWxsKG8pIDogKG8gPSB0eXBlb2YgX192YWx1ZXMgPT09IFwiZnVuY3Rpb25cIiA/IF9fdmFsdWVzKG8pIDogb1tTeW1ib2wuaXRlcmF0b3JdKCksIGkgPSB7fSwgdmVyYihcIm5leHRcIiksIHZlcmIoXCJ0aHJvd1wiKSwgdmVyYihcInJldHVyblwiKSwgaVtTeW1ib2wuYXN5bmNJdGVyYXRvcl0gPSBmdW5jdGlvbiAoKSB7IHJldHVybiB0aGlzOyB9LCBpKTtcclxuICAgIGZ1bmN0aW9uIHZlcmIobikgeyBpW25dID0gb1tuXSAmJiBmdW5jdGlvbiAodikgeyByZXR1cm4gbmV3IFByb21pc2UoZnVuY3Rpb24gKHJlc29sdmUsIHJlamVjdCkgeyB2ID0gb1tuXSh2KSwgc2V0dGxlKHJlc29sdmUsIHJlamVjdCwgdi5kb25lLCB2LnZhbHVlKTsgfSk7IH07IH1cclxuICAgIGZ1bmN0aW9uIHNldHRsZShyZXNvbHZlLCByZWplY3QsIGQsIHYpIHsgUHJvbWlzZS5yZXNvbHZlKHYpLnRoZW4oZnVuY3Rpb24odikgeyByZXNvbHZlKHsgdmFsdWU6IHYsIGRvbmU6IGQgfSk7IH0sIHJlamVjdCk7IH1cclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fbWFrZVRlbXBsYXRlT2JqZWN0KGNvb2tlZCwgcmF3KSB7XHJcbiAgICBpZiAoT2JqZWN0LmRlZmluZVByb3BlcnR5KSB7IE9iamVjdC5kZWZpbmVQcm9wZXJ0eShjb29rZWQsIFwicmF3XCIsIHsgdmFsdWU6IHJhdyB9KTsgfSBlbHNlIHsgY29va2VkLnJhdyA9IHJhdzsgfVxyXG4gICAgcmV0dXJuIGNvb2tlZDtcclxufTtcclxuXHJcbnZhciBfX3NldE1vZHVsZURlZmF1bHQgPSBPYmplY3QuY3JlYXRlID8gKGZ1bmN0aW9uKG8sIHYpIHtcclxuICAgIE9iamVjdC5kZWZpbmVQcm9wZXJ0eShvLCBcImRlZmF1bHRcIiwgeyBlbnVtZXJhYmxlOiB0cnVlLCB2YWx1ZTogdiB9KTtcclxufSkgOiBmdW5jdGlvbihvLCB2KSB7XHJcbiAgICBvW1wiZGVmYXVsdFwiXSA9IHY7XHJcbn07XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gX19pbXBvcnRTdGFyKG1vZCkge1xyXG4gICAgaWYgKG1vZCAmJiBtb2QuX19lc01vZHVsZSkgcmV0dXJuIG1vZDtcclxuICAgIHZhciByZXN1bHQgPSB7fTtcclxuICAgIGlmIChtb2QgIT0gbnVsbCkgZm9yICh2YXIgayBpbiBtb2QpIGlmIChrICE9PSBcImRlZmF1bHRcIiAmJiBPYmplY3QucHJvdG90eXBlLmhhc093blByb3BlcnR5LmNhbGwobW9kLCBrKSkgX19jcmVhdGVCaW5kaW5nKHJlc3VsdCwgbW9kLCBrKTtcclxuICAgIF9fc2V0TW9kdWxlRGVmYXVsdChyZXN1bHQsIG1vZCk7XHJcbiAgICByZXR1cm4gcmVzdWx0O1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gX19pbXBvcnREZWZhdWx0KG1vZCkge1xyXG4gICAgcmV0dXJuIChtb2QgJiYgbW9kLl9fZXNNb2R1bGUpID8gbW9kIDogeyBkZWZhdWx0OiBtb2QgfTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fY2xhc3NQcml2YXRlRmllbGRHZXQocmVjZWl2ZXIsIHN0YXRlLCBraW5kLCBmKSB7XHJcbiAgICBpZiAoa2luZCA9PT0gXCJhXCIgJiYgIWYpIHRocm93IG5ldyBUeXBlRXJyb3IoXCJQcml2YXRlIGFjY2Vzc29yIHdhcyBkZWZpbmVkIHdpdGhvdXQgYSBnZXR0ZXJcIik7XHJcbiAgICBpZiAodHlwZW9mIHN0YXRlID09PSBcImZ1bmN0aW9uXCIgPyByZWNlaXZlciAhPT0gc3RhdGUgfHwgIWYgOiAhc3RhdGUuaGFzKHJlY2VpdmVyKSkgdGhyb3cgbmV3IFR5cGVFcnJvcihcIkNhbm5vdCByZWFkIHByaXZhdGUgbWVtYmVyIGZyb20gYW4gb2JqZWN0IHdob3NlIGNsYXNzIGRpZCBub3QgZGVjbGFyZSBpdFwiKTtcclxuICAgIHJldHVybiBraW5kID09PSBcIm1cIiA/IGYgOiBraW5kID09PSBcImFcIiA/IGYuY2FsbChyZWNlaXZlcikgOiBmID8gZi52YWx1ZSA6IHN0YXRlLmdldChyZWNlaXZlcik7XHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfX2NsYXNzUHJpdmF0ZUZpZWxkU2V0KHJlY2VpdmVyLCBzdGF0ZSwgdmFsdWUsIGtpbmQsIGYpIHtcclxuICAgIGlmIChraW5kID09PSBcIm1cIikgdGhyb3cgbmV3IFR5cGVFcnJvcihcIlByaXZhdGUgbWV0aG9kIGlzIG5vdCB3cml0YWJsZVwiKTtcclxuICAgIGlmIChraW5kID09PSBcImFcIiAmJiAhZikgdGhyb3cgbmV3IFR5cGVFcnJvcihcIlByaXZhdGUgYWNjZXNzb3Igd2FzIGRlZmluZWQgd2l0aG91dCBhIHNldHRlclwiKTtcclxuICAgIGlmICh0eXBlb2Ygc3RhdGUgPT09IFwiZnVuY3Rpb25cIiA/IHJlY2VpdmVyICE9PSBzdGF0ZSB8fCAhZiA6ICFzdGF0ZS5oYXMocmVjZWl2ZXIpKSB0aHJvdyBuZXcgVHlwZUVycm9yKFwiQ2Fubm90IHdyaXRlIHByaXZhdGUgbWVtYmVyIHRvIGFuIG9iamVjdCB3aG9zZSBjbGFzcyBkaWQgbm90IGRlY2xhcmUgaXRcIik7XHJcbiAgICByZXR1cm4gKGtpbmQgPT09IFwiYVwiID8gZi5jYWxsKHJlY2VpdmVyLCB2YWx1ZSkgOiBmID8gZi52YWx1ZSA9IHZhbHVlIDogc3RhdGUuc2V0KHJlY2VpdmVyLCB2YWx1ZSkpLCB2YWx1ZTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9fY2xhc3NQcml2YXRlRmllbGRJbihzdGF0ZSwgcmVjZWl2ZXIpIHtcclxuICAgIGlmIChyZWNlaXZlciA9PT0gbnVsbCB8fCAodHlwZW9mIHJlY2VpdmVyICE9PSBcIm9iamVjdFwiICYmIHR5cGVvZiByZWNlaXZlciAhPT0gXCJmdW5jdGlvblwiKSkgdGhyb3cgbmV3IFR5cGVFcnJvcihcIkNhbm5vdCB1c2UgJ2luJyBvcGVyYXRvciBvbiBub24tb2JqZWN0XCIpO1xyXG4gICAgcmV0dXJuIHR5cGVvZiBzdGF0ZSA9PT0gXCJmdW5jdGlvblwiID8gcmVjZWl2ZXIgPT09IHN0YXRlIDogc3RhdGUuaGFzKHJlY2VpdmVyKTtcclxufVxyXG4iLCI8c2NyaXB0IGxhbmc9XCJ0c1wiPlxyXG4gICAgaW1wb3J0IHR5cGUgVGFibGVHZW5lcmF0b3JQbHVnaW4gZnJvbSBcIi4uLy4uL3RhYmxlR2VuZXJhdG9ySW5kZXhcIjtcclxuXHJcbiAgICBleHBvcnQgbGV0IHBsdWdpbjogVGFibGVHZW5lcmF0b3JQbHVnaW47XHJcbiAgICBleHBvcnQgbGV0IHJvd051bTogbnVtYmVyID0gODtcclxuICAgIGV4cG9ydCBsZXQgY29sTnVtOiBudW1iZXIgPSA4O1xyXG4gICAgZXhwb3J0IGxldCBob3ZlclRhYmxlRW5kOiBudW1iZXJbXTtcclxuICAgIGV4cG9ydCBsZXQgaW5zZXJ0VGFibGU6IChzZWxlY3RlZFRhYmxlRW5kOiBudW1iZXJbXSkgPT4gdm9pZDtcclxuXHJcbiAgICBsZXQgZ3JpZCA9IFtyb3dOdW0sIGNvbE51bV07XHJcblxyXG4gICAgJDogY29sID0gYHJlcGVhdCgkeyBncmlkWzFdIH0sIDFmcilgO1xyXG4gICAgJDogcm93ID0gYHJlcGVhdCgkeyBncmlkWzBdIH0sIDFmcilgO1xyXG4gICAgJDogaXNfYWN0aXZlID0gQXJyYXkoZ3JpZFswXSkuZmlsbCgwKS5tYXAoXyA9PiBBcnJheShncmlkWzFdKS5maWxsKGZhbHNlKSk7XHJcblxyXG4gICAgbGV0IHN0YXJ0OiBudW1iZXJbXSA9IFtdO1xyXG4gICAgbGV0IGVuZDogbnVtYmVyW10gPSBbXTtcclxuXHJcbiAgICBmdW5jdGlvbiBob3ZlcihpOiBudW1iZXIsIGo6IG51bWJlcikge1xyXG4gICAgICAgIHN0YXJ0ID0gWzAsIDBdO1xyXG4gICAgICAgIGVuZCA9IFtpLCBqXTtcclxuICAgICAgICBob3ZlclRhYmxlRW5kID0gW2kgKyAxLCBqICsgMV07XHJcbiAgICAgICAgY2hlY2tBY3RpdmUoZW5kKTtcclxuICAgIH1cclxuXHJcbiAgICBmdW5jdGlvbiB1bkhvdmVyKCkge1xyXG4gICAgICAgIHN0YXJ0ID0gZW5kID0gWy0xLCAtMV07XHJcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgICAgICAgIGhvdmVyVGFibGVFbmQgPSBbMCwgMF07XHJcbiAgICAgICAgICAgIGNoZWNrQWN0aXZlKGVuZCk7XHJcbiAgICAgICAgfSwgMTAwMCk7XHJcbiAgICB9XHJcblxyXG4gICAgZnVuY3Rpb24gY2xpY2soaTogbnVtYmVyLCBqOiBudW1iZXIpIHtcclxuICAgICAgICBpZiAoaiA9PT0gMCkgcmV0dXJuO1xyXG4gICAgICAgIGluc2VydFRhYmxlKFtpICsgMSwgaiArIDFdKTtcclxuICAgICAgICBwbHVnaW4uaGlkZVRhYmxlKCk7XHJcbiAgICB9XHJcblxyXG4gICAgZnVuY3Rpb24gaXNJblJhbmdlKFtpLCBqXTogbnVtYmVyW10sIFtpMiwgajJdOiBudW1iZXJbXSkge1xyXG4gICAgICAgIHJldHVybiAoKGkgLSBzdGFydFswXSkgKiAoaSAtIGkyKSA8PSAwKSAmJlxyXG4gICAgICAgICAgICAoKGogLSBzdGFydFsxXSkgKiAoaiAtIGoyKSA8PSAwKVxyXG4gICAgfVxyXG5cclxuICAgIGZ1bmN0aW9uIGNoZWNrQWN0aXZlKGVuZDogbnVtYmVyW10pIHtcclxuICAgICAgICBpc19hY3RpdmUgPSBpc19hY3RpdmUubWFwKFxyXG4gICAgICAgICAgICAoYSwgaSkgPT4gYS5tYXAoKF8sIGopID0+IGlzSW5SYW5nZShbaSwgal0sIGVuZCkpKTtcclxuICAgIH1cclxuPC9zY3JpcHQ+XHJcblxyXG48ZGl2IGNsYXNzPVwidGFibGUtY29udGFpbmVyXCIgc3R5bGU6Z3JpZC10ZW1wbGF0ZS1yb3dzPXtyb3d9IHN0eWxlOmdyaWQtdGVtcGxhdGUtY29sdW1ucz17Y29sfVxyXG4gICAgIG9uOm1vdXNlbGVhdmU9eygpID0+IHVuSG92ZXIoKX0gb246Ymx1cj17KCkgPT4gdW5Ib3ZlcigpfT5cclxuICAgIHsjZWFjaCB7bGVuZ3RoOiBncmlkWzBdfSBhcyBfLCBpIChpKX1cclxuICAgICAgICB7I2VhY2gge2xlbmd0aDogZ3JpZFsxXX0gYXMgXywgaiAoail9XHJcbiAgICAgICAgICAgIDxkaXZcclxuICAgICAgICAgICAgICAgIGNsYXNzPVwidGFibGUtZ2VuZXJhdG9yLWNlbGxcIlxyXG4gICAgICAgICAgICAgICAgY2xhc3M6YWN0aXZlPXtpc19hY3RpdmVbaV1bal19XHJcbiAgICAgICAgICAgICAgICBvbjptb3VzZWVudGVyPXsoKSA9PiBob3ZlcihpLCBqKX1cclxuICAgICAgICAgICAgICAgIG9uOmNsaWNrPXsoKSA9PiBjbGljayhpLCBqKX1cclxuICAgICAgICAgICAgPjwvZGl2PlxyXG4gICAgICAgIHsvZWFjaH1cclxuICAgIHsvZWFjaH1cclxuPC9kaXY+XHJcblxyXG48c3R5bGU+XHJcblxyXG4gICAgLnRhYmxlLWNvbnRhaW5lciB7XHJcbiAgICAgICAgZGlzcGxheTogZ3JpZDtcclxuICAgICAgICBib3JkZXItYm90dG9tOiAycHggZG90dGVkIHZhcigtLWNvbG9yLWJhc2UtNDApO1xyXG4gICAgICAgIGJvcmRlci10b3A6IDJweCBkb3R0ZWQgdmFyKC0tY29sb3ItYmFzZS00MCk7XHJcbiAgICAgICAgcGFkZGluZy10b3A6IHZhcigtLXNpemUtMi0xKTtcclxuICAgICAgICBwYWRkaW5nLWJvdHRvbTogdmFyKC0tc2l6ZS0yLTEpO1xyXG4gICAgICAgIHdpZHRoOiAxMDAlO1xyXG4gICAgICAgIGhlaWdodDogMTUwcHg7XHJcbiAgICAgICAgZ3JpZC1nYXA6IDFweDtcclxuICAgIH1cclxuXHJcbiAgICAudGFibGUtY29udGFpbmVyIGRpdiB7XHJcbiAgICAgICAgYmFja2dyb3VuZDogdmFyKC0tY29sb3ItYmFzZS0wMCk7XHJcbiAgICAgICAgYm9yZGVyLXJhZGl1czogdmFyKC0tcmFkaXVzLXMpO1xyXG4gICAgICAgIGJvcmRlcjogMXB4IHNvbGlkIHZhcigtLWNvbG9yLWJhc2UtNDApO1xyXG4gICAgfVxyXG5cclxuICAgIC50YWJsZS1jb250YWluZXIgLnRhYmxlLWdlbmVyYXRvci1jZWxsIHtcclxuICAgICAgICBoZWlnaHQ6IHZhcigtLXNpemUtNC00KTtcclxuICAgICAgICB3aWR0aDogdmFyKC0tc2l6ZS00LTQpO1xyXG4gICAgfVxyXG5cclxuICAgIGRpdi5hY3RpdmUge1xyXG4gICAgICAgIGJhY2tncm91bmQtY29sb3I6IHZhcigtLWFjdGl2ZS1jb2xvcik7XHJcbiAgICB9XHJcblxyXG48L3N0eWxlPlxyXG4iLCI8c2NyaXB0IGxhbmc9XCJ0c1wiPlxyXG4gICAgaW1wb3J0IFRhYmxlIGZyb20gXCIuL1RhYmxlLnN2ZWx0ZVwiO1xyXG4gICAgaW1wb3J0IHsgTm90aWNlIH0gZnJvbSBcIm9ic2lkaWFuXCI7XHJcbiAgICBpbXBvcnQgdHlwZSBUYWJsZUdlbmVyYXRvclBsdWdpbiBmcm9tIFwiLi4vLi4vdGFibGVHZW5lcmF0b3JJbmRleFwiO1xyXG5cclxuICAgIGV4cG9ydCBsZXQgdGl0bGU6IHN0cmluZztcclxuICAgIGV4cG9ydCBsZXQgcGx1Z2luOiBUYWJsZUdlbmVyYXRvclBsdWdpbjtcclxuICAgIGV4cG9ydCBsZXQgb25JbnNlcnQ6IChzZWxlY3RlZEdyaWQ6IG51bWJlcltdKSA9PiB2b2lkO1xyXG5cclxuICAgIGxldCBob3ZlclRhYmxlRW5kOiBudW1iZXJbXTtcclxuICAgIGxldCBncmlkUm93OiBudW1iZXI7XHJcbiAgICBsZXQgZ3JpZENvbDogbnVtYmVyO1xyXG5cclxuICAgICQ6IGlmIChob3ZlclRhYmxlRW5kKSB7XHJcbiAgICAgICAgc2V0Um93QW5kQ29sKGhvdmVyVGFibGVFbmQpO1xyXG4gICAgfVxyXG5cclxuICAgIGxldCBzZXR0aW5ncyA9IHtcclxuICAgICAgICByb3dOdW06IHBsdWdpbj8uc2V0dGluZ3Mucm93Q291bnQgPz8gOCxcclxuICAgICAgICBjb2xOdW06IHBsdWdpbj8uc2V0dGluZ3MuY29sdW1uQ291bnQgPz8gOCxcclxuICAgIH1cclxuXHJcbiAgICBmdW5jdGlvbiBzZXRSb3dBbmRDb2woZW5kOiBudW1iZXJbXSkge1xyXG4gICAgICAgIGlmIChlbmQubGVuZ3RoID09PSAwKSB7XHJcbiAgICAgICAgICAgIGdyaWRSb3cgPSAwO1xyXG4gICAgICAgICAgICBncmlkQ29sID0gMDtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBpZiAoIShob3ZlclRhYmxlRW5kWzBdID09PSAwICYmIGhvdmVyVGFibGVFbmRbMV0gPT09IDApKSB7XHJcbiAgICAgICAgICAgIGdyaWRSb3cgPSBob3ZlclRhYmxlRW5kWzBdO1xyXG4gICAgICAgICAgICBncmlkQ29sID0gaG92ZXJUYWJsZUVuZFsxXTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcbjwvc2NyaXB0PlxyXG5cclxuPGRpdiBjbGFzcz1cInRhYmxlLWdlbmVyYXRvclwiPlxyXG4gICAgPGRpdiBjbGFzcz1cInRhYmxlLWdlbmVyYXRvci1oZWFkZXJcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwiSDFcIj5cclxuICAgICAgICAgICAge3RpdGxlfVxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxzbG90IG5hbWU9XCJoZWFkZXJDb250cm9sc1wiPjwvc2xvdD5cclxuICAgIDwvZGl2PlxyXG4gICAgPFRhYmxlIHJvd051bT17c2V0dGluZ3Mucm93TnVtfSBjb2xOdW09e3NldHRpbmdzLmNvbE51bX0gaW5zZXJ0VGFibGU9e29uSW5zZXJ0fSB7cGx1Z2lufVxyXG4gICAgICAgICAgIGJpbmQ6aG92ZXJUYWJsZUVuZD17aG92ZXJUYWJsZUVuZH0vPlxyXG4gICAgPGRpdiBjbGFzcz1cImlucHV0LXRhYmxlLWdlbmVyYXRvclwiPlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJpbnB1dC10YWJsZS1nZW5lcmF0b3Itcm93XCI+XHJcbiAgICAgICAgICAgIFJPVzpcclxuICAgICAgICAgICAgPGlucHV0IGNsYXNzPVwicm93LWlucHV0XCIgYmluZDp2YWx1ZT17Z3JpZFJvd30+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cImlucHV0LXRhYmxlLWdlbmVyYXRvci1jb2xcIj5cclxuICAgICAgICAgICAgQ09MOlxyXG4gICAgICAgICAgICA8aW5wdXQgY2xhc3M9XCJjb2wtaW5wdXRcIiBiaW5kOnZhbHVlPXtncmlkQ29sfT5cclxuICAgICAgICA8L2Rpdj5cclxuICAgIDwvZGl2PlxyXG4gICAgPHNsb3QgbmFtZT1cInNpemVDb250cm9sc1wiPjwvc2xvdD5cclxuICAgIDxidXR0b24gb246Y2xpY2s9eygpID0+IHtcclxuICAgICAgICAgICAgaWYoL15cXGQrJC8udGVzdChncmlkUm93LnRvU3RyaW5nKCkpICYmIC9eXFxkKyQvLnRlc3QoZ3JpZENvbC50b1N0cmluZygpKSkge1xyXG4gICAgICAgICAgICAgICAgb25JbnNlcnQoW2dyaWRSb3csIGdyaWRDb2xdKTtcclxuICAgICAgICAgICAgfSBlbHNlIHtcclxuICAgICAgICAgICAgICAgIG5ldyBOb3RpY2UoXCJQbGVhc2UgZW50ZXIgYSB2YWxpZCBudW1iZXJcIik7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9fT5JbnNlcnRcclxuICAgIDwvYnV0dG9uPlxyXG48L2Rpdj5cclxuXHJcbjxzdHlsZT5cclxuICAgIC50YWJsZS1nZW5lcmF0b3Ige1xyXG4gICAgICAgIHBhZGRpbmctbGVmdDogNXB4O1xyXG4gICAgICAgIHBhZGRpbmctcmlnaHQ6IDVweDtcclxuICAgICAgICB3aWR0aDogMjIwcHg7XHJcbiAgICB9XHJcblxyXG4gICAgLnRhYmxlLWdlbmVyYXRvci1oZWFkZXIge1xyXG4gICAgICAgIGRpc3BsYXk6IGZsZXg7XHJcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xyXG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICAgICAgbWFyZ2luLXRvcDogdmFyKC0tc2l6ZS00LTEpO1xyXG4gICAgICAgIG1hcmdpbi1ib3R0b206IHZhcigtLXNpemUtNC0xKTtcclxuICAgIH1cclxuXHJcbiAgICAuaW5wdXQtdGFibGUtZ2VuZXJhdG9yIHtcclxuICAgICAgICBtYXJnaW4tbGVmdDogdmFyKC0tc2l6ZS0yLTIpO1xyXG4gICAgICAgIG1hcmdpbi1yaWdodDogdmFyKC0tc2l6ZS0yLTIpO1xyXG4gICAgICAgIG1hcmdpbi10b3A6IHZhcigtLXNpemUtNC0yKTtcclxuICAgICAgICBtYXJnaW4tYm90dG9tOiB2YXIoLS1zaXplLTQtMik7XHJcbiAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWFyb3VuZDtcclxuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgfVxyXG5cclxuICAgIC5pbnB1dC10YWJsZS1nZW5lcmF0b3Itcm93LCAuaW5wdXQtdGFibGUtZ2VuZXJhdG9yLWNvbCB7XHJcbiAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWFyb3VuZDtcclxuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgfVxyXG5cclxuICAgIGJ1dHRvbiB7XHJcbiAgICAgICAgd2lkdGg6IDgwcHg7XHJcbiAgICAgICAgaGVpZ2h0OiAyMHB4O1xyXG4gICAgICAgIG1hcmdpbjogdmFyKC0tc2l6ZS00LTEpIGF1dG8gdmFyKC0tc2l6ZS00LTIpO1xyXG4gICAgICAgIHBhZGRpbmc6IDBweCAxMHB4O1xyXG4gICAgICAgIHRleHQtYWxpZ246IGNlbnRlcjtcclxuICAgICAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XHJcbiAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgfVxyXG5cclxuICAgIGlucHV0IHtcclxuICAgICAgICB3aWR0aDogNDBweDtcclxuICAgICAgICBoZWlnaHQ6IDE4cHg7XHJcbiAgICAgICAgYm9yZGVyOiAxcHggc29saWQgdmFyKC0tY29sb3ItYmFzZS01MCk7XHJcbiAgICAgICAgbWFyZ2luLWxlZnQ6IHZhcigtLXNpemUtMi0yKTtcclxuICAgICAgICBib3JkZXItcmFkaXVzOiB2YXIoLS1yYWRpdXMtbSk7XHJcbiAgICAgICAgdGV4dC1hbGlnbjogY2VudGVyO1xyXG4gICAgfVxyXG5cclxuICAgIC5IMSB7XHJcbiAgICAgICAgbWFyZ2luLWxlZnQ6IGF1dG87XHJcbiAgICAgICAgbWFyZ2luLXJpZ2h0OiBhdXRvO1xyXG4gICAgICAgIHRleHQtYWxpZ246IGNlbnRlcjtcclxuICAgIH1cclxuPC9zdHlsZT5cclxuIiwiaW1wb3J0IHR5cGUgeyBFZGl0b3IgfSBmcm9tIFwib2JzaWRpYW5cIjtcclxuXHJcbmNvbnN0IGFsaWduTGluZVRleHQgPSAoYWxpZ246IEFsaWduTW9kZSkgPT4ge1xyXG4gICAgc3dpdGNoIChhbGlnbikge1xyXG4gICAgICAgIGNhc2UgXCJsZWZ0XCI6XHJcbiAgICAgICAgICAgIHJldHVybiBcInw6LS0tLS1cIjtcclxuICAgICAgICBjYXNlIFwiY2VudGVyXCI6XHJcbiAgICAgICAgICAgIHJldHVybiBcInw6LS0tLTpcIjtcclxuICAgICAgICBjYXNlIFwicmlnaHRcIjpcclxuICAgICAgICAgICAgcmV0dXJuIFwifC0tLS0tOlwiO1xyXG4gICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgIHJldHVybiBcIlwiO1xyXG4gICAgfVxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgZ2VuZXJhdGVNYXJrZG93blRhYmxlID0gKHNlbGVjdGVkR3JpZDogbnVtYmVyW10sIGFsaWduOiBBbGlnbk1vZGUpID0+IHtcclxuICAgIGxldCB0YWJsZSA9IFwiXCI7XHJcbiAgICBsZXQgc2Vjb25kTGluZSA9IFwiXCI7XHJcbiAgICBsZXQgbm9ybWFsTGluZSA9IFwiXCI7XHJcbiAgICBjb25zdCBhbGlnblRleHQgPSBhbGlnbkxpbmVUZXh0KGFsaWduKTtcclxuICAgIGlmIChzZWxlY3RlZEdyaWQubGVuZ3RoID09PSAwKSByZXR1cm4gdGFibGU7XHJcblxyXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBOdW1iZXIoc2VsZWN0ZWRHcmlkWzFdKTsgaSsrKSB7XHJcbiAgICAgICAgc2Vjb25kTGluZSArPSBhbGlnblRleHQ7XHJcbiAgICB9XHJcbiAgICBmb3IgKGxldCBpID0gMDsgaSA8IE51bWJlcihzZWxlY3RlZEdyaWRbMV0pOyBpKyspIHtcclxuICAgICAgICBub3JtYWxMaW5lICs9IFwifCAgICAgIFwiO1xyXG4gICAgfVxyXG5cclxuICAgIGlmICghc2VsZWN0ZWRHcmlkWzBdKSB7XHJcbiAgICAgICAgdGFibGUgPSBub3JtYWxMaW5lICsgXCJ8XFxuXCIgKyBzZWNvbmRMaW5lICsgXCJ8XFxuXCI7XHJcbiAgICAgICAgcmV0dXJuIHRhYmxlO1xyXG4gICAgfVxyXG4gICAgZm9yIChsZXQgaSA9IDA7IGkgPCBOdW1iZXIoc2VsZWN0ZWRHcmlkWzBdKSArIDE7IGkrKykge1xyXG4gICAgICAgIGlmICghaSkgdGFibGUgPSB0YWJsZSArIG5vcm1hbExpbmUgKyBcInxcXG5cIjtcclxuICAgICAgICBpZiAoaSA9PT0gMSkgdGFibGUgPSB0YWJsZSArIHNlY29uZExpbmUgKyBcInxcXG5cIjtcclxuICAgICAgICBpZiAoaSA+IDEpIHRhYmxlID0gdGFibGUgKyBub3JtYWxMaW5lICsgXCJ8XFxuXCI7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdGFibGUudHJpbSgpO1xyXG59XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tCbGFua0xpbmUoZWRpdG9yOiBFZGl0b3IsIGxpbmU6IG51bWJlcikge1xyXG4gICAgY29uc3QgZ2V0TGluZSA9IGVkaXRvci5nZXRMaW5lKGxpbmUpO1xyXG4gICAgaWYgKGdldExpbmUudHJpbSgpLmxlbmd0aCA+IDApIHJldHVybiBmYWxzZTtcclxuICAgIHJldHVybiB0cnVlO1xyXG59XHJcbiIsIjxzY3JpcHQgbGFuZz1cInRzXCI+XHJcbiAgICBpbXBvcnQgeyBvbk1vdW50LCBjcmVhdGVFdmVudERpc3BhdGNoZXIgfSBmcm9tIFwic3ZlbHRlXCI7XHJcbiAgICBpbXBvcnQgeyBzZXRJY29uIH0gZnJvbSBcIm9ic2lkaWFuXCI7XHJcblxyXG4gICAgZXhwb3J0IGxldCBhbGlnbjogQWxpZ25Nb2RlID0gJ2xlZnQnO1xyXG5cclxuICAgIGNvbnN0IGRpc3BhdGNoID0gY3JlYXRlRXZlbnREaXNwYXRjaGVyKCk7XHJcbiAgICBjb25zdCBhbGlnbm1lbnRzOiBBbGlnbk1vZGVbXSA9IFsnbGVmdCcsICdjZW50ZXInLCAncmlnaHQnXTtcclxuXHJcbiAgICBsZXQgcmVmczogUmVmc09iamVjdCA9IHt9O1xyXG5cclxuICAgIG9uTW91bnQoKCkgPT4ge1xyXG4gICAgICAgIHNldEljb24ocmVmc1snbGVmdCddISwgJ2FsaWduLWxlZnQnKTtcclxuICAgICAgICBzZXRJY29uKHJlZnNbJ2NlbnRlciddISwgJ2FsaWduLWNlbnRlcicpO1xyXG4gICAgICAgIHNldEljb24ocmVmc1sncmlnaHQnXSEsICdhbGlnbi1yaWdodCcpO1xyXG4gICAgfSk7XHJcblxyXG4gICAgZnVuY3Rpb24gY2xpY2sodXBkYXRlOiBBbGlnbk1vZGUpIHtcclxuICAgICAgICBhbGlnbiA9IHVwZGF0ZTtcclxuICAgICAgICBkaXNwYXRjaCgndXBkYXRlJywgYWxpZ24pO1xyXG4gICAgfVxyXG48L3NjcmlwdD5cclxuXHJcbjxkaXYgY2xhc3M9XCJ0YWJsZS1nZW5lcmF0b3ItYWxpZ24tZ3JvdXBcIj5cclxuICAgIHsjZWFjaCBhbGlnbm1lbnRzIGFzIGFsaWdubWVudCAoYWxpZ25tZW50KX1cclxuICAgICAgICA8ZGl2XHJcbiAgICAgICAgICAgIGJpbmQ6dGhpcz17cmVmc1thbGlnbm1lbnRdfVxyXG4gICAgICAgICAgICBjbGFzcz1cInRhYmxlLWdlbmVyYXRvci1hbGlnbi1pY29uXCJcclxuICAgICAgICAgICAgY2xhc3M6YWN0aXZlPXthbGlnbiA9PT0gYWxpZ25tZW50fVxyXG4gICAgICAgICAgICBvbjpjbGljaz17KCkgPT4gY2xpY2soYWxpZ25tZW50KX1cclxuICAgICAgICA+PC9kaXY+XHJcbiAgICB7L2VhY2h9XHJcbjwvZGl2PlxyXG5cclxuPHN0eWxlPlxyXG4gICAgLnRhYmxlLWdlbmVyYXRvci1hbGlnbi1ncm91cCB7XHJcbiAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgICAgIGZsZXgtZGlyZWN0aW9uOiByb3c7XHJcbiAgICAgICAgZ2FwOiB2YXIoLS1zaXplLTItMik7XHJcbiAgICB9XHJcblxyXG4gICAgLnRhYmxlLWdlbmVyYXRvci1hbGlnbi1pY29uIHtcclxuICAgICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICAgICAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XHJcbiAgICAgICAgYm9yZGVyLXJhZGl1czogdmFyKC0tcmFkaXVzLXMpO1xyXG4gICAgICAgIHBhZGRpbmc6IHZhcigtLXNpemUtMi0xKTtcclxuICAgIH1cclxuXHJcbiAgICAudGFibGUtZ2VuZXJhdG9yLWFsaWduLWljb246bm90KC5hY3RpdmUpOmhvdmVyIHtcclxuICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kLW1vZGlmaWVyLWhvdmVyKTtcclxuICAgIH1cclxuXHJcbiAgICAudGFibGUtZ2VuZXJhdG9yLWFsaWduLWljb24uYWN0aXZlIHtcclxuICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiB2YXIoLS1iYWNrZ3JvdW5kLW1vZGlmaWVyLWJvcmRlci1ob3Zlcik7XHJcbiAgICB9XHJcbjwvc3R5bGU+XHJcbiIsIjxzY3JpcHQgbGFuZz1cInRzXCI+XHJcbiAgICBpbXBvcnQgdHlwZSB7IEVkaXRvciB9IGZyb20gXCJvYnNpZGlhblwiO1xyXG4gICAgaW1wb3J0IFRhYmxlR2VuZXJhdG9yQ29tcG9uZW50IGZyb20gXCIuL2Jhc2ljL1RhYmxlR2VuZXJhdG9yQ29tcG9uZW50LnN2ZWx0ZVwiO1xyXG4gICAgaW1wb3J0IHsgY2hlY2tCbGFua0xpbmUsIGdlbmVyYXRlTWFya2Rvd25UYWJsZSB9IGZyb20gXCIuLi91dGlscy9tYXJrZG93blRhYmxlXCI7XHJcbiAgICBpbXBvcnQgdHlwZSBUYWJsZUdlbmVyYXRvclBsdWdpbiBmcm9tIFwiLi4vdGFibGVHZW5lcmF0b3JJbmRleFwiO1xyXG4gICAgaW1wb3J0IEFsaWduSXRlbXMgZnJvbSBcIi4vYmFzaWMvQWxpZ25JdGVtcy5zdmVsdGVcIjtcclxuXHJcbiAgICBleHBvcnQgbGV0IGVkaXRvcjogRWRpdG9yO1xyXG4gICAgZXhwb3J0IGxldCBwbHVnaW46IFRhYmxlR2VuZXJhdG9yUGx1Z2luO1xyXG4gICAgbGV0IGN1cnJlbnRBbGlnbjogQWxpZ25Nb2RlID0gcGx1Z2luPy5zZXR0aW5ncy5kZWZhdWx0QWxpZ25tZW50ID8/ICdsZWZ0JztcclxuXHJcbiAgICBhc3luYyBmdW5jdGlvbiBoYW5kbGVBbGlnbk1vZGVVcGRhdGUoZXZlbnQ6IGFueSkge1xyXG4gICAgICAgIGN1cnJlbnRBbGlnbiA9IGV2ZW50LmRldGFpbDtcclxuICAgICAgICAvLyBAdHMtaWdub3JlXHJcbiAgICAgICAgcGx1Z2luPy5zZXR0aW5ncz8uZGVmYXVsdEFsaWdubWVudCA9IGN1cnJlbnRBbGlnbjtcclxuICAgICAgICBhd2FpdCBwbHVnaW4/LnNhdmVTZXR0aW5ncygpO1xyXG4gICAgfVxyXG5cclxuICAgIGZ1bmN0aW9uIGluc2VydFRhYmxlKHNlbGVjdGVkR3JpZDogbnVtYmVyW10pIHtcclxuICAgICAgICBpZiAoc2VsZWN0ZWRHcmlkLmxlbmd0aCA9PT0gMCB8fCBzZWxlY3RlZEdyaWRbMV0gPCAyKSByZXR1cm47XHJcbiAgICAgICAgY29uc3QgYmFzaWNUYWJsZSA9IGdlbmVyYXRlTWFya2Rvd25UYWJsZShzZWxlY3RlZEdyaWQsIGN1cnJlbnRBbGlnbik7XHJcbiAgICAgICAgbGV0IG1hcmtkb3duVGFibGUgPSBiYXNpY1RhYmxlO1xyXG4gICAgICAgIGNvbnN0IGN1cnNvciA9IGVkaXRvci5nZXRDdXJzb3IoJ2Zyb20nKTtcclxuICAgICAgICBjb25zdCBsaW5lID0gZWRpdG9yLmdldExpbmUoY3Vyc29yLmxpbmUpO1xyXG5cclxuICAgICAgICBpZihjdXJzb3IubGluZSAhPT0gMCAmJiAobGluZS50cmltKCkubGVuZ3RoICE9PSAwKSkge1xyXG4gICAgICAgICAgICBtYXJrZG93blRhYmxlID0gJ1xcbicgKyBtYXJrZG93blRhYmxlO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgaWYgKGN1cnNvci5saW5lICE9PSBlZGl0b3IubGFzdExpbmUoKSAmJiAhY2hlY2tCbGFua0xpbmUoZWRpdG9yLCBjdXJzb3IubGluZSArIDEpKSB7XHJcbiAgICAgICAgICAgIG1hcmtkb3duVGFibGUgPSBtYXJrZG93blRhYmxlICsgJ1xcbic7XHJcbiAgICAgICAgfSBlbHNlIGlmIChjdXJzb3IubGluZSA9PT0gZWRpdG9yLmxhc3RMaW5lKCkpIHtcclxuICAgICAgICAgICAgbWFya2Rvd25UYWJsZSA9ICdcXG4nICsgbWFya2Rvd25UYWJsZTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGlmIChsaW5lLnRyaW0oKS5sZW5ndGggPiAwKSB7XHJcbiAgICAgICAgICAgIGVkaXRvci5yZXBsYWNlUmFuZ2UobWFya2Rvd25UYWJsZSwgeyBsaW5lOiBjdXJzb3IubGluZSArIDEsIGNoOiAwIH0sIHtcclxuICAgICAgICAgICAgICAgIGxpbmU6IGN1cnNvci5saW5lICsgMSxcclxuICAgICAgICAgICAgICAgIGNoOiAwXHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIGVkaXRvci5yZXBsYWNlUmFuZ2UobWFya2Rvd25UYWJsZSwgeyBsaW5lOiBjdXJzb3IubGluZSwgY2g6IDAgfSwgeyBsaW5lOiBjdXJzb3IubGluZSwgY2g6IDAgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuPC9zY3JpcHQ+XHJcblxyXG48VGFibGVHZW5lcmF0b3JDb21wb25lbnQgdGl0bGU9XCJUYWJsZSBHZW5lcmF0b3JcIiB7cGx1Z2lufSBvbkluc2VydD17aW5zZXJ0VGFibGV9PlxyXG4gICAgPEFsaWduSXRlbXMgYWxpZ249e2N1cnJlbnRBbGlnbn0gb246dXBkYXRlPXtoYW5kbGVBbGlnbk1vZGVVcGRhdGV9IHNsb3Q9XCJoZWFkZXJDb250cm9sc1wiIC8+XHJcbjwvVGFibGVHZW5lcmF0b3JDb21wb25lbnQ+XHJcblxyXG48c3R5bGU+PC9zdHlsZT5cclxuIiwiaW1wb3J0IHR5cGUgeyBFZGl0b3IgfSBmcm9tIFwib2JzaWRpYW5cIjtcclxuaW1wb3J0IHsgcmVxdWlyZUFwaVZlcnNpb24gfSBmcm9tIFwib2JzaWRpYW5cIjtcclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBnZXRMaW5lSGVpZ2h0KGVkaXRvcjogRWRpdG9yLCBwb3M6IG51bWJlcikge1xyXG4gICAgY29uc3QgbGluZUluZm8gPSAoZWRpdG9yIGFzIGFueSkuY20uc3RhdGUuZG9jLmxpbmVBdChwb3MpO1xyXG4gICAgY29uc3QgbGluZURPTSA9IChlZGl0b3IgYXMgYW55KS5jbS5kb21BdFBvcyhsaW5lSW5mby5mcm9tKTtcclxuICAgIHJldHVybiAobGluZURPTS5ub2RlIGFzIEhUTUxFbGVtZW50KS5vZmZzZXRIZWlnaHQ7IC8vIOi/meWwhui/lOWbnuihjOeahOmrmOW6plxyXG59XHJcblxyXG5leHBvcnQgY29uc3QgcmFuZG9tID0gKGU6IG51bWJlcikgPT4ge1xyXG4gICAgY29uc3QgdCA9IFtdO1xyXG4gICAgZm9yIChsZXQgbiA9IDA7IG4gPCBlOyBuKyspIHtcclxuICAgICAgICB0LnB1c2goKDE2ICogTWF0aC5yYW5kb20oKSB8IDApLnRvU3RyaW5nKDE2KSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gdC5qb2luKFwiXCIpXHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiByZXZlcnNlQ2FsY3VsYXRpb24objoge1xyXG4gICAgeDogbnVtYmVyO1xyXG4gICAgeTogbnVtYmVyO1xyXG59LCB0OiBhbnkpIHtcclxuICAgIGNvbnN0IHIgPSB0LnNjYWxlO1xyXG4gICAgY29uc3QgY3ggPSB0LmNhbnZhc1JlY3QuY3g7XHJcbiAgICBjb25zdCBjeSA9IHQuY2FudmFzUmVjdC5jeTtcclxuICAgIGNvbnN0IHggPSB0Lng7XHJcbiAgICBjb25zdCB5ID0gdC55O1xyXG5cclxuICAgIGNvbnN0IGVDbGllbnRYID0gKG4ueCAtIHgpICogciArIGN4O1xyXG4gICAgY29uc3QgZUNsaWVudFkgPSAobi55IC0geSkgKiByICsgY3k7XHJcblxyXG4gICAgcmV0dXJuIHtcclxuICAgICAgICBjbGllbnRYOiBlQ2xpZW50WCxcclxuICAgICAgICBjbGllbnRZOiBlQ2xpZW50WVxyXG4gICAgfTtcclxufVxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIGNhbGN1bGF0ZUVkaXRvcihlZGl0b3I6IEVkaXRvciwgdGFibGVHZW5lcmF0b3JCb2FyZDogSFRNTEVsZW1lbnQgfCBudWxsKSB7XHJcbiAgICBpZiAoIXRhYmxlR2VuZXJhdG9yQm9hcmQpIHJldHVybjtcclxuXHJcbiAgICBjb25zdCBjdXJzb3IgPSBlZGl0b3IuZ2V0Q3Vyc29yKCdmcm9tJyk7XHJcbiAgICBsZXQgY29vcmRzOiBDb29yZHM7XHJcblxyXG4gICAgLy8gR2V0IHRoZSBjdXJzb3IgcG9zaXRpb24gdXNpbmcgdGhlIGFwcHJvcHJpYXRlIENNNSBvciBDTTYgaW50ZXJmYWNlXHJcbiAgICBpZiAoKGVkaXRvciBhcyBhbnkpLmN1cnNvckNvb3Jkcykge1xyXG4gICAgICAgIGNvb3JkcyA9IChlZGl0b3IgYXMgYW55KS5jdXJzb3JDb29yZHModHJ1ZSwgJ3dpbmRvdycpO1xyXG4gICAgfSBlbHNlIGlmICgoZWRpdG9yIGFzIGFueSkuY29vcmRzQXRQb3MpIHtcclxuICAgICAgICBjb25zdCBvZmZzZXQgPSBlZGl0b3IucG9zVG9PZmZzZXQoY3Vyc29yKTtcclxuICAgICAgICBjb29yZHMgPSAoZWRpdG9yIGFzIGFueSkuY20uY29vcmRzQXRQb3M/LihvZmZzZXQpID8/IChlZGl0b3IgYXMgYW55KS5jb29yZHNBdFBvcyhvZmZzZXQpO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgICByZXR1cm47XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgbGluZUhlaWdodCA9IGdldExpbmVIZWlnaHQoZWRpdG9yLCBlZGl0b3IucG9zVG9PZmZzZXQoY3Vyc29yKSk7XHJcblxyXG4gICAgY29uc3QgY2FsY3VsYXRlVG9wID0gKHJlcXVpcmVBcGlWZXJzaW9uKFwiMC4xNS4wXCIpID9cclxuICAgICAgICBhY3RpdmVEb2N1bWVudCA6IGRvY3VtZW50KT8uYm9keS5nZXRCb3VuZGluZ0NsaWVudFJlY3QoKS5oZWlnaHQgLSAoY29vcmRzLnRvcCB8fCAwKSAtIChjb29yZHMuaGVpZ2h0IHx8IGxpbmVIZWlnaHQpO1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgICB0b3A6IGNhbGN1bGF0ZVRvcCB8fCAwLFxyXG4gICAgICAgIGxlZnQ6IGNvb3Jkcy5sZWZ0IHx8IDAsXHJcbiAgICAgICAgYm90dG9tOiBjb29yZHMuYm90dG9tIHx8IDAsXHJcbiAgICAgICAgaGVpZ2h0OiBjb29yZHMuaGVpZ2h0IHx8IGxpbmVIZWlnaHRcclxuICAgIH1cclxufVxyXG4iLCJleHBvcnQgZnVuY3Rpb24gYXJvdW5kKG9iaiwgZmFjdG9yaWVzKSB7XG4gICAgY29uc3QgcmVtb3ZlcnMgPSBPYmplY3Qua2V5cyhmYWN0b3JpZXMpLm1hcChrZXkgPT4gYXJvdW5kMShvYmosIGtleSwgZmFjdG9yaWVzW2tleV0pKTtcbiAgICByZXR1cm4gcmVtb3ZlcnMubGVuZ3RoID09PSAxID8gcmVtb3ZlcnNbMF0gOiBmdW5jdGlvbiAoKSB7IHJlbW92ZXJzLmZvckVhY2gociA9PiByKCkpOyB9O1xufVxuZnVuY3Rpb24gYXJvdW5kMShvYmosIG1ldGhvZCwgY3JlYXRlV3JhcHBlcikge1xuICAgIGNvbnN0IG9yaWdpbmFsID0gb2JqW21ldGhvZF0sIGhhZE93biA9IG9iai5oYXNPd25Qcm9wZXJ0eShtZXRob2QpO1xuICAgIGxldCBjdXJyZW50ID0gY3JlYXRlV3JhcHBlcihvcmlnaW5hbCk7XG4gICAgLy8gTGV0IG91ciB3cmFwcGVyIGluaGVyaXQgc3RhdGljIHByb3BzIGZyb20gdGhlIHdyYXBwaW5nIG1ldGhvZCxcbiAgICAvLyBhbmQgdGhlIHdyYXBwaW5nIG1ldGhvZCwgcHJvcHMgZnJvbSB0aGUgb3JpZ2luYWwgbWV0aG9kXG4gICAgaWYgKG9yaWdpbmFsKVxuICAgICAgICBPYmplY3Quc2V0UHJvdG90eXBlT2YoY3VycmVudCwgb3JpZ2luYWwpO1xuICAgIE9iamVjdC5zZXRQcm90b3R5cGVPZih3cmFwcGVyLCBjdXJyZW50KTtcbiAgICBvYmpbbWV0aG9kXSA9IHdyYXBwZXI7XG4gICAgLy8gUmV0dXJuIGEgY2FsbGJhY2sgdG8gYWxsb3cgc2FmZSByZW1vdmFsXG4gICAgcmV0dXJuIHJlbW92ZTtcbiAgICBmdW5jdGlvbiB3cmFwcGVyKC4uLmFyZ3MpIHtcbiAgICAgICAgLy8gSWYgd2UgaGF2ZSBiZWVuIGRlYWN0aXZhdGVkIGFuZCBhcmUgbm8gbG9uZ2VyIHdyYXBwZWQsIHJlbW92ZSBvdXJzZWx2ZXNcbiAgICAgICAgaWYgKGN1cnJlbnQgPT09IG9yaWdpbmFsICYmIG9ialttZXRob2RdID09PSB3cmFwcGVyKVxuICAgICAgICAgICAgcmVtb3ZlKCk7XG4gICAgICAgIHJldHVybiBjdXJyZW50LmFwcGx5KHRoaXMsIGFyZ3MpO1xuICAgIH1cbiAgICBmdW5jdGlvbiByZW1vdmUoKSB7XG4gICAgICAgIC8vIElmIG5vIG90aGVyIHBhdGNoZXMsIGp1c3QgZG8gYSBkaXJlY3QgcmVtb3ZhbFxuICAgICAgICBpZiAob2JqW21ldGhvZF0gPT09IHdyYXBwZXIpIHtcbiAgICAgICAgICAgIGlmIChoYWRPd24pXG4gICAgICAgICAgICAgICAgb2JqW21ldGhvZF0gPSBvcmlnaW5hbDtcbiAgICAgICAgICAgIGVsc2VcbiAgICAgICAgICAgICAgICBkZWxldGUgb2JqW21ldGhvZF07XG4gICAgICAgIH1cbiAgICAgICAgaWYgKGN1cnJlbnQgPT09IG9yaWdpbmFsKVxuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAvLyBFbHNlIHBhc3MgZnV0dXJlIGNhbGxzIHRocm91Z2gsIGFuZCByZW1vdmUgd3JhcHBlciBmcm9tIHRoZSBwcm90b3R5cGUgY2hhaW5cbiAgICAgICAgY3VycmVudCA9IG9yaWdpbmFsO1xuICAgICAgICBPYmplY3Quc2V0UHJvdG90eXBlT2Yod3JhcHBlciwgb3JpZ2luYWwgfHwgRnVuY3Rpb24pO1xuICAgIH1cbn1cbmV4cG9ydCBmdW5jdGlvbiBkZWR1cGUoa2V5LCBvbGRGbiwgbmV3Rm4pIHtcbiAgICBjaGVja1trZXldID0ga2V5O1xuICAgIHJldHVybiBjaGVjaztcbiAgICBmdW5jdGlvbiBjaGVjayguLi5hcmdzKSB7XG4gICAgICAgIHJldHVybiAob2xkRm5ba2V5XSA9PT0ga2V5ID8gb2xkRm4gOiBuZXdGbikuYXBwbHkodGhpcywgYXJncyk7XG4gICAgfVxufVxuZXhwb3J0IGZ1bmN0aW9uIGFmdGVyKHByb21pc2UsIGNiKSB7XG4gICAgcmV0dXJuIHByb21pc2UudGhlbihjYiwgY2IpO1xufVxuZXhwb3J0IGZ1bmN0aW9uIHNlcmlhbGl6ZShhc3luY0Z1bmN0aW9uKSB7XG4gICAgbGV0IGxhc3RSdW4gPSBQcm9taXNlLnJlc29sdmUoKTtcbiAgICBmdW5jdGlvbiB3cmFwcGVyKC4uLmFyZ3MpIHtcbiAgICAgICAgcmV0dXJuIGxhc3RSdW4gPSBuZXcgUHJvbWlzZSgocmVzLCByZWopID0+IHtcbiAgICAgICAgICAgIGFmdGVyKGxhc3RSdW4sICgpID0+IHtcbiAgICAgICAgICAgICAgICBhc3luY0Z1bmN0aW9uLmFwcGx5KHRoaXMsIGFyZ3MpLnRoZW4ocmVzLCByZWopO1xuICAgICAgICAgICAgfSk7XG4gICAgICAgIH0pO1xuICAgIH1cbiAgICB3cmFwcGVyLmFmdGVyID0gZnVuY3Rpb24gKCkge1xuICAgICAgICByZXR1cm4gbGFzdFJ1biA9IG5ldyBQcm9taXNlKChyZXMsIHJlaikgPT4geyBhZnRlcihsYXN0UnVuLCByZXMpOyB9KTtcbiAgICB9O1xuICAgIHJldHVybiB3cmFwcGVyO1xufVxuIiwiPHNjcmlwdCBsYW5nPVwidHNcIj5cclxuICAgIGltcG9ydCB7IGNyZWF0ZUV2ZW50RGlzcGF0Y2hlciB9IGZyb20gJ3N2ZWx0ZSc7XHJcblxyXG4gICAgLy8g5Yib5bu65LiA5Liq5LqL5Lu25YiG5Y+R5ZmoXHJcbiAgICBjb25zdCBkaXNwYXRjaCA9IGNyZWF0ZUV2ZW50RGlzcGF0Y2hlcigpO1xyXG5cclxuICAgIGV4cG9ydCBsZXQgaGVpZ2h0ID0gMTYwO1xyXG4gICAgZXhwb3J0IGxldCB3aWR0aCA9IDE2MDtcclxuXHJcbiAgICAvLyDlvZMgd2lkdGgg5oiWIGhlaWdodCDlj5HnlJ/lj5jljJbml7bvvIzlj5HpgIHmm7TmlrDkuovku7ZcclxuICAgICQ6IGRpc3BhdGNoKCdzaXplVXBkYXRlJywgeyBoZWlnaHQsd2lkdGggIH0pO1xyXG5cclxuPC9zY3JpcHQ+XHJcblxyXG48ZGl2IGNsYXNzPVwiaW5wdXQtdGFibGUtZ2VuZXJhdG9yXCI+XHJcbiAgICA8ZGl2IGNsYXNzPVwiaW5wdXQtdGFibGUtZ2VuZXJhdG9yLWhlaWdodFwiPlxyXG4gICAgICAgIEg6XHJcbiAgICAgICAgPGlucHV0IGNsYXNzPVwiaGVpZ2h0LWlucHV0XCIgYmluZDp2YWx1ZT17aGVpZ2h0fT5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImlucHV0LXRhYmxlLWdlbmVyYXRvci13aWR0aFwiPlxyXG4gICAgICAgIFc6XHJcbiAgICAgICAgPGlucHV0IGNsYXNzPVwid2lkdGgtaW5wdXRcIiBiaW5kOnZhbHVlPXt3aWR0aH0+XHJcbiAgICA8L2Rpdj5cclxuPC9kaXY+XHJcblxyXG48c3R5bGU+XHJcbiAgICAuaW5wdXQtdGFibGUtZ2VuZXJhdG9yIHtcclxuICAgICAgICBtYXJnaW4tbGVmdDogdmFyKC0tc2l6ZS0yLTIpO1xyXG4gICAgICAgIG1hcmdpbi1yaWdodDogdmFyKC0tc2l6ZS0yLTIpO1xyXG4gICAgICAgIG1hcmdpbi10b3A6IHZhcigtLXNpemUtNC0yKTtcclxuICAgICAgICBtYXJnaW4tYm90dG9tOiB2YXIoLS1zaXplLTQtMik7XHJcbiAgICAgICAgZGlzcGxheTogZmxleDtcclxuICAgICAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWFyb3VuZDtcclxuICAgICAgICBhbGlnbi1pdGVtczogY2VudGVyO1xyXG4gICAgfVxyXG5cclxuICAgIC5pbnB1dC10YWJsZS1nZW5lcmF0b3Itd2lkdGgsIC5pbnB1dC10YWJsZS1nZW5lcmF0b3ItaGVpZ2h0IHtcclxuICAgICAgICBkaXNwbGF5OiBmbGV4O1xyXG4gICAgICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYXJvdW5kO1xyXG4gICAgICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XHJcbiAgICB9XHJcblxyXG4gICAgaW5wdXQge1xyXG4gICAgICAgIHdpZHRoOiA3MHB4O1xyXG4gICAgICAgIGhlaWdodDogMThweDtcclxuICAgICAgICBib3JkZXI6IDFweCBzb2xpZCB2YXIoLS1jb2xvci1iYXNlLTUwKTtcclxuICAgICAgICBtYXJnaW4tbGVmdDogdmFyKC0tc2l6ZS0yLTIpO1xyXG4gICAgICAgIGJvcmRlci1yYWRpdXM6IHZhcigtLXJhZGl1cy1tKTtcclxuICAgICAgICB0ZXh0LWFsaWduOiBjZW50ZXI7XHJcbiAgICB9XHJcbjwvc3R5bGU+XHJcbiIsIjxzY3JpcHQgbGFuZz1cInRzXCI+XHJcbiAgICBpbXBvcnQgdHlwZSBUYWJsZUdlbmVyYXRvclBsdWdpbiBmcm9tIFwiLi4vdGFibGVHZW5lcmF0b3JJbmRleFwiO1xyXG4gICAgaW1wb3J0IHsgcmFuZG9tIH0gZnJvbSBcIi4uL3V0aWxzL3RhYmxlUE9TXCI7XHJcbiAgICBpbXBvcnQgVGFibGVHZW5lcmF0b3JDb21wb25lbnQgZnJvbSBcIi4vYmFzaWMvVGFibGVHZW5lcmF0b3JDb21wb25lbnQuc3ZlbHRlXCI7XHJcbiAgICBpbXBvcnQgU2l6ZUNvbnRyb2xzIGZyb20gXCIuL2Jhc2ljL1NpemVDb250cm9scy5zdmVsdGVcIjtcclxuXHJcbiAgICBleHBvcnQgbGV0IGNhbnZhczogYW55O1xyXG4gICAgZXhwb3J0IGxldCBjb29yZHM6IHtcclxuICAgICAgICB4OiBudW1iZXI7XHJcbiAgICAgICAgeTogbnVtYmVyO1xyXG4gICAgfTtcclxuICAgIGV4cG9ydCBsZXQgcGx1Z2luOiBUYWJsZUdlbmVyYXRvclBsdWdpbjtcclxuXHJcbiAgICBsZXQgd2lkdGggPSBwbHVnaW4uc2V0dGluZ3MuZGVmYXVsdENhcmRXaWR0aCB8fCAxNjA7XHJcbiAgICBsZXQgaGVpZ2h0ID0gcGx1Z2luLnNldHRpbmdzLmRlZmF1bHRDYXJkSGVpZ2h0IHx8IDE2MDtcclxuXHJcbiAgICBmdW5jdGlvbiBoYW5kbGVTaXplVXBkYXRlKGV2ZW50OiBhbnkpIHtcclxuICAgICAgICBoZWlnaHQgPSBwYXJzZUludChldmVudC5kZXRhaWwuaGVpZ2h0LDEwKTtcclxuICAgICAgICB3aWR0aCA9IHBhcnNlSW50KGV2ZW50LmRldGFpbC53aWR0aCwxMCk7XHJcblxyXG4gICAgICAgIHBsdWdpbi5zZXR0aW5ncy5kZWZhdWx0Q2FyZEhlaWdodCA9IGhlaWdodDtcclxuICAgICAgICBwbHVnaW4uc2V0dGluZ3MuZGVmYXVsdENhcmRXaWR0aCA9IHdpZHRoO1xyXG4gICAgICAgIHBsdWdpbi5zYXZlU2V0dGluZ3MoKTtcclxuICAgIH1cclxuXHJcbiAgICBhc3luYyBmdW5jdGlvbiBpbnNlcnRUYWJsZShzZWxlY3RlZEdyaWQ6IG51bWJlcltdKSB7XHJcbiAgICAgICAgaWYgKHNlbGVjdGVkR3JpZC5sZW5ndGggPT09IDAgfHwgc2VsZWN0ZWRHcmlkWzFdIDwgMikgcmV0dXJuO1xyXG4gICAgICAgIGNvbnN0IGNhbnZhc0ZpbGUgPSBhd2FpdCBwbHVnaW4uYXBwLnZhdWx0LmNhY2hlZFJlYWQoY2FudmFzLnZpZXcuZmlsZSk7XHJcbiAgICAgICAgY29uc3QgY2FudmFzRmlsZURhdGEgPSBKU09OLnBhcnNlKGNhbnZhc0ZpbGUpO1xyXG4gICAgICAgIGNvbnNvbGUubG9nKHNlbGVjdGVkR3JpZCk7XHJcbiAgICAgICAgZm9yIChsZXQgaSA9IDA7IGkgPCBzZWxlY3RlZEdyaWRbMF07IGkrKykge1xyXG4gICAgICAgICAgICBmb3IgKGxldCBqID0gMDsgaiA8IHNlbGVjdGVkR3JpZFsxXTsgaisrKSB7XHJcbiAgICAgICAgICAgICAgICBjYW52YXNGaWxlRGF0YS5ub2Rlcy5wdXNoKHtcclxuICAgICAgICAgICAgICAgICAgICBpZDogcmFuZG9tKDE2KSxcclxuICAgICAgICAgICAgICAgICAgICB4OiBjb29yZHMueCArIGogKiAod2lkdGggKyAxMCkgKyA0MCxcclxuICAgICAgICAgICAgICAgICAgICB5OiBjb29yZHMueSArIGkgKiAoaGVpZ2h0ICsgMTApICsgNDAsXHJcbiAgICAgICAgICAgICAgICAgICAgd2lkdGg6IHdpZHRoLFxyXG4gICAgICAgICAgICAgICAgICAgIGhlaWdodDogaGVpZ2h0LFxyXG4gICAgICAgICAgICAgICAgICAgIHR5cGU6IFwidGV4dFwiLFxyXG4gICAgICAgICAgICAgICAgICAgIHRleHQ6IFwiXCIsXHJcbiAgICAgICAgICAgICAgICB9KVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGNvbnNvbGUubG9nKGNhbnZhc0ZpbGVEYXRhKTtcclxuICAgICAgICBzZXRUaW1lb3V0KCgpID0+IHtcclxuICAgICAgICAgICAgY2FudmFzLnNldERhdGEoY2FudmFzRmlsZURhdGEpO1xyXG4gICAgICAgICAgICBjYW52YXMucmVxdWVzdFNhdmUoKTtcclxuICAgICAgICB9LCAxMDApO1xyXG4gICAgfVxyXG5cclxuPC9zY3JpcHQ+XHJcblxyXG48VGFibGVHZW5lcmF0b3JDb21wb25lbnQgdGl0bGU9XCJDYXJkIEdlbmVyYXRvclwiIHtwbHVnaW59IG9uSW5zZXJ0PXtpbnNlcnRUYWJsZX0+XHJcbiAgICA8U2l6ZUNvbnRyb2xzIHNsb3Q9XCJzaXplQ29udHJvbHNcIiB3aWR0aD17d2lkdGh9IGhlaWdodD17aGVpZ2h0fSBvbjpzaXplVXBkYXRlPXtoYW5kbGVTaXplVXBkYXRlfT48L1NpemVDb250cm9scz5cclxuPC9UYWJsZUdlbmVyYXRvckNvbXBvbmVudD5cclxuXHJcbjxzdHlsZT48L3N0eWxlPlxyXG4iLCJleHBvcnQgZnVuY3Rpb24gc2V0VGFibGVHZW5lcmF0b3JNZW51UG9zaXRpb24odGFibGVHZW5lcmF0b3JCb2FyZDogSFRNTEVsZW1lbnQgfCBudWxsLCBjb29yZHM6IENvb3JkcywgZGlzcGxheU1vZGU6IFwiY2FudmFzXCIgfCBcImVkaXRvclwiKSB7XHJcbiAgICBpZighdGFibGVHZW5lcmF0b3JCb2FyZCkgcmV0dXJuO1xyXG5cclxuICAgIHNldFRpbWVvdXQoKCk9PntcclxuICAgICAgICB0YWJsZUdlbmVyYXRvckJvYXJkLnN0eWxlLmRpc3BsYXkgPSAnYmxvY2snO1xyXG4gICAgICAgIHN3aXRjaCAoZGlzcGxheU1vZGUpIHtcclxuICAgICAgICAgICAgY2FzZSBcImNhbnZhc1wiOlxyXG4gICAgICAgICAgICAgICAgdGFibGVHZW5lcmF0b3JCb2FyZC5zdHlsZS50b3AgPSBgJHtjb29yZHMudG9wfXB4YDtcclxuICAgICAgICAgICAgICAgIHRhYmxlR2VuZXJhdG9yQm9hcmQuc3R5bGUubGVmdCA9IGAke2Nvb3Jkcy5sZWZ0fXB4YDtcclxuICAgICAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgICAgICBjYXNlIFwiZWRpdG9yXCI6XHJcbiAgICAgICAgICAgICAgICB0YWJsZUdlbmVyYXRvckJvYXJkLnN0eWxlLnRyYW5zZm9ybSA9IGB0cmFuc2xhdGUoJHtjb29yZHMubGVmdH1weCwtJHtjb29yZHMudG9wfXB4YDtcclxuICAgICAgICAgICAgICAgIGJyZWFrO1xyXG4gICAgICAgIH1cclxuICAgIH0pXHJcbn1cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBoYW5kbGVIaWRlVGFibGVHZW5lcmF0b3JNZW51KGV2dDogTW91c2VFdmVudCwgdGFibGVHZW5lcmF0b3JFbDogSFRNTEVsZW1lbnQgfCBudWxsKSB7XHJcbiAgICBjb25zdCB0YXJnZXQgPSBldnQudGFyZ2V0IGFzIEhUTUxFbGVtZW50O1xyXG5cclxuICAgIGlmICghdGFibGVHZW5lcmF0b3JFbCB8fCAhdGFyZ2V0KSByZXR1cm47XHJcbiAgICBpZiAodGFyZ2V0LmNsYXNzTGlzdC5jb250YWlucyhcInRhYmxlLWdlbmVyYXRvci1tZW51XCIpIHx8XHJcbiAgICAgICAgdGFyZ2V0LnBhcmVudEVsZW1lbnQ/LmNsYXNzTGlzdC5jb250YWlucyhcInRhYmxlLWdlbmVyYXRvci1tZW51XCIpIHx8XHJcbiAgICAgICAgdGFyZ2V0LnRhZ05hbWUgPT0gXCJCVVRUT05cIikgcmV0dXJuO1xyXG4gICAgaWYgKHRhYmxlR2VuZXJhdG9yRWw/LmNvbnRhaW5zKHRhcmdldCkpIHJldHVybjtcclxuICAgIGlmICghZG9jdW1lbnQuYm9keS5jb250YWlucyh0YWJsZUdlbmVyYXRvckVsKSkgcmV0dXJuO1xyXG5cclxuICAgIHRhYmxlR2VuZXJhdG9yRWwuZGV0YWNoKCk7XHJcbn1cclxuIiwiaW1wb3J0IHtcclxuICAgIEFwcCxcclxuICAgIEVkaXRvcixcclxuICAgIE1hcmtkb3duVmlldyxcclxuICAgIE1lbnUsXHJcbiAgICBNZW51SXRlbSxcclxuICAgIFBsdWdpbixcclxuICAgIFBsdWdpblNldHRpbmdUYWIsXHJcbiAgICByZXF1aXJlQXBpVmVyc2lvbixcclxuICAgIFNldHRpbmdcclxufSBmcm9tICdvYnNpZGlhbic7XHJcbmltcG9ydCBUYWJsZUdlbmVyYXRvciBmcm9tIFwiLi91aS9UYWJsZUdlbmVyYXRvci5zdmVsdGVcIjtcclxuaW1wb3J0IFwiLi9jc3MvdGFibGVHZW5lcmF0b3JEZWZhdWx0LmNzc1wiO1xyXG5pbXBvcnQgeyBjYWxjdWxhdGVFZGl0b3IsIHJldmVyc2VDYWxjdWxhdGlvbiB9IGZyb20gXCIuL3V0aWxzL3RhYmxlUE9TXCI7XHJcbmltcG9ydCB7IGFyb3VuZCB9IGZyb20gXCJtb25rZXktYXJvdW5kXCI7XHJcbmltcG9ydCBDYXJkR2VuZXJhdG9yIGZyb20gXCIuL3VpL0NhcmRHZW5lcmF0b3Iuc3ZlbHRlXCI7XHJcbmltcG9ydCB7IGhhbmRsZUhpZGVUYWJsZUdlbmVyYXRvck1lbnUsIHNldFRhYmxlR2VuZXJhdG9yTWVudVBvc2l0aW9uIH0gZnJvbSBcIi4vdXRpbHMvdGFibGVET01cIjtcclxuXHJcbmludGVyZmFjZSBUYWJsZUdlbmVyYXRvclBsdWdpblNldHRpbmdzIHtcclxuICAgIHJvd0NvdW50OiBudW1iZXI7XHJcbiAgICBjb2x1bW5Db3VudDogbnVtYmVyO1xyXG4gICAgZGVmYXVsdEFsaWdubWVudDogQWxpZ25Nb2RlO1xyXG4gICAgZGVmYXVsdENhcmRXaWR0aDogbnVtYmVyO1xyXG4gICAgZGVmYXVsdENhcmRIZWlnaHQ6IG51bWJlcjtcclxufVxyXG5cclxuXHJcblxyXG5jb25zdCBERUZBVUxUX1NFVFRJTkdTOiBUYWJsZUdlbmVyYXRvclBsdWdpblNldHRpbmdzID0ge1xyXG4gICAgcm93Q291bnQ6IDgsXHJcbiAgICBjb2x1bW5Db3VudDogOCxcclxuICAgIGRlZmF1bHRBbGlnbm1lbnQ6IFwibGVmdFwiLFxyXG4gICAgZGVmYXVsdENhcmRXaWR0aDogMTYwLFxyXG4gICAgZGVmYXVsdENhcmRIZWlnaHQ6IDE2MCxcclxufVxyXG5cclxuZXhwb3J0IGRlZmF1bHQgY2xhc3MgVGFibGVHZW5lcmF0b3JQbHVnaW4gZXh0ZW5kcyBQbHVnaW4ge1xyXG4gICAgdGFibGVHZW5lcmF0b3JFbDogSFRNTEVsZW1lbnQgfCBudWxsID0gbnVsbDtcclxuICAgIHRhYmxlR2VuZXJhdG9yQ29tcG9uZW50OiBUYWJsZUdlbmVyYXRvcjtcclxuICAgIHNldHRpbmdzOiBUYWJsZUdlbmVyYXRvclBsdWdpblNldHRpbmdzO1xyXG5cclxuICAgIGFzeW5jIG9ubG9hZCgpIHtcclxuICAgICAgICB0aGlzLnJlZ2lzdGVyRXZlbnQoXHJcbiAgICAgICAgICAgIHRoaXMuYXBwLndvcmtzcGFjZS5vbihcImVkaXRvci1tZW51XCIsIChtZW51OiBNZW51LCBlZGl0b3I6IEVkaXRvciwgdmlldzogTWFya2Rvd25WaWV3KSA9PiB0aGlzLmhhbmRsZUNyZWF0ZVRhYmxlR2VuZXJhdG9ySW5NZW51KG1lbnUsIGVkaXRvciwgdmlldykpXHJcbiAgICAgICAgKTtcclxuXHJcbiAgICAgICAgYXdhaXQgdGhpcy5yZWdpc3RlclNldHRpbmdzKCk7XHJcbiAgICAgICAgdGhpcy5yZWdpc3RlckRvbUV2ZW50KHdpbmRvdywgJ2NsaWNrJywgKGV2dDogTW91c2VFdmVudCkgPT4gaGFuZGxlSGlkZVRhYmxlR2VuZXJhdG9yTWVudShldnQsIHRoaXMudGFibGVHZW5lcmF0b3JFbCkpO1xyXG4gICAgICAgIC8vIEhhbmRsZSBzYW1lIG1vdXNlZXZlbnQgaW4gbXVsdGkgd2luZG93cyB3aGVuIHVzZWQgaW4gbmV3ZXIgdmVyc2lvbiBsaWtlIDAuMTUuMFxyXG4gICAgICAgIGlmIChyZXF1aXJlQXBpVmVyc2lvbihcIjAuMTUuMFwiKSkgdGhpcy5yZWdpc3RlclRhYmxlR2VuZXJhdG9yTWVudSgpO1xyXG5cclxuICAgICAgICB0aGlzLnJlZ2lzdGVyQ29tbWFuZHMoKTtcclxuICAgICAgICB0aGlzLnJlZ2lzdGVyQ2FudmFzTWVudSgpO1xyXG4gICAgfVxyXG5cclxuICAgIGhpZGVUYWJsZSgpIHtcclxuICAgICAgICB0aGlzLnRhYmxlR2VuZXJhdG9yRWw/LmRldGFjaCgpO1xyXG4gICAgfVxyXG5cclxuICAgIGhhbmRsZUNyZWF0ZVRhYmxlR2VuZXJhdG9ySW5NZW51KG1lbnU6IE1lbnUsIGVkaXRvcjogRWRpdG9yLCB2aWV3OiBNYXJrZG93blZpZXcpIHtcclxuICAgICAgICBtZW51LmFkZEl0ZW0oKGl0ZW0pID0+IHtcclxuICAgICAgICAgICAgY29uc3QgaXRlbURvbSA9IChpdGVtIGFzIGFueSkuZG9tIGFzIEhUTUxFbGVtZW50O1xyXG4gICAgICAgICAgICBpdGVtRG9tLmFkZENsYXNzKFwidGFibGUtZ2VuZXJhdG9yLW1lbnVcIik7XHJcbiAgICAgICAgICAgIGl0ZW1cclxuICAgICAgICAgICAgICAgIC5zZXRUaXRsZShcIkFkZCBNYXJrZG93biBUYWJsZVwiKVxyXG4gICAgICAgICAgICAgICAgLnNldEljb24oXCJ0YWJsZVwiKVxyXG4gICAgICAgICAgICAgICAgLnNldFNlY3Rpb24oXCJhY3Rpb25cIilcclxuICAgICAgICAgICAgICAgIC5vbkNsaWNrKGFzeW5jICgpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICB0aGlzLmNyZWF0ZUdlbmVyYXRvck1lbnUoXCJ0YWJsZVwiLCB7IGVkaXRvcjogZWRpdG9yIH0sIHRoaXMpO1xyXG4gICAgICAgICAgICAgICAgICAgIGNvbnN0IGNvb3JkcyA9IGNhbGN1bGF0ZUVkaXRvcihlZGl0b3IsIHRoaXMudGFibGVHZW5lcmF0b3JFbCk7XHJcbiAgICAgICAgICAgICAgICAgICAgaWYoIWNvb3JkcykgcmV0dXJuO1xyXG4gICAgICAgICAgICAgICAgICAgIHNldFRhYmxlR2VuZXJhdG9yTWVudVBvc2l0aW9uKHRoaXMudGFibGVHZW5lcmF0b3JFbCwgY29vcmRzLCBcImVkaXRvclwiKTtcclxuICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIGNyZWF0ZUdlbmVyYXRvck1lbnUoXHJcbiAgICAgICAgdHlwZTogXCJ0YWJsZVwiIHwgXCJjYXJkXCIsXHJcbiAgICAgICAgY29udGV4dDogeyBlZGl0b3I/OiBFZGl0b3IsIGNhbnZhcz86IGFueSwgY29vcmRzPzogeyB4OiBudW1iZXIsIHk6IG51bWJlciB9IH0sXHJcbiAgICAgICAgcGx1Z2luOiBUYWJsZUdlbmVyYXRvclBsdWdpblxyXG4gICAgKSB7XHJcbiAgICAgICAgLy8gQ2hlY2sgaWYgdGhpcyB0YWJsZUdlbmVyYXRvckVsIGlzIGFscmVhZHkgY3JlYXRlZCwgaWYgc28gZGVsZXRlIGl0O1xyXG4gICAgICAgIC8vIFVzZWQgZm9yIE11bHRpIHBvcG91dCB3aW5kb3dzLlxyXG4gICAgICAgIGlmICh0aGlzLnRhYmxlR2VuZXJhdG9yRWwpIHRoaXMudGFibGVHZW5lcmF0b3JFbC5kZXRhY2goKTtcclxuXHJcbiAgICAgICAgdGhpcy50YWJsZUdlbmVyYXRvckVsID0gKHJlcXVpcmVBcGlWZXJzaW9uKFwiMC4xNS4wXCIpID8gYWN0aXZlRG9jdW1lbnQgOiBkb2N1bWVudCk/LmJvZHkuY3JlYXRlRWwoXCJkaXZcIiwgeyBjbHM6IFwidGFibGUtZ2VuZXJhdG9yLXZpZXdcIiB9KTtcclxuICAgICAgICB0aGlzLnRhYmxlR2VuZXJhdG9yRWwuaGlkZSgpO1xyXG5cclxuICAgICAgICBpZiAodHlwZSA9PT0gXCJ0YWJsZVwiKSB7XHJcbiAgICAgICAgICAgIHRoaXMudGFibGVHZW5lcmF0b3JDb21wb25lbnQgPSBuZXcgVGFibGVHZW5lcmF0b3Ioe1xyXG4gICAgICAgICAgICAgICAgdGFyZ2V0OiB0aGlzLnRhYmxlR2VuZXJhdG9yRWwsXHJcbiAgICAgICAgICAgICAgICBwcm9wczogeyBlZGl0b3I6IGNvbnRleHQuZWRpdG9yLCBwbHVnaW46IHBsdWdpbiB9XHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH0gZWxzZSBpZiAodHlwZSA9PT0gXCJjYXJkXCIpIHtcclxuICAgICAgICAgICAgdGhpcy50YWJsZUdlbmVyYXRvckNvbXBvbmVudCA9IG5ldyBDYXJkR2VuZXJhdG9yKHtcclxuICAgICAgICAgICAgICAgIHRhcmdldDogdGhpcy50YWJsZUdlbmVyYXRvckVsLFxyXG4gICAgICAgICAgICAgICAgcHJvcHM6IHsgY2FudmFzOiBjb250ZXh0LmNhbnZhcywgY29vcmRzOiBjb250ZXh0LmNvb3JkcywgcGx1Z2luOiBwbHVnaW4gfVxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuXHJcbiAgICBhc3luYyByZWdpc3RlclNldHRpbmdzKCkge1xyXG4gICAgICAgIGF3YWl0IHRoaXMubG9hZFNldHRpbmdzKCk7XHJcbiAgICAgICAgdGhpcy5hZGRTZXR0aW5nVGFiKG5ldyBUYWJsZUdlbmVyYXRvclNldHRpbmdUYWIodGhpcy5hcHAsIHRoaXMpKTtcclxuICAgICAgICB0aGlzLnJlZ2lzdGVySW50ZXJ2YWwod2luZG93LnNldFRpbWVvdXQoKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5zYXZlU2V0dGluZ3MoKTtcclxuICAgICAgICAgICAgfSwgMTAwKVxyXG4gICAgICAgICk7XHJcbiAgICB9XHJcblxyXG4gICAgcmVnaXN0ZXJDYW52YXNNZW51KCkge1xyXG4gICAgICAgIGNvbnN0IGNyZWF0ZUNhcmRUYWJsZSA9IChjYW52YXM6IGFueSwgZTogTWVudSwgdDoge1xyXG4gICAgICAgICAgICB4OiBudW1iZXI7XHJcbiAgICAgICAgICAgIHk6IG51bWJlcjtcclxuICAgICAgICB9LCBhOiBhbnkpID0+IHtcclxuICAgICAgICAgICAgY29uc3QgeyB0b3AsIGxlZnQgfSA9IGUuZG9tLmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xyXG4gICAgICAgICAgICBjb25zdCBkYXRhID0gcmV2ZXJzZUNhbGN1bGF0aW9uKHQsIGNhbnZhcyk7XHJcbiAgICAgICAgICAgIGNvbnNvbGUubG9nKGRhdGEpO1xyXG4gICAgICAgICAgICBzZXRUaW1lb3V0KCgpPT57XHJcbiAgICAgICAgICAgICAgICB0aGlzLmNyZWF0ZUdlbmVyYXRvck1lbnUoXCJjYXJkXCIsIHsgY2FudmFzOiBjYW52YXMsIGNvb3JkczogdCB9LCB0aGlzKTtcclxuICAgICAgICAgICAgICAgIHNldFRhYmxlR2VuZXJhdG9yTWVudVBvc2l0aW9uKHRoaXMudGFibGVHZW5lcmF0b3JFbCwgeyB0b3A6IHRvcCAsIGxlZnQ6IGxlZnQsIGJvdHRvbTogMCwgaGVpZ2h0OiAwIH0sIFwiY2FudmFzXCIpO1xyXG4gICAgICAgICAgICB9LCAwKTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGNvbnN0IHBhdGNoTm9kZSA9ICgpID0+IHtcclxuICAgICAgICAgICAgY29uc3QgY2FudmFzVmlldyA9IHRoaXMuYXBwLndvcmtzcGFjZS5nZXRMZWF2ZXNPZlR5cGUoXCJjYW52YXNcIikuZmlyc3QoKT8udmlldztcclxuICAgICAgICAgICAgLy8gQHRzLWlnbm9yZVxyXG4gICAgICAgICAgICBjb25zdCBjYW52YXMgPSBjYW52YXNWaWV3Py5jYW52YXM7XHJcbiAgICAgICAgICAgIGlmKCFjYW52YXMpIHJldHVybiBmYWxzZTtcclxuXHJcbiAgICAgICAgICAgIGNvbnN0IHVuaW5zdGFsbGVyID0gYXJvdW5kKGNhbnZhcy5jb25zdHJ1Y3Rvci5wcm90b3R5cGUsIHtcclxuICAgICAgICAgICAgICAgIHNob3dDcmVhdGlvbk1lbnU6IChuZXh0OiBhbnkpID0+XHJcbiAgICAgICAgICAgICAgICAgICAgZnVuY3Rpb24gKGU6IE1lbnUsIHQ6YW55LCBhOmFueSkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zdCByZXN1bHQgPSBuZXh0LmNhbGwodGhpcywgZSwgdCwgYSk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGUuYWRkU2VwYXJhdG9yKCkuYWRkSXRlbSgoaXRlbTogTWVudUl0ZW0pID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgIGl0ZW0uc2V0U2VjdGlvbihcImNyZWF0ZVwiKVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC5zZXRUaXRsZShcIkFkZCBDYXJkIFRhYmxlXCIpXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgLnNldEljb24oXCJ0YWJsZVwiKVxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC5vbkNsaWNrKGFzeW5jICgpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY3JlYXRlQ2FyZFRhYmxlKHRoaXMsIGUsIHQsIGEpO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB9KTtcclxuICAgICAgICAgICAgICAgICAgICAgICAgcmV0dXJuIHJlc3VsdDtcclxuXHJcbiAgICAgICAgICAgICAgICAgICAgfSxcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgICAgIHRoaXMucmVnaXN0ZXIodW5pbnN0YWxsZXIpO1xyXG5cclxuICAgICAgICAgICAgY29uc29sZS5sb2coXCJPYnNpZGlhbi1DYW52YXMtTWluZE1hcDogY2FudmFzIG5vZGUgcGF0Y2hlZFwiKTtcclxuICAgICAgICAgICAgcmV0dXJuIHRydWU7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICB0aGlzLmFwcC53b3Jrc3BhY2Uub25MYXlvdXRSZWFkeSgoKSA9PiB7XHJcbiAgICAgICAgICAgIGlmICghcGF0Y2hOb2RlKCkpIHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IGV2dCA9IHRoaXMuYXBwLndvcmtzcGFjZS5vbihcImxheW91dC1jaGFuZ2VcIiwgKCkgPT4ge1xyXG4gICAgICAgICAgICAgICAgICAgIHBhdGNoTm9kZSgpICYmIHRoaXMuYXBwLndvcmtzcGFjZS5vZmZyZWYoZXZ0KTtcclxuICAgICAgICAgICAgICAgIH0pO1xyXG4gICAgICAgICAgICAgICAgdGhpcy5yZWdpc3RlckV2ZW50KGV2dCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICByZWdpc3RlckNvbW1hbmRzKCkge1xyXG4gICAgICAgIHRoaXMuYWRkQ29tbWFuZCh7XHJcbiAgICAgICAgICAgIGlkOiAnY3JlYXRlLXRhYmxlLWdlbmVydGF0b3InLFxyXG4gICAgICAgICAgICBuYW1lOiAnQ3JlYXRlIFRhYmxlIEdlbmVyYXRvcicsXHJcbiAgICAgICAgICAgIGVkaXRvckNhbGxiYWNrOiAoZWRpdG9yOiBFZGl0b3IsIHZpZXc6IE1hcmtkb3duVmlldykgPT4ge1xyXG4gICAgICAgICAgICAgICAgaWYgKChyZXF1aXJlQXBpVmVyc2lvbihcIjAuMTUuMFwiKSA/IGFjdGl2ZURvY3VtZW50IDogZG9jdW1lbnQpPy5ib2R5LmNvbnRhaW5zKHRoaXMudGFibGVHZW5lcmF0b3JFbCkpIHJldHVybjtcclxuXHJcbiAgICAgICAgICAgICAgICB0aGlzLmNyZWF0ZUdlbmVyYXRvck1lbnUoXCJ0YWJsZVwiLCB7IGVkaXRvcjogZWRpdG9yIH0sIHRoaXMpO1xyXG4gICAgICAgICAgICAgICAgY29uc3QgY29vcmRzID0gY2FsY3VsYXRlRWRpdG9yKGVkaXRvciwgdGhpcy50YWJsZUdlbmVyYXRvckVsKTtcclxuICAgICAgICAgICAgICAgIGlmKCFjb29yZHMpIHJldHVybjtcclxuICAgICAgICAgICAgICAgIHNldFRhYmxlR2VuZXJhdG9yTWVudVBvc2l0aW9uKHRoaXMudGFibGVHZW5lcmF0b3JFbCwgY29vcmRzLCBcImVkaXRvclwiKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIHJlZ2lzdGVyVGFibGVHZW5lcmF0b3JNZW51KCkge1xyXG4gICAgICAgIHRoaXMuYXBwLndvcmtzcGFjZS5vbignd2luZG93LW9wZW4nLCAobGVhZikgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLnJlZ2lzdGVyRG9tRXZlbnQobGVhZi5kb2MsICdjbGljaycsIChldnQ6IE1vdXNlRXZlbnQpID0+IHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IHRhcmdldCA9IGV2dC50YXJnZXQgYXMgSFRNTEVsZW1lbnQ7XHJcblxyXG4gICAgICAgICAgICAgICAgaWYgKCF0aGlzLnRhYmxlR2VuZXJhdG9yRWwgfHwgIXRhcmdldCkgcmV0dXJuO1xyXG4gICAgICAgICAgICAgICAgaWYgKHRhcmdldC5jbGFzc0xpc3QuY29udGFpbnMoXCJ0YWJsZS1nZW5lcmF0b3ItbWVudVwiKSB8fCB0YXJnZXQucGFyZW50RWxlbWVudD8uY2xhc3NMaXN0LmNvbnRhaW5zKFwidGFibGUtZ2VuZXJhdG9yLW1lbnVcIikgfHwgdGFyZ2V0LnRhZ05hbWUgPT0gXCJCVVRUT05cIikgcmV0dXJuO1xyXG4gICAgICAgICAgICAgICAgaWYgKHRoaXMudGFibGVHZW5lcmF0b3JFbD8uY29udGFpbnModGFyZ2V0KSkgcmV0dXJuO1xyXG4gICAgICAgICAgICAgICAgaWYgKCFhY3RpdmVEb2N1bWVudC5ib2R5LmNvbnRhaW5zKHRoaXMudGFibGVHZW5lcmF0b3JFbCkpIHJldHVybjtcclxuXHJcbiAgICAgICAgICAgICAgICB0aGlzLnRhYmxlR2VuZXJhdG9yRWwuZGV0YWNoKCk7XHJcbiAgICAgICAgICAgIH0pO1xyXG4gICAgICAgIH0pO1xyXG4gICAgfVxyXG5cclxuICAgIG9udW5sb2FkKCkge1xyXG4gICAgICAgIGlmICh0aGlzLnRhYmxlR2VuZXJhdG9yRWwpIHtcclxuICAgICAgICAgICAgdGhpcy50YWJsZUdlbmVyYXRvckNvbXBvbmVudC4kZGVzdHJveSgpO1xyXG4gICAgICAgICAgICB0aGlzLnRhYmxlR2VuZXJhdG9yRWwuZGV0YWNoKCk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIGFzeW5jIGxvYWRTZXR0aW5ncygpIHtcclxuICAgICAgICB0aGlzLnNldHRpbmdzID0gT2JqZWN0LmFzc2lnbih7fSwgREVGQVVMVF9TRVRUSU5HUywgYXdhaXQgdGhpcy5sb2FkRGF0YSgpKTtcclxuICAgIH1cclxuXHJcbiAgICBhc3luYyBzYXZlU2V0dGluZ3MoKSB7XHJcbiAgICAgICAgYXdhaXQgdGhpcy5zYXZlRGF0YSh0aGlzLnNldHRpbmdzKTtcclxuICAgIH1cclxufVxyXG5cclxuY2xhc3MgVGFibGVHZW5lcmF0b3JTZXR0aW5nVGFiIGV4dGVuZHMgUGx1Z2luU2V0dGluZ1RhYiB7XHJcbiAgICBwbHVnaW46IFRhYmxlR2VuZXJhdG9yUGx1Z2luO1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGFwcDogQXBwLCBwbHVnaW46IFRhYmxlR2VuZXJhdG9yUGx1Z2luKSB7XHJcbiAgICAgICAgc3VwZXIoYXBwLCBwbHVnaW4pO1xyXG4gICAgICAgIHRoaXMucGx1Z2luID0gcGx1Z2luO1xyXG4gICAgfVxyXG5cclxuICAgIGRpc3BsYXkoKTogdm9pZCB7XHJcbiAgICAgICAgY29uc3QgeyBjb250YWluZXJFbCB9ID0gdGhpcztcclxuXHJcbiAgICAgICAgY29udGFpbmVyRWwuZW1wdHkoKTtcclxuXHJcbiAgICAgICAgY29udGFpbmVyRWwuY3JlYXRlRWwoJ2gyJywgeyB0ZXh0OiAnVGFibGUgR2VuZXJhdG9yJyB9KTtcclxuXHJcbiAgICAgICAgbGV0IHJvd1RleHQ6IEhUTUxEaXZFbGVtZW50O1xyXG4gICAgICAgIG5ldyBTZXR0aW5nKGNvbnRhaW5lckVsKVxyXG4gICAgICAgICAgICAuc2V0TmFtZSgnUm93IENvdW50JylcclxuICAgICAgICAgICAgLnNldERlc2MoJ1RoZSBudW1iZXIgb2Ygcm93cyBpbiB0aGUgdGFibGUnKVxyXG4gICAgICAgICAgICAuYWRkU2xpZGVyKChzbGlkZXIpID0+XHJcbiAgICAgICAgICAgICAgICBzbGlkZXJcclxuICAgICAgICAgICAgICAgICAgICAuc2V0TGltaXRzKDIsIDEyLCAxKVxyXG4gICAgICAgICAgICAgICAgICAgIC5zZXRWYWx1ZSh0aGlzLnBsdWdpbi5zZXR0aW5ncy5yb3dDb3VudClcclxuICAgICAgICAgICAgICAgICAgICAub25DaGFuZ2UoYXN5bmMgKHZhbHVlKSA9PiB7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHJvd1RleHQuaW5uZXJUZXh0ID0gYCAkeyB2YWx1ZS50b1N0cmluZygpIH1gO1xyXG4gICAgICAgICAgICAgICAgICAgICAgICB0aGlzLnBsdWdpbi5zZXR0aW5ncy5yb3dDb3VudCA9IHZhbHVlO1xyXG4gICAgICAgICAgICAgICAgICAgIH0pLFxyXG4gICAgICAgICAgICApXHJcbiAgICAgICAgICAgIC5zZXR0aW5nRWwuY3JlYXRlRGl2KFwiXCIsIChlbCkgPT4ge1xyXG4gICAgICAgICAgICByb3dUZXh0ID0gZWw7XHJcbiAgICAgICAgICAgIGVsLmNsYXNzTmFtZSA9IFwidGFibGUtZ2VuZXJhdG9yLXNldHRpbmctdGV4dFwiO1xyXG4gICAgICAgICAgICBlbC5pbm5lclRleHQgPSBgICR7IHRoaXMucGx1Z2luLnNldHRpbmdzLnJvd0NvdW50LnRvU3RyaW5nKCkgfWA7XHJcbiAgICAgICAgfSk7XHJcblxyXG4gICAgICAgIGxldCBjb2x1bW5UZXh0OiBIVE1MRGl2RWxlbWVudDtcclxuICAgICAgICBuZXcgU2V0dGluZyhjb250YWluZXJFbClcclxuICAgICAgICAgICAgLnNldE5hbWUoJ0NvbHVtbnMgQ291bnQnKVxyXG4gICAgICAgICAgICAuc2V0RGVzYygnVGhlIG51bWJlciBvZiBjb2x1bW5zIGluIHRoZSB0YWJsZScpXHJcbiAgICAgICAgICAgIC5hZGRTbGlkZXIoKHNsaWRlcikgPT5cclxuICAgICAgICAgICAgICAgIHNsaWRlclxyXG4gICAgICAgICAgICAgICAgICAgIC5zZXRMaW1pdHMoMiwgMTIsIDEpXHJcbiAgICAgICAgICAgICAgICAgICAgLnNldFZhbHVlKHRoaXMucGx1Z2luLnNldHRpbmdzLmNvbHVtbkNvdW50KVxyXG4gICAgICAgICAgICAgICAgICAgIC5vbkNoYW5nZShhc3luYyAodmFsdWUpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgY29sdW1uVGV4dC5pbm5lclRleHQgPSBgICR7IHZhbHVlLnRvU3RyaW5nKCkgfWA7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMucGx1Z2luLnNldHRpbmdzLmNvbHVtbkNvdW50ID0gdmFsdWU7XHJcbiAgICAgICAgICAgICAgICAgICAgfSksXHJcbiAgICAgICAgICAgIClcclxuICAgICAgICAgICAgLnNldHRpbmdFbC5jcmVhdGVEaXYoXCJcIiwgKGVsKSA9PiB7XHJcbiAgICAgICAgICAgIGNvbHVtblRleHQgPSBlbDtcclxuICAgICAgICAgICAgZWwuY2xhc3NOYW1lID0gXCJ0YWJsZS1nZW5lcmF0b3Itc2V0dGluZy10ZXh0XCI7XHJcbiAgICAgICAgICAgIGVsLmlubmVyVGV4dCA9IGAgJHsgdGhpcy5wbHVnaW4uc2V0dGluZ3MuY29sdW1uQ291bnQudG9TdHJpbmcoKSB9YDtcclxuICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgdGhpcy5jb250YWluZXJFbC5jcmVhdGVFbCgnaDInLCB7IHRleHQ6ICdTYXkgVGhhbmsgWW91JyB9KTtcclxuXHJcbiAgICAgICAgbmV3IFNldHRpbmcoY29udGFpbmVyRWwpXHJcbiAgICAgICAgICAgIC5zZXROYW1lKCdEb25hdGUnKVxyXG4gICAgICAgICAgICAuc2V0RGVzYygnSWYgeW91IGxpa2UgdGhpcyBwbHVnaW4sIGNvbnNpZGVyIGRvbmF0aW5nIHRvIHN1cHBvcnQgY29udGludWVkIGRldmVsb3BtZW50OicpXHJcbiAgICAgICAgICAgIC5hZGRCdXR0b24oKGJ0KSA9PiB7XHJcbiAgICAgICAgICAgICAgICBidC5idXR0b25FbC5vdXRlckhUTUwgPSBgPGEgaHJlZj1cImh0dHBzOi8vd3d3LmJ1eW1lYWNvZmZlZS5jb20vYm9uaW5hbGxcIj48aW1nIHNyYz1cImh0dHBzOi8vaW1nLmJ1eW1lYWNvZmZlZS5jb20vYnV0dG9uLWFwaS8/dGV4dD1CdXkgbWUgYSBjb2ZmZWUmZW1vamk9JnNsdWc9Ym9uaW5hbGwmYnV0dG9uX2NvbG91cj02NDk1RUQmZm9udF9jb2xvdXI9ZmZmZmZmJmZvbnRfZmFtaWx5PUludGVyJm91dGxpbmVfY29sb3VyPTAwMDAwMCZjb2ZmZWVfY29sb3VyPUZGREQwMFwiPjwvYT5gO1xyXG4gICAgICAgICAgICB9KTtcclxuICAgIH1cclxufVxyXG4iXSwibmFtZXMiOlsiZWxlbWVudCIsImZpbGUiLCJkZXRhY2giLCJjcmVhdGVfZWFjaF9ibG9jayIsImluc2VydCIsImluc3RhbmNlIiwiY3JlYXRlX2ZyYWdtZW50IiwidGV4dCIsImN0eCIsImVuZCIsIk5vdGljZSIsInNldEljb24iLCJ1cGRhdGUiLCJfYSIsInJlcXVpcmVBcGlWZXJzaW9uIiwiUGx1Z2luIiwiUGx1Z2luU2V0dGluZ1RhYiIsIlNldHRpbmciXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsU0FBUyxPQUFPO0FBQUc7QUFFbkIsU0FBUyxPQUFPLEtBQUssS0FBSztBQUV0QixhQUFXLEtBQUs7QUFDWixRQUFJLEtBQUssSUFBSTtBQUNqQixTQUFPO0FBQ1g7QUFJQSxTQUFTLGFBQWFBLFVBQVNDLE9BQU0sTUFBTSxRQUFRLE1BQU07QUFDckQsRUFBQUQsU0FBUSxnQkFBZ0I7QUFBQSxJQUNwQixLQUFLLEVBQUUsTUFBQUMsT0FBTSxNQUFNLFFBQVEsS0FBTTtBQUFBLEVBQ3pDO0FBQ0E7QUFDQSxTQUFTLElBQUksSUFBSTtBQUNiLFNBQU8sR0FBRTtBQUNiO0FBQ0EsU0FBUyxlQUFlO0FBQ3BCLFNBQU8sdUJBQU8sT0FBTyxJQUFJO0FBQzdCO0FBQ0EsU0FBUyxRQUFRLEtBQUs7QUFDbEIsTUFBSSxRQUFRLEdBQUc7QUFDbkI7QUFDQSxTQUFTLFlBQVksT0FBTztBQUN4QixTQUFPLE9BQU8sVUFBVTtBQUM1QjtBQUNBLFNBQVMsZUFBZSxHQUFHLEdBQUc7QUFDMUIsU0FBTyxLQUFLLElBQUksS0FBSyxJQUFJLE1BQU0sTUFBTyxLQUFLLE9BQU8sTUFBTSxZQUFhLE9BQU8sTUFBTTtBQUN0RjtBQVlBLFNBQVMsU0FBUyxLQUFLO0FBQ25CLFNBQU8sT0FBTyxLQUFLLEdBQUcsRUFBRSxXQUFXO0FBQ3ZDO0FBcUJBLFNBQVMsWUFBWSxZQUFZLEtBQUssU0FBUyxJQUFJO0FBQy9DLE1BQUksWUFBWTtBQUNaLFVBQU0sV0FBVyxpQkFBaUIsWUFBWSxLQUFLLFNBQVMsRUFBRTtBQUM5RCxXQUFPLFdBQVcsR0FBRyxRQUFRO0FBQUEsRUFDaEM7QUFDTDtB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 diff --git a/.obsidian/plugins/obsidian-table-generator/manifest.json b/.obsidian/plugins/obsidian-table-generator/manifest.json new file mode 100644 index 0000000..06c9055 --- /dev/null +++ b/.obsidian/plugins/obsidian-table-generator/manifest.json @@ -0,0 +1,15 @@ +{ + "id": "obsidian-table-generator", + "name": "Table Generator", + "version": "1.4.1", + "minAppVersion": "1.1.0", + "description": "A plugin for generate markdown table quickly like Typora /card table in canvas .", + "author": "Boninall", + "authorUrl": "https://github.com/Quorafind", + "fundingUrl": { + "Buy Me a Coffee": "https://www.buymeacoffee.com/boninall", + "爱发电": "https://afdian.net/a/boninall", + "支付宝": "https://cdn.jsdelivr.net/gh/Quorafind/.github@main/IMAGE/%E6%94%AF%E4%BB%98%E5%AE%9D%E4%BB%98%E6%AC%BE%E7%A0%81.jpg" + }, + "isDesktopOnly": false +} \ No newline at end of file diff --git a/.obsidian/plugins/obsidian-table-generator/styles.css b/.obsidian/plugins/obsidian-table-generator/styles.css new file mode 100644 index 0000000..a150a92 --- /dev/null +++ b/.obsidian/plugins/obsidian-table-generator/styles.css @@ -0,0 +1,44 @@ +.table-container.s-VU35bhriycJk.s-VU35bhriycJk{display:grid;border-bottom:2px dotted var(--color-base-40);border-top:2px dotted var(--color-base-40);padding-top:var(--size-2-1);padding-bottom:var(--size-2-1);width:100%;height:150px;grid-gap:1px}.table-container.s-VU35bhriycJk div.s-VU35bhriycJk{background:var(--color-base-00);border-radius:var(--radius-s);border:1px solid var(--color-base-40)}.table-container.s-VU35bhriycJk .table-generator-cell.s-VU35bhriycJk{height:var(--size-4-4);width:var(--size-4-4)}div.active.s-VU35bhriycJk.s-VU35bhriycJk{background-color:var(--active-color)}.s-VU35bhriycJk.s-VU35bhriycJk{}.table-generator.s-YxLKubgSvLDy{padding-left:5px;padding-right:5px;width:220px}.table-generator-header.s-YxLKubgSvLDy{display:flex;justify-content:space-between;align-items:center;margin-top:var(--size-4-1);margin-bottom:var(--size-4-1)}.input-table-generator.s-YxLKubgSvLDy{margin-left:var(--size-2-2);margin-right:var(--size-2-2);margin-top:var(--size-4-2);margin-bottom:var(--size-4-2);display:flex;justify-content:space-around;align-items:center}.input-table-generator-row.s-YxLKubgSvLDy,.input-table-generator-col.s-YxLKubgSvLDy{display:flex;justify-content:space-around;align-items:center}button.s-YxLKubgSvLDy{width:80px;height:20px;margin:var(--size-4-1) auto var(--size-4-2);padding:0px 10px;text-align:center;text-decoration:none;display:flex;align-items:center}input.s-YxLKubgSvLDy{width:40px;height:18px;border:1px solid var(--color-base-50);margin-left:var(--size-2-2);border-radius:var(--radius-m);text-align:center}.H1.s-YxLKubgSvLDy{margin-left:auto;margin-right:auto;text-align:center}.s-YxLKubgSvLDy{}.table-generator-align-group.s-XNB-qso0yOHJ{display:flex;align-items:center;flex-direction:row;gap:var(--size-2-2)}.table-generator-align-icon.s-XNB-qso0yOHJ{display:flex;align-items:center;justify-content:center;border-radius:var(--radius-s);padding:var(--size-2-1)}.table-generator-align-icon.s-XNB-qso0yOHJ:not(.active):hover{background-color:var(--background-modifier-hover)}.table-generator-align-icon.active.s-XNB-qso0yOHJ{background-color:var(--background-modifier-border-hover)}.s-XNB-qso0yOHJ{}.table-generator-view { + position: absolute; + border: 1px solid var(--color-base-50); + border-radius: 5px; + background-color: var(--color-base-20); +} + +.table-generator-setting-text { + min-width: 2.3em; + text-align: right; +} + + +.theme-light .table-generator-view { + --color-base-00: #ffffff; + --color-base-05: #fcfcfc; + --color-base-10: #fafafa; + --color-base-20: #f6f6f6; + --color-base-25: #e3e3e3; + --color-base-30: #e0e0e0; + --color-base-35: #d4d4d4; + --color-base-40: #bdbdbd; + --color-base-50: #ababab; + --color-base-60: #707070; + --color-base-70: #5a5a5a; + --color-base-100: #222222; + --active-color: rgb(224 242 254); +} + +.theme-dark .table-generator-view { + --color-base-00: #1e1e1e; + --color-base-10: #242424; + --color-base-20: #262626; + --color-base-25: #2a2a2a; + --color-base-30: #363636; + --color-base-35: #3F3F3F; + --color-base-40: #555; + --color-base-50: #666; + --color-base-60: #999; + --color-base-70: #bababa; + --color-base-100: #dadada; + --active-color: rgb(3 105 161); +} +.input-table-generator.s-b7dfVi8Mj3e3{margin-left:var(--size-2-2);margin-right:var(--size-2-2);margin-top:var(--size-4-2);margin-bottom:var(--size-4-2);display:flex;justify-content:space-around;align-items:center}.input-table-generator-width.s-b7dfVi8Mj3e3,.input-table-generator-height.s-b7dfVi8Mj3e3{display:flex;justify-content:space-around;align-items:center}input.s-b7dfVi8Mj3e3{width:70px;height:18px;border:1px solid var(--color-base-50);margin-left:var(--size-2-2);border-radius:var(--radius-m);text-align:center}.s-b7dfVi8Mj3e3{} \ No newline at end of file diff --git a/.obsidian/workspace-mobile.json b/.obsidian/workspace-mobile.json new file mode 100644 index 0000000..d784cdc --- /dev/null +++ b/.obsidian/workspace-mobile.json @@ -0,0 +1,138 @@ +{ + "main": { + "id": "d9aca340a3366ea5", + "type": "split", + "children": [ + { + "id": "3650afc4d88131c8", + "type": "tabs", + "children": [ + { + "id": "461bdcdc86881a3a", + "type": "leaf", + "state": { + "type": "markdown", + "state": { + "file": "README.md", + "mode": "preview", + "source": false + } + } + } + ] + } + ], + "direction": "vertical" + }, + "left": { + "id": "c31faab13a2fedcc", + "type": "mobile-drawer", + "children": [ + { + "id": "f6c2ef0bfb1bf8c3", + "type": "leaf", + "state": { + "type": "file-explorer", + "state": { + "sortOrder": "alphabetical" + } + } + }, + { + "id": "0e363d83d9334a84", + "type": "leaf", + "state": { + "type": "search", + "state": { + "query": "", + "matchingCase": false, + "explainSearch": false, + "collapseAll": false, + "extraContext": false, + "sortOrder": "alphabetical" + } + } + }, + { + "id": "0b22c79979990f37", + "type": "leaf", + "state": { + "type": "tag", + "state": { + "sortOrder": "frequency", + "useHierarchy": true + } + } + }, + { + "id": "66311f969def336b", + "type": "leaf", + "state": { + "type": "bookmarks", + "state": {} + } + } + ], + "currentTab": 0 + }, + "right": { + "id": "f3f28e7659a18b5d", + "type": "mobile-drawer", + "children": [ + { + "id": "7e1babdc84d776ae", + "type": "leaf", + "state": { + "type": "backlink", + "state": { + "file": "README.md", + "collapseAll": false, + "extraContext": false, + "sortOrder": "alphabetical", + "showSearch": false, + "searchQuery": "", + "backlinkCollapsed": false, + "unlinkedCollapsed": true + } + } + }, + { + "id": "0d29d90218e5cebd", + "type": "leaf", + "state": { + "type": "outgoing-link", + "state": { + "file": "README.md", + "linksCollapsed": false, + "unlinkedCollapsed": true + } + } + }, + { + "id": "257e4a3e73e011d0", + "type": "leaf", + "state": { + "type": "outline", + "state": { + "file": "README.md" + } + } + } + ], + "currentTab": 0 + }, + "left-ribbon": { + "hiddenItems": { + "switcher:Open quick switcher": false, + "graph:Open graph view": false, + "canvas:Create new canvas": false, + "daily-notes:Open today's daily note": false, + "templates:Insert template": false, + "command-palette:Open command palette": false + } + }, + "active": "461bdcdc86881a3a", + "lastOpenFiles": [ + "README.md" + ] +} \ No newline at end of file diff --git a/.obsidian/workspace.json b/.obsidian/workspace.json new file mode 100644 index 0000000..78c8a88 --- /dev/null +++ b/.obsidian/workspace.json @@ -0,0 +1,176 @@ +{ + "main": { + "id": "6771390cbd136862", + "type": "split", + "children": [ + { + "id": "8f5f502f53642b40", + "type": "tabs", + "children": [ + { + "id": "cb5bc35ff4a8b486", + "type": "leaf", + "state": { + "type": "markdown", + "state": { + "file": "Algo/Séminaire/Chapter 2 - Functions.md", + "mode": "source", + "source": false + } + } + } + ] + } + ], + "direction": "vertical" + }, + "left": { + "id": "ec903177fcd621d4", + "type": "split", + "children": [ + { + "id": "98ef2fbce63fb703", + "type": "tabs", + "children": [ + { + "id": "c473a791e2b34194", + "type": "leaf", + "state": { + "type": "file-explorer", + "state": { + "sortOrder": "alphabetical" + } + } + }, + { + "id": "b673def08ee4253f", + "type": "leaf", + "state": { + "type": "search", + "state": { + "query": "", + "matchingCase": false, + "explainSearch": false, + "collapseAll": false, + "extraContext": false, + "sortOrder": "alphabetical" + } + } + }, + { + "id": "ab24fc8c647544b4", + "type": "leaf", + "state": { + "type": "bookmarks", + "state": {} + } + } + ] + } + ], + "direction": "horizontal", + "width": 300 + }, + "right": { + "id": "b83c16dd7908c658", + "type": "split", + "children": [ + { + "id": "ee54f13bcc40ae18", + "type": "tabs", + "children": [ + { + "id": "aff30c9f58e95884", + "type": "leaf", + "state": { + "type": "backlink", + "state": { + "file": "Algo/Séminaire/Chapter 2 - Functions.md", + "collapseAll": false, + "extraContext": false, + "sortOrder": "alphabetical", + "showSearch": false, + "searchQuery": "", + "backlinkCollapsed": false, + "unlinkedCollapsed": true + } + } + }, + { + "id": "9b5d28f22ac4145f", + "type": "leaf", + "state": { + "type": "outgoing-link", + "state": { + "file": "Algo/Séminaire/Chapter 2 - Functions.md", + "linksCollapsed": false, + "unlinkedCollapsed": true + } + } + }, + { + "id": "adef584a20cacde0", + "type": "leaf", + "state": { + "type": "tag", + "state": { + "sortOrder": "frequency", + "useHierarchy": true + } + } + }, + { + "id": "93f23b543eb1ec1a", + "type": "leaf", + "state": { + "type": "outline", + "state": { + "file": "Algo/Séminaire/Chapter 2 - Functions.md" + } + } + } + ] + } + ], + "direction": "horizontal", + "width": 300, + "collapsed": true + }, + "left-ribbon": { + "hiddenItems": { + "switcher:Open quick switcher": false, + "graph:Open graph view": false, + "canvas:Create new canvas": false, + "daily-notes:Open today's daily note": false, + "templates:Insert template": false, + "command-palette:Open command palette": false + } + }, + "active": "c473a791e2b34194", + "lastOpenFiles": [ + "Algo/Séminaire/Chapter 2 - Functions.md", + "Algo/Séminaire/Chapter 1 - CAML basics.md", + "Mathématiques/Séminaire/Logics/Logics.md", + "Algo/Séminaire/Introduction.md", + "Algo/Séminaire", + "Untitled.canvas", + "README.md", + "Mathématiques/Séminaire/Logics/Pasted image 20230904102817.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904101446.png", + "Mathématiques/Séminaire/Logics", + "Mathématiques/Séminaire/Logics/Pasted image 20230904101721.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904101453.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904100934.png", + "Mathématiques/Séminaire", + "Mathématiques/Séminaire/Logics/Pasted image 20230904100125.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904095003.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904094230.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904094156.png", + "Mathématiques/Séminaire/Logics/Pasted image 20230904093718.png", + "2023-09-01.md", + "Algo", + "Mathématiques", + "Cours algo.md", + "Test d'antidote avec Obsidian.md" + ] +} \ No newline at end of file diff --git a/Algo/Séminaire/Chapter 1 - CAML basics.md b/Algo/Séminaire/Chapter 1 - CAML basics.md new file mode 100644 index 0000000..4ee4805 --- /dev/null +++ b/Algo/Séminaire/Chapter 1 - CAML basics.md @@ -0,0 +1,150 @@ +CAML is a categorical abstract machine language. It is strongly typed. It was created by INRIA in 1984. + +## 1.1. General idea +It's a simple language to write. +```Ocaml +# 1+2 ;; +``` + +- **#** is the prompt (we don't have to write it) +- **1 + 2** is the program +- **;;** is the end of the line + +```Ocaml +_: int=3 *That a Caml answer to the previus program* +``` + +```Ocaml +# 1+2.2;; *That an error* + +# 1. +. 2.2;; *This is good* +``` +## 1.2. CAML interaction +```Ocaml +# 1;; *He can be a simple expression* +_: int=1 + +# "Hello World";; *He can be a string* +_:string = "Hello World" +``` + +The general form is : +```Ocaml +# expr ;; +_: type of the evaluation = result of the evaluation +``` + +## 1.3. Definitions +### Global definitions +```Ocaml +# let x=1+2;; +val x:int = 3 *our current env is x -> 3* + +# let y=x/2;; +val y:int = 1 *our current env is x -> 3 ; y -> 1* + +# let x = 2 +_:bool = false + +# x;; +_: int = 2 + +# let name = expr;; +val name: type of evaluation +``` +### Local definitions +```Ocaml +# let r = 1. in let pi = 3.14 in 2*pi*r;; +_ : float = 6.28 + +# let x = 10 in y = 2*x in x+y;; +_ : float = 30 + +# x;; +_ : int =2 *see global definition section* + +# pi;; +error: unbound value pi +``` + +when there is the keyword ``len``and ``in`` that create a local definition. A local definition is something that only exist in our expression and then it disappear. You can define a local definition into a variable : `` let x = let r = 1. in let pi = 3.14 in 2*pi*r;;`` (for example) + +### Multiple definitions +```Ocaml +# let r = 1. and pi : 3.14 in 2 *. pi *. r;; *local version* +_ : float = 6.28 + +# let x = 1.2 and y = "Hello";; +val x: float = 1.2 *our current env is x -> 3 ; y -> 1 ; x -> 1.2 * +val y: string = "Hello" *our current env is x -> 3 ; y -> 1 ; x -> 1.2 ; y -> "Hello"* + +# let x = 2 and y = x + 1 in y + 2;; +Error *because x is 1.2 in our current evaluation* +``` +> ⚠️ We have only one `let` and one `in` for the multiple definitions methods + +## 1.4 Basic types +- Integer: ``int`` + - Compatible operator : + ; - ; * ; / ; mod + - Same operator priority than in mathematics + ```Ocaml + # 2+3*2;; + _: int = 8 + + # (2+3)*3;; + _: int = 10 + + # max_int 1 073 741 823 + _: int = 2^30-1 + + # max_int -1 073 741 824 + _: int = -2^30 + ``` +- Float: ``float`` + - Compatible operator : -. ; +. ; * . ; /. +- Booleans: ``bool`` + - Can be ``true``or ``false`` +```Ocaml +# let x = 2 and y = 1 in x/y > 1;; +_: bool = true + +# let x = 2 and y = 0 in x/y > 1;; +Exception: Division by zero + +# let x = 2 and y = 0 in y<>0 && x/y> 1;; +_: bool = false +``` + + +- Char: `char` + - 8 bits -> extended ASCII table +```Ocaml +# 'a'= 'A';; +_: bool = false +``` + +- String: `string` +```Ocaml +# "ab" < "abc" ;; +_: bool = true *because O chars -> 2^24 - 6 chars* + +# "Hello" ^" World" +_: string = "Hello World" + +# "abc".[1] +_: char = "b" +``` + + + +### Comparaison + +|Mathematics|$=$|$\not=$|$<$|$>$|$\eqslantgtr$|$\eqslantless$| +|:----:|:----:|:----:|:----:|:----:|:----:| +|CAML|`=`|`<>`|`<`|`>`|`<=`|`>=`| + +|CAML|Maths|English| +|:-----|:-----|:-----| +|not|$\neg$|negation| +|&&|$\land$|and| +|//|$\lor$|or (inclusive)| diff --git a/Algo/Séminaire/Chapter 2 - Functions.md b/Algo/Séminaire/Chapter 2 - Functions.md new file mode 100644 index 0000000..2097f70 --- /dev/null +++ b/Algo/Séminaire/Chapter 2 - Functions.md @@ -0,0 +1,68 @@ +## 2.1. One parameter function +```Ocaml +# let successor x=x+1;; +val successor: int -> int = + +# successor;; +_ : int -> int = + +# successor 3;; +_: int = 4 + +# successor (-1):: +_: int = 0 +``` + +>`x` is call a formal parameter and `x+1` is call the body of the function. `3` is an effective parameter (= argument). For the last line, the paratheses are needed, without it, CAML will return an error + + +#### ⚠️ ``f x = f(x)`` and ``fx+gy = (fx)+(gy) + +```Ocaml +# let f x = x+1 and g x = x*2 +val f: int -> int = +val g: int -> int = + +# fg 3;; +Error: was expecting an integer and get a function +# f(g 3);; *This way there is no error* +_: int = 7 +``` + +```Ocaml +# let successor_of_double x=f(gx);; +val successor_of_double: int -> int = + +# successor_of_double (-12);; +_: int = -23 +``` + +#### Existing functions +```Ocaml +# sqrt;; +_: float -> float = + +# int_of_float;; +_: float -> int = + +# length "toto" ;; +Error : Unboud +# String.lenght "toto";; *String is a library* +_: int = 4 +``` + + +## 2.2. Functions and local definitions +```Ocaml +# let pred x = x - 1 in pred 3 + pred 4;; +_: int = 6 + +# pred;; +Error + +# let square_of_pred x = let pred_x = x - 1 in pred_x * pred_x;; +val square_of_pred: int -> int = + +# square_of_pred 3;; +_: int = 4 + diff --git a/Algo/Séminaire/Introduction.md b/Algo/Séminaire/Introduction.md new file mode 100644 index 0000000..ee2cdc1 --- /dev/null +++ b/Algo/Séminaire/Introduction.md @@ -0,0 +1,67 @@ +## An algorithm is +- a set of rules (finite) +- sequence (finite) +- The goal is to take an input and give an output with the solution + +## How to write an algorithm +1) What : + - What do you have available ; What is the output that your searching for => this is call specifications + - How : find resolution methods and choose the best one + - Formalism : shape it like a computer talk + - Translate : + +## Compilation and interpretation +### Compiler +```mermaid +flowchart TD + +A[High Level source code] -->|Compiler| B[Machine code] + +B --> C[execution] + +B --> D[execution 2] + +B --> E[execution ...] +``` +The compiler depends on +- Language of the source code +- The computer it will run the code + +Advantages : +- 1 translation +- Optimises the code + +> C or C++ language use the compiler +### Interpretation +The interpretor is a live compiler that translate in realtime. + +Disavantages: +- Don't optimize the code + +Avantages: +- We can share only the original source code + +> Javascript use interpretation + +## Language families +There is two families in the language word, the imperative and the declarative +### Imperative +- State (of the memory) +- Instruction that will modify the state of the memory +- and again... +- output + +### Declarative +- Defines relations between the input and the output + +In the declarative languages we have +- The functional languages +- $$f:x -> x+1$$ +- The logical languages +$$x\in{N}$$ +$$x>1$$ +$$x<3$$ +$$\text{-> } x=2$$ + + +Latest update 2023-09-04 diff --git a/Mathématiques/Séminaire/Logics/Logics.md b/Mathématiques/Séminaire/Logics/Logics.md new file mode 100644 index 0000000..829a4b3 --- /dev/null +++ b/Mathématiques/Séminaire/Logics/Logics.md @@ -0,0 +1,71 @@ +## Proposition +A proposition (or assertion) is a sentence that can be a math or anything else that can be true or false. Logic use connector to create new proposition +**Exemple** : +- P="The sky is red" +- Q="The is is not red" +- It's a negation : $$Q=\daleth{P}$$ and $$P=\daleth{Q}$$ +## Connectors + +1) Negation + - Def: Let P a proposition : we call negation of P a proposition or the proposition that is true when P is false and false when P is true. We denote this proposition : + $$\daleth{P}$$ + - **Exemple :** + - P="the sky is red" + - $$\daleth{P} = The sky is not red$$ + ![[Pasted image 20230904093718.png]] + +2) Conjunction + - Def : let P and Q two proposition. We call conjunction of P and Q denote $$P1Q$$ the proposition that is : + - True when P and Q are both true + - False if else + - ![[Pasted image 20230904094230.png]] + - Exemple: + - P: Floor is green + - Q: Wall is withe + - $$P\land{Q} = Floor is Green and the wall is white$$ +3) Disjunction + - Def: Let P and Q a proposition. We call disjunction of P and Q to a proposition that is + - True what at least one of $$P\land{Q}$$ is true and False when their both P and Q are false + - ![[Pasted image 20230904095003.png]] +4) If then (implication) + - Def: Let P and Q two propositions. We call if P then Q the proposition that is : + - False when P is true and Q is false. We denote $$P=>Q$$ + - True if else + ![[Pasted image 20230904100125.png]] + - Exemple + - Moustache => Nice + - Let's take $$R=[P=>Q]$$ + $$Q=>P$$ + Is a converse of $$R=[P=>Q]$$ + The contrapositive of $$R=[P=>Q]$$ is $$[\daleth{Q} => \daleth{P}]$$ + The both are equivalence +6) Equivalence + - Def: Let P and Q two propositions. We say P and Q are equivalent and denote $$P=>Q$$ when both $$(P=>Q) and (Q=>P) are true$$ In other words when $$(P=>Q) and (Q=>P) is true$$ + and false if else. + ![[Pasted image 20230904100934.png]] + + Let's take $$R = P\land{Q}$$ + ![[Pasted image 20230904101446.png]] + $$\daleth{(P\land{Q})}=\daleth{P}\land{\daleth{Q}}$$ + ![[Pasted image 20230904101721.png]] + + + ![[Pasted image 20230904102817.png]] + + $$A=>B$$ + A is the sufficient condition (to B) and B is the necessary condition (to A) + $$A<=>B$$ A & B are the necessary and sufficient conditons + +## Quantifiers +We know two quantifiers : $$\forall \text{ and } \exists$$ +**Example:** $$\forall{x \in{R}}, P(x)$$ is true whatever the values of x from R + $$x^2\eqslantgtr{0}$$ +$$\exists{x\in{R}}, P(x)$$ +P is true for at lease one value of R + $$\exists{x\in{R}}, x^2=0$$ + $$\exists{x\in{R}}, x^2=1$$ +### ⚠️ **The order maters for every quantifiers** +- The negation of $$\exists{ x \in{E}} \text{ is } \forall{x\in{E}} $$ +- The negation of +- $$\forall{x\in{E}} \text{ is } \exists{ x \in{E}}$$ +- \ No newline at end of file diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904093718.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904093718.png new file mode 100644 index 0000000000000000000000000000000000000000..279f7789eabc4810211998964be789f9d828ffa8 GIT binary patch literal 12797 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 Lnq28qvk(6Voi4{k literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904094156.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904094156.png new file mode 100644 index 0000000000000000000000000000000000000000..8b8f7b078c125ece7032dbd1718c8742dcccea5b GIT binary patch literal 47644 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�Pt> zoxuUds2gH|`JFx?aJxW;z+(XGO)q#81Cb9Y3^M3L$o5g+dLIMrEqqJtPdobDj9XL` z{u|LK)Kz-V>2TU2y-LsiXU7BsJi&KApmu_La+5_@P9 zO5i&JFFSZ+WQgTV#N#xa2HExL5h;RuA421cv%nU-@YZAz0H*8)Zwu^6*BrxH!@+-u z{OF=%IBMlU^$}G*?IRD%`XvFDz4+hpWvCy+B0TY*UP*mZ+x6_rRCvktrB_R=SwdtW ze^P~-L2R>t!Gyp8sp7PdGztcxMH}}B*xQ8$YL#>Dh&De*f~T;@@O{<9%C{^tx&^GP z+EtjnW(zr>h!;8qLY$dD+_^1S9zPA3_-#p9XWMlr!kvGiNQn0loj7W^Z5t?;fPA(x zJR|mtW3RF*71~;E+g;h`;!P-uQ0U#_gqYT>AvQmZmUKNLBZgK{F5Cm(={xhXWfSS- z3G5n=d&+N4@-vIa5)FFbF}wSZa-i%(hlitRKqt`Uhfjh0^qZOkpi{H8dvIdo08n6! z@&#sDW4p+vtQM5!TN}YFJ^_%eo*>|s81e1;fPoZ|p%(8`_Z>wD&e-~8v`mU}id!bL zbN>@`f;dt7mU)9x)f)m94z+IdL&iF;$pdD}Fq|w9e4R1vC#s7L4F^zdB)GGk|NTP) zdJCv#FXATRXG!9ptc)udNus(a0iusl&{4#w)BB=^F~H=^3Tl7gtv$F>Eas9+%&Y{+ zHQ#BG`KdUnL#fZz|5}C2O#<%d3&4Z^-aECa*QisBC>m(qIN(Y=Zdv}K*r|H4#Ey7P zMxIaY0rA~w3HG#18{#<*Frbb>_~K)~(k>jTtO;0tX*(}UtWmH^E@mJi-k&bht*Pg8nwr+lg52lGn#GQ83Yu!7EV zx~1B}8b<}R_r8jrsPJk+UGtBPu_QVCE!iu+nW@|x$OM?Rh zsAUzsM%vWF#xk181U=dcnv(X$?ufemx`3SpiqKh1>U&23YA{0EyYNfCdfWBoAPYc~ zmR$NzfKhZ02btj)-=SHPfD*jj00q$WJ&W%~K!JteAtsE}-GE$VTYuQ-u}a2F@23On zlb@SRS`P-SG%;5DnE@?&5;D^56rff%H=brt!UIOVmeTrLtX1`%Q_RpazB85zU;Y@$ z*@Hb@f#_Ur@Ns!kAVi$$K`6bR_ZW@f=bp6%G(=UvCSwmr3GtSmO=`{da;%E{25TC0 zy)ghc&~6vgm4x&C=TEUM2R>DQg#b`;JDfme6RQgzS5G&n!L}Me$-Ok(Y^)m~xSJ7F zl`!k8H@W%09`^?<0VYsQ!|!6V-xBg1ooS9I5g$v#e7Iqi_)Ndek=_o^FuVHJ%fOpD z8^{2N%ki0RIchB4AD~~m7PpDLg#6vSd6MG{!bA)fuTH-I?C(LMSb2lP+sj7cJ&&F8 zwffuDzT`+5?2f*;Xhx=-}YlODJM zVo*+s>_p)$%-Y`rkyfB|CV%5;QE?V-FV!_~r)g>VO?ef|Gs}!rKp+OFG>8NI__kcP z)^b0yE@GF6aYUiY5EwlB?JBqM%z_1L`3IKvA?TVrlPh~9CFE`np>N6bE1T9hPSMPg zBX3Ox(|U{W=l9#K3?Q+Q{D#o|yiewhYz;yIPb;AhvJ-AS3bx_03^#sDgf>oAPnU3niiR@7P&^@yV&SfimDsq*B;y7YFS}vv~&2R~U z3!YBjYvLvJdb>P!3N!FZw!q5Iwt}$PeQ0_WzM6!h+4Q;!OJl${2%-B8WYG)?{0XqA zlMVuDK%0yp{3>*4xUEPuQ4@f?OJRK75PN6#^y8s?dW?HEjw+nZhdJj2!1v94dba;W zZ-D--YG#Mux*)HLINn8X2DCNqsJ#>2_50GbZS<@|ou0!_p)lSDo9dNM>1#Lqq$w4u zz7I7_Z7-!vr_U{%$U&cZ^v2=0qhzQn`08dx5)7?>l)?$8=t(SL^Y`50u&LD0RvP>- zqgl_Bf~27M6>lwE-E^j8u}maMKt;qi7_a#z}5KvxeVeXe(#7)Zn<-)hN@$;zA-Ju@AbD zZn^hBTyI+sahgyX)f~bN-ph$b@m@>qM!fHvpyu@4axZKS2kOv?&}`Qc3ALzy4_1(L zLx(5(Utm*mBA9|X-$?_sce+D+!v@_7+>3PKmpjUnMC=qQ)(de3UGk+j!XsZNyO9doUMhO2Mu1&3u z*!j6;h+csCv>%R&R(puH+-zDS4vIVbDF33HTR&{VeLwtHfkX9byh``p{rM5sA!@;# zfyeL$=Bvj%NfdIK5X?B z0N_8mgjtFZUCwp4Nd@4TL$?2ZU8vn!HW)|6{WLrN??2He@~@;c*_M$aJ-P@w<5sX( zG+ch3*PYqnP-kIiR@?zji}~&{BJb8)r}`CNB*l@-wkz#wzIn}Ud$MI!TV49+2;rmEuE|cl zvHi97Hz`1N@GMmxf+fMX+x4^SR?w4u0_#r%T@<^Z8m)0HVzH9N6_mgD`%w~A8b z0e!{D=fnlaG1Iqd7Y7E12W_KrLKrl?+#Fg6fX^82J0grf$wNmh!Ro^J8>aG9)9uN8 zQsEII^HUT0CJ}K)!AQN_9JZVoO~N4I@;uPMlc46)lF~&OmIo+_IArnh?~=`tuR!nf z<$nQotv;!8Va+%s@6Xk`OGV*p+yN>uPpj8P7@X@3^YW(CN|pWqYN-ZMC?EL!4yNmN zY`DSQ%zLkVB3kb55Vh0PE& z+_c$To%0DF(XboAo=qp~)kW==1=W1bbzzc1j0hBw)JozBxMFurpT6EYO6C1J!FbFsEcLSLV%D3`hK8Vu)d?}+~cErhL7!4BlC>8+WZR)>kFmAI?ZbA`CQ z#Z$#G&V>}a`_RTQXoG+JMp@bn#QeqsC@d1{Ym2y^c_2twB;Iu%&|!hy+`JgiJG-<){?V> zHKUPoF2^+hb#?ePOhlVm8{@$dbd*hXqC}-7ux7n!*6JQv|$Umn` z_rN(ej)L&bfKYp^m>;b{YTtDzNG)r+7{B8K<`B@$B5RRqxb+G( zUVt`-|D~59A?Mzmq}fsp41yWD_h;ir-$GRA15|TMOpi{@k&shvbj(CpHzZeE4HE-n zJ{oFtUYlyd9J;cZ=|MR79;VdJ?xyqf5K#$Uu(JnD4u8kE5zPelac+V4`UpY=c^1daTkm&<| z{*!fY^;G;N5z&mF-aVx_OtXQKK=csjV{pws^D9*DxDJN9nY6Jwqgm5_J?t^nD%TAx z*AAZX3D0g&KBw}f6VNn#V+P(#)~P@$?o&e>ckSxt7_jJB;(yTMy`kGZ*|}day?X;9 zL~TgRWFL$*P7Hfk?h}!xjT>kZL983TK-2}pzdG)Z1lToGmu^9~rj1%u0GSnn-r>qb zc*|B9T#^Y2R9aP8F04B(Yv`r04KyOGcD}{P>%cd=%6^`1avcIiyK_K;eUoMAwe;&U zS_(vsrrklv8~Rf{m|j4l1+ynsJ}9#oVffno-MhAQWR(pWi7O^x`i^Y{mg6CBYLgv+ zgOuRHYzn@ViLf&&CKaa3x&0Y*&3=8FpN$*UEu!2rhwZvOg03#9=Ac5CpK68mVI$+r zl2ZbIdw5jdt%bp$`#CK-Z|q=Cx+FQczx(xt9DWmk<0=g{9Oks5cH%!r77l-T)0y1s zwOW|JJq!q}WT*ihZ1d470O|y4gD(!idQDo&nG2A0NzZyLY^zU~ejV<3Bg9Rjk#yQy z0Zg9D(Qc?eklKlN@jCqQ;zRBE@$XQtuStVrOIz7(7;IX@$=R}SQ{n+PN{jNrYn)8u zI&|;>d}Ejw$teTjB&vxf{TmuncT<*-Nu0$f-KaTIz-KR3JD}G8IHp2;ceEP261~+5 zng|xe_3a!7BwG@0&M%nRct~InYqoy>VbK^AHstXeJ->#K5%}veN~QkJV#T{?45gX* zNE4{@p{UP4TWH@HRWv9PViAU+!-?oSy6qKrL@{fj}*}c?*LmE6!_6bV7~<1 z4U}9{Sj=BQ=Ih5A+Y158UjE`OIx^%ktnbZ3iuCKLcS-}+yiGitXymA-Uzojreu~_| z{a!<`XdhB^m5NH{BJpd4MS9__z_q30@9t}-;h~JS$Yq1=0g?F--(-x4`|bywvwIi+|nJ*s)3fzeokgE@T(<^t4P_e6JR!(M0c;gsP#&^gzM8vHRrVACB< z4Yh<|HlMWAV@nFKf~sH}V6Ak#Lj$$R{te_Mm;|MISG)%e(%_s0i#S>%FbGV1?Bu*9 zJi>n!h){6d(&S8$vL?g|q6M;(j^?}%lrV?^KS)W;!J9oD6L>qHI(md08V1jY(wV8_ zV`)l?lRR{mz#BQSI|9eJ4r-tvXXNQ3{q`b)bGnQR5UyWTeZKGt$~|`98w+umuGMp} z6Pb6(Za&=o?lCxG?|5?-D!u}*esbWP!Xwl6iqzE$3QNc`(5fStZ2h_bH< z2Bq19oMh~#ek`Ejgm3ZlKZ?HrW$mLS{yChEn`o1gZeWCGKG^Rl^KAl;;-$@;*C; z^$@%^CA#+Ar0@E@#i02{ZWE$Du$e=Rf()^wvElWS%B)b(^key$_F*#YiDh-JGFHW6sarR*ZQN`spgQ2*94~e z%9|Fee#XN#XJ`cC#CEDjw;2&9K?BG-^lmNIUO2<`Wz$FN`KBDX7q$2`C?VhOv7_{{Q3h{yhi**U8EE!;zpO=*=IlQsqbOF4Ee*)2R~5;cyS zEPp79Z%QM(Ts=deVEQ0(x-HWYM$`BldbP8kgGy~Y4H}xLwCpj~)kmMLd!8Btw%MWl znxXfhF`75j89}K%M4%sh+V7PAajIZKNH`ABdjLJsgOX8D#dYhyA}FZh4l4Tq{CMqQ z_Jf(ZjpH(^dzIBYm4}0F9qDEJDXP31AyiDyyXj(!=adLQ5%0Afpju-UP}hF=GSywv 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 DE(F`Z literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904094230.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904094230.png new file mode 100644 index 0000000000000000000000000000000000000000..823bcad9dbedc403e68f8aa6f52ebdf3435e22fa GIT binary patch literal 46726 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 U_wXA{Fo1umN?P}-?^=ZZKcg@_e*gdg literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904095003.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904095003.png new file mode 100644 index 0000000000000000000000000000000000000000..ca59a222c20ca40377199f800a4b48176fdd42ae GIT binary patch literal 50520 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 literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904100125.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904100125.png new file mode 100644 index 0000000000000000000000000000000000000000..2203a7353e00c2d05a8252bbcf07c07228ae3407 GIT binary patch literal 58047 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ð z`d$lVfjxAQ7@tBr%^6@z`UStBuNsTi38sa#&enr?H5N&@r+bVr2k;5C$yJTH{F)++uPyY5ra6Q4C#s9C#QVHrp8rM5OiAlOJ~i` zzFGmkr|c5CIbJn@)G&K`Cr;svN`M9h;&73=!;+GF&vUoOnE067!;Aw;NvY~6;chBDtM@iZ76eN<{H72%CfQ|`nWvBOAkxE;Q+Jv#kpE%h)q2J$EBiL zo%yi!dAgPxc#F*%cVVVpc;^Ko(&?!-ZbMa14%sQDPan^?I^{fPM=cH@b zV9zj_@scI(QC{aed;z|+R=9t*`g?jicy>|9PH;(Bx;qt2KXtFVs^_j$AqWPn_|#U1 zDOQlHA9<-(V5%`5_gJ_q9^s+}%~hpM_pS)2T)h+dxo?wiZnkksFN?upf5o63bg;A3 zIh|*1a;E#E$8M3j7bUNK;2f^l^>`N|gXJ@}yPBP#fGiRdrtb+DB&EQ}E6iqoTRpL~ z1fJ822xaQanvAv`?zn|`1%s$MhmfN@UdGLoqplX5n{ z+Sf_DwM4z5RO&E?_nTSvy;P@A-w=F{n!1+LR1zwMN zHN)P3$XpB7v?TDGDNN|d$BR+v>sIt0NB~=_A62D?18@Tc1S9xSdd?C zB|>FJ@2#Sx0TZn79S+bJHS30Eli@gTq?t{5#d01{&*7KnPv7Q#t*AmZ(5%e>r#Nt8 z(Yh4DREMBOx(Tp&62e6i(pA^iV84@>q$y1`btQ6`+rmh4vK{$_7$8^;Zxbt5<1LK& z_2s11VA$!F^R66bhGDn}B=Gyij+ABR@^bRKBl*E;6Wx(N>k9twa)^EJ(NiqKRp^@p zm#bUMR#js{wEdHU!(DM&Xlcv?$ou}*x`s!fs})dNV$ zGZ;isZ-?Ph&{VoXieN}`#$~8xu_!TXI70z=ciGMR-sl&3T?4-j`d)5(k3H-GH>dH^ z(Uuf5oiLm`%m<5~kLk<(K`jR`eyvIvU)mNDpKNThiQlF|%lL2{3OF(i65hNLpmZGP z63Z3PqxwQM$Knbkv@?Yu@;F>ZkHy?pD{dJxG~_7_4>bYapkn|Ue{iR=UJvkC%62@M zWPjhD$doQHuVS~dz1|jG{?_{J>%g{mEo*zMxcWpnHOBgv$MYsJB%BFt?94}Atc7lCwD_kC*G`^=frl z271yvVJ=z6kJ*Ri%77aJ>d_yl`_rbiC!5VRWnu-OSWW4l?prl9m8gP`FxecA>qd5v z=d)@d);QQAFK{gf)n&iXqfWxGx7eDu5FcbI7-w^Xzg|Rgwh6uZc*YXstwKUjA1r@l zOXx+oSeVMBoJkLGxbHcZQ&2{f1OL;vi3!whPOs8uv zmOODncAye5tFApy_8$Ut`TjA(yd=zRoHtWTg6S{ED)B3R<)f|R(zMgIyx!r&22sZMa6=2K5pqf|% zg7i7-bUmsg=q+_VSK%Gdsc0}iiDWCWEu74_os;rX{IjWGhWF}-iBl?P(s&lK# z_wple<)A3CgrJbeHa*=#0;*nv4zUC14fD_A+WWhAENLSPJmEZ=C~bkytF*PifksNK zGWrYW#;J7hoSe#?Edm0=e^9hL;c=V!Udu4I+3m_jBT-fL@&aAD?5Npu=AU#H?A+fJ z0ZYPGlGTC5a+h-7S8ii?o4?d&YbY%&P@Nx|?f+NB&_FR7(#G#^ib=5*gU`iT{Y^0x zr^X_RQr;{G`Eyn4IGjLrP)PQJKNn#~u>ffP3#VpoNt0BIB>yK%6*{&Ca=NrTSSeQs&- z$09(Q3y_A#epL9CpyRh97r8*^u5hOR3qm6PD9s2x_nniWhp3On7JG7lpQDB*29Nd5 Gh5ipuL4v3N literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904100934.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904100934.png new file mode 100644 index 0000000000000000000000000000000000000000..1e4c77767a33e7ea61faa8c76f7ca9591c713004 GIT binary patch literal 72215 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

    <7&+V{kH?(`6n&M{;2Bmsp zLA5lqd^=7p7U>nzV2_&`&IDJFke`)y?%PW{7LGKUC@;;<%S(zz=F(W&Wy=xuEig$^XwGgujeH~ z`cEK(PTJ&}JgFvE*E$&eWEly20;Xu}`YYS|WMz&ecDwpUr@Lv_*1UZB z#}->(@M%0=hnm>iay&=y)(nb?afjzP8k3|{CoMM547+86^7KYjh7Z0SC@0s^wg`^f z?zKIhN`HAQ`1PB`HB@*gp0|t|id8H(s!_H&?>Nag!JIJFUfZIYu&7ZSRSoI3>2n$g z{lfFb+=I|Q_>tbv|140cZ5bUvJJ5}WIss}i4{SOvB^{TwPwziCx(66FWtL3t{|rm& z|Fum2#^`^)*qeZpVe=E8^mf|*fv~{v{qLs#vmbJSCO@oVH&YS?|7YC(&!&IP{O_Py nE+la-)itXBwEX|K^Bi3=r&29`#5fxf0H3>RI;s`QmZARx9mlz3 literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904101453.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904101453.png new file mode 100644 index 0000000000000000000000000000000000000000..2683338a795fc529bf7211e3482ffd11107f5970 GIT binary patch literal 75624 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

    <7&+V{kH?(`6n&M{;2Bmsp zLA5lqd^=7p7U>nzV2_&`&IDJFke`)y?%PW{7LGKUC@;;<%S(zz=F(W&Wy=xuEig$^XwGgujeH~ z`cEK(PTJ&}JgFvE*E$&eWEly20;Xu}`YYS|WMz&ecDwpUr@Lv_*1UZB z#}->(@M%0=hnm>iay&=y)(nb?afjzP8k3|{CoMM547+86^7KYjh7Z0SC@0s^wg`^f z?zKIhN`HAQ`1PB`HB@*gp0|t|id8H(s!_H&?>Nag!JIJFUfZIYu&7ZSRSoI3>2n$g z{lfFb+=I|Q_>tbv|140cZ5bUvJJ5}WIss}i4{SOvB^{TwPwziCx(66FWtL3t{|rm& z|Fum2#^`^)*qeZpVe=E8^mf|*fv~{v{qLs#vmbJSCO@oVH&YS?|7YC(&!&IP{O_Py nE+la-)itXBwEX|K^Bi3=r&29`#5fxf0H3>RI;s`QmZARx9mlz3 literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904101721.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904101721.png new file mode 100644 index 0000000000000000000000000000000000000000..748dadd5bfad91a3ee716c87ccc9b4302bb4955b GIT binary patch literal 81019 zcmce;WmHvN8#YQe0wOIXN|zuZwFv245VBOoaqn~;!HQY1DV(rh}UySuwvQewxq zeBSRp=hyq3e}^&FSc^60X3c%iYu<6)*W!!1svD|KVO04?`QsV#>m9@?+C1;Ow9jYqrd$-l>POj9&o~UdTro} zhDQ19?}4tQ`Sdp$nlzfyD;aH1^dl48OzrMzsn`b?5lrC}-0TGU{?Wt~KGB&R5j>S_ zN%}eOx_->Pdl&iTne7x_z73YR?hAc&jfy~Qb!jr0=qGr6i>UjNrTIF?`8uD|la*5N z+VMxN){Ehk6xZF67f;u^(wNQhs4+qV{?|zx3!{|t2~`rlTpKAr77_aYI;mp~nS)>b z+X#LvPCRtMIi0Wk++6?rd4K0Za}=!~7}gbn5B_}w#b;pNoUf^qDE^m;{$m^>_n!Z0#D7L)29fdyn_%O2R=xYz zmHFO2BKrTacBH_(iZ6k80cuF)F@xO5LALHPNZ~jjt z{WC&c2Jd@&S)XdvuZ{A)JX<#zaaAu4@B%e*PO-}e3K9Q-DaF7 z4cyrN)Dud0zwojW<8nwle2&!EnsGV=Pv;zMa$oF?=S1l_V;J{3!z5oc$VS4}7vAQ(7AgCVbw83-E$E}k>BQR(megM&g!tP;r*N+lgVsh6(vY0RX! z7&F1Km^zWLC0Z``V3P(yn@7bKSVI+>ogF-u<8MDClED{L7YcP2&v}gY?LTV@@7YON zXc-FeZMZxlEhbA5#Cj*wR!>1#;>P%)LFGXu-O7Y z0d%vAep;BVY1cMKX0-Z1u#aS}EuzHxtIPhNjac#J_gUqLo>K2`pG*=3fq4WAUAxH_ zYEsTbwdcKRikT27enXGnR4qTL;`qq0%i(=Cm-=rzXMMTPtomM1dPD=FOZ^`IIbV6>dIJxXw)Gr_>wL(;H7Qu1A(V z0VCj7hXTVyNh|zy9~T;?Y3`(?{&ftxJQ%eBKGP9pRe}!JjRQ$)6uTqVb2^p3IYkfi zt2p&VbuwyRrQmYtJb+rYVq@70##07VE@HEoa~7N9@dUlaOPJpS{MlRCN*|q|fR?P{ zhcY@k!pFmoI$w$#1&nrZS{vJ{mO|y*k_a9|Cfr6w1Q7e@Jh4W~F`H|N$hE)EIG1iq z&}GOp_?m{7a64=R#}PkN+Sv;5>LWqFe<}=G;?{P@iqe}ut1JNAs=5K*i#fEsDlAR8 z2BkUWP}(@_?ML0Ap@}S!hJ#<6i)WtNZZl(?(H+^RKesfr$D1Q+n#(NR4KJ-J2k-Y9 zy3^hF5I8O?I4C4GQurNVixkqzMx=H68Q)+jv-&CC+|;l)I3RJA zv`_%+=$Tw1{!o=2-joo=_6j?jdvJQuR^yIGb4Xn>``Lz3K_we)w7whX-CX3yp$Pho z#O%o4G78kM`O9cI$|l=aN*NR`9f=<~Es{$vA)?c!9WA8)9ZS9y^n zEU8>7MOvXIbRajf&5<3Z^mOOA9i4b zbWZ%Glk(?%__8?|%F`oHA6Yl#){CW{gZGqn=%H~=c4@%7dHy_%&+0w~{D#vRZ@F?` z5ns==$UfDuoM*qlI1viXr(nZIw|k(~Rxz2)Jf^=xmGdz|H!kT(gnrxUuY1*bLMjM)~Sqr z`Kb<^rH0)Oqa$BgnsgknXpgRp8|2kt`&4C>wv@D7-vOtu&4h8i{|=iVkFx4L?4_+t z1cgE9r$rfg>j?oJKfDAlzwjGkcQSd|&Hf}Khj|xvb}wFd9c`3*)9J4!W4CFYs+}Kp zwMVNNQ`{IK)Vjz&t*HJlt?)bve(NZ1!|K=O%#`}!&RE8xpAM#!LLbm`iY$MM|8%@i zWBt53$V$4+bkqv1+kpZzP@wKlH+xXG1rQqDK1(-HEtIho9{wy8c7>I7nM`!JxWvAc z%e=u$NY)J;G0*O&C7jnUUi*o zb7MUezTu%vpj0Ek5Ox*BCK49{21F<_sm05U4^Z3_HNEP3C~VL}?s7*1?!)h8WYj+} zPT3uW@=fNe#DkD$wA7j_2_dW837c!Xc~oXoqc)MDQS#bncw3WetyeRPH(PG0xmhP{ zpxZBLUOOpb#juZywdaUGtAn{p@mnO2dPC&xD5M|vw50&arkYj=?bnrHPihY$W8Z?w zkIWcXy;q9#()ZdUr(7dBrnPgl(r>Ks>};J6_&UneD6 z4JP$B>}GIvhLI$f)-L>{$-U}mFI>7`3ntkLBINzLibDRW5#a)n==siUE7A=k+Pp{96FS<@ zgM6OWa3{^gXzKMoM(S?wRoDaixaKqXS+D!?!n3=p!{j+I)bAmcsiy@7y&7Y+Z4C9J zXCqSgN3Wn#esSAfY+L;oiMobLZX!g#qf!@j z@x6vS=FCg?=YxFY{0^)YpA|4*`SG699sQDI_Xgac85d;4Wj0JY7Oyni zbRRFh35!O+a2b91D-X+>Sm#zM{Hzui@>Npbi@)&vy@nO#xi53vC`(H1rdC~PVOx7B zKTAETmB)beost~y33Wc;J}loB(Jkyk8fu${fbB)0OLNS+B4XJZ*s#_L!7k z>!EaU(HC+gl8@|Oa-R>#t!0E0BQHil&@D=0R*R)y_a~`a)Saotepn}83Skpuw|9r- zsWdRr@AY>F#pG%r#HWoI@e}o&K#{d^&p#WHeEEtR-)4^_Og)y}zQoXr+otP75Le`N z%kD-PhcdSQ;L(h9(f!=`xT}!hqCDkf-S-9qiAAyvR~>|WPiOQkqq`L7J|>teRy@(Byl7E&20}aBykg+H{jgdI-!|I`=O<<29%dllt-#wy}{!)qc4@c@=`as7{+6D|S$bW$ndQ z5vU);cg_fbpLGF<&4K5mpH}uVT*w^j%iz75HrO{PcQdh+P)qi_Ieaq?0FleSMEwJz zrtrGtcNFpN-(*8OZ|QwSd>4g*^<1TARH~7B#rm&{5%JE%Ip1j_42=f2wLn}}T#n7& zSdx%V*l3K}$c@BaX0U9?bG7McX>C(0&SQtBYo@X0f zB#@iV_bE1g)?qK>#m~CPFA`LB&cmACbUTr1|5Itys< z?d|gfEzJC`rYXmY%N7AN9UM8M&Y5PveGhT2>1g7&D#Zl>chi=|;+ zPe;U0o4c-N&B|c}5kgJT&{`J-&WrxmboT|0c7fWhoB1bTsWHBp5F#sMTaGfrCPp{i z3O*1x##6FOt=*+T)AcK?Ty(Q#j+ghOQZV|;rG|&8cKRgS-?Yb|r6l#2YM5k|1K2fh z$E3D-4z|HWI$iOQs;(!RF8M`ArC*i?OR94E@vy6FVhFHedAm{$CKuz1jQbOe#z@PV z5`+DIaLbNo!aDMI80h^~@_yEt1UcvUiM-Gpg%Q{QQd(~r@@BtW-p`97x~9QTFRguK zxWW~-!`ljvpj2-AaAFJ#qE}(~5F(^!hWG0ET&1%IWRqx@a4%A8sI;i z1j<{yuik9YRts{218?D5-e++?bW5R%$FIF5=5E^`udkZY*ags5ERU*7aSGsbc6H9U$p#LiF`N(*JZ{CDbor_XOG7WshKquXTeZ8 zABYpB6TJt(y6CG&?;LLNOABKT(Y=dywH!SYH=RTg_tL96LaCl%$y)ra z7nSK^Zno{WJYcMl2mVyN#&g*+!FHd?3hqx^L0~fF{-(5)=Opqn=AXKVRVK)J5{%$a zGtA^~uI*c{W|TkAkL>|&S~=80zYO2H%!RaX_nDmSiE@^mL-U!!HYr=kZ^1+U80d%H z$ujEE&P=)ywX7x1R{$o5qd!DQ>K1-R8fGC%oQ^)u>v6Fsd73a7b!aWFYw4w2-qD>W zry`$-Ec-?-eVSBp5kw--Vj+EWj&FA?Yv$uqC_e zjmoKLpIXiCUfut8A+=cN$jDLRRVIb?P$_>a*@N3Vov41+)aTi#mYTVfvT3#;yZ$b- zSNb7VkI3zKtp8I%@Q8Lf=%$@yYaR@xpjO3#tzwCX5zJgBFi3juxi){Hq}IfOS-QwC zAHCcZ+fLAm`(yr@oMK0CYe z3z6SEGWxAlvU0ZzLUHWr=ShtmHa}WgG!G`mg7rT#8tUoig4R65I}F5M?E4fp3i~`q zL?iHue^LT*MlhSVwM_73F~fKUH@c`kwOSJLf8QuE`WGhQ`4IYcZv;82akNmwtCquhCReg>?`fCks0K z@=}`m7sh^gPtW;(-e~gbS4f+BZBsxvd`??D&X=I(!m-9a$2CYzemi}BISyc5wxR?_ z)H@#|(t*rIc5@YQ!`wI3D#6!B^IH7HDl5JhD)T_}x@1Tq{c7acqBGiwH0P0Me^8-x zdh;fh1mB%sMM@Zv_F2~KMV|4tM7JUPc^^w`A&6F`qq-n(Ept@V8oQ4X zb)yL3m@CrwP2+wpwi>VLOafCAiu^uY;591JYDKcU;zB7zSJJy;9!m^%=`ne;vON^# z#ZHUSD6KO7&Xp`=o6-!+ydnJk!FQ7azT!BMsxuXo@hGTrct0Vgv&5I6GWoV2R4zcKY1FI2gNLuP70j22!fjZtFhnO~D&G3`Oa`lJF zI17s?U!A$IHaXZ8Lh7o9?d9b!8l5_NQy^1CnOBPl}&kbm*e`FvSRO;Sj^-uw5X z8p%uOENO2Ap?>dhyY@@xVDg=4I#D8eG40X*dm2IOT<^$Frf*K1k6-UVA>S*>IG~AJ z4W#MQnlHn{dPD7Sc3tweOv;+)E;g9eRUHu5b*(BcUyY*#SgD2W^uT|CFEqa|F0Ivsc(#Ab*e;pvxhVPl%3q&1-3lQz?ks0) z8RGJ1c4JNFk;`rdZ=i0~6z}au$j{L<<}nNmCT~JDfz_UcFfoDqy_^&Q_oKO}jGIs_ zaZgt0S#%1N2P;_d{8#!EF9tE0S7OAg12Apc$IEyq{8fc#lYP^1ErwkB5s)T`i92j3 z>Lq<+Q9LLp;V;Zn_;$6_+LFh{Oa9fahfWwW_Gu4wT(|0Q{ekSXW-G(@T&Z0_s=rtN zx6tL=owLnew$8I$vsVA%vcuaaKYCmQE<8ihLuf>B{rqoI#&q;d@{;HJ6hY}-`PhwH zZ4`RO>n-w9NpU`QC6x*SkhE`xHN2davX2sAE-g7Ft__-Jyn0ecUe09Ufrby0j8J#8 zt#KjiM;lNSe7FD5p6!V4UHV)u6}2%IUwYiEyQV)D?FHh7z<@8WY(1F}{xk5wp^MVp zkcwXbV{=rZo|&HxALJr+^=2_ErsqPPU;ekYZz+WWxH9%Q{c2X?ArE6t%s=>)DmLt4 zos6fT;_2Ti4)FORG1IE9E=uucm<#)N@fggYe}H_ZvLi1o#l!^jfNf)Q1~0lbkY;s z7>h*W#Q5Tn#R7H>4o_eN#|d)12Eh^=S#2RX_ZhblXXMV2Zs^r_5zD_0i%{w!OieylZE_fi&# z+T~%^YD0u0O87ZK{^t9U9wq8Xq@kCJJ3#fE`+vbOrlsX{!7%^c_|gAOfb>*~`pr|_ z+3UN-RU|84%Vib(vH+9_WU*`w->{^*Cum;3SgJg0x!p-!Hnd=Rj+;HR&lRZ7#r#Dg zkuv&25wY;>%KA{_JF(Uq_qk!*@510v7ucht5-RWYkEs0b>mR08tddPUe@r^V0;Wb@ z91@9i^Y4<{P>ffc_p?EtW)WIeaAD)7Fpn@?!S;Ud8%%f(2~m_corq=eZXbzfD7xis znI0VJwti6tlAKVKM51oe&?poHx_#lcBYkc?pj70U9G9D(gcm4lYF?Aj&A-%fE_&B7 z*efIVTEADy^k+_cx3LxT*YY0Du(GTyG-aQ?9#UgM&#rK?II+dB!=byH$Wagq{#u%D zl%<_w#P!$Kz(XHuVCUC(_7ZHLly^%Pb4MASX}~EfC5Ynszi46m{-}MYajZJb{PpRZ zn>c6O0@Ie;Bw=QNfPxayRKZ3XH_f9lH-L=->JPmUq-NZkF}3^Ha5qLPXbPR^x;0Zb49YSiw zRd|)UK{Py!FV9(d)3#Fw6N7?>FlR{P_9qJtj~WU2n)y?B{Bbr!IM>=j#VP;VjRE}2 zJ6VjSceOal^0669?yq5gpvHm8YH+St4S$v_p~dQO;?g0hFgKof8ns!)3Xkg$KbfMj zqH<>(iFwZQwRi68OU~r7b!DFzvN_iKWE}=(P?N*&wf08z@2!kGHWDPkn%W?*I4)&@ ze}c>gJy$|gD`oFsF?WK|y2cSsQ=y>Nt(S^Ra*ytIEx0TodAaZ@*7;cf63=zCQaKx) z&PcWRQAKC&skdJqrZuzk;hvh5v$*lyKtFw&<}6>~Q#@|IZpF4iN!y{K$MYZSmSt)5 zv-34LQFEe9DcW1k)c9>jorhF}|N3de0yqcjy zg<(;j_!C#ZvErC?mS(dcawXmGdOpj2_8NJt{{$;rI8>%~AkVITD;QeTpR9qji%?|r z(`E&Ds)oo$cX~{kQOtJAD|O#RnSa3Kq@1}WuFLKLDZMF)P`CpUqw%UuYqGr`G_QKB z=j21mf5CSReCi(z0P*k{mFcIfUo}?2{l7ZntQ;&po|pfjZF#P>_1>Vg*EYx`d#e|O ztjryGTEv%mSX`|Es$mr~E^z4hjIWe=4G>COUP2j8>5`}QdoI)-KnA(@!}@Yi#KQRX z%N9Xe)(pdI@+)jgu!#2`pc=iOjOx{N{tElL>i5TFSdKNlZ$6C;>RTm+8Z<*r*z*)c z(Wo^UygA9EmFX;tO-x$;(Xu6$vNDb~F=5}Yc{Z}!9g`=|1ij|hd(in8P5i(3k4fEf zp~qeP#@AbWIk7uM4FqybP^z5m86o3yi@ZeLha(%8up^1pdU)@O&nZ2P)uz|`J{O!m zOJ2nh(at@9_v!w}Qak|BsOk`MMcUNPYm44cVb4P3hHp>gbkeXJ$`f{5tcXRxzjuC7 z70KKD`le_UpzlB_zdHzB?myNYo>ay=oo>cTB^{QxnwolDQJfuyRAve5;o`m0F$~yB z0cU)h8db@$pHTl2?&6;20njIvppR#wmOVrb=L1~vqYX$Fk!Akb$AN`YZ;sJ4)vR3e zHr7u4|A-IcfM;tiQxLxDKduYwi}vEc#khT2!Btnb z&V59#Dk`(yxSeG5$u%$8%-^8=BE_UPpvN_&ybyHj#HEMR@&B5s6fItk*E__Up{YHF z@Fw+dLn<>%R8r|z!!nT9ZWZRlOr%@B#JdsyhBSnl*rPcZmDz zs;p?k=%jo-1@0Mrf1^v0J1)SPZka^aiL_}Q;Y9qrBfeYT6!U#xc1)y+21^yegRjO^ zQUv53 zYH3IgtP@oB@~{MUNr*90bpaFk@YtG>oe?ZCid*y8;(SdvhC2RG+6R)dAomY+3R93j z*fhE}aWI`#Rp0CN;4pLbTb zKrha)5>RPBFVFyxv4WIe4(pEqChdGD)$vVl4E;9HOo+29ZxPNhYvR!Vz)jn5)01?_ zJOOZdt~|2(oDc5i-Ebc}NxSSgE2o^pj%-Rc?YAq+5|%E$yO1Y;tet1Ir{o$lb2c^2 zql`+O_Uvt3ZiPS~DH2H$9{pIyxm!THBog|b+Tr>1l!0;@kBHCpQB=x0q0Xw};)jCt zt!R;zv8!-F@7h#~AnEFLaNZtmEk*BR*SCU1qX4zE6;AI97DNy?Ve1FGXsr}d& zAdW+-@|)Iz2wi07fkI*H$uhtMru#Fb3aYPVJzCl%gaUiC^~Xk57=z(h0GEBk#yQn6 z(PLgJ_|USr!_y6L`n^xyM!MQ)%(e_uD874Kq|vWjAVLKHLfeRhjMywV_tLwS>eD** zfo4`MIz#)AQ@IThChc@cI zW8M(RpbA=vu(;RK+a!BR z?N65h6&s(?r16*mc!#+e{*ImcfW{7jxF8{LI)Xr^1aeRf!MJW7lXV_B?dQ|E>6iN z?&A_bVT>F;|9bpxrP)jA#5}sw-c-+%QsfW7;T3EffYaR`-lX}2To&&u=%-WUy#=bj zmJQb~GR3ET?b>>8R`T-gcJmb1GRDW;&!2?*>H z4qyno#)l%JtrhgFCT-r1c+QE+CpQsS0p z^E1#@_8e~Pz3xf1jBGI^t!ImEcdSVmJ~xoU;!M$d{M~#wzDtQM{SiKseOmT9zZS2i z=qXL4q}}c#SpLKB2Fdk*R(!}$n=fJ@X=nBC`{TNXQUnF1if2=Ag>Ur5c>@htzx<`; zY_Pa$Iv-@=bH}8&EkxlDPqseK{x?O#}r z--j~YX=IVVc1X=p!)eUw@3HK`cG!>7pDf$I+v@w)Ar!nsywltS_1fIQOl5sgYrZl`|pFACVLkZhmRiphzThNVI2{hAo`mhJ>&gjl%SdL zT#puzf2kY+w5V7PI(=eVuWqT~Gs8NE^vm9wYwO`3iCig-KBjw(slJ$yF&W(b-O4$k zO4hT;cpuB&7!~u%-&kM{%6qMR7XnLdqQj^}m_(BMHj{ec2xsn7{`zN{vu}r|DJ|G~ z-_unCdBPzW7Lw~|u_*_1+EwOgM^h`HM4UnffdW2D{QUZGR;|9%n5Ut>Uc~GC{klVi$cksqP5P28 zj!3G7o?v!$kSG>|_a1Ygg~2>VVc4v1ROTk&$I-|Zr^S6q8`)syMfYYa+;HJ6c z$g7S>n;YYc0t+SXt0VhdG1^d7(RHkrD4HBr%$97KUGEv*YcBNHoi z8E+=jP8ZE_%&guis~L#VLDA7zbZ2|J752gP#?trK$EhKekppr}%-uG`T;;|ZuJ0vc zBlPi56jMxw5S~_mg1?>}K$yM&loP7qL>jF_k<6qNfuD_Zxor6_9P!@EXSR#QaZw*m zpl=TGB2ywGq|dzLjO8jQO&YUATcU1VV(mC*vMW{3I2cMN)@u*N6f=#3A8}V!1Xc3t zJOY{nGs%=ie~y~HN%>vV;}g%CZ_;>@M+S5s9+q3lfxE$pb7porJCzp26c(H(^!N6a z^`3_I9C-SXP>j%YO2WWb!3IH*A$i^LF##N+my8`5-3-XL{pcJ>R1w-OsT|@{uoRgyFftpyEV*n>Zn)MKlSpc9CbcQ-nsxO` z?84BY#mKMZRC$ub2#EOlLIeC7zZ28@B#B@Mr?NQiahtniRY*bHNv@|z`)~tYN=eAJ zg#3d|q%!rX<(RNAto8BH;j}F38Y+E8#?Ds`$Pj(M7)IsEwkfpc$u3O%UwvGmI@Z8qbcwn;w~@RI zlSS}q_L|MN7m97x4#K^iWq?{MvxY50wT=_`=N*A2K z+DEJX=wIZG2oG>B4mUT{Rss}6O6*5nfZ*~c8oJMOLu}cf6Wj~CRyv&Z5u@%6VXYJ- zU#8X~__Kz#JO@#Z?Rb-0@eMjG8%xc+LQgf?{(2`gk_ zt4uSaKh?*z{c7KWbz1PaU})DxZdL<%I4)NAJ<|cCToriRx(2|8Dyb}&o|%4~bTsT3 zjaStXVIj9lK>nK8s&@rG^Oe7pJye>W$y}`X!Dr*7CkuNO+!eDj*)w6~n9Rvp;nA9= z=@d=vWklZ%g|Fk>n z)%Wz-XJDy!qj&R4nGSGkdpF!(IG)pO@GON0sjYZ{yBk=eDHu@ac_PoCYuRq8DmmpO z>e%LW7n3>U&gB1EKs$C~$=E8OZ7zzVNcvUnBIB$`J7*EahZ3FN}IYQQGh`I5Ko>~yq zlY92Uz9RgO4uVj1~JAGO)YtPxtVsc7Qq;AoUR+$i@9 zg}Fs}{J@r}ZwNGrDpR#x-i)1YO}jb`#ASHhp%W872m0a$MJu|SNpVeU=?I0QCPBCk zugBOG!&VhS12uRH+ZGI%vJA(=1ZRYVCmfwZTp6LtDvWDk^3|8#dIEg{k``2-x*%QH8`M$9OQ@pg^6G9!6>A*fYIig(vt_j|+>mL(YE8os+QT zqvZBb62Hs0&+4w%6OCt(2KRdU_sKsYQ*#B)oTF;^MDE(nKizc*4{h1iyR>C|E%P4y zFrW}h6!dF|T>I`6Z}MA-Te9e3FNsngU7AzxTreKB;pt&JLjO)EqO~l?@>~Q-)q=!b zcukTI`BVklH~VNw;0PI$l>z^qd+QZsPS4U~_zofynIk##<`C7`Y=BC&jOw@oDRAYZ zY7iIKV#TO@R74qSifL_u3I_U)cvit3NP&G|HfzbT=m^xkc?96=y#z7#e5{gm`>Q#j z@eKUppP1izbI-3^C~tE7UVNC(^^kByQ8QM$I@?q?zh4sbQDf{7k4cg;FXDllc(FUi zgP!vv;|V{7%s|Rhjg9jmZ&8%Ri1F*;1(2R%DFXLF*|Ezh@4Om5j-$ps=!jhA<4e6l zq#U=#WZiXv^%)yWWFD#n<+usmx=~Bi`F082hyIubd0n;EJbzj@mr!ZaZ5AC3DM~cp zUJa|bhU$-X&!NVVKa}$xw*n4vE^O-fiBq;Qbrlw z#vem-G^N=mQQDsQs4Mwzf01ox)uv`ugW?!w6x4U2YHEMr*{T1TAUu0tvE&8jMaGKr zwwt4|jp8hW1Ux4a4KhN4U>kPW>ua>TX7v2|%>qUs>DqqwnsHCCZYDj?Eb^w9A};Ou zEgi~WF;W|apTEyI+3H*kYAnU@v^_RcH>g>uYN@?${fZ>%q*O*3pa$=tz#`O!oz&D_ zwSI)JqERIXF8_Nqmr9k-ydw9(hPp$@j^|G(^w1HfxgYT_IfEmY%?lKS zgbK~WWm^((Ct(Jw{q8*P;%}e#hseCXgFj>#9ndFx1pD~eg;yn z1d0lGW=_DFb;W5D0&kxYhnSvIq2G*zj!cxRz|+k+EC3(e>Um|B7=FP0*R2Hx*r}EP z@vrXPJ>!w80jl>7;(Q4SKB?XZO+w_SA$L!PdLY8cZR(c3O^C~256T*q>6UqO&Ddke z0Dv-P^((C1!|}$~ql5mXTRQ~#6I#0A{u|5YH%2J+#)e~~Q9s=;pB=c9jS?Xfrj0uM zfV>5~k4YFK@kQlf?m-U}o+)^%RoH{tn1%=paM1PgR1u9VyRhBa!CAO6F%1wJQR>rRphhO&-FHSj))oU!mE@<3- z-6~sV2#(!~3`WH|3#v-iv-9``XvE*(_L#@F7PIw0{(3}CBNS}9>Y7AFKujHoKjo-S ztUCH=@_)sFS79L&>%Xy?3CS+QqN-kZkup*8wAOtn0>|> z&VVnd63aVsbGy6bh+cGZB^3KhJ2}*jj{mc`#MZfEK8u>`(FK&~0%|S2X&<61V27F` zMC)>5Q6uS zGn~BzV|N7{Q8?UZY9EN))dfcCI~vrT?%e5dV{rG;lKiWFB7=;)Q-7g<6*)Q+z?1WB zInQSFC>jnY4C-x%`&|LZU@pm3OS8p>Y@-eS4Po&!Hw6a?oWa#&vv2OCp&>hAn3_E0!P%JCC8*RNl%EYC<*Rh?60+2J<8-Cnxhw{n8t`s=uM&+aah% zL9pBAZ)PL>MBWB67us%cuSIxFGN8_UOw#)+xA49a8H?F*2l-ixVYs!3vR(!9g|f26 z8y0He!Yb$QTOcF>4wH^JlD!&^rv~2kxC>EdXOiE8h==42Tf{%O%&kEtUxDJ^M;fCN zvaRkukoz?5DdE`C3_i*n%%nHY{ZS%*V#<;a8cnUtnGd&IDxYe*`N2w2K|+ElWc|k|8M9l|uG#6dUh;!2ibDd4??~p* zqu0~5NGlpi6VD7~q;e8>;=Jol0OOS2C#8oUBuv2^?QJ=L=y<@;t`xhqjSQ7t3t?m_ zJ^f}Kn^CMZJCZKcl5|sEy`%O3G3YyHa8Ebo7DV=m%B3HA{va51o28n?s#i4#>Gx26 zKa!>vNAsZwVVM@yU~*skS6pB8)N8nv{TwRkQ_F2stF3!j`QsDt2Eg97N3_RRjxAoj z+ZwdrrrdD5mwvTsH=>yGPk*X@n%`=DkKZ6s~NuV2vT)iQG>$!@hbozK=~ zZ)cn8PJtv%OYfMEBM4$~4^kc%9?pvJc+0zf1(?oyqt%;2$Gf5?qi$w_p~ux zF-=S_RWH-NZ*WkE(4RJVu!*i?qQWNEvYHZ)G9!FZl49Rf2r+K)=4WiMEG9g@ZBosT zEzcOMcZEEDPU7_Asldo!Pr}Q*g^-#{3Kr~0G>x|Bn`(oiCcN-;dramIP;kRn(O&sU zat}}eh%o^JSZ%@DEDMA7lJ*VdCjbHAG zf6Mrm4++O|_qkNJZeO)bDn{zXA!pxZu_$`4wbn+*&@^|na39Cw1c==IX^ge-9KP8z zbgh$wu#g}I+omAV8Q+CMK^E^6g&E(Bj*tz`N zb8gS|1Rj*Eb~inRB;6huho~qJ;YGdeUqWJ!UZOcZa#TKs`V54p^==QghMD!0fN15n z6QJ9#hYbj~Jq%*iQ9He(Q5sc_$GQq`OKd{VR9t5O!n>%p(g%LttGI8P~1C3qRR*S)EDFR*s@3CHD z6Tc)8w0@gx(fMG?m(gpB%%vvb#r}8O+si04XC%xZQq&QX*=|MM2b{$z?#=qDucQFQe{Wp2av zsC!t9lp121!{t&#k%ik!_Se|D#2RO!?rfsoOg-Uv>w<#-z^dFtOgUQ|o5eSCmLfdv zYg;Zw4dw!I%mTG_TVGwltac3A@;9|P?=GU zfX+b&cx#27^P#aw4a6SDOJ%lZaKLw>>sR=lS&apGmfRVr1Sy1+QLj87#pg|h&qJV5 z{zCZ9%B-2G+<}VO={8!fD%?rE@R*=?V7x9HbyZ>;5je@v|%&o%ZF+?Nd)V z1nl6aq--rDaAg37uBuSKN9tYt1rqJY$_jGsGAu z3Q*)*DlD-bkV6OsE@Y4F86H-Er6(ddSp)AO!0&J{rRy|#kW3>RGK9z{P~R?NU8dtx zdP(82nn;&Tv!;D6vc%YiJJ6w}{r3eFj>@I0Dc`ke@gEXlwLky;UjPZj&xN=AbWFeh zX`hc1M!E)krh&|AqT*kTNxhX0U)pw@cya{(ru>ubIdV`N^} zqvtLFs@h#nRq4aFwRRfxqva}=HdU3ez8Wkze-g%>2MwrW-%%ATs zsaZ`s6c6AWPOb$J<5-Wx6+pcV?>^QCmH^tV^LenVRpMGhPg)YPIG%N%JH@TyH&1j> z(LQVfa&cTIaCQL-XSYMY7H}i3OIJdxVR}PE0JZKQxK%3OM`E#5da(+h_zwPE!Y_eEewYf%b z6|W-fjGaAXAVOW*Z+6CqjWVG{-|<>MoqPR!@)^}YsciYJ)N*uw%a@mN>niEcC4<=$6@fhfXO1dd?R>Q|-sOxQwQeEXUX z3YnUDA;ZaR$$V9QR$hNavS()!6Vtk>Aq9t6omau6$vxl*Gn4WPZR&`(S3QCg>W;;#@p7LS|XWF zfa=g-qm;^9c!BO_lJ7Z(NV(0|jN(#O@snzn1qGrs4&!aHxz9+F?YAKB*OMUVP&(Hp z)Q^&I5b{~Aaq%^ueIM*tcx(C&Z`K9D0xiS^^mn|e#0x}rk`A#n`AcIRcV_!H#AzJ zh({Gb1B^z$8NmQ!_8oWz))Lp(Sb&;uMzbOLYGETkE`J=942$5_)h?@o`NVNx=C5&n z_K+If;uMIYSLu4LxonzP-t`_u9a2l&*jie=WXVfktcL)?df#;)`luh zn*>TdtZLVtJI4Rqj^Pdc^&S0h!IgZy(q7N>OIWtwFz477*yp!Y%Xw#a*eb!IbMUrZ z6BK(1vjH#xB}hSJEjA?y(A0nVU=JpF00ZUmKd||biM?eM5zHSKcV5tJMog=2;cTL5 zrKfFW*N7xl-lPbSKaKdI_+EL(1sOqa#uj{lX^qOGU)watFS=+GDe7<~^=%HC$=w}8 zP)r{Qa(hZD48@MXwj*%A1y!tuO81-8Fdw`s-Oc$?G&3hqhlM&F_`0l|vk#V4b!@P_ zGp+sfoNo}m40uG;eVUnTm!A{w7kR*x(iRVlRFh5G7w3|V|K%Kko1NqeygHMs@;z!U zUU?|(xxW%sICItpAnjly0s~C!5UFeH+AE_*2OgX$qH)E0ceP+fCFfTo;QbrCV-|BK z_OJ+}<6W_Ut$UA^=?vm#H2tQ!Mx$`XVSED@TmyevdM_5#=5wsmm(j8R?S3vOvSR_4 z@yDlU9Va0iQ@m7`e6dgfBlrn8X}RQW^V6@){!LTI{oMDYhI(nW)uxa)=aFMF7QhMN zwic}7(~ENhei@)DEZ+XjYHK;v*k5>TT+WW)9w|8d2Pl`Mc&NvjWw7-04N3oxlJw zCi-ilD2Cc0BA8)kwIlUBDb?$oaTbgRnCa}_pS z!S`Jd>k%Uhgdh*3qLK)8rtl6UJ1_lf&H}XIlQjOwaQUgXD^fdp=Vd)tQf3!?;O&At z>^7+{p~u{Kr%q3KQ~due&(j`CVqfA9ST-sJs9xCJVcVQ$<{Jbq$LW~|@~xEQoYQ$t zY$CcO0*yingb5}{c0!CIn0U#hUyBT;55e~Ag)b0XheLrIm#~NaT0qId_w`c(xm-i8 zIcOo7i-z2B!0id&>9l_F{#OVGt5gZQ2a_{XO1%Nnj&s*0x8E#i-*lSISDLKZgH0?BH&opud%W|v-d2{ui14wf3>j)XoK(!zhE0pm=eH3Mr9{D;Pw89U$1 zOz9qafP?DJR4_V6xRDr&ikk+UvABv6JyryJZ@CV$#r@as05<1HaCJkdW3;7z4`a6p zt++w1feNwOY^FfE3P2DCHqd=aeM>5l7EN%dpr*Q=;;zdfihtj^R%>6_|6SP+N0|vj zDa6|{7}K8iY3JFxt=zf_sFfWez5jQks&;%y@FJMRX0kI#{1}rI!>bYQiDxR{uTBQ` zJDGun?w`$@K^adX8A9WTv2L3%o9$Eq8CjH*#oga5)pz@GhDAP{qOvX^X{y=PE*%ut z`!GCYg*qSI`A}aVL=9YzzWb8*pIUYN^t>oXJQXq(Or%OHu`fCV>%O}1y&#^baPO=j zVQ3Ut(X?9>g9e->--RlCe=PiE1E;i3rpLPBC(n|t!JN>^ZYDNV2-UTjdQO+E$BM(g z!xdIZD}qS;UafO*iCoZ{bEF~gz7F-{UEw}h2jz9Pl?>q!p6lA3rk1gL*sFVvIV&CS z`)%Od@!3wpOsWJluk-1vGUDhg{BWo&luizN&$PL3L!J#TEFa*pHL-=0Lxsqm(jc8t zr2E~A>SqsA@zT`+1s*8nJgw_G3hptzYYsNNjktpXGbc#hG(Ax5lke(EWJv)%UbU

    z(3m1?m5 zZ#XN4v2GU|4bBi1anwAKyM*O4X&`;I$d}Aj)uw{IMPIs%)z1$i;Yf8ARK^mpln9=R zV}sr!%7?D0&OUH|0r4Vwkx_$9q#kG8`Z8FRpPCFOx!)Etc~vjwU4QsFQg2K8%pq-e zmZ$OH$b9_cW{+4C*m~Xs7hmbbUFPM-2*m-^#CR(taof&wNBS&!|5F5{0Mx4*8ox$$ z*@0N@bD=Q}7c@(dMn$4eN2(_Oy}6Af3h+N^9xhAmDw8mO``5Lq-C2Tpg#X7u^ayV{ zS7nP9_I7o5TYS_HeCl^GTxg~b)OH|?Yq>f3*FX(GY3HV5^Zm;Ga>}?sJlU8q--^e( zd1DP<|CH3`K~HdA$qcDmtK!fBh4&dK^REUMz4IC zVnYN@?g`IzQp~yk*1)rh8e)`g5+LUGv`N?^*jV-RJG=Y)mv3(qMhTRezGKDsO~y@hu278uSFjnu zN{oX8v^(9*temZ|s+u0hh0+6(j_G-2OPx`xvwsH8zbm!M$+~-7GjviIHSwI``OTZ; z*OucNe^mijW=Z$rAFu*EQC;x_c6P?=k0p1FU9yFQv6XVYb{`Q7C(W;zjCt1iAoZ7> z1J0;kskzIb5Q2Q>08%IH;vL^zNrcy{!m9lmx!@FkY5Q;M;rR47hwP1iJzCv9u8y-3 zLGdj}(YLEWJguk1U}H>2Dim{Qw$Ogcah!sBZ<5Wc#JtU}Flxv}NY+JirpyWU>EULT z==(b>huZo&%`$P}`}uLLLU1gQ%YH%{D0o+L^GKBJn^;-Fko_IwhFEZ`h1+oJ+UpB6 zi94nyU~TSGBcL-cUmzQgb3Zb?@Z@SFIAo6ly7P8+!QkO7vp3kX&LqJ&Qy^QGu|_6$ zOTh;-?__@#n?NXQC-roXo9Fp{IDfqM7D!q?c;E_kYWsF7>mL_CTf*;*I~a4dj^iq5 zs>kuNqnetTci6;;$BISu_yKwz43yUD8Jij?48V8Lil%CSbuVa;s{utR3-D*Jvc59D z-4!A#L~q1UZiP{^eRwhilD>lz*2K>{RQDi9D9z?>x8~1!$lMou{arp*2+t+v)D*3^ z0|>&oA6ZeYXPGH*(~Sr<=flQvV1wl0YU{s)X-@vRDZOG1#`Eb7OBw>Z($$2ThCiJ; z1j8|WZGnXxOmmR|!0qZ`v9%gCP-v3X;L?Sp#(`U)c_9a_XUGk27KM_oL7gwo@8o=P z=-ROYP5nWjjU-dx`xW?S6kw>|$NLr;6xU;5jrY0_+!Cnaqo7=k?g@Vw@~)5eh^^x) zDSVS;s)tPK_q7;a_Ixj0XLg_WY5Uf!Vx|lwmRHI|gQ&GP;P!a_*PXWSo0;y6AIfLE z=nAZgHC$>g92)w8$B24b(+}-u8zdKda^&_j7Y_MK{S7hJ01e^pE$v z3IE%Kue$ti=VH)QB=YQEKRrti9w8^YH%9uLYznyQ?M_4uyT%x}q8%)0)9LfO;!$=R zBa}MehYUiRWPQ{Gxlpecj#a6{6$$kzv3;(l6W5jIb0>{!b9ndjMVs$SZC{gL&&yMr zzO0qbt*`*+UOy)F2-&(%vr$q@GoiCKXX<;LtOggBhPOZ33?i4#8*d?p8L!?CStlxQ z9Q;Cx_jVGB%a<8z|$x~Yh zs|!8u=OZwmuvGf|%S5OMuFy1}8=4LdsSeNxznJsxo!!IL!PZ7V)A(brR(9AKUb2P z*If^FOD`33Ph;Ind#8w;@q;ovRQI{=lw`-o4{uVDdU=g&*hhGL`s3fhshjW|pMW%_ z0$LsSH}9Q%Ssi2^v_9X?w-I-=-)I~lVr|?^E>KWVr4sK=EchO_ubp=>a^fLM!<_8uaC1i6ijhwX3FovuJAWlFn8ruTkm0(&y0;CP>#4h{ z-CrHuwnI8_`4@l0%im`f#ip>dSI+$?{;X6xRFs8-QGI;r)2r}Y@@C-L@UUFI>gQ-> z&(RsqK%+S?r?$QN4^elxZwKq|7n`_eIx|iFt3N{WI67l<`BQ5}uIt=i=eh{vn0N>CW?Q40{wJiO4nuCNWptmcG?RGMGbX1Ctj${VL|Cb} z6mLnC|5H&keFtlQ!29rx?;yg|XXrdS+_F-q-2NW1tm=p61Zje{ZcaOE^}rxLVGPx9 zl|@Vl9AfrrLXe>H>GXWZt6|CpK-o9NQ!2%1QfEsiuUO=6;}xBxk=?O-O66~0e$~0% z?@mr%eULVCwaG8zpsX0?!xotq?CSrL_3oKQAKZ0*d||=X=-L-7oiBAX*>je0nB20% zCC2|@^3JS5m71Ttne{tkKKK#Jnz8zZ+3u#W=yZA2DqdP)^F^bn-+EsxTAN&$4Qht1 zzR(ML`AF;vl7F4>+L58FYx5+*%b4W4%JRH8HW`8Mme2}Ldkj1?n%V+ADYlz19b1B{ zi&z*nm404QXs;JBRTG{8(^dW&PT($mh1J%2VO?{~cej&Ox>veqeBR{#!+NEBtHbhk zcF)OHaZA^UsJn5tS4Ui?4w4^#iiO_%+k?Aj>HeDddwcfV-k#x`?R0|Sr3qSGqR;?E z7yVoZSb2A_?9@CIIw((V@*>^*@6+lJi-@9kM< zf&s`^rSk+kf9{y4_g7jF&;Ph}7Vn21pE0492o#2;|< zT|fq_Y#`V0sru>8-?h|D*sfMG=tBO~R%z9qsxT7k9MLBqG~R-%qG)}L{w{D|m6YG4 zzp$;lj~y1M7i;z^6vReQoc>y5-%L72H{h7n-k2!85Ibvy>ea8o9e1pI%;ZXpHTuJq z>~fKg+1h}F!8=n8mvI<&!y-MkMQJ{@WjMrzQ=3WCu=ms@6DK5U|>kMb~$!mh&_&P#i`)OvEP_*EBOn# zLy@&MZfYy^PD#QBp_3ldt2hUXO$4LIS}AIC3PFgzo0+VBg4#t1y(QyS1A36ZSCciQ zY1_oLXGng_P(b+}r-A~S{=S^Q%n4?c1Og`hAV>lCjA(TZMB|o(-AAi}*a$N&p;_pM zH(Js0KuMN3$L!j=o+xMyn z`1KE5KQyIJx0RBd<(8I=ziA&2p9kl(y7l)9=WMHgtm_?9V3W0bXLjy17-Q8<+D$~``xGq&^lX5BV)fpj z?sUqgL6K3puHo==zC64GaGCby&A_avZlfD!^8m!OCzqI9T8s0GnjDU8v0QJV%zoDU zJ?j4ne6hR+s{ubKuE^yTG8CubS7y?BI9j8lvB~2QS3in%ghPh%_+L}`N;{;Z~BhbweC}KJ_VL7VgH7&()eA-@=?r3-YOw~ zg3Er&>yTSIK0dsGdLJ#u#>AWb9|asi6E-CKw*$1p6JOLd-^WEU7TIp=br%+q0q#lC zHV65t^3U9m7Lm?t1U2P>@EG^&zwOt_JSu`z(83fSd*0CBSNmqPdAan~Co2;SL)RkS zcp^40?`h*Pg8{$XqO~?52rLXTN1d*do+X|LHQv@M$Hyc?FxrXig-?Hbv(sAB)*On` zJ)Fkb(W({5BiD!@ok1j?#1>HX*j553ycydoZ4;ekor!Y+YX@$b|Kz8;f`l%mVO8(8 zrs2pGa4Jqg#qom;ea-#mc319V5UldmEkD-#M+3`j&Iy&AVB3s$Rr!X5bZZ798UiIFVO&ENTJgZZ*|^*v@JizgNS zcgbvioI`1S3Cj8iEgDpYANL}cXAjPIPRkY72no_F{fzSzCj}WjOyN88>yO=knXbSA zG6NV1v!!Ps-RI_2?f=rE5J~Gl%L1w#bNr*PhthaW=*}FTpO~?NG5cLEBRq{9Rnk3V zxi6s)n0h~KP`OUKZI@mfboQjMkL!h^?9i_6d=41b6`}*K?LyuUBu1S;403Jm9XPod z_Po&;hhPVkb-&rmk@&-lVc~??V=SlJi&F zY4Zk@?hnW0_;3F`El-_qai>Sd9@~9YpI;^awzF*8Pri#3bz(xH_xC0E)(=2j1kXzj zZ>Xv2zg`qahr67Qqd=2hB{U4hKA6MmAydHbwkp7A5*UV_nPw%Z?11;aE@4AoLN$SF z&ExGVPvn3OmQ8qbR$Vy(r&LtJURl_=P+3ZD`Us-3nMzG2?LAwlMUBU%RHbxanhJN+ zd(34HsoWEoq>NvCeYDQrG`heAJuvR#u zb724Rn@hdfG>PXy_r!?~gu3dk&P%>t+)}h?uv@8cfoJR#_7AxI|LrseUexyK1)mY2 z4cE*dE~+N3=*16WY}WliYhTPcZU6MM63THO|Ewl=>8E|tYk?L^h$%z~gU$OOhChza z=g7_aclKxUHs_2-vpW<*6iH{Fa6+;a`kN2Tq%IPgkSG`gxoDt8+oEsS31U(W+em04qZpKap(iLLGh)XzV_=T{F3}2dJLEv1RoyI~`H(0gK)R|6|XwmgzD*NILHf#1ZgE zZ87%H0MR-?BzyL}P8(?uSTscG;y{sbC_jRME$dTF#wOKOmp98`nWIk2ljdmYuZ&^Y zRgPCuL9%B!IAesqxS~fDddO2M`$o4o`E+8S^nc(*^s%<6!efW#xssL zKB|-(Kr~I^i&8S%)N{+;Zq96&h_3>tGmYdTG5C#Vb8CM*i!G(vska`NYm1&leHo@a zD0jcTN+lVrkk+uPs6o*Q+H$);eU4{PfB)f{D}Pgrsg&Lf$`Zp@oE+6UeD}-?%~^yy zFQdJ&cUKuU;U7^j_w0#!^}J4@E{^?I(8U4R;&daHd{Wlt1y-Z-iC5TKLby znBD@NMG*2tYDJT-QH{_zKNR({y{Ixry2i>imy+fjy)SB_E(CH+0sDJ=|LZJ2*!>yE z?#K1}MTfUtNC^aO6-+Ob)Dg|!7D1HYe3!`L*-SiLl1d^aHeAg zXVz5&=vY|@0%BgH`TDu<>N*M<`}$QHEUK^oW{7=eSnv?+p4Q=5LN$jTu3CHSCMC;| zaYmlIxwd_JUOW}jNZrF<95izVyEzex43qvQMJ@Yp)<+4475T4;fQniy(x30^EBlKV zE;QKmC4t0_p}c0tQ2*4%DjBMbtfFu|2>pc@vpa^>A;vGirFLZNipo zrVhEQC3*Y~_Oi>!n4pV%vl3`V(iiqnZ~2 znm@M~mqo-siOy`DGELgO*%`|!cAOLV6LPliczeTG(=oy(c*n7s!S(3N#Zp<-5N|8l zl)78f<%UxE&;s;FoX{~6=Ff{WPO{K>?b*H{#5 zABIOZ9##dt!c_qhV^?5JFKRaccon{B*XjDglQp(c4a*2!2{}Vxh--A^dYoFOKDO1I zQW>j_g-DJ4nWw)>J|H`m*lV%PvTV<@N|4Ys^}nY2LzOZTuW9$C0)J8(88plrxj%Qq&NRJcs5I?*`UQX^BQcCop#`-d+VG&h~ zO&%<@Z*!>Jj*ZXDF;?H&8fr3o-ZoC=uV$UjKmg#Ccg)t6`Pc1$Dh8p@-$Sh%YOg0 zvbKPv)-{b#zf@(pRO3CF&lPm6wpjn27s|{kSkJQ}?tb^LSA&z~)HLl4%%M5$MdJn`|{kI#w#@qTc2&SMrkfC zi~Nts*zPOgB}@%V@U{{_%43}$mcWAb;F9NWz47P?J1>6Fs_nu?Bw5C*(3yoYz%K@A zf3~zrD6ytVAvvbItK}f08bSH?wbEnrbqK(fnD(XGoX*PV-FBe)R1vw zb?Z)8ZSo`LfPIE4uahmXKZ;cBX}B2OyWI7o^t!9Yr30Yaxpn!YC9N%GErwChn%aK0 zC6)U&AR}Pzn=%$Iz5B5)hkc|JE>6|TgSx^q7W$MfeVH;27;oDttzut!6F#ZxRA6ZE?NROai@ip( z9G{oJjkJ+8x!x7N7`fli4?&?{G%Ga$?d{X+1fOec5DunD0^kB+)+`TQma!9)7O4lr zEHg4AK!rgtHx`naYmnR;=rwO1DKZ$)(uhS@1Im!dS{9^!ys;>3R(w zygvZmT|Vj8h<0L_{s-T|afy9i?UZUs$JY-XFZ6`|Ks13MjT+=>%Jb`> z8RA~)2UrG;d$J+rmHI$^jgu_!DLBJPR%V@mg3k)WUo>&|oU_==RP0ZQ^8Gd%u?sx= zhdF&=4W56$*p0?MuX;M-xyqAT+*xLZ``1k^{yCnh3`IxcoOL@a4oL0msFgU^3 zinbUB36&PbsC^0*a@DiFLm7*?#?{yjYIktq3R@nqXqf(cd%|KiI-tgJb{fM6*9t(~ zsm!@qfeZqe)wJnmD@FCox7_{cd!`!A*N-V%hB_HN(dyJu#kev6O?k>e1g%Gem7Rh( zT{;de&7Bb!m;LQ_UtjbzVIKYNM6OkJ!r0LvRi||`s?71-m6Pgrl`8h`O4}0j8K?nU z1;?V!j#tb8pR&HNTV1JC8n3xHyFZMw?ri zxqr^@$3x%?81iF!j=(`uF%2ckf}%#dqK}v?4bHbATehALR%=kF|@q#FUn=nCVeFGa=dRm*VUS1 zF4Q5;gb^8aJZ-~Y#BcHzH%+JqcR~;iEe$?-*5UH@?w55DKpBLUfCbFs~@q`VSJ~wmM zjK)S80*ExT9438WDEtW~VkB=^#Cy}A6K>M=L!FTHYhzd0`9wmxiNJEB+`!FR>N2O3 zDyhe=dAi;KcgYWH%x>Q9#Yk6~D`Qo7lHS?mgBS=`o+Pprn@fXo3sIZlC;JH#q^%W84`EyZQ5y9# zwp))p<1sr~Rk&swj!BZ2vyxJw_7z;T7??w~JWQo$#=~y4CPB{kJp3U&8>6^eCvQ&K zU^4e|BXl#>G6e|Z7lKP8A9}kEXCYqvW5XOSlu~*ij0*w~wKs;2`{F)o z$|fyX9T%5PVn@K`0D9+JDKMi2^vwHif2Woq!)X~g2|LW`5+*8&+lWoqXZCbj#Z0Fn zRfTuGuZ2zBDm#4mkf)bGAN%jDmy5zY=(B~QPewEg0SUCK>=tQa-tKufBf6$I0sRi1 zYWhVO)m%P4ZWqK-zji%7m8Ul5aB7pLRoLKknW+#xv}?|p+~EyoX49FxAS3mrQ4<9R3c_L{|WNRcHlM_xnXKDJ*DF@h5|YIKu?H*d`a z$>oe2vQ8R|7#l5+I5IFLr2jC*Qm+>t9y+x#JGCQ=a83UT)O@KnA$M_zN&OHQT^TlE zgF`i<*ru&H;Pp_A7tIGS!oQoKW~_auO#Yf=G&Y2TQ7VL`ilumhpAB04AQF5)9FeFc#`PhX%q6`;8mNyjA~L@d~QN`wV#%#Xp|cJa^zaas;1)2qAPX+%8rIQmA|#lu}fHlOxI^C$=n zje?YddQhB3A8YR0F4yaP<{^o7_wTAOsyX>Bww5*oze3Nev*2Np$*~pY3wneab>XI3 zE^DGX*k>tqK>{yky|L$Gzw!UAlIPUN9FhhZ`*p3k&n?tgg(=XwR6g`dH3T5&?I``r zq4S>)r%mI#;zj4ayvo5bj;Y$j^{DdqVehZ*Du>^&gOC!R5}K|Hnz6+zKkA?#Jtd(u zBIQ{4;dtwIAc!nXwy}QP*swDL!eO@B;cs)b=ewOB0n++G|2S_d?iHU2GGyiO?r3n5 z)WI$|9scJ_#BD4oR_xG*iJ+TwzQaU<_5sV^rU9n(0As=j@v_a$eYFUNxL3xyMh{8q zdU#CRBIRYW{t~<@BuoARkk1SZL+*}1LNflH ze&VwjhR*--9Mb&QJxeG4^Kot3>mTusz>NuYTZ^ZV*R?Zc)nqPD1Za%tmHf#i1aeOz z7|ZZ#|D?0HD&+kGKW5p@KUzmJD@-kk^t)g6=s*32^i%^gj&Xl4xN+SgWN&hTqUS)F zJdxsbjnpo8DZ6CVlSo`=@2MYB>V9_$_#={Ei(Xo2X|GN}8P+@-PwrB@ zenu&Ru}p!_O@m(9mNNuu`0FDF46qaDQH#GzXMQ7Ey9f?@zHUfRt~qtW)27X$HMZU# zSvEMYzuBK@thzdh%V9WASm9s;j8s6%sRdXaRg~30>{O5(>l%FR64_n@R~Zps_BF`a@R$^|uNkE0mi5R2{MH zQblkWiqjX%bNe}}?FQx8(sOpuuFGC=70_^#PM?Nr1Sxj(@b>-D-DkrQ0vp`+SH$dY zM}$ijZd_bbr2XeY&YP`x)m_pN36Q0Cgbx!PWF-(2q1g)lWmpALV8O`8Q8;L>rA9n~4KC<9LlFB5&%z9miV2l(7*n z^8tvz;{~BBKE^EihCK^QkDnu)Jwlv1By2!sIeG_7eA()#Ih7QcB7+yAc)Xo&yXRkF zSgDP>fB|;P8O1>Lp|3ZdN5#?&-+h4b@B64%G{mV&BD%}?TqT&Nw-|M zTCR88{Cm&wN)5*Rqi|v+wH7U$E^S>oQzbVH9>18$6ZGO=9rnS#TNp#mYoU&p8q$Nl z*>r}7k$!g12m(B3b_S~~&=if-DhoN- zLhC!hoqG%i@D03_3Lv8$qm$}@c0JY*!IZiGseciGcDkOpf^?xoH4V1KCoP|r-9m3V z@HH!c9-!LN-%z|!<_k@lWDcY7A;~A^(0TjD30113Bg^^b4%NN;m@7RQnV*qvMCxyn zlO~Obh=>cmKJb%y@M3EWKKFNbbR|Rdm6OjOc5m0^Qs1iD8|mF#-zrl4z0q?BDXXp* z(P7@Jq1dLh@ z8=WF{DL2n<2EGo{H|J;oSlZ7MqA7j}VR>>ek8f>nAh#up&_P*$Y7LpefP5^u|MQ^` z_>G`~b7xcB=uEhz+coCE{YpO}xMl)li@63AI1*4(72Xy;tw&61RKx zb>2Bb{X5Dlpy!2Ofi6D8(wuW()QD`Gf*n+* zz2s#gX8mpCA~@BqEum(4IA}23?=vRBSYebFpaD|8LLZ#Lhx}PL;dsNM7(G2;I|*+1 z-bpVGP)67Sd!P)AD8PO~KbHnOR2nP&HTM()y42jeE0hMCoewW$VQ*4LP5`PD% zc$lSE@Ox)o$AVxU_+PJSs4ki3}S1lD_}?AHKn} z2_xk5Y=vZaU^gzTeC`0DJ<+E@KFHQ-B44~oDD0r~)1_dw*G@L66+$0o1_}^+y(YRRQMnTvjy!#j=BX3UJ@Y`r0C=QTk z69KyJo0v0Nz8D6-wjNA?3aQrzj7VD)0gOz_a(i31HG6c`U#7tGv4Qf)ml71eVC#Up+HBz(RNhu>#nzvAjNk z+s%r)MYD4qbN9XI-zh+scvo8%z#^rKVYmb$Bef9l;gB8ZG9sjIK=T2XWK(8mXnuJC z0Vx(lI%3(y+K2#Ee#4hod}({+7*L9%i$G4_j{?kux-2RF-SO6>y#4C5i-FW(+tTK=^#{=rD~|EUx7GsB%jLej`uU=b1uED>{N1t!A#9)7NXLQ?W#s(Tbeo$4kTSe zFT#`JTu5l|%R=_!(GKA0*Z;jI<1$EI*Xqovnk5{X6m$(e1Q`E8pB0i}syg*bT8|ED zuA!+R=P=v{`e_k-(9;ies|kLtL6Q%Czjq0$Tb(7vP5;f!l59~*Imm6lTq2|1OpO=$ z%Z><@c%crD*QXSnVA9vlX0 z6U>S>+=d$R)I#}(oJ+>A>El2?*c$DGHY3CCa^;NyX^EkriUq`vC!2iosrn8_O9+S* zH9erho=n`>JpfD_QE7=_oqnG~sdk{hAG|*mU0A=E3(V$D<`UO`yh~A=^J$v1{zE`& zBBM^x(!vyxAW%c(^?f>Gd%*LJfiE@WN5ZHJ9)xadvzK~BANeSc=r`m;FcG~B_RVfE z?F`t@!Hv8Js*HlOGi-vsKd^Q{8;Re_S!`52M(CaB(*X}eevZL6HfVq>fY9S{^!n4h zCwlswK_JAkcz!zWsubUogHYA*(R4<$hxoNsBG?Kv>JqRnSImCCfZ)4gz0oFm+rsrO z4!_+Rlkiq278xy=fK6`{E{Fs4MM$49-*E54yZ)WlaWOrVG-&!`>@y)UySM znC>PoLO0%UD!hGeY5x}e!y+8IJtDpjOp6k$bWa_DSS@Z6^w(gacmrnQz8}#}o2%0a zz`o4W1AxVT69r3&LBigcg)OZ17KHGd6+&MMTClIBYjjFIym%NbgSht4|0qS>T z%~7kKB2spnKT(;Gr-yroHf z)dE^A8k1KVTj!m_)QK__I1zuwPvQU8j1{1V=gtlNA5q*&N2PlIt#cXlmlN6wt!;^A zK73?_JcFn@mwY2C9RrwMwP|($;up`Nf-&INi~Yb-S)C^>5W#FDu*qj)PFVRML$*l- zt35Z74n(OE_XCeYEQb-RM`mJ2@Kbx8#kaOC!#dJ3EHChWKzcyYUGZNjvQ0XiQh3?q zNTiR;_0C2vy*{UnbAVuR9x_0@R(6lDg&$|A7(YF6OA2VfWq8<05;;RFihJuYWxp!i zcKwg302g?tp<_rO`!lW*;aj^K&^L}bApg_+qlTl_TT%82}YkJvS+8LTN?oq2MsOfQ} zbfoz!VJ3>}bp+ke{5VYpb+5yjjAzEz;^pU#;uc!Y;#iqqMOJrluc#NxTCl=#K_2o1 zmkz;GFkt7{^8|L2LbCjgXY`w9hJ4tm(XGD#4g4LV@#{^@nCR`q=NEhVpEUGsv$=i) z_SZQn&0prxpi4ky3+Ogt|3nLDlZs#;`EbTzcGW{E&S7ytK|-`p9I*H<4p8j{{>lnq z2@9^;cRI>+EVQx25;U)CT#w#-c~0DSaSuSyH#~{{D{L+PMbc*ED)Psa^V%tz|AF?v zDgWiYnZq=_3O^Ou-eAyCy>K+zzf}#lR8!nQx5>e37Ep`Me%zMb_~BNLTbLAZ014b0 z`2%w8_Q51w|GnQRkQyMb?ndH&Ynx`G0o#rV)|>*kFsjvPG~-()qt0txlm&yD?6*qg1<4 z%C90=YA5Zl_LqDPJ=QLzk;vk`mPf10TrHfpp*bE58o4zle@9&v;%m<&H=#{GdA|X= zr!<;PM{XA1Atr5i-t?xi!ba1@BFu33fdg}An2kP?4cZs6)_Z1$;UfV;yCVM^q@~9R zG%q$mn=o#)b|k>UVtXDu3J3rbXtPVe-u@#Rm*3FiqPMyORuKjs{~NRJD7^sVHn$&n z)|O*XwczmgwjIqO&%#s7Xv~ey7`bx0#729EY$6rMFN;%GVp1*J;u-G+G)E_U(Rpe8 zWeZKd!x3*-$Ik_$%zDTHeYuFs#Tu~?Vwz`MyqW)>1pv(A1KJQ<6WyOXo1Jt*Qb$Kjnm2 z<$0GV`I(S8Y}E3xXv0rtdW*wkU{$hYdZXgw8Rq8}#XopTHKW7RB0 z;KIBKm;>mw2;GL4K_X2@K_oj{augi}y%ajr+>#_Jaw~U_!e`wrsrCXUFFT7-0ytI)A&X|(e}I0(?MC1iJ!D@@4c7X`GWB-rT9_zJl=Q) zk@?M=Um73!W4;>1!@vFY9cx1>->+9l61qDNdSKUJiqrx8(y-S5mkjo5#Z)|WiyF7M zNq=F1jrdoBCb%O2s9MN+6-3I#N6}q^3s1iRv_!LL$R&6T5CWDjgBlq{uqEwCSWiEr z!tr}nH(t+DV*}BX>Mz^8{TEJeh*w+=D>`+r#UYf@ZJe1On;aep>lG$8(%I?ApTwDR zIK}GDBz|;5in!i>Zr*-sKH`V4?UxZ-(io?+YkC>+Axj!^xt_&@XY;s|XRX{J{1=#_ z%yYeL@hw;DJ67`rhxcQ;jV9q`2g9o>qQu|sT_gu~;J=0oJzakBHRj$Hi&*p9y4P$$ zZ7(`!-#%5tD@+gMHs|$kNV7^-&0DhSd7!qS(;B57Urq2iAOp7Z*?h=g=9hBk%HYT8 z8pl4R&T5_5EACHh#CwkUuT1JM*@C)R&9ilyj<{`}62CPQ%3{ql5hUK?y4#W36|9_x z^Ztw2r22P{$NHBtTOscgFXXH~BVJC^!m~Y8?yriYSs|mm+k*t&J51fg_!7#SL@6llr0X^S32klyPFEM`s?gIC|^9#qc*@TDrKK9 z9dr+MYbccR>W6Fpuzm=(c^5*#A;CFko>ifeniOcztD@XeI$TrZq+QyY6!)q0!b&Ff zV_B+>Eb%wa^1SM-G7h6BE5@iweaA91Me9X^`tiHCXp7Rt2fvUlwliKfOO6RVx(eg! z2GNPS+CTr$eWEDQBd!z6dRVFVXV$I#p{{U6ZcAmhMOo#nUTtdCg`X~N1vz@0mlBOZM)KS5eXLjU%~;4tQtH$#OL-fcrW}3G zlA!!a)PhCn3v;U;E#>KpD3!b=xgOm4Rm?~OG~0Nbu8F5(nq%0VrmtK7;%<))kNuCS z1It%jaYa*^9}?8>&4<#_{h|o32!HQbPd~e4+xfGBjIQ4Aa-CkMcJ`B=YN}qAo_Tj= z3tq!Cy&j%GYut3xaE0ZFA*r5DN`Mvhry2LS|0C+HqoQoXu5T$R2}u=jK)M7`8W|92 z1f{!?lYDhIuuot#XND1v7$P7RkX7cS?rQcAUSW&KPk5rxNbuN$O7yr#h zvd{B8@S|qu2BMP8dbM6B-suv9-5Hlz&0mK39i-~D^}q)jvomh}C(l(gSgRyTZNgP@ zL(TmyUN^lF4db2+TfOw+*H-H z_+u$$)mb5WecY2Pl4S8oY1CQo*Y@%Wby5r{aX!-2QeEK&(f+?=-}_or2C%sKvGu-* z7ODR++x*;^TE)!L(%~-{+SOl0n*CK(A;8Gn_z%W@^DbDRSm-SfHhv6bWR`#GKl;Ip zy|d`i@o>b-YdKfudK#QNH>cViw}GRU13g}my zHSHK?_fDXTKF^&)QS(hxEX{E5P}d$${?N;=g|B@J+ECRnNtoF>X$qu|KE^8}WmRn= z&?k5;Py^ZA7DO@i!zAGGV2Z8Hk|Uxvof0;wh0w5H&gXw^r~+aI1~f#goNC5r--Z%^ zz1&+>F?40x32!?AjUL{7xmM#0lk-X!(a`Mx)341SkazOMU!?&^@f`;XS8c!#^G}oB z9hUrj@@XN}299v@yo3ql(R6;8mSuVU7m{V35cI2bd!}Y(pqi9qi3Vi9pU-Kztp0xE zdYGTol7+Y_#K^Dz3M>Y%&OCd7VEPp@EvuM#|LdMqyqMJV^`RKrRiIp+NCM9CV{crU zW>>H3iU5JvGJy0s7+rnSY`jQC-tKWx(~=^C>djQ0Pkxn2UmpVaGoR9VT-eCtODo&ml@U8YJ;XkYps(7PMu8WiaYw~{dloq3T1?(p@S98dC!Lf z8yUe~X{+4o_?(Pws#mz*m{6ip3^g--3L{-nXObD!K=JPm=;WF0YlK*6eT5`D6`3vg zW9032qIRk6%IoWuevD%!(O;O}akg4f zTv>F`l5qHU(Qp1#A^Bm)ziGTb(Z9O9d&C-86|w(Iu%5#g70%ZG!~K!`mu**;ovJd+ zx0)T~MU?It1y}2uQGGCHe0bwpW1En*6A~ zp6P1=&&z>ztFf8O>8o2nUF-Cpn)O`R>){Q^tL6GF9GAQL(3xNkqNFU7tjtx{pDaI~dr3w9P?40)6I?0dA*>GYx)Lwcm-M8{=> zjecc6mB&i8oyU-6ABexuX1znG?muOsp*RBLi)>f^r<=d4_nk`4o95SA!7jg8v1Ek{d$9)Rlg8#C-OcJR$KQ;L6c*kjreQR^a`F^foefZZK zJ{pF#uc3CNsEF%!``taZlyv5BRpNw(_7W-TtmZjKgxdz2fY^YB$`6BYWT^tpiRH0} zw)6^JOaaUlJXO^OJg<5F)_cOsjGOz6QNA~y8rY{eEAtXD+3x-apQCy{^>`o<<;)4)?Nf&S)w} z{A@Q#&zYm+CP%CISjHO2J+e!)ZYloOmxoi*GuYhG)$Ub~Q+S=E>n^>vD>gQ@d9YsD zx$HEr^H-j3n?avp0f&K6KAnl<@9x!+sNeGzz>KD&*Oyo=y#q*otGRNl9p`ZXQoeIp zoo~fFV4q+qsF;Zu48#VQ+JH}|*4zHQjLi>51IB%5)mamp^zYFs1f1SgJZ}cVkKP*z zi~dDXJ8!?wY#TKK^jw_U7@P67S|uTKax3H~1~Y3@Z-ws`jCy_mNo0{}f-V)uv!!a9 z6NXB9o|oco!;dxv01m;qU^4vxu818m z#;tF=sZam>NP7?6w!n?3Wr@m&l!*^njeO^1n~@r2LR}8z-L~*M2*>)`UrY^a0B!?C z%eK9ERQ#3`>HI*l@@gMmSb@UKTmz~wT)^B5+8;(PxRn55Ew77R2J)Q8gU&@vcRSLL z2jv7RFyU?&Q5bO|(IOwNS@PXU6^p`tQAnY_wo=d6R0k0|+po=J#=4t7CygpT)mxdu1sQFtE9na zuQ>M`?6i5@2QPc6I0HdhXMm*I89-=l6=9x@grL_*AR2Mg{pKKsY3U9pQKTiLN}Eeo z|6S6;8`Gni;@C_vs*oEO*Y_vMFoi)4O~p@%OFf{c1IaVZ4X6IAU1@ml(P=vY-*LlT zy114r3Ey#y;KY?)T&&i)tP8ki5@5}5H*&_f2K8+P_U0z$AuFT$z# zj_sirVnN+OgLtEk27p7EJ^bqOd>VSeyJG7ncqqx}TiYQ;htc(LcX*5dvXh&E--g3( z?T&@f*E59i*SHXJ=bMlD$J)4vcfP37vRt(tnVm!sXdL(ZHA1gMh_!H zK2&(WXm$Z+gxfVSeqF!y+W&KURcpMS?h}{o_G^IcuQX4wbN#87fLCr1G}k4D@f@nh){c@=}y_|{r8C+MDEl_ z81hmGF8>KnA%q}`A|t(wwxX%V8W(z@BY-i%1rk;XOc0phJQ-ror>u$g+lkMPYUFZF|8$UYQOZgiA?sLHGZ4dwHEZh2M#$^R~3z(x` z*;W0@o+iQ)n}?6kzdMKM|30E*J%vWmeS5;JSu+e{UwP|sLh~93+d8%03;Jl=KC2Uz zV3!Wv$Q69yi5?MEGm*+Y`WdzpXa63aw9OI9xq=RVT1P%*;er@9x_)-I!T8PsR6KcycPRg|4T_k;p_gY{VeeyWnq%Wxt=LGI zeTB-s;(6b8Q7hSgu0ShLFJ-Dgge1g&G@Y=`(9|+X7=9^9`4Y+X!LEMXdAWt( zweL2BG1GQG!$r64NBJ1}>mYlyidP06LL(1M&ub0pcY!eJ-GLr|%(ssB>ktT0MU%Tl z_itDQ@7t)h%L4R@rZ4Beao^jL>v+a^Y!x%E*gzh&1{21}LX$+W$ri8+pmEmI^df2} zG+Th@r9jWiT#1O-!O;o+eM;%9Q)a0pvA_d=>QfrEN>0!H=<}x1iVhY70zHUM({To% zxt639_24U9m64Y=1DnK&0PohOWx4XL7=bX8Hc>sKtO!3qE0!;;!IrG4nAG_i5aHRF z;=-VxLB|k4s~pECn_d;%%wTFqPdU177euuxcCjAIhs*laEp8Km8Osm+;pT6QM(hbqx>jC7`WN%Cph|FN}&kH#yLh*OviD;nf-9ZHD-1a+C%^`H@q}}o|S9!e$ z_aC4*Y3oJ_oY)+*K@cEIZxx7}3?*1?4@HyZA?Eu^eh+?wGQJbiiV-(HPLfSf2px&dn= zx7KBVHm!cJj%fwL(6;m_O;X5!gTE&xbG9nwC-8Mv;VR^UagDNwA6@&4SvTz*<{;xq zCIsQeFKAKwqo(I8K72COvV!^C7RZK8Tg3#)Md`|<7Hwh}?rukc6K8WQ%RcZ41M4hh znYQO;|CPL8A`-aNjrgwuc84Gr4po6_T{Z2?N9eNv^A^X$cX5B=zvoUHkxFmRH_+?b z{d}jH-x+U)IyT1|CHre5vI>1!;r$AEbQ{}-2Je!a-UUkP-_ohQ7e}+>b{?y^O6IO6 z#B-#}Sy0nvk7x3`oT%o!*bO;TFTO7ggY5nsOYVN@N~ty}bRAwMK{E$Epj9&q>>4cN zhtgN@6%R?W@f(;m;SiOq@hk|^#C)0!79$r->z22x;k6)0@rMs$C&{6hCCW}=i!O;R zNmul=Z4OZEeEv@J8FLQVw>_6DX%jG;9Jce}=mO)6aIj%FK}6QFCvaC$@nCc(hB3=s z29f;UER&MBhbD+Jc1)wG>a}ONV|stWz9)AdW>YsQo}KnXoHiZ;$RWpy!s{CBTe6$0 z6f(`0*m=L!Mx^Ds-X7Zv{CVd7k>J%rBLSk}8xRlu_v>S* z?-6%X{fT&?yM-Ist06usrMOXlN_qRLF%_C(zc^PQdpf zX}f%m&`t8n1a9v8O)-PEN+9!iTqq2<6L9Q0sLVk!VG4Y|mcP({@5)&J1M$X);(J#B zHF&eQUkz>~Q+*b6k<LEL&wvoI9U!d1nNH*33|Fj-yD?j$|EQN0J(YQD6x#P2P@G87+sfn$K7aeht z=QKvaOJC%%J_fU+JGZ)=$7IwJx-bYEUwpDjS1-cG{(k@CiBW~+cY>p^P<5_VVW+hD zHfAW2$rNKfgn0Cj-;$2cl496bL0G-04!s629CoU{O4UHMTk|1&AUI$|xK}}Lwt4Y{ zpBU0wiauNYOyM?Kmc7qT@5xiUBX#aqwCB7@flqC?+N%ulcEZMAD1JA}+|04;zM4N+ zeT)Bn*Gpf@`EJp)^}5PJdc@SoHgenT>}s^;MeQYDUI2>}b*tvG8q*6^yWJfnc_%E8Da~feT9a9?flZzUKNH7wxJ2z1XnZs43FtG}nCxyfv z`!n)BGmB`;w~)5PKEPz{@T_SYznNda{l?5K%2YsW$WhN->(z-~7pQXBp9fcxznC@7 zZS@O+h-m|%qDW(?(3293=q=uWT<6lf_JTV4;Jk*Gm*{w)I(3rp8Sp)xINZ$g3BPsw z=E+58rj?!EpO!(!!s`($-&tdTn@b&Ehx$DpVWR~5+Dg;|@{{j~p8wq4;| z%nknn3Ubz~PV?WsZAFn%8&HqNdEP|(Q3-p0F#AtGWKacT@-s5M73)05=(T6kYc-7z zV;O=R!W!wJoupmHGymBpe{wm~mNo?k$Wr^pdR|Mlp?ye-_xynb78x31^TI5<79q{b zCJPm9yz3^JUXNlJv0CNkYU&^e(nj%#^EYeRe{BajxKyD1y+5VMX zx4Z_aKi9NtgAR>#=N!zdqRZQipD;_4*#mU9S*h-p92BaR3V}ooAsHx_70vo#3#rv6 zr{{27t@CLKt@s8bmjN-Ktkvd*sA5-*$tZBhWv~LgnBjdQ_&6(a6*B#LFX9G?;6KlV zY6DoJx4grs^1iEmr~L9WeF{0T(~GN`{dcTb?2+g$NgexpF0%3tkC*oc`BfU_``wg9&V4bJO#Y-O2xN=m<6?mdnAc+2gDfkT~XT+sGjzSE795J+W5m&N2klyTYZdlM>OmFUm1j(-dPi_kxQ&z%NoNs z!~`j^wAJnH~rL+o)b8?du(9RUZWmoHwbJs`xkaGFpmpzr1Ji(m^=oZ#0@1JT?U+!9`g zLJr2wz7EX^M%30DKE9{8bssULs8euphNy*ov)-3)5QyI#&vUGrOfgzMn=Qbr3m8r0 zKqDlw3ufgkX6NE}jcZZ%P`5>4lnj4QY5b?tQ*r%WWX6bNR>@W(V~acrdB+vMj3()K*}p+u*1h zw=yX4#}Nz^XJX4%pm)c9Q0RTx2lA?sOV588)5d+c7)@lCG{=6FEvu6KPiemt1z+HR zx;SE?mgLF^0bBUB&bCa#>PzyOBsSwHnfaQo>kCfpCns9pp8ujnlvY2@uxS3k_V@Tr z%Kk}F9jHl$*4;>7f9LbO9+kCkd-FGZA?bG?n!eL4@6q`tGQHl3?I~5aOZd;FArD9zX12X; zBAom%NSQ&VmgV`IAYO`L_$=s3e~a>V@*aFCWH$>mJoqZ0Z(D}r7zMrCW6*N3p`q-I zCp=4LV%;}zH{2bsh(lZPu}ffA3}k&NHU)0ZruFz>-|M?1D?*(q!iNPN|MV;Yh1KwS zoA9tl%jR1*OZ<1))w@B#3828u4jMZgdh6|9$&UZJreLwxv8O!Sp$~hrH%i{PN5;Yl zK$$;ovTdCgmQUG^?DLpL;5PjMaj2heUA=JyVV^@q8}oFuDG5o{(!9J%yZ zwpqz7ldUKQUSfQ=O!b8MuX#Izy^V!!RQLO+9S6PlXUl_AytJk-wGMmyE^7D2U{Vae zunHDj(s&Ud8rM^nktbm=*2ZElEvny!4Lff;B~nWY5@c4RPc%gB`{G*ewP6z6@oZF7 zM%VG}>m1PKghh+|kOQ22tu-!{RjqWRCXE-O3&%iA@oB%#r)ka&OrrLngJ!>OuFKxK^f(EB!zJmB|yH1B^vk(_W1n5pd@br_* z7B-`R{DXD51d+8z7CIr6_ zJFKa4;HLBK^Vj@YmZzG;%ZqmG4-99Uj!#yPf~bAK>q>#iWy#T&3>pf$-NJNM?48rH z2^fUVl3jh!2&^_5Y*7_*Z>1buB}>*a@z<_D4@~<^jW;ZQz5R!B$rPA_LFO@ zudpzqTW=6u4oo}IxAr#ygxk}#;2WOyRP(y`dhEQEKSgn|-AR)t(NNn@t}L#Q7g{ta zQGKa2*4--vnCwm~b1$xHc=lL)$DCQ_DMLflfP%4^fu!Nc%y5s6hHZ$ z-FjWVtpzN2qy!#|%g}S&C-Qf0=X5ymMZMV@K35DFI(2=Cw53|le$}s1^6`uIEp-K< zJbW$Ws!4r=t9y1<4YvXd_M!FU-6hYOnNe9Rzvi9W-``C*9OeW~EfIR15-`vC_)VFw zD#T!ZMYW|C>k$>1Oe9n^pYvJ4XZYHE$3Eiai2;#=o5w;uuCT>bvmB>`55)=1eN^|+ z_J#M?+8}dry}3Bp6#;7;M`Rz_2%h3nPiMn+S#@g(yYbpi8Ryi1(ep%dfWkQ_-x=K( znsiy1A`5hx#h7qM(`#Tro)7`$7Q#5sF@VP9m^8ypVdO6bnqMpR-}BH7>D95t^Tlu1 zD`c1vE;j;Ru3Le#)Ta5@n`jj|hwnQM41pTn%084(X(p(UogOf1KdBzj_~EPK+DXUC z+rITN0?D#M$67H#-$i3m0@2z3R&xZ%7ck`b+WfyB?cDN06&7YuOn|oqF&s z^3$uHz7%bW&+etp^RB39^9#W*X}Jm7^ND+NgD-_rfXx=g{+~^+Fmn`Z1yEL~oE+HR z>L01D&}n@z`k`~O6~-YiV}zLy*EQa_602sw(GFMCPU?J^t+ba96MVdMRPQG1-6pG^ zo0GqE(29H;;nk0J={uVg>$2|cML&T-9v+nxK+1CI*vI`=FC6a;A8;BZ?`?H4R39f) z@EaU6guW72YoziTptWsfDO z$@kBue%PA)Voql(o0*=VdDME|aqKipBx_3W0c)3!DUjn=0YidOeGu)|L%~|BpWkl; zkOJGwBE&zCC#4AZ!MmCCy=~|VR`J{v&;{-JCMZaopZwt>YTDfs`ju^)c=xDBZj7t7 zl^$?Eje<4;>7%-oWOLLhwtT_+=j*d%p}6b)EYL1neSk0IAZfD~jcU1P+zhu~sN06% z!69V3eok|guhhS)6}I=z3)-d8)jtVYTMGi;B^#l0>|{F9u$wxa)0h`Q9`w*K@ng5w zpUzyQHHrunD6r&mJRg2xgLLiOrvQiH{A#}uDQdk5nR1mLGJ%DjS|tvkSSCxY2SNbN zzQ}87VPQ|=uqNg-Z--28)#3nU;IfK%j&)*Ukga6uHU9Rx`&qUQ17UFb@ihI@F_ceB z*q{gPDna4HWN`bCp(xwg2A};G$=>n zm#;^y2(lq^GX>?GZc(g$z1xQ2bvL7xlnfRoDnx1m24B>t4fWIF2Z5Rw+pDdhA7(b@ z1id4Z`UK6W1Hi?O@M*;BeZHhq+8EuU5~kLW3))|@D=(l`v{z*y7ElXywXB>?s7>^$ z7wWK(=M4Lu6IKs}e#)}Nit3o=*cK!lcKR_PQy%~iJz+M)owWgO<;*Np4jG?KKi|$M z4QMRRCeP1$dgeR69^}V;IA7t9AUGF|If4YW%>-p_K;K|KH#7%cBRddc-Id(1)4L^= zE8%`72=YaEZzkV?{Bn6GS768wRM4~;NU^fGpWbW5uB?p;<5YMYd8tO@c%*!nZN)Uw z;6#nm>=h^Zx&Lj6QGz5(*pd|>m-~9*jsxCSVHm!CnRfoxSv|#ml0(b;>+kcWO&{Z@ z+j$#a(Ij?W`JxM|_j>wnpD|}PakCev7wWHMo|USsG}&#BXi3qz2=865d7KZ^Vd)uC zdi?-nR=~~BGrF`H`S|#{OZZ;j-1YR02^^QvqU}q?n7hD)$vU*6qTp3R-fcZ!4(V)h z`7E_D_>X~Nt+VHggea1${`nu;F)q-lU{BlrK?>9HRMNp&fW16*zdKpX_JLN&+ox}q zi2Wd?%${BtQJsQa@8d?1SP+=Y@^{Ow^^6p?S^qXJP0|_FLrsSYl*y#`OOoY+e3<&k zVr$KC-EwI_T2d1@!c|H7UjGF8zcQ}sTi`+f>5+o3nfw^S1<+&atdt7RU>$IKBtZ*vfJvwQwF zik>Wfjwk`Ra<0L~8&&^>jFLkOWd})7fG)gIi|p%3yXetQPc%JB4vwfv-t2xrc9qZ( z)^p!$;x0+)#;B)l*TXk2yP|GY`r8T;Ueq!q@6%q$q+siavC3t5fp&(HrXxAclR|^kYc`2w;f}(tE zMD`E+Rh{;(>|n3@EYr-$C+zqysBnRJpc`IHuV2Jc|CPOy8W2bRlTIq5?s|RC$y2Ex zI|3w=pN!N@b83%L|7jdi;zW$3{sh>NRvK1ex3b`@hw}XY;>W!hk$g1_-YDa=_WW5V zx-^}Kh*j@iRiooZ&GL`hDzaA*x)rOAHja2|rCzh*{{)34%WW3Svm@pH=$fTM%Q_)E zny(X*L>8s1ufEj~SxTV(d}%2`8ln7>;*lqo$FhX|VQM|KBvz&1C7pgj)yq2dxL;M` z-Q2~A50%QYPE_UpD|39nG>>TL+B>#T{@|p`?qO9uL8?AF3ux_3PSscci8M*D>tN@K zh3O4qaUym^MQ00*O)XkSONl-Pr46@AmG!0nSMBI7{_}Lc6;M0gVHk6>Nuhp7Q)ZU3 zPGrKwPNq%qi)NEqBdVHZaSIzG+F?M^DvwP|XH)ei3VvO6MV#C}p@GW7Gp3d&*qhI1tZDe5i z!;DtMd`tbfkIFVn$?{POfnH-t>0xN2vRl0y2E&PkCPKAYAW>w@I(Me}&Z6;%J+O31 zMLuJGtl;=a+qYiR3r)4$qTuY<CI3(GsI=5D z60eHtOp#xARk!jLbwJ~}e~t8?CCj7HInL3h5~8ZX(GnJf#QPOtfvKUT`i2zrH{VhB zOu7FkT4qbnX4J3(VtjV@3XEv(pHx=#%0@@^N9A18B`r8_>QT#is;7%e%I#aj>q^Re z0@>HB^|{L|N|!i|%1S~zt8sa4xf{GoXIlQR-jRi-^mS-Gsq^?B6U$ubKL&LAdfHa6 zROXb$PDbar^YKf=rMu|R+)xY^X(d@nXO`V>oMV zpfU3^WzHY{gvyyaJ8+=XKf;?rp|F1HotWycgX~QU1KRjNCG+u5L-4ZHAL3#veSD?a zGa5<}AFO8M1bGe3Ui(7ZWQvvqpLw{r6pIOyF5sMu~r%>GY3rEF{Szl!#le zm-$-CniG{5H|EoYfH@K4)6UXFXILjUEd>nQ-2Z?7?Nzpa|F%2!EA#xMuncy2RF#g8 zngG9ZO&5k1oIk;Y;z7rgYj*PGB@w4KDUFcqKe0Ek{j&3j6gQ2f<##2o8k>=+sMTfg zd@2J(#3h`)s(@D8{EZgy47FY6;esC~A9-c~O>gep=-SWPI}>udS~7j3^`EnzZp**o zSauU^KJHt`b&r=laW$-3bH)E?8qcU_U$e4)N-Doqc}uayjk;UjUEa8|Wq9y8y+Ky4 z@**KxAZBp-uTzDsu0>Fh=Q_%@LA2LkvjoEcNJ5moe4#=5tK@#d4|;+=V1-3|#V6eI z+njvJvX|aS@d>ZO+i#{<`NvPEK1~T5-6au>ry&gxtbgom?|>c;qVBSB931@F z>IRks^s31MLrB-1-+P24^9$-DpPbzB5#P#4<-x+lldaD1pwGpq_a;Q51TQfMrC9yw z!c*N+tHlVDG=A>JP98fA*ob?2N9lfy*JJI>-hrHdzDL!G;A{;r6WX(o;+^<#zVbVQn z>_Lo1)&@Xa(9p=ytIN*wf-DT}4+~JhXL?-rs|5{Y0>tIQMfJe8?yV8D0Lum>!EXn`6IyYv9~|H45N!v=^{T( zVdSiZtdaT(IjWT2f{!8j=a7em09e*eW;!g$OR-31LAK5Ix>JQLvm;>OHXNq62g$Kn zgw~d9+c-;6ATcFsU{Q+WkRi&@EQg|j0ze|ZWXI<=u;=#iobl9EX2RjOZxmVZqC;}a zwa9fIUrzaJmi`GD?aQne>hmxjq2qLHL?i zT}DCSn+4w(kn3=c>&^wOX;_w>m6ZPo@*h9_m6_O5eT(HidZfvomV_@K?R<4;WRgh& z)k-+oSReLJ>bLxpAmOc%LUXqayBM4g`+y9{6FO+&N$*q4cLJ4xYgvA+t z`uEz6^bK_8eb8v3wcm^aW|cw+ET|oiZ?qJN{WfGAaC-%Sdhn>?4H+g3E03ct&x?p? z8(^g5b@#?3r=jG$_*{65f8B&icMA4j=}ptVFFgL5DHle?BIaBM4~*~J=mj9Iq<@6e z`j;)vf4{lkQ??ht`Hz+FrOYj#K&lZ0pQ)}PV@TE@mtZ#>qH0)F>^Q`ATe4e~{(FK6L7Rcd7a~lmeEP(q zxS!9Mn*XSnW4n;|vFhLVf{?XnS4?v7fa?Vo6&eZ&eSM8=&bONX5H9&Lrr&(Z9{@me z5%#j|A05T?zjV}{#^Uk`Sh|!CIr#T2?*L=~Nxut$vDCrVDeV@Zw8B-tKkWe8`pS)V z3S?Ye*fxX$nHPy9!v7P29MLlJE)dmq*H6?dSz>zFt zG2iUNRA9u7q-aEXPn1Bbz07`08>gdTB>op%-7k_=mpYCz=iyt04{+=h@Xrq~48nAT zz4PeRVG)cF)KHxL=Z~W224UC#XycA2JsK0Z7(akI&LOZQ0escOy#8av@!`yQdi-;~jZjCSwar}Z3tAXm z#etiykz7c)jwberLxb?A|NgPLgVkSd(*Ur04w=vR3du}0^9~vIdkn!W-#*Oq$PpRw z1+8=Ic;^r~Bp4lzBvIQ#Cd?prCGFAUP?c8iGn--Sp?q+6uI=hg4qmwE&pftm{#x*6($o|4E=*GNp&1q zNzuQDZVIPun}w064V&(DDD35Lvd0O+|JU)O(m?rsE~HV9J#1f!QL1(G%03PJ10(#hU~ zI2c`gR>6WXNw)j`vs?+2Bi~d`U!S0JkBl(`JyR!3Bqp3u>t$6XZ5sxIDR03zF{#wu zrpR@ClG=!PK^#`iE;B3Wig0nJ8UFc;a(e-?NFEP~vJJb3l>O8v z%NLKta`Nm@ke%re9P|+X6N%FZsY~wh*!uo#=Vn+s;KjeC7VSTlacCHfP_K&=*<`s5 zzT-l_28UgO+p$b?H?}JNj01ZDxc&1e1R(~;i7K(M0?7VBYofCe>?w!C%CVMg*G)@z zG-E4>@We)kyHwfXYdpK%&YeCI==on-1s$h;&+i4DVJ5r01@I8^f86%XQ&!VEK;8VE zh)!=?FXrpz9VU;A?wa)-LCq(CE+$Bsd$jq&ZE#}^*ZO!D^hWW%%@tv!yN49ZBs8nN z26?eLdi`52zM}Zu;4bdly+rU{*Ia_dS)OEJX~fC{o#Kn2OO>x>DzMAXIi4nQp_GYF z_L<`@(uqI5y@-?(uaAhtO+AQ=``|QiE*Jm!Hu|X9y zeh0~d-8Pe3&j_urqaB)iKgSVRPZ9IYK5><>Z8BeCcjzE;EXlz|r`6fc@`VQRdUY4+ z#O0yMIN{^L0CZc~;Ni-2JbgEjUF+=O{(N8cu(_tsNW1-8$mbO5_?ep6F#jHhG6f1X zG(*WFHGNo_4HkQwI0L^Hta)g?v_K42seW0XcDWhEqB*2Cjh!O4@(waYF=!w9;2(>I zcuw$Uqs8gm*C?H4kFMkpWN4-iS3)*#aNHm(6WJYVO~*qWd~f!#Y_O_=KjPqlby^&q z#OAccveiV8S)T!P4d}ETFO#R&%S_^5Mh!?c@30i3LOxzp4sDOJM?xn)#*al

    KlFG6zcW$+b$W*n@Wyos1M3l?-?jaKSNvBzGjO^3^7i zBgqTHgHP+tfa7oOt?)nH3MI(dde)Q8XqsTvSIDt18l&GCyr7w%)ucsas(!)MYVW|d z(bNH)(v?VnrgKH=lx5gzze48MLSi%SwSe#E1=5SY8#w!Q;64a5uZnpqqonLimcnk3 zu8ArqkQ{{22oeW=`H~-(l9UQ5ehQ*0<3v_X%jm3bbZ@W?6gpbL_5Op){x17?kJRkV zx=TEQCwleBZ?2T|;@8iZG3!T7%!GpNxXg!|2{sf`1ZGdGdhhJh2}7cy+hRt0g9u#W z7{7)3(Z?{He3&2GJ+JD;x85AYU2Wb^Kb{acX6q&pr12BzItV{0nuZxEnl=X#+rP#1 zY~z(9yVA5D()G4@)Cfrqy>xNM3c~148)%{iY z_{2+r@b!(nltepQnQ2^iUT)lG^G$|--Jtt#i6s42h!3#l*_}qZpqsL*V@(L$Yr8P; zmD0jZx53+4Um=W2`|ltu3Fnf`;Yf`yKOf0Q3cV%6Urpo?3jL1db!Uc4h&W&NlQ$~? zruljw9{;|85)fkBN?FC-cG`CT=BwC>4mpP^7Y_^K}|CkN#1akU^wm> zH_HCXPrAW1rtWe%uRDoaM)Qzg2G$K;l#eC2!9hD&eHy3F5?=_toeIk8bHh9#4~P5( z5CA=E5jX4NfxyPBk+)E(5}x?yuOCI)P6BiTbj3EV*#yN#BFLNHfy4c=QYnlC=8K72 z!_wo8Lb_IVY6gZ?JKBu0b}!uhe#?esh|#}BP{``t*AjHy{? zg2JJ3BG@S@3?5hIL%Ch`7nkXa-IgfvJXlt5>aPAUOUJLYF7-KbT0hEf44Nwv4DOC# znDTK-UrM8GDFD6&B+r`zDD64C>rZOq7@=;jgu_Q1gj3j zo6^tN-0+!SkBc5mXjZ+gHWA30>&~S>!xQl4c5|>t3#-roYdL#H)#UeN1($l!Y(MlqLJ6*&sBSya6|lc9psr{7&>v`^otd&-NL zLM+B0@*(?z2ttvabtDG29or=nk*n^Xxh;Wu=N?h(ZG~PvwA)TB%93g=pvRQM@=CEf z|CP?b7TdRrT+AVilNuX4J;3{tZ+EZ|=tT=glE2bG#Mw4)7tfbB9F-shDyWI6jHxTi zDt>DBO{jLz>9fBkhfua%rO!kpHO(^-(mqAUYTOg?93G>FGvhz;hJpfq-lkXRN%R0kHH@zJDA?XX`V~N!$ex=5_ zI$LdYIlJQ!gTb~zT+Dq4O;}DR`~mU?9utTC(wEqo3krUE#B;1{m(f1lNh68;1oGsh zYPb;L7gDs%Z}{Gw56xv)W-4F?k;@@5pjl2n5ciHFJ2X7h0LmKLf z&gYIY628yXw4CaNPW4)@>MdfqL%7fof^Q+o$c$2?&JA>M+b7Km&P#}BUHD=j{to+1 zWH*^NbwhM2_^60>^{^_S4#Fjh+7%N8C~Ev1q{N@?eL{Q!a@mnvuW)}D&q74EZD`1| zT;4yBYn#JCS)QSS2&fS@wP+C+?%gGLBTCqF3d&*n7=ir#Q5nb&=DVya>iJhQ@D~EV z=}w^5?w)QFVr$=?F3*>@A|4J;_0S>oo1kJ9z?$%m5b5iX^8Q2;I)797z_ARKyy@p66o~Fz z`m(|D8$3%u+~`yLycuu9<)s_^y4kSQhGx_YUR+#`oaaSiJS##tTtKjBK@VF4%J1)@ zlxcdu=&4uS%|nCkNK>)BGVKW-xhFb()lgMg+S!5A-=dOQ;=!MUP{Uw>upA-2@N~Ku z%iu3h#RS8Cu8nbn#NveqRC%h};ga|QklO^cRRAbF1Jas7m1a&}c0oV)0rV}s&Rnl! z@AvzN^!PkuC(@thdlOGXpD%Za&w5{f)G-wr;Q50TY5Ygx+|Kv+$tPYF8j<#maTVmz6@_p`9wyOZ??Yj)c?ZT&oQ zK3T@c|QzReglS(#TGNe__ zLy@p;u%_^GM)8xUP+(H+qFw_^LL&I(H@_ut!}p~Si4kxnA?eP#w>(ae2wmRQ`iaIz z{o}o6UBK$VDd>0H#{b9CS%)?CzJFXoL6DM?oU{niN;4!RB}55PP$^MKrQ--F4WkhO zCxRk^q%<pstO?|I+v*Bc5}a)``ULRV0it`GS9 z4q8#E6U`;s2W*KnJri6XfB5pQ;@dimz@o><7wK|5qUO-)OlH{RaO%I|!;UX^)_nC$ zKzsRZSzB_-7l2)bx-1%co%Ete0f@5HN}b(yD^2oO<|zZ zDfsJjw#PiXp08$sQG>W03Exij9+Crl>!E;<_h6Y~?*pj*5H4Fr!IeyvWgkY&WQRJU z&`jy`NZ{{iOiW_ke0H()D_C$YY~oF|Gd$DKtVPFmy%DI zV4IrPJqBIP-h2Vu*a>lv5@&(T5m&WV0)49<60{nV2jGFD~lw3eRQhlB&o zs_1tsb0}E$hx?(0ze-)}TQkrr?r^qPxO zKb`HL^B-j>bwPacBBK8i&yHpEujptN(aSi-Mf@LlIDNsk+J3LWf# z7h%ORu@+siEHCu6HHc;6NimzqECHmB<^GpAsW*zV{;Zy_KQ}IhqxT!5__n__r7xC{ zlM?DA%9`4K{$^C7r+OCo592ozV(K}bxv!Y{XgM_auR(KjJlAWe?!k*jM1%Q6(-^seKKLXuco!v;p_wN`Fg3n>hf-p9D-@SdPme}_ zrY>cX}eR}jALbpu4qk+A#dgS$ zW;CNs=;R1TMN6Dlc-f{m9oR_rnGEk|x1^&H+tE6Y4ZyF7-xD6KnZ7LQxg8q~zD7d} z|BcW=i|Zrw*Q8ek-}f^G>`lLf)*IeD7T)1$UQF&`&OW#?kMpp#2jDKPqA?KklBl$XXdT{Kof0 zu-{T6K|m{yDE1>yj;pTI{tuu6_MQjYfR?bDtgL(Md^jMF@!tD3T&9m0SQ4z?M2+E; zxeDvMS$IY>B47QJJJa#wB>765oa!KVF6nyYs_UBE1082m((|Mc{lUZo<4wk0-behs zjZM2UnEupC#Ez19h36bH!z4O!-(%{N#b} z?9I;k&8>w7ojLWcRcX*aHvYy=j_zG_A>X|!J>Avg4`4eO zSG5#d3ps;5c`!#FAH9+4GvGmDP<+$4uhMn0GcjCUU0r{XmEV(w&p*kw$EA{Vns1pe+ zVdq@z71#E}lS(g4;k7z%I|UY*aG$L-Dbe4%uu@$|o(X*Ab&2!F!)43IPVC*%K;rBx z`H7;}E~gipnU(i@gl0od7bK<~Wm8^q5IO&by2Xzx#zNn^VfEk75m~v;j^QSU2PlYQ zU$>;|E7)VB8dl}YR~6^YVKN^wF-P_=Ng0ixzA$@6uRsIH+^tgb56mjr8Eed(agg>N z-)9*LoaFP9oELeg5C+u$a3>p*d=Tp2QhioS$S{aHkc4kwuj`dty6riBo2F4jPC4RT zBz#Yfxv_`;ig+Xty9Hd!D)>`MEWfu+Ut)=0Zw~5rP zTlJ*QDVLSVe;4J7D(Nia58kHxR;ut16~vvyK0+7r8D6QMQZft8+u$jI?+nl&jv zSLcskDY!9v{soi$x+CA^Q|o$~U|jA~rtTJg-_+N~OXM(Y3>#_XUMvU%lKos{3`}Zo z!~8t|euZkVf0HyqDUS&#X@c3x>XJ;`RTH+_O;;WH`WBwFGnipZ-8C0NE0=MtG-54L zaAvHhf#F$_so_}{z%1}SJjnoRWfCx<+XilLUW*JUSJ;7KH@aemlt)ouc|Io zwGVzV4!yd*o`0vlqH(WFYJIakC?>al86-ztr3Fvrk=inAoYN6sF2 zbUezq5NeuskPurE^Hi4^!m5HIyC^cCAU1#Ux1OJ6_l?I5|M+D0Jx>pXm>Oxk^v)m+ z5}cftR%~lMjtC^W~iTM_4TL$K19 z*9vQ3ZjLrYb0N{Ger4r#-9BpD7`?2|B=2rh6C>(mr%Q;-G8yqG?{t7Ky^KNP3yGOM zm#$CmLPLjr0ja44KxlL|{$xa8O4f!{Pt_EIS7~c0=KH-{$@xJ6&s0;1$+?>bhY0nL zqnY-hy(BaONTR3V3w}#jfP+&%BYU4@oOWe<)a56t_5CI+_@OJ;SLXgR-Sw$gq_CcS z03TT0Hb}eJAr8-4H5ITxDIYN%9T}39!5C**X4)K)5128B^F1EcT(wiq*^LzreokLo zZT!NsotJ~-8n=HGtGW23yzH}aAorQGqfo%Z_4k+Ynb*QEj;BvSJ6P3%3&FD+cE%r% zH^(1i9*6T#>+w#sd$Ei=xT#ytmiDrn`F5t0ot>;p(@%GRCQq=y#VH@kGO~LgW zB}Oearu7RBYnQ}cUS6v*J448Quy7`F3Ic|4XB#5G@olL$jzGF$p7ew$bk^mSIs_Iy zm#?u;8~jB}SY3I8*6iD83e8j@5x=fIX={buf7i!_*qiknZ z^uYai2&bQ$ttG#H*~S549xc9D)vs-yY(rmThbXU&rb}-= zJ+Wp6-=eJSLV6#cb;Fmxck;bM*b%pefwqEJ%qUM8DlxMccBAI7ZUx~-T%_}Q;0|)i zE*8q3MZHbuaNdQsrkNfTsrk!tLKcRuVd}xw`^7Ybs19#kHG$RYDUN(khaklqHy=L| zJ=SyG*l}UG^qaccv1%RHXKl8MsJgSEiCMMtLAcii>4ApOipJ~1RQ5X0?mZ~w^~@6c zt<$-nvYq+dI@bs$NW@(--XaLs60u)33_m|_nfcFU`3@=kJpE#O*?uW|P+j4#bnKzk z;gWP`tONe=SCmUTzi6K#!73Wk<^BvY{9r!o$1&mA>M^`~OeZ_Ty|U65hz2^mLWd55 zorf@sjmH}F9KJDqdz>RWkk|YYIACsa$6+c{DXLM^0P;6+;FK7G7A={Wd3K!`XKbMnZom$cnkB8Oh}-b>~Uj{?x`N zA131#z9;XDfS{rodZP{Pv*7OG0F>G=>GU_$caC&meGiI5LXYMx(o0EsMfa{TS`TZo zl|=KdqC@!97l{ z0G6j*j?XI<(#cX6MRu~#9lGRh6r+xK^b<3U+gZ0kb7I_SSQ9yYPtC@so}8A___DNl z{O7NGR*qkAFy&|O)Vf;7B;qP6w`yjfqGIKjX5iR3P~V3Lf80^(iCEM&74CD9+@l$O zTlOgct9(@tK^3a@eHFbuM-HEF@0B*b?D9-l^ldje=niAmAzLe;J)Smp9y;fOerzrP z%P6rc5loAUJLK;$)gW0L@+v*Q%0JcWaO%z0zEU#h^ejM>Mhn;7bce#BWQEH5q~DWE znI1vABnR~e^^%`CQ;ytUI|Y0s;ouHDbt62W2NN$qbu6dHLV-Y|d6a0SA6%RP8 z!K0HUj@BsX*aCkj8({U!ujF4Ug7yh<QIGxZ*?6YKcEqDO^{BwV{Bp&M z?NOM?^qr5A4IG>Vmvg6BQ?~*Yu_NH?X;>E8Z@(}fxh50 z_`z@S-Qyg9d4#yIzKBv1{qZYehHi~P>&H3ei}(FGZ1Iu!I+3`EM8SR`YxbD$UWAqY z-0Vds@?Vf&F*9klMD!Z@W2G#3tMjvO^lI4LQ`Pe`Z;G{CPvXVO{s(V|pOxnnk)Fj{2MF-qqomw5Gh>r38koH7V>TJu zwIW%8pNqjpZPxdpO39}AkwdK+=@?y2+!BWO-E+d2Y*H#2Su@mXC>+{n>mcj)AwFLy z!vLg!!e8oqaTYcGtEbVGpsFRd^TDZrxRlN4XX{o~opxLX%(>&syodxlIx-?DlthRq zzGeAo`o8kZ)P#z;Hx^4J)t*OJ4~Jpkq28GcgVoNR6Vsu<-Iy5nXpKA7@eo zkl4L~xKt%m7eFR8{E|Z3uOPK>wL%2eHJEpN`8^u^a0jrF6O?FQPgW^DCn4po?8VJK zxYW%8nv=9g^gA3Y*kvpH?yJ-M^^UmhZ8(W!X^(1jtC@~8FP}a_ek{JvFQz}*9PE7M z5cxZJys8dsv}Thhdd=SHK^Pxwnmn<3!#nc#Vm)}EifZD6{t{a@1O_# zwE=q|kUkE>%DjMXv1ilTM(=$)T$*^No^}q*Qx9f>sRuG2OkKhk+F423FMaYSdQG;+ zcnw<2c#(n*FObSA4NcFKc>7TV_sRD5uKJi~OqsG-JhH*>vWbGhxL)a}mG1A@pr-Dp zr~K;w_`fY8v6;nc7w_T^hex8yl883Ow+IV%AQv7+#xp-$vUf|D(R~O-q&ua{*B}{g zQ+Iu72nS;{dLLXCQZMsbfW{07gCNV;m!h^~gO%JuMfD6pomVm$K?l zp!F)$JBypzQ&y7(D+Q*N6Q2)S>Mn%4QT4|@))6)d^rY;t`1z(XHS}29ugf$vwz%0s zUOuJNStK%w(9|F|Pc_aOi62y4@K&4)&JSLSf#oeO{MRFb$&VHKuWKZESWgq|AshO0)l&?msae2f* zp{k7CkdS&6fqx{bCW(k*mcKQyn2tJq{H=d91(C1sk$LDdh}ZMxORm5FiKbe4e-yJ8 zULMsnxHNU33HsdEu)Tb2uTRjGWMj~}4|$yh75R2GzG<#Foxj~nx4*mQ{uE2rpYSEE2PK4iF71^lY-^%eOR&)tf(z4=<-9@bGnB_g{pcvGx+Ce?q zW1{r9jU4<6T{QkIfxXvU0L3G71nL&g{2?JO=F|=ZAy#e~Y!+*uJgu!D%Y; zDqgYHfPSm5xd|icMf?X)R?;ED*J9z~iNz-5L0G~Q6(#xuo8zd-D1B4HRAF;w=VminV?ee%1Pd&6C5DAeY0` z%uUvMbegHfcUpd&lUB>=lvb5fs3VE%L(P!+e%30i7Osq8y7>**+cV7pu0*Kx-D}=7 z_WpZm6m9R)g5jS z<^FeW603*#HpFMwe7}l!!PDE2PolX$V(p@dJXgm{f- z<9=oFWc%HxOjOX_T)A``rDm;g`#%|r=t2f7q~tFsg6X%qj!vwuuEisWo+uF#z1&v? z6&}HL{Yr9tKbDYCf7eo_wW6nyk7i7-$gJS2kxNa+9n4-Sc zz^mWExpLQvfVP+xmZ5N_GK8a^D0{$^gG4$I-TLqaY6(WyOP+c_!)`wQUx3Kl9N|32 z+sjG&!jxl-Z(q)5IRMd7)UWel2BK&Mtv+SUMEhCkW>G9R<0>7(FiNHWWtNW1#J4Ec1rO( z_I!Mk0Y~eGS;qZL#xiC<{~B@~my0T4GaUKtO8Xrs4W)m1pjreGSb2D|?2!{|eN5r$ z#JiHwU$6~}HG8HtF`3W)eYK<|*{g?olG)91e~Y9uwBkGM?72M7ku`OqIer9@x1xk4Y4h7f{PrXyyB#iygy z4kgZHi<3Bc?ji6@KbbHCRuI<=(^53!GKofSYE`=J{)v9>{Z;)o`oOC`M#*sdf534? z_u@XZ@+I{%E}e{LxSW+m=2D8^`h^FnUsO9cG)j}s)*P;4fm@@sIyTl;q85ADFr zp7d_MEw~V<^92{PLZd>9J5pK6TezDHUm@p({<-SOu@Dta)xm&ctgc(2!+4>sk}cVDtnNy~DX4B6LRb+5YD?~+EI z8sdn$6w;b@_xqdrRpc@hd+9|1(HBeetXCAGPP+!Denkm6?m)<3${>G*-KCD0k3$e< zg*AVv9f;ovF7z;7STbDVU7+x`Vc-e`pz`@BuUSh^-jOBMd*cbKfQv{m|1ZwL2Hm6!c-)mu8v z31tx)J&2(55GD@SY6Q~ti6@feO3fB`Dc1o z@@pHFgcbXfkrcN{fB7>pq8xv+mB|kXdXCAiU5gUbNr(PQXEr$XA6~gYWny019?6iZ zeV^xp8jbzMIs3mc*rW`l)&?n^Q~x}vyU^B}sR2hG@WMdrAu%XKPD>BN$?zhW>kXaf zzb!FdYR<~Li}56c^fu7;dc2i}ZEJ2CiddBF9-=O>%@S9fMJ{ly7#YKAv5i6>9BCr(tN_&QgTXlPwr=fm#`yR-6| zN%zDlDh3x7twjmad!UvOa<2-3GB`_+0CvGa=ZLXv2P;-&Ywj4g6DO@-D1lrvWGlMj zAbbQvdgJI6)wz_+3c;vA+n%&%^rtgrxujHFit=_#cg+bvz^+jCXCk$x4|aw>vQDi7 zBDl;3tI*Gfs{6n{?IZ`Y826huPDf7w{GqA(nJ_v0dZ`^2dD`H9AxIzg3BMSHD6PZL zJ)vgNnVO~Kq%;8x>0I93s$~quL7m-R{uXbpe+pkBIEl6JYv4EYzc@6*e95HZecs9T zr`luEwp7@|(xCl2uF2Rc8H{L^?&3FlD73O{t(cU4UANDLn!hh#%Gm=Ye1iT+0sPQc z`0zn%<;WdHdn->|InDS!)HAhu;PkojxghbP*soI{nA5!*o|lSgzyMzs3}G~-I)NS6 zS7;~ew809{v`9e@axnd2cMW>Sm&B)HAkk7<9QEfz0BK6oc1xx zE^`6cCrytkd75kL(4y^YeD}L^{lkN{Iyw2^C;aW+CuC`Wx(igRZN0-|#7}Jdmn86V zkt9X*e)WsUp$PL^3g%Donx zm05Q2u+q6zL&fjjnmv3iKZNaG*d8M8Eyk=htViJHqs5!<;@T=4*1Qvpz)$~+a0jWb ztBU+OuGb;I!e$9q{{%lbai}?j(4axqY7ua-BLqC-#Aw{EF;T-48x&jcU0ndpa0$+FIsk>6zfg z0GzELyuZ%syq&%G!|aPl?&L=ot)WQ! zs^1aA)ZbEZJEOJ8o%2KZcR44WoS0Cu7Qv-r2t5c!k zePWp*AX^Vqa_0ph6=z>6){nC6XG-N@Zm2ORSg?b#Ru9a@u~CHEsM$gqT`;etEuq^} zeNj45LhYHf++A^C`@V+vcf-tIxV#&?bB&xDn3Ey`W!-X+Mg+;h^)DMyx@UpC5w@dn>IZfZ;)6jYoUaFd%;HVct8?;U4kGRz4KKFCMeuOSgWgp`&$}CF zngv$@jgpQQFU|XqIiX+YXk+*_6v?zeSrl{#`))$+)&WK|S#-!R ztbY!p+REEQxF6(}{E@gp?5btLe4utNbCs+}PVBfpFoaMoc=wsbzN&4kt#EUx_36wQtA>Rh?Yk zjLFv`T9;V;8$WCOOhf`3LaqYuFg7j2hrKu$xTv>JChLuKO9=fpDKwrur1|2kM0|(G z4JCDB!zQxa>7naW3QSohMx34)gVAnmuUWyyNwVaMD^W=NWhLs)Ac$OI4B&<3{A-u! z5B&vTs6R>9pwl`Y$=iMUi$HBfWB=C6GE%m2O~E#_M~+*lWm4`SojdRhUainm=>YQf zINucP0V7zyS%|wd*i^J03tzs*ayjkePw4kismc0f+Zp#N2Jb&=Y0$GPpND*y$PnYx zr<+$V0-oY(1JTgd=(n&c6Snz4VvN|zgNtj3`4w4+t@Y?LVFE)tt;TMxmh7JfOK7+>tx%Ga5&Vhj$WhtuibB`bQTiNHn-hT7I zr_8qc1$zbvl-YyEtNn!`=XuqpLc-*VU1;$a<{usA;J7! z$ID+HqyWxuGLj)yQR82ht5m{L=~9Cb4aC|jS);Jegm-n`ApScdh*-HZHPz#O*JmlGXdRNX9+OQktWljMOLKcQzg&sx$^PvA)XXcz+ZJ-O6 z#U2th7mna38wiIRRuEAdY9M@$Ja8~74M>&ExzD)zw#Twd-1y1$YpIB-LU1|!AatU% z^T>q&q~9Wn7uF4H!x&@e%nU%eFeS)_wio_|{e1ofw;k^lIINfr3dQO<7M|VLMlmh4 zp|a2P2;VdC*9cMsY&<*IYGvYeLfXseW` zl3%s7E+{>&3uld9JpcOG?e~QZ7F?>LTqtbgpS)aK+T9ArZs-kJjVTHOk;ArXQU^9~ z#h%mb0#}_CZdB9-&k-uwC;#xF1B_h3H$4e$*cfV_nY2yQL@!4}#93okf0k ziIps{DV;_i)FC4W|M4Ae%w4e2|6CERVfn{Iq#cz@4$ez^xMNDm7JqGlefea=Te{}< zX8u>=jNC^XgE~|Kr~WJer@8J~({x-(*xk_BA?sKwyfa1m0sccFM*|)WPunBwzxv;9 z;Sbv1+V2=$^qaSF=aE==pLI{{)0;|L20gl?b)KPk8so@!H`<|xJHxAnXRtEV+RS?* z{S_-)=+E3aF-n!kO0t^J44YhB7_srVvcJ3nweTHKb{q{q?^jQC*!Fg!yqj-y`4U?* z`sOdV>4kmyge}$m)jLniOd?I&dxJK@Ro!m!#Z~eejf7%SC3ZVGnwq=$8+kZur@iT4 z33>kd>L5qY69I>aN7!;={RZeRw-ZSg&4_T?teeiqo55g--6Jp-80)vMY1PD+O@kY2 z96>T%Ry}aI@bXtV;>?TU8$bC1$TkGz`&ww;<4wrfn$@feoIdNlV$=Fb*-1!;P6V)H zyWp)I#q`>vx%%IpvV*DTv3pO66V^NJe3Cs`Y6;J@iB>yWNwRtT8E8_F?pkR1@ddJ~ zg#U1ZLP^roR7LB=yLCA32bJ*e(h;vD2Z7?Br1;0{fT-P7FL+MtD$J!TWL+NVGZAJb z&~XOcEit=d_&Ay~n4F_SL!b)JPt@`Q*sN?tjpYz&522DSpWk6z8Fr z?!e1O3Lad9(MJ7b%(*@LSAd}4#i7Wys9NN1i+4;dP!12*aOB9e$Fh#d(w z-Mvv8wmd;bOK&NS=8D^S_cF~El`nC6@rD_~;}j?C-k^2&@jQ7(AmAud;Q$eG;Fo`7*=&0$}Xd6uCYBcak`l=BZA&Tv~ z7=R%Py<_Q?r+sbBzD~^Tte9v^0}Qnc$Q7W3IoKW9e|}6836|4!X#WK2sZ&e{ zjI(q7~#_m0O~7QbiR9v%UQv@{{^3nZ-9jPYDoJSymbR6XN@{GETxzKfPjH_l7-2v{4S z7+P_B%?#ZY_1GSQ9|Zg1Cz`i8S`FGlcI%olJbWMZsviWm&e|-fuo7gvo!Q(aQ-MWz zzl{;;XQ(BYQJBc_^Jrjvd<+Y}WtGGIYO@s&a~ikv{{b*LcaYfSUKanXeK)|pH}Ai~ zpfuB>tDx*OP6Y(~$%wn#qM?Bz%z3yKN!)Wu{3WqFarjhw?o_IdIU?0`W}r#?i<9O~ zX=9=?p$;K<@Zs&m7}9e&CgAM#c$P~;6o^U6wDAucLL4f-_@^KATJmT^ooA693$LTD za`<4?lp=ffa#!}{1x10iYsqS zeIx8PmSs1L-P#}N=5Gx(PabGXsqp)vSafi1==a;&re;c-PraG?kmteR(XjeN$ll9B z2bteJeBM2Jv&>EELHY+tZ5p{f%f_BBrm-Kw5}Tf1NmUw9U0txj(^NlWM<-VkPx3Ej zoDXZ#B#5=bx#z5XUTH=&+X+J-qzFI~g$M~*)m8Y+VCO$D;@5=Jh7cK{*Q?w@n5Hk1 zK@=VVApx@fYZDW4w|BQx&Nm#YojzDepLnkw={-KkTuUdxL5W12w{t_y`8IV%r4XyS zQ29q<%bx>pV-M?|09EFOJNC~DxAD-XZ2nUDdj`aV8}u-{=SIl0q|FoHHtY`5fOs}; z-CC+2DdW}Dc;I(hUu3;)_><*%?-xcM4L0fQ&l+my@rUfEBih8u$&>O2gUi70eM{Y{ zfo=rsz(fU2J>SOmUj)(`|HI9bB}9er={@2Ix?8b3vgL+{lx&ESCn*&RUteIrm!XKK zd<`{tnx}8E{rzme?lWM@YKXRaU?vvjzJWZMc!#AqkiEkN7#`beolWfF{9cga-h56j zsfUF=G>;7kOy663{My*kSyI{kDDkRf|>Z3D?@W6PIx3;3uEc3P4F3uZotSDoJCtcF42WiA! z#P`1He<;76q)m6F7g3jvP|0R33+Fn~hk5ON7zA$qI4)a8X-ZX#D@gn4_{D@K5*&A1 z(PKV%rZDP;Jayut5-8^2dLGGZ+8t-EG$U23vXSef@7lL|clK+h-FCA#-u1x|Dg&QM z4kCa}FYsTxzW_~!UK)ocdmdm>#i4k4KXOP*$(ktXaKsCFci%@Tz(KldeL-d6XWZ=z zqieQ5tV)kfoD7GU+sbUZ`8GmP|puhgwd+B@Yxs)_a|(&mO!9T>d#f6)#o}IwqIpg=F;EqorQ};YykW z9=+`()Njue8}6P+H@0aw0)=J@e6#td5`#Pim)Emr=W9CB-@hNAw7QeSt?Azt&^WLctTXOH(qZv$ofA$ zfAM9L*7e(v8RvXJcdk4B&30SfhoUK$nYg4r3sFpX05Cb zqsD$Vewv7qKraTLyqG@x#55oROG0~9IqTw?Z>ilY&LfdB5f=7aqi}k{%qn$|xtJr@qKv{x&O z_M~i?A_~`UHW@jt-6rpINDA7#{zeoVk{o4=OtO+G&>p)8P0ss%VsFdKH~+j0ICH%% z3f=eStFbD#29fA`U^D^%tNt5Y&aMLseqc6ORfd$T6GgapTCFFawqB&m2x0)$uxx8=kgAFfHEjO_lxp zf%?`5nRtBF18$fGHHac&irq)(|?G_ou5&XQ1o3Rwg zY-b_j7Wn;)Ds+7N*fuRLJ*!8&B->tYo&|-hZ*5H-7|s7Yv*7d=HJA7YT+G10K^&|5 zY@Mw8=v_s5u^f-G?@l!3z%{CXgTG%rmY=>9J{qumVGJ3~fUnLIX;R?T|BxOm@YN^V z+BFM{_`-RjJ+Q}cy8C*#F1^@tIv(RQ9>Dn~(*t5JUxJbEG8E6t%Zqt0=x~V9eR@nf zfh5YBFNM(Z@Sm1O*=+E**CpG&blcVjg1(}=CCZnO{wa9R_-wg=O1JdUcswDnyt#RZ z-y3R7#h~6}RTq>JDVoQsDOOM>yFl(V7;%CM!~yd2#{&<}jm4un;3udTYr~H=+Yl>z zYc}uOgksYSHEjmi?Jm#)E5mFl_19%fDt3Y+MDJc?ymI)ERz>C7SDC>q3uaOUjQT7r z$uzO*b5OvXF!%C`oz%_zQDNyzo;Nsu>p$r@TyoEx^F1-WR6GD&jt`GXm62e~k`;^G zwEVQ4i5g>A+c0i0z*SY6vs7FvxeWd-0eXD2B{?3)5ciszJ$+Rbg`7C*F`TLk+K?6)U&MytgM zdKq4a{9o0|-buUEeB;Ml=asAM2i@?GM#i1{olJmqXn95-vWK}mv2_8LhvkHLW+CxS z5kMHY+pJ&>nZXU9fL^yhU&;)i2@lAux*tp?>7D(3PRL}+ow6E?@2cJP2;Y?*!R2Go znF+nZ&{ycKW_~yHsIw3aUrQsx5{@CAK17T2<-dNDc@J}Bo|&rWU!QiKntw=>t9gyE z7x&B~d)aHXMZQfS)<-i3J8G51Y>ELq$8>8CFYhye%BuH4z8F-%pD|GLt@cgy0+aAR zNCbLl1*Ycz1@c0guo+-s`aLA6olO{urVQUjMNXq`^$$8X^n&BK_6sjJ9ZwLbO}h@Ta9% zL_?Sus<0Ucn+o5Ca;KmfbI_J19ZUr?NkW9O$Gi3!tZkOq+AbIaA23BbeCGu>)GAPl zE~~X5UH#UKMtv0^EIbnAh7`PsD^poxF58T%@Tx>@34blL6Ige6ZPKyYuVzyGpgXR- z+(ml*^G>U%e|+EX!(EOzmU{db);HU0e7*xxbakEo!Z8OrM1yM!e_jA+lsRd^!VnXs z^hYz3=#~S@CK^KL^KvJK{z7lRFcP|tpOgo+DW;^6A9C1svU&zM{MG~BvHyz`@^H_d zy`^e^RV=?MRf*zp0(d@a{^BRdfBAY0Ybmh;`$1_JC@A9=LEb0oaXH_heWIOXcLfE# zs^z0ebVKJ7Yt;8q%*ZFya4G^7;+MF*{J{mcK>71NalNF{?DiTHb@WAwZDyhkXED=G z0l5appr2wN(gn{ZQZNhL-?dkzcLdLN8Xt}0yRqj|h(`$mgt9!Ww0+9T-W{wTWQ(mm zc$EV9^uQ-~b<9`b<<|r+qjn3sP+gaHoNo5Ocy?Y8r6E1xPsSc$#^bfym8g7bc|09h z@~=|NjIICn?M3GiC^{b17v>Do8a>@}3pDQyzQnp0yvTX6nwYD*cCcid`$sOs zy!{$9)B)dpY5fnUWJZXCwxJXt1-kvx_ZzXWV)3PQ2}OfB7^E26oyW5Sb9uYHU`-m< zSSMuddNAS?z~}#P^!JQbP{HIly@`IV)SEtuP<@Ii);?*v5>mT7@?#*7Xu6J$v*j5i zX4xawT6ZGpcRTCdcHGn25KAujwst2yP(xmIX>> ze|G4iAVCJOxGY@oyl?#62(HZJw=Cx{Ng_JYXxx>GI_W;6DSfaRtxgHuW80|(ZXn4#;R+zjNB2AW%SjLXn*(n;F_kDU$o9%o z=!(+%RE9O!3nDT!F1JZ#Le5sqQSn+9yuNH#kC7ELS)W}9+2h(+w!fmTH^Si_eDU4p zXwNDXtZ?&B6_kl0Egl5^7Q(y^fW>@tk|?QYGrh`NPXQE04uS8Y9eMpolSR6a7bfIu9B=^9d*IqO$l-zu*T}J7-7Olf9z;p zWNJv4Xj}}HsZ8oBi&7rpuYfu2r(h0M6%Q%_;n8l#vu+BC2+V;#F(^S%K~%`OLg)v1 z*;NRrOm2N0Om|1&s&w_G@M8qJ70`$9dJ#9i0Geh~@W0U3Bz$-0zv}M_*QZg?0#hxx zAy=Z2-N^i%KRDQ9!FY8wQJwChsuwR;eQ?@ zkL?HXWgVcRd$kf2F~`~53HdIeIIV1gzwMV-k>my(F122Ao`wanfH&*K!Op#! zH2wcS6V^o1k73M7phpf^TakARvlbyOn2`<`6jI60TCiU(WUYQR;UstQX)6ohE$v6o zLL2%#T3(HOo|y4mA2BOWRi5Z4cxLU4ZoPGA$OsI}RAOanvN)p$Jhg~%Dv|gFO-z)x zE{0}K7o&Kdq-{_FDw;v^=S}xxfUzTlTz^`y@bZy;CEy5+xj-MKewm09Y*!Fn38+BA zwO`C%qz$jLK2_^NuEKRy9<6ah+>AQ;)1b?(req_$DZWgD#CZUO@~{b6io))CPMRNn zoRk%h&ofl$XGCe0g*#$vzC{T=oLbFnSdP8xyA=LVM@}G-Ddmrf%=t!x)3>m%>VlYl z;2Ol(i8QfA5!>~dSv2>g!HF42$kow41)hRpyOHo0{>PBn{Gb0{;9G$}X#pe@NO z3oGkWXG}ra^xF>)-sy!;K`D?ObRNiEMIGC>pTI)SaYNaH>Co3OP|V|_BQ~p{edzP@ z%A249#@2V7nv*H=zM@qp{f`mr>e=H=Ti6x&H@)3p?lkMjxY2OfqKJX^SSW?C^E+Itl=7wiQio1CxSn4H)}cENlSP?)#j_7}>?1q(#% z!Ym@~B3}}RL*Jtqc_5c%NcQ}baEVmJKR(~I_D5MJVXx%B1j?q|df&}jQf2VM^qT5w z?`PTo22<-BFW98<&+eNbPQt{VT2IM7DB_zI;pXl`$)go-^Hx_*+Y>#kp~9wKdX`>T zul3tKQ1$^uC3)0xHvfqm7Sr`k59pkC*lAp`QJrCjAm13f_WG>-~i)0Zh%)ms9ZMUzMdFJN3wYOW-h(d+|9zJFqz*5oUfUzmMac zLhjry+`Fv?i$Wi{D>6^PMne}(jV?(Sm)o1C#P3nvdnafH@*CLdyu$fh0N2ToF7mq$ zXYQE^_Q3+-;^d{xjsz>*(gi9DAVDWLQU?AZ9>q_HI=y8`-nvsrHU-dkCX$24f15on z%u1-sKAG+hj$D{%JaY9f&K^WuAOIK#qdyW6N#p{^d9iNR%KYBD$g#XlWmI#uBx0WS z5}hY39U1D$>I2VlnbnXt`7O`yRhP__Kb@IX>ie7v(}X#_#?8TRn$r{I+ljm{Q<(eT zVmd-m$A^#KBb!nB;Djc&u_srx8ma*L(^~-TQ~<`$Za=C3Fh~O_?nguc zLbs7udz-`k%@8F^h>A9y0INtLcZx^eU&HW7660+W;)CTrVD~K!Fu>7hQhXp61w5To z>`fl$O&!SMnG@$dzsZUhx7rihvY;tMyso)Ro5ym`TEgtRY{6M-HbahEMyo&Puby~? ze8f3!O>yMtZloeUQQ?D)Sr#iXVm9iUeDC2g`TsTkbC7tPFuCy;kT3Eo015!xIqCGsvgB`qy2Fg=i1$ZfG^_ z7-p6PnznH^I%Qmjcv&~U&B@9$9=9S-(`|vaE{msk9KgxJjC`e{7)gLdc68S4Yea3J(*UjpYnH~4GGgaf8MI+O;s8{B=8Q#M?h3nMlk2k>>fC5i5<@z=$8G=vsa z)n=5dWGQa6w-}rhT`z%%vA%f2YY!{$@j}2VY%z9=gy*@cMFv zmzC^jzYP)=rwxk~x@vcm_nycm%b!cCvH}d$!j*qDAGlto2zr|JnVFK|P7C&&yXQwk z6I$l5%@9^fZCVA6u=rd?@5!4r%IOa+SpKj!d~2H%$=d4m$W(a4F*abmuN?UjJsvmNM(Iy!|hF^MBS5sHdt$WYeXYW`4@yKfPbpSt4<}*MK1f!-GkuvsGx=LIU9Vj67C|7nYiK zoyB~U!T9Cjq7PFG?hYrShlh!ovsMCMdE_vnFV8!og`68L+i|`SIr5L59da=Z)W*Cfkp2^UuA|r5=V!jas^MR^s_Ci$9 z02IV%CDXI~3Fp^2Y3a@#h3O~~V(9i%PEO@Ah}Ax9Ux8(&FN`e4|=9Mm-RsR4JkXqvZ?4YKm{PjHPRJI3N$VDG{3~C|%N!C5+H2 z=Iqk+UMU24(`eVtQb<`3s>!dzOloR9avg=w5MdsqwYE33Kj&eG+VvZGU<^JbPoi>J z<;8_21W4^4V%wFalByz|3mPitPog36xuPI%V$oNMi-ruk%Wc1%3sg~!;hrR5tnU+Q zsDE}&brfo483<%vlqP7aJL7>eWBiiYTzp8))Fg+u`VcRnecTLYc6{89=liLrkGQ)+ z2VZfD9S&X~ZhYE}4}rSyT)0)teQ{OvA>O~M=+Gh{07>L* zOSqeH_NR{+5R;fw2_%#(`5MXTY5UY7;gm9Fniu}Zs z0+&IrZl~TNay!--sxZ9`J*J6evr7DD3qs$JF>un~8n9v?{A8=>;;7-nA z6y$l;w5;pMlR5+B{4NHey@bzORq8qlHvYIlr3GJGo7K6lD6eR&Xx*pQ67yQ8E|}*> zSyrUhgSnj2mQtPO*8U3rVX!yHvOBI2DZ4>W8@?zf^(JZo9z#PBpK;0vLRQW+9-n)+ z{<3c?Cgg4MqXTN!0Rvx?4WKBv@rEd*hI9@<-%?BE@IVM8*Bk81SIu#-aoweJ@`4HbTp+& z)Z{oKu;9H;x-93>v}X22Obsf0Ir|wJO77y9ESvj0t?d4H*c$uHD`?B!h{&Dw)v&D( zm*lrZ=NE|aXM3l;l&%wn%Ipc!R3ytn>4WOf`JWa?fT}ao%eF@Kjgz(Ri0;z870ba- z*2{n!{GI+~J8jmNrxDpN5A`bn7;w$jv!q$#hXW_X67RQ-#{Dl~b6e@)?@w!~agNIk zD@{i~D>Dd1%a?Wi#9sAbYk&vJhIyaE&R)xv7(LAB`(4x@dmn?YHragzd<%V?o`a-i zu5$={0EqHp^ea+i4J?xr?kN}*mn0yb>n&i_bGcaI9_n2XsgZFS%dO^w=r@opqo&npq4U5i zAe>Tu%3|?B&8z(>=!g!)y?IXItsd~$*B8z>={Er&dRDV|K}P60o?H*pjIs-&rD}y6 z9$|*_=9wS(V)DEiUcPr7EA&bP~7cOrv4sOz=gIH>iakeiG6LGd0vQL9_SAw$0W@d*< zp7@jS`4HDpP9S#mhUi7HazmxhMd?jhABKZ9pyYDnc>5Z04b@Fg*zg^iLr{i0pozQa z4-}5he8P0nPfywYNWx|M;T_|{5itMy%NVc-9K!vVb>@9n{8tFS;MaFs**`{+3ndrg zH=_F+=Sw;;zPtUF>D-CNfS*gS0lu!78DWywK>>QFmbZB(RC((GEjNBL6eVqF&p!Kh zgJE%3UubbHHn8J~Dve-lFYCCqFEbq+rS3XQSN=(5tvLpH&2y=1w`3QIi>2gnahE`n zamG(fWoc@Oq+Xg`AlSyMU#r%FHjL;j(BkU`Z};#ke`8Z)!<7yrzCg`HEu)V;w8b2E zw49}G?rEcA#^@y3fjeO@844;Wt;!0ZR=l8Cw5bpWk5RW^+BcfNN-g6K;@ze^4xY&h zK<)iVJHNe8psfMc#|kV2R7R0Rc~9$4kX0wmrq?P;ra!Rt^0(l>-oG3isC6kV9Ds;| zg!>Di)7gga(OI{vxKO^PMIEr!Vk!KMlU&WTJx=ik6uy>Uee}oi$}uV|O&pA1Z{2x3 zetI0`9VZubdWAWM2A$D$CI6^uNBArI@ejilAfL3bqycDUHBC%pz1T8w*)hwV{OY|j zohQw{@?IfEz#JH_?D!Ul*Iw4(was8fgd-+=4S7XpdRScT1r$&knwX8TZCtQ{Ey4lm zc}PZmbhUU+^v$@xrkA_4xalEQ8o~0*B9(G^wk8jEx-@V*f0X{#t71OGq8|CfQKH4z z=U%e}WIk}zM}SC#vxUd~%=l_tfxY2(zO3eC=%j8&RP$*MX}S&*>(Tgkg~jJM?{+A> zP7pjfaGdu6nw89K4s{a!-eIwvc!C6$WBE&SI=#ieLQ{jRFzyQO08Jc`YpVJSzx9w) zF4Kd}0wsdV_*w&!AEfQ9^x_TRo*z145Z6U#KI7@Fo^l{<&s{9-!mO`sDzLB22s-=> zRv>TsT|A{^qAX5xMKwElTQkamPv+ZIPS(mHH~Y_l{xXm8>6XJtv6i8d$|JxfV_8h$ z%DCd~rTVhhJFkeN)LT_HOh=LMlDrYHlU9-2tg5cA|H4qX)y)-Ma)$)}YG2838a$lT#nDL|>gFmtmfn zKc1!5(t23rYuJJ-Vy>+9MX)OZ8vSKeELz5NL;JhXH)dJx1x;(=%y7I=%A*mXCok8& z*P->j6y8JJd%zHG14&fdY|SSUuzvbk^Etf!pwX!s)O4TrEI?@4gK!(ioEPVg-)zCY_4h7${*-ghuI9<#+)Lk@wIy9EW)pEhSd^8Z%yHN8D%8SwT zR~bi5%dOG2(-`l<9381{i2ktmk;T{Awz?v<%Q3HWBH2{9g1N6&~^4hjeRo zM;D=1v|MUu^cyy;9@(`o#$`AB^52h>rLYKG2Dmq;0BzBy0e0C9zniJ<%6Sem?ck^m zO(Vi7;B9jFc-Qu{u;_W*;^zHu^%t{6FsLeOC7qMpD*0&lMI0qWVA4o~R)7H0pWJ0O z_X|X)abQ1#SaX1t%|!R7d0f+WmcG9>67-^D6=J}0Chafa8NCeg=pE^ey%#> zu(J|z;{mcyeBgN#u?qTwj{7<%+VGMj+3#1IF9g9Kdi-UZqa0o%*15(ESNy8#^0_h~ zc8t`t>v=fOMoNFFU=b^(Yh>V!Y! ztfLe_yhyY`GNc-`7S*grI za2)v&nh3G}5quZY&%zSO5~lBjIfk^*elamv{TRbb0Si9o>G})VM4kM2nK7+oNp^O#i&uAd2U!*i$~9Wg zPCxL$?IhD}WX({n&UcAe#PyZfF5CevLDm6UYhGe9rgt4_;O$J$igkmpAqbiLPI>p2 zur_DM?cv({wx@?<0G!rrHd|$A>hW=lX zZ0dQggeCvhcy@dF--+*H0@wxnU^y|DsX;MM!$nMNfH#Vn;v4#gi}`rE`eaAAm%s?? zqX>%9Vw-GqM>}h>;}P6Fc?l51RZD}+=$k35{wmL-FWRMIthA2Bwf}P1-RAa%Z4Que zYJ9r7S`fhY5O8FqcvEvZkI~FTQ`79P{Y6pFKICP;PPC>D`b~`Q7{^Yy@pLnUsswvw1BUv@w;WsY@`-a_OqV=AqXz#N#IZ!FKuau*2n$9Eg%RkQLt{QmO&%BH15fE60L z3sJ~4)*##6x<5KpkSQB`Y~Bawj9$7!$ zVs4FzcUpDssx@Z(re0b9mY`If{S;Jl3~OVh7z^dURSFTix3H{rt$tt}>Mt+$S5Su? z_Hv1AVy()Gp1~XMprg5VS@1Q}qaIdTo&I}NJ@<7&y%!z#&tdgJf_4!-OzzS?NYIB> z9N(&goiS$J5b^>0wJ?VH*{?OVJMT1#a1chg-;?D*=s%?H)CF6AZ5;mCS0v|Rqu{>j z+iNlnh+=mk7*8+uuPQ8(~UqG4YYk$13|!dATmPS_}Z{UHoEXzsVi-*Fsr=PLxI#Wb+tj#)GP+b#YXS zh^&vmJxogBX4@ngmKmMq{6Pz9Z{3l^w?UcNfj%rvmD@HlnuQ21dNOa@?hPiRH2NUd z6tR8XvMNK$3*#Ip@5U`swnR$nlJE9~eWC+r(9@_;mhQ1z?{OWx(Mdpljs)|5JkNIZ zlGjjN$w~5ca?uH9sLjBBx?Yc2pb%kRu|BuZU{bK>Iw?Mu#GrJreY{h2rMYZbr(D+V zv6zOZL@NyOmr@}fz5LZK{7D9r(olib;%!y_xs9h6=P$lbX@$sIKo-#QkCdKByQWqv zX@jvivxcCCgQ*5~uT>0Qt8Y4yj8XeU+|D?hKT|{9B!2UZ+NX zs9_?Hr@^!8o6AQ%>F;3t7zs7%mw*JS58UGyul|StTN)k8`aob?KbHeb&~}#R$fX5Z z@2yg_7%M09#+u3W?y6n;F@I&i5Ow7>%=(7YG4>NE)nAQ-Kc8wOIABN{U2oCY7occ+ zo7U~^KQO@Zju@by9c3Q5W+lND|9DHcI3$3QMyHolC$8B0U4q(znqJ|)ddBT;J0Z*% z>niCk=IJ`-e)l@2BiRe`f&<(?*J?=F#ntMAoIK?-5sz`k@a=F@B?c12N6ySm?0=G2 zQ(^r%yhK89V=7eieidEQ-Xn+h!)wAX(t0fqb<3_7z#hTFXE&d2#2nuOl zi>6%`(HW_UoYFn8h@WQ!Zt_adNlpuj)Pmm{am?nsVKS}ObR8vUisUZ6O+i=m5V6EN zz^aI^O^RUk^hM$Q!PRs{l6(p}=we>$2cW(u^kd;q4GmtAI?;64`#tQY0QcmoZw1Sx z+0W_`6|e-Jht;gE`44_7R9skUxtup@CODqU6K7iw7FTXocX(>}i}P=h^79mJIa$Mi zc84eN4z4_k!fo$<+tZV0@=1nbJ9}+5e-Fm-{Jdc)6e+S&7AP)3mWtBWK$#}-fI7+f zavX!$TamEKkupnVdTfS%eq58M=%;@)Af2RG(+PJhv#qS1k3DNK58QA5u8bd*Y`5O*8#?Do%(P3ijp~5D4%j;d$8(!iFFA_ zY^r?Rp*P$srp%7Ea-yT6XGpp2<$Y^`6MSb+GM=mMbs=~9Ns1IX=JR|Is`piwF<)8P zD&xQ9*6Rj{sW~LI8?9f<DFsLkyx?B*<3sIlXeuBFYf4&yD;H3 zk@nXTVL;;QkUiHH*3tu%l;vFTc#!l}-}0XiA1PY}G;$G8F%89WsTRPKQX#1ITxUG#bEJ`1Taiv7xG6elID#XB z=Pa(TF0W|y2l}(ALRk>Jxv~6Lifp7pau?Svkn91cp1a=Zt=O6ET(ybYPDAHfQ1v(z z-CyA~j_{u`yHA%*GkPoPm+?wh|d1p!M8phop6SbO?7~Pl~eWm-$lki{xY`jhV zd0TLpp)5HvG`Kl1(nx1OeO?`H(&Y)X^T7rcQSGBUthQ}2P~WnONp*kP9IYP=df7l| zofWSjcwmG`a(Yq%unq&xzRWav@q?6uoG!z*EKAVx^nhY4adbM*pss(K?RUddBkO_a zja#(a7agN8`X&2bkopR|KJl(3sO3dH&LZX0wd}%rG?yBGLa-7+D_xYudGS)y>d*Cv zH}cObPqE^M+Q!wsk9#`3Lj~~+Z0vp7Joj0T;;XX16E?LQ0m1l7tGVr57#7-=G5u9q z&0~ks7%~v#1LG9%`&p0jJKGYJ1UY)jMI4tl8-g+Qk=gm&u8>U{x}9!JwF*2>I#5yw zm3z_f=Y}_eGXtoI{-A)Q36sk)vH*_ek2yb? z616s#A-~Ud$M<7|FF!>>vWmUz1nA?no*sRlD)ZjuVJSmT>6GKOzV{V)WvCEuZOY@o7~&whq;Tw~Peuc5VGwHyz(;Zj-e zjR@z37~m9vOEu==f4beD+yM*{wR{=BcZnhw>=c)Is8v267e|9zKPbODmCE93`nW=v zNwR4jqte`74*0@)OjUo2tA|10q;Vykmv1HU>dmMdx=m_yjy|#3iN>s-UN!@cLTNY? zib|&=4{L3-9GDe0#3A7yG>y&P5Jq%P$1k!qoEcGSAo(*?y&j6)Y3FBqW=Y5|9qK@* zXCvzEnE)Wj+r`ql>0+2Q%c?i$T&gz$n*~>|U&8z2wdndLeNz7*XjmwTCnsj%^aA9~ z4j{BRe)V{JKn?*637|Z}SSHf3^Y5qh+Hhv7JZyV2zlyJRD2@FO#nM?AN49PX_JILSZGnc=bDZ5g#6Zjh9a!e^h)blBVpzNZZClR4zU;dZ$-dKLCF9N;%Thwe4(=`Eir)^w(*6%~)VP z##xN&<0(a8VFo1+d|NrR4I$8WB+u#!FXxC=O$FBEl0PMj5;}p^Msp) ziL~DNJhVQPC6(+<|L8_p?^w-wN;h%0I7uF?`coe(bd^v@*?;+*WV$ zcIqkaqxtJzD&G?DQ5_j3)?#2>&(ou=Z`uVA0-#z0kJuOJ+Wkx_C3CMuUb>WD58#Yw zW=hi9Ab4)_`nkI^ylkE2$)WiS_;#S-`Hy32Gv>ceIIKyg0q(x|yoA%|31NM7sM*&% z_iRJd{d4qB9SssF9LwkjCTP^j@X@)}t`O{+G!-~3!6RtMP3$n{?vXcd}k%Yf6~<}CCk3-DREo7t^QWe998lX;B@Y#UG-ob4$t z;P9S=pGCL*6G=*P!yTZ~BgPzlDpEIhAGww~8)^E)`lh-_lzDfgyqy)}OK(boU7J3# z!+y|9r79Ro%0!!4AOwz*TEln4`{^vK`3$aY0N1Xy{QkY$JCNXOgqU45eLoL-UOfC; zy>6%&D|`R7XUjH&lbw$Sca&$Y!%3F1A!bDNNTIf9Fqy3?qAdFe9h$Zi zsfJVtyEI(l(cd>;raWyl`zj0q=G)G}GaIdtG^JaaTJrRz8bumv95!73L6(fPIl5^= zIGni>jHV=!&J>4_53EglHvg2rEHxDW2^lqbWonwhMNOLz9nOY?oJU! zul4uZ2SIPeY}3#-2hF&mR=`>NV805RmNcXM;Epb{@vGyfn!~w#bF{` zxbM@$(O)MHsi;pzlwM~Rsbp30p*@fj3AoIb`FqsOF+rR2(453`xDoA1>3sWK92_@Y zAx-mh!&p3BgbngUqGG{cT>zq^3ZY|%{2wT<%=qm;+ptBMqK=w6cq2vITa0E1I7UJu zM~Rud)ILD%kAF!1$h{N3T7nFfhvC6QP@r>Xu^ETr-G6S9jo5|;4m&gDQg7}C;| zkQ`fUcQw`i@CbyY;4*xDk$F&vIEtlN1{BO4W(a z-Ql>>H!4No&|p_RR1F$;mA=}IFWRzK$lFx1Lr>0)=5OR4%RSLf=W*r9e1={Py*{aa zpPbfVn5ws7ikd_oz;MR9bt+h$!nf9tKi76*xxI+({^l622m#J!GqDgj5rpYnj z*FV-jU=z%_$wgjX3(qcpg|G1(2`k=F#tFl!Tv^P5n2i0!F4l#TqYt-h88#HWEx98G zm_~UesMrdB27^g?bV7*;7Sz8n-|l3j3OJfh7;N;+j=sCYTylbS@}BDh5&tuHN5+G{ zabESwDZ!DQ4_bitTrnRYY5lq2w*F7vW0G>sIL=bz8kd5UNh$S1Ie56kHbAvOO(m7LZ z(ojUbBtcc=5`j(fV{brW;sdh1?K?qh{A$UZIo^9Q9xTp?5q+p8bs7(@cDZ+XlCg#r z&G&ISX)(Bbcl_mJ6JVY@dblgYCgPX<3a?YScqR)s*%e;0tA;= z+c-)WR!iiJV^~+ei80n7EGkSeYhmYlU-(hJ_9bqWqNHFhb%~_a>oMy>$@hl|!|&M| zv_d7QAc)-TB9MC_uB)oV1}>{YZIf`Z9(2)(M&|QLTshZFDa&q+P8&ZzzC0bSVr!zi>m-m~! z1T}GcTimhPxPc+4KNEdb=DW>dRu(#x?b0N0!w1V9MQ zrIPdz5c~0MO3=!4S&uB#v7MBTAJ|TO~xliOafok>V{g1?`_K7xu#DE03BW!9jH3ea*e#A?qQEmW0=u~`_hq7P1Wf9Yg|@E_1YCu&D_=@|zI!--f8> z#WJBh<_ch0^dH~9=BuOAXgkX*)aeKVxWS)fR7@(8xMN+VA?-y{15{LLU}XHv5>o%A zNLZ-cqG6#)gtMa*+D8d7lC~F|g8C?+1`79peLrOw_7}gPX}^;lBOBB&8nvqhO~?S; zQ+W}kTMo}sjA|VVZuRB|)Z!)LH|&LPx$|YI{|O#6jkGRZGlhH3qcaoKX(M|4ajVcS z!e@UCivNU$pzZ_=JEydm0ufhmn_lzD60h$c^kD7bH@EUo06kbfL(de4iwlwvL**v$w;t{*&;Y0L5c_8!w<*dr3sp}H z4Ii1CO{t+ep@X!V$bcjLW_5*O;alm8olrk~A5l4{JOotpIiu%dA75&+xdbGnM7qsv8^)eE72gV@}si zA_Un)_!(;~@ajeo>Ew42+UC@;W?5g?*)%4zxn&P(m;y%{D~mti`Z^h^6#H!ptCNq{ z;i$&U@yvt@M1s!%W5G86rBN1eNo>`vu^Y+R|9R#gBR~L#JxFXA^^fs8XLanRujxvB z=>L4@hg(E}FpOS7!QA~Jz;6qmR$Re8fr<)B2Yi-Fi#3-JGIlG3_)#=6bSeBOm8OFH zt-)ZO2Y^OetEB<85PLQ);Bh6n+aanEg$ELea|jY5Sp15%nP*`x_+gv8AC&1YmaS(#PK-5YSvw{fqG1&`!WdIOC15ir&(lAfoz&Q+q~NC=W|Ij{j=WPc z^Dmy?!0YQTj_;KaC5iOI>_>iHvVn;(tbvE8CLvY>Rs+=yCJcvt(jD>pQ&RcE&|}uc zaX=+KbF{fh<=5G{2r)5;=2A#}JsiyMrM2A*b5DtSA#sW}GCVPm z#`(rs6h_1;2;?yz})^zRsY+C z*g0NoSH(>#v+Un_`rmH-=Yvb&7FXi z_5U8!|J?)JltA;p#xywK|C^B|_}h=v+>QUb7Xg5F4AA`HULAq|vjY4Nqv9V9^rI#o oiSGY!?>}nz|EJOa%QSiv&1I5l7De10eFpr!msXOhkT3}NUv@L1&j0`b literal 0 HcmV?d00001 diff --git a/Mathématiques/Séminaire/Logics/Pasted image 20230904102817.png b/Mathématiques/Séminaire/Logics/Pasted image 20230904102817.png new file mode 100644 index 0000000000000000000000000000000000000000..b5923c52f0b7f3d826c93009f634cba4354fc42a GIT binary patch literal 37144 zcmeFZcQl;c+cu04L6m4o^hBbQ!YC0Xkr2I((FxJU=q*u$AZ6B{>s00RaJ};*&>O z1Oy~h1O$Xh7tVuE7X1z?z&AoyEro{!c^xeC;1`6Yo}!hiDght(`2qnkArk=!{uS^g zP00M;Kg$#H5S;t_IS~Ots4W5Uf8J38-|_!GfG_;t{PUeCiRi!HAfZY+_g_B~CV@8y z#O&l0!8bCeC;F}g1dKQFUxbQUH`WLUWC;`>JZ%g*Rw7<5z91 z?|Ig_&I!3%OV4d9t<)5E9v+>z&Lv1FlXh~+JtQC`rjh;ke-DW^gU2=*&wfbbL`2U* zd*K4dO9G;Q{inepTmO`hjP9&bX=Gmp%9;PWw!iO^6Z41*a6BdYcaivNG@PDXJhQ%+ zvH=7np(Hm{&gcccTym;6|C?U$&?HS1ynIFWuP*%UmTdjCJ7@I|d`1Gg&-mds;o0T# zh~GGWcIT5o_rDX-a-H1|(2K@1#uMKLdeD76*#_b>rwa7q!Uq$lt=V|7+kmfsKl((w>me)c9OUDMh@p;33XsG65M zw_M30Im?B~HOlqORmYJIEZ`2IKI@q+5h2%bifJ~Qi9ge{Uh{%Qry{GXaMs%5KmvPB zzXOxtKGS~8LCII>K434MWkXL=K%;EipdDmqwkigc+)Vt;{mg=UctE56r*&7h#X}}* zsMtErwl_UW3VAbHuR)-Ct-NxHd@&I z5e}8}T)p|GGMgK%x5_L`oZAFxpU*_W+Rig0%;b?w4D?JM%fr~*(tZQ^d?h}WzN75{ z({Y;@wEyd-E9*skvezPmQkOX{`N}Qgxnd;jzR(x4n(>vp`x{b>lbY%Io_*CkCg1r= zw9Lugbo;26(;dHrBDv8z&!T_Iu0Tb_b zMD=>}gMdjB?`2Ch@k!$1mC8kw+LwE=t97Si)muHvv&rv-?v{;u#JyNVmyK+|e~r}n zpB}ZZUkzX(WDw7(3f8jy_?Yp|X8XWNr)TZn6os(!)FW7Co&%@OpW0z~PAmzdUQ%C{ zuvEINt~r0(78ufUyR}zjbZrXkzQ5V%`TD(fS6EHn@7^IUx&pgXzEBB|&QCeAAAo!s zk+Nr8kxJbe^&G$2q+Zxp;cDGmXp!wlep#};Pi6CdXZ7(8PJVp-?Kot>sCQJEk3BA` z`TbRkuzL$Uy*aR3#d8VX{qAL;C$$o%N1N@%oziw&hprv*67qAo-Z5W1$A;ovJ0z^u zn=a=sO5>a@wtofvjO31!+8O+w$y{`ly3!JD?4e&g^_Cw6g&AX6eAepa(GJk!eJ*7d;TvygFM`TBH=f2o*U!m>gy?rA7%_4vt7S;BGm zNESeByBr<=E*T1(^-Ec8r++8=23#tQ>_OLHC{F__G`LHxtX>8SRS8{dg-K`x&Fs);v@6I}A(43-^@$L(Z z%Nx&cgrv{I?{7STwrnkzjeA*tagVk(EUa+7Kl4fZKF+H>PQo>PchDmI1x8u4Ox@7t z&rm~NHYRp9cp;Ybz_@hW?@+?jm=2M~u^OQ)wC+$od4BZ=XZS_G6m&_C(paRrv_8bH zuRPo9yP%22&7n6+nqPAS#rqUbCaL`|5KWJHud4RFaJ`MZ3}#3D{`w=DTYTkNT(%OY z>5mp8dv4J{@-`mV9&NP7H$a-g(e(>RR>}UVS(M%V(XE3!X%8P68s77#dvlP>?)}-s zE31mI$9b`JC*S`#$NG@Wy~UQac*Acy$CP9)m5BXN2ckLm;Zx8x%&)md$<^v_$?cFfO8t zfi_!1mE=`rsE*cy$;8v6xd{{36r^bO{G?akVA1i=T%(qF-o|*2nZXSGOpo_!%^bR* zf!rak(zI|ii$Nf-0c{zr-z?Z$=4k5auU()K!qq29t+Tf{_l5k@_xakx6^hv*gY=vH zG{FPihndb%b$(hh*4Yypv42RLO9xEi`tDDbGu@!s4u8Ho>PbB{v);mB#V?|2N!S;(?Ozhbo)YDlAs@nw}jC6(MD=z!A|00Wi zY-?CVu-fH>u}y@@qE`o_s5N z(6}C|Jp&hg+$#z3&eZ6qMlWWfOoaK``-G{9*-mQwr;%cezXRYO4_+AXQEkHBGQsv2 zxwl;pJrgWli-xxvC~gtI8>T&+kaDEq;YvEW`Kj+R4xBh9h>wA`25PPR`-_(a8i|P? z5-kwu`^ImRuY_$k!Q*&Id;3V0;t8LhZ0Gx5b>}l$O|8{i`kY_bEp!c1yw^FNU4c^T?6} zM!!E_L)#pxmaUdl%iev(Io6GCpK2rId=IvqeS2*ZqGA3msn3a!VL8tgE<4&E2IV5^ ziq|nFFP3vn6^b{?>?tl7)h$MGCOa#q?yriQE@x#VkaGzZHqu&sdr4StU88xr=XYwk z(1OM6{fHfZO?}XzbNWY7wQR)You;V^`U$XB8RYWD&p&=p-=~YUT0uID%9ykOeV3m% zM{^hRsycl3CPSMTb8sSuvLoAtHimbY3?AOQ?qaVGRO1k^{XxBtvE)7`e)l&iH)gs%%g`mE?l!{ufyQAetv4V zmkZ---3sjPE!omD_K|ym(^R|sSLb$N^&vRthdoLnDbZcJI30b}Pe<8*;B^kS0O{_eDj`gXCOv6`0=^jD{R2P|?Y zE!yB$F-aQ);{DDWvFyi+q%+h%z+r+|%2%Hr5;XR{D7y|h9OLYeXnw=L4D*fJA16Fq zsdDU=TaSAOuK?#})t|fDF?%ajt6rh39x;ci*~3Uh)fN`l_rf@*@02y(D-{{Gp;_rw z9%kP->iXLC(w^>lXSB1@i3fqHBLDr)jH8LBy>Lc?=54a^dEOcd8E- zay}0ulrv739sM^eJy+RSGFXlJw3ol>rouO5TNrAo_}DiheZSFep?Oc?Rqx=BjAqyk z`K2?mo4+beP|F;x#rw;g?stw}CDK*min?2iLs}kJ`TTW3TY@xH1R)nKNZY(r?qiI*gkuK71yZ*9cd?J_tC(9 z#Iav%mfmtLC0TBFg)Z7$LxyE>Z(**+8Y-lW9?y!^WtIDhcUZNfpxe&6BTn*{ZQP7X zBe2qD9;J!lQagGUq^h@pqZy#tCco4Y(_E1EphaFyyY-)as2>nAxzjXL$DbcqeZYnm>`=zi(bm1 z5W)DnZ?#KbcfYQ^r;A;IjfnEu;z-$^Cu#ce%=_upE%M)F%}5kkaN&>K*#00#bq6l^ zj8v7^iwDCl2b1hh%<{GpG!^naT5kcP*QjEy)vj!~X6Gi2A?P;lb+gx|G&Npix+?iJ z9KP|*bZp0Up$^iNM~RsbE+;MU#V{LQVG>Ae63b!=GLd<-m2ad~I@PN#Q!{eCP43&E z0ck)W%Jq@rNw@(zg>MHxORwrmFgS;*-}JnFZoqN@8-6c zJKqNlQkr+>wAW)4-d~xF9&+uJLM}_DPi>qKVLZNS(#gmSN&AmbGoQL<4LHTyUTreq z^t%#0>_40?#+heena;jD_r)_obC)d9XX6e36@OF0xCHTx1f-ob)HMJ&~lER*k*ev=^+%7tiaFm}V7)k+Cg9vA#-q zHgI`zS@+Onlrf9rF*WSichJBmj{;?|I+H!>89x(3$vjK0wN>LlTJGBJx;t!lD~0H> z)S7k^i{zd{yfJ;Qon3Bh3!AqTjM<+>7V=w zFVPzhUa*$+J(t;joF3zAOz(=Z zq+!1LU3qml+lSm_^Ip<)k(s=@@5^?{?&%ks)i?&&y=*V6TBc4Ur$7OSg_yUE(@?p7 zgvsXWzC{b9AM7`5beJ`FqqbG_Yr`-Hj#UiK=`nrV$};ItIt7x~9*>?6+=?MD^gEhn zuTr9FI>2Qsj6gP5%h_6(t(hl@w6H!}?4gsXt0_U$(&90xfk-W1VNwd{`fS=~6BlZ1 z0|c#OsOYPExoRM%L=pRkI#D@o=3P5XnMU%ZaiRX>j4X!tZ08RKh=*jBPI25G6=I<4*Ml_6z!_m8Qgv&ECWou$fmBiU+oH(4!7$G2e4 zmQ3}bd}EnT0t=2qYgW*;E0B4|C(d+2vL(iMVz0@Cl-Ch9g)NJ6WF)Kg`F=8})neOQ zoG~SZrsy8qE=Vdu?73B9CK!!@BmbU_Bm1hn@x7OsUG5;4&i9w7w} zpFP@MubKI5T5CQ|H%YfJT2*G~7^x~sratSdM3USLjd|LasVSsOZ@pl+`0iHi1*;rW z%5BP?99X{DRb*|t<{(^gCo~HeR`X!pW61LIuF0W}zho&F>pOG+9ZTXEF03hMIR5w{ zRe$e3yYE&v6#Y3Zc=#p;ft2n%x#GHS>v+4>s{3Fue>J-I4^A`UfLJ?z?=*SqO$Bf% z&M(>?=k7X>P&qTKc>d_zG%&Hx*w<{xHPe^0iQHW@J-v4&*03c>vwHblMD~HR;Go$@ zGTX|qep*BH2@VtNDlrghFr~8iiCL=j31&{E2+~~*9N6#0G8(R7X`08akj*j9xkq+K z8p=ldRXv`_#0*S&q}Yp%X9M}E2k(o6nG$?|tj^*{6UKnMJDIP$nPcy=GDMVbmN;DI zM?KgOhbqfraF_X$sDREtNC=BWOr~Y5J~!lHWO;XxjX~?*$BoLyt9pBIM4QFklQ}f2 z%3dC-=X2@LNmp-N3z=@zeJ*+8y)BbDT}G{OtSFJcQ!m@GzF<eaD30&;40&#{LeL|_fHm|LGYOmvdU+C_2CcN9y? zy5*T?d@8b2Y;Zn5d)ws%6-|FtzR^Ss8&Ek&p0pR;o6my`anIMU+u=0N|0oA*)wREr z^B30ZN|tdxt9fe+>_LLLtPIbR&Bv49@vzaC`vVHcYU0q$XDe2g9(&W57%*neX@ z^a>nC*wvuRB9j!Qaz;1PCb~M67&zbs1cru?*Eefm^+A3rEsFm=^=c36zp~3zn((qA z{9PWz&!e)49vd=q^~fRoNy zX)}w{7p^^u+%tni4xAg8c@OkSf}grF$jU30HtS~j{&^Y|rm)M4fvDA+W5!1&p1aE= z*X=9u`h>lm^YGiVJ-oPsSe9}uY+|Hf**a|Ow?a2+Y#%ATm~iCrVXX#O$I(ys7ido- z>`c-^!ABhk6yu+HgLr`}N$qr*y>>D3k!rL~jm!vf@5%91?`~&k2bLRo+#`&!3dGeN z{4OB5>n_PC`bjOoshIBYQ)?6I-V|)JlhtFeKJ#Za$}UqvJHECwuV%-mGjScAp=Y-j($VB)tM=3hmjFdONs#Uqy z=(u(srAkAh`VzwhSvnJqH;U13>=5Wcv)Y615{Pq9=ge5o2+Nrl$)9NX(2-ql@tylb3mmGBk*U!m1i>5%- z4P0QOcwC1*to;Vo)SOnUP>8kf=Iet%=w)#LB~}-fiYf1`!b3=PcYvH>Uru+kG6&P4MH1QDjlxF$pj%(i@y>VkdKjqPX{k0 z2XbG}&Prnn@#~4aad=KN#?kR%;4X&xhW{NCZ6UCuy}41BwIbYkzn6v=@&a>QUokjh zUp5-(JJ>+q>Gz^)9{v`ltmW=^*ff8V6{}vV{s3yI(w=(kj`fMs;rXyN_)EqdH}|ns z8~d<8=DLejXq^5~N2lv7^x(sINy|=#o^6y_Eeg8toIYR>_l1~Qr9RH%UCxaNT)oQu zrb&R?UTOTCXS<{D#hP^djoS~fHsz6mCm8Yh~F_;lvA+m*dulqpeZllSLsgjpmei5wpnS> zA%tYrgCf}RFPH-=54VvtY`1m*S zN%8i2{dJZT-R9>f0luu^u#TD=s(o*i@xv=Si+jRvVXVgcHdB#2&Gz&_qG|hLMxq~+ zKsrhkD@{@ZAYYZ|B`%b?53&7u_oZP+mnGgtoL3<;T5!RaVq zu{XR^7V-v8ikRvpex~Rhw8Zue=r%!VrF0B`?l8m&-z&?rz58~U%vZd&*n^cav1%i> zZn?n*hD-x^tAurkJQ>D!Yepq!M=ts#>^o;VBeQCSL9teAR@%q&B)tUjep+ZrN`gyl zBm;?`F)%D`?@O-ir}NYi8TBn993gOTc||6XMs+NefbHSpChX2mK$^tS+V`MNw3kI3 zJ84zIJ$Lxpn171yBflOgrHa&5`cgk_t#@V2j@5v5T=(krY7hXBqkW#a; zg-;^pmVNYL!e~SL+~b*B{?4iy z$H(&uCXn{PqnQ`&3^q`s8MeoZGV>;~oNtFw#r5@>hGfUzdN0Ht5HjBko~{}mRBLq? z@maZ>vvX9uR)!9|g0qf4%-|YT;=5mP&ZoQ^fwhzqXrIZ>wF=cu%dG|I!2@Y)vhfQw=#*^40aatP4i(=pLQet zrBAGDva9HiSr<=^K#*{ulkd4B=_Gk{x2GDKS{e&^k8&PBW&aF6vd_`b8L(~2MHTYT zPoh^Sm?5Yl|BF!@vaP}SLCA8^y_Sf|0VX>>QABAbRPuWY@8heMg-^M^h0peT}3YAT9Eg0$~WV_*%h$+=9MaXl`GTQXP~T(7nH91NcG#GQvE4P4Qu$o35mZgEYMo2=YEoJ=dE3dVh7Ih_OOSvo7rk#&g&33rN zFxE2A<}^RUn|FRj#!+g^bg;(d{>?iUb;ABDZ{UMc%N6Y}LEvqQzp z8qFVB=;6!^W6Xz+FFA1LXgE=N43tuq@>g=lDa1^vRI!xgSSMF8M5fapCEZRvz&jpFtc9r8HfB7yvhYHgRO1n;!=++}bptpvyveDT%~vnTo!v~qpo<%GaQhup|d%q%;(Xh`402mf~qP6@{oVRtL`vx%D znI}?HH%5--1=o{?6|z@lbzGm3&N(7pTa98D#Zp$w>}Lubp1Tn<(T=nC>u~JH%W#?$bH!55ZAnd4 zcWUto0*ga7x4EyD5Q4B;$E6_u0f8Y#*^2auCQM|BEyk&<>D6+}2QSR1Eq zE6h&jC(;AfWWtC~TR7voMMW%GiEsT=_l%!f7y8s?k3A7ZKe<*+PjuZac02t~dPe|+ zXf;^ybia82{Y$zFyQx)rLJ(~oBMSk&=5===q2^(@%H zJY|}HZA8l6unPIqvHTdzsliouitA#-QFs!awJ?xGXd`-@2_MrlJJb$~}Cv9hWgK zx2;qO(>Pu8nBcV_-E`W`=c8{^XL>q#OBVZNdVw)5q2*&;U1nm`_`%^Z@NnaMcP*bw z@)7qtK1SZRCq)Q*z04aA_u5Ocs;La`_pMrqoc0L~-W__si@~5ZzkWTi#O^*TCSTg@ zMC-8q@aR<)bEi%`c7K*94Z+^ZIQ4E$Y_Yo(psV95P}W(ZyDZ?@(PkG$P>5xj%U!++ zH_FQPD<}7l=VF}6wV%Y~gyhe%M@7i1Xlq*@GE7Fn4K(4*hK@C*hU$yML_d<>4G}%= zlwtD@nj2F4_)e&$(I_CbS$9Q~@${1n%DK<==XmzAjnr#l2*uGv5cS4o=R~Yg*XsFi zW7W|{d4GOgjlBZ7g>r9KBCk6RSPfRN>?>8}WXCb7P)atI7=i6ETDJJ03_a_N>FOyy zr$jO!id3<)EAraD(j+3IhXbh!C8Mm00>P3CD%-m`LRto25bfT#Mp$5~G4{w3U3T4{ z$2g{lgk^pqr;=b}kRIJ!GP`_p;Em+>{@0WzY;K9Uc0q}KqhZUAW31uw#rd!S0+0`o ziFV1yBw>4PIp-7S96CiZv z3@ePb&yICW)-w1?7aZRWa)@_P>y*;VJkDuxgxkJZ%=)K^_Ac{7VV#R!pD^hv1-_%N zbRzpQ-iQ6{?{YcjfEI^E7pkw_HTXPAxu0YUG(`$3`^PkH8*Zoa91~)f;u(ipwD~kho&xYsTz}vWVzYyzf2+pM&JcTS z@=eU4zb3S<&Z|zB8Rqfrq9--o3G>eQ?gF;8cr>l=u`<5c6DyiPe>Q$Pk$K`NJF zPG^%f04%HR@@p`Nr@B&|4@h2t1UGceIA5CnxWT<<;p?+cffY(Ey7ma@uv*`KrRVx; z)%L_#{|9&97`Rtq>d8%PehT`@-rvyIZ%kdGVz}6 zNvSi$@)x~l|? z3Llp{TZ&a-Qtl{~Y!i+*h0x<}?}X*N`lhe;2K1JtMXkeDCJrC?PFEEmddGx0TPEi& z{0Sw^Dv_;ffzAuRlTj#4ZLq~&)S~=ql`dkWkb^{<=Yh1$j@{L)+pS?Li$l`C-+t_~ zG!R~uT5$RHSd^AK?=3>;QY1oVKEeJi>a_*02aV^5bEx&}2UFdCaSp z)^uK1^(gUI^ee3baI`d|*+r1v=CKiE+KpEn5pwtN$tzid)7NwXag#w$42*`<0;C|k zg~w^nJEeAwQsXrR1<@ISEd~*&*gvxhDMJe_UF~AyOR6Z5tfln6rC{c-Q;!tip{Eq| zy|VoZ917~s7s|&AV%)JNCBC{9dfM8zAo@kV*IzIxRu~l>J84mL6P0=!MYT?sZ;CLb zz==!mmTtO>I3O%%91T?u`r^YvZL!B`O~{;uodzvMnyw4mCvpn7x(sGyrBT4wupz3! zsmjj<=a7%2gRNSk4U`7`u8(HUd#ur@qr-GI`)-K~Y-c+l-4arFXly);Aj-k@noFiU zcxKg;cQ55Dd!N{s-f(Zu^)J1F3@PiBJ}ie~UzDPkZTLVAJ**5uULl{@YbKQHMrKno z2)G*q+o|-zm_*Kj!t#3+x}?9c7iUulwGiwNt(FE0t?-HW#XE(CTNi9Z)^yVaK$>)` z3~hG>ROdn>a{KLxs0aZn;{5QMLK4O}q5J_aWUcw$V(xV9E`(?uK%sxmTlD(i{5@9A z)9on+IosS$HTE3Ex-InmWc_-6vk)>e`XZcJtV1PEwEd4)CZV&4(=U)Tu|w2Vk=pv`={6oVU+x-KN;ZUt|{z}QT?%U3(xhxK^!3fR&9i9sD&Kh z)zJzhF;}0XzTY+2El&}qr4F_C7hV~s6dReC%{ia!uz{HCTq#aS&h|)NzEW%E%f&&% zSPp0^$YuIbsbFgL0dJgGd||ufs0@QS|GZ)?E6ukW81fM=erRx3eMR{6+J_qfAeX(5 zQ_~W05x7ty|BdRy@7ihmUCw5YG7E&5D9G0)IFB!4{N*gF#_nXt&T->L1}79m%s3la;g1maWTEox$kD1KU z3~PhZh7H9p!euoB02^a~#kuiPUe@|VeNg+|Rsjpd+*ET|>XM&MW>y4w_IJhL5Wf2* zK}IovjMgSl+NU)+RIR{qhX^268)aW&ZvU30vB~-tbH~DECx6vZGP~w5<0_v>pVUlS ztZ;i#tB_r^p81>jnSIbUT>zuB}L;?S&t8_77C=E5IyXz4+rvE zr?L21`!KV}&dlcRM&^8|ytV=iHZCpiWPkhgtqikyu`tS_MAz&{e&NsYHHUrOa74x3XW~_P-FTxxe&B!15AAM z?o*-vmB#mQLl7iwCS>0!Yal(ru5=q>e`7m+@VkgzcFO&tDXPmpm3) zab|y>X(a_&Ye#hWfDDV`J(e(%Gh6-^&#=uZSE&;0y7Pv#8ras2^#bv9(aYt44M16l zosEt8_MJPAHinm1;)Xf@&8x8my&QS8(bstIv6%Bej*U&yzLrP(=_;=zy*a<-Rn&)G zO{26s-8vG;ieD1f&gw9YHt2B7%iORt=ZFc+k%~p0i`toeYQzsE7e~&SBl$rdu&sMz za^mUEoQ6A~>*jo~9gqUI8N z?HMZ8dwuc#UU1omNuLM`p-Lh1&cv^C#JzG2)m{$rWqhwTAbFi*Fr$|r0iG(p-Y>mC z11rreRD*!(AW8y}9swA%^I);HI-Z|8{lY|ztp*si6=1fy_ELc$*LB3XWu|Q)6vUbI zDi%aUwFHGT%4-Jdgj3lGCfZCewy}M$S7NzSF z*Tuna(Gun!{JvGNEPnq_N_d<3J3-wNGcA6Q)~A>aW%s)c=vsGbyteto-|H7!#gfr+ z#Q?(MPq&qkp^GfyUAeUf3tUE-`USLf!zM2W;fDgh|Jhc|$=8hW6m(^B8pE5mF_+|C zmcI>X$+jeUjV`+1h7b;DV_<=seOk<~8(XSe%(H5IeQ9=1=CmSK#5ST8Q`~W{bp*t& zvpveUAbhf08FO>^+>ah&1k75_Es}_+jEbq1<+4DIW!mVH8sDdL@A~!{~cRHXR2h+toY^cyG9R z&8dxS-H9;C6}=*-g6QQ$uZ1i;o{-m70H~@~#qFZP_y8i-|75@2I?>k(5QIezafh#)wFWX{JYR8FHKYxT+2oDfxf?bzzHTpKC?)bjK;9>0Tc0EL#Ms9@6^mt zc3s!$oV?0k@0rE&l6K5KUGxJC;&#i=#Y^6S@9*FVbuSjOGK_@(RJhKe zK#G6R_wRYneAqk z^l&S^!wW`J*i?f5?`STNfYBU#dou;}sk>UQ@*c3~d)(1)g=7(r#VnA| z$evYBtZntGck)i;KfTILVc@0n)C?VxC^UD)DQy=uaLh zI{aCZ^pwcwvgmu!O=d34U3MZ$LXJG9hF|h%g2KmFN~&aM&nv78s~l6U6nv*TY0=Bq z&QOEk;}TrRdA;r={-y}>D^b$G12iv=jix2UA1yy^|0;9(1iJiauw``!YbjFR7W$Ne^;oJUaQQJXZ?Mw9!b5|F7pD`@#>gTBsEUx8pJn5IcED~U zi&x0`b7_2}mrHuv06C1-M`#C6qHp377Q6{cQMwz^`&X`!ssD1d0X45z7znl?!q-C( zG8!19uuzKuyu|QCAmTZ`?C4)t>ll;CFT6_=8+*^QS;+< z{sk&~?Z9ActlDCpMw@uq76WowsP($^IZ)F1yRq7j@csc0KNuQ)HmhbD4vhIkAzTs6 zyvX>>hRiG0+G*8?!@v-pEq|s=F>jUs=FkDti+N@e(eE# z6EGba1cYsSZWIGWK&iwL^Q>Aj2swvx<%7n zV5(PHteR*+_3MQ$k$8vd-0DES>Ft>|;ZBk1W~6H(RC_HmB@C}0FuW~uH2Yq-<2JBP z5gTzU9xekq=|BRg;*Z7q%Z3DFzIX%6gc{+n(KVfA*!vB<~k>@LNVe-5+B2xY(Dix7Rj6eQuH!wM)UW{1OE{REh=z$zT@bcv zy8EL>*{f;ZBk5Ctjp>F&b;LexbqGmAA-x~F zNyzSnzUwq$8Ec0In5KId_J}6+$m@3J4)c93AJA6o^8bBwwEYI{b4mI$-GvsdJ>Qdi zjnLW)iTwYR=`Ur@Z~CfpnWw9sYHjl7{5J(86VzE}%8GRrA1wU-8EO3B>3FTLvG#BH zF8bqVQ$T&(1WFZV2Bw__EPqCbc`5E`#Q_;!C)22VEI!oZPaHuHd!|$gmXzC!wN?k0 zqH~k4u2yogbjt$-w&f%GHyF4IHlOT7FmN);m@QMnCMZ)?dP>%Y|7Q8b7kTA8_q{EA zJ`E7btIXn5WMzpO8J++7k00E@92Bz=A|?IJbAZDzcGo#-X2fx+g3b`RZMnEkqBWo+ zAx&m@mVOF+_J0M4|5t$cZH50`06N?wQ{G8CH;w@+F^Xc4`fWcqz4zZo;H#yA*RxcJCb)#MDoafYxARVHM zhFq8;V7(Ilz~bptqyBG%@}F`3|7k#W53{HU5|f?PyJOxE))OsdLCZ>yWrNo;)Tg$jI zt^^99@^A6ar`|x&tx7|eVt}`;501NR=}F)nwyMO77cR_fUS_#%_EOU*{K}mMKsLVb zFPf-*y=$pliHtczQ~u@Z_q*b4Zw0%S>=?&`3yTHTnI}+DdjjyqbH7p8{-Mu*g19lX zU!+)!f=GrjSuUYetnl>iNHtobZN?bK+UNdi33C;48>WlCK8SoNlBs5>cLGF#^)VQ^_uW`>pk&<5>!)c6hCXw}9X`NKOf*>lAP}*N^lh^@;2arwf4Qau%S& zBKu;|tJRxfLqPBrzwv;S^_iOV{%<1SO`BGmG11ZRa618-d7K=zRLRJ7DTn?NbNiSbr*m>GQzT|k@3z4NB~AiJojdC-~7(je6MOan^d4QE#${9pmAIx4~aJQ zdm(Jme6hF2dpDURa(E6f%&q?`Nf87PD^ zRAQ&5wt;^x3jCS8tKv=^5KiT5!hc1~N!RcW`YVVl^9-A`tNvIK-7E@w_n>bzW>CqO zF=K~V80NHx8$ZFv><}w}>5BkOqX-cF#l6_Z!i>)^ZvN>`X$Pu`XS#Y%Nm8sjn|i|i zk1SF&ql9Yr%w3lXTV@4ZfK(!mGfcc8bM1Egmd?~I|NVDEATDZ%e37UX0Me_YEYBwb ztd929A9rf3djeflW#CLQ#gX;YNQJBMeO{|=X_+kj6Li@a9H4$*vePr20Kw&5AP@_FSB598bJl@89v-fStqbVf_QgVB6%XaGfzStE zG0VFd&w)fO4!A>N){=Z{{TDj@zCHz6tdZK!MlOme0RcMVc@5w5>rU=jOG*E8{eZ?T z;MFYN{OPelQXbm*7g#8_!peQLrw6gi+pOE@QR2I>>8{QsATa5wfx1ouZaglxW@p$6 z)C>V!uFAS6sRMI~{$p6#J|#X5ou}cZ<#?c@80=edcuni^?)W$)xFi1>qph{Th+6=_ zKJpRTn}9pei2woeN;!~wi2`AaI4~;tw5F%BQgD6cx21` z)OI4#(4nHKeHi?m(SsyY-5S=!uX zZ6NS>Sf5{v5O$)q1`}1$$3fQ{0#_b;=b58SOmpo(9&NdXf?*)^{;3NyK=$}@FSH&FS z4UJW!?CZ_z)BD`qz=9LSn6+%*5Ucfg?i9BKsQ&uQr# zD|0_OEB^=fa>v)RccuZ;Wd_xExcS^ZPxezeeC1=I7#=9l_-B3}%B1(Hzx3Wa&`*D% zY*gG6Uxk(uGtVhKS*qFp3wzWBNiLUY8#h9F(Bq~fKt*j8Ld|aCR>ky2-xk1OkLQH% zR1o1MXcB<2n|)7~VQ)TBURzh&5@G=hEkCffOVKT*^uM;;+s`Gk&^ZUtA*WLjt=*S| z=Zxxt;f(nYZDqg$vRgr;?q25q)~_N%wS5AV=4lfeG=fT+Q`wJ0e>ebyCP4O|_P#`l zxie0%)pjKDjrc*rgaQcMT*bQ1Gxf7lOG|mN+5*TZKdKBDu z%EDVi1SHV0LmoJLW8}B#Fv*U=g5G+I zXWQ;%>u1)ILl>RERzo3gMAc$mc;(_{Cb;23?&p7iY1tY)np4Ju+XTDD?#<`u3~&N^ z!HduZAU^G%@U0?$hG~9UVU;m+cN1vi+)2bHEgMK4!0#1;)gNkoxq7wht6aSZSE|Cd z9lEE@VXTX4PgWruVdvH7fi{Er_Tv;sQ@8HN(8Pjeif&3w3fFqJX69@Ykj{p`06OLO z>9z!)7+^--ls;1}QvmNqP1>JAsqJK@*~=oA~Cf;PD}#MA|lo zv#-kA=n6h;ik4R~u`k7rY-D4z#WxiUs8-c+*e7jDK$-3OoN@J^T+eGkfT|!KifYIM z;{^UvwjyvRR1vv4!5~;Ap?y~pEbBYGfN9Fo_51+PRTqkErzUor>(y3SD04UpaH&*8 zCufsSDzkahA2LBCeAntpkAGIDt4!dji{zighMq+R7RTMO2)QcdRT8&y`Tk{rtwb{I zbd@_y2!&I&7r#FSHuWtHg^etwcP2>TYKFUOjOmW>w=u*6l_kldP2j}F8)#yw!Vd&d^VMC zS#CTyd6-MYj+B>#_hp*-?X?4Z(f*$M!te8igElEhqsb%`#P0S*26}+Ii~I>yQ-vwc z)BnMhIXam$X}T=*WvvuX$(9lU$*%I|d`4oWEnbedPH_|%_0Umt(Cl1F_s1v^@-h_H zp)Wn$8)obt#r*Q|CMhLT>Sfrp281+WT*Q2}cV8Zc?B#AR(W&n4gR2QThMK_=Tp0Q|7HGL_b|rz8 zP;4*Peuz-erGHXxlQ_A#ALQMy{2u-BkuyiS3ym4()9V!V-DNcOaaPawGvW(5+I<@i zGkMWuZ`f*Exy&s*_*szUVl?(X&Sw*8R| zb$0dEk5d#P{CQLCyoNSn0brB&_lv5f-uyi0DheuQ7!MwL{mv`ivTyL$xOJKx)44L)mnhFz<(Ra1dku~9>D-b zI=avC7e3n#ZXJj-!@#MsXFtPjvN|Q|v}cd(j{s;a8ZL8Eeig(FIlkhKW7TFH43q}W z%cTQMSo0gDp|XA_y54t+!m(v`ND}jOO?TeS|8KCr<@MwRn^iC+%l zG?0z>W0JC;Hn%Y@ove=urYb4x@rfy5&C_hp7q0e!&i1V=dO)C-A}&HIYglpb9)n+^ ze?*#jg!i6L7Q#=6fjvs3+zLu-E{%8h^^<~r-HaqoO8*8hM8(Ey?I3!xxlPYN53saf z&HY@t2jw~ic%W0*u3rFV_B%Y&aQnPo!3t4(m>^|f@@)NrqsBRuK+%uu^%7ZcHt-I+ zPEzh*CRf%sCvfKEy(lJU`)ueSQQY;A0%`>Hb;$Oo1jMMO^~SwET^zdS0Qe!JSx7%cmpDs!k1y7H(z^j1c%$tH*gLAb{+J;fqe*yQ+Kd|ewp zYSjYGn$FzaT2O9SsF@QTOd!8_JRGb^Js|pk68`3~@#mS|Ye^^Pl((;C4hNnirF!p{ z%x9L1`EaNDsXOC}=M}bu4sSflPe{y!-^B0?r#plzlkb54$ON2Xe7Z>xtR6vlZX|s` z9|WpKF3=KiCe9%Va>;`o6)lBl=2p8n0FK5?+-h}ZcHG7qJjF@uihKOimVZuz|Hk8( zZh(y_$ZSa9%=GCpp5!4p$JTOoLO2LqONO8kh&wYsp7aGE(1^K_>A|zx^#NqlgAqLa;u>yo=9N!L5AaNo3(@U=QS^Tt z{{J@@-qit~Vq908m(FaL$Pw~8r9a3Ru-&1v-3``@3p6J;Oi2qL~ zxvRc7>j5s$wm3x|nQbejd*&@$Nl-lDz!sawj2RE3#JRkuTm{^eJN;Hr;m1em zNPFi0qy+x|K)ymi*s`Biv2~{?JCH_UGrGa$PQ`6^TXkxDP6B(=RfX{$u(CkmtNDJk z;R!-IL)L7p`o$~=BlG7~z>QJ%{{_QQ23VOE7kx!77ym{@Egw1d4FT!^z-MY@i|eQ> zLU(6+kClwlB>fHlpZ2~wD$Dh2^N64*l7b>qilBsqNH;1-cc&or64D)_A_@p9phyTv zw{!~9ii83$-AGDzGyB2(eaD$uYyOxuYt485IL0GS+_B@@*S>BWM|Y|M(I^i(nV4A| zJfw<|3vN+mwxo{CJPgXh1qgoDUXFkOc3V?P5raG9T);?=#PEK_ZW0a(Q@M%kz+-UGoi$()+vc?D2 z0oyqM+-L!<3pvpihi%=2R7KHHs6k6+YYSj*2&Vg<@BILKZRy5_w*Nnaz6j*jgQ=)u zoh%vwNg$7-ax6DoALD5 zJV8Y?Tm8nNa(qUjY~cnhxTCtc?mI+!3~tMY6zv$uTi;&42)Fc3Is zl#b#>Hwx|Vi1|oCdzVcuMxxVzOFaUn88?K`8$%q!8DUkDqH+7#jfPo2mt(~8NxgpF zbN!_ep{kk)b5i3BpJTeeH%JdPyF{5UlSxy!5gjla ziF3&&O@`ik8v`EZWTW+#^@pscX%58RGDliA<^a2K{^#oC%Hy;nmBtpi?o`H1)k>Zv zub8>rA@yzqVYcbxvwmaCnWb~6%;Iq}HDM)-av{sPzT)vP!$7u99j7Szj{1Itx|vzA z=ZZubn`uRz5TtdTILq0{zx08Irw!d%2bttVLE+FnobkrdYX=09#oXJ_5^tCI&1@Q4 z^Q|1Adnj_s{kyx4=|(U^E&hn@QA)vx&4I~Wx=gamkr}hg$g-2&?yfsaAOFNb*|ZR- zVwgZljM;{M6AMJ_D;I%V*h>M2Y($h;7MbLDr!J_yPX?5XPDx~#v)96KXOFlZ)Y=~6 zQH1AGtiD8Ays>;9rlsfj^%kP|QtP^5v(Im}ePX%L(2Y$+L=U7xXsI{+SXHTsx7DsB z=it-m=L-OP@v|BgJ{1lvq3s#=Tqq@ngA7_{j#-Du0f{bV4!)ryDg<{={H~j`=x>6> zhTsLfR_dpzWWM-<8~WXJ5m53CJj3t&_ERAwgl)-NZ(9*S2<4kXASThKayQvH3FMOE zBUGn_aAOuh38TMBHTO2jz(zi1#pd|gT+k&uL-F!BMg?f#1P-4#sD>&w|op7T!H|#HHMpKnkloU zYx?HLBN(wZNFG?J;5ILTIu^ZY!ye#HXK~w?fLrqlp_U|fyLmQsXs&(aZ6bVR+k|Q+ z%s!2vErQ6`*RwHdJznzoAmFb0=KP)uk=i0|x2QYpxY4sYJ{>smsY45p!*On@F{B(z z(X-x|$!#gA?a(y8tfs|S)(rI1(Jk&W*d+m5$&4>oFhw}ZL)tG!>6s?CxOxE-HXH^} zm`Z2Rmw~&TEwwwf73;J%0WsOM9aO-zZv`K}H&--@X9wFc9I>flO)n*8X<~|80YbQk zQO+$c=)PgiRh4_ha1&$}$l4#FIrFJFf>iZa6hfY5d}$tQ-4~NS ze-=_fn*jq@v~tRF$BCmaY?gNNMx5)HxF_EUfwo;EfRQfJz7 zZ+sSonbCUGlKJgCvN|ia&{>VgE=J0e1RUR4k&B}rgnNoLiCmO>ZP8AjsW+*HemEnF zG>Iz&E1(6-K=iOr2u-dH3JXmyw5+DK7?g(t4+M+W0m`nx4QJk7-cchV-JE*2K48bu zu+vgTrzI>i;M8@?w}d=iY*IDYiI&5m17YP*u`rm@BMi>pbj}=`sx(khj~_Vo`om(OZmtzp$fjQYlw!6?p!lcqh4*`lBM9DD!Er2?SEnW1gog63bT2;=ws5OgwI z!n{DYMT~}lF{Pr0L{+^qxq|l{!_;|OXb~)3AKO#na8umIHoZNg`5YC~{EGdeiHeZw zRfYRsO)o6iN@PoYk9cFyumKBrkG7V2%?-Cj6lUSG)rjnqg)^3etzLyq4!UKXGF^pydJEVE3bF8ztqWzL%(8c zn(?&S-j!iB0K^Wd@uzsn{TN6I;-OO3$HlFJ^)&+S+h0}qDClj_vc;jV4ac@w1zcYF zuuGtaE}@OPz!jfiDnab^{4N*6-9>SMH5}_5m(46xGrvU_>v~q#T?XI>mTS1p=J%sK zEpsjxbXB2Ik$g^>XH|H-BDUN?zT(X4CmV3Oof+Nc*}JS6E*JuCYxaCfZFXLFBNqmw z(AKNs81SxXPr@rFE~2gbfz+d2W~xv5^JPikWm9T!wD(X{`X&yqx<9$wJqk1g6`= zaF-;01oqAS?ey7{x8jH2Ucv>Q}(bLyYo+kc;~EyUZP(n~$!EE6kJrP&V#<9^HBXYkH zDw?;I%@r0C))6_iFQ!A1Wax+=pspf-y3(lTym}iO{6Wgib}MlS?R>4kgi&W$&*Fl{ zV@y}Nm0h4l>V(CL%1r0EbgeO#>EpO6`sv{bapFOoB{m8TgAYfpAD&INR>;R!NrRiT|HHuG4i)R* z`?E`Q#Tc6|5q&gcA9{4C-J_0I+*w~9+0X+1Rl>sdP8@?n#%L+49z$ugRP9Y#!nt9_ zV@7U*Hb}-Y-tAj)xO#p$C{|f|$s>%VcH#n#{aYU+-RF4nK8~Scff*Bvsqf`?iBk#0 z?n@qkQ{yWCY(N36Na1PP<@ZXtN@%jS5(Z}^L}&tuR$`0X_OobJ<$W^Li}ZUj;Emt5 zzmd*T5T;S*VlQZ*NIX*air*!N@zP9hVHV>Frb2h;*INzlP`qt|8ttq>E!8ppvJ>+W z7oWx#p$0T^lZ*k)YLagr5CmSA`{_i+y>JSxzUm}KPsu1;8$hoVvk9GCa}Cq_7MDEK zWs}~G(`UAJd8pGxF!)}R!*WR2B2W$^@(d; zYV9dN!znT%f?KzxP)- z^aeuvQr1rFKQ$Rvb6A$fo+v8UQJNtHxLhy3JrU9yNnNbd=s%ntijKT9;{y1@YSU83 z;|!(=&(Y?nB2=VhN1?QZkpKpn-JW0CRl0D7r2iIx|Bh$=KdN_cZ?PU6F5p)1iqlf_ zJ2nL{M0D!Q7QF>Xwpb6aDdyt%pV-vRyIqnB#&na)fa)LPb-+ug1T6BtH+#XR%kuau zphaXQ=IWwS5~Mpbb<8zihPJW*CtoN?%jRK?3S)b2wwwXu+090c7pG0P?^R0#)4c+J zo3*3ya6A)Snlbc5$I^cpz=IeX80~EVKgeA@4NU#2@EmZRz2p{9cd*pw{@ewB0mVxK zqR;PSfwOx}Db>rZ66)xAnLH)9L@R6& z`uvtFIkd3=Vd@3YRT`#PSr{=uu!A*H0m({uK-e!P^OI`HnL8m1cmhRufcN6U5!w+(`9{f3^>j; zFIXzg1ppTQquQ;CBp%6U(JHDMv}rCMUAW|-&4SwMA(xD{5%=<0_vwQv$=QUYzIaHw znuEo4b-LC=&70t4Dv-QW6%1Y_1EF1+?M0RHIgv6bOzDm34)PXUm|`jd$D#Ol#Y zb%SHMkPU|$oPK1x9R?u~0wcKq=Lb1-;Ew&ZchKFUT9)$qijkkoT=7IBWL=gWI!-$5 z)3{IC%@24(kR?d=Z8LsIZspQh~WZKI4eZ$ zEH2RrZf_7&iV3Q5bGi)s$siwVr0c$TBW_+D*A)a|sM{*Myqxe~Rxm}keea(Mwx_F6 zd2UOiQ!i?fz$nD-#aVDn@=YtaVd5$0nJ00)6!!ZNvz;;1>3vpKIQ;PJk#F0*i+WJq zmum@Be3dJs;xK_~cxpN`XOt=VVhrTA9u=+Ze2<2KJ&GNvA<$9lwoJ4{uIO zR$#S#r+Wa12>tH;*MPpSH2|WcgiKl6c_(GLD?M~?`H&p%SiQ&u{2i-TP?GJ6CN9&3 z+!oQIC$?y-FlpQEhGu9Iruv9+Xc21SYN?`poW}Ik*1Y*y7wU;y&pH`b=JV;3cj5`$ z3Oh2VMuUV7z?d^gs_sLzJ1K4qWlYxlNAWq4UV%2Nid{#$0hb9C{#wHzfevj5AB_Q^ zn>$vrwfCi9SMxq}2vl@Khm&1FoZ!8yRm(t4>svt*F%OpFug}Gz{D217GXubC-6_iP z^m<>QD{6ggp$Q~7Xp_mtSo2OP%|bYJ-wJ4+w7b7Qbd(g$tqtjL6ZGiMX`;H07LJ1= zE(hdJFSC7o9eSzGN+$l39opz_wjOsrvq#`)u-i_Js_pVanlxQ%6`4?k$CT5g3`mdw zFu8iUqd+dV3Bg7$?-y3=Hj&JvxMV+1CAkBlE16SE@KMIikc@D>>+&kN-UU>|%T^sA zYd3xz13BGdeG_4Gab@#nB2CEdkY*TvxpCTIS-EQi=^trF&1}Ffq)0ON@Pw)t{CO|Yf-U?#7|%&n`G3>bT=Q^u zO{S3Cwu|i1T<~%1)%P72JLi;nS1}sB9t%I`I!zDt-*waHFsoAcM6Y?wwWkD^R(9NcSUBLCRty_J zr*h1F*{HxaSzYt>ql_0OA`JM{P-`H%8;lAA2^3aMPI3|bD2EO<*MGj9Ubvy2um43! zmZx^rExD>5X`kyFZ>+ph^0G~!4G|?p(F8(n)5U!I-e#EubVh`h^UGA7Aykw2;A2k- zu|>0cQ>#V-DC}QLFxL-OGy`HKuCb0yEeUc$$MJC5ZT5EQ4Mej%%6Yr3;hp2Rj;7?q zSkL$rGep_;79QUWYo|h?70Q8qyMZz5t3?${o^s_+!WLI$>TdEqF^>9k`Or>@it-3w zC#TJ9oq1o3hM`Wapw|ju*5AILDHR*5=>&am%@lVj*B;{F?#3yuvmn}PrBtQBf}`hN zxuv)zX_0W%P|IDjM#Z0J)5^_qrMm90I_%sQIg*G9O3`lH1VJySP zmwG{BuEP<5{o;!tA|lZ4RY~F0H@s&SQgP_;k)l11_INR_JWnJ8?bG5gVs>0kdqpPm zSq>l*W-MPpF@N318K)|f+zS;(7{-Vrb)&#l@!roV{(v#)qWJ$;LV;xJCnw)q)fD6KQzqLCmYA^rBsNbnUoJD zFq1o89n)7D#;DRa7&wbtAcCTTz2LFrM{`iYHVt@>Fv_RVO_Ces65?7@0}>uLgIl2& zG=b}mmWwe&2di!G?ieukZ$^aXezK?>Zt+}WXLp=Yf7#-i)ttxS?Dqr2`rv_T(6-bB zW2r6PkCKfe^YIjV2msvOFIQJz7J;Z|iMO1prWtKvH;`U>Og$6g=}h9+!0+{3%;Hu= zVlnSJ?2vD~iG7qnH`7{Q;3y058jLqX&E@~#igkJ*M7A1L*X4px6EW?4MWOy}x`NiI z3Jso8=~Lt=d&5=3_@Znqw{Ha$qz zWKLdEah~WDRd%{u`@H1Im&0nb`zk^u2nwTl-yOW>9A#QpNlA-h8h*dl>il3u*Li6v zZ`e=wq@{=G3Dk}?hJ=t4WrscwXxuQnZJRuR^x+kq>AxK;b6iv(nrw|%Ccjvfc(rN1 z{p>}T%#+JI-BBS<=@PHc#^Kg+Nm3GumX2BAFC3ek%E2+(fr~FO+uTp_O1*~1Q$v2h z%$g3az!&WNv2_j@S~r7)vvl9}eVja$BBZXpF(aA3)&-DEzX4z_MzSwi_DWE*u}3pX zoLs*%#*87TY>+qRT2y|VMrUARp;n_>ccrXJjw=|;7y65Fb7bNe<-o{$bi`b8)qID< zBS7kEm)V9G{^gNnT;IeScL)VLu)Dd~ihN5HW+0lB-MVcPRyhyd&} zHW0vVYsv*`5k$mG|+Z_F)*w2M#tV^I_XF zLyLtG>^vt9H;zT}Ow4S~+=gFGqVw0c(lZ*}TYAh_n>@47s_P%MLdAn9qfRkvhc(%d zrk$(bc>s(BNkXDiq7`r&)Kx7r9;?Tol;R9M#Ywzn9CV(KcfSOAhWI>Ol$w8Y!#}4t zR6LOURlnj%|M;3y%fyH#x@D=XLHuxu!?&CpDzG?S6VqaR7}0Wq_UE#dw&=aQS@ze; z6?e_kwzfZ9qjg>z=JJxNVSwGYdzj16t~{#{z3+ zhG5qeN8i_QDjU*D9j5}M0@MAqhpkigfe%|1E2ZI~V8rd2O|>S_S5d-j}O7RB-WOz3{KHJ>P}f{f`{W{`%hV0Iz%)dEu|)?h$Ai-negd6 z9+Xr(!i()~#vDzw~)Nif3m};IKnzq(|SI9OuOmUA_o)Oj;}az|A9u3c}fhC}F;6t7*IxbxsKiwVRi zui9H%pYIM3S0s@H$)_vsX-B^>XYB0P%C0NUWDtwqK3rO0J6KC%rq7|HmVi0AbH_A+ zA4P&DSw8w2g;z;>*%=xE9HuNrPj@yy45%fk|C;P`OwnI&z048bD8JXKIr5)F7?=$# z1m3r9+22wN;?#eCw}4NeWJ_avLhpTk=)Pd)bsQbFQ2F_@_4bylPdqcnR6BMu8uA0? z`;HO7B1L{2``2%j)9wzv)pVVu{`s6A4@5IibEkK_w$c6L6@I=8!zH*zU4HH4U*1IZQ01-swSeXG|MmR| zsO3fA8rC93_+Q>6|2Q^YTE0o->HqlVg9myahii$E6BG#nxvF^!H_KlJjD#4j5e&xu zUz@ru3NMqip+z~~mFKilvaU@ye;XeS{l$@5w7Y9RZ(%A9UMc!G)n6t?I3^y$N`;v| zso^if`1P8wby$#R`|-bgGcAnAix4HFzdU*A95r{NxDX2KFT?m8CRC~+<;q{~xJf`j zJ|0JvfA24AL;_YT?U?eJzueIs8yj!=OOU3>U*sn`y({G=2ETtW6fb&o-=A^ziU_$-wKn zVw#$^?BV|M^NjTOId6Xeb4ge7Q38n=4pz^~L*WN^vk}UHlJ7T=T_7TN^lOm)J~6_$ z$2U-UNBElPf0@M)acVJgM~83CCMB*XwtxOL1MH0S2PKBT?)v-nlWk#%ggQM1Jn3J{ zPW~8Nqiv@M{<)5+xiD}}G2KMMi?&piG(~fBbE}?&b3c}ex97a{PG9k>XpP@%>O=8+ zsNA(eIkY5?TaxV~5SBuL7*%2qEit!^pu?c{j+^X{2Pf0R<76CO2Gjn0l}ky&a`&s( zCOX>NL$Dq}*~-IpaC_h-G_mx0o)$XzI&WE=ntR%-tE*81LXP|gBWhP|1|!->N6l>! zxA5TSyT@eVgz$1(%=3V33-LLFfSUnYkpOY_{JN3SadIBp3%I1LF;X<6_*8Q$R0Ld+mv(AuUp9-3*qBtstXVrK`7@;Hv_&rS{`qb!o|g{Ep`6>IkE(k%@s%wO<4M;hnJ49(5^DIa+g!KIOFb_4QfCK^UI^bxyj{1ef6| zA2U!UNztqD?9XgDidcDSFO2?8CrRtDif=JoS{JxyWGw4{S=VHgcNNub9iETye>UIt zo_zB*XzmIRMW?AH6$zx5_5z5NIP3i<+L{EnLJ>9v)1I zBrp|Y!NJCJJJUD(%WR~oQI7}m0ebxbdJG zT%i^BVAXti%qE##s)hNO?L3>6S)eUIj!6L5C6%H#$q}y=qCtJCcWc2{C~|G4JD5Vk zTHV+hU3d%|ulExFuhFBHKZ^mp8(BuxbW@US+${jE+sIbasC$RS4$ka3`t zedpbt3DZOLkkGFDJHYfNBX}evX&6`|>H?{>n|lXfRB{M3fSf{^a|N1nX4Z-*)zXnM zSvlvuvA+ae(%~7AeG0ikE3xz(QhfH#Uv!q3PAI)Mi{C02yB;DSYd8`Z^NP)t?mR8u=({yxJjqN2%)5bTS)og zlt_2JxtgzupjBUyJ(OpXHmYjHVu)aqOD6Nt{rTeDKta?jb+qhFuE8d8njh#NJ;ibL zYP|YwTG5&f8XnPFP)}Pa(j|e_8`FcSR8>Cw&p!m0C9aDo7u*?qEx2CXl7NjTmw#FP zEj11<6iM7tb;@L8X5dLVC;5K*2H48(I5mCRY%C+-A#+rOM{T}!WYC(e07MXh^@#Ai zE`Ygakmj1fan!UaTD0)#$qx{@)R#b@49v5eXvV{*vLhXE=+v2lPJKr|7G(=e23Vfy z@#Tg;9Xd9_hm`lA?(8c1veL|&7ox5lBPq@X zdpSW>{k@Lfua?E@wM}LoRgy+;}yHJ zcg$e#(S9LiH`>7d zZm7OmZg1r1qJ5lWi6p1{#)3T% z^a>DWTE1EeJD+Jb|bDgk>~=H0ON z&tZY_;m#1o^sN;c0b~hT`EuK@GRw}yc^Zt3V-w>9$;im)q*Rr|po@5up4-j1y2BOK<)4!!wJ_8V>W0cu^N%YbrHf zR!z;w&d$DkGl10wlt`vP$%;{Bb^4re%tI{I49(E;^>_0L$a$(J7PU}V44DJFK^%u` ziHW)aug@qj#{WkGIvFBtXJ_XMkP4i2RODa{`y^`1!o-P8z}5Z~bu$21Zt$3;uOG*y zXP9DkvD@Dw0dXs`V3;rih8Co?+=mycsrFc5n+-{qx<(75!C9qcN<|X<+RKM95>6p! ztmm+@VbosA)~_u0*p_q+3u9jtn0Jvob)n8MWU4JmtEo7?fq_Pz$9u!8j>U7)e+5qW z<$kv@;%~zLO#SW@-{7V!V!l06ti>+#{SE7o=kz9J%Y*9v$*LOMvz)haazd734j(!3 zp{iQ+DQOTA6hKRfBRzf`GoUV)-h$Cx$&KD+0%^4hNl<$e7=1=38yVK*Y3x((GaqEzD?zN0ghv(! zI=u)lToIf?lAz&5jC}C%>7lP}U;lY`A7MxaT!AOvia??{5Jatj!k`oH?MW03L`T8Q zP+&VLi5Wm67BGoYK{m%>?+rz2vD3^NITtMZOY-jv$a*57?$lwb4dD`C2DDZA;K&VB zGGf}o^BN_@QAhq*0HG%zJ(FaCE|6p3b{<2=GE1)nkO*D6v1`@uCKO>4e-g_aAwPCq zedGOM{M%zl6R`a!1H$+sl1=EIaQCZ~v%p+phWonVn^XO9Uy_r~z>rg7Dj_;&5R2&d z)8DJJwFGC%ckX5+@I?HsIL>t0QYgN|Ow}D)7_OdzJ|QWjwO|X@?B}UxK0XhdfF*no zXPk`QxK74vZ#rxgglWqH&+<5JPW{KT&=&~&nQQnTD zQZ$5t!xN&SI~Gdh4CRhCI2GeL(hr_zKh>HC?KjL(4ao{|tw;n01^KC~PIG0_7WHt`f=M_ z!elIO&^byZVN{Jb`t-uc`&Pi*ER;sP_7Po)L^+RXrK$T=JNjg-`od~yZ-u5KTIG zhaDe+`f^KEl{zlZ9v=_Xjb66UR4uCyeT9Oz4Apj5eJiwRmumas6MO(rk~K>pP3PC= zVPbz(J@7yv;BHY+Vwb+4eJT4xH8hC0CG@iqeS=y_i)bxrHfbUMX(7${1htab7V@u9 zv*>=*hvY^FzU~C19$t>6yO6C(BZ=nL2XVpYf?HpL64l@JiQRqw5gb9VOquBK&-}+b zocNLT82EL*bIN^XE_R$Kwt;U=m&bkmso5H89-owBV4HaJL|7by4S!My&SD{WurGQaT0{CQ|ltJ(zmoIkG| zK%Ff=G670aY7dMz7KSy#xNlWGATAWBclTRVccv7o&uA^!IbO39Wz*{s@cKz_0FFOa z=(OriQK%<0)|q{Ib3;R(6eqGBjUGF#{0Tcm1Pu5QWtHDCB!oVyn2z%UQ3ixB!lbfy zN8v;<#-0GkC@wys5)x#DoghUK3h^+pT|2tfF@DurvtV)Etm%bNl4TQ%anit5TicSI zH|q&L?1JH2TwhH@0o*X_=A;~_prZiMls_A)fki3Mjoc0ENXTuO%%XlP@UF*)~a_&KPRYcJZ zwsHz0j)Yw0lYdMT=2if>Zo>0okDnRZFxtmncW!UnoNU120g-zq>43Lvl8v=pc>$zyx3CBE8lFH}sAHLtp4z}3u)EYDDTtM0Op)Zs1s8S7}< za#EUq42h>fSh5w)QV9hs^hI@K0;y`&qUsdRv(7Xrq-2w}AfZ_(2)vwk3)sseq?Q*1 zNM+Lk{R3V)2)?`p=?NJ5DnJzla^rMQE$xvGwCxj7#)}(Bn$_6k3~V4H9P^sV+L4Jx zyT(sl3XfIX^*r1RU0sI!+OJNm;8a^^74p4XkE}J@3%Q|T7f2=a`VE{tN_j}{LGCP7 z^(x5O)2j{y)>kcWxBx#b1p<0Tp9#X98}g*IRYT4dty+!OfC_Uu5u~wEuqB864&GrpU8ShUY59R6l}l6@>6mxJ6i%5Eiyl!vgH3IPJSgW`1P7Y*qEt)}n8|H* zUvuU^*9%G{ro3E`gM-6p%zol*;keacxj?Nbb1khHQ{6Woo-G5<@=E|w@#;9JEDvOp zov}D$cR~zXTYc9R*n%nY2C`Mox>HzYsfkKa*xqDN4Cv5L;xYPd_rXGL6bh%O_rAKD zJw#%+O>%1Y5ti_A+VOS&iP|8x{Xx(L${~vWHkHxV)T`OL_b#s4J#C4Pk!jvD?us2Q z=hdsXajI+Xv1Q+szNG?(64fbdAHQ{L#)L+gx&pT7&RWKc-&r`s^}>AK>Wvo~;w6H6 z-r0>)84f?iCZdt=1I}8nD9vnip5o&B+37XQ&Kbi^bt`(E`*H<$ z-0KkRM)EkRjk<(K{eP5wyaj0xIEmQ5IFG#RrK;d|ecoEAk=gcZOO5Tb;#U)-TJ*v) zJ=eYBZ(VC{uo5^$zV=G$+O=cK8L$OVrF8&3{KU49ksZK1&u?LA*@RK!91v~j|CDu{ zDWLfHsDf!&;p?NZ1S}0_`@mw1YsH&^s64^ETtaQ27iVG-~XMkCFFnRxr31$ ze=f`K|HeB9u6=4qv;EJ(Ie4l6_2U3ZVa#gyBPaOzCGCmuZJgUp8h>u@9}{>9sWqmT zF*xcB=Q+PnRNR2OQJ|AGG`ZpdEG6xF}? FKL828KFa_A literal 0 HcmV?d00001 diff --git a/README.md b/README.md new file mode 100644 index 0000000..b8927cf --- /dev/null +++ b/README.md @@ -0,0 +1 @@ +This is my epita courses