cindel 1.0.1 → 1.0.3

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.
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../node_modules/picomatch/lib/constants.js", "../node_modules/picomatch/lib/utils.js", "../node_modules/picomatch/lib/scan.js", "../node_modules/picomatch/lib/parse.js", "../node_modules/picomatch/lib/picomatch.js", "../node_modules/picomatch/index.js", "../src/client.js", "../src/client/file-loader.js", "../src/shared/constants.js", "../src/shared/utils.js", "../src/client/hmr-client.js"],
4
- "sourcesContent": ["'use strict';\n\nconst WIN_SLASH = '\\\\\\\\/';\nconst WIN_NO_SLASH = `[^${WIN_SLASH}]`;\n\n/**\n * Posix glob regex\n */\n\nconst DOT_LITERAL = '\\\\.';\nconst PLUS_LITERAL = '\\\\+';\nconst QMARK_LITERAL = '\\\\?';\nconst SLASH_LITERAL = '\\\\/';\nconst ONE_CHAR = '(?=.)';\nconst QMARK = '[^/]';\nconst END_ANCHOR = `(?:${SLASH_LITERAL}|$)`;\nconst START_ANCHOR = `(?:^|${SLASH_LITERAL})`;\nconst DOTS_SLASH = `${DOT_LITERAL}{1,2}${END_ANCHOR}`;\nconst NO_DOT = `(?!${DOT_LITERAL})`;\nconst NO_DOTS = `(?!${START_ANCHOR}${DOTS_SLASH})`;\nconst NO_DOT_SLASH = `(?!${DOT_LITERAL}{0,1}${END_ANCHOR})`;\nconst NO_DOTS_SLASH = `(?!${DOTS_SLASH})`;\nconst QMARK_NO_DOT = `[^.${SLASH_LITERAL}]`;\nconst STAR = `${QMARK}*?`;\nconst SEP = '/';\n\nconst POSIX_CHARS = {\n DOT_LITERAL,\n PLUS_LITERAL,\n QMARK_LITERAL,\n SLASH_LITERAL,\n ONE_CHAR,\n QMARK,\n END_ANCHOR,\n DOTS_SLASH,\n NO_DOT,\n NO_DOTS,\n NO_DOT_SLASH,\n NO_DOTS_SLASH,\n QMARK_NO_DOT,\n STAR,\n START_ANCHOR,\n SEP\n};\n\n/**\n * Windows glob regex\n */\n\nconst WINDOWS_CHARS = {\n ...POSIX_CHARS,\n\n SLASH_LITERAL: `[${WIN_SLASH}]`,\n QMARK: WIN_NO_SLASH,\n STAR: `${WIN_NO_SLASH}*?`,\n DOTS_SLASH: `${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$)`,\n NO_DOT: `(?!${DOT_LITERAL})`,\n NO_DOTS: `(?!(?:^|[${WIN_SLASH}])${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,\n NO_DOT_SLASH: `(?!${DOT_LITERAL}{0,1}(?:[${WIN_SLASH}]|$))`,\n NO_DOTS_SLASH: `(?!${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,\n QMARK_NO_DOT: `[^.${WIN_SLASH}]`,\n START_ANCHOR: `(?:^|[${WIN_SLASH}])`,\n END_ANCHOR: `(?:[${WIN_SLASH}]|$)`,\n SEP: '\\\\'\n};\n\n/**\n * POSIX Bracket Regex\n */\n\nconst POSIX_REGEX_SOURCE = {\n alnum: 'a-zA-Z0-9',\n alpha: 'a-zA-Z',\n ascii: '\\\\x00-\\\\x7F',\n blank: ' \\\\t',\n cntrl: '\\\\x00-\\\\x1F\\\\x7F',\n digit: '0-9',\n graph: '\\\\x21-\\\\x7E',\n lower: 'a-z',\n print: '\\\\x20-\\\\x7E ',\n punct: '\\\\-!\"#$%&\\'()\\\\*+,./:;<=>?@[\\\\]^_`{|}~',\n space: ' \\\\t\\\\r\\\\n\\\\v\\\\f',\n upper: 'A-Z',\n word: 'A-Za-z0-9_',\n xdigit: 'A-Fa-f0-9'\n};\n\nmodule.exports = {\n MAX_LENGTH: 1024 * 64,\n POSIX_REGEX_SOURCE,\n\n // regular expressions\n REGEX_BACKSLASH: /\\\\(?![*+?^${}(|)[\\]])/g,\n REGEX_NON_SPECIAL_CHARS: /^[^@![\\].,$*+?^{}()|\\\\/]+/,\n REGEX_SPECIAL_CHARS: /[-*+?.^${}(|)[\\]]/,\n REGEX_SPECIAL_CHARS_BACKREF: /(\\\\?)((\\W)(\\3*))/g,\n REGEX_SPECIAL_CHARS_GLOBAL: /([-*+?.^${}(|)[\\]])/g,\n REGEX_REMOVE_BACKSLASH: /(?:\\[.*?[^\\\\]\\]|\\\\(?=.))/g,\n\n // Replace globs with equivalent patterns to reduce parsing time.\n REPLACEMENTS: {\n __proto__: null,\n '***': '*',\n '**/**': '**',\n '**/**/**': '**'\n },\n\n // Digits\n CHAR_0: 48, /* 0 */\n CHAR_9: 57, /* 9 */\n\n // Alphabet chars.\n CHAR_UPPERCASE_A: 65, /* A */\n CHAR_LOWERCASE_A: 97, /* a */\n CHAR_UPPERCASE_Z: 90, /* Z */\n CHAR_LOWERCASE_Z: 122, /* z */\n\n CHAR_LEFT_PARENTHESES: 40, /* ( */\n CHAR_RIGHT_PARENTHESES: 41, /* ) */\n\n CHAR_ASTERISK: 42, /* * */\n\n // Non-alphabetic chars.\n CHAR_AMPERSAND: 38, /* & */\n CHAR_AT: 64, /* @ */\n CHAR_BACKWARD_SLASH: 92, /* \\ */\n CHAR_CARRIAGE_RETURN: 13, /* \\r */\n CHAR_CIRCUMFLEX_ACCENT: 94, /* ^ */\n CHAR_COLON: 58, /* : */\n CHAR_COMMA: 44, /* , */\n CHAR_DOT: 46, /* . */\n CHAR_DOUBLE_QUOTE: 34, /* \" */\n CHAR_EQUAL: 61, /* = */\n CHAR_EXCLAMATION_MARK: 33, /* ! */\n CHAR_FORM_FEED: 12, /* \\f */\n CHAR_FORWARD_SLASH: 47, /* / */\n CHAR_GRAVE_ACCENT: 96, /* ` */\n CHAR_HASH: 35, /* # */\n CHAR_HYPHEN_MINUS: 45, /* - */\n CHAR_LEFT_ANGLE_BRACKET: 60, /* < */\n CHAR_LEFT_CURLY_BRACE: 123, /* { */\n CHAR_LEFT_SQUARE_BRACKET: 91, /* [ */\n CHAR_LINE_FEED: 10, /* \\n */\n CHAR_NO_BREAK_SPACE: 160, /* \\u00A0 */\n CHAR_PERCENT: 37, /* % */\n CHAR_PLUS: 43, /* + */\n CHAR_QUESTION_MARK: 63, /* ? */\n CHAR_RIGHT_ANGLE_BRACKET: 62, /* > */\n CHAR_RIGHT_CURLY_BRACE: 125, /* } */\n CHAR_RIGHT_SQUARE_BRACKET: 93, /* ] */\n CHAR_SEMICOLON: 59, /* ; */\n CHAR_SINGLE_QUOTE: 39, /* ' */\n CHAR_SPACE: 32, /* */\n CHAR_TAB: 9, /* \\t */\n CHAR_UNDERSCORE: 95, /* _ */\n CHAR_VERTICAL_LINE: 124, /* | */\n CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279, /* \\uFEFF */\n\n /**\n * Create EXTGLOB_CHARS\n */\n\n extglobChars(chars) {\n return {\n '!': { type: 'negate', open: '(?:(?!(?:', close: `))${chars.STAR})` },\n '?': { type: 'qmark', open: '(?:', close: ')?' },\n '+': { type: 'plus', open: '(?:', close: ')+' },\n '*': { type: 'star', open: '(?:', close: ')*' },\n '@': { type: 'at', open: '(?:', close: ')' }\n };\n },\n\n /**\n * Create GLOB_CHARS\n */\n\n globChars(win32) {\n return win32 === true ? WINDOWS_CHARS : POSIX_CHARS;\n }\n};\n", "/*global navigator*/\n'use strict';\n\nconst {\n REGEX_BACKSLASH,\n REGEX_REMOVE_BACKSLASH,\n REGEX_SPECIAL_CHARS,\n REGEX_SPECIAL_CHARS_GLOBAL\n} = require('./constants');\n\nexports.isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val);\nexports.hasRegexChars = str => REGEX_SPECIAL_CHARS.test(str);\nexports.isRegexChar = str => str.length === 1 && exports.hasRegexChars(str);\nexports.escapeRegex = str => str.replace(REGEX_SPECIAL_CHARS_GLOBAL, '\\\\$1');\nexports.toPosixSlashes = str => str.replace(REGEX_BACKSLASH, '/');\n\nexports.isWindows = () => {\n if (typeof navigator !== 'undefined' && navigator.platform) {\n const platform = navigator.platform.toLowerCase();\n return platform === 'win32' || platform === 'windows';\n }\n\n if (typeof process !== 'undefined' && process.platform) {\n return process.platform === 'win32';\n }\n\n return false;\n};\n\nexports.removeBackslashes = str => {\n return str.replace(REGEX_REMOVE_BACKSLASH, match => {\n return match === '\\\\' ? '' : match;\n });\n};\n\nexports.escapeLast = (input, char, lastIdx) => {\n const idx = input.lastIndexOf(char, lastIdx);\n if (idx === -1) return input;\n if (input[idx - 1] === '\\\\') return exports.escapeLast(input, char, idx - 1);\n return `${input.slice(0, idx)}\\\\${input.slice(idx)}`;\n};\n\nexports.removePrefix = (input, state = {}) => {\n let output = input;\n if (output.startsWith('./')) {\n output = output.slice(2);\n state.prefix = './';\n }\n return output;\n};\n\nexports.wrapOutput = (input, state = {}, options = {}) => {\n const prepend = options.contains ? '' : '^';\n const append = options.contains ? '' : '$';\n\n let output = `${prepend}(?:${input})${append}`;\n if (state.negated === true) {\n output = `(?:^(?!${output}).*$)`;\n }\n return output;\n};\n\nexports.basename = (path, { windows } = {}) => {\n const segs = path.split(windows ? /[\\\\/]/ : '/');\n const last = segs[segs.length - 1];\n\n if (last === '') {\n return segs[segs.length - 2];\n }\n\n return last;\n};\n", "'use strict';\n\nconst utils = require('./utils');\nconst {\n CHAR_ASTERISK, /* * */\n CHAR_AT, /* @ */\n CHAR_BACKWARD_SLASH, /* \\ */\n CHAR_COMMA, /* , */\n CHAR_DOT, /* . */\n CHAR_EXCLAMATION_MARK, /* ! */\n CHAR_FORWARD_SLASH, /* / */\n CHAR_LEFT_CURLY_BRACE, /* { */\n CHAR_LEFT_PARENTHESES, /* ( */\n CHAR_LEFT_SQUARE_BRACKET, /* [ */\n CHAR_PLUS, /* + */\n CHAR_QUESTION_MARK, /* ? */\n CHAR_RIGHT_CURLY_BRACE, /* } */\n CHAR_RIGHT_PARENTHESES, /* ) */\n CHAR_RIGHT_SQUARE_BRACKET /* ] */\n} = require('./constants');\n\nconst isPathSeparator = code => {\n return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH;\n};\n\nconst depth = token => {\n if (token.isPrefix !== true) {\n token.depth = token.isGlobstar ? Infinity : 1;\n }\n};\n\n/**\n * Quickly scans a glob pattern and returns an object with a handful of\n * useful properties, like `isGlob`, `path` (the leading non-glob, if it exists),\n * `glob` (the actual pattern), `negated` (true if the path starts with `!` but not\n * with `!(`) and `negatedExtglob` (true if the path starts with `!(`).\n *\n * ```js\n * const pm = require('picomatch');\n * console.log(pm.scan('foo/bar/*.js'));\n * { isGlob: true, input: 'foo/bar/*.js', base: 'foo/bar', glob: '*.js' }\n * ```\n * @param {String} `str`\n * @param {Object} `options`\n * @return {Object} Returns an object with tokens and regex source string.\n * @api public\n */\n\nconst scan = (input, options) => {\n const opts = options || {};\n\n const length = input.length - 1;\n const scanToEnd = opts.parts === true || opts.scanToEnd === true;\n const slashes = [];\n const tokens = [];\n const parts = [];\n\n let str = input;\n let index = -1;\n let start = 0;\n let lastIndex = 0;\n let isBrace = false;\n let isBracket = false;\n let isGlob = false;\n let isExtglob = false;\n let isGlobstar = false;\n let braceEscaped = false;\n let backslashes = false;\n let negated = false;\n let negatedExtglob = false;\n let finished = false;\n let braces = 0;\n let prev;\n let code;\n let token = { value: '', depth: 0, isGlob: false };\n\n const eos = () => index >= length;\n const peek = () => str.charCodeAt(index + 1);\n const advance = () => {\n prev = code;\n return str.charCodeAt(++index);\n };\n\n while (index < length) {\n code = advance();\n let next;\n\n if (code === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n code = advance();\n\n if (code === CHAR_LEFT_CURLY_BRACE) {\n braceEscaped = true;\n }\n continue;\n }\n\n if (braceEscaped === true || code === CHAR_LEFT_CURLY_BRACE) {\n braces++;\n\n while (eos() !== true && (code = advance())) {\n if (code === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n advance();\n continue;\n }\n\n if (code === CHAR_LEFT_CURLY_BRACE) {\n braces++;\n continue;\n }\n\n if (braceEscaped !== true && code === CHAR_DOT && (code = advance()) === CHAR_DOT) {\n isBrace = token.isBrace = true;\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (braceEscaped !== true && code === CHAR_COMMA) {\n isBrace = token.isBrace = true;\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (code === CHAR_RIGHT_CURLY_BRACE) {\n braces--;\n\n if (braces === 0) {\n braceEscaped = false;\n isBrace = token.isBrace = true;\n finished = true;\n break;\n }\n }\n }\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (code === CHAR_FORWARD_SLASH) {\n slashes.push(index);\n tokens.push(token);\n token = { value: '', depth: 0, isGlob: false };\n\n if (finished === true) continue;\n if (prev === CHAR_DOT && index === (start + 1)) {\n start += 2;\n continue;\n }\n\n lastIndex = index + 1;\n continue;\n }\n\n if (opts.noext !== true) {\n const isExtglobChar = code === CHAR_PLUS\n || code === CHAR_AT\n || code === CHAR_ASTERISK\n || code === CHAR_QUESTION_MARK\n || code === CHAR_EXCLAMATION_MARK;\n\n if (isExtglobChar === true && peek() === CHAR_LEFT_PARENTHESES) {\n isGlob = token.isGlob = true;\n isExtglob = token.isExtglob = true;\n finished = true;\n if (code === CHAR_EXCLAMATION_MARK && index === start) {\n negatedExtglob = true;\n }\n\n if (scanToEnd === true) {\n while (eos() !== true && (code = advance())) {\n if (code === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n code = advance();\n continue;\n }\n\n if (code === CHAR_RIGHT_PARENTHESES) {\n isGlob = token.isGlob = true;\n finished = true;\n break;\n }\n }\n continue;\n }\n break;\n }\n }\n\n if (code === CHAR_ASTERISK) {\n if (prev === CHAR_ASTERISK) isGlobstar = token.isGlobstar = true;\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n break;\n }\n\n if (code === CHAR_QUESTION_MARK) {\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n break;\n }\n\n if (code === CHAR_LEFT_SQUARE_BRACKET) {\n while (eos() !== true && (next = advance())) {\n if (next === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n advance();\n continue;\n }\n\n if (next === CHAR_RIGHT_SQUARE_BRACKET) {\n isBracket = token.isBracket = true;\n isGlob = token.isGlob = true;\n finished = true;\n break;\n }\n }\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (opts.nonegate !== true && code === CHAR_EXCLAMATION_MARK && index === start) {\n negated = token.negated = true;\n start++;\n continue;\n }\n\n if (opts.noparen !== true && code === CHAR_LEFT_PARENTHESES) {\n isGlob = token.isGlob = true;\n\n if (scanToEnd === true) {\n while (eos() !== true && (code = advance())) {\n if (code === CHAR_LEFT_PARENTHESES) {\n backslashes = token.backslashes = true;\n code = advance();\n continue;\n }\n\n if (code === CHAR_RIGHT_PARENTHESES) {\n finished = true;\n break;\n }\n }\n continue;\n }\n break;\n }\n\n if (isGlob === true) {\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n }\n\n if (opts.noext === true) {\n isExtglob = false;\n isGlob = false;\n }\n\n let base = str;\n let prefix = '';\n let glob = '';\n\n if (start > 0) {\n prefix = str.slice(0, start);\n str = str.slice(start);\n lastIndex -= start;\n }\n\n if (base && isGlob === true && lastIndex > 0) {\n base = str.slice(0, lastIndex);\n glob = str.slice(lastIndex);\n } else if (isGlob === true) {\n base = '';\n glob = str;\n } else {\n base = str;\n }\n\n if (base && base !== '' && base !== '/' && base !== str) {\n if (isPathSeparator(base.charCodeAt(base.length - 1))) {\n base = base.slice(0, -1);\n }\n }\n\n if (opts.unescape === true) {\n if (glob) glob = utils.removeBackslashes(glob);\n\n if (base && backslashes === true) {\n base = utils.removeBackslashes(base);\n }\n }\n\n const state = {\n prefix,\n input,\n start,\n base,\n glob,\n isBrace,\n isBracket,\n isGlob,\n isExtglob,\n isGlobstar,\n negated,\n negatedExtglob\n };\n\n if (opts.tokens === true) {\n state.maxDepth = 0;\n if (!isPathSeparator(code)) {\n tokens.push(token);\n }\n state.tokens = tokens;\n }\n\n if (opts.parts === true || opts.tokens === true) {\n let prevIndex;\n\n for (let idx = 0; idx < slashes.length; idx++) {\n const n = prevIndex ? prevIndex + 1 : start;\n const i = slashes[idx];\n const value = input.slice(n, i);\n if (opts.tokens) {\n if (idx === 0 && start !== 0) {\n tokens[idx].isPrefix = true;\n tokens[idx].value = prefix;\n } else {\n tokens[idx].value = value;\n }\n depth(tokens[idx]);\n state.maxDepth += tokens[idx].depth;\n }\n if (idx !== 0 || value !== '') {\n parts.push(value);\n }\n prevIndex = i;\n }\n\n if (prevIndex && prevIndex + 1 < input.length) {\n const value = input.slice(prevIndex + 1);\n parts.push(value);\n\n if (opts.tokens) {\n tokens[tokens.length - 1].value = value;\n depth(tokens[tokens.length - 1]);\n state.maxDepth += tokens[tokens.length - 1].depth;\n }\n }\n\n state.slashes = slashes;\n state.parts = parts;\n }\n\n return state;\n};\n\nmodule.exports = scan;\n", "'use strict';\n\nconst constants = require('./constants');\nconst utils = require('./utils');\n\n/**\n * Constants\n */\n\nconst {\n MAX_LENGTH,\n POSIX_REGEX_SOURCE,\n REGEX_NON_SPECIAL_CHARS,\n REGEX_SPECIAL_CHARS_BACKREF,\n REPLACEMENTS\n} = constants;\n\n/**\n * Helpers\n */\n\nconst expandRange = (args, options) => {\n if (typeof options.expandRange === 'function') {\n return options.expandRange(...args, options);\n }\n\n args.sort();\n const value = `[${args.join('-')}]`;\n\n try {\n /* eslint-disable-next-line no-new */\n new RegExp(value);\n } catch (ex) {\n return args.map(v => utils.escapeRegex(v)).join('..');\n }\n\n return value;\n};\n\n/**\n * Create the message for a syntax error\n */\n\nconst syntaxError = (type, char) => {\n return `Missing ${type}: \"${char}\" - use \"\\\\\\\\${char}\" to match literal characters`;\n};\n\n/**\n * Parse the given input string.\n * @param {String} input\n * @param {Object} options\n * @return {Object}\n */\n\nconst parse = (input, options) => {\n if (typeof input !== 'string') {\n throw new TypeError('Expected a string');\n }\n\n input = REPLACEMENTS[input] || input;\n\n const opts = { ...options };\n const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;\n\n let len = input.length;\n if (len > max) {\n throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);\n }\n\n const bos = { type: 'bos', value: '', output: opts.prepend || '' };\n const tokens = [bos];\n\n const capture = opts.capture ? '' : '?:';\n\n // create constants based on platform, for windows or posix\n const PLATFORM_CHARS = constants.globChars(opts.windows);\n const EXTGLOB_CHARS = constants.extglobChars(PLATFORM_CHARS);\n\n const {\n DOT_LITERAL,\n PLUS_LITERAL,\n SLASH_LITERAL,\n ONE_CHAR,\n DOTS_SLASH,\n NO_DOT,\n NO_DOT_SLASH,\n NO_DOTS_SLASH,\n QMARK,\n QMARK_NO_DOT,\n STAR,\n START_ANCHOR\n } = PLATFORM_CHARS;\n\n const globstar = opts => {\n return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;\n };\n\n const nodot = opts.dot ? '' : NO_DOT;\n const qmarkNoDot = opts.dot ? QMARK : QMARK_NO_DOT;\n let star = opts.bash === true ? globstar(opts) : STAR;\n\n if (opts.capture) {\n star = `(${star})`;\n }\n\n // minimatch options support\n if (typeof opts.noext === 'boolean') {\n opts.noextglob = opts.noext;\n }\n\n const state = {\n input,\n index: -1,\n start: 0,\n dot: opts.dot === true,\n consumed: '',\n output: '',\n prefix: '',\n backtrack: false,\n negated: false,\n brackets: 0,\n braces: 0,\n parens: 0,\n quotes: 0,\n globstar: false,\n tokens\n };\n\n input = utils.removePrefix(input, state);\n len = input.length;\n\n const extglobs = [];\n const braces = [];\n const stack = [];\n let prev = bos;\n let value;\n\n /**\n * Tokenizing helpers\n */\n\n const eos = () => state.index === len - 1;\n const peek = state.peek = (n = 1) => input[state.index + n];\n const advance = state.advance = () => input[++state.index] || '';\n const remaining = () => input.slice(state.index + 1);\n const consume = (value = '', num = 0) => {\n state.consumed += value;\n state.index += num;\n };\n\n const append = token => {\n state.output += token.output != null ? token.output : token.value;\n consume(token.value);\n };\n\n const negate = () => {\n let count = 1;\n\n while (peek() === '!' && (peek(2) !== '(' || peek(3) === '?')) {\n advance();\n state.start++;\n count++;\n }\n\n if (count % 2 === 0) {\n return false;\n }\n\n state.negated = true;\n state.start++;\n return true;\n };\n\n const increment = type => {\n state[type]++;\n stack.push(type);\n };\n\n const decrement = type => {\n state[type]--;\n stack.pop();\n };\n\n /**\n * Push tokens onto the tokens array. This helper speeds up\n * tokenizing by 1) helping us avoid backtracking as much as possible,\n * and 2) helping us avoid creating extra tokens when consecutive\n * characters are plain text. This improves performance and simplifies\n * lookbehinds.\n */\n\n const push = tok => {\n if (prev.type === 'globstar') {\n const isBrace = state.braces > 0 && (tok.type === 'comma' || tok.type === 'brace');\n const isExtglob = tok.extglob === true || (extglobs.length && (tok.type === 'pipe' || tok.type === 'paren'));\n\n if (tok.type !== 'slash' && tok.type !== 'paren' && !isBrace && !isExtglob) {\n state.output = state.output.slice(0, -prev.output.length);\n prev.type = 'star';\n prev.value = '*';\n prev.output = star;\n state.output += prev.output;\n }\n }\n\n if (extglobs.length && tok.type !== 'paren') {\n extglobs[extglobs.length - 1].inner += tok.value;\n }\n\n if (tok.value || tok.output) append(tok);\n if (prev && prev.type === 'text' && tok.type === 'text') {\n prev.output = (prev.output || prev.value) + tok.value;\n prev.value += tok.value;\n return;\n }\n\n tok.prev = prev;\n tokens.push(tok);\n prev = tok;\n };\n\n const extglobOpen = (type, value) => {\n const token = { ...EXTGLOB_CHARS[value], conditions: 1, inner: '' };\n\n token.prev = prev;\n token.parens = state.parens;\n token.output = state.output;\n const output = (opts.capture ? '(' : '') + token.open;\n\n increment('parens');\n push({ type, value, output: state.output ? '' : ONE_CHAR });\n push({ type: 'paren', extglob: true, value: advance(), output });\n extglobs.push(token);\n };\n\n const extglobClose = token => {\n let output = token.close + (opts.capture ? ')' : '');\n let rest;\n\n if (token.type === 'negate') {\n let extglobStar = star;\n\n if (token.inner && token.inner.length > 1 && token.inner.includes('/')) {\n extglobStar = globstar(opts);\n }\n\n if (extglobStar !== star || eos() || /^\\)+$/.test(remaining())) {\n output = token.close = `)$))${extglobStar}`;\n }\n\n if (token.inner.includes('*') && (rest = remaining()) && /^\\.[^\\\\/.]+$/.test(rest)) {\n // Any non-magical string (`.ts`) or even nested expression (`.{ts,tsx}`) can follow after the closing parenthesis.\n // In this case, we need to parse the string and use it in the output of the original pattern.\n // Suitable patterns: `/!(*.d).ts`, `/!(*.d).{ts,tsx}`, `**/!(*-dbg).@(js)`.\n //\n // Disabling the `fastpaths` option due to a problem with parsing strings as `.ts` in the pattern like `**/!(*.d).ts`.\n const expression = parse(rest, { ...options, fastpaths: false }).output;\n\n output = token.close = `)${expression})${extglobStar})`;\n }\n\n if (token.prev.type === 'bos') {\n state.negatedExtglob = true;\n }\n }\n\n push({ type: 'paren', extglob: true, value, output });\n decrement('parens');\n };\n\n /**\n * Fast paths\n */\n\n if (opts.fastpaths !== false && !/(^[*!]|[/()[\\]{}\"])/.test(input)) {\n let backslashes = false;\n\n let output = input.replace(REGEX_SPECIAL_CHARS_BACKREF, (m, esc, chars, first, rest, index) => {\n if (first === '\\\\') {\n backslashes = true;\n return m;\n }\n\n if (first === '?') {\n if (esc) {\n return esc + first + (rest ? QMARK.repeat(rest.length) : '');\n }\n if (index === 0) {\n return qmarkNoDot + (rest ? QMARK.repeat(rest.length) : '');\n }\n return QMARK.repeat(chars.length);\n }\n\n if (first === '.') {\n return DOT_LITERAL.repeat(chars.length);\n }\n\n if (first === '*') {\n if (esc) {\n return esc + first + (rest ? star : '');\n }\n return star;\n }\n return esc ? m : `\\\\${m}`;\n });\n\n if (backslashes === true) {\n if (opts.unescape === true) {\n output = output.replace(/\\\\/g, '');\n } else {\n output = output.replace(/\\\\+/g, m => {\n return m.length % 2 === 0 ? '\\\\\\\\' : (m ? '\\\\' : '');\n });\n }\n }\n\n if (output === input && opts.contains === true) {\n state.output = input;\n return state;\n }\n\n state.output = utils.wrapOutput(output, state, options);\n return state;\n }\n\n /**\n * Tokenize input until we reach end-of-string\n */\n\n while (!eos()) {\n value = advance();\n\n if (value === '\\u0000') {\n continue;\n }\n\n /**\n * Escaped characters\n */\n\n if (value === '\\\\') {\n const next = peek();\n\n if (next === '/' && opts.bash !== true) {\n continue;\n }\n\n if (next === '.' || next === ';') {\n continue;\n }\n\n if (!next) {\n value += '\\\\';\n push({ type: 'text', value });\n continue;\n }\n\n // collapse slashes to reduce potential for exploits\n const match = /^\\\\+/.exec(remaining());\n let slashes = 0;\n\n if (match && match[0].length > 2) {\n slashes = match[0].length;\n state.index += slashes;\n if (slashes % 2 !== 0) {\n value += '\\\\';\n }\n }\n\n if (opts.unescape === true) {\n value = advance();\n } else {\n value += advance();\n }\n\n if (state.brackets === 0) {\n push({ type: 'text', value });\n continue;\n }\n }\n\n /**\n * If we're inside a regex character class, continue\n * until we reach the closing bracket.\n */\n\n if (state.brackets > 0 && (value !== ']' || prev.value === '[' || prev.value === '[^')) {\n if (opts.posix !== false && value === ':') {\n const inner = prev.value.slice(1);\n if (inner.includes('[')) {\n prev.posix = true;\n\n if (inner.includes(':')) {\n const idx = prev.value.lastIndexOf('[');\n const pre = prev.value.slice(0, idx);\n const rest = prev.value.slice(idx + 2);\n const posix = POSIX_REGEX_SOURCE[rest];\n if (posix) {\n prev.value = pre + posix;\n state.backtrack = true;\n advance();\n\n if (!bos.output && tokens.indexOf(prev) === 1) {\n bos.output = ONE_CHAR;\n }\n continue;\n }\n }\n }\n }\n\n if ((value === '[' && peek() !== ':') || (value === '-' && peek() === ']')) {\n value = `\\\\${value}`;\n }\n\n if (value === ']' && (prev.value === '[' || prev.value === '[^')) {\n value = `\\\\${value}`;\n }\n\n if (opts.posix === true && value === '!' && prev.value === '[') {\n value = '^';\n }\n\n prev.value += value;\n append({ value });\n continue;\n }\n\n /**\n * If we're inside a quoted string, continue\n * until we reach the closing double quote.\n */\n\n if (state.quotes === 1 && value !== '\"') {\n value = utils.escapeRegex(value);\n prev.value += value;\n append({ value });\n continue;\n }\n\n /**\n * Double quotes\n */\n\n if (value === '\"') {\n state.quotes = state.quotes === 1 ? 0 : 1;\n if (opts.keepQuotes === true) {\n push({ type: 'text', value });\n }\n continue;\n }\n\n /**\n * Parentheses\n */\n\n if (value === '(') {\n increment('parens');\n push({ type: 'paren', value });\n continue;\n }\n\n if (value === ')') {\n if (state.parens === 0 && opts.strictBrackets === true) {\n throw new SyntaxError(syntaxError('opening', '('));\n }\n\n const extglob = extglobs[extglobs.length - 1];\n if (extglob && state.parens === extglob.parens + 1) {\n extglobClose(extglobs.pop());\n continue;\n }\n\n push({ type: 'paren', value, output: state.parens ? ')' : '\\\\)' });\n decrement('parens');\n continue;\n }\n\n /**\n * Square brackets\n */\n\n if (value === '[') {\n if (opts.nobracket === true || !remaining().includes(']')) {\n if (opts.nobracket !== true && opts.strictBrackets === true) {\n throw new SyntaxError(syntaxError('closing', ']'));\n }\n\n value = `\\\\${value}`;\n } else {\n increment('brackets');\n }\n\n push({ type: 'bracket', value });\n continue;\n }\n\n if (value === ']') {\n if (opts.nobracket === true || (prev && prev.type === 'bracket' && prev.value.length === 1)) {\n push({ type: 'text', value, output: `\\\\${value}` });\n continue;\n }\n\n if (state.brackets === 0) {\n if (opts.strictBrackets === true) {\n throw new SyntaxError(syntaxError('opening', '['));\n }\n\n push({ type: 'text', value, output: `\\\\${value}` });\n continue;\n }\n\n decrement('brackets');\n\n const prevValue = prev.value.slice(1);\n if (prev.posix !== true && prevValue[0] === '^' && !prevValue.includes('/')) {\n value = `/${value}`;\n }\n\n prev.value += value;\n append({ value });\n\n // when literal brackets are explicitly disabled\n // assume we should match with a regex character class\n if (opts.literalBrackets === false || utils.hasRegexChars(prevValue)) {\n continue;\n }\n\n const escaped = utils.escapeRegex(prev.value);\n state.output = state.output.slice(0, -prev.value.length);\n\n // when literal brackets are explicitly enabled\n // assume we should escape the brackets to match literal characters\n if (opts.literalBrackets === true) {\n state.output += escaped;\n prev.value = escaped;\n continue;\n }\n\n // when the user specifies nothing, try to match both\n prev.value = `(${capture}${escaped}|${prev.value})`;\n state.output += prev.value;\n continue;\n }\n\n /**\n * Braces\n */\n\n if (value === '{' && opts.nobrace !== true) {\n increment('braces');\n\n const open = {\n type: 'brace',\n value,\n output: '(',\n outputIndex: state.output.length,\n tokensIndex: state.tokens.length\n };\n\n braces.push(open);\n push(open);\n continue;\n }\n\n if (value === '}') {\n const brace = braces[braces.length - 1];\n\n if (opts.nobrace === true || !brace) {\n push({ type: 'text', value, output: value });\n continue;\n }\n\n let output = ')';\n\n if (brace.dots === true) {\n const arr = tokens.slice();\n const range = [];\n\n for (let i = arr.length - 1; i >= 0; i--) {\n tokens.pop();\n if (arr[i].type === 'brace') {\n break;\n }\n if (arr[i].type !== 'dots') {\n range.unshift(arr[i].value);\n }\n }\n\n output = expandRange(range, opts);\n state.backtrack = true;\n }\n\n if (brace.comma !== true && brace.dots !== true) {\n const out = state.output.slice(0, brace.outputIndex);\n const toks = state.tokens.slice(brace.tokensIndex);\n brace.value = brace.output = '\\\\{';\n value = output = '\\\\}';\n state.output = out;\n for (const t of toks) {\n state.output += (t.output || t.value);\n }\n }\n\n push({ type: 'brace', value, output });\n decrement('braces');\n braces.pop();\n continue;\n }\n\n /**\n * Pipes\n */\n\n if (value === '|') {\n if (extglobs.length > 0) {\n extglobs[extglobs.length - 1].conditions++;\n }\n push({ type: 'text', value });\n continue;\n }\n\n /**\n * Commas\n */\n\n if (value === ',') {\n let output = value;\n\n const brace = braces[braces.length - 1];\n if (brace && stack[stack.length - 1] === 'braces') {\n brace.comma = true;\n output = '|';\n }\n\n push({ type: 'comma', value, output });\n continue;\n }\n\n /**\n * Slashes\n */\n\n if (value === '/') {\n // if the beginning of the glob is \"./\", advance the start\n // to the current index, and don't add the \"./\" characters\n // to the state. This greatly simplifies lookbehinds when\n // checking for BOS characters like \"!\" and \".\" (not \"./\")\n if (prev.type === 'dot' && state.index === state.start + 1) {\n state.start = state.index + 1;\n state.consumed = '';\n state.output = '';\n tokens.pop();\n prev = bos; // reset \"prev\" to the first token\n continue;\n }\n\n push({ type: 'slash', value, output: SLASH_LITERAL });\n continue;\n }\n\n /**\n * Dots\n */\n\n if (value === '.') {\n if (state.braces > 0 && prev.type === 'dot') {\n if (prev.value === '.') prev.output = DOT_LITERAL;\n const brace = braces[braces.length - 1];\n prev.type = 'dots';\n prev.output += value;\n prev.value += value;\n brace.dots = true;\n continue;\n }\n\n if ((state.braces + state.parens) === 0 && prev.type !== 'bos' && prev.type !== 'slash') {\n push({ type: 'text', value, output: DOT_LITERAL });\n continue;\n }\n\n push({ type: 'dot', value, output: DOT_LITERAL });\n continue;\n }\n\n /**\n * Question marks\n */\n\n if (value === '?') {\n const isGroup = prev && prev.value === '(';\n if (!isGroup && opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {\n extglobOpen('qmark', value);\n continue;\n }\n\n if (prev && prev.type === 'paren') {\n const next = peek();\n let output = value;\n\n if ((prev.value === '(' && !/[!=<:]/.test(next)) || (next === '<' && !/<([!=]|\\w+>)/.test(remaining()))) {\n output = `\\\\${value}`;\n }\n\n push({ type: 'text', value, output });\n continue;\n }\n\n if (opts.dot !== true && (prev.type === 'slash' || prev.type === 'bos')) {\n push({ type: 'qmark', value, output: QMARK_NO_DOT });\n continue;\n }\n\n push({ type: 'qmark', value, output: QMARK });\n continue;\n }\n\n /**\n * Exclamation\n */\n\n if (value === '!') {\n if (opts.noextglob !== true && peek() === '(') {\n if (peek(2) !== '?' || !/[!=<:]/.test(peek(3))) {\n extglobOpen('negate', value);\n continue;\n }\n }\n\n if (opts.nonegate !== true && state.index === 0) {\n negate();\n continue;\n }\n }\n\n /**\n * Plus\n */\n\n if (value === '+') {\n if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {\n extglobOpen('plus', value);\n continue;\n }\n\n if ((prev && prev.value === '(') || opts.regex === false) {\n push({ type: 'plus', value, output: PLUS_LITERAL });\n continue;\n }\n\n if ((prev && (prev.type === 'bracket' || prev.type === 'paren' || prev.type === 'brace')) || state.parens > 0) {\n push({ type: 'plus', value });\n continue;\n }\n\n push({ type: 'plus', value: PLUS_LITERAL });\n continue;\n }\n\n /**\n * Plain text\n */\n\n if (value === '@') {\n if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {\n push({ type: 'at', extglob: true, value, output: '' });\n continue;\n }\n\n push({ type: 'text', value });\n continue;\n }\n\n /**\n * Plain text\n */\n\n if (value !== '*') {\n if (value === '$' || value === '^') {\n value = `\\\\${value}`;\n }\n\n const match = REGEX_NON_SPECIAL_CHARS.exec(remaining());\n if (match) {\n value += match[0];\n state.index += match[0].length;\n }\n\n push({ type: 'text', value });\n continue;\n }\n\n /**\n * Stars\n */\n\n if (prev && (prev.type === 'globstar' || prev.star === true)) {\n prev.type = 'star';\n prev.star = true;\n prev.value += value;\n prev.output = star;\n state.backtrack = true;\n state.globstar = true;\n consume(value);\n continue;\n }\n\n let rest = remaining();\n if (opts.noextglob !== true && /^\\([^?]/.test(rest)) {\n extglobOpen('star', value);\n continue;\n }\n\n if (prev.type === 'star') {\n if (opts.noglobstar === true) {\n consume(value);\n continue;\n }\n\n const prior = prev.prev;\n const before = prior.prev;\n const isStart = prior.type === 'slash' || prior.type === 'bos';\n const afterStar = before && (before.type === 'star' || before.type === 'globstar');\n\n if (opts.bash === true && (!isStart || (rest[0] && rest[0] !== '/'))) {\n push({ type: 'star', value, output: '' });\n continue;\n }\n\n const isBrace = state.braces > 0 && (prior.type === 'comma' || prior.type === 'brace');\n const isExtglob = extglobs.length && (prior.type === 'pipe' || prior.type === 'paren');\n if (!isStart && prior.type !== 'paren' && !isBrace && !isExtglob) {\n push({ type: 'star', value, output: '' });\n continue;\n }\n\n // strip consecutive `/**/`\n while (rest.slice(0, 3) === '/**') {\n const after = input[state.index + 4];\n if (after && after !== '/') {\n break;\n }\n rest = rest.slice(3);\n consume('/**', 3);\n }\n\n if (prior.type === 'bos' && eos()) {\n prev.type = 'globstar';\n prev.value += value;\n prev.output = globstar(opts);\n state.output = prev.output;\n state.globstar = true;\n consume(value);\n continue;\n }\n\n if (prior.type === 'slash' && prior.prev.type !== 'bos' && !afterStar && eos()) {\n state.output = state.output.slice(0, -(prior.output + prev.output).length);\n prior.output = `(?:${prior.output}`;\n\n prev.type = 'globstar';\n prev.output = globstar(opts) + (opts.strictSlashes ? ')' : '|$)');\n prev.value += value;\n state.globstar = true;\n state.output += prior.output + prev.output;\n consume(value);\n continue;\n }\n\n if (prior.type === 'slash' && prior.prev.type !== 'bos' && rest[0] === '/') {\n const end = rest[1] !== void 0 ? '|$' : '';\n\n state.output = state.output.slice(0, -(prior.output + prev.output).length);\n prior.output = `(?:${prior.output}`;\n\n prev.type = 'globstar';\n prev.output = `${globstar(opts)}${SLASH_LITERAL}|${SLASH_LITERAL}${end})`;\n prev.value += value;\n\n state.output += prior.output + prev.output;\n state.globstar = true;\n\n consume(value + advance());\n\n push({ type: 'slash', value: '/', output: '' });\n continue;\n }\n\n if (prior.type === 'bos' && rest[0] === '/') {\n prev.type = 'globstar';\n prev.value += value;\n prev.output = `(?:^|${SLASH_LITERAL}|${globstar(opts)}${SLASH_LITERAL})`;\n state.output = prev.output;\n state.globstar = true;\n consume(value + advance());\n push({ type: 'slash', value: '/', output: '' });\n continue;\n }\n\n // remove single star from output\n state.output = state.output.slice(0, -prev.output.length);\n\n // reset previous token to globstar\n prev.type = 'globstar';\n prev.output = globstar(opts);\n prev.value += value;\n\n // reset output with globstar\n state.output += prev.output;\n state.globstar = true;\n consume(value);\n continue;\n }\n\n const token = { type: 'star', value, output: star };\n\n if (opts.bash === true) {\n token.output = '.*?';\n if (prev.type === 'bos' || prev.type === 'slash') {\n token.output = nodot + token.output;\n }\n push(token);\n continue;\n }\n\n if (prev && (prev.type === 'bracket' || prev.type === 'paren') && opts.regex === true) {\n token.output = value;\n push(token);\n continue;\n }\n\n if (state.index === state.start || prev.type === 'slash' || prev.type === 'dot') {\n if (prev.type === 'dot') {\n state.output += NO_DOT_SLASH;\n prev.output += NO_DOT_SLASH;\n\n } else if (opts.dot === true) {\n state.output += NO_DOTS_SLASH;\n prev.output += NO_DOTS_SLASH;\n\n } else {\n state.output += nodot;\n prev.output += nodot;\n }\n\n if (peek() !== '*') {\n state.output += ONE_CHAR;\n prev.output += ONE_CHAR;\n }\n }\n\n push(token);\n }\n\n while (state.brackets > 0) {\n if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ']'));\n state.output = utils.escapeLast(state.output, '[');\n decrement('brackets');\n }\n\n while (state.parens > 0) {\n if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ')'));\n state.output = utils.escapeLast(state.output, '(');\n decrement('parens');\n }\n\n while (state.braces > 0) {\n if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', '}'));\n state.output = utils.escapeLast(state.output, '{');\n decrement('braces');\n }\n\n if (opts.strictSlashes !== true && (prev.type === 'star' || prev.type === 'bracket')) {\n push({ type: 'maybe_slash', value: '', output: `${SLASH_LITERAL}?` });\n }\n\n // rebuild the output if we had to backtrack at any point\n if (state.backtrack === true) {\n state.output = '';\n\n for (const token of state.tokens) {\n state.output += token.output != null ? token.output : token.value;\n\n if (token.suffix) {\n state.output += token.suffix;\n }\n }\n }\n\n return state;\n};\n\n/**\n * Fast paths for creating regular expressions for common glob patterns.\n * This can significantly speed up processing and has very little downside\n * impact when none of the fast paths match.\n */\n\nparse.fastpaths = (input, options) => {\n const opts = { ...options };\n const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;\n const len = input.length;\n if (len > max) {\n throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);\n }\n\n input = REPLACEMENTS[input] || input;\n\n // create constants based on platform, for windows or posix\n const {\n DOT_LITERAL,\n SLASH_LITERAL,\n ONE_CHAR,\n DOTS_SLASH,\n NO_DOT,\n NO_DOTS,\n NO_DOTS_SLASH,\n STAR,\n START_ANCHOR\n } = constants.globChars(opts.windows);\n\n const nodot = opts.dot ? NO_DOTS : NO_DOT;\n const slashDot = opts.dot ? NO_DOTS_SLASH : NO_DOT;\n const capture = opts.capture ? '' : '?:';\n const state = { negated: false, prefix: '' };\n let star = opts.bash === true ? '.*?' : STAR;\n\n if (opts.capture) {\n star = `(${star})`;\n }\n\n const globstar = opts => {\n if (opts.noglobstar === true) return star;\n return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;\n };\n\n const create = str => {\n switch (str) {\n case '*':\n return `${nodot}${ONE_CHAR}${star}`;\n\n case '.*':\n return `${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n case '*.*':\n return `${nodot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n case '*/*':\n return `${nodot}${star}${SLASH_LITERAL}${ONE_CHAR}${slashDot}${star}`;\n\n case '**':\n return nodot + globstar(opts);\n\n case '**/*':\n return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${ONE_CHAR}${star}`;\n\n case '**/*.*':\n return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n case '**/.*':\n return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n default: {\n const match = /^(.*?)\\.(\\w+)$/.exec(str);\n if (!match) return;\n\n const source = create(match[1]);\n if (!source) return;\n\n return source + DOT_LITERAL + match[2];\n }\n }\n };\n\n const output = utils.removePrefix(input, state);\n let source = create(output);\n\n if (source && opts.strictSlashes !== true) {\n source += `${SLASH_LITERAL}?`;\n }\n\n return source;\n};\n\nmodule.exports = parse;\n", "'use strict';\n\nconst scan = require('./scan');\nconst parse = require('./parse');\nconst utils = require('./utils');\nconst constants = require('./constants');\nconst isObject = val => val && typeof val === 'object' && !Array.isArray(val);\n\n/**\n * Creates a matcher function from one or more glob patterns. The\n * returned function takes a string to match as its first argument,\n * and returns true if the string is a match. The returned matcher\n * function also takes a boolean as the second argument that, when true,\n * returns an object with additional information.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch(glob[, options]);\n *\n * const isMatch = picomatch('*.!(*a)');\n * console.log(isMatch('a.a')); //=> false\n * console.log(isMatch('a.b')); //=> true\n * ```\n * @name picomatch\n * @param {String|Array} `globs` One or more glob patterns.\n * @param {Object=} `options`\n * @return {Function=} Returns a matcher function.\n * @api public\n */\n\nconst picomatch = (glob, options, returnState = false) => {\n if (Array.isArray(glob)) {\n const fns = glob.map(input => picomatch(input, options, returnState));\n const arrayMatcher = str => {\n for (const isMatch of fns) {\n const state = isMatch(str);\n if (state) return state;\n }\n return false;\n };\n return arrayMatcher;\n }\n\n const isState = isObject(glob) && glob.tokens && glob.input;\n\n if (glob === '' || (typeof glob !== 'string' && !isState)) {\n throw new TypeError('Expected pattern to be a non-empty string');\n }\n\n const opts = options || {};\n const posix = opts.windows;\n const regex = isState\n ? picomatch.compileRe(glob, options)\n : picomatch.makeRe(glob, options, false, true);\n\n const state = regex.state;\n delete regex.state;\n\n let isIgnored = () => false;\n if (opts.ignore) {\n const ignoreOpts = { ...options, ignore: null, onMatch: null, onResult: null };\n isIgnored = picomatch(opts.ignore, ignoreOpts, returnState);\n }\n\n const matcher = (input, returnObject = false) => {\n const { isMatch, match, output } = picomatch.test(input, regex, options, { glob, posix });\n const result = { glob, state, regex, posix, input, output, match, isMatch };\n\n if (typeof opts.onResult === 'function') {\n opts.onResult(result);\n }\n\n if (isMatch === false) {\n result.isMatch = false;\n return returnObject ? result : false;\n }\n\n if (isIgnored(input)) {\n if (typeof opts.onIgnore === 'function') {\n opts.onIgnore(result);\n }\n result.isMatch = false;\n return returnObject ? result : false;\n }\n\n if (typeof opts.onMatch === 'function') {\n opts.onMatch(result);\n }\n return returnObject ? result : true;\n };\n\n if (returnState) {\n matcher.state = state;\n }\n\n return matcher;\n};\n\n/**\n * Test `input` with the given `regex`. This is used by the main\n * `picomatch()` function to test the input string.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.test(input, regex[, options]);\n *\n * console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\\/([^/]*?))$/));\n * // { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' }\n * ```\n * @param {String} `input` String to test.\n * @param {RegExp} `regex`\n * @return {Object} Returns an object with matching info.\n * @api public\n */\n\npicomatch.test = (input, regex, options, { glob, posix } = {}) => {\n if (typeof input !== 'string') {\n throw new TypeError('Expected input to be a string');\n }\n\n if (input === '') {\n return { isMatch: false, output: '' };\n }\n\n const opts = options || {};\n const format = opts.format || (posix ? utils.toPosixSlashes : null);\n let match = input === glob;\n let output = (match && format) ? format(input) : input;\n\n if (match === false) {\n output = format ? format(input) : input;\n match = output === glob;\n }\n\n if (match === false || opts.capture === true) {\n if (opts.matchBase === true || opts.basename === true) {\n match = picomatch.matchBase(input, regex, options, posix);\n } else {\n match = regex.exec(output);\n }\n }\n\n return { isMatch: Boolean(match), match, output };\n};\n\n/**\n * Match the basename of a filepath.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.matchBase(input, glob[, options]);\n * console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true\n * ```\n * @param {String} `input` String to test.\n * @param {RegExp|String} `glob` Glob pattern or regex created by [.makeRe](#makeRe).\n * @return {Boolean}\n * @api public\n */\n\npicomatch.matchBase = (input, glob, options) => {\n const regex = glob instanceof RegExp ? glob : picomatch.makeRe(glob, options);\n return regex.test(utils.basename(input));\n};\n\n/**\n * Returns true if **any** of the given glob `patterns` match the specified `string`.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.isMatch(string, patterns[, options]);\n *\n * console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true\n * console.log(picomatch.isMatch('a.a', 'b.*')); //=> false\n * ```\n * @param {String|Array} str The string to test.\n * @param {String|Array} patterns One or more glob patterns to use for matching.\n * @param {Object} [options] See available [options](#options).\n * @return {Boolean} Returns true if any patterns match `str`\n * @api public\n */\n\npicomatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str);\n\n/**\n * Parse a glob pattern to create the source string for a regular\n * expression.\n *\n * ```js\n * const picomatch = require('picomatch');\n * const result = picomatch.parse(pattern[, options]);\n * ```\n * @param {String} `pattern`\n * @param {Object} `options`\n * @return {Object} Returns an object with useful properties and output to be used as a regex source string.\n * @api public\n */\n\npicomatch.parse = (pattern, options) => {\n if (Array.isArray(pattern)) return pattern.map(p => picomatch.parse(p, options));\n return parse(pattern, { ...options, fastpaths: false });\n};\n\n/**\n * Scan a glob pattern to separate the pattern into segments.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.scan(input[, options]);\n *\n * const result = picomatch.scan('!./foo/*.js');\n * console.log(result);\n * { prefix: '!./',\n * input: '!./foo/*.js',\n * start: 3,\n * base: 'foo',\n * glob: '*.js',\n * isBrace: false,\n * isBracket: false,\n * isGlob: true,\n * isExtglob: false,\n * isGlobstar: false,\n * negated: true }\n * ```\n * @param {String} `input` Glob pattern to scan.\n * @param {Object} `options`\n * @return {Object} Returns an object with\n * @api public\n */\n\npicomatch.scan = (input, options) => scan(input, options);\n\n/**\n * Compile a regular expression from the `state` object returned by the\n * [parse()](#parse) method.\n *\n * @param {Object} `state`\n * @param {Object} `options`\n * @param {Boolean} `returnOutput` Intended for implementors, this argument allows you to return the raw output from the parser.\n * @param {Boolean} `returnState` Adds the state to a `state` property on the returned regex. Useful for implementors and debugging.\n * @return {RegExp}\n * @api public\n */\n\npicomatch.compileRe = (state, options, returnOutput = false, returnState = false) => {\n if (returnOutput === true) {\n return state.output;\n }\n\n const opts = options || {};\n const prepend = opts.contains ? '' : '^';\n const append = opts.contains ? '' : '$';\n\n let source = `${prepend}(?:${state.output})${append}`;\n if (state && state.negated === true) {\n source = `^(?!${source}).*$`;\n }\n\n const regex = picomatch.toRegex(source, options);\n if (returnState === true) {\n regex.state = state;\n }\n\n return regex;\n};\n\n/**\n * Create a regular expression from a parsed glob pattern.\n *\n * ```js\n * const picomatch = require('picomatch');\n * const state = picomatch.parse('*.js');\n * // picomatch.compileRe(state[, options]);\n *\n * console.log(picomatch.compileRe(state));\n * //=> /^(?:(?!\\.)(?=.)[^/]*?\\.js)$/\n * ```\n * @param {String} `state` The object returned from the `.parse` method.\n * @param {Object} `options`\n * @param {Boolean} `returnOutput` Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result.\n * @param {Boolean} `returnState` Implementors may use this argument to return the state from the parsed glob with the returned regular expression.\n * @return {RegExp} Returns a regex created from the given pattern.\n * @api public\n */\n\npicomatch.makeRe = (input, options = {}, returnOutput = false, returnState = false) => {\n if (!input || typeof input !== 'string') {\n throw new TypeError('Expected a non-empty string');\n }\n\n let parsed = { negated: false, fastpaths: true };\n\n if (options.fastpaths !== false && (input[0] === '.' || input[0] === '*')) {\n parsed.output = parse.fastpaths(input, options);\n }\n\n if (!parsed.output) {\n parsed = parse(input, options);\n }\n\n return picomatch.compileRe(parsed, options, returnOutput, returnState);\n};\n\n/**\n * Create a regular expression from the given regex source string.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.toRegex(source[, options]);\n *\n * const { output } = picomatch.parse('*.js');\n * console.log(picomatch.toRegex(output));\n * //=> /^(?:(?!\\.)(?=.)[^/]*?\\.js)$/\n * ```\n * @param {String} `source` Regular expression source string.\n * @param {Object} `options`\n * @return {RegExp}\n * @api public\n */\n\npicomatch.toRegex = (source, options) => {\n try {\n const opts = options || {};\n return new RegExp(source, opts.flags || (opts.nocase ? 'i' : ''));\n } catch (err) {\n if (options && options.debug === true) throw err;\n return /$^/;\n }\n};\n\n/**\n * Picomatch constants.\n * @return {Object}\n */\n\npicomatch.constants = constants;\n\n/**\n * Expose \"picomatch\"\n */\n\nmodule.exports = picomatch;\n", "'use strict';\n\nconst pico = require('./lib/picomatch');\nconst utils = require('./lib/utils');\n\nfunction picomatch(glob, options, returnState = false) {\n // default to os.platform()\n if (options && (options.windows === null || options.windows === undefined)) {\n // don't mutate the original options object\n options = { ...options, windows: utils.isWindows() };\n }\n\n return pico(glob, options, returnState);\n}\n\nObject.assign(picomatch, pico);\nmodule.exports = picomatch;\n", "export { HMRClient as default, HMRClient } from './client/hmr-client.js';\nexport { FileLoader } from './client/file-loader.js';", "/** Handles loading and hot reloading of JavaScript and CSS files via blob URLs. */\nexport class FileLoader {\n constructor(httpUrl) {\n this.httpUrl = httpUrl;\n /**\n * Debounce state per file. Stores { timeout, resolvers[] } so that\n * when a rapid second change clears the first timeout, the first\n * caller's Promise still resolves with the final load result.\n * @type {Map<string, { timeout: number, resolvers: Function[] }>}\n */\n this.loadQueue = new Map();\n /**\n * Load counter per file used for cache busting.\n * Produces short URLs like Logger.js?v=3 which keeps\n * browser stack traces readable.\n * @type {Map<string, number>}\n */\n this.versions = new Map();\n }\n\n async loadFile(path) {\n const isCSS = path.endsWith('.css');\n const isModule = path.endsWith('.mjs');\n\n if (isCSS) return await this.loadCSS(path);\n if (isModule) return await this.loadModule(path);\n return await this.loadScript(path);\n }\n\n // Load CSS atomically: append new <link>, wait for it to load, then remove\n // the old one. This fixes the brief flash of unstyled content that\n // happens when you remove the old sheet before the new one is parsed.\n async loadCSS(path) {\n const existing = document.querySelector(`link[data-file=\"${path}\"]`);\n const url = this.makeUrl(path);\n\n const link = document.createElement('link');\n link.rel = 'stylesheet';\n link.href = url;\n link.setAttribute('data-file', path);\n\n return new Promise((resolve, reject) => {\n link.onload = () => {\n if (existing) existing.remove();\n resolve(true);\n };\n link.onerror = () => {\n link.remove();\n reject(new Error(`Failed to load CSS: ${path}`));\n };\n document.head.appendChild(link);\n });\n }\n\n async loadModule(path) {\n const url = this.makeUrl(path);\n await import(url);\n return true;\n }\n\n async loadScript(path) {\n const url = this.makeUrl(path);\n\n const existing = document.querySelector(`script[data-file=\"${path}\"]`);\n if (existing) existing.remove();\n\n const script = document.createElement('script');\n script.src = url;\n script.setAttribute('data-file', path);\n\n return new Promise((resolve, reject) => {\n script.onload = () => resolve(true);\n script.onerror = () => reject(new Error(`Failed to load script: ${path}`));\n document.head.appendChild(script);\n });\n }\n\n // Debounce reloads within 100ms.\n // Calls in the same window share a single load and all receive the result.\n // Fixes prior behavior where only the last caller's Promise resolved.\n async reloadFile(path) {\n return new Promise((resolve, reject) => {\n if (this.loadQueue.has(path)) {\n const entry = this.loadQueue.get(path);\n clearTimeout(entry.timeout);\n entry.resolvers.push({ resolve, reject });\n entry.timeout = setTimeout(() => this._flushReload(path), 100);\n } else {\n const entry = {\n timeout: setTimeout(() => this._flushReload(path), 100),\n resolvers: [{ resolve, reject }]\n };\n this.loadQueue.set(path, entry);\n }\n });\n }\n\n async _flushReload(path) {\n const entry = this.loadQueue.get(path);\n this.loadQueue.delete(path);\n\n try {\n const success = await this.loadFile(path);\n for (const { resolve } of entry.resolvers) resolve(success);\n } catch (e) {\n for (const { reject } of entry.resolvers) reject(e);\n }\n }\n\n async removeFile(path) {\n // Cancel any pending reload debounce for this file\n if (this.loadQueue.has(path)) {\n const entry = this.loadQueue.get(path);\n clearTimeout(entry.timeout);\n for (const { reject } of entry.resolvers) reject(new Error(`File removed: ${path}`));\n this.loadQueue.delete(path);\n }\n\n const el = document.querySelector(`[data-file=\"${path}\"]`);\n if (el) {\n el.remove();\n await new Promise(r => setTimeout(r, 0));\n }\n\n // Reset version so the next load starts from v=1 again\n this.versions.delete(path);\n }\n\n // Increment the version counter for individual files and return a versioned URL\n makeUrl(path) {\n const v = (this.versions.get(path) ?? 0) + 1;\n this.versions.set(path, v);\n return `${this.httpUrl}${path}?v=${v}`;\n }\n}", "export const DEFAULT_PORT = 1338;\nexport const WATCHABLE_EXTENSIONS = ['.js', '.cjs', '.mjs', '.css'];\n\nexport const DEFAULT_FILES_ENDPOINT = '/files'\nexport const DEFAULT_CONFIG_ENDPOINT = '/config'\n\nexport const DEFAULT_CORS_PROXY_PATH = '/proxy';\nexport const DEFAULT_WS_PROXY_PATH = '/proxy';\n\nexport const WATCHER_CONFIG = {\n persistent: true,\n ignoreInitial: true,\n awaitWriteFinish: {\n stabilityThreshold: 50,\n pollInterval: 10\n },\n usePolling: false,\n alwaysStat: true,\n atomic: false\n};\n\nexport const HMR_ACTIONS = {\n RELOAD: 'reload',\n ADD: 'add',\n REMOVE: 'remove',\n INIT: 'init'\n};", "import picomatch from 'picomatch';\n\n// Cache compiled matchers so same patterns aren't recompiled on every call\nconst matcherCache = new Map();\n\nexport function matchGlob(file, patterns) {\n return patterns.some(pattern => {\n if (!matcherCache.has(pattern)) matcherCache.set(pattern, picomatch(pattern));\n return matcherCache.get(pattern)(file);\n });\n}\n\nexport function formatTime() {\n return new Date().toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit'\n });\n}\n\nexport function getBrowserFromUA(userAgent) {\n if (!userAgent) return 'Unknown';\n\n if (userAgent.includes('Chrome/')) return 'Chrome';\n if (userAgent.includes('Firefox/')) return 'Firefox';\n if (userAgent.includes('Safari/') && !userAgent.includes('Chrome/')) return 'Safari';\n if (userAgent.includes('Edge/')) return 'Edge';\n if (userAgent.includes('Opera/') || userAgent.includes('OPR/')) return 'Opera';\n\n return 'Unknown';\n}\n\nexport function getFileName(path) {\n return path.split('/').pop();\n}\n\nexport function getFilePath(path) {\n const parts = path.split('/');\n parts.pop();\n return parts.join('/') || '.';\n}\n\nexport function normalizeUrl(url) {\n return url.endsWith('/') ? url : url + '/';\n}\n\nexport function normalizeProxyPath(path, defaultPath) {\n return (path || defaultPath).replace(/^(?!\\/)/, '/').replace(/\\/+$/, '');\n}\n\nexport function resolveEndpoint(value, defaultPath) {\n if (!value) return null;\n if (value === true) return defaultPath;\n return value.startsWith('/') ? value : `/${value}`;\n}\n\n/**\n * Resolve HMR connection URLs from various input formats\n * @param {string|number|Object} options - Connection options\n * @returns {{ wsUrl: string, httpUrl: string }}\n * \n * @example\n * resolveConnectionUrls(1338)\n * // => { wsUrl: 'ws://localhost:1338', httpUrl: 'http://localhost:1338/' }\n * \n * @example\n * resolveConnectionUrls('ws://192.168.1.100:1338')\n * // => { wsUrl: 'ws://192.168.1.100:1338', httpUrl: 'http://192.168.1.100:1338/' }\n * \n * @example\n * resolveConnectionUrls({ host: 'dev.example.com', port: 1338, secure: true })\n * // => { wsUrl: 'wss://dev.example.com:1338', httpUrl: 'https://dev.example.com:1338/' }\n */\nfunction wsUrlToHttpUrl(wsUrl) {\n const u = new URL(wsUrl);\n return `${u.protocol === 'wss:' ? 'https' : 'http'}://${u.host}/`;\n}\n\nfunction httpUrlToWsUrl(httpUrl, wsPath) {\n const u = new URL(httpUrl);\n return `${u.protocol === 'https:' ? 'wss' : 'ws'}://${u.host}${wsPath}`;\n}\n\nexport function resolveConnectionUrls(options, wsPath = '/hmr') {\n if (typeof options === 'string') {\n return { wsUrl: options, httpUrl: wsUrlToHttpUrl(options) };\n }\n\n if (typeof options === 'number') {\n options = { port: options };\n }\n\n if (typeof options !== 'object' || options === null) {\n throw new Error('Options must be a string, number, or object');\n }\n\n if (options.wsUrl && options.httpUrl) {\n return { wsUrl: options.wsUrl, httpUrl: normalizeUrl(options.httpUrl) };\n }\n\n if (options.wsUrl) {\n return { wsUrl: options.wsUrl, httpUrl: wsUrlToHttpUrl(options.wsUrl) };\n }\n\n if (options.httpUrl) {\n const httpUrl = normalizeUrl(options.httpUrl);\n return { wsUrl: httpUrlToWsUrl(httpUrl, wsPath), httpUrl };\n }\n\n if (options.port) {\n const host = options.host || 'localhost';\n const secure = options.secure || false;\n const wsProtocol = secure ? 'wss' : 'ws';\n const httpProtocol = secure ? 'https' : 'http';\n\n const wsUrl = `${wsProtocol}://${host}:${options.port}${wsPath}`;\n const httpUrl = normalizeUrl(`${httpProtocol}://${host}:${options.port}`);\n\n return { wsUrl, httpUrl };\n }\n\n throw new Error('Must provide wsUrl, httpUrl, port, or host+port');\n}", "import { FileLoader } from './file-loader.js';\nimport { HMR_ACTIONS } from '../shared/constants.js'\nimport { matchGlob, getFileName, getFilePath, formatTime, resolveConnectionUrls } from './../shared/utils.js';\n\n/**\n * HMR client with baked-in file loading, override detection, and cold file handling.\n * \n * @example\n * // Simple setup\n * const client = new HMRClient({\n * port: 1338,\n * skip: ['_*\\/**'],\n * cold: ['**\\/*.cold.js'],\n * onFileLoaded: (file) => swapPrototype(file)\n * });\n * \n * @example\n * // With override detection\n * const client = new HMRClient({\n * port: 1338,\n * getOverrideTarget: (file, allFiles) => {\n * const m = file.match(/^x_[^/]+\\/overrides\\/(.+)$/);\n * if (!m) return null;\n * const core = `core/${m[1]}`;\n * return allFiles?.includes(core) ? core : null;\n * }\n * });\n */\nexport class HMRClient {\n /**\n * `options` can be a shorthand or a full config object:\n * - **number** treated as `{ port: n }`, connects to `ws://localhost:<n>`\n * - **string** treated as a full WebSocket URL\n * - **object** full config, see below\n *\n * @param {Object} options - setting options jsdoc to `Object` only for the sake of auto complete.\n * @param {string} [options.wsUrl] - Explicit WebSocket URL. Takes priority over host/port.\n * @param {string} [options.httpUrl] - Explicit HTTP base URL for fetching files. Derived from `wsUrl` if omitted.\n * @param {boolean} [options.watchFiles=true] Server side file watching is enabled by default.\n * @param {string} [options.host='localhost'] - Hostname (used when building from `port`)\n * @param {number} [options.port] - Port number\n * @param {boolean} [options.secure=false] - Use `wss://` and `https://`\n * @param {boolean} [options.autoReconnect=true] - Reconnect on disconnect with exponential backoff.\n * @param {number} [options.reconnectDelay=2000] - Base reconnect delay in ms\n * @param {number} [options.maxReconnectDelay=30000] - Maximum reconnect delay cap in ms\n * @param {boolean} [options.skipOnReconnect=true] - Skip files already present in the page on reconnect, preventing them from being loaded again.\n * @param {string[]} [options.skip] - Glob patterns for files that should never be loaded (e.g. `['_*\\/**']`)\n * @param {function(string, string[]): boolean} [options.filterSkip] - Custom skip logic. Receives `(filePath, allFiles)`. Combined with `skip` via OR.\n * @param {string[]} [options.cold] - Glob patterns for files that require a full page reload. Merged with the server's `cold` config on connect. A `cold` event is emitted instead of hot reloading.\n * @param {function(string): boolean} [options.filterCold] - Custom cold file logic. Receives `(filePath)`. Combined with `cold` via OR.\n * @param {function(string, string[]): string|null} [options.getOverrideTarget] - Given a changed file, return the path of the original it replaces, or `null`. Receives `(filePath, allFiles)`. When matched, the original is unloaded before the override loads.\n * @param {function(string): void} [options.onFileLoaded] - Called after each file loads or reloads. Receives `(filePath)`.\n * @param {function(string[]): string[]} [options.sortFiles] - Custom sort for the initial file load order. Default sorts CSS before JS, cold files first.\n */\n constructor(options) {\n // Extract additional options if object was passed\n const opts = typeof options === 'object' && !Array.isArray(options) ? options : {};\n\n const wsPath = opts.wsPath || '/hmr';\n const { wsUrl, httpUrl } = resolveConnectionUrls(options, wsPath);\n this.wsUrl = wsUrl;\n this.httpUrl = httpUrl;\n this.watchFiles = true;\n\n this._autoReconnectDefault = opts.autoReconnect !== false;\n this.autoReconnect = this._autoReconnectDefault;\n this.reconnectDelay = opts.reconnectDelay || 2000;\n this.maxReconnectDelay = opts.maxReconnectDelay || 30000;\n this.skipOnReconnect = opts.skipOnReconnect !== false;\n\n // Store original cold config so we can merge server patterns on connect\n this._coldPatterns = opts.cold || null;\n this._filterCold = opts.filterCold || null;\n\n // Create normalized filter functions\n this.shouldSkipFile = this.makeFilter(opts.skip || null, opts.filterSkip || null);\n this.isColdFile = this.makeFilter(this._coldPatterns, this._filterCold);\n\n // Tracks the current set of watched files (seeded on init, updated on add/remove)\n this.allFiles = [];\n\n this.getOverrideTarget = opts.getOverrideTarget || null;\n this.onFileLoaded = opts.onFileLoaded || null;\n this.sortFiles = opts.sortFiles || this.defaultSortFiles.bind(this);\n\n this.socket = null;\n this.reconnectAttempts = 0;\n this.isConnected = false;\n this.eventHandlers = new Map();\n this._reconnectTimer = null;\n\n // Serialized message processing, this prevents concurrent handleMessage calls\n // from racing when two WS messages arrive before the first async chain completes.\n this._messageQueue = [];\n this._processingMessages = false;\n\n this.fileLoader = new FileLoader(this.httpUrl);\n\n /** @type {Map<string, string>} - Maps override file -> original file */\n this.overrideMap = new Map();\n /** @type {Map<string, Set<string>>} - Maps original file -> set of active overrides */\n this._reverseOverrideMap = new Map();\n\n this.logStyles = {\n info: { symbol: '\u2139', color: '#76fffd' },\n success: { symbol: '\u25B6', color: '#68ff51' },\n warning: { symbol: '\u232C', color: '#ff8400' },\n error: { symbol: '\u2716', color: '#ff0000' },\n add: { symbol: '\u2295', color: '#22c55e' },\n remove: { symbol: '\u2296', color: '#f87171' },\n inject: { symbol: '\u2398', color: '#facc15' },\n disconnect: { symbol: '\u2726', color: '#ef4444' },\n override: { symbol: '\u29EB', color: '#ff8400' },\n skip: { symbol: '\u2298', color: '#888888' },\n cold: { symbol: '\u2744', color: '#60a5fa' }\n };\n }\n\n defaultSortFiles(files) {\n const coldSet = new Set(files.filter(f => this.isColdFile(f)));\n return [...files].sort((a, b) => {\n const aIsCSS = a.endsWith('.css');\n const bIsCSS = b.endsWith('.css');\n\n // CSS always before JS, regardless of cold status\n if (aIsCSS && !bIsCSS) return -1;\n if (!aIsCSS && bIsCSS) return 1;\n\n // Within the same extension group: cold files first\n const coldA = coldSet.has(a);\n const coldB = coldSet.has(b);\n if (coldA && !coldB) return -1;\n if (!coldA && coldB) return 1;\n\n // Alphabetical as tiebreaker\n return a.localeCompare(b);\n });\n }\n\n makeFilter(patterns, callback) {\n // If both provided, combine them with OR logic\n if (patterns && callback) {\n return (file, allFiles) => {\n return matchGlob(file, patterns) || callback(file, allFiles);\n };\n }\n if (patterns) {\n return (file) => matchGlob(file, patterns);\n }\n if (callback) {\n return callback;\n }\n return () => false;\n }\n\n log(type, message) {\n const { symbol, color } = this.logStyles[type] || this.logStyles.info;\n const time = formatTime();\n console.log(`%c${symbol} [${time}] ${message}`, `color: ${color}; font-weight: bold;`);\n }\n\n logInitFileGroup(files, overrideMap, isColdFile) {\n if (!files.length) return;\n\n const overrideCount = files.filter(f => overrideMap.has(f)).length;\n const coldCount = files.filter(f => isColdFile(f)).length;\n const jsCount = files.filter(f => f.endsWith('.js') || f.endsWith('.cjs') || f.endsWith('.mjs')).length;\n const cssCount = files.filter(f => f.endsWith('.css')).length;\n\n const parts = [];\n if (overrideCount) parts.push(`${overrideCount} overridden`);\n if (coldCount) parts.push(`${coldCount} cold`);\n if (cssCount) parts.push(`${jsCount} JS, ${cssCount} CSS`);\n\n const suffix = parts.length ? ` (${parts.join(', ')})` : '';\n const title = `Loading ${files.length} initial file${files.length !== 1 ? 's' : ''}${suffix}`;\n\n const { symbol, color } = this.logStyles.inject;\n console.groupCollapsed(\n `%c${symbol} [${formatTime()}] ${title}`,\n `color: ${color}; font-weight: bold;`\n );\n\n files.forEach(file => {\n const fileName = getFileName(file);\n const filePath = getFilePath(file);\n const isOverride = overrideMap.has(file);\n const isCold = isColdFile(file);\n\n if (isOverride) {\n const target = getFileName(overrideMap.get(file));\n const targetPath = getFilePath(overrideMap.get(file));\n console.log(\n `%c\u2514\u2500 ${fileName} -> ${target}%c (${filePath} -> ${targetPath})`,\n `color: ${this.logStyles.override.color}; font-weight: bold;`,\n 'color: #888888; font-style: italic;'\n );\n } else if (isCold) {\n console.log(\n `%c\u2514\u2500 ${fileName}%c (${filePath})`,\n `color: ${this.logStyles.cold.color}; font-weight: bold;`,\n 'color: #888888; font-style: italic;'\n );\n } else {\n console.log(\n `\u2514\u2500 %c${fileName}%c (${filePath})`,\n 'color: #ffffff; font-weight: bold;',\n 'color: #888888; font-style: italic;'\n );\n }\n });\n\n console.groupEnd();\n }\n\n buildOverrideMap(files) {\n this.overrideMap.clear();\n this._reverseOverrideMap.clear();\n const overrideFiles = new Set();\n const originalFiles = new Set();\n\n if (!this.getOverrideTarget) {\n return files; // No override detection configured\n }\n\n // First pass: identify overrides and their targets\n for (const file of files) {\n const target = this.getOverrideTarget(file, files);\n if (target) {\n this.overrideMap.set(file, target);\n if (!this._reverseOverrideMap.has(target)) {\n this._reverseOverrideMap.set(target, new Set());\n }\n this._reverseOverrideMap.get(target).add(file);\n overrideFiles.add(file);\n originalFiles.add(target);\n }\n }\n\n // Return files with originals removed\n return files.filter(f => !originalFiles.has(f));\n }\n\n async processInitFiles(files) {\n const filtered = [];\n const skipped = [];\n for (const f of files) {\n (this.shouldSkipFile(f, files) ? skipped : filtered).push(f);\n }\n\n if (skipped.length > 0) {\n console.groupCollapsed(\n `%c${this.logStyles.skip.symbol} [${formatTime()}] Skipped ${skipped.length} file${skipped.length !== 1 ? 's' : ''}`,\n `color: ${this.logStyles.skip.color}; font-weight: bold;`\n );\n skipped.forEach(f => console.log(` \u2514\u2500 ${getFileName(f)}`));\n console.groupEnd();\n }\n\n // Skip files that are already present\n let toLoad = filtered;\n if (this.skipOnReconnect) {\n const alreadyLoaded = [];\n toLoad = [];\n for (const f of filtered) {\n const isLoaded = this.fileLoader.versions.has(f) ||\n document.querySelector(`[data-file=\"${f}\"]`);\n (isLoaded ? alreadyLoaded : toLoad).push(f);\n }\n\n if (alreadyLoaded.length > 0) {\n this.log('info', `Server reconnected - skipping ${alreadyLoaded.length} existing file${alreadyLoaded.length !== 1 ? 's' : ''}`);\n }\n }\n\n // Build override map and remove original files\n const withOverrides = this.buildOverrideMap(toLoad);\n\n // Sort files\n const sorted = this.sortFiles(withOverrides);\n\n // Log what we're loading\n this.logInitFileGroup(sorted, this.overrideMap, this.isColdFile.bind(this));\n\n // Both CSS and JS are loaded sequentially to preserve order.\n for (const file of sorted) {\n await this.fileLoader.loadFile(file);\n if (this.onFileLoaded) this.onFileLoaded(file);\n }\n\n this.log('success', `HMR client ready (${sorted.length} files loaded)`);\n }\n\n async handleFileChange(file, action, serverCold = false) {\n if (this.shouldSkipFile(file, this.allFiles)) {\n this.log('skip', `Skipping ${action}: ${getFileName(file)}`);\n return;\n }\n\n // If this file is currently overridden, don't load it\n if (this._reverseOverrideMap.has(file)) {\n this.log('skip', `Skipping ${action}: ${getFileName(file)} (overridden)`);\n return;\n }\n\n if (this.getOverrideTarget) {\n const newTarget = this.getOverrideTarget(file, this.allFiles);\n\n // If the target changed since last time, tear down the old relationship\n // so _reverseOverrideMap doesn't accumulate stale entries.\n const previousTarget = this.overrideMap.get(file);\n if (previousTarget && previousTarget !== newTarget) {\n const siblings = this._reverseOverrideMap.get(previousTarget);\n if (siblings) {\n siblings.delete(file);\n if (siblings.size === 0) this._reverseOverrideMap.delete(previousTarget);\n }\n this.overrideMap.delete(file);\n }\n\n if (newTarget) {\n this.log('override', `${getFileName(file)} -> ${getFileName(newTarget)}`);\n await this.fileLoader.removeFile(newTarget);\n this.overrideMap.set(file, newTarget);\n\n // Keep _reverseOverrideMap in sync for live events, not just init.\n if (!this._reverseOverrideMap.has(newTarget)) {\n this._reverseOverrideMap.set(newTarget, new Set());\n }\n this._reverseOverrideMap.get(newTarget).add(file);\n }\n }\n\n // Check if cold file but server flag is authoritative\n const isCold = serverCold || this.isColdFile(file);\n if (isCold) {\n this.log('cold', `Cold file changed: ${getFileName(file)}`);\n this.emit('cold', file);\n return;\n }\n\n const fileName = getFileName(file);\n const filePath = getFilePath(file);\n const actionType = action === HMR_ACTIONS.RELOAD ? 'warning' : 'add';\n\n this.log(actionType, `HMR ${action}: ${fileName}`);\n console.log(`%c \u2514\u2500 Path: ${filePath}`, 'color: #888888; font-style: italic;');\n\n if (action === HMR_ACTIONS.RELOAD) {\n await this.fileLoader.reloadFile(file);\n } else {\n await this.fileLoader.loadFile(file);\n }\n\n if (this.onFileLoaded) {\n this.onFileLoaded(file);\n }\n\n this.emit(action, file);\n }\n\n async handleFileRemove(file) {\n if (this.shouldSkipFile(file, this.allFiles)) {\n this.log('skip', `Skipping remove: ${getFileName(file)}`);\n return;\n }\n\n const fileName = getFileName(file);\n const filePath = getFilePath(file);\n\n this.log('remove', `HMR remove: ${fileName}`);\n console.log(`%c \u2514\u2500 Path: ${filePath}`, 'color: #888888; font-style: italic;');\n\n // If this file was overriding something, only restore the original\n // if no other overrides are still actively replacing it\n const overriddenFile = this.overrideMap.get(file);\n if (overriddenFile) {\n this.overrideMap.delete(file);\n\n const remainingOverrides = this._reverseOverrideMap.get(overriddenFile);\n if (remainingOverrides) {\n remainingOverrides.delete(file);\n if (remainingOverrides.size === 0) {\n // No more overrides for this target, safe to restore\n this._reverseOverrideMap.delete(overriddenFile);\n this.log('override', `Restoring: ${getFileName(overriddenFile)}`);\n\n const originalExists = this.allFiles.includes(overriddenFile);\n if (originalExists) {\n try {\n await this.fileLoader.loadFile(overriddenFile);\n } catch (e) {\n this.log('error', `Failed to restore original: ${getFileName(overriddenFile)} - ${e.message}`);\n // Remove from allFiles since it's clearly gone\n this.allFiles = this.allFiles.filter(f => f !== overriddenFile);\n }\n } else {\n this.log('warning', `Original file no longer tracked, skipping restore: ${getFileName(overriddenFile)}`);\n }\n }\n }\n }\n\n await this.fileLoader.removeFile(file);\n this.emit(HMR_ACTIONS.REMOVE, file);\n }\n\n async handleMessage(data) {\n if (data.type === HMR_ACTIONS.INIT) {\n this.emit(HMR_ACTIONS.INIT, data);\n\n this.watchFiles = data.config?.watchFiles ?? true;\n if (!this.watchFiles) {\n this.log('info', 'Static snapshot mode -> live watching disabled');\n }\n\n // Merge server cold patterns with any client configured patterns,\n // so that both sources are respected.\n if (data.config?.cold?.length) {\n // Always merge from the original client patterns, not the previously merged ones\n const merged = [...new Set([...(this._coldPatterns || []), ...data.config.cold])];\n this.isColdFile = this.makeFilter(merged, this._filterCold);\n }\n\n if (data.files && data.files.length > 0) {\n this.allFiles = [...data.files];\n await this.processInitFiles(data.files);\n } else {\n const modeLabel = this.watchFiles ? 'HMR ready' : 'Static snapshot ready';\n this.log('success', `${modeLabel} (${sorted.length} files loaded)`);\n }\n return;\n }\n\n const { action, file } = data;\n if (!action || !file) return;\n\n if (action === HMR_ACTIONS.ADD) {\n this.allFiles = [...this.allFiles, file];\n }\n\n if (action === HMR_ACTIONS.REMOVE) {\n this.allFiles = this.allFiles.filter(f => f !== file);\n }\n\n if (action === HMR_ACTIONS.RELOAD || action === HMR_ACTIONS.ADD) {\n await this.handleFileChange(file, action, data.cold ?? false);\n }\n\n if (action === HMR_ACTIONS.REMOVE) {\n await this.handleFileRemove(file);\n }\n }\n\n /**\n * Register an event handler\n * @param {'init'|'reload'|'add'|'remove'|'cold'|'connect'|'disconnect'|'error'} event - Event name\n * @param {Function} handler - Event handler function\n * @returns {HMRClient} This client for chaining\n */\n on(event, handler) {\n if (!this.eventHandlers.has(event)) {\n this.eventHandlers.set(event, []);\n }\n this.eventHandlers.get(event).push(handler);\n return this;\n }\n\n /**\n * Register a one-time event handler that auto-removes itself after the first call\n * @param {'init'|'reload'|'add'|'remove'|'cold'|'connect'|'disconnect'|'error'} event - Event name\n * @param {Function} handler - Event handler function\n * @returns {HMRClient} This client for chaining\n */\n once(event, handler) {\n const wrapper = (...args) => {\n this.off(event, wrapper);\n handler(...args);\n };\n wrapper._original = handler;\n return this.on(event, wrapper);\n }\n\n /**\n * Remove a previously registered event handler\n * @param {'init'|'reload'|'add'|'remove'|'cold'|'connect'|'disconnect'|'error'} event - Event name\n * @param {Function} handler - The exact handler reference passed to `on()`\n * @returns {HMRClient} This client for chaining\n */\n off(event, handler) {\n const handlers = this.eventHandlers.get(event);\n if (!handlers) return this;\n if (!handler) {\n // Remove all handlers for this event\n this.eventHandlers.delete(event);\n return this;\n }\n\n const remaining = handlers.filter(h => h !== handler && h._original !== handler);\n if (remaining.length === handlers.length) return this;\n\n if (remaining.length === 0) {\n this.eventHandlers.delete(event);\n } else {\n this.eventHandlers.set(event, remaining);\n }\n return this;\n }\n\n emit(event, ...args) {\n const handlers = this.eventHandlers.get(event);\n if (!handlers) return;\n\n // Snapshot to prevent mutation issues during emit\n for (const handler of [...handlers]) {\n handler(...args);\n }\n }\n\n // Push an incoming message onto the serial queue and drain it if not already\n // running. This ensures handleMessage calls never execute concurrently, a\n // rapid pair of change events for the same file would otherwise race between\n // removeFile and loadFile and could leave the DOM in a broken state.\n _enqueueMessage(data) {\n this._messageQueue.push(data);\n if (!this._processingMessages) this._drainMessageQueue();\n }\n\n async _drainMessageQueue() {\n this._processingMessages = true;\n while (this._messageQueue.length > 0) {\n const data = this._messageQueue.shift();\n try {\n await this.handleMessage(data);\n } catch (e) {\n this.log('error', `Message handling error: ${e.message}`);\n }\n }\n this._processingMessages = false;\n }\n\n /**\n * Connect to the HMR server\n * @returns {Promise<void>}\n */\n connect() {\n this.autoReconnect = this._autoReconnectDefault;\n if (this._reconnectTimer) {\n clearTimeout(this._reconnectTimer);\n this._reconnectTimer = null;\n }\n\n // Prevent orphaned sockets if called while already connected or connecting\n if (this.socket) {\n this.socket.onopen = null;\n this.socket.onclose = null;\n this.socket.onerror = null;\n this.socket.onmessage = null;\n this.socket.close();\n this.socket = null;\n }\n\n return new Promise((resolve, reject) => {\n // Guards against onerror and onclose both settling the Promise\n let settled = false;\n\n try {\n this.socket = new WebSocket(this.wsUrl);\n\n this.socket.onopen = () => {\n settled = true;\n this.isConnected = true;\n this.reconnectAttempts = 0;\n // Discard any messages queued from the previous connection\n this._messageQueue = [];\n this._processingMessages = false;\n this.log('success', 'HMR connected');\n this.emit('connect');\n resolve();\n };\n\n this.socket.onclose = () => {\n this.isConnected = false;\n this.socket = null;\n this.emit('disconnect');\n\n // Reconnect on any disconnect, including failed initial attempts\n if (this.autoReconnect) {\n const delay = Math.min(\n this.reconnectDelay * Math.pow(1.5, this.reconnectAttempts++),\n this.maxReconnectDelay\n );\n\n const msg = settled\n ? `HMR disconnected, retrying in ${(delay / 1000).toFixed(1)}s...`\n : `HMR connection failed, retrying in ${(delay / 1000).toFixed(1)}s...`;\n\n this.log('disconnect', msg);\n this._reconnectTimer = setTimeout(() => {\n this.connect().catch((error) => {\n this.log('error', `Reconnect attempt failed: ${error.message}`);\n this.emit('error', error);\n });\n }, delay);\n } else {\n if (settled) this.log('disconnect', 'HMR disconnected');\n }\n };\n\n this.socket.onerror = (error) => {\n const errorMsg = error.message || 'Connection failed';\n this.log('error', `HMR error: ${errorMsg}`);\n this.emit('error', error);\n if (!settled) { settled = true; reject(error); }\n };\n\n this.socket.onmessage = (event) => {\n try {\n const data = JSON.parse(event.data);\n this._enqueueMessage(data);\n } catch (e) {\n this.log('error', `Failed to parse message: ${e.message}`);\n }\n };\n\n } catch (error) {\n this.log('error', `Failed to create WebSocket: ${error.message}`);\n reject(error);\n }\n });\n }\n\n /**\n * Disconnect from the HMR server and clean up\n */\n disconnect() {\n this.autoReconnect = false;\n this.reconnectAttempts = 0;\n this.isConnected = false;\n clearTimeout(this._reconnectTimer);\n this._reconnectTimer = null;\n if (this.socket) {\n this.socket.close();\n this.socket = null;\n }\n }\n}"],
4
+ "sourcesContent": ["'use strict';\n\nconst WIN_SLASH = '\\\\\\\\/';\nconst WIN_NO_SLASH = `[^${WIN_SLASH}]`;\n\n/**\n * Posix glob regex\n */\n\nconst DOT_LITERAL = '\\\\.';\nconst PLUS_LITERAL = '\\\\+';\nconst QMARK_LITERAL = '\\\\?';\nconst SLASH_LITERAL = '\\\\/';\nconst ONE_CHAR = '(?=.)';\nconst QMARK = '[^/]';\nconst END_ANCHOR = `(?:${SLASH_LITERAL}|$)`;\nconst START_ANCHOR = `(?:^|${SLASH_LITERAL})`;\nconst DOTS_SLASH = `${DOT_LITERAL}{1,2}${END_ANCHOR}`;\nconst NO_DOT = `(?!${DOT_LITERAL})`;\nconst NO_DOTS = `(?!${START_ANCHOR}${DOTS_SLASH})`;\nconst NO_DOT_SLASH = `(?!${DOT_LITERAL}{0,1}${END_ANCHOR})`;\nconst NO_DOTS_SLASH = `(?!${DOTS_SLASH})`;\nconst QMARK_NO_DOT = `[^.${SLASH_LITERAL}]`;\nconst STAR = `${QMARK}*?`;\nconst SEP = '/';\n\nconst POSIX_CHARS = {\n DOT_LITERAL,\n PLUS_LITERAL,\n QMARK_LITERAL,\n SLASH_LITERAL,\n ONE_CHAR,\n QMARK,\n END_ANCHOR,\n DOTS_SLASH,\n NO_DOT,\n NO_DOTS,\n NO_DOT_SLASH,\n NO_DOTS_SLASH,\n QMARK_NO_DOT,\n STAR,\n START_ANCHOR,\n SEP\n};\n\n/**\n * Windows glob regex\n */\n\nconst WINDOWS_CHARS = {\n ...POSIX_CHARS,\n\n SLASH_LITERAL: `[${WIN_SLASH}]`,\n QMARK: WIN_NO_SLASH,\n STAR: `${WIN_NO_SLASH}*?`,\n DOTS_SLASH: `${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$)`,\n NO_DOT: `(?!${DOT_LITERAL})`,\n NO_DOTS: `(?!(?:^|[${WIN_SLASH}])${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,\n NO_DOT_SLASH: `(?!${DOT_LITERAL}{0,1}(?:[${WIN_SLASH}]|$))`,\n NO_DOTS_SLASH: `(?!${DOT_LITERAL}{1,2}(?:[${WIN_SLASH}]|$))`,\n QMARK_NO_DOT: `[^.${WIN_SLASH}]`,\n START_ANCHOR: `(?:^|[${WIN_SLASH}])`,\n END_ANCHOR: `(?:[${WIN_SLASH}]|$)`,\n SEP: '\\\\'\n};\n\n/**\n * POSIX Bracket Regex\n */\n\nconst POSIX_REGEX_SOURCE = {\n alnum: 'a-zA-Z0-9',\n alpha: 'a-zA-Z',\n ascii: '\\\\x00-\\\\x7F',\n blank: ' \\\\t',\n cntrl: '\\\\x00-\\\\x1F\\\\x7F',\n digit: '0-9',\n graph: '\\\\x21-\\\\x7E',\n lower: 'a-z',\n print: '\\\\x20-\\\\x7E ',\n punct: '\\\\-!\"#$%&\\'()\\\\*+,./:;<=>?@[\\\\]^_`{|}~',\n space: ' \\\\t\\\\r\\\\n\\\\v\\\\f',\n upper: 'A-Z',\n word: 'A-Za-z0-9_',\n xdigit: 'A-Fa-f0-9'\n};\n\nmodule.exports = {\n MAX_LENGTH: 1024 * 64,\n POSIX_REGEX_SOURCE,\n\n // regular expressions\n REGEX_BACKSLASH: /\\\\(?![*+?^${}(|)[\\]])/g,\n REGEX_NON_SPECIAL_CHARS: /^[^@![\\].,$*+?^{}()|\\\\/]+/,\n REGEX_SPECIAL_CHARS: /[-*+?.^${}(|)[\\]]/,\n REGEX_SPECIAL_CHARS_BACKREF: /(\\\\?)((\\W)(\\3*))/g,\n REGEX_SPECIAL_CHARS_GLOBAL: /([-*+?.^${}(|)[\\]])/g,\n REGEX_REMOVE_BACKSLASH: /(?:\\[.*?[^\\\\]\\]|\\\\(?=.))/g,\n\n // Replace globs with equivalent patterns to reduce parsing time.\n REPLACEMENTS: {\n __proto__: null,\n '***': '*',\n '**/**': '**',\n '**/**/**': '**'\n },\n\n // Digits\n CHAR_0: 48, /* 0 */\n CHAR_9: 57, /* 9 */\n\n // Alphabet chars.\n CHAR_UPPERCASE_A: 65, /* A */\n CHAR_LOWERCASE_A: 97, /* a */\n CHAR_UPPERCASE_Z: 90, /* Z */\n CHAR_LOWERCASE_Z: 122, /* z */\n\n CHAR_LEFT_PARENTHESES: 40, /* ( */\n CHAR_RIGHT_PARENTHESES: 41, /* ) */\n\n CHAR_ASTERISK: 42, /* * */\n\n // Non-alphabetic chars.\n CHAR_AMPERSAND: 38, /* & */\n CHAR_AT: 64, /* @ */\n CHAR_BACKWARD_SLASH: 92, /* \\ */\n CHAR_CARRIAGE_RETURN: 13, /* \\r */\n CHAR_CIRCUMFLEX_ACCENT: 94, /* ^ */\n CHAR_COLON: 58, /* : */\n CHAR_COMMA: 44, /* , */\n CHAR_DOT: 46, /* . */\n CHAR_DOUBLE_QUOTE: 34, /* \" */\n CHAR_EQUAL: 61, /* = */\n CHAR_EXCLAMATION_MARK: 33, /* ! */\n CHAR_FORM_FEED: 12, /* \\f */\n CHAR_FORWARD_SLASH: 47, /* / */\n CHAR_GRAVE_ACCENT: 96, /* ` */\n CHAR_HASH: 35, /* # */\n CHAR_HYPHEN_MINUS: 45, /* - */\n CHAR_LEFT_ANGLE_BRACKET: 60, /* < */\n CHAR_LEFT_CURLY_BRACE: 123, /* { */\n CHAR_LEFT_SQUARE_BRACKET: 91, /* [ */\n CHAR_LINE_FEED: 10, /* \\n */\n CHAR_NO_BREAK_SPACE: 160, /* \\u00A0 */\n CHAR_PERCENT: 37, /* % */\n CHAR_PLUS: 43, /* + */\n CHAR_QUESTION_MARK: 63, /* ? */\n CHAR_RIGHT_ANGLE_BRACKET: 62, /* > */\n CHAR_RIGHT_CURLY_BRACE: 125, /* } */\n CHAR_RIGHT_SQUARE_BRACKET: 93, /* ] */\n CHAR_SEMICOLON: 59, /* ; */\n CHAR_SINGLE_QUOTE: 39, /* ' */\n CHAR_SPACE: 32, /* */\n CHAR_TAB: 9, /* \\t */\n CHAR_UNDERSCORE: 95, /* _ */\n CHAR_VERTICAL_LINE: 124, /* | */\n CHAR_ZERO_WIDTH_NOBREAK_SPACE: 65279, /* \\uFEFF */\n\n /**\n * Create EXTGLOB_CHARS\n */\n\n extglobChars(chars) {\n return {\n '!': { type: 'negate', open: '(?:(?!(?:', close: `))${chars.STAR})` },\n '?': { type: 'qmark', open: '(?:', close: ')?' },\n '+': { type: 'plus', open: '(?:', close: ')+' },\n '*': { type: 'star', open: '(?:', close: ')*' },\n '@': { type: 'at', open: '(?:', close: ')' }\n };\n },\n\n /**\n * Create GLOB_CHARS\n */\n\n globChars(win32) {\n return win32 === true ? WINDOWS_CHARS : POSIX_CHARS;\n }\n};\n", "/*global navigator*/\n'use strict';\n\nconst {\n REGEX_BACKSLASH,\n REGEX_REMOVE_BACKSLASH,\n REGEX_SPECIAL_CHARS,\n REGEX_SPECIAL_CHARS_GLOBAL\n} = require('./constants');\n\nexports.isObject = val => val !== null && typeof val === 'object' && !Array.isArray(val);\nexports.hasRegexChars = str => REGEX_SPECIAL_CHARS.test(str);\nexports.isRegexChar = str => str.length === 1 && exports.hasRegexChars(str);\nexports.escapeRegex = str => str.replace(REGEX_SPECIAL_CHARS_GLOBAL, '\\\\$1');\nexports.toPosixSlashes = str => str.replace(REGEX_BACKSLASH, '/');\n\nexports.isWindows = () => {\n if (typeof navigator !== 'undefined' && navigator.platform) {\n const platform = navigator.platform.toLowerCase();\n return platform === 'win32' || platform === 'windows';\n }\n\n if (typeof process !== 'undefined' && process.platform) {\n return process.platform === 'win32';\n }\n\n return false;\n};\n\nexports.removeBackslashes = str => {\n return str.replace(REGEX_REMOVE_BACKSLASH, match => {\n return match === '\\\\' ? '' : match;\n });\n};\n\nexports.escapeLast = (input, char, lastIdx) => {\n const idx = input.lastIndexOf(char, lastIdx);\n if (idx === -1) return input;\n if (input[idx - 1] === '\\\\') return exports.escapeLast(input, char, idx - 1);\n return `${input.slice(0, idx)}\\\\${input.slice(idx)}`;\n};\n\nexports.removePrefix = (input, state = {}) => {\n let output = input;\n if (output.startsWith('./')) {\n output = output.slice(2);\n state.prefix = './';\n }\n return output;\n};\n\nexports.wrapOutput = (input, state = {}, options = {}) => {\n const prepend = options.contains ? '' : '^';\n const append = options.contains ? '' : '$';\n\n let output = `${prepend}(?:${input})${append}`;\n if (state.negated === true) {\n output = `(?:^(?!${output}).*$)`;\n }\n return output;\n};\n\nexports.basename = (path, { windows } = {}) => {\n const segs = path.split(windows ? /[\\\\/]/ : '/');\n const last = segs[segs.length - 1];\n\n if (last === '') {\n return segs[segs.length - 2];\n }\n\n return last;\n};\n", "'use strict';\n\nconst utils = require('./utils');\nconst {\n CHAR_ASTERISK, /* * */\n CHAR_AT, /* @ */\n CHAR_BACKWARD_SLASH, /* \\ */\n CHAR_COMMA, /* , */\n CHAR_DOT, /* . */\n CHAR_EXCLAMATION_MARK, /* ! */\n CHAR_FORWARD_SLASH, /* / */\n CHAR_LEFT_CURLY_BRACE, /* { */\n CHAR_LEFT_PARENTHESES, /* ( */\n CHAR_LEFT_SQUARE_BRACKET, /* [ */\n CHAR_PLUS, /* + */\n CHAR_QUESTION_MARK, /* ? */\n CHAR_RIGHT_CURLY_BRACE, /* } */\n CHAR_RIGHT_PARENTHESES, /* ) */\n CHAR_RIGHT_SQUARE_BRACKET /* ] */\n} = require('./constants');\n\nconst isPathSeparator = code => {\n return code === CHAR_FORWARD_SLASH || code === CHAR_BACKWARD_SLASH;\n};\n\nconst depth = token => {\n if (token.isPrefix !== true) {\n token.depth = token.isGlobstar ? Infinity : 1;\n }\n};\n\n/**\n * Quickly scans a glob pattern and returns an object with a handful of\n * useful properties, like `isGlob`, `path` (the leading non-glob, if it exists),\n * `glob` (the actual pattern), `negated` (true if the path starts with `!` but not\n * with `!(`) and `negatedExtglob` (true if the path starts with `!(`).\n *\n * ```js\n * const pm = require('picomatch');\n * console.log(pm.scan('foo/bar/*.js'));\n * { isGlob: true, input: 'foo/bar/*.js', base: 'foo/bar', glob: '*.js' }\n * ```\n * @param {String} `str`\n * @param {Object} `options`\n * @return {Object} Returns an object with tokens and regex source string.\n * @api public\n */\n\nconst scan = (input, options) => {\n const opts = options || {};\n\n const length = input.length - 1;\n const scanToEnd = opts.parts === true || opts.scanToEnd === true;\n const slashes = [];\n const tokens = [];\n const parts = [];\n\n let str = input;\n let index = -1;\n let start = 0;\n let lastIndex = 0;\n let isBrace = false;\n let isBracket = false;\n let isGlob = false;\n let isExtglob = false;\n let isGlobstar = false;\n let braceEscaped = false;\n let backslashes = false;\n let negated = false;\n let negatedExtglob = false;\n let finished = false;\n let braces = 0;\n let prev;\n let code;\n let token = { value: '', depth: 0, isGlob: false };\n\n const eos = () => index >= length;\n const peek = () => str.charCodeAt(index + 1);\n const advance = () => {\n prev = code;\n return str.charCodeAt(++index);\n };\n\n while (index < length) {\n code = advance();\n let next;\n\n if (code === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n code = advance();\n\n if (code === CHAR_LEFT_CURLY_BRACE) {\n braceEscaped = true;\n }\n continue;\n }\n\n if (braceEscaped === true || code === CHAR_LEFT_CURLY_BRACE) {\n braces++;\n\n while (eos() !== true && (code = advance())) {\n if (code === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n advance();\n continue;\n }\n\n if (code === CHAR_LEFT_CURLY_BRACE) {\n braces++;\n continue;\n }\n\n if (braceEscaped !== true && code === CHAR_DOT && (code = advance()) === CHAR_DOT) {\n isBrace = token.isBrace = true;\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (braceEscaped !== true && code === CHAR_COMMA) {\n isBrace = token.isBrace = true;\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (code === CHAR_RIGHT_CURLY_BRACE) {\n braces--;\n\n if (braces === 0) {\n braceEscaped = false;\n isBrace = token.isBrace = true;\n finished = true;\n break;\n }\n }\n }\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (code === CHAR_FORWARD_SLASH) {\n slashes.push(index);\n tokens.push(token);\n token = { value: '', depth: 0, isGlob: false };\n\n if (finished === true) continue;\n if (prev === CHAR_DOT && index === (start + 1)) {\n start += 2;\n continue;\n }\n\n lastIndex = index + 1;\n continue;\n }\n\n if (opts.noext !== true) {\n const isExtglobChar = code === CHAR_PLUS\n || code === CHAR_AT\n || code === CHAR_ASTERISK\n || code === CHAR_QUESTION_MARK\n || code === CHAR_EXCLAMATION_MARK;\n\n if (isExtglobChar === true && peek() === CHAR_LEFT_PARENTHESES) {\n isGlob = token.isGlob = true;\n isExtglob = token.isExtglob = true;\n finished = true;\n if (code === CHAR_EXCLAMATION_MARK && index === start) {\n negatedExtglob = true;\n }\n\n if (scanToEnd === true) {\n while (eos() !== true && (code = advance())) {\n if (code === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n code = advance();\n continue;\n }\n\n if (code === CHAR_RIGHT_PARENTHESES) {\n isGlob = token.isGlob = true;\n finished = true;\n break;\n }\n }\n continue;\n }\n break;\n }\n }\n\n if (code === CHAR_ASTERISK) {\n if (prev === CHAR_ASTERISK) isGlobstar = token.isGlobstar = true;\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n break;\n }\n\n if (code === CHAR_QUESTION_MARK) {\n isGlob = token.isGlob = true;\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n break;\n }\n\n if (code === CHAR_LEFT_SQUARE_BRACKET) {\n while (eos() !== true && (next = advance())) {\n if (next === CHAR_BACKWARD_SLASH) {\n backslashes = token.backslashes = true;\n advance();\n continue;\n }\n\n if (next === CHAR_RIGHT_SQUARE_BRACKET) {\n isBracket = token.isBracket = true;\n isGlob = token.isGlob = true;\n finished = true;\n break;\n }\n }\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n\n if (opts.nonegate !== true && code === CHAR_EXCLAMATION_MARK && index === start) {\n negated = token.negated = true;\n start++;\n continue;\n }\n\n if (opts.noparen !== true && code === CHAR_LEFT_PARENTHESES) {\n isGlob = token.isGlob = true;\n\n if (scanToEnd === true) {\n while (eos() !== true && (code = advance())) {\n if (code === CHAR_LEFT_PARENTHESES) {\n backslashes = token.backslashes = true;\n code = advance();\n continue;\n }\n\n if (code === CHAR_RIGHT_PARENTHESES) {\n finished = true;\n break;\n }\n }\n continue;\n }\n break;\n }\n\n if (isGlob === true) {\n finished = true;\n\n if (scanToEnd === true) {\n continue;\n }\n\n break;\n }\n }\n\n if (opts.noext === true) {\n isExtglob = false;\n isGlob = false;\n }\n\n let base = str;\n let prefix = '';\n let glob = '';\n\n if (start > 0) {\n prefix = str.slice(0, start);\n str = str.slice(start);\n lastIndex -= start;\n }\n\n if (base && isGlob === true && lastIndex > 0) {\n base = str.slice(0, lastIndex);\n glob = str.slice(lastIndex);\n } else if (isGlob === true) {\n base = '';\n glob = str;\n } else {\n base = str;\n }\n\n if (base && base !== '' && base !== '/' && base !== str) {\n if (isPathSeparator(base.charCodeAt(base.length - 1))) {\n base = base.slice(0, -1);\n }\n }\n\n if (opts.unescape === true) {\n if (glob) glob = utils.removeBackslashes(glob);\n\n if (base && backslashes === true) {\n base = utils.removeBackslashes(base);\n }\n }\n\n const state = {\n prefix,\n input,\n start,\n base,\n glob,\n isBrace,\n isBracket,\n isGlob,\n isExtglob,\n isGlobstar,\n negated,\n negatedExtglob\n };\n\n if (opts.tokens === true) {\n state.maxDepth = 0;\n if (!isPathSeparator(code)) {\n tokens.push(token);\n }\n state.tokens = tokens;\n }\n\n if (opts.parts === true || opts.tokens === true) {\n let prevIndex;\n\n for (let idx = 0; idx < slashes.length; idx++) {\n const n = prevIndex ? prevIndex + 1 : start;\n const i = slashes[idx];\n const value = input.slice(n, i);\n if (opts.tokens) {\n if (idx === 0 && start !== 0) {\n tokens[idx].isPrefix = true;\n tokens[idx].value = prefix;\n } else {\n tokens[idx].value = value;\n }\n depth(tokens[idx]);\n state.maxDepth += tokens[idx].depth;\n }\n if (idx !== 0 || value !== '') {\n parts.push(value);\n }\n prevIndex = i;\n }\n\n if (prevIndex && prevIndex + 1 < input.length) {\n const value = input.slice(prevIndex + 1);\n parts.push(value);\n\n if (opts.tokens) {\n tokens[tokens.length - 1].value = value;\n depth(tokens[tokens.length - 1]);\n state.maxDepth += tokens[tokens.length - 1].depth;\n }\n }\n\n state.slashes = slashes;\n state.parts = parts;\n }\n\n return state;\n};\n\nmodule.exports = scan;\n", "'use strict';\n\nconst constants = require('./constants');\nconst utils = require('./utils');\n\n/**\n * Constants\n */\n\nconst {\n MAX_LENGTH,\n POSIX_REGEX_SOURCE,\n REGEX_NON_SPECIAL_CHARS,\n REGEX_SPECIAL_CHARS_BACKREF,\n REPLACEMENTS\n} = constants;\n\n/**\n * Helpers\n */\n\nconst expandRange = (args, options) => {\n if (typeof options.expandRange === 'function') {\n return options.expandRange(...args, options);\n }\n\n args.sort();\n const value = `[${args.join('-')}]`;\n\n try {\n /* eslint-disable-next-line no-new */\n new RegExp(value);\n } catch (ex) {\n return args.map(v => utils.escapeRegex(v)).join('..');\n }\n\n return value;\n};\n\n/**\n * Create the message for a syntax error\n */\n\nconst syntaxError = (type, char) => {\n return `Missing ${type}: \"${char}\" - use \"\\\\\\\\${char}\" to match literal characters`;\n};\n\n/**\n * Parse the given input string.\n * @param {String} input\n * @param {Object} options\n * @return {Object}\n */\n\nconst parse = (input, options) => {\n if (typeof input !== 'string') {\n throw new TypeError('Expected a string');\n }\n\n input = REPLACEMENTS[input] || input;\n\n const opts = { ...options };\n const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;\n\n let len = input.length;\n if (len > max) {\n throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);\n }\n\n const bos = { type: 'bos', value: '', output: opts.prepend || '' };\n const tokens = [bos];\n\n const capture = opts.capture ? '' : '?:';\n\n // create constants based on platform, for windows or posix\n const PLATFORM_CHARS = constants.globChars(opts.windows);\n const EXTGLOB_CHARS = constants.extglobChars(PLATFORM_CHARS);\n\n const {\n DOT_LITERAL,\n PLUS_LITERAL,\n SLASH_LITERAL,\n ONE_CHAR,\n DOTS_SLASH,\n NO_DOT,\n NO_DOT_SLASH,\n NO_DOTS_SLASH,\n QMARK,\n QMARK_NO_DOT,\n STAR,\n START_ANCHOR\n } = PLATFORM_CHARS;\n\n const globstar = opts => {\n return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;\n };\n\n const nodot = opts.dot ? '' : NO_DOT;\n const qmarkNoDot = opts.dot ? QMARK : QMARK_NO_DOT;\n let star = opts.bash === true ? globstar(opts) : STAR;\n\n if (opts.capture) {\n star = `(${star})`;\n }\n\n // minimatch options support\n if (typeof opts.noext === 'boolean') {\n opts.noextglob = opts.noext;\n }\n\n const state = {\n input,\n index: -1,\n start: 0,\n dot: opts.dot === true,\n consumed: '',\n output: '',\n prefix: '',\n backtrack: false,\n negated: false,\n brackets: 0,\n braces: 0,\n parens: 0,\n quotes: 0,\n globstar: false,\n tokens\n };\n\n input = utils.removePrefix(input, state);\n len = input.length;\n\n const extglobs = [];\n const braces = [];\n const stack = [];\n let prev = bos;\n let value;\n\n /**\n * Tokenizing helpers\n */\n\n const eos = () => state.index === len - 1;\n const peek = state.peek = (n = 1) => input[state.index + n];\n const advance = state.advance = () => input[++state.index] || '';\n const remaining = () => input.slice(state.index + 1);\n const consume = (value = '', num = 0) => {\n state.consumed += value;\n state.index += num;\n };\n\n const append = token => {\n state.output += token.output != null ? token.output : token.value;\n consume(token.value);\n };\n\n const negate = () => {\n let count = 1;\n\n while (peek() === '!' && (peek(2) !== '(' || peek(3) === '?')) {\n advance();\n state.start++;\n count++;\n }\n\n if (count % 2 === 0) {\n return false;\n }\n\n state.negated = true;\n state.start++;\n return true;\n };\n\n const increment = type => {\n state[type]++;\n stack.push(type);\n };\n\n const decrement = type => {\n state[type]--;\n stack.pop();\n };\n\n /**\n * Push tokens onto the tokens array. This helper speeds up\n * tokenizing by 1) helping us avoid backtracking as much as possible,\n * and 2) helping us avoid creating extra tokens when consecutive\n * characters are plain text. This improves performance and simplifies\n * lookbehinds.\n */\n\n const push = tok => {\n if (prev.type === 'globstar') {\n const isBrace = state.braces > 0 && (tok.type === 'comma' || tok.type === 'brace');\n const isExtglob = tok.extglob === true || (extglobs.length && (tok.type === 'pipe' || tok.type === 'paren'));\n\n if (tok.type !== 'slash' && tok.type !== 'paren' && !isBrace && !isExtglob) {\n state.output = state.output.slice(0, -prev.output.length);\n prev.type = 'star';\n prev.value = '*';\n prev.output = star;\n state.output += prev.output;\n }\n }\n\n if (extglobs.length && tok.type !== 'paren') {\n extglobs[extglobs.length - 1].inner += tok.value;\n }\n\n if (tok.value || tok.output) append(tok);\n if (prev && prev.type === 'text' && tok.type === 'text') {\n prev.output = (prev.output || prev.value) + tok.value;\n prev.value += tok.value;\n return;\n }\n\n tok.prev = prev;\n tokens.push(tok);\n prev = tok;\n };\n\n const extglobOpen = (type, value) => {\n const token = { ...EXTGLOB_CHARS[value], conditions: 1, inner: '' };\n\n token.prev = prev;\n token.parens = state.parens;\n token.output = state.output;\n const output = (opts.capture ? '(' : '') + token.open;\n\n increment('parens');\n push({ type, value, output: state.output ? '' : ONE_CHAR });\n push({ type: 'paren', extglob: true, value: advance(), output });\n extglobs.push(token);\n };\n\n const extglobClose = token => {\n let output = token.close + (opts.capture ? ')' : '');\n let rest;\n\n if (token.type === 'negate') {\n let extglobStar = star;\n\n if (token.inner && token.inner.length > 1 && token.inner.includes('/')) {\n extglobStar = globstar(opts);\n }\n\n if (extglobStar !== star || eos() || /^\\)+$/.test(remaining())) {\n output = token.close = `)$))${extglobStar}`;\n }\n\n if (token.inner.includes('*') && (rest = remaining()) && /^\\.[^\\\\/.]+$/.test(rest)) {\n // Any non-magical string (`.ts`) or even nested expression (`.{ts,tsx}`) can follow after the closing parenthesis.\n // In this case, we need to parse the string and use it in the output of the original pattern.\n // Suitable patterns: `/!(*.d).ts`, `/!(*.d).{ts,tsx}`, `**/!(*-dbg).@(js)`.\n //\n // Disabling the `fastpaths` option due to a problem with parsing strings as `.ts` in the pattern like `**/!(*.d).ts`.\n const expression = parse(rest, { ...options, fastpaths: false }).output;\n\n output = token.close = `)${expression})${extglobStar})`;\n }\n\n if (token.prev.type === 'bos') {\n state.negatedExtglob = true;\n }\n }\n\n push({ type: 'paren', extglob: true, value, output });\n decrement('parens');\n };\n\n /**\n * Fast paths\n */\n\n if (opts.fastpaths !== false && !/(^[*!]|[/()[\\]{}\"])/.test(input)) {\n let backslashes = false;\n\n let output = input.replace(REGEX_SPECIAL_CHARS_BACKREF, (m, esc, chars, first, rest, index) => {\n if (first === '\\\\') {\n backslashes = true;\n return m;\n }\n\n if (first === '?') {\n if (esc) {\n return esc + first + (rest ? QMARK.repeat(rest.length) : '');\n }\n if (index === 0) {\n return qmarkNoDot + (rest ? QMARK.repeat(rest.length) : '');\n }\n return QMARK.repeat(chars.length);\n }\n\n if (first === '.') {\n return DOT_LITERAL.repeat(chars.length);\n }\n\n if (first === '*') {\n if (esc) {\n return esc + first + (rest ? star : '');\n }\n return star;\n }\n return esc ? m : `\\\\${m}`;\n });\n\n if (backslashes === true) {\n if (opts.unescape === true) {\n output = output.replace(/\\\\/g, '');\n } else {\n output = output.replace(/\\\\+/g, m => {\n return m.length % 2 === 0 ? '\\\\\\\\' : (m ? '\\\\' : '');\n });\n }\n }\n\n if (output === input && opts.contains === true) {\n state.output = input;\n return state;\n }\n\n state.output = utils.wrapOutput(output, state, options);\n return state;\n }\n\n /**\n * Tokenize input until we reach end-of-string\n */\n\n while (!eos()) {\n value = advance();\n\n if (value === '\\u0000') {\n continue;\n }\n\n /**\n * Escaped characters\n */\n\n if (value === '\\\\') {\n const next = peek();\n\n if (next === '/' && opts.bash !== true) {\n continue;\n }\n\n if (next === '.' || next === ';') {\n continue;\n }\n\n if (!next) {\n value += '\\\\';\n push({ type: 'text', value });\n continue;\n }\n\n // collapse slashes to reduce potential for exploits\n const match = /^\\\\+/.exec(remaining());\n let slashes = 0;\n\n if (match && match[0].length > 2) {\n slashes = match[0].length;\n state.index += slashes;\n if (slashes % 2 !== 0) {\n value += '\\\\';\n }\n }\n\n if (opts.unescape === true) {\n value = advance();\n } else {\n value += advance();\n }\n\n if (state.brackets === 0) {\n push({ type: 'text', value });\n continue;\n }\n }\n\n /**\n * If we're inside a regex character class, continue\n * until we reach the closing bracket.\n */\n\n if (state.brackets > 0 && (value !== ']' || prev.value === '[' || prev.value === '[^')) {\n if (opts.posix !== false && value === ':') {\n const inner = prev.value.slice(1);\n if (inner.includes('[')) {\n prev.posix = true;\n\n if (inner.includes(':')) {\n const idx = prev.value.lastIndexOf('[');\n const pre = prev.value.slice(0, idx);\n const rest = prev.value.slice(idx + 2);\n const posix = POSIX_REGEX_SOURCE[rest];\n if (posix) {\n prev.value = pre + posix;\n state.backtrack = true;\n advance();\n\n if (!bos.output && tokens.indexOf(prev) === 1) {\n bos.output = ONE_CHAR;\n }\n continue;\n }\n }\n }\n }\n\n if ((value === '[' && peek() !== ':') || (value === '-' && peek() === ']')) {\n value = `\\\\${value}`;\n }\n\n if (value === ']' && (prev.value === '[' || prev.value === '[^')) {\n value = `\\\\${value}`;\n }\n\n if (opts.posix === true && value === '!' && prev.value === '[') {\n value = '^';\n }\n\n prev.value += value;\n append({ value });\n continue;\n }\n\n /**\n * If we're inside a quoted string, continue\n * until we reach the closing double quote.\n */\n\n if (state.quotes === 1 && value !== '\"') {\n value = utils.escapeRegex(value);\n prev.value += value;\n append({ value });\n continue;\n }\n\n /**\n * Double quotes\n */\n\n if (value === '\"') {\n state.quotes = state.quotes === 1 ? 0 : 1;\n if (opts.keepQuotes === true) {\n push({ type: 'text', value });\n }\n continue;\n }\n\n /**\n * Parentheses\n */\n\n if (value === '(') {\n increment('parens');\n push({ type: 'paren', value });\n continue;\n }\n\n if (value === ')') {\n if (state.parens === 0 && opts.strictBrackets === true) {\n throw new SyntaxError(syntaxError('opening', '('));\n }\n\n const extglob = extglobs[extglobs.length - 1];\n if (extglob && state.parens === extglob.parens + 1) {\n extglobClose(extglobs.pop());\n continue;\n }\n\n push({ type: 'paren', value, output: state.parens ? ')' : '\\\\)' });\n decrement('parens');\n continue;\n }\n\n /**\n * Square brackets\n */\n\n if (value === '[') {\n if (opts.nobracket === true || !remaining().includes(']')) {\n if (opts.nobracket !== true && opts.strictBrackets === true) {\n throw new SyntaxError(syntaxError('closing', ']'));\n }\n\n value = `\\\\${value}`;\n } else {\n increment('brackets');\n }\n\n push({ type: 'bracket', value });\n continue;\n }\n\n if (value === ']') {\n if (opts.nobracket === true || (prev && prev.type === 'bracket' && prev.value.length === 1)) {\n push({ type: 'text', value, output: `\\\\${value}` });\n continue;\n }\n\n if (state.brackets === 0) {\n if (opts.strictBrackets === true) {\n throw new SyntaxError(syntaxError('opening', '['));\n }\n\n push({ type: 'text', value, output: `\\\\${value}` });\n continue;\n }\n\n decrement('brackets');\n\n const prevValue = prev.value.slice(1);\n if (prev.posix !== true && prevValue[0] === '^' && !prevValue.includes('/')) {\n value = `/${value}`;\n }\n\n prev.value += value;\n append({ value });\n\n // when literal brackets are explicitly disabled\n // assume we should match with a regex character class\n if (opts.literalBrackets === false || utils.hasRegexChars(prevValue)) {\n continue;\n }\n\n const escaped = utils.escapeRegex(prev.value);\n state.output = state.output.slice(0, -prev.value.length);\n\n // when literal brackets are explicitly enabled\n // assume we should escape the brackets to match literal characters\n if (opts.literalBrackets === true) {\n state.output += escaped;\n prev.value = escaped;\n continue;\n }\n\n // when the user specifies nothing, try to match both\n prev.value = `(${capture}${escaped}|${prev.value})`;\n state.output += prev.value;\n continue;\n }\n\n /**\n * Braces\n */\n\n if (value === '{' && opts.nobrace !== true) {\n increment('braces');\n\n const open = {\n type: 'brace',\n value,\n output: '(',\n outputIndex: state.output.length,\n tokensIndex: state.tokens.length\n };\n\n braces.push(open);\n push(open);\n continue;\n }\n\n if (value === '}') {\n const brace = braces[braces.length - 1];\n\n if (opts.nobrace === true || !brace) {\n push({ type: 'text', value, output: value });\n continue;\n }\n\n let output = ')';\n\n if (brace.dots === true) {\n const arr = tokens.slice();\n const range = [];\n\n for (let i = arr.length - 1; i >= 0; i--) {\n tokens.pop();\n if (arr[i].type === 'brace') {\n break;\n }\n if (arr[i].type !== 'dots') {\n range.unshift(arr[i].value);\n }\n }\n\n output = expandRange(range, opts);\n state.backtrack = true;\n }\n\n if (brace.comma !== true && brace.dots !== true) {\n const out = state.output.slice(0, brace.outputIndex);\n const toks = state.tokens.slice(brace.tokensIndex);\n brace.value = brace.output = '\\\\{';\n value = output = '\\\\}';\n state.output = out;\n for (const t of toks) {\n state.output += (t.output || t.value);\n }\n }\n\n push({ type: 'brace', value, output });\n decrement('braces');\n braces.pop();\n continue;\n }\n\n /**\n * Pipes\n */\n\n if (value === '|') {\n if (extglobs.length > 0) {\n extglobs[extglobs.length - 1].conditions++;\n }\n push({ type: 'text', value });\n continue;\n }\n\n /**\n * Commas\n */\n\n if (value === ',') {\n let output = value;\n\n const brace = braces[braces.length - 1];\n if (brace && stack[stack.length - 1] === 'braces') {\n brace.comma = true;\n output = '|';\n }\n\n push({ type: 'comma', value, output });\n continue;\n }\n\n /**\n * Slashes\n */\n\n if (value === '/') {\n // if the beginning of the glob is \"./\", advance the start\n // to the current index, and don't add the \"./\" characters\n // to the state. This greatly simplifies lookbehinds when\n // checking for BOS characters like \"!\" and \".\" (not \"./\")\n if (prev.type === 'dot' && state.index === state.start + 1) {\n state.start = state.index + 1;\n state.consumed = '';\n state.output = '';\n tokens.pop();\n prev = bos; // reset \"prev\" to the first token\n continue;\n }\n\n push({ type: 'slash', value, output: SLASH_LITERAL });\n continue;\n }\n\n /**\n * Dots\n */\n\n if (value === '.') {\n if (state.braces > 0 && prev.type === 'dot') {\n if (prev.value === '.') prev.output = DOT_LITERAL;\n const brace = braces[braces.length - 1];\n prev.type = 'dots';\n prev.output += value;\n prev.value += value;\n brace.dots = true;\n continue;\n }\n\n if ((state.braces + state.parens) === 0 && prev.type !== 'bos' && prev.type !== 'slash') {\n push({ type: 'text', value, output: DOT_LITERAL });\n continue;\n }\n\n push({ type: 'dot', value, output: DOT_LITERAL });\n continue;\n }\n\n /**\n * Question marks\n */\n\n if (value === '?') {\n const isGroup = prev && prev.value === '(';\n if (!isGroup && opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {\n extglobOpen('qmark', value);\n continue;\n }\n\n if (prev && prev.type === 'paren') {\n const next = peek();\n let output = value;\n\n if ((prev.value === '(' && !/[!=<:]/.test(next)) || (next === '<' && !/<([!=]|\\w+>)/.test(remaining()))) {\n output = `\\\\${value}`;\n }\n\n push({ type: 'text', value, output });\n continue;\n }\n\n if (opts.dot !== true && (prev.type === 'slash' || prev.type === 'bos')) {\n push({ type: 'qmark', value, output: QMARK_NO_DOT });\n continue;\n }\n\n push({ type: 'qmark', value, output: QMARK });\n continue;\n }\n\n /**\n * Exclamation\n */\n\n if (value === '!') {\n if (opts.noextglob !== true && peek() === '(') {\n if (peek(2) !== '?' || !/[!=<:]/.test(peek(3))) {\n extglobOpen('negate', value);\n continue;\n }\n }\n\n if (opts.nonegate !== true && state.index === 0) {\n negate();\n continue;\n }\n }\n\n /**\n * Plus\n */\n\n if (value === '+') {\n if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {\n extglobOpen('plus', value);\n continue;\n }\n\n if ((prev && prev.value === '(') || opts.regex === false) {\n push({ type: 'plus', value, output: PLUS_LITERAL });\n continue;\n }\n\n if ((prev && (prev.type === 'bracket' || prev.type === 'paren' || prev.type === 'brace')) || state.parens > 0) {\n push({ type: 'plus', value });\n continue;\n }\n\n push({ type: 'plus', value: PLUS_LITERAL });\n continue;\n }\n\n /**\n * Plain text\n */\n\n if (value === '@') {\n if (opts.noextglob !== true && peek() === '(' && peek(2) !== '?') {\n push({ type: 'at', extglob: true, value, output: '' });\n continue;\n }\n\n push({ type: 'text', value });\n continue;\n }\n\n /**\n * Plain text\n */\n\n if (value !== '*') {\n if (value === '$' || value === '^') {\n value = `\\\\${value}`;\n }\n\n const match = REGEX_NON_SPECIAL_CHARS.exec(remaining());\n if (match) {\n value += match[0];\n state.index += match[0].length;\n }\n\n push({ type: 'text', value });\n continue;\n }\n\n /**\n * Stars\n */\n\n if (prev && (prev.type === 'globstar' || prev.star === true)) {\n prev.type = 'star';\n prev.star = true;\n prev.value += value;\n prev.output = star;\n state.backtrack = true;\n state.globstar = true;\n consume(value);\n continue;\n }\n\n let rest = remaining();\n if (opts.noextglob !== true && /^\\([^?]/.test(rest)) {\n extglobOpen('star', value);\n continue;\n }\n\n if (prev.type === 'star') {\n if (opts.noglobstar === true) {\n consume(value);\n continue;\n }\n\n const prior = prev.prev;\n const before = prior.prev;\n const isStart = prior.type === 'slash' || prior.type === 'bos';\n const afterStar = before && (before.type === 'star' || before.type === 'globstar');\n\n if (opts.bash === true && (!isStart || (rest[0] && rest[0] !== '/'))) {\n push({ type: 'star', value, output: '' });\n continue;\n }\n\n const isBrace = state.braces > 0 && (prior.type === 'comma' || prior.type === 'brace');\n const isExtglob = extglobs.length && (prior.type === 'pipe' || prior.type === 'paren');\n if (!isStart && prior.type !== 'paren' && !isBrace && !isExtglob) {\n push({ type: 'star', value, output: '' });\n continue;\n }\n\n // strip consecutive `/**/`\n while (rest.slice(0, 3) === '/**') {\n const after = input[state.index + 4];\n if (after && after !== '/') {\n break;\n }\n rest = rest.slice(3);\n consume('/**', 3);\n }\n\n if (prior.type === 'bos' && eos()) {\n prev.type = 'globstar';\n prev.value += value;\n prev.output = globstar(opts);\n state.output = prev.output;\n state.globstar = true;\n consume(value);\n continue;\n }\n\n if (prior.type === 'slash' && prior.prev.type !== 'bos' && !afterStar && eos()) {\n state.output = state.output.slice(0, -(prior.output + prev.output).length);\n prior.output = `(?:${prior.output}`;\n\n prev.type = 'globstar';\n prev.output = globstar(opts) + (opts.strictSlashes ? ')' : '|$)');\n prev.value += value;\n state.globstar = true;\n state.output += prior.output + prev.output;\n consume(value);\n continue;\n }\n\n if (prior.type === 'slash' && prior.prev.type !== 'bos' && rest[0] === '/') {\n const end = rest[1] !== void 0 ? '|$' : '';\n\n state.output = state.output.slice(0, -(prior.output + prev.output).length);\n prior.output = `(?:${prior.output}`;\n\n prev.type = 'globstar';\n prev.output = `${globstar(opts)}${SLASH_LITERAL}|${SLASH_LITERAL}${end})`;\n prev.value += value;\n\n state.output += prior.output + prev.output;\n state.globstar = true;\n\n consume(value + advance());\n\n push({ type: 'slash', value: '/', output: '' });\n continue;\n }\n\n if (prior.type === 'bos' && rest[0] === '/') {\n prev.type = 'globstar';\n prev.value += value;\n prev.output = `(?:^|${SLASH_LITERAL}|${globstar(opts)}${SLASH_LITERAL})`;\n state.output = prev.output;\n state.globstar = true;\n consume(value + advance());\n push({ type: 'slash', value: '/', output: '' });\n continue;\n }\n\n // remove single star from output\n state.output = state.output.slice(0, -prev.output.length);\n\n // reset previous token to globstar\n prev.type = 'globstar';\n prev.output = globstar(opts);\n prev.value += value;\n\n // reset output with globstar\n state.output += prev.output;\n state.globstar = true;\n consume(value);\n continue;\n }\n\n const token = { type: 'star', value, output: star };\n\n if (opts.bash === true) {\n token.output = '.*?';\n if (prev.type === 'bos' || prev.type === 'slash') {\n token.output = nodot + token.output;\n }\n push(token);\n continue;\n }\n\n if (prev && (prev.type === 'bracket' || prev.type === 'paren') && opts.regex === true) {\n token.output = value;\n push(token);\n continue;\n }\n\n if (state.index === state.start || prev.type === 'slash' || prev.type === 'dot') {\n if (prev.type === 'dot') {\n state.output += NO_DOT_SLASH;\n prev.output += NO_DOT_SLASH;\n\n } else if (opts.dot === true) {\n state.output += NO_DOTS_SLASH;\n prev.output += NO_DOTS_SLASH;\n\n } else {\n state.output += nodot;\n prev.output += nodot;\n }\n\n if (peek() !== '*') {\n state.output += ONE_CHAR;\n prev.output += ONE_CHAR;\n }\n }\n\n push(token);\n }\n\n while (state.brackets > 0) {\n if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ']'));\n state.output = utils.escapeLast(state.output, '[');\n decrement('brackets');\n }\n\n while (state.parens > 0) {\n if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', ')'));\n state.output = utils.escapeLast(state.output, '(');\n decrement('parens');\n }\n\n while (state.braces > 0) {\n if (opts.strictBrackets === true) throw new SyntaxError(syntaxError('closing', '}'));\n state.output = utils.escapeLast(state.output, '{');\n decrement('braces');\n }\n\n if (opts.strictSlashes !== true && (prev.type === 'star' || prev.type === 'bracket')) {\n push({ type: 'maybe_slash', value: '', output: `${SLASH_LITERAL}?` });\n }\n\n // rebuild the output if we had to backtrack at any point\n if (state.backtrack === true) {\n state.output = '';\n\n for (const token of state.tokens) {\n state.output += token.output != null ? token.output : token.value;\n\n if (token.suffix) {\n state.output += token.suffix;\n }\n }\n }\n\n return state;\n};\n\n/**\n * Fast paths for creating regular expressions for common glob patterns.\n * This can significantly speed up processing and has very little downside\n * impact when none of the fast paths match.\n */\n\nparse.fastpaths = (input, options) => {\n const opts = { ...options };\n const max = typeof opts.maxLength === 'number' ? Math.min(MAX_LENGTH, opts.maxLength) : MAX_LENGTH;\n const len = input.length;\n if (len > max) {\n throw new SyntaxError(`Input length: ${len}, exceeds maximum allowed length: ${max}`);\n }\n\n input = REPLACEMENTS[input] || input;\n\n // create constants based on platform, for windows or posix\n const {\n DOT_LITERAL,\n SLASH_LITERAL,\n ONE_CHAR,\n DOTS_SLASH,\n NO_DOT,\n NO_DOTS,\n NO_DOTS_SLASH,\n STAR,\n START_ANCHOR\n } = constants.globChars(opts.windows);\n\n const nodot = opts.dot ? NO_DOTS : NO_DOT;\n const slashDot = opts.dot ? NO_DOTS_SLASH : NO_DOT;\n const capture = opts.capture ? '' : '?:';\n const state = { negated: false, prefix: '' };\n let star = opts.bash === true ? '.*?' : STAR;\n\n if (opts.capture) {\n star = `(${star})`;\n }\n\n const globstar = opts => {\n if (opts.noglobstar === true) return star;\n return `(${capture}(?:(?!${START_ANCHOR}${opts.dot ? DOTS_SLASH : DOT_LITERAL}).)*?)`;\n };\n\n const create = str => {\n switch (str) {\n case '*':\n return `${nodot}${ONE_CHAR}${star}`;\n\n case '.*':\n return `${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n case '*.*':\n return `${nodot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n case '*/*':\n return `${nodot}${star}${SLASH_LITERAL}${ONE_CHAR}${slashDot}${star}`;\n\n case '**':\n return nodot + globstar(opts);\n\n case '**/*':\n return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${ONE_CHAR}${star}`;\n\n case '**/*.*':\n return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${slashDot}${star}${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n case '**/.*':\n return `(?:${nodot}${globstar(opts)}${SLASH_LITERAL})?${DOT_LITERAL}${ONE_CHAR}${star}`;\n\n default: {\n const match = /^(.*?)\\.(\\w+)$/.exec(str);\n if (!match) return;\n\n const source = create(match[1]);\n if (!source) return;\n\n return source + DOT_LITERAL + match[2];\n }\n }\n };\n\n const output = utils.removePrefix(input, state);\n let source = create(output);\n\n if (source && opts.strictSlashes !== true) {\n source += `${SLASH_LITERAL}?`;\n }\n\n return source;\n};\n\nmodule.exports = parse;\n", "'use strict';\n\nconst scan = require('./scan');\nconst parse = require('./parse');\nconst utils = require('./utils');\nconst constants = require('./constants');\nconst isObject = val => val && typeof val === 'object' && !Array.isArray(val);\n\n/**\n * Creates a matcher function from one or more glob patterns. The\n * returned function takes a string to match as its first argument,\n * and returns true if the string is a match. The returned matcher\n * function also takes a boolean as the second argument that, when true,\n * returns an object with additional information.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch(glob[, options]);\n *\n * const isMatch = picomatch('*.!(*a)');\n * console.log(isMatch('a.a')); //=> false\n * console.log(isMatch('a.b')); //=> true\n * ```\n * @name picomatch\n * @param {String|Array} `globs` One or more glob patterns.\n * @param {Object=} `options`\n * @return {Function=} Returns a matcher function.\n * @api public\n */\n\nconst picomatch = (glob, options, returnState = false) => {\n if (Array.isArray(glob)) {\n const fns = glob.map(input => picomatch(input, options, returnState));\n const arrayMatcher = str => {\n for (const isMatch of fns) {\n const state = isMatch(str);\n if (state) return state;\n }\n return false;\n };\n return arrayMatcher;\n }\n\n const isState = isObject(glob) && glob.tokens && glob.input;\n\n if (glob === '' || (typeof glob !== 'string' && !isState)) {\n throw new TypeError('Expected pattern to be a non-empty string');\n }\n\n const opts = options || {};\n const posix = opts.windows;\n const regex = isState\n ? picomatch.compileRe(glob, options)\n : picomatch.makeRe(glob, options, false, true);\n\n const state = regex.state;\n delete regex.state;\n\n let isIgnored = () => false;\n if (opts.ignore) {\n const ignoreOpts = { ...options, ignore: null, onMatch: null, onResult: null };\n isIgnored = picomatch(opts.ignore, ignoreOpts, returnState);\n }\n\n const matcher = (input, returnObject = false) => {\n const { isMatch, match, output } = picomatch.test(input, regex, options, { glob, posix });\n const result = { glob, state, regex, posix, input, output, match, isMatch };\n\n if (typeof opts.onResult === 'function') {\n opts.onResult(result);\n }\n\n if (isMatch === false) {\n result.isMatch = false;\n return returnObject ? result : false;\n }\n\n if (isIgnored(input)) {\n if (typeof opts.onIgnore === 'function') {\n opts.onIgnore(result);\n }\n result.isMatch = false;\n return returnObject ? result : false;\n }\n\n if (typeof opts.onMatch === 'function') {\n opts.onMatch(result);\n }\n return returnObject ? result : true;\n };\n\n if (returnState) {\n matcher.state = state;\n }\n\n return matcher;\n};\n\n/**\n * Test `input` with the given `regex`. This is used by the main\n * `picomatch()` function to test the input string.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.test(input, regex[, options]);\n *\n * console.log(picomatch.test('foo/bar', /^(?:([^/]*?)\\/([^/]*?))$/));\n * // { isMatch: true, match: [ 'foo/', 'foo', 'bar' ], output: 'foo/bar' }\n * ```\n * @param {String} `input` String to test.\n * @param {RegExp} `regex`\n * @return {Object} Returns an object with matching info.\n * @api public\n */\n\npicomatch.test = (input, regex, options, { glob, posix } = {}) => {\n if (typeof input !== 'string') {\n throw new TypeError('Expected input to be a string');\n }\n\n if (input === '') {\n return { isMatch: false, output: '' };\n }\n\n const opts = options || {};\n const format = opts.format || (posix ? utils.toPosixSlashes : null);\n let match = input === glob;\n let output = (match && format) ? format(input) : input;\n\n if (match === false) {\n output = format ? format(input) : input;\n match = output === glob;\n }\n\n if (match === false || opts.capture === true) {\n if (opts.matchBase === true || opts.basename === true) {\n match = picomatch.matchBase(input, regex, options, posix);\n } else {\n match = regex.exec(output);\n }\n }\n\n return { isMatch: Boolean(match), match, output };\n};\n\n/**\n * Match the basename of a filepath.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.matchBase(input, glob[, options]);\n * console.log(picomatch.matchBase('foo/bar.js', '*.js'); // true\n * ```\n * @param {String} `input` String to test.\n * @param {RegExp|String} `glob` Glob pattern or regex created by [.makeRe](#makeRe).\n * @return {Boolean}\n * @api public\n */\n\npicomatch.matchBase = (input, glob, options) => {\n const regex = glob instanceof RegExp ? glob : picomatch.makeRe(glob, options);\n return regex.test(utils.basename(input));\n};\n\n/**\n * Returns true if **any** of the given glob `patterns` match the specified `string`.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.isMatch(string, patterns[, options]);\n *\n * console.log(picomatch.isMatch('a.a', ['b.*', '*.a'])); //=> true\n * console.log(picomatch.isMatch('a.a', 'b.*')); //=> false\n * ```\n * @param {String|Array} str The string to test.\n * @param {String|Array} patterns One or more glob patterns to use for matching.\n * @param {Object} [options] See available [options](#options).\n * @return {Boolean} Returns true if any patterns match `str`\n * @api public\n */\n\npicomatch.isMatch = (str, patterns, options) => picomatch(patterns, options)(str);\n\n/**\n * Parse a glob pattern to create the source string for a regular\n * expression.\n *\n * ```js\n * const picomatch = require('picomatch');\n * const result = picomatch.parse(pattern[, options]);\n * ```\n * @param {String} `pattern`\n * @param {Object} `options`\n * @return {Object} Returns an object with useful properties and output to be used as a regex source string.\n * @api public\n */\n\npicomatch.parse = (pattern, options) => {\n if (Array.isArray(pattern)) return pattern.map(p => picomatch.parse(p, options));\n return parse(pattern, { ...options, fastpaths: false });\n};\n\n/**\n * Scan a glob pattern to separate the pattern into segments.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.scan(input[, options]);\n *\n * const result = picomatch.scan('!./foo/*.js');\n * console.log(result);\n * { prefix: '!./',\n * input: '!./foo/*.js',\n * start: 3,\n * base: 'foo',\n * glob: '*.js',\n * isBrace: false,\n * isBracket: false,\n * isGlob: true,\n * isExtglob: false,\n * isGlobstar: false,\n * negated: true }\n * ```\n * @param {String} `input` Glob pattern to scan.\n * @param {Object} `options`\n * @return {Object} Returns an object with\n * @api public\n */\n\npicomatch.scan = (input, options) => scan(input, options);\n\n/**\n * Compile a regular expression from the `state` object returned by the\n * [parse()](#parse) method.\n *\n * @param {Object} `state`\n * @param {Object} `options`\n * @param {Boolean} `returnOutput` Intended for implementors, this argument allows you to return the raw output from the parser.\n * @param {Boolean} `returnState` Adds the state to a `state` property on the returned regex. Useful for implementors and debugging.\n * @return {RegExp}\n * @api public\n */\n\npicomatch.compileRe = (state, options, returnOutput = false, returnState = false) => {\n if (returnOutput === true) {\n return state.output;\n }\n\n const opts = options || {};\n const prepend = opts.contains ? '' : '^';\n const append = opts.contains ? '' : '$';\n\n let source = `${prepend}(?:${state.output})${append}`;\n if (state && state.negated === true) {\n source = `^(?!${source}).*$`;\n }\n\n const regex = picomatch.toRegex(source, options);\n if (returnState === true) {\n regex.state = state;\n }\n\n return regex;\n};\n\n/**\n * Create a regular expression from a parsed glob pattern.\n *\n * ```js\n * const picomatch = require('picomatch');\n * const state = picomatch.parse('*.js');\n * // picomatch.compileRe(state[, options]);\n *\n * console.log(picomatch.compileRe(state));\n * //=> /^(?:(?!\\.)(?=.)[^/]*?\\.js)$/\n * ```\n * @param {String} `state` The object returned from the `.parse` method.\n * @param {Object} `options`\n * @param {Boolean} `returnOutput` Implementors may use this argument to return the compiled output, instead of a regular expression. This is not exposed on the options to prevent end-users from mutating the result.\n * @param {Boolean} `returnState` Implementors may use this argument to return the state from the parsed glob with the returned regular expression.\n * @return {RegExp} Returns a regex created from the given pattern.\n * @api public\n */\n\npicomatch.makeRe = (input, options = {}, returnOutput = false, returnState = false) => {\n if (!input || typeof input !== 'string') {\n throw new TypeError('Expected a non-empty string');\n }\n\n let parsed = { negated: false, fastpaths: true };\n\n if (options.fastpaths !== false && (input[0] === '.' || input[0] === '*')) {\n parsed.output = parse.fastpaths(input, options);\n }\n\n if (!parsed.output) {\n parsed = parse(input, options);\n }\n\n return picomatch.compileRe(parsed, options, returnOutput, returnState);\n};\n\n/**\n * Create a regular expression from the given regex source string.\n *\n * ```js\n * const picomatch = require('picomatch');\n * // picomatch.toRegex(source[, options]);\n *\n * const { output } = picomatch.parse('*.js');\n * console.log(picomatch.toRegex(output));\n * //=> /^(?:(?!\\.)(?=.)[^/]*?\\.js)$/\n * ```\n * @param {String} `source` Regular expression source string.\n * @param {Object} `options`\n * @return {RegExp}\n * @api public\n */\n\npicomatch.toRegex = (source, options) => {\n try {\n const opts = options || {};\n return new RegExp(source, opts.flags || (opts.nocase ? 'i' : ''));\n } catch (err) {\n if (options && options.debug === true) throw err;\n return /$^/;\n }\n};\n\n/**\n * Picomatch constants.\n * @return {Object}\n */\n\npicomatch.constants = constants;\n\n/**\n * Expose \"picomatch\"\n */\n\nmodule.exports = picomatch;\n", "'use strict';\n\nconst pico = require('./lib/picomatch');\nconst utils = require('./lib/utils');\n\nfunction picomatch(glob, options, returnState = false) {\n // default to os.platform()\n if (options && (options.windows === null || options.windows === undefined)) {\n // don't mutate the original options object\n options = { ...options, windows: utils.isWindows() };\n }\n\n return pico(glob, options, returnState);\n}\n\nObject.assign(picomatch, pico);\nmodule.exports = picomatch;\n", "export { HMRClient as default, HMRClient } from './client/hmr-client.js';\nexport { FileLoader } from './client/file-loader.js';", "/** Handles loading and hot reloading of JavaScript and CSS files via blob URLs. */\nexport class FileLoader {\n constructor(httpUrl) {\n this.httpUrl = httpUrl;\n /**\n * Debounce state per file. Stores { timeout, resolvers[] } so that\n * when a rapid second change clears the first timeout, the first\n * caller's Promise still resolves with the final load result.\n * @type {Map<string, { timeout: number, resolvers: Function[] }>}\n */\n this.loadQueue = new Map();\n /**\n * Load counter per file used for cache busting.\n * Produces short URLs like Logger.js?v=3 which keeps\n * browser stack traces readable.\n * @type {Map<string, number>}\n */\n this.versions = new Map();\n }\n\n async loadFile(path) {\n const isCSS = path.endsWith('.css');\n const isModule = path.endsWith('.mjs');\n\n if (isCSS) return await this.loadCSS(path);\n if (isModule) return await this.loadModule(path);\n return await this.loadScript(path);\n }\n\n // Load CSS atomically: append new <link>, wait for it to load, then remove\n // the old one. This fixes the brief flash of unstyled content that\n // happens when you remove the old sheet before the new one is parsed.\n async loadCSS(path) {\n const existing = document.querySelector(`link[data-file=\"${path}\"]`);\n const url = this.makeUrl(path);\n\n const link = document.createElement('link');\n link.rel = 'stylesheet';\n link.href = url;\n link.setAttribute('data-file', path);\n\n return new Promise((resolve, reject) => {\n link.onload = () => {\n if (existing) existing.remove();\n resolve(true);\n };\n link.onerror = () => {\n link.remove();\n reject(new Error(`Failed to load CSS: ${path}`));\n };\n document.head.appendChild(link);\n });\n }\n\n async loadModule(path) {\n const url = this.makeUrl(path);\n await import(url);\n return true;\n }\n\n async loadScript(path) {\n const url = this.makeUrl(path);\n\n const existing = document.querySelector(`script[data-file=\"${path}\"]`);\n if (existing) existing.remove();\n\n const script = document.createElement('script');\n script.src = url;\n script.setAttribute('data-file', path);\n\n return new Promise((resolve, reject) => {\n script.onload = () => resolve(true);\n script.onerror = () => reject(new Error(`Failed to load script: ${path}`));\n document.head.appendChild(script);\n });\n }\n\n // Debounce reloads within 100ms.\n // Calls in the same window share a single load and all receive the result.\n // Fixes prior behavior where only the last caller's Promise resolved.\n async reloadFile(path) {\n return new Promise((resolve, reject) => {\n if (this.loadQueue.has(path)) {\n const entry = this.loadQueue.get(path);\n clearTimeout(entry.timeout);\n entry.resolvers.push({ resolve, reject });\n entry.timeout = setTimeout(() => this._flushReload(path), 100);\n } else {\n const entry = {\n timeout: setTimeout(() => this._flushReload(path), 100),\n resolvers: [{ resolve, reject }]\n };\n this.loadQueue.set(path, entry);\n }\n });\n }\n\n async _flushReload(path) {\n const entry = this.loadQueue.get(path);\n this.loadQueue.delete(path);\n\n try {\n const success = await this.loadFile(path);\n for (const { resolve } of entry.resolvers) resolve(success);\n } catch (e) {\n for (const { reject } of entry.resolvers) reject(e);\n }\n }\n\n async removeFile(path) {\n // Cancel any pending reload debounce for this file\n if (this.loadQueue.has(path)) {\n const entry = this.loadQueue.get(path);\n clearTimeout(entry.timeout);\n for (const { reject } of entry.resolvers) reject(new Error(`File removed: ${path}`));\n this.loadQueue.delete(path);\n }\n\n const el = document.querySelector(`[data-file=\"${path}\"]`);\n if (el) {\n el.remove();\n await new Promise(r => setTimeout(r, 0));\n }\n\n // Reset version so the next load starts from v=1 again\n this.versions.delete(path);\n }\n\n // Increment the version counter for individual files and return a versioned URL\n makeUrl(path) {\n const v = (this.versions.get(path) ?? 0) + 1;\n this.versions.set(path, v);\n return `${this.httpUrl}${path}?v=${v}`;\n }\n}", "export const DEFAULT_PORT = 1338;\nexport const WATCHABLE_EXTENSIONS = ['.js', '.cjs', '.mjs', '.css'];\n\nexport const DEFAULT_FILES_ENDPOINT = '/files'\nexport const DEFAULT_CONFIG_ENDPOINT = '/config'\n\nexport const DEFAULT_CORS_PROXY_PATH = '/proxy';\nexport const DEFAULT_WS_PROXY_PATH = '/proxy';\n\nexport const WATCHER_CONFIG = {\n persistent: true,\n ignoreInitial: true,\n awaitWriteFinish: {\n stabilityThreshold: 50,\n pollInterval: 10\n },\n usePolling: false,\n alwaysStat: true,\n atomic: false\n};\n\nexport const HMR_ACTIONS = {\n RELOAD: 'reload',\n ADD: 'add',\n REMOVE: 'remove',\n INIT: 'init'\n};\n\nexport const CORS_HEADERS = {\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Headers': '*',\n 'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',\n 'Access-Control-Allow-Private-Network': 'true',\n};", "import picomatch from 'picomatch';\n\n// Cache compiled matchers so same patterns aren't recompiled on every call\nconst matcherCache = new Map();\n\nexport function matchGlob(file, patterns) {\n return patterns.some(pattern => {\n if (!matcherCache.has(pattern)) matcherCache.set(pattern, picomatch(pattern));\n return matcherCache.get(pattern)(file);\n });\n}\n\nexport function formatTime() {\n return new Date().toLocaleTimeString('en-US', {\n hour12: false,\n hour: '2-digit',\n minute: '2-digit',\n second: '2-digit'\n });\n}\n\nexport function getBrowserFromUA(userAgent) {\n if (!userAgent) return 'Unknown';\n\n if (userAgent.includes('Chrome/')) return 'Chrome';\n if (userAgent.includes('Firefox/')) return 'Firefox';\n if (userAgent.includes('Safari/') && !userAgent.includes('Chrome/')) return 'Safari';\n if (userAgent.includes('Edge/')) return 'Edge';\n if (userAgent.includes('Opera/') || userAgent.includes('OPR/')) return 'Opera';\n\n return 'Unknown';\n}\n\nexport function getFileName(path) {\n return path.split('/').pop();\n}\n\nexport function getFilePath(path) {\n const parts = path.split('/');\n parts.pop();\n return parts.join('/') || '.';\n}\n\nexport function normalizeUrl(url) {\n return url.endsWith('/') ? url : url + '/';\n}\n\nexport function normalizeProxyPath(path, defaultPath) {\n return (path || defaultPath).replace(/^(?!\\/)/, '/').replace(/\\/+$/, '');\n}\n\nexport function resolveEndpoint(value, defaultPath) {\n if (!value) return null;\n if (value === true) return defaultPath;\n return value.startsWith('/') ? value : `/${value}`;\n}\n\n/**\n * Resolve HMR connection URLs from various input formats\n * @param {string|number|Object} options - Connection options\n * @returns {{ wsUrl: string, httpUrl: string }}\n * \n * @example\n * resolveConnectionUrls(1338)\n * // => { wsUrl: 'ws://localhost:1338', httpUrl: 'http://localhost:1338/' }\n * \n * @example\n * resolveConnectionUrls('ws://192.168.1.100:1338')\n * // => { wsUrl: 'ws://192.168.1.100:1338', httpUrl: 'http://192.168.1.100:1338/' }\n * \n * @example\n * resolveConnectionUrls({ host: 'dev.example.com', port: 1338, secure: true })\n * // => { wsUrl: 'wss://dev.example.com:1338', httpUrl: 'https://dev.example.com:1338/' }\n */\nfunction wsUrlToHttpUrl(wsUrl) {\n const u = new URL(wsUrl);\n return `${u.protocol === 'wss:' ? 'https' : 'http'}://${u.host}/`;\n}\n\nfunction httpUrlToWsUrl(httpUrl, wsPath) {\n const u = new URL(httpUrl);\n return `${u.protocol === 'https:' ? 'wss' : 'ws'}://${u.host}${wsPath}`;\n}\n\nexport function resolveConnectionUrls(options, wsPath = '/hmr') {\n if (typeof options === 'string') {\n return { wsUrl: options, httpUrl: wsUrlToHttpUrl(options) };\n }\n\n if (typeof options === 'number') {\n options = { port: options };\n }\n\n if (typeof options !== 'object' || options === null) {\n throw new Error('Options must be a string, number, or object');\n }\n\n if (options.wsUrl && options.httpUrl) {\n return { wsUrl: options.wsUrl, httpUrl: normalizeUrl(options.httpUrl) };\n }\n\n if (options.wsUrl) {\n return { wsUrl: options.wsUrl, httpUrl: wsUrlToHttpUrl(options.wsUrl) };\n }\n\n if (options.httpUrl) {\n const httpUrl = normalizeUrl(options.httpUrl);\n return { wsUrl: httpUrlToWsUrl(httpUrl, wsPath), httpUrl };\n }\n\n if (options.port) {\n const host = options.host || 'localhost';\n const secure = options.secure || false;\n const wsProtocol = secure ? 'wss' : 'ws';\n const httpProtocol = secure ? 'https' : 'http';\n\n const wsUrl = `${wsProtocol}://${host}:${options.port}${wsPath}`;\n const httpUrl = normalizeUrl(`${httpProtocol}://${host}:${options.port}`);\n\n return { wsUrl, httpUrl };\n }\n\n throw new Error('Must provide wsUrl, httpUrl, port, or host+port');\n}", "import { FileLoader } from './file-loader.js';\nimport { HMR_ACTIONS } from '../shared/constants.js'\nimport { matchGlob, getFileName, getFilePath, formatTime, resolveConnectionUrls } from './../shared/utils.js';\n\n/**\n * HMR client with baked-in file loading, override detection, and cold file handling.\n * \n * @example\n * // Simple setup\n * const client = new HMRClient({\n * port: 1338,\n * skip: ['_*\\/**'],\n * cold: ['**\\/*.cold.js'],\n * onFileLoaded: (file) => swapPrototype(file)\n * });\n * \n * @example\n * // With override detection\n * const client = new HMRClient({\n * port: 1338,\n * getOverrideTarget: (file, allFiles) => {\n * const m = file.match(/^x_[^/]+\\/overrides\\/(.+)$/);\n * if (!m) return null;\n * const core = `core/${m[1]}`;\n * return allFiles?.includes(core) ? core : null;\n * }\n * });\n */\nexport class HMRClient {\n /**\n * `options` can be a shorthand or a full config object:\n * - **number** treated as `{ port: n }`, connects to `ws://localhost:<n>`\n * - **string** treated as a full WebSocket URL\n * - **object** full config, see below\n *\n * @param {Object} options - setting options jsdoc to `Object` only for the sake of auto complete.\n * @param {string} [options.wsUrl] - Explicit WebSocket URL. Takes priority over host/port.\n * @param {string} [options.httpUrl] - Explicit HTTP base URL for fetching files. Derived from `wsUrl` if omitted.\n * @param {boolean} [options.watchFiles=true] Server side file watching is enabled by default.\n * @param {string} [options.host='localhost'] - Hostname (used when building from `port`)\n * @param {number} [options.port] - Port number\n * @param {boolean} [options.secure=false] - Use `wss://` and `https://`\n * @param {boolean} [options.autoReconnect=true] - Reconnect on disconnect with exponential backoff.\n * @param {number} [options.reconnectDelay=2000] - Base reconnect delay in ms\n * @param {number} [options.maxReconnectDelay=30000] - Maximum reconnect delay cap in ms\n * @param {boolean} [options.skipOnReconnect=true] - Skip files already present in the page on reconnect, preventing them from being loaded again.\n * @param {string[]} [options.skip] - Glob patterns for files that should never be loaded (e.g. `['_*\\/**']`)\n * @param {function(string, string[]): boolean} [options.filterSkip] - Custom skip logic. Receives `(filePath, allFiles)`. Combined with `skip` via OR.\n * @param {string[]} [options.cold] - Glob patterns for files that require a full page reload. Merged with the server's `cold` config on connect. A `cold` event is emitted instead of hot reloading.\n * @param {function(string): boolean} [options.filterCold] - Custom cold file logic. Receives `(filePath)`. Combined with `cold` via OR.\n * @param {function(string, string[]): string|null} [options.getOverrideTarget] - Given a changed file, return the path of the original it replaces, or `null`. Receives `(filePath, allFiles)`. When matched, the original is unloaded before the override loads.\n * @param {function(string): void} [options.onFileLoaded] - Called after each file loads or reloads. Receives `(filePath)`.\n * @param {function(string[]): string[]} [options.sortFiles] - Custom sort for the initial file load order. Default sorts CSS before JS, cold files first.\n */\n constructor(options) {\n // Extract additional options if object was passed\n const opts = typeof options === 'object' && !Array.isArray(options) ? options : {};\n\n const wsPath = opts.wsPath || '/hmr';\n const { wsUrl, httpUrl } = resolveConnectionUrls(options, wsPath);\n this.wsUrl = wsUrl;\n this.httpUrl = httpUrl;\n this.watchFiles = true;\n\n this._autoReconnectDefault = opts.autoReconnect !== false;\n this.autoReconnect = this._autoReconnectDefault;\n this.reconnectDelay = opts.reconnectDelay || 2000;\n this.maxReconnectDelay = opts.maxReconnectDelay || 30000;\n this.skipOnReconnect = opts.skipOnReconnect !== false;\n\n // Store original cold config so we can merge server patterns on connect\n this._coldPatterns = opts.cold || null;\n this._filterCold = opts.filterCold || null;\n\n // Create normalized filter functions\n this.shouldSkipFile = this.makeFilter(opts.skip || null, opts.filterSkip || null);\n this.isColdFile = this.makeFilter(this._coldPatterns, this._filterCold);\n\n // Tracks the current set of watched files (seeded on init, updated on add/remove)\n this.allFiles = [];\n\n this.getOverrideTarget = opts.getOverrideTarget || null;\n this.onFileLoaded = opts.onFileLoaded || null;\n this.sortFiles = opts.sortFiles || this.defaultSortFiles.bind(this);\n\n this.socket = null;\n this.reconnectAttempts = 0;\n this.isConnected = false;\n this.eventHandlers = new Map();\n this._reconnectTimer = null;\n\n // Serialized message processing, this prevents concurrent handleMessage calls\n // from racing when two WS messages arrive before the first async chain completes.\n this._messageQueue = [];\n this._processingMessages = false;\n\n this.fileLoader = new FileLoader(this.httpUrl);\n\n /** @type {Map<string, string>} - Maps override file -> original file */\n this.overrideMap = new Map();\n /** @type {Map<string, Set<string>>} - Maps original file -> set of active overrides */\n this._reverseOverrideMap = new Map();\n\n this.logStyles = {\n info: { symbol: '\u2139', color: '#76fffd' },\n success: { symbol: '\u25B6', color: '#68ff51' },\n warning: { symbol: '\u232C', color: '#ff8400' },\n error: { symbol: '\u2716', color: '#ff0000' },\n add: { symbol: '\u2295', color: '#22c55e' },\n remove: { symbol: '\u2296', color: '#f87171' },\n inject: { symbol: '\u2398', color: '#facc15' },\n disconnect: { symbol: '\u2726', color: '#ef4444' },\n override: { symbol: '\u29EB', color: '#ff8400' },\n skip: { symbol: '\u2298', color: '#888888' },\n cold: { symbol: '\u2744', color: '#60a5fa' }\n };\n }\n\n defaultSortFiles(files) {\n const coldSet = new Set(files.filter(f => this.isColdFile(f)));\n return [...files].sort((a, b) => {\n const aIsCSS = a.endsWith('.css');\n const bIsCSS = b.endsWith('.css');\n\n // CSS always before JS, regardless of cold status\n if (aIsCSS && !bIsCSS) return -1;\n if (!aIsCSS && bIsCSS) return 1;\n\n // Within the same extension group: cold files first\n const coldA = coldSet.has(a);\n const coldB = coldSet.has(b);\n if (coldA && !coldB) return -1;\n if (!coldA && coldB) return 1;\n\n // Alphabetical as tiebreaker\n return a.localeCompare(b);\n });\n }\n\n makeFilter(patterns, callback) {\n // If both provided, combine them with OR logic\n if (patterns && callback) {\n return (file, allFiles) => {\n return matchGlob(file, patterns) || callback(file, allFiles);\n };\n }\n if (patterns) {\n return (file) => matchGlob(file, patterns);\n }\n if (callback) {\n return callback;\n }\n return () => false;\n }\n\n log(type, message) {\n const { symbol, color } = this.logStyles[type] || this.logStyles.info;\n const time = formatTime();\n console.log(`%c${symbol} [${time}] ${message}`, `color: ${color}; font-weight: bold;`);\n }\n\n logInitFileGroup(files, overrideMap, isColdFile) {\n if (!files.length) return;\n\n const overrideCount = files.filter(f => overrideMap.has(f)).length;\n const coldCount = files.filter(f => isColdFile(f)).length;\n const jsCount = files.filter(f => f.endsWith('.js') || f.endsWith('.cjs') || f.endsWith('.mjs')).length;\n const cssCount = files.filter(f => f.endsWith('.css')).length;\n\n const parts = [];\n if (overrideCount) parts.push(`${overrideCount} overridden`);\n if (coldCount) parts.push(`${coldCount} cold`);\n if (cssCount) parts.push(`${jsCount} JS, ${cssCount} CSS`);\n\n const suffix = parts.length ? ` (${parts.join(', ')})` : '';\n const title = `Loading ${files.length} initial file${files.length !== 1 ? 's' : ''}${suffix}`;\n\n const { symbol, color } = this.logStyles.inject;\n console.groupCollapsed(\n `%c${symbol} [${formatTime()}] ${title}`,\n `color: ${color}; font-weight: bold;`\n );\n\n files.forEach(file => {\n const fileName = getFileName(file);\n const filePath = getFilePath(file);\n const isOverride = overrideMap.has(file);\n const isCold = isColdFile(file);\n\n if (isOverride) {\n const target = getFileName(overrideMap.get(file));\n const targetPath = getFilePath(overrideMap.get(file));\n console.log(\n `%c\u2514\u2500 ${fileName} -> ${target}%c (${filePath} -> ${targetPath})`,\n `color: ${this.logStyles.override.color}; font-weight: bold;`,\n 'color: #888888; font-style: italic;'\n );\n } else if (isCold) {\n console.log(\n `%c\u2514\u2500 ${fileName}%c (${filePath})`,\n `color: ${this.logStyles.cold.color}; font-weight: bold;`,\n 'color: #888888; font-style: italic;'\n );\n } else {\n console.log(\n `\u2514\u2500 %c${fileName}%c (${filePath})`,\n 'color: #ffffff; font-weight: bold;',\n 'color: #888888; font-style: italic;'\n );\n }\n });\n\n console.groupEnd();\n }\n\n buildOverrideMap(files) {\n this.overrideMap.clear();\n this._reverseOverrideMap.clear();\n const overrideFiles = new Set();\n const originalFiles = new Set();\n\n if (!this.getOverrideTarget) {\n return files; // No override detection configured\n }\n\n // First pass: identify overrides and their targets\n for (const file of files) {\n const target = this.getOverrideTarget(file, files);\n if (target) {\n this.overrideMap.set(file, target);\n if (!this._reverseOverrideMap.has(target)) {\n this._reverseOverrideMap.set(target, new Set());\n }\n this._reverseOverrideMap.get(target).add(file);\n overrideFiles.add(file);\n originalFiles.add(target);\n }\n }\n\n // Return files with originals removed\n return files.filter(f => !originalFiles.has(f));\n }\n\n async processInitFiles(files) {\n const filtered = [];\n const skipped = [];\n for (const f of files) {\n (this.shouldSkipFile(f, files) ? skipped : filtered).push(f);\n }\n\n if (skipped.length > 0) {\n console.groupCollapsed(\n `%c${this.logStyles.skip.symbol} [${formatTime()}] Skipped ${skipped.length} file${skipped.length !== 1 ? 's' : ''}`,\n `color: ${this.logStyles.skip.color}; font-weight: bold;`\n );\n skipped.forEach(f => console.log(` \u2514\u2500 ${getFileName(f)}`));\n console.groupEnd();\n }\n\n // Skip files that are already present\n let toLoad = filtered;\n if (this.skipOnReconnect) {\n const alreadyLoaded = [];\n toLoad = [];\n for (const f of filtered) {\n const isLoaded = this.fileLoader.versions.has(f) ||\n document.querySelector(`[data-file=\"${f}\"]`);\n (isLoaded ? alreadyLoaded : toLoad).push(f);\n }\n\n if (alreadyLoaded.length > 0) {\n this.log('info', `Server reconnected - skipping ${alreadyLoaded.length} existing file${alreadyLoaded.length !== 1 ? 's' : ''}`);\n }\n }\n\n // Build override map and remove original files\n const withOverrides = this.buildOverrideMap(toLoad);\n\n // Sort files\n const sorted = this.sortFiles(withOverrides);\n\n // Log what we're loading\n this.logInitFileGroup(sorted, this.overrideMap, this.isColdFile.bind(this));\n\n // Both CSS and JS are loaded sequentially to preserve order.\n for (const file of sorted) {\n await this.fileLoader.loadFile(file);\n if (this.onFileLoaded) this.onFileLoaded(file);\n }\n\n this.log('success', `HMR client ready (${sorted.length} files loaded)`);\n }\n\n async handleFileChange(file, action, serverCold = false) {\n if (this.shouldSkipFile(file, this.allFiles)) {\n this.log('skip', `Skipping ${action}: ${getFileName(file)}`);\n return;\n }\n\n // If this file is currently overridden, don't load it\n if (this._reverseOverrideMap.has(file)) {\n this.log('skip', `Skipping ${action}: ${getFileName(file)} (overridden)`);\n return;\n }\n\n if (this.getOverrideTarget) {\n const newTarget = this.getOverrideTarget(file, this.allFiles);\n\n // If the target changed since last time, tear down the old relationship\n // so _reverseOverrideMap doesn't accumulate stale entries.\n const previousTarget = this.overrideMap.get(file);\n if (previousTarget && previousTarget !== newTarget) {\n const siblings = this._reverseOverrideMap.get(previousTarget);\n if (siblings) {\n siblings.delete(file);\n if (siblings.size === 0) this._reverseOverrideMap.delete(previousTarget);\n }\n this.overrideMap.delete(file);\n }\n\n if (newTarget) {\n this.log('override', `${getFileName(file)} -> ${getFileName(newTarget)}`);\n await this.fileLoader.removeFile(newTarget);\n this.overrideMap.set(file, newTarget);\n\n // Keep _reverseOverrideMap in sync for live events, not just init.\n if (!this._reverseOverrideMap.has(newTarget)) {\n this._reverseOverrideMap.set(newTarget, new Set());\n }\n this._reverseOverrideMap.get(newTarget).add(file);\n }\n }\n\n // Check if cold file but server flag is authoritative\n const isCold = serverCold || this.isColdFile(file);\n if (isCold) {\n this.log('cold', `Cold file changed: ${getFileName(file)}`);\n this.emit('cold', file);\n return;\n }\n\n const fileName = getFileName(file);\n const filePath = getFilePath(file);\n const actionType = action === HMR_ACTIONS.RELOAD ? 'warning' : 'add';\n\n this.log(actionType, `HMR ${action}: ${fileName}`);\n console.log(`%c \u2514\u2500 Path: ${filePath}`, 'color: #888888; font-style: italic;');\n\n if (action === HMR_ACTIONS.RELOAD) {\n await this.fileLoader.reloadFile(file);\n } else {\n await this.fileLoader.loadFile(file);\n }\n\n if (this.onFileLoaded) {\n this.onFileLoaded(file);\n }\n\n this.emit(action, file);\n }\n\n async handleFileRemove(file) {\n if (this.shouldSkipFile(file, this.allFiles)) {\n this.log('skip', `Skipping remove: ${getFileName(file)}`);\n return;\n }\n\n const fileName = getFileName(file);\n const filePath = getFilePath(file);\n\n this.log('remove', `HMR remove: ${fileName}`);\n console.log(`%c \u2514\u2500 Path: ${filePath}`, 'color: #888888; font-style: italic;');\n\n // If this file was overriding something, only restore the original\n // if no other overrides are still actively replacing it\n const overriddenFile = this.overrideMap.get(file);\n if (overriddenFile) {\n this.overrideMap.delete(file);\n\n const remainingOverrides = this._reverseOverrideMap.get(overriddenFile);\n if (remainingOverrides) {\n remainingOverrides.delete(file);\n if (remainingOverrides.size === 0) {\n // No more overrides for this target, safe to restore\n this._reverseOverrideMap.delete(overriddenFile);\n this.log('override', `Restoring: ${getFileName(overriddenFile)}`);\n\n const originalExists = this.allFiles.includes(overriddenFile);\n if (originalExists) {\n try {\n await this.fileLoader.loadFile(overriddenFile);\n } catch (e) {\n this.log('error', `Failed to restore original: ${getFileName(overriddenFile)} - ${e.message}`);\n // Remove from allFiles since it's clearly gone\n this.allFiles = this.allFiles.filter(f => f !== overriddenFile);\n }\n } else {\n this.log('warning', `Original file no longer tracked, skipping restore: ${getFileName(overriddenFile)}`);\n }\n }\n }\n }\n\n await this.fileLoader.removeFile(file);\n this.emit(HMR_ACTIONS.REMOVE, file);\n }\n\n async handleMessage(data) {\n if (data.type === HMR_ACTIONS.INIT) {\n this.emit(HMR_ACTIONS.INIT, data);\n\n this.watchFiles = data.config?.watchFiles ?? true;\n if (!this.watchFiles) {\n this.log('info', 'Static snapshot mode -> live watching disabled');\n }\n\n // Merge server cold patterns with any client configured patterns,\n // so that both sources are respected.\n if (data.config?.cold?.length) {\n // Always merge from the original client patterns, not the previously merged ones\n const merged = [...new Set([...(this._coldPatterns || []), ...data.config.cold])];\n this.isColdFile = this.makeFilter(merged, this._filterCold);\n }\n\n if (data.files && data.files.length > 0) {\n this.allFiles = [...data.files];\n await this.processInitFiles(data.files);\n } else {\n const modeLabel = this.watchFiles ? 'HMR ready' : 'Static snapshot ready';\n this.log('success', `${modeLabel} (${sorted.length} files loaded)`);\n }\n return;\n }\n\n const { action, file } = data;\n if (!action || !file) return;\n\n if (action === HMR_ACTIONS.ADD) {\n this.allFiles = [...this.allFiles, file];\n }\n\n if (action === HMR_ACTIONS.REMOVE) {\n this.allFiles = this.allFiles.filter(f => f !== file);\n }\n\n if (action === HMR_ACTIONS.RELOAD || action === HMR_ACTIONS.ADD) {\n await this.handleFileChange(file, action, data.cold ?? false);\n }\n\n if (action === HMR_ACTIONS.REMOVE) {\n await this.handleFileRemove(file);\n }\n }\n\n /**\n * Register an event handler\n * @param {'init'|'reload'|'add'|'remove'|'cold'|'connect'|'disconnect'|'error'} event - Event name\n * @param {Function} handler - Event handler function\n * @returns {HMRClient} This client for chaining\n */\n on(event, handler) {\n if (!this.eventHandlers.has(event)) {\n this.eventHandlers.set(event, []);\n }\n this.eventHandlers.get(event).push(handler);\n return this;\n }\n\n /**\n * Register a one-time event handler that auto-removes itself after the first call\n * @param {'init'|'reload'|'add'|'remove'|'cold'|'connect'|'disconnect'|'error'} event - Event name\n * @param {Function} handler - Event handler function\n * @returns {HMRClient} This client for chaining\n */\n once(event, handler) {\n const wrapper = (...args) => {\n this.off(event, wrapper);\n handler(...args);\n };\n wrapper._original = handler;\n return this.on(event, wrapper);\n }\n\n /**\n * Remove a previously registered event handler\n * @param {'init'|'reload'|'add'|'remove'|'cold'|'connect'|'disconnect'|'error'} event - Event name\n * @param {Function} handler - The exact handler reference passed to `on()`\n * @returns {HMRClient} This client for chaining\n */\n off(event, handler) {\n const handlers = this.eventHandlers.get(event);\n if (!handlers) return this;\n if (!handler) {\n // Remove all handlers for this event\n this.eventHandlers.delete(event);\n return this;\n }\n\n const remaining = handlers.filter(h => h !== handler && h._original !== handler);\n if (remaining.length === handlers.length) return this;\n\n if (remaining.length === 0) {\n this.eventHandlers.delete(event);\n } else {\n this.eventHandlers.set(event, remaining);\n }\n return this;\n }\n\n emit(event, ...args) {\n const handlers = this.eventHandlers.get(event);\n if (!handlers) return;\n\n // Snapshot to prevent mutation issues during emit\n for (const handler of [...handlers]) {\n handler(...args);\n }\n }\n\n // Push an incoming message onto the serial queue and drain it if not already\n // running. This ensures handleMessage calls never execute concurrently, a\n // rapid pair of change events for the same file would otherwise race between\n // removeFile and loadFile and could leave the DOM in a broken state.\n _enqueueMessage(data) {\n this._messageQueue.push(data);\n if (!this._processingMessages) this._drainMessageQueue();\n }\n\n async _drainMessageQueue() {\n this._processingMessages = true;\n while (this._messageQueue.length > 0) {\n const data = this._messageQueue.shift();\n try {\n await this.handleMessage(data);\n } catch (e) {\n this.log('error', `Message handling error: ${e.message}`);\n }\n }\n this._processingMessages = false;\n }\n\n /**\n * Connect to the HMR server\n * @returns {Promise<void>}\n */\n connect() {\n this.autoReconnect = this._autoReconnectDefault;\n if (this._reconnectTimer) {\n clearTimeout(this._reconnectTimer);\n this._reconnectTimer = null;\n }\n\n // Prevent orphaned sockets if called while already connected or connecting\n if (this.socket) {\n this.socket.onopen = null;\n this.socket.onclose = null;\n this.socket.onerror = null;\n this.socket.onmessage = null;\n this.socket.close();\n this.socket = null;\n }\n\n return new Promise((resolve, reject) => {\n // Guards against onerror and onclose both settling the Promise\n let settled = false;\n\n try {\n this.socket = new WebSocket(this.wsUrl);\n\n this.socket.onopen = () => {\n settled = true;\n this.isConnected = true;\n this.reconnectAttempts = 0;\n // Discard any messages queued from the previous connection\n this._messageQueue = [];\n this._processingMessages = false;\n this.log('success', 'HMR connected');\n this.emit('connect');\n resolve();\n };\n\n this.socket.onclose = () => {\n this.isConnected = false;\n this.socket = null;\n this.emit('disconnect');\n\n // Reconnect on any disconnect, including failed initial attempts\n if (this.autoReconnect) {\n const delay = Math.min(\n this.reconnectDelay * Math.pow(1.5, this.reconnectAttempts++),\n this.maxReconnectDelay\n );\n\n const msg = settled\n ? `HMR disconnected, retrying in ${(delay / 1000).toFixed(1)}s...`\n : `HMR connection failed, retrying in ${(delay / 1000).toFixed(1)}s...`;\n\n this.log('disconnect', msg);\n this._reconnectTimer = setTimeout(() => {\n this.connect().catch((error) => {\n this.log('error', `Reconnect attempt failed: ${error.message}`);\n this.emit('error', error);\n });\n }, delay);\n } else {\n if (settled) this.log('disconnect', 'HMR disconnected');\n }\n };\n\n this.socket.onerror = (error) => {\n const errorMsg = error.message || 'Connection failed';\n this.log('error', `HMR error: ${errorMsg}`);\n this.emit('error', error);\n if (!settled) { settled = true; reject(error); }\n };\n\n this.socket.onmessage = (event) => {\n try {\n const data = JSON.parse(event.data);\n this._enqueueMessage(data);\n } catch (e) {\n this.log('error', `Failed to parse message: ${e.message}`);\n }\n };\n\n } catch (error) {\n this.log('error', `Failed to create WebSocket: ${error.message}`);\n reject(error);\n }\n });\n }\n\n /**\n * Disconnect from the HMR server and clean up\n */\n disconnect() {\n this.autoReconnect = false;\n this.reconnectAttempts = 0;\n this.isConnected = false;\n clearTimeout(this._reconnectTimer);\n this._reconnectTimer = null;\n if (this.socket) {\n this.socket.close();\n this.socket = null;\n }\n }\n}"],
5
5
  "mappings": "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",
6
6
  "names": ["opts", "value", "rest", "source", "picomatch", "state", "require_picomatch", "picomatch", "picomatch", "sorted"]
7
7
  }