mirror of
https://github.com/mblanke/holiday-travel-app.git
synced 2026-03-01 05:20:22 -05:00
35 lines
101 KiB
JavaScript
35 lines
101 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
exports.id = "vendor-chunks/encoding-sniffer";
|
|
exports.ids = ["vendor-chunks/encoding-sniffer"];
|
|
exports.modules = {
|
|
|
|
/***/ "(rsc)/./node_modules/encoding-sniffer/dist/esm/index.js":
|
|
/*!*********************************************************!*\
|
|
!*** ./node_modules/encoding-sniffer/dist/esm/index.js ***!
|
|
\*********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ DecodeStream: () => (/* binding */ DecodeStream),\n/* harmony export */ decodeBuffer: () => (/* binding */ decodeBuffer),\n/* harmony export */ getEncoding: () => (/* reexport safe */ _sniffer_js__WEBPACK_IMPORTED_MODULE_2__.getEncoding)\n/* harmony export */ });\n/* harmony import */ var node_stream__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! node:stream */ \"node:stream\");\n/* harmony import */ var iconv_lite__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! iconv-lite */ \"(rsc)/./node_modules/iconv-lite/lib/index.js\");\n/* harmony import */ var _sniffer_js__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./sniffer.js */ \"(rsc)/./node_modules/encoding-sniffer/dist/esm/sniffer.js\");\n\n\n\n/**\n * Sniff the encoding of a buffer, then decode it.\n *\n * @param buffer Buffer to be decoded\n * @param options Options for the sniffer\n * @returns The decoded buffer\n */\nfunction decodeBuffer(buffer, options = {}) {\n return iconv_lite__WEBPACK_IMPORTED_MODULE_1__.decode(buffer, (0,_sniffer_js__WEBPACK_IMPORTED_MODULE_2__.getEncoding)(buffer, options));\n}\n/**\n * Decodes a stream of buffers into a stream of strings.\n *\n * Reads the first 1024 bytes and passes them to the sniffer. Once an encoding\n * has been determined, it passes all data to iconv-lite's stream and outputs\n * the results.\n */\nclass DecodeStream extends node_stream__WEBPACK_IMPORTED_MODULE_0__.Transform {\n constructor(options) {\n var _a;\n super({ decodeStrings: false, encoding: \"utf-8\" });\n this.buffers = [];\n /** The iconv decode stream. If it is set, we have read more than `options.maxBytes` bytes. */\n this.iconv = null;\n this.readBytes = 0;\n this.sniffer = new _sniffer_js__WEBPACK_IMPORTED_MODULE_2__.Sniffer(options);\n this.maxBytes = (_a = options === null || options === void 0 ? void 0 : options.maxBytes) !== null && _a !== void 0 ? _a : 1024;\n }\n _transform(chunk, _encoding, callback) {\n if (this.readBytes < this.maxBytes) {\n this.sniffer.write(chunk);\n this.readBytes += chunk.length;\n if (this.readBytes < this.maxBytes) {\n this.buffers.push(chunk);\n callback();\n return;\n }\n }\n this.getIconvStream().write(chunk, callback);\n }\n getIconvStream() {\n if (this.iconv) {\n return this.iconv;\n }\n const stream = iconv_lite__WEBPACK_IMPORTED_MODULE_1__.decodeStream(this.sniffer.encoding);\n stream.on(\"data\", (chunk) => this.push(chunk, \"utf-8\"));\n stream.on(\"end\", () => this.push(null));\n this.iconv = stream;\n for (const buffer of this.buffers) {\n stream.write(buffer);\n }\n this.buffers.length = 0;\n return stream;\n }\n _flush(callback) {\n this.getIconvStream().end(callback);\n }\n}\n\n//# sourceMappingURL=index.js.map//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiKHJzYykvLi9ub2RlX21vZHVsZXMvZW5jb2Rpbmctc25pZmZlci9kaXN0L2VzbS9pbmRleC5qcyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7QUFBd0M7QUFDVDtBQUNxQjtBQUNwRDtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNPLDBDQUEwQztBQUNqRCxXQUFXLDhDQUFZLFNBQVMsd0RBQVc7QUFDM0M7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNPLDJCQUEyQixrREFBUztBQUMzQztBQUNBO0FBQ0EsZ0JBQWdCLHlDQUF5QztBQUN6RDtBQUNBO0FBQ0E7QUFDQTtBQUNBLDJCQUEyQixnREFBTztBQUNsQztBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1QkFBdUIsb0RBQWtCO0FBQ3pDO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQzJDO0FBQzNDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vaG9saWRheS1kZWFsLWZpbmRlci8uL25vZGVfbW9kdWxlcy9lbmNvZGluZy1zbmlmZmVyL2Rpc3QvZXNtL2luZGV4LmpzP2RkNjQiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHJhbnNmb3JtIH0gZnJvbSBcIm5vZGU6c3RyZWFtXCI7XG5pbXBvcnQgaWNvbnYgZnJvbSBcImljb252LWxpdGVcIjtcbmltcG9ydCB7IFNuaWZmZXIsIGdldEVuY29kaW5nIH0gZnJvbSBcIi4vc25pZmZlci5qc1wiO1xuLyoqXG4gKiBTbmlmZiB0aGUgZW5jb2Rpbmcgb2YgYSBidWZmZXIsIHRoZW4gZGVjb2RlIGl0LlxuICpcbiAqIEBwYXJhbSBidWZmZXIgQnVmZmVyIHRvIGJlIGRlY29kZWRcbiAqIEBwYXJhbSBvcHRpb25zIE9wdGlvbnMgZm9yIHRoZSBzbmlmZmVyXG4gKiBAcmV0dXJucyBUaGUgZGVjb2RlZCBidWZmZXJcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGRlY29kZUJ1ZmZlcihidWZmZXIsIG9wdGlvbnMgPSB7fSkge1xuICAgIHJldHVybiBpY29udi5kZWNvZGUoYnVmZmVyLCBnZXRFbmNvZGluZyhidWZmZXIsIG9wdGlvbnMpKTtcbn1cbi8qKlxuICogRGVjb2RlcyBhIHN0cmVhbSBvZiBidWZmZXJzIGludG8gYSBzdHJlYW0gb2Ygc3RyaW5ncy5cbiAqXG4gKiBSZWFkcyB0aGUgZmlyc3QgMTAyNCBieXRlcyBhbmQgcGFzc2VzIHRoZW0gdG8gdGhlIHNuaWZmZXIuIE9uY2UgYW4gZW5jb2RpbmdcbiAqIGhhcyBiZWVuIGRldGVybWluZWQsIGl0IHBhc3NlcyBhbGwgZGF0YSB0byBpY29udi1saXRlJ3Mgc3RyZWFtIGFuZCBvdXRwdXRzXG4gKiB0aGUgcmVzdWx0cy5cbiAqL1xuZXhwb3J0IGNsYXNzIERlY29kZVN0cmVhbSBleHRlbmRzIFRyYW5zZm9ybSB7XG4gICAgY29uc3RydWN0b3Iob3B0aW9ucykge1xuICAgICAgICB2YXIgX2E7XG4gICAgICAgIHN1cGVyKHsgZGVjb2RlU3RyaW5nczogZmFsc2UsIGVuY29kaW5nOiBcInV0Zi04XCIgfSk7XG4gICAgICAgIHRoaXMuYnVmZmVycyA9IFtdO1xuICAgICAgICAvKiogVGhlIGljb252IGRlY29kZSBzdHJlYW0uIElmIGl0IGlzIHNldCwgd2UgaGF2ZSByZWFkIG1vcmUgdGhhbiBgb3B0aW9ucy5tYXhCeXRlc2AgYnl0ZXMuICovXG4gICAgICAgIHRoaXMuaWNvbnYgPSBudWxsO1xuICAgICAgICB0aGlzLnJlYWRCeXRlcyA9IDA7XG4gICAgICAgIHRoaXMuc25pZmZlciA9IG5ldyBTbmlmZmVyKG9wdGlvbnMpO1xuICAgICAgICB0aGlzLm1heEJ5dGVzID0gKF9hID0gb3B0aW9ucyA9PT0gbnVsbCB8fCBvcHRpb25zID09PSB2b2lkIDAgPyB2b2lkIDAgOiBvcHRpb25zLm1heEJ5dGVzKSAhPT0gbnVsbCAmJiBfYSAhPT0gdm9pZCAwID8gX2EgOiAxMDI0O1xuICAgIH1cbiAgICBfdHJhbnNmb3JtKGNodW5rLCBfZW5jb2RpbmcsIGNhbGxiYWNrKSB7XG4gICAgICAgIGlmICh0aGlzLnJlYWRCeXRlcyA8IHRoaXMubWF4Qnl0ZXMpIHtcbiAgICAgICAgICAgIHRoaXMuc25pZmZlci53cml0ZShjaHVuayk7XG4gICAgICAgICAgICB0aGlzLnJlYWRCeXRlcyArPSBjaHVuay5sZW5ndGg7XG4gICAgICAgICAgICBpZiAodGhpcy5yZWFkQnl0ZXMgPCB0aGlzLm1heEJ5dGVzKSB7XG4gICAgICAgICAgICAgICAgdGhpcy5idWZmZXJzLnB1c2goY2h1bmspO1xuICAgICAgICAgICAgICAgIGNhbGxiYWNrKCk7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIHRoaXMuZ2V0SWNvbnZTdHJlYW0oKS53cml0ZShjaHVuaywgY2FsbGJhY2spO1xuICAgIH1cbiAgICBnZXRJY29udlN0cmVhbSgpIHtcbiAgICAgICAgaWYgKHRoaXMuaWNvbnYpIHtcbiAgICAgICAgICAgIHJldHVybiB0aGlzLmljb252O1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHN0cmVhbSA9IGljb252LmRlY29kZVN0cmVhbSh0aGlzLnNuaWZmZXIuZW5jb2RpbmcpO1xuICAgICAgICBzdHJlYW0ub24oXCJkYXRhXCIsIChjaHVuaykgPT4gdGhpcy5wdXNoKGNodW5rLCBcInV0Zi04XCIpKTtcbiAgICAgICAgc3RyZWFtLm9uKFwiZW5kXCIsICgpID0+IHRoaXMucHVzaChudWxsKSk7XG4gICAgICAgIHRoaXMuaWNvbnYgPSBzdHJlYW07XG4gICAgICAgIGZvciAoY29uc3QgYnVmZmVyIG9mIHRoaXMuYnVmZmVycykge1xuICAgICAgICAgICAgc3RyZWFtLndyaXRlKGJ1ZmZlcik7XG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5idWZmZXJzLmxlbmd0aCA9IDA7XG4gICAgICAgIHJldHVybiBzdHJlYW07XG4gICAgfVxuICAgIF9mbHVzaChjYWxsYmFjaykge1xuICAgICAgICB0aGlzLmdldEljb252U3RyZWFtKCkuZW5kKGNhbGxiYWNrKTtcbiAgICB9XG59XG5leHBvcnQgeyBnZXRFbmNvZGluZyB9IGZyb20gXCIuL3NuaWZmZXIuanNcIjtcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPWluZGV4LmpzLm1hcCJdLCJuYW1lcyI6W10sInNvdXJjZVJvb3QiOiIifQ==\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/encoding-sniffer/dist/esm/index.js\n");
|
|
|
|
/***/ }),
|
|
|
|
/***/ "(rsc)/./node_modules/encoding-sniffer/dist/esm/sniffer.js":
|
|
/*!***********************************************************!*\
|
|
!*** ./node_modules/encoding-sniffer/dist/esm/sniffer.js ***!
|
|
\***********************************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ ResultType: () => (/* binding */ ResultType),\n/* harmony export */ STRINGS: () => (/* binding */ STRINGS),\n/* harmony export */ Sniffer: () => (/* binding */ Sniffer),\n/* harmony export */ getEncoding: () => (/* binding */ getEncoding)\n/* harmony export */ });\n/* harmony import */ var whatwg_encoding__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! whatwg-encoding */ \"(rsc)/./node_modules/whatwg-encoding/lib/whatwg-encoding.js\");\n\n// https://html.spec.whatwg.org/multipage/syntax.html#prescan-a-byte-stream-to-determine-its-encoding\nvar State;\n(function (State) {\n // Before anything starts; can be any of BOM, UTF-16 XML declarations or meta tags\n State[State[\"Begin\"] = 0] = \"Begin\";\n // Inside of a BOM\n State[State[\"BOM16BE\"] = 1] = \"BOM16BE\";\n State[State[\"BOM16LE\"] = 2] = \"BOM16LE\";\n State[State[\"BOM8\"] = 3] = \"BOM8\";\n // XML prefix\n State[State[\"UTF16LE_XML_PREFIX\"] = 4] = \"UTF16LE_XML_PREFIX\";\n State[State[\"BeginLT\"] = 5] = \"BeginLT\";\n State[State[\"UTF16BE_XML_PREFIX\"] = 6] = \"UTF16BE_XML_PREFIX\";\n // Waiting for opening `<`\n State[State[\"BeforeTag\"] = 7] = \"BeforeTag\";\n // After the opening `<`\n State[State[\"BeforeTagName\"] = 8] = \"BeforeTagName\";\n // After `</`\n State[State[\"BeforeCloseTagName\"] = 9] = \"BeforeCloseTagName\";\n // Beginning of a comment\n State[State[\"CommentStart\"] = 10] = \"CommentStart\";\n // End of a comment\n State[State[\"CommentEnd\"] = 11] = \"CommentEnd\";\n // A tag name that could be `meta`\n State[State[\"TagNameMeta\"] = 12] = \"TagNameMeta\";\n // A tag name that is not `meta`\n State[State[\"TagNameOther\"] = 13] = \"TagNameOther\";\n // XML declaration\n State[State[\"XMLDeclaration\"] = 14] = \"XMLDeclaration\";\n State[State[\"XMLDeclarationBeforeEncoding\"] = 15] = \"XMLDeclarationBeforeEncoding\";\n State[State[\"XMLDeclarationAfterEncoding\"] = 16] = \"XMLDeclarationAfterEncoding\";\n State[State[\"XMLDeclarationBeforeValue\"] = 17] = \"XMLDeclarationBeforeValue\";\n State[State[\"XMLDeclarationValue\"] = 18] = \"XMLDeclarationValue\";\n // Anything that looks like a tag, but doesn't fit in the above categories\n State[State[\"WeirdTag\"] = 19] = \"WeirdTag\";\n State[State[\"BeforeAttribute\"] = 20] = \"BeforeAttribute\";\n /*\n * Attributes in meta tag — we compare them to our set here, and back out\n * We care about four attributes: http-equiv, content-type, content, charset\n */\n State[State[\"MetaAttribHttpEquiv\"] = 21] = \"MetaAttribHttpEquiv\";\n // The value has to be `content-type`\n State[State[\"MetaAttribHttpEquivValue\"] = 22] = \"MetaAttribHttpEquivValue\";\n State[State[\"MetaAttribC\"] = 23] = \"MetaAttribC\";\n State[State[\"MetaAttribContent\"] = 24] = \"MetaAttribContent\";\n State[State[\"MetaAttribCharset\"] = 25] = \"MetaAttribCharset\";\n // Waiting for whitespace\n State[State[\"MetaAttribAfterName\"] = 26] = \"MetaAttribAfterName\";\n State[State[\"MetaContentValueQuotedBeforeEncoding\"] = 27] = \"MetaContentValueQuotedBeforeEncoding\";\n State[State[\"MetaContentValueQuotedAfterEncoding\"] = 28] = \"MetaContentValueQuotedAfterEncoding\";\n State[State[\"MetaContentValueQuotedBeforeValue\"] = 29] = \"MetaContentValueQuotedBeforeValue\";\n State[State[\"MetaContentValueQuotedValueQuoted\"] = 30] = \"MetaContentValueQuotedValueQuoted\";\n State[State[\"MetaContentValueQuotedValueUnquoted\"] = 31] = \"MetaContentValueQuotedValueUnquoted\";\n State[State[\"MetaContentValueUnquotedBeforeEncoding\"] = 32] = \"MetaContentValueUnquotedBeforeEncoding\";\n State[State[\"MetaContentValueUnquotedBeforeValue\"] = 33] = \"MetaContentValueUnquotedBeforeValue\";\n State[State[\"MetaContentValueUnquotedValueQuoted\"] = 34] = \"MetaContentValueUnquotedValueQuoted\";\n State[State[\"MetaContentValueUnquotedValueUnquoted\"] = 35] = \"MetaContentValueUnquotedValueUnquoted\";\n State[State[\"AnyAttribName\"] = 36] = \"AnyAttribName\";\n // After the name of an attribute, before the equals sign\n State[State[\"AfterAttributeName\"] = 37] = \"AfterAttributeName\";\n // After `=`\n State[State[\"BeforeAttributeValue\"] = 38] = \"BeforeAttributeValue\";\n State[State[\"AttributeValueQuoted\"] = 39] = \"AttributeValueQuoted\";\n State[State[\"AttributeValueUnquoted\"] = 40] = \"AttributeValueUnquoted\";\n})(State || (State = {}));\nvar ResultType;\n(function (ResultType) {\n // Byte order mark\n ResultType[ResultType[\"BOM\"] = 0] = \"BOM\";\n // User- or transport layer-defined\n ResultType[ResultType[\"PASSED\"] = 1] = \"PASSED\";\n // XML prefixes\n ResultType[ResultType[\"XML_PREFIX\"] = 2] = \"XML_PREFIX\";\n // Meta tag\n ResultType[ResultType[\"META_TAG\"] = 3] = \"META_TAG\";\n // XML encoding\n ResultType[ResultType[\"XML_ENCODING\"] = 4] = \"XML_ENCODING\";\n // Default\n ResultType[ResultType[\"DEFAULT\"] = 5] = \"DEFAULT\";\n})(ResultType || (ResultType = {}));\nvar AttribType;\n(function (AttribType) {\n AttribType[AttribType[\"None\"] = 0] = \"None\";\n AttribType[AttribType[\"HttpEquiv\"] = 1] = \"HttpEquiv\";\n AttribType[AttribType[\"Content\"] = 2] = \"Content\";\n AttribType[AttribType[\"Charset\"] = 3] = \"Charset\";\n})(AttribType || (AttribType = {}));\nvar Chars;\n(function (Chars) {\n Chars[Chars[\"NIL\"] = 0] = \"NIL\";\n Chars[Chars[\"TAB\"] = 9] = \"TAB\";\n Chars[Chars[\"LF\"] = 10] = \"LF\";\n Chars[Chars[\"CR\"] = 13] = \"CR\";\n Chars[Chars[\"SPACE\"] = 32] = \"SPACE\";\n Chars[Chars[\"EXCLAMATION\"] = 33] = \"EXCLAMATION\";\n Chars[Chars[\"DQUOTE\"] = 34] = \"DQUOTE\";\n Chars[Chars[\"SQUOTE\"] = 39] = \"SQUOTE\";\n Chars[Chars[\"DASH\"] = 45] = \"DASH\";\n Chars[Chars[\"SLASH\"] = 47] = \"SLASH\";\n Chars[Chars[\"SEMICOLON\"] = 59] = \"SEMICOLON\";\n Chars[Chars[\"LT\"] = 60] = \"LT\";\n Chars[Chars[\"EQUALS\"] = 61] = \"EQUALS\";\n Chars[Chars[\"GT\"] = 62] = \"GT\";\n Chars[Chars[\"QUESTION\"] = 63] = \"QUESTION\";\n Chars[Chars[\"UpperA\"] = 65] = \"UpperA\";\n Chars[Chars[\"UpperZ\"] = 90] = \"UpperZ\";\n Chars[Chars[\"LowerA\"] = 97] = \"LowerA\";\n Chars[Chars[\"LowerZ\"] = 122] = \"LowerZ\";\n})(Chars || (Chars = {}));\nconst SPACE_CHARACTERS = new Set([Chars.SPACE, Chars.LF, Chars.CR, Chars.TAB]);\nconst END_OF_UNQUOTED_ATTRIBUTE_VALUE = new Set([\n Chars.SPACE,\n Chars.LF,\n Chars.CR,\n Chars.TAB,\n Chars.GT,\n]);\nfunction toUint8Array(str) {\n const arr = new Uint8Array(str.length);\n for (let i = 0; i < str.length; i++) {\n arr[i] = str.charCodeAt(i);\n }\n return arr;\n}\nconst STRINGS = {\n UTF8_BOM: new Uint8Array([0xef, 0xbb, 0xbf]),\n UTF16LE_BOM: new Uint8Array([0xff, 0xfe]),\n UTF16BE_BOM: new Uint8Array([0xfe, 0xff]),\n UTF16LE_XML_PREFIX: new Uint8Array([0x3c, 0x0, 0x3f, 0x0, 0x78, 0x0]),\n UTF16BE_XML_PREFIX: new Uint8Array([0x0, 0x3c, 0x0, 0x3f, 0x0, 0x78]),\n XML_DECLARATION: toUint8Array(\"<?xml\"),\n ENCODING: toUint8Array(\"encoding\"),\n META: toUint8Array(\"meta\"),\n HTTP_EQUIV: toUint8Array(\"http-equiv\"),\n CONTENT: toUint8Array(\"content\"),\n CONTENT_TYPE: toUint8Array(\"content-type\"),\n CHARSET: toUint8Array(\"charset\"),\n COMMENT_START: toUint8Array(\"<!--\"),\n COMMENT_END: toUint8Array(\"-->\"),\n};\nfunction isAsciiAlpha(c) {\n return ((c >= Chars.UpperA && c <= Chars.UpperZ) ||\n (c >= Chars.LowerA && c <= Chars.LowerZ));\n}\nfunction isQuote(c) {\n return c === Chars.DQUOTE || c === Chars.SQUOTE;\n}\nclass Sniffer {\n setResult(label, type) {\n if (this.resultType === ResultType.DEFAULT || this.resultType > type) {\n const encoding = (0,whatwg_encoding__WEBPACK_IMPORTED_MODULE_0__.labelToName)(label);\n if (encoding) {\n this.encoding =\n // Check if we are in a meta tag and the encoding is `x-user-defined`\n type === ResultType.META_TAG &&\n encoding === \"x-user-defined\"\n ? \"windows-1252\"\n : // Check if we are in a meta tag or xml declaration, and the encoding is UTF-16\n (type === ResultType.META_TAG ||\n type === ResultType.XML_ENCODING) &&\n (encoding === \"UTF-16LE\" || encoding === \"UTF-16BE\")\n ? \"UTF-8\"\n : encoding;\n this.resultType = type;\n }\n }\n }\n constructor({ maxBytes = 1024, userEncoding, transportLayerEncodingLabel, defaultEncoding, } = {}) {\n /** The offset of the previous buffers. */\n this.offset = 0;\n this.state = State.Begin;\n this.sectionIndex = 0;\n this.attribType = AttribType.None;\n /**\n * Indicates if the `http-equiv` is `content-type`.\n *\n * Initially `null`, a boolean when a value is found.\n */\n this.gotPragma = null;\n this.needsPragma = null;\n this.inMetaTag = false;\n this.encoding = \"windows-1252\";\n this.resultType = ResultType.DEFAULT;\n this.quoteCharacter = 0;\n this.attributeValue = [];\n this.maxBytes = maxBytes;\n if (userEncoding) {\n this.setResult(userEncoding, ResultType.PASSED);\n }\n if (transportLayerEncodingLabel) {\n this.setResult(transportLayerEncodingLabel, ResultType.PASSED);\n }\n if (defaultEncoding) {\n this.setResult(defaultEncoding, ResultType.DEFAULT);\n }\n }\n stateBegin(c) {\n switch (c) {\n case STRINGS.UTF16BE_BOM[0]: {\n this.state = State.BOM16BE;\n break;\n }\n case STRINGS.UTF16LE_BOM[0]: {\n this.state = State.BOM16LE;\n break;\n }\n case STRINGS.UTF8_BOM[0]: {\n this.sectionIndex = 1;\n this.state = State.BOM8;\n break;\n }\n case Chars.NIL: {\n this.state = State.UTF16BE_XML_PREFIX;\n this.sectionIndex = 1;\n break;\n }\n case Chars.LT: {\n this.state = State.BeginLT;\n break;\n }\n default: {\n this.state = State.BeforeTag;\n }\n }\n }\n stateBeginLT(c) {\n if (c === Chars.NIL) {\n this.state = State.UTF16LE_XML_PREFIX;\n this.sectionIndex = 2;\n }\n else if (c === Chars.QUESTION) {\n this.state = State.XMLDeclaration;\n this.sectionIndex = 2;\n }\n else {\n this.state = State.BeforeTagName;\n this.stateBeforeTagName(c);\n }\n }\n stateUTF16BE_XML_PREFIX(c) {\n // Advance position in the section\n if (this.advanceSection(STRINGS.UTF16BE_XML_PREFIX, c)) {\n if (this.sectionIndex === STRINGS.UTF16BE_XML_PREFIX.length) {\n // We have the whole prefix\n this.setResult(\"utf-16be\", ResultType.XML_PREFIX);\n }\n }\n else {\n this.state = State.BeforeTag;\n this.stateBeforeTag(c);\n }\n }\n stateUTF16LE_XML_PREFIX(c) {\n // Advance position in the section\n if (this.advanceSection(STRINGS.UTF16LE_XML_PREFIX, c)) {\n if (this.sectionIndex === STRINGS.UTF16LE_XML_PREFIX.length) {\n // We have the whole prefix\n this.setResult(\"utf-16le\", ResultType.XML_PREFIX);\n }\n }\n else {\n this.state = State.BeforeTag;\n this.stateBeforeTag(c);\n }\n }\n stateBOM16LE(c) {\n if (c === STRINGS.UTF16LE_BOM[1]) {\n this.setResult(\"utf-16le\", ResultType.BOM);\n }\n else {\n this.state = State.BeforeTag;\n this.stateBeforeTag(c);\n }\n }\n stateBOM16BE(c) {\n if (c === STRINGS.UTF16BE_BOM[1]) {\n this.setResult(\"utf-16be\", ResultType.BOM);\n }\n else {\n this.state = State.BeforeTag;\n this.stateBeforeTag(c);\n }\n }\n stateBOM8(c) {\n if (this.advanceSection(STRINGS.UTF8_BOM, c) &&\n this.sectionIndex === STRINGS.UTF8_BOM.length) {\n this.setResult(\"utf-8\", ResultType.BOM);\n }\n }\n stateBeforeTag(c) {\n if (c === Chars.LT) {\n this.state = State.BeforeTagName;\n this.inMetaTag = false;\n }\n }\n /**\n * We have seen a `<`, and now have to figure out what to do.\n *\n * Options:\n * - `<meta`\n * - Any other tag\n * - A closing tag\n * - `<!--`\n * - An XML declaration\n *\n */\n stateBeforeTagName(c) {\n if (isAsciiAlpha(c)) {\n if ((c | 0x20) === STRINGS.META[0]) {\n this.sectionIndex = 1;\n this.state = State.TagNameMeta;\n }\n else {\n this.state = State.TagNameOther;\n }\n }\n else\n switch (c) {\n case Chars.SLASH: {\n this.state = State.BeforeCloseTagName;\n break;\n }\n case Chars.EXCLAMATION: {\n this.state = State.CommentStart;\n this.sectionIndex = 2;\n break;\n }\n case Chars.QUESTION: {\n this.state = State.WeirdTag;\n break;\n }\n default: {\n this.state = State.BeforeTag;\n this.stateBeforeTag(c);\n }\n }\n }\n stateBeforeCloseTagName(c) {\n this.state = isAsciiAlpha(c)\n ? // Switch to `TagNameOther`; the HTML spec allows attributes here as well.\n State.TagNameOther\n : State.WeirdTag;\n }\n stateCommentStart(c) {\n if (this.advanceSection(STRINGS.COMMENT_START, c)) {\n if (this.sectionIndex === STRINGS.COMMENT_START.length) {\n this.state = State.CommentEnd;\n // The -- of the comment start can be part of the end.\n this.sectionIndex = 2;\n }\n }\n else {\n this.state = State.WeirdTag;\n this.stateWeirdTag(c);\n }\n }\n stateCommentEnd(c) {\n if (this.advanceSection(STRINGS.COMMENT_END, c)) {\n if (this.sectionIndex === STRINGS.COMMENT_END.length) {\n this.state = State.BeforeTag;\n }\n }\n else if (c === Chars.DASH) {\n /*\n * If we are here, we know we expected a `>` above.\n * Set this to 2, to support many dashes before the closing `>`.\n */\n this.sectionIndex = 2;\n }\n }\n /**\n * Any section starting with `<!`, `<?`, `</`, without being a closing tag or comment.\n */\n stateWeirdTag(c) {\n if (c === Chars.GT) {\n this.state = State.BeforeTag;\n }\n }\n /**\n * Advances the section, ignoring upper/lower case.\n *\n * Make sure the section has left-over characters before calling.\n *\n * @returns `false` if we did not match the section.\n */\n advanceSectionIC(section, c) {\n return this.advanceSection(section, c | 0x20);\n }\n /**\n * Advances the section.\n *\n * Make sure the section has left-over characters before calling.\n *\n * @returns `false` if we did not match the section.\n */\n advanceSection(section, c) {\n if (section[this.sectionIndex] === c) {\n this.sectionIndex++;\n return true;\n }\n this.sectionIndex = 0;\n return false;\n }\n stateTagNameMeta(c) {\n if (this.sectionIndex < STRINGS.META.length) {\n if (this.advanceSectionIC(STRINGS.META, c)) {\n return;\n }\n }\n else if (SPACE_CHARACTERS.has(c)) {\n this.inMetaTag = true;\n this.gotPragma = null;\n this.needsPragma = null;\n this.state = State.BeforeAttribute;\n return;\n }\n this.state = State.TagNameOther;\n // Reconsume in case there is a `>`.\n this.stateTagNameOther(c);\n }\n stateTagNameOther(c) {\n if (SPACE_CHARACTERS.has(c)) {\n this.state = State.BeforeAttribute;\n }\n else if (c === Chars.GT) {\n this.state = State.BeforeTag;\n }\n }\n stateBeforeAttribute(c) {\n if (SPACE_CHARACTERS.has(c))\n return;\n if (this.inMetaTag) {\n const lower = c | 0x20;\n if (lower === STRINGS.HTTP_EQUIV[0]) {\n this.sectionIndex = 1;\n this.state = State.MetaAttribHttpEquiv;\n return;\n }\n else if (lower === STRINGS.CHARSET[0]) {\n this.sectionIndex = 1;\n this.state = State.MetaAttribC;\n return;\n }\n }\n this.state =\n c === Chars.SLASH || c === Chars.GT\n ? State.BeforeTag\n : State.AnyAttribName;\n }\n handleMetaAttrib(c, section, type) {\n if (this.advanceSectionIC(section, c)) {\n if (this.sectionIndex === section.length) {\n this.attribType = type;\n this.state = State.MetaAttribAfterName;\n }\n }\n else {\n this.state = State.AnyAttribName;\n this.stateAnyAttribName(c);\n }\n }\n stateMetaAttribHttpEquiv(c) {\n this.handleMetaAttrib(c, STRINGS.HTTP_EQUIV, AttribType.HttpEquiv);\n }\n stateMetaAttribC(c) {\n const lower = c | 0x20;\n if (lower === STRINGS.CHARSET[1]) {\n this.sectionIndex = 2;\n this.state = State.MetaAttribCharset;\n }\n else if (lower === STRINGS.CONTENT[1]) {\n this.sectionIndex = 2;\n this.state = State.MetaAttribContent;\n }\n else {\n this.state = State.AnyAttribName;\n this.stateAnyAttribName(c);\n }\n }\n stateMetaAttribCharset(c) {\n this.handleMetaAttrib(c, STRINGS.CHARSET, AttribType.Charset);\n }\n stateMetaAttribContent(c) {\n this.handleMetaAttrib(c, STRINGS.CONTENT, AttribType.Content);\n }\n stateMetaAttribAfterName(c) {\n if (SPACE_CHARACTERS.has(c) || c === Chars.EQUALS) {\n this.state = State.AfterAttributeName;\n this.stateAfterAttributeName(c);\n }\n else {\n this.state = State.AnyAttribName;\n this.stateAnyAttribName(c);\n }\n }\n stateAnyAttribName(c) {\n if (SPACE_CHARACTERS.has(c)) {\n this.attribType = AttribType.None;\n this.state = State.AfterAttributeName;\n }\n else if (c === Chars.SLASH || c === Chars.GT) {\n this.state = State.BeforeTag;\n }\n else if (c === Chars.EQUALS) {\n this.state = State.BeforeAttributeValue;\n }\n }\n stateAfterAttributeName(c) {\n if (SPACE_CHARACTERS.has(c))\n return;\n if (c === Chars.EQUALS) {\n this.state = State.BeforeAttributeValue;\n }\n else {\n this.state = State.BeforeAttribute;\n this.stateBeforeAttribute(c);\n }\n }\n stateBeforeAttributeValue(c) {\n if (SPACE_CHARACTERS.has(c))\n return;\n this.attributeValue.length = 0;\n this.sectionIndex = 0;\n if (isQuote(c)) {\n this.quoteCharacter = c;\n this.state =\n this.attribType === AttribType.Content\n ? State.MetaContentValueQuotedBeforeEncoding\n : this.attribType === AttribType.HttpEquiv\n ? State.MetaAttribHttpEquivValue\n : State.AttributeValueQuoted;\n }\n else if (this.attribType === AttribType.Content) {\n this.state = State.MetaContentValueUnquotedBeforeEncoding;\n this.stateMetaContentValueUnquotedBeforeEncoding(c);\n }\n else if (this.attribType === AttribType.HttpEquiv) {\n // We use `quoteCharacter = 0` to signify that the value is unquoted.\n this.quoteCharacter = 0;\n this.sectionIndex = 0;\n this.state = State.MetaAttribHttpEquivValue;\n this.stateMetaAttribHttpEquivValue(c);\n }\n else {\n this.state = State.AttributeValueUnquoted;\n this.stateAttributeValueUnquoted(c);\n }\n }\n // The value has to be `content-type`\n stateMetaAttribHttpEquivValue(c) {\n if (this.sectionIndex === STRINGS.CONTENT_TYPE.length) {\n if (this.quoteCharacter === 0\n ? END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)\n : c === this.quoteCharacter) {\n if (this.needsPragma !== null) {\n this.setResult(this.needsPragma, ResultType.META_TAG);\n }\n else if (this.gotPragma === null) {\n this.gotPragma = true;\n }\n this.state = State.BeforeAttribute;\n return;\n }\n }\n else if (this.advanceSectionIC(STRINGS.CONTENT_TYPE, c)) {\n return;\n }\n this.gotPragma = false;\n if (this.quoteCharacter === 0) {\n this.state = State.AttributeValueUnquoted;\n this.stateAttributeValueUnquoted(c);\n }\n else {\n this.state = State.AttributeValueQuoted;\n this.stateAttributeValueQuoted(c);\n }\n }\n handleMetaContentValue() {\n if (this.attributeValue.length === 0)\n return;\n const encoding = String.fromCharCode(...this.attributeValue);\n if (this.gotPragma) {\n this.setResult(encoding, ResultType.META_TAG);\n }\n else if (this.needsPragma === null) {\n // Don't override a previous result.\n this.needsPragma = encoding;\n }\n this.attributeValue.length = 0;\n }\n handleAttributeValue() {\n if (this.attribType === AttribType.Charset) {\n this.setResult(String.fromCharCode(...this.attributeValue), ResultType.META_TAG);\n }\n }\n stateAttributeValueUnquoted(c) {\n if (SPACE_CHARACTERS.has(c)) {\n this.handleAttributeValue();\n this.state = State.BeforeAttribute;\n }\n else if (c === Chars.SLASH || c === Chars.GT) {\n this.handleAttributeValue();\n this.state = State.BeforeTag;\n }\n else if (this.attribType === AttribType.Charset) {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n findMetaContentEncoding(c) {\n if (this.advanceSectionIC(STRINGS.CHARSET, c)) {\n if (this.sectionIndex === STRINGS.CHARSET.length) {\n return true;\n }\n }\n else {\n // If we encountered another `c`, assume we started over.\n this.sectionIndex = Number(c === STRINGS.CHARSET[0]);\n }\n return false;\n }\n stateMetaContentValueUnquotedBeforeEncoding(c) {\n if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)) {\n this.stateAttributeValueUnquoted(c);\n }\n else if (this.sectionIndex === STRINGS.CHARSET.length) {\n if (c === Chars.EQUALS) {\n this.state = State.MetaContentValueUnquotedBeforeValue;\n }\n }\n else {\n this.findMetaContentEncoding(c);\n }\n }\n stateMetaContentValueUnquotedBeforeValue(c) {\n if (isQuote(c)) {\n this.quoteCharacter = c;\n this.state = State.MetaContentValueUnquotedValueQuoted;\n }\n else if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)) {\n // Can't have spaces here, as it would no longer be part of the attribute value.\n this.stateAttributeValueUnquoted(c);\n }\n else {\n this.state = State.MetaContentValueUnquotedValueUnquoted;\n this.stateMetaContentValueUnquotedValueUnquoted(c);\n }\n }\n stateMetaContentValueUnquotedValueQuoted(c) {\n if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)) {\n // Quotes weren't matched, so we're done.\n this.stateAttributeValueUnquoted(c);\n }\n else if (c === this.quoteCharacter) {\n this.handleMetaContentValue();\n this.state = State.AttributeValueUnquoted;\n }\n else {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n stateMetaContentValueUnquotedValueUnquoted(c) {\n if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c) || c === Chars.SEMICOLON) {\n this.handleMetaContentValue();\n this.state = State.AttributeValueUnquoted;\n this.stateAttributeValueUnquoted(c);\n }\n else {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n stateMetaContentValueQuotedValueUnquoted(c) {\n if (isQuote(c) || SPACE_CHARACTERS.has(c) || c === Chars.SEMICOLON) {\n this.handleMetaContentValue();\n // We are done with the value, but might not be at the end of the attribute\n this.state = State.AttributeValueQuoted;\n this.stateAttributeValueQuoted(c);\n }\n else {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n stateMetaContentValueQuotedValueQuoted(c) {\n if (isQuote(c)) {\n // We have reached the end of our value.\n if (c !== this.quoteCharacter) {\n // Only handle the value if inner quotes were matched.\n this.handleMetaContentValue();\n }\n this.state = State.AttributeValueQuoted;\n this.stateAttributeValueQuoted(c);\n }\n else {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n stateMetaContentValueQuotedBeforeEncoding(c) {\n if (c === this.quoteCharacter) {\n this.stateAttributeValueQuoted(c);\n }\n else if (this.findMetaContentEncoding(c)) {\n this.state = State.MetaContentValueQuotedAfterEncoding;\n }\n }\n stateMetaContentValueQuotedAfterEncoding(c) {\n if (c === Chars.EQUALS) {\n this.state = State.MetaContentValueQuotedBeforeValue;\n }\n else if (!SPACE_CHARACTERS.has(c)) {\n // Look for the next encoding\n this.state = State.MetaContentValueQuotedBeforeEncoding;\n this.stateMetaContentValueQuotedBeforeEncoding(c);\n }\n }\n stateMetaContentValueQuotedBeforeValue(c) {\n if (c === this.quoteCharacter) {\n this.stateAttributeValueQuoted(c);\n }\n else if (isQuote(c)) {\n this.state = State.MetaContentValueQuotedValueQuoted;\n }\n else if (!SPACE_CHARACTERS.has(c)) {\n this.state = State.MetaContentValueQuotedValueUnquoted;\n this.stateMetaContentValueQuotedValueUnquoted(c);\n }\n }\n stateAttributeValueQuoted(c) {\n if (c === this.quoteCharacter) {\n this.handleAttributeValue();\n this.state = State.BeforeAttribute;\n }\n else if (this.attribType === AttribType.Charset) {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n // Read STRINGS.XML_DECLARATION\n stateXMLDeclaration(c) {\n if (this.advanceSection(STRINGS.XML_DECLARATION, c)) {\n if (this.sectionIndex === STRINGS.XML_DECLARATION.length) {\n this.sectionIndex = 0;\n this.state = State.XMLDeclarationBeforeEncoding;\n }\n }\n else {\n this.state = State.WeirdTag;\n }\n }\n stateXMLDeclarationBeforeEncoding(c) {\n if (this.advanceSection(STRINGS.ENCODING, c)) {\n if (this.sectionIndex === STRINGS.ENCODING.length) {\n this.state = State.XMLDeclarationAfterEncoding;\n }\n }\n else if (c === Chars.GT) {\n this.state = State.BeforeTag;\n }\n else {\n // If we encountered another `c`, assume we started over.\n this.sectionIndex = Number(c === STRINGS.ENCODING[0]);\n }\n }\n stateXMLDeclarationAfterEncoding(c) {\n if (c === Chars.EQUALS) {\n this.state = State.XMLDeclarationBeforeValue;\n }\n else if (c > Chars.SPACE) {\n this.state = State.WeirdTag;\n this.stateWeirdTag(c);\n }\n }\n stateXMLDeclarationBeforeValue(c) {\n if (isQuote(c)) {\n this.attributeValue.length = 0;\n this.state = State.XMLDeclarationValue;\n }\n else if (c > Chars.SPACE) {\n this.state = State.WeirdTag;\n this.stateWeirdTag(c);\n }\n }\n stateXMLDeclarationValue(c) {\n if (isQuote(c)) {\n this.setResult(String.fromCharCode(...this.attributeValue), ResultType.XML_ENCODING);\n this.state = State.WeirdTag;\n }\n else if (c === Chars.GT) {\n this.state = State.BeforeTag;\n }\n else if (c <= Chars.SPACE) {\n this.state = State.WeirdTag;\n }\n else {\n this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n }\n }\n write(buffer) {\n let index = 0;\n for (; index < buffer.length && this.offset + index < this.maxBytes; index++) {\n const c = buffer[index];\n switch (this.state) {\n case State.Begin: {\n this.stateBegin(c);\n break;\n }\n case State.BOM16BE: {\n this.stateBOM16BE(c);\n break;\n }\n case State.BOM16LE: {\n this.stateBOM16LE(c);\n break;\n }\n case State.BOM8: {\n this.stateBOM8(c);\n break;\n }\n case State.UTF16LE_XML_PREFIX: {\n this.stateUTF16LE_XML_PREFIX(c);\n break;\n }\n case State.BeginLT: {\n this.stateBeginLT(c);\n break;\n }\n case State.UTF16BE_XML_PREFIX: {\n this.stateUTF16BE_XML_PREFIX(c);\n break;\n }\n case State.BeforeTag: {\n // Optimization: Skip all characters until we find a `<`\n const idx = buffer.indexOf(Chars.LT, index);\n if (idx === -1) {\n // We are done with this buffer. Stay in the state and try on the next one.\n index = buffer.length;\n }\n else {\n index = idx;\n this.stateBeforeTag(Chars.LT);\n }\n break;\n }\n case State.BeforeTagName: {\n this.stateBeforeTagName(c);\n break;\n }\n case State.BeforeCloseTagName: {\n this.stateBeforeCloseTagName(c);\n break;\n }\n case State.CommentStart: {\n this.stateCommentStart(c);\n break;\n }\n case State.CommentEnd: {\n this.stateCommentEnd(c);\n break;\n }\n case State.TagNameMeta: {\n this.stateTagNameMeta(c);\n break;\n }\n case State.TagNameOther: {\n this.stateTagNameOther(c);\n break;\n }\n case State.XMLDeclaration: {\n this.stateXMLDeclaration(c);\n break;\n }\n case State.XMLDeclarationBeforeEncoding: {\n this.stateXMLDeclarationBeforeEncoding(c);\n break;\n }\n case State.XMLDeclarationAfterEncoding: {\n this.stateXMLDeclarationAfterEncoding(c);\n break;\n }\n case State.XMLDeclarationBeforeValue: {\n this.stateXMLDeclarationBeforeValue(c);\n break;\n }\n case State.XMLDeclarationValue: {\n this.stateXMLDeclarationValue(c);\n break;\n }\n case State.WeirdTag: {\n this.stateWeirdTag(c);\n break;\n }\n case State.BeforeAttribute: {\n this.stateBeforeAttribute(c);\n break;\n }\n case State.MetaAttribHttpEquiv: {\n this.stateMetaAttribHttpEquiv(c);\n break;\n }\n case State.MetaAttribHttpEquivValue: {\n this.stateMetaAttribHttpEquivValue(c);\n break;\n }\n case State.MetaAttribC: {\n this.stateMetaAttribC(c);\n break;\n }\n case State.MetaAttribContent: {\n this.stateMetaAttribContent(c);\n break;\n }\n case State.MetaAttribCharset: {\n this.stateMetaAttribCharset(c);\n break;\n }\n case State.MetaAttribAfterName: {\n this.stateMetaAttribAfterName(c);\n break;\n }\n case State.MetaContentValueQuotedBeforeEncoding: {\n this.stateMetaContentValueQuotedBeforeEncoding(c);\n break;\n }\n case State.MetaContentValueQuotedAfterEncoding: {\n this.stateMetaContentValueQuotedAfterEncoding(c);\n break;\n }\n case State.MetaContentValueQuotedBeforeValue: {\n this.stateMetaContentValueQuotedBeforeValue(c);\n break;\n }\n case State.MetaContentValueQuotedValueQuoted: {\n this.stateMetaContentValueQuotedValueQuoted(c);\n break;\n }\n case State.MetaContentValueQuotedValueUnquoted: {\n this.stateMetaContentValueQuotedValueUnquoted(c);\n break;\n }\n case State.MetaContentValueUnquotedBeforeEncoding: {\n this.stateMetaContentValueUnquotedBeforeEncoding(c);\n break;\n }\n case State.MetaContentValueUnquotedBeforeValue: {\n this.stateMetaContentValueUnquotedBeforeValue(c);\n break;\n }\n case State.MetaContentValueUnquotedValueQuoted: {\n this.stateMetaContentValueUnquotedValueQuoted(c);\n break;\n }\n case State.MetaContentValueUnquotedValueUnquoted: {\n this.stateMetaContentValueUnquotedValueUnquoted(c);\n break;\n }\n case State.AnyAttribName: {\n this.stateAnyAttribName(c);\n break;\n }\n case State.AfterAttributeName: {\n this.stateAfterAttributeName(c);\n break;\n }\n case State.BeforeAttributeValue: {\n this.stateBeforeAttributeValue(c);\n break;\n }\n case State.AttributeValueQuoted: {\n this.stateAttributeValueQuoted(c);\n break;\n }\n case State.AttributeValueUnquoted: {\n this.stateAttributeValueUnquoted(c);\n break;\n }\n }\n }\n this.offset += index;\n }\n}\n/** Get the encoding for the passed buffer. */\nfunction getEncoding(buffer, options) {\n const sniffer = new Sniffer(options);\n sniffer.write(buffer);\n return sniffer.encoding;\n}\n//# sourceMappingURL=sniffer.js.map//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(rsc)/./node_modules/encoding-sniffer/dist/esm/sniffer.js","mappings":";;;;;;;;AAA8C;AAC9C;AACA;AACA;AACA,+BAA+B;AAC/B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,sBAAsB;AAChB;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,gCAAgC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,gCAAgC;AACjC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC,sBAAsB;AACvB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,oBAAoB,gBAAgB;AACpC;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA,6BAA6B,4DAAW;AACxC;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,kBAAkB,+EAA+E,IAAI;AACrG;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,2CAA2C;AAC3C;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,eAAe,8DAA8D;AAC7E;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACO;AACP;AACA;AACA;AACA;AACA","sources":["webpack://holiday-deal-finder/./node_modules/encoding-sniffer/dist/esm/sniffer.js?4a62"],"sourcesContent":["import { labelToName } from \"whatwg-encoding\";\n// https://html.spec.whatwg.org/multipage/syntax.html#prescan-a-byte-stream-to-determine-its-encoding\nvar State;\n(function (State) {\n    // Before anything starts; can be any of BOM, UTF-16 XML declarations or meta tags\n    State[State[\"Begin\"] = 0] = \"Begin\";\n    // Inside of a BOM\n    State[State[\"BOM16BE\"] = 1] = \"BOM16BE\";\n    State[State[\"BOM16LE\"] = 2] = \"BOM16LE\";\n    State[State[\"BOM8\"] = 3] = \"BOM8\";\n    // XML prefix\n    State[State[\"UTF16LE_XML_PREFIX\"] = 4] = \"UTF16LE_XML_PREFIX\";\n    State[State[\"BeginLT\"] = 5] = \"BeginLT\";\n    State[State[\"UTF16BE_XML_PREFIX\"] = 6] = \"UTF16BE_XML_PREFIX\";\n    // Waiting for opening `<`\n    State[State[\"BeforeTag\"] = 7] = \"BeforeTag\";\n    // After the opening `<`\n    State[State[\"BeforeTagName\"] = 8] = \"BeforeTagName\";\n    // After `</`\n    State[State[\"BeforeCloseTagName\"] = 9] = \"BeforeCloseTagName\";\n    // Beginning of a comment\n    State[State[\"CommentStart\"] = 10] = \"CommentStart\";\n    // End of a comment\n    State[State[\"CommentEnd\"] = 11] = \"CommentEnd\";\n    // A tag name that could be `meta`\n    State[State[\"TagNameMeta\"] = 12] = \"TagNameMeta\";\n    // A tag name that is not `meta`\n    State[State[\"TagNameOther\"] = 13] = \"TagNameOther\";\n    // XML declaration\n    State[State[\"XMLDeclaration\"] = 14] = \"XMLDeclaration\";\n    State[State[\"XMLDeclarationBeforeEncoding\"] = 15] = \"XMLDeclarationBeforeEncoding\";\n    State[State[\"XMLDeclarationAfterEncoding\"] = 16] = \"XMLDeclarationAfterEncoding\";\n    State[State[\"XMLDeclarationBeforeValue\"] = 17] = \"XMLDeclarationBeforeValue\";\n    State[State[\"XMLDeclarationValue\"] = 18] = \"XMLDeclarationValue\";\n    // Anything that looks like a tag, but doesn't fit in the above categories\n    State[State[\"WeirdTag\"] = 19] = \"WeirdTag\";\n    State[State[\"BeforeAttribute\"] = 20] = \"BeforeAttribute\";\n    /*\n     * Attributes in meta tag — we compare them to our set here, and back out\n     * We care about four attributes: http-equiv, content-type, content, charset\n     */\n    State[State[\"MetaAttribHttpEquiv\"] = 21] = \"MetaAttribHttpEquiv\";\n    // The value has to be `content-type`\n    State[State[\"MetaAttribHttpEquivValue\"] = 22] = \"MetaAttribHttpEquivValue\";\n    State[State[\"MetaAttribC\"] = 23] = \"MetaAttribC\";\n    State[State[\"MetaAttribContent\"] = 24] = \"MetaAttribContent\";\n    State[State[\"MetaAttribCharset\"] = 25] = \"MetaAttribCharset\";\n    // Waiting for whitespace\n    State[State[\"MetaAttribAfterName\"] = 26] = \"MetaAttribAfterName\";\n    State[State[\"MetaContentValueQuotedBeforeEncoding\"] = 27] = \"MetaContentValueQuotedBeforeEncoding\";\n    State[State[\"MetaContentValueQuotedAfterEncoding\"] = 28] = \"MetaContentValueQuotedAfterEncoding\";\n    State[State[\"MetaContentValueQuotedBeforeValue\"] = 29] = \"MetaContentValueQuotedBeforeValue\";\n    State[State[\"MetaContentValueQuotedValueQuoted\"] = 30] = \"MetaContentValueQuotedValueQuoted\";\n    State[State[\"MetaContentValueQuotedValueUnquoted\"] = 31] = \"MetaContentValueQuotedValueUnquoted\";\n    State[State[\"MetaContentValueUnquotedBeforeEncoding\"] = 32] = \"MetaContentValueUnquotedBeforeEncoding\";\n    State[State[\"MetaContentValueUnquotedBeforeValue\"] = 33] = \"MetaContentValueUnquotedBeforeValue\";\n    State[State[\"MetaContentValueUnquotedValueQuoted\"] = 34] = \"MetaContentValueUnquotedValueQuoted\";\n    State[State[\"MetaContentValueUnquotedValueUnquoted\"] = 35] = \"MetaContentValueUnquotedValueUnquoted\";\n    State[State[\"AnyAttribName\"] = 36] = \"AnyAttribName\";\n    // After the name of an attribute, before the equals sign\n    State[State[\"AfterAttributeName\"] = 37] = \"AfterAttributeName\";\n    // After `=`\n    State[State[\"BeforeAttributeValue\"] = 38] = \"BeforeAttributeValue\";\n    State[State[\"AttributeValueQuoted\"] = 39] = \"AttributeValueQuoted\";\n    State[State[\"AttributeValueUnquoted\"] = 40] = \"AttributeValueUnquoted\";\n})(State || (State = {}));\nexport var ResultType;\n(function (ResultType) {\n    // Byte order mark\n    ResultType[ResultType[\"BOM\"] = 0] = \"BOM\";\n    // User- or transport layer-defined\n    ResultType[ResultType[\"PASSED\"] = 1] = \"PASSED\";\n    // XML prefixes\n    ResultType[ResultType[\"XML_PREFIX\"] = 2] = \"XML_PREFIX\";\n    // Meta tag\n    ResultType[ResultType[\"META_TAG\"] = 3] = \"META_TAG\";\n    // XML encoding\n    ResultType[ResultType[\"XML_ENCODING\"] = 4] = \"XML_ENCODING\";\n    // Default\n    ResultType[ResultType[\"DEFAULT\"] = 5] = \"DEFAULT\";\n})(ResultType || (ResultType = {}));\nvar AttribType;\n(function (AttribType) {\n    AttribType[AttribType[\"None\"] = 0] = \"None\";\n    AttribType[AttribType[\"HttpEquiv\"] = 1] = \"HttpEquiv\";\n    AttribType[AttribType[\"Content\"] = 2] = \"Content\";\n    AttribType[AttribType[\"Charset\"] = 3] = \"Charset\";\n})(AttribType || (AttribType = {}));\nvar Chars;\n(function (Chars) {\n    Chars[Chars[\"NIL\"] = 0] = \"NIL\";\n    Chars[Chars[\"TAB\"] = 9] = \"TAB\";\n    Chars[Chars[\"LF\"] = 10] = \"LF\";\n    Chars[Chars[\"CR\"] = 13] = \"CR\";\n    Chars[Chars[\"SPACE\"] = 32] = \"SPACE\";\n    Chars[Chars[\"EXCLAMATION\"] = 33] = \"EXCLAMATION\";\n    Chars[Chars[\"DQUOTE\"] = 34] = \"DQUOTE\";\n    Chars[Chars[\"SQUOTE\"] = 39] = \"SQUOTE\";\n    Chars[Chars[\"DASH\"] = 45] = \"DASH\";\n    Chars[Chars[\"SLASH\"] = 47] = \"SLASH\";\n    Chars[Chars[\"SEMICOLON\"] = 59] = \"SEMICOLON\";\n    Chars[Chars[\"LT\"] = 60] = \"LT\";\n    Chars[Chars[\"EQUALS\"] = 61] = \"EQUALS\";\n    Chars[Chars[\"GT\"] = 62] = \"GT\";\n    Chars[Chars[\"QUESTION\"] = 63] = \"QUESTION\";\n    Chars[Chars[\"UpperA\"] = 65] = \"UpperA\";\n    Chars[Chars[\"UpperZ\"] = 90] = \"UpperZ\";\n    Chars[Chars[\"LowerA\"] = 97] = \"LowerA\";\n    Chars[Chars[\"LowerZ\"] = 122] = \"LowerZ\";\n})(Chars || (Chars = {}));\nconst SPACE_CHARACTERS = new Set([Chars.SPACE, Chars.LF, Chars.CR, Chars.TAB]);\nconst END_OF_UNQUOTED_ATTRIBUTE_VALUE = new Set([\n    Chars.SPACE,\n    Chars.LF,\n    Chars.CR,\n    Chars.TAB,\n    Chars.GT,\n]);\nfunction toUint8Array(str) {\n    const arr = new Uint8Array(str.length);\n    for (let i = 0; i < str.length; i++) {\n        arr[i] = str.charCodeAt(i);\n    }\n    return arr;\n}\nexport const STRINGS = {\n    UTF8_BOM: new Uint8Array([0xef, 0xbb, 0xbf]),\n    UTF16LE_BOM: new Uint8Array([0xff, 0xfe]),\n    UTF16BE_BOM: new Uint8Array([0xfe, 0xff]),\n    UTF16LE_XML_PREFIX: new Uint8Array([0x3c, 0x0, 0x3f, 0x0, 0x78, 0x0]),\n    UTF16BE_XML_PREFIX: new Uint8Array([0x0, 0x3c, 0x0, 0x3f, 0x0, 0x78]),\n    XML_DECLARATION: toUint8Array(\"<?xml\"),\n    ENCODING: toUint8Array(\"encoding\"),\n    META: toUint8Array(\"meta\"),\n    HTTP_EQUIV: toUint8Array(\"http-equiv\"),\n    CONTENT: toUint8Array(\"content\"),\n    CONTENT_TYPE: toUint8Array(\"content-type\"),\n    CHARSET: toUint8Array(\"charset\"),\n    COMMENT_START: toUint8Array(\"<!--\"),\n    COMMENT_END: toUint8Array(\"-->\"),\n};\nfunction isAsciiAlpha(c) {\n    return ((c >= Chars.UpperA && c <= Chars.UpperZ) ||\n        (c >= Chars.LowerA && c <= Chars.LowerZ));\n}\nfunction isQuote(c) {\n    return c === Chars.DQUOTE || c === Chars.SQUOTE;\n}\nexport class Sniffer {\n    setResult(label, type) {\n        if (this.resultType === ResultType.DEFAULT || this.resultType > type) {\n            const encoding = labelToName(label);\n            if (encoding) {\n                this.encoding =\n                    // Check if we are in a meta tag and the encoding is `x-user-defined`\n                    type === ResultType.META_TAG &&\n                        encoding === \"x-user-defined\"\n                        ? \"windows-1252\"\n                        : // Check if we are in a meta tag or xml declaration, and the encoding is UTF-16\n                            (type === ResultType.META_TAG ||\n                                type === ResultType.XML_ENCODING) &&\n                                (encoding === \"UTF-16LE\" || encoding === \"UTF-16BE\")\n                                ? \"UTF-8\"\n                                : encoding;\n                this.resultType = type;\n            }\n        }\n    }\n    constructor({ maxBytes = 1024, userEncoding, transportLayerEncodingLabel, defaultEncoding, } = {}) {\n        /** The offset of the previous buffers. */\n        this.offset = 0;\n        this.state = State.Begin;\n        this.sectionIndex = 0;\n        this.attribType = AttribType.None;\n        /**\n         * Indicates if the `http-equiv` is `content-type`.\n         *\n         * Initially `null`, a boolean when a value is found.\n         */\n        this.gotPragma = null;\n        this.needsPragma = null;\n        this.inMetaTag = false;\n        this.encoding = \"windows-1252\";\n        this.resultType = ResultType.DEFAULT;\n        this.quoteCharacter = 0;\n        this.attributeValue = [];\n        this.maxBytes = maxBytes;\n        if (userEncoding) {\n            this.setResult(userEncoding, ResultType.PASSED);\n        }\n        if (transportLayerEncodingLabel) {\n            this.setResult(transportLayerEncodingLabel, ResultType.PASSED);\n        }\n        if (defaultEncoding) {\n            this.setResult(defaultEncoding, ResultType.DEFAULT);\n        }\n    }\n    stateBegin(c) {\n        switch (c) {\n            case STRINGS.UTF16BE_BOM[0]: {\n                this.state = State.BOM16BE;\n                break;\n            }\n            case STRINGS.UTF16LE_BOM[0]: {\n                this.state = State.BOM16LE;\n                break;\n            }\n            case STRINGS.UTF8_BOM[0]: {\n                this.sectionIndex = 1;\n                this.state = State.BOM8;\n                break;\n            }\n            case Chars.NIL: {\n                this.state = State.UTF16BE_XML_PREFIX;\n                this.sectionIndex = 1;\n                break;\n            }\n            case Chars.LT: {\n                this.state = State.BeginLT;\n                break;\n            }\n            default: {\n                this.state = State.BeforeTag;\n            }\n        }\n    }\n    stateBeginLT(c) {\n        if (c === Chars.NIL) {\n            this.state = State.UTF16LE_XML_PREFIX;\n            this.sectionIndex = 2;\n        }\n        else if (c === Chars.QUESTION) {\n            this.state = State.XMLDeclaration;\n            this.sectionIndex = 2;\n        }\n        else {\n            this.state = State.BeforeTagName;\n            this.stateBeforeTagName(c);\n        }\n    }\n    stateUTF16BE_XML_PREFIX(c) {\n        // Advance position in the section\n        if (this.advanceSection(STRINGS.UTF16BE_XML_PREFIX, c)) {\n            if (this.sectionIndex === STRINGS.UTF16BE_XML_PREFIX.length) {\n                // We have the whole prefix\n                this.setResult(\"utf-16be\", ResultType.XML_PREFIX);\n            }\n        }\n        else {\n            this.state = State.BeforeTag;\n            this.stateBeforeTag(c);\n        }\n    }\n    stateUTF16LE_XML_PREFIX(c) {\n        // Advance position in the section\n        if (this.advanceSection(STRINGS.UTF16LE_XML_PREFIX, c)) {\n            if (this.sectionIndex === STRINGS.UTF16LE_XML_PREFIX.length) {\n                // We have the whole prefix\n                this.setResult(\"utf-16le\", ResultType.XML_PREFIX);\n            }\n        }\n        else {\n            this.state = State.BeforeTag;\n            this.stateBeforeTag(c);\n        }\n    }\n    stateBOM16LE(c) {\n        if (c === STRINGS.UTF16LE_BOM[1]) {\n            this.setResult(\"utf-16le\", ResultType.BOM);\n        }\n        else {\n            this.state = State.BeforeTag;\n            this.stateBeforeTag(c);\n        }\n    }\n    stateBOM16BE(c) {\n        if (c === STRINGS.UTF16BE_BOM[1]) {\n            this.setResult(\"utf-16be\", ResultType.BOM);\n        }\n        else {\n            this.state = State.BeforeTag;\n            this.stateBeforeTag(c);\n        }\n    }\n    stateBOM8(c) {\n        if (this.advanceSection(STRINGS.UTF8_BOM, c) &&\n            this.sectionIndex === STRINGS.UTF8_BOM.length) {\n            this.setResult(\"utf-8\", ResultType.BOM);\n        }\n    }\n    stateBeforeTag(c) {\n        if (c === Chars.LT) {\n            this.state = State.BeforeTagName;\n            this.inMetaTag = false;\n        }\n    }\n    /**\n     * We have seen a `<`, and now have to figure out what to do.\n     *\n     * Options:\n     *  - `<meta`\n     *  - Any other tag\n     *  - A closing tag\n     *  - `<!--`\n     *  - An XML declaration\n     *\n     */\n    stateBeforeTagName(c) {\n        if (isAsciiAlpha(c)) {\n            if ((c | 0x20) === STRINGS.META[0]) {\n                this.sectionIndex = 1;\n                this.state = State.TagNameMeta;\n            }\n            else {\n                this.state = State.TagNameOther;\n            }\n        }\n        else\n            switch (c) {\n                case Chars.SLASH: {\n                    this.state = State.BeforeCloseTagName;\n                    break;\n                }\n                case Chars.EXCLAMATION: {\n                    this.state = State.CommentStart;\n                    this.sectionIndex = 2;\n                    break;\n                }\n                case Chars.QUESTION: {\n                    this.state = State.WeirdTag;\n                    break;\n                }\n                default: {\n                    this.state = State.BeforeTag;\n                    this.stateBeforeTag(c);\n                }\n            }\n    }\n    stateBeforeCloseTagName(c) {\n        this.state = isAsciiAlpha(c)\n            ? // Switch to `TagNameOther`; the HTML spec allows attributes here as well.\n                State.TagNameOther\n            : State.WeirdTag;\n    }\n    stateCommentStart(c) {\n        if (this.advanceSection(STRINGS.COMMENT_START, c)) {\n            if (this.sectionIndex === STRINGS.COMMENT_START.length) {\n                this.state = State.CommentEnd;\n                // The -- of the comment start can be part of the end.\n                this.sectionIndex = 2;\n            }\n        }\n        else {\n            this.state = State.WeirdTag;\n            this.stateWeirdTag(c);\n        }\n    }\n    stateCommentEnd(c) {\n        if (this.advanceSection(STRINGS.COMMENT_END, c)) {\n            if (this.sectionIndex === STRINGS.COMMENT_END.length) {\n                this.state = State.BeforeTag;\n            }\n        }\n        else if (c === Chars.DASH) {\n            /*\n             * If we are here, we know we expected a `>` above.\n             * Set this to 2, to support many dashes before the closing `>`.\n             */\n            this.sectionIndex = 2;\n        }\n    }\n    /**\n     * Any section starting with `<!`, `<?`, `</`, without being a closing tag or comment.\n     */\n    stateWeirdTag(c) {\n        if (c === Chars.GT) {\n            this.state = State.BeforeTag;\n        }\n    }\n    /**\n     * Advances the section, ignoring upper/lower case.\n     *\n     * Make sure the section has left-over characters before calling.\n     *\n     * @returns `false` if we did not match the section.\n     */\n    advanceSectionIC(section, c) {\n        return this.advanceSection(section, c | 0x20);\n    }\n    /**\n     * Advances the section.\n     *\n     * Make sure the section has left-over characters before calling.\n     *\n     * @returns `false` if we did not match the section.\n     */\n    advanceSection(section, c) {\n        if (section[this.sectionIndex] === c) {\n            this.sectionIndex++;\n            return true;\n        }\n        this.sectionIndex = 0;\n        return false;\n    }\n    stateTagNameMeta(c) {\n        if (this.sectionIndex < STRINGS.META.length) {\n            if (this.advanceSectionIC(STRINGS.META, c)) {\n                return;\n            }\n        }\n        else if (SPACE_CHARACTERS.has(c)) {\n            this.inMetaTag = true;\n            this.gotPragma = null;\n            this.needsPragma = null;\n            this.state = State.BeforeAttribute;\n            return;\n        }\n        this.state = State.TagNameOther;\n        // Reconsume in case there is a `>`.\n        this.stateTagNameOther(c);\n    }\n    stateTagNameOther(c) {\n        if (SPACE_CHARACTERS.has(c)) {\n            this.state = State.BeforeAttribute;\n        }\n        else if (c === Chars.GT) {\n            this.state = State.BeforeTag;\n        }\n    }\n    stateBeforeAttribute(c) {\n        if (SPACE_CHARACTERS.has(c))\n            return;\n        if (this.inMetaTag) {\n            const lower = c | 0x20;\n            if (lower === STRINGS.HTTP_EQUIV[0]) {\n                this.sectionIndex = 1;\n                this.state = State.MetaAttribHttpEquiv;\n                return;\n            }\n            else if (lower === STRINGS.CHARSET[0]) {\n                this.sectionIndex = 1;\n                this.state = State.MetaAttribC;\n                return;\n            }\n        }\n        this.state =\n            c === Chars.SLASH || c === Chars.GT\n                ? State.BeforeTag\n                : State.AnyAttribName;\n    }\n    handleMetaAttrib(c, section, type) {\n        if (this.advanceSectionIC(section, c)) {\n            if (this.sectionIndex === section.length) {\n                this.attribType = type;\n                this.state = State.MetaAttribAfterName;\n            }\n        }\n        else {\n            this.state = State.AnyAttribName;\n            this.stateAnyAttribName(c);\n        }\n    }\n    stateMetaAttribHttpEquiv(c) {\n        this.handleMetaAttrib(c, STRINGS.HTTP_EQUIV, AttribType.HttpEquiv);\n    }\n    stateMetaAttribC(c) {\n        const lower = c | 0x20;\n        if (lower === STRINGS.CHARSET[1]) {\n            this.sectionIndex = 2;\n            this.state = State.MetaAttribCharset;\n        }\n        else if (lower === STRINGS.CONTENT[1]) {\n            this.sectionIndex = 2;\n            this.state = State.MetaAttribContent;\n        }\n        else {\n            this.state = State.AnyAttribName;\n            this.stateAnyAttribName(c);\n        }\n    }\n    stateMetaAttribCharset(c) {\n        this.handleMetaAttrib(c, STRINGS.CHARSET, AttribType.Charset);\n    }\n    stateMetaAttribContent(c) {\n        this.handleMetaAttrib(c, STRINGS.CONTENT, AttribType.Content);\n    }\n    stateMetaAttribAfterName(c) {\n        if (SPACE_CHARACTERS.has(c) || c === Chars.EQUALS) {\n            this.state = State.AfterAttributeName;\n            this.stateAfterAttributeName(c);\n        }\n        else {\n            this.state = State.AnyAttribName;\n            this.stateAnyAttribName(c);\n        }\n    }\n    stateAnyAttribName(c) {\n        if (SPACE_CHARACTERS.has(c)) {\n            this.attribType = AttribType.None;\n            this.state = State.AfterAttributeName;\n        }\n        else if (c === Chars.SLASH || c === Chars.GT) {\n            this.state = State.BeforeTag;\n        }\n        else if (c === Chars.EQUALS) {\n            this.state = State.BeforeAttributeValue;\n        }\n    }\n    stateAfterAttributeName(c) {\n        if (SPACE_CHARACTERS.has(c))\n            return;\n        if (c === Chars.EQUALS) {\n            this.state = State.BeforeAttributeValue;\n        }\n        else {\n            this.state = State.BeforeAttribute;\n            this.stateBeforeAttribute(c);\n        }\n    }\n    stateBeforeAttributeValue(c) {\n        if (SPACE_CHARACTERS.has(c))\n            return;\n        this.attributeValue.length = 0;\n        this.sectionIndex = 0;\n        if (isQuote(c)) {\n            this.quoteCharacter = c;\n            this.state =\n                this.attribType === AttribType.Content\n                    ? State.MetaContentValueQuotedBeforeEncoding\n                    : this.attribType === AttribType.HttpEquiv\n                        ? State.MetaAttribHttpEquivValue\n                        : State.AttributeValueQuoted;\n        }\n        else if (this.attribType === AttribType.Content) {\n            this.state = State.MetaContentValueUnquotedBeforeEncoding;\n            this.stateMetaContentValueUnquotedBeforeEncoding(c);\n        }\n        else if (this.attribType === AttribType.HttpEquiv) {\n            // We use `quoteCharacter = 0` to signify that the value is unquoted.\n            this.quoteCharacter = 0;\n            this.sectionIndex = 0;\n            this.state = State.MetaAttribHttpEquivValue;\n            this.stateMetaAttribHttpEquivValue(c);\n        }\n        else {\n            this.state = State.AttributeValueUnquoted;\n            this.stateAttributeValueUnquoted(c);\n        }\n    }\n    // The value has to be `content-type`\n    stateMetaAttribHttpEquivValue(c) {\n        if (this.sectionIndex === STRINGS.CONTENT_TYPE.length) {\n            if (this.quoteCharacter === 0\n                ? END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)\n                : c === this.quoteCharacter) {\n                if (this.needsPragma !== null) {\n                    this.setResult(this.needsPragma, ResultType.META_TAG);\n                }\n                else if (this.gotPragma === null) {\n                    this.gotPragma = true;\n                }\n                this.state = State.BeforeAttribute;\n                return;\n            }\n        }\n        else if (this.advanceSectionIC(STRINGS.CONTENT_TYPE, c)) {\n            return;\n        }\n        this.gotPragma = false;\n        if (this.quoteCharacter === 0) {\n            this.state = State.AttributeValueUnquoted;\n            this.stateAttributeValueUnquoted(c);\n        }\n        else {\n            this.state = State.AttributeValueQuoted;\n            this.stateAttributeValueQuoted(c);\n        }\n    }\n    handleMetaContentValue() {\n        if (this.attributeValue.length === 0)\n            return;\n        const encoding = String.fromCharCode(...this.attributeValue);\n        if (this.gotPragma) {\n            this.setResult(encoding, ResultType.META_TAG);\n        }\n        else if (this.needsPragma === null) {\n            // Don't override a previous result.\n            this.needsPragma = encoding;\n        }\n        this.attributeValue.length = 0;\n    }\n    handleAttributeValue() {\n        if (this.attribType === AttribType.Charset) {\n            this.setResult(String.fromCharCode(...this.attributeValue), ResultType.META_TAG);\n        }\n    }\n    stateAttributeValueUnquoted(c) {\n        if (SPACE_CHARACTERS.has(c)) {\n            this.handleAttributeValue();\n            this.state = State.BeforeAttribute;\n        }\n        else if (c === Chars.SLASH || c === Chars.GT) {\n            this.handleAttributeValue();\n            this.state = State.BeforeTag;\n        }\n        else if (this.attribType === AttribType.Charset) {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    findMetaContentEncoding(c) {\n        if (this.advanceSectionIC(STRINGS.CHARSET, c)) {\n            if (this.sectionIndex === STRINGS.CHARSET.length) {\n                return true;\n            }\n        }\n        else {\n            // If we encountered another `c`, assume we started over.\n            this.sectionIndex = Number(c === STRINGS.CHARSET[0]);\n        }\n        return false;\n    }\n    stateMetaContentValueUnquotedBeforeEncoding(c) {\n        if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)) {\n            this.stateAttributeValueUnquoted(c);\n        }\n        else if (this.sectionIndex === STRINGS.CHARSET.length) {\n            if (c === Chars.EQUALS) {\n                this.state = State.MetaContentValueUnquotedBeforeValue;\n            }\n        }\n        else {\n            this.findMetaContentEncoding(c);\n        }\n    }\n    stateMetaContentValueUnquotedBeforeValue(c) {\n        if (isQuote(c)) {\n            this.quoteCharacter = c;\n            this.state = State.MetaContentValueUnquotedValueQuoted;\n        }\n        else if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)) {\n            // Can't have spaces here, as it would no longer be part of the attribute value.\n            this.stateAttributeValueUnquoted(c);\n        }\n        else {\n            this.state = State.MetaContentValueUnquotedValueUnquoted;\n            this.stateMetaContentValueUnquotedValueUnquoted(c);\n        }\n    }\n    stateMetaContentValueUnquotedValueQuoted(c) {\n        if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c)) {\n            // Quotes weren't matched, so we're done.\n            this.stateAttributeValueUnquoted(c);\n        }\n        else if (c === this.quoteCharacter) {\n            this.handleMetaContentValue();\n            this.state = State.AttributeValueUnquoted;\n        }\n        else {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    stateMetaContentValueUnquotedValueUnquoted(c) {\n        if (END_OF_UNQUOTED_ATTRIBUTE_VALUE.has(c) || c === Chars.SEMICOLON) {\n            this.handleMetaContentValue();\n            this.state = State.AttributeValueUnquoted;\n            this.stateAttributeValueUnquoted(c);\n        }\n        else {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    stateMetaContentValueQuotedValueUnquoted(c) {\n        if (isQuote(c) || SPACE_CHARACTERS.has(c) || c === Chars.SEMICOLON) {\n            this.handleMetaContentValue();\n            // We are done with the value, but might not be at the end of the attribute\n            this.state = State.AttributeValueQuoted;\n            this.stateAttributeValueQuoted(c);\n        }\n        else {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    stateMetaContentValueQuotedValueQuoted(c) {\n        if (isQuote(c)) {\n            // We have reached the end of our value.\n            if (c !== this.quoteCharacter) {\n                // Only handle the value if inner quotes were matched.\n                this.handleMetaContentValue();\n            }\n            this.state = State.AttributeValueQuoted;\n            this.stateAttributeValueQuoted(c);\n        }\n        else {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    stateMetaContentValueQuotedBeforeEncoding(c) {\n        if (c === this.quoteCharacter) {\n            this.stateAttributeValueQuoted(c);\n        }\n        else if (this.findMetaContentEncoding(c)) {\n            this.state = State.MetaContentValueQuotedAfterEncoding;\n        }\n    }\n    stateMetaContentValueQuotedAfterEncoding(c) {\n        if (c === Chars.EQUALS) {\n            this.state = State.MetaContentValueQuotedBeforeValue;\n        }\n        else if (!SPACE_CHARACTERS.has(c)) {\n            // Look for the next encoding\n            this.state = State.MetaContentValueQuotedBeforeEncoding;\n            this.stateMetaContentValueQuotedBeforeEncoding(c);\n        }\n    }\n    stateMetaContentValueQuotedBeforeValue(c) {\n        if (c === this.quoteCharacter) {\n            this.stateAttributeValueQuoted(c);\n        }\n        else if (isQuote(c)) {\n            this.state = State.MetaContentValueQuotedValueQuoted;\n        }\n        else if (!SPACE_CHARACTERS.has(c)) {\n            this.state = State.MetaContentValueQuotedValueUnquoted;\n            this.stateMetaContentValueQuotedValueUnquoted(c);\n        }\n    }\n    stateAttributeValueQuoted(c) {\n        if (c === this.quoteCharacter) {\n            this.handleAttributeValue();\n            this.state = State.BeforeAttribute;\n        }\n        else if (this.attribType === AttribType.Charset) {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    // Read STRINGS.XML_DECLARATION\n    stateXMLDeclaration(c) {\n        if (this.advanceSection(STRINGS.XML_DECLARATION, c)) {\n            if (this.sectionIndex === STRINGS.XML_DECLARATION.length) {\n                this.sectionIndex = 0;\n                this.state = State.XMLDeclarationBeforeEncoding;\n            }\n        }\n        else {\n            this.state = State.WeirdTag;\n        }\n    }\n    stateXMLDeclarationBeforeEncoding(c) {\n        if (this.advanceSection(STRINGS.ENCODING, c)) {\n            if (this.sectionIndex === STRINGS.ENCODING.length) {\n                this.state = State.XMLDeclarationAfterEncoding;\n            }\n        }\n        else if (c === Chars.GT) {\n            this.state = State.BeforeTag;\n        }\n        else {\n            // If we encountered another `c`, assume we started over.\n            this.sectionIndex = Number(c === STRINGS.ENCODING[0]);\n        }\n    }\n    stateXMLDeclarationAfterEncoding(c) {\n        if (c === Chars.EQUALS) {\n            this.state = State.XMLDeclarationBeforeValue;\n        }\n        else if (c > Chars.SPACE) {\n            this.state = State.WeirdTag;\n            this.stateWeirdTag(c);\n        }\n    }\n    stateXMLDeclarationBeforeValue(c) {\n        if (isQuote(c)) {\n            this.attributeValue.length = 0;\n            this.state = State.XMLDeclarationValue;\n        }\n        else if (c > Chars.SPACE) {\n            this.state = State.WeirdTag;\n            this.stateWeirdTag(c);\n        }\n    }\n    stateXMLDeclarationValue(c) {\n        if (isQuote(c)) {\n            this.setResult(String.fromCharCode(...this.attributeValue), ResultType.XML_ENCODING);\n            this.state = State.WeirdTag;\n        }\n        else if (c === Chars.GT) {\n            this.state = State.BeforeTag;\n        }\n        else if (c <= Chars.SPACE) {\n            this.state = State.WeirdTag;\n        }\n        else {\n            this.attributeValue.push(c | (c >= 0x41 && c <= 0x5a ? 0x20 : 0));\n        }\n    }\n    write(buffer) {\n        let index = 0;\n        for (; index < buffer.length && this.offset + index < this.maxBytes; index++) {\n            const c = buffer[index];\n            switch (this.state) {\n                case State.Begin: {\n                    this.stateBegin(c);\n                    break;\n                }\n                case State.BOM16BE: {\n                    this.stateBOM16BE(c);\n                    break;\n                }\n                case State.BOM16LE: {\n                    this.stateBOM16LE(c);\n                    break;\n                }\n                case State.BOM8: {\n                    this.stateBOM8(c);\n                    break;\n                }\n                case State.UTF16LE_XML_PREFIX: {\n                    this.stateUTF16LE_XML_PREFIX(c);\n                    break;\n                }\n                case State.BeginLT: {\n                    this.stateBeginLT(c);\n                    break;\n                }\n                case State.UTF16BE_XML_PREFIX: {\n                    this.stateUTF16BE_XML_PREFIX(c);\n                    break;\n                }\n                case State.BeforeTag: {\n                    // Optimization: Skip all characters until we find a `<`\n                    const idx = buffer.indexOf(Chars.LT, index);\n                    if (idx === -1) {\n                        // We are done with this buffer. Stay in the state and try on the next one.\n                        index = buffer.length;\n                    }\n                    else {\n                        index = idx;\n                        this.stateBeforeTag(Chars.LT);\n                    }\n                    break;\n                }\n                case State.BeforeTagName: {\n                    this.stateBeforeTagName(c);\n                    break;\n                }\n                case State.BeforeCloseTagName: {\n                    this.stateBeforeCloseTagName(c);\n                    break;\n                }\n                case State.CommentStart: {\n                    this.stateCommentStart(c);\n                    break;\n                }\n                case State.CommentEnd: {\n                    this.stateCommentEnd(c);\n                    break;\n                }\n                case State.TagNameMeta: {\n                    this.stateTagNameMeta(c);\n                    break;\n                }\n                case State.TagNameOther: {\n                    this.stateTagNameOther(c);\n                    break;\n                }\n                case State.XMLDeclaration: {\n                    this.stateXMLDeclaration(c);\n                    break;\n                }\n                case State.XMLDeclarationBeforeEncoding: {\n                    this.stateXMLDeclarationBeforeEncoding(c);\n                    break;\n                }\n                case State.XMLDeclarationAfterEncoding: {\n                    this.stateXMLDeclarationAfterEncoding(c);\n                    break;\n                }\n                case State.XMLDeclarationBeforeValue: {\n                    this.stateXMLDeclarationBeforeValue(c);\n                    break;\n                }\n                case State.XMLDeclarationValue: {\n                    this.stateXMLDeclarationValue(c);\n                    break;\n                }\n                case State.WeirdTag: {\n                    this.stateWeirdTag(c);\n                    break;\n                }\n                case State.BeforeAttribute: {\n                    this.stateBeforeAttribute(c);\n                    break;\n                }\n                case State.MetaAttribHttpEquiv: {\n                    this.stateMetaAttribHttpEquiv(c);\n                    break;\n                }\n                case State.MetaAttribHttpEquivValue: {\n                    this.stateMetaAttribHttpEquivValue(c);\n                    break;\n                }\n                case State.MetaAttribC: {\n                    this.stateMetaAttribC(c);\n                    break;\n                }\n                case State.MetaAttribContent: {\n                    this.stateMetaAttribContent(c);\n                    break;\n                }\n                case State.MetaAttribCharset: {\n                    this.stateMetaAttribCharset(c);\n                    break;\n                }\n                case State.MetaAttribAfterName: {\n                    this.stateMetaAttribAfterName(c);\n                    break;\n                }\n                case State.MetaContentValueQuotedBeforeEncoding: {\n                    this.stateMetaContentValueQuotedBeforeEncoding(c);\n                    break;\n                }\n                case State.MetaContentValueQuotedAfterEncoding: {\n                    this.stateMetaContentValueQuotedAfterEncoding(c);\n                    break;\n                }\n                case State.MetaContentValueQuotedBeforeValue: {\n                    this.stateMetaContentValueQuotedBeforeValue(c);\n                    break;\n                }\n                case State.MetaContentValueQuotedValueQuoted: {\n                    this.stateMetaContentValueQuotedValueQuoted(c);\n                    break;\n                }\n                case State.MetaContentValueQuotedValueUnquoted: {\n                    this.stateMetaContentValueQuotedValueUnquoted(c);\n                    break;\n                }\n                case State.MetaContentValueUnquotedBeforeEncoding: {\n                    this.stateMetaContentValueUnquotedBeforeEncoding(c);\n                    break;\n                }\n                case State.MetaContentValueUnquotedBeforeValue: {\n                    this.stateMetaContentValueUnquotedBeforeValue(c);\n                    break;\n                }\n                case State.MetaContentValueUnquotedValueQuoted: {\n                    this.stateMetaContentValueUnquotedValueQuoted(c);\n                    break;\n                }\n                case State.MetaContentValueUnquotedValueUnquoted: {\n                    this.stateMetaContentValueUnquotedValueUnquoted(c);\n                    break;\n                }\n                case State.AnyAttribName: {\n                    this.stateAnyAttribName(c);\n                    break;\n                }\n                case State.AfterAttributeName: {\n                    this.stateAfterAttributeName(c);\n                    break;\n                }\n                case State.BeforeAttributeValue: {\n                    this.stateBeforeAttributeValue(c);\n                    break;\n                }\n                case State.AttributeValueQuoted: {\n                    this.stateAttributeValueQuoted(c);\n                    break;\n                }\n                case State.AttributeValueUnquoted: {\n                    this.stateAttributeValueUnquoted(c);\n                    break;\n                }\n            }\n        }\n        this.offset += index;\n    }\n}\n/** Get the encoding for the passed buffer. */\nexport function getEncoding(buffer, options) {\n    const sniffer = new Sniffer(options);\n    sniffer.write(buffer);\n    return sniffer.encoding;\n}\n//# sourceMappingURL=sniffer.js.map"],"names":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(rsc)/./node_modules/encoding-sniffer/dist/esm/sniffer.js\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |