@stencil/core 5.0.0-alpha.5 → 5.0.0-alpha.6

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.
Files changed (43) hide show
  1. package/dist/{client-Dnio47yQ.mjs → client-fWOou5EW.mjs} +2324 -2125
  2. package/dist/compiler/index.d.mts +5 -5
  3. package/dist/compiler/index.mjs +2 -2
  4. package/dist/compiler/utils/index.d.mts +2 -2
  5. package/dist/compiler/utils/index.mjs +3 -3
  6. package/dist/{compiler-Dxri2g8Z.mjs → compiler-CdUbDTbV.mjs} +13329 -12670
  7. package/dist/declarations/stencil-public-compiler.d.ts +254 -121
  8. package/dist/declarations/stencil-public-docs.d.ts +10 -0
  9. package/dist/declarations/stencil-public-runtime.d.ts +49 -12
  10. package/dist/{index-D5zaocDq.d.mts → index-D8vvsppY.d.mts} +228 -180
  11. package/dist/{index-D61XZw0f.d.ts → index-Dap2E02-.d.ts} +82 -31
  12. package/dist/{index-Dat4djoo.d.mts → index-UUlemGuu.d.mts} +13 -2
  13. package/dist/index.d.mts +0 -1
  14. package/dist/index.mjs +1 -1
  15. package/dist/jsx-runtime.d.mts +18 -0
  16. package/dist/jsx-runtime.mjs +2 -0
  17. package/dist/{node-pj6rF4Wt.mjs → node-klLZLdDe.mjs} +59 -55
  18. package/dist/{regular-expression-D0_N0PGa.mjs → regular-expression-DUdhF3Ei.mjs} +72 -6
  19. package/dist/runtime/app-data/index.d.ts +1 -1
  20. package/dist/runtime/app-data/index.js +15 -9
  21. package/dist/{runtime-CKyUrF4i.js → runtime/client/lazy.js} +2539 -2199
  22. package/dist/runtime/client/{index.d.ts → runtime.d.ts} +49 -40
  23. package/dist/runtime/client/{index.js → runtime.js} +2401 -2185
  24. package/dist/runtime/index.d.ts +20 -3
  25. package/dist/runtime/index.js +4956 -2
  26. package/dist/runtime/server/index.d.mts +30 -39
  27. package/dist/runtime/server/index.mjs +2369 -2185
  28. package/dist/runtime/server/runner.d.mts +4 -6
  29. package/dist/runtime/server/runner.mjs +307 -361
  30. package/dist/signals/index.d.ts +47 -0
  31. package/dist/signals/index.js +199 -0
  32. package/dist/sys/node/index.d.mts +1 -1
  33. package/dist/sys/node/index.mjs +1 -1
  34. package/dist/sys/node/worker.mjs +2 -2
  35. package/dist/testing/index.d.mts +97 -3
  36. package/dist/testing/index.mjs +199 -47
  37. package/dist/{validation-BA8nzXu_.mjs → validation-2QipI30K.mjs} +21 -32
  38. package/package.json +41 -27
  39. package/dist/index-D-XN9HW_.d.ts +0 -30
  40. package/dist/jsx-runtime-B3vQbWIW.d.ts +0 -28
  41. package/dist/jsx-runtime.d.ts +0 -2
  42. package/dist/jsx-runtime.js +0 -2
  43. /package/dist/{chunk-CjcI7cDX.mjs → chunk-z9aeyW2b.mjs} +0 -0
@@ -1,7 +1,7 @@
1
- import { Readable } from "node:stream";
2
1
  import { ssrFactory } from "@stencil/core/runtime/server/ssr-factory";
3
2
  import { BUILD } from "@stencil/core/runtime/app-data";
4
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/common/unicode.js
3
+ import "@preact/signals-core";
4
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/common/unicode.js
5
5
  const UNDEFINED_CODE_POINTS = new Set([
6
6
  65534,
7
7
  65535,
@@ -91,7 +91,7 @@ function isUndefinedCodePoint(cp) {
91
91
  return cp >= 64976 && cp <= 65007 || UNDEFINED_CODE_POINTS.has(cp);
92
92
  }
93
93
  //#endregion
94
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/common/error-codes.js
94
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/common/error-codes.js
95
95
  var ERR;
96
96
  (function(ERR) {
97
97
  ERR["controlCharacterInInputStream"] = "control-character-in-input-stream";
@@ -156,7 +156,7 @@ var ERR;
156
156
  ERR["eofInElementThatCanContainOnlyText"] = "eof-in-element-that-can-contain-only-text";
157
157
  })(ERR || (ERR = {}));
158
158
  //#endregion
159
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/tokenizer/preprocessor.js
159
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/tokenizer/preprocessor.js
160
160
  const DEFAULT_BUFFER_WATERLINE = 65536;
161
161
  var Preprocessor = class {
162
162
  constructor(handler) {
@@ -307,7 +307,7 @@ var Preprocessor = class {
307
307
  }
308
308
  };
309
309
  //#endregion
310
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/common/token.js
310
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/common/token.js
311
311
  var TokenType;
312
312
  (function(TokenType) {
313
313
  TokenType[TokenType["CHARACTER"] = 0] = "CHARACTER";
@@ -325,14 +325,7 @@ function getTokenAttr(token, attrName) {
325
325
  return null;
326
326
  }
327
327
  //#endregion
328
- //#region ../../node_modules/.pnpm/entities@4.5.0/node_modules/entities/lib/esm/generated/decode-data-html.js
329
- var decode_data_html_default = new Uint16Array("ᵁ<Õıʊҝջאٵ۞ޢߖࠏ੊ઑඡ๭༉༦჊ረዡᐕᒝᓃᓟᔥ\0\0\0\0\0\0ᕫᛍᦍᰒᷝ὾⁠↰⊍⏀⏻⑂⠤⤒ⴈ⹈⿎〖㊺㘹㞬㣾㨨㩱㫠㬮ࠀEMabcfglmnoprstu\\bfms„‹•˜¦³¹ÈÏlig耻Æ䃆P耻&䀦cute耻Á䃁reve;䄂Āiyx}rc耻Â䃂;䐐r;쀀𝔄rave耻À䃀pha;䎑acr;䄀d;橓Āgp¡on;䄄f;쀀𝔸plyFunction;恡ing耻Å䃅Ācs¾Ãr;쀀𝒜ign;扔ilde耻Ã䃃ml耻Ä䃄ЀaceforsuåûþėĜĢħĪĀcrêòkslash;或Ŷöø;櫧ed;挆y;䐑ƀcrtąċĔause;戵noullis;愬a;䎒r;쀀𝔅pf;쀀𝔹eve;䋘còēmpeq;扎܀HOacdefhilorsuōőŖƀƞƢƵƷƺǜȕɳɸɾcy;䐧PY耻©䂩ƀcpyŝŢźute;䄆Ā;iŧŨ拒talDifferentialD;慅leys;愭ȀaeioƉƎƔƘron;䄌dil耻Ç䃇rc;䄈nint;戰ot;䄊ĀdnƧƭilla;䂸terDot;䂷òſi;䎧rcleȀDMPTLJNjǑǖot;抙inus;抖lus;投imes;抗oĀcsǢǸkwiseContourIntegral;戲eCurlyĀDQȃȏoubleQuote;思uote;怙ȀlnpuȞȨɇɕonĀ;eȥȦ户;橴ƀgitȯȶȺruent;扡nt;戯ourIntegral;戮ĀfrɌɎ;愂oduct;成nterClockwiseContourIntegral;戳oss;樯cr;쀀𝒞pĀ;Cʄʅ拓ap;才րDJSZacefiosʠʬʰʴʸˋ˗ˡ˦̳ҍĀ;oŹʥtrahd;椑cy;䐂cy;䐅cy;䐏ƀgrsʿ˄ˇger;怡r;憡hv;櫤Āayː˕ron;䄎;䐔lĀ;t˝˞戇a;䎔r;쀀𝔇Āaf˫̧Ācm˰̢riticalȀADGT̖̜̀̆cute;䂴oŴ̋̍;䋙bleAcute;䋝rave;䁠ilde;䋜ond;拄ferentialD;慆Ѱ̽\0\0\0͔͂\0Ѕf;쀀𝔻ƀ;DE͈͉͍䂨ot;惜qual;扐blèCDLRUVͣͲ΂ϏϢϸontourIntegraìȹoɴ͹\0\0ͻ»͉nArrow;懓Āeo·ΤftƀARTΐΖΡrrow;懐ightArrow;懔eåˊngĀLRΫτeftĀARγιrrow;柸ightArrow;柺ightArrow;柹ightĀATϘϞrrow;懒ee;抨pɁϩ\0\0ϯrrow;懑ownArrow;懕erticalBar;戥ǹABLRTaВЪаўѿͼrrowƀ;BUНОТ憓ar;椓pArrow;懵reve;䌑eft˒к\0ц\0ѐightVector;楐eeVector;楞ectorĀ;Bљњ憽ar;楖ightǔѧ\0ѱeeVector;楟ectorĀ;BѺѻ懁ar;楗eeĀ;A҆҇护rrow;憧ĀctҒҗr;쀀𝒟rok;䄐ࠀNTacdfglmopqstuxҽӀӄӋӞӢӧӮӵԡԯԶՒ՝ՠեG;䅊H耻Ð䃐cute耻É䃉ƀaiyӒӗӜron;䄚rc耻Ê䃊;䐭ot;䄖r;쀀𝔈rave耻È䃈ement;戈ĀapӺӾcr;䄒tyɓԆ\0\0ԒmallSquare;旻erySmallSquare;斫ĀgpԦԪon;䄘f;쀀𝔼silon;䎕uĀaiԼՉlĀ;TՂՃ橵ilde;扂librium;懌Āci՗՚r;愰m;橳a;䎗ml耻Ë䃋Āipժկsts;戃onentialE;慇ʀcfiosօֈ֍ֲ׌y;䐤r;쀀𝔉lledɓ֗\0\0֣mallSquare;旼erySmallSquare;斪Ͱֺ\0ֿ\0\0ׄf;쀀𝔽All;戀riertrf;愱cò׋؀JTabcdfgorstר׬ׯ׺؀ؒؖ؛؝أ٬ٲcy;䐃耻>䀾mmaĀ;d׷׸䎓;䏜reve;䄞ƀeiy؇،ؐdil;䄢rc;䄜;䐓ot;䄠r;쀀𝔊;拙pf;쀀𝔾eater̀EFGLSTصلَٖٛ٦qualĀ;Lؾؿ扥ess;招ullEqual;执reater;檢ess;扷lantEqual;橾ilde;扳cr;쀀𝒢;扫ЀAacfiosuڅڋږڛڞڪھۊRDcy;䐪Āctڐڔek;䋇;䁞irc;䄤r;愌lbertSpace;愋ǰگ\0ڲf;愍izontalLine;攀Āctۃۅòکrok;䄦mpńېۘownHumðįqual;扏܀EJOacdfgmnostuۺ۾܃܇܎ܚܞܡܨ݄ݸދޏޕcy;䐕lig;䄲cy;䐁cute耻Í䃍Āiyܓܘrc耻Î䃎;䐘ot;䄰r;愑rave耻Ì䃌ƀ;apܠܯܿĀcgܴܷr;䄪inaryI;慈lieóϝǴ݉\0ݢĀ;eݍݎ戬Āgrݓݘral;戫section;拂isibleĀCTݬݲomma;恣imes;恢ƀgptݿރވon;䄮f;쀀𝕀a;䎙cr;愐ilde;䄨ǫޚ\0ޞcy;䐆l耻Ï䃏ʀcfosuެ޷޼߂ߐĀiyޱ޵rc;䄴;䐙r;쀀𝔍pf;쀀𝕁ǣ߇\0ߌr;쀀𝒥rcy;䐈kcy;䐄΀HJacfosߤߨ߽߬߱ࠂࠈcy;䐥cy;䐌ppa;䎚Āey߶߻dil;䄶;䐚r;쀀𝔎pf;쀀𝕂cr;쀀𝒦րJTaceflmostࠥࠩࠬࡐࡣ঳সে্਷ੇcy;䐉耻<䀼ʀcmnpr࠷࠼ࡁࡄࡍute;䄹bda;䎛g;柪lacetrf;愒r;憞ƀaeyࡗ࡜ࡡron;䄽dil;䄻;䐛Āfsࡨ॰tԀACDFRTUVarࡾࢩࢱࣦ࣠ࣼयज़ΐ४Ānrࢃ࢏gleBracket;柨rowƀ;BR࢙࢚࢞憐ar;懤ightArrow;懆eiling;挈oǵࢷ\0ࣃbleBracket;柦nǔࣈ\0࣒eeVector;楡ectorĀ;Bࣛࣜ懃ar;楙loor;挊ightĀAV࣯ࣵrrow;憔ector;楎Āerँगeƀ;AVउऊऐ抣rrow;憤ector;楚iangleƀ;BEतथऩ抲ar;槏qual;抴pƀDTVषूौownVector;楑eeVector;楠ectorĀ;Bॖॗ憿ar;楘ectorĀ;B॥०憼ar;楒ightáΜs̀EFGLSTॾঋকঝঢভqualGreater;拚ullEqual;扦reater;扶ess;檡lantEqual;橽ilde;扲r;쀀𝔏Ā;eঽা拘ftarrow;懚idot;䄿ƀnpw৔ਖਛgȀLRlr৞৷ਂਐeftĀAR০৬rrow;柵ightArrow;柷ightArrow;柶eftĀarγਊightáοightáϊf;쀀𝕃erĀLRਢਬeftArrow;憙ightArrow;憘ƀchtਾੀੂòࡌ;憰rok;䅁;扪Ѐacefiosuਗ਼੝੠੷੼અઋ઎p;椅y;䐜Ādl੥੯iumSpace;恟lintrf;愳r;쀀𝔐nusPlus;戓pf;쀀𝕄cò੶;䎜ҀJacefostuણધભીଔଙඑ඗ඞcy;䐊cute;䅃ƀaey઴હાron;䅇dil;䅅;䐝ƀgswે૰଎ativeƀMTV૓૟૨ediumSpace;怋hiĀcn૦૘ë૙eryThiî૙tedĀGL૸ଆreaterGreateòٳessLesóੈLine;䀊r;쀀𝔑ȀBnptଢନଷ଺reak;恠BreakingSpace;䂠f;愕ڀ;CDEGHLNPRSTV୕ୖ୪୼஡௫ఄ౞಄ದ೘ൡඅ櫬Āou୛୤ngruent;扢pCap;扭oubleVerticalBar;戦ƀlqxஃஊ஛ement;戉ualĀ;Tஒஓ扠ilde;쀀≂̸ists;戄reater΀;EFGLSTஶஷ஽௉௓௘௥扯qual;扱ullEqual;쀀≧̸reater;쀀≫̸ess;批lantEqual;쀀⩾̸ilde;扵umpń௲௽ownHump;쀀≎̸qual;쀀≏̸eĀfsఊధtTriangleƀ;BEచఛడ拪ar;쀀⧏̸qual;括s̀;EGLSTవశ఼ౄోౘ扮qual;扰reater;扸ess;쀀≪̸lantEqual;쀀⩽̸ilde;扴estedĀGL౨౹reaterGreater;쀀⪢̸essLess;쀀⪡̸recedesƀ;ESಒಓಛ技qual;쀀⪯̸lantEqual;拠ĀeiಫಹverseElement;戌ghtTriangleƀ;BEೋೌ೒拫ar;쀀⧐̸qual;拭ĀquೝഌuareSuĀbp೨೹setĀ;E೰ೳ쀀⊏̸qual;拢ersetĀ;Eഃആ쀀⊐̸qual;拣ƀbcpഓതൎsetĀ;Eഛഞ쀀⊂⃒qual;抈ceedsȀ;ESTലള഻െ抁qual;쀀⪰̸lantEqual;拡ilde;쀀≿̸ersetĀ;E൘൛쀀⊃⃒qual;抉ildeȀ;EFT൮൯൵ൿ扁qual;扄ullEqual;扇ilde;扉erticalBar;戤cr;쀀𝒩ilde耻Ñ䃑;䎝܀Eacdfgmoprstuvලෂ෉෕ෛ෠෧෼ขภยา฿ไlig;䅒cute耻Ó䃓Āiy෎ීrc耻Ô䃔;䐞blac;䅐r;쀀𝔒rave耻Ò䃒ƀaei෮ෲ෶cr;䅌ga;䎩cron;䎟pf;쀀𝕆enCurlyĀDQฎบoubleQuote;怜uote;怘;橔Āclวฬr;쀀𝒪ash耻Ø䃘iŬื฼de耻Õ䃕es;樷ml耻Ö䃖erĀBP๋๠Āar๐๓r;怾acĀek๚๜;揞et;掴arenthesis;揜Ҁacfhilors๿ງຊຏຒດຝະ໼rtialD;戂y;䐟r;쀀𝔓i;䎦;䎠usMinus;䂱Āipຢອncareplanåڝf;愙Ȁ;eio຺ູ໠໤檻cedesȀ;EST່້໏໚扺qual;檯lantEqual;扼ilde;找me;怳Ādp໩໮uct;戏ortionĀ;aȥ໹l;戝Āci༁༆r;쀀𝒫;䎨ȀUfos༑༖༛༟OT耻\"䀢r;쀀𝔔pf;愚cr;쀀𝒬؀BEacefhiorsu༾གྷཇའཱིྦྷྪྭ႖ႩႴႾarr;椐G耻®䂮ƀcnrཎནབute;䅔g;柫rĀ;tཛྷཝ憠l;椖ƀaeyཧཬཱron;䅘dil;䅖;䐠Ā;vླྀཹ愜erseĀEUྂྙĀlq྇ྎement;戋uilibrium;懋pEquilibrium;楯r»ཹo;䎡ghtЀACDFTUVa࿁࿫࿳ဢဨၛႇϘĀnr࿆࿒gleBracket;柩rowƀ;BL࿜࿝࿡憒ar;懥eftArrow;懄eiling;按oǵ࿹\0စbleBracket;柧nǔည\0နeeVector;楝ectorĀ;Bဝသ懂ar;楕loor;挋Āerိ၃eƀ;AVဵံြ抢rrow;憦ector;楛iangleƀ;BEၐၑၕ抳ar;槐qual;抵pƀDTVၣၮၸownVector;楏eeVector;楜ectorĀ;Bႂႃ憾ar;楔ectorĀ;B႑႒懀ar;楓Āpuႛ႞f;愝ndImplies;楰ightarrow;懛ĀchႹႼr;愛;憱leDelayed;槴ڀHOacfhimoqstuფჱჷჽᄙᄞᅑᅖᅡᅧᆵᆻᆿĀCcჩხHcy;䐩y;䐨FTcy;䐬cute;䅚ʀ;aeiyᄈᄉᄎᄓᄗ檼ron;䅠dil;䅞rc;䅜;䐡r;쀀𝔖ortȀDLRUᄪᄴᄾᅉownArrow»ОeftArrow»࢚ightArrow»࿝pArrow;憑gma;䎣allCircle;战pf;쀀𝕊ɲᅭ\0\0ᅰt;戚areȀ;ISUᅻᅼᆉᆯ斡ntersection;抓uĀbpᆏᆞsetĀ;Eᆗᆘ抏qual;抑ersetĀ;Eᆨᆩ抐qual;抒nion;抔cr;쀀𝒮ar;拆ȀbcmpᇈᇛሉላĀ;sᇍᇎ拐etĀ;Eᇍᇕqual;抆ĀchᇠህeedsȀ;ESTᇭᇮᇴᇿ扻qual;檰lantEqual;扽ilde;承Tháྌ;我ƀ;esሒሓሣ拑rsetĀ;Eሜም抃qual;抇et»ሓրHRSacfhiorsሾቄ቉ቕ቞ቱቶኟዂወዑORN耻Þ䃞ADE;愢ĀHc቎ቒcy;䐋y;䐦Ābuቚቜ;䀉;䎤ƀaeyብቪቯron;䅤dil;䅢;䐢r;쀀𝔗Āeiቻ኉Dzኀ\0ኇefore;戴a;䎘Ācn኎ኘkSpace;쀀  Space;怉ldeȀ;EFTካኬኲኼ戼qual;扃ullEqual;扅ilde;扈pf;쀀𝕋ipleDot;惛Āctዖዛr;쀀𝒯rok;䅦ૡዷጎጚጦ\0ጬጱ\0\0\0\0\0ጸጽ፷ᎅ\0᏿ᐄᐊᐐĀcrዻጁute耻Ú䃚rĀ;oጇገ憟cir;楉rǣጓ\0጖y;䐎ve;䅬Āiyጞጣrc耻Û䃛;䐣blac;䅰r;쀀𝔘rave耻Ù䃙acr;䅪Ādiፁ፩erĀBPፈ፝Āarፍፐr;䁟acĀekፗፙ;揟et;掵arenthesis;揝onĀ;P፰፱拃lus;抎Āgp፻፿on;䅲f;쀀𝕌ЀADETadps᎕ᎮᎸᏄϨᏒᏗᏳrrowƀ;BDᅐᎠᎤar;椒ownArrow;懅ownArrow;憕quilibrium;楮eeĀ;AᏋᏌ报rrow;憥ownáϳerĀLRᏞᏨeftArrow;憖ightArrow;憗iĀ;lᏹᏺ䏒on;䎥ing;䅮cr;쀀𝒰ilde;䅨ml耻Ü䃜ҀDbcdefosvᐧᐬᐰᐳᐾᒅᒊᒐᒖash;披ar;櫫y;䐒ashĀ;lᐻᐼ抩;櫦Āerᑃᑅ;拁ƀbtyᑌᑐᑺar;怖Ā;iᑏᑕcalȀBLSTᑡᑥᑪᑴar;戣ine;䁼eparator;杘ilde;所ThinSpace;怊r;쀀𝔙pf;쀀𝕍cr;쀀𝒱dash;抪ʀcefosᒧᒬᒱᒶᒼirc;䅴dge;拀r;쀀𝔚pf;쀀𝕎cr;쀀𝒲Ȁfiosᓋᓐᓒᓘr;쀀𝔛;䎞pf;쀀𝕏cr;쀀𝒳ҀAIUacfosuᓱᓵᓹᓽᔄᔏᔔᔚᔠcy;䐯cy;䐇cy;䐮cute耻Ý䃝Āiyᔉᔍrc;䅶;䐫r;쀀𝔜pf;쀀𝕐cr;쀀𝒴ml;䅸ЀHacdefosᔵᔹᔿᕋᕏᕝᕠᕤcy;䐖cute;䅹Āayᕄᕉron;䅽;䐗ot;䅻Dzᕔ\0ᕛoWidtè૙a;䎖r;愨pf;愤cr;쀀𝒵௡ᖃᖊᖐ\0ᖰᖶᖿ\0\0\0\0ᗆᗛᗫᙟ᙭\0ᚕ᚛ᚲᚹ\0ᚾcute耻á䃡reve;䄃̀;Ediuyᖜᖝᖡᖣᖨᖭ戾;쀀∾̳;房rc耻â䃢te肻´̆;䐰lig耻æ䃦Ā;r²ᖺ;쀀𝔞rave耻à䃠ĀepᗊᗖĀfpᗏᗔsym;愵èᗓha;䎱ĀapᗟcĀclᗤᗧr;䄁g;樿ɤᗰ\0\0ᘊʀ;adsvᗺᗻᗿᘁᘇ戧nd;橕;橜lope;橘;橚΀;elmrszᘘᘙᘛᘞᘿᙏᙙ戠;榤e»ᘙsdĀ;aᘥᘦ戡ѡᘰᘲᘴᘶᘸᘺᘼᘾ;榨;榩;榪;榫;榬;榭;榮;榯tĀ;vᙅᙆ戟bĀ;dᙌᙍ抾;榝Āptᙔᙗh;戢»¹arr;捼Āgpᙣᙧon;䄅f;쀀𝕒΀;Eaeiop዁ᙻᙽᚂᚄᚇᚊ;橰cir;橯;扊d;手s;䀧roxĀ;e዁ᚒñᚃing耻å䃥ƀctyᚡᚦᚨr;쀀𝒶;䀪mpĀ;e዁ᚯñʈilde耻ã䃣ml耻ä䃤Āciᛂᛈoninôɲnt;樑ࠀNabcdefiklnoprsu᛭ᛱᜰ᜼ᝃᝈ᝸᝽០៦ᠹᡐᜍ᤽᥈ᥰot;櫭Ācrᛶ᜞kȀcepsᜀᜅᜍᜓong;扌psilon;䏶rime;怵imĀ;e᜚᜛戽q;拍Ŷᜢᜦee;抽edĀ;gᜬᜭ挅e»ᜭrkĀ;t፜᜷brk;掶Āoyᜁᝁ;䐱quo;怞ʀcmprtᝓ᝛ᝡᝤᝨausĀ;eĊĉptyv;榰séᜌnoõēƀahwᝯ᝱ᝳ;䎲;愶een;扬r;쀀𝔟g΀costuvwឍឝឳេ៕៛៞ƀaiuបពរðݠrc;旯p»፱ƀdptឤឨឭot;樀lus;樁imes;樂ɱឹ\0\0ើcup;樆ar;昅riangleĀdu៍្own;施p;斳plus;樄eåᑄåᒭarow;植ƀako៭ᠦᠵĀcn៲ᠣkƀlst៺֫᠂ozenge;槫riangleȀ;dlr᠒᠓᠘᠝斴own;斾eft;旂ight;斸k;搣Ʊᠫ\0ᠳƲᠯ\0ᠱ;斒;斑4;斓ck;斈ĀeoᠾᡍĀ;qᡃᡆ쀀=⃥uiv;쀀≡⃥t;挐Ȁptwxᡙᡞᡧᡬf;쀀𝕓Ā;tᏋᡣom»Ꮜtie;拈؀DHUVbdhmptuvᢅᢖᢪᢻᣗᣛᣬ᣿ᤅᤊᤐᤡȀLRlrᢎᢐᢒᢔ;敗;敔;敖;敓ʀ;DUduᢡᢢᢤᢦᢨ敐;敦;敩;敤;敧ȀLRlrᢳᢵᢷᢹ;敝;敚;敜;教΀;HLRhlrᣊᣋᣍᣏᣑᣓᣕ救;敬;散;敠;敫;敢;敟ox;槉ȀLRlrᣤᣦᣨᣪ;敕;敒;攐;攌ʀ;DUduڽ᣷᣹᣻᣽;敥;敨;攬;攴inus;抟lus;択imes;抠ȀLRlrᤙᤛᤝ᤟;敛;敘;攘;攔΀;HLRhlrᤰᤱᤳᤵᤷ᤻᤹攂;敪;敡;敞;攼;攤;攜Āevģ᥂bar耻¦䂦Ȁceioᥑᥖᥚᥠr;쀀𝒷mi;恏mĀ;e᜚᜜lƀ;bhᥨᥩᥫ䁜;槅sub;柈Ŭᥴ᥾lĀ;e᥹᥺怢t»᥺pƀ;Eeįᦅᦇ;檮Ā;qۜۛೡᦧ\0᧨ᨑᨕᨲ\0ᨷᩐ\0\0᪴\0\0᫁\0\0ᬡᬮ᭍᭒\0᯽\0ᰌƀcpr᦭ᦲ᧝ute;䄇̀;abcdsᦿᧀᧄ᧊᧕᧙戩nd;橄rcup;橉Āau᧏᧒p;橋p;橇ot;橀;쀀∩︀Āeo᧢᧥t;恁îړȀaeiu᧰᧻ᨁᨅǰ᧵\0᧸s;橍on;䄍dil耻ç䃧rc;䄉psĀ;sᨌᨍ橌m;橐ot;䄋ƀdmnᨛᨠᨦil肻¸ƭptyv;榲t脀¢;eᨭᨮ䂢räƲr;쀀𝔠ƀceiᨽᩀᩍy;䑇ckĀ;mᩇᩈ朓ark»ᩈ;䏇r΀;Ecefms᩟᩠ᩢᩫ᪤᪪᪮旋;槃ƀ;elᩩᩪᩭ䋆q;扗eɡᩴ\0\0᪈rrowĀlr᩼᪁eft;憺ight;憻ʀRSacd᪒᪔᪖᪚᪟»ཇ;擈st;抛irc;抚ash;抝nint;樐id;櫯cir;槂ubsĀ;u᪻᪼晣it»᪼ˬ᫇᫔᫺\0ᬊonĀ;eᫍᫎ䀺Ā;qÇÆɭ᫙\0\0᫢aĀ;t᫞᫟䀬;䁀ƀ;fl᫨᫩᫫戁îᅠeĀmx᫱᫶ent»᫩eóɍǧ᫾\0ᬇĀ;dኻᬂot;橭nôɆƀfryᬐᬔᬗ;쀀𝕔oäɔ脀©;sŕᬝr;愗Āaoᬥᬩrr;憵ss;朗Ācuᬲᬷr;쀀𝒸Ābpᬼ᭄Ā;eᭁᭂ櫏;櫑Ā;eᭉᭊ櫐;櫒dot;拯΀delprvw᭠᭬᭷ᮂᮬᯔ᯹arrĀlr᭨᭪;椸;椵ɰ᭲\0\0᭵r;拞c;拟arrĀ;p᭿ᮀ憶;椽̀;bcdosᮏᮐᮖᮡᮥᮨ截rcap;橈Āauᮛᮞp;橆p;橊ot;抍r;橅;쀀∪︀Ȁalrv᮵ᮿᯞᯣrrĀ;mᮼᮽ憷;椼yƀevwᯇᯔᯘqɰᯎ\0\0ᯒreã᭳uã᭵ee;拎edge;拏en耻¤䂤earrowĀlrᯮ᯳eft»ᮀight»ᮽeäᯝĀciᰁᰇoninôǷnt;戱lcty;挭ঀAHabcdefhijlorstuwz᰸᰻᰿ᱝᱩᱵᲊᲞᲬᲷ᳻᳿ᴍᵻᶑᶫᶻ᷆᷍rò΁ar;楥Ȁglrs᱈ᱍ᱒᱔ger;怠eth;愸òᄳhĀ;vᱚᱛ怐»ऊūᱡᱧarow;椏aã̕Āayᱮᱳron;䄏;䐴ƀ;ao̲ᱼᲄĀgrʿᲁr;懊tseq;橷ƀglmᲑᲔᲘ耻°䂰ta;䎴ptyv;榱ĀirᲣᲨsht;楿;쀀𝔡arĀlrᲳᲵ»ࣜ»သʀaegsv᳂͸᳖᳜᳠mƀ;oș᳊᳔ndĀ;ș᳑uit;晦amma;䏝in;拲ƀ;io᳧᳨᳸䃷de脀÷;o᳧ᳰntimes;拇nø᳷cy;䑒cɯᴆ\0\0ᴊrn;挞op;挍ʀlptuwᴘᴝᴢᵉᵕlar;䀤f;쀀𝕕ʀ;emps̋ᴭᴷᴽᵂqĀ;d͒ᴳot;扑inus;戸lus;戔quare;抡blebarwedgåúnƀadhᄮᵝᵧownarrowóᲃarpoonĀlrᵲᵶefôᲴighôᲶŢᵿᶅkaro÷གɯᶊ\0\0ᶎrn;挟op;挌ƀcotᶘᶣᶦĀryᶝᶡ;쀀𝒹;䑕l;槶rok;䄑Ādrᶰᶴot;拱iĀ;fᶺ᠖斿Āah᷀᷃ròЩaòྦangle;榦Āci᷒ᷕy;䑟grarr;柿ऀDacdefglmnopqrstuxḁḉḙḸոḼṉṡṾấắẽỡἪἷὄ὎὚ĀDoḆᴴoôᲉĀcsḎḔute耻é䃩ter;橮ȀaioyḢḧḱḶron;䄛rĀ;cḭḮ扖耻ê䃪lon;払;䑍ot;䄗ĀDrṁṅot;扒;쀀𝔢ƀ;rsṐṑṗ檚ave耻è䃨Ā;dṜṝ檖ot;檘Ȁ;ilsṪṫṲṴ檙nters;揧;愓Ā;dṹṺ檕ot;檗ƀapsẅẉẗcr;䄓tyƀ;svẒẓẕ戅et»ẓpĀ1;ẝẤijạả;怄;怅怃ĀgsẪẬ;䅋p;怂ĀgpẴẸon;䄙f;쀀𝕖ƀalsỄỎỒrĀ;sỊị拕l;槣us;橱iƀ;lvỚớở䎵on»ớ;䏵ȀcsuvỪỳἋἣĀioữḱrc»Ḯɩỹ\0\0ỻíՈantĀglἂἆtr»ṝess»Ṻƀaeiἒ἖Ἒls;䀽st;扟vĀ;DȵἠD;橸parsl;槥ĀDaἯἳot;打rr;楱ƀcdiἾὁỸr;愯oô͒ĀahὉὋ;䎷耻ð䃰Āmrὓὗl耻ë䃫o;悬ƀcipὡὤὧl;䀡sôծĀeoὬὴctatioîՙnentialåչৡᾒ\0ᾞ\0ᾡᾧ\0\0ῆῌ\0ΐ\0ῦῪ \0 ⁚llingdotseñṄy;䑄male;晀ƀilrᾭᾳ῁lig;耀ffiɩᾹ\0\0᾽g;耀ffig;耀ffl;쀀𝔣lig;耀filig;쀀fjƀaltῙ῜ῡt;晭ig;耀flns;斱of;䆒ǰ΅\0ῳf;쀀𝕗ĀakֿῷĀ;vῼ´拔;櫙artint;樍Āao‌⁕Ācs‑⁒ႉ‸⁅⁈\0⁐β•‥‧‪‬\0‮耻½䂽;慓耻¼䂼;慕;慙;慛Ƴ‴\0‶;慔;慖ʴ‾⁁\0\0⁃耻¾䂾;慗;慜5;慘ƶ⁌\0⁎;慚;慝8;慞l;恄wn;挢cr;쀀𝒻ࢀEabcdefgijlnorstv₂₉₟₥₰₴⃰⃵⃺⃿℃ℒℸ̗ℾ⅒↞Ā;lٍ₇;檌ƀcmpₐₕ₝ute;䇵maĀ;dₜ᳚䎳;檆reve;䄟Āiy₪₮rc;䄝;䐳ot;䄡Ȁ;lqsؾق₽⃉ƀ;qsؾٌ⃄lanô٥Ȁ;cdl٥⃒⃥⃕c;檩otĀ;o⃜⃝檀Ā;l⃢⃣檂;檄Ā;e⃪⃭쀀⋛︀s;檔r;쀀𝔤Ā;gٳ؛mel;愷cy;䑓Ȁ;Eajٚℌℎℐ;檒;檥;檤ȀEaesℛℝ℩ℴ;扩pĀ;p℣ℤ檊rox»ℤĀ;q℮ℯ檈Ā;q℮ℛim;拧pf;쀀𝕘Āci⅃ⅆr;愊mƀ;el٫ⅎ⅐;檎;檐茀>;cdlqr׮ⅠⅪⅮⅳⅹĀciⅥⅧ;檧r;橺ot;拗Par;榕uest;橼ʀadelsↄⅪ←ٖ↛ǰ↉\0↎proø₞r;楸qĀlqؿ↖lesó₈ií٫Āen↣↭rtneqq;쀀≩︀Å↪ԀAabcefkosy⇄⇇⇱⇵⇺∘∝∯≨≽ròΠȀilmr⇐⇔⇗⇛rsðᒄf»․ilôکĀdr⇠⇤cy;䑊ƀ;cwࣴ⇫⇯ir;楈;憭ar;意irc;䄥ƀalr∁∎∓rtsĀ;u∉∊晥it»∊lip;怦con;抹r;쀀𝔥sĀew∣∩arow;椥arow;椦ʀamopr∺∾≃≞≣rr;懿tht;戻kĀlr≉≓eftarrow;憩ightarrow;憪f;쀀𝕙bar;怕ƀclt≯≴≸r;쀀𝒽asè⇴rok;䄧Ābp⊂⊇ull;恃hen»ᱛૡ⊣\0⊪\0⊸⋅⋎\0⋕⋳\0\0⋸⌢⍧⍢⍿\0⎆⎪⎴cute耻í䃭ƀ;iyݱ⊰⊵rc耻î䃮;䐸Ācx⊼⊿y;䐵cl耻¡䂡ĀfrΟ⋉;쀀𝔦rave耻ì䃬Ȁ;inoܾ⋝⋩⋮Āin⋢⋦nt;樌t;戭fin;槜ta;愩lig;䄳ƀaop⋾⌚⌝ƀcgt⌅⌈⌗r;䄫ƀelpܟ⌏⌓inåގarôܠh;䄱f;抷ed;䆵ʀ;cfotӴ⌬⌱⌽⍁are;愅inĀ;t⌸⌹戞ie;槝doô⌙ʀ;celpݗ⍌⍐⍛⍡al;抺Āgr⍕⍙eróᕣã⍍arhk;樗rod;樼Ȁcgpt⍯⍲⍶⍻y;䑑on;䄯f;쀀𝕚a;䎹uest耻¿䂿Āci⎊⎏r;쀀𝒾nʀ;EdsvӴ⎛⎝⎡ӳ;拹ot;拵Ā;v⎦⎧拴;拳Ā;iݷ⎮lde;䄩ǫ⎸\0⎼cy;䑖l耻ï䃯̀cfmosu⏌⏗⏜⏡⏧⏵Āiy⏑⏕rc;䄵;䐹r;쀀𝔧ath;䈷pf;쀀𝕛ǣ⏬\0⏱r;쀀𝒿rcy;䑘kcy;䑔Ѐacfghjos␋␖␢␧␭␱␵␻ppaĀ;v␓␔䎺;䏰Āey␛␠dil;䄷;䐺r;쀀𝔨reen;䄸cy;䑅cy;䑜pf;쀀𝕜cr;쀀𝓀஀ABEHabcdefghjlmnoprstuv⑰⒁⒆⒍⒑┎┽╚▀♎♞♥♹♽⚚⚲⛘❝❨➋⟀⠁⠒ƀart⑷⑺⑼rò৆òΕail;椛arr;椎Ā;gঔ⒋;檋ar;楢ॣ⒥\0⒪\0⒱\0\0\0\0\0⒵Ⓔ\0ⓆⓈⓍ\0⓹ute;䄺mptyv;榴raîࡌbda;䎻gƀ;dlࢎⓁⓃ;榑åࢎ;檅uo耻«䂫rЀ;bfhlpst࢙ⓞⓦⓩ⓫⓮⓱⓵Ā;f࢝ⓣs;椟s;椝ë≒p;憫l;椹im;楳l;憢ƀ;ae⓿─┄檫il;椙Ā;s┉┊檭;쀀⪭︀ƀabr┕┙┝rr;椌rk;杲Āak┢┬cĀek┨┪;䁻;䁛Āes┱┳;榋lĀdu┹┻;榏;榍Ȁaeuy╆╋╖╘ron;䄾Ādi═╔il;䄼ìࢰâ┩;䐻Ȁcqrs╣╦╭╽a;椶uoĀ;rนᝆĀdu╲╷har;楧shar;楋h;憲ʀ;fgqs▋▌উ◳◿扤tʀahlrt▘▤▷◂◨rrowĀ;t࢙□aé⓶arpoonĀdu▯▴own»њp»०eftarrows;懇ightƀahs◍◖◞rrowĀ;sࣴࢧarpoonó྘quigarro÷⇰hreetimes;拋ƀ;qs▋ও◺lanôবʀ;cdgsব☊☍☝☨c;檨otĀ;o☔☕橿Ā;r☚☛檁;檃Ā;e☢☥쀀⋚︀s;檓ʀadegs☳☹☽♉♋pproøⓆot;拖qĀgq♃♅ôউgtò⒌ôছiíলƀilr♕࣡♚sht;楼;쀀𝔩Ā;Eজ♣;檑š♩♶rĀdu▲♮Ā;l॥♳;楪lk;斄cy;䑙ʀ;achtੈ⚈⚋⚑⚖rò◁orneòᴈard;楫ri;旺Āio⚟⚤dot;䅀ustĀ;a⚬⚭掰che»⚭ȀEaes⚻⚽⛉⛔;扨pĀ;p⛃⛄檉rox»⛄Ā;q⛎⛏檇Ā;q⛎⚻im;拦Ѐabnoptwz⛩⛴⛷✚✯❁❇❐Ānr⛮⛱g;柬r;懽rëࣁgƀlmr⛿✍✔eftĀar০✇ightá৲apsto;柼ightá৽parrowĀlr✥✩efô⓭ight;憬ƀafl✶✹✽r;榅;쀀𝕝us;樭imes;樴š❋❏st;戗áፎƀ;ef❗❘᠀旊nge»❘arĀ;l❤❥䀨t;榓ʀachmt❳❶❼➅➇ròࢨorneòᶌarĀ;d྘➃;業;怎ri;抿̀achiqt➘➝ੀ➢➮➻quo;怹r;쀀𝓁mƀ;egল➪➬;檍;檏Ābu┪➳oĀ;rฟ➹;怚rok;䅂萀<;cdhilqrࠫ⟒☹⟜⟠⟥⟪⟰Āci⟗⟙;檦r;橹reå◲mes;拉arr;楶uest;橻ĀPi⟵⟹ar;榖ƀ;ef⠀भ᠛旃rĀdu⠇⠍shar;楊har;楦Āen⠗⠡rtneqq;쀀≨︀Å⠞܀Dacdefhilnopsu⡀⡅⢂⢎⢓⢠⢥⢨⣚⣢⣤ઃ⣳⤂Dot;戺Ȁclpr⡎⡒⡣⡽r耻¯䂯Āet⡗⡙;時Ā;e⡞⡟朠se»⡟Ā;sျ⡨toȀ;dluျ⡳⡷⡻owîҌefôएðᏑker;斮Āoy⢇⢌mma;権;䐼ash;怔asuredangle»ᘦr;쀀𝔪o;愧ƀcdn⢯⢴⣉ro耻µ䂵Ȁ;acdᑤ⢽⣀⣄sôᚧir;櫰ot肻·Ƶusƀ;bd⣒ᤃ⣓戒Ā;uᴼ⣘;横ţ⣞⣡p;櫛ò−ðઁĀdp⣩⣮els;抧f;쀀𝕞Āct⣸⣽r;쀀𝓂pos»ᖝƀ;lm⤉⤊⤍䎼timap;抸ఀGLRVabcdefghijlmoprstuvw⥂⥓⥾⦉⦘⧚⧩⨕⨚⩘⩝⪃⪕⪤⪨⬄⬇⭄⭿⮮ⰴⱧⱼ⳩Āgt⥇⥋;쀀⋙̸Ā;v⥐௏쀀≫⃒ƀelt⥚⥲⥶ftĀar⥡⥧rrow;懍ightarrow;懎;쀀⋘̸Ā;v⥻ే쀀≪⃒ightarrow;懏ĀDd⦎⦓ash;抯ash;抮ʀbcnpt⦣⦧⦬⦱⧌la»˞ute;䅄g;쀀∠⃒ʀ;Eiop඄⦼⧀⧅⧈;쀀⩰̸d;쀀≋̸s;䅉roø඄urĀ;a⧓⧔普lĀ;s⧓ସdz⧟\0⧣p肻\xA0ଷmpĀ;e௹ఀʀaeouy⧴⧾⨃⨐⨓ǰ⧹\0⧻;橃on;䅈dil;䅆ngĀ;dൾ⨊ot;쀀⩭̸p;橂;䐽ash;怓΀;Aadqsxஒ⨩⨭⨻⩁⩅⩐rr;懗rĀhr⨳⨶k;椤Ā;oᏲᏰot;쀀≐̸uiöୣĀei⩊⩎ar;椨í஘istĀ;s஠டr;쀀𝔫ȀEest௅⩦⩹⩼ƀ;qs஼⩭௡ƀ;qs஼௅⩴lanô௢ií௪Ā;rஶ⪁»ஷƀAap⪊⪍⪑rò⥱rr;憮ar;櫲ƀ;svྍ⪜ྌĀ;d⪡⪢拼;拺cy;䑚΀AEadest⪷⪺⪾⫂⫅⫶⫹rò⥦;쀀≦̸rr;憚r;急Ȁ;fqs఻⫎⫣⫯tĀar⫔⫙rro÷⫁ightarro÷⪐ƀ;qs఻⪺⫪lanôౕĀ;sౕ⫴»శiíౝĀ;rవ⫾iĀ;eచథiäඐĀpt⬌⬑f;쀀𝕟膀¬;in⬙⬚⬶䂬nȀ;Edvஉ⬤⬨⬮;쀀⋹̸ot;쀀⋵̸ǡஉ⬳⬵;拷;拶iĀ;vಸ⬼ǡಸ⭁⭃;拾;拽ƀaor⭋⭣⭩rȀ;ast୻⭕⭚⭟lleì୻l;쀀⫽⃥;쀀∂̸lint;樔ƀ;ceಒ⭰⭳uåಥĀ;cಘ⭸Ā;eಒ⭽ñಘȀAait⮈⮋⮝⮧rò⦈rrƀ;cw⮔⮕⮙憛;쀀⤳̸;쀀↝̸ghtarrow»⮕riĀ;eೋೖ΀chimpqu⮽⯍⯙⬄୸⯤⯯Ȁ;cerല⯆ഷ⯉uå൅;쀀𝓃ortɭ⬅\0\0⯖ará⭖mĀ;e൮⯟Ā;q൴൳suĀbp⯫⯭å೸åഋƀbcp⯶ⰑⰙȀ;Ees⯿ⰀഢⰄ抄;쀀⫅̸etĀ;eഛⰋqĀ;qണⰀcĀ;eലⰗñസȀ;EesⰢⰣൟⰧ抅;쀀⫆̸etĀ;e൘ⰮqĀ;qൠⰣȀgilrⰽⰿⱅⱇìௗlde耻ñ䃱çృiangleĀlrⱒⱜeftĀ;eచⱚñదightĀ;eೋⱥñ೗Ā;mⱬⱭ䎽ƀ;esⱴⱵⱹ䀣ro;愖p;怇ҀDHadgilrsⲏⲔⲙⲞⲣⲰⲶⳓⳣash;抭arr;椄p;쀀≍⃒ash;抬ĀetⲨⲬ;쀀≥⃒;쀀>⃒nfin;槞ƀAetⲽⳁⳅrr;椂;쀀≤⃒Ā;rⳊⳍ쀀<⃒ie;쀀⊴⃒ĀAtⳘⳜrr;椃rie;쀀⊵⃒im;쀀∼⃒ƀAan⳰⳴ⴂrr;懖rĀhr⳺⳽k;椣Ā;oᏧᏥear;椧ቓ᪕\0\0\0\0\0\0\0\0\0\0\0\0\0ⴭ\0ⴸⵈⵠⵥ⵲ⶄᬇ\0\0ⶍⶫ\0ⷈⷎ\0ⷜ⸙⸫⸾⹃Ācsⴱ᪗ute耻ó䃳ĀiyⴼⵅrĀ;c᪞ⵂ耻ô䃴;䐾ʀabios᪠ⵒⵗLjⵚlac;䅑v;樸old;榼lig;䅓Ācr⵩⵭ir;榿;쀀𝔬ͯ⵹\0\0⵼\0ⶂn;䋛ave耻ò䃲;槁Ābmⶈ෴ar;榵Ȁacitⶕ⶘ⶥⶨrò᪀Āir⶝ⶠr;榾oss;榻nå๒;槀ƀaeiⶱⶵⶹcr;䅍ga;䏉ƀcdnⷀⷅǍron;䎿;榶pf;쀀𝕠ƀaelⷔ⷗ǒr;榷rp;榹΀;adiosvⷪⷫⷮ⸈⸍⸐⸖戨rò᪆Ȁ;efmⷷⷸ⸂⸅橝rĀ;oⷾⷿ愴f»ⷿ耻ª䂪耻º䂺gof;抶r;橖lope;橗;橛ƀclo⸟⸡⸧ò⸁ash耻ø䃸l;折iŬⸯ⸴de耻õ䃵esĀ;aǛ⸺s;樶ml耻ö䃶bar;挽ૡ⹞\0⹽\0⺀⺝\0⺢⺹\0\0⻋ຜ\0⼓\0\0⼫⾼\0⿈rȀ;astЃ⹧⹲຅脀¶;l⹭⹮䂶leìЃɩ⹸\0\0⹻m;櫳;櫽y;䐿rʀcimpt⺋⺏⺓ᡥ⺗nt;䀥od;䀮il;怰enk;怱r;쀀𝔭ƀimo⺨⺰⺴Ā;v⺭⺮䏆;䏕maô੶ne;明ƀ;tv⺿⻀⻈䏀chfork»´;䏖Āau⻏⻟nĀck⻕⻝kĀ;h⇴⻛;愎ö⇴sҀ;abcdemst⻳⻴ᤈ⻹⻽⼄⼆⼊⼎䀫cir;樣ir;樢Āouᵀ⼂;樥;橲n肻±ຝim;樦wo;樧ƀipu⼙⼠⼥ntint;樕f;쀀𝕡nd耻£䂣Ԁ;Eaceinosu່⼿⽁⽄⽇⾁⾉⾒⽾⾶;檳p;檷uå໙Ā;c໎⽌̀;acens່⽙⽟⽦⽨⽾pproø⽃urlyeñ໙ñ໎ƀaes⽯⽶⽺pprox;檹qq;檵im;拨iíໟmeĀ;s⾈ຮ怲ƀEas⽸⾐⽺ð⽵ƀdfp໬⾙⾯ƀals⾠⾥⾪lar;挮ine;挒urf;挓Ā;t໻⾴ï໻rel;抰Āci⿀⿅r;쀀𝓅;䏈ncsp;怈̀fiopsu⿚⋢⿟⿥⿫⿱r;쀀𝔮pf;쀀𝕢rime;恗cr;쀀𝓆ƀaeo⿸〉〓tĀei⿾々rnionóڰnt;樖stĀ;e【】䀿ñἙô༔઀ABHabcdefhilmnoprstux぀けさすムㄎㄫㅇㅢㅲㆎ㈆㈕㈤㈩㉘㉮㉲㊐㊰㊷ƀartぇおがròႳòϝail;検aròᱥar;楤΀cdenqrtとふへみわゔヌĀeuねぱ;쀀∽̱te;䅕iãᅮmptyv;榳gȀ;del࿑らるろ;榒;榥å࿑uo耻»䂻rր;abcfhlpstw࿜ガクシスゼゾダッデナp;極Ā;f࿠ゴs;椠;椳s;椞ë≝ð✮l;楅im;楴l;憣;憝Āaiパフil;椚oĀ;nホボ戶aló༞ƀabrョリヮrò៥rk;杳ĀakンヽcĀekヹ・;䁽;䁝Āes㄂㄄;榌lĀduㄊㄌ;榎;榐Ȁaeuyㄗㄜㄧㄩron;䅙Ādiㄡㄥil;䅗ì࿲âヺ;䑀Ȁclqsㄴㄷㄽㅄa;椷dhar;楩uoĀ;rȎȍh;憳ƀacgㅎㅟངlȀ;ipsླྀㅘㅛႜnåႻarôྩt;断ƀilrㅩဣㅮsht;楽;쀀𝔯ĀaoㅷㆆrĀduㅽㅿ»ѻĀ;l႑ㆄ;楬Ā;vㆋㆌ䏁;䏱ƀgns㆕ㇹㇼht̀ahlrstㆤㆰ㇂㇘㇤㇮rrowĀ;t࿜ㆭaéトarpoonĀduㆻㆿowîㅾp»႒eftĀah㇊㇐rrowó࿪arpoonóՑightarrows;應quigarro÷ニhreetimes;拌g;䋚ingdotseñἲƀahm㈍㈐㈓rò࿪aòՑ;怏oustĀ;a㈞㈟掱che»㈟mid;櫮Ȁabpt㈲㈽㉀㉒Ānr㈷㈺g;柭r;懾rëဃƀafl㉇㉊㉎r;榆;쀀𝕣us;樮imes;樵Āap㉝㉧rĀ;g㉣㉤䀩t;榔olint;樒arò㇣Ȁachq㉻㊀Ⴜ㊅quo;怺r;쀀𝓇Ābu・㊊oĀ;rȔȓƀhir㊗㊛㊠reåㇸmes;拊iȀ;efl㊪ၙᠡ㊫方tri;槎luhar;楨;愞ൡ㋕㋛㋟㌬㌸㍱\0㍺㎤\0\0㏬㏰\0㐨㑈㑚㒭㒱㓊㓱\0㘖\0\0㘳cute;䅛quï➺Ԁ;Eaceinpsyᇭ㋳㋵㋿㌂㌋㌏㌟㌦㌩;檴ǰ㋺\0㋼;檸on;䅡uåᇾĀ;dᇳ㌇il;䅟rc;䅝ƀEas㌖㌘㌛;檶p;檺im;择olint;樓iíሄ;䑁otƀ;be㌴ᵇ㌵担;橦΀Aacmstx㍆㍊㍗㍛㍞㍣㍭rr;懘rĀhr㍐㍒ë∨Ā;oਸ਼਴t耻§䂧i;䀻war;椩mĀin㍩ðnuóñt;朶rĀ;o㍶⁕쀀𝔰Ȁacoy㎂㎆㎑㎠rp;景Āhy㎋㎏cy;䑉;䑈rtɭ㎙\0\0㎜iäᑤaraì⹯耻­䂭Āgm㎨㎴maƀ;fv㎱㎲㎲䏃;䏂Ѐ;deglnprካ㏅㏉㏎㏖㏞㏡㏦ot;橪Ā;q኱ኰĀ;E㏓㏔檞;檠Ā;E㏛㏜檝;檟e;扆lus;樤arr;楲aròᄽȀaeit㏸㐈㐏㐗Āls㏽㐄lsetmé㍪hp;樳parsl;槤Ādlᑣ㐔e;挣Ā;e㐜㐝檪Ā;s㐢㐣檬;쀀⪬︀ƀflp㐮㐳㑂tcy;䑌Ā;b㐸㐹䀯Ā;a㐾㐿槄r;挿f;쀀𝕤aĀdr㑍ЂesĀ;u㑔㑕晠it»㑕ƀcsu㑠㑹㒟Āau㑥㑯pĀ;sᆈ㑫;쀀⊓︀pĀ;sᆴ㑵;쀀⊔︀uĀbp㑿㒏ƀ;esᆗᆜ㒆etĀ;eᆗ㒍ñᆝƀ;esᆨᆭ㒖etĀ;eᆨ㒝ñᆮƀ;afᅻ㒦ְrť㒫ֱ»ᅼaròᅈȀcemt㒹㒾㓂㓅r;쀀𝓈tmîñiì㐕aræᆾĀar㓎㓕rĀ;f㓔ឿ昆Āan㓚㓭ightĀep㓣㓪psiloîỠhé⺯s»⡒ʀbcmnp㓻㕞ሉ㖋㖎Ҁ;Edemnprs㔎㔏㔑㔕㔞㔣㔬㔱㔶抂;櫅ot;檽Ā;dᇚ㔚ot;櫃ult;櫁ĀEe㔨㔪;櫋;把lus;檿arr;楹ƀeiu㔽㕒㕕tƀ;en㔎㕅㕋qĀ;qᇚ㔏eqĀ;q㔫㔨m;櫇Ābp㕚㕜;櫕;櫓c̀;acensᇭ㕬㕲㕹㕻㌦pproø㋺urlyeñᇾñᇳƀaes㖂㖈㌛pproø㌚qñ㌗g;晪ڀ123;Edehlmnps㖩㖬㖯ሜ㖲㖴㗀㗉㗕㗚㗟㗨㗭耻¹䂹耻²䂲耻³䂳;櫆Āos㖹㖼t;檾ub;櫘Ā;dሢ㗅ot;櫄sĀou㗏㗒l;柉b;櫗arr;楻ult;櫂ĀEe㗤㗦;櫌;抋lus;櫀ƀeiu㗴㘉㘌tƀ;enሜ㗼㘂qĀ;qሢ㖲eqĀ;q㗧㗤m;櫈Ābp㘑㘓;櫔;櫖ƀAan㘜㘠㘭rr;懙rĀhr㘦㘨ë∮Ā;oਫ਩war;椪lig耻ß䃟௡㙑㙝㙠ዎ㙳㙹\0㙾㛂\0\0\0\0\0㛛㜃\0㜉㝬\0\0\0㞇ɲ㙖\0\0㙛get;挖;䏄rë๟ƀaey㙦㙫㙰ron;䅥dil;䅣;䑂lrec;挕r;쀀𝔱Ȁeiko㚆㚝㚵㚼Dz㚋\0㚑eĀ4fኄኁaƀ;sv㚘㚙㚛䎸ym;䏑Ācn㚢㚲kĀas㚨㚮pproø዁im»ኬsðኞĀas㚺㚮ð዁rn耻þ䃾Ǭ̟㛆⋧es膀×;bd㛏㛐㛘䃗Ā;aᤏ㛕r;樱;樰ƀeps㛡㛣㜀á⩍Ȁ;bcf҆㛬㛰㛴ot;挶ir;櫱Ā;o㛹㛼쀀𝕥rk;櫚á㍢rime;怴ƀaip㜏㜒㝤dåቈ΀adempst㜡㝍㝀㝑㝗㝜㝟ngleʀ;dlqr㜰㜱㜶㝀㝂斵own»ᶻeftĀ;e⠀㜾ñम;扜ightĀ;e㊪㝋ñၚot;旬inus;樺lus;樹b;槍ime;樻ezium;揢ƀcht㝲㝽㞁Āry㝷㝻;쀀𝓉;䑆cy;䑛rok;䅧Āio㞋㞎xô᝷headĀlr㞗㞠eftarro÷ࡏightarrow»ཝऀAHabcdfghlmoprstuw㟐㟓㟗㟤㟰㟼㠎㠜㠣㠴㡑㡝㡫㢩㣌㣒㣪㣶ròϭar;楣Ācr㟜㟢ute耻ú䃺òᅐrǣ㟪\0㟭y;䑞ve;䅭Āiy㟵㟺rc耻û䃻;䑃ƀabh㠃㠆㠋ròᎭlac;䅱aòᏃĀir㠓㠘sht;楾;쀀𝔲rave耻ù䃹š㠧㠱rĀlr㠬㠮»ॗ»ႃlk;斀Āct㠹㡍ɯ㠿\0\0㡊rnĀ;e㡅㡆挜r»㡆op;挏ri;旸Āal㡖㡚cr;䅫肻¨͉Āgp㡢㡦on;䅳f;쀀𝕦̀adhlsuᅋ㡸㡽፲㢑㢠ownáᎳarpoonĀlr㢈㢌efô㠭ighô㠯iƀ;hl㢙㢚㢜䏅»ᏺon»㢚parrows;懈ƀcit㢰㣄㣈ɯ㢶\0\0㣁rnĀ;e㢼㢽挝r»㢽op;挎ng;䅯ri;旹cr;쀀𝓊ƀdir㣙㣝㣢ot;拰lde;䅩iĀ;f㜰㣨»᠓Āam㣯㣲rò㢨l耻ü䃼angle;榧ހABDacdeflnoprsz㤜㤟㤩㤭㦵㦸㦽㧟㧤㧨㧳㧹㧽㨁㨠ròϷarĀ;v㤦㤧櫨;櫩asèϡĀnr㤲㤷grt;榜΀eknprst㓣㥆㥋㥒㥝㥤㦖appá␕othinçẖƀhir㓫⻈㥙opô⾵Ā;hᎷ㥢ïㆍĀiu㥩㥭gmá㎳Ābp㥲㦄setneqĀ;q㥽㦀쀀⊊︀;쀀⫋︀setneqĀ;q㦏㦒쀀⊋︀;쀀⫌︀Āhr㦛㦟etá㚜iangleĀlr㦪㦯eft»थight»ၑy;䐲ash»ံƀelr㧄㧒㧗ƀ;beⷪ㧋㧏ar;抻q;扚lip;拮Ābt㧜ᑨaòᑩr;쀀𝔳tré㦮suĀbp㧯㧱»ജ»൙pf;쀀𝕧roð໻tré㦴Ācu㨆㨋r;쀀𝓋Ābp㨐㨘nĀEe㦀㨖»㥾nĀEe㦒㨞»㦐igzag;榚΀cefoprs㨶㨻㩖㩛㩔㩡㩪irc;䅵Ādi㩀㩑Ābg㩅㩉ar;機eĀ;qᗺ㩏;扙erp;愘r;쀀𝔴pf;쀀𝕨Ā;eᑹ㩦atèᑹcr;쀀𝓌ૣណ㪇\0㪋\0㪐㪛\0\0㪝㪨㪫㪯\0\0㫃㫎\0㫘ៜ៟tré៑r;쀀𝔵ĀAa㪔㪗ròσrò৶;䎾ĀAa㪡㪤ròθrò৫að✓is;拻ƀdptឤ㪵㪾Āfl㪺ឩ;쀀𝕩imåឲĀAa㫇㫊ròώròਁĀcq㫒ីr;쀀𝓍Āpt៖㫜ré។Ѐacefiosu㫰㫽㬈㬌㬑㬕㬛㬡cĀuy㫶㫻te耻ý䃽;䑏Āiy㬂㬆rc;䅷;䑋n耻¥䂥r;쀀𝔶cy;䑗pf;쀀𝕪cr;쀀𝓎Ācm㬦㬩y;䑎l耻ÿ䃿Ԁacdefhiosw㭂㭈㭔㭘㭤㭩㭭㭴㭺㮀cute;䅺Āay㭍㭒ron;䅾;䐷ot;䅼Āet㭝㭡træᕟa;䎶r;쀀𝔷cy;䐶grarr;懝pf;쀀𝕫cr;쀀𝓏Ājn㮅㮇;怍j;怌".split("").map((c) => c.charCodeAt(0)));
330
- //#endregion
331
- //#region ../../node_modules/.pnpm/entities@4.5.0/node_modules/entities/lib/esm/generated/decode-data-xml.js
332
- var decode_data_xml_default = new Uint16Array("Ȁaglq \x1Bɭ\0\0p;䀦os;䀧t;䀾t;䀼uot;䀢".split("").map((c) => c.charCodeAt(0)));
333
- //#endregion
334
- //#region ../../node_modules/.pnpm/entities@4.5.0/node_modules/entities/lib/esm/decode_codepoint.js
335
- var _a;
328
+ //#region ../../node_modules/.pnpm/entities@8.0.0/node_modules/entities/dist/decode-codepoint.js
336
329
  const decodeMap = new Map([
337
330
  [0, 65533],
338
331
  [128, 8364],
@@ -364,30 +357,58 @@ const decodeMap = new Map([
364
357
  [159, 376]
365
358
  ]);
366
359
  /**
367
- * Polyfill for `String.fromCodePoint`. It is used to create a string from a Unicode code point.
368
- */
369
- const fromCodePoint = (_a = String.fromCodePoint) !== null && _a !== void 0 ? _a : function(codePoint) {
370
- let output = "";
371
- if (codePoint > 65535) {
372
- codePoint -= 65536;
373
- output += String.fromCharCode(codePoint >>> 10 & 1023 | 55296);
374
- codePoint = 56320 | codePoint & 1023;
375
- }
376
- output += String.fromCharCode(codePoint);
377
- return output;
378
- };
379
- /**
380
360
  * Replace the given code point with a replacement character if it is a
381
361
  * surrogate or is outside the valid range. Otherwise return the code
382
362
  * point unchanged.
363
+ * @param codePoint Unicode code point to convert.
383
364
  */
384
365
  function replaceCodePoint(codePoint) {
385
- var _a;
386
366
  if (codePoint >= 55296 && codePoint <= 57343 || codePoint > 1114111) return 65533;
387
- return (_a = decodeMap.get(codePoint)) !== null && _a !== void 0 ? _a : codePoint;
367
+ return decodeMap.get(codePoint) ?? codePoint;
388
368
  }
389
369
  //#endregion
390
- //#region ../../node_modules/.pnpm/entities@4.5.0/node_modules/entities/lib/esm/decode.js
370
+ //#region ../../node_modules/.pnpm/entities@8.0.0/node_modules/entities/dist/internal/decode-shared.js
371
+ /**
372
+ * Shared base64 decode helper for generated decode data.
373
+ * Assumes global atob is available.
374
+ * @param input Input string to encode or decode.
375
+ */
376
+ function decodeBase64(input) {
377
+ const binary = atob(input);
378
+ const evenLength = binary.length & -2;
379
+ const out = new Uint16Array(evenLength / 2);
380
+ for (let index = 0, outIndex = 0; index < evenLength; index += 2) {
381
+ const lo = binary.charCodeAt(index);
382
+ const hi = binary.charCodeAt(index + 1);
383
+ out[outIndex++] = lo | hi << 8;
384
+ }
385
+ return out;
386
+ }
387
+ //#endregion
388
+ //#region ../../node_modules/.pnpm/entities@8.0.0/node_modules/entities/dist/generated/decode-data-html.js
389
+ /** Packed HTML decode trie data. */
390
+ const htmlDecodeTree = /* @__PURE__ */ decodeBase64("QR08ALkAAgH6AYsDNQR2BO0EPgXZBQEGLAbdBxMISQrvCmQLfQurDKQNLw4fD4YPpA+6D/IPAAAAAAAAAAAAAAAAKhBMEY8TmxUWF2EYLBkxGuAa3RsJHDscWR8YIC8jSCSIJcMl6ie3Ku8rEC0CLjoupS7kLgAIRU1hYmNmZ2xtbm9wcnN0dVQAWgBeAGUAaQBzAHcAfgCBAIQAhwCSAJoAoACsALMAbABpAGcAO4DGAMZAUAA7gCYAJkBjAHUAdABlADuAwQDBQHIiZXZlAAJhAAFpeW0AcgByAGMAO4DCAMJAEGRyAADgNdgE3XIAYQB2AGUAO4DAAMBA8CFoYZFj4SFjcgBhZAAAoFMqAAFncIsAjgBvAG4ABGFmAADgNdg43fAlbHlGdW5jdGlvbgCgYSBpAG4AZwA7gMUAxUAAAWNzpACoAHIAAOA12Jzc6SFnbgCgVCJpAGwAZABlADuAwwDDQG0AbAA7gMQAxEAABGFjZWZvcnN1xQDYANoA7QDxAPYA+QD8AAABY3LJAM8AayNzbGFzaAAAoBYidgHTANUAAKDnKmUAZAAAoAYjeQARZIABY3J0AOAA5QDrAGEidXNlAACgNSLuI291bGxpcwCgLCFhAJJjcgAA4DXYBd1wAGYAAOA12Dnd5SF2ZdhiYwDyAOoAbSJwZXEAAKBOIgAHSE9hY2RlZmhpbG9yc3UXARoBHwE6AVIBVQFiAWQBZgGCAakB6QHtAfIBYwB5ACdkUABZADuAqQCpQIABY3B5ACUBKAE1AfUhdGUGYWmg0iJ0KGFsRGlmZmVyZW50aWFsRAAAoEUhbCJleXMAAKAtIQACYWVpb0EBRAFKAU0B8iFvbgxhZABpAGwAO4DHAMdAcgBjAAhhbiJpbnQAAKAwIm8AdAAKYQABZG5ZAV0BaSJsbGEAuGB0I2VyRG90ALdg8gA5AWkAp2NyImNsZQAAAkRNUFRwAXQBeQF9AW8AdAAAoJkiaSJudXMAAKCWIuwhdXMAoJUiaSJtZXMAAKCXIm8AAAFjc4cBlAFrKndpc2VDb250b3VySW50ZWdyYWwAAKAyImUjQ3VybHkAAAFEUZwBpAFvJXVibGVRdW90ZQAAoB0gdSJvdGUAAKAZIAACbG5wdbABtgHNAdgBbwBuAGWgNyIAoHQqgAFnaXQAvAHBAcUB8iJ1ZW50AKBhIm4AdAAAoC8i7yV1ckludGVncmFsAKAuIgABZnLRAdMBAKACIe8iZHVjdACgECJuLnRlckNsb2Nrd2lzZUNvbnRvdXJJbnRlZ3JhbAAAoDMi7yFzcwCgLypjAHIAAOA12J7ccABDoNMiYQBwAACgTSKABURKU1phY2VmaW9zAAsCEgIVAhgCGwIsAjQCOQI9AnMCfwNvoEUh9CJyYWhkAKARKWMAeQACZGMAeQAFZGMAeQAPZIABZ3JzACECJQIoAuchZXIAoCEgcgAAoKEhaAB2AACg5CoAAWF5MAIzAvIhb24OYRRkbAB0oAciYQCUY3IAAOA12AfdAAFhZkECawIAAWNtRQJnAvIjaXRpY2FsAAJBREdUUAJUAl8CYwJjInV0ZQC0YG8AdAFZAloC2WJiJGxlQWN1dGUA3WJyImF2ZQBgYGkibGRlANxi7yFuZACgxCJmJWVyZW50aWFsRAAAoEYhcAR9AgAAAAAAAIECjgIAABoDZgAA4DXYO91EoagAhQKJAm8AdAAAoNwgcSJ1YWwAAKBQIuIhbGUAA0NETFJVVpkCqAK1Au8C/wIRA28AbgB0AG8AdQByAEkAbgB0AGUAZwByAGEA7ADEAW8AdAKvAgAAAACwAqhgbiNBcnJvdwAAoNMhAAFlb7kC0AJmAHQAgAFBUlQAwQLGAs0CciJyb3cAAKDQIekkZ2h0QXJyb3cAoNQhZQDlACsCbgBnAAABTFLWAugC5SFmdAABQVLcAuECciJyb3cAAKD4J+kkZ2h0QXJyb3cAoPon6SRnaHRBcnJvdwCg+SdpImdodAAAAUFU9gL7AnIicm93AACg0iFlAGUAAKCoInAAQQIGAwAAAAALA3Iicm93AACg0SFvJHduQXJyb3cAAKDVIWUlcnRpY2FsQmFyAACgJSJuAAADQUJMUlRhJAM2AzoDWgNxA3oDciJyb3cAAKGTIUJVLAMwA2EAcgAAoBMpcCNBcnJvdwAAoPUhciJldmUAEWPlIWZ00gJDAwAASwMAAFIDaSVnaHRWZWN0b3IAAKBQKWUkZVZlY3RvcgAAoF4p5SJjdG9yQqC9IWEAcgAAoFYpaSJnaHQA1AFiAwAAaQNlJGVWZWN0b3IAAKBfKeUiY3RvckKgwSFhAHIAAKBXKWUAZQBBoKQiciJyb3cAAKCnIXIAcgBvAPcAtAIAAWN0gwOHA3IA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YwAAoN8i4SFycnCgtiEAoD0pgKIqImJjZG9zACsVMBU6FT4VQRVyImNhcAAAoEgqAAFhdTQVNxVwAACgRipwAACgSipvAHQAAKCNInIAAKBFKgDgKiIA/gACYWxydksVURVuFXMVcgByAG2gtyEAoDwpeQCAAWV2dwBYFWUVaRVxAHACXxUAAAAAYxVyAGUA4wAXFXUA4wAZFWUAZQAAoM4iZSJkZ2UAAKDPImUAbgA7gKQApEBlI2Fycm93AAABbHJ7FX8V5SFmdACgtiFpImdodAAAoLchZQDkAG0VAAFjaYsVkRVvAG4AaQBuAPQAkwFuAHQAAKAxImwiY3R5AACgLSOACUFIYWJjZGVmaGlqbG9yc3R1d3oAuBW7Fb8V1RXgFegV+RUKFhUWHxZUFlcWZRbFFtsW7xb7FgUXChdyAPIAtAJhAHIAAKBlKQACZ2xyc8YVyhXOFdAV5yFlcgCgICDlIXRoAKA4IfIA9QxoAHagECAAoKMiawHZFd4VYSJyb3cAAKAPKWEA4wBfAgABYXnkFecV8iFvbg9hNGQAoUYhYW/tFfQVAAFnciEC8RVyAACgyiF0InNlcQAAoHcqgAFnbG0A/xUCFgUWO4CwALBAdABhALRjcCJ0eXYAAKCxKQABaXIOFhIW8yFodACgfykA4DXYId1hAHIAAAFschsWHRYAoMMhAKDCIYACYWVnc3YAKBauAjYWOhY+Fm0AAKHEIm9zLhY0Fm4AZABzoMQi9SFpdACgZiZhIm1tYQDdY2kAbgAAoPIiAKH3AGlvQxZRFmQAZQAAgfcAO29KFksW90BuI3RpbWVzAACgxyJuAPgAUBZjAHkAUmRjAG8CXhYAAAAAYhZyAG4AAKAeI28AcAAAoA0jgAJscHR1dwBuFnEWdRaSFp4W7CFhciRgZgAA4DXYVd0AotkCZW1wc30WhBaJFo0WcQBkoFAibwB0AACgUSJpIm51cwAAoDgi7CF1cwCgFCLxInVhcmUAoKEiYgBsAGUAYgBhAHIAdwBlAGQAZwDlANcAbgCAAWFkaAClFqoWtBZyAHIAbwD3APUMbwB3AG4AYQByAHIAbwB3APMA8xVhI3Jwb29uAAABbHK8FsAWZQBmAPQAHBZpAGcAaAD0AB4WYgHJFs8WawBhAHIAbwD3AJILbwLUFgAAAADYFnIAbgAAoB8jbwBwAACgDCOAAWNvdADhFukW7BYAAXJ55RboFgDgNdi53FVkbAAAoPYp8iFvaxFhAAFkcvMW9xZvAHQAAKDxImkA5qC/JVsSAAFhaP8WAhdyAPIANQNhAPIA1wvhIm5nbGUAoKYpAAFjaQ4XEBd5AF9k5yJyYXJyAKD/JwAJRGFjZGVmZ2xtbm9wcXJzdHV4MRc4F0YXWxcyBF4XaRd5F40XrBe0F78X2RcVGCEYLRg1GEAYAAFEbzUXgRZvAPQA+BUAAWNzPBdCF3UAdABlADuA6QDpQPQhZXIAoG4qAAJhaW95TRdQF1YXWhfyIW9uG2FyAGOgViI7gOoA6kDsIW9uAKBVIk1kbwB0ABdhAAFEcmIXZhdvAHQAAKBSIgDgNdgi3XKhmipuF3QXYQB2AGUAO4DoAOhAZKCWKm8AdAAAoJgqgKGZKmlscwCAF4UXhxfuInRlcnMAoOcjAKATIWSglSpvAHQAAKCXKoABYXBzAJMXlheiF2MAcgATYXQAeQBzogUinxcAAAAAoRdlAHQAAKAFInAAMaADIDMBqRerFwCgBCAAoAUgAAFnc7AXsRdLYXAAAKACIAABZ3C4F7sXbwBuABlhZgAA4DXYVt2AAWFscwDFF8sXzxdyAHOg1SJsAACg4yl1AHMAAKBxKmkAAKG1A2x21RfYF28AbgC1Y/VjAAJjc3V24BfoF/0XEBgAAWlv5BdWF3IAYwAAoFYiaQLuFwAAAADwF+0ADQThIW50AAFnbPUX+Rd0AHIAAKCWKuUhc3MAoJUqgAFhZWkAAxgGGAoYbABzAD1gcwB0AACgXyJ2AESgYSJEAACgeCrwImFyc2wAoOUpAAFEYRkYHRhvAHQAAKBTInIAcgAAoHEpgAFjZGkAJxgqGO0XcgAAoC8hbwD0AIwCAAFhaDEYMhi3YzuA8ADwQAABbXI5GD0YbAA7gOsA60BvAACgrCCAAWNpcABGGEgYSxhsACFgcwD0ACwEAAFlb08YVxhjAHQAYQB0AGkAbwDuABoEbgBlAG4AdABpAGEAbADlADME4Ql1GAAAgRgAAIMYiBgAAAAAoRilGAAAqhgAALsYvhjRGAAA1xgnGWwAbABpAG4AZwBkAG8AdABzAGUA8QBlF3kARGRtImFsZQAAoEAmgAFpbHIAjRiRGJ0Y7CFpZwCgA/tpApcYAAAAAJoYZwAAoAD7aQBnAACgBPsA4DXYI93sIWlnAKAB++whaWcA4GYAagCAAWFsdACvGLIYthh0AACgbSZpAGcAAKAC+24AcwAAoLElbwBmAJJh8AHCGAAAxhhmAADgNdhX3QABYWvJGMwYbADsAGsEdqDUIgCg2SphI3J0aW50AACgDSoAAWFv2hgiGQABY3PeGB8ZsQPnGP0YBRkSGRUZAAAdGbID7xjyGPQY9xj5GAAA+xg7gL0AvUAAoFMhO4C8ALxAAKBVIQCgWSEAoFshswEBGQAAAxkAoFQhAKBWIbQCCxkOGQAAAAAQGTuAvgC+QACgVyEAoFwhNQAAoFghtgEZGQAAGxkAoFohAKBdITgAAKBeIWwAAKBEIHcAbgAAoCIjYwByAADgNdi73IAIRWFiY2RlZmdpamxub3JzdHYARhlKGVoZXhlmGWkZkhmWGZkZnRmgGa0ZxhnLGc8Z4BkjGmygZyIAoIwqgAFjbXAAUBlTGVgZ9SF0ZfVhbQBhAOSgswM6FgCghipyImV2ZQAfYQABaXliGWUZcgBjAB1hM2RvAHQAIWGAoWUibHFzAMYEcBl6GfGhZSLOBAAAdhlsAGEAbgD0AN8EgKF+KmNkbACBGYQZjBljAACgqSpvAHQAb6CAKmyggioAoIQqZeDbIgD+cwAAoJQqcgAA4DXYJN3noGsirATtIWVsAKA3IWMAeQBTZIChdyJFYWoApxmpGasZAKCSKgCgpSoAoKQqAAJFYWVztBm2Gb0ZwhkAoGkicABwoIoq8iFveACgiipxoIgq8aCIKrUZaQBtAACg5yJwAGYAAOA12FjdYQB2AOUAYwIAAWNp0xnWGXIAAKAKIW0AAKFzImVs3BneGQCgjioAoJAqAIM+ADtjZGxxco0E6xn0GfgZ/BkBGgABY2nvGfEZAKCnKnIAAKB6Km8AdAAAoNci0CFhcgCglSl1ImVzdAAAoHwqgAJhZGVscwAKGvQZFhrVBCAa8AEPGgAAFBpwAHIAbwD4AFkZcgAAoHgpcQAAAWxxxAQbGmwAZQBzAPMASRlpAO0A5AQAAWVuJxouGnIjdG5lcXEAAOBpIgD+xQAsGgAFQWFiY2Vma29zeUAaQxpmGmoabRqDGocalhrCGtMacgDyAMwCAAJpbG1yShpOGlAaVBpyAHMA8ABxD2YAvWBpAGwA9AASBQABZHJYGlsaYwB5AEpkAKGUIWN3YBpkGmkAcgAAoEgpAKCtIWEAcgAAoA8h6SFyYyVhgAFhbHIAcxp7Gn8a8iF0c3WgZSZpAHQAAKBlJuwhaXAAoCYg4yFvbgCguSJyAADgNdgl3XMAAAFld4wakRphInJvdwAAoCUpYSJyb3cAAKAmKYACYW1vcHIAnxqjGqcauhq+GnIAcgAAoP8h9CFodACgOyJrAAABbHKsGrMaZSRmdGFycm93AACgqSHpJGdodGFycm93AKCqIWYAAOA12Fnd4iFhcgCgFSCAAWNsdADIGswa0BpyAADgNdi93GEAcwDoAGka8iFvaydhAAFicNca2xr1IWxsAKBDIOghZW4AoBAg4Qr2GgAA/RoAAAgbExsaGwAAIRs7GwAAAAA+G2IbmRuVG6sbAACyG80b0htjAHUAdABlADuA7QDtQAChYyBpeQEbBhtyAGMAO4DuAO5AOGQAAWN4CxsNG3kANWRjAGwAO4ChAKFAAAFmcssCFhsA4DXYJt1yAGEAdgBlADuA7ADsQIChSCFpbm8AJxsyGzYbAAFpbisbLxtuAHQAAKAMKnQAAKAtIuYhaW4AoNwpdABhAACgKSHsIWlnM2GAAWFvcABDG1sbXhuAAWNndABJG0sbWRtyACthgAFlbHAAcQVRG1UbaQBuAOUAyAVhAHIA9AByBWgAMWFmAACgtyJlAGQAtWEAoggiY2ZvdGkbbRt1G3kb4SFyZQCgBSFpAG4AdKAeImkAZQAAoN0pZABvAPQAWxsAoisiY2VscIEbhRuPG5QbYQBsAACguiIAAWdyiRuNG2UAcgDzACMQ4wCCG2EicmhrAACgFyryIW9kAKA8KgACY2dwdJ8boRukG6gbeQBRZG8AbgAvYWYAAOA12FrdYQC5Y3UAZQBzAHQAO4C/AL9AAAFjabUbuRtyAADgNdi+3G4AAKIIIkVkc3bCG8QbyBvQAwCg+SJvAHQAAKD1Inag9CIAoPMiaaBiIOwhZGUpYesB1hsAANkbYwB5AFZkbAA7gO8A70AAA2NmbW9zdeYb7hvyG/Ub+hsFHAABaXnqG+0bcgBjADVhOWRyAADgNdgn3eEhdGg3YnAAZgAA4DXYW93jAf8bAAADHHIAAOA12L/c8iFjeVhk6yFjeVRkAARhY2ZnaGpvcxUcGhwiHCYcKhwtHDAcNRzwIXBhdqC6A/BjAAFleR4cIRzkIWls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ZmdobG1vcHJzdHV3CiwNLBEsHSwnLDEsQCxLLFIsYix6LIQsjyzLLOgs7Sz/LAotcgDyAAkDYQByAACgYykAAWNyFSwbLHUAdABlADuA+gD6QPIACQ1yAOMBIywAACUseQBeZHYAZQBtYQABaXkrLDAscgBjADuA+wD7QENkgAFhYmgANyw6LD0scgDyANEO7CFhY3FhYQDyAOAOAAFpckQsSCzzIWh0AKB+KQDgNdgy3XIAYQB2AGUAO4D5APlAYQFWLF8scgAAAWxyWixcLACgvyEAoL4hbABrAACggCUAAWN0Zix2LG8CbCwAAAAAcyxyAG4AZaAcI3IAAKAcI28AcAAAoA8jcgBpAACg+CUAAWFsfiyBLGMAcgBrYTuAqACoQAABZ3CILIssbwBuAHNhZgAA4DXYZt0AA2FkaGxzdZksniynLLgsuyzFLHIAcgBvAPcACQ1vAHcAbgBhAHIAcgBvAPcA2A5hI3Jwb29uAAABbHKvLLMsZQBmAPQAWyxpAGcAaAD0AF0sdQDzAKYOaQAAocUDaGzBLMIs0mNvAG4AxWPwI2Fycm93cwCgyCGAAWNpdADRLOEs5CxvAtcsAAAAAN4scgBuAGWgHSNyAACgHSNvAHAAAKAOI24AZwBvYXIAaQAAoPklYwByAADgNdjK3IABZGlyAPMs9yz6LG8AdAAAoPAi7CFkZWlhaQBmoLUlAKC0JQABYW0DLQYtcgDyAMosbAA7gPwA/EDhIm5nbGUAoKcpgAdBQkRhY2RlZmxub3Byc3oAJy0qLTAtNC2bLZ0toS2/LcMtxy3TLdgt3C3gLfwtcgDyABADYQByAHag6CoAoOkqYQBzAOgA/gIAAW5yOC08LechcnQAoJwpgANla25wcnN0AJkpSC1NLVQtXi1iLYItYQBwAHAA4QAaHG8AdABoAGkAbgDnAKEXgAFoaXIAoSmzJFotbwBwAPQAdCVooJUh7wD4JgABaXVmLWotZwBtAOEAuygAAWJwbi14LXMjZXRuZXEAceCKIgD+AODLKgD+cyNldG5lcQBx4IsiAP4A4MwqAP4AAWhyhi2KLWUAdADhABIraSNhbmdsZQAAAWxyki2WLeUhZnQAoLIiaSJnaHQAAKCzInkAMmThIXNoAKCiIoABZWxyAKcttC24LWKiKCKuLQAAAACyLWEAcgAAoLsicQAAoFoi7CFpcACg7iIAAWJ0vC1eD2EA8gBfD3IAAOA12DPddAByAOkAlS1zAHUAAAFicM0t0C0A4IIi0iAA4IMi0iBwAGYAAOA12GfdcgBvAPAAWQt0AHIA6QCaLQABY3XkLegtcgAA4DXYy9wAAWJw7C30LW4AAAFFZXUt8S0A4IoiAP5uAAABRWV/LfktAOCLIgD+6SJnemFnAKCaKYADY2Vmb3BycwANLhAuJS4pLiMuLi40LukhcmN1YQABZGkULiEuAAFiZxguHC5hAHIAAKBfKmUAcaAnIgCgWSLlIXJwAKAYIXIAAOA12DTdcABmAADgNdho3WWgQCJhAHQA6ABqD2MAcgAA4DXYzNzjCuQRUC4AAFQuAABYLmIuAAAAAGMubS5wLnQuAAAAAIguki4AAJouJxIqEnQAcgDpAB0ScgAA4DXYNd0AAUFhWy5eLnIA8gDnAnIA8gCTB75jAAFBYWYuaS5yAPIA4AJyAPIAjAdhAPAAeh5pAHMAAKD7IoABZHB0APgReS6DLgABZmx9LoAuAOA12GnddQDzAP8RaQBtAOUABBIAAUFhiy6OLnIA8gDuAnIA8gCaBwABY3GVLgoScgAA4DXYzdwAAXB0nS6hLmwAdQDzACUScgDpACASAARhY2VmaW9zdbEuvC7ELsguzC7PLtQu2S5jAAABdXm2LrsudABlADuA/QD9QE9kAAFpecAuwy5yAGMAd2FLZG4AO4ClAKVAcgAA4DXYNt1jAHkAV2RwAGYAAOA12GrdYwByAADgNdjO3AABY23dLt8ueQBOZGwAO4D/AP9AAAVhY2RlZmhpb3N38y73Lv8uAi8MLxAvEy8YLx0vIi9jInV0ZQB6YQABYXn7Lv4u8iFvbn5hN2RvAHQAfGEAAWV0Bi8KL3QAcgDmAB8QYQC2Y3IAAOA12DfdYwB5ADZk5yJyYXJyAKDdIXAAZgAA4DXYa91jAHIAAOA12M/cAAFqbiYvKC8AoA0gagAAoAwg");
391
+ //#endregion
392
+ //#region ../../node_modules/.pnpm/entities@8.0.0/node_modules/entities/dist/internal/bin-trie-flags.js
393
+ /**
394
+ * Bit flags & masks for the binary trie encoding used for entity decoding.
395
+ *
396
+ * Bit layout (16 bits total):
397
+ * 15..14 VALUE_LENGTH (+1 encoding; 0 => no value)
398
+ * 13 FLAG13. If valueLength>0: semicolon required flag (implicit ';').
399
+ * If valueLength==0: compact run flag.
400
+ * 12..7 BRANCH_LENGTH Branch length (0 => single branch in 6..0 if jumpOffset==char) OR run length (when compact run)
401
+ * 6..0 JUMP_TABLE Jump offset (jump table) OR single-branch char code OR first run char
402
+ */
403
+ var BinTrieFlags;
404
+ (function(BinTrieFlags) {
405
+ BinTrieFlags[BinTrieFlags["VALUE_LENGTH"] = 49152] = "VALUE_LENGTH";
406
+ BinTrieFlags[BinTrieFlags["FLAG13"] = 8192] = "FLAG13";
407
+ BinTrieFlags[BinTrieFlags["BRANCH_LENGTH"] = 8064] = "BRANCH_LENGTH";
408
+ BinTrieFlags[BinTrieFlags["JUMP_TABLE"] = 127] = "JUMP_TABLE";
409
+ })(BinTrieFlags || (BinTrieFlags = {}));
410
+ //#endregion
411
+ //#region ../../node_modules/.pnpm/entities@8.0.0/node_modules/entities/dist/decode.js
391
412
  var CharCodes;
392
413
  (function(CharCodes) {
393
414
  CharCodes[CharCodes["NUM"] = 35] = "NUM";
@@ -405,12 +426,6 @@ var CharCodes;
405
426
  })(CharCodes || (CharCodes = {}));
406
427
  /** Bit that needs to be set to convert an upper case ASCII character to lower case */
407
428
  const TO_LOWER_BIT = 32;
408
- var BinTrieFlags;
409
- (function(BinTrieFlags) {
410
- BinTrieFlags[BinTrieFlags["VALUE_LENGTH"] = 49152] = "VALUE_LENGTH";
411
- BinTrieFlags[BinTrieFlags["BRANCH_LENGTH"] = 16256] = "BRANCH_LENGTH";
412
- BinTrieFlags[BinTrieFlags["JUMP_TABLE"] = 127] = "JUMP_TABLE";
413
- })(BinTrieFlags || (BinTrieFlags = {}));
414
429
  function isNumber(code) {
415
430
  return code >= CharCodes.ZERO && code <= CharCodes.NINE;
416
431
  }
@@ -425,6 +440,7 @@ function isAsciiAlphaNumeric$1(code) {
425
440
  *
426
441
  * Attribute values that aren't terminated properly aren't parsed, and shouldn't lead to a parser error.
427
442
  * See the example in https://html.spec.whatwg.org/multipage/parsing.html#named-character-reference-state
443
+ * @param code Code point to decode.
428
444
  */
429
445
  function isEntityInAttributeInvalidEnd(code) {
430
446
  return code === CharCodes.EQUALS || isAsciiAlphaNumeric$1(code);
@@ -437,6 +453,9 @@ var EntityDecoderState;
437
453
  EntityDecoderState[EntityDecoderState["NumericHex"] = 3] = "NumericHex";
438
454
  EntityDecoderState[EntityDecoderState["NamedEntity"] = 4] = "NamedEntity";
439
455
  })(EntityDecoderState || (EntityDecoderState = {}));
456
+ /**
457
+ * Decoding mode for named entities.
458
+ */
440
459
  var DecodingMode;
441
460
  (function(DecodingMode) {
442
461
  /** Entities in text nodes that can end with any character. */
@@ -450,29 +469,37 @@ var DecodingMode;
450
469
  * Token decoder with support of writing partial entities.
451
470
  */
452
471
  var EntityDecoder = class {
472
+ decodeTree;
473
+ emitCodePoint;
474
+ errors;
453
475
  constructor(decodeTree, emitCodePoint, errors) {
454
476
  this.decodeTree = decodeTree;
455
477
  this.emitCodePoint = emitCodePoint;
456
478
  this.errors = errors;
457
- /** The current state of the decoder. */
458
- this.state = EntityDecoderState.EntityStart;
459
- /** Characters that were consumed while parsing an entity. */
460
- this.consumed = 1;
461
- /**
462
- * The result of the entity.
463
- *
464
- * Either the result index of a numeric entity, or the codepoint of a
465
- * numeric entity.
466
- */
467
- this.result = 0;
468
- /** The current index in the decode tree. */
469
- this.treeIndex = 0;
470
- /** The number of characters that were consumed in excess. */
471
- this.excess = 1;
472
- /** The mode in which the decoder is operating. */
473
- this.decodeMode = DecodingMode.Strict;
474
479
  }
475
- /** Resets the instance to make it reusable. */
480
+ /** The current state of the decoder. */
481
+ state = EntityDecoderState.EntityStart;
482
+ /** Characters that were consumed while parsing an entity. */
483
+ consumed = 1;
484
+ /**
485
+ * The result of the entity.
486
+ *
487
+ * Either the result index of a numeric entity, or the codepoint of a
488
+ * numeric entity.
489
+ */
490
+ result = 0;
491
+ /** The current index in the decode tree. */
492
+ treeIndex = 0;
493
+ /** The number of characters that were consumed in excess. */
494
+ excess = 1;
495
+ /** The mode in which the decoder is operating. */
496
+ decodeMode = DecodingMode.Strict;
497
+ /** The number of characters that have been consumed in the current run. */
498
+ runConsumed = 0;
499
+ /**
500
+ * Resets the instance to make it reusable.
501
+ * @param decodeMode Entity decoding mode to use.
502
+ */
476
503
  startEntity(decodeMode) {
477
504
  this.decodeMode = decodeMode;
478
505
  this.state = EntityDecoderState.EntityStart;
@@ -480,6 +507,7 @@ var EntityDecoder = class {
480
507
  this.treeIndex = 0;
481
508
  this.excess = 1;
482
509
  this.consumed = 1;
510
+ this.runConsumed = 0;
483
511
  }
484
512
  /**
485
513
  * Write an entity to the decoder. This can be called multiple times with partial entities.
@@ -487,95 +515,81 @@ var EntityDecoder = class {
487
515
  *
488
516
  * Mirrors the implementation of `getDecoder`, but with the ability to stop decoding if the
489
517
  * entity is incomplete, and resume when the next string is written.
490
- *
491
- * @param string The string containing the entity (or a continuation of the entity).
518
+ * @param input The string containing the entity (or a continuation of the entity).
492
519
  * @param offset The offset at which the entity begins. Should be 0 if this is not the first call.
493
520
  * @returns The number of characters that were consumed, or -1 if the entity is incomplete.
494
521
  */
495
- write(str, offset) {
522
+ write(input, offset) {
496
523
  switch (this.state) {
497
524
  case EntityDecoderState.EntityStart:
498
- if (str.charCodeAt(offset) === CharCodes.NUM) {
525
+ if (input.charCodeAt(offset) === CharCodes.NUM) {
499
526
  this.state = EntityDecoderState.NumericStart;
500
527
  this.consumed += 1;
501
- return this.stateNumericStart(str, offset + 1);
528
+ return this.stateNumericStart(input, offset + 1);
502
529
  }
503
530
  this.state = EntityDecoderState.NamedEntity;
504
- return this.stateNamedEntity(str, offset);
505
- case EntityDecoderState.NumericStart: return this.stateNumericStart(str, offset);
506
- case EntityDecoderState.NumericDecimal: return this.stateNumericDecimal(str, offset);
507
- case EntityDecoderState.NumericHex: return this.stateNumericHex(str, offset);
508
- case EntityDecoderState.NamedEntity: return this.stateNamedEntity(str, offset);
531
+ return this.stateNamedEntity(input, offset);
532
+ case EntityDecoderState.NumericStart: return this.stateNumericStart(input, offset);
533
+ case EntityDecoderState.NumericDecimal: return this.stateNumericDecimal(input, offset);
534
+ case EntityDecoderState.NumericHex: return this.stateNumericHex(input, offset);
535
+ case EntityDecoderState.NamedEntity: return this.stateNamedEntity(input, offset);
509
536
  }
510
537
  }
511
538
  /**
512
539
  * Switches between the numeric decimal and hexadecimal states.
513
540
  *
514
541
  * Equivalent to the `Numeric character reference state` in the HTML spec.
515
- *
516
- * @param str The string containing the entity (or a continuation of the entity).
542
+ * @param input The string containing the entity (or a continuation of the entity).
517
543
  * @param offset The current offset.
518
544
  * @returns The number of characters that were consumed, or -1 if the entity is incomplete.
519
545
  */
520
- stateNumericStart(str, offset) {
521
- if (offset >= str.length) return -1;
522
- if ((str.charCodeAt(offset) | TO_LOWER_BIT) === CharCodes.LOWER_X) {
546
+ stateNumericStart(input, offset) {
547
+ if (offset >= input.length) return -1;
548
+ if ((input.charCodeAt(offset) | TO_LOWER_BIT) === CharCodes.LOWER_X) {
523
549
  this.state = EntityDecoderState.NumericHex;
524
550
  this.consumed += 1;
525
- return this.stateNumericHex(str, offset + 1);
551
+ return this.stateNumericHex(input, offset + 1);
526
552
  }
527
553
  this.state = EntityDecoderState.NumericDecimal;
528
- return this.stateNumericDecimal(str, offset);
529
- }
530
- addToNumericResult(str, start, end, base) {
531
- if (start !== end) {
532
- const digitCount = end - start;
533
- this.result = this.result * Math.pow(base, digitCount) + parseInt(str.substr(start, digitCount), base);
534
- this.consumed += digitCount;
535
- }
554
+ return this.stateNumericDecimal(input, offset);
536
555
  }
537
556
  /**
538
557
  * Parses a hexadecimal numeric entity.
539
558
  *
540
559
  * Equivalent to the `Hexademical character reference state` in the HTML spec.
541
- *
542
- * @param str The string containing the entity (or a continuation of the entity).
560
+ * @param input The string containing the entity (or a continuation of the entity).
543
561
  * @param offset The current offset.
544
562
  * @returns The number of characters that were consumed, or -1 if the entity is incomplete.
545
563
  */
546
- stateNumericHex(str, offset) {
547
- const startIdx = offset;
548
- while (offset < str.length) {
549
- const char = str.charCodeAt(offset);
550
- if (isNumber(char) || isHexadecimalCharacter(char)) offset += 1;
551
- else {
552
- this.addToNumericResult(str, startIdx, offset, 16);
553
- return this.emitNumericEntity(char, 3);
554
- }
564
+ stateNumericHex(input, offset) {
565
+ while (offset < input.length) {
566
+ const char = input.charCodeAt(offset);
567
+ if (isNumber(char) || isHexadecimalCharacter(char)) {
568
+ const digit = char <= CharCodes.NINE ? char - CharCodes.ZERO : (char | TO_LOWER_BIT) - CharCodes.LOWER_A + 10;
569
+ this.result = this.result * 16 + digit;
570
+ this.consumed++;
571
+ offset++;
572
+ } else return this.emitNumericEntity(char, 3);
555
573
  }
556
- this.addToNumericResult(str, startIdx, offset, 16);
557
574
  return -1;
558
575
  }
559
576
  /**
560
577
  * Parses a decimal numeric entity.
561
578
  *
562
579
  * Equivalent to the `Decimal character reference state` in the HTML spec.
563
- *
564
- * @param str The string containing the entity (or a continuation of the entity).
580
+ * @param input The string containing the entity (or a continuation of the entity).
565
581
  * @param offset The current offset.
566
582
  * @returns The number of characters that were consumed, or -1 if the entity is incomplete.
567
583
  */
568
- stateNumericDecimal(str, offset) {
569
- const startIdx = offset;
570
- while (offset < str.length) {
571
- const char = str.charCodeAt(offset);
572
- if (isNumber(char)) offset += 1;
573
- else {
574
- this.addToNumericResult(str, startIdx, offset, 10);
575
- return this.emitNumericEntity(char, 2);
576
- }
584
+ stateNumericDecimal(input, offset) {
585
+ while (offset < input.length) {
586
+ const char = input.charCodeAt(offset);
587
+ if (isNumber(char)) {
588
+ this.result = this.result * 10 + (char - CharCodes.ZERO);
589
+ this.consumed++;
590
+ offset++;
591
+ } else return this.emitNumericEntity(char, 2);
577
592
  }
578
- this.addToNumericResult(str, startIdx, offset, 10);
579
593
  return -1;
580
594
  }
581
595
  /**
@@ -583,7 +597,6 @@ var EntityDecoder = class {
583
597
  *
584
598
  * Implements the logic from the `Hexademical character reference start
585
599
  * state` and `Numeric character reference end state` in the HTML spec.
586
- *
587
600
  * @param lastCp The last code point of the entity. Used to see if the
588
601
  * entity was terminated with a semicolon.
589
602
  * @param expectedLength The minimum number of characters that should be
@@ -592,9 +605,8 @@ var EntityDecoder = class {
592
605
  * @returns The number of characters that were consumed.
593
606
  */
594
607
  emitNumericEntity(lastCp, expectedLength) {
595
- var _a;
596
608
  if (this.consumed <= expectedLength) {
597
- (_a = this.errors) === null || _a === void 0 || _a.absenceOfDigitsInNumericCharacterReference(this.consumed);
609
+ this.errors?.absenceOfDigitsInNumericCharacterReference(this.consumed);
598
610
  return 0;
599
611
  }
600
612
  if (lastCp === CharCodes.SEMI) this.consumed += 1;
@@ -610,57 +622,83 @@ var EntityDecoder = class {
610
622
  * Parses a named entity.
611
623
  *
612
624
  * Equivalent to the `Named character reference state` in the HTML spec.
613
- *
614
- * @param str The string containing the entity (or a continuation of the entity).
625
+ * @param input The string containing the entity (or a continuation of the entity).
615
626
  * @param offset The current offset.
616
627
  * @returns The number of characters that were consumed, or -1 if the entity is incomplete.
617
628
  */
618
- stateNamedEntity(str, offset) {
629
+ stateNamedEntity(input, offset) {
619
630
  const { decodeTree } = this;
620
631
  let current = decodeTree[this.treeIndex];
621
632
  let valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;
622
- for (; offset < str.length; offset++, this.excess++) {
623
- const char = str.charCodeAt(offset);
633
+ while (offset < input.length) {
634
+ if (valueLength === 0 && (current & BinTrieFlags.FLAG13) !== 0) {
635
+ const runLength = (current & BinTrieFlags.BRANCH_LENGTH) >> 7;
636
+ if (this.runConsumed === 0) {
637
+ const firstChar = current & BinTrieFlags.JUMP_TABLE;
638
+ if (input.charCodeAt(offset) !== firstChar) return this.result === 0 ? 0 : this.emitNotTerminatedNamedEntity();
639
+ offset++;
640
+ this.excess++;
641
+ this.runConsumed++;
642
+ }
643
+ while (this.runConsumed < runLength) {
644
+ if (offset >= input.length) return -1;
645
+ const charIndexInPacked = this.runConsumed - 1;
646
+ const packedWord = decodeTree[this.treeIndex + 1 + (charIndexInPacked >> 1)];
647
+ const expectedChar = charIndexInPacked % 2 === 0 ? packedWord & 255 : packedWord >> 8 & 255;
648
+ if (input.charCodeAt(offset) !== expectedChar) {
649
+ this.runConsumed = 0;
650
+ return this.result === 0 ? 0 : this.emitNotTerminatedNamedEntity();
651
+ }
652
+ offset++;
653
+ this.excess++;
654
+ this.runConsumed++;
655
+ }
656
+ this.runConsumed = 0;
657
+ this.treeIndex += 1 + (runLength >> 1);
658
+ current = decodeTree[this.treeIndex];
659
+ valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;
660
+ }
661
+ if (offset >= input.length) break;
662
+ const char = input.charCodeAt(offset);
663
+ if (char === CharCodes.SEMI && valueLength !== 0 && (current & BinTrieFlags.FLAG13) !== 0) return this.emitNamedEntityData(this.treeIndex, valueLength, this.consumed + this.excess);
624
664
  this.treeIndex = determineBranch(decodeTree, current, this.treeIndex + Math.max(1, valueLength), char);
625
665
  if (this.treeIndex < 0) return this.result === 0 || this.decodeMode === DecodingMode.Attribute && (valueLength === 0 || isEntityInAttributeInvalidEnd(char)) ? 0 : this.emitNotTerminatedNamedEntity();
626
666
  current = decodeTree[this.treeIndex];
627
667
  valueLength = (current & BinTrieFlags.VALUE_LENGTH) >> 14;
628
668
  if (valueLength !== 0) {
629
669
  if (char === CharCodes.SEMI) return this.emitNamedEntityData(this.treeIndex, valueLength, this.consumed + this.excess);
630
- if (this.decodeMode !== DecodingMode.Strict) {
670
+ if (this.decodeMode !== DecodingMode.Strict && (current & BinTrieFlags.FLAG13) === 0) {
631
671
  this.result = this.treeIndex;
632
672
  this.consumed += this.excess;
633
673
  this.excess = 0;
634
674
  }
635
675
  }
676
+ offset++;
677
+ this.excess++;
636
678
  }
637
679
  return -1;
638
680
  }
639
681
  /**
640
682
  * Emit a named entity that was not terminated with a semicolon.
641
- *
642
683
  * @returns The number of characters consumed.
643
684
  */
644
685
  emitNotTerminatedNamedEntity() {
645
- var _a;
646
686
  const { result, decodeTree } = this;
647
687
  const valueLength = (decodeTree[result] & BinTrieFlags.VALUE_LENGTH) >> 14;
648
688
  this.emitNamedEntityData(result, valueLength, this.consumed);
649
- (_a = this.errors) === null || _a === void 0 || _a.missingSemicolonAfterCharacterReference();
689
+ this.errors?.missingSemicolonAfterCharacterReference();
650
690
  return this.consumed;
651
691
  }
652
692
  /**
653
693
  * Emit a named entity.
654
- *
655
694
  * @param result The index of the entity in the decode tree.
656
695
  * @param valueLength The number of bytes in the entity.
657
696
  * @param consumed The number of characters consumed.
658
- *
659
697
  * @returns The number of characters consumed.
660
698
  */
661
699
  emitNamedEntityData(result, valueLength, consumed) {
662
700
  const { decodeTree } = this;
663
- this.emitCodePoint(valueLength === 1 ? decodeTree[result] & ~BinTrieFlags.VALUE_LENGTH : decodeTree[result + 1], consumed);
701
+ this.emitCodePoint(valueLength === 1 ? decodeTree[result] & ~(BinTrieFlags.VALUE_LENGTH | BinTrieFlags.FLAG13) : decodeTree[result + 1], consumed);
664
702
  if (valueLength === 3) this.emitCodePoint(decodeTree[result + 2], consumed);
665
703
  return consumed;
666
704
  }
@@ -668,83 +706,51 @@ var EntityDecoder = class {
668
706
  * Signal to the parser that the end of the input was reached.
669
707
  *
670
708
  * Remaining data will be emitted and relevant errors will be produced.
671
- *
672
709
  * @returns The number of characters consumed.
673
710
  */
674
711
  end() {
675
- var _a;
676
712
  switch (this.state) {
677
713
  case EntityDecoderState.NamedEntity: return this.result !== 0 && (this.decodeMode !== DecodingMode.Attribute || this.result === this.treeIndex) ? this.emitNotTerminatedNamedEntity() : 0;
678
714
  case EntityDecoderState.NumericDecimal: return this.emitNumericEntity(0, 2);
679
715
  case EntityDecoderState.NumericHex: return this.emitNumericEntity(0, 3);
680
716
  case EntityDecoderState.NumericStart:
681
- (_a = this.errors) === null || _a === void 0 || _a.absenceOfDigitsInNumericCharacterReference(this.consumed);
717
+ this.errors?.absenceOfDigitsInNumericCharacterReference(this.consumed);
682
718
  return 0;
683
719
  case EntityDecoderState.EntityStart: return 0;
684
720
  }
685
721
  }
686
722
  };
687
723
  /**
688
- * Creates a function that decodes entities in a string.
689
- *
690
- * @param decodeTree The decode tree.
691
- * @returns A function that decodes entities in a string.
692
- */
693
- function getDecoder(decodeTree) {
694
- let ret = "";
695
- const decoder = new EntityDecoder(decodeTree, (str) => ret += fromCodePoint(str));
696
- return function decodeWithTrie(str, decodeMode) {
697
- let lastIndex = 0;
698
- let offset = 0;
699
- while ((offset = str.indexOf("&", offset)) >= 0) {
700
- ret += str.slice(lastIndex, offset);
701
- decoder.startEntity(decodeMode);
702
- const len = decoder.write(str, offset + 1);
703
- if (len < 0) {
704
- lastIndex = offset + decoder.end();
705
- break;
706
- }
707
- lastIndex = offset + len;
708
- offset = len === 0 ? lastIndex + 1 : lastIndex;
709
- }
710
- const result = ret + str.slice(lastIndex);
711
- ret = "";
712
- return result;
713
- };
714
- }
715
- /**
716
724
  * Determines the branch of the current node that is taken given the current
717
725
  * character. This function is used to traverse the trie.
718
- *
719
726
  * @param decodeTree The trie.
720
727
  * @param current The current node.
721
- * @param nodeIdx The index right after the current node and its value.
728
+ * @param nodeIndex Index immediately after the current node header.
722
729
  * @param char The current character.
723
730
  * @returns The index of the next node, or -1 if no branch is taken.
724
731
  */
725
- function determineBranch(decodeTree, current, nodeIdx, char) {
732
+ function determineBranch(decodeTree, current, nodeIndex, char) {
726
733
  const branchCount = (current & BinTrieFlags.BRANCH_LENGTH) >> 7;
727
734
  const jumpOffset = current & BinTrieFlags.JUMP_TABLE;
728
- if (branchCount === 0) return jumpOffset !== 0 && char === jumpOffset ? nodeIdx : -1;
735
+ if (branchCount === 0) return jumpOffset !== 0 && char === jumpOffset ? nodeIndex : -1;
729
736
  if (jumpOffset) {
730
737
  const value = char - jumpOffset;
731
- return value < 0 || value >= branchCount ? -1 : decodeTree[nodeIdx + value] - 1;
738
+ return value < 0 || value >= branchCount ? -1 : decodeTree[nodeIndex + value] - 1;
732
739
  }
733
- let lo = nodeIdx;
734
- let hi = lo + branchCount - 1;
740
+ const packedKeySlots = branchCount + 1 >> 1;
741
+ let lo = 0;
742
+ let hi = branchCount - 1;
735
743
  while (lo <= hi) {
736
744
  const mid = lo + hi >>> 1;
737
- const midVal = decodeTree[mid];
738
- if (midVal < char) lo = mid + 1;
739
- else if (midVal > char) hi = mid - 1;
740
- else return decodeTree[mid + branchCount];
745
+ const midKey = decodeTree[nodeIndex + (mid >> 1)] >> (mid & 1) * 8 & 255;
746
+ if (midKey < char) lo = mid + 1;
747
+ else if (midKey > char) hi = mid - 1;
748
+ else return decodeTree[nodeIndex + packedKeySlots + mid];
741
749
  }
742
750
  return -1;
743
751
  }
744
- getDecoder(decode_data_html_default);
745
- getDecoder(decode_data_xml_default);
746
752
  //#endregion
747
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/common/html.js
753
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/common/html.js
748
754
  /** All valid namespaces in HTML. */
749
755
  var NS;
750
756
  (function(NS) {
@@ -1284,7 +1290,7 @@ new Set([
1284
1290
  TAG_NAMES.PLAINTEXT
1285
1291
  ]);
1286
1292
  //#endregion
1287
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/tokenizer/index.js
1293
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/tokenizer/index.js
1288
1294
  var State;
1289
1295
  (function(State) {
1290
1296
  State[State["DATA"] = 0] = "DATA";
@@ -1429,7 +1435,7 @@ var Tokenizer = class {
1429
1435
  };
1430
1436
  this.preprocessor = new Preprocessor(handler);
1431
1437
  this.currentLocation = this.getCurrentLocation(-1);
1432
- this.entityDecoder = new EntityDecoder(decode_data_html_default, (cp, consumed) => {
1438
+ this.entityDecoder = new EntityDecoder(htmlDecodeTree, (cp, consumed) => {
1433
1439
  this.preprocessor.pos = this.entityStartPos + consumed - 1;
1434
1440
  this._flushCodePointConsumedAsCharacterReference(cp);
1435
1441
  }, handler.onParseError ? {
@@ -1670,7 +1676,7 @@ var Tokenizer = class {
1670
1676
  }
1671
1677
  _emitCodePoint(cp) {
1672
1678
  const type = isWhitespace(cp) ? TokenType.WHITESPACE_CHARACTER : cp === CODE_POINTS.NULL ? TokenType.NULL_CHARACTER : TokenType.CHARACTER;
1673
- this._appendCharToCurrentCharacterToken(type, String.fromCodePoint(cp));
1679
+ this._appendCharToCurrentCharacterToken(type, cp < 65536 ? String.fromCharCode(cp) : String.fromCodePoint(cp));
1674
1680
  }
1675
1681
  _emitChars(ch) {
1676
1682
  this._appendCharToCurrentCharacterToken(TokenType.CHARACTER, ch);
@@ -3342,7 +3348,7 @@ var Tokenizer = class {
3342
3348
  }
3343
3349
  };
3344
3350
  //#endregion
3345
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/parser/open-element-stack.js
3351
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/parser/open-element-stack.js
3346
3352
  const IMPLICIT_END_TAG_REQUIRED = new Set([
3347
3353
  TAG_ID.DD,
3348
3354
  TAG_ID.DT,
@@ -3465,14 +3471,14 @@ var OpenElementStack = class {
3465
3471
  this.tagIDs.splice(insertionIdx, 0, newElementID);
3466
3472
  this.stackTop++;
3467
3473
  if (insertionIdx === this.stackTop) this._updateCurrentElement();
3468
- this.handler.onItemPush(this.current, this.currentTagId, insertionIdx === this.stackTop);
3474
+ if (this.current && this.currentTagId !== void 0) this.handler.onItemPush(this.current, this.currentTagId, insertionIdx === this.stackTop);
3469
3475
  }
3470
3476
  popUntilTagNamePopped(tagName) {
3471
3477
  let targetIdx = this.stackTop + 1;
3472
3478
  do
3473
3479
  targetIdx = this.tagIDs.lastIndexOf(tagName, targetIdx - 1);
3474
3480
  while (targetIdx > 0 && this.treeAdapter.getNamespaceURI(this.items[targetIdx]) !== NS.HTML);
3475
- this.shortenToLength(targetIdx < 0 ? 0 : targetIdx);
3481
+ this.shortenToLength(Math.max(targetIdx, 0));
3476
3482
  }
3477
3483
  shortenToLength(idx) {
3478
3484
  while (this.stackTop >= idx) {
@@ -3485,11 +3491,11 @@ var OpenElementStack = class {
3485
3491
  }
3486
3492
  popUntilElementPopped(element) {
3487
3493
  const idx = this._indexOf(element);
3488
- this.shortenToLength(idx < 0 ? 0 : idx);
3494
+ this.shortenToLength(Math.max(idx, 0));
3489
3495
  }
3490
3496
  popUntilPopped(tagNames, targetNS) {
3491
3497
  const idx = this._indexOfTagNames(tagNames, targetNS);
3492
- this.shortenToLength(idx < 0 ? 0 : idx);
3498
+ this.shortenToLength(Math.max(idx, 0));
3493
3499
  }
3494
3500
  popUntilNumberedHeaderPopped() {
3495
3501
  this.popUntilPopped(NUMBERED_HEADERS, NS.HTML);
@@ -3624,17 +3630,17 @@ var OpenElementStack = class {
3624
3630
  return true;
3625
3631
  }
3626
3632
  generateImpliedEndTags() {
3627
- while (IMPLICIT_END_TAG_REQUIRED.has(this.currentTagId)) this.pop();
3633
+ while (this.currentTagId !== void 0 && IMPLICIT_END_TAG_REQUIRED.has(this.currentTagId)) this.pop();
3628
3634
  }
3629
3635
  generateImpliedEndTagsThoroughly() {
3630
- while (IMPLICIT_END_TAG_REQUIRED_THOROUGHLY.has(this.currentTagId)) this.pop();
3636
+ while (this.currentTagId !== void 0 && IMPLICIT_END_TAG_REQUIRED_THOROUGHLY.has(this.currentTagId)) this.pop();
3631
3637
  }
3632
3638
  generateImpliedEndTagsWithExclusion(exclusionId) {
3633
- while (this.currentTagId !== exclusionId && IMPLICIT_END_TAG_REQUIRED_THOROUGHLY.has(this.currentTagId)) this.pop();
3639
+ while (this.currentTagId !== void 0 && this.currentTagId !== exclusionId && IMPLICIT_END_TAG_REQUIRED_THOROUGHLY.has(this.currentTagId)) this.pop();
3634
3640
  }
3635
3641
  };
3636
3642
  //#endregion
3637
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/parser/formatting-element-list.js
3643
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/parser/formatting-element-list.js
3638
3644
  const NOAH_ARK_CAPACITY = 3;
3639
3645
  var EntryType;
3640
3646
  (function(EntryType) {
@@ -3703,7 +3709,7 @@ var FormattingElementList = class {
3703
3709
  }
3704
3710
  removeEntry(entry) {
3705
3711
  const entryIndex = this.entries.indexOf(entry);
3706
- if (entryIndex >= 0) this.entries.splice(entryIndex, 1);
3712
+ if (entryIndex !== -1) this.entries.splice(entryIndex, 1);
3707
3713
  }
3708
3714
  /**
3709
3715
  * Clears the list of formatting elements up to the last marker.
@@ -3712,8 +3718,8 @@ var FormattingElementList = class {
3712
3718
  */
3713
3719
  clearToLastMarker() {
3714
3720
  const markerIdx = this.entries.indexOf(MARKER);
3715
- if (markerIdx >= 0) this.entries.splice(0, markerIdx + 1);
3716
- else this.entries.length = 0;
3721
+ if (markerIdx === -1) this.entries.length = 0;
3722
+ else this.entries.splice(0, markerIdx + 1);
3717
3723
  }
3718
3724
  getElementEntryInScopeWithTagName(tagName) {
3719
3725
  const entry = this.entries.find((entry) => entry.type === EntryType.Marker || this.treeAdapter.getTagName(entry.element) === tagName);
@@ -3724,7 +3730,7 @@ var FormattingElementList = class {
3724
3730
  }
3725
3731
  };
3726
3732
  //#endregion
3727
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/tree-adapters/default.js
3733
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/tree-adapters/default.js
3728
3734
  const defaultTreeAdapter = {
3729
3735
  createDocument() {
3730
3736
  return {
@@ -3886,7 +3892,7 @@ const defaultTreeAdapter = {
3886
3892
  }
3887
3893
  };
3888
3894
  //#endregion
3889
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/common/doctype.js
3895
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/common/doctype.js
3890
3896
  const VALID_DOCTYPE_NAME = "html";
3891
3897
  const VALID_SYSTEM_ID = "about:legacy-compat";
3892
3898
  const QUIRKS_MODE_SYSTEM_ID = "http://www.ibm.com/data/dtd/v11/ibmxhtml1-transitional.dtd";
@@ -3985,7 +3991,7 @@ function getDocumentMode(token) {
3985
3991
  return DOCUMENT_MODE.NO_QUIRKS;
3986
3992
  }
3987
3993
  //#endregion
3988
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/common/foreign-content.js
3994
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/common/foreign-content.js
3989
3995
  const MIME_TYPES = {
3990
3996
  TEXT_HTML: "text/html",
3991
3997
  APPLICATION_XML: "application/xhtml+xml"
@@ -4242,7 +4248,7 @@ function isIntegrationPoint(tn, ns, attrs, foreignNS) {
4242
4248
  return (!foreignNS || foreignNS === NS.HTML) && isHtmlIntegrationPoint(tn, ns, attrs) || (!foreignNS || foreignNS === NS.MATHML) && isMathMLTextIntegrationPoint(tn, ns);
4243
4249
  }
4244
4250
  //#endregion
4245
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/parser/index.js
4251
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/parser/index.js
4246
4252
  const HIDDEN_INPUT_TYPE = "hidden";
4247
4253
  const AA_OUTER_LOOP_ITER = 8;
4248
4254
  const AA_INNER_LOOP_ITER = 3;
@@ -4404,9 +4410,9 @@ var Parser = class {
4404
4410
  }
4405
4411
  }
4406
4412
  _setContextModes(current, tid) {
4407
- const isHTML = current === this.document || this.treeAdapter.getNamespaceURI(current) === NS.HTML;
4413
+ const isHTML = current === this.document || current && this.treeAdapter.getNamespaceURI(current) === NS.HTML;
4408
4414
  this.currentNotInHTML = !isHTML;
4409
- this.tokenizer.inForeignNode = !isHTML && !this._isIntegrationPoint(tid, current);
4415
+ this.tokenizer.inForeignNode = !isHTML && current !== void 0 && tid !== void 0 && !this._isIntegrationPoint(tid, current);
4410
4416
  }
4411
4417
  /** @protected */
4412
4418
  _switchToTextParsing(currentToken, nextTokenizerState) {
@@ -4482,7 +4488,7 @@ var Parser = class {
4482
4488
  if (this._shouldFosterParentOnInsertion()) this._fosterParentElement(element);
4483
4489
  else {
4484
4490
  const parent = this.openElements.currentTmplContentOrNode;
4485
- this.treeAdapter.appendChild(parent, element);
4491
+ this.treeAdapter.appendChild(parent !== null && parent !== void 0 ? parent : this.document, element);
4486
4492
  }
4487
4493
  }
4488
4494
  /**
@@ -4586,7 +4592,7 @@ var Parser = class {
4586
4592
  currentTagId = this.fragmentContextID;
4587
4593
  } else ({current, currentTagId} = this.openElements);
4588
4594
  if (token.tagID === TAG_ID.SVG && this.treeAdapter.getTagName(current) === TAG_NAMES.ANNOTATION_XML && this.treeAdapter.getNamespaceURI(current) === NS.MATHML) return false;
4589
- return this.tokenizer.inForeignNode || (token.tagID === TAG_ID.MGLYPH || token.tagID === TAG_ID.MALIGNMARK) && !this._isIntegrationPoint(currentTagId, current, NS.HTML);
4595
+ return this.tokenizer.inForeignNode || (token.tagID === TAG_ID.MGLYPH || token.tagID === TAG_ID.MALIGNMARK) && currentTagId !== void 0 && !this._isIntegrationPoint(currentTagId, current, NS.HTML);
4590
4596
  }
4591
4597
  /** @protected */
4592
4598
  _processToken(token) {
@@ -4626,7 +4632,7 @@ var Parser = class {
4626
4632
  const listLength = this.activeFormattingElements.entries.length;
4627
4633
  if (listLength) {
4628
4634
  const endIndex = this.activeFormattingElements.entries.findIndex((entry) => entry.type === EntryType.Marker || this.openElements.contains(entry.element));
4629
- const unopenIdx = endIndex < 0 ? listLength - 1 : endIndex - 1;
4635
+ const unopenIdx = endIndex === -1 ? listLength - 1 : endIndex - 1;
4630
4636
  for (let i = unopenIdx; i >= 0; i--) {
4631
4637
  const entry = this.activeFormattingElements.entries[i];
4632
4638
  this._insertElement(entry.token, this.treeAdapter.getNamespaceURI(entry.element));
@@ -4715,7 +4721,7 @@ var Parser = class {
4715
4721
  }
4716
4722
  /** @protected */
4717
4723
  _shouldFosterParentOnInsertion() {
4718
- return this.fosterParentingEnabled && this._isElementCausesFosterParenting(this.openElements.currentTagId);
4724
+ return this.fosterParentingEnabled && this.openElements.currentTagId !== void 0 && this._isElementCausesFosterParenting(this.openElements.currentTagId);
4719
4725
  }
4720
4726
  /** @protected */
4721
4727
  _findFosterParentingLocation() {
@@ -5209,7 +5215,7 @@ function aaObtainFurthestBlock(p, formattingElementEntry) {
5209
5215
  if (p._isSpecialElement(element, p.openElements.tagIDs[idx])) furthestBlock = element;
5210
5216
  }
5211
5217
  if (!furthestBlock) {
5212
- p.openElements.shortenToLength(idx < 0 ? 0 : idx);
5218
+ p.openElements.shortenToLength(Math.max(idx, 0));
5213
5219
  p.activeFormattingElements.removeEntry(formattingElementEntry);
5214
5220
  }
5215
5221
  return furthestBlock;
@@ -5579,7 +5585,7 @@ function addressStartTagInBody(p, token) {
5579
5585
  }
5580
5586
  function numberedHeaderStartTagInBody(p, token) {
5581
5587
  if (p.openElements.hasInButtonScope(TAG_ID.P)) p._closePElement();
5582
- if (NUMBERED_HEADERS.has(p.openElements.currentTagId)) p.openElements.pop();
5588
+ if (p.openElements.currentTagId !== void 0 && NUMBERED_HEADERS.has(p.openElements.currentTagId)) p.openElements.pop();
5583
5589
  p._insertElement(token, NS.HTML);
5584
5590
  }
5585
5591
  function preStartTagInBody(p, token) {
@@ -6118,7 +6124,7 @@ function eofInText(p, token) {
6118
6124
  p.onEof(token);
6119
6125
  }
6120
6126
  function characterInTable(p, token) {
6121
- if (TABLE_STRUCTURE_TAGS.has(p.openElements.currentTagId)) {
6127
+ if (p.openElements.currentTagId !== void 0 && TABLE_STRUCTURE_TAGS.has(p.openElements.currentTagId)) {
6122
6128
  p.pendingCharacterTokens.length = 0;
6123
6129
  p.hasNonWhitespacePendingCharacterToken = false;
6124
6130
  p.originalInsertionMode = p.insertionMode;
@@ -6730,7 +6736,7 @@ function characterInForeignContent(p, token) {
6730
6736
  p.framesetOk = false;
6731
6737
  }
6732
6738
  function popUntilHtmlOrIntegrationPoint(p) {
6733
- while (p.treeAdapter.getNamespaceURI(p.openElements.current) !== NS.HTML && !p._isIntegrationPoint(p.openElements.currentTagId, p.openElements.current)) p.openElements.pop();
6739
+ while (p.treeAdapter.getNamespaceURI(p.openElements.current) !== NS.HTML && p.openElements.currentTagId !== void 0 && !p._isIntegrationPoint(p.openElements.currentTagId, p.openElements.current)) p.openElements.pop();
6734
6740
  }
6735
6741
  function startTagInForeignContent(p, token) {
6736
6742
  if (causesExit(token)) {
@@ -6791,7 +6797,7 @@ new Set([
6791
6797
  TAG_NAMES.WBR
6792
6798
  ]);
6793
6799
  //#endregion
6794
- //#region ../../node_modules/.pnpm/parse5@7.2.1/node_modules/parse5/dist/index.js
6800
+ //#region ../../node_modules/.pnpm/parse5@8.0.1/node_modules/parse5/dist/index.js
6795
6801
  /**
6796
6802
  * Parses an HTML string.
6797
6803
  *
@@ -6830,7 +6836,7 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
6830
6836
  var __getOwnPropNames = Object.getOwnPropertyNames;
6831
6837
  var __getProtoOf = Object.getPrototypeOf;
6832
6838
  var __hasOwnProp = Object.prototype.hasOwnProperty;
6833
- var __commonJSMin = (cb, mod) => () => (mod || cb((mod = { exports: {} }).exports, mod), mod.exports);
6839
+ var __commonJSMin = (cb, mod) => () => (mod || (cb((mod = { exports: {} }).exports, mod), cb = null), mod.exports);
6834
6840
  var __copyProps = (to, from, except, desc) => {
6835
6841
  if (from && typeof from === "object" || typeof from === "function") for (var keys = __getOwnPropNames(from), i = 0, n = keys.length, key; i < n; i++) {
6836
6842
  key = keys[i];
@@ -6861,28 +6867,13 @@ function getPrefixForNamespace(namespaceURI) {
6861
6867
  if (namespaceURI === XMLNS_NS) return "xmlns";
6862
6868
  return null;
6863
6869
  }
6864
- let NODE_TYPES = /* @__PURE__ */ function(NODE_TYPES) {
6865
- NODE_TYPES[NODE_TYPES["ELEMENT_NODE"] = 1] = "ELEMENT_NODE";
6866
- NODE_TYPES[NODE_TYPES["TEXT_NODE"] = 3] = "TEXT_NODE";
6867
- NODE_TYPES[NODE_TYPES["COMMENT_NODE"] = 8] = "COMMENT_NODE";
6868
- NODE_TYPES[NODE_TYPES["DOCUMENT_NODE"] = 9] = "DOCUMENT_NODE";
6869
- NODE_TYPES[NODE_TYPES["DOCUMENT_TYPE_NODE"] = 10] = "DOCUMENT_TYPE_NODE";
6870
- NODE_TYPES[NODE_TYPES["DOCUMENT_FRAGMENT_NODE"] = 11] = "DOCUMENT_FRAGMENT_NODE";
6871
- return NODE_TYPES;
6872
- }({});
6873
- let NODE_NAMES = /* @__PURE__ */ function(NODE_NAMES) {
6874
- NODE_NAMES["COMMENT_NODE"] = "#comment";
6875
- NODE_NAMES["DOCUMENT_NODE"] = "#document";
6876
- NODE_NAMES["DOCUMENT_FRAGMENT_NODE"] = "#document-fragment";
6877
- NODE_NAMES["TEXT_NODE"] = "#text";
6878
- return NODE_NAMES;
6879
- }({});
6880
6870
  const attrHandler = { get(obj, prop) {
6881
6871
  if (prop in obj) return obj[prop];
6882
6872
  if (typeof prop !== "symbol" && !isNaN(prop)) return obj.__items[prop];
6883
6873
  } };
6884
6874
  const createAttributeProxy = (caseInsensitive) => new Proxy(new MockAttributeMap(caseInsensitive), attrHandler);
6885
6875
  var MockAttributeMap = class {
6876
+ caseInsensitive;
6886
6877
  __items = [];
6887
6878
  constructor(caseInsensitive = false) {
6888
6879
  this.caseInsensitive = caseInsensitive;
@@ -7101,6 +7092,7 @@ function jsCaseToCssCase(str) {
7101
7092
  return str;
7102
7093
  }
7103
7094
  var MockCustomElementRegistry = class {
7095
+ win;
7104
7096
  __registry;
7105
7097
  __whenDefined;
7106
7098
  constructor(win) {
@@ -7205,7 +7197,7 @@ const proxyElements = /* @__PURE__ */ new WeakMap();
7205
7197
  const upgradedElements = /* @__PURE__ */ new WeakSet();
7206
7198
  function connectNode(ownerDocument, node) {
7207
7199
  node.ownerDocument = ownerDocument;
7208
- if (node.nodeType === NODE_TYPES.ELEMENT_NODE) {
7200
+ if (node.nodeType === 1) {
7209
7201
  if (ownerDocument != null && node.nodeName.includes("-")) {
7210
7202
  if (ownerDocument.defaultView != null && typeof node.connectedCallback === "function" && node.isConnected) fireConnectedCallback(node);
7211
7203
  const shadowRoot = node.shadowRoot;
@@ -7230,7 +7222,7 @@ function fireConnectedCallback(node) {
7230
7222
  }
7231
7223
  }
7232
7224
  function disconnectNode(node) {
7233
- if (node.nodeType === NODE_TYPES.ELEMENT_NODE) {
7225
+ if (node.nodeType === 1) {
7234
7226
  if (node.nodeName.includes("-") === true && typeof node.disconnectedCallback === "function") {
7235
7227
  if (tempDisableCallbacks.has(node.ownerDocument) === false) try {
7236
7228
  node.disconnectedCallback();
@@ -7320,7 +7312,7 @@ var MockEvent = class {
7320
7312
  let currentElement = this.target;
7321
7313
  while (currentElement) {
7322
7314
  composedPath.push(currentElement);
7323
- if (!currentElement.parentElement && currentElement.nodeName === NODE_NAMES.DOCUMENT_NODE) {
7315
+ if (!currentElement.parentElement && currentElement.nodeName === "#document") {
7324
7316
  composedPath.push(currentElement.defaultView);
7325
7317
  break;
7326
7318
  }
@@ -7451,7 +7443,7 @@ function triggerEventListener(elm, ev) {
7451
7443
  }
7452
7444
  });
7453
7445
  if (ev.bubbles === false) return;
7454
- if (elm.nodeName === NODE_NAMES.DOCUMENT_NODE) triggerEventListener(elm.defaultView, ev);
7446
+ if (elm.nodeName === "#document") triggerEventListener(elm.defaultView, ev);
7455
7447
  else if (elm.parentElement == null && elm.tagName === "HTML") triggerEventListener(elm.ownerDocument, ev);
7456
7448
  else triggerEventListener(getNextEventTarget(elm, ev), ev);
7457
7449
  }
@@ -7498,7 +7490,7 @@ function getParser(ownerDocument) {
7498
7490
  if (parseOptions != null) return parseOptions;
7499
7491
  parseOptions = { treeAdapter: {
7500
7492
  createDocument() {
7501
- const doc = ownerDocument.createElement(NODE_NAMES.DOCUMENT_NODE);
7493
+ const doc = ownerDocument.createElement("#document");
7502
7494
  doc["x-mode"] = "no-quirks";
7503
7495
  return doc;
7504
7496
  },
@@ -7537,7 +7529,7 @@ function getParser(ownerDocument) {
7537
7529
  return templateElement.content;
7538
7530
  },
7539
7531
  setDocumentType(doc, name, publicId, systemId) {
7540
- let doctypeNode = doc.childNodes.find((n) => n.nodeType === NODE_TYPES.DOCUMENT_TYPE_NODE);
7532
+ let doctypeNode = doc.childNodes.find((n) => n.nodeType === 10);
7541
7533
  if (doctypeNode == null) {
7542
7534
  doctypeNode = ownerDocument.createDocumentTypeNode();
7543
7535
  doc.insertBefore(doctypeNode, doc.firstChild);
@@ -7558,12 +7550,12 @@ function getParser(ownerDocument) {
7558
7550
  },
7559
7551
  insertText(parentNode, text) {
7560
7552
  const lastChild = parentNode.lastChild;
7561
- if (lastChild != null && lastChild.nodeType === NODE_TYPES.TEXT_NODE) lastChild.nodeValue += text;
7553
+ if (lastChild != null && lastChild.nodeType === 3) lastChild.nodeValue += text;
7562
7554
  else parentNode.appendChild(ownerDocument.createTextNode(text));
7563
7555
  },
7564
7556
  insertTextBefore(parentNode, text, referenceNode) {
7565
7557
  const prevNode = parentNode.childNodes[parentNode.childNodes.indexOf(referenceNode) - 1];
7566
- if (prevNode != null && prevNode.nodeType === NODE_TYPES.TEXT_NODE) prevNode.nodeValue += text;
7558
+ if (prevNode != null && prevNode.nodeType === 3) prevNode.nodeValue += text;
7567
7559
  else parentNode.insertBefore(ownerDocument.createTextNode(text), referenceNode);
7568
7560
  },
7569
7561
  adoptAttributes(recipient, attrs) {
@@ -7615,16 +7607,16 @@ function getParser(ownerDocument) {
7615
7607
  return doctypeNode["x-systemId"];
7616
7608
  },
7617
7609
  isTextNode(node) {
7618
- return node.nodeType === NODE_TYPES.TEXT_NODE;
7610
+ return node.nodeType === 3;
7619
7611
  },
7620
7612
  isCommentNode(node) {
7621
- return node.nodeType === NODE_TYPES.COMMENT_NODE;
7613
+ return node.nodeType === 8;
7622
7614
  },
7623
7615
  isDocumentTypeNode(node) {
7624
- return node.nodeType === NODE_TYPES.DOCUMENT_TYPE_NODE;
7616
+ return node.nodeType === 10;
7625
7617
  },
7626
7618
  isElementNode(node) {
7627
- return node.nodeType === NODE_TYPES.ELEMENT_NODE;
7619
+ return node.nodeType === 1;
7628
7620
  }
7629
7621
  } };
7630
7622
  docParser.set(ownerDocument, parseOptions);
@@ -7696,8 +7688,8 @@ const shadowRootTag = "mock:shadow-root";
7696
7688
  * @yields the serialized HTML in chunks
7697
7689
  */
7698
7690
  function* streamToHtml(node, opts, output) {
7699
- const isShadowRoot = node.nodeType === NODE_TYPES.DOCUMENT_FRAGMENT_NODE;
7700
- if (node.nodeType === NODE_TYPES.ELEMENT_NODE || isShadowRoot) {
7691
+ const isShadowRoot = node.nodeType === 11;
7692
+ if (node.nodeType === 1 || isShadowRoot) {
7701
7693
  const tagName = isShadowRoot ? shadowRootTag : getTagName(node);
7702
7694
  if (tagName === "body") output.isWithinBody = true;
7703
7695
  const ignoreTag = opts.excludeTags != null && opts.excludeTags.includes(tagName);
@@ -7733,7 +7725,7 @@ function* streamToHtml(node, opts, output) {
7733
7725
  const attr = attributes.item(i);
7734
7726
  const attrName = attr.name;
7735
7727
  if (attrName === "style") continue;
7736
- if (tag === "template" && isShadowRoot && (attrName === "shadowrootmode" || attrName === "shadowrootdelegatesfocus")) continue;
7728
+ if (tag === "template" && isShadowRoot && (attrName === "shadowrootmode" || attrName === "shadowrootdelegatesfocus" || attrName === "shadowrootcustomelementregistry")) continue;
7737
7729
  let attrValue = attr.value;
7738
7730
  if (opts.removeEmptyAttributes && attrValue === "" && REMOVE_EMPTY_ATTR.has(attrName)) continue;
7739
7731
  const attrNamespaceURI = attr.namespaceURI;
@@ -7796,7 +7788,7 @@ function* streamToHtml(node, opts, output) {
7796
7788
  yield* streamToHtml(shadowRoot, opts, output);
7797
7789
  output.indent = output.indent - (opts.indentSpaces ?? 0);
7798
7790
  const childNodes = getChildNodes(node);
7799
- if (opts.newLines && (childNodes.length === 0 || childNodes.length === 1 && childNodes[0].nodeType === NODE_TYPES.TEXT_NODE && childNodes[0].nodeValue?.trim() === "")) {
7791
+ if (opts.newLines && (childNodes.length === 0 || childNodes.length === 1 && childNodes[0].nodeType === 3 && childNodes[0].nodeValue?.trim() === "")) {
7800
7792
  yield "\n";
7801
7793
  output.currentLineWidth = 0;
7802
7794
  for (let i = 0; i < output.indent; i++) yield " ";
@@ -7807,7 +7799,7 @@ function* streamToHtml(node, opts, output) {
7807
7799
  const tag = tagName === shadowRootTag ? "template" : tagName;
7808
7800
  const childNodes = tagName === "template" ? node.content.childNodes : getChildNodes(node);
7809
7801
  const childNodeLength = childNodes.length;
7810
- if (childNodeLength > 0) if (childNodeLength === 1 && childNodes[0].nodeType === NODE_TYPES.TEXT_NODE && (typeof childNodes[0].nodeValue !== "string" || childNodes[0].nodeValue.trim() === "")) {} else {
7802
+ if (childNodeLength > 0) if (childNodeLength === 1 && childNodes[0].nodeType === 3 && (typeof childNodes[0].nodeValue !== "string" || childNodes[0].nodeValue.trim() === "")) {} else {
7811
7803
  const isWithinWhitespaceSensitiveNode = opts.newLines || (opts.indentSpaces ?? 0) > 0 ? isWithinWhitespaceSensitive(node) : false;
7812
7804
  if (!isWithinWhitespaceSensitiveNode && (opts.indentSpaces ?? 0) > 0 && ignoreTag === false) output.indent = output.indent + (opts.indentSpaces ?? 0);
7813
7805
  for (let i = 0; i < childNodeLength; i++) {
@@ -7849,7 +7841,7 @@ function* streamToHtml(node, opts, output) {
7849
7841
  output.currentLineWidth = 0;
7850
7842
  }
7851
7843
  if (tagName === "body") output.isWithinBody = false;
7852
- } else if (node.nodeType === NODE_TYPES.TEXT_NODE) {
7844
+ } else if (node.nodeType === 3) {
7853
7845
  let textContent = node.nodeValue;
7854
7846
  if (typeof textContent === "string") {
7855
7847
  const trimmedTextContent = textContent.trim();
@@ -7876,7 +7868,7 @@ function* streamToHtml(node, opts, output) {
7876
7868
  }
7877
7869
  let textContentLength = textContent.length;
7878
7870
  if (textContentLength > 0) {
7879
- const parentTagName = node.parentNode != null && node.parentNode.nodeType === NODE_TYPES.ELEMENT_NODE ? node.parentNode.nodeName : null;
7871
+ const parentTagName = node.parentNode != null && node.parentNode.nodeType === 1 ? node.parentNode.nodeName : null;
7880
7872
  if (typeof parentTagName === "string" && NON_ESCAPABLE_CONTENT.has(parentTagName)) {
7881
7873
  if (isWithinWhitespaceSensitive(node)) yield textContent;
7882
7874
  else {
@@ -7890,13 +7882,13 @@ function* streamToHtml(node, opts, output) {
7890
7882
  } else {
7891
7883
  if (isWithinWhitespaceSensitive(node)) output.currentLineWidth += textContentLength;
7892
7884
  else {
7893
- if (/\s/.test(textContent.charAt(0))) textContent = " " + textContent.trimLeft();
7885
+ if (/\s/.test(textContent.charAt(0))) textContent = " " + textContent.trimStart();
7894
7886
  textContentLength = textContent.length;
7895
7887
  if (textContentLength > 1) {
7896
7888
  if (/\s/.test(textContent.charAt(textContentLength - 1))) if (opts.approximateLineWidth && opts.approximateLineWidth > 0 && output.currentLineWidth + textContentLength > opts.approximateLineWidth) {
7897
- textContent = textContent.trimRight() + "\n";
7889
+ textContent = textContent.trimEnd() + "\n";
7898
7890
  output.currentLineWidth = 0;
7899
- } else textContent = textContent.trimRight() + " ";
7891
+ } else textContent = textContent.trimEnd() + " ";
7900
7892
  }
7901
7893
  output.currentLineWidth += textContentLength;
7902
7894
  }
@@ -7905,7 +7897,7 @@ function* streamToHtml(node, opts, output) {
7905
7897
  }
7906
7898
  }
7907
7899
  }
7908
- } else if (node.nodeType === NODE_TYPES.COMMENT_NODE) {
7900
+ } else if (node.nodeType === 8) {
7909
7901
  const nodeValue = node.nodeValue;
7910
7902
  const isHydrateAnnotation = nodeValue?.startsWith("r.") || nodeValue?.startsWith("o.") || nodeValue?.startsWith("s.") || nodeValue?.startsWith("t.");
7911
7903
  /**
@@ -7924,7 +7916,7 @@ function* streamToHtml(node, opts, output) {
7924
7916
  }
7925
7917
  yield "<!--" + nodeValue + "-->";
7926
7918
  if (nodeValue) output.currentLineWidth += nodeValue.length + 7;
7927
- } else if (node.nodeType === NODE_TYPES.DOCUMENT_TYPE_NODE) yield "<!doctype html>";
7919
+ } else if (node.nodeType === 10) yield "<!doctype html>";
7928
7920
  }
7929
7921
  const AMP_REGEX = /&/g;
7930
7922
  const NBSP_REGEX = /\u00a0/g;
@@ -7971,11 +7963,7 @@ const NON_ESCAPABLE_CONTENT = new Set([
7971
7963
  "STYLE",
7972
7964
  "SCRIPT",
7973
7965
  "IFRAME",
7974
- "NOSCRIPT",
7975
- "XMP",
7976
- "NOEMBED",
7977
- "NOFRAMES",
7978
- "PLAINTEXT"
7966
+ "NOSCRIPT"
7979
7967
  ]);
7980
7968
  /**
7981
7969
  * A list of whitespace sensitive tag names, such as `code`, `pre`, etc.
@@ -7983,7 +7971,6 @@ const NON_ESCAPABLE_CONTENT = new Set([
7983
7971
  const WHITESPACE_SENSITIVE = new Set([
7984
7972
  "CODE",
7985
7973
  "OUTPUT",
7986
- "PLAINTEXT",
7987
7974
  "PRE",
7988
7975
  "SCRIPT",
7989
7976
  "TEMPLATE",
@@ -7992,21 +7979,16 @@ const WHITESPACE_SENSITIVE = new Set([
7992
7979
  const EMPTY_ELEMENTS = new Set([
7993
7980
  "area",
7994
7981
  "base",
7995
- "basefont",
7996
- "bgsound",
7997
7982
  "br",
7998
7983
  "col",
7999
7984
  "embed",
8000
- "frame",
8001
7985
  "hr",
8002
7986
  "img",
8003
7987
  "input",
8004
- "keygen",
8005
7988
  "link",
8006
7989
  "meta",
8007
7990
  "param",
8008
7991
  "source",
8009
- "trace",
8010
7992
  "track",
8011
7993
  "wbr"
8012
7994
  ]);
@@ -8024,44 +8006,29 @@ const BOOLEAN_ATTR = new Set([
8024
8006
  "autofocus",
8025
8007
  "autoplay",
8026
8008
  "checked",
8027
- "compact",
8028
8009
  "controls",
8029
- "declare",
8030
8010
  "default",
8031
- "defaultchecked",
8032
- "defaultmuted",
8033
- "defaultselected",
8034
8011
  "defer",
8035
8012
  "disabled",
8036
- "enabled",
8037
8013
  "formnovalidate",
8038
8014
  "hidden",
8039
- "indeterminate",
8040
8015
  "inert",
8041
8016
  "ismap",
8042
8017
  "itemscope",
8043
8018
  "loop",
8044
8019
  "multiple",
8045
8020
  "muted",
8046
- "nohref",
8047
8021
  "nomodule",
8048
- "noresize",
8049
- "noshade",
8050
8022
  "novalidate",
8051
- "nowrap",
8052
8023
  "open",
8053
- "pauseonexit",
8054
8024
  "readonly",
8055
8025
  "required",
8056
8026
  "reversed",
8057
- "scoped",
8058
- "seamless",
8059
8027
  "selected",
8028
+ "shadowrootclonable",
8029
+ "shadowrootcustomelementregistry",
8060
8030
  "shadowrootdelegatesfocus",
8061
- "sortable",
8062
- "truespeed",
8063
- "typemustmatch",
8064
- "visible"
8031
+ "shadowrootserializable"
8065
8032
  ]);
8066
8033
  const STRUCTURE_ELEMENTS = new Set([
8067
8034
  "html",
@@ -8076,6 +8043,8 @@ const STRUCTURE_ELEMENTS = new Set([
8076
8043
  "style"
8077
8044
  ]);
8078
8045
  var MockTokenList = class {
8046
+ elm;
8047
+ attr;
8079
8048
  constructor(elm, attr) {
8080
8049
  this.elm = elm;
8081
8050
  this.attr = attr;
@@ -8156,7 +8125,7 @@ var MockNode = class {
8156
8125
  this._childNodes = value;
8157
8126
  }
8158
8127
  appendChild(newNode) {
8159
- if (newNode.nodeType === NODE_TYPES.DOCUMENT_FRAGMENT_NODE) {
8128
+ if (newNode.nodeType === 11) {
8160
8129
  const nodes = newNode.childNodes.slice();
8161
8130
  for (const child of nodes) this.appendChild(child);
8162
8131
  } else {
@@ -8187,22 +8156,20 @@ var MockNode = class {
8187
8156
  const DOCUMENT_POSITION_DISCONNECTED = 1;
8188
8157
  const DOCUMENT_POSITION_PRECEDING = 2;
8189
8158
  const DOCUMENT_POSITION_FOLLOWING = 4;
8190
- const DOCUMENT_POSITION_CONTAINS = 8;
8191
- const DOCUMENT_POSITION_CONTAINED_BY = 16;
8192
8159
  if (this === other) return 0;
8193
8160
  let thisRoot = this;
8194
8161
  while (thisRoot.parentNode) thisRoot = thisRoot.parentNode;
8195
8162
  let otherRoot = other;
8196
8163
  while (otherRoot.parentNode) otherRoot = otherRoot.parentNode;
8197
- if (thisRoot !== otherRoot) return DOCUMENT_POSITION_DISCONNECTED | DOCUMENT_POSITION_PRECEDING;
8164
+ if (thisRoot !== otherRoot) return 3;
8198
8165
  let node = other;
8199
8166
  while (node) {
8200
- if (node === this) return DOCUMENT_POSITION_CONTAINS | DOCUMENT_POSITION_PRECEDING;
8167
+ if (node === this) return 10;
8201
8168
  node = node.parentNode;
8202
8169
  }
8203
8170
  node = this;
8204
8171
  while (node) {
8205
- if (node === other) return DOCUMENT_POSITION_CONTAINED_BY | DOCUMENT_POSITION_FOLLOWING;
8172
+ if (node === other) return 20;
8206
8173
  node = node.parentNode;
8207
8174
  }
8208
8175
  const getAncestors = (n) => {
@@ -8230,16 +8197,16 @@ var MockNode = class {
8230
8197
  return this.childNodes[0] || null;
8231
8198
  }
8232
8199
  insertBefore(newNode, referenceNode) {
8233
- if (newNode.nodeType === NODE_TYPES.DOCUMENT_FRAGMENT_NODE) for (let i = 0, ii = newNode.childNodes.length; i < ii; i++) insertBefore(this, newNode.childNodes[i], referenceNode);
8200
+ if (newNode.nodeType === 11) for (let i = 0, ii = newNode.childNodes.length; i < ii; i++) insertBefore(this, newNode.childNodes[i], referenceNode);
8234
8201
  else insertBefore(this, newNode, referenceNode);
8235
8202
  return newNode;
8236
8203
  }
8237
8204
  get isConnected() {
8238
8205
  let node = this;
8239
8206
  while (node != null) {
8240
- if (node.nodeType === NODE_TYPES.DOCUMENT_NODE) return true;
8207
+ if (node.nodeType === 9) return true;
8241
8208
  node = node.parentNode;
8242
- if (node != null && node.nodeType === NODE_TYPES.DOCUMENT_FRAGMENT_NODE) node = node.host;
8209
+ if (node != null && node.nodeType === 11) node = node.host;
8243
8210
  }
8244
8211
  return false;
8245
8212
  }
@@ -8285,7 +8252,7 @@ var MockNode = class {
8285
8252
  const index = this.childNodes.indexOf(childNode);
8286
8253
  if (index > -1) {
8287
8254
  this.childNodes.splice(index, 1);
8288
- if (this.nodeType === NODE_TYPES.ELEMENT_NODE) {
8255
+ if (this.nodeType === 1) {
8289
8256
  const wasConnected = this.isConnected;
8290
8257
  childNode.parentNode = null;
8291
8258
  if (wasConnected === true) disconnectNode(childNode);
@@ -8354,7 +8321,7 @@ var MockElement = class extends MockNode {
8354
8321
  } });
8355
8322
  }
8356
8323
  constructor(ownerDocument, nodeName, namespaceURI = null) {
8357
- super(ownerDocument, NODE_TYPES.ELEMENT_NODE, typeof nodeName === "string" ? nodeName : null, null);
8324
+ super(ownerDocument, 1, typeof nodeName === "string" ? nodeName : null, null);
8358
8325
  this.__namespaceURI = namespaceURI;
8359
8326
  this.__localName = typeof nodeName === "string" ? nodeName : null;
8360
8327
  this.__shadowRoot = null;
@@ -8429,10 +8396,10 @@ var MockElement = class extends MockNode {
8429
8396
  this.__attributeMap = attrs;
8430
8397
  }
8431
8398
  get children() {
8432
- return this.childNodes.filter((n) => n.nodeType === NODE_TYPES.ELEMENT_NODE);
8399
+ return this.childNodes.filter((n) => n.nodeType === 1);
8433
8400
  }
8434
8401
  get childElementCount() {
8435
- return this.childNodes.filter((n) => n.nodeType === NODE_TYPES.ELEMENT_NODE).length;
8402
+ return this.childNodes.filter((n) => n.nodeType === 1).length;
8436
8403
  }
8437
8404
  get className() {
8438
8405
  return this.getAttributeNS(null, "class") || "";
@@ -8625,7 +8592,7 @@ var MockElement = class extends MockNode {
8625
8592
  }
8626
8593
  get nextElementSibling() {
8627
8594
  const parentElement = this.parentElement;
8628
- if (parentElement != null && (parentElement.nodeType === NODE_TYPES.ELEMENT_NODE || parentElement.nodeType === NODE_TYPES.DOCUMENT_FRAGMENT_NODE || parentElement.nodeType === NODE_TYPES.DOCUMENT_NODE)) {
8595
+ if (parentElement != null && (parentElement.nodeType === 1 || parentElement.nodeType === 11 || parentElement.nodeType === 9)) {
8629
8596
  const index = parentElement.children.indexOf(this) + 1;
8630
8597
  return parentElement.children[index] || null;
8631
8598
  }
@@ -8640,7 +8607,7 @@ var MockElement = class extends MockNode {
8640
8607
  }
8641
8608
  get previousElementSibling() {
8642
8609
  const parentElement = this.parentElement;
8643
- if (parentElement != null && (parentElement.nodeType === NODE_TYPES.ELEMENT_NODE || parentElement.nodeType === NODE_TYPES.DOCUMENT_FRAGMENT_NODE || parentElement.nodeType === NODE_TYPES.DOCUMENT_NODE)) {
8610
+ if (parentElement != null && (parentElement.nodeType === 1 || parentElement.nodeType === 11 || parentElement.nodeType === 9)) {
8644
8611
  const index = parentElement.children.indexOf(this) - 1;
8645
8612
  return parentElement.children[index] || null;
8646
8613
  }
@@ -8931,7 +8898,7 @@ var MockHTMLElement = class extends MockElement {
8931
8898
  };
8932
8899
  var MockTextNode = class MockTextNode extends MockNode {
8933
8900
  constructor(ownerDocument, text) {
8934
- super(ownerDocument, NODE_TYPES.TEXT_NODE, NODE_NAMES.TEXT_NODE, text);
8901
+ super(ownerDocument, 3, "#text", text);
8935
8902
  }
8936
8903
  cloneNode(_deep) {
8937
8904
  return new MockTextNode(null, this.nodeValue);
@@ -8953,7 +8920,7 @@ var MockTextNode = class MockTextNode extends MockNode {
8953
8920
  const text = [];
8954
8921
  for (let i = 0, ii = this.parentNode.childNodes.length; i < ii; i++) {
8955
8922
  const childNode = this.parentNode.childNodes[i];
8956
- if (childNode.nodeType === NODE_TYPES.TEXT_NODE) text.push(childNode.nodeValue);
8923
+ if (childNode.nodeType === 3) text.push(childNode.nodeValue);
8957
8924
  }
8958
8925
  return text.join("");
8959
8926
  }
@@ -8963,8 +8930,8 @@ var MockTextNode = class MockTextNode extends MockNode {
8963
8930
  function getTextContent(childNodes, text) {
8964
8931
  for (let i = 0, ii = childNodes.length; i < ii; i++) {
8965
8932
  const childNode = childNodes[i];
8966
- if (childNode.nodeType === NODE_TYPES.TEXT_NODE) text.push(childNode.nodeValue);
8967
- else if (childNode.nodeType === NODE_TYPES.ELEMENT_NODE) getTextContent(childNode.childNodes, text);
8933
+ if (childNode.nodeType === 3) text.push(childNode.nodeValue);
8934
+ else if (childNode.nodeType === 1) getTextContent(childNode.childNodes, text);
8968
8935
  }
8969
8936
  }
8970
8937
  function setTextContent(elm, text) {
@@ -9007,7 +8974,7 @@ function unmarkAsDispatching(target, eventType) {
9007
8974
  }
9008
8975
  var MockComment = class MockComment extends MockNode {
9009
8976
  constructor(ownerDocument, data) {
9010
- super(ownerDocument, NODE_TYPES.COMMENT_NODE, NODE_NAMES.COMMENT_NODE, data);
8977
+ super(ownerDocument, 8, "#comment", data);
9011
8978
  }
9012
8979
  cloneNode(_deep) {
9013
8980
  return new MockComment(null, this.nodeValue);
@@ -10160,8 +10127,8 @@ var import_nwsapi = /* @__PURE__ */ __toESM((/* @__PURE__ */ __commonJSMin(((exp
10160
10127
  var MockDocumentFragment = class MockDocumentFragment extends MockHTMLElement {
10161
10128
  constructor(ownerDocument) {
10162
10129
  super(ownerDocument, null);
10163
- this.nodeName = NODE_NAMES.DOCUMENT_FRAGMENT_NODE;
10164
- this.nodeType = NODE_TYPES.DOCUMENT_FRAGMENT_NODE;
10130
+ this.nodeName = "#document-fragment";
10131
+ this.nodeType = 11;
10165
10132
  }
10166
10133
  getElementById(id) {
10167
10134
  return getElementById(this, id);
@@ -10176,7 +10143,7 @@ var MockDocumentFragment = class MockDocumentFragment extends MockHTMLElement {
10176
10143
  const cloned = new MockDocumentFragment(null);
10177
10144
  if (deep) for (let i = 0, ii = this.childNodes.length; i < ii; i++) {
10178
10145
  const childNode = this.childNodes[i];
10179
- if (childNode.nodeType === NODE_TYPES.ELEMENT_NODE || childNode.nodeType === NODE_TYPES.TEXT_NODE || childNode.nodeType === NODE_TYPES.COMMENT_NODE) {
10146
+ if (childNode.nodeType === 1 || childNode.nodeType === 3 || childNode.nodeType === 8) {
10180
10147
  const clonedChildNode = this.childNodes[i].cloneNode(true);
10181
10148
  cloned.appendChild(clonedChildNode);
10182
10149
  }
@@ -10187,11 +10154,12 @@ var MockDocumentFragment = class MockDocumentFragment extends MockHTMLElement {
10187
10154
  var MockDocumentTypeNode = class extends MockHTMLElement {
10188
10155
  constructor(ownerDocument) {
10189
10156
  super(ownerDocument, "!DOCTYPE");
10190
- this.nodeType = NODE_TYPES.DOCUMENT_TYPE_NODE;
10157
+ this.nodeType = 10;
10191
10158
  this.setAttribute("html", "");
10192
10159
  }
10193
10160
  };
10194
10161
  var MockCSSRule = class {
10162
+ parentStyleSheet;
10195
10163
  cssText = "";
10196
10164
  type = 0;
10197
10165
  constructor(parentStyleSheet) {
@@ -10677,8 +10645,8 @@ var MockSlotElement = class MockSlotElement extends MockHTMLElement {
10677
10645
  const ownerHost = this.getRootNode().host;
10678
10646
  if (!ownerHost) return nodesToReturn;
10679
10647
  if (ownerHost.childNodes.length) {
10680
- if (this.name) nodesToReturn = ownerHost.childNodes.filter((n) => n.nodeType === NODE_TYPES.ELEMENT_NODE && n.getAttribute("slot") === this.name);
10681
- else nodesToReturn = ownerHost.childNodes.filter((n) => n.nodeType === NODE_TYPES.ELEMENT_NODE && !n.getAttribute("slot") || n.nodeType !== NODE_TYPES.ELEMENT_NODE);
10648
+ if (this.name) nodesToReturn = ownerHost.childNodes.filter((n) => n.nodeType === 1 && n.getAttribute("slot") === this.name);
10649
+ else nodesToReturn = ownerHost.childNodes.filter((n) => n.nodeType === 1 && !n.getAttribute("slot") || n.nodeType !== 1);
10682
10650
  if (nodesToReturn.length) return nodesToReturn;
10683
10651
  }
10684
10652
  if (!opts?.flatten) return this.childNodes.filter((n) => !(n instanceof MockSlotElement));
@@ -12038,8 +12006,8 @@ var MockDocument = class MockDocument extends MockHTMLElement {
12038
12006
  #nwsapi = null;
12039
12007
  constructor(html = null, win = null) {
12040
12008
  super(null, null);
12041
- this.nodeName = NODE_NAMES.DOCUMENT_NODE;
12042
- this.nodeType = NODE_TYPES.DOCUMENT_NODE;
12009
+ this.nodeName = "#document";
12010
+ this.nodeType = 9;
12043
12011
  this.defaultView = win;
12044
12012
  this.cookie = "";
12045
12013
  this.referrer = "";
@@ -12130,7 +12098,7 @@ var MockDocument = class MockDocument extends MockHTMLElement {
12130
12098
  return documentElement;
12131
12099
  }
12132
12100
  set documentElement(documentElement) {
12133
- for (let i = this.childNodes.length - 1; i >= 0; i--) if (this.childNodes[i].nodeType !== NODE_TYPES.DOCUMENT_TYPE_NODE) this.childNodes[i].remove();
12101
+ for (let i = this.childNodes.length - 1; i >= 0; i--) if (this.childNodes[i].nodeType !== 10) this.childNodes[i].remove();
12134
12102
  if (documentElement != null) {
12135
12103
  this.appendChild(documentElement);
12136
12104
  setOwnerDocument(documentElement, this);
@@ -12182,7 +12150,7 @@ var MockDocument = class MockDocument extends MockHTMLElement {
12182
12150
  return new MockAttr(attrName, "", namespaceURI);
12183
12151
  }
12184
12152
  createElement(tagName) {
12185
- if (tagName === NODE_NAMES.DOCUMENT_NODE) {
12153
+ if (tagName === "#document") {
12186
12154
  const doc = new MockDocument(false);
12187
12155
  doc.nodeName = tagName;
12188
12156
  doc.parentNode = null;
@@ -12248,10 +12216,10 @@ function resetDocument(doc) {
12248
12216
  }
12249
12217
  for (const key in doc) if (doc.hasOwnProperty(key) && !DOC_KEY_KEEPERS.has(key)) delete doc[key];
12250
12218
  try {
12251
- doc.nodeName = NODE_NAMES.DOCUMENT_NODE;
12219
+ doc.nodeName = "#document";
12252
12220
  } catch {}
12253
12221
  try {
12254
- doc.nodeType = NODE_TYPES.DOCUMENT_NODE;
12222
+ doc.nodeType = 9;
12255
12223
  } catch {}
12256
12224
  try {
12257
12225
  doc.cookie = "";
@@ -12295,7 +12263,7 @@ function getElementsByName(elm, elmName, foundElms = []) {
12295
12263
  function setOwnerDocument(elm, ownerDocument) {
12296
12264
  for (let i = 0, ii = elm.childNodes.length; i < ii; i++) {
12297
12265
  elm.childNodes[i].ownerDocument = ownerDocument;
12298
- if (elm.childNodes[i].nodeType === NODE_TYPES.ELEMENT_NODE) setOwnerDocument(elm.childNodes[i], ownerDocument);
12266
+ if (elm.childNodes[i].nodeType === 1) setOwnerDocument(elm.childNodes[i], ownerDocument);
12299
12267
  }
12300
12268
  }
12301
12269
  //#endregion
@@ -12309,6 +12277,8 @@ function createWindowFromHtml(templateHtml, uniqueId) {
12309
12277
  }
12310
12278
  return cloneWindow(templateWindow);
12311
12279
  }
12280
+ //#endregion
12281
+ //#region src/runtime/runtime-constants.ts
12312
12282
  const HYDRATED_STYLE_ID = "sty-id";
12313
12283
  const STENCIL_DOC_DATA = "_stencilDocData";
12314
12284
  //#endregion
@@ -12317,7 +12287,6 @@ const isString = (v) => typeof v === "string";
12317
12287
  //#endregion
12318
12288
  //#region src/runtime/mode.ts
12319
12289
  const setMode = (handler) => modeResolutionChain.push(handler);
12320
- new RegExp("Capture$");
12321
12290
  BUILD.lazyLoad || globalThis.HTMLElement;
12322
12291
  //#endregion
12323
12292
  //#region src/runtime/tag-transform.ts
@@ -12338,7 +12307,8 @@ function transformTag(tag) {
12338
12307
  function setTagTransformer(transformer) {
12339
12308
  tagTransformer = transformer;
12340
12309
  }
12341
- BUILD.shadowDom;
12310
+ //#endregion
12311
+ //#region src/server/platform/index.ts
12342
12312
  const modeResolutionChain = [];
12343
12313
  //#endregion
12344
12314
  //#region src/compiler/html/canonical-link.ts
@@ -12405,28 +12375,6 @@ const shouldIgnoreError = (msg) => {
12405
12375
  };
12406
12376
  const TASK_CANCELED_MSG = `task canceled`;
12407
12377
  //#endregion
12408
- //#region src/compiler/style/css-parser/css-parse-declarations.ts
12409
- let CssNodeType = /* @__PURE__ */ function(CssNodeType) {
12410
- CssNodeType[CssNodeType["Charset"] = 0] = "Charset";
12411
- CssNodeType[CssNodeType["Comment"] = 1] = "Comment";
12412
- CssNodeType[CssNodeType["CustomMedia"] = 2] = "CustomMedia";
12413
- CssNodeType[CssNodeType["Document"] = 3] = "Document";
12414
- CssNodeType[CssNodeType["Declaration"] = 4] = "Declaration";
12415
- CssNodeType[CssNodeType["FontFace"] = 5] = "FontFace";
12416
- CssNodeType[CssNodeType["Host"] = 6] = "Host";
12417
- CssNodeType[CssNodeType["Import"] = 7] = "Import";
12418
- CssNodeType[CssNodeType["KeyFrames"] = 8] = "KeyFrames";
12419
- CssNodeType[CssNodeType["KeyFrame"] = 9] = "KeyFrame";
12420
- CssNodeType[CssNodeType["Media"] = 10] = "Media";
12421
- CssNodeType[CssNodeType["Container"] = 11] = "Container";
12422
- CssNodeType[CssNodeType["Namespace"] = 12] = "Namespace";
12423
- CssNodeType[CssNodeType["Page"] = 13] = "Page";
12424
- CssNodeType[CssNodeType["Rule"] = 14] = "Rule";
12425
- CssNodeType[CssNodeType["StyleSheet"] = 15] = "StyleSheet";
12426
- CssNodeType[CssNodeType["Supports"] = 16] = "Supports";
12427
- return CssNodeType;
12428
- }({});
12429
- //#endregion
12430
12378
  //#region src/compiler/style/css-parser/parse-css.ts
12431
12379
  /**
12432
12380
  * Parses CSS string input into an AST representation.
@@ -12497,12 +12445,11 @@ const parseCss = (css, filePath) => {
12497
12445
  return null;
12498
12446
  };
12499
12447
  const stylesheet = () => {
12500
- const rulesList = rules();
12501
12448
  return {
12502
- type: CssNodeType.StyleSheet,
12449
+ type: 15,
12503
12450
  stylesheet: {
12504
12451
  source: filePath,
12505
- rules: rulesList
12452
+ rules: rules()
12506
12453
  }
12507
12454
  };
12508
12455
  };
@@ -12547,7 +12494,7 @@ const parseCss = (css, filePath) => {
12547
12494
  css = css.slice(i);
12548
12495
  column += 2;
12549
12496
  return pos({
12550
- type: CssNodeType.Comment,
12497
+ type: 1,
12551
12498
  comment: commentText
12552
12499
  });
12553
12500
  };
@@ -12568,7 +12515,7 @@ const parseCss = (css, filePath) => {
12568
12515
  if (!match(/^:\s*/)) return error(`property missing ':'`);
12569
12516
  const val = match(/^((?:'(?:\\'|.)*?'|"(?:\\"|.)*?"|\([^)]*?\)|[^};])+)/);
12570
12517
  const ret = pos({
12571
- type: CssNodeType.Declaration,
12518
+ type: 4,
12572
12519
  property: prop.replace(commentre, ""),
12573
12520
  value: val ? trim(val[0]).replace(commentre, "") : ""
12574
12521
  });
@@ -12597,7 +12544,7 @@ const parseCss = (css, filePath) => {
12597
12544
  }
12598
12545
  if (!values.length) return null;
12599
12546
  return pos({
12600
- type: CssNodeType.KeyFrame,
12547
+ type: 9,
12601
12548
  values,
12602
12549
  declarations: declarations()
12603
12550
  });
@@ -12619,7 +12566,7 @@ const parseCss = (css, filePath) => {
12619
12566
  }
12620
12567
  if (!close()) return error(`@keyframes missing '}'`);
12621
12568
  return pos({
12622
- type: CssNodeType.KeyFrames,
12569
+ type: 8,
12623
12570
  name,
12624
12571
  vendor,
12625
12572
  keyframes: frames
@@ -12634,7 +12581,7 @@ const parseCss = (css, filePath) => {
12634
12581
  const style = comments().concat(rules());
12635
12582
  if (!close()) return error(`@supports missing '}'`);
12636
12583
  return pos({
12637
- type: CssNodeType.Supports,
12584
+ type: 16,
12638
12585
  supports,
12639
12586
  rules: style
12640
12587
  });
@@ -12646,7 +12593,7 @@ const parseCss = (css, filePath) => {
12646
12593
  const style = comments().concat(rules());
12647
12594
  if (!close()) return error(`@host missing '}'`);
12648
12595
  return pos({
12649
- type: CssNodeType.Host,
12596
+ type: 6,
12650
12597
  rules: style
12651
12598
  });
12652
12599
  };
@@ -12659,7 +12606,7 @@ const parseCss = (css, filePath) => {
12659
12606
  const style = comments().concat(rules());
12660
12607
  if (!close()) return error(`@${name} missing '}'`);
12661
12608
  return pos({
12662
- type: name === "media" ? CssNodeType.Media : CssNodeType.Container,
12609
+ type: name === "media" ? 10 : 11,
12663
12610
  media,
12664
12611
  rules: style
12665
12612
  });
@@ -12677,7 +12624,7 @@ const parseCss = (css, filePath) => {
12677
12624
  const decls = declarations();
12678
12625
  if (!decls) return null;
12679
12626
  return pos({
12680
- type: name === "media" ? CssNodeType.Media : name === "container" ? CssNodeType.Container : CssNodeType.Supports,
12627
+ type: name === "media" ? 10 : name === "container" ? 11 : 16,
12681
12628
  media,
12682
12629
  declarations: decls
12683
12630
  });
@@ -12695,7 +12642,7 @@ const parseCss = (css, filePath) => {
12695
12642
  const m = match(/^@custom-media\s+(--[^\s]+)\s*([^{;]+);/);
12696
12643
  if (!m) return null;
12697
12644
  return pos({
12698
- type: CssNodeType.CustomMedia,
12645
+ type: 2,
12699
12646
  name: trim(m[1]),
12700
12647
  media: trim(m[2])
12701
12648
  });
@@ -12713,7 +12660,7 @@ const parseCss = (css, filePath) => {
12713
12660
  }
12714
12661
  if (!close()) return error(`@page missing '}'`);
12715
12662
  return pos({
12716
- type: CssNodeType.Page,
12663
+ type: 13,
12717
12664
  selectors: sel,
12718
12665
  declarations: decls
12719
12666
  });
@@ -12728,7 +12675,7 @@ const parseCss = (css, filePath) => {
12728
12675
  const style = comments().concat(rules());
12729
12676
  if (!close()) return error(`@document missing '}'`);
12730
12677
  return pos({
12731
- type: CssNodeType.Document,
12678
+ type: 3,
12732
12679
  document: doc,
12733
12680
  vendor,
12734
12681
  rules: style
@@ -12746,7 +12693,7 @@ const parseCss = (css, filePath) => {
12746
12693
  }
12747
12694
  if (!close()) return error(`@font-face missing '}'`);
12748
12695
  return pos({
12749
- type: CssNodeType.FontFace,
12696
+ type: 5,
12750
12697
  declarations: decls
12751
12698
  });
12752
12699
  };
@@ -12761,9 +12708,9 @@ const parseCss = (css, filePath) => {
12761
12708
  return pos(node);
12762
12709
  };
12763
12710
  };
12764
- const atimport = compileAtrule("import", CssNodeType.Import);
12765
- const atcharset = compileAtrule("charset", CssNodeType.Charset);
12766
- const atnamespace = compileAtrule("namespace", CssNodeType.Namespace);
12711
+ const atimport = compileAtrule("import", 7);
12712
+ const atcharset = compileAtrule("charset", 0);
12713
+ const atnamespace = compileAtrule("namespace", 12);
12767
12714
  const atrule = () => {
12768
12715
  if (css[0] !== "@") return null;
12769
12716
  return atkeyframes() || atquery("media") || atquery("container") || atcustommedia() || atsupports() || atimport() || atcharset() || atnamespace() || atdocument() || atpage() || athost() || atfontface();
@@ -12817,7 +12764,7 @@ const parseCss = (css, filePath) => {
12817
12764
  }
12818
12765
  if (!close()) return error(`missing '}'`);
12819
12766
  return pos({
12820
- type: CssNodeType.Rule,
12767
+ type: 14,
12821
12768
  selectors: sel,
12822
12769
  declarations: decls,
12823
12770
  rules: nestedRules.length > 0 ? nestedRules : null
@@ -12927,23 +12874,23 @@ const serializeCss = (stylesheet, serializeOpts) => {
12927
12874
  };
12928
12875
  const serializeCssVisitNode = (opts, node, index, len) => {
12929
12876
  const nodeType = node.type;
12930
- if (nodeType === CssNodeType.Declaration) return serializeCssDeclaration(node, index, len);
12931
- if (nodeType === CssNodeType.Rule) return serializeCssRule(opts, node);
12932
- if (nodeType === CssNodeType.Comment) if (node.comment?.[0] === "!") return `/*${node.comment}*/`;
12877
+ if (nodeType === 4) return serializeCssDeclaration(node, index, len);
12878
+ if (nodeType === 14) return serializeCssRule(opts, node);
12879
+ if (nodeType === 1) if (node.comment?.[0] === "!") return `/*${node.comment}*/`;
12933
12880
  else return "";
12934
- if (nodeType === CssNodeType.Media) return serializeCssMedia(opts, node);
12935
- if (nodeType === CssNodeType.Container) return serializeCssContainer(opts, node);
12936
- if (nodeType === CssNodeType.KeyFrames) return serializeCssKeyframes(opts, node);
12937
- if (nodeType === CssNodeType.KeyFrame) return serializeCssKeyframe(opts, node);
12938
- if (nodeType === CssNodeType.FontFace) return serializeCssFontFace(opts, node);
12939
- if (nodeType === CssNodeType.Supports) return serializeCssSupports(opts, node);
12940
- if (nodeType === CssNodeType.Import) return "@import " + node.import + ";";
12941
- if (nodeType === CssNodeType.Charset) return "@charset " + node.charset + ";";
12942
- if (nodeType === CssNodeType.Page) return serializeCssPage(opts, node);
12943
- if (nodeType === CssNodeType.Host) return "@host{" + serializeCssMapVisit(opts, node.rules) + "}";
12944
- if (nodeType === CssNodeType.CustomMedia) return "@custom-media " + node.name + " " + node.media + ";";
12945
- if (nodeType === CssNodeType.Document) return serializeCssDocument(opts, node);
12946
- if (nodeType === CssNodeType.Namespace) return "@namespace " + node.namespace + ";";
12881
+ if (nodeType === 10) return serializeCssMedia(opts, node);
12882
+ if (nodeType === 11) return serializeCssContainer(opts, node);
12883
+ if (nodeType === 8) return serializeCssKeyframes(opts, node);
12884
+ if (nodeType === 9) return serializeCssKeyframe(opts, node);
12885
+ if (nodeType === 5) return serializeCssFontFace(opts, node);
12886
+ if (nodeType === 16) return serializeCssSupports(opts, node);
12887
+ if (nodeType === 7) return "@import " + node.import + ";";
12888
+ if (nodeType === 0) return "@charset " + node.charset + ";";
12889
+ if (nodeType === 13) return serializeCssPage(opts, node);
12890
+ if (nodeType === 6) return "@host{" + serializeCssMapVisit(opts, node.rules) + "}";
12891
+ if (nodeType === 2) return "@custom-media " + node.name + " " + node.media + ";";
12892
+ if (nodeType === 3) return serializeCssDocument(opts, node);
12893
+ if (nodeType === 12) return "@namespace " + node.namespace + ";";
12947
12894
  return "";
12948
12895
  };
12949
12896
  const serializeCssRule = (opts, node) => {
@@ -13513,18 +13460,17 @@ function renderToString(html, options) {
13513
13460
  return ssrDocument(html, opts);
13514
13461
  }
13515
13462
  /**
13516
- * Renders HTML and returns a Node.js Readable stream.
13517
- * This is a Node.js-specific convenience wrapper around renderToString.
13518
- * Note: This function requires Node.js and cannot be used in QuickJS/WASM environments.
13463
+ * Renders HTML and returns a web-standard ReadableStream.
13464
+ * Works in Node 22+, Cloudflare Workers, Deno, Bun, and any WinterCG-compatible runtime.
13519
13465
  * @param html - the HTML string or document to render
13520
13466
  * @param options - serialization options
13521
- * @returns a Node.js Readable stream
13467
+ * @returns a ReadableStream
13522
13468
  */
13523
13469
  function streamToString(html, options) {
13524
- async function* generateStream() {
13525
- yield (await renderToString(html, options)).html;
13526
- }
13527
- return Readable.from(generateStream());
13470
+ return new ReadableStream({ async start(controller) {
13471
+ controller.enqueue((await renderToString(html, options)).html);
13472
+ controller.close();
13473
+ } });
13528
13474
  }
13529
13475
  /**
13530
13476
  * Server side renders a document or HTML string, returning the full render results.