tasmota-webserial-esptool 6.2.0 → 6.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -1
- package/dist/const.js +2 -0
- package/dist/stubs/esp32p4.json +4 -4
- package/dist/web/esp32p4-Drc2t__U.js +1 -0
- package/dist/web/index.js +1 -1
- package/js/modules/esp32p4-Drc2t__U.js +1 -0
- package/js/modules/esptool.js +1 -1
- package/js/script.js +2 -3
- package/package.json +10 -10
- package/src/const.ts +2 -0
- package/src/stubs/esp32c5.json +8 -0
- package/src/stubs/esp32c61.json +8 -0
- package/src/stubs/esp32p4.json +7 -7
- package/dist/web/esp32p4-BvuBbdjO.js +0 -1
- package/js/modules/esp32p4-BvuBbdjO.js +0 -1
package/README.md
CHANGED
|
@@ -2,6 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
JavaScript package to install firmware on ESP devices via the browser using WebSerial.
|
|
4
4
|
|
|
5
|
+
This fork supports additionally the ESP32-P4
|
|
6
|
+
|
|
7
|
+
|
|
5
8
|
## Local development
|
|
6
9
|
|
|
7
10
|
- Clone this repository.
|
|
@@ -11,4 +14,6 @@ JavaScript package to install firmware on ESP devices via the browser using WebS
|
|
|
11
14
|
|
|
12
15
|
## Origin
|
|
13
16
|
|
|
14
|
-
This project was originally written by [Melissa LeBlanc-Williams](https://github.com/makermelissa). [Nabu Casa](https://www.nabucasa.com) ported the code over to TypeScript and in March 2022 took over maintenance from Adafruit. In July 2022, the Nabucasa stopped maintaining the project in favor of an official, but very early release of Espressif's [esptool-js](https://github.com/espressif/esptool-js/). Due to the instability of the tool, Adafruit updated their fork with Nabucasa's changes in November 2022 and took over maintenance once again.
|
|
17
|
+
This project was originally written by [Melissa LeBlanc-Williams](https://github.com/makermelissa). [Nabu Casa](https://www.nabucasa.com) ported the code over to TypeScript and in March 2022 took over maintenance from Adafruit. In July 2022, the Nabucasa stopped maintaining the project in favor of an official, but very early release of Espressif's [esptool-js](https://github.com/espressif/esptool-js/). Due to the instability of the tool, Adafruit updated their fork with Nabucasa's changes in November 2022 and took over maintenance once again. Since Adafruit is slow in adding new MCUs (support for C2, C6 and H2 is from this fork) i decided to maintain my own version and do not provide PRs upstream anymore.
|
|
18
|
+
|
|
19
|
+
Copyright: Adafruit, Nabu Casa and Johann Obermeier
|
package/dist/const.js
CHANGED
|
@@ -157,6 +157,7 @@ export const CHIP_DETECT_MAGIC_VALUES = {
|
|
|
157
157
|
0x9: { name: "ESP32-S3", family: CHIP_FAMILY_ESP32S3 },
|
|
158
158
|
0x6f51306f: { name: "ESP32-C2", family: CHIP_FAMILY_ESP32C2 },
|
|
159
159
|
0x7c41a06f: { name: "ESP32-C2", family: CHIP_FAMILY_ESP32C2 },
|
|
160
|
+
0x0c21e06f: { name: "ESP32-C2", family: CHIP_FAMILY_ESP32C2 },
|
|
160
161
|
0x6921506f: { name: "ESP32-C3", family: CHIP_FAMILY_ESP32C3 },
|
|
161
162
|
0x1b31506f: { name: "ESP32-C3", family: CHIP_FAMILY_ESP32C3 },
|
|
162
163
|
0x4881606f: { name: "ESP32-C3", family: CHIP_FAMILY_ESP32C3 },
|
|
@@ -164,6 +165,7 @@ export const CHIP_DETECT_MAGIC_VALUES = {
|
|
|
164
165
|
0xd7b73e80: { name: "ESP32-H2", family: CHIP_FAMILY_ESP32H2 },
|
|
165
166
|
0x2ce0806f: { name: "ESP32-C6", family: CHIP_FAMILY_ESP32C6 },
|
|
166
167
|
0x0addbad0: { name: "ESP32-P4", family: CHIP_FAMILY_ESP32P4 },
|
|
168
|
+
0x7039ad9: { name: "ESP32-P4", family: CHIP_FAMILY_ESP32P4 },
|
|
167
169
|
0x0: { name: "ESP32-P4", family: CHIP_FAMILY_ESP32P4 },
|
|
168
170
|
};
|
|
169
171
|
// Commands supported by ESP8266 ROM bootloader
|
package/dist/stubs/esp32p4.json
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
|
-
"entry":
|
|
3
|
-
"text": "QREixCbCBsa3Jw1QEUc3BPVP2Mu3JA1QEwQEANxAkYuR57JAIkSSREEBgoCIQBxAE3X1D4KX3bcBEbenDFBOxoOphwBKyDcJ9U8mylLEBs4izLekDFB9WhMJCQDATBN09D8N4PJAYkQjqDQBQknSRLJJIkoFYYKAiECDJwkAE3X1D4KXfRTjGUT/
|
|
2
|
+
"entry": 1341196252,
|
|
3
|
+
"text": "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",
|
|
4
4
|
"text_start": 1341194240,
|
|
5
|
-
"data": "
|
|
6
|
-
"data_start":
|
|
5
|
+
"data": "XAD1T1QM8U+kDPFP/AzxT9IN8U8+DvFP7A3xTyAL8U+ODfFPzg3xTxAN8U/QCvFPRA3xT9AK8U8uDPFPdAzxT6QM8U/8DPFPQAzxT4QL8U+0C/FPPAzxT5YQ8U+kDPFPXg/xT1YQ8U9sCfFPehDxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFP8g7xT2wJ8U98D/FPVhDxTw==",
|
|
6
|
+
"data_start": 1341533176,
|
|
7
7
|
"bss_start": 1341456384
|
|
8
8
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var A=1341196252,B="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",w=1341194240,E="XAD1T1QM8U+kDPFP/AzxT9IN8U8+DvFP7A3xTyAL8U+ODfFPzg3xTxAN8U/QCvFPRA3xT9AK8U8uDPFPdAzxT6QM8U/8DPFPQAzxT4QL8U+0C/FPPAzxT5YQ8U+kDPFPXg/xT1YQ8U9sCfFPehDxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFP8g7xT2wJ8U98D/FPVhDxTw==",F=1341533176,Q=1341456384,T={entry:A,text:B,text_start:w,data:E,data_start:F,bss_start:Q};export{Q as bss_start,E as data,F as data_start,T as default,A as entry,B as text,w as text_start};
|
package/dist/web/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=t=>{let e=[];for(let a=0;a<t.length;a++){let i=t.charCodeAt(a);i<=255&&e.push(i)}return e},e=t=>"["+t.map((t=>a(t))).join(", ")+"]",a=(t,e=2)=>{let a=t.toString(16).toUpperCase();return a.startsWith("-")?"-0x"+a.substring(1).padStart(e,"0"):"0x"+a.padStart(e,"0")},i=t=>new Promise((e=>setTimeout(e,t))),s={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),o=33382,l=50,h=12882,d=12883,f=12994,_=12995,c=12998,u=12914,w=12928,g={4293968129:{name:"ESP8266",family:o},15736195:{name:"ESP32",family:l},1990:{name:"ESP32-S2",family:h},9:{name:"ESP32-S3",family:d},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},1763790959:{name:"ESP32-C3",family:_},456216687:{name:"ESP32-C3",family:_},1216438383:{name:"ESP32-C3",family:_},1130455151:{name:"ESP32-C3",family:_},3619110528:{name:"ESP32-H2",family:u},752910447:{name:"ESP32-C6",family:c},182303440:{name:"ESP32-P4",family:w},0:{name:"ESP32-P4",family:w}},m=3e3,p=6e5,b=(t,e)=>{let a=Math.floor(t*(e/486));return a<m?m:a},y=t=>{switch(t){case l:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case h:return{regBase:1061167104,baseFuse:1061265408,macFuse:1061265476,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612856,flashOffs:4096};case d:return{regBase:1610620928,usrOffs:24,baseFuse:1610641408,macFuse:1610641476,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612864,flashOffs:0};case o:return{regBase:1610613248,usrOffs:28,baseFuse:1072693328,macFuse:1072693328,usr1Offs:32,usr2Offs:36,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:64,uartDateReg:1610612856,flashOffs:0};case f:case _:return{regBase:1610620928,baseFuse:1610647552,macFuse:1610647620,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case c:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case u:return{regBase:1610620928,baseFuse:1610719232,macFuse:1610719300,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case w:return{regBase:1342754816,baseFuse:1343410176,macFuse:1343410244,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1343004812,flashOffs:8192};default:return{regBase:-1,baseFuse:-1,macFuse:-1,usrOffs:-1,usr1Offs:-1,usr2Offs:-1,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:-1,uartDateReg:-1,flashOffs:-1}}};class k extends Error{constructor(t){super(t),this.name="SlipReadError"}}const v=async e=>{let a;return e==l?a=await import("./esp32-BLbsWvxO.js"):e==h?a=await import("./esp32s2-CrsP1231.js"):e==d?a=await import("./esp32s3-CiJyd6Fk.js"):e==o?a=await import("./esp8266-CQFcqJ_a.js"):e==f?a=await import("./esp32c2-wLQhZItC.js"):e==_?a=await import("./esp32c3-DmSvHQKL.js"):e==c?a=await import("./esp32c6-ZuxjUVr4.js"):e==u?a=await import("./esp32h2-CZ4EIL3w.js"):e==w&&(a=await import("./esp32p4-BvuBbdjO.js")),{...a,text:t(atob(a.text)),data:t(atob(a.data))}};function x(t){let e=t.length;for(;--e>=0;)t[e]=0}const z=256,R=286,S=30,E=15,D=new Uint8Array([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]),U=new Uint8Array([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]),A=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),O=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),I=new Array(576);x(I);const F=new Array(60);x(F);const B=new Array(512);x(B);const T=new Array(256);x(T);const C=new Array(29);x(C);const Z=new Array(S);function L(t,e,a,i,s){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=i,this.max_length=s,this.has_stree=t&&t.length}let M,N,P;function H(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}x(Z);const $=t=>t<256?B[t]:B[256+(t>>>7)],j=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},V=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,j(t,t.bi_buf),t.bi_buf=e>>16-t.bi_valid,t.bi_valid+=a-16):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=a)},W=(t,e,a)=>{V(t,a[2*e],a[2*e+1])},K=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Y=(t,e,a)=>{const i=new Array(16);let s,r,n=0;for(s=1;s<=E;s++)n=n+a[s-1]<<1,i[s]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=K(i[e]++,e))}},q=t=>{let e;for(e=0;e<R;e++)t.dyn_ltree[2*e]=0;for(e=0;e<S;e++)t.dyn_dtree[2*e]=0;for(e=0;e<19;e++)t.bl_tree[2*e]=0;t.dyn_ltree[512]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},G=t=>{t.bi_valid>8?j(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},X=(t,e,a,i)=>{const s=2*e,r=2*a;return t[s]<t[r]||t[s]===t[r]&&i[e]<=i[a]},Q=(t,e,a)=>{const i=t.heap[a];let s=a<<1;for(;s<=t.heap_len&&(s<t.heap_len&&X(e,t.heap[s+1],t.heap[s],t.depth)&&s++,!X(e,i,t.heap[s],t.depth));)t.heap[a]=t.heap[s],a=s,s<<=1;t.heap[a]=i},J=(t,e,a)=>{let i,s,r,n,o=0;if(0!==t.sym_next)do{i=255&t.pending_buf[t.sym_buf+o++],i+=(255&t.pending_buf[t.sym_buf+o++])<<8,s=t.pending_buf[t.sym_buf+o++],0===i?W(t,s,e):(r=T[s],W(t,r+z+1,e),n=D[r],0!==n&&(s-=C[r],V(t,s,n)),i--,r=$(i),W(t,r,a),n=U[r],0!==n&&(i-=Z[r],V(t,i,n)))}while(o<t.sym_next);W(t,256,e)},tt=(t,e)=>{const a=e.dyn_tree,i=e.stat_desc.static_tree,s=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,o,l,h=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=h=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=h<2?++h:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,s&&(t.static_len-=i[2*l+1]);for(e.max_code=h,n=t.heap_len>>1;n>=1;n--)Q(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],Q(t,a,1),o=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=o,a[2*l]=a[2*n]+a[2*o],t.depth[l]=(t.depth[n]>=t.depth[o]?t.depth[n]:t.depth[o])+1,a[2*n+1]=a[2*o+1]=l,t.heap[1]=l++,Q(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,i=e.max_code,s=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,o=e.stat_desc.extra_base,l=e.stat_desc.max_length;let h,d,f,_,c,u,w=0;for(_=0;_<=E;_++)t.bl_count[_]=0;for(a[2*t.heap[t.heap_max]+1]=0,h=t.heap_max+1;h<573;h++)d=t.heap[h],_=a[2*a[2*d+1]+1]+1,_>l&&(_=l,w++),a[2*d+1]=_,d>i||(t.bl_count[_]++,c=0,d>=o&&(c=n[d-o]),u=a[2*d],t.opt_len+=u*(_+c),r&&(t.static_len+=u*(s[2*d+1]+c)));if(0!==w){do{for(_=l-1;0===t.bl_count[_];)_--;t.bl_count[_]--,t.bl_count[_+1]+=2,t.bl_count[l]--,w-=2}while(w>0);for(_=l;0!==_;_--)for(d=t.bl_count[_];0!==d;)f=t.heap[--h],f>i||(a[2*f+1]!==_&&(t.opt_len+=(_-a[2*f+1])*a[2*f],a[2*f+1]=_),d--)}})(t,e),Y(a,h,t.bl_count)},et=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),e[2*(a+1)+1]=65535,i=0;i<=a;i++)s=n,n=e[2*(i+1)+1],++o<l&&s===n||(o<h?t.bl_tree[2*s]+=o:0!==s?(s!==r&&t.bl_tree[2*s]++,t.bl_tree[32]++):o<=10?t.bl_tree[34]++:t.bl_tree[36]++,o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4))},at=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),i=0;i<=a;i++)if(s=n,n=e[2*(i+1)+1],!(++o<l&&s===n)){if(o<h)do{W(t,s,t.bl_tree)}while(0!=--o);else 0!==s?(s!==r&&(W(t,s,t.bl_tree),o--),W(t,16,t.bl_tree),V(t,o-3,2)):o<=10?(W(t,17,t.bl_tree),V(t,o-3,3)):(W(t,18,t.bl_tree),V(t,o-11,7));o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4)}};let it=!1;const st=(t,e,a,i)=>{V(t,0+(i?1:0),3),G(t),j(t,a),j(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var rt=(t,e,a,i)=>{let s,r,n=0;t.level>0?(2===t.strm.data_type&&(t.strm.data_type=(t=>{let e,a=4093624447;for(e=0;e<=31;e++,a>>>=1)if(1&a&&0!==t.dyn_ltree[2*e])return 0;if(0!==t.dyn_ltree[18]||0!==t.dyn_ltree[20]||0!==t.dyn_ltree[26])return 1;for(e=32;e<z;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),tt(t,t.l_desc),tt(t,t.d_desc),n=(t=>{let e;for(et(t,t.dyn_ltree,t.l_desc.max_code),et(t,t.dyn_dtree,t.d_desc.max_code),tt(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*O[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),s=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=s&&(s=r)):s=r=a+5,a+4<=s&&-1!==e?st(t,e,a,i):4===t.strategy||r===s?(V(t,2+(i?1:0),3),J(t,I,F)):(V(t,4+(i?1:0),3),((t,e,a,i)=>{let s;for(V(t,e-257,5),V(t,a-1,5),V(t,i-4,4),s=0;s<i;s++)V(t,t.bl_tree[2*O[s]+1],3);at(t,t.dyn_ltree,e-1),at(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),J(t,t.dyn_ltree,t.dyn_dtree)),q(t),i&&G(t)},nt={_tr_init:t=>{it||((()=>{let t,e,a,i,s;const r=new Array(16);for(a=0,i=0;i<28;i++)for(C[i]=a,t=0;t<1<<D[i];t++)T[a++]=i;for(T[a-1]=i,s=0,i=0;i<16;i++)for(Z[i]=s,t=0;t<1<<U[i];t++)B[s++]=i;for(s>>=7;i<S;i++)for(Z[i]=s<<7,t=0;t<1<<U[i]-7;t++)B[256+s++]=i;for(e=0;e<=E;e++)r[e]=0;for(t=0;t<=143;)I[2*t+1]=8,t++,r[8]++;for(;t<=255;)I[2*t+1]=9,t++,r[9]++;for(;t<=279;)I[2*t+1]=7,t++,r[7]++;for(;t<=287;)I[2*t+1]=8,t++,r[8]++;for(Y(I,287,r),t=0;t<S;t++)F[2*t+1]=5,F[2*t]=K(t,5);M=new L(I,D,257,R,E),N=new L(F,U,0,S,E),P=new L(new Array(0),A,0,19,7)})(),it=!0),t.l_desc=new H(t.dyn_ltree,M),t.d_desc=new H(t.dyn_dtree,N),t.bl_desc=new H(t.bl_tree,P),t.bi_buf=0,t.bi_valid=0,q(t)},_tr_stored_block:st,_tr_flush_block:rt,_tr_tally:(t,e,a)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=a,0===e?t.dyn_ltree[2*a]++:(t.matches++,e--,t.dyn_ltree[2*(T[a]+z+1)]++,t.dyn_dtree[2*$(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{V(t,2,3),W(t,256,I),(t=>{16===t.bi_valid?(j(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=255&t.bi_buf,t.bi_buf>>=8,t.bi_valid-=8)})(t)}};var ot=(t,e,a,i)=>{let s=65535&t|0,r=t>>>16&65535|0,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{s=s+e[i++]|0,r=r+s|0}while(--n);s%=65521,r%=65521}return s|r<<16|0};const lt=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var i=0;i<8;i++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ht=(t,e,a,i)=>{const s=lt,r=i+a;t^=-1;for(let a=i;a<r;a++)t=t>>>8^s[255&(t^e[a])];return-1^t},dt={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"},ft={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,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_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,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:_t,_tr_stored_block:ct,_tr_flush_block:ut,_tr_tally:wt,_tr_align:gt}=nt,{Z_NO_FLUSH:mt,Z_PARTIAL_FLUSH:pt,Z_FULL_FLUSH:bt,Z_FINISH:yt,Z_BLOCK:kt,Z_OK:vt,Z_STREAM_END:xt,Z_STREAM_ERROR:zt,Z_DATA_ERROR:Rt,Z_BUF_ERROR:St,Z_DEFAULT_COMPRESSION:Et,Z_FILTERED:Dt,Z_HUFFMAN_ONLY:Ut,Z_RLE:At,Z_FIXED:Ot,Z_DEFAULT_STRATEGY:It,Z_UNKNOWN:Ft,Z_DEFLATED:Bt}=ft,Tt=258,Ct=262,Zt=42,Lt=113,Mt=666,Nt=(t,e)=>(t.msg=dt[e],e),Pt=t=>2*t-(t>4?9:0),Ht=t=>{let e=t.length;for(;--e>=0;)t[e]=0},$t=t=>{let e,a,i,s=t.w_size;e=t.hash_size,i=e;do{a=t.head[--i],t.head[i]=a>=s?a-s:0}while(--e);e=s,i=e;do{a=t.prev[--i],t.prev[i]=a>=s?a-s:0}while(--e)};let jt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Vt=t=>{const e=t.state;let a=e.pending;a>t.avail_out&&(a=t.avail_out),0!==a&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+a),t.next_out),t.next_out+=a,e.pending_out+=a,t.total_out+=a,t.avail_out-=a,e.pending-=a,0===e.pending&&(e.pending_out=0))},Wt=(t,e)=>{ut(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Vt(t.strm)},Kt=(t,e)=>{t.pending_buf[t.pending++]=e},Yt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},qt=(t,e,a,i)=>{let s=t.avail_in;return s>i&&(s=i),0===s?0:(t.avail_in-=s,e.set(t.input.subarray(t.next_in,t.next_in+s),a),1===t.state.wrap?t.adler=ot(t.adler,e,s,a):2===t.state.wrap&&(t.adler=ht(t.adler,e,s,a)),t.next_in+=s,t.total_in+=s,s)},Gt=(t,e)=>{let a,i,s=t.max_chain_length,r=t.strstart,n=t.prev_length,o=t.nice_match;const l=t.strstart>t.w_size-Ct?t.strstart-(t.w_size-Ct):0,h=t.window,d=t.w_mask,f=t.prev,_=t.strstart+Tt;let c=h[r+n-1],u=h[r+n];t.prev_length>=t.good_match&&(s>>=2),o>t.lookahead&&(o=t.lookahead);do{if(a=e,h[a+n]===u&&h[a+n-1]===c&&h[a]===h[r]&&h[++a]===h[r+1]){r+=2,a++;do{}while(h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&r<_);if(i=Tt-(_-r),r=_-Tt,i>n){if(t.match_start=e,n=i,i>=o)break;c=h[r+n-1],u=h[r+n]}}}while((e=f[e&d])>l&&0!=--s);return n<=t.lookahead?n:t.lookahead},Xt=t=>{const e=t.w_size;let a,i,s;do{if(i=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-Ct)&&(t.window.set(t.window.subarray(e,e+e-i),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),$t(t),i+=e),0===t.strm.avail_in)break;if(a=qt(t.strm,t.window,t.strstart+t.lookahead,i),t.lookahead+=a,t.lookahead+t.insert>=3)for(s=t.strstart-t.insert,t.ins_h=t.window[s],t.ins_h=jt(t,t.ins_h,t.window[s+1]);t.insert&&(t.ins_h=jt(t,t.ins_h,t.window[s+3-1]),t.prev[s&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=s,s++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<Ct&&0!==t.strm.avail_in)},Qt=(t,e)=>{let a,i,s,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,o=t.strm.avail_in;do{if(a=65535,s=t.bi_valid+42>>3,t.strm.avail_out<s)break;if(s=t.strm.avail_out-s,i=t.strstart-t.block_start,a>i+t.strm.avail_in&&(a=i+t.strm.avail_in),a>s&&(a=s),a<r&&(0===a&&e!==yt||e===mt||a!==i+t.strm.avail_in))break;n=e===yt&&a===i+t.strm.avail_in?1:0,ct(t,0,0,n),t.pending_buf[t.pending-4]=a,t.pending_buf[t.pending-3]=a>>8,t.pending_buf[t.pending-2]=~a,t.pending_buf[t.pending-1]=~a>>8,Vt(t.strm),i&&(i>a&&(i=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,a-=i),a&&(qt(t.strm,t.strm.output,t.strm.next_out,a),t.strm.next_out+=a,t.strm.avail_out-=a,t.strm.total_out+=a)}while(0===n);return o-=t.strm.avail_in,o&&(o>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=o&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-o,t.strm.next_in),t.strstart),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==mt&&e!==yt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(s=t.window_size-t.strstart,t.strm.avail_in>s&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,s+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),s>t.strm.avail_in&&(s=t.strm.avail_in),s&&(qt(t.strm,t.window,t.strstart,s),t.strstart+=s,t.insert+=s>t.w_size-t.insert?t.w_size-t.insert:s),t.high_water<t.strstart&&(t.high_water=t.strstart),s=t.bi_valid+42>>3,s=t.pending_buf_size-s>65535?65535:t.pending_buf_size-s,r=s>t.w_size?t.w_size:s,i=t.strstart-t.block_start,(i>=r||(i||e===yt)&&e!==mt&&0===t.strm.avail_in&&i<=s)&&(a=i>s?s:i,n=e===yt&&0===t.strm.avail_in&&a===i?1:0,ct(t,t.block_start,a,n),t.block_start+=a,Vt(t.strm)),n?3:1)},Jt=(t,e)=>{let a,i;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),0!==a&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a)),t.match_length>=3)if(i=wt(t,t.strstart-t.match_start,t.match_length-3),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=3){t.match_length--;do{t.strstart++,t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart}while(0!=--t.match_length);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=jt(t,t.ins_h,t.window[t.strstart+1]);else i=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(i&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2},te=(t,e)=>{let a,i,s;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=2,0!==a&&t.prev_length<t.max_lazy_match&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a),t.match_length<=5&&(t.strategy===Dt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){s=t.strstart+t.lookahead-3,i=wt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=s&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart)}while(0!=--t.prev_length);if(t.match_available=0,t.match_length=2,t.strstart++,i&&(Wt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(i=wt(t,0,t.window[t.strstart-1]),i&&Wt(t,!1),t.strstart++,t.lookahead--,0===t.strm.avail_out)return 1}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(i=wt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2};function ee(t,e,a,i,s){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=i,this.func=s}const ae=[new ee(0,0,0,0,Qt),new ee(4,4,8,4,Jt),new ee(4,5,16,8,Jt),new ee(4,6,32,32,Jt),new ee(4,4,16,16,te),new ee(8,16,32,32,te),new ee(8,16,128,128,te),new ee(8,32,128,256,te),new ee(32,128,258,1024,te),new ee(32,258,258,4096,te)];function ie(){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=Bt,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 Uint16Array(1146),this.dyn_dtree=new Uint16Array(122),this.bl_tree=new Uint16Array(78),Ht(this.dyn_ltree),Ht(this.dyn_dtree),Ht(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(16),this.heap=new Uint16Array(573),Ht(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Ht(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}const se=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Zt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Lt&&e.status!==Mt?1:0},re=t=>{if(se(t))return Nt(t,zt);t.total_in=t.total_out=0,t.data_type=Ft;const e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=2===e.wrap?57:e.wrap?Zt:Lt,t.adler=2===e.wrap?0:1,e.last_flush=-2,_t(e),vt},ne=t=>{const e=re(t);var a;return e===vt&&((a=t.state).window_size=2*a.w_size,Ht(a.head),a.max_lazy_match=ae[a.level].max_lazy,a.good_match=ae[a.level].good_length,a.nice_match=ae[a.level].nice_length,a.max_chain_length=ae[a.level].max_chain,a.strstart=0,a.block_start=0,a.lookahead=0,a.insert=0,a.match_length=a.prev_length=2,a.match_available=0,a.ins_h=0),e},oe=(t,e,a,i,s,r)=>{if(!t)return zt;let n=1;if(e===Et&&(e=6),i<0?(n=0,i=-i):i>15&&(n=2,i-=16),s<1||s>9||a!==Bt||i<8||i>15||e<0||e>9||r<0||r>Ot||8===i&&1!==n)return Nt(t,zt);8===i&&(i=9);const o=new ie;return t.state=o,o.strm=t,o.status=Zt,o.wrap=n,o.gzhead=null,o.w_bits=i,o.w_size=1<<o.w_bits,o.w_mask=o.w_size-1,o.hash_bits=s+7,o.hash_size=1<<o.hash_bits,o.hash_mask=o.hash_size-1,o.hash_shift=~~((o.hash_bits+3-1)/3),o.window=new Uint8Array(2*o.w_size),o.head=new Uint16Array(o.hash_size),o.prev=new Uint16Array(o.w_size),o.lit_bufsize=1<<s+6,o.pending_buf_size=4*o.lit_bufsize,o.pending_buf=new Uint8Array(o.pending_buf_size),o.sym_buf=o.lit_bufsize,o.sym_end=3*(o.lit_bufsize-1),o.level=e,o.strategy=r,o.method=a,ne(t)};var le={deflateInit:(t,e)=>oe(t,e,Bt,15,8,It),deflateInit2:oe,deflateReset:ne,deflateResetKeep:re,deflateSetHeader:(t,e)=>se(t)||2!==t.state.wrap?zt:(t.state.gzhead=e,vt),deflate:(t,e)=>{if(se(t)||e>kt||e<0)return t?Nt(t,zt):zt;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Mt&&e!==yt)return Nt(t,0===t.avail_out?St:zt);const i=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Vt(t),0===t.avail_out)return a.last_flush=-1,vt}else if(0===t.avail_in&&Pt(e)<=Pt(i)&&e!==yt)return Nt(t,St);if(a.status===Mt&&0!==t.avail_in)return Nt(t,St);if(a.status===Zt&&0===a.wrap&&(a.status=Lt),a.status===Zt){let e=Bt+(a.w_bits-8<<4)<<8,i=-1;if(i=a.strategy>=Ut||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=i<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Yt(a,e),0!==a.strstart&&(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),t.adler=1,a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(57===a.status)if(t.adler=0,Kt(a,31),Kt(a,139),Kt(a,8),a.gzhead)Kt(a,(a.gzhead.text?1:0)+(a.gzhead.hcrc?2:0)+(a.gzhead.extra?4:0)+(a.gzhead.name?8:0)+(a.gzhead.comment?16:0)),Kt(a,255&a.gzhead.time),Kt(a,a.gzhead.time>>8&255),Kt(a,a.gzhead.time>>16&255),Kt(a,a.gzhead.time>>24&255),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Kt(a,255&a.gzhead.extra.length),Kt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ht(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,3),a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt;if(69===a.status){if(a.gzhead.extra){let e=a.pending,i=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+i>a.pending_buf_size;){let s=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=s,Vt(t),0!==a.pending)return a.last_flush=-1,vt;e=0,i-=s}let s=new Uint8Array(a.gzhead.extra);a.pending_buf.set(s.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending+=i,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex=0}a.status=73}if(73===a.status){if(a.gzhead.name){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Vt(t),0!==a.pending))return a.last_flush=-1,vt;Kt(a,255&t.adler),Kt(a,t.adler>>8&255),t.adler=0}if(a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(0!==t.avail_in||0!==a.lookahead||e!==mt&&a.status!==Mt){let i=0===a.level?Qt(a,e):a.strategy===Ut?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(Xt(t),0===t.lookahead)){if(e===mt)return 1;break}if(t.match_length=0,a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===At?((t,e)=>{let a,i,s,r;const n=t.window;for(;;){if(t.lookahead<=Tt){if(Xt(t),t.lookahead<=Tt&&e===mt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(s=t.strstart-1,i=n[s],i===n[++s]&&i===n[++s]&&i===n[++s])){r=t.strstart+Tt;do{}while(i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&s<r);t.match_length=Tt-(r-s),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=wt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ae[a.level].func(a,e);if(3!==i&&4!==i||(a.status=Mt),1===i||3===i)return 0===t.avail_out&&(a.last_flush=-1),vt;if(2===i&&(e===pt?gt(a):e!==kt&&(ct(a,0,0,!1),e===bt&&(Ht(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Vt(t),0===t.avail_out))return a.last_flush=-1,vt}return e!==yt?vt:a.wrap<=0?xt:(2===a.wrap?(Kt(a,255&t.adler),Kt(a,t.adler>>8&255),Kt(a,t.adler>>16&255),Kt(a,t.adler>>24&255),Kt(a,255&t.total_in),Kt(a,t.total_in>>8&255),Kt(a,t.total_in>>16&255),Kt(a,t.total_in>>24&255)):(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),Vt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?vt:xt)},deflateEnd:t=>{if(se(t))return zt;const e=t.state.status;return t.state=null,e===Lt?Nt(t,Rt):vt},deflateSetDictionary:(t,e)=>{let a=e.length;if(se(t))return zt;const i=t.state,s=i.wrap;if(2===s||1===s&&i.status!==Zt||i.lookahead)return zt;if(1===s&&(t.adler=ot(t.adler,e,a,0)),i.wrap=0,a>=i.w_size){0===s&&(Ht(i.head),i.strstart=0,i.block_start=0,i.insert=0);let t=new Uint8Array(i.w_size);t.set(e.subarray(a-i.w_size,a),0),e=t,a=i.w_size}const r=t.avail_in,n=t.next_in,o=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,Xt(i);i.lookahead>=3;){let t=i.strstart,e=i.lookahead-2;do{i.ins_h=jt(i,i.ins_h,i.window[t+3-1]),i.prev[t&i.w_mask]=i.head[i.ins_h],i.head[i.ins_h]=t,t++}while(--e);i.strstart=t,i.lookahead=2,Xt(i)}return i.strstart+=i.lookahead,i.block_start=i.strstart,i.insert=i.lookahead,i.lookahead=0,i.match_length=i.prev_length=2,i.match_available=0,t.next_in=n,t.input=o,t.avail_in=r,i.wrap=s,vt},deflateInfo:"pako deflate (from Nodeca project)"};const he=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var de={assign:function(t){const e=Array.prototype.slice.call(arguments,1);for(;e.length;){const a=e.shift();if(a){if("object"!=typeof a)throw new TypeError(a+"must be non-object");for(const e in a)he(a,e)&&(t[e]=a[e])}}return t},flattenChunks:t=>{let e=0;for(let a=0,i=t.length;a<i;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,i=0,s=t.length;e<s;e++){let s=t[e];a.set(s,i),i+=s.length}return a}};let fe=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){fe=!1}const _e=new Uint8Array(256);for(let t=0;t<256;t++)_e[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;_e[254]=_e[254]=1;var ce={string2buf:t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,i,s,r,n=t.length,o=0;for(s=0;s<n;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),o+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(o),r=0,s=0;r<o;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),a<128?e[r++]=a:a<2048?(e[r++]=192|a>>>6,e[r++]=128|63&a):a<65536?(e[r++]=224|a>>>12,e[r++]=128|a>>>6&63,e[r++]=128|63&a):(e[r++]=240|a>>>18,e[r++]=128|a>>>12&63,e[r++]=128|a>>>6&63,e[r++]=128|63&a);return e},buf2string:(t,e)=>{const a=e||t.length;if("function"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(t.subarray(0,e));let i,s;const r=new Array(2*a);for(s=0,i=0;i<a;){let e=t[i++];if(e<128){r[s++]=e;continue}let n=_e[e];if(n>4)r[s++]=65533,i+=n-1;else{for(e&=2===n?31:3===n?15:7;n>1&&i<a;)e=e<<6|63&t[i++],n--;n>1?r[s++]=65533:e<65536?r[s++]=e:(e-=65536,r[s++]=55296|e>>10&1023,r[s++]=56320|1023&e)}}return((t,e)=>{if(e<65534&&t.subarray&&fe)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let a="";for(let i=0;i<e;i++)a+=String.fromCharCode(t[i]);return a})(r,s)},utf8border:(t,e)=>{(e=e||t.length)>t.length&&(e=t.length);let a=e-1;for(;a>=0&&128==(192&t[a]);)a--;return a<0||0===a?e:a+_e[t[a]]>e?a:e}};var ue=function(){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};const we=Object.prototype.toString,{Z_NO_FLUSH:ge,Z_SYNC_FLUSH:me,Z_FULL_FLUSH:pe,Z_FINISH:be,Z_OK:ye,Z_STREAM_END:ke,Z_DEFAULT_COMPRESSION:ve,Z_DEFAULT_STRATEGY:xe,Z_DEFLATED:ze}=ft;function Re(t){this.options=de.assign({level:ve,method:ze,chunkSize:16384,windowBits:15,memLevel:8,strategy:xe},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new ue,this.strm.avail_out=0;let a=le.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==ye)throw new Error(dt[a]);if(e.header&&le.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?ce.string2buf(e.dictionary):"[object ArrayBuffer]"===we.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=le.deflateSetDictionary(this.strm,t),a!==ye)throw new Error(dt[a]);this._dict_set=!0}}function Se(t,e){const a=new Re(e);if(a.push(t,!0),a.err)throw a.msg||dt[a.err];return a.result}Re.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize;let s,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?be:ge,"string"==typeof t?a.input=ce.string2buf(t):"[object ArrayBuffer]"===we.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;)if(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),(r===me||r===pe)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(s=le.deflate(a,r),s===ke)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),s=le.deflateEnd(this.strm),this.onEnd(s),this.ended=!0,s===ye;if(0!==a.avail_out){if(r>0&&a.next_out>0)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else if(0===a.avail_in)break}else this.onData(a.output)}return!0},Re.prototype.onData=function(t){this.chunks.push(t)},Re.prototype.onEnd=function(t){t===ye&&(this.result=de.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Ee={Deflate:Re,deflate:Se,deflateRaw:function(t,e){return(e=e||{}).raw=!0,Se(t,e)},gzip:function(t,e){return(e=e||{}).gzip=!0,Se(t,e)},constants:ft};const De=16209;var Ue=function(t,e){let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z,R;const S=t.state;a=t.next_in,z=t.input,i=a+(t.avail_in-5),s=t.next_out,R=t.output,r=s-(e-t.avail_out),n=s+(t.avail_out-257),o=S.dmax,l=S.wsize,h=S.whave,d=S.wnext,f=S.window,_=S.hold,c=S.bits,u=S.lencode,w=S.distcode,g=(1<<S.lenbits)-1,m=(1<<S.distbits)-1;t:do{c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=u[_&g];e:for(;;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,0===b)R[s++]=65535&p;else{if(!(16&b)){if(0==(64&b)){p=u[(65535&p)+(_&(1<<b)-1)];continue e}if(32&b){S.mode=16191;break t}t.msg="invalid literal/length code",S.mode=De;break t}y=65535&p,b&=15,b&&(c<b&&(_+=z[a++]<<c,c+=8),y+=_&(1<<b)-1,_>>>=b,c-=b),c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=w[_&m];a:for(;;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,!(16&b)){if(0==(64&b)){p=w[(65535&p)+(_&(1<<b)-1)];continue a}t.msg="invalid distance code",S.mode=De;break t}if(k=65535&p,b&=15,c<b&&(_+=z[a++]<<c,c+=8,c<b&&(_+=z[a++]<<c,c+=8)),k+=_&(1<<b)-1,k>o){t.msg="invalid distance too far back",S.mode=De;break t}if(_>>>=b,c-=b,b=s-r,k>b){if(b=k-b,b>h&&S.sane){t.msg="invalid distance too far back",S.mode=De;break t}if(v=0,x=f,0===d){if(v+=l-b,b<y){y-=b;do{R[s++]=f[v++]}while(--b);v=s-k,x=R}}else if(d<b){if(v+=l+d-b,b-=d,b<y){y-=b;do{R[s++]=f[v++]}while(--b);if(v=0,d<y){b=d,y-=b;do{R[s++]=f[v++]}while(--b);v=s-k,x=R}}}else if(v+=d-b,b<y){y-=b;do{R[s++]=f[v++]}while(--b);v=s-k,x=R}for(;y>2;)R[s++]=x[v++],R[s++]=x[v++],R[s++]=x[v++],y-=3;y&&(R[s++]=x[v++],y>1&&(R[s++]=x[v++]))}else{v=s-k;do{R[s++]=R[v++],R[s++]=R[v++],R[s++]=R[v++],y-=3}while(y>2);y&&(R[s++]=R[v++],y>1&&(R[s++]=R[v++]))}break}}break}}while(a<i&&s<n);y=c>>3,a-=y,c-=y<<3,_&=(1<<c)-1,t.next_in=a,t.next_out=s,t.avail_in=a<i?i-a+5:5-(a-i),t.avail_out=s<n?n-s+257:257-(s-n),S.hold=_,S.bits=c};const Ae=15,Oe=new Uint16Array([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]),Ie=new Uint8Array([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]),Fe=new Uint16Array([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]),Be=new Uint8Array([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]);var Te=(t,e,a,i,s,r,n,o)=>{const l=o.bits;let h,d,f,_,c,u,w=0,g=0,m=0,p=0,b=0,y=0,k=0,v=0,x=0,z=0,R=null;const S=new Uint16Array(16),E=new Uint16Array(16);let D,U,A,O=null;for(w=0;w<=Ae;w++)S[w]=0;for(g=0;g<i;g++)S[e[a+g]]++;for(b=l,p=Ae;p>=1&&0===S[p];p--);if(b>p&&(b=p),0===p)return s[r++]=20971520,s[r++]=20971520,o.bits=1,0;for(m=1;m<p&&0===S[m];m++);for(b<m&&(b=m),v=1,w=1;w<=Ae;w++)if(v<<=1,v-=S[w],v<0)return-1;if(v>0&&(0===t||1!==p))return-1;for(E[1]=0,w=1;w<Ae;w++)E[w+1]=E[w]+S[w];for(g=0;g<i;g++)0!==e[a+g]&&(n[E[e[a+g]]++]=g);if(0===t?(R=O=n,u=20):1===t?(R=Oe,O=Ie,u=257):(R=Fe,O=Be,u=0),z=0,g=0,w=m,c=r,y=b,k=0,f=-1,x=1<<b,_=x-1,1===t&&x>852||2===t&&x>592)return 1;for(;;){D=w-k,n[g]+1<u?(U=0,A=n[g]):n[g]>=u?(U=O[n[g]-u],A=R[n[g]-u]):(U=96,A=0),h=1<<w-k,d=1<<y,m=d;do{d-=h,s[c+(z>>k)+d]=D<<24|U<<16|A|0}while(0!==d);for(h=1<<w-1;z&h;)h>>=1;if(0!==h?(z&=h-1,z+=h):z=0,g++,0==--S[w]){if(w===p)break;w=e[a+n[g]]}if(w>b&&(z&_)!==f){for(0===k&&(k=b),c+=m,y=w-k,v=1<<y;y+k<p&&(v-=S[y+k],!(v<=0));)y++,v<<=1;if(x+=1<<y,1===t&&x>852||2===t&&x>592)return 1;f=z&_,s[f]=b<<24|y<<16|c-r|0}}return 0!==z&&(s[c+z]=w-k<<24|64<<16|0),o.bits=b,0};const{Z_FINISH:Ce,Z_BLOCK:Ze,Z_TREES:Le,Z_OK:Me,Z_STREAM_END:Ne,Z_NEED_DICT:Pe,Z_STREAM_ERROR:He,Z_DATA_ERROR:$e,Z_MEM_ERROR:je,Z_BUF_ERROR:Ve,Z_DEFLATED:We}=ft,Ke=16180,Ye=16190,qe=16191,Ge=16192,Xe=16194,Qe=16199,Je=16200,ta=16206,ea=16209,aa=t=>(t>>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24);function ia(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}const sa=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.mode<Ke||e.mode>16211?1:0},ra=t=>{if(sa(t))return He;const e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=1&e.wrap),e.mode=Ke,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(852),e.distcode=e.distdyn=new Int32Array(592),e.sane=1,e.back=-1,Me},na=t=>{if(sa(t))return He;const e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,ra(t)},oa=(t,e)=>{let a;if(sa(t))return He;const i=t.state;return e<0?(a=0,e=-e):(a=5+(e>>4),e<48&&(e&=15)),e&&(e<8||e>15)?He:(null!==i.window&&i.wbits!==e&&(i.window=null),i.wrap=a,i.wbits=e,na(t))},la=(t,e)=>{if(!t)return He;const a=new ia;t.state=a,a.strm=t,a.window=null,a.mode=Ke;const i=oa(t,e);return i!==Me&&(t.state=null),i};let ha,da,fa=!0;const _a=t=>{if(fa){ha=new Int32Array(512),da=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(Te(1,t.lens,0,288,ha,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;Te(2,t.lens,0,32,da,0,t.work,{bits:5}),fa=!1}t.lencode=ha,t.lenbits=9,t.distcode=da,t.distbits=5},ca=(t,e,a,i)=>{let s;const r=t.state;return null===r.window&&(r.wsize=1<<r.wbits,r.wnext=0,r.whave=0,r.window=new Uint8Array(r.wsize)),i>=r.wsize?(r.window.set(e.subarray(a-r.wsize,a),0),r.wnext=0,r.whave=r.wsize):(s=r.wsize-r.wnext,s>i&&(s=i),r.window.set(e.subarray(a-i,a-i+s),r.wnext),(i-=s)?(r.window.set(e.subarray(a-i,a),0),r.wnext=i,r.whave=r.wsize):(r.wnext+=s,r.wnext===r.wsize&&(r.wnext=0),r.whave<r.wsize&&(r.whave+=s))),0};var ua={inflateReset:na,inflateReset2:oa,inflateResetKeep:ra,inflateInit:t=>la(t,15),inflateInit2:la,inflate:(t,e)=>{let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z=0;const R=new Uint8Array(4);let S,E;const D=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(sa(t)||!t.output||!t.input&&0!==t.avail_in)return He;a=t.state,a.mode===qe&&(a.mode=Ge),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,f=o,_=l,x=Me;t:for(;;)switch(a.mode){case Ke:if(0===a.wrap){a.mode=Ge;break}for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(2&a.wrap&&35615===h){0===a.wbits&&(a.wbits=15),a.check=0,R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0),h=0,d=0,a.mode=16181;break}if(a.head&&(a.head.done=!1),!(1&a.wrap)||(((255&h)<<8)+(h>>8))%31){t.msg="incorrect header check",a.mode=ea;break}if((15&h)!==We){t.msg="unknown compression method",a.mode=ea;break}if(h>>>=4,d-=4,v=8+(15&h),0===a.wbits&&(a.wbits=v),v>15||v>a.wbits){t.msg="invalid window size",a.mode=ea;break}a.dmax=1<<a.wbits,a.flags=0,t.adler=a.check=1,a.mode=512&h?16189:qe,h=0,d=0;break;case 16181:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.flags=h,(255&a.flags)!==We){t.msg="unknown compression method",a.mode=ea;break}if(57344&a.flags){t.msg="unknown header flags set",a.mode=ea;break}a.head&&(a.head.text=h>>8&1),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0)),h=0,d=0,a.mode=16182;case 16182:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.time=h),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,R[2]=h>>>16&255,R[3]=h>>>24&255,a.check=ht(a.check,R,4,0)),h=0,d=0,a.mode=16183;case 16183:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.xflags=255&h,a.head.os=h>>8),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0)),h=0,d=0,a.mode=16184;case 16184:if(1024&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length=h,a.head&&(a.head.extra_len=h),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0)),h=0,d=0}else a.head&&(a.head.extra=null);a.mode=16185;case 16185:if(1024&a.flags&&(c=a.length,c>o&&(c=o),c&&(a.head&&(v=a.head.extra_len-a.length,a.head.extra||(a.head.extra=new Uint8Array(a.head.extra_len)),a.head.extra.set(i.subarray(r,r+c),v)),512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,a.length-=c),a.length))break t;a.length=0,a.mode=16186;case 16186:if(2048&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.name+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.name=null);a.length=0,a.mode=16187;case 16187:if(4096&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.comment+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.comment=null);a.mode=16188;case 16188:if(512&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(65535&a.check)){t.msg="header crc mismatch",a.mode=ea;break}h=0,d=0}a.head&&(a.head.hcrc=a.flags>>9&1,a.head.done=!0),t.adler=a.check=0,a.mode=qe;break;case 16189:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}t.adler=a.check=aa(h),h=0,d=0,a.mode=Ye;case Ye:if(0===a.havedict)return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,Pe;t.adler=a.check=1,a.mode=qe;case qe:if(e===Ze||e===Le)break t;case Ge:if(a.last){h>>>=7&d,d-=7&d,a.mode=ta;break}for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}switch(a.last=1&h,h>>>=1,d-=1,3&h){case 0:a.mode=16193;break;case 1:if(_a(a),a.mode=Qe,e===Le){h>>>=2,d-=2;break t}break;case 2:a.mode=16196;break;case 3:t.msg="invalid block type",a.mode=ea}h>>>=2,d-=2;break;case 16193:for(h>>>=7&d,d-=7&d;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if((65535&h)!=(h>>>16^65535)){t.msg="invalid stored block lengths",a.mode=ea;break}if(a.length=65535&h,h=0,d=0,a.mode=Xe,e===Le)break t;case Xe:a.mode=16195;case 16195:if(c=a.length,c){if(c>o&&(c=o),c>l&&(c=l),0===c)break t;s.set(i.subarray(r,r+c),n),o-=c,r+=c,l-=c,n+=c,a.length-=c;break}a.mode=qe;break;case 16196:for(;d<14;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.nlen=257+(31&h),h>>>=5,d-=5,a.ndist=1+(31&h),h>>>=5,d-=5,a.ncode=4+(15&h),h>>>=4,d-=4,a.nlen>286||a.ndist>30){t.msg="too many length or distance symbols",a.mode=ea;break}a.have=0,a.mode=16197;case 16197:for(;a.have<a.ncode;){for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.lens[D[a.have++]]=7&h,h>>>=3,d-=3}for(;a.have<19;)a.lens[D[a.have++]]=0;if(a.lencode=a.lendyn,a.lenbits=7,S={bits:a.lenbits},x=Te(0,a.lens,0,19,a.lencode,0,a.work,S),a.lenbits=S.bits,x){t.msg="invalid code lengths set",a.mode=ea;break}a.have=0,a.mode=16198;case 16198:for(;a.have<a.nlen+a.ndist;){for(;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(p<16)h>>>=g,d-=g,a.lens[a.have++]=p;else{if(16===p){for(E=g+2;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(h>>>=g,d-=g,0===a.have){t.msg="invalid bit length repeat",a.mode=ea;break}v=a.lens[a.have-1],c=3+(3&h),h>>>=2,d-=2}else if(17===p){for(E=g+3;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=3+(7&h),h>>>=3,d-=3}else{for(E=g+7;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=11+(127&h),h>>>=7,d-=7}if(a.have+c>a.nlen+a.ndist){t.msg="invalid bit length repeat",a.mode=ea;break}for(;c--;)a.lens[a.have++]=v}}if(a.mode===ea)break;if(0===a.lens[256]){t.msg="invalid code -- missing end-of-block",a.mode=ea;break}if(a.lenbits=9,S={bits:a.lenbits},x=Te(1,a.lens,0,a.nlen,a.lencode,0,a.work,S),a.lenbits=S.bits,x){t.msg="invalid literal/lengths set",a.mode=ea;break}if(a.distbits=6,a.distcode=a.distdyn,S={bits:a.distbits},x=Te(2,a.lens,a.nlen,a.ndist,a.distcode,0,a.work,S),a.distbits=S.bits,x){t.msg="invalid distances set",a.mode=ea;break}if(a.mode=Qe,e===Le)break t;case Qe:a.mode=Je;case Je:if(o>=6&&l>=258){t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,Ue(t,_),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,a.mode===qe&&(a.back=-1);break}for(a.back=0;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(m&&0==(240&m)){for(b=g,y=m,k=p;z=a.lencode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,a.length=p,0===m){a.mode=16205;break}if(32&m){a.back=-1,a.mode=qe;break}if(64&m){t.msg="invalid literal/length code",a.mode=ea;break}a.extra=15&m,a.mode=16201;case 16201:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}a.was=a.length,a.mode=16202;case 16202:for(;z=a.distcode[h&(1<<a.distbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(0==(240&m)){for(b=g,y=m,k=p;z=a.distcode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,64&m){t.msg="invalid distance code",a.mode=ea;break}a.offset=p,a.extra=15&m,a.mode=16203;case 16203:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.offset+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}if(a.offset>a.dmax){t.msg="invalid distance too far back",a.mode=ea;break}a.mode=16204;case 16204:if(0===l)break t;if(c=_-l,a.offset>c){if(c=a.offset-c,c>a.whave&&a.sane){t.msg="invalid distance too far back",a.mode=ea;break}c>a.wnext?(c-=a.wnext,u=a.wsize-c):u=a.wnext-c,c>a.length&&(c=a.length),w=a.window}else w=s,u=n-a.offset,c=a.length;c>l&&(c=l),l-=c,a.length-=c;do{s[n++]=w[u++]}while(--c);0===a.length&&(a.mode=Je);break;case 16205:if(0===l)break t;s[n++]=a.length,l--,a.mode=Je;break;case ta:if(a.wrap){for(;d<32;){if(0===o)break t;o--,h|=i[r++]<<d,d+=8}if(_-=l,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,n-_):ot(a.check,s,_,n-_)),_=l,4&a.wrap&&(a.flags?h:aa(h))!==a.check){t.msg="incorrect data check",a.mode=ea;break}h=0,d=0}a.mode=16207;case 16207:if(a.wrap&&a.flags){for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(4294967295&a.total)){t.msg="incorrect length check",a.mode=ea;break}h=0,d=0}a.mode=16208;case 16208:x=Ne;break t;case ea:x=$e;break t;case 16210:return je;default:return He}return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,(a.wsize||_!==t.avail_out&&a.mode<ea&&(a.mode<ta||e!==Ce))&&ca(t,t.output,t.next_out,_-t.avail_out),f-=t.avail_in,_-=t.avail_out,t.total_in+=f,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,t.next_out-_):ot(a.check,s,_,t.next_out-_)),t.data_type=a.bits+(a.last?64:0)+(a.mode===qe?128:0)+(a.mode===Qe||a.mode===Xe?256:0),(0===f&&0===_||e===Ce)&&x===Me&&(x=Ve),x},inflateEnd:t=>{if(sa(t))return He;let e=t.state;return e.window&&(e.window=null),t.state=null,Me},inflateGetHeader:(t,e)=>{if(sa(t))return He;const a=t.state;return 0==(2&a.wrap)?He:(a.head=e,e.done=!1,Me)},inflateSetDictionary:(t,e)=>{const a=e.length;let i,s,r;return sa(t)?He:(i=t.state,0!==i.wrap&&i.mode!==Ye?He:i.mode===Ye&&(s=1,s=ot(s,e,a,0),s!==i.check)?$e:(r=ca(t,e,a,a),r?(i.mode=16210,je):(i.havedict=1,Me)))},inflateInfo:"pako inflate (from Nodeca project)"};var wa=function(){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=!1};const ga=Object.prototype.toString,{Z_NO_FLUSH:ma,Z_FINISH:pa,Z_OK:ba,Z_STREAM_END:ya,Z_NEED_DICT:ka,Z_STREAM_ERROR:va,Z_DATA_ERROR:xa,Z_MEM_ERROR:za}=ft;function Ra(t){this.options=de.assign({chunkSize:65536,windowBits:15,to:""},t||{});const e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&0==(15&e.windowBits)&&(e.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new ue,this.strm.avail_out=0;let a=ua.inflateInit2(this.strm,e.windowBits);if(a!==ba)throw new Error(dt[a]);if(this.header=new wa,ua.inflateGetHeader(this.strm,this.header),e.dictionary&&("string"==typeof e.dictionary?e.dictionary=ce.string2buf(e.dictionary):"[object ArrayBuffer]"===ga.call(e.dictionary)&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(a=ua.inflateSetDictionary(this.strm,e.dictionary),a!==ba)))throw new Error(dt[a])}Ra.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize,s=this.options.dictionary;let r,n,o;if(this.ended)return!1;for(n=e===~~e?e:!0===e?pa:ma,"[object ArrayBuffer]"===ga.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;){for(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),r=ua.inflate(a,n),r===ka&&s&&(r=ua.inflateSetDictionary(a,s),r===ba?r=ua.inflate(a,n):r===xa&&(r=ka));a.avail_in>0&&r===ya&&a.state.wrap>0&&0!==t[a.next_in];)ua.inflateReset(a),r=ua.inflate(a,n);switch(r){case va:case xa:case ka:case za:return this.onEnd(r),this.ended=!0,!1}if(o=a.avail_out,a.next_out&&(0===a.avail_out||r===ya))if("string"===this.options.to){let t=ce.utf8border(a.output,a.next_out),e=a.next_out-t,s=ce.buf2string(a.output,t);a.next_out=e,a.avail_out=i-e,e&&a.output.set(a.output.subarray(t,t+e),0),this.onData(s)}else this.onData(a.output.length===a.next_out?a.output:a.output.subarray(0,a.next_out));if(r!==ba||0!==o){if(r===ya)return r=ua.inflateEnd(this.strm),this.onEnd(r),this.ended=!0,!0;if(0===a.avail_in)break}}return!0},Ra.prototype.onData=function(t){this.chunks.push(t)},Ra.prototype.onEnd=function(t){t===ba&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=de.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};const{Deflate:Sa,deflate:Ea,deflateRaw:Da,gzip:Ua}=Ee;var Aa=Ea;const Oa={b:{u:DataView.prototype.getInt8,p:DataView.prototype.setInt8,bytes:1},B:{u:DataView.prototype.getUint8,p:DataView.prototype.setUint8,bytes:1},h:{u:DataView.prototype.getInt16,p:DataView.prototype.setInt16,bytes:2},H:{u:DataView.prototype.getUint16,p:DataView.prototype.setUint16,bytes:2},i:{u:DataView.prototype.getInt32,p:DataView.prototype.setInt32,bytes:4},I:{u:DataView.prototype.getUint32,p:DataView.prototype.setUint32,bytes:4},q:{u:DataView.prototype.getInt64,p:DataView.prototype.setInt64,bytes:8},Q:{u:DataView.prototype.getUint64,p:DataView.prototype.setUint64,bytes:8}},Ia=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let i=[],s=!0;for(let i=0;i<t.length;i++)"<"==t[i]?s=!0:">"==t[i]?s=!1:(r(t[i],e[a]),a++);function r(t,e){if(!(t in Oa))throw"Unhandled character '"+t+"' in pack format";let a=Oa[t].bytes,r=new DataView(new ArrayBuffer(a));Oa[t].p.bind(r)(0,e,s);for(let t=0;t<a;t++)i.push(r.getUint8(t))}return i},Fa=(t,e)=>{let a=0,i=[],s=!0;for(let e of t)"<"==e?s=!0:">"==e?s=!1:r(e);function r(t){if(!(t in Oa))throw"Unhandled character '"+t+"' in unpack format";let r=Oa[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let o=Oa[t].u.bind(n);i.push(o(0,s)),a+=r}return i};class Ba extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this._efuses=new Array(4).fill(0),this._flashsize=4194304,this.debug=!1,this.IS_STUB=!1,this.connected=!0,this.flashSize=null,this.state_DTR=!1}get _inputBuffer(){return this._parent?this._parent._inputBuffer:this.__inputBuffer}async initialize(){await this.hardReset(!0),this._parent||(this.__inputBuffer=[],this.readLoop()),await this.sync();let t=await this.readRegister(1073745920),e=g[t>>>0];if(void 0===e)throw new Error(`Unknown Chip: Hex: ${a(t>>>0,8).toLowerCase()} Number: ${t}`);this.chipName=e.name,this.chipFamily=e.family;let i=y(this.getChipFamily()).macFuse;for(let t=0;t<4;t++)this._efuses[t]=await this.readRegister(i+4*t);this.logger.log(`Chip type ${this.chipName}`)}async readLoop(){this.debug&&this.logger.debug("Starting read loop"),this._reader=this.port.readable.getReader();try{for(;;){const{value:t,done:e}=await this._reader.read();if(e){this._reader.releaseLock();break}t&&0!==t.length&&this._inputBuffer.push(...Array.from(t))}}catch(t){console.error("Read loop got disconnected")}this.connected=!1,this.dispatchEvent(new Event("disconnect")),this.logger.debug("Finished read loop")}sleep(t=100){return new Promise((e=>setTimeout(e,t)))}async setRTS(t){await this.port.setSignals({requestToSend:t}),await this.setDTR(this.state_DTR)}async setDTR(t){this.state_DTR=t,await this.port.setSignals({dataTerminalReady:t})}async hardReset(t=!1){this.logger.log("Try hard reset."),t?4097===this.port.getInfo().usbProductId?(await this.setDTR(!1),await this.setRTS(!1),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(100),await this.setRTS(!0),await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!1),await this.setRTS(!1)):(await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(50),await this.setDTR(!1)):(await this.setRTS(!0),await this.sleep(100),await this.setRTS(!1)),await new Promise((t=>setTimeout(t,1e3)))}macAddr(){let t,e=new Array(6).fill(0),a=this._efuses[0],i=this._efuses[1],s=this._efuses[2],r=this._efuses[3];if(this.chipFamily==o){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(0==(i>>16&255))t=[24,254,52];else{if(1!=(i>>16&255))throw new Error("Couldnt determine OUI");t=[172,208,116]}e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=i>>8&255,e[4]=255&i,e[5]=a>>24&255}else if(this.chipFamily==l)e[0]=s>>8&255,e[1]=255&s,e[2]=i>>24&255,e[3]=i>>16&255,e[4]=i>>8&255,e[5]=255&i;else{if(this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=i>>8&255,e[1]=255&i,e[2]=a>>24&255,e[3]=a>>16&255,e[4]=a>>8&255,e[5]=255&a}return e}async readRegister(t){this.debug&&this.logger.debug("Reading from Register "+a(t,8));let e=Ia("<I",t);await this.sendCommand(10,e);let[i,s]=await this.getResponse(10);return i}async checkCommand(t,e,i=0,s=3e3){s=Math.min(s,12e5),await this.sendCommand(t,e,i);let[r,n]=await this.getResponse(t,s);if(null===n)throw new Error("Didn't get enough status bytes");let g=0;if(this.IS_STUB||this.chipFamily==o?g=2:[l,h,d,f,_,c,u,w].includes(this.chipFamily)?g=4:[2,4].includes(n.length)&&(g=n.length),n.length<g)throw new Error("Didn't get enough status bytes");let m=n.slice(-g,n.length);if(n=n.slice(0,-g),this.debug&&(this.logger.debug("status",m),this.logger.debug("value",r),this.logger.debug("data",n)),1==m[0])throw 5==m[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(m[1]));return[r,n]}async sendCommand(t,e,a=0){let i=(t=>{let e=[192];for(let a of t)219==a?e=e.concat([219,221]):192==a?e=e.concat([219,220]):e.push(a);return e.push(192),e})([...Ia("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${i.length} byte${1==i.length?"":"s"}:`,i),await this.writeToStream(i)}async readPacket(t){let s=null,r=!1,n=[];for(;;){let o=Date.now();for(n=[];Date.now()-o<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await i(10)}if(0==n.length){throw new k("Timed out waiting for packet "+(null===s?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===s){if(192!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid head of packet ("+a(t)+")");s=[]}else if(r)if(r=!1,220==t)s.push(192);else{if(221!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid SLIP escape (0xdb, "+a(t)+")");s.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(s)),s;s.push(t)}}throw new k("Invalid state")}async getResponse(t,e=3e3){for(let i=0;i<100;i++){const i=await this.readPacket(e);if(i.length<8)continue;const[s,r,n,o]=Fa("<BBHI",i.slice(0,8));if(1!=s)continue;const l=i.slice(8);if(null==t||r==t)return[o,l];if(0!=l[0]&&5==l[1])throw this._inputBuffer.length=0,new Error(`Invalid (unsupported) command ${a(t)}`)}throw"Response doesn't match request"}checksum(t,e=239){for(let a of t)e^=a;return e}async setBaudrate(t){if(this.chipFamily==o)throw new Error("Changing baud rate is not supported on the ESP8266");this.logger.log("Attempting to change baud rate to "+t+"...");try{let e=Ia("<II",t,this.IS_STUB?r:0);await this.checkCommand(15,e)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: No response from set baud rate command.`)}this._parent?await this._parent.reconfigurePort(t):await this.reconfigurePort(t)}async reconfigurePort(t){var e;try{await(null===(e=this._reader)||void 0===e?void 0:e.cancel()),await this.port.close(),await this.port.open({baudRate:t}),this.readLoop(),this.logger.log(`Changed baud rate to ${t}`)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: ${e}`)}}async sync(){for(let t=0;t<5;t++){if(this._inputBuffer.length=0,await this._sync())return await i(100),!0;await i(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,n);for(let t=0;t<8;t++)try{let[t,e]=await this.getResponse(8,100);if(e.length>1&&0==e[0]&&0==e[1])return!0}catch(t){}return!1}getFlashWriteSize(){return this.IS_STUB?16384:1024}async flashData(t,e,i=0,s=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],i=r[2],s=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(i)}, FlashSizeFreq=${a(s)}`)}let n,o=t.byteLength,l=0,h=m;s?(n=Aa(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${o}. Compressed Size: ${l}`),h=await this.flashDeflBegin(o,l,i)):(this.logger.log(`Writing data with filesize: ${o}`),n=t,await this.flashBegin(o,i));let d=[],f=0,_=0,c=0,u=Date.now(),w=this.getFlashWriteSize(),g=s?l:o;for(;g-c>0;)this.debug&&this.logger.log(`Writing at ${a(i+f*w,8)} `),g-c>=w?d=Array.from(new Uint8Array(n,c,w)):(d=Array.from(new Uint8Array(n,c,g-c)),s||(d=d.concat(new Array(w-d.length).fill(255)))),s?await this.flashDeflBlock(d,f,h):await this.flashBlock(d,f),f+=1,_+=s?Math.round(d.length*o/l):d.length,c+=w,e(Math.min(_,o),o);this.logger.log("Took "+(Date.now()-u)+"ms to write "+g+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),s?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Ia("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Ia("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,i=!1){let s,r,n=this.getFlashWriteSize();!this.IS_STUB&&[l,h,d,f,_,c,u,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let g,p=Math.floor((t+n-1)/n);s=this.chipFamily==o?this.getEraseSize(e,t):t,g=this.IS_STUB?m:b(3e4,t);let y=Date.now();return r=Ia("<IIII",s,p,n,e),this.chipFamily!=l&&this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w||(r=r.concat(Ia("<I",i?1:0))),this.logger.log("Erase size "+s+", blocks "+p+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(i?"yes":"no")),await this.checkCommand(2,r,0,g),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-y)+"ms to erase "+p+" bytes"),p}async flashDeflBegin(t=0,e=0,a=0,i=!1){let s,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),o=Math.floor((t+r-1)/r),l=0,h=0;return this.IS_STUB?(l=t,h=b(3e4,l)):(l=o*r,h=m),s=Ia("<IIII",l,n,r,a),await this.checkCommand(16,s,0,h),h}async flashFinish(){let t=Ia("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Ia("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return y(this.getChipFamily()).flashOffs}async flashId(){return await this.runSpiFlashCommand(159,[],24)}getChipFamily(){return this._parent?this._parent.chipFamily:this.chipFamily}async writeRegister(t,e,a=4294967295,i=0,s=0){let r=Ia("<IIII",t,e,a,i);s>0&&r.concat(Ia("<IIII",y(this.getChipFamily()).uartDateReg,0,0,s)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let i=t.regBase+t.mosiDlenOffs,s=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(i,e-1),a>0&&await this.writeRegister(s,a-1)}else{let i=t.regBase+t.usr1Offs,s=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(i,s)}}async waitDone(t,e){for(let a=0;a<10;a++){if(0==(await this.readRegister(t)&e))return}throw Error("SPI command did not complete in time")}async runSpiFlashCommand(t,e,i=0){let s=y(this.getChipFamily()),r=s.regBase,n=r,o=r+s.usrOffs,l=r+s.usr2Offs,h=r+s.w0Offs,d=1<<18;if(i>32)throw new Error("Reading more than 32 bits back from a SPI flash operation is unsupported");if(e.length>64)throw new Error("Writing more than 64 bytes of data with one SPI command is unsupported");let f=8*e.length,_=await this.readRegister(o),c=await this.readRegister(l),u=1<<31;if(i>0&&(u|=268435456),f>0&&(u|=134217728),await this.setDataLengths(s,f,i),await this.writeRegister(o,u),await this.writeRegister(l,7<<28|t),0==f)await this.writeRegister(h,0);else{e.concat(new Array(e.length%4).fill(0));let t=Fa("I".repeat(Math.floor(e.length/4)),e),i=h;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(i)}`),await this.writeRegister(i,e),i+=4}await this.writeRegister(n,d),await this.waitDone(n,d);let w=await this.readRegister(h);return await this.writeRegister(o,_),await this.writeRegister(l,c),w}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,i=t>>16&255;this.logger.log(`FlashId: ${a(t)}`),this.logger.log(`Flash Manufacturer: ${e.toString(16)}`),this.logger.log(`Flash Device: ${(t>>8&255).toString(16)}${i.toString(16)}`),this.flashSize=s[i],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,i=Math.floor((e+a-1)/a),s=16-Math.floor(t/a)%16;return i<s&&(s=i),i<2*s?Math.floor((i+1)/2*a):(i-s)*a}async memBegin(t,e,a,i){return await this.checkCommand(5,Ia("<IIII",t,e,a,i))}async memBlock(t,e){return await this.checkCommand(7,Ia("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?m:500,a=Ia("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await v(this.chipFamily);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let i=t[e+"_start"],s=t[e].length,r=Math.floor((s+a-1)/a);await this.memBegin(s,r,a,i);for(let i of Array(r).keys()){let r=i*a,n=r+a;n>s&&(n=s),await this.memBlock(t[e].slice(r,n),i)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const i=await this.readPacket(500);if(e=String.fromCharCode(...i),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const s=new Ta(this.port,this.logger,this);return await s.detectFlashSize(),s}async writeToStream(t){const e=this.port.writable.getWriter();await e.write(new Uint8Array(t));try{e.releaseLock()}catch(t){console.error("Ignoring release lock error",t)}}async disconnect(){this._parent?await this._parent.disconnect():(await this.port.writable.getWriter().close(),await new Promise((t=>{this._reader||t(void 0),this.addEventListener("disconnect",t,{once:!0}),this._reader.cancel()})),this.connected=!1)}}class Ta extends Ba{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,i,s){let r=await v(this.chipFamily),n=s,o=s+t;console.log(n,o),console.log(r.data_start,r.data.length,r.text_start,r.text.length);for(let[t,e]of[[r.data_start,r.data_start+r.data.length],[r.text_start,r.text_start+r.text.length]])if(n<e&&o>t)throw new Error("Software loader is resident at "+a(t,8)+"-"+a(e,8)+". Can't load binary at overlapping address range "+a(n,8)+"-"+a(o,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,p)}}const Ca=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Ba(e,t)};export{l as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,_ as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C6,u as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,h as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,o as CHIP_FAMILY_ESP8266,Ba as ESPLoader,Ca as connect};
|
|
1
|
+
const t=t=>{let e=[];for(let a=0;a<t.length;a++){let i=t.charCodeAt(a);i<=255&&e.push(i)}return e},e=t=>"["+t.map((t=>a(t))).join(", ")+"]",a=(t,e=2)=>{let a=t.toString(16).toUpperCase();return a.startsWith("-")?"-0x"+a.substring(1).padStart(e,"0"):"0x"+a.padStart(e,"0")},i=t=>new Promise((e=>setTimeout(e,t))),s={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),o=33382,l=50,h=12882,d=12883,f=12994,_=12995,c=12998,u=12914,w=12928,g={4293968129:{name:"ESP8266",family:o},15736195:{name:"ESP32",family:l},1990:{name:"ESP32-S2",family:h},9:{name:"ESP32-S3",family:d},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},203546735:{name:"ESP32-C2",family:f},1763790959:{name:"ESP32-C3",family:_},456216687:{name:"ESP32-C3",family:_},1216438383:{name:"ESP32-C3",family:_},1130455151:{name:"ESP32-C3",family:_},3619110528:{name:"ESP32-H2",family:u},752910447:{name:"ESP32-C6",family:c},182303440:{name:"ESP32-P4",family:w},117676761:{name:"ESP32-P4",family:w},0:{name:"ESP32-P4",family:w}},m=3e3,p=6e5,b=(t,e)=>{let a=Math.floor(t*(e/486));return a<m?m:a},y=t=>{switch(t){case l:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case h:return{regBase:1061167104,baseFuse:1061265408,macFuse:1061265476,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612856,flashOffs:4096};case d:return{regBase:1610620928,usrOffs:24,baseFuse:1610641408,macFuse:1610641476,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612864,flashOffs:0};case o:return{regBase:1610613248,usrOffs:28,baseFuse:1072693328,macFuse:1072693328,usr1Offs:32,usr2Offs:36,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:64,uartDateReg:1610612856,flashOffs:0};case f:case _:return{regBase:1610620928,baseFuse:1610647552,macFuse:1610647620,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case c:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case u:return{regBase:1610620928,baseFuse:1610719232,macFuse:1610719300,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case w:return{regBase:1342754816,baseFuse:1343410176,macFuse:1343410244,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1343004812,flashOffs:8192};default:return{regBase:-1,baseFuse:-1,macFuse:-1,usrOffs:-1,usr1Offs:-1,usr2Offs:-1,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:-1,uartDateReg:-1,flashOffs:-1}}};class k extends Error{constructor(t){super(t),this.name="SlipReadError"}}const v=async e=>{let a;return e==l?a=await import("./esp32-BLbsWvxO.js"):e==h?a=await import("./esp32s2-CrsP1231.js"):e==d?a=await import("./esp32s3-CiJyd6Fk.js"):e==o?a=await import("./esp8266-CQFcqJ_a.js"):e==f?a=await import("./esp32c2-wLQhZItC.js"):e==_?a=await import("./esp32c3-DmSvHQKL.js"):e==c?a=await import("./esp32c6-ZuxjUVr4.js"):e==u?a=await import("./esp32h2-CZ4EIL3w.js"):e==w&&(a=await import("./esp32p4-Drc2t__U.js")),{...a,text:t(atob(a.text)),data:t(atob(a.data))}};function x(t){let e=t.length;for(;--e>=0;)t[e]=0}const z=256,S=286,R=30,E=15,D=new Uint8Array([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]),U=new Uint8Array([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]),A=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),O=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),I=new Array(576);x(I);const F=new Array(60);x(F);const B=new Array(512);x(B);const T=new Array(256);x(T);const C=new Array(29);x(C);const Z=new Array(R);function L(t,e,a,i,s){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=i,this.max_length=s,this.has_stree=t&&t.length}let P,M,N;function H(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}x(Z);const $=t=>t<256?B[t]:B[256+(t>>>7)],j=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},V=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,j(t,t.bi_buf),t.bi_buf=e>>16-t.bi_valid,t.bi_valid+=a-16):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=a)},W=(t,e,a)=>{V(t,a[2*e],a[2*e+1])},K=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Y=(t,e,a)=>{const i=new Array(16);let s,r,n=0;for(s=1;s<=E;s++)n=n+a[s-1]<<1,i[s]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=K(i[e]++,e))}},q=t=>{let e;for(e=0;e<S;e++)t.dyn_ltree[2*e]=0;for(e=0;e<R;e++)t.dyn_dtree[2*e]=0;for(e=0;e<19;e++)t.bl_tree[2*e]=0;t.dyn_ltree[512]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},G=t=>{t.bi_valid>8?j(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},X=(t,e,a,i)=>{const s=2*e,r=2*a;return t[s]<t[r]||t[s]===t[r]&&i[e]<=i[a]},Q=(t,e,a)=>{const i=t.heap[a];let s=a<<1;for(;s<=t.heap_len&&(s<t.heap_len&&X(e,t.heap[s+1],t.heap[s],t.depth)&&s++,!X(e,i,t.heap[s],t.depth));)t.heap[a]=t.heap[s],a=s,s<<=1;t.heap[a]=i},J=(t,e,a)=>{let i,s,r,n,o=0;if(0!==t.sym_next)do{i=255&t.pending_buf[t.sym_buf+o++],i+=(255&t.pending_buf[t.sym_buf+o++])<<8,s=t.pending_buf[t.sym_buf+o++],0===i?W(t,s,e):(r=T[s],W(t,r+z+1,e),n=D[r],0!==n&&(s-=C[r],V(t,s,n)),i--,r=$(i),W(t,r,a),n=U[r],0!==n&&(i-=Z[r],V(t,i,n)))}while(o<t.sym_next);W(t,256,e)},tt=(t,e)=>{const a=e.dyn_tree,i=e.stat_desc.static_tree,s=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,o,l,h=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=h=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=h<2?++h:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,s&&(t.static_len-=i[2*l+1]);for(e.max_code=h,n=t.heap_len>>1;n>=1;n--)Q(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],Q(t,a,1),o=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=o,a[2*l]=a[2*n]+a[2*o],t.depth[l]=(t.depth[n]>=t.depth[o]?t.depth[n]:t.depth[o])+1,a[2*n+1]=a[2*o+1]=l,t.heap[1]=l++,Q(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,i=e.max_code,s=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,o=e.stat_desc.extra_base,l=e.stat_desc.max_length;let h,d,f,_,c,u,w=0;for(_=0;_<=E;_++)t.bl_count[_]=0;for(a[2*t.heap[t.heap_max]+1]=0,h=t.heap_max+1;h<573;h++)d=t.heap[h],_=a[2*a[2*d+1]+1]+1,_>l&&(_=l,w++),a[2*d+1]=_,d>i||(t.bl_count[_]++,c=0,d>=o&&(c=n[d-o]),u=a[2*d],t.opt_len+=u*(_+c),r&&(t.static_len+=u*(s[2*d+1]+c)));if(0!==w){do{for(_=l-1;0===t.bl_count[_];)_--;t.bl_count[_]--,t.bl_count[_+1]+=2,t.bl_count[l]--,w-=2}while(w>0);for(_=l;0!==_;_--)for(d=t.bl_count[_];0!==d;)f=t.heap[--h],f>i||(a[2*f+1]!==_&&(t.opt_len+=(_-a[2*f+1])*a[2*f],a[2*f+1]=_),d--)}})(t,e),Y(a,h,t.bl_count)},et=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),e[2*(a+1)+1]=65535,i=0;i<=a;i++)s=n,n=e[2*(i+1)+1],++o<l&&s===n||(o<h?t.bl_tree[2*s]+=o:0!==s?(s!==r&&t.bl_tree[2*s]++,t.bl_tree[32]++):o<=10?t.bl_tree[34]++:t.bl_tree[36]++,o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4))},at=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),i=0;i<=a;i++)if(s=n,n=e[2*(i+1)+1],!(++o<l&&s===n)){if(o<h)do{W(t,s,t.bl_tree)}while(0!=--o);else 0!==s?(s!==r&&(W(t,s,t.bl_tree),o--),W(t,16,t.bl_tree),V(t,o-3,2)):o<=10?(W(t,17,t.bl_tree),V(t,o-3,3)):(W(t,18,t.bl_tree),V(t,o-11,7));o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4)}};let it=!1;const st=(t,e,a,i)=>{V(t,0+(i?1:0),3),G(t),j(t,a),j(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var rt=(t,e,a,i)=>{let s,r,n=0;t.level>0?(2===t.strm.data_type&&(t.strm.data_type=(t=>{let e,a=4093624447;for(e=0;e<=31;e++,a>>>=1)if(1&a&&0!==t.dyn_ltree[2*e])return 0;if(0!==t.dyn_ltree[18]||0!==t.dyn_ltree[20]||0!==t.dyn_ltree[26])return 1;for(e=32;e<z;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),tt(t,t.l_desc),tt(t,t.d_desc),n=(t=>{let e;for(et(t,t.dyn_ltree,t.l_desc.max_code),et(t,t.dyn_dtree,t.d_desc.max_code),tt(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*O[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),s=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=s&&(s=r)):s=r=a+5,a+4<=s&&-1!==e?st(t,e,a,i):4===t.strategy||r===s?(V(t,2+(i?1:0),3),J(t,I,F)):(V(t,4+(i?1:0),3),((t,e,a,i)=>{let s;for(V(t,e-257,5),V(t,a-1,5),V(t,i-4,4),s=0;s<i;s++)V(t,t.bl_tree[2*O[s]+1],3);at(t,t.dyn_ltree,e-1),at(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),J(t,t.dyn_ltree,t.dyn_dtree)),q(t),i&&G(t)},nt={_tr_init:t=>{it||((()=>{let t,e,a,i,s;const r=new Array(16);for(a=0,i=0;i<28;i++)for(C[i]=a,t=0;t<1<<D[i];t++)T[a++]=i;for(T[a-1]=i,s=0,i=0;i<16;i++)for(Z[i]=s,t=0;t<1<<U[i];t++)B[s++]=i;for(s>>=7;i<R;i++)for(Z[i]=s<<7,t=0;t<1<<U[i]-7;t++)B[256+s++]=i;for(e=0;e<=E;e++)r[e]=0;for(t=0;t<=143;)I[2*t+1]=8,t++,r[8]++;for(;t<=255;)I[2*t+1]=9,t++,r[9]++;for(;t<=279;)I[2*t+1]=7,t++,r[7]++;for(;t<=287;)I[2*t+1]=8,t++,r[8]++;for(Y(I,287,r),t=0;t<R;t++)F[2*t+1]=5,F[2*t]=K(t,5);P=new L(I,D,257,S,E),M=new L(F,U,0,R,E),N=new L(new Array(0),A,0,19,7)})(),it=!0),t.l_desc=new H(t.dyn_ltree,P),t.d_desc=new H(t.dyn_dtree,M),t.bl_desc=new H(t.bl_tree,N),t.bi_buf=0,t.bi_valid=0,q(t)},_tr_stored_block:st,_tr_flush_block:rt,_tr_tally:(t,e,a)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=a,0===e?t.dyn_ltree[2*a]++:(t.matches++,e--,t.dyn_ltree[2*(T[a]+z+1)]++,t.dyn_dtree[2*$(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{V(t,2,3),W(t,256,I),(t=>{16===t.bi_valid?(j(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=255&t.bi_buf,t.bi_buf>>=8,t.bi_valid-=8)})(t)}};var ot=(t,e,a,i)=>{let s=65535&t,r=t>>>16&65535,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{s=s+e[i++]|0,r=r+s|0}while(--n);s%=65521,r%=65521}return s|r<<16};const lt=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var i=0;i<8;i++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ht=(t,e,a,i)=>{const s=lt,r=i+a;t^=-1;for(let a=i;a<r;a++)t=t>>>8^s[255&(t^e[a])];return~t},dt={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"},ft={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,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_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,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:_t,_tr_stored_block:ct,_tr_flush_block:ut,_tr_tally:wt,_tr_align:gt}=nt,{Z_NO_FLUSH:mt,Z_PARTIAL_FLUSH:pt,Z_FULL_FLUSH:bt,Z_FINISH:yt,Z_BLOCK:kt,Z_OK:vt,Z_STREAM_END:xt,Z_STREAM_ERROR:zt,Z_DATA_ERROR:St,Z_BUF_ERROR:Rt,Z_DEFAULT_COMPRESSION:Et,Z_FILTERED:Dt,Z_HUFFMAN_ONLY:Ut,Z_RLE:At,Z_FIXED:Ot,Z_DEFAULT_STRATEGY:It,Z_UNKNOWN:Ft,Z_DEFLATED:Bt}=ft,Tt=258,Ct=262,Zt=42,Lt=113,Pt=666,Mt=(t,e)=>(t.msg=dt[e],e),Nt=t=>2*t-(t>4?9:0),Ht=t=>{let e=t.length;for(;--e>=0;)t[e]=0},$t=t=>{let e,a,i,s=t.w_size;e=t.hash_size,i=e;do{a=t.head[--i],t.head[i]=a>=s?a-s:0}while(--e);e=s,i=e;do{a=t.prev[--i],t.prev[i]=a>=s?a-s:0}while(--e)};let jt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Vt=t=>{const e=t.state;let a=e.pending;a>t.avail_out&&(a=t.avail_out),0!==a&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+a),t.next_out),t.next_out+=a,e.pending_out+=a,t.total_out+=a,t.avail_out-=a,e.pending-=a,0===e.pending&&(e.pending_out=0))},Wt=(t,e)=>{ut(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Vt(t.strm)},Kt=(t,e)=>{t.pending_buf[t.pending++]=e},Yt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},qt=(t,e,a,i)=>{let s=t.avail_in;return s>i&&(s=i),0===s?0:(t.avail_in-=s,e.set(t.input.subarray(t.next_in,t.next_in+s),a),1===t.state.wrap?t.adler=ot(t.adler,e,s,a):2===t.state.wrap&&(t.adler=ht(t.adler,e,s,a)),t.next_in+=s,t.total_in+=s,s)},Gt=(t,e)=>{let a,i,s=t.max_chain_length,r=t.strstart,n=t.prev_length,o=t.nice_match;const l=t.strstart>t.w_size-Ct?t.strstart-(t.w_size-Ct):0,h=t.window,d=t.w_mask,f=t.prev,_=t.strstart+Tt;let c=h[r+n-1],u=h[r+n];t.prev_length>=t.good_match&&(s>>=2),o>t.lookahead&&(o=t.lookahead);do{if(a=e,h[a+n]===u&&h[a+n-1]===c&&h[a]===h[r]&&h[++a]===h[r+1]){r+=2,a++;do{}while(h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&r<_);if(i=Tt-(_-r),r=_-Tt,i>n){if(t.match_start=e,n=i,i>=o)break;c=h[r+n-1],u=h[r+n]}}}while((e=f[e&d])>l&&0!=--s);return n<=t.lookahead?n:t.lookahead},Xt=t=>{const e=t.w_size;let a,i,s;do{if(i=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-Ct)&&(t.window.set(t.window.subarray(e,e+e-i),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),$t(t),i+=e),0===t.strm.avail_in)break;if(a=qt(t.strm,t.window,t.strstart+t.lookahead,i),t.lookahead+=a,t.lookahead+t.insert>=3)for(s=t.strstart-t.insert,t.ins_h=t.window[s],t.ins_h=jt(t,t.ins_h,t.window[s+1]);t.insert&&(t.ins_h=jt(t,t.ins_h,t.window[s+3-1]),t.prev[s&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=s,s++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<Ct&&0!==t.strm.avail_in)},Qt=(t,e)=>{let a,i,s,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,o=t.strm.avail_in;do{if(a=65535,s=t.bi_valid+42>>3,t.strm.avail_out<s)break;if(s=t.strm.avail_out-s,i=t.strstart-t.block_start,a>i+t.strm.avail_in&&(a=i+t.strm.avail_in),a>s&&(a=s),a<r&&(0===a&&e!==yt||e===mt||a!==i+t.strm.avail_in))break;n=e===yt&&a===i+t.strm.avail_in?1:0,ct(t,0,0,n),t.pending_buf[t.pending-4]=a,t.pending_buf[t.pending-3]=a>>8,t.pending_buf[t.pending-2]=~a,t.pending_buf[t.pending-1]=~a>>8,Vt(t.strm),i&&(i>a&&(i=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,a-=i),a&&(qt(t.strm,t.strm.output,t.strm.next_out,a),t.strm.next_out+=a,t.strm.avail_out-=a,t.strm.total_out+=a)}while(0===n);return o-=t.strm.avail_in,o&&(o>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=o&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-o,t.strm.next_in),t.strstart),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==mt&&e!==yt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(s=t.window_size-t.strstart,t.strm.avail_in>s&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,s+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),s>t.strm.avail_in&&(s=t.strm.avail_in),s&&(qt(t.strm,t.window,t.strstart,s),t.strstart+=s,t.insert+=s>t.w_size-t.insert?t.w_size-t.insert:s),t.high_water<t.strstart&&(t.high_water=t.strstart),s=t.bi_valid+42>>3,s=t.pending_buf_size-s>65535?65535:t.pending_buf_size-s,r=s>t.w_size?t.w_size:s,i=t.strstart-t.block_start,(i>=r||(i||e===yt)&&e!==mt&&0===t.strm.avail_in&&i<=s)&&(a=i>s?s:i,n=e===yt&&0===t.strm.avail_in&&a===i?1:0,ct(t,t.block_start,a,n),t.block_start+=a,Vt(t.strm)),n?3:1)},Jt=(t,e)=>{let a,i;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),0!==a&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a)),t.match_length>=3)if(i=wt(t,t.strstart-t.match_start,t.match_length-3),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=3){t.match_length--;do{t.strstart++,t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart}while(0!=--t.match_length);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=jt(t,t.ins_h,t.window[t.strstart+1]);else i=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(i&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2},te=(t,e)=>{let a,i,s;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=2,0!==a&&t.prev_length<t.max_lazy_match&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a),t.match_length<=5&&(t.strategy===Dt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){s=t.strstart+t.lookahead-3,i=wt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=s&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart)}while(0!=--t.prev_length);if(t.match_available=0,t.match_length=2,t.strstart++,i&&(Wt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(i=wt(t,0,t.window[t.strstart-1]),i&&Wt(t,!1),t.strstart++,t.lookahead--,0===t.strm.avail_out)return 1}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(i=wt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2};function ee(t,e,a,i,s){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=i,this.func=s}const ae=[new ee(0,0,0,0,Qt),new ee(4,4,8,4,Jt),new ee(4,5,16,8,Jt),new ee(4,6,32,32,Jt),new ee(4,4,16,16,te),new ee(8,16,32,32,te),new ee(8,16,128,128,te),new ee(8,32,128,256,te),new ee(32,128,258,1024,te),new ee(32,258,258,4096,te)];function ie(){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=Bt,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 Uint16Array(1146),this.dyn_dtree=new Uint16Array(122),this.bl_tree=new Uint16Array(78),Ht(this.dyn_ltree),Ht(this.dyn_dtree),Ht(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(16),this.heap=new Uint16Array(573),Ht(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Ht(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}const se=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Zt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Lt&&e.status!==Pt?1:0},re=t=>{if(se(t))return Mt(t,zt);t.total_in=t.total_out=0,t.data_type=Ft;const e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=2===e.wrap?57:e.wrap?Zt:Lt,t.adler=2===e.wrap?0:1,e.last_flush=-2,_t(e),vt},ne=t=>{const e=re(t);var a;return e===vt&&((a=t.state).window_size=2*a.w_size,Ht(a.head),a.max_lazy_match=ae[a.level].max_lazy,a.good_match=ae[a.level].good_length,a.nice_match=ae[a.level].nice_length,a.max_chain_length=ae[a.level].max_chain,a.strstart=0,a.block_start=0,a.lookahead=0,a.insert=0,a.match_length=a.prev_length=2,a.match_available=0,a.ins_h=0),e},oe=(t,e,a,i,s,r)=>{if(!t)return zt;let n=1;if(e===Et&&(e=6),i<0?(n=0,i=-i):i>15&&(n=2,i-=16),s<1||s>9||a!==Bt||i<8||i>15||e<0||e>9||r<0||r>Ot||8===i&&1!==n)return Mt(t,zt);8===i&&(i=9);const o=new ie;return t.state=o,o.strm=t,o.status=Zt,o.wrap=n,o.gzhead=null,o.w_bits=i,o.w_size=1<<o.w_bits,o.w_mask=o.w_size-1,o.hash_bits=s+7,o.hash_size=1<<o.hash_bits,o.hash_mask=o.hash_size-1,o.hash_shift=~~((o.hash_bits+3-1)/3),o.window=new Uint8Array(2*o.w_size),o.head=new Uint16Array(o.hash_size),o.prev=new Uint16Array(o.w_size),o.lit_bufsize=1<<s+6,o.pending_buf_size=4*o.lit_bufsize,o.pending_buf=new Uint8Array(o.pending_buf_size),o.sym_buf=o.lit_bufsize,o.sym_end=3*(o.lit_bufsize-1),o.level=e,o.strategy=r,o.method=a,ne(t)};var le={deflateInit:(t,e)=>oe(t,e,Bt,15,8,It),deflateInit2:oe,deflateReset:ne,deflateResetKeep:re,deflateSetHeader:(t,e)=>se(t)||2!==t.state.wrap?zt:(t.state.gzhead=e,vt),deflate:(t,e)=>{if(se(t)||e>kt||e<0)return t?Mt(t,zt):zt;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Pt&&e!==yt)return Mt(t,0===t.avail_out?Rt:zt);const i=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Vt(t),0===t.avail_out)return a.last_flush=-1,vt}else if(0===t.avail_in&&Nt(e)<=Nt(i)&&e!==yt)return Mt(t,Rt);if(a.status===Pt&&0!==t.avail_in)return Mt(t,Rt);if(a.status===Zt&&0===a.wrap&&(a.status=Lt),a.status===Zt){let e=Bt+(a.w_bits-8<<4)<<8,i=-1;if(i=a.strategy>=Ut||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=i<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Yt(a,e),0!==a.strstart&&(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),t.adler=1,a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(57===a.status)if(t.adler=0,Kt(a,31),Kt(a,139),Kt(a,8),a.gzhead)Kt(a,(a.gzhead.text?1:0)+(a.gzhead.hcrc?2:0)+(a.gzhead.extra?4:0)+(a.gzhead.name?8:0)+(a.gzhead.comment?16:0)),Kt(a,255&a.gzhead.time),Kt(a,a.gzhead.time>>8&255),Kt(a,a.gzhead.time>>16&255),Kt(a,a.gzhead.time>>24&255),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Kt(a,255&a.gzhead.extra.length),Kt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ht(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,3),a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt;if(69===a.status){if(a.gzhead.extra){let e=a.pending,i=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+i>a.pending_buf_size;){let s=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=s,Vt(t),0!==a.pending)return a.last_flush=-1,vt;e=0,i-=s}let s=new Uint8Array(a.gzhead.extra);a.pending_buf.set(s.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending+=i,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex=0}a.status=73}if(73===a.status){if(a.gzhead.name){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Vt(t),0!==a.pending))return a.last_flush=-1,vt;Kt(a,255&t.adler),Kt(a,t.adler>>8&255),t.adler=0}if(a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(0!==t.avail_in||0!==a.lookahead||e!==mt&&a.status!==Pt){let i=0===a.level?Qt(a,e):a.strategy===Ut?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(Xt(t),0===t.lookahead)){if(e===mt)return 1;break}if(t.match_length=0,a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===At?((t,e)=>{let a,i,s,r;const n=t.window;for(;;){if(t.lookahead<=Tt){if(Xt(t),t.lookahead<=Tt&&e===mt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(s=t.strstart-1,i=n[s],i===n[++s]&&i===n[++s]&&i===n[++s])){r=t.strstart+Tt;do{}while(i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&s<r);t.match_length=Tt-(r-s),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=wt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ae[a.level].func(a,e);if(3!==i&&4!==i||(a.status=Pt),1===i||3===i)return 0===t.avail_out&&(a.last_flush=-1),vt;if(2===i&&(e===pt?gt(a):e!==kt&&(ct(a,0,0,!1),e===bt&&(Ht(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Vt(t),0===t.avail_out))return a.last_flush=-1,vt}return e!==yt?vt:a.wrap<=0?xt:(2===a.wrap?(Kt(a,255&t.adler),Kt(a,t.adler>>8&255),Kt(a,t.adler>>16&255),Kt(a,t.adler>>24&255),Kt(a,255&t.total_in),Kt(a,t.total_in>>8&255),Kt(a,t.total_in>>16&255),Kt(a,t.total_in>>24&255)):(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),Vt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?vt:xt)},deflateEnd:t=>{if(se(t))return zt;const e=t.state.status;return t.state=null,e===Lt?Mt(t,St):vt},deflateSetDictionary:(t,e)=>{let a=e.length;if(se(t))return zt;const i=t.state,s=i.wrap;if(2===s||1===s&&i.status!==Zt||i.lookahead)return zt;if(1===s&&(t.adler=ot(t.adler,e,a,0)),i.wrap=0,a>=i.w_size){0===s&&(Ht(i.head),i.strstart=0,i.block_start=0,i.insert=0);let t=new Uint8Array(i.w_size);t.set(e.subarray(a-i.w_size,a),0),e=t,a=i.w_size}const r=t.avail_in,n=t.next_in,o=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,Xt(i);i.lookahead>=3;){let t=i.strstart,e=i.lookahead-2;do{i.ins_h=jt(i,i.ins_h,i.window[t+3-1]),i.prev[t&i.w_mask]=i.head[i.ins_h],i.head[i.ins_h]=t,t++}while(--e);i.strstart=t,i.lookahead=2,Xt(i)}return i.strstart+=i.lookahead,i.block_start=i.strstart,i.insert=i.lookahead,i.lookahead=0,i.match_length=i.prev_length=2,i.match_available=0,t.next_in=n,t.input=o,t.avail_in=r,i.wrap=s,vt},deflateInfo:"pako deflate (from Nodeca project)"};const he=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var de=function(t){const e=Array.prototype.slice.call(arguments,1);for(;e.length;){const a=e.shift();if(a){if("object"!=typeof a)throw new TypeError(a+"must be non-object");for(const e in a)he(a,e)&&(t[e]=a[e])}}return t},fe=t=>{let e=0;for(let a=0,i=t.length;a<i;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,i=0,s=t.length;e<s;e++){let s=t[e];a.set(s,i),i+=s.length}return a};let _e=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){_e=!1}const ce=new Uint8Array(256);for(let t=0;t<256;t++)ce[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;ce[254]=ce[254]=1;var ue=t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,i,s,r,n=t.length,o=0;for(s=0;s<n;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),o+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(o),r=0,s=0;r<o;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),a<128?e[r++]=a:a<2048?(e[r++]=192|a>>>6,e[r++]=128|63&a):a<65536?(e[r++]=224|a>>>12,e[r++]=128|a>>>6&63,e[r++]=128|63&a):(e[r++]=240|a>>>18,e[r++]=128|a>>>12&63,e[r++]=128|a>>>6&63,e[r++]=128|63&a);return e},we=(t,e)=>{const a=e||t.length;if("function"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(t.subarray(0,e));let i,s;const r=new Array(2*a);for(s=0,i=0;i<a;){let e=t[i++];if(e<128){r[s++]=e;continue}let n=ce[e];if(n>4)r[s++]=65533,i+=n-1;else{for(e&=2===n?31:3===n?15:7;n>1&&i<a;)e=e<<6|63&t[i++],n--;n>1?r[s++]=65533:e<65536?r[s++]=e:(e-=65536,r[s++]=55296|e>>10&1023,r[s++]=56320|1023&e)}}return((t,e)=>{if(e<65534&&t.subarray&&_e)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let a="";for(let i=0;i<e;i++)a+=String.fromCharCode(t[i]);return a})(r,s)},ge=(t,e)=>{(e=e||t.length)>t.length&&(e=t.length);let a=e-1;for(;a>=0&&128==(192&t[a]);)a--;return a<0||0===a?e:a+ce[t[a]]>e?a:e};var me=function(){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};const pe=Object.prototype.toString,{Z_NO_FLUSH:be,Z_SYNC_FLUSH:ye,Z_FULL_FLUSH:ke,Z_FINISH:ve,Z_OK:xe,Z_STREAM_END:ze,Z_DEFAULT_COMPRESSION:Se,Z_DEFAULT_STRATEGY:Re,Z_DEFLATED:Ee}=ft;function De(t){this.options=de({level:Se,method:Ee,chunkSize:16384,windowBits:15,memLevel:8,strategy:Re},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new me,this.strm.avail_out=0;let a=le.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==xe)throw new Error(dt[a]);if(e.header&&le.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?ue(e.dictionary):"[object ArrayBuffer]"===pe.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=le.deflateSetDictionary(this.strm,t),a!==xe)throw new Error(dt[a]);this._dict_set=!0}}function Ue(t,e){const a=new De(e);if(a.push(t,!0),a.err)throw a.msg||dt[a.err];return a.result}De.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize;let s,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?ve:be,"string"==typeof t?a.input=ue(t):"[object ArrayBuffer]"===pe.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;)if(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),(r===ye||r===ke)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(s=le.deflate(a,r),s===ze)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),s=le.deflateEnd(this.strm),this.onEnd(s),this.ended=!0,s===xe;if(0!==a.avail_out){if(r>0&&a.next_out>0)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else if(0===a.avail_in)break}else this.onData(a.output)}return!0},De.prototype.onData=function(t){this.chunks.push(t)},De.prototype.onEnd=function(t){t===xe&&(this.result=fe(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Ae={Deflate:De,deflate:Ue,deflateRaw:function(t,e){return(e=e||{}).raw=!0,Ue(t,e)},gzip:function(t,e){return(e=e||{}).gzip=!0,Ue(t,e)},constants:ft};const Oe=16209;var Ie=function(t,e){let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z,S;const R=t.state;a=t.next_in,z=t.input,i=a+(t.avail_in-5),s=t.next_out,S=t.output,r=s-(e-t.avail_out),n=s+(t.avail_out-257),o=R.dmax,l=R.wsize,h=R.whave,d=R.wnext,f=R.window,_=R.hold,c=R.bits,u=R.lencode,w=R.distcode,g=(1<<R.lenbits)-1,m=(1<<R.distbits)-1;t:do{c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=u[_&g];e:for(;;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,0===b)S[s++]=65535&p;else{if(!(16&b)){if(64&b){if(32&b){R.mode=16191;break t}t.msg="invalid literal/length code",R.mode=Oe;break t}p=u[(65535&p)+(_&(1<<b)-1)];continue e}for(y=65535&p,b&=15,b&&(c<b&&(_+=z[a++]<<c,c+=8),y+=_&(1<<b)-1,_>>>=b,c-=b),c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=w[_&m];;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,16&b){if(k=65535&p,b&=15,c<b&&(_+=z[a++]<<c,c+=8,c<b&&(_+=z[a++]<<c,c+=8)),k+=_&(1<<b)-1,k>o){t.msg="invalid distance too far back",R.mode=Oe;break t}if(_>>>=b,c-=b,b=s-r,k>b){if(b=k-b,b>h&&R.sane){t.msg="invalid distance too far back",R.mode=Oe;break t}if(v=0,x=f,0===d){if(v+=l-b,b<y){y-=b;do{S[s++]=f[v++]}while(--b);v=s-k,x=S}}else if(d<b){if(v+=l+d-b,b-=d,b<y){y-=b;do{S[s++]=f[v++]}while(--b);if(v=0,d<y){b=d,y-=b;do{S[s++]=f[v++]}while(--b);v=s-k,x=S}}}else if(v+=d-b,b<y){y-=b;do{S[s++]=f[v++]}while(--b);v=s-k,x=S}for(;y>2;)S[s++]=x[v++],S[s++]=x[v++],S[s++]=x[v++],y-=3;y&&(S[s++]=x[v++],y>1&&(S[s++]=x[v++]))}else{v=s-k;do{S[s++]=S[v++],S[s++]=S[v++],S[s++]=S[v++],y-=3}while(y>2);y&&(S[s++]=S[v++],y>1&&(S[s++]=S[v++]))}break}if(64&b){t.msg="invalid distance code",R.mode=Oe;break t}p=w[(65535&p)+(_&(1<<b)-1)]}}break}}while(a<i&&s<n);y=c>>3,a-=y,c-=y<<3,_&=(1<<c)-1,t.next_in=a,t.next_out=s,t.avail_in=a<i?i-a+5:5-(a-i),t.avail_out=s<n?n-s+257:257-(s-n),R.hold=_,R.bits=c};const Fe=15,Be=new Uint16Array([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]),Te=new Uint8Array([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]),Ce=new Uint16Array([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]),Ze=new Uint8Array([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]);var Le=(t,e,a,i,s,r,n,o)=>{const l=o.bits;let h,d,f,_,c,u,w=0,g=0,m=0,p=0,b=0,y=0,k=0,v=0,x=0,z=0,S=null;const R=new Uint16Array(16),E=new Uint16Array(16);let D,U,A,O=null;for(w=0;w<=Fe;w++)R[w]=0;for(g=0;g<i;g++)R[e[a+g]]++;for(b=l,p=Fe;p>=1&&0===R[p];p--);if(b>p&&(b=p),0===p)return s[r++]=20971520,s[r++]=20971520,o.bits=1,0;for(m=1;m<p&&0===R[m];m++);for(b<m&&(b=m),v=1,w=1;w<=Fe;w++)if(v<<=1,v-=R[w],v<0)return-1;if(v>0&&(0===t||1!==p))return-1;for(E[1]=0,w=1;w<Fe;w++)E[w+1]=E[w]+R[w];for(g=0;g<i;g++)0!==e[a+g]&&(n[E[e[a+g]]++]=g);if(0===t?(S=O=n,u=20):1===t?(S=Be,O=Te,u=257):(S=Ce,O=Ze,u=0),z=0,g=0,w=m,c=r,y=b,k=0,f=-1,x=1<<b,_=x-1,1===t&&x>852||2===t&&x>592)return 1;for(;;){D=w-k,n[g]+1<u?(U=0,A=n[g]):n[g]>=u?(U=O[n[g]-u],A=S[n[g]-u]):(U=96,A=0),h=1<<w-k,d=1<<y,m=d;do{d-=h,s[c+(z>>k)+d]=D<<24|U<<16|A}while(0!==d);for(h=1<<w-1;z&h;)h>>=1;if(0!==h?(z&=h-1,z+=h):z=0,g++,0==--R[w]){if(w===p)break;w=e[a+n[g]]}if(w>b&&(z&_)!==f){for(0===k&&(k=b),c+=m,y=w-k,v=1<<y;y+k<p&&(v-=R[y+k],!(v<=0));)y++,v<<=1;if(x+=1<<y,1===t&&x>852||2===t&&x>592)return 1;f=z&_,s[f]=b<<24|y<<16|c-r}}return 0!==z&&(s[c+z]=w-k<<24|64<<16),o.bits=b,0};const{Z_FINISH:Pe,Z_BLOCK:Me,Z_TREES:Ne,Z_OK:He,Z_STREAM_END:$e,Z_NEED_DICT:je,Z_STREAM_ERROR:Ve,Z_DATA_ERROR:We,Z_MEM_ERROR:Ke,Z_BUF_ERROR:Ye,Z_DEFLATED:qe}=ft,Ge=16180,Xe=16190,Qe=16191,Je=16192,ta=16194,ea=16199,aa=16200,ia=16206,sa=16209,ra=t=>(t>>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24);function na(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}const oa=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.mode<Ge||e.mode>16211?1:0},la=t=>{if(oa(t))return Ve;const e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=1&e.wrap),e.mode=Ge,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(852),e.distcode=e.distdyn=new Int32Array(592),e.sane=1,e.back=-1,He},ha=t=>{if(oa(t))return Ve;const e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,la(t)},da=(t,e)=>{let a;if(oa(t))return Ve;const i=t.state;return e<0?(a=0,e=-e):(a=5+(e>>4),e<48&&(e&=15)),e&&(e<8||e>15)?Ve:(null!==i.window&&i.wbits!==e&&(i.window=null),i.wrap=a,i.wbits=e,ha(t))},fa=(t,e)=>{if(!t)return Ve;const a=new na;t.state=a,a.strm=t,a.window=null,a.mode=Ge;const i=da(t,e);return i!==He&&(t.state=null),i};let _a,ca,ua=!0;const wa=t=>{if(ua){_a=new Int32Array(512),ca=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(Le(1,t.lens,0,288,_a,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;Le(2,t.lens,0,32,ca,0,t.work,{bits:5}),ua=!1}t.lencode=_a,t.lenbits=9,t.distcode=ca,t.distbits=5},ga=(t,e,a,i)=>{let s;const r=t.state;return null===r.window&&(r.wsize=1<<r.wbits,r.wnext=0,r.whave=0,r.window=new Uint8Array(r.wsize)),i>=r.wsize?(r.window.set(e.subarray(a-r.wsize,a),0),r.wnext=0,r.whave=r.wsize):(s=r.wsize-r.wnext,s>i&&(s=i),r.window.set(e.subarray(a-i,a-i+s),r.wnext),(i-=s)?(r.window.set(e.subarray(a-i,a),0),r.wnext=i,r.whave=r.wsize):(r.wnext+=s,r.wnext===r.wsize&&(r.wnext=0),r.whave<r.wsize&&(r.whave+=s))),0};var ma={inflateReset:ha,inflateReset2:da,inflateResetKeep:la,inflateInit:t=>fa(t,15),inflateInit2:fa,inflate:(t,e)=>{let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z=0;const S=new Uint8Array(4);let R,E;const D=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(oa(t)||!t.output||!t.input&&0!==t.avail_in)return Ve;a=t.state,a.mode===Qe&&(a.mode=Je),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,f=o,_=l,x=He;t:for(;;)switch(a.mode){case Ge:if(0===a.wrap){a.mode=Je;break}for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(2&a.wrap&&35615===h){0===a.wbits&&(a.wbits=15),a.check=0,S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0),h=0,d=0,a.mode=16181;break}if(a.head&&(a.head.done=!1),!(1&a.wrap)||(((255&h)<<8)+(h>>8))%31){t.msg="incorrect header check",a.mode=sa;break}if((15&h)!==qe){t.msg="unknown compression method",a.mode=sa;break}if(h>>>=4,d-=4,v=8+(15&h),0===a.wbits&&(a.wbits=v),v>15||v>a.wbits){t.msg="invalid window size",a.mode=sa;break}a.dmax=1<<a.wbits,a.flags=0,t.adler=a.check=1,a.mode=512&h?16189:Qe,h=0,d=0;break;case 16181:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.flags=h,(255&a.flags)!==qe){t.msg="unknown compression method",a.mode=sa;break}if(57344&a.flags){t.msg="unknown header flags set",a.mode=sa;break}a.head&&(a.head.text=h>>8&1),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0)),h=0,d=0,a.mode=16182;case 16182:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.time=h),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,S[2]=h>>>16&255,S[3]=h>>>24&255,a.check=ht(a.check,S,4,0)),h=0,d=0,a.mode=16183;case 16183:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.xflags=255&h,a.head.os=h>>8),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0)),h=0,d=0,a.mode=16184;case 16184:if(1024&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length=h,a.head&&(a.head.extra_len=h),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0)),h=0,d=0}else a.head&&(a.head.extra=null);a.mode=16185;case 16185:if(1024&a.flags&&(c=a.length,c>o&&(c=o),c&&(a.head&&(v=a.head.extra_len-a.length,a.head.extra||(a.head.extra=new Uint8Array(a.head.extra_len)),a.head.extra.set(i.subarray(r,r+c),v)),512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,a.length-=c),a.length))break t;a.length=0,a.mode=16186;case 16186:if(2048&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.name+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.name=null);a.length=0,a.mode=16187;case 16187:if(4096&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.comment+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.comment=null);a.mode=16188;case 16188:if(512&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(65535&a.check)){t.msg="header crc mismatch",a.mode=sa;break}h=0,d=0}a.head&&(a.head.hcrc=a.flags>>9&1,a.head.done=!0),t.adler=a.check=0,a.mode=Qe;break;case 16189:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}t.adler=a.check=ra(h),h=0,d=0,a.mode=Xe;case Xe:if(0===a.havedict)return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,je;t.adler=a.check=1,a.mode=Qe;case Qe:if(e===Me||e===Ne)break t;case Je:if(a.last){h>>>=7&d,d-=7&d,a.mode=ia;break}for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}switch(a.last=1&h,h>>>=1,d-=1,3&h){case 0:a.mode=16193;break;case 1:if(wa(a),a.mode=ea,e===Ne){h>>>=2,d-=2;break t}break;case 2:a.mode=16196;break;case 3:t.msg="invalid block type",a.mode=sa}h>>>=2,d-=2;break;case 16193:for(h>>>=7&d,d-=7&d;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if((65535&h)!=(h>>>16^65535)){t.msg="invalid stored block lengths",a.mode=sa;break}if(a.length=65535&h,h=0,d=0,a.mode=ta,e===Ne)break t;case ta:a.mode=16195;case 16195:if(c=a.length,c){if(c>o&&(c=o),c>l&&(c=l),0===c)break t;s.set(i.subarray(r,r+c),n),o-=c,r+=c,l-=c,n+=c,a.length-=c;break}a.mode=Qe;break;case 16196:for(;d<14;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.nlen=257+(31&h),h>>>=5,d-=5,a.ndist=1+(31&h),h>>>=5,d-=5,a.ncode=4+(15&h),h>>>=4,d-=4,a.nlen>286||a.ndist>30){t.msg="too many length or distance symbols",a.mode=sa;break}a.have=0,a.mode=16197;case 16197:for(;a.have<a.ncode;){for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.lens[D[a.have++]]=7&h,h>>>=3,d-=3}for(;a.have<19;)a.lens[D[a.have++]]=0;if(a.lencode=a.lendyn,a.lenbits=7,R={bits:a.lenbits},x=Le(0,a.lens,0,19,a.lencode,0,a.work,R),a.lenbits=R.bits,x){t.msg="invalid code lengths set",a.mode=sa;break}a.have=0,a.mode=16198;case 16198:for(;a.have<a.nlen+a.ndist;){for(;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(p<16)h>>>=g,d-=g,a.lens[a.have++]=p;else{if(16===p){for(E=g+2;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(h>>>=g,d-=g,0===a.have){t.msg="invalid bit length repeat",a.mode=sa;break}v=a.lens[a.have-1],c=3+(3&h),h>>>=2,d-=2}else if(17===p){for(E=g+3;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=3+(7&h),h>>>=3,d-=3}else{for(E=g+7;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=11+(127&h),h>>>=7,d-=7}if(a.have+c>a.nlen+a.ndist){t.msg="invalid bit length repeat",a.mode=sa;break}for(;c--;)a.lens[a.have++]=v}}if(a.mode===sa)break;if(0===a.lens[256]){t.msg="invalid code -- missing end-of-block",a.mode=sa;break}if(a.lenbits=9,R={bits:a.lenbits},x=Le(1,a.lens,0,a.nlen,a.lencode,0,a.work,R),a.lenbits=R.bits,x){t.msg="invalid literal/lengths set",a.mode=sa;break}if(a.distbits=6,a.distcode=a.distdyn,R={bits:a.distbits},x=Le(2,a.lens,a.nlen,a.ndist,a.distcode,0,a.work,R),a.distbits=R.bits,x){t.msg="invalid distances set",a.mode=sa;break}if(a.mode=ea,e===Ne)break t;case ea:a.mode=aa;case aa:if(o>=6&&l>=258){t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,Ie(t,_),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,a.mode===Qe&&(a.back=-1);break}for(a.back=0;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(m&&!(240&m)){for(b=g,y=m,k=p;z=a.lencode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,a.length=p,0===m){a.mode=16205;break}if(32&m){a.back=-1,a.mode=Qe;break}if(64&m){t.msg="invalid literal/length code",a.mode=sa;break}a.extra=15&m,a.mode=16201;case 16201:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}a.was=a.length,a.mode=16202;case 16202:for(;z=a.distcode[h&(1<<a.distbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(!(240&m)){for(b=g,y=m,k=p;z=a.distcode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,64&m){t.msg="invalid distance code",a.mode=sa;break}a.offset=p,a.extra=15&m,a.mode=16203;case 16203:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.offset+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}if(a.offset>a.dmax){t.msg="invalid distance too far back",a.mode=sa;break}a.mode=16204;case 16204:if(0===l)break t;if(c=_-l,a.offset>c){if(c=a.offset-c,c>a.whave&&a.sane){t.msg="invalid distance too far back",a.mode=sa;break}c>a.wnext?(c-=a.wnext,u=a.wsize-c):u=a.wnext-c,c>a.length&&(c=a.length),w=a.window}else w=s,u=n-a.offset,c=a.length;c>l&&(c=l),l-=c,a.length-=c;do{s[n++]=w[u++]}while(--c);0===a.length&&(a.mode=aa);break;case 16205:if(0===l)break t;s[n++]=a.length,l--,a.mode=aa;break;case ia:if(a.wrap){for(;d<32;){if(0===o)break t;o--,h|=i[r++]<<d,d+=8}if(_-=l,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,n-_):ot(a.check,s,_,n-_)),_=l,4&a.wrap&&(a.flags?h:ra(h))!==a.check){t.msg="incorrect data check",a.mode=sa;break}h=0,d=0}a.mode=16207;case 16207:if(a.wrap&&a.flags){for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(4294967295&a.total)){t.msg="incorrect length check",a.mode=sa;break}h=0,d=0}a.mode=16208;case 16208:x=$e;break t;case sa:x=We;break t;case 16210:return Ke;default:return Ve}return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,(a.wsize||_!==t.avail_out&&a.mode<sa&&(a.mode<ia||e!==Pe))&&ga(t,t.output,t.next_out,_-t.avail_out),f-=t.avail_in,_-=t.avail_out,t.total_in+=f,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,t.next_out-_):ot(a.check,s,_,t.next_out-_)),t.data_type=a.bits+(a.last?64:0)+(a.mode===Qe?128:0)+(a.mode===ea||a.mode===ta?256:0),(0===f&&0===_||e===Pe)&&x===He&&(x=Ye),x},inflateEnd:t=>{if(oa(t))return Ve;let e=t.state;return e.window&&(e.window=null),t.state=null,He},inflateGetHeader:(t,e)=>{if(oa(t))return Ve;const a=t.state;return 2&a.wrap?(a.head=e,e.done=!1,He):Ve},inflateSetDictionary:(t,e)=>{const a=e.length;let i,s,r;return oa(t)?Ve:(i=t.state,0!==i.wrap&&i.mode!==Xe?Ve:i.mode===Xe&&(s=1,s=ot(s,e,a,0),s!==i.check)?We:(r=ga(t,e,a,a),r?(i.mode=16210,Ke):(i.havedict=1,He)))},inflateInfo:"pako inflate (from Nodeca project)"};var pa=function(){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=!1};const ba=Object.prototype.toString,{Z_NO_FLUSH:ya,Z_FINISH:ka,Z_OK:va,Z_STREAM_END:xa,Z_NEED_DICT:za,Z_STREAM_ERROR:Sa,Z_DATA_ERROR:Ra,Z_MEM_ERROR:Ea}=ft;function Da(t){this.options=de({chunkSize:65536,windowBits:15,to:""},t||{});const e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&(15&e.windowBits||(e.windowBits|=15)),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new me,this.strm.avail_out=0;let a=ma.inflateInit2(this.strm,e.windowBits);if(a!==va)throw new Error(dt[a]);if(this.header=new pa,ma.inflateGetHeader(this.strm,this.header),e.dictionary&&("string"==typeof e.dictionary?e.dictionary=ue(e.dictionary):"[object ArrayBuffer]"===ba.call(e.dictionary)&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(a=ma.inflateSetDictionary(this.strm,e.dictionary),a!==va)))throw new Error(dt[a])}Da.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize,s=this.options.dictionary;let r,n,o;if(this.ended)return!1;for(n=e===~~e?e:!0===e?ka:ya,"[object ArrayBuffer]"===ba.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;){for(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),r=ma.inflate(a,n),r===za&&s&&(r=ma.inflateSetDictionary(a,s),r===va?r=ma.inflate(a,n):r===Ra&&(r=za));a.avail_in>0&&r===xa&&a.state.wrap>0&&0!==t[a.next_in];)ma.inflateReset(a),r=ma.inflate(a,n);switch(r){case Sa:case Ra:case za:case Ea:return this.onEnd(r),this.ended=!0,!1}if(o=a.avail_out,a.next_out&&(0===a.avail_out||r===xa))if("string"===this.options.to){let t=ge(a.output,a.next_out),e=a.next_out-t,s=we(a.output,t);a.next_out=e,a.avail_out=i-e,e&&a.output.set(a.output.subarray(t,t+e),0),this.onData(s)}else this.onData(a.output.length===a.next_out?a.output:a.output.subarray(0,a.next_out));if(r!==va||0!==o){if(r===xa)return r=ma.inflateEnd(this.strm),this.onEnd(r),this.ended=!0,!0;if(0===a.avail_in)break}}return!0},Da.prototype.onData=function(t){this.chunks.push(t)},Da.prototype.onEnd=function(t){t===va&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=fe(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};const{Deflate:Ua,deflate:Aa,deflateRaw:Oa,gzip:Ia}=Ae;var Fa=Aa;const Ba={b:{u:DataView.prototype.getInt8,p:DataView.prototype.setInt8,bytes:1},B:{u:DataView.prototype.getUint8,p:DataView.prototype.setUint8,bytes:1},h:{u:DataView.prototype.getInt16,p:DataView.prototype.setInt16,bytes:2},H:{u:DataView.prototype.getUint16,p:DataView.prototype.setUint16,bytes:2},i:{u:DataView.prototype.getInt32,p:DataView.prototype.setInt32,bytes:4},I:{u:DataView.prototype.getUint32,p:DataView.prototype.setUint32,bytes:4},q:{u:DataView.prototype.getInt64,p:DataView.prototype.setInt64,bytes:8},Q:{u:DataView.prototype.getUint64,p:DataView.prototype.setUint64,bytes:8}},Ta=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let i=[],s=!0;for(let i=0;i<t.length;i++)"<"==t[i]?s=!0:">"==t[i]?s=!1:(r(t[i],e[a]),a++);function r(t,e){if(!(t in Ba))throw"Unhandled character '"+t+"' in pack format";let a=Ba[t].bytes,r=new DataView(new ArrayBuffer(a));Ba[t].p.bind(r)(0,e,s);for(let t=0;t<a;t++)i.push(r.getUint8(t))}return i},Ca=(t,e)=>{let a=0,i=[],s=!0;for(let e of t)"<"==e?s=!0:">"==e?s=!1:r(e);function r(t){if(!(t in Ba))throw"Unhandled character '"+t+"' in unpack format";let r=Ba[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let o=Ba[t].u.bind(n);i.push(o(0,s)),a+=r}return i};class Za extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this._efuses=new Array(4).fill(0),this._flashsize=4194304,this.debug=!1,this.IS_STUB=!1,this.connected=!0,this.flashSize=null,this.state_DTR=!1}get _inputBuffer(){return this._parent?this._parent._inputBuffer:this.__inputBuffer}async initialize(){await this.hardReset(!0),this._parent||(this.__inputBuffer=[],this.readLoop()),await this.sync();let t=await this.readRegister(1073745920),e=g[t>>>0];if(void 0===e)throw new Error(`Unknown Chip: Hex: ${a(t>>>0,8).toLowerCase()} Number: ${t}`);this.chipName=e.name,this.chipFamily=e.family;let i=y(this.getChipFamily()).macFuse;for(let t=0;t<4;t++)this._efuses[t]=await this.readRegister(i+4*t);this.logger.log(`Chip type ${this.chipName}`)}async readLoop(){this.debug&&this.logger.debug("Starting read loop"),this._reader=this.port.readable.getReader();try{for(;;){const{value:t,done:e}=await this._reader.read();if(e){this._reader.releaseLock();break}t&&0!==t.length&&this._inputBuffer.push(...Array.from(t))}}catch(t){console.error("Read loop got disconnected")}this.connected=!1,this.dispatchEvent(new Event("disconnect")),this.logger.debug("Finished read loop")}sleep(t=100){return new Promise((e=>setTimeout(e,t)))}async setRTS(t){await this.port.setSignals({requestToSend:t}),await this.setDTR(this.state_DTR)}async setDTR(t){this.state_DTR=t,await this.port.setSignals({dataTerminalReady:t})}async hardReset(t=!1){this.logger.log("Try hard reset."),t?4097===this.port.getInfo().usbProductId?(await this.setDTR(!1),await this.setRTS(!1),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(100),await this.setRTS(!0),await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!1),await this.setRTS(!1)):(await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(50),await this.setDTR(!1)):(await this.setRTS(!0),await this.sleep(100),await this.setRTS(!1)),await new Promise((t=>setTimeout(t,1e3)))}macAddr(){let t,e=new Array(6).fill(0),a=this._efuses[0],i=this._efuses[1],s=this._efuses[2],r=this._efuses[3];if(this.chipFamily==o){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(i>>16&255){if(1!=(i>>16&255))throw new Error("Couldnt determine OUI");t=[172,208,116]}else t=[24,254,52];e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=i>>8&255,e[4]=255&i,e[5]=a>>24&255}else if(this.chipFamily==l)e[0]=s>>8&255,e[1]=255&s,e[2]=i>>24&255,e[3]=i>>16&255,e[4]=i>>8&255,e[5]=255&i;else{if(this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=i>>8&255,e[1]=255&i,e[2]=a>>24&255,e[3]=a>>16&255,e[4]=a>>8&255,e[5]=255&a}return e}async readRegister(t){this.debug&&this.logger.debug("Reading from Register "+a(t,8));let e=Ta("<I",t);await this.sendCommand(10,e);let[i,s]=await this.getResponse(10);return i}async checkCommand(t,e,i=0,s=3e3){s=Math.min(s,12e5),await this.sendCommand(t,e,i);let[r,n]=await this.getResponse(t,s);if(null===n)throw new Error("Didn't get enough status bytes");let g=0;if(this.IS_STUB||this.chipFamily==o?g=2:[l,h,d,f,_,c,u,w].includes(this.chipFamily)?g=4:[2,4].includes(n.length)&&(g=n.length),n.length<g)throw new Error("Didn't get enough status bytes");let m=n.slice(-g,n.length);if(n=n.slice(0,-g),this.debug&&(this.logger.debug("status",m),this.logger.debug("value",r),this.logger.debug("data",n)),1==m[0])throw 5==m[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(m[1]));return[r,n]}async sendCommand(t,e,a=0){let i=(t=>{let e=[192];for(let a of t)219==a?e=e.concat([219,221]):192==a?e=e.concat([219,220]):e.push(a);return e.push(192),e})([...Ta("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${i.length} byte${1==i.length?"":"s"}:`,i),await this.writeToStream(i)}async readPacket(t){let s=null,r=!1,n=[];for(;;){let o=Date.now();for(n=[];Date.now()-o<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await i(10)}if(0==n.length){throw new k("Timed out waiting for packet "+(null===s?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===s){if(192!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid head of packet ("+a(t)+")");s=[]}else if(r)if(r=!1,220==t)s.push(192);else{if(221!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid SLIP escape (0xdb, "+a(t)+")");s.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(s)),s;s.push(t)}}throw new k("Invalid state")}async getResponse(t,e=3e3){for(let i=0;i<100;i++){const i=await this.readPacket(e);if(i.length<8)continue;const[s,r,n,o]=Ca("<BBHI",i.slice(0,8));if(1!=s)continue;const l=i.slice(8);if(null==t||r==t)return[o,l];if(0!=l[0]&&5==l[1])throw this._inputBuffer.length=0,new Error(`Invalid (unsupported) command ${a(t)}`)}throw"Response doesn't match request"}checksum(t,e=239){for(let a of t)e^=a;return e}async setBaudrate(t){if(this.chipFamily==o)throw new Error("Changing baud rate is not supported on the ESP8266");this.logger.log("Attempting to change baud rate to "+t+"...");try{let e=Ta("<II",t,this.IS_STUB?r:0);await this.checkCommand(15,e)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: No response from set baud rate command.`)}this._parent?await this._parent.reconfigurePort(t):await this.reconfigurePort(t)}async reconfigurePort(t){var e;try{await(null===(e=this._reader)||void 0===e?void 0:e.cancel()),await this.port.close(),await this.port.open({baudRate:t}),this.readLoop(),this.logger.log(`Changed baud rate to ${t}`)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: ${e}`)}}async sync(){for(let t=0;t<5;t++){if(this._inputBuffer.length=0,await this._sync())return await i(100),!0;await i(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,n);for(let t=0;t<8;t++)try{let[t,e]=await this.getResponse(8,100);if(e.length>1&&0==e[0]&&0==e[1])return!0}catch(t){}return!1}getFlashWriteSize(){return this.IS_STUB?16384:1024}async flashData(t,e,i=0,s=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],i=r[2],s=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(i)}, FlashSizeFreq=${a(s)}`)}let n,o=t.byteLength,l=0,h=m;s?(n=Fa(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${o}. Compressed Size: ${l}`),h=await this.flashDeflBegin(o,l,i)):(this.logger.log(`Writing data with filesize: ${o}`),n=t,await this.flashBegin(o,i));let d=[],f=0,_=0,c=0,u=Date.now(),w=this.getFlashWriteSize(),g=s?l:o;for(;g-c>0;)this.debug&&this.logger.log(`Writing at ${a(i+f*w,8)} `),g-c>=w?d=Array.from(new Uint8Array(n,c,w)):(d=Array.from(new Uint8Array(n,c,g-c)),s||(d=d.concat(new Array(w-d.length).fill(255)))),s?await this.flashDeflBlock(d,f,h):await this.flashBlock(d,f),f+=1,_+=s?Math.round(d.length*o/l):d.length,c+=w,e(Math.min(_,o),o);this.logger.log("Took "+(Date.now()-u)+"ms to write "+g+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),s?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Ta("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Ta("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,i=!1){let s,r,n=this.getFlashWriteSize();!this.IS_STUB&&[l,h,d,f,_,c,u,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let g,p=Math.floor((t+n-1)/n);s=this.chipFamily==o?this.getEraseSize(e,t):t,g=this.IS_STUB?m:b(3e4,t);let y=Date.now();return r=Ta("<IIII",s,p,n,e),this.chipFamily!=l&&this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w||(r=r.concat(Ta("<I",i?1:0))),this.logger.log("Erase size "+s+", blocks "+p+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(i?"yes":"no")),await this.checkCommand(2,r,0,g),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-y)+"ms to erase "+p+" bytes"),p}async flashDeflBegin(t=0,e=0,a=0,i=!1){let s,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),o=Math.floor((t+r-1)/r),l=0,h=0;return this.IS_STUB?(l=t,h=b(3e4,l)):(l=o*r,h=m),s=Ta("<IIII",l,n,r,a),await this.checkCommand(16,s,0,h),h}async flashFinish(){let t=Ta("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Ta("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return y(this.getChipFamily()).flashOffs}async flashId(){return await this.runSpiFlashCommand(159,[],24)}getChipFamily(){return this._parent?this._parent.chipFamily:this.chipFamily}async writeRegister(t,e,a=4294967295,i=0,s=0){let r=Ta("<IIII",t,e,a,i);s>0&&r.concat(Ta("<IIII",y(this.getChipFamily()).uartDateReg,0,0,s)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let i=t.regBase+t.mosiDlenOffs,s=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(i,e-1),a>0&&await this.writeRegister(s,a-1)}else{let i=t.regBase+t.usr1Offs,s=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(i,s)}}async waitDone(t,e){for(let a=0;a<10;a++){if(!(await this.readRegister(t)&e))return}throw Error("SPI command did not complete in time")}async runSpiFlashCommand(t,e,i=0){let s=y(this.getChipFamily()),r=s.regBase,n=r,o=r+s.usrOffs,l=r+s.usr2Offs,h=r+s.w0Offs,d=1<<18;if(i>32)throw new Error("Reading more than 32 bits back from a SPI flash operation is unsupported");if(e.length>64)throw new Error("Writing more than 64 bytes of data with one SPI command is unsupported");let f=8*e.length,_=await this.readRegister(o),c=await this.readRegister(l),u=1<<31;if(i>0&&(u|=268435456),f>0&&(u|=134217728),await this.setDataLengths(s,f,i),await this.writeRegister(o,u),await this.writeRegister(l,7<<28|t),0==f)await this.writeRegister(h,0);else{e.concat(new Array(e.length%4).fill(0));let t=Ca("I".repeat(Math.floor(e.length/4)),e),i=h;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(i)}`),await this.writeRegister(i,e),i+=4}await this.writeRegister(n,d),await this.waitDone(n,d);let w=await this.readRegister(h);return await this.writeRegister(o,_),await this.writeRegister(l,c),w}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,i=t>>16&255;this.logger.log(`FlashId: ${a(t)}`),this.logger.log(`Flash Manufacturer: ${e.toString(16)}`),this.logger.log(`Flash Device: ${(t>>8&255).toString(16)}${i.toString(16)}`),this.flashSize=s[i],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,i=Math.floor((e+a-1)/a),s=16-Math.floor(t/a)%16;return i<s&&(s=i),i<2*s?Math.floor((i+1)/2*a):(i-s)*a}async memBegin(t,e,a,i){return await this.checkCommand(5,Ta("<IIII",t,e,a,i))}async memBlock(t,e){return await this.checkCommand(7,Ta("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?m:500,a=Ta("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await v(this.chipFamily);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let i=t[e+"_start"],s=t[e].length,r=Math.floor((s+a-1)/a);await this.memBegin(s,r,a,i);for(let i of Array(r).keys()){let r=i*a,n=r+a;n>s&&(n=s),await this.memBlock(t[e].slice(r,n),i)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const i=await this.readPacket(500);if(e=String.fromCharCode(...i),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const s=new La(this.port,this.logger,this);return await s.detectFlashSize(),s}async writeToStream(t){const e=this.port.writable.getWriter();await e.write(new Uint8Array(t));try{e.releaseLock()}catch(t){console.error("Ignoring release lock error",t)}}async disconnect(){this._parent?await this._parent.disconnect():(await this.port.writable.getWriter().close(),await new Promise((t=>{this._reader||t(void 0),this.addEventListener("disconnect",t,{once:!0}),this._reader.cancel()})),this.connected=!1)}}class La extends Za{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,i,s){let r=await v(this.chipFamily),n=s,o=s+t;console.log(n,o),console.log(r.data_start,r.data.length,r.text_start,r.text.length);for(let[t,e]of[[r.data_start,r.data_start+r.data.length],[r.text_start,r.text_start+r.text.length]])if(n<e&&o>t)throw new Error("Software loader is resident at "+a(t,8)+"-"+a(e,8)+". Can't load binary at overlapping address range "+a(n,8)+"-"+a(o,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,p)}}const Pa=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Za(e,t)};export{l as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,_ as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C6,u as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,h as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,o as CHIP_FAMILY_ESP8266,Za as ESPLoader,Pa as connect};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
var A=1341196252,B="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",w=1341194240,E="XAD1T1QM8U+kDPFP/AzxT9IN8U8+DvFP7A3xTyAL8U+ODfFPzg3xTxAN8U/QCvFPRA3xT9AK8U8uDPFPdAzxT6QM8U/8DPFPQAzxT4QL8U+0C/FPPAzxT5YQ8U+kDPFPXg/xT1YQ8U9sCfFPehDxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFP8g7xT2wJ8U98D/FPVhDxTw==",F=1341533176,Q=1341456384,T={entry:A,text:B,text_start:w,data:E,data_start:F,bss_start:Q};export{Q as bss_start,E as data,F as data_start,T as default,A as entry,B as text,w as text_start};
|
package/js/modules/esptool.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=t=>{let e=[];for(let a=0;a<t.length;a++){let i=t.charCodeAt(a);i<=255&&e.push(i)}return e},e=t=>"["+t.map((t=>a(t))).join(", ")+"]",a=(t,e=2)=>{let a=t.toString(16).toUpperCase();return a.startsWith("-")?"-0x"+a.substring(1).padStart(e,"0"):"0x"+a.padStart(e,"0")},i=t=>new Promise((e=>setTimeout(e,t))),s={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),o=33382,l=50,h=12882,d=12883,f=12994,_=12995,c=12998,u=12914,w=12928,g={4293968129:{name:"ESP8266",family:o},15736195:{name:"ESP32",family:l},1990:{name:"ESP32-S2",family:h},9:{name:"ESP32-S3",family:d},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},1763790959:{name:"ESP32-C3",family:_},456216687:{name:"ESP32-C3",family:_},1216438383:{name:"ESP32-C3",family:_},1130455151:{name:"ESP32-C3",family:_},3619110528:{name:"ESP32-H2",family:u},752910447:{name:"ESP32-C6",family:c},182303440:{name:"ESP32-P4",family:w},0:{name:"ESP32-P4",family:w}},m=3e3,p=6e5,b=(t,e)=>{let a=Math.floor(t*(e/486));return a<m?m:a},y=t=>{switch(t){case l:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case h:return{regBase:1061167104,baseFuse:1061265408,macFuse:1061265476,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612856,flashOffs:4096};case d:return{regBase:1610620928,usrOffs:24,baseFuse:1610641408,macFuse:1610641476,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612864,flashOffs:0};case o:return{regBase:1610613248,usrOffs:28,baseFuse:1072693328,macFuse:1072693328,usr1Offs:32,usr2Offs:36,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:64,uartDateReg:1610612856,flashOffs:0};case f:case _:return{regBase:1610620928,baseFuse:1610647552,macFuse:1610647620,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case c:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case u:return{regBase:1610620928,baseFuse:1610719232,macFuse:1610719300,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case w:return{regBase:1342754816,baseFuse:1343410176,macFuse:1343410244,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1343004812,flashOffs:8192};default:return{regBase:-1,baseFuse:-1,macFuse:-1,usrOffs:-1,usr1Offs:-1,usr2Offs:-1,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:-1,uartDateReg:-1,flashOffs:-1}}};class k extends Error{constructor(t){super(t),this.name="SlipReadError"}}const v=async e=>{let a;return e==l?a=await import("./esp32-BLbsWvxO.js"):e==h?a=await import("./esp32s2-CrsP1231.js"):e==d?a=await import("./esp32s3-CiJyd6Fk.js"):e==o?a=await import("./esp8266-CQFcqJ_a.js"):e==f?a=await import("./esp32c2-wLQhZItC.js"):e==_?a=await import("./esp32c3-DmSvHQKL.js"):e==c?a=await import("./esp32c6-ZuxjUVr4.js"):e==u?a=await import("./esp32h2-CZ4EIL3w.js"):e==w&&(a=await import("./esp32p4-BvuBbdjO.js")),{...a,text:t(atob(a.text)),data:t(atob(a.data))}};function x(t){let e=t.length;for(;--e>=0;)t[e]=0}const z=256,R=286,S=30,E=15,D=new Uint8Array([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]),U=new Uint8Array([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]),A=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),O=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),I=new Array(576);x(I);const F=new Array(60);x(F);const B=new Array(512);x(B);const T=new Array(256);x(T);const C=new Array(29);x(C);const Z=new Array(S);function L(t,e,a,i,s){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=i,this.max_length=s,this.has_stree=t&&t.length}let M,N,P;function H(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}x(Z);const $=t=>t<256?B[t]:B[256+(t>>>7)],j=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},V=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,j(t,t.bi_buf),t.bi_buf=e>>16-t.bi_valid,t.bi_valid+=a-16):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=a)},W=(t,e,a)=>{V(t,a[2*e],a[2*e+1])},K=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Y=(t,e,a)=>{const i=new Array(16);let s,r,n=0;for(s=1;s<=E;s++)n=n+a[s-1]<<1,i[s]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=K(i[e]++,e))}},q=t=>{let e;for(e=0;e<R;e++)t.dyn_ltree[2*e]=0;for(e=0;e<S;e++)t.dyn_dtree[2*e]=0;for(e=0;e<19;e++)t.bl_tree[2*e]=0;t.dyn_ltree[512]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},G=t=>{t.bi_valid>8?j(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},X=(t,e,a,i)=>{const s=2*e,r=2*a;return t[s]<t[r]||t[s]===t[r]&&i[e]<=i[a]},Q=(t,e,a)=>{const i=t.heap[a];let s=a<<1;for(;s<=t.heap_len&&(s<t.heap_len&&X(e,t.heap[s+1],t.heap[s],t.depth)&&s++,!X(e,i,t.heap[s],t.depth));)t.heap[a]=t.heap[s],a=s,s<<=1;t.heap[a]=i},J=(t,e,a)=>{let i,s,r,n,o=0;if(0!==t.sym_next)do{i=255&t.pending_buf[t.sym_buf+o++],i+=(255&t.pending_buf[t.sym_buf+o++])<<8,s=t.pending_buf[t.sym_buf+o++],0===i?W(t,s,e):(r=T[s],W(t,r+z+1,e),n=D[r],0!==n&&(s-=C[r],V(t,s,n)),i--,r=$(i),W(t,r,a),n=U[r],0!==n&&(i-=Z[r],V(t,i,n)))}while(o<t.sym_next);W(t,256,e)},tt=(t,e)=>{const a=e.dyn_tree,i=e.stat_desc.static_tree,s=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,o,l,h=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=h=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=h<2?++h:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,s&&(t.static_len-=i[2*l+1]);for(e.max_code=h,n=t.heap_len>>1;n>=1;n--)Q(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],Q(t,a,1),o=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=o,a[2*l]=a[2*n]+a[2*o],t.depth[l]=(t.depth[n]>=t.depth[o]?t.depth[n]:t.depth[o])+1,a[2*n+1]=a[2*o+1]=l,t.heap[1]=l++,Q(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,i=e.max_code,s=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,o=e.stat_desc.extra_base,l=e.stat_desc.max_length;let h,d,f,_,c,u,w=0;for(_=0;_<=E;_++)t.bl_count[_]=0;for(a[2*t.heap[t.heap_max]+1]=0,h=t.heap_max+1;h<573;h++)d=t.heap[h],_=a[2*a[2*d+1]+1]+1,_>l&&(_=l,w++),a[2*d+1]=_,d>i||(t.bl_count[_]++,c=0,d>=o&&(c=n[d-o]),u=a[2*d],t.opt_len+=u*(_+c),r&&(t.static_len+=u*(s[2*d+1]+c)));if(0!==w){do{for(_=l-1;0===t.bl_count[_];)_--;t.bl_count[_]--,t.bl_count[_+1]+=2,t.bl_count[l]--,w-=2}while(w>0);for(_=l;0!==_;_--)for(d=t.bl_count[_];0!==d;)f=t.heap[--h],f>i||(a[2*f+1]!==_&&(t.opt_len+=(_-a[2*f+1])*a[2*f],a[2*f+1]=_),d--)}})(t,e),Y(a,h,t.bl_count)},et=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),e[2*(a+1)+1]=65535,i=0;i<=a;i++)s=n,n=e[2*(i+1)+1],++o<l&&s===n||(o<h?t.bl_tree[2*s]+=o:0!==s?(s!==r&&t.bl_tree[2*s]++,t.bl_tree[32]++):o<=10?t.bl_tree[34]++:t.bl_tree[36]++,o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4))},at=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),i=0;i<=a;i++)if(s=n,n=e[2*(i+1)+1],!(++o<l&&s===n)){if(o<h)do{W(t,s,t.bl_tree)}while(0!=--o);else 0!==s?(s!==r&&(W(t,s,t.bl_tree),o--),W(t,16,t.bl_tree),V(t,o-3,2)):o<=10?(W(t,17,t.bl_tree),V(t,o-3,3)):(W(t,18,t.bl_tree),V(t,o-11,7));o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4)}};let it=!1;const st=(t,e,a,i)=>{V(t,0+(i?1:0),3),G(t),j(t,a),j(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var rt=(t,e,a,i)=>{let s,r,n=0;t.level>0?(2===t.strm.data_type&&(t.strm.data_type=(t=>{let e,a=4093624447;for(e=0;e<=31;e++,a>>>=1)if(1&a&&0!==t.dyn_ltree[2*e])return 0;if(0!==t.dyn_ltree[18]||0!==t.dyn_ltree[20]||0!==t.dyn_ltree[26])return 1;for(e=32;e<z;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),tt(t,t.l_desc),tt(t,t.d_desc),n=(t=>{let e;for(et(t,t.dyn_ltree,t.l_desc.max_code),et(t,t.dyn_dtree,t.d_desc.max_code),tt(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*O[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),s=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=s&&(s=r)):s=r=a+5,a+4<=s&&-1!==e?st(t,e,a,i):4===t.strategy||r===s?(V(t,2+(i?1:0),3),J(t,I,F)):(V(t,4+(i?1:0),3),((t,e,a,i)=>{let s;for(V(t,e-257,5),V(t,a-1,5),V(t,i-4,4),s=0;s<i;s++)V(t,t.bl_tree[2*O[s]+1],3);at(t,t.dyn_ltree,e-1),at(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),J(t,t.dyn_ltree,t.dyn_dtree)),q(t),i&&G(t)},nt={_tr_init:t=>{it||((()=>{let t,e,a,i,s;const r=new Array(16);for(a=0,i=0;i<28;i++)for(C[i]=a,t=0;t<1<<D[i];t++)T[a++]=i;for(T[a-1]=i,s=0,i=0;i<16;i++)for(Z[i]=s,t=0;t<1<<U[i];t++)B[s++]=i;for(s>>=7;i<S;i++)for(Z[i]=s<<7,t=0;t<1<<U[i]-7;t++)B[256+s++]=i;for(e=0;e<=E;e++)r[e]=0;for(t=0;t<=143;)I[2*t+1]=8,t++,r[8]++;for(;t<=255;)I[2*t+1]=9,t++,r[9]++;for(;t<=279;)I[2*t+1]=7,t++,r[7]++;for(;t<=287;)I[2*t+1]=8,t++,r[8]++;for(Y(I,287,r),t=0;t<S;t++)F[2*t+1]=5,F[2*t]=K(t,5);M=new L(I,D,257,R,E),N=new L(F,U,0,S,E),P=new L(new Array(0),A,0,19,7)})(),it=!0),t.l_desc=new H(t.dyn_ltree,M),t.d_desc=new H(t.dyn_dtree,N),t.bl_desc=new H(t.bl_tree,P),t.bi_buf=0,t.bi_valid=0,q(t)},_tr_stored_block:st,_tr_flush_block:rt,_tr_tally:(t,e,a)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=a,0===e?t.dyn_ltree[2*a]++:(t.matches++,e--,t.dyn_ltree[2*(T[a]+z+1)]++,t.dyn_dtree[2*$(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{V(t,2,3),W(t,256,I),(t=>{16===t.bi_valid?(j(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=255&t.bi_buf,t.bi_buf>>=8,t.bi_valid-=8)})(t)}};var ot=(t,e,a,i)=>{let s=65535&t|0,r=t>>>16&65535|0,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{s=s+e[i++]|0,r=r+s|0}while(--n);s%=65521,r%=65521}return s|r<<16|0};const lt=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var i=0;i<8;i++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ht=(t,e,a,i)=>{const s=lt,r=i+a;t^=-1;for(let a=i;a<r;a++)t=t>>>8^s[255&(t^e[a])];return-1^t},dt={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"},ft={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,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_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,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:_t,_tr_stored_block:ct,_tr_flush_block:ut,_tr_tally:wt,_tr_align:gt}=nt,{Z_NO_FLUSH:mt,Z_PARTIAL_FLUSH:pt,Z_FULL_FLUSH:bt,Z_FINISH:yt,Z_BLOCK:kt,Z_OK:vt,Z_STREAM_END:xt,Z_STREAM_ERROR:zt,Z_DATA_ERROR:Rt,Z_BUF_ERROR:St,Z_DEFAULT_COMPRESSION:Et,Z_FILTERED:Dt,Z_HUFFMAN_ONLY:Ut,Z_RLE:At,Z_FIXED:Ot,Z_DEFAULT_STRATEGY:It,Z_UNKNOWN:Ft,Z_DEFLATED:Bt}=ft,Tt=258,Ct=262,Zt=42,Lt=113,Mt=666,Nt=(t,e)=>(t.msg=dt[e],e),Pt=t=>2*t-(t>4?9:0),Ht=t=>{let e=t.length;for(;--e>=0;)t[e]=0},$t=t=>{let e,a,i,s=t.w_size;e=t.hash_size,i=e;do{a=t.head[--i],t.head[i]=a>=s?a-s:0}while(--e);e=s,i=e;do{a=t.prev[--i],t.prev[i]=a>=s?a-s:0}while(--e)};let jt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Vt=t=>{const e=t.state;let a=e.pending;a>t.avail_out&&(a=t.avail_out),0!==a&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+a),t.next_out),t.next_out+=a,e.pending_out+=a,t.total_out+=a,t.avail_out-=a,e.pending-=a,0===e.pending&&(e.pending_out=0))},Wt=(t,e)=>{ut(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Vt(t.strm)},Kt=(t,e)=>{t.pending_buf[t.pending++]=e},Yt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},qt=(t,e,a,i)=>{let s=t.avail_in;return s>i&&(s=i),0===s?0:(t.avail_in-=s,e.set(t.input.subarray(t.next_in,t.next_in+s),a),1===t.state.wrap?t.adler=ot(t.adler,e,s,a):2===t.state.wrap&&(t.adler=ht(t.adler,e,s,a)),t.next_in+=s,t.total_in+=s,s)},Gt=(t,e)=>{let a,i,s=t.max_chain_length,r=t.strstart,n=t.prev_length,o=t.nice_match;const l=t.strstart>t.w_size-Ct?t.strstart-(t.w_size-Ct):0,h=t.window,d=t.w_mask,f=t.prev,_=t.strstart+Tt;let c=h[r+n-1],u=h[r+n];t.prev_length>=t.good_match&&(s>>=2),o>t.lookahead&&(o=t.lookahead);do{if(a=e,h[a+n]===u&&h[a+n-1]===c&&h[a]===h[r]&&h[++a]===h[r+1]){r+=2,a++;do{}while(h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&r<_);if(i=Tt-(_-r),r=_-Tt,i>n){if(t.match_start=e,n=i,i>=o)break;c=h[r+n-1],u=h[r+n]}}}while((e=f[e&d])>l&&0!=--s);return n<=t.lookahead?n:t.lookahead},Xt=t=>{const e=t.w_size;let a,i,s;do{if(i=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-Ct)&&(t.window.set(t.window.subarray(e,e+e-i),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),$t(t),i+=e),0===t.strm.avail_in)break;if(a=qt(t.strm,t.window,t.strstart+t.lookahead,i),t.lookahead+=a,t.lookahead+t.insert>=3)for(s=t.strstart-t.insert,t.ins_h=t.window[s],t.ins_h=jt(t,t.ins_h,t.window[s+1]);t.insert&&(t.ins_h=jt(t,t.ins_h,t.window[s+3-1]),t.prev[s&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=s,s++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<Ct&&0!==t.strm.avail_in)},Qt=(t,e)=>{let a,i,s,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,o=t.strm.avail_in;do{if(a=65535,s=t.bi_valid+42>>3,t.strm.avail_out<s)break;if(s=t.strm.avail_out-s,i=t.strstart-t.block_start,a>i+t.strm.avail_in&&(a=i+t.strm.avail_in),a>s&&(a=s),a<r&&(0===a&&e!==yt||e===mt||a!==i+t.strm.avail_in))break;n=e===yt&&a===i+t.strm.avail_in?1:0,ct(t,0,0,n),t.pending_buf[t.pending-4]=a,t.pending_buf[t.pending-3]=a>>8,t.pending_buf[t.pending-2]=~a,t.pending_buf[t.pending-1]=~a>>8,Vt(t.strm),i&&(i>a&&(i=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,a-=i),a&&(qt(t.strm,t.strm.output,t.strm.next_out,a),t.strm.next_out+=a,t.strm.avail_out-=a,t.strm.total_out+=a)}while(0===n);return o-=t.strm.avail_in,o&&(o>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=o&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-o,t.strm.next_in),t.strstart),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==mt&&e!==yt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(s=t.window_size-t.strstart,t.strm.avail_in>s&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,s+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),s>t.strm.avail_in&&(s=t.strm.avail_in),s&&(qt(t.strm,t.window,t.strstart,s),t.strstart+=s,t.insert+=s>t.w_size-t.insert?t.w_size-t.insert:s),t.high_water<t.strstart&&(t.high_water=t.strstart),s=t.bi_valid+42>>3,s=t.pending_buf_size-s>65535?65535:t.pending_buf_size-s,r=s>t.w_size?t.w_size:s,i=t.strstart-t.block_start,(i>=r||(i||e===yt)&&e!==mt&&0===t.strm.avail_in&&i<=s)&&(a=i>s?s:i,n=e===yt&&0===t.strm.avail_in&&a===i?1:0,ct(t,t.block_start,a,n),t.block_start+=a,Vt(t.strm)),n?3:1)},Jt=(t,e)=>{let a,i;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),0!==a&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a)),t.match_length>=3)if(i=wt(t,t.strstart-t.match_start,t.match_length-3),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=3){t.match_length--;do{t.strstart++,t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart}while(0!=--t.match_length);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=jt(t,t.ins_h,t.window[t.strstart+1]);else i=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(i&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2},te=(t,e)=>{let a,i,s;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=2,0!==a&&t.prev_length<t.max_lazy_match&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a),t.match_length<=5&&(t.strategy===Dt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){s=t.strstart+t.lookahead-3,i=wt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=s&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart)}while(0!=--t.prev_length);if(t.match_available=0,t.match_length=2,t.strstart++,i&&(Wt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(i=wt(t,0,t.window[t.strstart-1]),i&&Wt(t,!1),t.strstart++,t.lookahead--,0===t.strm.avail_out)return 1}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(i=wt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2};function ee(t,e,a,i,s){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=i,this.func=s}const ae=[new ee(0,0,0,0,Qt),new ee(4,4,8,4,Jt),new ee(4,5,16,8,Jt),new ee(4,6,32,32,Jt),new ee(4,4,16,16,te),new ee(8,16,32,32,te),new ee(8,16,128,128,te),new ee(8,32,128,256,te),new ee(32,128,258,1024,te),new ee(32,258,258,4096,te)];function ie(){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=Bt,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 Uint16Array(1146),this.dyn_dtree=new Uint16Array(122),this.bl_tree=new Uint16Array(78),Ht(this.dyn_ltree),Ht(this.dyn_dtree),Ht(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(16),this.heap=new Uint16Array(573),Ht(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Ht(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}const se=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Zt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Lt&&e.status!==Mt?1:0},re=t=>{if(se(t))return Nt(t,zt);t.total_in=t.total_out=0,t.data_type=Ft;const e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=2===e.wrap?57:e.wrap?Zt:Lt,t.adler=2===e.wrap?0:1,e.last_flush=-2,_t(e),vt},ne=t=>{const e=re(t);var a;return e===vt&&((a=t.state).window_size=2*a.w_size,Ht(a.head),a.max_lazy_match=ae[a.level].max_lazy,a.good_match=ae[a.level].good_length,a.nice_match=ae[a.level].nice_length,a.max_chain_length=ae[a.level].max_chain,a.strstart=0,a.block_start=0,a.lookahead=0,a.insert=0,a.match_length=a.prev_length=2,a.match_available=0,a.ins_h=0),e},oe=(t,e,a,i,s,r)=>{if(!t)return zt;let n=1;if(e===Et&&(e=6),i<0?(n=0,i=-i):i>15&&(n=2,i-=16),s<1||s>9||a!==Bt||i<8||i>15||e<0||e>9||r<0||r>Ot||8===i&&1!==n)return Nt(t,zt);8===i&&(i=9);const o=new ie;return t.state=o,o.strm=t,o.status=Zt,o.wrap=n,o.gzhead=null,o.w_bits=i,o.w_size=1<<o.w_bits,o.w_mask=o.w_size-1,o.hash_bits=s+7,o.hash_size=1<<o.hash_bits,o.hash_mask=o.hash_size-1,o.hash_shift=~~((o.hash_bits+3-1)/3),o.window=new Uint8Array(2*o.w_size),o.head=new Uint16Array(o.hash_size),o.prev=new Uint16Array(o.w_size),o.lit_bufsize=1<<s+6,o.pending_buf_size=4*o.lit_bufsize,o.pending_buf=new Uint8Array(o.pending_buf_size),o.sym_buf=o.lit_bufsize,o.sym_end=3*(o.lit_bufsize-1),o.level=e,o.strategy=r,o.method=a,ne(t)};var le={deflateInit:(t,e)=>oe(t,e,Bt,15,8,It),deflateInit2:oe,deflateReset:ne,deflateResetKeep:re,deflateSetHeader:(t,e)=>se(t)||2!==t.state.wrap?zt:(t.state.gzhead=e,vt),deflate:(t,e)=>{if(se(t)||e>kt||e<0)return t?Nt(t,zt):zt;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Mt&&e!==yt)return Nt(t,0===t.avail_out?St:zt);const i=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Vt(t),0===t.avail_out)return a.last_flush=-1,vt}else if(0===t.avail_in&&Pt(e)<=Pt(i)&&e!==yt)return Nt(t,St);if(a.status===Mt&&0!==t.avail_in)return Nt(t,St);if(a.status===Zt&&0===a.wrap&&(a.status=Lt),a.status===Zt){let e=Bt+(a.w_bits-8<<4)<<8,i=-1;if(i=a.strategy>=Ut||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=i<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Yt(a,e),0!==a.strstart&&(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),t.adler=1,a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(57===a.status)if(t.adler=0,Kt(a,31),Kt(a,139),Kt(a,8),a.gzhead)Kt(a,(a.gzhead.text?1:0)+(a.gzhead.hcrc?2:0)+(a.gzhead.extra?4:0)+(a.gzhead.name?8:0)+(a.gzhead.comment?16:0)),Kt(a,255&a.gzhead.time),Kt(a,a.gzhead.time>>8&255),Kt(a,a.gzhead.time>>16&255),Kt(a,a.gzhead.time>>24&255),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Kt(a,255&a.gzhead.extra.length),Kt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ht(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,3),a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt;if(69===a.status){if(a.gzhead.extra){let e=a.pending,i=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+i>a.pending_buf_size;){let s=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=s,Vt(t),0!==a.pending)return a.last_flush=-1,vt;e=0,i-=s}let s=new Uint8Array(a.gzhead.extra);a.pending_buf.set(s.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending+=i,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex=0}a.status=73}if(73===a.status){if(a.gzhead.name){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Vt(t),0!==a.pending))return a.last_flush=-1,vt;Kt(a,255&t.adler),Kt(a,t.adler>>8&255),t.adler=0}if(a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(0!==t.avail_in||0!==a.lookahead||e!==mt&&a.status!==Mt){let i=0===a.level?Qt(a,e):a.strategy===Ut?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(Xt(t),0===t.lookahead)){if(e===mt)return 1;break}if(t.match_length=0,a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===At?((t,e)=>{let a,i,s,r;const n=t.window;for(;;){if(t.lookahead<=Tt){if(Xt(t),t.lookahead<=Tt&&e===mt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(s=t.strstart-1,i=n[s],i===n[++s]&&i===n[++s]&&i===n[++s])){r=t.strstart+Tt;do{}while(i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&s<r);t.match_length=Tt-(r-s),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=wt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ae[a.level].func(a,e);if(3!==i&&4!==i||(a.status=Mt),1===i||3===i)return 0===t.avail_out&&(a.last_flush=-1),vt;if(2===i&&(e===pt?gt(a):e!==kt&&(ct(a,0,0,!1),e===bt&&(Ht(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Vt(t),0===t.avail_out))return a.last_flush=-1,vt}return e!==yt?vt:a.wrap<=0?xt:(2===a.wrap?(Kt(a,255&t.adler),Kt(a,t.adler>>8&255),Kt(a,t.adler>>16&255),Kt(a,t.adler>>24&255),Kt(a,255&t.total_in),Kt(a,t.total_in>>8&255),Kt(a,t.total_in>>16&255),Kt(a,t.total_in>>24&255)):(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),Vt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?vt:xt)},deflateEnd:t=>{if(se(t))return zt;const e=t.state.status;return t.state=null,e===Lt?Nt(t,Rt):vt},deflateSetDictionary:(t,e)=>{let a=e.length;if(se(t))return zt;const i=t.state,s=i.wrap;if(2===s||1===s&&i.status!==Zt||i.lookahead)return zt;if(1===s&&(t.adler=ot(t.adler,e,a,0)),i.wrap=0,a>=i.w_size){0===s&&(Ht(i.head),i.strstart=0,i.block_start=0,i.insert=0);let t=new Uint8Array(i.w_size);t.set(e.subarray(a-i.w_size,a),0),e=t,a=i.w_size}const r=t.avail_in,n=t.next_in,o=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,Xt(i);i.lookahead>=3;){let t=i.strstart,e=i.lookahead-2;do{i.ins_h=jt(i,i.ins_h,i.window[t+3-1]),i.prev[t&i.w_mask]=i.head[i.ins_h],i.head[i.ins_h]=t,t++}while(--e);i.strstart=t,i.lookahead=2,Xt(i)}return i.strstart+=i.lookahead,i.block_start=i.strstart,i.insert=i.lookahead,i.lookahead=0,i.match_length=i.prev_length=2,i.match_available=0,t.next_in=n,t.input=o,t.avail_in=r,i.wrap=s,vt},deflateInfo:"pako deflate (from Nodeca project)"};const he=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var de={assign:function(t){const e=Array.prototype.slice.call(arguments,1);for(;e.length;){const a=e.shift();if(a){if("object"!=typeof a)throw new TypeError(a+"must be non-object");for(const e in a)he(a,e)&&(t[e]=a[e])}}return t},flattenChunks:t=>{let e=0;for(let a=0,i=t.length;a<i;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,i=0,s=t.length;e<s;e++){let s=t[e];a.set(s,i),i+=s.length}return a}};let fe=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){fe=!1}const _e=new Uint8Array(256);for(let t=0;t<256;t++)_e[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;_e[254]=_e[254]=1;var ce={string2buf:t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,i,s,r,n=t.length,o=0;for(s=0;s<n;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),o+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(o),r=0,s=0;r<o;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),a<128?e[r++]=a:a<2048?(e[r++]=192|a>>>6,e[r++]=128|63&a):a<65536?(e[r++]=224|a>>>12,e[r++]=128|a>>>6&63,e[r++]=128|63&a):(e[r++]=240|a>>>18,e[r++]=128|a>>>12&63,e[r++]=128|a>>>6&63,e[r++]=128|63&a);return e},buf2string:(t,e)=>{const a=e||t.length;if("function"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(t.subarray(0,e));let i,s;const r=new Array(2*a);for(s=0,i=0;i<a;){let e=t[i++];if(e<128){r[s++]=e;continue}let n=_e[e];if(n>4)r[s++]=65533,i+=n-1;else{for(e&=2===n?31:3===n?15:7;n>1&&i<a;)e=e<<6|63&t[i++],n--;n>1?r[s++]=65533:e<65536?r[s++]=e:(e-=65536,r[s++]=55296|e>>10&1023,r[s++]=56320|1023&e)}}return((t,e)=>{if(e<65534&&t.subarray&&fe)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let a="";for(let i=0;i<e;i++)a+=String.fromCharCode(t[i]);return a})(r,s)},utf8border:(t,e)=>{(e=e||t.length)>t.length&&(e=t.length);let a=e-1;for(;a>=0&&128==(192&t[a]);)a--;return a<0||0===a?e:a+_e[t[a]]>e?a:e}};var ue=function(){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};const we=Object.prototype.toString,{Z_NO_FLUSH:ge,Z_SYNC_FLUSH:me,Z_FULL_FLUSH:pe,Z_FINISH:be,Z_OK:ye,Z_STREAM_END:ke,Z_DEFAULT_COMPRESSION:ve,Z_DEFAULT_STRATEGY:xe,Z_DEFLATED:ze}=ft;function Re(t){this.options=de.assign({level:ve,method:ze,chunkSize:16384,windowBits:15,memLevel:8,strategy:xe},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new ue,this.strm.avail_out=0;let a=le.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==ye)throw new Error(dt[a]);if(e.header&&le.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?ce.string2buf(e.dictionary):"[object ArrayBuffer]"===we.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=le.deflateSetDictionary(this.strm,t),a!==ye)throw new Error(dt[a]);this._dict_set=!0}}function Se(t,e){const a=new Re(e);if(a.push(t,!0),a.err)throw a.msg||dt[a.err];return a.result}Re.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize;let s,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?be:ge,"string"==typeof t?a.input=ce.string2buf(t):"[object ArrayBuffer]"===we.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;)if(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),(r===me||r===pe)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(s=le.deflate(a,r),s===ke)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),s=le.deflateEnd(this.strm),this.onEnd(s),this.ended=!0,s===ye;if(0!==a.avail_out){if(r>0&&a.next_out>0)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else if(0===a.avail_in)break}else this.onData(a.output)}return!0},Re.prototype.onData=function(t){this.chunks.push(t)},Re.prototype.onEnd=function(t){t===ye&&(this.result=de.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Ee={Deflate:Re,deflate:Se,deflateRaw:function(t,e){return(e=e||{}).raw=!0,Se(t,e)},gzip:function(t,e){return(e=e||{}).gzip=!0,Se(t,e)},constants:ft};const De=16209;var Ue=function(t,e){let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z,R;const S=t.state;a=t.next_in,z=t.input,i=a+(t.avail_in-5),s=t.next_out,R=t.output,r=s-(e-t.avail_out),n=s+(t.avail_out-257),o=S.dmax,l=S.wsize,h=S.whave,d=S.wnext,f=S.window,_=S.hold,c=S.bits,u=S.lencode,w=S.distcode,g=(1<<S.lenbits)-1,m=(1<<S.distbits)-1;t:do{c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=u[_&g];e:for(;;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,0===b)R[s++]=65535&p;else{if(!(16&b)){if(0==(64&b)){p=u[(65535&p)+(_&(1<<b)-1)];continue e}if(32&b){S.mode=16191;break t}t.msg="invalid literal/length code",S.mode=De;break t}y=65535&p,b&=15,b&&(c<b&&(_+=z[a++]<<c,c+=8),y+=_&(1<<b)-1,_>>>=b,c-=b),c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=w[_&m];a:for(;;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,!(16&b)){if(0==(64&b)){p=w[(65535&p)+(_&(1<<b)-1)];continue a}t.msg="invalid distance code",S.mode=De;break t}if(k=65535&p,b&=15,c<b&&(_+=z[a++]<<c,c+=8,c<b&&(_+=z[a++]<<c,c+=8)),k+=_&(1<<b)-1,k>o){t.msg="invalid distance too far back",S.mode=De;break t}if(_>>>=b,c-=b,b=s-r,k>b){if(b=k-b,b>h&&S.sane){t.msg="invalid distance too far back",S.mode=De;break t}if(v=0,x=f,0===d){if(v+=l-b,b<y){y-=b;do{R[s++]=f[v++]}while(--b);v=s-k,x=R}}else if(d<b){if(v+=l+d-b,b-=d,b<y){y-=b;do{R[s++]=f[v++]}while(--b);if(v=0,d<y){b=d,y-=b;do{R[s++]=f[v++]}while(--b);v=s-k,x=R}}}else if(v+=d-b,b<y){y-=b;do{R[s++]=f[v++]}while(--b);v=s-k,x=R}for(;y>2;)R[s++]=x[v++],R[s++]=x[v++],R[s++]=x[v++],y-=3;y&&(R[s++]=x[v++],y>1&&(R[s++]=x[v++]))}else{v=s-k;do{R[s++]=R[v++],R[s++]=R[v++],R[s++]=R[v++],y-=3}while(y>2);y&&(R[s++]=R[v++],y>1&&(R[s++]=R[v++]))}break}}break}}while(a<i&&s<n);y=c>>3,a-=y,c-=y<<3,_&=(1<<c)-1,t.next_in=a,t.next_out=s,t.avail_in=a<i?i-a+5:5-(a-i),t.avail_out=s<n?n-s+257:257-(s-n),S.hold=_,S.bits=c};const Ae=15,Oe=new Uint16Array([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]),Ie=new Uint8Array([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]),Fe=new Uint16Array([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]),Be=new Uint8Array([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]);var Te=(t,e,a,i,s,r,n,o)=>{const l=o.bits;let h,d,f,_,c,u,w=0,g=0,m=0,p=0,b=0,y=0,k=0,v=0,x=0,z=0,R=null;const S=new Uint16Array(16),E=new Uint16Array(16);let D,U,A,O=null;for(w=0;w<=Ae;w++)S[w]=0;for(g=0;g<i;g++)S[e[a+g]]++;for(b=l,p=Ae;p>=1&&0===S[p];p--);if(b>p&&(b=p),0===p)return s[r++]=20971520,s[r++]=20971520,o.bits=1,0;for(m=1;m<p&&0===S[m];m++);for(b<m&&(b=m),v=1,w=1;w<=Ae;w++)if(v<<=1,v-=S[w],v<0)return-1;if(v>0&&(0===t||1!==p))return-1;for(E[1]=0,w=1;w<Ae;w++)E[w+1]=E[w]+S[w];for(g=0;g<i;g++)0!==e[a+g]&&(n[E[e[a+g]]++]=g);if(0===t?(R=O=n,u=20):1===t?(R=Oe,O=Ie,u=257):(R=Fe,O=Be,u=0),z=0,g=0,w=m,c=r,y=b,k=0,f=-1,x=1<<b,_=x-1,1===t&&x>852||2===t&&x>592)return 1;for(;;){D=w-k,n[g]+1<u?(U=0,A=n[g]):n[g]>=u?(U=O[n[g]-u],A=R[n[g]-u]):(U=96,A=0),h=1<<w-k,d=1<<y,m=d;do{d-=h,s[c+(z>>k)+d]=D<<24|U<<16|A|0}while(0!==d);for(h=1<<w-1;z&h;)h>>=1;if(0!==h?(z&=h-1,z+=h):z=0,g++,0==--S[w]){if(w===p)break;w=e[a+n[g]]}if(w>b&&(z&_)!==f){for(0===k&&(k=b),c+=m,y=w-k,v=1<<y;y+k<p&&(v-=S[y+k],!(v<=0));)y++,v<<=1;if(x+=1<<y,1===t&&x>852||2===t&&x>592)return 1;f=z&_,s[f]=b<<24|y<<16|c-r|0}}return 0!==z&&(s[c+z]=w-k<<24|64<<16|0),o.bits=b,0};const{Z_FINISH:Ce,Z_BLOCK:Ze,Z_TREES:Le,Z_OK:Me,Z_STREAM_END:Ne,Z_NEED_DICT:Pe,Z_STREAM_ERROR:He,Z_DATA_ERROR:$e,Z_MEM_ERROR:je,Z_BUF_ERROR:Ve,Z_DEFLATED:We}=ft,Ke=16180,Ye=16190,qe=16191,Ge=16192,Xe=16194,Qe=16199,Je=16200,ta=16206,ea=16209,aa=t=>(t>>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24);function ia(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}const sa=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.mode<Ke||e.mode>16211?1:0},ra=t=>{if(sa(t))return He;const e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=1&e.wrap),e.mode=Ke,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(852),e.distcode=e.distdyn=new Int32Array(592),e.sane=1,e.back=-1,Me},na=t=>{if(sa(t))return He;const e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,ra(t)},oa=(t,e)=>{let a;if(sa(t))return He;const i=t.state;return e<0?(a=0,e=-e):(a=5+(e>>4),e<48&&(e&=15)),e&&(e<8||e>15)?He:(null!==i.window&&i.wbits!==e&&(i.window=null),i.wrap=a,i.wbits=e,na(t))},la=(t,e)=>{if(!t)return He;const a=new ia;t.state=a,a.strm=t,a.window=null,a.mode=Ke;const i=oa(t,e);return i!==Me&&(t.state=null),i};let ha,da,fa=!0;const _a=t=>{if(fa){ha=new Int32Array(512),da=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(Te(1,t.lens,0,288,ha,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;Te(2,t.lens,0,32,da,0,t.work,{bits:5}),fa=!1}t.lencode=ha,t.lenbits=9,t.distcode=da,t.distbits=5},ca=(t,e,a,i)=>{let s;const r=t.state;return null===r.window&&(r.wsize=1<<r.wbits,r.wnext=0,r.whave=0,r.window=new Uint8Array(r.wsize)),i>=r.wsize?(r.window.set(e.subarray(a-r.wsize,a),0),r.wnext=0,r.whave=r.wsize):(s=r.wsize-r.wnext,s>i&&(s=i),r.window.set(e.subarray(a-i,a-i+s),r.wnext),(i-=s)?(r.window.set(e.subarray(a-i,a),0),r.wnext=i,r.whave=r.wsize):(r.wnext+=s,r.wnext===r.wsize&&(r.wnext=0),r.whave<r.wsize&&(r.whave+=s))),0};var ua={inflateReset:na,inflateReset2:oa,inflateResetKeep:ra,inflateInit:t=>la(t,15),inflateInit2:la,inflate:(t,e)=>{let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z=0;const R=new Uint8Array(4);let S,E;const D=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(sa(t)||!t.output||!t.input&&0!==t.avail_in)return He;a=t.state,a.mode===qe&&(a.mode=Ge),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,f=o,_=l,x=Me;t:for(;;)switch(a.mode){case Ke:if(0===a.wrap){a.mode=Ge;break}for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(2&a.wrap&&35615===h){0===a.wbits&&(a.wbits=15),a.check=0,R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0),h=0,d=0,a.mode=16181;break}if(a.head&&(a.head.done=!1),!(1&a.wrap)||(((255&h)<<8)+(h>>8))%31){t.msg="incorrect header check",a.mode=ea;break}if((15&h)!==We){t.msg="unknown compression method",a.mode=ea;break}if(h>>>=4,d-=4,v=8+(15&h),0===a.wbits&&(a.wbits=v),v>15||v>a.wbits){t.msg="invalid window size",a.mode=ea;break}a.dmax=1<<a.wbits,a.flags=0,t.adler=a.check=1,a.mode=512&h?16189:qe,h=0,d=0;break;case 16181:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.flags=h,(255&a.flags)!==We){t.msg="unknown compression method",a.mode=ea;break}if(57344&a.flags){t.msg="unknown header flags set",a.mode=ea;break}a.head&&(a.head.text=h>>8&1),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0)),h=0,d=0,a.mode=16182;case 16182:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.time=h),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,R[2]=h>>>16&255,R[3]=h>>>24&255,a.check=ht(a.check,R,4,0)),h=0,d=0,a.mode=16183;case 16183:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.xflags=255&h,a.head.os=h>>8),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0)),h=0,d=0,a.mode=16184;case 16184:if(1024&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length=h,a.head&&(a.head.extra_len=h),512&a.flags&&4&a.wrap&&(R[0]=255&h,R[1]=h>>>8&255,a.check=ht(a.check,R,2,0)),h=0,d=0}else a.head&&(a.head.extra=null);a.mode=16185;case 16185:if(1024&a.flags&&(c=a.length,c>o&&(c=o),c&&(a.head&&(v=a.head.extra_len-a.length,a.head.extra||(a.head.extra=new Uint8Array(a.head.extra_len)),a.head.extra.set(i.subarray(r,r+c),v)),512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,a.length-=c),a.length))break t;a.length=0,a.mode=16186;case 16186:if(2048&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.name+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.name=null);a.length=0,a.mode=16187;case 16187:if(4096&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.comment+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.comment=null);a.mode=16188;case 16188:if(512&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(65535&a.check)){t.msg="header crc mismatch",a.mode=ea;break}h=0,d=0}a.head&&(a.head.hcrc=a.flags>>9&1,a.head.done=!0),t.adler=a.check=0,a.mode=qe;break;case 16189:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}t.adler=a.check=aa(h),h=0,d=0,a.mode=Ye;case Ye:if(0===a.havedict)return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,Pe;t.adler=a.check=1,a.mode=qe;case qe:if(e===Ze||e===Le)break t;case Ge:if(a.last){h>>>=7&d,d-=7&d,a.mode=ta;break}for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}switch(a.last=1&h,h>>>=1,d-=1,3&h){case 0:a.mode=16193;break;case 1:if(_a(a),a.mode=Qe,e===Le){h>>>=2,d-=2;break t}break;case 2:a.mode=16196;break;case 3:t.msg="invalid block type",a.mode=ea}h>>>=2,d-=2;break;case 16193:for(h>>>=7&d,d-=7&d;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if((65535&h)!=(h>>>16^65535)){t.msg="invalid stored block lengths",a.mode=ea;break}if(a.length=65535&h,h=0,d=0,a.mode=Xe,e===Le)break t;case Xe:a.mode=16195;case 16195:if(c=a.length,c){if(c>o&&(c=o),c>l&&(c=l),0===c)break t;s.set(i.subarray(r,r+c),n),o-=c,r+=c,l-=c,n+=c,a.length-=c;break}a.mode=qe;break;case 16196:for(;d<14;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.nlen=257+(31&h),h>>>=5,d-=5,a.ndist=1+(31&h),h>>>=5,d-=5,a.ncode=4+(15&h),h>>>=4,d-=4,a.nlen>286||a.ndist>30){t.msg="too many length or distance symbols",a.mode=ea;break}a.have=0,a.mode=16197;case 16197:for(;a.have<a.ncode;){for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.lens[D[a.have++]]=7&h,h>>>=3,d-=3}for(;a.have<19;)a.lens[D[a.have++]]=0;if(a.lencode=a.lendyn,a.lenbits=7,S={bits:a.lenbits},x=Te(0,a.lens,0,19,a.lencode,0,a.work,S),a.lenbits=S.bits,x){t.msg="invalid code lengths set",a.mode=ea;break}a.have=0,a.mode=16198;case 16198:for(;a.have<a.nlen+a.ndist;){for(;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(p<16)h>>>=g,d-=g,a.lens[a.have++]=p;else{if(16===p){for(E=g+2;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(h>>>=g,d-=g,0===a.have){t.msg="invalid bit length repeat",a.mode=ea;break}v=a.lens[a.have-1],c=3+(3&h),h>>>=2,d-=2}else if(17===p){for(E=g+3;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=3+(7&h),h>>>=3,d-=3}else{for(E=g+7;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=11+(127&h),h>>>=7,d-=7}if(a.have+c>a.nlen+a.ndist){t.msg="invalid bit length repeat",a.mode=ea;break}for(;c--;)a.lens[a.have++]=v}}if(a.mode===ea)break;if(0===a.lens[256]){t.msg="invalid code -- missing end-of-block",a.mode=ea;break}if(a.lenbits=9,S={bits:a.lenbits},x=Te(1,a.lens,0,a.nlen,a.lencode,0,a.work,S),a.lenbits=S.bits,x){t.msg="invalid literal/lengths set",a.mode=ea;break}if(a.distbits=6,a.distcode=a.distdyn,S={bits:a.distbits},x=Te(2,a.lens,a.nlen,a.ndist,a.distcode,0,a.work,S),a.distbits=S.bits,x){t.msg="invalid distances set",a.mode=ea;break}if(a.mode=Qe,e===Le)break t;case Qe:a.mode=Je;case Je:if(o>=6&&l>=258){t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,Ue(t,_),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,a.mode===qe&&(a.back=-1);break}for(a.back=0;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(m&&0==(240&m)){for(b=g,y=m,k=p;z=a.lencode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,a.length=p,0===m){a.mode=16205;break}if(32&m){a.back=-1,a.mode=qe;break}if(64&m){t.msg="invalid literal/length code",a.mode=ea;break}a.extra=15&m,a.mode=16201;case 16201:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}a.was=a.length,a.mode=16202;case 16202:for(;z=a.distcode[h&(1<<a.distbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(0==(240&m)){for(b=g,y=m,k=p;z=a.distcode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,64&m){t.msg="invalid distance code",a.mode=ea;break}a.offset=p,a.extra=15&m,a.mode=16203;case 16203:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.offset+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}if(a.offset>a.dmax){t.msg="invalid distance too far back",a.mode=ea;break}a.mode=16204;case 16204:if(0===l)break t;if(c=_-l,a.offset>c){if(c=a.offset-c,c>a.whave&&a.sane){t.msg="invalid distance too far back",a.mode=ea;break}c>a.wnext?(c-=a.wnext,u=a.wsize-c):u=a.wnext-c,c>a.length&&(c=a.length),w=a.window}else w=s,u=n-a.offset,c=a.length;c>l&&(c=l),l-=c,a.length-=c;do{s[n++]=w[u++]}while(--c);0===a.length&&(a.mode=Je);break;case 16205:if(0===l)break t;s[n++]=a.length,l--,a.mode=Je;break;case ta:if(a.wrap){for(;d<32;){if(0===o)break t;o--,h|=i[r++]<<d,d+=8}if(_-=l,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,n-_):ot(a.check,s,_,n-_)),_=l,4&a.wrap&&(a.flags?h:aa(h))!==a.check){t.msg="incorrect data check",a.mode=ea;break}h=0,d=0}a.mode=16207;case 16207:if(a.wrap&&a.flags){for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(4294967295&a.total)){t.msg="incorrect length check",a.mode=ea;break}h=0,d=0}a.mode=16208;case 16208:x=Ne;break t;case ea:x=$e;break t;case 16210:return je;default:return He}return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,(a.wsize||_!==t.avail_out&&a.mode<ea&&(a.mode<ta||e!==Ce))&&ca(t,t.output,t.next_out,_-t.avail_out),f-=t.avail_in,_-=t.avail_out,t.total_in+=f,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,t.next_out-_):ot(a.check,s,_,t.next_out-_)),t.data_type=a.bits+(a.last?64:0)+(a.mode===qe?128:0)+(a.mode===Qe||a.mode===Xe?256:0),(0===f&&0===_||e===Ce)&&x===Me&&(x=Ve),x},inflateEnd:t=>{if(sa(t))return He;let e=t.state;return e.window&&(e.window=null),t.state=null,Me},inflateGetHeader:(t,e)=>{if(sa(t))return He;const a=t.state;return 0==(2&a.wrap)?He:(a.head=e,e.done=!1,Me)},inflateSetDictionary:(t,e)=>{const a=e.length;let i,s,r;return sa(t)?He:(i=t.state,0!==i.wrap&&i.mode!==Ye?He:i.mode===Ye&&(s=1,s=ot(s,e,a,0),s!==i.check)?$e:(r=ca(t,e,a,a),r?(i.mode=16210,je):(i.havedict=1,Me)))},inflateInfo:"pako inflate (from Nodeca project)"};var wa=function(){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=!1};const ga=Object.prototype.toString,{Z_NO_FLUSH:ma,Z_FINISH:pa,Z_OK:ba,Z_STREAM_END:ya,Z_NEED_DICT:ka,Z_STREAM_ERROR:va,Z_DATA_ERROR:xa,Z_MEM_ERROR:za}=ft;function Ra(t){this.options=de.assign({chunkSize:65536,windowBits:15,to:""},t||{});const e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&0==(15&e.windowBits)&&(e.windowBits|=15),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new ue,this.strm.avail_out=0;let a=ua.inflateInit2(this.strm,e.windowBits);if(a!==ba)throw new Error(dt[a]);if(this.header=new wa,ua.inflateGetHeader(this.strm,this.header),e.dictionary&&("string"==typeof e.dictionary?e.dictionary=ce.string2buf(e.dictionary):"[object ArrayBuffer]"===ga.call(e.dictionary)&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(a=ua.inflateSetDictionary(this.strm,e.dictionary),a!==ba)))throw new Error(dt[a])}Ra.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize,s=this.options.dictionary;let r,n,o;if(this.ended)return!1;for(n=e===~~e?e:!0===e?pa:ma,"[object ArrayBuffer]"===ga.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;){for(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),r=ua.inflate(a,n),r===ka&&s&&(r=ua.inflateSetDictionary(a,s),r===ba?r=ua.inflate(a,n):r===xa&&(r=ka));a.avail_in>0&&r===ya&&a.state.wrap>0&&0!==t[a.next_in];)ua.inflateReset(a),r=ua.inflate(a,n);switch(r){case va:case xa:case ka:case za:return this.onEnd(r),this.ended=!0,!1}if(o=a.avail_out,a.next_out&&(0===a.avail_out||r===ya))if("string"===this.options.to){let t=ce.utf8border(a.output,a.next_out),e=a.next_out-t,s=ce.buf2string(a.output,t);a.next_out=e,a.avail_out=i-e,e&&a.output.set(a.output.subarray(t,t+e),0),this.onData(s)}else this.onData(a.output.length===a.next_out?a.output:a.output.subarray(0,a.next_out));if(r!==ba||0!==o){if(r===ya)return r=ua.inflateEnd(this.strm),this.onEnd(r),this.ended=!0,!0;if(0===a.avail_in)break}}return!0},Ra.prototype.onData=function(t){this.chunks.push(t)},Ra.prototype.onEnd=function(t){t===ba&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=de.flattenChunks(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};const{Deflate:Sa,deflate:Ea,deflateRaw:Da,gzip:Ua}=Ee;var Aa=Ea;const Oa={b:{u:DataView.prototype.getInt8,p:DataView.prototype.setInt8,bytes:1},B:{u:DataView.prototype.getUint8,p:DataView.prototype.setUint8,bytes:1},h:{u:DataView.prototype.getInt16,p:DataView.prototype.setInt16,bytes:2},H:{u:DataView.prototype.getUint16,p:DataView.prototype.setUint16,bytes:2},i:{u:DataView.prototype.getInt32,p:DataView.prototype.setInt32,bytes:4},I:{u:DataView.prototype.getUint32,p:DataView.prototype.setUint32,bytes:4},q:{u:DataView.prototype.getInt64,p:DataView.prototype.setInt64,bytes:8},Q:{u:DataView.prototype.getUint64,p:DataView.prototype.setUint64,bytes:8}},Ia=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let i=[],s=!0;for(let i=0;i<t.length;i++)"<"==t[i]?s=!0:">"==t[i]?s=!1:(r(t[i],e[a]),a++);function r(t,e){if(!(t in Oa))throw"Unhandled character '"+t+"' in pack format";let a=Oa[t].bytes,r=new DataView(new ArrayBuffer(a));Oa[t].p.bind(r)(0,e,s);for(let t=0;t<a;t++)i.push(r.getUint8(t))}return i},Fa=(t,e)=>{let a=0,i=[],s=!0;for(let e of t)"<"==e?s=!0:">"==e?s=!1:r(e);function r(t){if(!(t in Oa))throw"Unhandled character '"+t+"' in unpack format";let r=Oa[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let o=Oa[t].u.bind(n);i.push(o(0,s)),a+=r}return i};class Ba extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this._efuses=new Array(4).fill(0),this._flashsize=4194304,this.debug=!1,this.IS_STUB=!1,this.connected=!0,this.flashSize=null,this.state_DTR=!1}get _inputBuffer(){return this._parent?this._parent._inputBuffer:this.__inputBuffer}async initialize(){await this.hardReset(!0),this._parent||(this.__inputBuffer=[],this.readLoop()),await this.sync();let t=await this.readRegister(1073745920),e=g[t>>>0];if(void 0===e)throw new Error(`Unknown Chip: Hex: ${a(t>>>0,8).toLowerCase()} Number: ${t}`);this.chipName=e.name,this.chipFamily=e.family;let i=y(this.getChipFamily()).macFuse;for(let t=0;t<4;t++)this._efuses[t]=await this.readRegister(i+4*t);this.logger.log(`Chip type ${this.chipName}`)}async readLoop(){this.debug&&this.logger.debug("Starting read loop"),this._reader=this.port.readable.getReader();try{for(;;){const{value:t,done:e}=await this._reader.read();if(e){this._reader.releaseLock();break}t&&0!==t.length&&this._inputBuffer.push(...Array.from(t))}}catch(t){console.error("Read loop got disconnected")}this.connected=!1,this.dispatchEvent(new Event("disconnect")),this.logger.debug("Finished read loop")}sleep(t=100){return new Promise((e=>setTimeout(e,t)))}async setRTS(t){await this.port.setSignals({requestToSend:t}),await this.setDTR(this.state_DTR)}async setDTR(t){this.state_DTR=t,await this.port.setSignals({dataTerminalReady:t})}async hardReset(t=!1){this.logger.log("Try hard reset."),t?4097===this.port.getInfo().usbProductId?(await this.setDTR(!1),await this.setRTS(!1),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(100),await this.setRTS(!0),await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!1),await this.setRTS(!1)):(await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(50),await this.setDTR(!1)):(await this.setRTS(!0),await this.sleep(100),await this.setRTS(!1)),await new Promise((t=>setTimeout(t,1e3)))}macAddr(){let t,e=new Array(6).fill(0),a=this._efuses[0],i=this._efuses[1],s=this._efuses[2],r=this._efuses[3];if(this.chipFamily==o){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(0==(i>>16&255))t=[24,254,52];else{if(1!=(i>>16&255))throw new Error("Couldnt determine OUI");t=[172,208,116]}e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=i>>8&255,e[4]=255&i,e[5]=a>>24&255}else if(this.chipFamily==l)e[0]=s>>8&255,e[1]=255&s,e[2]=i>>24&255,e[3]=i>>16&255,e[4]=i>>8&255,e[5]=255&i;else{if(this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=i>>8&255,e[1]=255&i,e[2]=a>>24&255,e[3]=a>>16&255,e[4]=a>>8&255,e[5]=255&a}return e}async readRegister(t){this.debug&&this.logger.debug("Reading from Register "+a(t,8));let e=Ia("<I",t);await this.sendCommand(10,e);let[i,s]=await this.getResponse(10);return i}async checkCommand(t,e,i=0,s=3e3){s=Math.min(s,12e5),await this.sendCommand(t,e,i);let[r,n]=await this.getResponse(t,s);if(null===n)throw new Error("Didn't get enough status bytes");let g=0;if(this.IS_STUB||this.chipFamily==o?g=2:[l,h,d,f,_,c,u,w].includes(this.chipFamily)?g=4:[2,4].includes(n.length)&&(g=n.length),n.length<g)throw new Error("Didn't get enough status bytes");let m=n.slice(-g,n.length);if(n=n.slice(0,-g),this.debug&&(this.logger.debug("status",m),this.logger.debug("value",r),this.logger.debug("data",n)),1==m[0])throw 5==m[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(m[1]));return[r,n]}async sendCommand(t,e,a=0){let i=(t=>{let e=[192];for(let a of t)219==a?e=e.concat([219,221]):192==a?e=e.concat([219,220]):e.push(a);return e.push(192),e})([...Ia("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${i.length} byte${1==i.length?"":"s"}:`,i),await this.writeToStream(i)}async readPacket(t){let s=null,r=!1,n=[];for(;;){let o=Date.now();for(n=[];Date.now()-o<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await i(10)}if(0==n.length){throw new k("Timed out waiting for packet "+(null===s?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===s){if(192!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid head of packet ("+a(t)+")");s=[]}else if(r)if(r=!1,220==t)s.push(192);else{if(221!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid SLIP escape (0xdb, "+a(t)+")");s.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(s)),s;s.push(t)}}throw new k("Invalid state")}async getResponse(t,e=3e3){for(let i=0;i<100;i++){const i=await this.readPacket(e);if(i.length<8)continue;const[s,r,n,o]=Fa("<BBHI",i.slice(0,8));if(1!=s)continue;const l=i.slice(8);if(null==t||r==t)return[o,l];if(0!=l[0]&&5==l[1])throw this._inputBuffer.length=0,new Error(`Invalid (unsupported) command ${a(t)}`)}throw"Response doesn't match request"}checksum(t,e=239){for(let a of t)e^=a;return e}async setBaudrate(t){if(this.chipFamily==o)throw new Error("Changing baud rate is not supported on the ESP8266");this.logger.log("Attempting to change baud rate to "+t+"...");try{let e=Ia("<II",t,this.IS_STUB?r:0);await this.checkCommand(15,e)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: No response from set baud rate command.`)}this._parent?await this._parent.reconfigurePort(t):await this.reconfigurePort(t)}async reconfigurePort(t){var e;try{await(null===(e=this._reader)||void 0===e?void 0:e.cancel()),await this.port.close(),await this.port.open({baudRate:t}),this.readLoop(),this.logger.log(`Changed baud rate to ${t}`)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: ${e}`)}}async sync(){for(let t=0;t<5;t++){if(this._inputBuffer.length=0,await this._sync())return await i(100),!0;await i(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,n);for(let t=0;t<8;t++)try{let[t,e]=await this.getResponse(8,100);if(e.length>1&&0==e[0]&&0==e[1])return!0}catch(t){}return!1}getFlashWriteSize(){return this.IS_STUB?16384:1024}async flashData(t,e,i=0,s=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],i=r[2],s=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(i)}, FlashSizeFreq=${a(s)}`)}let n,o=t.byteLength,l=0,h=m;s?(n=Aa(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${o}. Compressed Size: ${l}`),h=await this.flashDeflBegin(o,l,i)):(this.logger.log(`Writing data with filesize: ${o}`),n=t,await this.flashBegin(o,i));let d=[],f=0,_=0,c=0,u=Date.now(),w=this.getFlashWriteSize(),g=s?l:o;for(;g-c>0;)this.debug&&this.logger.log(`Writing at ${a(i+f*w,8)} `),g-c>=w?d=Array.from(new Uint8Array(n,c,w)):(d=Array.from(new Uint8Array(n,c,g-c)),s||(d=d.concat(new Array(w-d.length).fill(255)))),s?await this.flashDeflBlock(d,f,h):await this.flashBlock(d,f),f+=1,_+=s?Math.round(d.length*o/l):d.length,c+=w,e(Math.min(_,o),o);this.logger.log("Took "+(Date.now()-u)+"ms to write "+g+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),s?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Ia("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Ia("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,i=!1){let s,r,n=this.getFlashWriteSize();!this.IS_STUB&&[l,h,d,f,_,c,u,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let g,p=Math.floor((t+n-1)/n);s=this.chipFamily==o?this.getEraseSize(e,t):t,g=this.IS_STUB?m:b(3e4,t);let y=Date.now();return r=Ia("<IIII",s,p,n,e),this.chipFamily!=l&&this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w||(r=r.concat(Ia("<I",i?1:0))),this.logger.log("Erase size "+s+", blocks "+p+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(i?"yes":"no")),await this.checkCommand(2,r,0,g),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-y)+"ms to erase "+p+" bytes"),p}async flashDeflBegin(t=0,e=0,a=0,i=!1){let s,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),o=Math.floor((t+r-1)/r),l=0,h=0;return this.IS_STUB?(l=t,h=b(3e4,l)):(l=o*r,h=m),s=Ia("<IIII",l,n,r,a),await this.checkCommand(16,s,0,h),h}async flashFinish(){let t=Ia("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Ia("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return y(this.getChipFamily()).flashOffs}async flashId(){return await this.runSpiFlashCommand(159,[],24)}getChipFamily(){return this._parent?this._parent.chipFamily:this.chipFamily}async writeRegister(t,e,a=4294967295,i=0,s=0){let r=Ia("<IIII",t,e,a,i);s>0&&r.concat(Ia("<IIII",y(this.getChipFamily()).uartDateReg,0,0,s)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let i=t.regBase+t.mosiDlenOffs,s=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(i,e-1),a>0&&await this.writeRegister(s,a-1)}else{let i=t.regBase+t.usr1Offs,s=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(i,s)}}async waitDone(t,e){for(let a=0;a<10;a++){if(0==(await this.readRegister(t)&e))return}throw Error("SPI command did not complete in time")}async runSpiFlashCommand(t,e,i=0){let s=y(this.getChipFamily()),r=s.regBase,n=r,o=r+s.usrOffs,l=r+s.usr2Offs,h=r+s.w0Offs,d=1<<18;if(i>32)throw new Error("Reading more than 32 bits back from a SPI flash operation is unsupported");if(e.length>64)throw new Error("Writing more than 64 bytes of data with one SPI command is unsupported");let f=8*e.length,_=await this.readRegister(o),c=await this.readRegister(l),u=1<<31;if(i>0&&(u|=268435456),f>0&&(u|=134217728),await this.setDataLengths(s,f,i),await this.writeRegister(o,u),await this.writeRegister(l,7<<28|t),0==f)await this.writeRegister(h,0);else{e.concat(new Array(e.length%4).fill(0));let t=Fa("I".repeat(Math.floor(e.length/4)),e),i=h;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(i)}`),await this.writeRegister(i,e),i+=4}await this.writeRegister(n,d),await this.waitDone(n,d);let w=await this.readRegister(h);return await this.writeRegister(o,_),await this.writeRegister(l,c),w}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,i=t>>16&255;this.logger.log(`FlashId: ${a(t)}`),this.logger.log(`Flash Manufacturer: ${e.toString(16)}`),this.logger.log(`Flash Device: ${(t>>8&255).toString(16)}${i.toString(16)}`),this.flashSize=s[i],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,i=Math.floor((e+a-1)/a),s=16-Math.floor(t/a)%16;return i<s&&(s=i),i<2*s?Math.floor((i+1)/2*a):(i-s)*a}async memBegin(t,e,a,i){return await this.checkCommand(5,Ia("<IIII",t,e,a,i))}async memBlock(t,e){return await this.checkCommand(7,Ia("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?m:500,a=Ia("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await v(this.chipFamily);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let i=t[e+"_start"],s=t[e].length,r=Math.floor((s+a-1)/a);await this.memBegin(s,r,a,i);for(let i of Array(r).keys()){let r=i*a,n=r+a;n>s&&(n=s),await this.memBlock(t[e].slice(r,n),i)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const i=await this.readPacket(500);if(e=String.fromCharCode(...i),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const s=new Ta(this.port,this.logger,this);return await s.detectFlashSize(),s}async writeToStream(t){const e=this.port.writable.getWriter();await e.write(new Uint8Array(t));try{e.releaseLock()}catch(t){console.error("Ignoring release lock error",t)}}async disconnect(){this._parent?await this._parent.disconnect():(await this.port.writable.getWriter().close(),await new Promise((t=>{this._reader||t(void 0),this.addEventListener("disconnect",t,{once:!0}),this._reader.cancel()})),this.connected=!1)}}class Ta extends Ba{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,i,s){let r=await v(this.chipFamily),n=s,o=s+t;console.log(n,o),console.log(r.data_start,r.data.length,r.text_start,r.text.length);for(let[t,e]of[[r.data_start,r.data_start+r.data.length],[r.text_start,r.text_start+r.text.length]])if(n<e&&o>t)throw new Error("Software loader is resident at "+a(t,8)+"-"+a(e,8)+". Can't load binary at overlapping address range "+a(n,8)+"-"+a(o,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,p)}}const Ca=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Ba(e,t)};export{l as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,_ as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C6,u as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,h as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,o as CHIP_FAMILY_ESP8266,Ba as ESPLoader,Ca as connect};
|
|
1
|
+
const t=t=>{let e=[];for(let a=0;a<t.length;a++){let i=t.charCodeAt(a);i<=255&&e.push(i)}return e},e=t=>"["+t.map((t=>a(t))).join(", ")+"]",a=(t,e=2)=>{let a=t.toString(16).toUpperCase();return a.startsWith("-")?"-0x"+a.substring(1).padStart(e,"0"):"0x"+a.padStart(e,"0")},i=t=>new Promise((e=>setTimeout(e,t))),s={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),o=33382,l=50,h=12882,d=12883,f=12994,_=12995,c=12998,u=12914,w=12928,g={4293968129:{name:"ESP8266",family:o},15736195:{name:"ESP32",family:l},1990:{name:"ESP32-S2",family:h},9:{name:"ESP32-S3",family:d},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},203546735:{name:"ESP32-C2",family:f},1763790959:{name:"ESP32-C3",family:_},456216687:{name:"ESP32-C3",family:_},1216438383:{name:"ESP32-C3",family:_},1130455151:{name:"ESP32-C3",family:_},3619110528:{name:"ESP32-H2",family:u},752910447:{name:"ESP32-C6",family:c},182303440:{name:"ESP32-P4",family:w},117676761:{name:"ESP32-P4",family:w},0:{name:"ESP32-P4",family:w}},m=3e3,p=6e5,b=(t,e)=>{let a=Math.floor(t*(e/486));return a<m?m:a},y=t=>{switch(t){case l:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case h:return{regBase:1061167104,baseFuse:1061265408,macFuse:1061265476,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612856,flashOffs:4096};case d:return{regBase:1610620928,usrOffs:24,baseFuse:1610641408,macFuse:1610641476,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612864,flashOffs:0};case o:return{regBase:1610613248,usrOffs:28,baseFuse:1072693328,macFuse:1072693328,usr1Offs:32,usr2Offs:36,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:64,uartDateReg:1610612856,flashOffs:0};case f:case _:return{regBase:1610620928,baseFuse:1610647552,macFuse:1610647620,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case c:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case u:return{regBase:1610620928,baseFuse:1610719232,macFuse:1610719300,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case w:return{regBase:1342754816,baseFuse:1343410176,macFuse:1343410244,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1343004812,flashOffs:8192};default:return{regBase:-1,baseFuse:-1,macFuse:-1,usrOffs:-1,usr1Offs:-1,usr2Offs:-1,mosiDlenOffs:-1,misoDlenOffs:-1,w0Offs:-1,uartDateReg:-1,flashOffs:-1}}};class k extends Error{constructor(t){super(t),this.name="SlipReadError"}}const v=async e=>{let a;return e==l?a=await import("./esp32-BLbsWvxO.js"):e==h?a=await import("./esp32s2-CrsP1231.js"):e==d?a=await import("./esp32s3-CiJyd6Fk.js"):e==o?a=await import("./esp8266-CQFcqJ_a.js"):e==f?a=await import("./esp32c2-wLQhZItC.js"):e==_?a=await import("./esp32c3-DmSvHQKL.js"):e==c?a=await import("./esp32c6-ZuxjUVr4.js"):e==u?a=await import("./esp32h2-CZ4EIL3w.js"):e==w&&(a=await import("./esp32p4-Drc2t__U.js")),{...a,text:t(atob(a.text)),data:t(atob(a.data))}};function x(t){let e=t.length;for(;--e>=0;)t[e]=0}const z=256,S=286,R=30,E=15,D=new Uint8Array([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]),U=new Uint8Array([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]),A=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),O=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),I=new Array(576);x(I);const F=new Array(60);x(F);const B=new Array(512);x(B);const T=new Array(256);x(T);const C=new Array(29);x(C);const Z=new Array(R);function L(t,e,a,i,s){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=i,this.max_length=s,this.has_stree=t&&t.length}let P,M,N;function H(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}x(Z);const $=t=>t<256?B[t]:B[256+(t>>>7)],j=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},V=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,j(t,t.bi_buf),t.bi_buf=e>>16-t.bi_valid,t.bi_valid+=a-16):(t.bi_buf|=e<<t.bi_valid&65535,t.bi_valid+=a)},W=(t,e,a)=>{V(t,a[2*e],a[2*e+1])},K=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Y=(t,e,a)=>{const i=new Array(16);let s,r,n=0;for(s=1;s<=E;s++)n=n+a[s-1]<<1,i[s]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=K(i[e]++,e))}},q=t=>{let e;for(e=0;e<S;e++)t.dyn_ltree[2*e]=0;for(e=0;e<R;e++)t.dyn_dtree[2*e]=0;for(e=0;e<19;e++)t.bl_tree[2*e]=0;t.dyn_ltree[512]=1,t.opt_len=t.static_len=0,t.sym_next=t.matches=0},G=t=>{t.bi_valid>8?j(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},X=(t,e,a,i)=>{const s=2*e,r=2*a;return t[s]<t[r]||t[s]===t[r]&&i[e]<=i[a]},Q=(t,e,a)=>{const i=t.heap[a];let s=a<<1;for(;s<=t.heap_len&&(s<t.heap_len&&X(e,t.heap[s+1],t.heap[s],t.depth)&&s++,!X(e,i,t.heap[s],t.depth));)t.heap[a]=t.heap[s],a=s,s<<=1;t.heap[a]=i},J=(t,e,a)=>{let i,s,r,n,o=0;if(0!==t.sym_next)do{i=255&t.pending_buf[t.sym_buf+o++],i+=(255&t.pending_buf[t.sym_buf+o++])<<8,s=t.pending_buf[t.sym_buf+o++],0===i?W(t,s,e):(r=T[s],W(t,r+z+1,e),n=D[r],0!==n&&(s-=C[r],V(t,s,n)),i--,r=$(i),W(t,r,a),n=U[r],0!==n&&(i-=Z[r],V(t,i,n)))}while(o<t.sym_next);W(t,256,e)},tt=(t,e)=>{const a=e.dyn_tree,i=e.stat_desc.static_tree,s=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,o,l,h=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=h=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=h<2?++h:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,s&&(t.static_len-=i[2*l+1]);for(e.max_code=h,n=t.heap_len>>1;n>=1;n--)Q(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],Q(t,a,1),o=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=o,a[2*l]=a[2*n]+a[2*o],t.depth[l]=(t.depth[n]>=t.depth[o]?t.depth[n]:t.depth[o])+1,a[2*n+1]=a[2*o+1]=l,t.heap[1]=l++,Q(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,i=e.max_code,s=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,o=e.stat_desc.extra_base,l=e.stat_desc.max_length;let h,d,f,_,c,u,w=0;for(_=0;_<=E;_++)t.bl_count[_]=0;for(a[2*t.heap[t.heap_max]+1]=0,h=t.heap_max+1;h<573;h++)d=t.heap[h],_=a[2*a[2*d+1]+1]+1,_>l&&(_=l,w++),a[2*d+1]=_,d>i||(t.bl_count[_]++,c=0,d>=o&&(c=n[d-o]),u=a[2*d],t.opt_len+=u*(_+c),r&&(t.static_len+=u*(s[2*d+1]+c)));if(0!==w){do{for(_=l-1;0===t.bl_count[_];)_--;t.bl_count[_]--,t.bl_count[_+1]+=2,t.bl_count[l]--,w-=2}while(w>0);for(_=l;0!==_;_--)for(d=t.bl_count[_];0!==d;)f=t.heap[--h],f>i||(a[2*f+1]!==_&&(t.opt_len+=(_-a[2*f+1])*a[2*f],a[2*f+1]=_),d--)}})(t,e),Y(a,h,t.bl_count)},et=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),e[2*(a+1)+1]=65535,i=0;i<=a;i++)s=n,n=e[2*(i+1)+1],++o<l&&s===n||(o<h?t.bl_tree[2*s]+=o:0!==s?(s!==r&&t.bl_tree[2*s]++,t.bl_tree[32]++):o<=10?t.bl_tree[34]++:t.bl_tree[36]++,o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4))},at=(t,e,a)=>{let i,s,r=-1,n=e[1],o=0,l=7,h=4;for(0===n&&(l=138,h=3),i=0;i<=a;i++)if(s=n,n=e[2*(i+1)+1],!(++o<l&&s===n)){if(o<h)do{W(t,s,t.bl_tree)}while(0!=--o);else 0!==s?(s!==r&&(W(t,s,t.bl_tree),o--),W(t,16,t.bl_tree),V(t,o-3,2)):o<=10?(W(t,17,t.bl_tree),V(t,o-3,3)):(W(t,18,t.bl_tree),V(t,o-11,7));o=0,r=s,0===n?(l=138,h=3):s===n?(l=6,h=3):(l=7,h=4)}};let it=!1;const st=(t,e,a,i)=>{V(t,0+(i?1:0),3),G(t),j(t,a),j(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var rt=(t,e,a,i)=>{let s,r,n=0;t.level>0?(2===t.strm.data_type&&(t.strm.data_type=(t=>{let e,a=4093624447;for(e=0;e<=31;e++,a>>>=1)if(1&a&&0!==t.dyn_ltree[2*e])return 0;if(0!==t.dyn_ltree[18]||0!==t.dyn_ltree[20]||0!==t.dyn_ltree[26])return 1;for(e=32;e<z;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),tt(t,t.l_desc),tt(t,t.d_desc),n=(t=>{let e;for(et(t,t.dyn_ltree,t.l_desc.max_code),et(t,t.dyn_dtree,t.d_desc.max_code),tt(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*O[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),s=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=s&&(s=r)):s=r=a+5,a+4<=s&&-1!==e?st(t,e,a,i):4===t.strategy||r===s?(V(t,2+(i?1:0),3),J(t,I,F)):(V(t,4+(i?1:0),3),((t,e,a,i)=>{let s;for(V(t,e-257,5),V(t,a-1,5),V(t,i-4,4),s=0;s<i;s++)V(t,t.bl_tree[2*O[s]+1],3);at(t,t.dyn_ltree,e-1),at(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),J(t,t.dyn_ltree,t.dyn_dtree)),q(t),i&&G(t)},nt={_tr_init:t=>{it||((()=>{let t,e,a,i,s;const r=new Array(16);for(a=0,i=0;i<28;i++)for(C[i]=a,t=0;t<1<<D[i];t++)T[a++]=i;for(T[a-1]=i,s=0,i=0;i<16;i++)for(Z[i]=s,t=0;t<1<<U[i];t++)B[s++]=i;for(s>>=7;i<R;i++)for(Z[i]=s<<7,t=0;t<1<<U[i]-7;t++)B[256+s++]=i;for(e=0;e<=E;e++)r[e]=0;for(t=0;t<=143;)I[2*t+1]=8,t++,r[8]++;for(;t<=255;)I[2*t+1]=9,t++,r[9]++;for(;t<=279;)I[2*t+1]=7,t++,r[7]++;for(;t<=287;)I[2*t+1]=8,t++,r[8]++;for(Y(I,287,r),t=0;t<R;t++)F[2*t+1]=5,F[2*t]=K(t,5);P=new L(I,D,257,S,E),M=new L(F,U,0,R,E),N=new L(new Array(0),A,0,19,7)})(),it=!0),t.l_desc=new H(t.dyn_ltree,P),t.d_desc=new H(t.dyn_dtree,M),t.bl_desc=new H(t.bl_tree,N),t.bi_buf=0,t.bi_valid=0,q(t)},_tr_stored_block:st,_tr_flush_block:rt,_tr_tally:(t,e,a)=>(t.pending_buf[t.sym_buf+t.sym_next++]=e,t.pending_buf[t.sym_buf+t.sym_next++]=e>>8,t.pending_buf[t.sym_buf+t.sym_next++]=a,0===e?t.dyn_ltree[2*a]++:(t.matches++,e--,t.dyn_ltree[2*(T[a]+z+1)]++,t.dyn_dtree[2*$(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{V(t,2,3),W(t,256,I),(t=>{16===t.bi_valid?(j(t,t.bi_buf),t.bi_buf=0,t.bi_valid=0):t.bi_valid>=8&&(t.pending_buf[t.pending++]=255&t.bi_buf,t.bi_buf>>=8,t.bi_valid-=8)})(t)}};var ot=(t,e,a,i)=>{let s=65535&t,r=t>>>16&65535,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{s=s+e[i++]|0,r=r+s|0}while(--n);s%=65521,r%=65521}return s|r<<16};const lt=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var i=0;i<8;i++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ht=(t,e,a,i)=>{const s=lt,r=i+a;t^=-1;for(let a=i;a<r;a++)t=t>>>8^s[255&(t^e[a])];return~t},dt={2:"need dictionary",1:"stream end",0:"","-1":"file error","-2":"stream error","-3":"data error","-4":"insufficient memory","-5":"buffer error","-6":"incompatible version"},ft={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,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_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,Z_BINARY:0,Z_TEXT:1,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:_t,_tr_stored_block:ct,_tr_flush_block:ut,_tr_tally:wt,_tr_align:gt}=nt,{Z_NO_FLUSH:mt,Z_PARTIAL_FLUSH:pt,Z_FULL_FLUSH:bt,Z_FINISH:yt,Z_BLOCK:kt,Z_OK:vt,Z_STREAM_END:xt,Z_STREAM_ERROR:zt,Z_DATA_ERROR:St,Z_BUF_ERROR:Rt,Z_DEFAULT_COMPRESSION:Et,Z_FILTERED:Dt,Z_HUFFMAN_ONLY:Ut,Z_RLE:At,Z_FIXED:Ot,Z_DEFAULT_STRATEGY:It,Z_UNKNOWN:Ft,Z_DEFLATED:Bt}=ft,Tt=258,Ct=262,Zt=42,Lt=113,Pt=666,Mt=(t,e)=>(t.msg=dt[e],e),Nt=t=>2*t-(t>4?9:0),Ht=t=>{let e=t.length;for(;--e>=0;)t[e]=0},$t=t=>{let e,a,i,s=t.w_size;e=t.hash_size,i=e;do{a=t.head[--i],t.head[i]=a>=s?a-s:0}while(--e);e=s,i=e;do{a=t.prev[--i],t.prev[i]=a>=s?a-s:0}while(--e)};let jt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Vt=t=>{const e=t.state;let a=e.pending;a>t.avail_out&&(a=t.avail_out),0!==a&&(t.output.set(e.pending_buf.subarray(e.pending_out,e.pending_out+a),t.next_out),t.next_out+=a,e.pending_out+=a,t.total_out+=a,t.avail_out-=a,e.pending-=a,0===e.pending&&(e.pending_out=0))},Wt=(t,e)=>{ut(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Vt(t.strm)},Kt=(t,e)=>{t.pending_buf[t.pending++]=e},Yt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},qt=(t,e,a,i)=>{let s=t.avail_in;return s>i&&(s=i),0===s?0:(t.avail_in-=s,e.set(t.input.subarray(t.next_in,t.next_in+s),a),1===t.state.wrap?t.adler=ot(t.adler,e,s,a):2===t.state.wrap&&(t.adler=ht(t.adler,e,s,a)),t.next_in+=s,t.total_in+=s,s)},Gt=(t,e)=>{let a,i,s=t.max_chain_length,r=t.strstart,n=t.prev_length,o=t.nice_match;const l=t.strstart>t.w_size-Ct?t.strstart-(t.w_size-Ct):0,h=t.window,d=t.w_mask,f=t.prev,_=t.strstart+Tt;let c=h[r+n-1],u=h[r+n];t.prev_length>=t.good_match&&(s>>=2),o>t.lookahead&&(o=t.lookahead);do{if(a=e,h[a+n]===u&&h[a+n-1]===c&&h[a]===h[r]&&h[++a]===h[r+1]){r+=2,a++;do{}while(h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&h[++r]===h[++a]&&r<_);if(i=Tt-(_-r),r=_-Tt,i>n){if(t.match_start=e,n=i,i>=o)break;c=h[r+n-1],u=h[r+n]}}}while((e=f[e&d])>l&&0!=--s);return n<=t.lookahead?n:t.lookahead},Xt=t=>{const e=t.w_size;let a,i,s;do{if(i=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-Ct)&&(t.window.set(t.window.subarray(e,e+e-i),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),$t(t),i+=e),0===t.strm.avail_in)break;if(a=qt(t.strm,t.window,t.strstart+t.lookahead,i),t.lookahead+=a,t.lookahead+t.insert>=3)for(s=t.strstart-t.insert,t.ins_h=t.window[s],t.ins_h=jt(t,t.ins_h,t.window[s+1]);t.insert&&(t.ins_h=jt(t,t.ins_h,t.window[s+3-1]),t.prev[s&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=s,s++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<Ct&&0!==t.strm.avail_in)},Qt=(t,e)=>{let a,i,s,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,o=t.strm.avail_in;do{if(a=65535,s=t.bi_valid+42>>3,t.strm.avail_out<s)break;if(s=t.strm.avail_out-s,i=t.strstart-t.block_start,a>i+t.strm.avail_in&&(a=i+t.strm.avail_in),a>s&&(a=s),a<r&&(0===a&&e!==yt||e===mt||a!==i+t.strm.avail_in))break;n=e===yt&&a===i+t.strm.avail_in?1:0,ct(t,0,0,n),t.pending_buf[t.pending-4]=a,t.pending_buf[t.pending-3]=a>>8,t.pending_buf[t.pending-2]=~a,t.pending_buf[t.pending-1]=~a>>8,Vt(t.strm),i&&(i>a&&(i=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+i),t.strm.next_out),t.strm.next_out+=i,t.strm.avail_out-=i,t.strm.total_out+=i,t.block_start+=i,a-=i),a&&(qt(t.strm,t.strm.output,t.strm.next_out,a),t.strm.next_out+=a,t.strm.avail_out-=a,t.strm.total_out+=a)}while(0===n);return o-=t.strm.avail_in,o&&(o>=t.w_size?(t.matches=2,t.window.set(t.strm.input.subarray(t.strm.next_in-t.w_size,t.strm.next_in),0),t.strstart=t.w_size,t.insert=t.strstart):(t.window_size-t.strstart<=o&&(t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,t.insert>t.strstart&&(t.insert=t.strstart)),t.window.set(t.strm.input.subarray(t.strm.next_in-o,t.strm.next_in),t.strstart),t.strstart+=o,t.insert+=o>t.w_size-t.insert?t.w_size-t.insert:o),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==mt&&e!==yt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(s=t.window_size-t.strstart,t.strm.avail_in>s&&t.block_start>=t.w_size&&(t.block_start-=t.w_size,t.strstart-=t.w_size,t.window.set(t.window.subarray(t.w_size,t.w_size+t.strstart),0),t.matches<2&&t.matches++,s+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),s>t.strm.avail_in&&(s=t.strm.avail_in),s&&(qt(t.strm,t.window,t.strstart,s),t.strstart+=s,t.insert+=s>t.w_size-t.insert?t.w_size-t.insert:s),t.high_water<t.strstart&&(t.high_water=t.strstart),s=t.bi_valid+42>>3,s=t.pending_buf_size-s>65535?65535:t.pending_buf_size-s,r=s>t.w_size?t.w_size:s,i=t.strstart-t.block_start,(i>=r||(i||e===yt)&&e!==mt&&0===t.strm.avail_in&&i<=s)&&(a=i>s?s:i,n=e===yt&&0===t.strm.avail_in&&a===i?1:0,ct(t,t.block_start,a,n),t.block_start+=a,Vt(t.strm)),n?3:1)},Jt=(t,e)=>{let a,i;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),0!==a&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a)),t.match_length>=3)if(i=wt(t,t.strstart-t.match_start,t.match_length-3),t.lookahead-=t.match_length,t.match_length<=t.max_lazy_match&&t.lookahead>=3){t.match_length--;do{t.strstart++,t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart}while(0!=--t.match_length);t.strstart++}else t.strstart+=t.match_length,t.match_length=0,t.ins_h=t.window[t.strstart],t.ins_h=jt(t,t.ins_h,t.window[t.strstart+1]);else i=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(i&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2},te=(t,e)=>{let a,i,s;for(;;){if(t.lookahead<Ct){if(Xt(t),t.lookahead<Ct&&e===mt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart),t.prev_length=t.match_length,t.prev_match=t.match_start,t.match_length=2,0!==a&&t.prev_length<t.max_lazy_match&&t.strstart-a<=t.w_size-Ct&&(t.match_length=Gt(t,a),t.match_length<=5&&(t.strategy===Dt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){s=t.strstart+t.lookahead-3,i=wt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=s&&(t.ins_h=jt(t,t.ins_h,t.window[t.strstart+3-1]),a=t.prev[t.strstart&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=t.strstart)}while(0!=--t.prev_length);if(t.match_available=0,t.match_length=2,t.strstart++,i&&(Wt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(i=wt(t,0,t.window[t.strstart-1]),i&&Wt(t,!1),t.strstart++,t.lookahead--,0===t.strm.avail_out)return 1}else t.match_available=1,t.strstart++,t.lookahead--}return t.match_available&&(i=wt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2};function ee(t,e,a,i,s){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=i,this.func=s}const ae=[new ee(0,0,0,0,Qt),new ee(4,4,8,4,Jt),new ee(4,5,16,8,Jt),new ee(4,6,32,32,Jt),new ee(4,4,16,16,te),new ee(8,16,32,32,te),new ee(8,16,128,128,te),new ee(8,32,128,256,te),new ee(32,128,258,1024,te),new ee(32,258,258,4096,te)];function ie(){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=Bt,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 Uint16Array(1146),this.dyn_dtree=new Uint16Array(122),this.bl_tree=new Uint16Array(78),Ht(this.dyn_ltree),Ht(this.dyn_dtree),Ht(this.bl_tree),this.l_desc=null,this.d_desc=null,this.bl_desc=null,this.bl_count=new Uint16Array(16),this.heap=new Uint16Array(573),Ht(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Ht(this.depth),this.sym_buf=0,this.lit_bufsize=0,this.sym_next=0,this.sym_end=0,this.opt_len=0,this.static_len=0,this.matches=0,this.insert=0,this.bi_buf=0,this.bi_valid=0}const se=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Zt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Lt&&e.status!==Pt?1:0},re=t=>{if(se(t))return Mt(t,zt);t.total_in=t.total_out=0,t.data_type=Ft;const e=t.state;return e.pending=0,e.pending_out=0,e.wrap<0&&(e.wrap=-e.wrap),e.status=2===e.wrap?57:e.wrap?Zt:Lt,t.adler=2===e.wrap?0:1,e.last_flush=-2,_t(e),vt},ne=t=>{const e=re(t);var a;return e===vt&&((a=t.state).window_size=2*a.w_size,Ht(a.head),a.max_lazy_match=ae[a.level].max_lazy,a.good_match=ae[a.level].good_length,a.nice_match=ae[a.level].nice_length,a.max_chain_length=ae[a.level].max_chain,a.strstart=0,a.block_start=0,a.lookahead=0,a.insert=0,a.match_length=a.prev_length=2,a.match_available=0,a.ins_h=0),e},oe=(t,e,a,i,s,r)=>{if(!t)return zt;let n=1;if(e===Et&&(e=6),i<0?(n=0,i=-i):i>15&&(n=2,i-=16),s<1||s>9||a!==Bt||i<8||i>15||e<0||e>9||r<0||r>Ot||8===i&&1!==n)return Mt(t,zt);8===i&&(i=9);const o=new ie;return t.state=o,o.strm=t,o.status=Zt,o.wrap=n,o.gzhead=null,o.w_bits=i,o.w_size=1<<o.w_bits,o.w_mask=o.w_size-1,o.hash_bits=s+7,o.hash_size=1<<o.hash_bits,o.hash_mask=o.hash_size-1,o.hash_shift=~~((o.hash_bits+3-1)/3),o.window=new Uint8Array(2*o.w_size),o.head=new Uint16Array(o.hash_size),o.prev=new Uint16Array(o.w_size),o.lit_bufsize=1<<s+6,o.pending_buf_size=4*o.lit_bufsize,o.pending_buf=new Uint8Array(o.pending_buf_size),o.sym_buf=o.lit_bufsize,o.sym_end=3*(o.lit_bufsize-1),o.level=e,o.strategy=r,o.method=a,ne(t)};var le={deflateInit:(t,e)=>oe(t,e,Bt,15,8,It),deflateInit2:oe,deflateReset:ne,deflateResetKeep:re,deflateSetHeader:(t,e)=>se(t)||2!==t.state.wrap?zt:(t.state.gzhead=e,vt),deflate:(t,e)=>{if(se(t)||e>kt||e<0)return t?Mt(t,zt):zt;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Pt&&e!==yt)return Mt(t,0===t.avail_out?Rt:zt);const i=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Vt(t),0===t.avail_out)return a.last_flush=-1,vt}else if(0===t.avail_in&&Nt(e)<=Nt(i)&&e!==yt)return Mt(t,Rt);if(a.status===Pt&&0!==t.avail_in)return Mt(t,Rt);if(a.status===Zt&&0===a.wrap&&(a.status=Lt),a.status===Zt){let e=Bt+(a.w_bits-8<<4)<<8,i=-1;if(i=a.strategy>=Ut||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=i<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Yt(a,e),0!==a.strstart&&(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),t.adler=1,a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(57===a.status)if(t.adler=0,Kt(a,31),Kt(a,139),Kt(a,8),a.gzhead)Kt(a,(a.gzhead.text?1:0)+(a.gzhead.hcrc?2:0)+(a.gzhead.extra?4:0)+(a.gzhead.name?8:0)+(a.gzhead.comment?16:0)),Kt(a,255&a.gzhead.time),Kt(a,a.gzhead.time>>8&255),Kt(a,a.gzhead.time>>16&255),Kt(a,a.gzhead.time>>24&255),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Kt(a,255&a.gzhead.extra.length),Kt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ht(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,0),Kt(a,9===a.level?2:a.strategy>=Ut||a.level<2?4:0),Kt(a,3),a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt;if(69===a.status){if(a.gzhead.extra){let e=a.pending,i=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+i>a.pending_buf_size;){let s=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=s,Vt(t),0!==a.pending)return a.last_flush=-1,vt;e=0,i-=s}let s=new Uint8Array(a.gzhead.extra);a.pending_buf.set(s.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending+=i,a.gzhead.hcrc&&a.pending>e&&(t.adler=ht(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex=0}a.status=73}if(73===a.status){if(a.gzhead.name){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,i=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i)),Vt(t),0!==a.pending)return a.last_flush=-1,vt;i=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Kt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>i&&(t.adler=ht(t.adler,a.pending_buf,a.pending-i,i))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Vt(t),0!==a.pending))return a.last_flush=-1,vt;Kt(a,255&t.adler),Kt(a,t.adler>>8&255),t.adler=0}if(a.status=Lt,Vt(t),0!==a.pending)return a.last_flush=-1,vt}if(0!==t.avail_in||0!==a.lookahead||e!==mt&&a.status!==Pt){let i=0===a.level?Qt(a,e):a.strategy===Ut?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(Xt(t),0===t.lookahead)){if(e===mt)return 1;break}if(t.match_length=0,a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===At?((t,e)=>{let a,i,s,r;const n=t.window;for(;;){if(t.lookahead<=Tt){if(Xt(t),t.lookahead<=Tt&&e===mt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(s=t.strstart-1,i=n[s],i===n[++s]&&i===n[++s]&&i===n[++s])){r=t.strstart+Tt;do{}while(i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&i===n[++s]&&s<r);t.match_length=Tt-(r-s),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=wt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=wt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(Wt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===yt?(Wt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(Wt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ae[a.level].func(a,e);if(3!==i&&4!==i||(a.status=Pt),1===i||3===i)return 0===t.avail_out&&(a.last_flush=-1),vt;if(2===i&&(e===pt?gt(a):e!==kt&&(ct(a,0,0,!1),e===bt&&(Ht(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Vt(t),0===t.avail_out))return a.last_flush=-1,vt}return e!==yt?vt:a.wrap<=0?xt:(2===a.wrap?(Kt(a,255&t.adler),Kt(a,t.adler>>8&255),Kt(a,t.adler>>16&255),Kt(a,t.adler>>24&255),Kt(a,255&t.total_in),Kt(a,t.total_in>>8&255),Kt(a,t.total_in>>16&255),Kt(a,t.total_in>>24&255)):(Yt(a,t.adler>>>16),Yt(a,65535&t.adler)),Vt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?vt:xt)},deflateEnd:t=>{if(se(t))return zt;const e=t.state.status;return t.state=null,e===Lt?Mt(t,St):vt},deflateSetDictionary:(t,e)=>{let a=e.length;if(se(t))return zt;const i=t.state,s=i.wrap;if(2===s||1===s&&i.status!==Zt||i.lookahead)return zt;if(1===s&&(t.adler=ot(t.adler,e,a,0)),i.wrap=0,a>=i.w_size){0===s&&(Ht(i.head),i.strstart=0,i.block_start=0,i.insert=0);let t=new Uint8Array(i.w_size);t.set(e.subarray(a-i.w_size,a),0),e=t,a=i.w_size}const r=t.avail_in,n=t.next_in,o=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,Xt(i);i.lookahead>=3;){let t=i.strstart,e=i.lookahead-2;do{i.ins_h=jt(i,i.ins_h,i.window[t+3-1]),i.prev[t&i.w_mask]=i.head[i.ins_h],i.head[i.ins_h]=t,t++}while(--e);i.strstart=t,i.lookahead=2,Xt(i)}return i.strstart+=i.lookahead,i.block_start=i.strstart,i.insert=i.lookahead,i.lookahead=0,i.match_length=i.prev_length=2,i.match_available=0,t.next_in=n,t.input=o,t.avail_in=r,i.wrap=s,vt},deflateInfo:"pako deflate (from Nodeca project)"};const he=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var de=function(t){const e=Array.prototype.slice.call(arguments,1);for(;e.length;){const a=e.shift();if(a){if("object"!=typeof a)throw new TypeError(a+"must be non-object");for(const e in a)he(a,e)&&(t[e]=a[e])}}return t},fe=t=>{let e=0;for(let a=0,i=t.length;a<i;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,i=0,s=t.length;e<s;e++){let s=t[e];a.set(s,i),i+=s.length}return a};let _e=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){_e=!1}const ce=new Uint8Array(256);for(let t=0;t<256;t++)ce[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;ce[254]=ce[254]=1;var ue=t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,i,s,r,n=t.length,o=0;for(s=0;s<n;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),o+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(o),r=0,s=0;r<o;s++)a=t.charCodeAt(s),55296==(64512&a)&&s+1<n&&(i=t.charCodeAt(s+1),56320==(64512&i)&&(a=65536+(a-55296<<10)+(i-56320),s++)),a<128?e[r++]=a:a<2048?(e[r++]=192|a>>>6,e[r++]=128|63&a):a<65536?(e[r++]=224|a>>>12,e[r++]=128|a>>>6&63,e[r++]=128|63&a):(e[r++]=240|a>>>18,e[r++]=128|a>>>12&63,e[r++]=128|a>>>6&63,e[r++]=128|63&a);return e},we=(t,e)=>{const a=e||t.length;if("function"==typeof TextDecoder&&TextDecoder.prototype.decode)return(new TextDecoder).decode(t.subarray(0,e));let i,s;const r=new Array(2*a);for(s=0,i=0;i<a;){let e=t[i++];if(e<128){r[s++]=e;continue}let n=ce[e];if(n>4)r[s++]=65533,i+=n-1;else{for(e&=2===n?31:3===n?15:7;n>1&&i<a;)e=e<<6|63&t[i++],n--;n>1?r[s++]=65533:e<65536?r[s++]=e:(e-=65536,r[s++]=55296|e>>10&1023,r[s++]=56320|1023&e)}}return((t,e)=>{if(e<65534&&t.subarray&&_e)return String.fromCharCode.apply(null,t.length===e?t:t.subarray(0,e));let a="";for(let i=0;i<e;i++)a+=String.fromCharCode(t[i]);return a})(r,s)},ge=(t,e)=>{(e=e||t.length)>t.length&&(e=t.length);let a=e-1;for(;a>=0&&128==(192&t[a]);)a--;return a<0||0===a?e:a+ce[t[a]]>e?a:e};var me=function(){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};const pe=Object.prototype.toString,{Z_NO_FLUSH:be,Z_SYNC_FLUSH:ye,Z_FULL_FLUSH:ke,Z_FINISH:ve,Z_OK:xe,Z_STREAM_END:ze,Z_DEFAULT_COMPRESSION:Se,Z_DEFAULT_STRATEGY:Re,Z_DEFLATED:Ee}=ft;function De(t){this.options=de({level:Se,method:Ee,chunkSize:16384,windowBits:15,memLevel:8,strategy:Re},t||{});let e=this.options;e.raw&&e.windowBits>0?e.windowBits=-e.windowBits:e.gzip&&e.windowBits>0&&e.windowBits<16&&(e.windowBits+=16),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new me,this.strm.avail_out=0;let a=le.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==xe)throw new Error(dt[a]);if(e.header&&le.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?ue(e.dictionary):"[object ArrayBuffer]"===pe.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=le.deflateSetDictionary(this.strm,t),a!==xe)throw new Error(dt[a]);this._dict_set=!0}}function Ue(t,e){const a=new De(e);if(a.push(t,!0),a.err)throw a.msg||dt[a.err];return a.result}De.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize;let s,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?ve:be,"string"==typeof t?a.input=ue(t):"[object ArrayBuffer]"===pe.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;)if(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),(r===ye||r===ke)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(s=le.deflate(a,r),s===ze)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),s=le.deflateEnd(this.strm),this.onEnd(s),this.ended=!0,s===xe;if(0!==a.avail_out){if(r>0&&a.next_out>0)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else if(0===a.avail_in)break}else this.onData(a.output)}return!0},De.prototype.onData=function(t){this.chunks.push(t)},De.prototype.onEnd=function(t){t===xe&&(this.result=fe(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Ae={Deflate:De,deflate:Ue,deflateRaw:function(t,e){return(e=e||{}).raw=!0,Ue(t,e)},gzip:function(t,e){return(e=e||{}).gzip=!0,Ue(t,e)},constants:ft};const Oe=16209;var Ie=function(t,e){let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z,S;const R=t.state;a=t.next_in,z=t.input,i=a+(t.avail_in-5),s=t.next_out,S=t.output,r=s-(e-t.avail_out),n=s+(t.avail_out-257),o=R.dmax,l=R.wsize,h=R.whave,d=R.wnext,f=R.window,_=R.hold,c=R.bits,u=R.lencode,w=R.distcode,g=(1<<R.lenbits)-1,m=(1<<R.distbits)-1;t:do{c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=u[_&g];e:for(;;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,0===b)S[s++]=65535&p;else{if(!(16&b)){if(64&b){if(32&b){R.mode=16191;break t}t.msg="invalid literal/length code",R.mode=Oe;break t}p=u[(65535&p)+(_&(1<<b)-1)];continue e}for(y=65535&p,b&=15,b&&(c<b&&(_+=z[a++]<<c,c+=8),y+=_&(1<<b)-1,_>>>=b,c-=b),c<15&&(_+=z[a++]<<c,c+=8,_+=z[a++]<<c,c+=8),p=w[_&m];;){if(b=p>>>24,_>>>=b,c-=b,b=p>>>16&255,16&b){if(k=65535&p,b&=15,c<b&&(_+=z[a++]<<c,c+=8,c<b&&(_+=z[a++]<<c,c+=8)),k+=_&(1<<b)-1,k>o){t.msg="invalid distance too far back",R.mode=Oe;break t}if(_>>>=b,c-=b,b=s-r,k>b){if(b=k-b,b>h&&R.sane){t.msg="invalid distance too far back",R.mode=Oe;break t}if(v=0,x=f,0===d){if(v+=l-b,b<y){y-=b;do{S[s++]=f[v++]}while(--b);v=s-k,x=S}}else if(d<b){if(v+=l+d-b,b-=d,b<y){y-=b;do{S[s++]=f[v++]}while(--b);if(v=0,d<y){b=d,y-=b;do{S[s++]=f[v++]}while(--b);v=s-k,x=S}}}else if(v+=d-b,b<y){y-=b;do{S[s++]=f[v++]}while(--b);v=s-k,x=S}for(;y>2;)S[s++]=x[v++],S[s++]=x[v++],S[s++]=x[v++],y-=3;y&&(S[s++]=x[v++],y>1&&(S[s++]=x[v++]))}else{v=s-k;do{S[s++]=S[v++],S[s++]=S[v++],S[s++]=S[v++],y-=3}while(y>2);y&&(S[s++]=S[v++],y>1&&(S[s++]=S[v++]))}break}if(64&b){t.msg="invalid distance code",R.mode=Oe;break t}p=w[(65535&p)+(_&(1<<b)-1)]}}break}}while(a<i&&s<n);y=c>>3,a-=y,c-=y<<3,_&=(1<<c)-1,t.next_in=a,t.next_out=s,t.avail_in=a<i?i-a+5:5-(a-i),t.avail_out=s<n?n-s+257:257-(s-n),R.hold=_,R.bits=c};const Fe=15,Be=new Uint16Array([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]),Te=new Uint8Array([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]),Ce=new Uint16Array([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]),Ze=new Uint8Array([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]);var Le=(t,e,a,i,s,r,n,o)=>{const l=o.bits;let h,d,f,_,c,u,w=0,g=0,m=0,p=0,b=0,y=0,k=0,v=0,x=0,z=0,S=null;const R=new Uint16Array(16),E=new Uint16Array(16);let D,U,A,O=null;for(w=0;w<=Fe;w++)R[w]=0;for(g=0;g<i;g++)R[e[a+g]]++;for(b=l,p=Fe;p>=1&&0===R[p];p--);if(b>p&&(b=p),0===p)return s[r++]=20971520,s[r++]=20971520,o.bits=1,0;for(m=1;m<p&&0===R[m];m++);for(b<m&&(b=m),v=1,w=1;w<=Fe;w++)if(v<<=1,v-=R[w],v<0)return-1;if(v>0&&(0===t||1!==p))return-1;for(E[1]=0,w=1;w<Fe;w++)E[w+1]=E[w]+R[w];for(g=0;g<i;g++)0!==e[a+g]&&(n[E[e[a+g]]++]=g);if(0===t?(S=O=n,u=20):1===t?(S=Be,O=Te,u=257):(S=Ce,O=Ze,u=0),z=0,g=0,w=m,c=r,y=b,k=0,f=-1,x=1<<b,_=x-1,1===t&&x>852||2===t&&x>592)return 1;for(;;){D=w-k,n[g]+1<u?(U=0,A=n[g]):n[g]>=u?(U=O[n[g]-u],A=S[n[g]-u]):(U=96,A=0),h=1<<w-k,d=1<<y,m=d;do{d-=h,s[c+(z>>k)+d]=D<<24|U<<16|A}while(0!==d);for(h=1<<w-1;z&h;)h>>=1;if(0!==h?(z&=h-1,z+=h):z=0,g++,0==--R[w]){if(w===p)break;w=e[a+n[g]]}if(w>b&&(z&_)!==f){for(0===k&&(k=b),c+=m,y=w-k,v=1<<y;y+k<p&&(v-=R[y+k],!(v<=0));)y++,v<<=1;if(x+=1<<y,1===t&&x>852||2===t&&x>592)return 1;f=z&_,s[f]=b<<24|y<<16|c-r}}return 0!==z&&(s[c+z]=w-k<<24|64<<16),o.bits=b,0};const{Z_FINISH:Pe,Z_BLOCK:Me,Z_TREES:Ne,Z_OK:He,Z_STREAM_END:$e,Z_NEED_DICT:je,Z_STREAM_ERROR:Ve,Z_DATA_ERROR:We,Z_MEM_ERROR:Ke,Z_BUF_ERROR:Ye,Z_DEFLATED:qe}=ft,Ge=16180,Xe=16190,Qe=16191,Je=16192,ta=16194,ea=16199,aa=16200,ia=16206,sa=16209,ra=t=>(t>>>24&255)+(t>>>8&65280)+((65280&t)<<8)+((255&t)<<24);function na(){this.strm=null,this.mode=0,this.last=!1,this.wrap=0,this.havedict=!1,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 Uint16Array(320),this.work=new Uint16Array(288),this.lendyn=null,this.distdyn=null,this.sane=0,this.back=0,this.was=0}const oa=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.mode<Ge||e.mode>16211?1:0},la=t=>{if(oa(t))return Ve;const e=t.state;return t.total_in=t.total_out=e.total=0,t.msg="",e.wrap&&(t.adler=1&e.wrap),e.mode=Ge,e.last=0,e.havedict=0,e.flags=-1,e.dmax=32768,e.head=null,e.hold=0,e.bits=0,e.lencode=e.lendyn=new Int32Array(852),e.distcode=e.distdyn=new Int32Array(592),e.sane=1,e.back=-1,He},ha=t=>{if(oa(t))return Ve;const e=t.state;return e.wsize=0,e.whave=0,e.wnext=0,la(t)},da=(t,e)=>{let a;if(oa(t))return Ve;const i=t.state;return e<0?(a=0,e=-e):(a=5+(e>>4),e<48&&(e&=15)),e&&(e<8||e>15)?Ve:(null!==i.window&&i.wbits!==e&&(i.window=null),i.wrap=a,i.wbits=e,ha(t))},fa=(t,e)=>{if(!t)return Ve;const a=new na;t.state=a,a.strm=t,a.window=null,a.mode=Ge;const i=da(t,e);return i!==He&&(t.state=null),i};let _a,ca,ua=!0;const wa=t=>{if(ua){_a=new Int32Array(512),ca=new Int32Array(32);let e=0;for(;e<144;)t.lens[e++]=8;for(;e<256;)t.lens[e++]=9;for(;e<280;)t.lens[e++]=7;for(;e<288;)t.lens[e++]=8;for(Le(1,t.lens,0,288,_a,0,t.work,{bits:9}),e=0;e<32;)t.lens[e++]=5;Le(2,t.lens,0,32,ca,0,t.work,{bits:5}),ua=!1}t.lencode=_a,t.lenbits=9,t.distcode=ca,t.distbits=5},ga=(t,e,a,i)=>{let s;const r=t.state;return null===r.window&&(r.wsize=1<<r.wbits,r.wnext=0,r.whave=0,r.window=new Uint8Array(r.wsize)),i>=r.wsize?(r.window.set(e.subarray(a-r.wsize,a),0),r.wnext=0,r.whave=r.wsize):(s=r.wsize-r.wnext,s>i&&(s=i),r.window.set(e.subarray(a-i,a-i+s),r.wnext),(i-=s)?(r.window.set(e.subarray(a-i,a),0),r.wnext=i,r.whave=r.wsize):(r.wnext+=s,r.wnext===r.wsize&&(r.wnext=0),r.whave<r.wsize&&(r.whave+=s))),0};var ma={inflateReset:ha,inflateReset2:da,inflateResetKeep:la,inflateInit:t=>fa(t,15),inflateInit2:fa,inflate:(t,e)=>{let a,i,s,r,n,o,l,h,d,f,_,c,u,w,g,m,p,b,y,k,v,x,z=0;const S=new Uint8Array(4);let R,E;const D=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]);if(oa(t)||!t.output||!t.input&&0!==t.avail_in)return Ve;a=t.state,a.mode===Qe&&(a.mode=Je),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,f=o,_=l,x=He;t:for(;;)switch(a.mode){case Ge:if(0===a.wrap){a.mode=Je;break}for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(2&a.wrap&&35615===h){0===a.wbits&&(a.wbits=15),a.check=0,S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0),h=0,d=0,a.mode=16181;break}if(a.head&&(a.head.done=!1),!(1&a.wrap)||(((255&h)<<8)+(h>>8))%31){t.msg="incorrect header check",a.mode=sa;break}if((15&h)!==qe){t.msg="unknown compression method",a.mode=sa;break}if(h>>>=4,d-=4,v=8+(15&h),0===a.wbits&&(a.wbits=v),v>15||v>a.wbits){t.msg="invalid window size",a.mode=sa;break}a.dmax=1<<a.wbits,a.flags=0,t.adler=a.check=1,a.mode=512&h?16189:Qe,h=0,d=0;break;case 16181:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.flags=h,(255&a.flags)!==qe){t.msg="unknown compression method",a.mode=sa;break}if(57344&a.flags){t.msg="unknown header flags set",a.mode=sa;break}a.head&&(a.head.text=h>>8&1),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0)),h=0,d=0,a.mode=16182;case 16182:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.time=h),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,S[2]=h>>>16&255,S[3]=h>>>24&255,a.check=ht(a.check,S,4,0)),h=0,d=0,a.mode=16183;case 16183:for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.head&&(a.head.xflags=255&h,a.head.os=h>>8),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0)),h=0,d=0,a.mode=16184;case 16184:if(1024&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length=h,a.head&&(a.head.extra_len=h),512&a.flags&&4&a.wrap&&(S[0]=255&h,S[1]=h>>>8&255,a.check=ht(a.check,S,2,0)),h=0,d=0}else a.head&&(a.head.extra=null);a.mode=16185;case 16185:if(1024&a.flags&&(c=a.length,c>o&&(c=o),c&&(a.head&&(v=a.head.extra_len-a.length,a.head.extra||(a.head.extra=new Uint8Array(a.head.extra_len)),a.head.extra.set(i.subarray(r,r+c),v)),512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,a.length-=c),a.length))break t;a.length=0,a.mode=16186;case 16186:if(2048&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.name+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.name=null);a.length=0,a.mode=16187;case 16187:if(4096&a.flags){if(0===o)break t;c=0;do{v=i[r+c++],a.head&&v&&a.length<65536&&(a.head.comment+=String.fromCharCode(v))}while(v&&c<o);if(512&a.flags&&4&a.wrap&&(a.check=ht(a.check,i,c,r)),o-=c,r+=c,v)break t}else a.head&&(a.head.comment=null);a.mode=16188;case 16188:if(512&a.flags){for(;d<16;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(65535&a.check)){t.msg="header crc mismatch",a.mode=sa;break}h=0,d=0}a.head&&(a.head.hcrc=a.flags>>9&1,a.head.done=!0),t.adler=a.check=0,a.mode=Qe;break;case 16189:for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}t.adler=a.check=ra(h),h=0,d=0,a.mode=Xe;case Xe:if(0===a.havedict)return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,je;t.adler=a.check=1,a.mode=Qe;case Qe:if(e===Me||e===Ne)break t;case Je:if(a.last){h>>>=7&d,d-=7&d,a.mode=ia;break}for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}switch(a.last=1&h,h>>>=1,d-=1,3&h){case 0:a.mode=16193;break;case 1:if(wa(a),a.mode=ea,e===Ne){h>>>=2,d-=2;break t}break;case 2:a.mode=16196;break;case 3:t.msg="invalid block type",a.mode=sa}h>>>=2,d-=2;break;case 16193:for(h>>>=7&d,d-=7&d;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if((65535&h)!=(h>>>16^65535)){t.msg="invalid stored block lengths",a.mode=sa;break}if(a.length=65535&h,h=0,d=0,a.mode=ta,e===Ne)break t;case ta:a.mode=16195;case 16195:if(c=a.length,c){if(c>o&&(c=o),c>l&&(c=l),0===c)break t;s.set(i.subarray(r,r+c),n),o-=c,r+=c,l-=c,n+=c,a.length-=c;break}a.mode=Qe;break;case 16196:for(;d<14;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(a.nlen=257+(31&h),h>>>=5,d-=5,a.ndist=1+(31&h),h>>>=5,d-=5,a.ncode=4+(15&h),h>>>=4,d-=4,a.nlen>286||a.ndist>30){t.msg="too many length or distance symbols",a.mode=sa;break}a.have=0,a.mode=16197;case 16197:for(;a.have<a.ncode;){for(;d<3;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.lens[D[a.have++]]=7&h,h>>>=3,d-=3}for(;a.have<19;)a.lens[D[a.have++]]=0;if(a.lencode=a.lendyn,a.lenbits=7,R={bits:a.lenbits},x=Le(0,a.lens,0,19,a.lencode,0,a.work,R),a.lenbits=R.bits,x){t.msg="invalid code lengths set",a.mode=sa;break}a.have=0,a.mode=16198;case 16198:for(;a.have<a.nlen+a.ndist;){for(;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(p<16)h>>>=g,d-=g,a.lens[a.have++]=p;else{if(16===p){for(E=g+2;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(h>>>=g,d-=g,0===a.have){t.msg="invalid bit length repeat",a.mode=sa;break}v=a.lens[a.have-1],c=3+(3&h),h>>>=2,d-=2}else if(17===p){for(E=g+3;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=3+(7&h),h>>>=3,d-=3}else{for(E=g+7;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=g,d-=g,v=0,c=11+(127&h),h>>>=7,d-=7}if(a.have+c>a.nlen+a.ndist){t.msg="invalid bit length repeat",a.mode=sa;break}for(;c--;)a.lens[a.have++]=v}}if(a.mode===sa)break;if(0===a.lens[256]){t.msg="invalid code -- missing end-of-block",a.mode=sa;break}if(a.lenbits=9,R={bits:a.lenbits},x=Le(1,a.lens,0,a.nlen,a.lencode,0,a.work,R),a.lenbits=R.bits,x){t.msg="invalid literal/lengths set",a.mode=sa;break}if(a.distbits=6,a.distcode=a.distdyn,R={bits:a.distbits},x=Le(2,a.lens,a.nlen,a.ndist,a.distcode,0,a.work,R),a.distbits=R.bits,x){t.msg="invalid distances set",a.mode=sa;break}if(a.mode=ea,e===Ne)break t;case ea:a.mode=aa;case aa:if(o>=6&&l>=258){t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,Ie(t,_),n=t.next_out,s=t.output,l=t.avail_out,r=t.next_in,i=t.input,o=t.avail_in,h=a.hold,d=a.bits,a.mode===Qe&&(a.back=-1);break}for(a.back=0;z=a.lencode[h&(1<<a.lenbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(m&&!(240&m)){for(b=g,y=m,k=p;z=a.lencode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,a.length=p,0===m){a.mode=16205;break}if(32&m){a.back=-1,a.mode=Qe;break}if(64&m){t.msg="invalid literal/length code",a.mode=sa;break}a.extra=15&m,a.mode=16201;case 16201:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.length+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}a.was=a.length,a.mode=16202;case 16202:for(;z=a.distcode[h&(1<<a.distbits)-1],g=z>>>24,m=z>>>16&255,p=65535&z,!(g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(!(240&m)){for(b=g,y=m,k=p;z=a.distcode[k+((h&(1<<b+y)-1)>>b)],g=z>>>24,m=z>>>16&255,p=65535&z,!(b+g<=d);){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}h>>>=b,d-=b,a.back+=b}if(h>>>=g,d-=g,a.back+=g,64&m){t.msg="invalid distance code",a.mode=sa;break}a.offset=p,a.extra=15&m,a.mode=16203;case 16203:if(a.extra){for(E=a.extra;d<E;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}a.offset+=h&(1<<a.extra)-1,h>>>=a.extra,d-=a.extra,a.back+=a.extra}if(a.offset>a.dmax){t.msg="invalid distance too far back",a.mode=sa;break}a.mode=16204;case 16204:if(0===l)break t;if(c=_-l,a.offset>c){if(c=a.offset-c,c>a.whave&&a.sane){t.msg="invalid distance too far back",a.mode=sa;break}c>a.wnext?(c-=a.wnext,u=a.wsize-c):u=a.wnext-c,c>a.length&&(c=a.length),w=a.window}else w=s,u=n-a.offset,c=a.length;c>l&&(c=l),l-=c,a.length-=c;do{s[n++]=w[u++]}while(--c);0===a.length&&(a.mode=aa);break;case 16205:if(0===l)break t;s[n++]=a.length,l--,a.mode=aa;break;case ia:if(a.wrap){for(;d<32;){if(0===o)break t;o--,h|=i[r++]<<d,d+=8}if(_-=l,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,n-_):ot(a.check,s,_,n-_)),_=l,4&a.wrap&&(a.flags?h:ra(h))!==a.check){t.msg="incorrect data check",a.mode=sa;break}h=0,d=0}a.mode=16207;case 16207:if(a.wrap&&a.flags){for(;d<32;){if(0===o)break t;o--,h+=i[r++]<<d,d+=8}if(4&a.wrap&&h!==(4294967295&a.total)){t.msg="incorrect length check",a.mode=sa;break}h=0,d=0}a.mode=16208;case 16208:x=$e;break t;case sa:x=We;break t;case 16210:return Ke;default:return Ve}return t.next_out=n,t.avail_out=l,t.next_in=r,t.avail_in=o,a.hold=h,a.bits=d,(a.wsize||_!==t.avail_out&&a.mode<sa&&(a.mode<ia||e!==Pe))&&ga(t,t.output,t.next_out,_-t.avail_out),f-=t.avail_in,_-=t.avail_out,t.total_in+=f,t.total_out+=_,a.total+=_,4&a.wrap&&_&&(t.adler=a.check=a.flags?ht(a.check,s,_,t.next_out-_):ot(a.check,s,_,t.next_out-_)),t.data_type=a.bits+(a.last?64:0)+(a.mode===Qe?128:0)+(a.mode===ea||a.mode===ta?256:0),(0===f&&0===_||e===Pe)&&x===He&&(x=Ye),x},inflateEnd:t=>{if(oa(t))return Ve;let e=t.state;return e.window&&(e.window=null),t.state=null,He},inflateGetHeader:(t,e)=>{if(oa(t))return Ve;const a=t.state;return 2&a.wrap?(a.head=e,e.done=!1,He):Ve},inflateSetDictionary:(t,e)=>{const a=e.length;let i,s,r;return oa(t)?Ve:(i=t.state,0!==i.wrap&&i.mode!==Xe?Ve:i.mode===Xe&&(s=1,s=ot(s,e,a,0),s!==i.check)?We:(r=ga(t,e,a,a),r?(i.mode=16210,Ke):(i.havedict=1,He)))},inflateInfo:"pako inflate (from Nodeca project)"};var pa=function(){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=!1};const ba=Object.prototype.toString,{Z_NO_FLUSH:ya,Z_FINISH:ka,Z_OK:va,Z_STREAM_END:xa,Z_NEED_DICT:za,Z_STREAM_ERROR:Sa,Z_DATA_ERROR:Ra,Z_MEM_ERROR:Ea}=ft;function Da(t){this.options=de({chunkSize:65536,windowBits:15,to:""},t||{});const e=this.options;e.raw&&e.windowBits>=0&&e.windowBits<16&&(e.windowBits=-e.windowBits,0===e.windowBits&&(e.windowBits=-15)),!(e.windowBits>=0&&e.windowBits<16)||t&&t.windowBits||(e.windowBits+=32),e.windowBits>15&&e.windowBits<48&&(15&e.windowBits||(e.windowBits|=15)),this.err=0,this.msg="",this.ended=!1,this.chunks=[],this.strm=new me,this.strm.avail_out=0;let a=ma.inflateInit2(this.strm,e.windowBits);if(a!==va)throw new Error(dt[a]);if(this.header=new pa,ma.inflateGetHeader(this.strm,this.header),e.dictionary&&("string"==typeof e.dictionary?e.dictionary=ue(e.dictionary):"[object ArrayBuffer]"===ba.call(e.dictionary)&&(e.dictionary=new Uint8Array(e.dictionary)),e.raw&&(a=ma.inflateSetDictionary(this.strm,e.dictionary),a!==va)))throw new Error(dt[a])}Da.prototype.push=function(t,e){const a=this.strm,i=this.options.chunkSize,s=this.options.dictionary;let r,n,o;if(this.ended)return!1;for(n=e===~~e?e:!0===e?ka:ya,"[object ArrayBuffer]"===ba.call(t)?a.input=new Uint8Array(t):a.input=t,a.next_in=0,a.avail_in=a.input.length;;){for(0===a.avail_out&&(a.output=new Uint8Array(i),a.next_out=0,a.avail_out=i),r=ma.inflate(a,n),r===za&&s&&(r=ma.inflateSetDictionary(a,s),r===va?r=ma.inflate(a,n):r===Ra&&(r=za));a.avail_in>0&&r===xa&&a.state.wrap>0&&0!==t[a.next_in];)ma.inflateReset(a),r=ma.inflate(a,n);switch(r){case Sa:case Ra:case za:case Ea:return this.onEnd(r),this.ended=!0,!1}if(o=a.avail_out,a.next_out&&(0===a.avail_out||r===xa))if("string"===this.options.to){let t=ge(a.output,a.next_out),e=a.next_out-t,s=we(a.output,t);a.next_out=e,a.avail_out=i-e,e&&a.output.set(a.output.subarray(t,t+e),0),this.onData(s)}else this.onData(a.output.length===a.next_out?a.output:a.output.subarray(0,a.next_out));if(r!==va||0!==o){if(r===xa)return r=ma.inflateEnd(this.strm),this.onEnd(r),this.ended=!0,!0;if(0===a.avail_in)break}}return!0},Da.prototype.onData=function(t){this.chunks.push(t)},Da.prototype.onEnd=function(t){t===va&&("string"===this.options.to?this.result=this.chunks.join(""):this.result=fe(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};const{Deflate:Ua,deflate:Aa,deflateRaw:Oa,gzip:Ia}=Ae;var Fa=Aa;const Ba={b:{u:DataView.prototype.getInt8,p:DataView.prototype.setInt8,bytes:1},B:{u:DataView.prototype.getUint8,p:DataView.prototype.setUint8,bytes:1},h:{u:DataView.prototype.getInt16,p:DataView.prototype.setInt16,bytes:2},H:{u:DataView.prototype.getUint16,p:DataView.prototype.setUint16,bytes:2},i:{u:DataView.prototype.getInt32,p:DataView.prototype.setInt32,bytes:4},I:{u:DataView.prototype.getUint32,p:DataView.prototype.setUint32,bytes:4},q:{u:DataView.prototype.getInt64,p:DataView.prototype.setInt64,bytes:8},Q:{u:DataView.prototype.getUint64,p:DataView.prototype.setUint64,bytes:8}},Ta=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let i=[],s=!0;for(let i=0;i<t.length;i++)"<"==t[i]?s=!0:">"==t[i]?s=!1:(r(t[i],e[a]),a++);function r(t,e){if(!(t in Ba))throw"Unhandled character '"+t+"' in pack format";let a=Ba[t].bytes,r=new DataView(new ArrayBuffer(a));Ba[t].p.bind(r)(0,e,s);for(let t=0;t<a;t++)i.push(r.getUint8(t))}return i},Ca=(t,e)=>{let a=0,i=[],s=!0;for(let e of t)"<"==e?s=!0:">"==e?s=!1:r(e);function r(t){if(!(t in Ba))throw"Unhandled character '"+t+"' in unpack format";let r=Ba[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let o=Ba[t].u.bind(n);i.push(o(0,s)),a+=r}return i};class Za extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this._efuses=new Array(4).fill(0),this._flashsize=4194304,this.debug=!1,this.IS_STUB=!1,this.connected=!0,this.flashSize=null,this.state_DTR=!1}get _inputBuffer(){return this._parent?this._parent._inputBuffer:this.__inputBuffer}async initialize(){await this.hardReset(!0),this._parent||(this.__inputBuffer=[],this.readLoop()),await this.sync();let t=await this.readRegister(1073745920),e=g[t>>>0];if(void 0===e)throw new Error(`Unknown Chip: Hex: ${a(t>>>0,8).toLowerCase()} Number: ${t}`);this.chipName=e.name,this.chipFamily=e.family;let i=y(this.getChipFamily()).macFuse;for(let t=0;t<4;t++)this._efuses[t]=await this.readRegister(i+4*t);this.logger.log(`Chip type ${this.chipName}`)}async readLoop(){this.debug&&this.logger.debug("Starting read loop"),this._reader=this.port.readable.getReader();try{for(;;){const{value:t,done:e}=await this._reader.read();if(e){this._reader.releaseLock();break}t&&0!==t.length&&this._inputBuffer.push(...Array.from(t))}}catch(t){console.error("Read loop got disconnected")}this.connected=!1,this.dispatchEvent(new Event("disconnect")),this.logger.debug("Finished read loop")}sleep(t=100){return new Promise((e=>setTimeout(e,t)))}async setRTS(t){await this.port.setSignals({requestToSend:t}),await this.setDTR(this.state_DTR)}async setDTR(t){this.state_DTR=t,await this.port.setSignals({dataTerminalReady:t})}async hardReset(t=!1){this.logger.log("Try hard reset."),t?4097===this.port.getInfo().usbProductId?(await this.setDTR(!1),await this.setRTS(!1),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(100),await this.setRTS(!0),await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!1),await this.setRTS(!1)):(await this.setDTR(!1),await this.setRTS(!0),await this.sleep(100),await this.setDTR(!0),await this.setRTS(!1),await this.sleep(50),await this.setDTR(!1)):(await this.setRTS(!0),await this.sleep(100),await this.setRTS(!1)),await new Promise((t=>setTimeout(t,1e3)))}macAddr(){let t,e=new Array(6).fill(0),a=this._efuses[0],i=this._efuses[1],s=this._efuses[2],r=this._efuses[3];if(this.chipFamily==o){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(i>>16&255){if(1!=(i>>16&255))throw new Error("Couldnt determine OUI");t=[172,208,116]}else t=[24,254,52];e[0]=t[0],e[1]=t[1],e[2]=t[2],e[3]=i>>8&255,e[4]=255&i,e[5]=a>>24&255}else if(this.chipFamily==l)e[0]=s>>8&255,e[1]=255&s,e[2]=i>>24&255,e[3]=i>>16&255,e[4]=i>>8&255,e[5]=255&i;else{if(this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=i>>8&255,e[1]=255&i,e[2]=a>>24&255,e[3]=a>>16&255,e[4]=a>>8&255,e[5]=255&a}return e}async readRegister(t){this.debug&&this.logger.debug("Reading from Register "+a(t,8));let e=Ta("<I",t);await this.sendCommand(10,e);let[i,s]=await this.getResponse(10);return i}async checkCommand(t,e,i=0,s=3e3){s=Math.min(s,12e5),await this.sendCommand(t,e,i);let[r,n]=await this.getResponse(t,s);if(null===n)throw new Error("Didn't get enough status bytes");let g=0;if(this.IS_STUB||this.chipFamily==o?g=2:[l,h,d,f,_,c,u,w].includes(this.chipFamily)?g=4:[2,4].includes(n.length)&&(g=n.length),n.length<g)throw new Error("Didn't get enough status bytes");let m=n.slice(-g,n.length);if(n=n.slice(0,-g),this.debug&&(this.logger.debug("status",m),this.logger.debug("value",r),this.logger.debug("data",n)),1==m[0])throw 5==m[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(m[1]));return[r,n]}async sendCommand(t,e,a=0){let i=(t=>{let e=[192];for(let a of t)219==a?e=e.concat([219,221]):192==a?e=e.concat([219,220]):e.push(a);return e.push(192),e})([...Ta("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${i.length} byte${1==i.length?"":"s"}:`,i),await this.writeToStream(i)}async readPacket(t){let s=null,r=!1,n=[];for(;;){let o=Date.now();for(n=[];Date.now()-o<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await i(10)}if(0==n.length){throw new k("Timed out waiting for packet "+(null===s?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===s){if(192!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid head of packet ("+a(t)+")");s=[]}else if(r)if(r=!1,220==t)s.push(192);else{if(221!=t)throw this.debug&&(this.logger.debug("Read invalid data: "+e(n)),this.logger.debug("Remaining data in serial buffer: "+e(this._inputBuffer))),new k("Invalid SLIP escape (0xdb, "+a(t)+")");s.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(s)),s;s.push(t)}}throw new k("Invalid state")}async getResponse(t,e=3e3){for(let i=0;i<100;i++){const i=await this.readPacket(e);if(i.length<8)continue;const[s,r,n,o]=Ca("<BBHI",i.slice(0,8));if(1!=s)continue;const l=i.slice(8);if(null==t||r==t)return[o,l];if(0!=l[0]&&5==l[1])throw this._inputBuffer.length=0,new Error(`Invalid (unsupported) command ${a(t)}`)}throw"Response doesn't match request"}checksum(t,e=239){for(let a of t)e^=a;return e}async setBaudrate(t){if(this.chipFamily==o)throw new Error("Changing baud rate is not supported on the ESP8266");this.logger.log("Attempting to change baud rate to "+t+"...");try{let e=Ta("<II",t,this.IS_STUB?r:0);await this.checkCommand(15,e)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: No response from set baud rate command.`)}this._parent?await this._parent.reconfigurePort(t):await this.reconfigurePort(t)}async reconfigurePort(t){var e;try{await(null===(e=this._reader)||void 0===e?void 0:e.cancel()),await this.port.close(),await this.port.open({baudRate:t}),this.readLoop(),this.logger.log(`Changed baud rate to ${t}`)}catch(e){throw console.error(e),new Error(`Unable to change the baud rate to ${t}: ${e}`)}}async sync(){for(let t=0;t<5;t++){if(this._inputBuffer.length=0,await this._sync())return await i(100),!0;await i(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,n);for(let t=0;t<8;t++)try{let[t,e]=await this.getResponse(8,100);if(e.length>1&&0==e[0]&&0==e[1])return!0}catch(t){}return!1}getFlashWriteSize(){return this.IS_STUB?16384:1024}async flashData(t,e,i=0,s=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],i=r[2],s=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(i)}, FlashSizeFreq=${a(s)}`)}let n,o=t.byteLength,l=0,h=m;s?(n=Fa(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${o}. Compressed Size: ${l}`),h=await this.flashDeflBegin(o,l,i)):(this.logger.log(`Writing data with filesize: ${o}`),n=t,await this.flashBegin(o,i));let d=[],f=0,_=0,c=0,u=Date.now(),w=this.getFlashWriteSize(),g=s?l:o;for(;g-c>0;)this.debug&&this.logger.log(`Writing at ${a(i+f*w,8)} `),g-c>=w?d=Array.from(new Uint8Array(n,c,w)):(d=Array.from(new Uint8Array(n,c,g-c)),s||(d=d.concat(new Array(w-d.length).fill(255)))),s?await this.flashDeflBlock(d,f,h):await this.flashBlock(d,f),f+=1,_+=s?Math.round(d.length*o/l):d.length,c+=w,e(Math.min(_,o),o);this.logger.log("Took "+(Date.now()-u)+"ms to write "+g+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),s?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Ta("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Ta("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,i=!1){let s,r,n=this.getFlashWriteSize();!this.IS_STUB&&[l,h,d,f,_,c,u,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let g,p=Math.floor((t+n-1)/n);s=this.chipFamily==o?this.getEraseSize(e,t):t,g=this.IS_STUB?m:b(3e4,t);let y=Date.now();return r=Ta("<IIII",s,p,n,e),this.chipFamily!=l&&this.chipFamily!=h&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=_&&this.chipFamily!=c&&this.chipFamily!=u&&this.chipFamily!=w||(r=r.concat(Ta("<I",i?1:0))),this.logger.log("Erase size "+s+", blocks "+p+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(i?"yes":"no")),await this.checkCommand(2,r,0,g),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-y)+"ms to erase "+p+" bytes"),p}async flashDeflBegin(t=0,e=0,a=0,i=!1){let s,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),o=Math.floor((t+r-1)/r),l=0,h=0;return this.IS_STUB?(l=t,h=b(3e4,l)):(l=o*r,h=m),s=Ta("<IIII",l,n,r,a),await this.checkCommand(16,s,0,h),h}async flashFinish(){let t=Ta("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Ta("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return y(this.getChipFamily()).flashOffs}async flashId(){return await this.runSpiFlashCommand(159,[],24)}getChipFamily(){return this._parent?this._parent.chipFamily:this.chipFamily}async writeRegister(t,e,a=4294967295,i=0,s=0){let r=Ta("<IIII",t,e,a,i);s>0&&r.concat(Ta("<IIII",y(this.getChipFamily()).uartDateReg,0,0,s)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let i=t.regBase+t.mosiDlenOffs,s=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(i,e-1),a>0&&await this.writeRegister(s,a-1)}else{let i=t.regBase+t.usr1Offs,s=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(i,s)}}async waitDone(t,e){for(let a=0;a<10;a++){if(!(await this.readRegister(t)&e))return}throw Error("SPI command did not complete in time")}async runSpiFlashCommand(t,e,i=0){let s=y(this.getChipFamily()),r=s.regBase,n=r,o=r+s.usrOffs,l=r+s.usr2Offs,h=r+s.w0Offs,d=1<<18;if(i>32)throw new Error("Reading more than 32 bits back from a SPI flash operation is unsupported");if(e.length>64)throw new Error("Writing more than 64 bytes of data with one SPI command is unsupported");let f=8*e.length,_=await this.readRegister(o),c=await this.readRegister(l),u=1<<31;if(i>0&&(u|=268435456),f>0&&(u|=134217728),await this.setDataLengths(s,f,i),await this.writeRegister(o,u),await this.writeRegister(l,7<<28|t),0==f)await this.writeRegister(h,0);else{e.concat(new Array(e.length%4).fill(0));let t=Ca("I".repeat(Math.floor(e.length/4)),e),i=h;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(i)}`),await this.writeRegister(i,e),i+=4}await this.writeRegister(n,d),await this.waitDone(n,d);let w=await this.readRegister(h);return await this.writeRegister(o,_),await this.writeRegister(l,c),w}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,i=t>>16&255;this.logger.log(`FlashId: ${a(t)}`),this.logger.log(`Flash Manufacturer: ${e.toString(16)}`),this.logger.log(`Flash Device: ${(t>>8&255).toString(16)}${i.toString(16)}`),this.flashSize=s[i],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,i=Math.floor((e+a-1)/a),s=16-Math.floor(t/a)%16;return i<s&&(s=i),i<2*s?Math.floor((i+1)/2*a):(i-s)*a}async memBegin(t,e,a,i){return await this.checkCommand(5,Ta("<IIII",t,e,a,i))}async memBlock(t,e){return await this.checkCommand(7,Ta("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?m:500,a=Ta("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await v(this.chipFamily);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let i=t[e+"_start"],s=t[e].length,r=Math.floor((s+a-1)/a);await this.memBegin(s,r,a,i);for(let i of Array(r).keys()){let r=i*a,n=r+a;n>s&&(n=s),await this.memBlock(t[e].slice(r,n),i)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const i=await this.readPacket(500);if(e=String.fromCharCode(...i),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const s=new La(this.port,this.logger,this);return await s.detectFlashSize(),s}async writeToStream(t){const e=this.port.writable.getWriter();await e.write(new Uint8Array(t));try{e.releaseLock()}catch(t){console.error("Ignoring release lock error",t)}}async disconnect(){this._parent?await this._parent.disconnect():(await this.port.writable.getWriter().close(),await new Promise((t=>{this._reader||t(void 0),this.addEventListener("disconnect",t,{once:!0}),this._reader.cancel()})),this.connected=!1)}}class La extends Za{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,i,s){let r=await v(this.chipFamily),n=s,o=s+t;console.log(n,o),console.log(r.data_start,r.data.length,r.text_start,r.text.length);for(let[t,e]of[[r.data_start,r.data_start+r.data.length],[r.text_start,r.text_start+r.text.length]])if(n<e&&o>t)throw new Error("Software loader is resident at "+a(t,8)+"-"+a(e,8)+". Can't load binary at overlapping address range "+a(n,8)+"-"+a(o,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,p)}}const Pa=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Za(e,t)};export{l as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,_ as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C6,u as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,h as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,o as CHIP_FAMILY_ESP8266,Za as ESPLoader,Pa as connect};
|
package/js/script.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
let espStub;
|
|
2
2
|
|
|
3
|
-
const baudRates = [1500000, 921600,
|
|
4
|
-
|
|
3
|
+
const baudRates = [2000000, 1500000, 921600, 460800, 230400, 153600, 128000, 115200];
|
|
5
4
|
const bufferSize = 512;
|
|
6
5
|
const colors = ["#00a7e9", "#f89521", "#be1e2d"];
|
|
7
6
|
const measurementPeriodId = "0001";
|
|
@@ -419,7 +418,7 @@ function toggleUIConnected(connected) {
|
|
|
419
418
|
function loadAllSettings() {
|
|
420
419
|
// Load all saved settings or defaults
|
|
421
420
|
autoscroll.checked = loadSetting("autoscroll", true);
|
|
422
|
-
baudRate.value = loadSetting("baudrate",
|
|
421
|
+
baudRate.value = loadSetting("baudrate", 1500000);
|
|
423
422
|
darkMode.checked = loadSetting("darkmode", false);
|
|
424
423
|
}
|
|
425
424
|
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "tasmota-webserial-esptool",
|
|
3
|
-
"version": "6.
|
|
3
|
+
"version": "6.3.0",
|
|
4
4
|
"description": "Flash ESP devices using WebSerial",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"repository": {
|
|
@@ -18,19 +18,19 @@
|
|
|
18
18
|
},
|
|
19
19
|
"devDependencies": {
|
|
20
20
|
"@rollup/plugin-json": "^6.1.0",
|
|
21
|
-
"@rollup/plugin-node-resolve": "^
|
|
21
|
+
"@rollup/plugin-node-resolve": "^16.0.0",
|
|
22
22
|
"@rollup/plugin-terser": "^0.4.4",
|
|
23
|
-
"@rollup/plugin-typescript": "^
|
|
23
|
+
"@rollup/plugin-typescript": "^12.1.2",
|
|
24
24
|
"@types/pako": "^2.0.3",
|
|
25
|
-
"@types/w3c-web-serial": "^1.0.
|
|
26
|
-
"prettier": "^3.
|
|
27
|
-
"rollup": "^4.
|
|
28
|
-
"serve": "^14.2.
|
|
29
|
-
"typescript": "^5.
|
|
25
|
+
"@types/w3c-web-serial": "^1.0.7",
|
|
26
|
+
"prettier": "^3.4.2",
|
|
27
|
+
"rollup": "^4.30.1",
|
|
28
|
+
"serve": "^14.2.4",
|
|
29
|
+
"typescript": "^5.7.3"
|
|
30
30
|
},
|
|
31
31
|
"dependencies": {
|
|
32
|
-
"@types/node": "^
|
|
32
|
+
"@types/node": "^22.10.7",
|
|
33
33
|
"pako": "^2.1.0",
|
|
34
|
-
"tslib": "^2.
|
|
34
|
+
"tslib": "^2.8.1"
|
|
35
35
|
}
|
|
36
36
|
}
|
package/src/const.ts
CHANGED
|
@@ -215,6 +215,7 @@ export const CHIP_DETECT_MAGIC_VALUES: ChipInfo = {
|
|
|
215
215
|
0x9: { name: "ESP32-S3", family: CHIP_FAMILY_ESP32S3 },
|
|
216
216
|
0x6f51306f: { name: "ESP32-C2", family: CHIP_FAMILY_ESP32C2 },
|
|
217
217
|
0x7c41a06f: { name: "ESP32-C2", family: CHIP_FAMILY_ESP32C2 },
|
|
218
|
+
0x0c21e06f: { name: "ESP32-C2", family: CHIP_FAMILY_ESP32C2 },
|
|
218
219
|
0x6921506f: { name: "ESP32-C3", family: CHIP_FAMILY_ESP32C3 },
|
|
219
220
|
0x1b31506f: { name: "ESP32-C3", family: CHIP_FAMILY_ESP32C3 },
|
|
220
221
|
0x4881606f: { name: "ESP32-C3", family: CHIP_FAMILY_ESP32C3 },
|
|
@@ -222,6 +223,7 @@ export const CHIP_DETECT_MAGIC_VALUES: ChipInfo = {
|
|
|
222
223
|
0xd7b73e80: { name: "ESP32-H2", family: CHIP_FAMILY_ESP32H2 },
|
|
223
224
|
0x2ce0806f: { name: "ESP32-C6", family: CHIP_FAMILY_ESP32C6 },
|
|
224
225
|
0x0addbad0: { name: "ESP32-P4", family: CHIP_FAMILY_ESP32P4 },
|
|
226
|
+
0x7039ad9: { name: "ESP32-P4", family: CHIP_FAMILY_ESP32P4 },
|
|
225
227
|
0x0: { name: "ESP32-P4", family: CHIP_FAMILY_ESP32P4 },
|
|
226
228
|
};
|
|
227
229
|
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
{
|
|
2
|
+
"entry": 1082132164,
|
|
3
|
+
"text": "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",
|
|
4
|
+
"text_start": 1082130432,
|
|
5
|
+
"data": "FACEQG4KgEC+CoBAFguAQOQLgEBQDIBA/guAQDoJgECgC4BA4AuAQCoLgEDqCIBAXguAQOoIgEBICoBAjgqAQL4KgEAWC4BAWgqAQJ4JgEDOCYBAVgqAQKgOgEC+CoBAaA2AQGAOgEAqCIBAiA6AQCoIgEAqCIBAKgiAQCoIgEAqCIBAKgiAQCoIgEAqCIBABA2AQCoIgECGDYBAYA6AQA==",
|
|
6
|
+
"data_start": 1082469296,
|
|
7
|
+
"bss_start": 1082392576
|
|
8
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
{
|
|
2
|
+
"entry": 1082132164,
|
|
3
|
+
"text": "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",
|
|
4
|
+
"text_start": 1082130432,
|
|
5
|
+
"data": "FECAQHQKgEDECoBAHAuAQOoLgEBWDIBABAyAQEAJgECmC4BA5guAQDALgEDwCIBAZAuAQPAIgEBOCoBAlAqAQMQKgEAcC4BAYAqAQKQJgEDUCYBAXAqAQK4OgEDECoBAbg2AQGYOgEAwCIBAjg6AQDAIgEAwCIBAMAiAQDAIgEAwCIBAMAiAQDAIgEAwCIBACg2AQDAIgECMDYBAZg6AQA==",
|
|
6
|
+
"data_start": 1082223536,
|
|
7
|
+
"bss_start": 1082146816
|
|
8
|
+
}
|
package/src/stubs/esp32p4.json
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
2
|
+
"entry": 1341196252,
|
|
3
|
+
"text": "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",
|
|
4
|
+
"text_start": 1341194240,
|
|
5
|
+
"data": "XAD1T1QM8U+kDPFP/AzxT9IN8U8+DvFP7A3xTyAL8U+ODfFPzg3xTxAN8U/QCvFPRA3xT9AK8U8uDPFPdAzxT6QM8U/8DPFPQAzxT4QL8U+0C/FPPAzxT5YQ8U+kDPFPXg/xT1YQ8U9sCfFPehDxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFPbAnxT2wJ8U9sCfFP8g7xT2wJ8U98D/FPVhDxTw==",
|
|
6
|
+
"data_start": 1341533176,
|
|
7
|
+
"bss_start": 1341456384
|
|
8
|
+
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
var A=1341195918,B="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",w=1341194240,E="EAD1TwYK8U9WCvFPrgrxT4QL8U/wC/FPngvxT9QI8U9AC/FPgAvxT8IK8U+ECPFP9grxT4QI8U/gCfFPJgrxT1YK8U+uCvFP8gnxTzgJ8U9oCfFP7gnxT0AO8U9WCvFPCA3xTwAO8U/EB/FPJA7xT8QH8U/EB/FPxAfxT8QH8U/EB/FPxAfxT8QH8U/EB/FPpAzxT8QH8U8mDfFPAA7xTw==",c=1341533100,M=1341456384,T={entry:A,text:B,text_start:w,data:E,data_start:c,bss_start:M};export{M as bss_start,E as data,c as data_start,T as default,A as entry,B as text,w as text_start};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
var A=1341195918,B="QREixCbCBsa3Jw1QEUc3BPVP2Mu3JA1QEwQEANxAkYuR57JAIkSSREEBgoCIQBxAE3X1D4KX3bcBEbenDFBOxoOphwBKyDcJ9U8mylLEBs4izLekDFB9WhMJCQDATBN09D8N4PJAYkQjqDQBQknSRLJJIkoFYYKAiECDJwkAE3X1D4KXfRTjGUT/yb8TBwAMlEGqh2MY5QCFR4XGI6AFAHlVgoAFR2OH5gAJRmONxgB9VYKAQgUTB7ANQYVjlecCiUecwfW3kwbADWMW1QCYwRMFAAyCgJMG0A19VWOV1wCYwRMFsA2CgLc19k9BEZOFRboGxmE/Y0UFBrc39k+Th8exA6cHCAPWRwgTdfUPkwYWAMIGwYIjktcIMpcjAKcAA9dHCJFnk4cHBGMe9wI3t/VPEwfHsaFnupcDpgcIt/b1T7c39k+Th8exk4bGtWMf5gAjpscII6DXCCOSBwghoPlX4wb1/LJAQQGCgCOm1wgjoOcI3bc31whQfEudi/X/N8cIUHxLnYv1/4KAQREGxt03t9cIUCOmBwI3BwAImMOYQ33/yFeyQBNF9f8FiUEBgoBBEQbG2T993TcHAEC31whQmMM31whQHEP9/7JAQQGCgEERIsQ3hPVPkwcEAUrAA6kHAQbGJsJjCgkERTc5xb1HEwQEAYFEY9YnAQREvYiTtBQAfTeFPxxENwaAABOXxwCZ4DcGAAG39v8AdY+31ghQ2MKQwphCff9BR5HgBUczCelAupcjKCQBHMSyQCJEkkQCSUEBgoABEQbOIswlNzcE9E9sABMFxP6XAM//54Ag86qHBUWV57JHk/cHID7GiTc31whQHEe3BkAAEwXE/tWPHMeyRZcAz//ngKDwMzWgAPJAYkQFYYKAQRG3h/VPBsaThwcBBUcjgOcAE9fFAJjHBWd9F8zDyMf5jTqVqpWxgYzLI6oHAEE3GcETBVAMskBBAYKAAREizDeE9U+TBwQBJsrER07GBs5KyKqJEwQEAWPzlQCuhKnAAylEACaZE1nJABxIY1XwABxEY175ArU9fd1IQCaGzoWXAM//54Cg4xN19Q8BxZMHQAxcyFxAppdcwFxEhY9cxPJAYkTSREJJskkFYYKAaTVtv0ERBsaXAM//54BA1gNFhQGyQGkVEzUVAEEBgoBBEQbGxTcRwRlFskBBARcDz/9nAOPPQREGxibCIsSqhJcAz//ngADNdT8NyTcH9U+TBgcAg9dGABMEBwCFB8IHwYMjkvYAkwYADGOG1AATB+ADY3X3AG03IxIEALJAIkSSREEBgoBBEQbGEwcADGMa5QATBbANRTcTBcANskBBAVm/EwewDeMb5f5xNxMF0A31t0ERIsQmwgbGKoSzBLUAYxeUALJAIkSSREEBgoADRQQABQRNP+23NXEmy07H/XKFaf10Is1KyVLFVsMGz5OEhPoWkZOHCQemlxgIs4TnACqJJoUuhJcAz//ngOAZk4cJBxgIBWq6l7OKR0Ex5AVnfXWTBYX6kwcHBxMFhfkUCKqXM4XXAJMHBweul7OF1wAqxpcAz//ngKAWMkXBRZU3AUWFYhaR+kBqRNpESkm6SSpKmkoNYYKAooljc4oAhWlOhtaFSoWXAM//54CgyRN19Q8B7U6G1oUmhZcAz//ngOARTpkzBDRBUbcTBTAGVb8TBQAMSb0xcf1yBWdO11LVVtNezwbfIt0m20rZWtFizWbLaslux/13FpETBwcHPpccCLqXPsYjqgf4qokuirKKtosNNZMHAAIZwbcHAgA+hZcAz//ngIAKhWdj5VcTBWR9eRMJifqTBwQHypcYCDOJ5wBKhZcAz//ngAAJfXsTDDv5kwyL+RMHBAeTBwQHFAhil+aXgUQzDNcAs4zXAFJNY3xNCWPxpANBqJk/ooUIAY01uTcihgwBSoWXAM//54DgBKKZopRj9UQDs4ekQWPxdwMzBJpAY/OKAFaEIoYMAU6FlwDP/+eA4LgTdfUPVd0CzAFEeV2NTaMJAQBihZcAz//ngKCnffkDRTEB5oVZPGNPBQDj4o3+hWeThwcHopcYCLqX2pcjiqf4BQTxt+MVpf2RR+MF9PYFZ311kwcHB5MFhfoTBYX5FAiqlzOF1wCTBwcHrpezhdcAKsaXAM//54AA+3E9MkXBRWUzUT3dObcHAgAZ4ZMHAAI+hZcAz//ngAD4hWIWkfpQalTaVEpZulkqWppaClv6S2pM2kxKTbpNKWGCgLdXQUkZcZOH94QBRYbeotym2srYztbS1NbS2tDezuLM5srqyO7GPs6XAM//54DgoHkxBcU3R9hQt2cRUBMHF6qYzyOgBwAjrAcAmNPYT7cGBABVj9jPI6AHArcH9U83N/ZPk4cHABMHx7ohoCOgBwCRB+Pt5/7VM5FFaAjFOfE7t7f1T5OHx7EhZz6XIyD3CLcH8U83CfVPk4eHDiMg+QC3OfZPKTmTicmxEwkJAGMFBRC3Zw1QEwcQArjPhUVFRZcAz//ngKDmtwXxTwFGk4UFAEVFlwDP/+eAoOe3Jw1QEUeYyzcFAgCXAM//54Dg5rcHDlCIX4FFt4T1T3GJYRUTNRUAlwDP/+eAYKXBZ/0XEwcAEIVmQWa3BQABAUWThAQBtwr1Tw1qlwDP/+eAIJsTiwoBJpqDp8kI9d+Dq8kIhUcjpgkIIwLxAoPHGwAJRyMT4QKjAvECAtRNR2OB5whRR2OP5wYpR2Of5wCDxzsAA8crAKIH2Y8RR2OW5wCDp4sAnEM+1NE5oUVIEMU2g8c7AAPHKwCiB9mPEWdBB2N09wQTBbANqTYTBcANkTYTBeAOPT5dMUG3twXxTwFGk4WFAxVFlwDP/+eAoNg3pwxQXEcTBQACk+cXEFzHMbfJRyMT8QJNtwPHGwDRRmPn5gKFRmPm5gABTBME8A+FqHkXE3f3D8lG4+jm/rc29k8KB5OGBrs2lxhDAoeTBgcDk/b2DxFG42nW/BMH9wITd/cPjUZj6+YItzb2TwoHk4bGvzaXGEMChxMHQAJjl+cQAtQdRAFFcTwBReU0ATH9PqFFSBB9FCE2dfQBTAFEE3X0D8E8E3X8D+k0zTbjHgTqg8cbAElHY2v3MAlH43b36vUXk/f3Dz1H42D36jc39k+KBxMHx8C6l5xDgocFRJ3rcBCBRQFFl/DO/+eAoHcd4dFFaBBtNAFEMagFRIHvl/DO/+eAIH0zNKAAKaAhR2OF5wAFRAFMYbcDrIsAA6TLALNnjADSB/X30TBl9cFsIpz9HH19MwWMQF3cs3eVAZXjwWwzBYxAY+aMAv18MwWMQF3QMYGX8M7/54DAeV35ZpT1tzGBl/DO/+eAwHhd8WqU0bdBgZfwzv/ngAB4WfkzBJRBwbchR+OK5/ABTBMEAAw5t0FHzb9BRwVE453n9oOlywADpYsAOTy5v0FHBUTjk+f2A6cLAZFnY+7nHoOlSwEDpYsA7/C/hz2/QUcFROOT5/SDpwsBEWdjbvccA6fLAIOlSwEDpYsAM4TnAu/wP4UjrAQAIySKsDm3A8cEAGMHBxQDp4sAwRcTBAAMYxP3AMBIAUeTBvAOY0b3AoPHWwADx0sAAUyiB9mPA8drAEIHXY+Dx3sA4gfZj+OC9uYTBBAMsb0zhusAA0aGAQUHsY7ht4PHBAD9y9xEY5EHFsBII4AEAEW9YUdjlucCg6fLAQOniwGDpksBA6YLAYOlywADpYsAl/DO/+eAgGgqjDM0oAAxtQFMBUQZtRFHBUTjm+fmtxcOUPRfZXd9FwVm+Y7RjgOliwCThQcI9N+UQfmO0Y6UwZOFRwiUQfmO0Y6UwbRfgUV1j1GPuN+X8M7/54AgaxG9E/f3AOMRB+qT3EcAE4SLAAFMfV3jcZzbSESX8M7/54AgThhEVEAQQPmOYwenARxCE0f3/32P2Y4UwgUMQQTZvxFHhbVBRwVE45Tn3oOniwADp0sBIyb5ACMk6QBdu4MliQDBF5Hlic8BTBMEYAyxswMnyQBjZvcGE/c3AOMVB+IDKMkAAUYBRzMF6ECzhuUAY2n3AOMBBtIjJqkAIyTZABm7M4brABBOEQeQwgVG6b8hRwVE457n1gMkyQAZwBMEgAwjJgkAIyQJADM0gACNswFMEwQgDNWxAUwTBIAM8bkBTBMEkAzRuRMHIA1jg+cMEwdADeOY57gDxDsAg8crACIEXYyX8M7/54AATgOsxABBFGNzhAEijOMGDLbAQGKUMYCcSGNV8ACcRGNb9Arv8O/Rdd3IQGKGk4WLAZfwzv/ngABKAcWTB0AM3MjcQOKX3MDcRLOHh0HcxJfwzv/ngOBIDbYJZRMFBXEDrMsAA6SLAJfwzv/ngKA4t6cMUNhLtwYAAcEWk1dHARIHdY+9i9mPs4eHAwFFs9WHApfwzv/ngAA6EwWAPpfwzv/ngEA10byDpksBA6YLAYOlywADpYsA7/DP/n28g8U7AIPHKwAThYsBogXdjcEV7/DP21207/Avyz2/A8Q7AIPHKwATjIsBIgRdjNxEQRTN45FHhUtj/4cIkweQDNzIrbwDpw0AItAFSLOH7EA+1oMnirBjc/QADUhCxjrE7/CvxiJHMkg3hfVP4oV8EJOGCgEQEBMFhQKX8M7/54BgNze39U+TCAcBglcDp4iwg6UNAB2MHY8+nLJXI6TosKqLvpUjoL0Ak4cKAZ2NAcWhZ2OX9QBahe/wb9EjoG0BCcTcRJnD409w92PfCwCTB3AMvbeFS7c99k+3jPVPk43NupOMDAHpv+OaC5zcROOHB5yTB4AMqbeDp4sA45AHnO/wD9YJZRMFBXGX8M7/54CgIpfwzv/ngKAnTbIDpMsA4w4EmO/wz9MTBYA+l/DO/+eAgCAClFmy9lBmVNZURlm2WSZalloGW/ZLZkzWTEZNtk0JYYKAAAA=",w=1341194240,E="EAD1TwYK8U9WCvFPrgrxT4QL8U/wC/FPngvxT9QI8U9AC/FPgAvxT8IK8U+ECPFP9grxT4QI8U/gCfFPJgrxT1YK8U+uCvFP8gnxTzgJ8U9oCfFP7gnxT0AO8U9WCvFPCA3xTwAO8U/EB/FPJA7xT8QH8U/EB/FPxAfxT8QH8U/EB/FPxAfxT8QH8U/EB/FPpAzxT8QH8U8mDfFPAA7xTw==",c=1341533100,M=1341456384,T={entry:A,text:B,text_start:w,data:E,data_start:c,bss_start:M};export{M as bss_start,E as data,c as data_start,T as default,A as entry,B as text,w as text_start};
|