tasmota-webserial-esptool 6.5.0 → 6.5.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,126 @@
1
+ # Bugfix: GET_SECURITY_INFO für ESP32-C3
2
+
3
+ ## Problem
4
+
5
+ ESP32-C3 v0.4 (und andere moderne Chips) sollten `GET_SECURITY_INFO` unterstützen, aber es schlug mit einer leeren Antwort fehl:
6
+
7
+ ```
8
+ GET_SECURITY_INFO failed, using magic value detection: Error: Invalid security info response length: 0
9
+ ```
10
+
11
+ ## Ursache
12
+
13
+ Das Problem lag in der `checkCommand()` Funktion:
14
+
15
+ 1. `GET_SECURITY_INFO` wird während `detectChip()` aufgerufen
16
+ 2. Zu diesem Zeitpunkt ist `chipFamily` noch **nicht gesetzt**
17
+ 3. `checkCommand()` konnte die Status-Länge nicht korrekt bestimmen
18
+ 4. Es fiel in den `else` Block und verwendete die falsche Status-Länge
19
+ 5. Die Daten wurden falsch geparst → leere `responseData`
20
+
21
+ ### Code-Flow (vorher):
22
+
23
+ ```typescript
24
+ async detectChip() {
25
+ // chipFamily ist noch NICHT gesetzt!
26
+ const securityInfo = await this.getSecurityInfo();
27
+ // ↓
28
+ // checkCommand(ESP_GET_SECURITY_INFO, ...)
29
+ // ↓
30
+ // chipFamily ist undefined
31
+ // ↓
32
+ // statusLen wird falsch berechnet
33
+ // ↓
34
+ // data wird falsch geparst
35
+ // ↓
36
+ // responseData.length === 0
37
+ }
38
+ ```
39
+
40
+ ## Lösung
41
+
42
+ In `checkCommand()` wurde eine spezielle Behandlung für `GET_SECURITY_INFO` hinzugefügt:
43
+
44
+ ```typescript
45
+ async checkCommand(opcode, buffer, checksum, timeout) {
46
+ // ...
47
+
48
+ let statusLen = 0;
49
+
50
+ if (this.IS_STUB || this.chipFamily == CHIP_FAMILY_ESP8266) {
51
+ statusLen = 2;
52
+ } else if ([CHIP_FAMILY_ESP32, ...].includes(this.chipFamily)) {
53
+ statusLen = 4;
54
+ } else {
55
+ // NEU: Wenn chipFamily noch nicht gesetzt ist (während detectChip)
56
+ if (opcode === ESP_GET_SECURITY_INFO) {
57
+ statusLen = 4; // Moderne Chips verwenden 4-Byte Status
58
+ } else if ([2, 4].includes(data.length)) {
59
+ statusLen = data.length;
60
+ }
61
+ }
62
+
63
+ // ...
64
+ }
65
+ ```
66
+
67
+ ## Ergebnis
68
+
69
+ Nach dem Fix sollte ESP32-C3 v0.4 (und andere moderne Chips) korrekt erkannt werden:
70
+
71
+ ### Vorher:
72
+ ```
73
+ [debug] GET_SECURITY_INFO failed, using magic value detection: Error: Invalid security info response length: 0
74
+ [debug] Detected chip via magic value: 0x1B31506F (ESP32-C3)
75
+ ```
76
+
77
+ ### Nachher (erwartet):
78
+ ```
79
+ [debug] Detected chip via IMAGE_CHIP_ID: 5 (ESP32-C3)
80
+ Chip type ESP32-C3
81
+ ```
82
+
83
+ ## Betroffene Chips
84
+
85
+ Dieser Fix verbessert die Erkennung für:
86
+
87
+ - ✅ ESP32-C3 (alle Revisionen mit GET_SECURITY_INFO Support)
88
+ - ✅ ESP32-S3
89
+ - ✅ ESP32-C6
90
+ - ✅ ESP32-C61
91
+ - ✅ ESP32-H2
92
+ - ✅ ESP32-C5
93
+ - ✅ ESP32-P4 Rev. 300+
94
+
95
+ ## Fallback bleibt erhalten
96
+
97
+ Der Fallback auf Magic Value Detection bleibt weiterhin funktionsfähig für:
98
+
99
+ - ESP8266
100
+ - ESP32
101
+ - ESP32-S2
102
+ - Ältere ROM-Versionen, die GET_SECURITY_INFO nicht unterstützen
103
+
104
+ ## Testing
105
+
106
+ ### Zu testen:
107
+ - [ ] ESP32-C3 v0.4 → sollte via IMAGE_CHIP_ID erkannt werden
108
+ - [ ] ESP32-S3 → sollte via IMAGE_CHIP_ID erkannt werden
109
+ - [ ] ESP32-P4 Rev. 300+ → sollte via IMAGE_CHIP_ID erkannt werden
110
+ - [ ] ESP8266 → sollte via Magic Value erkannt werden (Fallback)
111
+ - [ ] ESP32 → sollte via Magic Value erkannt werden (Fallback)
112
+
113
+ ### Erwartetes Verhalten:
114
+
115
+ **Moderne Chips (mit GET_SECURITY_INFO):**
116
+ ```
117
+ [debug] Detected chip via IMAGE_CHIP_ID: X (ESP32-XX)
118
+ ```
119
+
120
+ **Ältere Chips (ohne GET_SECURITY_INFO):**
121
+ ```
122
+ [debug] GET_SECURITY_INFO failed, using magic value detection
123
+ [debug] Detected chip via magic value: 0xXXXXXXXX (ESP32-XX)
124
+ ```
125
+
126
+ Beide Wege führen zur korrekten Chip-Erkennung! ✅
@@ -162,9 +162,23 @@ Die ESP32-P4 Revision wird aus den eFuses gelesen (EFUSE_BLOCK1):
162
162
 
163
163
  ### Erkennungsmethoden
164
164
 
165
- ESP32-P4 kann auf zwei Arten erkannt werden:
166
-
167
- 1. **IMAGE_CHIP_ID** (Rev. 300+): Verwendet `GET_SECURITY_INFO` Kommando
168
- 2. **Magic Value** (Rev. < 300): Liest Magic-Wert aus Register
169
-
170
- In beiden Fällen wird die Revision gelesen und die entsprechende Variante gesetzt.
165
+ Die Chip-Erkennung verwendet einen zweistufigen Ansatz:
166
+
167
+ 1. **Primär: GET_SECURITY_INFO** (IMAGE_CHIP_ID)
168
+ - Unterstützt von: ESP32-C3 (neuere ROM), ESP32-S3, ESP32-C6, ESP32-H2, ESP32-P4 Rev. 300+
169
+ - Liefert direkt die Chip-ID
170
+ - Wenn nicht unterstützt oder leere Antwort Fallback zu Magic Value
171
+
172
+ 2. **Fallback: Magic Value Detection**
173
+ - Unterstützt von: ESP8266, ESP32, ESP32-S2, ESP32-C3 (ältere ROM), ESP32-P4 Rev. < 300
174
+ - Liest Magic-Wert aus Register 0x40001000
175
+ - Zuverlässige Methode für ältere Chips
176
+
177
+ **Für ESP32-P4:**
178
+ - Beide Methoden funktionieren
179
+ - Nach Erkennung wird die Revision aus eFuses gelesen
180
+ - Basierend auf Revision wird `chipVariant` gesetzt:
181
+ - Rev. < 300 → `"rev0"`
182
+ - Rev. >= 300 → `"rev300"`
183
+
184
+ **Hinweis:** Die Debug-Meldung "GET_SECURITY_INFO failed, using magic value detection" ist normal und erwartet für ältere Chips. Der Fallback-Mechanismus stellt sicher, dass alle Chips korrekt erkannt werden.
@@ -0,0 +1,145 @@
1
+ # GET_SECURITY_INFO Erklärung
2
+
3
+ ## Warum schlägt GET_SECURITY_INFO manchmal fehl?
4
+
5
+ Die Debug-Meldung:
6
+ ```
7
+ GET_SECURITY_INFO failed, using magic value detection: Error: Invalid security info response length: 0
8
+ ```
9
+
10
+ ist **normal und erwartet** für viele ESP-Chips.
11
+
12
+ ## Chip-Erkennungsstrategie
13
+
14
+ Der Code verwendet einen robusten zweistufigen Ansatz:
15
+
16
+ ### 1. Primär: GET_SECURITY_INFO (IMAGE_CHIP_ID)
17
+
18
+ **Unterstützt von:**
19
+ - ESP32-C3 (neuere ROM-Versionen)
20
+ - ESP32-S3
21
+ - ESP32-C6
22
+ - ESP32-C61
23
+ - ESP32-H2
24
+ - ESP32-C5
25
+ - ESP32-P4 Rev. 300+
26
+
27
+ **Vorteile:**
28
+ - Direkte Chip-ID
29
+ - Zusätzliche Sicherheitsinformationen
30
+ - Zukunftssicher
31
+
32
+ **Problem:**
33
+ - Nicht von allen Chips/ROM-Versionen unterstützt
34
+ - Manche Chips geben leere Antwort zurück (length: 0)
35
+
36
+ ### 2. Fallback: Magic Value Detection
37
+
38
+ **Unterstützt von:**
39
+ - ESP8266
40
+ - ESP32
41
+ - ESP32-S2
42
+ - ESP32-C3 (ältere ROM-Versionen)
43
+ - ESP32-P4 Rev. < 300
44
+ - Alle anderen Chips als Fallback
45
+
46
+ **Vorteile:**
47
+ - Funktioniert auf allen ESP-Chips
48
+ - Sehr zuverlässig
49
+ - Seit Jahren bewährt
50
+
51
+ **Funktionsweise:**
52
+ - Liest Magic-Wert aus Register `0x40001000`
53
+ - Vergleicht mit bekannten Magic-Werten
54
+ - Identifiziert Chip-Familie
55
+
56
+ ## Beispiel-Log (ESP32-C3)
57
+
58
+ ```
59
+ Try hard reset.
60
+ [debug] GET_SECURITY_INFO failed, using magic value detection: Error: GET_SECURITY_INFO not supported or returned empty response
61
+ [debug] Detected chip via magic value: 0x1B31506F (ESP32-C3)
62
+ Chip type ESP32-C3
63
+ ```
64
+
65
+ **Interpretation:**
66
+ 1. ✅ GET_SECURITY_INFO wurde versucht (wie es sein soll)
67
+ 2. ✅ Leere Antwort erkannt (dieser ESP32-C3 unterstützt es nicht)
68
+ 3. ✅ Fallback auf Magic Value Detection (funktioniert perfekt)
69
+ 4. ✅ Chip korrekt als ESP32-C3 erkannt
70
+
71
+ ## Beispiel-Log (ESP32-P4 Rev. 300+)
72
+
73
+ ```
74
+ Try hard reset.
75
+ [debug] Detected chip via IMAGE_CHIP_ID: 18 (ESP32-P4)
76
+ [debug] ESP32-P4 revision: 300
77
+ [debug] ESP32-P4 variant: rev300
78
+ Chip type ESP32-P4
79
+ ```
80
+
81
+ **Interpretation:**
82
+ 1. ✅ GET_SECURITY_INFO funktioniert (neuere ROM-Version)
83
+ 2. ✅ Chip-ID 18 = ESP32-P4
84
+ 3. ✅ Revision aus eFuses gelesen
85
+ 4. ✅ Variante korrekt gesetzt
86
+
87
+ ## Warum ist das so implementiert?
88
+
89
+ ### Historischer Kontext
90
+
91
+ 1. **Ältere Chips (ESP8266, ESP32, ESP32-S2)**:
92
+ - Haben GET_SECURITY_INFO nicht
93
+ - Verwenden nur Magic Value Detection
94
+
95
+ 2. **Neuere Chips (ESP32-C3, ESP32-S3, etc.)**:
96
+ - Sollten GET_SECURITY_INFO unterstützen
97
+ - Aber: ROM-Versionen variieren
98
+ - Manche frühe Produktionen haben es nicht
99
+
100
+ 3. **Robustheit**:
101
+ - Fallback stellt sicher, dass ALLE Chips erkannt werden
102
+ - Keine Abhängigkeit von ROM-Version
103
+ - Funktioniert auch bei zukünftigen Chips
104
+
105
+ ## Ist das ein Problem?
106
+
107
+ **Nein!** Das ist das erwartete Verhalten:
108
+
109
+ ✅ **Korrekt erkannt**: Der Chip wird korrekt identifiziert
110
+ ✅ **Funktioniert**: Flashing funktioniert einwandfrei
111
+ ✅ **Robust**: Fallback-Mechanismus ist bewährt
112
+ ✅ **Debug-Info**: Die Meldung ist nur zur Information
113
+
114
+ ## Wann wäre es ein Problem?
115
+
116
+ ❌ **Nur wenn:**
117
+ - Chip wird NICHT erkannt
118
+ - Falscher Chip-Typ wird erkannt
119
+ - Flashing schlägt fehl
120
+
121
+ In Ihrem Log:
122
+ ```
123
+ Detected chip via magic value: 0x1B31506F (ESP32-C3)
124
+ Chip type ESP32-C3
125
+ Connected to ESP32-C3
126
+ MAC Address: 34:B7:DA:F7:8F:00
127
+ ```
128
+
129
+ → Alles funktioniert perfekt! ✅
130
+
131
+ ## Zusammenfassung
132
+
133
+ Die Meldung "GET_SECURITY_INFO failed" ist:
134
+ - ✅ Normal
135
+ - ✅ Erwartet für viele Chips
136
+ - ✅ Kein Fehler
137
+ - ✅ Teil des robusten Erkennungsmechanismus
138
+
139
+ Der Fallback auf Magic Value Detection ist:
140
+ - ✅ Bewährt
141
+ - ✅ Zuverlässig
142
+ - ✅ Funktioniert auf allen ESP-Chips
143
+ - ✅ Genau so designed
144
+
145
+ **Fazit:** Alles funktioniert wie vorgesehen! 🎉
@@ -77,6 +77,16 @@ export class ESPLoader extends EventTarget {
77
77
  catch (err) {
78
78
  // GET_SECURITY_INFO not supported, fall back to magic value detection
79
79
  this.logger.debug(`GET_SECURITY_INFO failed, using magic value detection: ${err}`);
80
+ // Clear input buffer and re-sync to recover from failed command
81
+ this._inputBuffer.length = 0;
82
+ await sleep(100);
83
+ // Re-sync with the chip to ensure clean communication
84
+ try {
85
+ await this.sync();
86
+ }
87
+ catch (syncErr) {
88
+ this.logger.debug(`Re-sync after GET_SECURITY_INFO failure: ${syncErr}`);
89
+ }
80
90
  }
81
91
  // Fallback: Use magic value detection for ESP8266, ESP32, ESP32-S2, and ESP32-P4 RC versions
82
92
  let chipMagicValue = await this.readRegister(CHIP_DETECT_MAGIC_REG_ADDR);
@@ -122,8 +132,12 @@ export class ESPLoader extends EventTarget {
122
132
  */
123
133
  async getSecurityInfo() {
124
134
  const [_, responseData] = await this.checkCommand(ESP_GET_SECURITY_INFO, [], 0);
125
- if (responseData.length < 20) {
126
- throw new Error(`Invalid security info response length: ${responseData.length}`);
135
+ // Some chips/ROM versions return empty response or don't support this command
136
+ if (responseData.length === 0) {
137
+ throw new Error(`GET_SECURITY_INFO not supported or returned empty response`);
138
+ }
139
+ if (responseData.length < 12) {
140
+ throw new Error(`Invalid security info response length: ${responseData.length} (expected at least 12 bytes)`);
127
141
  }
128
142
  const flags = unpack("<I", responseData.slice(0, 4))[0];
129
143
  const flashCryptCnt = responseData[4];
@@ -330,7 +344,12 @@ export class ESPLoader extends EventTarget {
330
344
  statusLen = 4;
331
345
  }
332
346
  else {
333
- if ([2, 4].includes(data.length)) {
347
+ // When chipFamily is not yet set (e.g., during GET_SECURITY_INFO in detectChip),
348
+ // assume modern chips use 4-byte status
349
+ if (opcode === ESP_GET_SECURITY_INFO) {
350
+ statusLen = 4;
351
+ }
352
+ else if ([2, 4].includes(data.length)) {
334
353
  statusLen = data.length;
335
354
  }
336
355
  }
package/dist/web/index.js CHANGED
@@ -1 +1 @@
1
- const t=t=>{let e=[];for(let a=0;a<t.length;a++){let s=t.charCodeAt(a);s<=255&&e.push(s)}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")},s=t=>new Promise(e=>setTimeout(e,t)),i={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=1343410176,h=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),l=33382,o=50,_=12882,d=12883,f=12994,u=12995,c=12997,g=12998,m=207969,p=12914,w=12928,y={5:{name:"ESP32-C3",family:u},9:{name:"ESP32-S3",family:d},12:{name:"ESP32-C2",family:f},13:{name:"ESP32-C6",family:g},16:{name:"ESP32-H2",family:p},17:{name:"ESP32-C5",family:c},18:{name:"ESP32-P4",family:w},20:{name:"ESP32-C61",family:m}},b={4293968129:{name:"ESP8266",family:l},15736195:{name:"ESP32",family:o},1990:{name:"ESP32-S2",family:_},9:{name:"ESP32-S3",family:d},203546735:{name:"ESP32-C2",family:f},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},456216687:{name:"ESP32-C3",family:u},1130455151:{name:"ESP32-C3",family:u},1216438383:{name:"ESP32-C3",family:u},1763790959:{name:"ESP32-C3",family:u},285294703:{name:"ESP32-C5",family:c},1607549039:{name:"ESP32-C5",family:c},1548751960:{name:"ESP32-C5",family:c},1675706479:{name:"ESP32-C5",family:c},752910447:{name:"ESP32-C6",family:g},606167151:{name:"ESP32-C61",family:m},871374959:{name:"ESP32-C61",family:m},1333878895:{name:"ESP32-C61",family:m},1913741423:{name:"ESP32-C61",family:m},2548236392:{name:"ESP32-H2",family:p},3619110528:{name:"ESP32-H2",family:p},0:{name:"ESP32-P4",family:w},117676761:{name:"ESP32-P4",family:w},182303440:{name:"ESP32-P4",family:w}},v=3e3,k=6e5,S=(t,e)=>{let a=Math.floor(t*(e/486));return a<v?v:a},z=t=>{switch(t){case o:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case _: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 l: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 u: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:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:8192};case g:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case m:return{regBase:1610625024,baseFuse:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case p:return{regBase:1610625024,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:n,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 R extends Error{constructor(t){super(t),this.name="SlipReadError"}}const F=async(e,a)=>{let s;return e==o?s=await import("./esp32-BNIFdu1P.js"):e==_?s=await import("./esp32s2-Bk4mqADi.js"):e==d?s=await import("./esp32s3-Df3OUCOC.js"):e==l?s=await import("./esp8266-CQFcqJ_a.js"):e==f?s=await import("./esp32c2-BqxquOKw.js"):e==u?s=await import("./esp32c3-BOOqe8me.js"):e==c?s=await import("./esp32c5-mcj52-K1.js"):e==g?s=await import("./esp32c6-Cg5qYgg7.js"):e==m?s=await import("./esp32c61-CzCdsydk.js"):e==p?s=await import("./esp32h2-DZa_lpff.js"):e==w&&(s=null!=a&&a>=300?await import("./esp32p4r3-Cle9QJmZ.js"):await import("./esp32p4-DyGqUAeZ.js")),{...s,text:t(atob(s.text)),data:t(atob(s.data))}};function D(t){let e=t.length;for(;--e>=0;)t[e]=0}const E=256,U=286,O=30,I=15,x=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]),A=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]),C=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),B=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),T=new Array(576);D(T);const P=new Array(60);D(P);const L=new Array(512);D(L);const Z=new Array(256);D(Z);const $=new Array(29);D($);const M=new Array(O);function N(t,e,a,s,i){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=s,this.max_length=i,this.has_stree=t&&t.length}let H,V,j;function W(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}D(M);const K=t=>t<256?L[t]:L[256+(t>>>7)],Y=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},G=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,Y(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)},q=(t,e,a)=>{G(t,a[2*e],a[2*e+1])},X=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Q=(t,e,a)=>{const s=new Array(16);let i,r,n=0;for(i=1;i<=I;i++)n=n+a[i-1]<<1,s[i]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=X(s[e]++,e))}},J=t=>{let e;for(e=0;e<U;e++)t.dyn_ltree[2*e]=0;for(e=0;e<O;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},tt=t=>{t.bi_valid>8?Y(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},et=(t,e,a,s)=>{const i=2*e,r=2*a;return t[i]<t[r]||t[i]===t[r]&&s[e]<=s[a]},at=(t,e,a)=>{const s=t.heap[a];let i=a<<1;for(;i<=t.heap_len&&(i<t.heap_len&&et(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!et(e,s,t.heap[i],t.depth));)t.heap[a]=t.heap[i],a=i,i<<=1;t.heap[a]=s},st=(t,e,a)=>{let s,i,r,n,h=0;if(0!==t.sym_next)do{s=255&t.pending_buf[t.sym_buf+h++],s+=(255&t.pending_buf[t.sym_buf+h++])<<8,i=t.pending_buf[t.sym_buf+h++],0===s?q(t,i,e):(r=Z[i],q(t,r+E+1,e),n=x[r],0!==n&&(i-=$[r],G(t,i,n)),s--,r=K(s),q(t,r,a),n=A[r],0!==n&&(s-=M[r],G(t,s,n)))}while(h<t.sym_next);q(t,256,e)},it=(t,e)=>{const a=e.dyn_tree,s=e.stat_desc.static_tree,i=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,h,l,o=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=o=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=o<2?++o:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,i&&(t.static_len-=s[2*l+1]);for(e.max_code=o,n=t.heap_len>>1;n>=1;n--)at(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],at(t,a,1),h=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=h,a[2*l]=a[2*n]+a[2*h],t.depth[l]=(t.depth[n]>=t.depth[h]?t.depth[n]:t.depth[h])+1,a[2*n+1]=a[2*h+1]=l,t.heap[1]=l++,at(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,s=e.max_code,i=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,h=e.stat_desc.extra_base,l=e.stat_desc.max_length;let o,_,d,f,u,c,g=0;for(f=0;f<=I;f++)t.bl_count[f]=0;for(a[2*t.heap[t.heap_max]+1]=0,o=t.heap_max+1;o<573;o++)_=t.heap[o],f=a[2*a[2*_+1]+1]+1,f>l&&(f=l,g++),a[2*_+1]=f,_>s||(t.bl_count[f]++,u=0,_>=h&&(u=n[_-h]),c=a[2*_],t.opt_len+=c*(f+u),r&&(t.static_len+=c*(i[2*_+1]+u)));if(0!==g){do{for(f=l-1;0===t.bl_count[f];)f--;t.bl_count[f]--,t.bl_count[f+1]+=2,t.bl_count[l]--,g-=2}while(g>0);for(f=l;0!==f;f--)for(_=t.bl_count[f];0!==_;)d=t.heap[--o],d>s||(a[2*d+1]!==f&&(t.opt_len+=(f-a[2*d+1])*a[2*d],a[2*d+1]=f),_--)}})(t,e),Q(a,o,t.bl_count)},rt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),e[2*(a+1)+1]=65535,s=0;s<=a;s++)i=n,n=e[2*(s+1)+1],++h<l&&i===n||(h<o?t.bl_tree[2*i]+=h:0!==i?(i!==r&&t.bl_tree[2*i]++,t.bl_tree[32]++):h<=10?t.bl_tree[34]++:t.bl_tree[36]++,h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4))},nt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),s=0;s<=a;s++)if(i=n,n=e[2*(s+1)+1],!(++h<l&&i===n)){if(h<o)do{q(t,i,t.bl_tree)}while(0!==--h);else 0!==i?(i!==r&&(q(t,i,t.bl_tree),h--),q(t,16,t.bl_tree),G(t,h-3,2)):h<=10?(q(t,17,t.bl_tree),G(t,h-3,3)):(q(t,18,t.bl_tree),G(t,h-11,7));h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4)}};let ht=!1;const lt=(t,e,a,s)=>{G(t,0+(s?1:0),3),tt(t),Y(t,a),Y(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var ot=(t,e,a,s)=>{let i,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<E;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),it(t,t.l_desc),it(t,t.d_desc),n=(t=>{let e;for(rt(t,t.dyn_ltree,t.l_desc.max_code),rt(t,t.dyn_dtree,t.d_desc.max_code),it(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*B[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),i=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=i&&(i=r)):i=r=a+5,a+4<=i&&-1!==e?lt(t,e,a,s):4===t.strategy||r===i?(G(t,2+(s?1:0),3),st(t,T,P)):(G(t,4+(s?1:0),3),((t,e,a,s)=>{let i;for(G(t,e-257,5),G(t,a-1,5),G(t,s-4,4),i=0;i<s;i++)G(t,t.bl_tree[2*B[i]+1],3);nt(t,t.dyn_ltree,e-1),nt(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),st(t,t.dyn_ltree,t.dyn_dtree)),J(t),s&&tt(t)},_t={_tr_init:t=>{ht||((()=>{let t,e,a,s,i;const r=new Array(16);for(a=0,s=0;s<28;s++)for($[s]=a,t=0;t<1<<x[s];t++)Z[a++]=s;for(Z[a-1]=s,i=0,s=0;s<16;s++)for(M[s]=i,t=0;t<1<<A[s];t++)L[i++]=s;for(i>>=7;s<O;s++)for(M[s]=i<<7,t=0;t<1<<A[s]-7;t++)L[256+i++]=s;for(e=0;e<=I;e++)r[e]=0;for(t=0;t<=143;)T[2*t+1]=8,t++,r[8]++;for(;t<=255;)T[2*t+1]=9,t++,r[9]++;for(;t<=279;)T[2*t+1]=7,t++,r[7]++;for(;t<=287;)T[2*t+1]=8,t++,r[8]++;for(Q(T,287,r),t=0;t<O;t++)P[2*t+1]=5,P[2*t]=X(t,5);H=new N(T,x,257,U,I),V=new N(P,A,0,O,I),j=new N(new Array(0),C,0,19,7)})(),ht=!0),t.l_desc=new W(t.dyn_ltree,H),t.d_desc=new W(t.dyn_dtree,V),t.bl_desc=new W(t.bl_tree,j),t.bi_buf=0,t.bi_valid=0,J(t)},_tr_stored_block:lt,_tr_flush_block:ot,_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*(Z[a]+E+1)]++,t.dyn_dtree[2*K(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{G(t,2,3),q(t,256,T),(t=>{16===t.bi_valid?(Y(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 dt=(t,e,a,s)=>{let i=65535&t,r=t>>>16&65535,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{i=i+e[s++]|0,r=r+i|0}while(--n);i%=65521,r%=65521}return i|r<<16};const ft=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var s=0;s<8;s++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ut=(t,e,a,s)=>{const i=ft,r=s+a;t^=-1;for(let a=s;a<r;a++)t=t>>>8^i[255&(t^e[a])];return-1^t},ct={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"},gt={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_OK:0,Z_STREAM_END:1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_BUF_ERROR:-5,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:mt,_tr_stored_block:pt,_tr_flush_block:wt,_tr_tally:yt,_tr_align:bt}=_t,{Z_NO_FLUSH:vt,Z_PARTIAL_FLUSH:kt,Z_FULL_FLUSH:St,Z_FINISH:zt,Z_BLOCK:Rt,Z_OK:Ft,Z_STREAM_END:Dt,Z_STREAM_ERROR:Et,Z_DATA_ERROR:Ut,Z_BUF_ERROR:Ot,Z_DEFAULT_COMPRESSION:It,Z_FILTERED:xt,Z_HUFFMAN_ONLY:At,Z_RLE:Ct,Z_FIXED:Bt,Z_DEFAULT_STRATEGY:Tt,Z_UNKNOWN:Pt,Z_DEFLATED:Lt}=gt,Zt=258,$t=262,Mt=42,Nt=113,Ht=666,Vt=(t,e)=>(t.msg=ct[e],e),jt=t=>2*t-(t>4?9:0),Wt=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Kt=t=>{let e,a,s,i=t.w_size;e=t.hash_size,s=e;do{a=t.head[--s],t.head[s]=a>=i?a-i:0}while(--e);e=i,s=e;do{a=t.prev[--s],t.prev[s]=a>=i?a-i:0}while(--e)};let Yt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Gt=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))},qt=(t,e)=>{wt(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Gt(t.strm)},Xt=(t,e)=>{t.pending_buf[t.pending++]=e},Qt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},Jt=(t,e,a,s)=>{let i=t.avail_in;return i>s&&(i=s),0===i?0:(t.avail_in-=i,e.set(t.input.subarray(t.next_in,t.next_in+i),a),1===t.state.wrap?t.adler=dt(t.adler,e,i,a):2===t.state.wrap&&(t.adler=ut(t.adler,e,i,a)),t.next_in+=i,t.total_in+=i,i)},te=(t,e)=>{let a,s,i=t.max_chain_length,r=t.strstart,n=t.prev_length,h=t.nice_match;const l=t.strstart>t.w_size-$t?t.strstart-(t.w_size-$t):0,o=t.window,_=t.w_mask,d=t.prev,f=t.strstart+Zt;let u=o[r+n-1],c=o[r+n];t.prev_length>=t.good_match&&(i>>=2),h>t.lookahead&&(h=t.lookahead);do{if(a=e,o[a+n]===c&&o[a+n-1]===u&&o[a]===o[r]&&o[++a]===o[r+1]){r+=2,a++;do{}while(o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&r<f);if(s=Zt-(f-r),r=f-Zt,s>n){if(t.match_start=e,n=s,s>=h)break;u=o[r+n-1],c=o[r+n]}}}while((e=d[e&_])>l&&0!==--i);return n<=t.lookahead?n:t.lookahead},ee=t=>{const e=t.w_size;let a,s,i;do{if(s=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-$t)&&(t.window.set(t.window.subarray(e,e+e-s),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),Kt(t),s+=e),0===t.strm.avail_in)break;if(a=Jt(t.strm,t.window,t.strstart+t.lookahead,s),t.lookahead+=a,t.lookahead+t.insert>=3)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Yt(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Yt(t,t.ins_h,t.window[i+3-1]),t.prev[i&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=i,i++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<$t&&0!==t.strm.avail_in)},ae=(t,e)=>{let a,s,i,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,h=t.strm.avail_in;do{if(a=65535,i=t.bi_valid+42>>3,t.strm.avail_out<i)break;if(i=t.strm.avail_out-i,s=t.strstart-t.block_start,a>s+t.strm.avail_in&&(a=s+t.strm.avail_in),a>i&&(a=i),a<r&&(0===a&&e!==zt||e===vt||a!==s+t.strm.avail_in))break;n=e===zt&&a===s+t.strm.avail_in?1:0,pt(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,Gt(t.strm),s&&(s>a&&(s=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+s),t.strm.next_out),t.strm.next_out+=s,t.strm.avail_out-=s,t.strm.total_out+=s,t.block_start+=s,a-=s),a&&(Jt(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 h-=t.strm.avail_in,h&&(h>=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<=h&&(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-h,t.strm.next_in),t.strstart),t.strstart+=h,t.insert+=h>t.w_size-t.insert?t.w_size-t.insert:h),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==vt&&e!==zt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(i=t.window_size-t.strstart,t.strm.avail_in>i&&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++,i+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),i>t.strm.avail_in&&(i=t.strm.avail_in),i&&(Jt(t.strm,t.window,t.strstart,i),t.strstart+=i,t.insert+=i>t.w_size-t.insert?t.w_size-t.insert:i),t.high_water<t.strstart&&(t.high_water=t.strstart),i=t.bi_valid+42>>3,i=t.pending_buf_size-i>65535?65535:t.pending_buf_size-i,r=i>t.w_size?t.w_size:i,s=t.strstart-t.block_start,(s>=r||(s||e===zt)&&e!==vt&&0===t.strm.avail_in&&s<=i)&&(a=s>i?i:s,n=e===zt&&0===t.strm.avail_in&&a===s?1:0,pt(t,t.block_start,a,n),t.block_start+=a,Gt(t.strm)),n?3:1)},se=(t,e)=>{let a,s;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a)),t.match_length>=3)if(s=yt(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=Yt(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=Yt(t,t.ins_h,t.window[t.strstart+1]);else s=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(s&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2},ie=(t,e)=>{let a,s,i;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a),t.match_length<=5&&(t.strategy===xt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-3,s=yt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=i&&(t.ins_h=Yt(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++,s&&(qt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(s=yt(t,0,t.window[t.strstart-1]),s&&qt(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&&(s=yt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2};function re(t,e,a,s,i){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=s,this.func=i}const ne=[new re(0,0,0,0,ae),new re(4,4,8,4,se),new re(4,5,16,8,se),new re(4,6,32,32,se),new re(4,4,16,16,ie),new re(8,16,32,32,ie),new re(8,16,128,128,ie),new re(8,32,128,256,ie),new re(32,128,258,1024,ie),new re(32,258,258,4096,ie)];function he(){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=Lt,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),Wt(this.dyn_ltree),Wt(this.dyn_dtree),Wt(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),Wt(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Wt(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 le=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Mt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Nt&&e.status!==Ht?1:0},oe=t=>{if(le(t))return Vt(t,Et);t.total_in=t.total_out=0,t.data_type=Pt;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?Mt:Nt,t.adler=2===e.wrap?0:1,e.last_flush=-2,mt(e),Ft},_e=t=>{const e=oe(t);var a;return e===Ft&&((a=t.state).window_size=2*a.w_size,Wt(a.head),a.max_lazy_match=ne[a.level].max_lazy,a.good_match=ne[a.level].good_length,a.nice_match=ne[a.level].nice_length,a.max_chain_length=ne[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},de=(t,e,a,s,i,r)=>{if(!t)return Et;let n=1;if(e===It&&(e=6),s<0?(n=0,s=-s):s>15&&(n=2,s-=16),i<1||i>9||a!==Lt||s<8||s>15||e<0||e>9||r<0||r>Bt||8===s&&1!==n)return Vt(t,Et);8===s&&(s=9);const h=new he;return t.state=h,h.strm=t,h.status=Mt,h.wrap=n,h.gzhead=null,h.w_bits=s,h.w_size=1<<h.w_bits,h.w_mask=h.w_size-1,h.hash_bits=i+7,h.hash_size=1<<h.hash_bits,h.hash_mask=h.hash_size-1,h.hash_shift=~~((h.hash_bits+3-1)/3),h.window=new Uint8Array(2*h.w_size),h.head=new Uint16Array(h.hash_size),h.prev=new Uint16Array(h.w_size),h.lit_bufsize=1<<i+6,h.pending_buf_size=4*h.lit_bufsize,h.pending_buf=new Uint8Array(h.pending_buf_size),h.sym_buf=h.lit_bufsize,h.sym_end=3*(h.lit_bufsize-1),h.level=e,h.strategy=r,h.method=a,_e(t)};var fe={deflateInit:(t,e)=>de(t,e,Lt,15,8,Tt),deflateInit2:de,deflateReset:_e,deflateResetKeep:oe,deflateSetHeader:(t,e)=>le(t)||2!==t.state.wrap?Et:(t.state.gzhead=e,Ft),deflate:(t,e)=>{if(le(t)||e>Rt||e<0)return t?Vt(t,Et):Et;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Ht&&e!==zt)return Vt(t,0===t.avail_out?Ot:Et);const s=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Gt(t),0===t.avail_out)return a.last_flush=-1,Ft}else if(0===t.avail_in&&jt(e)<=jt(s)&&e!==zt)return Vt(t,Ot);if(a.status===Ht&&0!==t.avail_in)return Vt(t,Ot);if(a.status===Mt&&0===a.wrap&&(a.status=Nt),a.status===Mt){let e=Lt+(a.w_bits-8<<4)<<8,s=-1;if(s=a.strategy>=At||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=s<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Qt(a,e),0!==a.strstart&&(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),t.adler=1,a.status=Nt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(57===a.status)if(t.adler=0,Xt(a,31),Xt(a,139),Xt(a,8),a.gzhead)Xt(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)),Xt(a,255&a.gzhead.time),Xt(a,a.gzhead.time>>8&255),Xt(a,a.gzhead.time>>16&255),Xt(a,a.gzhead.time>>24&255),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Xt(a,255&a.gzhead.extra.length),Xt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ut(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,3),a.status=Nt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;if(69===a.status){if(a.gzhead.extra){let e=a.pending,s=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+s>a.pending_buf_size;){let i=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=i,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;e=0,s-=i}let i=new Uint8Array(a.gzhead.extra);a.pending_buf.set(i.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending+=s,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(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,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Gt(t),0!==a.pending))return a.last_flush=-1,Ft;Xt(a,255&t.adler),Xt(a,t.adler>>8&255),t.adler=0}if(a.status=Nt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(0!==t.avail_in||0!==a.lookahead||e!==vt&&a.status!==Ht){let s=0===a.level?ae(a,e):a.strategy===At?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(ee(t),0===t.lookahead)){if(e===vt)return 1;break}if(t.match_length=0,a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===Ct?((t,e)=>{let a,s,i,r;const n=t.window;for(;;){if(t.lookahead<=Zt){if(ee(t),t.lookahead<=Zt&&e===vt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(i=t.strstart-1,s=n[i],s===n[++i]&&s===n[++i]&&s===n[++i])){r=t.strstart+Zt;do{}while(s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&i<r);t.match_length=Zt-(r-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=yt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ne[a.level].func(a,e);if(3!==s&&4!==s||(a.status=Ht),1===s||3===s)return 0===t.avail_out&&(a.last_flush=-1),Ft;if(2===s&&(e===kt?bt(a):e!==Rt&&(pt(a,0,0,!1),e===St&&(Wt(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Gt(t),0===t.avail_out))return a.last_flush=-1,Ft}return e!==zt?Ft:a.wrap<=0?Dt:(2===a.wrap?(Xt(a,255&t.adler),Xt(a,t.adler>>8&255),Xt(a,t.adler>>16&255),Xt(a,t.adler>>24&255),Xt(a,255&t.total_in),Xt(a,t.total_in>>8&255),Xt(a,t.total_in>>16&255),Xt(a,t.total_in>>24&255)):(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),Gt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?Ft:Dt)},deflateEnd:t=>{if(le(t))return Et;const e=t.state.status;return t.state=null,e===Nt?Vt(t,Ut):Ft},deflateSetDictionary:(t,e)=>{let a=e.length;if(le(t))return Et;const s=t.state,i=s.wrap;if(2===i||1===i&&s.status!==Mt||s.lookahead)return Et;if(1===i&&(t.adler=dt(t.adler,e,a,0)),s.wrap=0,a>=s.w_size){0===i&&(Wt(s.head),s.strstart=0,s.block_start=0,s.insert=0);let t=new Uint8Array(s.w_size);t.set(e.subarray(a-s.w_size,a),0),e=t,a=s.w_size}const r=t.avail_in,n=t.next_in,h=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,ee(s);s.lookahead>=3;){let t=s.strstart,e=s.lookahead-2;do{s.ins_h=Yt(s,s.ins_h,s.window[t+3-1]),s.prev[t&s.w_mask]=s.head[s.ins_h],s.head[s.ins_h]=t,t++}while(--e);s.strstart=t,s.lookahead=2,ee(s)}return s.strstart+=s.lookahead,s.block_start=s.strstart,s.insert=s.lookahead,s.lookahead=0,s.match_length=s.prev_length=2,s.match_available=0,t.next_in=n,t.input=h,t.avail_in=r,s.wrap=i,Ft},deflateInfo:"pako deflate (from Nodeca project)"};const ue=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var ce=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)ue(a,e)&&(t[e]=a[e])}}return t},ge=t=>{let e=0;for(let a=0,s=t.length;a<s;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,s=0,i=t.length;e<i;e++){let i=t[e];a.set(i,s),s+=i.length}return a};let me=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){me=!1}const pe=new Uint8Array(256);for(let t=0;t<256;t++)pe[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;pe[254]=pe[254]=1;var we=t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,s,i,r,n=t.length,h=0;for(i=0;i<n;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),h+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(h),r=0,i=0;r<h;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),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};var ye=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 be=Object.prototype.toString,{Z_NO_FLUSH:ve,Z_SYNC_FLUSH:ke,Z_FULL_FLUSH:Se,Z_FINISH:ze,Z_OK:Re,Z_STREAM_END:Fe,Z_DEFAULT_COMPRESSION:De,Z_DEFAULT_STRATEGY:Ee,Z_DEFLATED:Ue}=gt;function Oe(t){this.options=ce({level:De,method:Ue,chunkSize:16384,windowBits:15,memLevel:8,strategy:Ee},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 ye,this.strm.avail_out=0;let a=fe.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==Re)throw new Error(ct[a]);if(e.header&&fe.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?we(e.dictionary):"[object ArrayBuffer]"===be.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=fe.deflateSetDictionary(this.strm,t),a!==Re)throw new Error(ct[a]);this._dict_set=!0}}Oe.prototype.push=function(t,e){const a=this.strm,s=this.options.chunkSize;let i,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?ze:ve,"string"==typeof t?a.input=we(t):"[object ArrayBuffer]"===be.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(s),a.next_out=0,a.avail_out=s),(r===ke||r===Se)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(i=fe.deflate(a,r),i===Fe)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),i=fe.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===Re;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},Oe.prototype.onData=function(t){this.chunks.push(t)},Oe.prototype.onEnd=function(t){t===Re&&(this.result=ge(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Ie={deflate:function(t,e){const a=new Oe(e);if(a.push(t,!0),a.err)throw a.msg||ct[a.err];return a.result}};const{deflate:xe}=Ie;var Ae=xe;const Ce={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}},Be=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let s=[],i=!0;for(let s=0;s<t.length;s++)"<"==t[s]?i=!0:">"==t[s]?i=!1:(r(t[s],e[a]),a++);function r(t,e){if(!(t in Ce))throw"Unhandled character '"+t+"' in pack format";let a=Ce[t].bytes,r=new DataView(new ArrayBuffer(a));Ce[t].p.bind(r)(0,e,i);for(let t=0;t<a;t++)s.push(r.getUint8(t))}return s},Te=(t,e)=>{let a=0,s=[],i=!0;for(let e of t)"<"==e?i=!0:">"==e?i=!1:r(e);function r(t){if(!(t in Ce))throw"Unhandled character '"+t+"' in unpack format";let r=Ce[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let h=Ce[t].u.bind(n);s.push(h(0,i)),a+=r}return s};class Pe extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this.chipRevision=null,this.chipVariant=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(),await this.detectChip();let t=z(this.getChipFamily()).macFuse;for(let e=0;e<4;e++)this._efuses[e]=await this.readRegister(t+4*e);this.logger.log(`Chip type ${this.chipName}`)}async detectChip(){try{const t=(await this.getSecurityInfo()).chipId,e=y[t];if(e)return this.chipName=e.name,this.chipFamily=e.family,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),void this.logger.debug(`Detected chip via IMAGE_CHIP_ID: ${t} (${this.chipName})`);this.logger.debug(`Unknown IMAGE_CHIP_ID: ${t}, falling back to magic value detection`)}catch(t){this.logger.debug(`GET_SECURITY_INFO failed, using magic value detection: ${t}`)}let t=await this.readRegister(1073745920),e=b[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,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),this.logger.debug(`Detected chip via magic value: ${a(t>>>0,8)} (${this.chipName})`)}async getChipRevision(){if(this.chipFamily!==w)return 0;const t=await this.readRegister(1343410252);return 100*((t>>23&1)<<2|t>>4&3)+(15&t)}async getSecurityInfo(){const[t,e]=await this.checkCommand(20,[],0);if(e.length<20)throw new Error(`Invalid security info response length: ${e.length}`);return{flags:Te("<I",e.slice(0,4))[0],flashCryptCnt:e[4],keyPurposes:Array.from(e.slice(5,12)),chipId:e.length>=16?Te("<I",e.slice(12,16))[0]:0,apiVersion:e.length>=20?Te("<I",e.slice(16,20))[0]:0}}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],s=this._efuses[1],i=this._efuses[2],r=this._efuses[3];if(this.chipFamily==l){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(s>>16&255){if(1!=(s>>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]=s>>8&255,e[4]=255&s,e[5]=a>>24&255}else if(this.chipFamily==o)e[0]=i>>8&255,e[1]=255&i,e[2]=s>>24&255,e[3]=s>>16&255,e[4]=s>>8&255,e[5]=255&s;else{if(this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=m&&this.chipFamily!=p&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=s>>8&255,e[1]=255&s,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=Be("<I",t);await this.sendCommand(10,e);let[s,i]=await this.getResponse(10);return s}async checkCommand(t,e,s=0,i=3e3){i=Math.min(i,12e5),await this.sendCommand(t,e,s);let[r,n]=await this.getResponse(t,i);if(null===n)throw new Error("Didn't get enough status bytes");let h=0;if(this.IS_STUB||this.chipFamily==l?h=2:[o,_,d,f,u,c,g,m,p,w].includes(this.chipFamily)?h=4:[2,4].includes(n.length)&&(h=n.length),n.length<h)throw new Error("Didn't get enough status bytes");let y=n.slice(-h,n.length);if(n=n.slice(0,-h),this.debug&&(this.logger.debug("status",y),this.logger.debug("value",r),this.logger.debug("data",n)),1==y[0])throw 5==y[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(y[1]));return[r,n]}async sendCommand(t,e,a=0){let s=(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})([...Be("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${s.length} byte${1==s.length?"":"s"}:`,s),await this.writeToStream(s)}async readPacket(t){let i=null,r=!1,n=[];for(;;){let h=Date.now();for(n=[];Date.now()-h<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await s(10)}if(0==n.length){throw new R("Timed out waiting for packet "+(null===i?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===i){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 R("Invalid head of packet ("+a(t)+")");i=[]}else if(r)if(r=!1,220==t)i.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 R("Invalid SLIP escape (0xdb, "+a(t)+")");i.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(i)),i;i.push(t)}}throw new R("Invalid state")}async getResponse(t,e=3e3){for(let s=0;s<100;s++){const s=await this.readPacket(e);if(s.length<8)continue;const[i,r,n,h]=Te("<BBHI",s.slice(0,8));if(1!=i)continue;const l=s.slice(8);if(null==t||r==t)return[h,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==l)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=Be("<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),this.logger.log(`Changed baud rate to ${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()}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 s(100),!0;await s(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,h);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,s=0,i=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],s=r[2],i=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(s)}, FlashSizeFreq=${a(i)}`)}let n,h=t.byteLength,l=0,o=v;i?(n=Ae(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${h}. Compressed Size: ${l}`),o=await this.flashDeflBegin(h,l,s)):(this.logger.log(`Writing data with filesize: ${h}`),n=t,await this.flashBegin(h,s));let _=[],d=0,f=0,u=0,c=Date.now(),g=this.getFlashWriteSize(),m=i?l:h;for(;m-u>0;)this.debug&&this.logger.log(`Writing at ${a(s+d*g,8)} `),m-u>=g?_=Array.from(new Uint8Array(n,u,g)):(_=Array.from(new Uint8Array(n,u,m-u)),i||(_=_.concat(new Array(g-_.length).fill(255)))),i?await this.flashDeflBlock(_,d,o):await this.flashBlock(_,d),d+=1,f+=i?Math.round(_.length*h/l):_.length,u+=g,e(Math.min(f,h),h);this.logger.log("Took "+(Date.now()-c)+"ms to write "+m+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),i?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,s=!1){let i,r,n=this.getFlashWriteSize();!this.IS_STUB&&[o,_,d,f,u,c,g,m,p,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let h,y=Math.floor((t+n-1)/n);i=this.chipFamily==l?this.getEraseSize(e,t):t,h=this.IS_STUB?v:S(3e4,t);let b=Date.now();return r=Be("<IIII",i,y,n,e),this.chipFamily!=o&&this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=m&&this.chipFamily!=p&&this.chipFamily!=w||(r=r.concat(Be("<I",s?1:0))),this.logger.log("Erase size "+i+", blocks "+y+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(s?"yes":"no")),await this.checkCommand(2,r,0,h),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-b)+"ms to erase "+y+" bytes"),y}async flashDeflBegin(t=0,e=0,a=0,s=!1){let i,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),h=Math.floor((t+r-1)/r),l=0,o=0;return this.IS_STUB?(l=t,o=S(3e4,l)):(l=h*r,o=v),i=Be("<IIII",l,n,r,a),await this.checkCommand(16,i,0,o),o}async flashFinish(){let t=Be("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Be("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return z(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,s=0,i=0){let r=Be("<IIII",t,e,a,s);i>0&&r.concat(Be("<IIII",z(this.getChipFamily()).uartDateReg,0,0,i)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let s=t.regBase+t.mosiDlenOffs,i=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(s,e-1),a>0&&await this.writeRegister(i,a-1)}else{let s=t.regBase+t.usr1Offs,i=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(s,i)}}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,s=0){let i=z(this.getChipFamily()),r=i.regBase,n=r,h=r+i.usrOffs,l=r+i.usr2Offs,o=r+i.w0Offs,_=1<<18;if(s>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 d=8*e.length,f=await this.readRegister(h),u=await this.readRegister(l),c=1<<31;if(s>0&&(c|=268435456),d>0&&(c|=134217728),await this.setDataLengths(i,d,s),await this.writeRegister(h,c),await this.writeRegister(l,7<<28|t),0==d)await this.writeRegister(o,0);else{e.concat(new Array(e.length%4).fill(0));let t=Te("I".repeat(Math.floor(e.length/4)),e),s=o;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(s)}`),await this.writeRegister(s,e),s+=4}await this.writeRegister(n,_),await this.waitDone(n,_);let g=await this.readRegister(o);return await this.writeRegister(h,f),await this.writeRegister(l,u),g}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,s=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)}${s.toString(16)}`),this.flashSize=i[s],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,s=Math.floor((e+a-1)/a),i=16-Math.floor(t/a)%16;return s<i&&(i=s),s<2*i?Math.floor((s+1)/2*a):(s-i)*a}async memBegin(t,e,a,s){return await this.checkCommand(5,Be("<IIII",t,e,a,s))}async memBlock(t,e){return await this.checkCommand(7,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?v:500,a=Be("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await F(this.chipFamily,this.chipRevision);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let s=t[e+"_start"],i=t[e].length,r=Math.floor((i+a-1)/a);await this.memBegin(i,r,a,s);for(let s of Array(r).keys()){let r=s*a,n=r+a;n>i&&(n=i),await this.memBlock(t[e].slice(r,n),s)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const s=await this.readPacket(500);if(e=String.fromCharCode(...s),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const i=new Le(this.port,this.logger,this);return await i.detectFlashSize(),i}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 Le extends Pe{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,s,i){let r=await F(this.chipFamily,this.chipRevision),n=i,h=i+t;console.log(n,h),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&&h>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(h,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,k)}}const Ze=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Pe(e,t)};export{o as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,u as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C5,g as CHIP_FAMILY_ESP32C6,m as CHIP_FAMILY_ESP32C61,p as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,_ as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,l as CHIP_FAMILY_ESP8266,Pe as ESPLoader,Ze as connect};
1
+ const t=t=>{let e=[];for(let a=0;a<t.length;a++){let s=t.charCodeAt(a);s<=255&&e.push(s)}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")},s=t=>new Promise(e=>setTimeout(e,t)),i={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=1343410176,h=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),l=33382,o=50,_=12882,d=12883,f=12994,u=12995,c=12997,g=12998,p=207969,m=12914,w=12928,y={5:{name:"ESP32-C3",family:u},9:{name:"ESP32-S3",family:d},12:{name:"ESP32-C2",family:f},13:{name:"ESP32-C6",family:g},16:{name:"ESP32-H2",family:m},17:{name:"ESP32-C5",family:c},18:{name:"ESP32-P4",family:w},20:{name:"ESP32-C61",family:p}},b={4293968129:{name:"ESP8266",family:l},15736195:{name:"ESP32",family:o},1990:{name:"ESP32-S2",family:_},9:{name:"ESP32-S3",family:d},203546735:{name:"ESP32-C2",family:f},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},456216687:{name:"ESP32-C3",family:u},1130455151:{name:"ESP32-C3",family:u},1216438383:{name:"ESP32-C3",family:u},1763790959:{name:"ESP32-C3",family:u},285294703:{name:"ESP32-C5",family:c},1607549039:{name:"ESP32-C5",family:c},1548751960:{name:"ESP32-C5",family:c},1675706479:{name:"ESP32-C5",family:c},752910447:{name:"ESP32-C6",family:g},606167151:{name:"ESP32-C61",family:p},871374959:{name:"ESP32-C61",family:p},1333878895:{name:"ESP32-C61",family:p},1913741423:{name:"ESP32-C61",family:p},2548236392:{name:"ESP32-H2",family:m},3619110528:{name:"ESP32-H2",family:m},0:{name:"ESP32-P4",family:w},117676761:{name:"ESP32-P4",family:w},182303440:{name:"ESP32-P4",family:w}},v=3e3,S=6e5,k=(t,e)=>{let a=Math.floor(t*(e/486));return a<v?v:a},z=t=>{switch(t){case o:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case _: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 l: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 u: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:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:8192};case g:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case p:return{regBase:1610625024,baseFuse:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case m:return{regBase:1610625024,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:n,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 R extends Error{constructor(t){super(t),this.name="SlipReadError"}}const F=async(e,a)=>{let s;return e==o?s=await import("./esp32-BNIFdu1P.js"):e==_?s=await import("./esp32s2-Bk4mqADi.js"):e==d?s=await import("./esp32s3-Df3OUCOC.js"):e==l?s=await import("./esp8266-CQFcqJ_a.js"):e==f?s=await import("./esp32c2-BqxquOKw.js"):e==u?s=await import("./esp32c3-BOOqe8me.js"):e==c?s=await import("./esp32c5-mcj52-K1.js"):e==g?s=await import("./esp32c6-Cg5qYgg7.js"):e==p?s=await import("./esp32c61-CzCdsydk.js"):e==m?s=await import("./esp32h2-DZa_lpff.js"):e==w&&(s=null!=a&&a>=300?await import("./esp32p4r3-Cle9QJmZ.js"):await import("./esp32p4-DyGqUAeZ.js")),{...s,text:t(atob(s.text)),data:t(atob(s.data))}};function E(t){let e=t.length;for(;--e>=0;)t[e]=0}const U=256,D=286,I=30,O=15,x=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]),A=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]),C=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),B=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),T=new Array(576);E(T);const P=new Array(60);E(P);const L=new Array(512);E(L);const Z=new Array(256);E(Z);const $=new Array(29);E($);const N=new Array(I);function M(t,e,a,s,i){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=s,this.max_length=i,this.has_stree=t&&t.length}let H,V,j;function W(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}E(N);const K=t=>t<256?L[t]:L[256+(t>>>7)],Y=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},G=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,Y(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)},q=(t,e,a)=>{G(t,a[2*e],a[2*e+1])},X=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Q=(t,e,a)=>{const s=new Array(16);let i,r,n=0;for(i=1;i<=O;i++)n=n+a[i-1]<<1,s[i]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=X(s[e]++,e))}},J=t=>{let e;for(e=0;e<D;e++)t.dyn_ltree[2*e]=0;for(e=0;e<I;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},tt=t=>{t.bi_valid>8?Y(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},et=(t,e,a,s)=>{const i=2*e,r=2*a;return t[i]<t[r]||t[i]===t[r]&&s[e]<=s[a]},at=(t,e,a)=>{const s=t.heap[a];let i=a<<1;for(;i<=t.heap_len&&(i<t.heap_len&&et(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!et(e,s,t.heap[i],t.depth));)t.heap[a]=t.heap[i],a=i,i<<=1;t.heap[a]=s},st=(t,e,a)=>{let s,i,r,n,h=0;if(0!==t.sym_next)do{s=255&t.pending_buf[t.sym_buf+h++],s+=(255&t.pending_buf[t.sym_buf+h++])<<8,i=t.pending_buf[t.sym_buf+h++],0===s?q(t,i,e):(r=Z[i],q(t,r+U+1,e),n=x[r],0!==n&&(i-=$[r],G(t,i,n)),s--,r=K(s),q(t,r,a),n=A[r],0!==n&&(s-=N[r],G(t,s,n)))}while(h<t.sym_next);q(t,256,e)},it=(t,e)=>{const a=e.dyn_tree,s=e.stat_desc.static_tree,i=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,h,l,o=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=o=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=o<2?++o:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,i&&(t.static_len-=s[2*l+1]);for(e.max_code=o,n=t.heap_len>>1;n>=1;n--)at(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],at(t,a,1),h=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=h,a[2*l]=a[2*n]+a[2*h],t.depth[l]=(t.depth[n]>=t.depth[h]?t.depth[n]:t.depth[h])+1,a[2*n+1]=a[2*h+1]=l,t.heap[1]=l++,at(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,s=e.max_code,i=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,h=e.stat_desc.extra_base,l=e.stat_desc.max_length;let o,_,d,f,u,c,g=0;for(f=0;f<=O;f++)t.bl_count[f]=0;for(a[2*t.heap[t.heap_max]+1]=0,o=t.heap_max+1;o<573;o++)_=t.heap[o],f=a[2*a[2*_+1]+1]+1,f>l&&(f=l,g++),a[2*_+1]=f,_>s||(t.bl_count[f]++,u=0,_>=h&&(u=n[_-h]),c=a[2*_],t.opt_len+=c*(f+u),r&&(t.static_len+=c*(i[2*_+1]+u)));if(0!==g){do{for(f=l-1;0===t.bl_count[f];)f--;t.bl_count[f]--,t.bl_count[f+1]+=2,t.bl_count[l]--,g-=2}while(g>0);for(f=l;0!==f;f--)for(_=t.bl_count[f];0!==_;)d=t.heap[--o],d>s||(a[2*d+1]!==f&&(t.opt_len+=(f-a[2*d+1])*a[2*d],a[2*d+1]=f),_--)}})(t,e),Q(a,o,t.bl_count)},rt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),e[2*(a+1)+1]=65535,s=0;s<=a;s++)i=n,n=e[2*(s+1)+1],++h<l&&i===n||(h<o?t.bl_tree[2*i]+=h:0!==i?(i!==r&&t.bl_tree[2*i]++,t.bl_tree[32]++):h<=10?t.bl_tree[34]++:t.bl_tree[36]++,h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4))},nt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),s=0;s<=a;s++)if(i=n,n=e[2*(s+1)+1],!(++h<l&&i===n)){if(h<o)do{q(t,i,t.bl_tree)}while(0!==--h);else 0!==i?(i!==r&&(q(t,i,t.bl_tree),h--),q(t,16,t.bl_tree),G(t,h-3,2)):h<=10?(q(t,17,t.bl_tree),G(t,h-3,3)):(q(t,18,t.bl_tree),G(t,h-11,7));h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4)}};let ht=!1;const lt=(t,e,a,s)=>{G(t,0+(s?1:0),3),tt(t),Y(t,a),Y(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var ot=(t,e,a,s)=>{let i,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<U;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),it(t,t.l_desc),it(t,t.d_desc),n=(t=>{let e;for(rt(t,t.dyn_ltree,t.l_desc.max_code),rt(t,t.dyn_dtree,t.d_desc.max_code),it(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*B[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),i=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=i&&(i=r)):i=r=a+5,a+4<=i&&-1!==e?lt(t,e,a,s):4===t.strategy||r===i?(G(t,2+(s?1:0),3),st(t,T,P)):(G(t,4+(s?1:0),3),((t,e,a,s)=>{let i;for(G(t,e-257,5),G(t,a-1,5),G(t,s-4,4),i=0;i<s;i++)G(t,t.bl_tree[2*B[i]+1],3);nt(t,t.dyn_ltree,e-1),nt(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),st(t,t.dyn_ltree,t.dyn_dtree)),J(t),s&&tt(t)},_t={_tr_init:t=>{ht||((()=>{let t,e,a,s,i;const r=new Array(16);for(a=0,s=0;s<28;s++)for($[s]=a,t=0;t<1<<x[s];t++)Z[a++]=s;for(Z[a-1]=s,i=0,s=0;s<16;s++)for(N[s]=i,t=0;t<1<<A[s];t++)L[i++]=s;for(i>>=7;s<I;s++)for(N[s]=i<<7,t=0;t<1<<A[s]-7;t++)L[256+i++]=s;for(e=0;e<=O;e++)r[e]=0;for(t=0;t<=143;)T[2*t+1]=8,t++,r[8]++;for(;t<=255;)T[2*t+1]=9,t++,r[9]++;for(;t<=279;)T[2*t+1]=7,t++,r[7]++;for(;t<=287;)T[2*t+1]=8,t++,r[8]++;for(Q(T,287,r),t=0;t<I;t++)P[2*t+1]=5,P[2*t]=X(t,5);H=new M(T,x,257,D,O),V=new M(P,A,0,I,O),j=new M(new Array(0),C,0,19,7)})(),ht=!0),t.l_desc=new W(t.dyn_ltree,H),t.d_desc=new W(t.dyn_dtree,V),t.bl_desc=new W(t.bl_tree,j),t.bi_buf=0,t.bi_valid=0,J(t)},_tr_stored_block:lt,_tr_flush_block:ot,_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*(Z[a]+U+1)]++,t.dyn_dtree[2*K(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{G(t,2,3),q(t,256,T),(t=>{16===t.bi_valid?(Y(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 dt=(t,e,a,s)=>{let i=65535&t,r=t>>>16&65535,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{i=i+e[s++]|0,r=r+i|0}while(--n);i%=65521,r%=65521}return i|r<<16};const ft=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var s=0;s<8;s++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ut=(t,e,a,s)=>{const i=ft,r=s+a;t^=-1;for(let a=s;a<r;a++)t=t>>>8^i[255&(t^e[a])];return-1^t},ct={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"},gt={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_OK:0,Z_STREAM_END:1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_BUF_ERROR:-5,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:pt,_tr_stored_block:mt,_tr_flush_block:wt,_tr_tally:yt,_tr_align:bt}=_t,{Z_NO_FLUSH:vt,Z_PARTIAL_FLUSH:St,Z_FULL_FLUSH:kt,Z_FINISH:zt,Z_BLOCK:Rt,Z_OK:Ft,Z_STREAM_END:Et,Z_STREAM_ERROR:Ut,Z_DATA_ERROR:Dt,Z_BUF_ERROR:It,Z_DEFAULT_COMPRESSION:Ot,Z_FILTERED:xt,Z_HUFFMAN_ONLY:At,Z_RLE:Ct,Z_FIXED:Bt,Z_DEFAULT_STRATEGY:Tt,Z_UNKNOWN:Pt,Z_DEFLATED:Lt}=gt,Zt=258,$t=262,Nt=42,Mt=113,Ht=666,Vt=(t,e)=>(t.msg=ct[e],e),jt=t=>2*t-(t>4?9:0),Wt=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Kt=t=>{let e,a,s,i=t.w_size;e=t.hash_size,s=e;do{a=t.head[--s],t.head[s]=a>=i?a-i:0}while(--e);e=i,s=e;do{a=t.prev[--s],t.prev[s]=a>=i?a-i:0}while(--e)};let Yt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Gt=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))},qt=(t,e)=>{wt(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Gt(t.strm)},Xt=(t,e)=>{t.pending_buf[t.pending++]=e},Qt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},Jt=(t,e,a,s)=>{let i=t.avail_in;return i>s&&(i=s),0===i?0:(t.avail_in-=i,e.set(t.input.subarray(t.next_in,t.next_in+i),a),1===t.state.wrap?t.adler=dt(t.adler,e,i,a):2===t.state.wrap&&(t.adler=ut(t.adler,e,i,a)),t.next_in+=i,t.total_in+=i,i)},te=(t,e)=>{let a,s,i=t.max_chain_length,r=t.strstart,n=t.prev_length,h=t.nice_match;const l=t.strstart>t.w_size-$t?t.strstart-(t.w_size-$t):0,o=t.window,_=t.w_mask,d=t.prev,f=t.strstart+Zt;let u=o[r+n-1],c=o[r+n];t.prev_length>=t.good_match&&(i>>=2),h>t.lookahead&&(h=t.lookahead);do{if(a=e,o[a+n]===c&&o[a+n-1]===u&&o[a]===o[r]&&o[++a]===o[r+1]){r+=2,a++;do{}while(o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&r<f);if(s=Zt-(f-r),r=f-Zt,s>n){if(t.match_start=e,n=s,s>=h)break;u=o[r+n-1],c=o[r+n]}}}while((e=d[e&_])>l&&0!==--i);return n<=t.lookahead?n:t.lookahead},ee=t=>{const e=t.w_size;let a,s,i;do{if(s=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-$t)&&(t.window.set(t.window.subarray(e,e+e-s),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),Kt(t),s+=e),0===t.strm.avail_in)break;if(a=Jt(t.strm,t.window,t.strstart+t.lookahead,s),t.lookahead+=a,t.lookahead+t.insert>=3)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Yt(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Yt(t,t.ins_h,t.window[i+3-1]),t.prev[i&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=i,i++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<$t&&0!==t.strm.avail_in)},ae=(t,e)=>{let a,s,i,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,h=t.strm.avail_in;do{if(a=65535,i=t.bi_valid+42>>3,t.strm.avail_out<i)break;if(i=t.strm.avail_out-i,s=t.strstart-t.block_start,a>s+t.strm.avail_in&&(a=s+t.strm.avail_in),a>i&&(a=i),a<r&&(0===a&&e!==zt||e===vt||a!==s+t.strm.avail_in))break;n=e===zt&&a===s+t.strm.avail_in?1:0,mt(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,Gt(t.strm),s&&(s>a&&(s=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+s),t.strm.next_out),t.strm.next_out+=s,t.strm.avail_out-=s,t.strm.total_out+=s,t.block_start+=s,a-=s),a&&(Jt(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 h-=t.strm.avail_in,h&&(h>=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<=h&&(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-h,t.strm.next_in),t.strstart),t.strstart+=h,t.insert+=h>t.w_size-t.insert?t.w_size-t.insert:h),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==vt&&e!==zt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(i=t.window_size-t.strstart,t.strm.avail_in>i&&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++,i+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),i>t.strm.avail_in&&(i=t.strm.avail_in),i&&(Jt(t.strm,t.window,t.strstart,i),t.strstart+=i,t.insert+=i>t.w_size-t.insert?t.w_size-t.insert:i),t.high_water<t.strstart&&(t.high_water=t.strstart),i=t.bi_valid+42>>3,i=t.pending_buf_size-i>65535?65535:t.pending_buf_size-i,r=i>t.w_size?t.w_size:i,s=t.strstart-t.block_start,(s>=r||(s||e===zt)&&e!==vt&&0===t.strm.avail_in&&s<=i)&&(a=s>i?i:s,n=e===zt&&0===t.strm.avail_in&&a===s?1:0,mt(t,t.block_start,a,n),t.block_start+=a,Gt(t.strm)),n?3:1)},se=(t,e)=>{let a,s;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a)),t.match_length>=3)if(s=yt(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=Yt(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=Yt(t,t.ins_h,t.window[t.strstart+1]);else s=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(s&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2},ie=(t,e)=>{let a,s,i;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a),t.match_length<=5&&(t.strategy===xt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-3,s=yt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=i&&(t.ins_h=Yt(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++,s&&(qt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(s=yt(t,0,t.window[t.strstart-1]),s&&qt(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&&(s=yt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2};function re(t,e,a,s,i){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=s,this.func=i}const ne=[new re(0,0,0,0,ae),new re(4,4,8,4,se),new re(4,5,16,8,se),new re(4,6,32,32,se),new re(4,4,16,16,ie),new re(8,16,32,32,ie),new re(8,16,128,128,ie),new re(8,32,128,256,ie),new re(32,128,258,1024,ie),new re(32,258,258,4096,ie)];function he(){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=Lt,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),Wt(this.dyn_ltree),Wt(this.dyn_dtree),Wt(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),Wt(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Wt(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 le=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Nt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Mt&&e.status!==Ht?1:0},oe=t=>{if(le(t))return Vt(t,Ut);t.total_in=t.total_out=0,t.data_type=Pt;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?Nt:Mt,t.adler=2===e.wrap?0:1,e.last_flush=-2,pt(e),Ft},_e=t=>{const e=oe(t);var a;return e===Ft&&((a=t.state).window_size=2*a.w_size,Wt(a.head),a.max_lazy_match=ne[a.level].max_lazy,a.good_match=ne[a.level].good_length,a.nice_match=ne[a.level].nice_length,a.max_chain_length=ne[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},de=(t,e,a,s,i,r)=>{if(!t)return Ut;let n=1;if(e===Ot&&(e=6),s<0?(n=0,s=-s):s>15&&(n=2,s-=16),i<1||i>9||a!==Lt||s<8||s>15||e<0||e>9||r<0||r>Bt||8===s&&1!==n)return Vt(t,Ut);8===s&&(s=9);const h=new he;return t.state=h,h.strm=t,h.status=Nt,h.wrap=n,h.gzhead=null,h.w_bits=s,h.w_size=1<<h.w_bits,h.w_mask=h.w_size-1,h.hash_bits=i+7,h.hash_size=1<<h.hash_bits,h.hash_mask=h.hash_size-1,h.hash_shift=~~((h.hash_bits+3-1)/3),h.window=new Uint8Array(2*h.w_size),h.head=new Uint16Array(h.hash_size),h.prev=new Uint16Array(h.w_size),h.lit_bufsize=1<<i+6,h.pending_buf_size=4*h.lit_bufsize,h.pending_buf=new Uint8Array(h.pending_buf_size),h.sym_buf=h.lit_bufsize,h.sym_end=3*(h.lit_bufsize-1),h.level=e,h.strategy=r,h.method=a,_e(t)};var fe={deflateInit:(t,e)=>de(t,e,Lt,15,8,Tt),deflateInit2:de,deflateReset:_e,deflateResetKeep:oe,deflateSetHeader:(t,e)=>le(t)||2!==t.state.wrap?Ut:(t.state.gzhead=e,Ft),deflate:(t,e)=>{if(le(t)||e>Rt||e<0)return t?Vt(t,Ut):Ut;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Ht&&e!==zt)return Vt(t,0===t.avail_out?It:Ut);const s=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Gt(t),0===t.avail_out)return a.last_flush=-1,Ft}else if(0===t.avail_in&&jt(e)<=jt(s)&&e!==zt)return Vt(t,It);if(a.status===Ht&&0!==t.avail_in)return Vt(t,It);if(a.status===Nt&&0===a.wrap&&(a.status=Mt),a.status===Nt){let e=Lt+(a.w_bits-8<<4)<<8,s=-1;if(s=a.strategy>=At||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=s<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Qt(a,e),0!==a.strstart&&(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),t.adler=1,a.status=Mt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(57===a.status)if(t.adler=0,Xt(a,31),Xt(a,139),Xt(a,8),a.gzhead)Xt(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)),Xt(a,255&a.gzhead.time),Xt(a,a.gzhead.time>>8&255),Xt(a,a.gzhead.time>>16&255),Xt(a,a.gzhead.time>>24&255),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Xt(a,255&a.gzhead.extra.length),Xt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ut(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,3),a.status=Mt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;if(69===a.status){if(a.gzhead.extra){let e=a.pending,s=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+s>a.pending_buf_size;){let i=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=i,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;e=0,s-=i}let i=new Uint8Array(a.gzhead.extra);a.pending_buf.set(i.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending+=s,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(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,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Gt(t),0!==a.pending))return a.last_flush=-1,Ft;Xt(a,255&t.adler),Xt(a,t.adler>>8&255),t.adler=0}if(a.status=Mt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(0!==t.avail_in||0!==a.lookahead||e!==vt&&a.status!==Ht){let s=0===a.level?ae(a,e):a.strategy===At?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(ee(t),0===t.lookahead)){if(e===vt)return 1;break}if(t.match_length=0,a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===Ct?((t,e)=>{let a,s,i,r;const n=t.window;for(;;){if(t.lookahead<=Zt){if(ee(t),t.lookahead<=Zt&&e===vt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(i=t.strstart-1,s=n[i],s===n[++i]&&s===n[++i]&&s===n[++i])){r=t.strstart+Zt;do{}while(s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&i<r);t.match_length=Zt-(r-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=yt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ne[a.level].func(a,e);if(3!==s&&4!==s||(a.status=Ht),1===s||3===s)return 0===t.avail_out&&(a.last_flush=-1),Ft;if(2===s&&(e===St?bt(a):e!==Rt&&(mt(a,0,0,!1),e===kt&&(Wt(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Gt(t),0===t.avail_out))return a.last_flush=-1,Ft}return e!==zt?Ft:a.wrap<=0?Et:(2===a.wrap?(Xt(a,255&t.adler),Xt(a,t.adler>>8&255),Xt(a,t.adler>>16&255),Xt(a,t.adler>>24&255),Xt(a,255&t.total_in),Xt(a,t.total_in>>8&255),Xt(a,t.total_in>>16&255),Xt(a,t.total_in>>24&255)):(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),Gt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?Ft:Et)},deflateEnd:t=>{if(le(t))return Ut;const e=t.state.status;return t.state=null,e===Mt?Vt(t,Dt):Ft},deflateSetDictionary:(t,e)=>{let a=e.length;if(le(t))return Ut;const s=t.state,i=s.wrap;if(2===i||1===i&&s.status!==Nt||s.lookahead)return Ut;if(1===i&&(t.adler=dt(t.adler,e,a,0)),s.wrap=0,a>=s.w_size){0===i&&(Wt(s.head),s.strstart=0,s.block_start=0,s.insert=0);let t=new Uint8Array(s.w_size);t.set(e.subarray(a-s.w_size,a),0),e=t,a=s.w_size}const r=t.avail_in,n=t.next_in,h=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,ee(s);s.lookahead>=3;){let t=s.strstart,e=s.lookahead-2;do{s.ins_h=Yt(s,s.ins_h,s.window[t+3-1]),s.prev[t&s.w_mask]=s.head[s.ins_h],s.head[s.ins_h]=t,t++}while(--e);s.strstart=t,s.lookahead=2,ee(s)}return s.strstart+=s.lookahead,s.block_start=s.strstart,s.insert=s.lookahead,s.lookahead=0,s.match_length=s.prev_length=2,s.match_available=0,t.next_in=n,t.input=h,t.avail_in=r,s.wrap=i,Ft},deflateInfo:"pako deflate (from Nodeca project)"};const ue=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var ce=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)ue(a,e)&&(t[e]=a[e])}}return t},ge=t=>{let e=0;for(let a=0,s=t.length;a<s;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,s=0,i=t.length;e<i;e++){let i=t[e];a.set(i,s),s+=i.length}return a};let pe=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){pe=!1}const me=new Uint8Array(256);for(let t=0;t<256;t++)me[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;me[254]=me[254]=1;var we=t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,s,i,r,n=t.length,h=0;for(i=0;i<n;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),h+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(h),r=0,i=0;r<h;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),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};var ye=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 be=Object.prototype.toString,{Z_NO_FLUSH:ve,Z_SYNC_FLUSH:Se,Z_FULL_FLUSH:ke,Z_FINISH:ze,Z_OK:Re,Z_STREAM_END:Fe,Z_DEFAULT_COMPRESSION:Ee,Z_DEFAULT_STRATEGY:Ue,Z_DEFLATED:De}=gt;function Ie(t){this.options=ce({level:Ee,method:De,chunkSize:16384,windowBits:15,memLevel:8,strategy:Ue},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 ye,this.strm.avail_out=0;let a=fe.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==Re)throw new Error(ct[a]);if(e.header&&fe.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?we(e.dictionary):"[object ArrayBuffer]"===be.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=fe.deflateSetDictionary(this.strm,t),a!==Re)throw new Error(ct[a]);this._dict_set=!0}}Ie.prototype.push=function(t,e){const a=this.strm,s=this.options.chunkSize;let i,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?ze:ve,"string"==typeof t?a.input=we(t):"[object ArrayBuffer]"===be.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(s),a.next_out=0,a.avail_out=s),(r===Se||r===ke)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(i=fe.deflate(a,r),i===Fe)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),i=fe.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===Re;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},Ie.prototype.onData=function(t){this.chunks.push(t)},Ie.prototype.onEnd=function(t){t===Re&&(this.result=ge(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Oe={deflate:function(t,e){const a=new Ie(e);if(a.push(t,!0),a.err)throw a.msg||ct[a.err];return a.result}};const{deflate:xe}=Oe;var Ae=xe;const Ce={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}},Be=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let s=[],i=!0;for(let s=0;s<t.length;s++)"<"==t[s]?i=!0:">"==t[s]?i=!1:(r(t[s],e[a]),a++);function r(t,e){if(!(t in Ce))throw"Unhandled character '"+t+"' in pack format";let a=Ce[t].bytes,r=new DataView(new ArrayBuffer(a));Ce[t].p.bind(r)(0,e,i);for(let t=0;t<a;t++)s.push(r.getUint8(t))}return s},Te=(t,e)=>{let a=0,s=[],i=!0;for(let e of t)"<"==e?i=!0:">"==e?i=!1:r(e);function r(t){if(!(t in Ce))throw"Unhandled character '"+t+"' in unpack format";let r=Ce[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let h=Ce[t].u.bind(n);s.push(h(0,i)),a+=r}return s};class Pe extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this.chipRevision=null,this.chipVariant=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(),await this.detectChip();let t=z(this.getChipFamily()).macFuse;for(let e=0;e<4;e++)this._efuses[e]=await this.readRegister(t+4*e);this.logger.log(`Chip type ${this.chipName}`)}async detectChip(){try{const t=(await this.getSecurityInfo()).chipId,e=y[t];if(e)return this.chipName=e.name,this.chipFamily=e.family,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),void this.logger.debug(`Detected chip via IMAGE_CHIP_ID: ${t} (${this.chipName})`);this.logger.debug(`Unknown IMAGE_CHIP_ID: ${t}, falling back to magic value detection`)}catch(t){this.logger.debug(`GET_SECURITY_INFO failed, using magic value detection: ${t}`),this._inputBuffer.length=0,await s(100);try{await this.sync()}catch(t){this.logger.debug(`Re-sync after GET_SECURITY_INFO failure: ${t}`)}}let t=await this.readRegister(1073745920),e=b[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,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),this.logger.debug(`Detected chip via magic value: ${a(t>>>0,8)} (${this.chipName})`)}async getChipRevision(){if(this.chipFamily!==w)return 0;const t=await this.readRegister(1343410252);return 100*((t>>23&1)<<2|t>>4&3)+(15&t)}async getSecurityInfo(){const[t,e]=await this.checkCommand(20,[],0);if(0===e.length)throw new Error("GET_SECURITY_INFO not supported or returned empty response");if(e.length<12)throw new Error(`Invalid security info response length: ${e.length} (expected at least 12 bytes)`);return{flags:Te("<I",e.slice(0,4))[0],flashCryptCnt:e[4],keyPurposes:Array.from(e.slice(5,12)),chipId:e.length>=16?Te("<I",e.slice(12,16))[0]:0,apiVersion:e.length>=20?Te("<I",e.slice(16,20))[0]:0}}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],s=this._efuses[1],i=this._efuses[2],r=this._efuses[3];if(this.chipFamily==l){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(s>>16&255){if(1!=(s>>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]=s>>8&255,e[4]=255&s,e[5]=a>>24&255}else if(this.chipFamily==o)e[0]=i>>8&255,e[1]=255&i,e[2]=s>>24&255,e[3]=s>>16&255,e[4]=s>>8&255,e[5]=255&s;else{if(this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=p&&this.chipFamily!=m&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=s>>8&255,e[1]=255&s,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=Be("<I",t);await this.sendCommand(10,e);let[s,i]=await this.getResponse(10);return s}async checkCommand(t,e,s=0,i=3e3){i=Math.min(i,12e5),await this.sendCommand(t,e,s);let[r,n]=await this.getResponse(t,i);if(null===n)throw new Error("Didn't get enough status bytes");let h=0;if(this.IS_STUB||this.chipFamily==l?h=2:[o,_,d,f,u,c,g,p,m,w].includes(this.chipFamily)||20===t?h=4:[2,4].includes(n.length)&&(h=n.length),n.length<h)throw new Error("Didn't get enough status bytes");let y=n.slice(-h,n.length);if(n=n.slice(0,-h),this.debug&&(this.logger.debug("status",y),this.logger.debug("value",r),this.logger.debug("data",n)),1==y[0])throw 5==y[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(y[1]));return[r,n]}async sendCommand(t,e,a=0){let s=(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})([...Be("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${s.length} byte${1==s.length?"":"s"}:`,s),await this.writeToStream(s)}async readPacket(t){let i=null,r=!1,n=[];for(;;){let h=Date.now();for(n=[];Date.now()-h<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await s(10)}if(0==n.length){throw new R("Timed out waiting for packet "+(null===i?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===i){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 R("Invalid head of packet ("+a(t)+")");i=[]}else if(r)if(r=!1,220==t)i.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 R("Invalid SLIP escape (0xdb, "+a(t)+")");i.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(i)),i;i.push(t)}}throw new R("Invalid state")}async getResponse(t,e=3e3){for(let s=0;s<100;s++){const s=await this.readPacket(e);if(s.length<8)continue;const[i,r,n,h]=Te("<BBHI",s.slice(0,8));if(1!=i)continue;const l=s.slice(8);if(null==t||r==t)return[h,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==l)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=Be("<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),this.logger.log(`Changed baud rate to ${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()}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 s(100),!0;await s(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,h);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,s=0,i=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],s=r[2],i=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(s)}, FlashSizeFreq=${a(i)}`)}let n,h=t.byteLength,l=0,o=v;i?(n=Ae(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${h}. Compressed Size: ${l}`),o=await this.flashDeflBegin(h,l,s)):(this.logger.log(`Writing data with filesize: ${h}`),n=t,await this.flashBegin(h,s));let _=[],d=0,f=0,u=0,c=Date.now(),g=this.getFlashWriteSize(),p=i?l:h;for(;p-u>0;)this.debug&&this.logger.log(`Writing at ${a(s+d*g,8)} `),p-u>=g?_=Array.from(new Uint8Array(n,u,g)):(_=Array.from(new Uint8Array(n,u,p-u)),i||(_=_.concat(new Array(g-_.length).fill(255)))),i?await this.flashDeflBlock(_,d,o):await this.flashBlock(_,d),d+=1,f+=i?Math.round(_.length*h/l):_.length,u+=g,e(Math.min(f,h),h);this.logger.log("Took "+(Date.now()-c)+"ms to write "+p+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),i?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,s=!1){let i,r,n=this.getFlashWriteSize();!this.IS_STUB&&[o,_,d,f,u,c,g,p,m,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let h,y=Math.floor((t+n-1)/n);i=this.chipFamily==l?this.getEraseSize(e,t):t,h=this.IS_STUB?v:k(3e4,t);let b=Date.now();return r=Be("<IIII",i,y,n,e),this.chipFamily!=o&&this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=p&&this.chipFamily!=m&&this.chipFamily!=w||(r=r.concat(Be("<I",s?1:0))),this.logger.log("Erase size "+i+", blocks "+y+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(s?"yes":"no")),await this.checkCommand(2,r,0,h),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-b)+"ms to erase "+y+" bytes"),y}async flashDeflBegin(t=0,e=0,a=0,s=!1){let i,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),h=Math.floor((t+r-1)/r),l=0,o=0;return this.IS_STUB?(l=t,o=k(3e4,l)):(l=h*r,o=v),i=Be("<IIII",l,n,r,a),await this.checkCommand(16,i,0,o),o}async flashFinish(){let t=Be("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Be("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return z(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,s=0,i=0){let r=Be("<IIII",t,e,a,s);i>0&&r.concat(Be("<IIII",z(this.getChipFamily()).uartDateReg,0,0,i)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let s=t.regBase+t.mosiDlenOffs,i=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(s,e-1),a>0&&await this.writeRegister(i,a-1)}else{let s=t.regBase+t.usr1Offs,i=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(s,i)}}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,s=0){let i=z(this.getChipFamily()),r=i.regBase,n=r,h=r+i.usrOffs,l=r+i.usr2Offs,o=r+i.w0Offs,_=1<<18;if(s>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 d=8*e.length,f=await this.readRegister(h),u=await this.readRegister(l),c=1<<31;if(s>0&&(c|=268435456),d>0&&(c|=134217728),await this.setDataLengths(i,d,s),await this.writeRegister(h,c),await this.writeRegister(l,7<<28|t),0==d)await this.writeRegister(o,0);else{e.concat(new Array(e.length%4).fill(0));let t=Te("I".repeat(Math.floor(e.length/4)),e),s=o;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(s)}`),await this.writeRegister(s,e),s+=4}await this.writeRegister(n,_),await this.waitDone(n,_);let g=await this.readRegister(o);return await this.writeRegister(h,f),await this.writeRegister(l,u),g}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,s=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)}${s.toString(16)}`),this.flashSize=i[s],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,s=Math.floor((e+a-1)/a),i=16-Math.floor(t/a)%16;return s<i&&(i=s),s<2*i?Math.floor((s+1)/2*a):(s-i)*a}async memBegin(t,e,a,s){return await this.checkCommand(5,Be("<IIII",t,e,a,s))}async memBlock(t,e){return await this.checkCommand(7,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?v:500,a=Be("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await F(this.chipFamily,this.chipRevision);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let s=t[e+"_start"],i=t[e].length,r=Math.floor((i+a-1)/a);await this.memBegin(i,r,a,s);for(let s of Array(r).keys()){let r=s*a,n=r+a;n>i&&(n=i),await this.memBlock(t[e].slice(r,n),s)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const s=await this.readPacket(500);if(e=String.fromCharCode(...s),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const i=new Le(this.port,this.logger,this);return await i.detectFlashSize(),i}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 Le extends Pe{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,s,i){let r=await F(this.chipFamily,this.chipRevision),n=i,h=i+t;console.log(n,h),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&&h>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(h,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,S)}}const Ze=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Pe(e,t)};export{o as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,u as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C5,g as CHIP_FAMILY_ESP32C6,p as CHIP_FAMILY_ESP32C61,m as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,_ as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,l as CHIP_FAMILY_ESP8266,Pe as ESPLoader,Ze as connect};
@@ -1 +1 @@
1
- const t=t=>{let e=[];for(let a=0;a<t.length;a++){let s=t.charCodeAt(a);s<=255&&e.push(s)}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")},s=t=>new Promise(e=>setTimeout(e,t)),i={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=1343410176,h=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),l=33382,o=50,_=12882,d=12883,f=12994,u=12995,c=12997,g=12998,m=207969,p=12914,w=12928,y={5:{name:"ESP32-C3",family:u},9:{name:"ESP32-S3",family:d},12:{name:"ESP32-C2",family:f},13:{name:"ESP32-C6",family:g},16:{name:"ESP32-H2",family:p},17:{name:"ESP32-C5",family:c},18:{name:"ESP32-P4",family:w},20:{name:"ESP32-C61",family:m}},b={4293968129:{name:"ESP8266",family:l},15736195:{name:"ESP32",family:o},1990:{name:"ESP32-S2",family:_},9:{name:"ESP32-S3",family:d},203546735:{name:"ESP32-C2",family:f},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},456216687:{name:"ESP32-C3",family:u},1130455151:{name:"ESP32-C3",family:u},1216438383:{name:"ESP32-C3",family:u},1763790959:{name:"ESP32-C3",family:u},285294703:{name:"ESP32-C5",family:c},1607549039:{name:"ESP32-C5",family:c},1548751960:{name:"ESP32-C5",family:c},1675706479:{name:"ESP32-C5",family:c},752910447:{name:"ESP32-C6",family:g},606167151:{name:"ESP32-C61",family:m},871374959:{name:"ESP32-C61",family:m},1333878895:{name:"ESP32-C61",family:m},1913741423:{name:"ESP32-C61",family:m},2548236392:{name:"ESP32-H2",family:p},3619110528:{name:"ESP32-H2",family:p},0:{name:"ESP32-P4",family:w},117676761:{name:"ESP32-P4",family:w},182303440:{name:"ESP32-P4",family:w}},v=3e3,k=6e5,S=(t,e)=>{let a=Math.floor(t*(e/486));return a<v?v:a},z=t=>{switch(t){case o:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case _: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 l: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 u: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:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:8192};case g:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case m:return{regBase:1610625024,baseFuse:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case p:return{regBase:1610625024,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:n,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 R extends Error{constructor(t){super(t),this.name="SlipReadError"}}const F=async(e,a)=>{let s;return e==o?s=await import("./esp32-BNIFdu1P.js"):e==_?s=await import("./esp32s2-Bk4mqADi.js"):e==d?s=await import("./esp32s3-Df3OUCOC.js"):e==l?s=await import("./esp8266-CQFcqJ_a.js"):e==f?s=await import("./esp32c2-BqxquOKw.js"):e==u?s=await import("./esp32c3-BOOqe8me.js"):e==c?s=await import("./esp32c5-mcj52-K1.js"):e==g?s=await import("./esp32c6-Cg5qYgg7.js"):e==m?s=await import("./esp32c61-CzCdsydk.js"):e==p?s=await import("./esp32h2-DZa_lpff.js"):e==w&&(s=null!=a&&a>=300?await import("./esp32p4r3-Cle9QJmZ.js"):await import("./esp32p4-DyGqUAeZ.js")),{...s,text:t(atob(s.text)),data:t(atob(s.data))}};function D(t){let e=t.length;for(;--e>=0;)t[e]=0}const E=256,U=286,O=30,I=15,x=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]),A=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]),C=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),B=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),T=new Array(576);D(T);const P=new Array(60);D(P);const L=new Array(512);D(L);const Z=new Array(256);D(Z);const $=new Array(29);D($);const M=new Array(O);function N(t,e,a,s,i){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=s,this.max_length=i,this.has_stree=t&&t.length}let H,V,j;function W(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}D(M);const K=t=>t<256?L[t]:L[256+(t>>>7)],Y=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},G=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,Y(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)},q=(t,e,a)=>{G(t,a[2*e],a[2*e+1])},X=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Q=(t,e,a)=>{const s=new Array(16);let i,r,n=0;for(i=1;i<=I;i++)n=n+a[i-1]<<1,s[i]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=X(s[e]++,e))}},J=t=>{let e;for(e=0;e<U;e++)t.dyn_ltree[2*e]=0;for(e=0;e<O;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},tt=t=>{t.bi_valid>8?Y(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},et=(t,e,a,s)=>{const i=2*e,r=2*a;return t[i]<t[r]||t[i]===t[r]&&s[e]<=s[a]},at=(t,e,a)=>{const s=t.heap[a];let i=a<<1;for(;i<=t.heap_len&&(i<t.heap_len&&et(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!et(e,s,t.heap[i],t.depth));)t.heap[a]=t.heap[i],a=i,i<<=1;t.heap[a]=s},st=(t,e,a)=>{let s,i,r,n,h=0;if(0!==t.sym_next)do{s=255&t.pending_buf[t.sym_buf+h++],s+=(255&t.pending_buf[t.sym_buf+h++])<<8,i=t.pending_buf[t.sym_buf+h++],0===s?q(t,i,e):(r=Z[i],q(t,r+E+1,e),n=x[r],0!==n&&(i-=$[r],G(t,i,n)),s--,r=K(s),q(t,r,a),n=A[r],0!==n&&(s-=M[r],G(t,s,n)))}while(h<t.sym_next);q(t,256,e)},it=(t,e)=>{const a=e.dyn_tree,s=e.stat_desc.static_tree,i=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,h,l,o=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=o=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=o<2?++o:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,i&&(t.static_len-=s[2*l+1]);for(e.max_code=o,n=t.heap_len>>1;n>=1;n--)at(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],at(t,a,1),h=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=h,a[2*l]=a[2*n]+a[2*h],t.depth[l]=(t.depth[n]>=t.depth[h]?t.depth[n]:t.depth[h])+1,a[2*n+1]=a[2*h+1]=l,t.heap[1]=l++,at(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,s=e.max_code,i=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,h=e.stat_desc.extra_base,l=e.stat_desc.max_length;let o,_,d,f,u,c,g=0;for(f=0;f<=I;f++)t.bl_count[f]=0;for(a[2*t.heap[t.heap_max]+1]=0,o=t.heap_max+1;o<573;o++)_=t.heap[o],f=a[2*a[2*_+1]+1]+1,f>l&&(f=l,g++),a[2*_+1]=f,_>s||(t.bl_count[f]++,u=0,_>=h&&(u=n[_-h]),c=a[2*_],t.opt_len+=c*(f+u),r&&(t.static_len+=c*(i[2*_+1]+u)));if(0!==g){do{for(f=l-1;0===t.bl_count[f];)f--;t.bl_count[f]--,t.bl_count[f+1]+=2,t.bl_count[l]--,g-=2}while(g>0);for(f=l;0!==f;f--)for(_=t.bl_count[f];0!==_;)d=t.heap[--o],d>s||(a[2*d+1]!==f&&(t.opt_len+=(f-a[2*d+1])*a[2*d],a[2*d+1]=f),_--)}})(t,e),Q(a,o,t.bl_count)},rt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),e[2*(a+1)+1]=65535,s=0;s<=a;s++)i=n,n=e[2*(s+1)+1],++h<l&&i===n||(h<o?t.bl_tree[2*i]+=h:0!==i?(i!==r&&t.bl_tree[2*i]++,t.bl_tree[32]++):h<=10?t.bl_tree[34]++:t.bl_tree[36]++,h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4))},nt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),s=0;s<=a;s++)if(i=n,n=e[2*(s+1)+1],!(++h<l&&i===n)){if(h<o)do{q(t,i,t.bl_tree)}while(0!==--h);else 0!==i?(i!==r&&(q(t,i,t.bl_tree),h--),q(t,16,t.bl_tree),G(t,h-3,2)):h<=10?(q(t,17,t.bl_tree),G(t,h-3,3)):(q(t,18,t.bl_tree),G(t,h-11,7));h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4)}};let ht=!1;const lt=(t,e,a,s)=>{G(t,0+(s?1:0),3),tt(t),Y(t,a),Y(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var ot=(t,e,a,s)=>{let i,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<E;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),it(t,t.l_desc),it(t,t.d_desc),n=(t=>{let e;for(rt(t,t.dyn_ltree,t.l_desc.max_code),rt(t,t.dyn_dtree,t.d_desc.max_code),it(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*B[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),i=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=i&&(i=r)):i=r=a+5,a+4<=i&&-1!==e?lt(t,e,a,s):4===t.strategy||r===i?(G(t,2+(s?1:0),3),st(t,T,P)):(G(t,4+(s?1:0),3),((t,e,a,s)=>{let i;for(G(t,e-257,5),G(t,a-1,5),G(t,s-4,4),i=0;i<s;i++)G(t,t.bl_tree[2*B[i]+1],3);nt(t,t.dyn_ltree,e-1),nt(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),st(t,t.dyn_ltree,t.dyn_dtree)),J(t),s&&tt(t)},_t={_tr_init:t=>{ht||((()=>{let t,e,a,s,i;const r=new Array(16);for(a=0,s=0;s<28;s++)for($[s]=a,t=0;t<1<<x[s];t++)Z[a++]=s;for(Z[a-1]=s,i=0,s=0;s<16;s++)for(M[s]=i,t=0;t<1<<A[s];t++)L[i++]=s;for(i>>=7;s<O;s++)for(M[s]=i<<7,t=0;t<1<<A[s]-7;t++)L[256+i++]=s;for(e=0;e<=I;e++)r[e]=0;for(t=0;t<=143;)T[2*t+1]=8,t++,r[8]++;for(;t<=255;)T[2*t+1]=9,t++,r[9]++;for(;t<=279;)T[2*t+1]=7,t++,r[7]++;for(;t<=287;)T[2*t+1]=8,t++,r[8]++;for(Q(T,287,r),t=0;t<O;t++)P[2*t+1]=5,P[2*t]=X(t,5);H=new N(T,x,257,U,I),V=new N(P,A,0,O,I),j=new N(new Array(0),C,0,19,7)})(),ht=!0),t.l_desc=new W(t.dyn_ltree,H),t.d_desc=new W(t.dyn_dtree,V),t.bl_desc=new W(t.bl_tree,j),t.bi_buf=0,t.bi_valid=0,J(t)},_tr_stored_block:lt,_tr_flush_block:ot,_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*(Z[a]+E+1)]++,t.dyn_dtree[2*K(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{G(t,2,3),q(t,256,T),(t=>{16===t.bi_valid?(Y(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 dt=(t,e,a,s)=>{let i=65535&t,r=t>>>16&65535,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{i=i+e[s++]|0,r=r+i|0}while(--n);i%=65521,r%=65521}return i|r<<16};const ft=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var s=0;s<8;s++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ut=(t,e,a,s)=>{const i=ft,r=s+a;t^=-1;for(let a=s;a<r;a++)t=t>>>8^i[255&(t^e[a])];return-1^t},ct={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"},gt={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_OK:0,Z_STREAM_END:1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_BUF_ERROR:-5,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:mt,_tr_stored_block:pt,_tr_flush_block:wt,_tr_tally:yt,_tr_align:bt}=_t,{Z_NO_FLUSH:vt,Z_PARTIAL_FLUSH:kt,Z_FULL_FLUSH:St,Z_FINISH:zt,Z_BLOCK:Rt,Z_OK:Ft,Z_STREAM_END:Dt,Z_STREAM_ERROR:Et,Z_DATA_ERROR:Ut,Z_BUF_ERROR:Ot,Z_DEFAULT_COMPRESSION:It,Z_FILTERED:xt,Z_HUFFMAN_ONLY:At,Z_RLE:Ct,Z_FIXED:Bt,Z_DEFAULT_STRATEGY:Tt,Z_UNKNOWN:Pt,Z_DEFLATED:Lt}=gt,Zt=258,$t=262,Mt=42,Nt=113,Ht=666,Vt=(t,e)=>(t.msg=ct[e],e),jt=t=>2*t-(t>4?9:0),Wt=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Kt=t=>{let e,a,s,i=t.w_size;e=t.hash_size,s=e;do{a=t.head[--s],t.head[s]=a>=i?a-i:0}while(--e);e=i,s=e;do{a=t.prev[--s],t.prev[s]=a>=i?a-i:0}while(--e)};let Yt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Gt=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))},qt=(t,e)=>{wt(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Gt(t.strm)},Xt=(t,e)=>{t.pending_buf[t.pending++]=e},Qt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},Jt=(t,e,a,s)=>{let i=t.avail_in;return i>s&&(i=s),0===i?0:(t.avail_in-=i,e.set(t.input.subarray(t.next_in,t.next_in+i),a),1===t.state.wrap?t.adler=dt(t.adler,e,i,a):2===t.state.wrap&&(t.adler=ut(t.adler,e,i,a)),t.next_in+=i,t.total_in+=i,i)},te=(t,e)=>{let a,s,i=t.max_chain_length,r=t.strstart,n=t.prev_length,h=t.nice_match;const l=t.strstart>t.w_size-$t?t.strstart-(t.w_size-$t):0,o=t.window,_=t.w_mask,d=t.prev,f=t.strstart+Zt;let u=o[r+n-1],c=o[r+n];t.prev_length>=t.good_match&&(i>>=2),h>t.lookahead&&(h=t.lookahead);do{if(a=e,o[a+n]===c&&o[a+n-1]===u&&o[a]===o[r]&&o[++a]===o[r+1]){r+=2,a++;do{}while(o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&r<f);if(s=Zt-(f-r),r=f-Zt,s>n){if(t.match_start=e,n=s,s>=h)break;u=o[r+n-1],c=o[r+n]}}}while((e=d[e&_])>l&&0!==--i);return n<=t.lookahead?n:t.lookahead},ee=t=>{const e=t.w_size;let a,s,i;do{if(s=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-$t)&&(t.window.set(t.window.subarray(e,e+e-s),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),Kt(t),s+=e),0===t.strm.avail_in)break;if(a=Jt(t.strm,t.window,t.strstart+t.lookahead,s),t.lookahead+=a,t.lookahead+t.insert>=3)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Yt(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Yt(t,t.ins_h,t.window[i+3-1]),t.prev[i&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=i,i++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<$t&&0!==t.strm.avail_in)},ae=(t,e)=>{let a,s,i,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,h=t.strm.avail_in;do{if(a=65535,i=t.bi_valid+42>>3,t.strm.avail_out<i)break;if(i=t.strm.avail_out-i,s=t.strstart-t.block_start,a>s+t.strm.avail_in&&(a=s+t.strm.avail_in),a>i&&(a=i),a<r&&(0===a&&e!==zt||e===vt||a!==s+t.strm.avail_in))break;n=e===zt&&a===s+t.strm.avail_in?1:0,pt(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,Gt(t.strm),s&&(s>a&&(s=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+s),t.strm.next_out),t.strm.next_out+=s,t.strm.avail_out-=s,t.strm.total_out+=s,t.block_start+=s,a-=s),a&&(Jt(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 h-=t.strm.avail_in,h&&(h>=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<=h&&(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-h,t.strm.next_in),t.strstart),t.strstart+=h,t.insert+=h>t.w_size-t.insert?t.w_size-t.insert:h),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==vt&&e!==zt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(i=t.window_size-t.strstart,t.strm.avail_in>i&&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++,i+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),i>t.strm.avail_in&&(i=t.strm.avail_in),i&&(Jt(t.strm,t.window,t.strstart,i),t.strstart+=i,t.insert+=i>t.w_size-t.insert?t.w_size-t.insert:i),t.high_water<t.strstart&&(t.high_water=t.strstart),i=t.bi_valid+42>>3,i=t.pending_buf_size-i>65535?65535:t.pending_buf_size-i,r=i>t.w_size?t.w_size:i,s=t.strstart-t.block_start,(s>=r||(s||e===zt)&&e!==vt&&0===t.strm.avail_in&&s<=i)&&(a=s>i?i:s,n=e===zt&&0===t.strm.avail_in&&a===s?1:0,pt(t,t.block_start,a,n),t.block_start+=a,Gt(t.strm)),n?3:1)},se=(t,e)=>{let a,s;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a)),t.match_length>=3)if(s=yt(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=Yt(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=Yt(t,t.ins_h,t.window[t.strstart+1]);else s=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(s&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2},ie=(t,e)=>{let a,s,i;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a),t.match_length<=5&&(t.strategy===xt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-3,s=yt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=i&&(t.ins_h=Yt(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++,s&&(qt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(s=yt(t,0,t.window[t.strstart-1]),s&&qt(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&&(s=yt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2};function re(t,e,a,s,i){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=s,this.func=i}const ne=[new re(0,0,0,0,ae),new re(4,4,8,4,se),new re(4,5,16,8,se),new re(4,6,32,32,se),new re(4,4,16,16,ie),new re(8,16,32,32,ie),new re(8,16,128,128,ie),new re(8,32,128,256,ie),new re(32,128,258,1024,ie),new re(32,258,258,4096,ie)];function he(){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=Lt,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),Wt(this.dyn_ltree),Wt(this.dyn_dtree),Wt(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),Wt(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Wt(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 le=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Mt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Nt&&e.status!==Ht?1:0},oe=t=>{if(le(t))return Vt(t,Et);t.total_in=t.total_out=0,t.data_type=Pt;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?Mt:Nt,t.adler=2===e.wrap?0:1,e.last_flush=-2,mt(e),Ft},_e=t=>{const e=oe(t);var a;return e===Ft&&((a=t.state).window_size=2*a.w_size,Wt(a.head),a.max_lazy_match=ne[a.level].max_lazy,a.good_match=ne[a.level].good_length,a.nice_match=ne[a.level].nice_length,a.max_chain_length=ne[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},de=(t,e,a,s,i,r)=>{if(!t)return Et;let n=1;if(e===It&&(e=6),s<0?(n=0,s=-s):s>15&&(n=2,s-=16),i<1||i>9||a!==Lt||s<8||s>15||e<0||e>9||r<0||r>Bt||8===s&&1!==n)return Vt(t,Et);8===s&&(s=9);const h=new he;return t.state=h,h.strm=t,h.status=Mt,h.wrap=n,h.gzhead=null,h.w_bits=s,h.w_size=1<<h.w_bits,h.w_mask=h.w_size-1,h.hash_bits=i+7,h.hash_size=1<<h.hash_bits,h.hash_mask=h.hash_size-1,h.hash_shift=~~((h.hash_bits+3-1)/3),h.window=new Uint8Array(2*h.w_size),h.head=new Uint16Array(h.hash_size),h.prev=new Uint16Array(h.w_size),h.lit_bufsize=1<<i+6,h.pending_buf_size=4*h.lit_bufsize,h.pending_buf=new Uint8Array(h.pending_buf_size),h.sym_buf=h.lit_bufsize,h.sym_end=3*(h.lit_bufsize-1),h.level=e,h.strategy=r,h.method=a,_e(t)};var fe={deflateInit:(t,e)=>de(t,e,Lt,15,8,Tt),deflateInit2:de,deflateReset:_e,deflateResetKeep:oe,deflateSetHeader:(t,e)=>le(t)||2!==t.state.wrap?Et:(t.state.gzhead=e,Ft),deflate:(t,e)=>{if(le(t)||e>Rt||e<0)return t?Vt(t,Et):Et;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Ht&&e!==zt)return Vt(t,0===t.avail_out?Ot:Et);const s=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Gt(t),0===t.avail_out)return a.last_flush=-1,Ft}else if(0===t.avail_in&&jt(e)<=jt(s)&&e!==zt)return Vt(t,Ot);if(a.status===Ht&&0!==t.avail_in)return Vt(t,Ot);if(a.status===Mt&&0===a.wrap&&(a.status=Nt),a.status===Mt){let e=Lt+(a.w_bits-8<<4)<<8,s=-1;if(s=a.strategy>=At||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=s<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Qt(a,e),0!==a.strstart&&(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),t.adler=1,a.status=Nt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(57===a.status)if(t.adler=0,Xt(a,31),Xt(a,139),Xt(a,8),a.gzhead)Xt(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)),Xt(a,255&a.gzhead.time),Xt(a,a.gzhead.time>>8&255),Xt(a,a.gzhead.time>>16&255),Xt(a,a.gzhead.time>>24&255),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Xt(a,255&a.gzhead.extra.length),Xt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ut(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,3),a.status=Nt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;if(69===a.status){if(a.gzhead.extra){let e=a.pending,s=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+s>a.pending_buf_size;){let i=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=i,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;e=0,s-=i}let i=new Uint8Array(a.gzhead.extra);a.pending_buf.set(i.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending+=s,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(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,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Gt(t),0!==a.pending))return a.last_flush=-1,Ft;Xt(a,255&t.adler),Xt(a,t.adler>>8&255),t.adler=0}if(a.status=Nt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(0!==t.avail_in||0!==a.lookahead||e!==vt&&a.status!==Ht){let s=0===a.level?ae(a,e):a.strategy===At?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(ee(t),0===t.lookahead)){if(e===vt)return 1;break}if(t.match_length=0,a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===Ct?((t,e)=>{let a,s,i,r;const n=t.window;for(;;){if(t.lookahead<=Zt){if(ee(t),t.lookahead<=Zt&&e===vt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(i=t.strstart-1,s=n[i],s===n[++i]&&s===n[++i]&&s===n[++i])){r=t.strstart+Zt;do{}while(s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&i<r);t.match_length=Zt-(r-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=yt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ne[a.level].func(a,e);if(3!==s&&4!==s||(a.status=Ht),1===s||3===s)return 0===t.avail_out&&(a.last_flush=-1),Ft;if(2===s&&(e===kt?bt(a):e!==Rt&&(pt(a,0,0,!1),e===St&&(Wt(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Gt(t),0===t.avail_out))return a.last_flush=-1,Ft}return e!==zt?Ft:a.wrap<=0?Dt:(2===a.wrap?(Xt(a,255&t.adler),Xt(a,t.adler>>8&255),Xt(a,t.adler>>16&255),Xt(a,t.adler>>24&255),Xt(a,255&t.total_in),Xt(a,t.total_in>>8&255),Xt(a,t.total_in>>16&255),Xt(a,t.total_in>>24&255)):(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),Gt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?Ft:Dt)},deflateEnd:t=>{if(le(t))return Et;const e=t.state.status;return t.state=null,e===Nt?Vt(t,Ut):Ft},deflateSetDictionary:(t,e)=>{let a=e.length;if(le(t))return Et;const s=t.state,i=s.wrap;if(2===i||1===i&&s.status!==Mt||s.lookahead)return Et;if(1===i&&(t.adler=dt(t.adler,e,a,0)),s.wrap=0,a>=s.w_size){0===i&&(Wt(s.head),s.strstart=0,s.block_start=0,s.insert=0);let t=new Uint8Array(s.w_size);t.set(e.subarray(a-s.w_size,a),0),e=t,a=s.w_size}const r=t.avail_in,n=t.next_in,h=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,ee(s);s.lookahead>=3;){let t=s.strstart,e=s.lookahead-2;do{s.ins_h=Yt(s,s.ins_h,s.window[t+3-1]),s.prev[t&s.w_mask]=s.head[s.ins_h],s.head[s.ins_h]=t,t++}while(--e);s.strstart=t,s.lookahead=2,ee(s)}return s.strstart+=s.lookahead,s.block_start=s.strstart,s.insert=s.lookahead,s.lookahead=0,s.match_length=s.prev_length=2,s.match_available=0,t.next_in=n,t.input=h,t.avail_in=r,s.wrap=i,Ft},deflateInfo:"pako deflate (from Nodeca project)"};const ue=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var ce=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)ue(a,e)&&(t[e]=a[e])}}return t},ge=t=>{let e=0;for(let a=0,s=t.length;a<s;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,s=0,i=t.length;e<i;e++){let i=t[e];a.set(i,s),s+=i.length}return a};let me=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){me=!1}const pe=new Uint8Array(256);for(let t=0;t<256;t++)pe[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;pe[254]=pe[254]=1;var we=t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,s,i,r,n=t.length,h=0;for(i=0;i<n;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),h+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(h),r=0,i=0;r<h;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),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};var ye=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 be=Object.prototype.toString,{Z_NO_FLUSH:ve,Z_SYNC_FLUSH:ke,Z_FULL_FLUSH:Se,Z_FINISH:ze,Z_OK:Re,Z_STREAM_END:Fe,Z_DEFAULT_COMPRESSION:De,Z_DEFAULT_STRATEGY:Ee,Z_DEFLATED:Ue}=gt;function Oe(t){this.options=ce({level:De,method:Ue,chunkSize:16384,windowBits:15,memLevel:8,strategy:Ee},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 ye,this.strm.avail_out=0;let a=fe.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==Re)throw new Error(ct[a]);if(e.header&&fe.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?we(e.dictionary):"[object ArrayBuffer]"===be.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=fe.deflateSetDictionary(this.strm,t),a!==Re)throw new Error(ct[a]);this._dict_set=!0}}Oe.prototype.push=function(t,e){const a=this.strm,s=this.options.chunkSize;let i,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?ze:ve,"string"==typeof t?a.input=we(t):"[object ArrayBuffer]"===be.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(s),a.next_out=0,a.avail_out=s),(r===ke||r===Se)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(i=fe.deflate(a,r),i===Fe)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),i=fe.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===Re;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},Oe.prototype.onData=function(t){this.chunks.push(t)},Oe.prototype.onEnd=function(t){t===Re&&(this.result=ge(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Ie={deflate:function(t,e){const a=new Oe(e);if(a.push(t,!0),a.err)throw a.msg||ct[a.err];return a.result}};const{deflate:xe}=Ie;var Ae=xe;const Ce={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}},Be=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let s=[],i=!0;for(let s=0;s<t.length;s++)"<"==t[s]?i=!0:">"==t[s]?i=!1:(r(t[s],e[a]),a++);function r(t,e){if(!(t in Ce))throw"Unhandled character '"+t+"' in pack format";let a=Ce[t].bytes,r=new DataView(new ArrayBuffer(a));Ce[t].p.bind(r)(0,e,i);for(let t=0;t<a;t++)s.push(r.getUint8(t))}return s},Te=(t,e)=>{let a=0,s=[],i=!0;for(let e of t)"<"==e?i=!0:">"==e?i=!1:r(e);function r(t){if(!(t in Ce))throw"Unhandled character '"+t+"' in unpack format";let r=Ce[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let h=Ce[t].u.bind(n);s.push(h(0,i)),a+=r}return s};class Pe extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this.chipRevision=null,this.chipVariant=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(),await this.detectChip();let t=z(this.getChipFamily()).macFuse;for(let e=0;e<4;e++)this._efuses[e]=await this.readRegister(t+4*e);this.logger.log(`Chip type ${this.chipName}`)}async detectChip(){try{const t=(await this.getSecurityInfo()).chipId,e=y[t];if(e)return this.chipName=e.name,this.chipFamily=e.family,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),void this.logger.debug(`Detected chip via IMAGE_CHIP_ID: ${t} (${this.chipName})`);this.logger.debug(`Unknown IMAGE_CHIP_ID: ${t}, falling back to magic value detection`)}catch(t){this.logger.debug(`GET_SECURITY_INFO failed, using magic value detection: ${t}`)}let t=await this.readRegister(1073745920),e=b[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,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),this.logger.debug(`Detected chip via magic value: ${a(t>>>0,8)} (${this.chipName})`)}async getChipRevision(){if(this.chipFamily!==w)return 0;const t=await this.readRegister(1343410252);return 100*((t>>23&1)<<2|t>>4&3)+(15&t)}async getSecurityInfo(){const[t,e]=await this.checkCommand(20,[],0);if(e.length<20)throw new Error(`Invalid security info response length: ${e.length}`);return{flags:Te("<I",e.slice(0,4))[0],flashCryptCnt:e[4],keyPurposes:Array.from(e.slice(5,12)),chipId:e.length>=16?Te("<I",e.slice(12,16))[0]:0,apiVersion:e.length>=20?Te("<I",e.slice(16,20))[0]:0}}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],s=this._efuses[1],i=this._efuses[2],r=this._efuses[3];if(this.chipFamily==l){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(s>>16&255){if(1!=(s>>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]=s>>8&255,e[4]=255&s,e[5]=a>>24&255}else if(this.chipFamily==o)e[0]=i>>8&255,e[1]=255&i,e[2]=s>>24&255,e[3]=s>>16&255,e[4]=s>>8&255,e[5]=255&s;else{if(this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=m&&this.chipFamily!=p&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=s>>8&255,e[1]=255&s,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=Be("<I",t);await this.sendCommand(10,e);let[s,i]=await this.getResponse(10);return s}async checkCommand(t,e,s=0,i=3e3){i=Math.min(i,12e5),await this.sendCommand(t,e,s);let[r,n]=await this.getResponse(t,i);if(null===n)throw new Error("Didn't get enough status bytes");let h=0;if(this.IS_STUB||this.chipFamily==l?h=2:[o,_,d,f,u,c,g,m,p,w].includes(this.chipFamily)?h=4:[2,4].includes(n.length)&&(h=n.length),n.length<h)throw new Error("Didn't get enough status bytes");let y=n.slice(-h,n.length);if(n=n.slice(0,-h),this.debug&&(this.logger.debug("status",y),this.logger.debug("value",r),this.logger.debug("data",n)),1==y[0])throw 5==y[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(y[1]));return[r,n]}async sendCommand(t,e,a=0){let s=(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})([...Be("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${s.length} byte${1==s.length?"":"s"}:`,s),await this.writeToStream(s)}async readPacket(t){let i=null,r=!1,n=[];for(;;){let h=Date.now();for(n=[];Date.now()-h<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await s(10)}if(0==n.length){throw new R("Timed out waiting for packet "+(null===i?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===i){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 R("Invalid head of packet ("+a(t)+")");i=[]}else if(r)if(r=!1,220==t)i.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 R("Invalid SLIP escape (0xdb, "+a(t)+")");i.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(i)),i;i.push(t)}}throw new R("Invalid state")}async getResponse(t,e=3e3){for(let s=0;s<100;s++){const s=await this.readPacket(e);if(s.length<8)continue;const[i,r,n,h]=Te("<BBHI",s.slice(0,8));if(1!=i)continue;const l=s.slice(8);if(null==t||r==t)return[h,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==l)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=Be("<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),this.logger.log(`Changed baud rate to ${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()}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 s(100),!0;await s(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,h);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,s=0,i=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],s=r[2],i=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(s)}, FlashSizeFreq=${a(i)}`)}let n,h=t.byteLength,l=0,o=v;i?(n=Ae(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${h}. Compressed Size: ${l}`),o=await this.flashDeflBegin(h,l,s)):(this.logger.log(`Writing data with filesize: ${h}`),n=t,await this.flashBegin(h,s));let _=[],d=0,f=0,u=0,c=Date.now(),g=this.getFlashWriteSize(),m=i?l:h;for(;m-u>0;)this.debug&&this.logger.log(`Writing at ${a(s+d*g,8)} `),m-u>=g?_=Array.from(new Uint8Array(n,u,g)):(_=Array.from(new Uint8Array(n,u,m-u)),i||(_=_.concat(new Array(g-_.length).fill(255)))),i?await this.flashDeflBlock(_,d,o):await this.flashBlock(_,d),d+=1,f+=i?Math.round(_.length*h/l):_.length,u+=g,e(Math.min(f,h),h);this.logger.log("Took "+(Date.now()-c)+"ms to write "+m+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),i?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,s=!1){let i,r,n=this.getFlashWriteSize();!this.IS_STUB&&[o,_,d,f,u,c,g,m,p,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let h,y=Math.floor((t+n-1)/n);i=this.chipFamily==l?this.getEraseSize(e,t):t,h=this.IS_STUB?v:S(3e4,t);let b=Date.now();return r=Be("<IIII",i,y,n,e),this.chipFamily!=o&&this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=m&&this.chipFamily!=p&&this.chipFamily!=w||(r=r.concat(Be("<I",s?1:0))),this.logger.log("Erase size "+i+", blocks "+y+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(s?"yes":"no")),await this.checkCommand(2,r,0,h),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-b)+"ms to erase "+y+" bytes"),y}async flashDeflBegin(t=0,e=0,a=0,s=!1){let i,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),h=Math.floor((t+r-1)/r),l=0,o=0;return this.IS_STUB?(l=t,o=S(3e4,l)):(l=h*r,o=v),i=Be("<IIII",l,n,r,a),await this.checkCommand(16,i,0,o),o}async flashFinish(){let t=Be("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Be("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return z(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,s=0,i=0){let r=Be("<IIII",t,e,a,s);i>0&&r.concat(Be("<IIII",z(this.getChipFamily()).uartDateReg,0,0,i)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let s=t.regBase+t.mosiDlenOffs,i=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(s,e-1),a>0&&await this.writeRegister(i,a-1)}else{let s=t.regBase+t.usr1Offs,i=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(s,i)}}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,s=0){let i=z(this.getChipFamily()),r=i.regBase,n=r,h=r+i.usrOffs,l=r+i.usr2Offs,o=r+i.w0Offs,_=1<<18;if(s>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 d=8*e.length,f=await this.readRegister(h),u=await this.readRegister(l),c=1<<31;if(s>0&&(c|=268435456),d>0&&(c|=134217728),await this.setDataLengths(i,d,s),await this.writeRegister(h,c),await this.writeRegister(l,7<<28|t),0==d)await this.writeRegister(o,0);else{e.concat(new Array(e.length%4).fill(0));let t=Te("I".repeat(Math.floor(e.length/4)),e),s=o;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(s)}`),await this.writeRegister(s,e),s+=4}await this.writeRegister(n,_),await this.waitDone(n,_);let g=await this.readRegister(o);return await this.writeRegister(h,f),await this.writeRegister(l,u),g}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,s=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)}${s.toString(16)}`),this.flashSize=i[s],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,s=Math.floor((e+a-1)/a),i=16-Math.floor(t/a)%16;return s<i&&(i=s),s<2*i?Math.floor((s+1)/2*a):(s-i)*a}async memBegin(t,e,a,s){return await this.checkCommand(5,Be("<IIII",t,e,a,s))}async memBlock(t,e){return await this.checkCommand(7,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?v:500,a=Be("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await F(this.chipFamily,this.chipRevision);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let s=t[e+"_start"],i=t[e].length,r=Math.floor((i+a-1)/a);await this.memBegin(i,r,a,s);for(let s of Array(r).keys()){let r=s*a,n=r+a;n>i&&(n=i),await this.memBlock(t[e].slice(r,n),s)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const s=await this.readPacket(500);if(e=String.fromCharCode(...s),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const i=new Le(this.port,this.logger,this);return await i.detectFlashSize(),i}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 Le extends Pe{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,s,i){let r=await F(this.chipFamily,this.chipRevision),n=i,h=i+t;console.log(n,h),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&&h>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(h,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,k)}}const Ze=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Pe(e,t)};export{o as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,u as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C5,g as CHIP_FAMILY_ESP32C6,m as CHIP_FAMILY_ESP32C61,p as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,_ as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,l as CHIP_FAMILY_ESP8266,Pe as ESPLoader,Ze as connect};
1
+ const t=t=>{let e=[];for(let a=0;a<t.length;a++){let s=t.charCodeAt(a);s<=255&&e.push(s)}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")},s=t=>new Promise(e=>setTimeout(e,t)),i={18:"256KB",19:"512KB",20:"1MB",21:"2MB",22:"4MB",23:"8MB",24:"16MB",25:"32MB",26:"64MB"},r=115200,n=1343410176,h=t(" UUUUUUUUUUUUUUUUUUUUUUUUUUUUUUUU"),l=33382,o=50,_=12882,d=12883,f=12994,u=12995,c=12997,g=12998,p=207969,m=12914,w=12928,y={5:{name:"ESP32-C3",family:u},9:{name:"ESP32-S3",family:d},12:{name:"ESP32-C2",family:f},13:{name:"ESP32-C6",family:g},16:{name:"ESP32-H2",family:m},17:{name:"ESP32-C5",family:c},18:{name:"ESP32-P4",family:w},20:{name:"ESP32-C61",family:p}},b={4293968129:{name:"ESP8266",family:l},15736195:{name:"ESP32",family:o},1990:{name:"ESP32-S2",family:_},9:{name:"ESP32-S3",family:d},203546735:{name:"ESP32-C2",family:f},1867591791:{name:"ESP32-C2",family:f},2084675695:{name:"ESP32-C2",family:f},456216687:{name:"ESP32-C3",family:u},1130455151:{name:"ESP32-C3",family:u},1216438383:{name:"ESP32-C3",family:u},1763790959:{name:"ESP32-C3",family:u},285294703:{name:"ESP32-C5",family:c},1607549039:{name:"ESP32-C5",family:c},1548751960:{name:"ESP32-C5",family:c},1675706479:{name:"ESP32-C5",family:c},752910447:{name:"ESP32-C6",family:g},606167151:{name:"ESP32-C61",family:p},871374959:{name:"ESP32-C61",family:p},1333878895:{name:"ESP32-C61",family:p},1913741423:{name:"ESP32-C61",family:p},2548236392:{name:"ESP32-H2",family:m},3619110528:{name:"ESP32-H2",family:m},0:{name:"ESP32-P4",family:w},117676761:{name:"ESP32-P4",family:w},182303440:{name:"ESP32-P4",family:w}},v=3e3,S=6e5,k=(t,e)=>{let a=Math.floor(t*(e/486));return a<v?v:a},z=t=>{switch(t){case o:return{regBase:1072963584,baseFuse:1073061888,macFuse:1073061888,usrOffs:28,usr1Offs:32,usr2Offs:36,mosiDlenOffs:40,misoDlenOffs:44,w0Offs:128,uartDateReg:1610612856,flashOffs:4096};case _: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 l: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 u: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:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:8192};case g:return{regBase:1610625024,baseFuse:1611335680,macFuse:1611335748,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case p:return{regBase:1610625024,baseFuse:1611352064,macFuse:1611352132,usrOffs:24,usr1Offs:28,usr2Offs:32,mosiDlenOffs:36,misoDlenOffs:40,w0Offs:88,uartDateReg:1610612860,flashOffs:0};case m:return{regBase:1610625024,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:n,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 R extends Error{constructor(t){super(t),this.name="SlipReadError"}}const F=async(e,a)=>{let s;return e==o?s=await import("./esp32-BNIFdu1P.js"):e==_?s=await import("./esp32s2-Bk4mqADi.js"):e==d?s=await import("./esp32s3-Df3OUCOC.js"):e==l?s=await import("./esp8266-CQFcqJ_a.js"):e==f?s=await import("./esp32c2-BqxquOKw.js"):e==u?s=await import("./esp32c3-BOOqe8me.js"):e==c?s=await import("./esp32c5-mcj52-K1.js"):e==g?s=await import("./esp32c6-Cg5qYgg7.js"):e==p?s=await import("./esp32c61-CzCdsydk.js"):e==m?s=await import("./esp32h2-DZa_lpff.js"):e==w&&(s=null!=a&&a>=300?await import("./esp32p4r3-Cle9QJmZ.js"):await import("./esp32p4-DyGqUAeZ.js")),{...s,text:t(atob(s.text)),data:t(atob(s.data))}};function E(t){let e=t.length;for(;--e>=0;)t[e]=0}const U=256,D=286,I=30,O=15,x=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]),A=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]),C=new Uint8Array([0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,3,7]),B=new Uint8Array([16,17,18,0,8,7,9,6,10,5,11,4,12,3,13,2,14,1,15]),T=new Array(576);E(T);const P=new Array(60);E(P);const L=new Array(512);E(L);const Z=new Array(256);E(Z);const $=new Array(29);E($);const N=new Array(I);function M(t,e,a,s,i){this.static_tree=t,this.extra_bits=e,this.extra_base=a,this.elems=s,this.max_length=i,this.has_stree=t&&t.length}let H,V,j;function W(t,e){this.dyn_tree=t,this.max_code=0,this.stat_desc=e}E(N);const K=t=>t<256?L[t]:L[256+(t>>>7)],Y=(t,e)=>{t.pending_buf[t.pending++]=255&e,t.pending_buf[t.pending++]=e>>>8&255},G=(t,e,a)=>{t.bi_valid>16-a?(t.bi_buf|=e<<t.bi_valid&65535,Y(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)},q=(t,e,a)=>{G(t,a[2*e],a[2*e+1])},X=(t,e)=>{let a=0;do{a|=1&t,t>>>=1,a<<=1}while(--e>0);return a>>>1},Q=(t,e,a)=>{const s=new Array(16);let i,r,n=0;for(i=1;i<=O;i++)n=n+a[i-1]<<1,s[i]=n;for(r=0;r<=e;r++){let e=t[2*r+1];0!==e&&(t[2*r]=X(s[e]++,e))}},J=t=>{let e;for(e=0;e<D;e++)t.dyn_ltree[2*e]=0;for(e=0;e<I;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},tt=t=>{t.bi_valid>8?Y(t,t.bi_buf):t.bi_valid>0&&(t.pending_buf[t.pending++]=t.bi_buf),t.bi_buf=0,t.bi_valid=0},et=(t,e,a,s)=>{const i=2*e,r=2*a;return t[i]<t[r]||t[i]===t[r]&&s[e]<=s[a]},at=(t,e,a)=>{const s=t.heap[a];let i=a<<1;for(;i<=t.heap_len&&(i<t.heap_len&&et(e,t.heap[i+1],t.heap[i],t.depth)&&i++,!et(e,s,t.heap[i],t.depth));)t.heap[a]=t.heap[i],a=i,i<<=1;t.heap[a]=s},st=(t,e,a)=>{let s,i,r,n,h=0;if(0!==t.sym_next)do{s=255&t.pending_buf[t.sym_buf+h++],s+=(255&t.pending_buf[t.sym_buf+h++])<<8,i=t.pending_buf[t.sym_buf+h++],0===s?q(t,i,e):(r=Z[i],q(t,r+U+1,e),n=x[r],0!==n&&(i-=$[r],G(t,i,n)),s--,r=K(s),q(t,r,a),n=A[r],0!==n&&(s-=N[r],G(t,s,n)))}while(h<t.sym_next);q(t,256,e)},it=(t,e)=>{const a=e.dyn_tree,s=e.stat_desc.static_tree,i=e.stat_desc.has_stree,r=e.stat_desc.elems;let n,h,l,o=-1;for(t.heap_len=0,t.heap_max=573,n=0;n<r;n++)0!==a[2*n]?(t.heap[++t.heap_len]=o=n,t.depth[n]=0):a[2*n+1]=0;for(;t.heap_len<2;)l=t.heap[++t.heap_len]=o<2?++o:0,a[2*l]=1,t.depth[l]=0,t.opt_len--,i&&(t.static_len-=s[2*l+1]);for(e.max_code=o,n=t.heap_len>>1;n>=1;n--)at(t,a,n);l=r;do{n=t.heap[1],t.heap[1]=t.heap[t.heap_len--],at(t,a,1),h=t.heap[1],t.heap[--t.heap_max]=n,t.heap[--t.heap_max]=h,a[2*l]=a[2*n]+a[2*h],t.depth[l]=(t.depth[n]>=t.depth[h]?t.depth[n]:t.depth[h])+1,a[2*n+1]=a[2*h+1]=l,t.heap[1]=l++,at(t,a,1)}while(t.heap_len>=2);t.heap[--t.heap_max]=t.heap[1],((t,e)=>{const a=e.dyn_tree,s=e.max_code,i=e.stat_desc.static_tree,r=e.stat_desc.has_stree,n=e.stat_desc.extra_bits,h=e.stat_desc.extra_base,l=e.stat_desc.max_length;let o,_,d,f,u,c,g=0;for(f=0;f<=O;f++)t.bl_count[f]=0;for(a[2*t.heap[t.heap_max]+1]=0,o=t.heap_max+1;o<573;o++)_=t.heap[o],f=a[2*a[2*_+1]+1]+1,f>l&&(f=l,g++),a[2*_+1]=f,_>s||(t.bl_count[f]++,u=0,_>=h&&(u=n[_-h]),c=a[2*_],t.opt_len+=c*(f+u),r&&(t.static_len+=c*(i[2*_+1]+u)));if(0!==g){do{for(f=l-1;0===t.bl_count[f];)f--;t.bl_count[f]--,t.bl_count[f+1]+=2,t.bl_count[l]--,g-=2}while(g>0);for(f=l;0!==f;f--)for(_=t.bl_count[f];0!==_;)d=t.heap[--o],d>s||(a[2*d+1]!==f&&(t.opt_len+=(f-a[2*d+1])*a[2*d],a[2*d+1]=f),_--)}})(t,e),Q(a,o,t.bl_count)},rt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),e[2*(a+1)+1]=65535,s=0;s<=a;s++)i=n,n=e[2*(s+1)+1],++h<l&&i===n||(h<o?t.bl_tree[2*i]+=h:0!==i?(i!==r&&t.bl_tree[2*i]++,t.bl_tree[32]++):h<=10?t.bl_tree[34]++:t.bl_tree[36]++,h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4))},nt=(t,e,a)=>{let s,i,r=-1,n=e[1],h=0,l=7,o=4;for(0===n&&(l=138,o=3),s=0;s<=a;s++)if(i=n,n=e[2*(s+1)+1],!(++h<l&&i===n)){if(h<o)do{q(t,i,t.bl_tree)}while(0!==--h);else 0!==i?(i!==r&&(q(t,i,t.bl_tree),h--),q(t,16,t.bl_tree),G(t,h-3,2)):h<=10?(q(t,17,t.bl_tree),G(t,h-3,3)):(q(t,18,t.bl_tree),G(t,h-11,7));h=0,r=i,0===n?(l=138,o=3):i===n?(l=6,o=3):(l=7,o=4)}};let ht=!1;const lt=(t,e,a,s)=>{G(t,0+(s?1:0),3),tt(t),Y(t,a),Y(t,~a),a&&t.pending_buf.set(t.window.subarray(e,e+a),t.pending),t.pending+=a};var ot=(t,e,a,s)=>{let i,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<U;e++)if(0!==t.dyn_ltree[2*e])return 1;return 0})(t)),it(t,t.l_desc),it(t,t.d_desc),n=(t=>{let e;for(rt(t,t.dyn_ltree,t.l_desc.max_code),rt(t,t.dyn_dtree,t.d_desc.max_code),it(t,t.bl_desc),e=18;e>=3&&0===t.bl_tree[2*B[e]+1];e--);return t.opt_len+=3*(e+1)+5+5+4,e})(t),i=t.opt_len+3+7>>>3,r=t.static_len+3+7>>>3,r<=i&&(i=r)):i=r=a+5,a+4<=i&&-1!==e?lt(t,e,a,s):4===t.strategy||r===i?(G(t,2+(s?1:0),3),st(t,T,P)):(G(t,4+(s?1:0),3),((t,e,a,s)=>{let i;for(G(t,e-257,5),G(t,a-1,5),G(t,s-4,4),i=0;i<s;i++)G(t,t.bl_tree[2*B[i]+1],3);nt(t,t.dyn_ltree,e-1),nt(t,t.dyn_dtree,a-1)})(t,t.l_desc.max_code+1,t.d_desc.max_code+1,n+1),st(t,t.dyn_ltree,t.dyn_dtree)),J(t),s&&tt(t)},_t={_tr_init:t=>{ht||((()=>{let t,e,a,s,i;const r=new Array(16);for(a=0,s=0;s<28;s++)for($[s]=a,t=0;t<1<<x[s];t++)Z[a++]=s;for(Z[a-1]=s,i=0,s=0;s<16;s++)for(N[s]=i,t=0;t<1<<A[s];t++)L[i++]=s;for(i>>=7;s<I;s++)for(N[s]=i<<7,t=0;t<1<<A[s]-7;t++)L[256+i++]=s;for(e=0;e<=O;e++)r[e]=0;for(t=0;t<=143;)T[2*t+1]=8,t++,r[8]++;for(;t<=255;)T[2*t+1]=9,t++,r[9]++;for(;t<=279;)T[2*t+1]=7,t++,r[7]++;for(;t<=287;)T[2*t+1]=8,t++,r[8]++;for(Q(T,287,r),t=0;t<I;t++)P[2*t+1]=5,P[2*t]=X(t,5);H=new M(T,x,257,D,O),V=new M(P,A,0,I,O),j=new M(new Array(0),C,0,19,7)})(),ht=!0),t.l_desc=new W(t.dyn_ltree,H),t.d_desc=new W(t.dyn_dtree,V),t.bl_desc=new W(t.bl_tree,j),t.bi_buf=0,t.bi_valid=0,J(t)},_tr_stored_block:lt,_tr_flush_block:ot,_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*(Z[a]+U+1)]++,t.dyn_dtree[2*K(e)]++),t.sym_next===t.sym_end),_tr_align:t=>{G(t,2,3),q(t,256,T),(t=>{16===t.bi_valid?(Y(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 dt=(t,e,a,s)=>{let i=65535&t,r=t>>>16&65535,n=0;for(;0!==a;){n=a>2e3?2e3:a,a-=n;do{i=i+e[s++]|0,r=r+i|0}while(--n);i%=65521,r%=65521}return i|r<<16};const ft=new Uint32Array((()=>{let t,e=[];for(var a=0;a<256;a++){t=a;for(var s=0;s<8;s++)t=1&t?3988292384^t>>>1:t>>>1;e[a]=t}return e})());var ut=(t,e,a,s)=>{const i=ft,r=s+a;t^=-1;for(let a=s;a<r;a++)t=t>>>8^i[255&(t^e[a])];return-1^t},ct={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"},gt={Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_OK:0,Z_STREAM_END:1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_BUF_ERROR:-5,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,Z_UNKNOWN:2,Z_DEFLATED:8};const{_tr_init:pt,_tr_stored_block:mt,_tr_flush_block:wt,_tr_tally:yt,_tr_align:bt}=_t,{Z_NO_FLUSH:vt,Z_PARTIAL_FLUSH:St,Z_FULL_FLUSH:kt,Z_FINISH:zt,Z_BLOCK:Rt,Z_OK:Ft,Z_STREAM_END:Et,Z_STREAM_ERROR:Ut,Z_DATA_ERROR:Dt,Z_BUF_ERROR:It,Z_DEFAULT_COMPRESSION:Ot,Z_FILTERED:xt,Z_HUFFMAN_ONLY:At,Z_RLE:Ct,Z_FIXED:Bt,Z_DEFAULT_STRATEGY:Tt,Z_UNKNOWN:Pt,Z_DEFLATED:Lt}=gt,Zt=258,$t=262,Nt=42,Mt=113,Ht=666,Vt=(t,e)=>(t.msg=ct[e],e),jt=t=>2*t-(t>4?9:0),Wt=t=>{let e=t.length;for(;--e>=0;)t[e]=0},Kt=t=>{let e,a,s,i=t.w_size;e=t.hash_size,s=e;do{a=t.head[--s],t.head[s]=a>=i?a-i:0}while(--e);e=i,s=e;do{a=t.prev[--s],t.prev[s]=a>=i?a-i:0}while(--e)};let Yt=(t,e,a)=>(e<<t.hash_shift^a)&t.hash_mask;const Gt=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))},qt=(t,e)=>{wt(t,t.block_start>=0?t.block_start:-1,t.strstart-t.block_start,e),t.block_start=t.strstart,Gt(t.strm)},Xt=(t,e)=>{t.pending_buf[t.pending++]=e},Qt=(t,e)=>{t.pending_buf[t.pending++]=e>>>8&255,t.pending_buf[t.pending++]=255&e},Jt=(t,e,a,s)=>{let i=t.avail_in;return i>s&&(i=s),0===i?0:(t.avail_in-=i,e.set(t.input.subarray(t.next_in,t.next_in+i),a),1===t.state.wrap?t.adler=dt(t.adler,e,i,a):2===t.state.wrap&&(t.adler=ut(t.adler,e,i,a)),t.next_in+=i,t.total_in+=i,i)},te=(t,e)=>{let a,s,i=t.max_chain_length,r=t.strstart,n=t.prev_length,h=t.nice_match;const l=t.strstart>t.w_size-$t?t.strstart-(t.w_size-$t):0,o=t.window,_=t.w_mask,d=t.prev,f=t.strstart+Zt;let u=o[r+n-1],c=o[r+n];t.prev_length>=t.good_match&&(i>>=2),h>t.lookahead&&(h=t.lookahead);do{if(a=e,o[a+n]===c&&o[a+n-1]===u&&o[a]===o[r]&&o[++a]===o[r+1]){r+=2,a++;do{}while(o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&o[++r]===o[++a]&&r<f);if(s=Zt-(f-r),r=f-Zt,s>n){if(t.match_start=e,n=s,s>=h)break;u=o[r+n-1],c=o[r+n]}}}while((e=d[e&_])>l&&0!==--i);return n<=t.lookahead?n:t.lookahead},ee=t=>{const e=t.w_size;let a,s,i;do{if(s=t.window_size-t.lookahead-t.strstart,t.strstart>=e+(e-$t)&&(t.window.set(t.window.subarray(e,e+e-s),0),t.match_start-=e,t.strstart-=e,t.block_start-=e,t.insert>t.strstart&&(t.insert=t.strstart),Kt(t),s+=e),0===t.strm.avail_in)break;if(a=Jt(t.strm,t.window,t.strstart+t.lookahead,s),t.lookahead+=a,t.lookahead+t.insert>=3)for(i=t.strstart-t.insert,t.ins_h=t.window[i],t.ins_h=Yt(t,t.ins_h,t.window[i+1]);t.insert&&(t.ins_h=Yt(t,t.ins_h,t.window[i+3-1]),t.prev[i&t.w_mask]=t.head[t.ins_h],t.head[t.ins_h]=i,i++,t.insert--,!(t.lookahead+t.insert<3)););}while(t.lookahead<$t&&0!==t.strm.avail_in)},ae=(t,e)=>{let a,s,i,r=t.pending_buf_size-5>t.w_size?t.w_size:t.pending_buf_size-5,n=0,h=t.strm.avail_in;do{if(a=65535,i=t.bi_valid+42>>3,t.strm.avail_out<i)break;if(i=t.strm.avail_out-i,s=t.strstart-t.block_start,a>s+t.strm.avail_in&&(a=s+t.strm.avail_in),a>i&&(a=i),a<r&&(0===a&&e!==zt||e===vt||a!==s+t.strm.avail_in))break;n=e===zt&&a===s+t.strm.avail_in?1:0,mt(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,Gt(t.strm),s&&(s>a&&(s=a),t.strm.output.set(t.window.subarray(t.block_start,t.block_start+s),t.strm.next_out),t.strm.next_out+=s,t.strm.avail_out-=s,t.strm.total_out+=s,t.block_start+=s,a-=s),a&&(Jt(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 h-=t.strm.avail_in,h&&(h>=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<=h&&(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-h,t.strm.next_in),t.strstart),t.strstart+=h,t.insert+=h>t.w_size-t.insert?t.w_size-t.insert:h),t.block_start=t.strstart),t.high_water<t.strstart&&(t.high_water=t.strstart),n?4:e!==vt&&e!==zt&&0===t.strm.avail_in&&t.strstart===t.block_start?2:(i=t.window_size-t.strstart,t.strm.avail_in>i&&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++,i+=t.w_size,t.insert>t.strstart&&(t.insert=t.strstart)),i>t.strm.avail_in&&(i=t.strm.avail_in),i&&(Jt(t.strm,t.window,t.strstart,i),t.strstart+=i,t.insert+=i>t.w_size-t.insert?t.w_size-t.insert:i),t.high_water<t.strstart&&(t.high_water=t.strstart),i=t.bi_valid+42>>3,i=t.pending_buf_size-i>65535?65535:t.pending_buf_size-i,r=i>t.w_size?t.w_size:i,s=t.strstart-t.block_start,(s>=r||(s||e===zt)&&e!==vt&&0===t.strm.avail_in&&s<=i)&&(a=s>i?i:s,n=e===zt&&0===t.strm.avail_in&&a===s?1:0,mt(t,t.block_start,a,n),t.block_start+=a,Gt(t.strm)),n?3:1)},se=(t,e)=>{let a,s;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a)),t.match_length>=3)if(s=yt(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=Yt(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=Yt(t,t.ins_h,t.window[t.strstart+1]);else s=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++;if(s&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2},ie=(t,e)=>{let a,s,i;for(;;){if(t.lookahead<$t){if(ee(t),t.lookahead<$t&&e===vt)return 1;if(0===t.lookahead)break}if(a=0,t.lookahead>=3&&(t.ins_h=Yt(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-$t&&(t.match_length=te(t,a),t.match_length<=5&&(t.strategy===xt||3===t.match_length&&t.strstart-t.match_start>4096)&&(t.match_length=2)),t.prev_length>=3&&t.match_length<=t.prev_length){i=t.strstart+t.lookahead-3,s=yt(t,t.strstart-1-t.prev_match,t.prev_length-3),t.lookahead-=t.prev_length-1,t.prev_length-=2;do{++t.strstart<=i&&(t.ins_h=Yt(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++,s&&(qt(t,!1),0===t.strm.avail_out))return 1}else if(t.match_available){if(s=yt(t,0,t.window[t.strstart-1]),s&&qt(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&&(s=yt(t,0,t.window[t.strstart-1]),t.match_available=0),t.insert=t.strstart<2?t.strstart:2,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2};function re(t,e,a,s,i){this.good_length=t,this.max_lazy=e,this.nice_length=a,this.max_chain=s,this.func=i}const ne=[new re(0,0,0,0,ae),new re(4,4,8,4,se),new re(4,5,16,8,se),new re(4,6,32,32,se),new re(4,4,16,16,ie),new re(8,16,32,32,ie),new re(8,16,128,128,ie),new re(8,32,128,256,ie),new re(32,128,258,1024,ie),new re(32,258,258,4096,ie)];function he(){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=Lt,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),Wt(this.dyn_ltree),Wt(this.dyn_dtree),Wt(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),Wt(this.heap),this.heap_len=0,this.heap_max=0,this.depth=new Uint16Array(573),Wt(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 le=t=>{if(!t)return 1;const e=t.state;return!e||e.strm!==t||e.status!==Nt&&57!==e.status&&69!==e.status&&73!==e.status&&91!==e.status&&103!==e.status&&e.status!==Mt&&e.status!==Ht?1:0},oe=t=>{if(le(t))return Vt(t,Ut);t.total_in=t.total_out=0,t.data_type=Pt;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?Nt:Mt,t.adler=2===e.wrap?0:1,e.last_flush=-2,pt(e),Ft},_e=t=>{const e=oe(t);var a;return e===Ft&&((a=t.state).window_size=2*a.w_size,Wt(a.head),a.max_lazy_match=ne[a.level].max_lazy,a.good_match=ne[a.level].good_length,a.nice_match=ne[a.level].nice_length,a.max_chain_length=ne[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},de=(t,e,a,s,i,r)=>{if(!t)return Ut;let n=1;if(e===Ot&&(e=6),s<0?(n=0,s=-s):s>15&&(n=2,s-=16),i<1||i>9||a!==Lt||s<8||s>15||e<0||e>9||r<0||r>Bt||8===s&&1!==n)return Vt(t,Ut);8===s&&(s=9);const h=new he;return t.state=h,h.strm=t,h.status=Nt,h.wrap=n,h.gzhead=null,h.w_bits=s,h.w_size=1<<h.w_bits,h.w_mask=h.w_size-1,h.hash_bits=i+7,h.hash_size=1<<h.hash_bits,h.hash_mask=h.hash_size-1,h.hash_shift=~~((h.hash_bits+3-1)/3),h.window=new Uint8Array(2*h.w_size),h.head=new Uint16Array(h.hash_size),h.prev=new Uint16Array(h.w_size),h.lit_bufsize=1<<i+6,h.pending_buf_size=4*h.lit_bufsize,h.pending_buf=new Uint8Array(h.pending_buf_size),h.sym_buf=h.lit_bufsize,h.sym_end=3*(h.lit_bufsize-1),h.level=e,h.strategy=r,h.method=a,_e(t)};var fe={deflateInit:(t,e)=>de(t,e,Lt,15,8,Tt),deflateInit2:de,deflateReset:_e,deflateResetKeep:oe,deflateSetHeader:(t,e)=>le(t)||2!==t.state.wrap?Ut:(t.state.gzhead=e,Ft),deflate:(t,e)=>{if(le(t)||e>Rt||e<0)return t?Vt(t,Ut):Ut;const a=t.state;if(!t.output||0!==t.avail_in&&!t.input||a.status===Ht&&e!==zt)return Vt(t,0===t.avail_out?It:Ut);const s=a.last_flush;if(a.last_flush=e,0!==a.pending){if(Gt(t),0===t.avail_out)return a.last_flush=-1,Ft}else if(0===t.avail_in&&jt(e)<=jt(s)&&e!==zt)return Vt(t,It);if(a.status===Ht&&0!==t.avail_in)return Vt(t,It);if(a.status===Nt&&0===a.wrap&&(a.status=Mt),a.status===Nt){let e=Lt+(a.w_bits-8<<4)<<8,s=-1;if(s=a.strategy>=At||a.level<2?0:a.level<6?1:6===a.level?2:3,e|=s<<6,0!==a.strstart&&(e|=32),e+=31-e%31,Qt(a,e),0!==a.strstart&&(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),t.adler=1,a.status=Mt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(57===a.status)if(t.adler=0,Xt(a,31),Xt(a,139),Xt(a,8),a.gzhead)Xt(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)),Xt(a,255&a.gzhead.time),Xt(a,a.gzhead.time>>8&255),Xt(a,a.gzhead.time>>16&255),Xt(a,a.gzhead.time>>24&255),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,255&a.gzhead.os),a.gzhead.extra&&a.gzhead.extra.length&&(Xt(a,255&a.gzhead.extra.length),Xt(a,a.gzhead.extra.length>>8&255)),a.gzhead.hcrc&&(t.adler=ut(t.adler,a.pending_buf,a.pending,0)),a.gzindex=0,a.status=69;else if(Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,0),Xt(a,9===a.level?2:a.strategy>=At||a.level<2?4:0),Xt(a,3),a.status=Mt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;if(69===a.status){if(a.gzhead.extra){let e=a.pending,s=(65535&a.gzhead.extra.length)-a.gzindex;for(;a.pending+s>a.pending_buf_size;){let i=a.pending_buf_size-a.pending;if(a.pending_buf.set(a.gzhead.extra.subarray(a.gzindex,a.gzindex+i),a.pending),a.pending=a.pending_buf_size,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(t.adler,a.pending_buf,a.pending-e,e)),a.gzindex+=i,Gt(t),0!==a.pending)return a.last_flush=-1,Ft;e=0,s-=i}let i=new Uint8Array(a.gzhead.extra);a.pending_buf.set(i.subarray(a.gzindex,a.gzindex+s),a.pending),a.pending+=s,a.gzhead.hcrc&&a.pending>e&&(t.adler=ut(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,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.name.length?255&a.gzhead.name.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),a.gzindex=0}a.status=91}if(91===a.status){if(a.gzhead.comment){let e,s=a.pending;do{if(a.pending===a.pending_buf_size){if(a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s)),Gt(t),0!==a.pending)return a.last_flush=-1,Ft;s=0}e=a.gzindex<a.gzhead.comment.length?255&a.gzhead.comment.charCodeAt(a.gzindex++):0,Xt(a,e)}while(0!==e);a.gzhead.hcrc&&a.pending>s&&(t.adler=ut(t.adler,a.pending_buf,a.pending-s,s))}a.status=103}if(103===a.status){if(a.gzhead.hcrc){if(a.pending+2>a.pending_buf_size&&(Gt(t),0!==a.pending))return a.last_flush=-1,Ft;Xt(a,255&t.adler),Xt(a,t.adler>>8&255),t.adler=0}if(a.status=Mt,Gt(t),0!==a.pending)return a.last_flush=-1,Ft}if(0!==t.avail_in||0!==a.lookahead||e!==vt&&a.status!==Ht){let s=0===a.level?ae(a,e):a.strategy===At?((t,e)=>{let a;for(;;){if(0===t.lookahead&&(ee(t),0===t.lookahead)){if(e===vt)return 1;break}if(t.match_length=0,a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++,a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):a.strategy===Ct?((t,e)=>{let a,s,i,r;const n=t.window;for(;;){if(t.lookahead<=Zt){if(ee(t),t.lookahead<=Zt&&e===vt)return 1;if(0===t.lookahead)break}if(t.match_length=0,t.lookahead>=3&&t.strstart>0&&(i=t.strstart-1,s=n[i],s===n[++i]&&s===n[++i]&&s===n[++i])){r=t.strstart+Zt;do{}while(s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&s===n[++i]&&i<r);t.match_length=Zt-(r-i),t.match_length>t.lookahead&&(t.match_length=t.lookahead)}if(t.match_length>=3?(a=yt(t,1,t.match_length-3),t.lookahead-=t.match_length,t.strstart+=t.match_length,t.match_length=0):(a=yt(t,0,t.window[t.strstart]),t.lookahead--,t.strstart++),a&&(qt(t,!1),0===t.strm.avail_out))return 1}return t.insert=0,e===zt?(qt(t,!0),0===t.strm.avail_out?3:4):t.sym_next&&(qt(t,!1),0===t.strm.avail_out)?1:2})(a,e):ne[a.level].func(a,e);if(3!==s&&4!==s||(a.status=Ht),1===s||3===s)return 0===t.avail_out&&(a.last_flush=-1),Ft;if(2===s&&(e===St?bt(a):e!==Rt&&(mt(a,0,0,!1),e===kt&&(Wt(a.head),0===a.lookahead&&(a.strstart=0,a.block_start=0,a.insert=0))),Gt(t),0===t.avail_out))return a.last_flush=-1,Ft}return e!==zt?Ft:a.wrap<=0?Et:(2===a.wrap?(Xt(a,255&t.adler),Xt(a,t.adler>>8&255),Xt(a,t.adler>>16&255),Xt(a,t.adler>>24&255),Xt(a,255&t.total_in),Xt(a,t.total_in>>8&255),Xt(a,t.total_in>>16&255),Xt(a,t.total_in>>24&255)):(Qt(a,t.adler>>>16),Qt(a,65535&t.adler)),Gt(t),a.wrap>0&&(a.wrap=-a.wrap),0!==a.pending?Ft:Et)},deflateEnd:t=>{if(le(t))return Ut;const e=t.state.status;return t.state=null,e===Mt?Vt(t,Dt):Ft},deflateSetDictionary:(t,e)=>{let a=e.length;if(le(t))return Ut;const s=t.state,i=s.wrap;if(2===i||1===i&&s.status!==Nt||s.lookahead)return Ut;if(1===i&&(t.adler=dt(t.adler,e,a,0)),s.wrap=0,a>=s.w_size){0===i&&(Wt(s.head),s.strstart=0,s.block_start=0,s.insert=0);let t=new Uint8Array(s.w_size);t.set(e.subarray(a-s.w_size,a),0),e=t,a=s.w_size}const r=t.avail_in,n=t.next_in,h=t.input;for(t.avail_in=a,t.next_in=0,t.input=e,ee(s);s.lookahead>=3;){let t=s.strstart,e=s.lookahead-2;do{s.ins_h=Yt(s,s.ins_h,s.window[t+3-1]),s.prev[t&s.w_mask]=s.head[s.ins_h],s.head[s.ins_h]=t,t++}while(--e);s.strstart=t,s.lookahead=2,ee(s)}return s.strstart+=s.lookahead,s.block_start=s.strstart,s.insert=s.lookahead,s.lookahead=0,s.match_length=s.prev_length=2,s.match_available=0,t.next_in=n,t.input=h,t.avail_in=r,s.wrap=i,Ft},deflateInfo:"pako deflate (from Nodeca project)"};const ue=(t,e)=>Object.prototype.hasOwnProperty.call(t,e);var ce=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)ue(a,e)&&(t[e]=a[e])}}return t},ge=t=>{let e=0;for(let a=0,s=t.length;a<s;a++)e+=t[a].length;const a=new Uint8Array(e);for(let e=0,s=0,i=t.length;e<i;e++){let i=t[e];a.set(i,s),s+=i.length}return a};let pe=!0;try{String.fromCharCode.apply(null,new Uint8Array(1))}catch(t){pe=!1}const me=new Uint8Array(256);for(let t=0;t<256;t++)me[t]=t>=252?6:t>=248?5:t>=240?4:t>=224?3:t>=192?2:1;me[254]=me[254]=1;var we=t=>{if("function"==typeof TextEncoder&&TextEncoder.prototype.encode)return(new TextEncoder).encode(t);let e,a,s,i,r,n=t.length,h=0;for(i=0;i<n;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),h+=a<128?1:a<2048?2:a<65536?3:4;for(e=new Uint8Array(h),r=0,i=0;r<h;i++)a=t.charCodeAt(i),55296==(64512&a)&&i+1<n&&(s=t.charCodeAt(i+1),56320==(64512&s)&&(a=65536+(a-55296<<10)+(s-56320),i++)),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};var ye=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 be=Object.prototype.toString,{Z_NO_FLUSH:ve,Z_SYNC_FLUSH:Se,Z_FULL_FLUSH:ke,Z_FINISH:ze,Z_OK:Re,Z_STREAM_END:Fe,Z_DEFAULT_COMPRESSION:Ee,Z_DEFAULT_STRATEGY:Ue,Z_DEFLATED:De}=gt;function Ie(t){this.options=ce({level:Ee,method:De,chunkSize:16384,windowBits:15,memLevel:8,strategy:Ue},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 ye,this.strm.avail_out=0;let a=fe.deflateInit2(this.strm,e.level,e.method,e.windowBits,e.memLevel,e.strategy);if(a!==Re)throw new Error(ct[a]);if(e.header&&fe.deflateSetHeader(this.strm,e.header),e.dictionary){let t;if(t="string"==typeof e.dictionary?we(e.dictionary):"[object ArrayBuffer]"===be.call(e.dictionary)?new Uint8Array(e.dictionary):e.dictionary,a=fe.deflateSetDictionary(this.strm,t),a!==Re)throw new Error(ct[a]);this._dict_set=!0}}Ie.prototype.push=function(t,e){const a=this.strm,s=this.options.chunkSize;let i,r;if(this.ended)return!1;for(r=e===~~e?e:!0===e?ze:ve,"string"==typeof t?a.input=we(t):"[object ArrayBuffer]"===be.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(s),a.next_out=0,a.avail_out=s),(r===Se||r===ke)&&a.avail_out<=6)this.onData(a.output.subarray(0,a.next_out)),a.avail_out=0;else{if(i=fe.deflate(a,r),i===Fe)return a.next_out>0&&this.onData(a.output.subarray(0,a.next_out)),i=fe.deflateEnd(this.strm),this.onEnd(i),this.ended=!0,i===Re;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},Ie.prototype.onData=function(t){this.chunks.push(t)},Ie.prototype.onEnd=function(t){t===Re&&(this.result=ge(this.chunks)),this.chunks=[],this.err=t,this.msg=this.strm.msg};var Oe={deflate:function(t,e){const a=new Ie(e);if(a.push(t,!0),a.err)throw a.msg||ct[a.err];return a.result}};const{deflate:xe}=Oe;var Ae=xe;const Ce={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}},Be=(t,...e)=>{let a=0;if(t.replace(/[<>]/,"").length!=e.length)throw"Pack format to Argument count mismatch";let s=[],i=!0;for(let s=0;s<t.length;s++)"<"==t[s]?i=!0:">"==t[s]?i=!1:(r(t[s],e[a]),a++);function r(t,e){if(!(t in Ce))throw"Unhandled character '"+t+"' in pack format";let a=Ce[t].bytes,r=new DataView(new ArrayBuffer(a));Ce[t].p.bind(r)(0,e,i);for(let t=0;t<a;t++)s.push(r.getUint8(t))}return s},Te=(t,e)=>{let a=0,s=[],i=!0;for(let e of t)"<"==e?i=!0:">"==e?i=!1:r(e);function r(t){if(!(t in Ce))throw"Unhandled character '"+t+"' in unpack format";let r=Ce[t].bytes,n=new DataView(new ArrayBuffer(r));for(let t=0;t<r;t++)n.setUint8(t,255&e[a+t]);let h=Ce[t].u.bind(n);s.push(h(0,i)),a+=r}return s};class Pe extends EventTarget{constructor(t,e,a){super(),this.port=t,this.logger=e,this._parent=a,this.chipName=null,this.chipRevision=null,this.chipVariant=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(),await this.detectChip();let t=z(this.getChipFamily()).macFuse;for(let e=0;e<4;e++)this._efuses[e]=await this.readRegister(t+4*e);this.logger.log(`Chip type ${this.chipName}`)}async detectChip(){try{const t=(await this.getSecurityInfo()).chipId,e=y[t];if(e)return this.chipName=e.name,this.chipFamily=e.family,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),void this.logger.debug(`Detected chip via IMAGE_CHIP_ID: ${t} (${this.chipName})`);this.logger.debug(`Unknown IMAGE_CHIP_ID: ${t}, falling back to magic value detection`)}catch(t){this.logger.debug(`GET_SECURITY_INFO failed, using magic value detection: ${t}`),this._inputBuffer.length=0,await s(100);try{await this.sync()}catch(t){this.logger.debug(`Re-sync after GET_SECURITY_INFO failure: ${t}`)}}let t=await this.readRegister(1073745920),e=b[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,this.chipFamily===w&&(this.chipRevision=await this.getChipRevision(),this.logger.debug(`ESP32-P4 revision: ${this.chipRevision}`),this.chipRevision>=300?this.chipVariant="rev300":this.chipVariant="rev0",this.logger.debug(`ESP32-P4 variant: ${this.chipVariant}`)),this.logger.debug(`Detected chip via magic value: ${a(t>>>0,8)} (${this.chipName})`)}async getChipRevision(){if(this.chipFamily!==w)return 0;const t=await this.readRegister(1343410252);return 100*((t>>23&1)<<2|t>>4&3)+(15&t)}async getSecurityInfo(){const[t,e]=await this.checkCommand(20,[],0);if(0===e.length)throw new Error("GET_SECURITY_INFO not supported or returned empty response");if(e.length<12)throw new Error(`Invalid security info response length: ${e.length} (expected at least 12 bytes)`);return{flags:Te("<I",e.slice(0,4))[0],flashCryptCnt:e[4],keyPurposes:Array.from(e.slice(5,12)),chipId:e.length>=16?Te("<I",e.slice(12,16))[0]:0,apiVersion:e.length>=20?Te("<I",e.slice(16,20))[0]:0}}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],s=this._efuses[1],i=this._efuses[2],r=this._efuses[3];if(this.chipFamily==l){if(0!=r)t=[r>>16&255,r>>8&255,255&r];else if(s>>16&255){if(1!=(s>>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]=s>>8&255,e[4]=255&s,e[5]=a>>24&255}else if(this.chipFamily==o)e[0]=i>>8&255,e[1]=255&i,e[2]=s>>24&255,e[3]=s>>16&255,e[4]=s>>8&255,e[5]=255&s;else{if(this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=p&&this.chipFamily!=m&&this.chipFamily!=w)throw new Error("Unknown chip family");e[0]=s>>8&255,e[1]=255&s,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=Be("<I",t);await this.sendCommand(10,e);let[s,i]=await this.getResponse(10);return s}async checkCommand(t,e,s=0,i=3e3){i=Math.min(i,12e5),await this.sendCommand(t,e,s);let[r,n]=await this.getResponse(t,i);if(null===n)throw new Error("Didn't get enough status bytes");let h=0;if(this.IS_STUB||this.chipFamily==l?h=2:[o,_,d,f,u,c,g,p,m,w].includes(this.chipFamily)||20===t?h=4:[2,4].includes(n.length)&&(h=n.length),n.length<h)throw new Error("Didn't get enough status bytes");let y=n.slice(-h,n.length);if(n=n.slice(0,-h),this.debug&&(this.logger.debug("status",y),this.logger.debug("value",r),this.logger.debug("data",n)),1==y[0])throw 5==y[1]?new Error("Invalid (unsupported) command "+a(t)):new Error("Command failure error code "+a(y[1]));return[r,n]}async sendCommand(t,e,a=0){let s=(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})([...Be("<BBHI",0,t,e.length,a),...e]);this.debug&&this.logger.debug(`Writing ${s.length} byte${1==s.length?"":"s"}:`,s),await this.writeToStream(s)}async readPacket(t){let i=null,r=!1,n=[];for(;;){let h=Date.now();for(n=[];Date.now()-h<t;){if(this._inputBuffer.length>0){n.push(this._inputBuffer.shift());break}await s(10)}if(0==n.length){throw new R("Timed out waiting for packet "+(null===i?"header":"content"))}this.debug&&this.logger.debug("Read "+n.length+" bytes: "+e(n));for(let t of n)if(null===i){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 R("Invalid head of packet ("+a(t)+")");i=[]}else if(r)if(r=!1,220==t)i.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 R("Invalid SLIP escape (0xdb, "+a(t)+")");i.push(219)}else if(219==t)r=!0;else{if(192==t)return this.debug&&this.logger.debug("Received full packet: "+e(i)),i;i.push(t)}}throw new R("Invalid state")}async getResponse(t,e=3e3){for(let s=0;s<100;s++){const s=await this.readPacket(e);if(s.length<8)continue;const[i,r,n,h]=Te("<BBHI",s.slice(0,8));if(1!=i)continue;const l=s.slice(8);if(null==t||r==t)return[h,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==l)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=Be("<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),this.logger.log(`Changed baud rate to ${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()}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 s(100),!0;await s(100)}throw new Error("Couldn't sync to ESP. Try resetting.")}async _sync(){await this.sendCommand(8,h);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,s=0,i=!1){if(t.byteLength>=8){var r=Array.from(new Uint8Array(t,0,4));let e=r[0],s=r[2],i=r[3];this.logger.log(`Image header, Magic=${a(e)}, FlashMode=${a(s)}, FlashSizeFreq=${a(i)}`)}let n,h=t.byteLength,l=0,o=v;i?(n=Ae(new Uint8Array(t),{level:9}).buffer,l=n.byteLength,this.logger.log(`Writing data with filesize: ${h}. Compressed Size: ${l}`),o=await this.flashDeflBegin(h,l,s)):(this.logger.log(`Writing data with filesize: ${h}`),n=t,await this.flashBegin(h,s));let _=[],d=0,f=0,u=0,c=Date.now(),g=this.getFlashWriteSize(),p=i?l:h;for(;p-u>0;)this.debug&&this.logger.log(`Writing at ${a(s+d*g,8)} `),p-u>=g?_=Array.from(new Uint8Array(n,u,g)):(_=Array.from(new Uint8Array(n,u,p-u)),i||(_=_.concat(new Array(g-_.length).fill(255)))),i?await this.flashDeflBlock(_,d,o):await this.flashBlock(_,d),d+=1,f+=i?Math.round(_.length*h/l):_.length,u+=g,e(Math.min(f,h),h);this.logger.log("Took "+(Date.now()-c)+"ms to write "+p+" bytes"),this.IS_STUB&&(await this.flashBegin(0,0),i?await this.flashDeflFinish():await this.flashFinish())}async flashBlock(t,e,a=3e3){await this.checkCommand(3,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashDeflBlock(t,e,a=3e3){await this.checkCommand(17,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t),a)}async flashBegin(t=0,e=0,s=!1){let i,r,n=this.getFlashWriteSize();!this.IS_STUB&&[o,_,d,f,u,c,g,p,m,w].includes(this.chipFamily)&&await this.checkCommand(13,new Array(8).fill(0));let h,y=Math.floor((t+n-1)/n);i=this.chipFamily==l?this.getEraseSize(e,t):t,h=this.IS_STUB?v:k(3e4,t);let b=Date.now();return r=Be("<IIII",i,y,n,e),this.chipFamily!=o&&this.chipFamily!=_&&this.chipFamily!=d&&this.chipFamily!=f&&this.chipFamily!=u&&this.chipFamily!=c&&this.chipFamily!=g&&this.chipFamily!=p&&this.chipFamily!=m&&this.chipFamily!=w||(r=r.concat(Be("<I",s?1:0))),this.logger.log("Erase size "+i+", blocks "+y+", block size "+a(n,4)+", offset "+a(e,4)+", encrypted "+(s?"yes":"no")),await this.checkCommand(2,r,0,h),0==t||this.IS_STUB||this.logger.log("Took "+(Date.now()-b)+"ms to erase "+y+" bytes"),y}async flashDeflBegin(t=0,e=0,a=0,s=!1){let i,r=this.getFlashWriteSize(),n=Math.floor((e+r-1)/r),h=Math.floor((t+r-1)/r),l=0,o=0;return this.IS_STUB?(l=t,o=k(3e4,l)):(l=h*r,o=v),i=Be("<IIII",l,n,r,a),await this.checkCommand(16,i,0,o),o}async flashFinish(){let t=Be("<I",1);await this.checkCommand(4,t)}async flashDeflFinish(){let t=Be("<I",1);await this.checkCommand(18,t)}getBootloaderOffset(){return z(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,s=0,i=0){let r=Be("<IIII",t,e,a,s);i>0&&r.concat(Be("<IIII",z(this.getChipFamily()).uartDateReg,0,0,i)),await this.checkCommand(9,r)}async setDataLengths(t,e,a){if(-1!=t.mosiDlenOffs){let s=t.regBase+t.mosiDlenOffs,i=t.regBase+t.misoDlenOffs;e>0&&await this.writeRegister(s,e-1),a>0&&await this.writeRegister(i,a-1)}else{let s=t.regBase+t.usr1Offs,i=(0==a?0:a-1)<<8|(0==e?0:e-1)<<17;await this.writeRegister(s,i)}}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,s=0){let i=z(this.getChipFamily()),r=i.regBase,n=r,h=r+i.usrOffs,l=r+i.usr2Offs,o=r+i.w0Offs,_=1<<18;if(s>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 d=8*e.length,f=await this.readRegister(h),u=await this.readRegister(l),c=1<<31;if(s>0&&(c|=268435456),d>0&&(c|=134217728),await this.setDataLengths(i,d,s),await this.writeRegister(h,c),await this.writeRegister(l,7<<28|t),0==d)await this.writeRegister(o,0);else{e.concat(new Array(e.length%4).fill(0));let t=Te("I".repeat(Math.floor(e.length/4)),e),s=o;this.logger.debug(`Words Length: ${t.length}`);for(const e of t)this.logger.debug(`Writing word ${a(e)} to register offset ${a(s)}`),await this.writeRegister(s,e),s+=4}await this.writeRegister(n,_),await this.waitDone(n,_);let g=await this.readRegister(o);return await this.writeRegister(h,f),await this.writeRegister(l,u),g}async detectFlashSize(){this.logger.log("Detecting Flash Size");let t=await this.flashId(),e=255&t,s=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)}${s.toString(16)}`),this.flashSize=i[s],this.logger.log(`Auto-detected Flash size: ${this.flashSize}`)}getEraseSize(t,e){let a=4096,s=Math.floor((e+a-1)/a),i=16-Math.floor(t/a)%16;return s<i&&(i=s),s<2*i?Math.floor((s+1)/2*a):(s-i)*a}async memBegin(t,e,a,s){return await this.checkCommand(5,Be("<IIII",t,e,a,s))}async memBlock(t,e){return await this.checkCommand(7,Be("<IIII",t.length,e,0,0).concat(t),this.checksum(t))}async memFinish(t=0){let e=this.IS_STUB?v:500,a=Be("<II",0==t?1:0,t);return await this.checkCommand(6,a,0,e)}async runStub(){const t=await F(this.chipFamily,this.chipRevision);let e,a=2048;this.logger.log("Uploading stub...");for(let e of["text","data"])if(Object.keys(t).includes(e)){let s=t[e+"_start"],i=t[e].length,r=Math.floor((i+a-1)/a);await this.memBegin(i,r,a,s);for(let s of Array(r).keys()){let r=s*a,n=r+a;n>i&&(n=i),await this.memBlock(t[e].slice(r,n),s)}}this.logger.log("Running stub..."),await this.memFinish(t.entry);const s=await this.readPacket(500);if(e=String.fromCharCode(...s),"OHAI"!=e)throw new Error("Failed to start stub. Unexpected response: "+e);this.logger.log("Stub is now running...");const i=new Le(this.port,this.logger,this);return await i.detectFlashSize(),i}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 Le extends Pe{constructor(){super(...arguments),this.IS_STUB=!0}async memBegin(t,e,s,i){let r=await F(this.chipFamily,this.chipRevision),n=i,h=i+t;console.log(n,h),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&&h>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(h,8)+". Try changing the binary loading address.")}async eraseFlash(){await this.checkCommand(208,[],0,S)}}const Ze=async t=>{const e=await navigator.serial.requestPort();return t.log("Connecting..."),await e.open({baudRate:r}),t.log("Connected successfully."),new Pe(e,t)};export{o as CHIP_FAMILY_ESP32,f as CHIP_FAMILY_ESP32C2,u as CHIP_FAMILY_ESP32C3,c as CHIP_FAMILY_ESP32C5,g as CHIP_FAMILY_ESP32C6,p as CHIP_FAMILY_ESP32C61,m as CHIP_FAMILY_ESP32H2,w as CHIP_FAMILY_ESP32P4,_ as CHIP_FAMILY_ESP32S2,d as CHIP_FAMILY_ESP32S3,l as CHIP_FAMILY_ESP8266,Pe as ESPLoader,Ze as connect};
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "tasmota-webserial-esptool",
3
- "version": "6.5.0",
3
+ "version": "6.5.2",
4
4
  "description": "Flash ESP devices using WebSerial",
5
5
  "main": "dist/index.js",
6
6
  "repository": {
package/src/esp_loader.ts CHANGED
@@ -153,6 +153,19 @@ export class ESPLoader extends EventTarget {
153
153
  this.logger.debug(
154
154
  `GET_SECURITY_INFO failed, using magic value detection: ${err}`,
155
155
  );
156
+
157
+ // Clear input buffer and re-sync to recover from failed command
158
+ this._inputBuffer.length = 0;
159
+ await sleep(100);
160
+
161
+ // Re-sync with the chip to ensure clean communication
162
+ try {
163
+ await this.sync();
164
+ } catch (syncErr) {
165
+ this.logger.debug(
166
+ `Re-sync after GET_SECURITY_INFO failure: ${syncErr}`,
167
+ );
168
+ }
156
169
  }
157
170
 
158
171
  // Fallback: Use magic value detection for ESP8266, ESP32, ESP32-S2, and ESP32-P4 RC versions
@@ -225,9 +238,16 @@ export class ESPLoader extends EventTarget {
225
238
  0,
226
239
  );
227
240
 
228
- if (responseData.length < 20) {
241
+ // Some chips/ROM versions return empty response or don't support this command
242
+ if (responseData.length === 0) {
243
+ throw new Error(
244
+ `GET_SECURITY_INFO not supported or returned empty response`,
245
+ );
246
+ }
247
+
248
+ if (responseData.length < 12) {
229
249
  throw new Error(
230
- `Invalid security info response length: ${responseData.length}`,
250
+ `Invalid security info response length: ${responseData.length} (expected at least 12 bytes)`,
231
251
  );
232
252
  }
233
253
 
@@ -455,7 +475,11 @@ export class ESPLoader extends EventTarget {
455
475
  ) {
456
476
  statusLen = 4;
457
477
  } else {
458
- if ([2, 4].includes(data.length)) {
478
+ // When chipFamily is not yet set (e.g., during GET_SECURITY_INFO in detectChip),
479
+ // assume modern chips use 4-byte status
480
+ if (opcode === ESP_GET_SECURITY_INFO) {
481
+ statusLen = 4;
482
+ } else if ([2, 4].includes(data.length)) {
459
483
  statusLen = data.length;
460
484
  }
461
485
  }