@real-router/core 0.8.0 â 0.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +0 -1
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/metafile-cjs.json +1 -1
- package/dist/esm/index.mjs +1 -1
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/metafile-esm.json +1 -1
- package/package.json +3 -4
package/dist/cjs/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../type-guards/src/guards/navigation.ts","../../../type-guards/src/internal/router-error.ts","../../../type-guards/src/guards/routes.ts","../../../type-guards/src/guards/params.ts","../../../type-guards/src/internal/meta-fields.ts","../../../type-guards/src/guards/state.ts","../../../type-guards/src/guards/primitives.ts","../../../type-guards/src/validators/routes.ts","../../../type-guards/src/utilities/type-description.ts","../../../type-guards/src/validators/state.ts","../../src/constants.ts","../../src/helpers.ts","../../src/namespaces/DependenciesNamespace/validators.ts","../../src/namespaces/DependenciesNamespace/DependenciesNamespace.ts","../../src/namespaces/ObservableNamespace/constants.ts","../../src/namespaces/ObservableNamespace/helpers.ts","../../src/namespaces/ObservableNamespace/ObservableNamespace.ts","../../src/namespaces/OptionsNamespace/constants.ts","../../src/namespaces/OptionsNamespace/helpers.ts","../../src/namespaces/OptionsNamespace/validators.ts","../../src/namespaces/OptionsNamespace/OptionsNamespace.ts","../../src/namespaces/StateNamespace/helpers.ts","../../src/namespaces/StateNamespace/StateNamespace.ts","../../src/namespaces/MiddlewareNamespace/validators.ts","../../src/namespaces/MiddlewareNamespace/MiddlewareNamespace.ts","../../src/namespaces/PluginsNamespace/constants.ts","../../src/namespaces/PluginsNamespace/validators.ts","../../src/namespaces/PluginsNamespace/PluginsNamespace.ts","../../src/namespaces/RouteLifecycleNamespace/validators.ts","../../src/namespaces/RouteLifecycleNamespace/RouteLifecycleNamespace.ts","../../../search-params/src/decode.ts","../../../search-params/src/strategies/array.ts","../../../search-params/src/strategies/boolean.ts","../../../search-params/src/strategies/null.ts","../../../search-params/src/strategies/index.ts","../../../search-params/src/encode.ts","../../../search-params/src/utils.ts","../../../search-params/src/searchParams.ts","../../../route-tree/src/parser/path-parser/buildPathFromPattern.ts","../../../route-tree/src/parser/path-parser/constants.ts","../../../route-tree/src/parser/path-parser/encoding.ts","../../../route-tree/src/parser/path-parser/tokeniser.ts","../../../route-tree/src/parser/path-parser/Path.ts","../../../route-tree/src/parser/defaultParserFactory.ts","../../../route-tree/src/builder/buildTree.ts","../../../route-tree/src/builder/computeCaches.ts","../../../route-tree/src/builder/sortTree.ts","../../../route-tree/src/builder/createRouteTree.ts","../../../route-tree/src/operations/match.ts","../../../route-tree/src/operations/query.ts","../../../route-tree/src/validation/errors.ts","../../../route-tree/src/operations/build.ts","../../../route-tree/src/operations/meta.ts","../../../route-tree/src/operations/routeTreeToDefinitions.ts","../../../route-tree/src/validation/routes.ts","../../../route-tree/src/validation/route-batch.ts","../../src/namespaces/RoutesNamespace/constants.ts","../../src/namespaces/RoutesNamespace/helpers.ts","../../src/namespaces/RoutesNamespace/stateBuilder.ts","../../src/namespaces/RoutesNamespace/validators.ts","../../src/transitionPath.ts","../../src/namespaces/RoutesNamespace/RoutesNamespace.ts","../../src/namespaces/NavigationNamespace/helpers.ts","../../../logger/src/constants.ts","../../../logger/src/Logger.ts","../../src/namespaces/NavigationNamespace/transition/makeError.ts","../../src/namespaces/NavigationNamespace/transition/mergeStates.ts","../../src/RouterError.ts","../../src/namespaces/NavigationNamespace/transition/processLifecycleResult.ts","../../src/namespaces/NavigationNamespace/transition/shared.ts","../../src/namespaces/NavigationNamespace/transition/wrapSyncError.ts","../../src/namespaces/NavigationNamespace/transition/executeLifecycleHooks.ts","../../src/namespaces/NavigationNamespace/transition/executeMiddleware.ts","../../src/namespaces/NavigationNamespace/transition/index.ts","../../src/namespaces/NavigationNamespace/validators.ts","../../src/namespaces/NavigationNamespace/NavigationNamespace.ts","../../src/namespaces/RouterLifecycleNamespace/constants.ts","../../src/namespaces/RouterLifecycleNamespace/helpers.ts","../../src/namespaces/RouterLifecycleNamespace/RouterLifecycleNamespace.ts","../../src/namespaces/CloneNamespace/CloneNamespace.ts","../../src/typeGuards.ts","../../src/Router.ts","../../src/createRouter.ts"],"names":["logger","plugins","unsubscribed","encodeValue","hasPrefix","getSearch","createRouterError","FULL_ROUTE_PATTERN","HAS_NON_WHITESPACE","MAX_ROUTE_NAME_LENGTH","getTypeDescription","validateRouteName","DEFAULT_ROUTE_NAME","safeCallback","LOG_TAG","noop"],"mappings":"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","file":"index.js","sourcesContent":["// packages/type-guards/modules/guards/navigation.ts\n\nimport type { NavigationOptions } from \"@real-router/types\";\n\n// Constant in module scope - created once, not on every call\nconst NAVIGATION_OPTIONS_FIELDS = [\n \"replace\",\n \"reload\",\n \"skipTransition\",\n \"force\",\n \"forceDeactivate\",\n \"redirected\",\n] as const;\n\n/**\n * Type guard for NavigationOptions.\n * Validates all optional boolean fields.\n *\n * @param value - Value to check\n * @returns true if value is a valid NavigationOptions object\n *\n * @example\n * isNavigationOptions({ replace: true }); // true\n * isNavigationOptions({ reload: false, force: true }); // true\n * isNavigationOptions({ replace: \"true\" }); // false (not boolean)\n * isNavigationOptions(null); // false\n */\nexport function isNavigationOptions(\n value: unknown,\n): value is NavigationOptions {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n // for-of instead of .every() - no iterator/callback allocation\n for (const field of NAVIGATION_OPTIONS_FIELDS) {\n const fieldValue = obj[field];\n\n if (fieldValue !== undefined && typeof fieldValue !== \"boolean\") {\n return false;\n }\n }\n\n return true;\n}\n","// packages/type-guards/modules/internal/router-error.ts\n\n/**\n * Checks if string contains at least one non-whitespace character.\n * Used to validate that route name is not empty or only whitespace.\n * Matches: any non-whitespace character (\\S = [^ \\t\\n\\r\\f])\n *\n * @internal\n */\nexport const HAS_NON_WHITESPACE = /\\S/;\n\n/**\n * Pattern for complete route validation (all segments at once).\n * Matches: single segment or multiple segments separated by dots.\n * Each segment must start with letter/underscore, followed by alphanumeric/hyphen/underscore.\n * Rejects: leading/trailing/consecutive dots, segments starting with numbers/hyphens.\n * Note: Empty string is handled by early return in validateRouteName.\n *\n * @internal\n */\nexport const FULL_ROUTE_PATTERN = /^[A-Z_a-z][\\w-]*(?:\\.[A-Z_a-z][\\w-]*)*$/;\n\n/**\n * Maximum route name length to prevent DoS and performance issues.\n * This is a technical limit, not a business constraint.\n * Real route names rarely exceed 200 characters even with deep nesting.\n *\n * @internal\n */\nexport const MAX_ROUTE_NAME_LENGTH = 10_000;\n\n/**\n * Creates a TypeError with consistent router error message format.\n *\n * @param methodName - Name of the method that triggered the error\n * @param message - Error message\n * @returns TypeError with formatted message\n * @internal\n */\nexport function createRouterError(\n methodName: string,\n message: string,\n): TypeError {\n return new TypeError(`[router.${methodName}] ${message}`);\n}\n","// packages/type-guards/modules/guards/routes.ts\n\nimport {\n FULL_ROUTE_PATTERN,\n MAX_ROUTE_NAME_LENGTH,\n} from \"../internal/router-error\";\n\n/**\n * Type guard that checks if a value is a valid route name.\n *\n * Route name rules:\n * - Must be a string\n * - Empty string (\"\") is valid and represents the root node\n * - Can use dots (.) for hierarchy (e.g., \"users.profile\")\n * - Each segment must match [a-zA-Z_][a-zA-Z0-9_-]*\n * - No consecutive dots (..)\n * - No leading/trailing dots\n * - Cannot contain only whitespace\n * - System routes (starting with @@) bypass pattern validation\n *\n * @param name - Value to check\n * @returns true if name is a valid route name string\n *\n * @example\n * // Valid names\n * isRouteName(\"\"); // true (root node)\n * isRouteName(\"home\"); // true\n * isRouteName(\"users.profile\"); // true\n * isRouteName(\"admin_panel\"); // true\n * isRouteName(\"api-v2\"); // true\n * isRouteName(\"@@router/UNKNOWN_ROUTE\"); // true (system route)\n *\n * @example\n * // Invalid names\n * isRouteName(\" \"); // false (only whitespace)\n * isRouteName(\".users\"); // false (leading dot)\n * isRouteName(\"users.\"); // false (trailing dot)\n * isRouteName(\"users..profile\"); // false (consecutive dots)\n * isRouteName(\"users.123\"); // false (segment starts with number)\n * isRouteName(\"users profile\"); // false (contains space)\n */\nexport function isRouteName(name: unknown): name is string {\n if (typeof name !== \"string\") {\n return false;\n }\n\n // Empty string is valid (represents root node)\n if (name === \"\") {\n return true;\n }\n\n // Too long is invalid\n if (name.length > MAX_ROUTE_NAME_LENGTH) {\n return false;\n }\n\n // System routes are valid (bypass pattern validation)\n if (name.startsWith(\"@@\")) {\n return true;\n }\n\n // Regular routes must match pattern\n // Note: FULL_ROUTE_PATTERN rejects whitespace-only strings\n return FULL_ROUTE_PATTERN.test(name);\n}\n","// packages/type-guards/modules/guards/params.ts\n\nimport type { Params } from \"@real-router/types\";\n\n/**\n * Internal helper to check if value is serializable (no circular refs, functions, instances).\n * Recursively validates the entire object tree with protection against circular references.\n *\n * @param value - Value to check\n * @param visited - Set of visited objects to detect circular references\n * @returns true if value can be serialized\n * @internal\n */\nfunction isSerializable(\n value: unknown,\n visited = new WeakSet<object>(),\n): boolean {\n // null/undefined are serializable (JSON.stringify handles them)\n if (value === null || value === undefined) {\n return true;\n }\n\n const type = typeof value;\n\n // Primitives: string, boolean\n if (type === \"string\" || type === \"boolean\") {\n return true;\n }\n\n // Numbers: must be finite (reject NaN and Infinity)\n if (type === \"number\") {\n return Number.isFinite(value);\n }\n\n // Functions and symbols cannot be serialized\n if (type === \"function\" || type === \"symbol\") {\n return false;\n }\n\n // Arrays (including nested arrays)\n if (Array.isArray(value)) {\n // Circular reference detection\n if (visited.has(value)) {\n return false;\n }\n\n visited.add(value);\n\n // Recursively check all items\n return value.every((item) => isSerializable(item, visited));\n }\n\n // Objects\n if (type === \"object\") {\n // Circular reference detection\n if (visited.has(value)) {\n return false;\n }\n\n // Add to visited set\n visited.add(value);\n\n // Only allow plain objects (reject Date, RegExp, Map, Set, etc.)\n const proto = Object.getPrototypeOf(value) as object | null;\n\n if (proto !== null && proto !== Object.prototype) {\n return false; // Instance of a class\n }\n\n // Recursively check all values\n return Object.values(value).every((v) => isSerializable(v, visited));\n }\n\n return false;\n}\n\n/**\n * Fast path check for primitive values (no recursion needed).\n * Returns true if primitive, false if needs deeper inspection.\n *\n * @internal\n */\nfunction isPrimitiveValue(value: unknown): boolean {\n if (value === null || value === undefined) {\n return true;\n }\n\n const type = typeof value;\n\n if (type === \"string\" || type === \"boolean\") {\n return true;\n }\n\n if (type === \"number\") {\n return Number.isFinite(value);\n }\n\n // object, array, function, symbol â need deeper check\n return false;\n}\n\n/**\n * Type guard for Params object.\n * Validates that all values are serializable (primitives, arrays, nested arrays, or nested objects).\n * Rejects circular references, functions, symbols, and class instances.\n * Allows null/undefined anywhere (objects and arrays).\n *\n * Performance optimization: Uses two-phase validation.\n * Phase 1 (fast path): Check if all values are primitives â O(p) without recursion.\n * Phase 2 (slow path): Full recursive validation only if nested structures detected.\n *\n * @param value - Value to check\n * @returns true if value is a valid Params object\n *\n * @example\n * // Valid\n * isParams({ id: '123', page: 1 }); // true (fast path)\n * isParams({ sort: ['name', 'age'] }); // true (slow path)\n * isParams({ filter: { status: 'active' } }); // true (slow path)\n * isParams({ teamId: null, orgId: undefined }); // true (fast path)\n * isParams({ matrix: [[1, 2], [3, 4]] }); // true (slow path)\n * isParams({ users: [{ id: 1 }, { id: 2 }] }); // true (slow path)\n * isParams({ scores: [100, null, 85] }); // true (slow path)\n *\n * // Invalid\n * isParams({ fn: () => {} }); // false (function)\n * isParams({ date: new Date() }); // false (class instance)\n * isParams({ self: circularRef }); // false (circular reference)\n * isParams(null); // false (not an object)\n * isParams([]); // false (array, not object)\n */\nexport function isParams(value: unknown): value is Params {\n // Reject null, undefined, and arrays (must be a plain object)\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n return false;\n }\n\n // Reject objects with custom prototype (e.g., Object.create(proto), class instances)\n // This check is required for both fast and slow paths\n const proto = Object.getPrototypeOf(value) as object | null;\n\n if (proto !== null && proto !== Object.prototype) {\n return false;\n }\n\n // Phase 1: Fast path for flat objects (95%+ of real-world params)\n // Check if all values are primitives â no recursion, no WeakSet allocation\n let needsDeepCheck = false;\n\n for (const key in value) {\n // Skip inherited properties (only check own properties for fast path)\n // Note: With proto === Object.prototype check above, inherited properties\n // would only come from Object.prototype, which has no enumerable properties.\n // This check is defensive against Object.prototype pollution.\n /* v8 ignore next 3 -- @preserve Defensive: Object.prototype pollution */\n if (!Object.hasOwn(value, key)) {\n continue;\n }\n\n const val = (value as Record<string, unknown>)[key];\n\n if (!isPrimitiveValue(val)) {\n // Found non-primitive â need full validation\n // But first check for obvious invalids (functions, symbols)\n const type = typeof val;\n\n if (type === \"function\" || type === \"symbol\") {\n return false; // Early reject\n }\n\n needsDeepCheck = true;\n\n break; // Exit fast path, proceed to slow path\n }\n }\n\n // Fast path: all primitives, valid params\n if (!needsDeepCheck) {\n return true;\n }\n\n // Phase 2: Slow path â full recursive validation\n return isSerializable(value);\n}\n\n/**\n * Internal helper for strict param validation (browser plugin).\n * Only allows primitives and arrays of primitives, no nested objects.\n *\n * @param value - Value to check\n * @returns true if value is valid\n * @internal\n */\nexport function isValidParamValueStrict(value: unknown): boolean {\n if (value === null || value === undefined) {\n return true;\n }\n\n const type = typeof value;\n\n // Primitives: string, boolean, finite number\n if (type === \"string\" || type === \"boolean\") {\n return true;\n }\n\n if (type === \"number\") {\n return Number.isFinite(value as number);\n }\n\n // Arrays of primitives only\n if (Array.isArray(value)) {\n return value.every((item) => {\n const itemType = typeof item;\n\n // Primitives: string, boolean, finite number\n if (itemType === \"string\" || itemType === \"boolean\") {\n return true;\n }\n\n if (itemType === \"number\") {\n return Number.isFinite(item);\n }\n\n // Reject everything else (objects, arrays, functions, symbols, etc.)\n return false;\n });\n }\n\n // Reject objects, functions, symbols, etc.\n return false;\n}\n\n/**\n * Strict type guard for Params (browser plugin version).\n * Only allows primitives and arrays of primitives, no nested objects.\n *\n * @param value - Value to check\n * @returns true if value is a valid Params object\n */\nexport function isParamsStrict(value: unknown): value is Params {\n // Check if value is an object (null returns \"object\" but fails Array.isArray and other checks)\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n return false;\n }\n\n // Check all own properties have valid param values\n for (const key in value) {\n if (!Object.hasOwn(value, key)) {\n continue; // Skip inherited properties\n }\n\n const val = (value as Record<string, unknown>)[key];\n\n if (!isValidParamValueStrict(val)) {\n return false;\n }\n }\n\n return true;\n}\n","// packages/type-guards/modules/internal/meta-fields.ts\n\nimport { isParams, isParamsStrict } from \"../guards/params\";\nimport { isRouteName } from \"../guards/routes\";\n\nimport type { Params, StateMeta } from \"@real-router/types\";\n\n/**\n * Type guard for meta object fields if present.\n * Used by both isStateStrict and isHistoryState.\n *\n * @param meta - Value to check\n * @returns true if meta has valid StateMeta structure\n * @internal\n */\nexport function isMetaFields<MP extends Params = Params>(\n meta: unknown,\n): meta is StateMeta<MP> {\n // Early check: must be a non-null object\n if (typeof meta !== \"object\" || meta === null) {\n return false;\n }\n\n const obj = meta as Record<string, unknown>;\n\n // Check params field if present\n if (\"params\" in obj && !isParamsStrict(obj.params)) {\n return false;\n }\n\n // Check options field if present\n if (\"options\" in obj && typeof obj.options !== \"object\") {\n return false;\n }\n\n // Check id field if present\n if (\"id\" in obj && typeof obj.id !== \"number\") {\n return false;\n }\n\n // Check redirected field if present\n if (\"redirected\" in obj && typeof obj.redirected !== \"boolean\") {\n return false;\n }\n\n // Check source field if present\n return !(\"source\" in obj && typeof obj.source !== \"string\");\n}\n\n/**\n * Type guard helper that checks if required State fields have valid types.\n * Validates that name, path, and params exist and have correct types.\n * Used by both isStateStrict and isHistoryState.\n *\n * @param obj - Object to check\n * @returns true if object has valid required fields\n * @internal\n */\nexport function isRequiredFields(obj: Record<string, unknown>): boolean {\n return (\n isRouteName(obj.name) &&\n typeof obj.path === \"string\" &&\n isParams(obj.params)\n );\n}\n","// packages/type-guards/modules/guards/state.ts\n\nimport { isMetaFields, isRequiredFields } from \"../internal/meta-fields\";\n\nimport type { Params, State } from \"@real-router/types\";\n\n/**\n * Type guard for State object.\n * Checks for required fields: name, params, path.\n * Does NOT validate meta field deeply.\n *\n * @param value - Value to check\n * @returns true if value is a valid State object\n *\n * @example\n * isState({ name: 'home', params: {}, path: '/' }); // true\n * isState({ name: 'home', path: '/' }); // false (missing params)\n */\nexport function isState<P extends Params = Params, MP extends Params = Params>(\n value: unknown,\n): value is State<P, MP> {\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n return isRequiredFields(obj);\n}\n\n/**\n * Enhanced type guard for State with deep validation.\n * Checks not only presence but also types of all required fields.\n * Validates params using isParams and meta structure if present.\n *\n * @param value - Value to check\n * @returns true if value is a valid State object with correct types\n *\n * @example\n * isStateStrict({ name: 'home', params: {}, path: '/', meta: { id: 1 } }); // true\n * isStateStrict({ name: 'home', params: 'invalid', path: '/' }); // false\n */\nexport function isStateStrict<\n P extends Params = Params,\n MP extends Params = Params,\n>(value: unknown): value is State<P, MP> {\n // Basic structure check\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n // Check required fields and their types\n if (!isRequiredFields(obj)) {\n return false;\n }\n\n // Validate meta if present\n if (obj.meta !== undefined) {\n return isMetaFields(obj.meta);\n }\n\n return true;\n}\n\n/**\n * Type guard for HistoryState (browser plugin).\n * HistoryState must have meta object with specific structure.\n * This is stricter than regular State validation.\n *\n * @param value - Value to check\n * @returns true if value is a valid HistoryState object\n */\nexport function isHistoryState(value: unknown): value is State & {\n meta: NonNullable<State[\"meta\"]>;\n} {\n // Basic structure check\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n // Check required fields and their types\n if (!isRequiredFields(obj)) {\n return false;\n }\n\n // HistoryState requires meta to be present and valid\n // Note: The check !(\"meta\" in obj) is redundant because isMetaFields(undefined) returns false\n // However, we keep it for clarity and explicit error semantics\n return \"meta\" in obj && isMetaFields(obj.meta);\n}\n","// packages/type-guards/modules/primitives.ts\n\n/**\n * Type guard for string type.\n *\n * @param value - Value to check\n * @returns true if value is a string\n */\nexport function isString(value: unknown): value is string {\n return typeof value === \"string\";\n}\n\n/**\n * Type guard for boolean type.\n *\n * @param value - Value to check\n * @returns true if value is a boolean\n */\nexport function isBoolean(value: unknown): value is boolean {\n return typeof value === \"boolean\";\n}\n\n/**\n * Type guard for Promise type.\n *\n * @param value - Value to check\n * @returns true if value is a Promise\n */\nexport function isPromise<T = unknown>(value: unknown): value is Promise<T> {\n return (\n typeof value === \"object\" &&\n value !== null &&\n \"then\" in value &&\n typeof value.then === \"function\"\n );\n}\n\n/**\n * Type guard for object key existence.\n * Narrows the key type to a valid key of the object.\n *\n * @param key - Key to check\n * @param obj - Object to check in\n * @returns true if key exists in object\n */\nexport function isObjKey<T extends object>(\n key: string,\n obj: T,\n): key is Extract<keyof T, string> {\n return key in obj;\n}\n\n/**\n * Type guard for primitive values suitable for URL parameters.\n * Only string, number, and boolean are allowed.\n * Rejects NaN and Infinity for numbers.\n *\n * @param value - Value to check\n * @returns true if value is string, number, or boolean\n */\nexport function isPrimitiveValue(\n value: unknown,\n): value is string | number | boolean {\n if (typeof value === \"number\") {\n return Number.isFinite(value);\n }\n\n return typeof value === \"string\" || typeof value === \"boolean\";\n}\n","// packages/type-guards/modules/validators/routes.ts\n\nimport {\n createRouterError,\n FULL_ROUTE_PATTERN,\n HAS_NON_WHITESPACE,\n MAX_ROUTE_NAME_LENGTH,\n} from \"../internal/router-error\";\n\n/**\n * Validates that a route name is a valid string and matches the expected format.\n * Throws a descriptive error if validation fails.\n *\n * Route name rules:\n * - Must be a string\n * - Empty string (\"\") is valid and represents the root node\n * - Can use dots (.) for hierarchy (e.g., \"users.profile\")\n * - Each segment must match [a-zA-Z_][a-zA-Z0-9_-]*\n * - No consecutive dots (..)\n * - No leading/trailing dots\n * - Cannot contain only whitespace\n * - System routes (starting with @@) bypass pattern validation\n *\n * @param name - Route name to validate\n * @param methodName - Name of calling method for error messages\n * @throws {TypeError} If name is invalid\n *\n * @example\n * // Valid names\n * validateRouteName(\"\", \"add\"); // ok (root node)\n * validateRouteName(\"home\", \"add\"); // ok\n * validateRouteName(\"users.profile\", \"add\"); // ok\n * validateRouteName(\"@@router/UNKNOWN_ROUTE\", \"add\"); // ok (system route)\n *\n * @example\n * // Invalid names (throws)\n * validateRouteName(\" \", \"add\"); // throws (only whitespace)\n * validateRouteName(\".users\", \"add\"); // throws (leading dot)\n * validateRouteName(\"users.\", \"add\"); // throws (trailing dot)\n * validateRouteName(\"users..profile\", \"add\"); // throws (consecutive dots)\n * validateRouteName(\"users.123\", \"add\"); // throws (segment starts with number)\n * validateRouteName(\"users profile\", \"add\"); // throws (contains space)\n */\nexport function validateRouteName(\n name: unknown,\n methodName: string,\n): asserts name is string {\n // Type check\n if (typeof name !== \"string\") {\n throw createRouterError(\n methodName,\n `Route name must be a string, got ${typeof name}`,\n );\n }\n\n // Empty string is valid (represents root node) - fast path\n if (name === \"\") {\n return;\n }\n\n // Whitespace-only strings are invalid\n if (!HAS_NON_WHITESPACE.test(name)) {\n throw createRouterError(\n methodName,\n \"Route name cannot contain only whitespace\",\n );\n }\n\n // Length check for technical safety\n if (name.length > MAX_ROUTE_NAME_LENGTH) {\n throw createRouterError(\n methodName,\n `Route name exceeds maximum length of ${MAX_ROUTE_NAME_LENGTH} characters. This is a technical safety limit.`,\n );\n }\n\n // System routes bypass validation (e.g., @@router/UNKNOWN_ROUTE)\n // SECURITY NOTE: System routes are currently created ONLY in router code,\n // not from user input. If this changes, add sanitization for <>\"'&\\x00-\\x1F\n if (name.startsWith(\"@@\")) {\n return;\n }\n\n // Validate route pattern\n if (!FULL_ROUTE_PATTERN.test(name)) {\n throw createRouterError(\n methodName,\n `Invalid route name \"${name}\". Each segment must start with a letter or underscore, followed by letters, numbers, underscores, or hyphens. Segments are separated by dots (e.g., \"users.profile\").`,\n );\n }\n}\n","// packages/type-guards/modules/internal/type-description.ts\n\n/**\n * Gets a human-readable description of a value's type.\n * Used for error messages to provide helpful debugging information.\n *\n * @param value - Value to describe\n * @returns String description of the value's type\n *\n * @example\n * getTypeDescription(null); // \"null\"\n * getTypeDescription([1, 2, 3]); // \"array[3]\"\n * getTypeDescription(new Date()); // \"Date\"\n * getTypeDescription({}); // \"object\"\n * getTypeDescription(\"hello\"); // \"string\"\n */\nexport function getTypeDescription(value: unknown): string {\n // Handle null explicitly (typeof null === \"object\")\n if (value === null) {\n return \"null\";\n }\n\n // Array with length info\n if (Array.isArray(value)) {\n return `array[${value.length}]`;\n }\n\n if (typeof value === \"object\") {\n // Return constructor name for class instances\n if (\"constructor\" in value && value.constructor.name !== \"Object\") {\n return value.constructor.name;\n }\n\n // Plain object\n return \"object\";\n }\n\n // Primitive types (string, number, boolean, undefined, etc.)\n // Note: typeof undefined === \"undefined\", so we don't need explicit check\n return typeof value;\n}\n","// packages/type-guards/modules/validators/state.ts\n\nimport { isState } from \"../guards\";\nimport { getTypeDescription } from \"../utilities/type-description\";\n\nimport type { State } from \"@real-router/types\";\n\n/**\n * Validates that a state has the correct structure.\n * Throws a descriptive error if validation fails.\n *\n * @param state - State to validate\n * @param method - Context for error message\n * @throws {TypeError} If state structure is invalid\n *\n * @example\n * validateState({ name: 'home', params: {}, path: '/' }, 'navigate'); // ok\n * validateState({ name: 'home' }, 'navigate'); // throws (missing params, path)\n * validateState(null, 'navigate'); // throws (not an object)\n */\nexport function validateState(\n state: unknown,\n method: string,\n): asserts state is State {\n if (!isState(state)) {\n throw new TypeError(\n `[${method}] Invalid state structure: ${getTypeDescription(state)}. ` +\n `Expected State object with name, params, and path properties.`,\n );\n }\n}\n","// packages/real-router/modules/constants.ts\n\nimport type {\n EventToNameMap,\n EventToPluginMap,\n ErrorCodeToValueMap,\n ErrorCodeKeys,\n ErrorCodeValues,\n} from \"@real-router/types\";\n\nexport type ConstantsKeys = \"UNKNOWN_ROUTE\";\n\nexport type Constants = Record<ConstantsKeys, string>;\n\n// =============================================================================\n// Error Codes (migrated from router-error)\n// =============================================================================\n\nexport type ErrorCodes = Record<ErrorCodeKeys, ErrorCodeValues>;\n\n/**\n * Error codes for router operations.\n * Used to identify specific failure scenarios in navigation and lifecycle.\n * Frozen to prevent accidental modifications.\n */\nexport const errorCodes: ErrorCodeToValueMap = Object.freeze({\n ROUTER_NOT_STARTED: \"NOT_STARTED\", // navigate() called before start()\n NO_START_PATH_OR_STATE: \"NO_START_PATH_OR_STATE\", // start() without initial route\n ROUTER_ALREADY_STARTED: \"ALREADY_STARTED\", // start() called twice\n ROUTE_NOT_FOUND: \"ROUTE_NOT_FOUND\", // Navigation to non-existent route\n SAME_STATES: \"SAME_STATES\", // Navigate to current route without reload\n CANNOT_DEACTIVATE: \"CANNOT_DEACTIVATE\", // canDeactivate guard blocked navigation\n CANNOT_ACTIVATE: \"CANNOT_ACTIVATE\", // canActivate guard blocked navigation\n TRANSITION_ERR: \"TRANSITION_ERR\", // Generic transition failure\n TRANSITION_CANCELLED: \"CANCELLED\", // Navigation cancelled by user or new navigation\n});\n\n/**\n * General router constants.\n * Special route names and identifiers.\n */\nexport const constants: Constants = {\n UNKNOWN_ROUTE: \"@@router/UNKNOWN_ROUTE\", // Special route for 404/not found states\n};\n\n/**\n * Plugin method names.\n * Maps to methods that plugins can implement to hook into router lifecycle.\n */\nexport const plugins: EventToPluginMap = {\n ROUTER_START: \"onStart\", // Plugin method called when router starts\n ROUTER_STOP: \"onStop\", // Plugin method called when router stops\n TRANSITION_START: \"onTransitionStart\", // Plugin method called when navigation begins\n TRANSITION_CANCEL: \"onTransitionCancel\", // Plugin method called when navigation cancelled\n TRANSITION_SUCCESS: \"onTransitionSuccess\", // Plugin method called when navigation succeeds\n TRANSITION_ERROR: \"onTransitionError\", // Plugin method called when navigation fails\n};\n\n/**\n * Event names for router event system.\n * Used with addEventListener/removeEventListener for reactive subscriptions.\n */\nexport const events: EventToNameMap = {\n ROUTER_START: \"$start\", // Emitted when router.start() succeeds\n ROUTER_STOP: \"$stop\", // Emitted when router.stop() is called\n TRANSITION_START: \"$$start\", // Emitted when navigation begins\n TRANSITION_CANCEL: \"$$cancel\", // Emitted when navigation is cancelled\n TRANSITION_SUCCESS: \"$$success\", // Emitted when navigation completes successfully\n TRANSITION_ERROR: \"$$error\", // Emitted when navigation fails\n};\n\n/**\n * Default limits configuration for the router.\n * These values match the hardcoded constants from the current codebase.\n */\nexport const DEFAULT_LIMITS = {\n maxDependencies: 100,\n maxPlugins: 50,\n maxMiddleware: 50,\n maxListeners: 10_000,\n maxEventDepth: 5,\n maxLifecycleHandlers: 200,\n} as const;\n\n/**\n * Bounds for each limit - defines min and max allowed values.\n * Used for runtime validation in setLimit/withLimits.\n */\nexport const LIMIT_BOUNDS = {\n maxDependencies: { min: 0, max: 10_000 },\n maxPlugins: { min: 0, max: 1000 },\n maxMiddleware: { min: 0, max: 1000 },\n maxListeners: { min: 0, max: 100_000 },\n maxEventDepth: { min: 0, max: 100 },\n maxLifecycleHandlers: { min: 0, max: 10_000 },\n} as const;\n","// packages/real-router/modules/helpers.ts\n\nimport { DEFAULT_LIMITS } from \"./constants\";\n\nimport type { Limits } from \"./types\";\nimport type { State, Options, LimitsConfig } from \"@real-router/types\";\nimport type { BuildOptions, TrailingSlashMode } from \"route-tree\";\n\nexport { getTypeDescription } from \"type-guards\";\n\n// =============================================================================\n// State Helpers\n// =============================================================================\n\n/**\n * Structural type guard for State object.\n * Only checks required fields exist with correct types.\n * Does NOT validate params serializability (allows circular refs).\n *\n * Use `isState` from type-guards for full validation (serializable params).\n * Use this for internal operations like deepFreezeState that handle any object structure.\n *\n * @param value - Value to check\n * @returns true if value has State structure\n * @internal\n */\nfunction isStateStructural(value: unknown): value is State {\n if (value === null || typeof value !== \"object\") {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n return (\n typeof obj.name === \"string\" &&\n typeof obj.path === \"string\" &&\n typeof obj.params === \"object\" &&\n obj.params !== null\n );\n}\n\n/**\n * Deep freezes State object to prevent mutations.\n * Creates a deep clone first, then recursively freezes the clone and all nested objects.\n * Uses simple recursive freezing after cloning (no need for WeakSet since clone has no circular refs).\n *\n * @param state - The State object to freeze\n * @returns A frozen deep clone of the state\n * @throws {TypeError} If state is not a valid State object\n *\n * @example\n * const state = { name: 'home', params: {}, path: '/' };\n * const frozen = deepFreezeState(state);\n * // frozen.params is now immutable\n * // original state is unchanged\n */\nexport function deepFreezeState<T extends State>(state: T): T {\n // Early return for null/undefined\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!state) {\n return state;\n }\n\n // Validate State structure (structural check, allows circular refs)\n if (!isStateStructural(state)) {\n throw new TypeError(\n `[deepFreezeState] Expected valid State object, got: ${typeof state}`,\n );\n }\n\n // Create a deep clone to avoid mutating the original\n // structuredClone preserves circular references, so we need to track visited objects\n const clonedState = structuredClone(state);\n\n // WeakSet to track visited objects (prevent infinite recursion with circular refs)\n const visited = new WeakSet<object>();\n\n // Recursive freeze function with circular reference protection\n function freezeClonedRecursive(obj: unknown): void {\n // Skip primitives, null, undefined\n // Note: typeof undefined === \"undefined\" !== \"object\", so checking undefined is redundant\n if (obj === null || typeof obj !== \"object\") {\n return;\n }\n\n // Skip already visited objects (circular reference protection)\n if (visited.has(obj)) {\n return;\n }\n\n // Mark as visited\n visited.add(obj);\n\n // Freeze the object/array itself\n Object.freeze(obj);\n\n // Get all values to freeze recursively\n const values = Array.isArray(obj) ? obj : Object.values(obj);\n\n // Recursively freeze nested values\n for (const value of values) {\n freezeClonedRecursive(value);\n }\n }\n\n // Freeze the entire cloned state tree\n freezeClonedRecursive(clonedState);\n\n return clonedState;\n}\n\n// WeakSet to track already frozen root objects for O(1) re-freeze check\nconst frozenRoots = new WeakSet<object>();\n\n// Module-scope recursive freeze function - better JIT optimization, no allocation per call\nfunction freezeRecursive(obj: unknown): void {\n // Skip primitives, null\n if (obj === null || typeof obj !== \"object\") {\n return;\n }\n\n // Skip already frozen objects (handles potential shared refs)\n if (Object.isFrozen(obj)) {\n return;\n }\n\n // Freeze the object/array\n Object.freeze(obj);\n\n // Iterate without Object.values() allocation\n if (Array.isArray(obj)) {\n for (const item of obj) {\n freezeRecursive(item);\n }\n } else {\n for (const key in obj) {\n freezeRecursive((obj as Record<string, unknown>)[key]);\n }\n }\n}\n\n/**\n * Freezes State object in-place without cloning.\n * Optimized for hot paths where state is known to be a fresh object.\n *\n * IMPORTANT: Only use this when you know the state is a fresh object\n * that hasn't been exposed to external code yet (e.g., from makeState()).\n *\n * @param state - The State object to freeze (must be a fresh object)\n * @returns The same state object, now frozen\n * @internal\n */\nexport function freezeStateInPlace<T extends State>(state: T): T {\n // Early return for null/undefined - state from makeState() is never null\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!state) {\n return state;\n }\n\n // Fast path: already processed root object - O(1) check\n if (frozenRoots.has(state)) {\n return state;\n }\n\n // Freeze the entire state tree\n freezeRecursive(state);\n\n // Mark root as processed for future calls\n frozenRoots.add(state);\n\n return state;\n}\n\n// =============================================================================\n// Route Options Helpers\n// =============================================================================\n\n/**\n * Maps real-router trailingSlash option to route-tree's trailingSlashMode.\n *\n * @param trailingSlash - real-router trailing slash option\n * @returns route-tree trailing slash mode\n * @internal\n */\nfunction mapTrailingSlashMode(\n trailingSlash: Options[\"trailingSlash\"],\n): TrailingSlashMode {\n switch (trailingSlash) {\n case \"never\": {\n return \"never\";\n }\n case \"always\": {\n return \"always\";\n }\n default: {\n return \"default\";\n }\n }\n}\n\n/**\n * Creates route-tree BuildOptions from real-router Options.\n * Used for buildPath caching in routerLifecycle.ts.\n *\n * @param options - real-router options\n * @returns route-tree build options\n */\nexport function createBuildOptions(options: Options): BuildOptions {\n const buildOptions: BuildOptions = {\n trailingSlashMode: mapTrailingSlashMode(options.trailingSlash),\n queryParamsMode: options.queryParamsMode,\n urlParamsEncoding: options.urlParamsEncoding,\n };\n\n // Only include queryParams if defined (exactOptionalPropertyTypes)\n if (options.queryParams !== undefined) {\n buildOptions.queryParams = options.queryParams;\n }\n\n return buildOptions;\n}\n\n/**\n * Computes warning and error thresholds for a given limit.\n * WARN threshold: 20% of limit\n * ERROR threshold: 50% of limit\n */\nexport function computeThresholds(limit: number): {\n warn: number;\n error: number;\n} {\n return {\n warn: Math.floor(limit * 0.2),\n error: Math.floor(limit * 0.5),\n };\n}\n\n/**\n * Merges user limits with defaults.\n * Returns frozen object for immutability.\n */\nexport function createLimits(userLimits: Partial<LimitsConfig> = {}): Limits {\n return { ...DEFAULT_LIMITS, ...userLimits };\n}\n","// packages/core/src/namespaces/DependenciesNamespace/validators.ts\n\n/**\n * Static validation functions for DependenciesNamespace.\n * Called by Router facade before instance methods.\n *\n * Extracted from DependenciesNamespace class for better separation of concerns.\n */\n\nimport { getTypeDescription } from \"type-guards\";\n\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\n/**\n * Validates that dependency name is a string.\n * Called by facade before get/remove/has operations.\n */\nexport function validateDependencyName(\n name: unknown,\n methodName: string,\n): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.${methodName}]: dependency name must be a string, got ${typeof name}`,\n );\n }\n}\n\n/**\n * Validates setDependency name argument.\n * Value is not validated - any value is valid.\n */\nexport function validateSetDependencyArgs(\n name: unknown,\n): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.setDependency]: dependency name must be a string, got ${typeof name}`,\n );\n }\n}\n\n/**\n * Validates that dependencies object is a plain object without getters.\n * Called by facade before setMultiple/constructor.\n */\nexport function validateDependenciesObject(\n deps: unknown,\n methodName: string,\n): asserts deps is Record<string, unknown> {\n // Reject non-plain objects (classes, Date, Map, Array)\n if (!(deps && typeof deps === \"object\" && deps.constructor === Object)) {\n throw new TypeError(\n `[router.${methodName}] Invalid argument: expected plain object, received ${getTypeDescription(deps)}`,\n );\n }\n\n // Getters can throw, return different values, or have side effects\n for (const key in deps) {\n if (Object.getOwnPropertyDescriptor(deps, key)?.get) {\n throw new TypeError(\n `[router.${methodName}] Getters not allowed: \"${key}\"`,\n );\n }\n }\n}\n\n/**\n * Validates that dependency exists (not undefined).\n * Throws ReferenceError if dependency is not found.\n */\nexport function validateDependencyExists(\n value: unknown,\n dependencyName: string,\n): asserts value is NonNullable<unknown> {\n if (value === undefined) {\n throw new ReferenceError(\n `[router.getDependency]: dependency \"${dependencyName}\" not found`,\n );\n }\n}\n\n/**\n * Validates that adding dependencies won't exceed the hard limit.\n * Called before bulk operations to ensure atomicity.\n */\nexport function validateDependencyLimit(\n currentCount: number,\n newCount: number,\n methodName: string,\n maxDependencies: number = DEFAULT_LIMITS.maxDependencies,\n): void {\n if (maxDependencies === 0) {\n return;\n }\n\n const totalCount = currentCount + newCount;\n\n if (totalCount >= maxDependencies) {\n throw new Error(\n `[router.${methodName}] Dependency limit exceeded (${maxDependencies}). ` +\n `Current: ${totalCount}. This is likely a bug in your code.`,\n );\n }\n}\n","// packages/core/src/namespaces/DependenciesNamespace/DependenciesNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\nimport { getTypeDescription } from \"type-guards\";\n\nimport {\n validateDependencyExists,\n validateDependencyLimit,\n validateDependencyName,\n validateDependenciesObject,\n validateSetDependencyArgs,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { Limits } from \"../../types\";\nimport type { DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Independent namespace for managing router dependencies.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic (limits, warnings).\n */\nexport class DependenciesNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #dependencies: Partial<Dependencies> = Object.create(\n null,\n ) as Partial<Dependencies>;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n constructor(initialDependencies: Partial<Dependencies> = {} as Dependencies) {\n this.setMultiple(initialDependencies);\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateName(\n name: unknown,\n methodName: string,\n ): asserts name is string {\n validateDependencyName(name, methodName);\n }\n\n static validateSetDependencyArgs(name: unknown): asserts name is string {\n validateSetDependencyArgs(name);\n }\n\n static validateDependenciesObject(\n deps: unknown,\n methodName: string,\n ): asserts deps is Record<string, unknown> {\n validateDependenciesObject(deps, methodName);\n }\n\n static validateDependencyExists(\n value: unknown,\n dependencyName: string,\n ): asserts value is NonNullable<unknown> {\n validateDependencyExists(value, dependencyName);\n }\n\n static validateDependencyLimit(\n currentCount: number,\n newCount: number,\n methodName: string,\n maxDependencies?: number,\n ): void {\n validateDependencyLimit(\n currentCount,\n newCount,\n methodName,\n maxDependencies,\n );\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Sets a single dependency.\n * Returns true if set, false if value was undefined (no-op).\n *\n * @param dependencyName - Already validated by facade\n * @param dependencyValue - Value to set\n */\n set<K extends keyof Dependencies & string>(\n dependencyName: K,\n dependencyValue: Dependencies[K],\n ): boolean {\n // undefined = \"don't set\" (feature for conditional setting)\n if (dependencyValue === undefined) {\n return false;\n }\n\n const isNewKey = !Object.hasOwn(this.#dependencies, dependencyName);\n\n if (isNewKey) {\n // Only check limit when adding new keys (overwrites don't increase count)\n this.#checkDependencyCount(\"setDependency\");\n } else {\n const oldValue = this.#dependencies[dependencyName];\n const isChanging = oldValue !== dependencyValue;\n // Special case for NaN idempotency (NaN !== NaN is always true)\n const bothAreNaN =\n Number.isNaN(oldValue) && Number.isNaN(dependencyValue);\n\n if (isChanging && !bothAreNaN) {\n logger.warn(\n \"router.setDependency\",\n \"Router dependency already exists and is being overwritten:\",\n dependencyName,\n );\n }\n }\n\n this.#dependencies[dependencyName] = dependencyValue;\n\n return true;\n }\n\n /**\n * Sets multiple dependencies at once.\n * Limit check should be done by facade before calling this method.\n *\n * @param deps - Already validated by facade\n */\n setMultiple(deps: Partial<Dependencies>): void {\n const overwrittenKeys: string[] = [];\n\n for (const key in deps) {\n if (deps[key] !== undefined) {\n if (Object.hasOwn(this.#dependencies, key)) {\n overwrittenKeys.push(key);\n }\n\n this.#dependencies[key] = deps[key];\n }\n }\n\n if (overwrittenKeys.length > 0) {\n logger.warn(\n \"router.setDependencies\",\n \"Overwritten:\",\n overwrittenKeys.join(\", \"),\n );\n }\n }\n\n /**\n * Gets a single dependency.\n * Throws if not found.\n *\n * @param dependencyName - Already validated by facade\n */\n get<K extends keyof Dependencies>(dependencyName: K): Dependencies[K] {\n return this.#dependencies[dependencyName] as Dependencies[K];\n }\n\n /**\n * Gets all dependencies as a shallow copy.\n */\n getAll(): Partial<Dependencies> {\n return { ...this.#dependencies };\n }\n\n /**\n * Gets the current number of dependencies.\n */\n count(): number {\n return Object.keys(this.#dependencies).length;\n }\n\n /**\n * Removes a dependency by name.\n * Logs warning if dependency doesn't exist.\n */\n remove(dependencyName: keyof Dependencies): void {\n if (!Object.hasOwn(this.#dependencies, dependencyName)) {\n logger.warn(\n `router.removeDependency`,\n `Attempted to remove non-existent dependency: \"${getTypeDescription(dependencyName)}\"`,\n );\n }\n\n delete this.#dependencies[dependencyName];\n }\n\n /**\n * Checks if a dependency exists.\n */\n has(dependencyName: keyof Dependencies): boolean {\n return Object.hasOwn(this.#dependencies, dependencyName);\n }\n\n /**\n * Removes all dependencies.\n */\n reset(): void {\n for (const key in this.#dependencies) {\n delete this.#dependencies[key];\n }\n }\n\n // =========================================================================\n // Private methods (business logic)\n // =========================================================================\n\n #checkDependencyCount(methodName: string): void {\n const maxDependencies = this.#limits.maxDependencies;\n\n if (maxDependencies === 0) {\n return;\n }\n\n const currentCount = Object.keys(this.#dependencies).length;\n\n const { warn, error } = computeThresholds(maxDependencies);\n\n if (currentCount === warn) {\n logger.warn(\n `router.${methodName}`,\n `${warn} dependencies registered. ` + `Consider if all are necessary.`,\n );\n } else if (currentCount === error) {\n logger.error(\n `router.${methodName}`,\n `${error} dependencies registered! ` +\n `This indicates architectural problems. ` +\n `Hard limit at ${maxDependencies}.`,\n );\n } else if (currentCount >= maxDependencies) {\n throw new Error(\n `[router.${methodName}] Dependency limit exceeded (${maxDependencies}). ` +\n `Current: ${currentCount}. This is likely a bug in your code. ` +\n `If you genuinely need more dependencies, your architecture needs refactoring.`,\n );\n }\n }\n}\n","// packages/core/src/namespaces/ObservableNamespace/constants.ts\n\nimport { events } from \"../../constants\";\n\nimport type { EventName } from \"@real-router/types\";\n\n/**\n * Valid event names for validation\n */\nexport const validEventNames = new Set<EventName>([\n events.ROUTER_START,\n events.TRANSITION_START,\n events.TRANSITION_SUCCESS,\n events.TRANSITION_ERROR,\n events.TRANSITION_CANCEL,\n events.ROUTER_STOP,\n]);\n","// packages/core/src/namespaces/ObservableNamespace/helpers.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport type { EventMethodMap } from \"./types\";\nimport type { EventName, Plugin } from \"@real-router/types\";\n\n/**\n * Invoke all listeners for a given event.\n */\nexport function invokeFor<E extends EventName>(\n eventName: E,\n set: Set<Plugin[EventMethodMap[E]]>,\n ...args: Parameters<NonNullable<Plugin[EventMethodMap[E]]>>\n): void {\n if (set.size === 0) {\n return;\n }\n\n // Clone the listeners array so that removals/additions\n // during iteration won't affect this loop.\n const listeners = [...set];\n\n for (const cb of listeners) {\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type -- Function.prototype.apply requires Function type\n Function.prototype.apply.call(cb as Function, undefined, args);\n } catch (error) {\n logger.error(\"Router\", `Error in listener for ${eventName}:`, error);\n }\n }\n}\n","// packages/core/src/namespaces/ObservableNamespace/ObservableNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport { validEventNames } from \"./constants\";\nimport { invokeFor } from \"./helpers\";\nimport { DEFAULT_LIMITS, events } from \"../../constants\";\n\nimport type { EventMethodMap } from \"./types\";\nimport type { Limits } from \"../../types\";\nimport type {\n EventName,\n EventsKeys,\n NavigationOptions,\n Plugin,\n RouterError as RouterErrorType,\n State,\n SubscribeFn,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing router observability (events).\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle listener storage and invocation.\n */\nexport class ObservableNamespace {\n readonly #callbacks: {\n [E in EventName]?: Set<Plugin[EventMethodMap[E]]>;\n } = {};\n\n #eventDepthMap: Record<EventName, number> | null = null;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates that event name is valid.\n */\n static validateEventName(eventName: unknown): asserts eventName is EventName {\n if (!validEventNames.has(eventName as EventName)) {\n throw new Error(`Invalid event name: ${String(eventName)}`);\n }\n }\n\n /**\n * Validates callback is a function.\n */\n static validateCallback(\n cb: unknown,\n eventName: EventName,\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n ): asserts cb is Function {\n if (typeof cb !== \"function\") {\n throw new TypeError(\n `Expected callback to be a function for event ${eventName}`,\n );\n }\n }\n\n /**\n * Validates listener arguments (event name + callback).\n * Called by facade before addEventListener/removeEventListener.\n */\n static validateListenerArgs<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): void {\n ObservableNamespace.validateEventName(eventName);\n ObservableNamespace.validateCallback(cb, eventName);\n }\n\n /**\n * Validates subscribe listener is a function.\n */\n static validateSubscribeListener(\n listener: unknown,\n ): asserts listener is SubscribeFn {\n if (typeof listener !== \"function\") {\n throw new TypeError(\n \"[router.subscribe] Expected a function. \" +\n \"For Observable pattern use @real-router/rx package\",\n );\n }\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Central event dispatcher.\n * Input should be validated by facade before calling.\n */\n invoke(\n eventName: (typeof events)[EventsKeys],\n toState?: State,\n fromState?: State,\n arg?: RouterErrorType | NavigationOptions,\n ): void {\n // Check recursion depth (business logic, not input validation)\n this.#checkRecursionDepth(eventName);\n\n const depthMap = this.#getEventDepthMap();\n\n try {\n depthMap[eventName]++;\n\n switch (eventName) {\n case events.TRANSITION_START:\n case events.TRANSITION_CANCEL: {\n invokeFor(\n eventName,\n this.#getCallbackSet(eventName),\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- validated by facade\n toState!,\n fromState,\n );\n\n break;\n }\n case events.TRANSITION_ERROR: {\n invokeFor(\n eventName,\n this.#getCallbackSet(eventName),\n toState,\n fromState,\n arg as RouterErrorType,\n );\n\n break;\n }\n case events.TRANSITION_SUCCESS: {\n invokeFor(\n eventName,\n this.#getCallbackSet(eventName),\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- validated by facade\n toState!,\n fromState,\n arg as NavigationOptions,\n );\n\n break;\n }\n // for events.ROUTER_START, events.ROUTER_STOP\n default: {\n const _exhaustiveCheck:\n | typeof events.ROUTER_START\n | typeof events.ROUTER_STOP = eventName;\n\n invokeFor(_exhaustiveCheck, this.#getCallbackSet(_exhaustiveCheck));\n\n break;\n }\n }\n } finally {\n depthMap[eventName]--;\n }\n }\n\n /**\n * Checks if there are any listeners registered for a given event.\n */\n hasListeners(eventName: (typeof events)[EventsKeys]): boolean {\n const set = this.#callbacks[eventName];\n\n return set !== undefined && set.size > 0;\n }\n\n /**\n * Removes an event listener.\n * Input should be validated by facade before calling.\n */\n removeEventListener<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): void {\n // Don't create Set just for removal - check if it exists first\n const set = this.#callbacks[eventName];\n\n if (!set || set.size === 0) {\n return;\n }\n\n const deleted = set.delete(cb);\n\n if (!deleted) {\n logger.warn(\n \"Router\",\n `Attempted to remove non-existent listener for \"${eventName}\". ` +\n `This might indicate a memory leak or incorrect cleanup logic.`,\n );\n }\n }\n\n /**\n * Adds an event listener and returns an unsubscribe function.\n * Input should be validated by facade before calling.\n */\n addEventListener<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): Unsubscribe {\n const set = this.#getCallbackSet(eventName);\n\n // Duplicate check (business logic)\n if (set.has(cb)) {\n throw new Error(\n `[router.addEventListener] Listener already exists for event \"${eventName}\". ` +\n `Each listener function can only be registered once per event. ` +\n `Store the returned unsubscribe function to remove the listener.`,\n );\n }\n\n const maxListeners = this.#limits.maxListeners;\n\n if (set.size === 1000) {\n logger.warn(\n \"router.addEventListener\",\n `Warning: Event \"${eventName}\" has ${set.size} listeners. ` +\n `This might indicate a memory leak.`,\n );\n }\n\n if (maxListeners !== 0 && set.size >= maxListeners) {\n throw new Error(\n `[router.addEventListener] Maximum listener limit (${maxListeners}) ` +\n `reached for event \"${eventName}\". ` +\n `This is a critical memory leak. The application is creating listeners ` +\n `exponentially. Check for loops or recursive calls that register listeners.`,\n );\n }\n\n set.add(cb);\n\n return () => {\n this.removeEventListener(eventName, cb);\n };\n }\n\n /**\n * Simple subscription API for navigation success events.\n * Input should be validated by facade before calling.\n */\n subscribe(listener: SubscribeFn): Unsubscribe {\n return this.addEventListener(\n events.TRANSITION_SUCCESS,\n (toState: State, fromState?: State) => {\n listener({\n route: toState,\n previousRoute: fromState,\n });\n },\n );\n }\n\n // =========================================================================\n // Private methods (business logic)\n // =========================================================================\n\n /**\n * Gets or creates a Set for the given event name (lazy initialization)\n */\n #getCallbackSet<E extends EventName>(\n eventName: E,\n ): Set<Plugin[EventMethodMap[E]]> {\n const existing = this.#callbacks[eventName];\n\n if (existing) {\n return existing;\n }\n\n const set = new Set<Plugin[EventMethodMap[E]]>();\n\n // Type assertion needed: TS can't narrow generic E to specific event name\n (this.#callbacks as Record<E, Set<Plugin[EventMethodMap[E]]>>)[eventName] =\n set;\n\n return set;\n }\n\n /**\n * Gets or creates the event depth map (lazy initialization)\n */\n #getEventDepthMap(): Record<EventName, number> {\n this.#eventDepthMap ??= {\n [events.ROUTER_START]: 0,\n [events.TRANSITION_START]: 0,\n [events.TRANSITION_SUCCESS]: 0,\n [events.TRANSITION_ERROR]: 0,\n [events.TRANSITION_CANCEL]: 0,\n [events.ROUTER_STOP]: 0,\n };\n\n return this.#eventDepthMap;\n }\n\n #checkRecursionDepth(eventName: (typeof events)[EventsKeys]): void {\n const maxEventDepth = this.#limits.maxEventDepth;\n\n if (maxEventDepth === 0) {\n return;\n }\n\n const depthMap = this.#getEventDepthMap();\n const depth = depthMap[eventName];\n\n /* v8 ignore next 5 -- @preserve defensive: protects against recursive plugins */\n if (depth >= maxEventDepth) {\n throw new Error(\n `[Router] Maximum recursion depth (${maxEventDepth}) exceeded for event: ${eventName}`,\n );\n }\n }\n}\n","// packages/core/src/namespaces/OptionsNamespace/constants.ts\n\nimport type { Options } from \"@real-router/types\";\n\n/**\n * Default options for the router.\n */\nexport const defaultOptions: Options = {\n defaultRoute: \"\",\n defaultParams: {},\n trailingSlash: \"preserve\",\n queryParamsMode: \"loose\",\n queryParams: {\n arrayFormat: \"none\",\n booleanFormat: \"none\",\n nullFormat: \"default\",\n },\n caseSensitive: false,\n urlParamsEncoding: \"default\",\n allowNotFound: true,\n rewritePathOnMatch: true,\n noValidate: false,\n} satisfies Options;\n\n/**\n * Valid values for string enum options.\n * Used for runtime validation in setOption/withOptions.\n */\nexport const VALID_OPTION_VALUES = {\n trailingSlash: [\"strict\", \"never\", \"always\", \"preserve\"] as const,\n queryParamsMode: [\"default\", \"strict\", \"loose\"] as const,\n urlParamsEncoding: [\"default\", \"uri\", \"uriComponent\", \"none\"] as const,\n} as const;\n\n/**\n * Valid keys and values for queryParams option.\n */\nexport const VALID_QUERY_PARAMS = {\n arrayFormat: [\"none\", \"brackets\", \"index\", \"comma\"] as const,\n booleanFormat: [\"none\", \"string\", \"empty-true\"] as const,\n nullFormat: [\"default\", \"hidden\"] as const,\n} as const;\n\n/**\n * Options that can be changed after router is locked (started).\n */\nexport const UNLOCKED_OPTIONS = new Set<keyof Options>([\n \"defaultRoute\",\n \"defaultParams\",\n]);\n","// packages/core/src/namespaces/OptionsNamespace/helpers.ts\n\nimport type { Options } from \"@real-router/types\";\n\n/**\n * Creates a ReferenceError for option not found.\n */\nexport const optionNotFoundError = (\n method: string,\n name: keyof Options,\n): ReferenceError =>\n new ReferenceError(`[router.${method}]: option \"${name}\" not found`);\n\n/**\n * Recursively freezes an object and all nested objects.\n * Only freezes plain objects, not primitives or special objects.\n */\nexport function deepFreeze<T extends object>(obj: T): Readonly<T> {\n Object.freeze(obj);\n\n for (const key of Object.keys(obj)) {\n const value = (obj as Record<string, unknown>)[key];\n\n if (value && typeof value === \"object\" && value.constructor === Object) {\n deepFreeze(value);\n }\n }\n\n return obj;\n}\n","// packages/core/src/namespaces/OptionsNamespace/validators.ts\n\n/**\n * Static validation functions for OptionsNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { isObjKey, getTypeDescription } from \"type-guards\";\n\nimport {\n defaultOptions,\n UNLOCKED_OPTIONS,\n VALID_OPTION_VALUES,\n VALID_QUERY_PARAMS,\n} from \"./constants\";\nimport { optionNotFoundError } from \"./helpers\";\nimport { LIMIT_BOUNDS } from \"../../constants\";\n\nimport type { LimitsConfig, Options } from \"@real-router/types\";\n\n/**\n * Validates that option name is a string.\n */\nexport function validateOptionName(\n name: unknown,\n methodName: string,\n): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.${methodName}]: option name must be a string, got ${typeof name}`,\n );\n }\n}\n\n/**\n * Validates that option exists in defaults.\n */\nexport function validateOptionExists(\n optionName: string,\n methodName: string,\n): void {\n if (!Object.hasOwn(defaultOptions, optionName)) {\n throw optionNotFoundError(methodName, optionName as keyof Options);\n }\n}\n\n/**\n * Validates that options are not locked for this option.\n */\nexport function validateNotLocked(isLocked: boolean, optionName: string): void {\n if (isLocked && !UNLOCKED_OPTIONS.has(optionName as keyof Options)) {\n throw new Error(\n `[router.setOption] Options cannot be changed after router.start(). ` +\n `Only defaultRoute/defaultParams can be changed after start.`,\n );\n }\n}\n\n/**\n * Validates that value is a plain object without getters.\n */\nexport function validatePlainObject(\n value: unknown,\n optionName: string,\n methodName: string,\n): asserts value is Record<string, unknown> {\n if (!value || typeof value !== \"object\" || value.constructor !== Object) {\n throw new TypeError(\n `[router.${methodName}] Invalid type for \"${optionName}\": ` +\n `expected plain object, got ${getTypeDescription(value)}`,\n );\n }\n\n // Getters can throw, return different values, or have side effects\n for (const key in value) {\n if (Object.getOwnPropertyDescriptor(value, key)?.get) {\n throw new TypeError(\n `[router.${methodName}] Getters not allowed in \"${optionName}\": \"${key}\"`,\n );\n }\n }\n}\n\n/**\n * Validates queryParams keys and values against allowed enums.\n */\nexport function validateQueryParams(\n value: Record<string, unknown>,\n methodName: string,\n): void {\n for (const key in value) {\n if (!isObjKey(key, VALID_QUERY_PARAMS)) {\n const validKeys = Object.keys(VALID_QUERY_PARAMS)\n .map((k) => `\"${k}\"`)\n .join(\", \");\n\n throw new TypeError(\n `[router.${methodName}] Unknown queryParams key: \"${key}\". ` +\n `Valid keys: ${validKeys}`,\n );\n }\n\n const paramValue = value[key];\n const validValues = VALID_QUERY_PARAMS[key];\n const isValid = (validValues as readonly string[]).includes(\n paramValue as string,\n );\n\n if (!isValid) {\n const allowedValues = validValues.map((v) => `\"${v}\"`).join(\", \");\n\n throw new TypeError(\n `[router.${methodName}] Invalid value for queryParams.${key}: ` +\n `expected one of ${allowedValues}, got \"${String(paramValue)}\"`,\n );\n }\n }\n}\n\n/**\n * Validates string enum options against allowed values.\n */\nexport function validateEnumOption(\n optionName: keyof typeof VALID_OPTION_VALUES,\n value: unknown,\n methodName: string,\n): void {\n const validValues = VALID_OPTION_VALUES[optionName];\n const isValid = (validValues as readonly string[]).includes(value as string);\n\n if (!isValid) {\n const allowedValues = validValues.map((v) => `\"${v}\"`).join(\", \");\n\n throw new TypeError(\n `[router.${methodName}] Invalid value for \"${optionName}\": ` +\n `expected one of ${allowedValues}, got \"${String(value)}\"`,\n );\n }\n}\n\n/**\n * Validates a single option value against expected type and constraints.\n * Skips validation for unknown options - validateOptionExists handles that.\n */\nexport function validateOptionValue(\n optionName: keyof Options,\n value: unknown,\n methodName: string,\n): void {\n const expectedValue = defaultOptions[optionName];\n\n // For object options - ensure plain objects only (not null, arrays, Date, etc)\n if (expectedValue && typeof expectedValue === \"object\") {\n validatePlainObject(value, optionName, methodName);\n\n if (optionName === \"queryParams\") {\n validateQueryParams(value, methodName);\n }\n\n return;\n }\n\n // For primitives - typeof check first\n if (typeof value !== typeof expectedValue) {\n throw new TypeError(\n `[router.${methodName}] Invalid type for \"${optionName}\": ` +\n `expected ${typeof expectedValue}, got ${typeof value}`,\n );\n }\n\n // For string enum options - validate against allowed values\n if (optionName in VALID_OPTION_VALUES) {\n validateEnumOption(\n optionName as keyof typeof VALID_OPTION_VALUES,\n value,\n methodName,\n );\n }\n}\n\n/**\n * Validates optional fields not in defaultOptions.\n * Note: logger is handled before validateOptions in Router constructor.\n */\nfunction validateOptionalField(\n key: string,\n value: unknown,\n methodName: string,\n): boolean {\n if (key === \"limits\") {\n if (value !== undefined) {\n validateLimits(value, methodName);\n }\n\n return true;\n }\n\n throw new TypeError(`[router.${methodName}] Unknown option: \"${key}\"`);\n}\n\n/**\n * Validates a partial options object.\n * Called by facade before constructor/withOptions.\n */\nexport function validateOptions(\n options: unknown,\n methodName: string,\n): asserts options is Partial<Options> {\n if (\n !options ||\n typeof options !== \"object\" ||\n options.constructor !== Object\n ) {\n throw new TypeError(\n `[router.${methodName}] Invalid options: expected plain object, got ${getTypeDescription(options)}`,\n );\n }\n\n for (const [key, value] of Object.entries(options)) {\n // Skip optional fields that aren't in defaultOptions (limits, logger, etc.)\n /* v8 ignore next -- @preserve branch: optional field handled separately */\n if (!isObjKey(key, defaultOptions)) {\n validateOptionalField(key, value, methodName);\n continue;\n }\n\n // Skip undefined values for conditional configuration\n if (value === undefined) {\n continue;\n }\n\n validateOptionValue(key, value, methodName);\n }\n}\n\n/**\n * Validates that a limit value is within bounds.\n */\nexport function validateLimitValue(\n limitName: keyof LimitsConfig,\n value: unknown,\n methodName: string,\n): void {\n if (typeof value !== \"number\" || !Number.isInteger(value)) {\n throw new TypeError(\n `[router.${methodName}]: limit \"${limitName}\" must be an integer, got ${String(value)}`,\n );\n }\n\n const bounds = LIMIT_BOUNDS[limitName];\n\n if (value < bounds.min || value > bounds.max) {\n throw new RangeError(\n `[router.${methodName}]: limit \"${limitName}\" must be between ${bounds.min} and ${bounds.max}, got ${value}`,\n );\n }\n}\n\n/**\n * Validates a partial limits object.\n */\nexport function validateLimits(\n limits: unknown,\n methodName: string,\n): asserts limits is Partial<LimitsConfig> {\n if (!limits || typeof limits !== \"object\" || limits.constructor !== Object) {\n throw new TypeError(\n `[router.${methodName}]: invalid limits: expected plain object, got ${typeof limits}`,\n );\n }\n\n for (const [key, value] of Object.entries(limits)) {\n if (!Object.hasOwn(LIMIT_BOUNDS, key)) {\n throw new TypeError(`[router.${methodName}]: unknown limit: \"${key}\"`);\n }\n\n if (value === undefined) {\n continue;\n }\n\n validateLimitValue(key as keyof LimitsConfig, value, methodName);\n }\n}\n","// packages/core/src/namespaces/OptionsNamespace/OptionsNamespace.ts\n\nimport { defaultOptions } from \"./constants\";\nimport { deepFreeze } from \"./helpers\";\nimport {\n validateNotLocked,\n validateOptionExists,\n validateOptionName,\n validateOptions,\n validateOptionValue,\n} from \"./validators\";\n\nimport type { Options } from \"@real-router/types\";\n\n/**\n * Independent namespace for managing router options.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and lock state.\n */\nexport class OptionsNamespace {\n #options: Readonly<Options>;\n #locked = false;\n\n constructor(initialOptions: Partial<Options> = {}) {\n // Note: validation should be done by facade before calling constructor\n this.#options = deepFreeze({\n ...defaultOptions,\n ...initialOptions,\n });\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateOptionName(\n name: unknown,\n methodName: string,\n ): asserts name is string {\n validateOptionName(name, methodName);\n }\n\n static validateOptionExists(optionName: string, methodName: string): void {\n validateOptionExists(optionName, methodName);\n }\n\n static validateNotLocked(isLocked: boolean, optionName: string): void {\n validateNotLocked(isLocked, optionName);\n }\n\n static validateOptionValue(\n optionName: keyof Options,\n value: unknown,\n methodName: string,\n ): void {\n validateOptionValue(optionName, value, methodName);\n }\n\n static validateOptions(\n options: unknown,\n methodName: string,\n ): asserts options is Partial<Options> {\n validateOptions(options, methodName);\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the frozen options object.\n * Safe to return directly - mutations will throw in strict mode.\n */\n get(): Readonly<Options> {\n return this.#options;\n }\n\n /**\n * Gets a single option value.\n * Input already validated by facade.\n *\n * @param optionName - Already validated by facade\n */\n getOption<K extends keyof Options>(optionName: K): Options[K] {\n return this.#options[optionName];\n }\n\n /**\n * Sets a single option value.\n * Input already validated by facade (including lock check).\n *\n * @param optionName - Already validated by facade\n * @param value - Already validated by facade\n */\n set<K extends keyof Options>(optionName: K, value: Options[K]): void {\n // Recreate frozen options with new value\n // For nested objects (defaultParams), create a shallow copy to avoid\n // sharing mutable references\n const newValue =\n value && typeof value === \"object\" && value.constructor === Object\n ? { ...value }\n : value;\n\n this.#options = deepFreeze({\n ...this.#options,\n [optionName]: newValue,\n });\n }\n\n /**\n * Returns true if options are locked.\n * Used by facade for lock validation.\n */\n isLocked(): boolean {\n return this.#locked;\n }\n\n /**\n * Locks options - called when router starts.\n * After locking, only UNLOCKED_OPTIONS can be changed.\n */\n lock(): void {\n this.#locked = true;\n }\n\n /**\n * Unlocks options - called when router stops.\n */\n unlock(): void {\n this.#locked = false;\n }\n}\n","// packages/core/src/namespaces/StateNamespace/helpers.ts\n\nimport type { RouteTreeStateMeta } from \"route-tree\";\n\n/**\n * Extracts URL param names from RouteTreeStateMeta.\n * This is an O(segments à params) operation but avoids tree traversal.\n */\nexport function getUrlParamsFromMeta(meta: RouteTreeStateMeta): string[] {\n const urlParams: string[] = [];\n\n for (const segmentName in meta) {\n const paramMap = meta[segmentName];\n\n for (const param in paramMap) {\n if (paramMap[param] === \"url\") {\n urlParams.push(param);\n }\n }\n }\n\n return urlParams;\n}\n\n/**\n * Compares two parameter values for equality.\n * Supports deep equality for arrays (common in route params like tags, ids).\n */\nexport function areParamValuesEqual(val1: unknown, val2: unknown): boolean {\n if (val1 === val2) {\n return true;\n }\n\n if (Array.isArray(val1) && Array.isArray(val2)) {\n if (val1.length !== val2.length) {\n return false;\n }\n\n return val1.every((v, i) => areParamValuesEqual(v, val2[i]));\n }\n\n return false;\n}\n","// packages/core/src/namespaces/StateNamespace/StateNamespace.ts\n\nimport {\n getTypeDescription,\n isParams,\n isString,\n validateState,\n} from \"type-guards\";\n\nimport { areParamValuesEqual, getUrlParamsFromMeta } from \"./helpers\";\nimport { constants } from \"../../constants\";\nimport { freezeStateInPlace } from \"../../helpers\";\n\nimport type { StateNamespaceDependencies } from \"./types\";\nimport type {\n NavigationOptions,\n Params,\n State,\n StateMetaInput,\n} from \"@real-router/types\";\nimport type { RouteTreeStateMeta } from \"route-tree\";\n\n/**\n * Independent namespace for managing router state storage and creation.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle state storage, freezing, and creation.\n */\nexport class StateNamespace {\n /**\n * Auto-incrementing state ID for tracking navigation history.\n */\n #stateId = 0;\n\n /**\n * Cached frozen state - avoids structuredClone on every getState() call.\n */\n #frozenState: State | undefined = undefined;\n\n /**\n * Previous state before the last setState call.\n */\n #previousState: State | undefined = undefined;\n\n /**\n * Dependencies injected from Router.\n */\n #deps: StateNamespaceDependencies | undefined;\n\n /**\n * Cache for URL params by route name.\n */\n readonly #urlParamsCache = new Map<string, string[]>();\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates makeState arguments.\n */\n static validateMakeStateArgs(\n name: unknown,\n params: unknown,\n path: unknown,\n forceId: unknown,\n ): void {\n // Validate name is a string\n if (!isString(name)) {\n throw new TypeError(\n `[router.makeState] Invalid name: ${getTypeDescription(name)}. Expected string.`,\n );\n }\n\n // Validate params if provided\n if (params !== undefined && !isParams(params)) {\n throw new TypeError(\n `[router.makeState] Invalid params: ${getTypeDescription(params)}. Expected plain object.`,\n );\n }\n\n // Validate path if provided\n if (path !== undefined && !isString(path)) {\n throw new TypeError(\n `[router.makeState] Invalid path: ${getTypeDescription(path)}. Expected string.`,\n );\n }\n\n // Validate forceId if provided\n if (forceId !== undefined && typeof forceId !== \"number\") {\n throw new TypeError(\n `[router.makeState] Invalid forceId: ${getTypeDescription(forceId)}. Expected number.`,\n );\n }\n }\n\n /**\n * Validates areStatesEqual arguments.\n */\n static validateAreStatesEqualArgs(\n state1: unknown,\n state2: unknown,\n ignoreQueryParams: unknown,\n ): void {\n // null/undefined are valid (represent \"no state\")\n if (state1 != null) {\n validateState(state1, \"areStatesEqual\");\n }\n\n if (state2 != null) {\n validateState(state2, \"areStatesEqual\");\n }\n\n if (\n ignoreQueryParams !== undefined &&\n typeof ignoreQueryParams !== \"boolean\"\n ) {\n throw new TypeError(\n `[router.areStatesEqual] Invalid ignoreQueryParams: ${getTypeDescription(ignoreQueryParams)}. Expected boolean.`,\n );\n }\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the current router state.\n *\n * The returned state is deeply frozen (immutable) for safety.\n * Returns `undefined` if the router has not been started or has been stopped.\n */\n get<P extends Params = Params, MP extends Params = Params>():\n | State<P, MP>\n | undefined {\n return this.#frozenState as State<P, MP> | undefined;\n }\n\n /**\n * Sets the current router state.\n *\n * The state is deeply frozen before storage to ensure immutability.\n * The previous state is preserved and accessible via `getPrevious()`.\n *\n * @param state - Already validated by facade, or undefined to clear\n */\n set(state: State | undefined): void {\n // Preserve current state as previous before updating\n this.#previousState = this.#frozenState;\n\n // If state is already frozen (from makeState()), use it directly.\n // For external states, freeze in place without cloning.\n if (!state) {\n this.#frozenState = undefined;\n } else if (Object.isFrozen(state)) {\n // State is already frozen (typically from makeState)\n this.#frozenState = state;\n } else {\n // External state - freeze in place without cloning.\n this.#frozenState = freezeStateInPlace(state);\n }\n }\n\n /**\n * Returns the previous router state (before the last navigation).\n */\n getPrevious<P extends Params = Params, MP extends Params = Params>():\n | State<P, MP>\n | undefined {\n return this.#previousState as State<P, MP> | undefined;\n }\n\n // =========================================================================\n // Dependency Injection\n // =========================================================================\n\n /**\n * Sets dependencies for state creation methods.\n * Must be called before using makeState, areStatesEqual, etc.\n */\n setDependencies(deps: StateNamespaceDependencies): void {\n this.#deps = deps;\n }\n\n // =========================================================================\n // State Creation Methods\n // =========================================================================\n\n /**\n * Creates a frozen state object for a route.\n */\n makeState<P extends Params = Params, MP extends Params = Params>(\n name: string,\n params?: P,\n path?: string,\n meta?: StateMetaInput<MP>,\n forceId?: number,\n ): State<P, MP> {\n const madeMeta = meta\n ? {\n ...meta,\n id: forceId ?? ++this.#stateId,\n params: meta.params,\n options: meta.options,\n redirected: meta.redirected,\n }\n : undefined;\n\n // Optimization: O(1) lookup instead of O(depth) ancestor iteration\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const defaultParamsConfig = this.#deps!.getDefaultParams();\n const hasDefaultParams = Object.hasOwn(defaultParamsConfig, name);\n\n // Conditional allocation: avoid spreading when no defaultParams exist\n let mergedParams: P;\n\n if (hasDefaultParams) {\n mergedParams = { ...defaultParamsConfig[name], ...params } as P;\n } else if (params) {\n mergedParams = { ...params };\n } else {\n mergedParams = {} as P;\n }\n\n const state: State<P, MP> = {\n name,\n params: mergedParams,\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n path: path ?? this.#deps!.buildPath(name, params),\n meta: madeMeta,\n };\n\n return freezeStateInPlace(state);\n }\n\n /**\n * Creates a frozen state object for the \"not found\" route.\n */\n makeNotFoundState(path: string, options: NavigationOptions): State {\n return this.makeState<{ path: string }>(\n constants.UNKNOWN_ROUTE,\n { path },\n path,\n {\n options,\n params: {},\n redirected: false,\n },\n );\n }\n\n // =========================================================================\n // State Comparison Methods\n // =========================================================================\n\n /**\n * Compares two states for equality.\n * By default, ignores query params (only compares URL params).\n */\n areStatesEqual(\n state1: State | undefined,\n state2: State | undefined,\n ignoreQueryParams = true,\n ): boolean {\n if (!state1 || !state2) {\n return !!state1 === !!state2;\n }\n\n if (state1.name !== state2.name) {\n return false;\n }\n\n if (ignoreQueryParams) {\n const stateMeta = (state1.meta?.params ?? state2.meta?.params) as\n | RouteTreeStateMeta\n | undefined;\n\n const urlParams = stateMeta\n ? getUrlParamsFromMeta(stateMeta)\n : this.#getUrlParams(state1.name);\n\n return urlParams.every((param) =>\n areParamValuesEqual(state1.params[param], state2.params[param]),\n );\n }\n\n const state1Keys = Object.keys(state1.params);\n const state2Keys = Object.keys(state2.params);\n\n if (state1Keys.length !== state2Keys.length) {\n return false;\n }\n\n return state1Keys.every(\n (param) =>\n param in state2.params &&\n areParamValuesEqual(state1.params[param], state2.params[param]),\n );\n }\n\n // =========================================================================\n // Private Helpers\n // =========================================================================\n\n /**\n * Gets URL params for a route name, using cache for performance.\n */\n #getUrlParams(name: string): string[] {\n const cached = this.#urlParamsCache.get(name);\n\n if (cached !== undefined) {\n return cached;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const result = this.#deps!.getUrlParams(name);\n\n this.#urlParamsCache.set(name, result);\n\n return result;\n }\n}\n","// packages/core/src/namespaces/MiddlewareNamespace/validators.ts\n\n/**\n * Static validation functions for MiddlewareNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { getTypeDescription } from \"type-guards\";\n\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\nimport type { MiddlewareFactory } from \"../../types\";\nimport type { DefaultDependencies, Middleware } from \"@real-router/types\";\n\n/**\n * Gets a displayable name for a factory function.\n */\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction getFactoryName(factory: Function): string {\n return factory.name || \"anonymous\";\n}\n\n/**\n * Validates useMiddleware arguments - each must be a function.\n */\nexport function validateUseMiddlewareArgs<D extends DefaultDependencies>(\n middlewares: unknown[],\n): asserts middlewares is MiddlewareFactory<D>[] {\n for (const [i, middleware] of middlewares.entries()) {\n if (typeof middleware !== \"function\") {\n throw new TypeError(\n `[router.useMiddleware] Expected middleware factory function at index ${i}, ` +\n `got ${getTypeDescription(middleware)}`,\n );\n }\n }\n}\n\n/**\n * Validates that a middleware factory returned a valid middleware function.\n */\nexport function validateMiddleware<D extends DefaultDependencies>(\n middleware: unknown,\n factory: MiddlewareFactory<D>,\n): asserts middleware is Middleware {\n if (typeof middleware !== \"function\") {\n throw new TypeError(\n `[router.useMiddleware] Middleware factory must return a function, ` +\n `got ${getTypeDescription(middleware)}. ` +\n `Factory: ${getFactoryName(factory)}`,\n );\n }\n}\n\n/**\n * Validates that no duplicate factories are being registered.\n */\nexport function validateNoDuplicates<D extends DefaultDependencies>(\n newFactories: MiddlewareFactory<D>[],\n existingFactories: MiddlewareFactory<D>[],\n): void {\n const existingSet = new Set(existingFactories);\n\n for (const factory of newFactories) {\n if (existingSet.has(factory)) {\n throw new Error(\n `[router.useMiddleware] Middleware factory already registered. ` +\n `To re-register, first unsubscribe the existing middleware. ` +\n `Factory: ${getFactoryName(factory)}`,\n );\n }\n }\n}\n\n/**\n * Validates that adding middleware won't exceed the hard limit.\n */\nexport function validateMiddlewareLimit(\n currentCount: number,\n newCount: number,\n maxMiddleware: number = DEFAULT_LIMITS.maxMiddleware,\n): void {\n if (maxMiddleware === 0) {\n return;\n }\n\n const totalSize = currentCount + newCount;\n\n if (totalSize > maxMiddleware) {\n throw new Error(\n `[router.useMiddleware] Middleware limit exceeded (${maxMiddleware}). ` +\n `Current: ${currentCount}, Attempting to add: ${newCount}. ` +\n `This indicates an architectural problem. Consider consolidating middleware.`,\n );\n }\n}\n","// packages/core/src/namespaces/MiddlewareNamespace/MiddlewareNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport {\n validateMiddleware,\n validateMiddlewareLimit,\n validateNoDuplicates,\n validateUseMiddlewareArgs,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { InitializedMiddleware, MiddlewareDependencies } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { Limits, MiddlewareFactory } from \"../../types\";\nimport type {\n DefaultDependencies,\n Middleware,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing middleware.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class MiddlewareNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #factories = new Set<MiddlewareFactory<Dependencies>>();\n readonly #factoryToMiddleware = new Map<\n MiddlewareFactory<Dependencies>,\n Middleware\n >();\n\n #router: Router<Dependencies> | undefined;\n\n #deps: MiddlewareDependencies<Dependencies> | undefined;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateUseMiddlewareArgs<D extends DefaultDependencies>(\n middlewares: unknown[],\n ): asserts middlewares is MiddlewareFactory<D>[] {\n validateUseMiddlewareArgs<D>(middlewares);\n }\n\n static validateMiddleware<D extends DefaultDependencies>(\n middleware: unknown,\n factory: MiddlewareFactory<D>,\n ): asserts middleware is Middleware {\n validateMiddleware<D>(middleware, factory);\n }\n\n static validateNoDuplicates<D extends DefaultDependencies>(\n newFactories: MiddlewareFactory<D>[],\n existingFactories: MiddlewareFactory<D>[],\n ): void {\n validateNoDuplicates<D>(newFactories, existingFactories);\n }\n\n static validateMiddlewareLimit(\n currentCount: number,\n newCount: number,\n maxMiddleware?: number,\n ): void {\n validateMiddlewareLimit(currentCount, newCount, maxMiddleware);\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n setRouter(router: Router<Dependencies>): void {\n this.#router = router;\n }\n\n setDependencies(deps: MiddlewareDependencies<Dependencies>): void {\n this.#deps = deps;\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the current number of registered middleware.\n */\n count(): number {\n return this.#factories.size;\n }\n\n /**\n * Initializes middleware factories without committing to storage.\n * Returns array of initialized middleware for validation by facade.\n *\n * @param factories - Already validated by facade\n */\n initialize(\n ...factories: MiddlewareFactory<Dependencies>[]\n ): InitializedMiddleware<Dependencies>[] {\n const initialized: InitializedMiddleware<Dependencies>[] = [];\n\n for (const factory of factories) {\n // Router and deps are guaranteed to be set at this point\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const router = this.#router!;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const deps = this.#deps!;\n\n // Middleware factories receive full router as part of their public API\n const middleware = factory(router, deps.getDependency);\n\n initialized.push({ factory, middleware });\n }\n\n return initialized;\n }\n\n /**\n * Commits initialized middleware to storage.\n * Returns unsubscribe function to remove all added middleware.\n *\n * @param initialized - Already validated by facade\n */\n commit(initialized: InitializedMiddleware<Dependencies>[]): Unsubscribe {\n // Check count thresholds and log warnings if needed\n this.#checkCountThresholds(initialized.length);\n\n // Add to storage\n for (const { factory, middleware } of initialized) {\n this.#factories.add(factory);\n this.#factoryToMiddleware.set(factory, middleware);\n }\n\n // Return unsubscribe function specific to THIS call's middleware\n let unsubscribed = false;\n\n return (): void => {\n if (unsubscribed) {\n return;\n }\n\n unsubscribed = true;\n\n for (const { factory } of initialized) {\n this.#factories.delete(factory);\n this.#factoryToMiddleware.delete(factory);\n }\n };\n }\n\n /**\n * Removes all registered middleware.\n */\n clear(): void {\n this.#factories.clear();\n this.#factoryToMiddleware.clear();\n }\n\n /**\n * Returns a copy of registered middleware factories.\n * Preserves insertion order.\n */\n getFactories(): MiddlewareFactory<Dependencies>[] {\n return [...this.#factories];\n }\n\n /**\n * Returns the actual middleware functions in execution order.\n */\n getFunctions(): Middleware[] {\n return [...this.#factoryToMiddleware.values()];\n }\n\n // =========================================================================\n // Private methods\n // =========================================================================\n\n #checkCountThresholds(newCount: number): void {\n const maxMiddleware = this.#limits.maxMiddleware;\n\n if (maxMiddleware === 0) {\n return;\n }\n\n const totalSize = newCount + this.#factories.size;\n\n const { warn, error } = computeThresholds(maxMiddleware);\n\n if (totalSize >= error) {\n logger.error(\n \"router.useMiddleware\",\n `${totalSize} middleware registered! ` +\n `This is excessive and will impact performance. ` +\n `Hard limit at ${maxMiddleware}.`,\n );\n } else if (totalSize >= warn) {\n logger.warn(\n \"router.useMiddleware\",\n `${totalSize} middleware registered. ` +\n `Consider if all are necessary.`,\n );\n }\n }\n}\n","// packages/core/src/namespaces/PluginsNamespace/constants.ts\n\nimport { isObjKey } from \"type-guards\";\n\nimport {\n events as EVENTS_CONST,\n plugins as PLUGINS_CONST,\n} from \"../../constants\";\n\nimport type { EventName } from \"@real-router/types\";\n\n/**\n * Maps plugin method names to router event names.\n */\nexport const EVENTS_MAP = {\n [PLUGINS_CONST.ROUTER_START]: EVENTS_CONST.ROUTER_START,\n [PLUGINS_CONST.ROUTER_STOP]: EVENTS_CONST.ROUTER_STOP,\n [PLUGINS_CONST.TRANSITION_SUCCESS]: EVENTS_CONST.TRANSITION_SUCCESS,\n [PLUGINS_CONST.TRANSITION_START]: EVENTS_CONST.TRANSITION_START,\n [PLUGINS_CONST.TRANSITION_ERROR]: EVENTS_CONST.TRANSITION_ERROR,\n [PLUGINS_CONST.TRANSITION_CANCEL]: EVENTS_CONST.TRANSITION_CANCEL,\n} as const satisfies Record<\n (typeof PLUGINS_CONST)[keyof typeof PLUGINS_CONST],\n EventName\n>;\n\n/**\n * Plugin method names that correspond to router events.\n */\nexport const EVENT_METHOD_NAMES = Object.keys(EVENTS_MAP).filter(\n (eventName): eventName is keyof typeof EVENTS_MAP =>\n isObjKey<typeof EVENTS_MAP>(eventName, EVENTS_MAP),\n);\n\nexport const LOGGER_CONTEXT = \"router.usePlugin\";\n","// packages/core/src/namespaces/PluginsNamespace/validators.ts\n\n/**\n * Static validation functions for PluginsNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { getTypeDescription, isObjKey } from \"type-guards\";\n\nimport { EVENTS_MAP } from \"./constants\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\nimport type { PluginFactory } from \"../../types\";\nimport type { DefaultDependencies, Plugin } from \"@real-router/types\";\n\n/**\n * Validates usePlugin arguments - all must be functions.\n */\nexport function validateUsePluginArgs<D extends DefaultDependencies>(\n plugins: unknown[],\n): asserts plugins is PluginFactory<D>[] {\n for (const plugin of plugins) {\n if (typeof plugin !== \"function\") {\n throw new TypeError(\n `[router.usePlugin] Expected plugin factory function, got ${typeof plugin}`,\n );\n }\n }\n}\n\n/**\n * Validates that a plugin factory returned a valid plugin object.\n */\nexport function validatePlugin(plugin: Plugin): void {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!(plugin && typeof plugin === \"object\") || Array.isArray(plugin)) {\n throw new TypeError(\n `[router.usePlugin] Plugin factory must return an object, got ${getTypeDescription(\n plugin,\n )}`,\n );\n }\n\n // Detect async factory (returns Promise)\n if (typeof (plugin as unknown as { then?: unknown }).then === \"function\") {\n throw new TypeError(\n `[router.usePlugin] Async plugin factories are not supported. ` +\n `Factory returned a Promise instead of a plugin object.`,\n );\n }\n\n for (const key in plugin) {\n if (!(key === \"teardown\" || isObjKey<typeof EVENTS_MAP>(key, EVENTS_MAP))) {\n throw new TypeError(\n `[router.usePlugin] Unknown property '${key}'. ` +\n `Plugin must only contain event handlers and optional teardown.`,\n );\n }\n }\n}\n\n/**\n * Validates that adding new plugins won't exceed the hard limit.\n */\nexport function validatePluginLimit(\n currentCount: number,\n newCount: number,\n maxPlugins: number = DEFAULT_LIMITS.maxPlugins,\n): void {\n if (maxPlugins === 0) {\n return;\n }\n\n const totalCount = currentCount + newCount;\n\n if (totalCount > maxPlugins) {\n throw new Error(`[router.usePlugin] Plugin limit exceeded (${maxPlugins})`);\n }\n}\n","// packages/core/src/namespaces/PluginsNamespace/PluginsNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport { EVENTS_MAP, EVENT_METHOD_NAMES, LOGGER_CONTEXT } from \"./constants\";\nimport {\n validatePlugin,\n validatePluginLimit,\n validateUsePluginArgs,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { PluginsDependencies } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { Limits, PluginFactory } from \"../../types\";\nimport type {\n DefaultDependencies,\n Plugin,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing plugins.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class PluginsNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #plugins = new Set<PluginFactory<Dependencies>>();\n\n #router: Router<Dependencies> | undefined;\n\n #deps: PluginsDependencies<Dependencies> | undefined;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateUsePluginArgs<D extends DefaultDependencies>(\n plugins: unknown[],\n ): asserts plugins is PluginFactory<D>[] {\n validateUsePluginArgs<D>(plugins);\n }\n\n static validatePlugin(plugin: Plugin): void {\n validatePlugin(plugin);\n }\n\n static validatePluginLimit(\n currentCount: number,\n newCount: number,\n maxPlugins?: number,\n ): void {\n validatePluginLimit(currentCount, newCount, maxPlugins);\n }\n\n static validateNoDuplicatePlugins<D extends DefaultDependencies>(\n newFactories: PluginFactory<D>[],\n hasPlugin: (factory: PluginFactory<D>) => boolean,\n ): void {\n for (const factory of newFactories) {\n if (hasPlugin(factory)) {\n throw new Error(\n `[router.usePlugin] Plugin factory already registered. ` +\n `To re-register, first unsubscribe the existing plugin.`,\n );\n }\n }\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n setRouter(router: Router<Dependencies>): void {\n this.#router = router;\n }\n\n setDependencies(deps: PluginsDependencies<Dependencies>): void {\n this.#deps = deps;\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the number of registered plugins.\n * Used by facade for limit validation.\n */\n count(): number {\n return this.#plugins.size;\n }\n\n /**\n * Registers one or more plugin factories.\n * Returns unsubscribe function to remove all added plugins.\n * Input already validated by facade (limit, duplicates).\n *\n * @param factories - Already validated by facade\n */\n use(...factories: PluginFactory<Dependencies>[]): Unsubscribe {\n // Emit warnings for count thresholds (not validation, just warnings)\n this.#checkCountThresholds(factories.length);\n\n // Fast path for single plugin (common case)\n if (factories.length === 1) {\n const factory = factories[0];\n const cleanup = this.#startPlugin(factory);\n\n this.#plugins.add(factory);\n\n let unsubscribed = false;\n\n return () => {\n if (unsubscribed) {\n return;\n }\n\n unsubscribed = true;\n this.#plugins.delete(factory);\n try {\n cleanup();\n } catch (error) {\n logger.error(LOGGER_CONTEXT, \"Error during cleanup:\", error);\n }\n };\n }\n\n // Deduplicate batch with warning (validation already done by facade)\n const seenInBatch = this.#deduplicateBatch(factories);\n\n // Track successfully initialized plugins for cleanup\n const initializedPlugins: {\n factory: PluginFactory<Dependencies>;\n cleanup: Unsubscribe;\n }[] = [];\n\n // Initialize deduplicated plugins sequentially\n try {\n for (const plugin of seenInBatch) {\n const cleanup = this.#startPlugin(plugin);\n\n initializedPlugins.push({ factory: plugin, cleanup });\n }\n } catch (error) {\n // Rollback on failure - cleanup all initialized plugins\n for (const { cleanup } of initializedPlugins) {\n try {\n cleanup();\n } catch (cleanupError) {\n logger.error(LOGGER_CONTEXT, \"Cleanup error:\", cleanupError);\n }\n }\n\n throw error;\n }\n\n // Commit phase - add to registry\n for (const { factory } of initializedPlugins) {\n this.#plugins.add(factory);\n }\n\n // Return unsubscribe function\n let unsubscribed = false;\n\n return () => {\n if (unsubscribed) {\n return;\n }\n\n unsubscribed = true;\n\n for (const { factory } of initializedPlugins) {\n this.#plugins.delete(factory);\n }\n\n for (const { cleanup } of initializedPlugins) {\n try {\n cleanup();\n } catch (error) {\n logger.error(LOGGER_CONTEXT, \"Error during cleanup:\", error);\n }\n }\n };\n }\n\n /**\n * Returns registered plugin factories.\n */\n getAll(): PluginFactory<Dependencies>[] {\n return [...this.#plugins];\n }\n\n /**\n * Checks if a plugin factory is registered.\n * Used internally by validation to avoid array allocation.\n */\n has(factory: PluginFactory<Dependencies>): boolean {\n return this.#plugins.has(factory);\n }\n\n // =========================================================================\n // Private methods\n // =========================================================================\n\n #checkCountThresholds(newCount: number): void {\n const maxPlugins = this.#limits.maxPlugins;\n\n if (maxPlugins === 0) {\n return;\n }\n\n const totalCount = newCount + this.#plugins.size;\n\n const { warn, error } = computeThresholds(maxPlugins);\n\n if (totalCount >= error) {\n logger.error(LOGGER_CONTEXT, `${totalCount} plugins registered!`);\n } else if (totalCount >= warn) {\n logger.warn(LOGGER_CONTEXT, `${totalCount} plugins registered`);\n }\n }\n\n /**\n * Deduplicates batch with warning for duplicates within batch.\n * Validation (existing duplicates) is done by facade.\n */\n #deduplicateBatch(\n plugins: PluginFactory<Dependencies>[],\n ): Set<PluginFactory<Dependencies>> {\n const seenInBatch = new Set<PluginFactory<Dependencies>>();\n\n for (const plugin of plugins) {\n if (seenInBatch.has(plugin)) {\n logger.warn(\n LOGGER_CONTEXT,\n \"Duplicate factory in batch, will be registered once\",\n );\n } else {\n seenInBatch.add(plugin);\n }\n }\n\n return seenInBatch;\n }\n\n #startPlugin(pluginFactory: PluginFactory<Dependencies>): Unsubscribe {\n // Router and deps are guaranteed to be set at this point\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const router = this.#router!;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const deps = this.#deps!;\n\n // Bind getDependency to preserve 'this' context when called from factory\n // Plugin factories receive full router as part of their public API\n const appliedPlugin = pluginFactory(router, deps.getDependency);\n\n PluginsNamespace.validatePlugin(appliedPlugin);\n\n Object.freeze(appliedPlugin);\n\n // Collect all unsubscribe functions\n const removeEventListeners: Unsubscribe[] = [];\n\n // Subscribe plugin methods to corresponding router events\n for (const methodName of EVENT_METHOD_NAMES) {\n if (methodName in appliedPlugin) {\n if (typeof appliedPlugin[methodName] === \"function\") {\n removeEventListeners.push(\n deps.addEventListener(\n EVENTS_MAP[methodName],\n appliedPlugin[methodName],\n ),\n );\n\n if (methodName === \"onStart\" && deps.isStarted()) {\n logger.warn(\n LOGGER_CONTEXT,\n \"Router already started, onStart will not be called\",\n );\n }\n } else {\n logger.warn(\n LOGGER_CONTEXT,\n `Property '${methodName}' is not a function, skipping`,\n );\n }\n }\n }\n\n // Return composite cleanup function\n return () => {\n for (const removeListener of removeEventListeners) {\n removeListener();\n }\n\n if (typeof appliedPlugin.teardown === \"function\") {\n appliedPlugin.teardown();\n }\n };\n }\n}\n","// packages/core/src/namespaces/RouteLifecycleNamespace/validators.ts\n\n/**\n * Static validation functions for RouteLifecycleNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { isBoolean, getTypeDescription } from \"type-guards\";\n\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\nimport type { ActivationFnFactory } from \"../../types\";\nimport type { DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Validates that a handler is either a boolean or a factory function.\n */\nexport function validateHandler<D extends DefaultDependencies>(\n handler: unknown,\n methodName: string,\n): asserts handler is ActivationFnFactory<D> | boolean {\n if (!isBoolean(handler) && typeof handler !== \"function\") {\n throw new TypeError(\n `[router.${methodName}] Handler must be a boolean or factory function, ` +\n `got ${getTypeDescription(handler)}`,\n );\n }\n}\n\n/**\n * Validates that a route is not currently being registered.\n * Prevents self-modification during factory compilation.\n */\nexport function validateNotRegistering(\n isRegistering: boolean,\n name: string,\n methodName: string,\n): void {\n if (isRegistering) {\n throw new Error(\n `[router.${methodName}] Cannot modify route \"${name}\" during its own registration`,\n );\n }\n}\n\n/**\n * Validates that adding a new handler won't exceed the hard limit.\n */\nexport function validateHandlerLimit(\n currentCount: number,\n methodName: string,\n maxLifecycleHandlers: number = DEFAULT_LIMITS.maxLifecycleHandlers,\n): void {\n if (maxLifecycleHandlers === 0) {\n return;\n }\n\n if (currentCount >= maxLifecycleHandlers) {\n throw new Error(\n `[router.${methodName}] Lifecycle handler limit exceeded (${maxLifecycleHandlers}). ` +\n `This indicates too many routes with individual handlers. ` +\n `Consider using middleware for cross-cutting concerns.`,\n );\n }\n}\n","// packages/core/src/namespaces/RouteLifecycleNamespace/RouteLifecycleNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\nimport { isBoolean, getTypeDescription } from \"type-guards\";\n\nimport {\n validateHandler,\n validateHandlerLimit,\n validateNotRegistering,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { RouteLifecycleDependencies } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { ActivationFnFactory, Limits } from \"../../types\";\nimport type { ActivationFn, DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Converts a boolean value to an activation function factory.\n * Used for the shorthand syntax where true/false is passed instead of a function.\n */\nfunction booleanToFactory<Dependencies extends DefaultDependencies>(\n value: boolean,\n): ActivationFnFactory<Dependencies> {\n const activationFn: ActivationFn = () => value;\n\n return () => activationFn;\n}\n\n/**\n * Independent namespace for managing route lifecycle handlers.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class RouteLifecycleNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #canDeactivateFactories = new Map<\n string,\n ActivationFnFactory<Dependencies>\n >();\n readonly #canActivateFactories = new Map<\n string,\n ActivationFnFactory<Dependencies>\n >();\n readonly #canDeactivateFunctions = new Map<string, ActivationFn>();\n readonly #canActivateFunctions = new Map<string, ActivationFn>();\n\n readonly #registering = new Set<string>();\n\n #router: Router<Dependencies> | undefined;\n\n #deps: RouteLifecycleDependencies<Dependencies> | undefined;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateHandler<D extends DefaultDependencies>(\n handler: unknown,\n methodName: string,\n ): asserts handler is ActivationFnFactory<D> | boolean {\n validateHandler<D>(handler, methodName);\n }\n\n static validateNotRegistering(\n isRegistering: boolean,\n name: string,\n methodName: string,\n ): void {\n validateNotRegistering(isRegistering, name, methodName);\n }\n\n static validateHandlerLimit(\n currentCount: number,\n methodName: string,\n maxLifecycleHandlers?: number,\n ): void {\n validateHandlerLimit(currentCount, methodName, maxLifecycleHandlers);\n }\n\n setRouter(router: Router<Dependencies>): void {\n this.#router = router;\n }\n\n setDependencies(deps: RouteLifecycleDependencies<Dependencies>): void {\n this.#deps = deps;\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // State accessors (for facade validation)\n // =========================================================================\n\n /**\n * Returns true if route is currently being registered.\n * Used by facade for self-modification validation.\n */\n isRegistering(name: string): boolean {\n return this.#registering.has(name);\n }\n\n /**\n * Returns the number of canActivate handlers.\n * Used by facade for limit validation.\n */\n countCanActivate(): number {\n return this.#canActivateFactories.size;\n }\n\n /**\n * Returns the number of canDeactivate handlers.\n * Used by facade for limit validation.\n */\n countCanDeactivate(): number {\n return this.#canDeactivateFactories.size;\n }\n\n /**\n * Returns true if canActivate handler exists for route.\n * Used by facade to determine if this is an overwrite.\n */\n hasCanActivate(name: string): boolean {\n return this.#canActivateFactories.has(name);\n }\n\n /**\n * Returns true if canDeactivate handler exists for route.\n * Used by facade to determine if this is an overwrite.\n */\n hasCanDeactivate(name: string): boolean {\n return this.#canDeactivateFactories.has(name);\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Registers a canActivate guard for a route.\n * Input already validated by facade (not registering, limit).\n *\n * @param name - Route name (already validated by facade)\n * @param handler - Guard function or boolean (already validated)\n * @param isOverwrite - True if overwriting existing handler (computed by facade)\n */\n registerCanActivate(\n name: string,\n handler: ActivationFnFactory<Dependencies> | boolean,\n isOverwrite: boolean,\n ): void {\n this.#registerHandler(\n \"activate\",\n name,\n handler,\n this.#canActivateFactories,\n this.#canActivateFunctions,\n \"canActivate\",\n isOverwrite,\n );\n }\n\n /**\n * Registers a canDeactivate guard for a route.\n * Input already validated by facade (not registering, limit).\n *\n * @param name - Route name (already validated by facade)\n * @param handler - Guard function or boolean (already validated)\n * @param isOverwrite - True if overwriting existing handler (computed by facade)\n */\n registerCanDeactivate(\n name: string,\n handler: ActivationFnFactory<Dependencies> | boolean,\n isOverwrite: boolean,\n ): void {\n this.#registerHandler(\n \"deactivate\",\n name,\n handler,\n this.#canDeactivateFactories,\n this.#canDeactivateFunctions,\n \"canDeactivate\",\n isOverwrite,\n );\n }\n\n /**\n * Removes a canActivate guard for a route.\n * Input already validated by facade (not registering).\n *\n * @param name - Route name (already validated by facade)\n * @param _silent - Unused (kept for API compatibility)\n */\n clearCanActivate(name: string, _silent = false): void {\n this.#canActivateFactories.delete(name);\n this.#canActivateFunctions.delete(name);\n }\n\n /**\n * Removes a canDeactivate guard for a route.\n * Input already validated by facade (not registering).\n *\n * @param name - Route name (already validated by facade)\n * @param _silent - Unused (kept for API compatibility)\n */\n clearCanDeactivate(name: string, _silent = false): void {\n this.#canDeactivateFactories.delete(name);\n this.#canDeactivateFunctions.delete(name);\n }\n\n /**\n * Clears all lifecycle handlers (canActivate and canDeactivate).\n * Used by clearRoutes to reset all lifecycle state.\n */\n clearAll(): void {\n this.#canActivateFactories.clear();\n this.#canActivateFunctions.clear();\n this.#canDeactivateFactories.clear();\n this.#canDeactivateFunctions.clear();\n }\n\n /**\n * Returns lifecycle factories as records for cloning.\n *\n * @returns Tuple of [canDeactivateFactories, canActivateFactories]\n */\n getFactories(): [\n Record<string, ActivationFnFactory<Dependencies>>,\n Record<string, ActivationFnFactory<Dependencies>>,\n ] {\n const deactivateRecord: Record<\n string,\n ActivationFnFactory<Dependencies>\n > = {};\n const activateRecord: Record<\n string,\n ActivationFnFactory<Dependencies>\n > = {};\n\n for (const [name, factory] of this.#canDeactivateFactories) {\n deactivateRecord[name] = factory;\n }\n\n for (const [name, factory] of this.#canActivateFactories) {\n activateRecord[name] = factory;\n }\n\n return [deactivateRecord, activateRecord];\n }\n\n /**\n * Returns compiled lifecycle functions for transition execution.\n *\n * @returns Tuple of [canDeactivateFunctions, canActivateFunctions] as Maps\n */\n getFunctions(): [Map<string, ActivationFn>, Map<string, ActivationFn>] {\n return [this.#canDeactivateFunctions, this.#canActivateFunctions];\n }\n\n // =========================================================================\n // Private methods (business logic)\n // =========================================================================\n\n /**\n * Registers a handler. Input already validated by facade.\n * Handles overwrite warning, count threshold warnings, and factory compilation.\n */\n #registerHandler(\n type: \"activate\" | \"deactivate\",\n name: string,\n handler: ActivationFnFactory<Dependencies> | boolean,\n factories: Map<string, ActivationFnFactory<Dependencies>>,\n functions: Map<string, ActivationFn>,\n methodName: string,\n isOverwrite: boolean,\n ): void {\n // Emit warnings (validation done by facade)\n if (isOverwrite) {\n logger.warn(\n `router.${methodName}`,\n `Overwriting existing ${type} handler for route \"${name}\"`,\n );\n } else {\n this.#checkCountThresholds(factories.size + 1, methodName);\n }\n\n // Convert boolean to factory if needed\n const factory = isBoolean(handler)\n ? booleanToFactory<Dependencies>(handler)\n : handler;\n\n // Store factory\n factories.set(name, factory);\n\n // Mark route as being registered before calling user factory\n this.#registering.add(name);\n\n try {\n // Router and deps are guaranteed to be set at this point\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const router = this.#router!;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const deps = this.#deps!;\n\n // Lifecycle factories receive full router as part of their public API\n const fn = factory(router, deps.getDependency);\n\n if (typeof fn !== \"function\") {\n throw new TypeError(\n `[router.${methodName}] Factory must return a function, got ${getTypeDescription(fn)}`,\n );\n }\n\n functions.set(name, fn);\n } catch (error) {\n // Rollback on failure to maintain consistency\n factories.delete(name);\n\n throw error;\n } finally {\n this.#registering.delete(name);\n }\n }\n\n #checkCountThresholds(currentSize: number, methodName: string): void {\n const maxLifecycleHandlers = this.#limits.maxLifecycleHandlers;\n\n if (maxLifecycleHandlers === 0) {\n return;\n }\n\n const { warn, error } = computeThresholds(maxLifecycleHandlers);\n\n if (currentSize >= error) {\n logger.error(\n `router.${methodName}`,\n `${currentSize} lifecycle handlers registered! ` +\n `This is excessive. Hard limit at ${maxLifecycleHandlers}.`,\n );\n } else if (currentSize >= warn) {\n logger.warn(\n `router.${methodName}`,\n `${currentSize} lifecycle handlers registered. ` +\n `Consider consolidating logic.`,\n );\n }\n }\n}\n","// packages/route-node/modules/search-params/decode.ts\n\n/**\n * Decoding functions for search-params.\n *\n * Extracted from encode.ts for better separation of concerns.\n *\n * @module search-params/decode\n */\n\nimport type { ResolvedStrategies } from \"./strategies\";\nimport type { DecodeResult } from \"./types\";\n\n// =============================================================================\n// Value Decoding\n// =============================================================================\n\n/**\n * Decodes a URL-encoded value, handling + as space.\n * Optimized: only replaces + if present, skips decodeURIComponent if not needed.\n *\n * Uses indexOf for checking presence - more mutation-resistant than includes\n * because indexOf(\"x\") returns -1 when not found, while includes(\"\") always returns true.\n */\nexport const decodeValue = (value: string): string => {\n const percentIdx = value.indexOf(\"%\");\n const plusIdx = value.indexOf(\"+\");\n\n // Fast path: no encoding needed (common case - most values are simple)\n if (percentIdx === -1 && plusIdx === -1) {\n return value;\n }\n\n // Only replace + if present (avoid regex overhead)\n const withSpaces = plusIdx === -1 ? value : value.split(\"+\").join(\" \");\n\n // Only decode if % is present\n return percentIdx === -1 ? withSpaces : decodeURIComponent(withSpaces);\n};\n\n// =============================================================================\n// Main Decode\n// =============================================================================\n\n/**\n * Decodes a query parameter value using resolved strategies.\n *\n * @param value - Raw value from query string (undefined for key-only params)\n * @param strategies - Pre-resolved format strategies\n * @returns Decoded value (string, boolean, or null)\n */\nexport const decode = (\n value: string | undefined,\n strategies: ResolvedStrategies,\n): DecodeResult => {\n // Handle undefined (key-only params like ?flag)\n if (value === undefined) {\n return strategies.boolean.decodeUndefined();\n }\n\n // Check raw value for boolean formats (e.g., \"true\"/\"false\")\n const rawResult = strategies.boolean.decodeRaw(value);\n\n if (rawResult !== null) {\n return rawResult;\n }\n\n // Decode URI and check decoded value for boolean formats (e.g., â/â)\n const decoded = decodeValue(value);\n\n return strategies.boolean.decodeValue(decoded);\n};\n","// packages/route-node/modules/search-params/strategies/array.ts\n\n/**\n * Array encoding strategies.\n *\n * @module search-params/strategies/array\n */\n\nimport type { ArrayFormat } from \"../types\";\n\n// =============================================================================\n// Strategy Interface\n// =============================================================================\n\n/**\n * Strategy for encoding array values.\n */\nexport interface ArrayStrategy {\n /**\n * Encodes an array as a query string segment.\n *\n * @param name - URL-encoded parameter name\n * @param values - Array values to encode\n * @returns Query string segment (e.g., \"items=a&items=b\" or \"items=a,b\")\n */\n encodeArray: (name: string, values: unknown[]) => string;\n}\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\nconst encodeValue = (value: unknown): string =>\n encodeURIComponent(value as string | number | boolean);\n\n// =============================================================================\n// Strategy Implementations\n// =============================================================================\n\n/**\n * Repeated keys without brackets.\n * Example: items=a&items=b\n */\nexport const noneArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n values.map((val) => `${name}=${encodeValue(val)}`).join(\"&\"),\n};\n\n/**\n * Bracket notation without index.\n * Example: items[]=a&items[]=b\n */\nexport const bracketsArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n values.map((val) => `${name}[]=${encodeValue(val)}`).join(\"&\"),\n};\n\n/**\n * Indexed bracket notation.\n * Example: items[0]=a&items[1]=b\n */\nexport const indexArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n values.map((val, i) => `${name}[${i}]=${encodeValue(val)}`).join(\"&\"),\n};\n\n/**\n * Comma-separated values.\n * Example: items=a,b,c\n */\nexport const commaArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n `${name}=${values.map((val) => encodeValue(val)).join(\",\")}`,\n};\n\n/**\n * Map of array format to strategy implementation.\n */\nexport const arrayStrategies: Record<ArrayFormat, ArrayStrategy> = {\n none: noneArrayStrategy,\n brackets: bracketsArrayStrategy,\n index: indexArrayStrategy,\n comma: commaArrayStrategy,\n};\n","// packages/route-node/modules/search-params/strategies/boolean.ts\n\n/**\n * Boolean encoding/decoding strategies.\n *\n * @module search-params/strategies/boolean\n */\n\nimport type { DecodeResult, BooleanFormat } from \"../types\";\n\n// =============================================================================\n// Strategy Map\n// =============================================================================\n\n// =============================================================================\n// Strategy Interface\n// =============================================================================\n\n/**\n * Strategy for encoding/decoding boolean values.\n */\nexport interface BooleanStrategy {\n /**\n * Encodes a boolean value as a query string segment.\n *\n * @param name - URL-encoded parameter name\n * @param value - Boolean value to encode\n * @returns Query string segment (e.g., \"flag=true\" or just \"flag\")\n */\n encode: (name: string, value: boolean) => string;\n\n /**\n * Handles undefined value (key-only params like ?flag).\n *\n * @returns Decoded value for undefined\n */\n decodeUndefined: () => DecodeResult;\n\n /**\n * Decodes a raw (not URI-decoded) value before decodeValue() is called.\n * Used for formats that check raw values (e.g., \"string\" checks \"true\"/\"false\").\n *\n * @param rawValue - Raw value before URI decoding\n * @returns boolean if matched, null to continue with URI decoding\n */\n decodeRaw: (rawValue: string) => boolean | null;\n\n /**\n * Decodes a URI-decoded value.\n *\n * @param decodedValue - Value after URI decoding\n * @returns Decoded value (boolean or the same string)\n */\n decodeValue: (decodedValue: string) => DecodeResult;\n}\n\n// =============================================================================\n// Strategy Implementations\n// =============================================================================\n\n/**\n * No special boolean handling - values are treated as strings.\n */\nexport const noneBooleanStrategy: BooleanStrategy = {\n encode: (name, value) => `${name}=${value}`,\n decodeUndefined: () => null,\n decodeRaw: () => null, // No raw value matching\n decodeValue: (decoded) => decoded, // Return as-is\n};\n\n/**\n * Parse \"true\"/\"false\" strings as boolean values.\n * Checks raw value before URI decoding.\n */\nexport const stringBooleanStrategy: BooleanStrategy = {\n encode: (name, value) => `${name}=${value}`,\n decodeUndefined: () => null,\n decodeRaw: (raw) => {\n if (raw === \"true\") {\n return true;\n }\n if (raw === \"false\") {\n return false;\n }\n\n return null; // Continue with URI decoding\n },\n decodeValue: (decoded) => decoded, // Return decoded string\n};\n\n/**\n * True values are key-only (no =value), false values are omitted.\n * Example: ?flag instead of ?flag=true\n */\nexport const emptyTrueBooleanStrategy: BooleanStrategy = {\n encode: (name, value) => (value ? name : `${name}=false`),\n decodeUndefined: () => true, // Key-only means true\n decodeRaw: () => null, // No raw value matching\n decodeValue: (decoded) => decoded, // Return as-is\n};\n\n/**\n * Map of boolean format to strategy implementation.\n */\nexport const booleanStrategies: Record<BooleanFormat, BooleanStrategy> = {\n none: noneBooleanStrategy,\n string: stringBooleanStrategy,\n \"empty-true\": emptyTrueBooleanStrategy,\n};\n","// packages/route-node/modules/search-params/strategies/null.ts\n\n/**\n * Null encoding/decoding strategies.\n *\n * @module search-params/strategies/null\n */\n\n// =============================================================================\n// Strategy Interface\n// =============================================================================\n\n/**\n * Strategy for encoding/decoding null values.\n */\n// =============================================================================\n// Strategy Map\n// =============================================================================\n\nimport type { NullFormat } from \"../types\";\n\nexport interface NullStrategy {\n /**\n * Encodes a null value as a query string segment.\n *\n * @param name - URL-encoded parameter name\n * @returns Query string segment (e.g., \"key\" or \"\")\n */\n encode: (name: string) => string;\n}\n\n// =============================================================================\n// Strategy Implementations\n// =============================================================================\n\n/**\n * Default null format - key only without value.\n * Example: ?key (no equals sign)\n */\nexport const defaultNullStrategy: NullStrategy = {\n encode: (name) => name,\n};\n\n/**\n * Null values are hidden (omitted from query string).\n * Example: (nothing)\n */\nexport const hiddenNullStrategy: NullStrategy = {\n encode: () => \"\",\n};\n\n/**\n * Map of null format to strategy implementation.\n */\nexport const nullStrategies: Record<NullFormat, NullStrategy> = {\n default: defaultNullStrategy,\n hidden: hiddenNullStrategy,\n};\n","// packages/route-node/modules/search-params/strategies/index.ts\n\n/**\n * Search Params Strategies - Factory and Types.\n *\n * Provides a unified interface for format-specific encoding/decoding strategies.\n * Strategies are resolved once when options are created, avoiding repeated\n * format checks during encode/decode operations.\n *\n * @module search-params/strategies\n */\n\nimport { arrayStrategies, type ArrayStrategy } from \"./array\";\nimport { booleanStrategies, type BooleanStrategy } from \"./boolean\";\nimport { nullStrategies, type NullStrategy } from \"./null\";\n\nimport type { FinalOptions } from \"../types\";\n\n// =============================================================================\n// Exports\n// =============================================================================\n\nexport type { ArrayStrategy } from \"./array\";\n\nexport type { BooleanStrategy } from \"./boolean\";\n\nexport type { NullStrategy } from \"./null\";\n\n// =============================================================================\n// Resolved Strategies\n// =============================================================================\n\n/**\n * Pre-resolved strategies based on options.\n * Created once when makeOptions() is called, avoiding repeated lookups.\n */\nexport interface ResolvedStrategies {\n readonly boolean: BooleanStrategy;\n readonly null: NullStrategy;\n readonly array: ArrayStrategy;\n}\n\n/**\n * Resolves strategies based on format options.\n *\n * @param arrayFormat - Array format\n * @param booleanFormat - Boolean format\n * @param nullFormat - Null format\n * @returns Resolved strategy implementations\n */\nexport const resolveStrategies = (\n arrayFormat: FinalOptions[\"arrayFormat\"],\n booleanFormat: FinalOptions[\"booleanFormat\"],\n nullFormat: FinalOptions[\"nullFormat\"],\n): ResolvedStrategies => ({\n boolean: booleanStrategies[booleanFormat],\n null: nullStrategies[nullFormat],\n array: arrayStrategies[arrayFormat],\n});\n\n// =============================================================================\n// Default Strategies\n// =============================================================================\n\n/**\n * Default strategies matching DEFAULT_OPTIONS.\n * Used when no custom options are provided.\n */\nexport const DEFAULT_STRATEGIES: ResolvedStrategies = {\n boolean: booleanStrategies.none,\n null: nullStrategies.default,\n array: arrayStrategies.none,\n};\n","// packages/route-node/modules/search-params/encode.ts\n\n/**\n * Encoding functions for search-params.\n *\n * Uses Strategy pattern for format-specific encoding.\n * Strategies are resolved once when options are created.\n *\n * @module search-params/encode\n */\n\nimport {\n DEFAULT_STRATEGIES,\n resolveStrategies,\n type ResolvedStrategies,\n} from \"./strategies\";\n\nimport type { FinalOptions, Options } from \"./types\";\n\n// =============================================================================\n// Options with Strategies\n// =============================================================================\n\n/**\n * Extended options with pre-resolved strategies.\n */\nexport interface OptionsWithStrategies extends FinalOptions {\n readonly strategies: ResolvedStrategies;\n}\n\n/**\n * Cached default options with strategies - avoids allocation when no options passed.\n */\nconst DEFAULT_OPTIONS: OptionsWithStrategies = {\n arrayFormat: \"none\",\n booleanFormat: \"none\",\n nullFormat: \"default\",\n strategies: DEFAULT_STRATEGIES,\n};\n\n/**\n * Creates options with defaults and pre-resolved strategies.\n * Returns cached DEFAULT_OPTIONS when no custom options are specified.\n */\nexport const makeOptions = (opts?: Options): OptionsWithStrategies => {\n if (\n !opts ||\n (opts.arrayFormat === undefined &&\n opts.booleanFormat === undefined &&\n opts.nullFormat === undefined)\n ) {\n return DEFAULT_OPTIONS;\n }\n\n // Avoid object spread - direct property assignment is faster\n const arrayFormat = opts.arrayFormat ?? \"none\";\n const booleanFormat = opts.booleanFormat ?? \"none\";\n const nullFormat = opts.nullFormat ?? \"default\";\n\n return {\n arrayFormat,\n booleanFormat,\n nullFormat,\n strategies: resolveStrategies(arrayFormat, booleanFormat, nullFormat),\n };\n};\n\n// =============================================================================\n// Value Encoding\n// =============================================================================\n\n/**\n * Encodes a value for use in a URL query string.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-argument\nexport const encodeValue = (value: any): string => encodeURIComponent(value);\n\n// =============================================================================\n// Main Encode\n// =============================================================================\n\n/**\n * Encodes a parameter name and value as a query string segment.\n *\n * Uses pre-resolved strategies for format-specific encoding.\n * Strategies handle all formats uniformly - no inline optimizations\n * to avoid equivalent mutants in mutation testing.\n *\n * @param name - Parameter name\n * @param value - Parameter value\n * @param opts - Options with pre-resolved strategies\n * @returns Query string segment (e.g., \"key=value\")\n */\nexport const encode = (\n name: string,\n value: unknown,\n opts: OptionsWithStrategies,\n): string => {\n const encodedName = encodeValue(name);\n\n // Handle each type using strategies\n switch (typeof value) {\n case \"string\":\n case \"number\": {\n return `${encodedName}=${encodeValue(value)}`;\n }\n case \"boolean\": {\n return opts.strategies.boolean.encode(encodedName, value);\n }\n case \"object\": {\n // Null check\n if (value === null) {\n return opts.strategies.null.encode(encodedName);\n }\n // Array check\n if (Array.isArray(value)) {\n return opts.strategies.array.encodeArray(encodedName, value);\n }\n\n // Fallback for other objects - treat as string\n return `${encodedName}=${encodeValue(value)}`;\n }\n default: {\n // Fallback for other types (undefined handled by caller)\n return `${encodedName}=${encodeValue(value)}`;\n }\n }\n};\n","// packages/route-node/modules/search-params/utils.ts\n\n/**\n * Utility functions for search-params.\n *\n * Internalized from https://github.com/troch/search-params\n *\n * @module search-params/utils\n */\n\n// =============================================================================\n// Query String Extraction\n// =============================================================================\n\n/**\n * Extracts the query string portion from a path.\n * Returns everything after \"?\" or the entire string if no \"?\" exists.\n */\nexport const getSearch = (path: string): string => {\n const pos = path.indexOf(\"?\");\n\n if (pos === -1) {\n return path;\n }\n\n return path.slice(pos + 1);\n};\n","// packages/route-node/modules/search-params/searchParams.ts\n\n/**\n * Search Params - Query String Parsing and Building.\n *\n * Internalized from https://github.com/troch/search-params (MIT License)\n * for better code control and optimization.\n *\n * @module search-params/searchParams\n */\n\nimport { decode, decodeValue } from \"./decode\";\nimport { encode, makeOptions } from \"./encode\";\nimport { getSearch } from \"./utils\";\n\nimport type { ResolvedStrategies } from \"./strategies\";\nimport type { KeepResponse, OmitResponse, Options } from \"./types\";\n\n// =============================================================================\n// Internal Helpers\n// =============================================================================\n\n/**\n * Extracts parameter name from raw name (removes bracket suffix).\n *\n * @internal\n */\nfunction extractParamName(rawName: string): {\n name: string;\n hasBrackets: boolean;\n} {\n const bracketPos = rawName.indexOf(\"[\");\n\n return bracketPos === -1\n ? { name: rawName, hasBrackets: false }\n : { name: rawName.slice(0, bracketPos), hasBrackets: true };\n}\n\n/**\n * Adds a decoded value to params object, handling array accumulation.\n *\n * @internal\n */\nfunction addToParams(\n params: Record<string, unknown>,\n decodedName: string,\n decodedValue: unknown,\n hasBrackets: boolean,\n): void {\n const currentValue = params[decodedName];\n\n if (currentValue === undefined) {\n params[decodedName] = hasBrackets ? [decodedValue] : decodedValue;\n } else if (Array.isArray(currentValue)) {\n currentValue.push(decodedValue);\n } else {\n params[decodedName] = [currentValue, decodedValue];\n }\n}\n\n/**\n * Decodes a parameter value based on whether strategies are provided.\n *\n * @internal\n */\nfunction decodeParamValue(\n searchPart: string,\n eqPos: number,\n end: number,\n hasValue: boolean,\n strategies: ResolvedStrategies | undefined,\n): unknown {\n if (strategies) {\n const rawValue = hasValue ? searchPart.slice(eqPos + 1, end) : undefined;\n\n return decode(rawValue, strategies);\n }\n\n return hasValue ? decodeValue(searchPart.slice(eqPos + 1, end)) : null;\n}\n\n/**\n * Processes a single query parameter chunk and adds to params.\n *\n * @internal\n */\nfunction processParamChunk(\n searchPart: string,\n start: number,\n end: number,\n params: Record<string, unknown>,\n strategies?: ResolvedStrategies,\n): void {\n const eqPos = searchPart.indexOf(\"=\", start);\n const hasValue = eqPos !== -1 && eqPos < end;\n\n const rawName = hasValue\n ? searchPart.slice(start, eqPos)\n : searchPart.slice(start, end);\n\n const { name, hasBrackets } = extractParamName(rawName);\n const decodedName = decodeValue(name);\n const decodedValue = decodeParamValue(\n searchPart,\n eqPos,\n end,\n hasValue,\n strategies,\n );\n\n addToParams(params, decodedName, decodedValue, hasBrackets);\n}\n\n/**\n * Iterates over query string parameters, calling handler for each chunk.\n *\n * @internal\n */\nfunction forEachParam(\n searchPart: string,\n handler: (chunk: string, start: number, end: number) => void,\n): void {\n let start = 0;\n const len = searchPart.length;\n\n while (start < len) {\n let end = searchPart.indexOf(\"&\", start);\n\n if (end === -1) {\n end = len;\n }\n\n handler(searchPart.slice(start, end), start, end);\n start = end + 1;\n }\n}\n\n// =============================================================================\n// Parse\n// =============================================================================\n\n/**\n * Parse a querystring and return an object of parameters.\n *\n * @example\n * ```typescript\n * parse(\"page=1&sort=name\");\n * // => { page: \"1\", sort: \"name\" }\n *\n * parse(\"items[]=a&items[]=b\", { arrayFormat: \"brackets\" });\n * // => { items: [\"a\", \"b\"] }\n * ```\n */\nexport const parse = (\n path: string,\n opts?: Options,\n): Record<string, unknown> => {\n const searchPart = getSearch(path);\n\n // Fast path: empty query string\n if (searchPart === \"\" || searchPart === \"?\") {\n return {};\n }\n\n // Fast path: no options - use simplified parser (skip strategy resolution)\n if (!opts) {\n return parseSimple(searchPart);\n }\n\n const options = makeOptions(opts);\n const params: Record<string, unknown> = {};\n\n // Process each parameter\n let start = 0;\n const len = searchPart.length;\n\n while (start < len) {\n let end = searchPart.indexOf(\"&\", start);\n\n if (end === -1) {\n end = len;\n }\n\n processParamChunk(searchPart, start, end, params, options.strategies);\n start = end + 1;\n }\n\n return params;\n};\n\n/**\n * Simplified parse without strategy resolution.\n * Used when no options are provided (most common case).\n * Returns string values only (no boolean/null conversion).\n *\n * @internal\n */\nfunction parseSimple(searchPart: string): Record<string, unknown> {\n const params: Record<string, unknown> = {};\n\n parseIntoInternal(searchPart, params);\n\n return params;\n}\n\n/**\n * Parse query string directly into a target object.\n * Avoids creating intermediate object and Object.assign.\n * Optimized for loose mode query params handling.\n *\n * @param queryString - Query string without leading \"?\"\n * @param target - Object to add params to\n */\nexport function parseInto(\n queryString: string,\n target: Record<string, unknown>,\n): void {\n if (queryString === \"\") {\n return;\n }\n\n parseIntoInternal(queryString, target);\n}\n\n/**\n * Internal function to parse query string into target object.\n * Shared by parseSimple and parseInto.\n *\n * @internal\n */\nfunction parseIntoInternal(\n searchPart: string,\n params: Record<string, unknown>,\n): void {\n let start = 0;\n const len = searchPart.length;\n\n while (start < len) {\n let end = searchPart.indexOf(\"&\", start);\n\n if (end === -1) {\n end = len;\n }\n\n // No strategies = simple decoding\n processParamChunk(searchPart, start, end, params);\n start = end + 1;\n }\n}\n\n// =============================================================================\n// Build\n// =============================================================================\n\n/**\n * Build a querystring from an object of parameters.\n *\n * @example\n * ```typescript\n * build({ page: 1, sort: \"name\" });\n * // => \"page=1&sort=name\"\n *\n * build({ items: [\"a\", \"b\"] }, { arrayFormat: \"brackets\" });\n * // => \"items[]=a&items[]=b\"\n * ```\n */\nexport const build = (\n params: Record<string, unknown>,\n opts?: Options,\n): string => {\n // Fast path for empty params (common case)\n const keys = Object.keys(params);\n\n if (keys.length === 0) {\n return \"\";\n }\n\n const options = makeOptions(opts);\n\n // Optimized: single loop instead of filter().map().filter().join()\n // Avoids creating 3 intermediate arrays\n const parts: string[] = [];\n\n for (const key of keys) {\n const value = params[key];\n\n // Skip undefined values (not serialisable)\n if (value === undefined) {\n continue;\n }\n\n const encoded = encode(key, value, options);\n\n // Skip empty strings (e.g., from nullFormat: \"hidden\")\n if (encoded) {\n parts.push(encoded);\n }\n }\n\n return parts.join(\"&\");\n};\n\n// =============================================================================\n// Omit\n// =============================================================================\n\n/**\n * Remove a list of parameters from a querystring.\n *\n * @example\n * ```typescript\n * omit(\"page=1&sort=name&limit=10\", [\"sort\", \"limit\"]);\n * // => { querystring: \"page=1\", removedParams: { sort: \"name\", limit: \"10\" } }\n * ```\n */\nexport const omit = (\n path: string,\n paramsToOmit: string[],\n opts?: Options,\n): OmitResponse => {\n const searchPart = getSearch(path);\n\n if (searchPart === \"\") {\n return { querystring: \"\", removedParams: {} };\n }\n\n // Fast path: no params to omit - keep entire querystring\n if (paramsToOmit.length === 0) {\n const hasPrefix = path.startsWith(\"?\");\n\n return {\n querystring: hasPrefix ? path : searchPart,\n removedParams: {},\n };\n }\n\n const options = makeOptions(opts);\n const hasPrefix = path.startsWith(\"?\");\n const omitSet = new Set(paramsToOmit);\n const kept: string[] = [];\n const removed: string[] = [];\n\n forEachParam(searchPart, (chunk) => {\n const eqPos = chunk.indexOf(\"=\");\n const rawName = eqPos === -1 ? chunk : chunk.slice(0, eqPos);\n const { name } = extractParamName(rawName);\n\n if (omitSet.has(name)) {\n removed.push(chunk);\n } else {\n kept.push(chunk);\n }\n });\n\n const querystring = kept.join(\"&\");\n\n return {\n querystring: hasPrefix && querystring ? `?${querystring}` : querystring,\n removedParams: parse(removed.join(\"&\"), options),\n };\n};\n\n// =============================================================================\n// Keep\n// =============================================================================\n\n/**\n * Keep only specified parameters from a querystring.\n *\n * @example\n * ```typescript\n * keep(\"page=1&sort=name&limit=10\", [\"page\"]);\n * // => { querystring: \"page=1\", keptParams: { page: \"1\" } }\n * ```\n */\nexport const keep = (\n path: string,\n paramsToKeep: string[],\n opts?: Options,\n): KeepResponse => {\n const searchPart = getSearch(path);\n\n if (searchPart === \"\") {\n return { keptParams: {}, querystring: \"\" };\n }\n\n // Fast path: no params to keep\n if (paramsToKeep.length === 0) {\n return { keptParams: {}, querystring: \"\" };\n }\n\n const options = makeOptions(opts);\n const keepSet = new Set(paramsToKeep);\n const kept: string[] = [];\n\n forEachParam(searchPart, (chunk) => {\n const eqPos = chunk.indexOf(\"=\");\n const rawName = eqPos === -1 ? chunk : chunk.slice(0, eqPos);\n const { name } = extractParamName(rawName);\n\n if (keepSet.has(name)) {\n kept.push(chunk);\n }\n });\n\n const querystring = kept.join(\"&\");\n\n return { keptParams: parse(querystring, options), querystring };\n};\n","// packages/route-tree/modules/parser/path-parser/buildPathFromPattern.ts\n\n/**\n * Standalone Path Building from Pattern.\n *\n * Pre-compiles route patterns for fast path building without regex at runtime.\n * R4 optimization used by Path.buildBasePath().\n *\n * NOTE: This module is designed for rou3 migration.\n * buildFromPattern() can be used as standalone buildPath without Path class.\n *\n * @example\n * ```typescript\n * // Compile once at initialization\n * const compiled = compilePathPattern(\"/users/:id/posts/:postId\");\n *\n * // Build many times (fast, no regex)\n * buildFromPattern(compiled, { id: \"123\", postId: \"456\" });\n * // â \"/users/123/posts/456\"\n * ```\n *\n * @module parser/path-parser/buildPathFromPattern\n */\n\n// =============================================================================\n// Types\n// =============================================================================\n\n/**\n * Pre-compiled path pattern for fast building.\n * Created once per route, reused for every buildPath call.\n */\nexport interface CompiledPathPattern {\n /** Static parts interleaved with params: [static0, static1, ..., staticN] */\n readonly staticParts: readonly string[];\n /** Parameter names in order: [param0, param1, ..., paramN-1] */\n readonly paramNames: readonly string[];\n /** Original pattern string (for debugging) */\n readonly pattern: string;\n}\n\n// =============================================================================\n// Pattern Parsing\n// =============================================================================\n\n/**\n * Pre-compiles a route pattern for fast path building.\n *\n * Supports:\n * - URL parameters: `/users/:id`\n * - Optional parameters: `/users/:id?`\n * - Wildcards: `/files/*` or `/files/*path`\n * - Matrix parameters: `/users;id=123`\n *\n * @param pattern - Route pattern string (e.g., \"/users/:id/posts/:postId\")\n * @returns Compiled pattern ready for buildFromPattern()\n *\n * @example\n * ```typescript\n * compilePathPattern(\"/users/:id\")\n * // â { staticParts: [\"/users/\", \"\"], paramNames: [\"id\"], pattern: \"/users/:id\" }\n *\n * compilePathPattern(\"/api/:version/:resource/:id\")\n * // â { staticParts: [\"/api/\", \"/\", \"/\", \"\"], paramNames: [\"version\", \"resource\", \"id\"], ... }\n * ```\n */\nexport function compilePathPattern(pattern: string): CompiledPathPattern {\n const staticParts: string[] = [];\n const paramNames: string[] = [];\n\n let lastIndex = 0;\n let currentStatic = \"\";\n\n // Combined regex for params and matrix\n // Group 1: URL param/wildcard (:param or *wildcard)\n // Group 2: Matrix param (;param=)\n const combinedRegex = /[*:](\\w*)\\??|;(\\w+)=?/g;\n let match: RegExpExecArray | null;\n\n while ((match = combinedRegex.exec(pattern)) !== null) {\n // Add static content before this match\n currentStatic += pattern.slice(lastIndex, match.index);\n\n // Check which group matched\n const urlParamName = match[1];\n const matrixParamName = match[2];\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- regex alternation: only one group matches\n if (matrixParamName === undefined) {\n // URL parameter or wildcard (:param or *wildcard)\n // urlParamName is defined here (may be empty string for bare *)\n const paramName = urlParamName || \"splat\";\n\n staticParts.push(currentStatic);\n currentStatic = \"\";\n paramNames.push(paramName);\n } else {\n // Matrix parameter (;param=)\n currentStatic += `;${matrixParamName}=`;\n staticParts.push(currentStatic);\n currentStatic = \"\";\n paramNames.push(matrixParamName);\n }\n\n lastIndex = combinedRegex.lastIndex;\n }\n\n // Add remaining static content\n currentStatic += pattern.slice(lastIndex);\n staticParts.push(currentStatic);\n\n return {\n staticParts,\n paramNames,\n pattern,\n };\n}\n\n// =============================================================================\n// Path Building\n// =============================================================================\n\n/**\n * Builds a URL path from a pre-compiled pattern and parameters.\n *\n * This is the hot path - optimized for speed:\n * - No regex at runtime\n * - O(n) string concatenation where n = number of params\n * - No object allocation\n *\n * @param compiled - Pre-compiled pattern from compilePathPattern()\n * @param params - Parameter values to inject (converted to string via String())\n * @returns Built URL path\n *\n * @example\n * ```typescript\n * const compiled = compilePathPattern(\"/users/:id/posts/:postId\");\n *\n * buildFromPattern(compiled, { id: \"123\", postId: \"456\" });\n * // â \"/users/123/posts/456\"\n *\n * buildFromPattern(compiled, { id: \"abc\", postId: \"def\" });\n * // â \"/users/abc/posts/def\"\n * ```\n */\nexport function buildFromPattern(\n compiled: CompiledPathPattern,\n params: Readonly<Record<string, unknown>>,\n): string {\n const { staticParts, paramNames } = compiled;\n\n // Fast path: no parameters\n if (paramNames.length === 0) {\n return staticParts[0];\n }\n\n // Build path using interleaved parts\n let path = staticParts[0];\n\n for (const [i, paramName] of paramNames.entries()) {\n path += String(params[paramName]) + staticParts[i + 1];\n }\n\n return path;\n}\n\n// =============================================================================\n// Convenience Functions\n// =============================================================================\n\n/**\n * One-shot path building (compiles and builds in one call).\n *\n * Use this only when pattern is used once.\n * For repeated builds, use compilePathPattern() + buildFromPattern().\n *\n * @param pattern - Route pattern string\n * @param params - Parameter values to inject\n * @returns Built URL path\n *\n * @example\n * ```typescript\n * buildPath(\"/users/:id\", { id: \"123\" });\n * // â \"/users/123\"\n * ```\n */\nexport function buildPathOnce(\n pattern: string,\n params: Readonly<Record<string, unknown>>,\n): string {\n return buildFromPattern(compilePathPattern(pattern), params);\n}\n","// packages/route-node/modules/parser/path-parser/constants.ts\n\n/**\n * Path Parser Constants.\n *\n * Consolidated constants for the path-parser module.\n *\n * @module parser/path-parser/constants\n */\n\nimport type { InternalPathOptions, Rule, URLParamsEncodingType } from \"./types\";\n\n// =============================================================================\n// Encoding Constants\n// =============================================================================\n\n/**\n * Optimized regex: only matches characters that ACTUALLY need encoding.\n * Excludes:\n * - A-Za-z0-9: alphanumeric (unreserved per RFC 3986)\n * - -._~: unreserved characters per RFC 3986\n * - !$'()*+,:;|: sub-delimiters we want to preserve\n *\n * Performance: This regex skips alphanumeric characters entirely,\n * avoiding unnecessary encodeURIComponent calls that return the same value.\n *\n * IMPORTANT: The 'u' (Unicode) flag is required to handle emoji and other\n * characters outside the Basic Multilingual Plane (BMP). Without it, the regex\n * matches individual UTF-16 code units (surrogates), and encodeURIComponent\n * fails on lone surrogates with \"URI malformed\" error.\n */\nconst NEEDS_ENCODING_REGEX = /[^\\w!$'()*+,.:;|~-]/gu;\n\n/**\n * Fast check regex (without global flag) to test if encoding is needed at all.\n * Used for pre-check optimization: if string contains only safe chars, skip encoding.\n *\n * IMPORTANT: The 'u' flag ensures proper handling of emoji/surrogate pairs.\n */\nconst NEEDS_ENCODING_TEST = /[^\\w!$'()*+,.:;|~-]/u;\n\n// =============================================================================\n// Encoding/Decoding Method Maps\n// =============================================================================\n\n/**\n * Encode a segment while preserving sub-delimiters.\n * Uses pre-check optimization: fast path for strings without special chars.\n *\n * Performance improvement over naive approach:\n * - Alphanumeric strings: 29-57x faster\n * - Strings with special chars: 2-3x faster\n */\nexport const encodeURIComponentExcludingSubDelims = (\n segment: string,\n): string => {\n // Fast path: if no special chars, return as-is\n if (!NEEDS_ENCODING_TEST.test(segment)) {\n return segment;\n }\n\n return segment.replaceAll(NEEDS_ENCODING_REGEX, (match) =>\n encodeURIComponent(match),\n );\n};\n\n/**\n * Encoding functions for each encoding type.\n */\nexport const ENCODING_METHODS: Record<\n URLParamsEncodingType,\n (param: string) => string\n> = {\n default: encodeURIComponentExcludingSubDelims,\n uri: encodeURI,\n uriComponent: encodeURIComponent,\n none: (val) => val,\n legacy: encodeURI,\n};\n\n/**\n * Decoding functions for each encoding type.\n */\nexport const DECODING_METHODS: Record<\n URLParamsEncodingType,\n (param: string) => string\n> = {\n default: decodeURIComponent,\n uri: decodeURI,\n uriComponent: decodeURIComponent,\n none: (val) => val,\n legacy: decodeURIComponent,\n};\n\n// =============================================================================\n// Path Defaults\n// =============================================================================\n\n/**\n * Default options for Path instances.\n */\nexport const DEFAULT_PATH_OPTIONS: InternalPathOptions = {\n urlParamsEncoding: \"default\",\n};\n\n// =============================================================================\n// Test Pattern Constants\n// =============================================================================\n\n/**\n * Regex patterns for Path.test() method.\n * Controls how URL matching handles query strings and end-of-path.\n */\nexport const TEST_PATTERNS = {\n /** Pattern for URL ending with optional query string: matches \"?\" followed by anything, or end of string */\n withQueryParams: String.raw`(\\?.*$|$)`,\n /** Pattern for URL ending: matches end of string only */\n withoutQueryParams: \"$\",\n} as const;\n\n/**\n * Regex patterns for Path.partialTest() method.\n * Controls delimiter matching for partial URL matching.\n */\nexport const PARTIAL_TEST_PATTERNS = {\n /** Delimiter pattern: matches /, ?, ., ;, or end of string */\n delimiter: String.raw`([/?.;]|$)`,\n} as const;\n\n// =============================================================================\n// Tokenizer Rules\n// =============================================================================\n\n/**\n * Default regex pattern for URL parameters without constraints.\n */\nexport const DEFAULT_PARAM_PATTERN = String.raw`[a-zA-Z0-9_.~%':|=+*@$-]+`;\n\n/**\n * Returns the constraint pattern or the default parameter pattern.\n * Wraps the pattern in a capturing group.\n *\n * @param match - The constraint pattern (e.g., \"<\\\\d+>\") or empty string\n * @returns Regex pattern string wrapped in parentheses\n *\n * @example\n * ```typescript\n * defaultOrConstrained('<\\\\d+>');\n * // => '(\\\\d+)'\n *\n * defaultOrConstrained('');\n * // => '([a-zA-Z0-9-_.~%\\':|=+\\\\*@$]+)'\n * ```\n */\nexport const defaultOrConstrained = (match: string): string => {\n const pattern = match\n ? match.replaceAll(/(^<|>$)/g, \"\")\n : DEFAULT_PARAM_PATTERN;\n\n return `(${pattern})`;\n};\n\n/**\n * Tokenization rules for parsing path patterns.\n *\n * Order matters: more specific rules should come first.\n * Each rule defines a pattern to match in the path string and\n * optionally a regex to use for URL matching.\n *\n * @example Path pattern examples:\n * - `/users/:id` - URL parameter\n * - `/users/:id<\\\\d+>` - Constrained URL parameter\n * - `/files/*path` - Splat parameter (matches rest of path)\n * - `/users/;section` - Matrix parameter\n * - `/users?page&limit` - Query parameters\n */\nexport const RULES: Rule[] = [\n /**\n * URL Parameter: `:paramName` or `:paramName<constraint>`\n * Matches: :id, :userId, :id<\\\\d+>\n */\n {\n name: \"url-parameter\",\n pattern: /^:([\\w-]*[\\dA-Za-z])(<(.+?)>)?/,\n regex: (match: RegExpMatchArray) =>\n new RegExp(defaultOrConstrained(match[2])),\n },\n /**\n * Splat Parameter: `*paramName`\n * Matches everything up to query string.\n * Example: *path in /files/*path matches \"docs/readme.md\"\n */\n {\n name: \"url-parameter-splat\",\n pattern: /^\\*([\\w-]*[\\dA-Za-z])/,\n regex: /([^?]*)/,\n },\n /**\n * Matrix Parameter: `;paramName` or `;paramName<constraint>`\n * RFC 3986 matrix URI syntax.\n * Example: ;section in /users/;section matches \";section=profile\"\n */\n {\n name: \"url-parameter-matrix\",\n pattern: /^;([\\w-]*[\\dA-Za-z])(<(.+?)>)?/,\n regex: (match: RegExpMatchArray) =>\n new RegExp(`;${match[1]}=${defaultOrConstrained(match[2])}`),\n },\n /**\n * Query Parameter: `?paramName` or `¶mName`\n * Defines expected query string parameters.\n * No regex - query params handled by search-params library.\n */\n {\n name: \"query-parameter\",\n pattern: /^[&?]:?([\\w-]*[\\dA-Za-z])/,\n },\n /**\n * Delimiter: `/` or `?`\n * Path segment separators.\n */\n {\n name: \"delimiter\",\n pattern: /^([/?])/,\n regex: (match: RegExpMatchArray) => new RegExp(`\\\\${match[0]}`),\n },\n /**\n * Sub-delimiter: `!`, `&`, `.`, `;`, `_`, `-`\n * RFC 3986 sub-delimiters used in paths.\n */\n {\n name: \"sub-delimiter\",\n pattern: /^([!&.;_-])/,\n regex: (match: RegExpMatchArray) => new RegExp(match[0]),\n },\n /**\n * Fragment: alphanumeric text\n * Static path segments like \"users\", \"posts\", \"api\".\n */\n {\n name: \"fragment\",\n pattern: /^([\\dA-Za-z]+)/,\n regex: (match: RegExpMatchArray) => new RegExp(match[0]),\n },\n];\n","// packages/route-node/modules/parser/path-parser/encoding.ts\n\n/**\n * Performance-critical code: string concatenation is 2x faster than template\n * literals/String.raw in V8 hot paths. See benchmarks for details.\n */\n/* eslint-disable prefer-template */\n\n/**\n * URL Parameter Encoding/Decoding.\n *\n * We encode using encodeURIComponent but we want to\n * preserve certain characters which are commonly used\n * (sub delimiters and ':')\n *\n * https://www.ietf.org/rfc/rfc3986.txt\n *\n * reserved = gen-delims / sub-delims\n * gen-delims = \":\" / \"/\" / \"?\" / \"#\" / \"[\" / \"]\" / \"@\"\n * sub-delims = \"!\" / \"$\" / \"&\" / \"'\" / \"(\" / \")\"\n * / \"*\" / \"+\" / \",\" / \";\" / \"=\"\n *\n * @module parser/path-parser/encoding\n */\n\nimport { DECODING_METHODS, ENCODING_METHODS } from \"./constants\";\n\nimport type { URLParamsEncodingType } from \"./types\";\n\n/**\n * Encodes a URL parameter value using the specified encoding strategy.\n *\n * For splat parameters (*path), encodes each path segment separately\n * while preserving \"/\" characters.\n *\n * @param param - The parameter value to encode\n * @param encoding - The encoding strategy to use\n * @param isSpatParam - Whether this is a splat parameter\n * @returns The encoded parameter string\n *\n * @example\n * ```typescript\n * encodeParam('hello world', 'default', false);\n * // => 'hello%20world'\n *\n * encodeParam('docs/readme.md', 'default', true);\n * // => 'docs/readme.md' (splat preserves slashes)\n * ```\n */\nexport const encodeParam = (\n param: string | number | boolean,\n encoding: URLParamsEncodingType,\n isSpatParam: boolean,\n): string => {\n const encoder = ENCODING_METHODS[encoding];\n const str = String(param);\n\n if (!isSpatParam) {\n return encoder(str);\n }\n\n // Splat params: encode each segment separately, preserving \"/\"\n // H6 optimization: string concatenation is 2x faster than template literals\n const segments = str.split(\"/\");\n let result = encoder(segments[0]);\n\n for (let i = 1; i < segments.length; i++) {\n result += \"/\" + encoder(segments[i]);\n }\n\n return result;\n};\n\n/**\n * Decodes a URL parameter value using the specified encoding strategy.\n *\n * @param param - The encoded parameter string to decode\n * @param encoding - The encoding strategy to use for decoding\n * @returns The decoded parameter string\n *\n * @example\n * ```typescript\n * decodeParam('hello%20world', 'default');\n * // => 'hello world'\n * ```\n */\nexport const decodeParam = (\n param: string,\n encoding: URLParamsEncodingType,\n): string => DECODING_METHODS[encoding](param);\n","// packages/route-node/modules/parser/path-parser/tokeniser.ts\n\n/**\n * Path Pattern Tokenizer.\n *\n * Parses path patterns into tokens for matching and building URLs.\n *\n * @module parser/path-parser/tokeniser\n */\n\nimport { RULES } from \"./constants\";\n\nimport type { Token } from \"./types\";\n\n/**\n * Tokenizes a path pattern string into an array of tokens.\n *\n * Recursively parses the path using tokenization rules defined in constants.\n * Each token represents a segment of the path (static fragment, parameter, etc.).\n *\n * @param str - The path pattern string to tokenize\n * @param tokens - Accumulator array for tokens (used in recursion)\n * @returns Array of parsed tokens\n * @throws Error if path contains unparseable segments\n *\n * @example\n * ```typescript\n * tokenise('/users/:id');\n * // => [\n * // { type: 'delimiter', match: '/', ... },\n * // { type: 'fragment', match: 'users', ... },\n * // { type: 'delimiter', match: '/', ... },\n * // { type: 'url-parameter', match: ':id', val: ['id'], ... }\n * // ]\n *\n * tokenise('/files/*path');\n * // => [\n * // { type: 'delimiter', match: '/', ... },\n * // { type: 'fragment', match: 'files', ... },\n * // { type: 'delimiter', match: '/', ... },\n * // { type: 'url-parameter-splat', match: '*path', val: ['path'], ... }\n * // ]\n * ```\n */\nexport const tokenise = (str: string, tokens: Token[] = []): Token[] => {\n // Look for a matching rule\n const matched = RULES.some((rule) => {\n const match = rule.pattern.exec(str);\n\n if (!match) {\n return false;\n }\n\n tokens.push({\n type: rule.name,\n match: match[0],\n val: match.slice(1, 2),\n otherVal: match.slice(2),\n regex: typeof rule.regex === \"function\" ? rule.regex(match) : rule.regex,\n });\n\n if (match[0].length < str.length) {\n tokenise(str.slice(match[0].length), tokens);\n }\n\n return true;\n });\n\n // If no rules matched, throw an error (possible malformed path)\n if (!matched) {\n throw new Error(`Could not parse path '${str}'`);\n }\n\n return tokens;\n};\n","// packages/route-node/modules/parser/path-parser/Path.ts\n\n/**\n * Performance-critical code: string concatenation is 2x faster than template\n * literals/String.raw in V8 hot paths. See benchmarks for details.\n */\n/* eslint-disable prefer-template */\n/* eslint-disable unicorn/prefer-string-raw */\n\n/**\n * Path Class for URL Routing.\n *\n * Parses, matches, and builds URLs with support for parameters and query strings.\n *\n * @module parser/path-parser/Path\n */\n\nimport {\n build as buildQueryParams,\n parse as parseQueryParams,\n} from \"search-params\";\n\nimport { buildFromPattern } from \"./buildPathFromPattern\";\nimport {\n DEFAULT_PATH_OPTIONS,\n defaultOrConstrained,\n PARTIAL_TEST_PATTERNS,\n TEST_PATTERNS,\n} from \"./constants\";\nimport { decodeParam, encodeParam } from \"./encoding\";\nimport { tokenise } from \"./tokeniser\";\n\nimport type { CompiledPathPattern } from \"./buildPathFromPattern\";\nimport type {\n InternalPathOptions,\n ParamValue,\n PathBuildOptions,\n PathOptions,\n PathPartialTestOptions,\n PathTestOptions,\n TestMatch,\n Token,\n URLParamsEncodingType,\n} from \"./types\";\nimport type { Options } from \"search-params\";\n\n// =============================================================================\n// Types for Regex Cache\n// =============================================================================\n\n/**\n * Cached RegExp variations for case-sensitive and case-insensitive matching.\n */\ninterface RegexVariation {\n /** Case-sensitive regex */\n sensitive: RegExp;\n /** Case-insensitive regex */\n insensitive: RegExp;\n}\n\n/**\n * All precompiled regex variations for test() and partialTest().\n * Eliminates RegExp creation on every call (major performance win).\n */\ninterface RegexCache {\n /** For test() with strictTrailingSlash: false (default) */\n test: RegexVariation;\n /** For test() with strictTrailingSlash: true */\n testStrict: RegexVariation;\n /** For partialTest() with delimited: false */\n partial: RegexVariation;\n /** For partialTest() with delimited: true (default) */\n partialDelimited: RegexVariation;\n}\n\n// =============================================================================\n// Module-Private Helper Functions\n// =============================================================================\n\n/**\n * Checks if a value is defined (not null or undefined).\n */\nconst isDefined = (val: unknown): boolean => val !== undefined && val !== null;\n\n/**\n * Type guard to check if a value is a primitive parameter value.\n */\nconst isParamValue = (val: unknown): val is ParamValue =>\n typeof val === \"string\" ||\n typeof val === \"number\" ||\n typeof val === \"boolean\";\n\n/**\n * Type guard to check if a value is encodable (primitive or array of primitives).\n * Filters out null, undefined, and invalid types.\n */\nconst isEncodableParam = (val: unknown): val is ParamValue | ParamValue[] => {\n if (!isDefined(val)) {\n return false;\n }\n\n if (isParamValue(val)) {\n return true;\n }\n\n if (Array.isArray(val)) {\n return val.every((v) => isParamValue(v));\n }\n\n return false;\n};\n\n/**\n * Modifies regex source to make trailing slash optional.\n * Used in test() for flexible URL matching.\n *\n * @param source - Regex source string\n * @returns Modified regex source with optional trailing slash\n */\nconst optTrailingSlash = (source: string) => {\n if (source === \"\\\\/\") {\n return source;\n }\n\n return source.replace(/\\\\\\/$/, \"\") + \"(?:\\\\/)?\";\n};\n\n/**\n * Appends delimiter pattern for partial URL matching.\n * Ensures partial matches stop at path boundaries.\n *\n * @param source - Regex source string\n * @returns Modified regex source with delimiter boundary\n */\nconst upToDelimiter = (source: string) => {\n return /(\\/)$/.test(source)\n ? source\n : source + PARTIAL_TEST_PATTERNS.delimiter;\n};\n\n/**\n * Appends a query parameter value to the params object.\n * If param already exists (e.g., from URL param), combines into array.\n *\n * Note: The search-params library already combines duplicate query params,\n * so this is only called once per param key. The array accumulation handles\n * the case where URL param and query param share the same name.\n *\n * @param params - Target params object (mutated)\n * @param param - Parameter name\n * @param val - Parameter value to append\n * @returns The mutated params object\n */\nconst appendQueryParam = (\n params: Record<string, unknown>,\n param: string,\n val: unknown = \"\",\n): Record<string, unknown> => {\n const existingVal = params[param];\n\n // Existing value from URL param - combine with query param value\n params[param] = existingVal === undefined ? val : [existingVal, val];\n\n return params;\n};\n\n// =============================================================================\n// Path Class\n// =============================================================================\n\n/**\n * URL Path parser, matcher, and builder.\n *\n * Supports URL parameters (`:id`), splat parameters (`*path`),\n * matrix parameters (`;section`), query parameters (`?page`),\n * and parameter constraints (`:id<\\\\d+>`).\n *\n * @template T - Type of extracted/provided parameters object\n *\n * @example\n * ```typescript\n * const path = new Path('/users/:id/posts/:postId');\n *\n * // Match URL and extract params\n * path.test('/users/123/posts/456');\n * // => { id: '123', postId: '456' }\n *\n * // Build URL from params\n * path.build({ id: '123', postId: '456' });\n * // => '/users/123/posts/456'\n * ```\n */\nexport class Path<T extends Record<string, unknown> = Record<string, unknown>> {\n /** Original path pattern string */\n path: string;\n\n /** Parsed tokens from the path pattern */\n tokens: Token[];\n\n /** True if pattern contains any URL parameters (:param, *splat, ;matrix) */\n hasUrlParams: boolean;\n\n /** True if pattern contains a splat parameter (*path) */\n hasSpatParam: boolean;\n\n /** True if pattern contains matrix parameters (;param) */\n hasMatrixParams: boolean;\n\n /** True if pattern contains query parameters (?param) */\n hasQueryParams: boolean;\n\n /** Merged options with defaults */\n options: InternalPathOptions;\n\n /** Names of splat parameters in the pattern */\n spatParams: string[];\n\n /** Names of all URL parameters (including splat and matrix) */\n urlParams: string[];\n\n /** Names of query parameters in the pattern */\n queryParams: string[];\n\n /** Names of all parameters (URL + query) */\n params: string[];\n\n /** Compiled regex source for URL matching */\n source: string;\n\n /**\n * Precompiled regex cache for test() and partialTest().\n * Eliminates RegExp creation overhead in hot paths.\n */\n private readonly regexCache: RegexCache;\n\n /**\n * Precompiled constraint patterns for build() validation.\n * Maps parameter name to { pattern: RegExp, constraint: original constraint string }.\n */\n private readonly constraintPatterns: Map<\n string,\n { pattern: RegExp; constraint: string }\n >;\n\n /**\n * Cached options for build() when no overrides are provided.\n * Eliminates object creation overhead in hot paths.\n */\n private readonly buildOptionsCache: {\n readonly ignoreConstraints: false;\n readonly ignoreSearch: false;\n readonly queryParams: Options;\n readonly urlParamsEncoding: URLParamsEncodingType;\n };\n\n // ===========================================================================\n // R4 Optimization: Pre-compiled Build Pattern\n // ===========================================================================\n\n /**\n * Pre-compiled pattern for fast path building.\n * Used by buildFromPattern() for O(n) path construction without token iteration.\n */\n private readonly compiledBuildPattern: CompiledPathPattern;\n\n /**\n * Creates a new Path instance.\n *\n * @param path - Path pattern to parse (e.g., '/users/:id?page')\n * @param options - Optional configuration for encoding and query params\n * @throws Error if path is empty\n *\n * @example\n * ```typescript\n * // Simple path with URL param\n * new Path('/users/:id');\n *\n * // With constraint\n * new Path('/users/:id<\\\\d+>');\n *\n * // With query params\n * new Path('/users/:id?page&limit');\n *\n * // With encoding options\n * new Path('/users/:id', { urlParamsEncoding: 'uriComponent' });\n * ```\n */\n constructor(path: string, options?: PathOptions) {\n if (!path) {\n throw new Error(\"Missing path in Path constructor\");\n }\n\n this.path = path;\n this.options = {\n ...DEFAULT_PATH_OPTIONS,\n ...options,\n };\n this.tokens = tokenise(path);\n\n this.hasUrlParams = this.tokens.some((t) =>\n t.type.startsWith(\"url-parameter\"),\n );\n this.hasSpatParam = this.tokens.some((t) => t.type.endsWith(\"splat\"));\n this.hasMatrixParams = this.tokens.some((t) => t.type.endsWith(\"matrix\"));\n this.hasQueryParams = this.tokens.some((t) =>\n t.type.startsWith(\"query-parameter\"),\n );\n\n // Extract named parameters from tokens\n this.spatParams = this.getParams(\"url-parameter-splat\");\n this.urlParams = this.getParams(/^url-parameter/);\n // Query params\n this.queryParams = this.getParams(\"query-parameter\");\n // All params\n this.params = [...this.urlParams, ...this.queryParams];\n\n // Regular expressions for url part only (full and partial match)\n let source = \"\";\n\n for (const t of this.tokens) {\n if (t.regex !== undefined) {\n source += t.regex.source;\n }\n }\n\n this.source = source;\n\n // Precompile all regex variations\n // Eliminates RegExp creation on every test()/partialTest() call\n const testSource = optTrailingSlash(source);\n const testStrictSource = source;\n const partialSource = source;\n const partialDelimitedSource = upToDelimiter(source);\n\n const testSuffix = this.hasQueryParams\n ? TEST_PATTERNS.withQueryParams\n : TEST_PATTERNS.withoutQueryParams;\n\n this.regexCache = {\n test: {\n sensitive: new RegExp(\"^\" + testSource + testSuffix),\n insensitive: new RegExp(\"^\" + testSource + testSuffix, \"i\"),\n },\n testStrict: {\n sensitive: new RegExp(\"^\" + testStrictSource + testSuffix),\n insensitive: new RegExp(\"^\" + testStrictSource + testSuffix, \"i\"),\n },\n partial: {\n sensitive: new RegExp(\"^\" + partialSource),\n insensitive: new RegExp(\"^\" + partialSource, \"i\"),\n },\n partialDelimited: {\n sensitive: new RegExp(\"^\" + partialDelimitedSource),\n insensitive: new RegExp(\"^\" + partialDelimitedSource, \"i\"),\n },\n };\n\n // Precompile constraint patterns for build() validation\n this.constraintPatterns = new Map();\n const constrainedTokens = this.tokens.filter(\n (t) => t.type.startsWith(\"url-parameter\") && !t.type.endsWith(\"-splat\"),\n );\n\n for (const t of constrainedTokens) {\n const paramName = t.val[0];\n const constraintStr = t.otherVal[0]; // e.g., \"<\\\\d+>\" or \"\"\n const pattern = new RegExp(\n \"^\" + defaultOrConstrained(constraintStr) + \"$\",\n );\n\n this.constraintPatterns.set(paramName, {\n pattern,\n constraint: constraintStr,\n });\n }\n\n // Pre-compute build options cache to avoid object creation in build()\n this.buildOptionsCache = {\n ignoreConstraints: false,\n ignoreSearch: false,\n queryParams: this.options.queryParams ?? {},\n urlParamsEncoding: this.options.urlParamsEncoding,\n };\n\n // R4 Optimization: Pre-compile build pattern for fast path construction\n // Filter out query parameters at parse time\n const buildTokens = this.tokens.filter(\n (t) => !t.type.startsWith(\"query-parameter\"),\n );\n\n // Pre-compute static parts and param names for interleaved building\n const staticParts: string[] = [];\n const paramNames: string[] = [];\n let currentStatic = \"\";\n\n for (const t of buildTokens) {\n if (\n t.type.startsWith(\"url-parameter\") &&\n t.type !== \"url-parameter-matrix\"\n ) {\n // Save accumulated static, then add param\n staticParts.push(currentStatic);\n currentStatic = \"\";\n paramNames.push(t.val[0]);\n } else if (t.type === \"url-parameter-matrix\") {\n // Matrix params need special handling - accumulate prefix\n currentStatic += \";\" + t.val[0] + \"=\";\n staticParts.push(currentStatic);\n currentStatic = \"\";\n paramNames.push(t.val[0]);\n } else {\n // Static content (delimiter, fragment, sub-delimiter)\n currentStatic += t.match;\n }\n }\n\n // Add trailing static (may be empty)\n staticParts.push(currentStatic);\n\n this.compiledBuildPattern = {\n staticParts,\n paramNames,\n pattern: path,\n };\n }\n\n /**\n * Factory method to create a Path instance.\n * Alternative to using `new Path()` directly.\n *\n * @param path - Path pattern to parse\n * @param options - Optional configuration\n * @returns New Path instance\n */\n static createPath<\n T extends Record<string, unknown> = Record<string, unknown>,\n >(path: string, options?: PathOptions): Path<T> {\n return new Path<T>(path, options);\n }\n\n /**\n * Checks if a parameter name is a query parameter.\n *\n * @param name - Parameter name to check\n * @returns True if the parameter is defined in query string\n */\n isQueryParam(name: string): boolean {\n return this.queryParams.includes(name);\n }\n\n /**\n * Checks if a parameter name is a splat parameter.\n *\n * @param name - Parameter name to check\n * @returns True if the parameter is a splat (*path)\n */\n isSpatParam(name: string): boolean {\n return this.spatParams.includes(name);\n }\n\n /**\n * Tests if a URL exactly matches this path pattern.\n * Extracts parameter values from matching URLs.\n *\n * This is the HOT PATH for leaf node matching in route trees.\n *\n * @param path - URL to test against the pattern\n * @param opts - Test options (case sensitivity, trailing slash handling)\n * @returns Extracted parameters object, or null if no match\n *\n * @example\n * ```typescript\n * const pattern = new Path('/users/:id');\n *\n * pattern.test('/users/123');\n * // => { id: '123' }\n *\n * pattern.test('/users/123/posts');\n * // => null (not exact match)\n *\n * pattern.test('/USERS/123');\n * // => { id: '123' } (case insensitive by default)\n *\n * pattern.test('/USERS/123', { caseSensitive: true });\n * // => null\n * ```\n */\n test(path: string, opts?: PathTestOptions): TestMatch<T> {\n // Direct property access avoids object spread overhead\n const caseSensitive = opts?.caseSensitive ?? false;\n const strictTrailingSlash = opts?.strictTrailingSlash ?? false;\n\n // Use precompiled regex instead of creating on every call\n const regexVariation = strictTrailingSlash\n ? this.regexCache.testStrict\n : this.regexCache.test;\n const regex = caseSensitive\n ? regexVariation.sensitive\n : regexVariation.insensitive;\n\n const match = this.urlTestWithRegex(\n path,\n regex,\n opts?.urlParamsEncoding ?? this.options.urlParamsEncoding,\n );\n\n // If no match, or no query params, no need to go further\n if (!match || !this.hasQueryParams) {\n return match;\n }\n\n // Extract query params\n const queryParams = parseQueryParams(\n path,\n opts?.queryParams ?? this.options.queryParams,\n );\n\n // Single pass: check for unexpected params AND copy in one loop\n // Avoids Object.keys() allocation and double iteration\n let hasUnexpected = false;\n\n for (const p in queryParams) {\n if (this.isQueryParam(p)) {\n (match as Record<string, unknown>)[p] = queryParams[p];\n } else {\n hasUnexpected = true;\n }\n }\n\n return hasUnexpected ? null : match;\n }\n\n /**\n * Tests if a URL starts with this path pattern.\n * Used for matching branch nodes in route trees.\n *\n * This is the HOT PATH for branch node matching in route trees.\n *\n * @param path - URL to test against the pattern\n * @param opts - Test options (case sensitivity, delimiter handling)\n * @returns Extracted parameters object, or null if no match\n *\n * @example\n * ```typescript\n * const pattern = new Path('/users/:id');\n *\n * pattern.partialTest('/users/123/posts/456');\n * // => { id: '123' } (matches prefix)\n *\n * pattern.partialTest('/users/123');\n * // => { id: '123' }\n *\n * pattern.partialTest('/posts/123');\n * // => null\n * ```\n */\n partialTest(path: string, opts?: PathPartialTestOptions): TestMatch<T> {\n // Direct property access avoids object spread overhead\n const caseSensitive = opts?.caseSensitive ?? false;\n const delimited = opts?.delimited ?? true;\n\n // Use precompiled regex instead of creating on every call\n const regexVariation = delimited\n ? this.regexCache.partialDelimited\n : this.regexCache.partial;\n const regex = caseSensitive\n ? regexVariation.sensitive\n : regexVariation.insensitive;\n\n const match = this.urlTestWithRegex(\n path,\n regex,\n opts?.urlParamsEncoding ?? this.options.urlParamsEncoding,\n );\n\n if (!match) {\n return match;\n }\n\n if (!this.hasQueryParams) {\n return match;\n }\n\n const queryParams = parseQueryParams(\n path,\n opts?.queryParams ?? this.options.queryParams,\n );\n\n // for-in is faster than Object.keys() iteration\n for (const p in queryParams) {\n if (this.isQueryParam(p)) {\n appendQueryParam(match as Record<string, unknown>, p, queryParams[p]);\n }\n }\n\n return match;\n }\n\n /**\n * Builds a URL from parameter values.\n * Encodes parameters and validates constraints.\n *\n * @param params - Parameter values to substitute into the pattern\n * @param opts - Build options (constraint validation, query string handling)\n * @returns Constructed URL string\n * @throws Error if required parameters are missing\n * @throws Error if parameters violate constraints (unless ignoreConstraints)\n *\n * @example\n * ```typescript\n * const pattern = new Path('/users/:id/posts/:postId?page');\n *\n * pattern.build({ id: '123', postId: '456' });\n * // => '/users/123/posts/456'\n *\n * pattern.build({ id: '123', postId: '456', page: '1' });\n * // => '/users/123/posts/456?page=1'\n *\n * pattern.build({ id: '123' });\n * // => Error: requires missing parameters { postId }\n * ```\n */\n build(params: T = {} as T, opts?: PathBuildOptions): string {\n // Use cached options when no overrides, avoiding object creation\n const options = opts\n ? {\n ignoreConstraints: opts.ignoreConstraints ?? false,\n ignoreSearch: opts.ignoreSearch ?? false,\n queryParams: opts.queryParams ?? this.buildOptionsCache.queryParams,\n urlParamsEncoding:\n opts.urlParamsEncoding ?? this.buildOptionsCache.urlParamsEncoding,\n }\n : this.buildOptionsCache;\n\n const encodedUrlParams = this.encodeUrlParams(\n params,\n options.urlParamsEncoding,\n );\n\n this.validateRequiredParams(params);\n\n if (!options.ignoreConstraints) {\n this.validateConstraints(encodedUrlParams);\n }\n\n const base = this.buildBasePath(encodedUrlParams);\n\n if (options.ignoreSearch) {\n return base;\n }\n\n return this.buildWithSearch(base, params, options.queryParams);\n }\n\n // ===========================================================================\n // Private Methods - Encoding\n // ===========================================================================\n\n /**\n * Encodes all URL parameters from the input params object.\n * Skips query parameters (handled separately by search-params).\n *\n * @param params - Raw parameter values\n * @param encoding - Encoding strategy to use\n * @returns Object with encoded parameter values\n */\n private encodeUrlParams(\n params: T,\n encoding: URLParamsEncodingType,\n ): Record<string, unknown> {\n const encoded: Record<string, unknown> = {};\n\n for (const key of Object.keys(params)) {\n if (this.isQueryParam(key)) {\n continue;\n }\n\n const val = params[key];\n\n if (!isEncodableParam(val)) {\n continue;\n }\n\n encoded[key] = this.encodeParamValue(val, key, encoding);\n }\n\n return encoded;\n }\n\n /**\n * Encodes a single parameter value.\n * Handles booleans, arrays, and primitive values.\n *\n * @param val - Value to encode (already validated by isEncodableParam)\n * @param key - Parameter name (to check if splat)\n * @param encoding - Encoding strategy to use\n * @returns Encoded value (string, boolean, or array)\n */\n private encodeParamValue(\n val: ParamValue | ParamValue[],\n key: string,\n encoding: URLParamsEncodingType,\n ): unknown {\n if (typeof val === \"boolean\") {\n return val;\n }\n\n const isSpatParam = this.isSpatParam(key);\n\n if (Array.isArray(val)) {\n return val.map((v) => encodeParam(v, encoding, isSpatParam));\n }\n\n return encodeParam(val, encoding, isSpatParam);\n }\n\n // ===========================================================================\n // Private Methods - Validation\n // ===========================================================================\n\n /**\n * Validates that all required URL parameters are present.\n *\n * @param params - Parameters to validate\n * @throws Error listing missing required parameters\n */\n private validateRequiredParams(params: T): void {\n const missingParameters = this.urlParams.filter(\n (p) => !isDefined(params[p]),\n );\n\n if (missingParameters.length > 0) {\n throw new Error(\n \"Cannot build path: '\" +\n this.path +\n \"' requires missing parameters { \" +\n missingParameters.join(\", \") +\n \" }\",\n );\n }\n }\n\n /**\n * Validates that encoded parameter values match their constraints.\n * Uses precompiled constraint patterns.\n *\n * @param encodedUrlParams - Already encoded parameter values\n * @throws Error if any parameter violates its constraint\n */\n private validateConstraints(encodedUrlParams: Record<string, unknown>): void {\n // Use precompiled constraint patterns\n for (const [paramName, { pattern, constraint }] of this\n .constraintPatterns) {\n const value = String(encodedUrlParams[paramName]);\n\n if (!pattern.test(value)) {\n // Extract constraint pattern without angle brackets for cleaner message\n // If no explicit constraint, show the default pattern description\n const constraintPattern = constraint\n ? constraint.replaceAll(/(^<)|(>$)/g, \"\")\n : \"[^/]+\";\n\n throw new Error(\n `Parameter '${paramName}' of '${this.path}' has invalid format: ` +\n `got '${value}', expected to match '${constraintPattern}'`,\n );\n }\n }\n }\n\n // ===========================================================================\n // Private Methods - URL Building\n // ===========================================================================\n\n /**\n * Builds the base URL path (without query string).\n * Uses buildFromPattern with pre-compiled pattern for O(n) construction.\n * R4 Optimization: 3x faster than token iteration.\n *\n * @param encodedUrlParams - Encoded parameter values\n * @returns Built URL path string\n */\n private buildBasePath(encodedUrlParams: Record<string, unknown>): string {\n return buildFromPattern(this.compiledBuildPattern, encodedUrlParams);\n }\n\n /**\n * Appends query string to the base path.\n * Uses search-params library for query string formatting.\n *\n * @param base - Base URL path\n * @param params - All parameters (filters to query params only)\n * @param queryParamsOptions - Formatting options for search-params\n * @returns Complete URL with query string (if any)\n */\n private buildWithSearch(\n base: string,\n params: T,\n queryParamsOptions: Options | undefined,\n ): string {\n const searchParams: Record<string, unknown> = {};\n\n // 'in' operator is O(1) vs Object.keys().includes() which is O(nÂē)\n for (const paramName of this.queryParams) {\n if (paramName in params) {\n searchParams[paramName] = params[paramName];\n }\n }\n\n const searchPart = buildQueryParams(searchParams, queryParamsOptions);\n\n return searchPart ? base + \"?\" + searchPart : base;\n }\n\n // ===========================================================================\n // Private Methods - Utilities\n // ===========================================================================\n\n /**\n * Extracts parameter names from tokens by type.\n * Single pass instead of filter + map.\n *\n * @param type - Token type to filter (string for exact match, RegExp for pattern)\n * @returns Array of parameter names\n */\n private getParams(type: string | RegExp): string[] {\n const result: string[] = [];\n const isRegex = type instanceof RegExp;\n\n for (const t of this.tokens) {\n if (isRegex ? type.test(t.type) : t.type === type) {\n result.push(t.val[0]);\n }\n }\n\n return result;\n }\n\n /**\n * Core regex matching logic for test() and partialTest().\n * Uses precompiled regex and extracts parameter values.\n *\n * @param path - URL to test\n * @param regex - Precompiled RegExp to use for matching\n * @param urlParamsEncoding - Decoding strategy for extracted values\n * @returns Extracted parameters object, or null if no match\n */\n private urlTestWithRegex(\n path: string,\n regex: RegExp,\n urlParamsEncoding: URLParamsEncodingType,\n ): TestMatch<T> {\n const match = regex.exec(path);\n\n if (!match) {\n return null;\n }\n\n if (this.urlParams.length === 0) {\n return {} as T;\n }\n\n // Reduce named params to key-value pairs\n const result: Record<string, unknown> = {};\n\n for (let i = 0; i < this.urlParams.length; i++) {\n result[this.urlParams[i]] = decodeParam(match[i + 1], urlParamsEncoding);\n }\n\n return result as T;\n }\n}\n","// packages/route-node/modules/parser/defaultParserFactory.ts\n\n/**\n * Default path parser factory using path-parser library.\n *\n * @module defaultParserFactory\n */\n\nimport { Path } from \"./path-parser\";\n\nimport type { PathParser } from \"../types\";\n\n/**\n * Factory interface for creating PathParser instances.\n */\nexport interface PathParserFactory {\n create: (path: string) => PathParser;\n}\n\n/**\n * Creates a PathParser instance.\n *\n * The Path class directly implements the PathParser interface,\n * eliminating wrapper overhead for better performance.\n *\n * @param path - The path pattern to parse\n * @returns PathParser instance\n */\nfunction createPathParser(path: string): PathParser {\n return new Path(path);\n}\n\n/**\n * Default factory that creates PathParser instances.\n *\n * This factory wraps the path-parser library's Path class, providing\n * the standard implementation used by RouteNode.\n *\n * @example\n * ```typescript\n * import { defaultParserFactory } from \"route-tree\";\n *\n * const parser = defaultParserFactory.create(\"/users/:id\");\n * parser.test(\"/users/123\"); // { id: \"123\" }\n * ```\n */\nexport const defaultParserFactory: PathParserFactory = {\n create: createPathParser,\n};\n","// packages/route-node/modules/builder/buildTree.ts\n\n/**\n * Tree Building.\n *\n * Constructs the mutable tree structure from route definitions.\n *\n * @module builder/buildTree\n */\n\nimport { defaultParserFactory } from \"../parser/defaultParserFactory\";\n\nimport type { PathParser, RouteDefinition } from \"../types\";\n\n// =============================================================================\n// Mutable Node Type (internal)\n// =============================================================================\n\n/**\n * Mutable version of RouteTree used during building.\n * After building, this is converted to immutable RouteTree.\n */\nexport interface MutableRouteNode {\n name: string;\n path: string;\n absolute: boolean;\n parser: PathParser | null;\n children: MutableRouteNode[];\n parent: MutableRouteNode | null;\n\n // These are computed later by computeCaches\n nonAbsoluteChildren: MutableRouteNode[];\n absoluteDescendants: MutableRouteNode[];\n childrenByName: Map<string, MutableRouteNode>;\n parentSegments: MutableRouteNode[];\n fullName: string;\n staticChildrenByFirstSegment: Map<string, MutableRouteNode[]>;\n}\n\n// =============================================================================\n// Building Functions\n// =============================================================================\n\n/**\n * Creates a mutable node from a route definition.\n *\n * @param definition - Route definition object\n * @param definition.name - Route name\n * @param definition.path - Route path\n * @param definition.children - Optional child routes\n * @param parent - Parent node (null for root)\n * @returns Mutable node\n */\nfunction createNode(\n definition: {\n name: string;\n path: string;\n children?: RouteDefinition[] | undefined;\n },\n parent: MutableRouteNode | null,\n): MutableRouteNode {\n const path = definition.path;\n const absolute = path.startsWith(\"~\");\n const normalizedPath = absolute ? path.slice(1) : path;\n\n const node: MutableRouteNode = {\n name: definition.name,\n path: normalizedPath,\n absolute,\n parser: normalizedPath ? defaultParserFactory.create(normalizedPath) : null,\n children: [],\n parent,\n // These will be computed by computeCaches\n nonAbsoluteChildren: [],\n absoluteDescendants: [],\n childrenByName: new Map(),\n parentSegments: [],\n fullName: \"\",\n staticChildrenByFirstSegment: new Map(),\n };\n\n // Recursively add children\n if (definition.children) {\n for (const childDef of definition.children) {\n const childNode = createNode(childDef, node);\n\n node.children.push(childNode);\n }\n }\n\n return node;\n}\n\n/**\n * Resolves parent node for dot-notation names.\n *\n * For example, \"users.profile\" needs to find the \"users\" node first.\n *\n * @param root - Root node\n * @param name - Route name (possibly with dots)\n * @returns Parent node and final name segment\n */\nfunction resolveParent(\n root: MutableRouteNode,\n name: string,\n): { parent: MutableRouteNode; finalName: string } {\n const parts = name.split(\".\");\n\n if (parts.length === 1) {\n return { parent: root, finalName: name };\n }\n\n // Navigate to parent\n let current = root;\n\n for (let i = 0; i < parts.length - 1; i++) {\n const partName = parts[i];\n\n // validateRoutes ensures parent exists before building\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n current = current.children.find((c) => c.name === partName)!;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return { parent: current, finalName: parts.at(-1)! };\n}\n\n/**\n * Builds the mutable tree structure from route definitions.\n *\n * Handles:\n * - Creating root node\n * - Processing flat and nested routes\n * - Dot-notation names (e.g., \"users.profile\")\n *\n * @param rootName - Root node name (typically \"\")\n * @param rootPath - Root node path (typically \"\")\n * @param routes - Route definitions\n * @returns Mutable root node\n */\nexport function buildTree(\n rootName: string,\n rootPath: string,\n routes: readonly RouteDefinition[],\n): MutableRouteNode {\n // Create root node\n const root = createNode({ name: rootName, path: rootPath }, null);\n\n // First pass: add routes with nested children\n const flatRoutes: RouteDefinition[] = [];\n\n for (const route of routes) {\n if (route.name.includes(\".\")) {\n // Dot-notation name - process later\n flatRoutes.push(route);\n } else if (route.children && route.children.length > 0) {\n // Has children - add directly\n const node = createNode(route, root);\n\n root.children.push(node);\n } else {\n // Simple route without children\n flatRoutes.push(route);\n }\n }\n\n // Second pass: add flat routes and dot-notation names\n for (const route of flatRoutes) {\n const { parent, finalName } = resolveParent(root, route.name);\n\n const node = createNode(\n { name: finalName, path: route.path, children: route.children },\n parent,\n );\n\n parent.children.push(node);\n }\n\n return root;\n}\n","// packages/route-node/modules/builder/computeCaches.ts\n\n/**\n * Cache Computation.\n *\n * Computes all pre-computed caches and freezes the tree.\n *\n * @module builder/computeCaches\n */\n\nimport type { MutableRouteNode } from \"./buildTree\";\nimport type { RouteTree } from \"../types\";\n\n// =============================================================================\n// Constants\n// =============================================================================\n\n/** Shared empty map for nodes with no static children (avoids allocation) */\nconst EMPTY_STATIC_INDEX: ReadonlyMap<string, readonly RouteTree[]> = new Map();\n\n// =============================================================================\n// Static Children Index\n// =============================================================================\n\n/**\n * Extracts the first static segment from a path pattern.\n *\n * Returns null for dynamic-only paths (starting with :param or *splat).\n *\n * @example\n * extractFirstStaticSegment(\"/users\") â \"users\"\n * extractFirstStaticSegment(\"/users/:id\") â \"users\"\n * extractFirstStaticSegment(\"/users?tab\") â \"users\"\n * extractFirstStaticSegment(\"/:id\") â null (dynamic)\n * extractFirstStaticSegment(\"*\") â null (splat)\n * extractFirstStaticSegment(\"/\") â null (root slash)\n *\n * @param path - Path pattern (without ~ prefix)\n * @returns First static segment or null if dynamic\n */\nfunction extractFirstStaticSegment(path: string): string | null {\n // Skip leading slash\n const start = path.startsWith(\"/\") ? 1 : 0;\n\n // Find end of first segment: next \"/\" or \"?\" (whichever comes first)\n let end = path.indexOf(\"/\", start);\n const queryPos = path.indexOf(\"?\", start);\n\n if (queryPos !== -1 && (end === -1 || queryPos < end)) {\n end = queryPos;\n }\n\n const segment = end === -1 ? path.slice(start) : path.slice(start, end);\n\n // Dynamic segments start with : or *, empty segment means root \"/\"\n if (\n segment === \"\" ||\n segment.startsWith(\":\") ||\n segment.startsWith(\"*\") ||\n segment.includes(\"(\") // optional segment like (locale)\n ) {\n return null;\n }\n\n // Normalize to lowercase for case-insensitive index lookup\n return segment.toLowerCase();\n}\n\n/**\n * Computes static children index for O(1) matching.\n *\n * Groups non-absolute children by their first static path segment.\n * Routes with dynamic first segments are not indexed (matched via linear search).\n *\n * @param children - Non-absolute children to index\n * @param freeze - Whether to freeze the result\n * @returns Map of first segment â routes\n */\nfunction computeStaticChildrenIndex(\n children: readonly RouteTree[],\n freeze: boolean,\n): ReadonlyMap<string, readonly RouteTree[]> {\n if (children.length === 0) {\n return EMPTY_STATIC_INDEX;\n }\n\n const index = new Map<string, RouteTree[]>();\n\n for (const child of children) {\n const segment = extractFirstStaticSegment(child.path);\n\n if (segment !== null) {\n const existing = index.get(segment);\n\n if (existing) {\n existing.push(child);\n } else {\n index.set(segment, [child]);\n }\n }\n }\n\n // No static children found\n if (index.size === 0) {\n return EMPTY_STATIC_INDEX;\n }\n\n // Freeze arrays for immutability\n // Cast needed: Object.freeze returns readonly[], but we return ReadonlyMap anyway\n if (freeze) {\n for (const [key, arr] of index) {\n index.set(key, Object.freeze(arr) as RouteTree[]);\n }\n }\n\n return index;\n}\n\n// =============================================================================\n// Cache Computation Functions\n// =============================================================================\n\n/**\n * Recursively collects all descendants with absolute paths.\n *\n * @param node - Node to collect from\n * @param result - Array to collect into\n */\nfunction collectAbsoluteDescendants(\n node: RouteTree,\n result: RouteTree[],\n): void {\n for (const child of node.children) {\n if (child.absolute) {\n result.push(child);\n }\n\n collectAbsoluteDescendants(child, result);\n }\n}\n\n/**\n * Computes all absolute descendants recursively.\n *\n * @param node - Node to start from\n * @returns Array of all absolute descendants\n */\nfunction computeAbsoluteDescendants(node: RouteTree): readonly RouteTree[] {\n const result: RouteTree[] = [];\n\n collectAbsoluteDescendants(node, result);\n\n return result;\n}\n\n/**\n * Computes parent segments from root to this node's parent.\n *\n * @param node - Node to compute for\n * @returns Array of parent segments\n */\nfunction computeParentSegments(node: RouteTree): readonly RouteTree[] {\n const segments: RouteTree[] = [];\n let current = node.parent;\n\n while (current?.parser) {\n segments.push(current);\n current = current.parent;\n }\n\n // Reverse to get root -> parent order\n segments.reverse();\n\n return segments;\n}\n\n/**\n * Computes the full dot-notation name for a node.\n * Parent fullName is always computed before children.\n *\n * @param node - Node to compute for\n * @returns Full name (e.g., \"users.profile\")\n */\nfunction computeFullName(node: RouteTree): string {\n if (!node.parent?.name) {\n return node.name;\n }\n\n // Parent fullName is always set before children are processed\n return `${node.parent.fullName}.${node.name}`;\n}\n\n/**\n * Computes static path for routes without parameters.\n *\n * Returns pre-built path string for fast buildPath lookup,\n * or null if the route has any dynamic parameters.\n *\n * @param node - Node to compute for\n * @returns Static path or null\n */\nfunction computeStaticPath(node: RouteTree): string | null {\n const parser = node.parser;\n\n if (!parser) {\n return null;\n }\n\n // If route has any parameters, we can't pre-compute\n if (parser.hasUrlParams || parser.hasQueryParams || parser.hasSpatParam) {\n return null;\n }\n\n // Build the full path from parent segments + this segment\n // Note: parentSegments only contains nodes with parsers (see computeParentSegments)\n let path = \"\";\n\n for (const segment of node.parentSegments) {\n // parentSegments only contains nodes with parsers (see computeParentSegments)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- by design\n const segmentParser = segment.parser!;\n\n // Parent segments with params invalidate static path\n if (\n segmentParser.hasUrlParams ||\n segmentParser.hasQueryParams ||\n segmentParser.hasSpatParam\n ) {\n return null;\n }\n\n path = segment.absolute ? segment.path : path + segment.path;\n }\n\n // Add this node's path\n path = node.absolute ? node.path : path + node.path;\n\n // Normalize double slashes - always apply regex (avoids equivalent mutants)\n return path.replaceAll(/\\/{2,}/g, \"/\");\n}\n\n// =============================================================================\n// Main Computation Function\n// =============================================================================\n\n/**\n * Recursively processes a mutable node into a RouteTree.\n *\n * This creates a new object with all caches computed.\n * Optionally freezes the result for immutability.\n *\n * @param mutable - Mutable node to process\n * @param parent - Already-processed parent node (null for root)\n * @param freeze - Whether to freeze the result\n * @returns RouteTree (frozen if freeze=true)\n */\nfunction processNode(\n mutable: MutableRouteNode,\n parent: RouteTree | null,\n freeze: boolean,\n): RouteTree {\n // Create node object with pre-allocated arrays\n const node = {\n name: mutable.name,\n path: mutable.path,\n absolute: mutable.absolute,\n parser: mutable.parser,\n parent,\n children: [] as RouteTree[],\n nonAbsoluteChildren: [] as RouteTree[],\n absoluteDescendants: [] as RouteTree[],\n childrenByName: new Map<string, RouteTree>(),\n parentSegments: [] as RouteTree[],\n fullName: \"\",\n staticPath: null as string | null,\n paramTypeMap: {} as Record<string, \"url\" | \"query\">,\n staticChildrenByFirstSegment: EMPTY_STATIC_INDEX,\n };\n\n // Compute paramTypeMap from parser (cached to avoid recomputing on every navigation)\n if (mutable.parser) {\n for (const p of mutable.parser.urlParams) {\n node.paramTypeMap[p] = \"url\";\n }\n\n for (const p of mutable.parser.queryParams) {\n node.paramTypeMap[p] = \"query\";\n }\n }\n\n // Compute fullName first (needs parent)\n node.fullName = computeFullName(node as RouteTree);\n\n // Process children and build childrenByName in single pass\n for (const childMutable of mutable.children) {\n const child = processNode(childMutable, node as RouteTree, freeze);\n\n node.children.push(child);\n node.childrenByName.set(child.name, child);\n\n // Build nonAbsoluteChildren inline\n if (!child.absolute) {\n node.nonAbsoluteChildren.push(child);\n }\n }\n\n // Compute absoluteDescendants (recursive collection)\n node.absoluteDescendants = computeAbsoluteDescendants(\n node as RouteTree,\n ) as RouteTree[];\n\n // Compute parentSegments\n node.parentSegments = computeParentSegments(node as RouteTree) as RouteTree[];\n\n // Compute staticPath for fast buildPath lookup\n node.staticPath = computeStaticPath(node as RouteTree);\n\n // Compute static children index for O(1) matching\n node.staticChildrenByFirstSegment = computeStaticChildrenIndex(\n node.nonAbsoluteChildren,\n freeze,\n );\n\n // Freeze only if requested\n if (freeze) {\n Object.freeze(node.children);\n Object.freeze(node.nonAbsoluteChildren);\n Object.freeze(node.absoluteDescendants);\n Object.freeze(node.parentSegments);\n Object.freeze(node.paramTypeMap);\n Object.freeze(node);\n }\n\n return node as RouteTree;\n}\n\n/**\n * Computes all caches and optionally freezes the tree.\n *\n * This is the final step in building a RouteTree.\n * When freeze=true (default), the tree is completely immutable.\n *\n * @param mutableRoot - Mutable root node\n * @param freeze - Whether to freeze the result (default: true)\n * @returns RouteTree (frozen if freeze=true)\n */\nexport function computeCaches(\n mutableRoot: MutableRouteNode,\n freeze = true,\n): RouteTree {\n return processNode(mutableRoot, null, freeze);\n}\n","// packages/route-node/modules/builder/sortTree.ts\n\n/**\n * Tree Sorting.\n *\n * Sorts route children by routing priority.\n *\n * @module builder/sortTree\n */\n\nimport type { MutableRouteNode } from \"./buildTree\";\n\n// =============================================================================\n// Utility Functions\n// =============================================================================\n\n/**\n * Removes trailing slash from path, preserving root \"/\".\n */\nfunction removeTrailingSlash(path: string): string {\n return path.endsWith(\"/\") && path.length > 1 ? path.slice(0, -1) : path;\n}\n\n/**\n * Normalizes path for comparison by removing query params and trailing slash.\n * Also removes route parameters (e.g., `<id>`) for comparison purposes.\n */\nfunction normalizePath(path: string): string {\n // Remove route parameters (e.g., <id>, <userId>)\n // Note: Angle bracket syntax is for internal path representation,\n // not typically used directly in route definitions\n let withoutParams = \"\";\n let depth = 0;\n\n for (const char of path) {\n if (char === \"<\") {\n depth++;\n } else if (char === \">\") {\n depth--;\n } else if (depth === 0) {\n withoutParams += char;\n }\n }\n\n const withoutQuery = withoutParams.split(\"?\")[0];\n\n return removeTrailingSlash(withoutQuery);\n}\n\n// =============================================================================\n// Sorting Implementation\n// =============================================================================\n\n/**\n * Pre-computed data for sorting comparison.\n */\ninterface PrecomputedSortData {\n readonly normalizedPath: string;\n readonly segmentCount: number;\n readonly lastSegmentLength: number;\n readonly originalIndex: number;\n}\n\n/**\n * Sorts children by routing priority.\n *\n * Priority (highest to lowest):\n * 1. Routes with more path segments\n * 2. Routes without splat parameters\n * 3. Routes with fewer URL parameters\n * 4. Routes with longer last segment\n * 5. Original definition order (stable sort)\n *\n * @param children - Array to sort (MUTATED in place)\n */\nfunction sortChildren(children: MutableRouteNode[]): void {\n if (children.length <= 1) {\n return;\n }\n\n // Pre-compute all derived data O(n)\n const precomputed = new Map<MutableRouteNode, PrecomputedSortData>();\n\n for (const [i, child] of children.entries()) {\n const normalizedPath = normalizePath(child.path);\n const segments = normalizedPath.split(\"/\");\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const lastSegment = segments.at(-1)!;\n\n precomputed.set(child, {\n normalizedPath,\n segmentCount: segments.length - 1,\n lastSegmentLength: lastSegment.length,\n originalIndex: i,\n });\n }\n\n // Sort using pre-computed data O(n log n)\n children.sort((left, right) => {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const l = precomputed.get(left)!;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const r = precomputed.get(right)!;\n\n // \"/\" always sorts last\n if (l.normalizedPath === \"/\") {\n return 1;\n }\n if (r.normalizedPath === \"/\") {\n return -1;\n }\n\n // Splat params sort last\n // All children have parsers by design (only empty root lacks parser)\n /* eslint-disable @typescript-eslint/no-non-null-assertion */\n if (left.parser!.hasSpatParam) {\n return 1;\n }\n if (right.parser!.hasSpatParam) {\n return -1;\n }\n /* eslint-enable @typescript-eslint/no-non-null-assertion */\n\n // More segments = higher priority\n if (l.segmentCount < r.segmentCount) {\n return 1;\n }\n if (l.segmentCount > r.segmentCount) {\n return -1;\n }\n\n // Same segments: fewer URL params = higher priority\n // All children have parsers by design (only empty root lacks parser)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const leftParamsCount = left.parser!.urlParams.length;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const rightParamsCount = right.parser!.urlParams.length;\n\n if (leftParamsCount < rightParamsCount) {\n return -1;\n }\n if (leftParamsCount > rightParamsCount) {\n return 1;\n }\n\n // Same params: longer last segment = higher priority\n if (l.lastSegmentLength < r.lastSegmentLength) {\n return 1;\n }\n if (l.lastSegmentLength > r.lastSegmentLength) {\n return -1;\n }\n\n // Preserve definition order (stable sort fallback)\n return l.originalIndex - r.originalIndex;\n });\n}\n\n/**\n * Recursively sorts all children in the tree.\n *\n * @param node - Root node of the tree\n */\nexport function sortTree(node: MutableRouteNode): void {\n // Sort this node's children\n sortChildren(node.children);\n\n // Recursively sort descendants\n for (const child of node.children) {\n sortTree(child);\n }\n}\n","// packages/route-node/modules/builder/createRouteTree.ts\n\n/**\n * Route Tree Builder.\n *\n * Creates immutable RouteTree from route definitions.\n *\n * @module builder/createRouteTree\n */\n\nimport { buildTree } from \"./buildTree\";\nimport { computeCaches } from \"./computeCaches\";\nimport { sortTree } from \"./sortTree\";\n\nimport type {\n RouteDefinition,\n RouteTree,\n RouteTreeBuilder,\n TreeBuildOptions,\n} from \"../types\";\n\n// =============================================================================\n// Builder Implementation\n// =============================================================================\n\n/**\n * Creates a RouteTreeBuilder for constructing route trees.\n *\n * @param name - Root node name (typically empty string)\n * @param path - Root node path (typically empty string)\n * @returns RouteTreeBuilder instance\n *\n * @example\n * ```typescript\n * const tree = createRouteTreeBuilder(\"\", \"\")\n * .add({ name: \"users\", path: \"/users\" })\n * .add({ name: \"users.profile\", path: \"/:id\" })\n * .build();\n * ```\n */\nexport function createRouteTreeBuilder(\n name: string,\n path: string,\n): RouteTreeBuilder {\n const routes: RouteDefinition[] = [];\n\n return {\n add(route: RouteDefinition): RouteTreeBuilder {\n routes.push(route);\n\n return this;\n },\n\n addMany(newRoutes: readonly RouteDefinition[]): RouteTreeBuilder {\n routes.push(...newRoutes);\n\n return this;\n },\n\n build(options?: TreeBuildOptions): RouteTree {\n // Step 1: Build mutable tree structure\n const mutableTree = buildTree(name, path, routes);\n\n // Step 2: Sort all children (unless skipped)\n if (!options?.skipSort) {\n sortTree(mutableTree);\n }\n\n // Step 3: Compute all caches and optionally freeze\n const freeze = !options?.skipFreeze;\n\n return computeCaches(mutableTree, freeze);\n },\n };\n}\n\n// =============================================================================\n// Convenience Function\n// =============================================================================\n\n/**\n * Creates a RouteTree directly from route definitions.\n *\n * Convenience wrapper around createRouteTreeBuilder().\n *\n * @param name - Root node name (typically empty string)\n * @param path - Root node path (typically empty string)\n * @param routes - Route definitions to add\n * @param options - Build options (e.g., skipSort, skipFreeze)\n * @returns Immutable RouteTree\n *\n * @example\n * ```typescript\n * const tree = createRouteTree(\"\", \"\", [\n * { name: \"users\", path: \"/users\" },\n * { name: \"users.profile\", path: \"/:id\" },\n * ]);\n * ```\n */\nexport function createRouteTree(\n name: string,\n path: string,\n routes: readonly RouteDefinition[],\n options?: TreeBuildOptions,\n): RouteTree {\n return createRouteTreeBuilder(name, path).addMany(routes).build(options);\n}\n","// packages/route-node/modules/operations/match.ts\n\n/**\n * Path Matching Operations.\n *\n * Pure functions for matching URL paths against route trees.\n *\n * @module operations/match\n */\n\nimport { omit, parseInto } from \"search-params\";\n\nimport type {\n MatchOptions,\n MatchResult,\n PathParser,\n RouteParams,\n RouteTree,\n} from \"../types\";\nimport type { MatchConfig, MatchResponse } from \"./types\";\n\n// =============================================================================\n// Pre-compiled Patterns & Cached Objects\n// =============================================================================\n\nconst SLASH_CHILD_PATTERN = /^\\/(\\?|$)/;\nconst TRAILING_SLASH = /\\/$/;\nconst LEADING_SLASH_QUERY = /^\\/\\?/;\n\n/**\n * Extracts the first segment from a runtime URL path.\n *\n * @example\n * extractFirstPathSegment(\"/users/123\") â \"users\"\n * extractFirstPathSegment(\"users/123\") â \"users\"\n * extractFirstPathSegment(\"/users?tab=1\") â \"users\"\n * extractFirstPathSegment(\"/\") â \"\"\n *\n * @param path - Runtime path (e.g., \"/users/123\")\n * @returns First segment (without leading slash, query string stripped)\n */\nfunction extractFirstPathSegment(path: string): string {\n // Runtime paths always start with \"/\" (see calculateRemainingPath)\n // Find end of segment: next \"/\" or \"?\" (whichever comes first)\n let end = path.indexOf(\"/\", 1);\n const queryPos = path.indexOf(\"?\", 1);\n\n if (queryPos !== -1 && (end === -1 || queryPos < end)) {\n end = queryPos;\n }\n\n const segment = end === -1 ? path.slice(1) : path.slice(1, end);\n\n // Normalize to lowercase for case-insensitive index lookup\n return segment.toLowerCase();\n}\n\n/**\n * Checks if a route path has a dynamic first segment (starts with : or *).\n * Used to skip static routes during fallback matching.\n */\nfunction hasDynamicFirstSegment(path: string): boolean {\n const start = path.startsWith(\"/\") ? 1 : 0;\n const firstChar = path.charAt(start);\n\n return (\n firstChar === \":\" ||\n firstChar === \"*\" ||\n firstChar === \"\" ||\n path.charAt(start) === \"(\"\n );\n}\n\n// Pre-computed default options objects (avoid allocation on every match)\nconst DEFAULT_FULL_TEST_OPTIONS = {\n caseSensitive: false,\n strictTrailingSlash: false,\n};\nconst DEFAULT_FULL_TEST_OPTIONS_STRICT = {\n caseSensitive: false,\n strictTrailingSlash: true,\n};\nconst DEFAULT_FULL_TEST_OPTIONS_CASE_SENSITIVE = {\n caseSensitive: true,\n strictTrailingSlash: false,\n};\nconst DEFAULT_FULL_TEST_OPTIONS_CASE_SENSITIVE_STRICT = {\n caseSensitive: true,\n strictTrailingSlash: true,\n};\nconst DEFAULT_PARTIAL_TEST_OPTIONS = { caseSensitive: false, delimited: true };\nconst DEFAULT_PARTIAL_TEST_OPTIONS_CASE_SENSITIVE = {\n caseSensitive: true,\n delimited: true,\n};\nconst DEFAULT_PARTIAL_TEST_OPTIONS_WEAK = {\n caseSensitive: false,\n delimited: false,\n};\nconst DEFAULT_PARTIAL_TEST_OPTIONS_CASE_SENSITIVE_WEAK = {\n caseSensitive: true,\n delimited: false,\n};\nconst DEFAULT_BUILD_OPTIONS = { ignoreSearch: true };\n\n// Cached default config (used when no options provided)\nconst DEFAULT_CONFIG: MatchConfig = {\n queryParamsMode: \"default\",\n strictTrailingSlash: false,\n strongMatching: true,\n caseSensitive: false,\n queryParams: undefined,\n urlParamsEncoding: undefined,\n fullTestOptions: DEFAULT_FULL_TEST_OPTIONS,\n partialTestOptions: DEFAULT_PARTIAL_TEST_OPTIONS,\n buildOptions: DEFAULT_BUILD_OPTIONS,\n};\n\n// =============================================================================\n// Public API\n// =============================================================================\n\n/**\n * Matches a URL path and returns raw segments.\n *\n * Returns raw segments and params without building the state name.\n * Use this when you need to build the state yourself (e.g., in real-router).\n *\n * @param tree - Route tree to match against\n * @param path - URL path to match\n * @param options - Matching options\n * @returns Match result with segments and params, or null if no match\n */\nexport function matchSegments(\n tree: RouteTree,\n path: string,\n options: MatchOptions = {},\n): MatchResult | null {\n let normalizedPath = path;\n\n if (normalizedPath === \"\" && !options.strictTrailingSlash) {\n normalizedPath = \"/\";\n }\n\n const match = getSegmentsMatchingPath(tree, normalizedPath, options);\n\n if (!match) {\n return null;\n }\n\n const matchedSegments = match.segments;\n\n if (matchedSegments[0]?.absolute) {\n const firstSegmentParents = matchedSegments[0].parentSegments;\n\n // Use for-loop instead of spread (faster for small arrays)\n\n for (let i = firstSegmentParents.length - 1; i >= 0; i--) {\n matchedSegments.unshift(firstSegmentParents[i]);\n }\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const lastSegment = matchedSegments.at(-1)!;\n const lastSegmentSlashChild = findSlashChild(lastSegment);\n\n if (lastSegmentSlashChild) {\n matchedSegments.push(lastSegmentSlashChild);\n }\n\n return {\n segments: matchedSegments,\n params: match.params,\n };\n}\n\n// =============================================================================\n// Internal: Tree Traversal\n// =============================================================================\n\n/**\n * Finds a slash child node (route that matches \"/\").\n */\nfunction findSlashChild(node: RouteTree): RouteTree | undefined {\n return node.nonAbsoluteChildren.find(\n (child) => child.parser && SLASH_CHILD_PATTERN.test(child.parser.path),\n );\n}\n\n/**\n * Gets a cached or creates a match config for the given options.\n * Uses DEFAULT_CONFIG for empty options, otherwise creates new config.\n *\n * Note: Benchmarks show config creation overhead is <1.5% for deep paths,\n * so we prioritize code simplicity over complex caching logic.\n */\nfunction getMatchConfig(options: MatchOptions): MatchConfig {\n // Fast path: no options - use default config\n if (\n options.queryParamsMode === undefined &&\n options.strictTrailingSlash === undefined &&\n options.strongMatching === undefined &&\n options.caseSensitive === undefined &&\n options.queryParams === undefined &&\n options.urlParamsEncoding === undefined &&\n options.trailingSlashMode === undefined\n ) {\n return DEFAULT_CONFIG;\n }\n\n // trailingSlashMode doesn't affect matching, only buildPath\n // If it's the only option set, we can use DEFAULT_CONFIG\n if (\n options.trailingSlashMode !== undefined &&\n options.queryParamsMode === undefined &&\n options.strictTrailingSlash === undefined &&\n options.strongMatching === undefined &&\n options.caseSensitive === undefined &&\n options.queryParams === undefined &&\n options.urlParamsEncoding === undefined\n ) {\n return DEFAULT_CONFIG;\n }\n\n return createMatchConfig(options);\n}\n\n/**\n * Gets segments matching the given path.\n */\nfunction getSegmentsMatchingPath(\n tree: RouteTree,\n path: string,\n options: MatchOptions,\n): MatchResponse | null {\n // Determine starting nodes (optimized: avoid spread for single node)\n const startingNodes: RouteTree[] = [];\n\n /* eslint-disable @typescript-eslint/prefer-for-of */\n if (tree.parser) {\n // Tree has a parser - use it directly\n startingNodes.push(tree);\n\n // Use for-loop instead of spread (1.36x faster)\n for (let i = 0; i < tree.absoluteDescendants.length; i++) {\n startingNodes.push(tree.absoluteDescendants[i]);\n }\n } else {\n // Use children as starting nodes\n for (const topNode of tree.children) {\n startingNodes.push(topNode);\n\n // Use for-loop instead of spread (1.36x faster)\n for (let i = 0; i < topNode.absoluteDescendants.length; i++) {\n startingNodes.push(topNode.absoluteDescendants[i]);\n }\n }\n }\n /* eslint-enable @typescript-eslint/prefer-for-of */\n\n const currentMatch: MatchResponse = {\n segments: [],\n params: {},\n };\n\n // Use cached config when possible (most common case)\n const config = getMatchConfig(options);\n\n // matchChildren only processes route children, never returns root-only matches\n return matchChildren(startingNodes, path, currentMatch, config);\n}\n\n// =============================================================================\n// Internal: Path Matching\n// =============================================================================\n\n/**\n * Recursively matches a path segment against route tree nodes.\n * Used for top-level matching where no static index is available.\n */\nfunction matchChildren(\n nodes: readonly RouteTree[],\n pathSegment: string,\n currentMatch: MatchResponse,\n config: MatchConfig,\n consumedBefore?: string,\n): MatchResponse | null {\n const isRoot = nodes.length === 1 && nodes[0].name === \"\";\n\n for (const child of nodes) {\n const result = tryMatchChild(\n child,\n pathSegment,\n currentMatch,\n config,\n isRoot,\n consumedBefore,\n );\n\n if (result !== undefined) {\n return result;\n }\n }\n\n return null;\n}\n\n/**\n * Tries to match any child from the list against the path segment.\n *\n * @returns First successful match or null if no match found\n */\nfunction tryMatchAnyChild(\n children: readonly RouteTree[],\n pathSegment: string,\n currentMatch: MatchResponse,\n config: MatchConfig,\n consumedBefore: string | undefined,\n skipStatic: boolean,\n): MatchResponse | null {\n for (const child of children) {\n if (skipStatic && !hasDynamicFirstSegment(child.path)) {\n continue;\n }\n\n const result = tryMatchChild(\n child,\n pathSegment,\n currentMatch,\n config,\n false, // isRoot = false for indexed matching\n consumedBefore,\n );\n\n if (result !== undefined) {\n return result;\n }\n }\n\n return null;\n}\n\n/**\n * Matches path segment against a parent's children using static index.\n *\n * Uses O(1) lookup for routes with static first segments,\n * then falls back to linear search for dynamic-only routes.\n *\n * @param parent - Parent node whose children to match against\n * @param pathSegment - Remaining path to match\n * @param currentMatch - Accumulated match result\n * @param config - Match configuration\n * @param consumedBefore - Previously consumed path (for \"/\" handling)\n * @returns Match result or null\n */\nfunction matchChildrenIndexed(\n parent: RouteTree,\n pathSegment: string,\n currentMatch: MatchResponse,\n config: MatchConfig,\n consumedBefore?: string,\n): MatchResponse | null {\n const staticIndex = parent.staticChildrenByFirstSegment;\n const children = parent.nonAbsoluteChildren;\n\n // Fast path: no static index, use linear search\n if (staticIndex.size === 0) {\n return tryMatchAnyChild(\n children,\n pathSegment,\n currentMatch,\n config,\n consumedBefore,\n false,\n );\n }\n\n // 1. Try static index first (O(1) lookup)\n const firstSegment = extractFirstPathSegment(pathSegment);\n const candidates = staticIndex.get(firstSegment);\n\n if (candidates) {\n const result = tryMatchAnyChild(\n candidates,\n pathSegment,\n currentMatch,\n config,\n consumedBefore,\n false,\n );\n\n if (result !== null) {\n return result;\n }\n }\n\n // 2. Fall back to dynamic routes only (routes not in static index)\n return tryMatchAnyChild(\n children,\n pathSegment,\n currentMatch,\n config,\n consumedBefore,\n true, // skipStatic = true\n );\n}\n\n/**\n * Attempts to match a single child node against the path segment.\n *\n * @returns Match result, null for no match, or undefined to continue iteration\n */\nfunction tryMatchChild(\n child: RouteTree,\n pathSegment: string,\n currentMatch: MatchResponse,\n config: MatchConfig,\n isRoot: boolean,\n consumedBefore?: string,\n): MatchResponse | null | undefined {\n // All route children have parsers by design (only empty root lacks parser)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const parser = child.parser!;\n\n // Handle duplicate \"/\" case\n const segment = resolveSegment(pathSegment, child.path, consumedBefore);\n\n // Try to match\n const match = tryMatchNode(child, parser, segment, config);\n\n if (!match) {\n return undefined;\n }\n\n // Process successful match\n const isLeafNode = child.children.length === 0;\n const consumedPath = buildConsumedPath(parser, match, config, isLeafNode);\n const remainingPath = calculateRemainingPath(\n segment,\n consumedPath,\n config,\n isLeafNode,\n isRoot,\n parser,\n );\n\n // Update accumulated match\n currentMatch.segments.push(child);\n Object.assign(currentMatch.params, match as RouteParams);\n\n return resolveMatchResult(\n child,\n currentMatch,\n remainingPath,\n config,\n isRoot,\n consumedPath,\n );\n}\n\n/**\n * Resolves the segment to match, handling duplicate \"/\" case.\n */\nfunction resolveSegment(\n pathSegment: string,\n childPath: string,\n consumedBefore?: string,\n): string {\n return consumedBefore === \"/\" && childPath === \"/\"\n ? `/${pathSegment}`\n : pathSegment;\n}\n\n/**\n * Resolves the final match result after a successful node match.\n */\nfunction resolveMatchResult(\n child: RouteTree,\n currentMatch: MatchResponse,\n remainingPath: string,\n config: MatchConfig,\n isRoot: boolean,\n consumedPath: string,\n): MatchResponse | null {\n // Check if fully matched\n if (!isRoot && remainingPath.length === 0) {\n return currentMatch;\n }\n\n // Check for unmatched query params in non-strict mode\n if (hasOnlyQueryParamsRemaining(remainingPath, config, isRoot)) {\n return handleRemainingQueryParams(currentMatch, remainingPath);\n }\n\n // Continue matching on children using static index\n if (child.nonAbsoluteChildren.length === 0) {\n return null;\n }\n\n return matchChildrenIndexed(\n child,\n remainingPath,\n currentMatch,\n config,\n consumedPath,\n );\n}\n\n/**\n * Checks if only query params remain in the path.\n */\nfunction hasOnlyQueryParamsRemaining(\n remainingPath: string,\n config: MatchConfig,\n isRoot: boolean,\n): boolean {\n return (\n !isRoot &&\n config.queryParamsMode !== \"strict\" &&\n remainingPath.startsWith(\"?\")\n );\n}\n\n/**\n * Creates match config from options with defaults.\n * Optimized to reuse pre-computed option objects when possible.\n */\nfunction createMatchConfig(options: MatchOptions): MatchConfig {\n const queryParamsMode = options.queryParamsMode ?? \"default\";\n const strictTrailingSlash = options.strictTrailingSlash ?? false;\n const strongMatching = options.strongMatching ?? true;\n const caseSensitive = options.caseSensitive ?? false;\n const { queryParams, urlParamsEncoding } = options;\n\n // Determine if we can use pre-computed options (no custom queryParams or urlParamsEncoding)\n const canUseCachedOptions =\n queryParams === undefined && urlParamsEncoding === undefined;\n\n // Get fullTestOptions - use cached or create new\n const fullTestOptions = canUseCachedOptions\n ? getFullTestOptions(caseSensitive, strictTrailingSlash)\n : { caseSensitive, strictTrailingSlash, queryParams, urlParamsEncoding };\n\n // Get partialTestOptions - use cached or create new\n const partialTestOptions = canUseCachedOptions\n ? getPartialTestOptions(caseSensitive, strongMatching)\n : {\n caseSensitive,\n delimited: strongMatching,\n queryParams,\n urlParamsEncoding,\n };\n\n // Direct assignment eliminates conditional mutants\n // Parser handles undefined urlParamsEncoding the same as missing key\n const buildOptions: Record<string, unknown> = {\n ignoreSearch: true,\n urlParamsEncoding,\n };\n\n return {\n queryParamsMode,\n strictTrailingSlash,\n strongMatching,\n caseSensitive,\n queryParams,\n urlParamsEncoding,\n fullTestOptions,\n partialTestOptions,\n buildOptions,\n };\n}\n\n/**\n * Returns pre-computed fullTestOptions for given flags.\n */\nfunction getFullTestOptions(\n caseSensitive: boolean,\n strictTrailingSlash: boolean,\n): Record<string, unknown> {\n if (caseSensitive) {\n return strictTrailingSlash\n ? DEFAULT_FULL_TEST_OPTIONS_CASE_SENSITIVE_STRICT\n : DEFAULT_FULL_TEST_OPTIONS_CASE_SENSITIVE;\n }\n\n return strictTrailingSlash\n ? DEFAULT_FULL_TEST_OPTIONS_STRICT\n : DEFAULT_FULL_TEST_OPTIONS;\n}\n\n/**\n * Returns pre-computed partialTestOptions for given flags.\n */\nfunction getPartialTestOptions(\n caseSensitive: boolean,\n strongMatching: boolean,\n): Record<string, unknown> {\n if (caseSensitive) {\n return strongMatching\n ? DEFAULT_PARTIAL_TEST_OPTIONS_CASE_SENSITIVE\n : DEFAULT_PARTIAL_TEST_OPTIONS_CASE_SENSITIVE_WEAK;\n }\n\n return strongMatching\n ? DEFAULT_PARTIAL_TEST_OPTIONS\n : DEFAULT_PARTIAL_TEST_OPTIONS_WEAK;\n}\n\n/**\n * Attempts to match a node against a path segment.\n */\nfunction tryMatchNode(\n node: RouteTree,\n parser: PathParser,\n segment: string,\n config: MatchConfig,\n): Record<string, unknown> | null {\n // Try full match for leaf nodes\n if (node.children.length === 0) {\n const fullMatch = parser.test(segment, config.fullTestOptions);\n\n if (fullMatch) {\n return fullMatch;\n }\n }\n\n // Try partial match\n return parser.partialTest(segment, config.partialTestOptions);\n}\n\n/**\n * Calculates the path consumed by a match.\n */\nfunction buildConsumedPath(\n parser: PathParser,\n match: Record<string, unknown>,\n config: MatchConfig,\n isLeafNode: boolean,\n): string {\n let consumedPath = parser.build(match, config.buildOptions);\n\n if (!config.strictTrailingSlash && isLeafNode) {\n consumedPath = consumedPath.replace(TRAILING_SLASH, \"\");\n }\n\n return consumedPath;\n}\n\n/**\n * Calculates remaining path after consuming matched portion.\n */\nfunction calculateRemainingPath(\n segment: string,\n consumedPath: string,\n config: MatchConfig,\n isLeafNode: boolean,\n isRoot: boolean,\n parser: PathParser,\n): string {\n // After successful match, consumedPath is always a prefix of segment (case-insensitive)\n // because consumedPath is built from the same params extracted from segment\n let remainingPath = segment.slice(consumedPath.length);\n\n if (!config.strictTrailingSlash && isLeafNode) {\n remainingPath = remainingPath.replace(LEADING_SLASH_QUERY, \"?\");\n }\n\n const { querystring } = omit(\n getSearch(segment.slice(consumedPath.length)),\n parser.queryParams,\n config.queryParams,\n );\n\n remainingPath =\n getPath(remainingPath) + (querystring ? `?${querystring}` : \"\");\n\n if (\n !config.strictTrailingSlash &&\n !isRoot &&\n remainingPath === \"/\" &&\n !consumedPath.endsWith(\"/\")\n ) {\n remainingPath = \"\";\n }\n\n return remainingPath;\n}\n\n/**\n * Handles remaining query params in non-strict mode.\n * Optimized with fast path for empty query strings and direct assignment.\n */\nfunction handleRemainingQueryParams(\n currentMatch: MatchResponse,\n remainingPath: string,\n): MatchResponse {\n // Direct assignment: parse directly into params object\n // Avoids intermediate object creation and Object.assign overhead\n // Note: remainingPath always has format \"?key=value\" (length > 1)\n // because calculateRemainingPath only adds \"?\" when querystring is non-empty\n parseInto(remainingPath.slice(1), currentMatch.params);\n\n return currentMatch;\n}\n\n// =============================================================================\n// Utility Functions\n// =============================================================================\n\n/**\n * Extracts the path portion before query string.\n * Uses indexOf instead of split for better performance.\n */\nfunction getPath(path: string): string {\n const idx = path.indexOf(\"?\");\n\n return idx === -1 ? path : path.slice(0, idx);\n}\n\n/**\n * Extracts the query string portion from path.\n * Uses indexOf instead of split for better performance.\n */\nfunction getSearch(path: string): string {\n const idx = path.indexOf(\"?\");\n\n return idx === -1 ? \"\" : path.slice(idx + 1);\n}\n","// packages/route-node/modules/operations/query.ts\n\n/**\n * Route Query Operations.\n *\n * Pure functions for querying route information from the tree.\n *\n * @module operations/query\n */\n\nimport type { RouteTree } from \"../types\";\n\n// =============================================================================\n// Public API\n// =============================================================================\n\n/**\n * Finds route nodes by dot-notation name.\n *\n * Returns an array of segments from root to the target node.\n * All returned segments have parsers (root included only if it has parser).\n * Uses childrenByName Map for O(1) lookup at each level.\n *\n * @param tree - Route tree to search in\n * @param routeName - Dot-notation route name (e.g., \"users.profile\")\n * @returns Array of route segments or null if not found\n *\n * @example\n * ```typescript\n * const segments = getSegmentsByName(tree, \"users.profile\");\n * // â [usersNode, profileNode]\n * ```\n */\nexport function getSegmentsByName(\n tree: RouteTree,\n routeName: string,\n): readonly RouteTree[] | null {\n const segments: RouteTree[] = [];\n\n // Optimize: avoid split() allocation for simple names without dots\n const names = routeName.includes(\".\") ? routeName.split(\".\") : [routeName];\n\n // Handle root with parser (include it as first segment)\n if (tree.parser) {\n segments.push(tree);\n }\n\n // Navigate through the tree using O(1) Map lookups\n let currentNode: RouteTree = tree;\n\n for (const name of names) {\n const segment = currentNode.childrenByName.get(name);\n\n if (!segment) {\n return null;\n }\n\n segments.push(segment);\n currentNode = segment;\n }\n\n return segments;\n}\n\n/**\n * Checks if a route exists in the tree by dot-notation name.\n * More efficient than getSegmentsByName when only existence check is needed.\n *\n * Avoids:\n * - Array allocation\n * - Array push operations\n *\n * @param tree - Route tree to search in\n * @param routeName - Dot-notation route name (e.g., \"users.profile\")\n * @returns true if route exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = hasSegmentsByName(tree, \"users.profile\");\n * // â true\n * ```\n */\nexport function hasSegmentsByName(tree: RouteTree, routeName: string): boolean {\n // Optimize: avoid split() allocation for simple names without dots\n const names = routeName.includes(\".\") ? routeName.split(\".\") : [routeName];\n\n // Navigate through the tree using O(1) Map lookups\n let currentNode: RouteTree = tree;\n\n for (const name of names) {\n const segment = currentNode.childrenByName.get(name);\n\n if (!segment) {\n return false;\n }\n\n currentNode = segment;\n }\n\n return true;\n}\n","// packages/route-node/modules/validation/errors.ts\n\n/**\n * Custom error types for route-node package.\n *\n * Provides structured error handling with specific error types\n * for different failure scenarios.\n *\n * @module errors\n */\n\n/**\n * Base error class for all route-node errors.\n *\n * All route-node specific errors inherit from this class,\n * allowing for unified error handling.\n *\n * @example\n * ```typescript\n * try {\n * node.add(invalidRoute);\n * } catch (error) {\n * if (error instanceof RouteNodeError) {\n * console.error(\"Route configuration error:\", error.message);\n * }\n * }\n * ```\n */\nexport class RouteNodeError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"RouteNodeError\";\n // Maintains proper prototype chain for instanceof checks\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\n/**\n * Error thrown when attempting to add a route with a duplicate name or path.\n *\n * @example\n * ```typescript\n * // Throws DuplicateRouteError: Alias \"home\" is already defined in route node\n * node.add({ name: \"home\", path: \"/\" });\n * node.add({ name: \"home\", path: \"/home\" }); // Duplicate name!\n * ```\n */\nexport class DuplicateRouteError extends RouteNodeError {\n /** The duplicate name or path that caused the error */\n public readonly duplicateValue: string;\n /** Whether the duplicate is a name (\"name\") or path (\"path\") */\n public readonly duplicateType: \"name\" | \"path\";\n\n constructor(\n message: string,\n duplicateValue: string,\n duplicateType: \"name\" | \"path\",\n ) {\n super(message);\n this.name = \"DuplicateRouteError\";\n this.duplicateValue = duplicateValue;\n this.duplicateType = duplicateType;\n }\n}\n\n/**\n * Error thrown when a route definition is invalid.\n *\n * Common causes:\n * - Missing required name or path property\n * - Invalid route type (not an object or RouteNode)\n * - Absolute path with parameterized parents\n *\n * @example\n * ```typescript\n * // Throws InvalidRouteError: RouteNode.add() expects routes to have a name and a path defined.\n * node.add({ name: \"incomplete\" }); // Missing path!\n * ```\n */\nexport class InvalidRouteError extends RouteNodeError {\n constructor(message: string) {\n super(message);\n this.name = \"InvalidRouteError\";\n }\n}\n\n/**\n * Error thrown when a referenced route cannot be found.\n *\n * @example\n * ```typescript\n * // Throws RouteNotFoundError: [route-node][buildPath] 'nonexistent' is not defined\n * node.buildPath(\"nonexistent\", {});\n * ```\n */\nexport class RouteNotFoundError extends RouteNodeError {\n /** The route name that was not found */\n public readonly routeName: string;\n\n constructor(message: string, routeName: string) {\n super(message);\n this.name = \"RouteNotFoundError\";\n this.routeName = routeName;\n }\n}\n\n/**\n * Error thrown when a parent route cannot be found for nested route addition.\n *\n * @example\n * ```typescript\n * // Throws ParentNotFoundError when parent \"users\" doesn't exist\n * node.add({ name: \"users.profile\", path: \"/profile\" });\n * ```\n */\nexport class ParentNotFoundError extends RouteNodeError {\n /** The route name whose parent was not found */\n public readonly routeName: string;\n\n constructor(message: string, routeName: string) {\n super(message);\n this.name = \"ParentNotFoundError\";\n this.routeName = routeName;\n }\n}\n","// packages/route-node/modules/operations/build.ts\n\n/**\n * Path Building Operations.\n *\n * Pure functions for building URL paths from route names and parameters.\n *\n * @module operations/build\n */\n\nimport { build as buildQueryString } from \"search-params\";\n\nimport { getSegmentsByName } from \"./query\";\nimport { RouteNotFoundError } from \"../validation/errors\";\n\nimport type {\n BuildOptions,\n RouteParams,\n RouteTree,\n TrailingSlashMode,\n} from \"../types\";\n\n// =============================================================================\n// Constants\n// =============================================================================\n\n/**\n * Shared empty array for lazy allocation optimization.\n * Avoids creating new empty arrays for routes without params.\n */\nconst EMPTY_ARRAY: readonly string[] = Object.freeze([]);\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\n/**\n * Checks if object has any own enumerable keys.\n * More efficient than Object.keys().length > 0 (avoids array allocation).\n */\nfunction hasOwnKeys(obj: object): boolean {\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Checks if BuildOptions contains any non-default values.\n * Used to determine if fast path can be taken.\n *\n * Default values that allow fast path:\n * - trailingSlashMode: \"default\" or undefined\n * - queryParamsMode: \"default\" or undefined\n * - queryParams: undefined\n * - urlParamsEncoding: \"default\" or undefined\n */\nfunction hasNonDefaultOptions(options: BuildOptions): boolean {\n return (\n (options.trailingSlashMode !== undefined &&\n options.trailingSlashMode !== \"default\") ||\n (options.queryParamsMode !== undefined &&\n options.queryParamsMode !== \"default\") ||\n options.queryParams !== undefined ||\n (options.urlParamsEncoding !== undefined &&\n options.urlParamsEncoding !== \"default\")\n );\n}\n\n// =============================================================================\n// Types\n// =============================================================================\n\n/**\n * Collected parameters from route segments.\n */\ninterface CollectedParams {\n readonly searchParams: readonly string[];\n readonly nonSearchParams: readonly string[];\n}\n\n// =============================================================================\n// Public API\n// =============================================================================\n\n/**\n * Tries fast path for simple route names without parameters.\n * Returns staticPath if available, null otherwise.\n */\nfunction tryStaticPathFast(tree: RouteTree, routeName: string): string | null {\n if (routeName.includes(\".\")) {\n const segments = getSegmentsByName(tree, routeName);\n const staticPath = segments?.at(-1)?.staticPath;\n\n return staticPath ?? null;\n }\n\n return tree.childrenByName.get(routeName)?.staticPath ?? null;\n}\n\n/**\n * Builds a URL path for the given route name and parameters.\n *\n * @param tree - Route tree to use\n * @param routeName - Dot-notation route name (e.g., \"users.profile\")\n * @param params - Route parameters\n * @param options - Build options\n * @param segments - Optional pre-computed segments (avoids getSegmentsByName call)\n * @returns Built URL path\n * @throws {RouteNotFoundError} If route not found\n *\n * @example\n * ```typescript\n * const url = buildPath(tree, \"users.profile\", { id: \"123\" });\n * // â \"/users/123\"\n *\n * // With pre-computed segments (avoids duplicate lookup)\n * const segments = getSegmentsByName(tree, \"users.profile\");\n * const url = buildPath(tree, \"users.profile\", { id: \"123\" }, {}, segments);\n * ```\n */\nexport function buildPath(\n tree: RouteTree,\n routeName: string,\n params: RouteParams = {},\n options: BuildOptions = {},\n segments?: readonly RouteTree[],\n): string {\n // If segments provided, skip lookup and fast path (caller already has segments)\n if (segments) {\n return buildPathFromSegments(segments, params, options);\n }\n\n // Fast path: no params, default options - try pre-computed staticPath\n // R6 optimization: use hasOwnKeys instead of Object.keys().length (avoids array allocation)\n // R7 optimization: check option VALUES not just keys (enables fast path for real-router)\n const hasParams = hasOwnKeys(params);\n const hasNonDefaults = hasNonDefaultOptions(options);\n\n if (!hasParams && !hasNonDefaults) {\n const staticPath = tryStaticPathFast(tree, routeName);\n\n if (staticPath !== null) {\n return staticPath;\n }\n }\n\n // Regular path: find segments and build\n const foundSegments = getSegmentsByName(tree, routeName);\n\n if (!foundSegments) {\n throw new RouteNotFoundError(\n `[route-node][buildPath] '${routeName}' is not defined`,\n routeName,\n );\n }\n\n return buildPathFromSegments(foundSegments, params, options);\n}\n\n// =============================================================================\n// Internal: Path Building\n// =============================================================================\n\n/**\n * Builds a URL path from route segments.\n *\n * Note: All segments from getSegmentsByName have parsers -\n * root is only included if it has a parser, and children always have parsers.\n */\nfunction buildPathFromSegments(\n segments: readonly RouteTree[],\n params: RouteParams,\n options: BuildOptions,\n): string {\n const { queryParamsMode = \"default\", trailingSlashMode = \"default\" } =\n options;\n\n const collected = collectParamsFromSegments(segments);\n const searchParams = resolveSearchParams(collected, params, queryParamsMode);\n const searchPart = buildSearchString(searchParams, params, options);\n const pathString = buildPathString(segments, params, options);\n const finalPath = applyTrailingSlashMode(pathString, trailingSlashMode);\n\n return finalPath + (searchPart ? `?${searchPart}` : \"\");\n}\n\n/**\n * Collects search and non-search parameters from segments.\n * Uses lazy allocation - arrays only created when params exist.\n */\nfunction collectParamsFromSegments(\n segments: readonly RouteTree[],\n): CollectedParams {\n let searchParams: string[] | null = null;\n let nonSearchParams: string[] | null = null;\n\n for (const segment of segments) {\n // All segments from getSegmentsByName have parsers by design\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const parser = segment.parser!;\n\n // Use for-loop instead of spread (1.49x faster)\n /* eslint-disable @typescript-eslint/prefer-for-of */\n if (parser.queryParams.length > 0) {\n searchParams ??= [];\n\n for (let i = 0; i < parser.queryParams.length; i++) {\n searchParams.push(parser.queryParams[i]);\n }\n }\n\n if (parser.urlParams.length > 0 || parser.spatParams.length > 0) {\n nonSearchParams ??= [];\n\n for (let i = 0; i < parser.urlParams.length; i++) {\n nonSearchParams.push(parser.urlParams[i]);\n }\n\n for (let i = 0; i < parser.spatParams.length; i++) {\n nonSearchParams.push(parser.spatParams[i]);\n }\n }\n /* eslint-enable @typescript-eslint/prefer-for-of */\n }\n\n return {\n searchParams: searchParams ?? EMPTY_ARRAY,\n nonSearchParams: nonSearchParams ?? EMPTY_ARRAY,\n };\n}\n\n/**\n * Resolves final search params, adding loose params if needed.\n */\nfunction resolveSearchParams(\n collected: CollectedParams,\n params: RouteParams,\n queryParamsMode: BuildOptions[\"queryParamsMode\"],\n): readonly string[] {\n if (queryParamsMode !== \"loose\") {\n return collected.searchParams;\n }\n\n // Use slice() instead of spread (1.15x faster)\n const searchParams = [...(collected.searchParams as string[])];\n const searchParamsSet = new Set(collected.searchParams);\n const nonSearchParamsSet = new Set(collected.nonSearchParams);\n\n // Object.hasOwn filters inherited properties (prototype pollution protection)\n for (const p in params) {\n if (\n Object.hasOwn(params, p) &&\n !searchParamsSet.has(p) &&\n !nonSearchParamsSet.has(p)\n ) {\n searchParams.push(p);\n }\n }\n\n return searchParams;\n}\n\n/**\n * Builds the query string from search params.\n */\nfunction buildSearchString(\n searchParams: readonly string[],\n params: RouteParams,\n options: BuildOptions,\n): string {\n const searchParamsObject: RouteParams = {};\n\n for (const paramName of searchParams) {\n if (paramName in params) {\n searchParamsObject[paramName] = params[paramName];\n }\n }\n\n return buildQueryString(searchParamsObject, options.queryParams);\n}\n\n/**\n * Builds the path string from segments.\n */\nfunction buildPathString(\n segments: readonly RouteTree[],\n params: RouteParams,\n options: BuildOptions,\n): string {\n // Direct assignment eliminates conditional mutants\n // Parser handles undefined values the same as missing keys\n const buildOptions: Record<string, unknown> = {\n ignoreSearch: true,\n queryParams: options.queryParams,\n urlParamsEncoding: options.urlParamsEncoding,\n };\n\n let path = \"\";\n\n for (const segment of segments) {\n // All segments from getSegmentsByName have parsers by design\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const segmentPath = segment.parser!.build(params, buildOptions);\n\n path = segment.absolute ? segmentPath : path + segmentPath;\n }\n\n // Always normalize - regex only matches actual \"//\" sequences\n // Removed conditional check as it created equivalent mutants\n return path.replaceAll(/\\/{2,}/g, \"/\");\n}\n\n/**\n * Applies trailing slash mode to the path.\n */\nfunction applyTrailingSlashMode(path: string, mode: TrailingSlashMode): string {\n if (mode === \"always\") {\n return path.endsWith(\"/\") ? path : `${path}/`;\n }\n\n if (mode === \"never\" && path !== \"/\") {\n return path.endsWith(\"/\") ? path.slice(0, -1) : path;\n }\n\n return path;\n}\n","// packages/route-node/modules/operations/meta.ts\n\n/**\n * Metadata Operations.\n *\n * Pure functions for building route parameter metadata.\n *\n * @module operations/meta\n */\n\nimport type {\n ParamTypeMap,\n PathParser,\n RouteTree,\n RouteTreeStateMeta,\n} from \"../types\";\n\n// =============================================================================\n// Public API\n// =============================================================================\n\n/**\n * Builds a map of parameter names to their source type (url or query).\n *\n * @param parser - Path parser to extract parameters from\n * @returns Map of parameter names to their source type\n */\nexport function buildParamTypeMap(parser: PathParser | null): ParamTypeMap {\n const params: ParamTypeMap = {};\n\n if (!parser) {\n return params;\n }\n\n for (const p of parser.urlParams) {\n params[p] = \"url\";\n }\n\n for (const p of parser.queryParams) {\n params[p] = \"query\";\n }\n\n return params;\n}\n\n/**\n * Builds parameter type metadata from route segments.\n *\n * @param segments - Array of route tree segments\n * @returns Metadata mapping segment names to their parameter types\n *\n * @example\n * ```typescript\n * const meta = getMetaFromSegments(matchResult.segments);\n * // â { users: {}, \"users.profile\": { id: \"url\" } }\n * ```\n */\nexport function getMetaFromSegments(\n segments: readonly RouteTree[],\n): RouteTreeStateMeta {\n const meta: RouteTreeStateMeta = {};\n\n for (const segment of segments) {\n // Use pre-computed fullName and paramTypeMap from RouteTree cache\n // This avoids string concatenation and buildParamTypeMap() call per segment\n meta[segment.fullName] = segment.paramTypeMap;\n }\n\n return meta;\n}\n","// packages/route-tree/modules/operations/routeTreeToDefinitions.ts\n\n/**\n * RouteTree to RouteDefinition Converter.\n *\n * Converts a RouteTree back to an array of RouteDefinition objects.\n * Used for serialization and router cloning.\n *\n * @module operations/routeTreeToDefinitions\n */\n\nimport type { RouteDefinition, RouteTree } from \"../types\";\n\n/**\n * Converts a single RouteTree node to a RouteDefinition.\n *\n * If the node has absolute=true, the path is prefixed with '~'\n * to reconstruct the original definition format.\n *\n * @param node - RouteTree node to convert\n * @returns RouteDefinition with name, path, and optional children\n */\nexport function nodeToDefinition(node: RouteTree): RouteDefinition {\n // Reconstruct absolute path marker if needed\n const path = node.absolute ? `~${node.path}` : node.path;\n\n const def: RouteDefinition = {\n name: node.name,\n path,\n };\n\n if (node.children.length > 0) {\n def.children = node.children.map((child) => nodeToDefinition(child));\n }\n\n return def;\n}\n\n/**\n * Converts a RouteTree back to an array of RouteDefinition objects.\n *\n * This is the inverse of createRouteTree - it extracts the minimal\n * definition data (name, path, children) from the computed tree.\n *\n * Note: Extra properties stored in RouteDefinition (like canActivate,\n * forwardTo, encodeParams, etc.) are NOT preserved in RouteTree,\n * so they won't be present in the output.\n *\n * @example\n * ```ts\n * const tree = createRouteTree(\"\", \"\", [\n * { name: \"users\", path: \"/users\", children: [\n * { name: \"profile\", path: \"/:id\" }\n * ]}\n * ]);\n *\n * const definitions = routeTreeToDefinitions(tree);\n * // [{ name: \"users\", path: \"/users\", children: [{ name: \"profile\", path: \"/:id\" }] }]\n * ```\n *\n * @param tree - RouteTree to convert\n * @returns Array of RouteDefinition objects (top-level routes only)\n */\nexport function routeTreeToDefinitions(tree: RouteTree): RouteDefinition[] {\n return tree.children.map((child) => nodeToDefinition(child));\n}\n","// packages/route-node/modules/validation/routes.ts\n\nimport type { RouteTree } from \"../types\";\n\n/**\n * Creates a TypeError with consistent router error message format.\n *\n * @param methodName - Name of the method that triggered the error\n * @param message - Error message\n * @returns TypeError with formatted message\n * @internal\n */\nfunction createRouterError(methodName: string, message: string): TypeError {\n return new TypeError(`[router.${methodName}] ${message}`);\n}\n\n/**\n * Validates route path format.\n * Throws a descriptive error if validation fails.\n *\n * Allows:\n * - Empty string (for grouping/root routes)\n * - Absolute paths: /path, ~path\n * - Query strings: ?query\n * - Relative segments: segment\n *\n * Prevents:\n * - Non-string values\n * - Double slashes (//)\n * - Absolute paths (~) under parameterized parent nodes\n *\n * @param path - Route path to validate\n * @param routeName - Name of route (for error messages)\n * @param methodName - Name of calling method for error messages\n * @param parentNode - Optional parent node for context validation\n * @throws {TypeError} If path is invalid\n *\n * @example\n * // Valid paths\n * validateRoutePath(\"\", \"home\", \"add\"); // ok (empty for grouping)\n * validateRoutePath(\"/users\", \"users\", \"add\"); // ok (absolute)\n * validateRoutePath(\"~dashboard\", \"dash\", \"add\"); // ok (absolute, if no parameterized parent)\n * validateRoutePath(\"?tab=1\", \"home\", \"add\"); // ok (query)\n * validateRoutePath(\"profile\", \"users.profile\", \"add\"); // ok (relative)\n *\n * @example\n * // Invalid paths (throws)\n * validateRoutePath(\"/users//list\", \"users.list\", \"add\"); // throws (double slash)\n * validateRoutePath(\"~dash\", \"dash\", \"add\", paramParent); // throws (~ under parameterized parent)\n */\nexport function validateRoutePath(\n path: unknown,\n routeName: string,\n methodName: string,\n parentNode?: RouteTree,\n): asserts path is string {\n // Type check\n if (typeof path !== \"string\") {\n // Get type description for error message\n let typeDesc: string;\n\n if (path === null) {\n typeDesc = \"null\";\n } else if (Array.isArray(path)) {\n typeDesc = \"array\";\n } else {\n typeDesc = typeof path;\n }\n\n throw createRouterError(\n methodName,\n `Route path must be a string, got ${typeDesc}`,\n );\n }\n\n // Empty path is valid (for grouping/root)\n if (path === \"\") {\n return;\n }\n\n // No whitespace characters (spaces, tabs, newlines)\n if (/\\s/.test(path)) {\n throw createRouterError(\n methodName,\n `Invalid path for route \"${routeName}\": whitespace not allowed in \"${path}\"`,\n );\n }\n\n // Valid path pattern\n if (!/^([/?~]|[^/]+$)/.test(path)) {\n throw createRouterError(\n methodName,\n `Route \"${routeName}\" has invalid path format: \"${path}\". Path should start with '/', '~', '?' or be a relative segment.`,\n );\n }\n\n // No double slashes\n if (path.includes(\"//\")) {\n throw createRouterError(\n methodName,\n `Invalid path for route \"${routeName}\": double slashes not allowed in \"${path}\"`,\n );\n }\n\n // Absolute paths under parameterized parents\n // RouteTree has parser with urlParams array\n // Also support legacy hasUrlParams for backwards compatibility\n const hasUrlParams =\n parentNode?.parser &&\n ((\"urlParams\" in parentNode.parser &&\n parentNode.parser.urlParams.length > 0) ||\n (\"hasUrlParams\" in parentNode.parser &&\n (parentNode.parser as { hasUrlParams?: boolean }).hasUrlParams));\n\n if (path.startsWith(\"~\") && hasUrlParams) {\n throw new Error(\n `[router.${methodName}] Absolute path \"${path}\" cannot be used under parent route with URL parameters`,\n );\n }\n}\n","// packages/route-node/modules/validation/route-batch.ts\n\n/**\n * Batch route validation utilities.\n *\n * Provides validation for adding routes with cross-batch duplicate detection.\n * Used by router.addRoute() to ensure atomicity - all routes validated before any modification.\n */\n\nimport { validateRoutePath } from \"./routes\";\n\nimport type { RouteDefinition, RouteTree } from \"../types\";\n\n/**\n * Pattern for complete route validation (all segments at once).\n * Matches: single segment or multiple segments separated by dots.\n * Each segment must start with letter/underscore, followed by alphanumeric/hyphen/underscore.\n * Rejects: leading/trailing/consecutive dots, segments starting with numbers/hyphens.\n */\nconst FULL_ROUTE_PATTERN = /^[A-Z_a-z][\\w-]*(?:\\.[A-Z_a-z][\\w-]*)*$/;\n\n/**\n * Checks if string contains at least one non-whitespace character.\n */\nconst HAS_NON_WHITESPACE = /\\S/;\n\n/**\n * Maximum route name length to prevent DoS and performance issues.\n */\nconst MAX_ROUTE_NAME_LENGTH = 10_000;\n\n/**\n * Gets a human-readable description of a value's type.\n * Used for error messages to provide helpful debugging information.\n */\nfunction getTypeDescription(value: unknown): string {\n // Handle null explicitly (typeof null === \"object\")\n if (value === null) {\n return \"null\";\n }\n\n if (typeof value === \"object\") {\n // Return constructor name for class instances\n if (\"constructor\" in value && value.constructor.name !== \"Object\") {\n return value.constructor.name;\n }\n\n // Plain object\n return \"object\";\n }\n\n // Primitive types (string, number, boolean, undefined, etc.)\n return typeof value;\n}\n\n/**\n * Checks if an object has getters or setters.\n * Used to detect potentially malicious route objects that could mutate during processing.\n *\n * @param obj - Object to check\n * @returns true if object has getters or setters\n */\nfunction hasGettersOrSetters(obj: Record<string, unknown>): boolean {\n for (const key of Object.keys(obj)) {\n const descriptor = Object.getOwnPropertyDescriptor(obj, key);\n\n if (descriptor && (descriptor.get || descriptor.set)) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Validates that route is a plain object without getters/setters.\n * Prevents malicious objects that could mutate during processing.\n *\n * @param route - Route to validate\n * @param methodName - Calling method for error context\n * @throws {TypeError} If route is not a plain object\n */\nfunction validateRouteType(\n route: unknown,\n methodName: string,\n): asserts route is Record<string, unknown> {\n if (!route || typeof route !== \"object\") {\n throw new TypeError(\n `[router.${methodName}] Route must be an object, got ${getTypeDescription(route)}`,\n );\n }\n\n // Check for plain object (prototype must be Object.prototype or null)\n const proto: object | null = Object.getPrototypeOf(route) as object | null;\n\n if (proto !== Object.prototype && proto !== null) {\n throw new TypeError(\n `[router.${methodName}] Route must be a plain object, got ${getTypeDescription(route)}`,\n );\n }\n\n // Check for getters/setters (could cause mutations during processing)\n if (hasGettersOrSetters(route as Record<string, unknown>)) {\n throw new TypeError(\n `[router.${methodName}] Route must not have getters or setters`,\n );\n }\n}\n\n/**\n * Validates that encodeParams is a function if provided.\n *\n * @param route - Route configuration\n * @param methodName - Calling method for error context\n * @throws {TypeError} If encodeParams is not a function\n */\nfunction validateEncodeParams(\n route: Record<string, unknown>,\n methodName: string,\n): void {\n if (\n route.encodeParams !== undefined &&\n typeof route.encodeParams !== \"function\"\n ) {\n throw new TypeError(\n `[router.${methodName}] Route \"${String(route.name)}\" encodeParams must be a function`,\n );\n }\n}\n\n/**\n * Validates that decodeParams is a function if provided.\n *\n * @param route - Route configuration\n * @param methodName - Calling method for error context\n * @throws {TypeError} If decodeParams is not a function\n */\nfunction validateDecodeParams(\n route: Record<string, unknown>,\n methodName: string,\n): void {\n if (\n route.decodeParams !== undefined &&\n typeof route.decodeParams !== \"function\"\n ) {\n throw new TypeError(\n `[router.${methodName}] Route \"${String(route.name)}\" decodeParams must be a function`,\n );\n }\n}\n\n/**\n * Validates that route name is a valid string matching the expected format.\n *\n * Route name rules:\n * - Must be a string\n * - Cannot be empty or whitespace-only\n * - Each segment must match [a-zA-Z_][a-zA-Z0-9_-]*\n * - Segments are separated by dots (e.g., \"users.profile\")\n * - No consecutive dots, no leading/trailing dots\n *\n * @param route - Route configuration\n * @param methodName - Calling method for error context\n * @throws {TypeError} If name is missing, not a string, or invalid format\n */\nfunction validateRouteName(\n route: Record<string, unknown>,\n methodName: string,\n): asserts route is Record<string, unknown> & { name: string } {\n if (typeof route.name !== \"string\") {\n throw new TypeError(\n `[router.${methodName}] Route name must be a string, got ${getTypeDescription(route.name)}`,\n );\n }\n\n const name = route.name;\n\n // Empty string is not allowed for addRoute (unlike root node in type-guards)\n if (name === \"\") {\n throw new TypeError(`[router.${methodName}] Route name cannot be empty`);\n }\n\n // Whitespace-only strings are invalid\n if (!HAS_NON_WHITESPACE.test(name)) {\n throw new TypeError(\n `[router.${methodName}] Route name cannot contain only whitespace`,\n );\n }\n\n // Length check for technical safety\n if (name.length > MAX_ROUTE_NAME_LENGTH) {\n throw new TypeError(\n `[router.${methodName}] Route name exceeds maximum length of ${MAX_ROUTE_NAME_LENGTH} characters`,\n );\n }\n\n // System routes bypass pattern validation (e.g., @@router/UNKNOWN_ROUTE)\n if (name.startsWith(\"@@\")) {\n return;\n }\n\n // Validate route pattern (ASCII only: letters, numbers, underscores, hyphens, dots)\n if (!FULL_ROUTE_PATTERN.test(name)) {\n throw new TypeError(\n `[router.${methodName}] Invalid route name \"${name}\". ` +\n `Each segment must start with a letter or underscore, ` +\n `followed by letters, numbers, underscores, or hyphens. ` +\n `Segments are separated by dots (e.g., \"users.profile\").`,\n );\n }\n}\n\n/**\n * Checks for duplicate route name in existing tree.\n *\n * @param rootNode - Root node to search in\n * @param fullName - Full route name (dot-notation)\n * @param methodName - Calling method for error context\n * @throws {Error} If route name already exists\n */\nfunction checkTreeNameDuplicate(\n rootNode: RouteTree,\n fullName: string,\n methodName: string,\n): void {\n // Use childrenByName Map for O(1) lookup\n const segments = fullName.split(\".\");\n let current: RouteTree | undefined = rootNode;\n\n for (const segment of segments) {\n current = current.childrenByName.get(segment);\n\n if (!current) {\n return; // Route doesn't exist\n }\n }\n\n throw new Error(`[router.${methodName}] Route \"${fullName}\" already exists`);\n}\n\n/**\n * Checks for duplicate route name in current batch.\n *\n * @param seenNames - Set of names already seen in batch\n * @param fullName - Full route name to check\n * @param methodName - Calling method for error context\n * @throws {Error} If duplicate name in batch\n */\nfunction checkBatchNameDuplicate(\n seenNames: Set<string>,\n fullName: string,\n methodName: string,\n): void {\n if (seenNames.has(fullName)) {\n throw new Error(\n `[router.${methodName}] Duplicate route \"${fullName}\" in batch`,\n );\n }\n\n seenNames.add(fullName);\n}\n\n/**\n * Checks for duplicate path in existing tree at same parent level.\n *\n * @param rootNode - Root node to search in\n * @param parentName - Parent route name (empty string for root level)\n * @param routePath - Path to check for duplicates\n * @throws {Error} If path already exists at this level\n */\nfunction checkTreePathDuplicate(\n rootNode: RouteTree,\n parentName: string,\n routePath: string,\n): void {\n // Find parent node using childrenByName\n let parentNode: RouteTree | undefined = rootNode;\n\n if (parentName !== \"\") {\n const segments = parentName.split(\".\");\n\n for (const segment of segments) {\n parentNode = parentNode.childrenByName.get(segment);\n\n if (!parentNode) {\n return; // Parent doesn't exist, so no duplicate\n }\n }\n }\n\n for (const child of parentNode.children) {\n if (child.path === routePath) {\n throw new Error(`Path \"${routePath}\" is already defined`);\n }\n }\n}\n\n/**\n * Checks that parent route exists for dot-notation names.\n *\n * For routes like \"users.profile\", verifies that \"users\" exists either:\n * - In the existing tree\n * - In the current batch (already added before this route)\n *\n * @param rootNode - Root node to search in\n * @param routeName - Route name (possibly with dots)\n * @param methodName - Calling method for error context\n * @param seenNames - Set of names already seen in batch\n * @throws {Error} If parent route does not exist\n */\nfunction checkParentExists(\n rootNode: RouteTree | undefined,\n routeName: string,\n methodName: string,\n seenNames?: Set<string>,\n): void {\n const parts = routeName.split(\".\");\n\n parts.pop(); // Remove last segment (actual route name)\n\n const parentName = parts.join(\".\");\n\n // Check if parent exists in current batch\n if (seenNames?.has(parentName)) {\n return; // Parent was added earlier in this batch\n }\n\n // Check if parent exists in tree\n if (rootNode) {\n const segments = parentName.split(\".\");\n let current: RouteTree | undefined = rootNode;\n\n for (const segment of segments) {\n current = current.childrenByName.get(segment);\n\n if (!current) {\n throw new Error(\n `[router.${methodName}] Parent route \"${parentName}\" does not exist for route \"${routeName}\"`,\n );\n }\n }\n\n return; // Parent exists in tree\n }\n\n // No tree and not in batch - parent doesn't exist\n throw new Error(\n `[router.${methodName}] Parent route \"${parentName}\" does not exist for route \"${routeName}\"`,\n );\n}\n\n/**\n * Checks for duplicate path in current batch at same parent level.\n *\n * @param seenPathsByParent - Map of paths by parent name\n * @param parentName - Parent route name (empty string for root level)\n * @param routePath - Path to check for duplicates\n * @throws {Error} If path already exists at this level in batch\n */\nfunction checkBatchPathDuplicate(\n seenPathsByParent: Map<string, Set<string>>,\n parentName: string,\n routePath: string,\n): void {\n const pathsAtLevel = seenPathsByParent.get(parentName);\n\n if (pathsAtLevel?.has(routePath)) {\n throw new Error(`Path \"${routePath}\" is already defined`);\n }\n\n if (pathsAtLevel) {\n pathsAtLevel.add(routePath);\n } else {\n seenPathsByParent.set(parentName, new Set([routePath]));\n }\n}\n\n/**\n * Validates route structure for add operations.\n *\n * Performs comprehensive validation including:\n * - Type check (must be object)\n * - Name validation\n * - Path validation\n * - Duplicate name detection (in tree and batch)\n * - Duplicate path detection (in tree and batch)\n * - Recursive children validation\n *\n * @param route - Route to validate\n * @param methodName - Calling method for error context\n * @param rootNode - Optional root node for duplicate checking\n * @param parentName - Parent route name for building full path (used in recursion)\n * @param seenNames - Set of names already seen in this batch\n * @param seenPathsByParent - Map of paths by parent for path duplicate detection\n * @throws {TypeError} If route structure is invalid\n * @throws {Error} If route already exists (duplicate)\n * @throws {Error} If path already defined (duplicate)\n *\n * @example\n * ```typescript\n * const seenNames = new Set<string>();\n * const seenPaths = new Map<string, Set<string>>();\n *\n * // Validate routes before adding\n * for (const route of routes) {\n * validateRoute(route, \"add\", rootNode, \"\", seenNames, seenPaths);\n * }\n * ```\n */\nexport function validateRoute(\n route: unknown,\n methodName: string,\n rootNode?: RouteTree,\n parentName = \"\",\n seenNames?: Set<string>,\n seenPathsByParent?: Map<string, Set<string>>,\n): asserts route is RouteDefinition {\n validateRouteType(route, methodName);\n\n const r = route;\n\n // Validate that name is a non-empty string\n validateRouteName(r, methodName);\n\n // Validate path structure\n validateRoutePath(r.path, r.name, methodName, rootNode);\n\n // Validate optional function properties\n validateEncodeParams(r, methodName);\n validateDecodeParams(r, methodName);\n\n const routeName = r.name;\n const fullName = parentName ? `${parentName}.${routeName}` : routeName;\n\n // Check that parent exists for dot-notation names (e.g., \"users.profile\" requires \"users\")\n // Only check for flat routes (no parentName) with dot-notation\n if (!parentName && fullName.includes(\".\")) {\n checkParentExists(rootNode, fullName, methodName, seenNames);\n }\n\n // Check for duplicate name in existing tree\n if (rootNode && fullName) {\n checkTreeNameDuplicate(rootNode, fullName, methodName);\n }\n\n // Check for duplicate name in current batch\n if (seenNames) {\n checkBatchNameDuplicate(seenNames, fullName, methodName);\n }\n\n const routePath = r.path;\n\n // For flat routes with dot-notation names (e.g., \"users.settings\"),\n // extract the parent from the name for path checking.\n // RouteNode will place such routes under their implied parent.\n let pathCheckParent = parentName;\n\n if (routeName.includes(\".\") && !parentName) {\n const parts = routeName.split(\".\");\n\n parts.pop(); // Remove last segment (actual route name)\n\n pathCheckParent = parts.join(\".\");\n }\n\n // Check for duplicate path in existing tree\n if (rootNode) {\n checkTreePathDuplicate(rootNode, pathCheckParent, routePath);\n }\n\n // Check for duplicate path in current batch\n if (seenPathsByParent) {\n checkBatchPathDuplicate(seenPathsByParent, pathCheckParent, routePath);\n }\n\n // Validate children recursively\n if (r.children !== undefined) {\n if (!Array.isArray(r.children)) {\n throw new TypeError(\n `[router.${methodName}] Route \"${routeName}\" children must be an array, got ${getTypeDescription(r.children)}`,\n );\n }\n\n for (const child of r.children) {\n validateRoute(\n child,\n methodName,\n rootNode,\n fullName,\n seenNames,\n seenPathsByParent,\n );\n }\n }\n}\n","// packages/core/src/namespaces/RoutesNamespace/constants.ts\n\n/**\n * Default route name for the root node.\n */\nexport const DEFAULT_ROUTE_NAME = \"\";\n\n/**\n * Cache for validated route names to skip regex validation on repeated calls.\n * Key insight: validateRouteName() regex takes ~40ns, but cache lookup is ~1ns.\n * This cache is module-level (shared across all router instances) since route name\n * validity is independent of router instance.\n */\nexport const validatedRouteNames = new Set<string>();\n","// packages/core/src/namespaces/RoutesNamespace/helpers.ts\n\nimport { getSegmentsByName } from \"route-tree\";\nimport { getTypeDescription } from \"type-guards\";\n\nimport { createBuildOptions } from \"../../helpers\";\n\nimport type { RouteConfig } from \"./types\";\nimport type { Route } from \"../../types\";\nimport type { DefaultDependencies, Options, Params } from \"@real-router/types\";\nimport type { MatchOptions, RouteDefinition, RouteTree } from \"route-tree\";\n\n/**\n * Creates an empty RouteConfig.\n */\nexport function createEmptyConfig(): RouteConfig {\n return {\n decoders: Object.create(null) as Record<string, (params: Params) => Params>,\n encoders: Object.create(null) as Record<string, (params: Params) => Params>,\n defaultParams: Object.create(null) as Record<string, Params>,\n forwardMap: Object.create(null) as Record<string, string>,\n };\n}\n\n/**\n * Creates RouteNode match options from real-router options.\n */\nexport function createMatchOptions(options: Options): MatchOptions {\n return {\n ...createBuildOptions(options),\n caseSensitive: options.caseSensitive,\n strictTrailingSlash: options.trailingSlash === \"strict\",\n strongMatching: false,\n };\n}\n\n// ============================================================================\n// Route Tree Helpers\n// ============================================================================\n\n/**\n * Checks if all params from source exist with same values in target.\n * Small function body allows V8 inlining.\n */\nexport function paramsMatch(source: Params, target: Params): boolean {\n for (const key in source) {\n if (source[key] !== target[key]) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Checks params match, skipping keys present in skipKeys.\n */\nexport function paramsMatchExcluding(\n source: Params,\n target: Params,\n skipKeys: Params,\n): boolean {\n for (const key in source) {\n if (key in skipKeys) {\n continue;\n }\n if (source[key] !== target[key]) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Sanitizes a route by keeping only essential properties.\n */\nexport function sanitizeRoute<Dependencies extends DefaultDependencies>(\n route: Route<Dependencies>,\n): RouteDefinition {\n const sanitized: RouteDefinition = {\n name: route.name,\n path: route.path,\n };\n\n if (route.children) {\n sanitized.children = route.children.map((child) => sanitizeRoute(child));\n }\n\n return sanitized;\n}\n\n/**\n * Recursively removes a route from definitions array.\n */\nexport function removeFromDefinitions(\n definitions: RouteDefinition[],\n routeName: string,\n parentPrefix = \"\",\n): boolean {\n for (let i = 0; i < definitions.length; i++) {\n const route = definitions[i];\n const fullName = parentPrefix\n ? `${parentPrefix}.${route.name}`\n : route.name;\n\n if (fullName === routeName) {\n definitions.splice(i, 1);\n\n return true;\n }\n\n if (\n route.children &&\n routeName.startsWith(`${fullName}.`) &&\n removeFromDefinitions(route.children, routeName, fullName)\n ) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Clears configuration entries that match the predicate.\n */\nexport function clearConfigEntries<T>(\n config: Record<string, T>,\n matcher: (key: string) => boolean,\n): void {\n for (const key of Object.keys(config)) {\n if (matcher(key)) {\n delete config[key];\n }\n }\n}\n\n// ============================================================================\n// Route Property Validation\n// ============================================================================\n\n/**\n * Validates route properties (canActivate, canDeactivate, defaultParams, async functions).\n * This ensures type safety at configuration time, not runtime.\n *\n * @param route - Route to validate\n * @param fullName - Full route name (with parent prefix)\n * @throws {TypeError} If canActivate/canDeactivate is not a function\n * @throws {TypeError} If defaultParams is not a plain object\n * @throws {TypeError} If decodeParams/encodeParams is async\n */\nexport function validateRouteProperties<\n Dependencies extends DefaultDependencies,\n>(route: Route<Dependencies>, fullName: string): void {\n // Validate canActivate is a function\n if (\n route.canActivate !== undefined &&\n typeof route.canActivate !== \"function\"\n ) {\n throw new TypeError(\n `[router.addRoute] canActivate must be a function for route \"${fullName}\", ` +\n `got ${getTypeDescription(route.canActivate)}`,\n );\n }\n\n // Validate canDeactivate is a function\n if (\n route.canDeactivate !== undefined &&\n typeof route.canDeactivate !== \"function\"\n ) {\n throw new TypeError(\n `[router.addRoute] canDeactivate must be a function for route \"${fullName}\", ` +\n `got ${getTypeDescription(route.canDeactivate)}`,\n );\n }\n\n // Validate defaultParams is a plain object\n // Runtime check for invalid types passed via `as any`\n if (route.defaultParams !== undefined) {\n const params: unknown = route.defaultParams;\n\n if (\n params === null ||\n typeof params !== \"object\" ||\n Array.isArray(params)\n ) {\n throw new TypeError(\n `[router.addRoute] defaultParams must be an object for route \"${fullName}\", ` +\n `got ${getTypeDescription(route.defaultParams)}`,\n );\n }\n }\n\n // Validate decodeParams is not async (sync required for matchPath/buildPath)\n if (route.decodeParams?.constructor.name === \"AsyncFunction\") {\n throw new TypeError(\n `[router.addRoute] decodeParams cannot be async for route \"${fullName}\". Async functions break matchPath/buildPath.`,\n );\n }\n\n // Validate encodeParams is not async (sync required for matchPath/buildPath)\n if (route.encodeParams?.constructor.name === \"AsyncFunction\") {\n throw new TypeError(\n `[router.addRoute] encodeParams cannot be async for route \"${fullName}\". Async functions break matchPath/buildPath.`,\n );\n }\n\n // Recursively validate children\n if (route.children) {\n for (const child of route.children) {\n const childFullName = `${fullName}.${child.name}`;\n\n validateRouteProperties(child, childFullName);\n }\n }\n}\n\n// ============================================================================\n// ForwardTo Validation\n// ============================================================================\n\n/**\n * Extracts parameter names from a path string.\n * Matches :param and *splat patterns.\n */\nfunction extractParamsFromPath(path: string): Set<string> {\n const params = new Set<string>();\n const paramRegex = /[*:]([A-Z_a-z]\\w*)/g;\n let match;\n\n while ((match = paramRegex.exec(path)) !== null) {\n params.add(match[1]);\n }\n\n return params;\n}\n\n/**\n * Extracts all parameters from multiple path segments.\n */\nfunction extractParamsFromPaths(paths: readonly string[]): Set<string> {\n const params = new Set<string>();\n\n for (const path of paths) {\n for (const param of extractParamsFromPath(path)) {\n params.add(param);\n }\n }\n\n return params;\n}\n\n/**\n * Collects all path segments for a route from batch definitions.\n * Traverses parent routes to include inherited path segments.\n */\nfunction collectPathsToRoute<Dependencies extends DefaultDependencies>(\n routes: readonly Route<Dependencies>[],\n routeName: string,\n parentName = \"\",\n paths: string[] = [],\n): string[] {\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n const currentPaths = [...paths, route.path];\n\n if (fullName === routeName) {\n return currentPaths;\n }\n\n if (route.children && routeName.startsWith(`${fullName}.`)) {\n return collectPathsToRoute(\n route.children,\n routeName,\n fullName,\n currentPaths,\n );\n }\n }\n\n /* v8 ignore next -- @preserve unreachable: callers validate existence */\n throw new Error(\n `[internal] collectPathsToRoute: route \"${routeName}\" not found`,\n );\n}\n\n/**\n * Collects all route names from a batch of routes (including children).\n */\nfunction collectRouteNames<Dependencies extends DefaultDependencies>(\n routes: readonly Route<Dependencies>[],\n parentName = \"\",\n): Set<string> {\n const names = new Set<string>();\n\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n\n names.add(fullName);\n\n if (route.children) {\n for (const childName of collectRouteNames(route.children, fullName)) {\n names.add(childName);\n }\n }\n }\n\n return names;\n}\n\n/**\n * Collects all forwardTo mappings from a batch of routes (including children).\n */\nfunction collectForwardMappings<Dependencies extends DefaultDependencies>(\n routes: readonly Route<Dependencies>[],\n parentName = \"\",\n): Map<string, string> {\n const mappings = new Map<string, string>();\n\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n\n if (route.forwardTo) {\n mappings.set(fullName, route.forwardTo);\n }\n\n if (route.children) {\n for (const [key, value] of collectForwardMappings(\n route.children,\n fullName,\n )) {\n mappings.set(key, value);\n }\n }\n }\n\n return mappings;\n}\n\n/**\n * Extracts required path parameters from route segments.\n */\nfunction getRequiredParams(segments: readonly RouteTree[]): Set<string> {\n const params = new Set<string>();\n\n for (const segment of segments) {\n // Named routes always have parsers (null only for root without path)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- route-tree guarantees parser for named routes\n for (const param of segment.parser!.urlParams) {\n params.add(param);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- route-tree guarantees parser for named routes\n for (const param of segment.parser!.spatParams) {\n params.add(param);\n }\n }\n\n return params;\n}\n\n/**\n * Checks if a route exists in the tree by navigating through childrenByName.\n */\nfunction routeExistsInTree(tree: RouteTree, routeName: string): boolean {\n const segments = routeName.split(\".\");\n let current: RouteTree | undefined = tree;\n\n for (const segment of segments) {\n current = current.childrenByName.get(segment);\n\n if (!current) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Gets the target route parameters for validation.\n */\nfunction getTargetParams<Dependencies extends DefaultDependencies>(\n targetRoute: string,\n existsInTree: boolean,\n tree: RouteTree,\n routes: readonly Route<Dependencies>[],\n): Set<string> {\n if (existsInTree) {\n const toSegments = getSegmentsByName(tree, targetRoute);\n\n // toSegments won't be null since we checked existsInTree\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return getRequiredParams(toSegments!);\n }\n\n // Target is in batch\n return extractParamsFromPaths(collectPathsToRoute(routes, targetRoute));\n}\n\n/**\n * Validates a single forward mapping for target existence and param compatibility.\n */\nfunction validateSingleForward<Dependencies extends DefaultDependencies>(\n fromRoute: string,\n targetRoute: string,\n routes: readonly Route<Dependencies>[],\n batchNames: Set<string>,\n tree: RouteTree,\n): void {\n const existsInTree = routeExistsInTree(tree, targetRoute);\n const existsInBatch = batchNames.has(targetRoute);\n\n if (!existsInTree && !existsInBatch) {\n throw new Error(\n `[router.addRoute] forwardTo target \"${targetRoute}\" does not exist ` +\n `for route \"${fromRoute}\"`,\n );\n }\n\n // Get source params\n const fromParams = extractParamsFromPaths(\n collectPathsToRoute(routes, fromRoute),\n );\n\n // Get target params\n const toParams = getTargetParams(targetRoute, existsInTree, tree, routes);\n\n // Check for missing params\n const missingParams = [...toParams].filter((p) => !fromParams.has(p));\n\n if (missingParams.length > 0) {\n throw new Error(\n `[router.addRoute] forwardTo target \"${targetRoute}\" requires params ` +\n `[${missingParams.join(\", \")}] that are not available in source route \"${fromRoute}\"`,\n );\n }\n}\n\n/**\n * Resolves a forwardTo chain to its final destination.\n * Detects cycles and enforces max depth.\n */\nexport function resolveForwardChain(\n startRoute: string,\n forwardMap: Record<string, string>,\n maxDepth = 100,\n): string {\n const visited = new Set<string>();\n const chain: string[] = [startRoute];\n let current = startRoute;\n\n while (forwardMap[current]) {\n const next = forwardMap[current];\n\n if (visited.has(next)) {\n const cycleStart = chain.indexOf(next);\n const cycle = [...chain.slice(cycleStart), next];\n\n throw new Error(`Circular forwardTo: ${cycle.join(\" â \")}`);\n }\n\n visited.add(current);\n chain.push(next);\n current = next;\n\n if (chain.length > maxDepth) {\n throw new Error(\n `forwardTo chain exceeds maximum depth (${maxDepth}): ${chain.join(\" â \")}`,\n );\n }\n }\n\n return current;\n}\n\n/**\n * Validates forwardTo targets and cycles BEFORE any modifications.\n * This ensures atomicity - if validation fails, no routes are added.\n *\n * @param routes - Routes to validate\n * @param existingForwardMap - Current forwardMap from router.config\n * @param tree - Current route tree\n *\n * @throws {Error} If forwardTo target doesn't exist\n * @throws {Error} If circular forwardTo is detected\n */\nexport function validateForwardToTargets<\n Dependencies extends DefaultDependencies,\n>(\n routes: readonly Route<Dependencies>[],\n existingForwardMap: Record<string, string>,\n tree: RouteTree,\n): void {\n const batchNames = collectRouteNames(routes);\n const batchForwards = collectForwardMappings(routes);\n\n // Merge with existing forwardMap for cycle detection\n const combinedForwardMap: Record<string, string> = { ...existingForwardMap };\n\n for (const [from, to] of batchForwards) {\n combinedForwardMap[from] = to;\n }\n\n // Validate each forwardTo target exists and params are compatible\n for (const [fromRoute, targetRoute] of batchForwards) {\n validateSingleForward(fromRoute, targetRoute, routes, batchNames, tree);\n }\n\n // Check for cycles in the combined forwardMap\n for (const fromRoute of Object.keys(combinedForwardMap)) {\n resolveForwardChain(fromRoute, combinedForwardMap);\n }\n}\n","// packages/real-router/modules/core/stateBuilder.ts\n\n/**\n * State Builder Utilities.\n *\n * Functions for building RouteTreeState from raw route segments.\n * This module handles the conversion from low-level route-node data\n * to the higher-level state representation used by real-router.\n *\n * @module core/stateBuilder\n */\n\nimport { getMetaFromSegments } from \"route-tree\";\n\nimport type {\n MatchResult,\n RouteParams,\n RouteTree,\n RouteTreeState,\n} from \"route-tree\";\n\n/**\n * Builds a dot-separated route name from segments.\n *\n * @param segments - Array of route segments with names\n * @returns Dot-separated route name (e.g., \"users.profile\")\n *\n * @example\n * ```typescript\n * const segments = [{ name: \"users\" }, { name: \"profile\" }];\n * buildNameFromSegments(segments); // \"users.profile\"\n * ```\n */\nexport function buildNameFromSegments(segments: readonly RouteTree[]): string {\n let name = \"\";\n\n for (const segment of segments) {\n if (segment.name) {\n if (name) {\n name += \".\";\n }\n\n name += segment.name;\n }\n }\n\n return name;\n}\n\n/**\n * Creates a RouteTreeState from a MatchResult.\n *\n * This function is the primary way to build a RouteTreeState when\n * you have a MatchResult from matchPathSegments() or other low-level APIs.\n *\n * @param matchResult - Result from matchPathSegments() containing segments and params\n * @param name - Optional explicit name (if not provided, built from segments)\n * @returns RouteTreeState with name, params, and meta\n *\n * @example\n * ```typescript\n * const matchResult = routeNode.matchPathSegments(\"/users/123\");\n * if (matchResult) {\n * const state = createRouteState(matchResult);\n * // { name: \"users.profile\", params: { id: \"123\" }, meta: {...} }\n * }\n * ```\n */\nexport function createRouteState<P extends RouteParams = RouteParams>(\n matchResult: MatchResult<P>,\n name?: string,\n): RouteTreeState<P> {\n const resolvedName = name ?? buildNameFromSegments(matchResult.segments);\n\n return {\n name: resolvedName,\n params: matchResult.params,\n meta: getMetaFromSegments(matchResult.segments),\n };\n}\n","// packages/core/src/namespaces/RoutesNamespace/validators.ts\n\n/**\n * Static validation functions for RoutesNamespace.\n * Called by Router facade before instance methods.\n *\n * Extracted from RoutesNamespace class for better separation of concerns.\n */\n\nimport { validateRoute } from \"route-tree\";\nimport {\n isString,\n validateRouteName,\n isParams,\n getTypeDescription,\n} from \"type-guards\";\n\nimport { validateRouteProperties, validateForwardToTargets } from \"./helpers\";\n\nimport type { Route, RouteConfigUpdate } from \"../../types\";\nimport type { DefaultDependencies } from \"@real-router/types\";\nimport type { RouteTree } from \"route-tree\";\n\n/**\n * Validates removeRoute arguments.\n */\nexport function validateRemoveRouteArgs(name: unknown): asserts name is string {\n validateRouteName(name, \"removeRoute\");\n}\n\n/**\n * Validates setRootPath arguments.\n */\nexport function validateSetRootPathArgs(\n rootPath: unknown,\n): asserts rootPath is string {\n if (typeof rootPath !== \"string\") {\n throw new TypeError(\n `[router.setRootPath] rootPath must be a string, got ${getTypeDescription(rootPath)}`,\n );\n }\n}\n\n/**\n * Validates addRoute arguments (route structure and properties).\n * State-dependent validation (duplicates, tree) happens in instance method.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- accepts any Route type\nexport function validateAddRouteArgs(routes: readonly Route<any>[]): void {\n for (const route of routes) {\n // First check if route is an object (before accessing route.name)\n // Runtime check for invalid types passed via `as any`\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- runtime check\n if (route === null || typeof route !== \"object\" || Array.isArray(route)) {\n throw new TypeError(\n `[router.addRoute] Route must be an object, got ${getTypeDescription(route)}`,\n );\n }\n\n // Validate route properties (canActivate, canDeactivate, defaultParams, async checks)\n // Note: validateRouteProperties handles children recursively\n validateRouteProperties(route, route.name);\n }\n}\n\n/**\n * Validates isActiveRoute arguments.\n */\nexport function validateIsActiveRouteArgs(\n name: unknown,\n params: unknown,\n strictEquality: unknown,\n ignoreQueryParams: unknown,\n): void {\n // Validate name - non-string throws\n if (!isString(name)) {\n throw new TypeError(`Route name must be a string`);\n }\n\n // Validate params if provided\n if (params !== undefined && !isParams(params)) {\n throw new TypeError(`[router.isActiveRoute] Invalid params structure`);\n }\n\n // Validate strictEquality if provided\n if (strictEquality !== undefined && typeof strictEquality !== \"boolean\") {\n throw new TypeError(\n `[router.isActiveRoute] strictEquality must be a boolean, got ${typeof strictEquality}`,\n );\n }\n\n // Validate ignoreQueryParams if provided\n if (\n ignoreQueryParams !== undefined &&\n typeof ignoreQueryParams !== \"boolean\"\n ) {\n throw new TypeError(\n `[router.isActiveRoute] ignoreQueryParams must be a boolean, got ${typeof ignoreQueryParams}`,\n );\n }\n}\n\n/**\n * Validates forwardState/buildState arguments.\n */\nexport function validateStateBuilderArgs(\n routeName: unknown,\n routeParams: unknown,\n methodName: string,\n): void {\n if (!isString(routeName)) {\n throw new TypeError(\n `[router.${methodName}] Invalid routeName: ${getTypeDescription(routeName)}. Expected string.`,\n );\n }\n\n if (!isParams(routeParams)) {\n throw new TypeError(\n `[router.${methodName}] Invalid routeParams: ${getTypeDescription(routeParams)}. Expected plain object.`,\n );\n }\n}\n\n/**\n * Validates updateRoute basic arguments (name and updates object structure).\n * Does NOT read property values to allow caller to cache them first.\n */\nexport function validateUpdateRouteBasicArgs<\n Dependencies extends DefaultDependencies,\n>(\n name: unknown,\n updates: unknown,\n): asserts updates is RouteConfigUpdate<Dependencies> {\n // Validate name\n validateRouteName(name, \"updateRoute\");\n\n if (name === \"\") {\n throw new ReferenceError(\n `[router.updateRoute] Invalid name: empty string. Cannot update root node.`,\n );\n }\n\n // Validate updates is not null\n\n if (updates === null) {\n throw new TypeError(\n `[real-router] updateRoute: updates must be an object, got null`,\n );\n }\n\n // Validate updates is an object (not array)\n if (typeof updates !== \"object\" || Array.isArray(updates)) {\n throw new TypeError(\n `[real-router] updateRoute: updates must be an object, got ${getTypeDescription(updates)}`,\n );\n }\n}\n\n/**\n * Validates updateRoute property types using pre-cached values.\n * Called AFTER properties are cached to ensure getters are called only once.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity -- validation logic is naturally verbose\nexport function validateUpdateRoutePropertyTypes(\n forwardTo: unknown,\n defaultParams: unknown,\n decodeParams: unknown,\n encodeParams: unknown,\n): void {\n // Validate forwardTo type (existence check is done by instance method)\n if (forwardTo !== undefined && forwardTo !== null && !isString(forwardTo)) {\n throw new TypeError(\n `[real-router] updateRoute: forwardTo must be a string or null, got ${getTypeDescription(forwardTo)}`,\n );\n }\n\n // Validate defaultParams\n if (\n defaultParams !== undefined &&\n defaultParams !== null &&\n (typeof defaultParams !== \"object\" || Array.isArray(defaultParams))\n ) {\n throw new TypeError(\n `[real-router] updateRoute: defaultParams must be an object or null, got ${getTypeDescription(defaultParams)}`,\n );\n }\n\n // Validate decodeParams\n if (decodeParams !== undefined && decodeParams !== null) {\n if (typeof decodeParams !== \"function\") {\n throw new TypeError(\n `[real-router] updateRoute: decodeParams must be a function or null, got ${typeof decodeParams}`,\n );\n }\n\n // Check for async function\n if (\n (decodeParams as { constructor: { name: string } }).constructor.name ===\n \"AsyncFunction\" ||\n (decodeParams as { toString: () => string })\n .toString()\n .includes(\"__awaiter\")\n ) {\n throw new TypeError(\n `[real-router] updateRoute: decodeParams cannot be an async function`,\n );\n }\n }\n\n // Validate encodeParams\n if (encodeParams !== undefined && encodeParams !== null) {\n if (typeof encodeParams !== \"function\") {\n throw new TypeError(\n `[real-router] updateRoute: encodeParams must be a function or null, got ${typeof encodeParams}`,\n );\n }\n\n // Check for async function\n if (\n (encodeParams as { constructor: { name: string } }).constructor.name ===\n \"AsyncFunction\" ||\n (encodeParams as { toString: () => string })\n .toString()\n .includes(\"__awaiter\")\n ) {\n throw new TypeError(\n `[real-router] updateRoute: encodeParams cannot be an async function`,\n );\n }\n }\n}\n\n/**\n * Validates buildPath arguments.\n */\nexport function validateBuildPathArgs(route: unknown): asserts route is string {\n if (!isString(route) || route === \"\") {\n throw new TypeError(\n `[real-router] buildPath: route must be a non-empty string, got ${typeof route === \"string\" ? '\"\"' : typeof route}`,\n );\n }\n}\n\n/**\n * Validates matchPath arguments.\n */\nexport function validateMatchPathArgs(path: unknown): asserts path is string {\n if (!isString(path)) {\n throw new TypeError(\n `[real-router] matchPath: path must be a string, got ${typeof path}`,\n );\n }\n}\n\n/**\n * Validates shouldUpdateNode arguments.\n */\nexport function validateShouldUpdateNodeArgs(\n nodeName: unknown,\n): asserts nodeName is string {\n if (!isString(nodeName)) {\n throw new TypeError(\n `[router.shouldUpdateNode] nodeName must be a string, got ${typeof nodeName}`,\n );\n }\n}\n\n/**\n * Validates routes for addition to the router.\n * Checks for duplicates, parent existence, and forwardTo targets/cycles.\n *\n * @param routes - Routes to validate\n * @param tree - Current route tree (optional for initial validation)\n * @param forwardMap - Current forward map for cycle detection\n */\nexport function validateRoutes<Dependencies extends DefaultDependencies>(\n routes: Route<Dependencies>[],\n tree?: RouteTree,\n forwardMap?: Record<string, string>,\n): void {\n // Tracking sets for duplicate detection\n const seenNames = new Set<string>();\n const seenPathsByParent = new Map<string, Set<string>>();\n\n for (const route of routes) {\n // Use route-tree's validateRoute for structural validation\n // (type, name, path, duplicates, parent exists, children array)\n // Note: validateRoute handles children recursively\n // When tree is undefined, only batch validation is performed (initial routes)\n validateRoute(route, \"addRoute\", tree, \"\", seenNames, seenPathsByParent);\n }\n\n // Validate forwardTo targets and cycles (only when tree is available)\n if (tree && forwardMap) {\n validateForwardToTargets(routes, forwardMap, tree);\n }\n}\n","// packages/real-router/modules/transitionPath.ts\n\nimport type { Params, State } from \"@real-router/types\";\n\n/**\n * Parameters extracted from a route segment.\n * Maps parameter names to their string values.\n */\ntype SegmentParams = Record<string, string>;\n\n/**\n * Represents a transition path between two router states.\n * Contains information about which route segments need to be activated/deactivated.\n */\ninterface TransitionPath {\n /** The common ancestor route segment where paths diverge */\n intersection: string;\n /** Route segments that need to be deactivated (in reverse order) */\n toDeactivate: string[];\n /** Route segments that need to be activated (in order) */\n toActivate: string[];\n}\n\n// Constants for better maintainability\nconst ROUTE_SEGMENT_SEPARATOR = \".\";\nconst EMPTY_INTERSECTION = \"\";\nconst DEFAULT_ROUTE_NAME = \"\";\n\n/**\n * Builds a reversed copy of a string array.\n * Optimization: single pass instead of creating intermediate array with .toReversed().\n *\n * @param arr - Source array\n * @returns New array with elements in reverse order\n * @internal\n */\nfunction reverseArray(arr: string[]): string[] {\n const len = arr.length;\n const result: string[] = [];\n\n for (let i = len - 1; i >= 0; i--) {\n result.push(arr[i]);\n }\n\n return result;\n}\n\n/**\n * Handles conversion of route names with many segments (5+).\n * Internal helper for nameToIDs function.\n *\n * Uses optimized hybrid approach: split to get segments, then slice original\n * string to build cumulative paths. This approach is 65-81% faster than\n * string concatenation for typical cases (5-10 segments).\n *\n * @param name - Route name with 5 or more segments\n * @returns Array of cumulative segment IDs\n * @throws {Error} If route depth exceeds maximum allowed\n * @internal\n */\nfunction nameToIDsGeneral(name: string): string[] {\n // We know there are at least 5 segments at this point (after fast paths)\n const segments = name.split(ROUTE_SEGMENT_SEPARATOR);\n const segmentCount = segments.length;\n\n // First segment is always just itself\n const ids: string[] = [segments[0]];\n\n // Calculate cumulative lengths and slice from original string\n // This avoids repeated string concatenation (O(kÂē) â O(k))\n let cumulativeLen = segments[0].length;\n\n for (let i = 1; i < segmentCount - 1; i++) {\n cumulativeLen += 1 + segments[i].length; // +1 for dot separator\n ids.push(name.slice(0, cumulativeLen));\n }\n\n // Last segment is always the full route name\n ids.push(name);\n\n return ids;\n}\n\n/**\n * Extracts segment-specific parameters from a state object.\n * Only includes parameters that are valid for serialization (primitives).\n *\n * @param name - Segment name to extract parameters for\n * @param state - State containing the parameters\n * @returns Object with extracted segment parameters\n */\nfunction extractSegmentParams(name: string, state: State): SegmentParams {\n const keys = state.meta?.params[name];\n\n // No parameters defined for this segment\n if (!keys || typeof keys !== \"object\") {\n return {};\n }\n\n const result: SegmentParams = {};\n\n for (const key in keys as Params) {\n // Skip inherited properties\n if (!Object.hasOwn(keys, key)) {\n continue;\n }\n\n // Skip undefined values for consistent behavior (treat { key: undefined } same as missing key)\n // Edge case: can appear from manual State creation or object merging\n // @ts-expect-error Params type doesn't allow undefined, but it can appear at runtime\n if (keys[key] === undefined) {\n continue;\n }\n\n const value = state.params[key];\n\n // Skip null/undefined values\n if (value == null) {\n continue;\n }\n\n // Only include primitives in segment params comparison.\n // Complex types (arrays, nested objects) are handled by query param serialization.\n // Note: symbol/function/bigint are rejected by isParams validation before reaching this code.\n if (\n typeof value === \"string\" ||\n typeof value === \"number\" ||\n typeof value === \"boolean\"\n ) {\n result[key] = String(value);\n }\n // Complex types silently skipped - they're serialized as query params elsewhere\n }\n\n return result;\n}\n\n/**\n * Finds the point where two state paths diverge based on segments and parameters.\n * Compares both segment names and their parameters to find the first difference.\n *\n * @param toState - Target state\n * @param fromState - Source state\n * @param toStateIds - Segment IDs for target state\n * @param fromStateIds - Segment IDs for source state\n * @param maxI - Maximum index to check (minimum of both arrays)\n * @returns Index of first difference, or maxI if all checked segments match\n */\nfunction pointOfDifference(\n toState: State,\n fromState: State,\n toStateIds: string[],\n fromStateIds: string[],\n maxI: number,\n): number {\n for (let i = 0; i < maxI; i++) {\n const toSegment = toStateIds[i];\n const fromSegment = fromStateIds[i];\n\n // Different segment names - immediate difference\n if (toSegment !== fromSegment) {\n return i;\n }\n\n // Same segment name - check parameters\n const toParams = extractSegmentParams(toSegment, toState);\n const fromParams = extractSegmentParams(fromSegment, fromState);\n\n // Fast check: different number of parameters\n const toKeys = Object.keys(toParams);\n const fromKeys = Object.keys(fromParams);\n\n if (toKeys.length !== fromKeys.length) {\n return i;\n }\n\n // Detailed check: compare parameter values\n for (const key of toKeys) {\n if (toParams[key] !== fromParams[key]) {\n return i;\n }\n }\n }\n\n return maxI;\n}\n\n/**\n * Converts a route name to an array of hierarchical segment identifiers.\n * Each segment ID includes all parent segments in the path.\n *\n * @param name - Route name in dot notation (e.g., 'users.profile.edit')\n * @returns Array of cumulative segment IDs\n * @throws {Error} If route depth exceeds maximum allowed depth\n *\n * @example\n * // Simple route\n * nameToIDs('users');\n * // Returns: ['users']\n *\n * @example\n * // Nested route\n * nameToIDs('users.profile.edit');\n * // Returns: ['users', 'users.profile', 'users.profile.edit']\n *\n * @example\n * // Empty string (root route)\n * nameToIDs('');\n * // Returns: ['']\n *\n * @remarks\n * Input parameter is NOT validated in this function for performance reasons.\n * Validation significantly slows down nameToIDs execution.\n * The input should be validated by the function/method that calls nameToIDs.\n */\nexport function nameToIDs(name: string): string[] {\n // ===== FAST PATH 1: Empty string (root route) =====\n // Most common in initial navigation\n if (!name) {\n return [DEFAULT_ROUTE_NAME];\n }\n\n // ===== FAST PATH 2: Single segment (no dots) =====\n // Very common: 'home', 'users', 'settings', etc.\n const firstDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR);\n\n if (firstDot === -1) {\n return [name];\n }\n\n // ===== FAST PATH 3: Two segments =====\n // Common: 'users.list', 'admin.dashboard', etc.\n const secondDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR, firstDot + 1);\n\n if (secondDot === -1) {\n return [\n name.slice(0, firstDot), // 'users'\n name, // 'users.list'\n ];\n }\n\n // ===== FAST PATH 4: Three segments =====\n // Common: 'users.profile.edit', 'app.settings.general', etc.\n const thirdDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR, secondDot + 1);\n\n if (thirdDot === -1) {\n return [\n name.slice(0, firstDot), // 'users'\n name.slice(0, secondDot), // 'users.profile'\n name, // 'users.profile.edit'\n ];\n }\n\n // ===== FAST PATH 5: Four segments =====\n const fourthDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR, thirdDot + 1);\n\n if (fourthDot === -1) {\n return [\n name.slice(0, firstDot),\n name.slice(0, secondDot),\n name.slice(0, thirdDot),\n name,\n ];\n }\n\n // ===== STANDARD PATH: 5+ segments =====\n // Less common, use general algorithm with optimizations\n return nameToIDsGeneral(name);\n}\n\n/**\n * Calculates the transition path between two router states.\n * Determines which route segments need to be deactivated and activated\n * to transition from one state to another.\n *\n * @param toState - Target state to transition to\n * @param fromState - Current state to transition from (optional)\n * @returns Transition path with intersection and segments to activate/deactivate\n *\n * @throws {TypeError} When toState is null or undefined\n * @throws {TypeError} When toState is not an object\n * @throws {TypeError} When toState.name is missing or not a string\n * @throws {TypeError} When toState.params is missing or not an object\n * @throws {TypeError} When toState.path is missing or not a string\n * @throws {TypeError} When toState.name contains invalid route format:\n * - Contains only whitespace (e.g., \" \")\n * - Has consecutive dots (e.g., \"users..profile\")\n * - Has leading/trailing dots (e.g., \".users\" or \"users.\")\n * - Segments don't match pattern [a-zA-Z_][a-zA-Z0-9_-]* (e.g., \"users.123\")\n * - Contains spaces or special characters (e.g., \"users profile\")\n * - Exceeds maximum length (8192 characters)\n * @throws {TypeError} When fromState is provided and has any of the validation errors listed above for toState\n *\n * @example\n * // â
Valid calls\n * getTransitionPath({ name: 'users.profile', params: {}, path: '/users/profile' });\n * getTransitionPath(toState, fromState);\n * getTransitionPath({ name: '', params: {}, path: '/' }); // root route\n *\n * @example\n * // â Invalid calls that throw TypeError\n * getTransitionPath(null); // toState is null\n * getTransitionPath(undefined); // toState is undefined\n * getTransitionPath({}); // missing required fields\n * getTransitionPath({ name: 123, params: {}, path: '/' }); // name not a string\n * getTransitionPath({ name: 'home', path: '/' }); // missing params\n * getTransitionPath({ name: 'users..profile', params: {}, path: '/' }); // consecutive dots\n * getTransitionPath({ name: '.users', params: {}, path: '/' }); // leading dot\n * getTransitionPath({ name: 'users.', params: {}, path: '/' }); // trailing dot\n * getTransitionPath({ name: 'users profile', params: {}, path: '/' }); // contains space\n * getTransitionPath({ name: 'users.123', params: {}, path: '/' }); // segment starts with number\n * getTransitionPath(validToState, { name: 'invalid..route', params: {}, path: '/' }); // fromState invalid\n *\n * @example\n * // Full activation (no fromState)\n * getTransitionPath(makeState('users.profile'));\n * // Returns: {\n * // intersection: '',\n * // toActivate: ['users', 'users.profile'],\n * // toDeactivate: []\n * // }\n *\n * @example\n * // Partial transition with common ancestor\n * getTransitionPath(\n * makeState('users.profile'),\n * makeState('users.list')\n * );\n * // Returns: {\n * // intersection: 'users',\n * // toActivate: ['users.profile'],\n * // toDeactivate: ['users.list']\n * // }\n *\n * @example\n * // Complete route change\n * getTransitionPath(\n * makeState('admin.dashboard'),\n * makeState('users.profile')\n * );\n * // Returns: {\n * // intersection: '',\n * // toActivate: ['admin', 'admin.dashboard'],\n * // toDeactivate: ['users.profile', 'users']\n * // }\n */\nexport function getTransitionPath(\n toState: State,\n fromState?: State,\n): TransitionPath {\n // ===== FAST PATH 1: Initial navigation (no fromState) =====\n // This is the best performing case in benchmarks (5M ops/sec)\n if (!fromState) {\n return {\n intersection: EMPTY_INTERSECTION,\n toActivate: nameToIDs(toState.name),\n toDeactivate: [],\n };\n }\n\n const toStateOptions = toState.meta?.options ?? {};\n\n // ===== FAST PATH 2: Force reload =====\n // Skip all optimization when reload is requested\n if (toStateOptions.reload) {\n return {\n intersection: EMPTY_INTERSECTION,\n toActivate: nameToIDs(toState.name),\n toDeactivate: reverseArray(nameToIDs(fromState.name)),\n };\n }\n\n // ===== FAST PATH 3: Missing meta or meta.params requires full reload =====\n // Check if meta or meta.params is actually missing (not just empty)\n const toHasMeta = toState.meta?.params !== undefined;\n const fromHasMeta = fromState.meta?.params !== undefined;\n\n if (!toHasMeta && !fromHasMeta) {\n // Both states missing meta.params - require full reload\n return {\n intersection: EMPTY_INTERSECTION,\n toActivate: nameToIDs(toState.name),\n toDeactivate: reverseArray(nameToIDs(fromState.name)),\n };\n }\n\n // ===== FAST PATH 4: Same routes with empty meta.params =====\n // If both have empty meta.params {}, no parameter checking needed\n if (toState.name === fromState.name && toHasMeta && fromHasMeta) {\n const toParamsEmpty =\n toState.meta && Object.keys(toState.meta.params).length === 0;\n const fromParamsEmpty =\n fromState.meta && Object.keys(fromState.meta.params).length === 0;\n\n if (toParamsEmpty && fromParamsEmpty) {\n // Both have empty params - no transition needed\n return {\n intersection: toState.name,\n toActivate: [],\n toDeactivate: [],\n };\n }\n }\n\n // ===== STANDARD PATH: Routes with parameters =====\n // Use original algorithm for complex cases with parameters\n const toStateIds = nameToIDs(toState.name);\n const fromStateIds = nameToIDs(fromState.name);\n const maxI = Math.min(fromStateIds.length, toStateIds.length);\n\n // Find where paths diverge based on segments and parameters\n // not obvious validate toState and fromState\n const i = pointOfDifference(\n toState,\n fromState,\n toStateIds,\n fromStateIds,\n maxI,\n );\n\n // Optimization: Build deactivation list in reverse order directly\n // instead of slice(i).toReversed() which creates 2 arrays\n const toDeactivate: string[] = [];\n\n for (let j = fromStateIds.length - 1; j >= i; j--) {\n toDeactivate.push(fromStateIds[j]);\n }\n\n // Build activation list (forward order for proper initialization)\n const toActivate = toStateIds.slice(i);\n\n // Determine intersection point (common ancestor)\n // Note: fromState is guaranteed to be defined here (early return on line 366)\n const intersection = i > 0 ? fromStateIds[i - 1] : EMPTY_INTERSECTION;\n\n return {\n intersection,\n toDeactivate,\n toActivate,\n };\n}\n","// packages/core/src/namespaces/RoutesNamespace/RoutesNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\nimport {\n createRouteTree,\n getSegmentsByName,\n hasSegmentsByName,\n nodeToDefinition,\n matchSegments,\n buildPath as routeNodeBuildPath,\n routeTreeToDefinitions,\n} from \"route-tree\";\nimport { isString, validateRouteName } from \"type-guards\";\n\nimport { DEFAULT_ROUTE_NAME, validatedRouteNames } from \"./constants\";\nimport {\n clearConfigEntries,\n createEmptyConfig,\n createMatchOptions,\n paramsMatch,\n paramsMatchExcluding,\n removeFromDefinitions,\n resolveForwardChain,\n sanitizeRoute,\n} from \"./helpers\";\nimport { createRouteState } from \"./stateBuilder\";\nimport {\n validateRemoveRouteArgs,\n validateSetRootPathArgs,\n validateAddRouteArgs,\n validateIsActiveRouteArgs,\n validateStateBuilderArgs,\n validateUpdateRouteBasicArgs,\n validateUpdateRoutePropertyTypes,\n validateBuildPathArgs,\n validateMatchPathArgs,\n validateShouldUpdateNodeArgs,\n validateRoutes,\n} from \"./validators\";\nimport { constants } from \"../../constants\";\nimport { createBuildOptions } from \"../../helpers\";\nimport { getTransitionPath } from \"../../transitionPath\";\n\nimport type { RouteConfig, RoutesDependencies } from \"./types\";\nimport type {\n ActivationFnFactory,\n BuildStateResultWithSegments,\n Route,\n RouteConfigUpdate,\n} from \"../../types\";\nimport type { RouteLifecycleNamespace } from \"../RouteLifecycleNamespace\";\nimport type {\n DefaultDependencies,\n Options,\n Params,\n State,\n} from \"@real-router/types\";\nimport type {\n BuildOptions,\n RouteDefinition,\n RouteTree,\n RouteTreeState,\n} from \"route-tree\";\n\n/**\n * Independent namespace for managing routes.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class RoutesNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n // =========================================================================\n // Private instance fields\n // =========================================================================\n\n readonly #definitions: RouteDefinition[] = [];\n readonly #config: RouteConfig = createEmptyConfig();\n readonly #resolvedForwardMap: Record<string, string> = Object.create(\n null,\n ) as Record<string, string>;\n\n // Pending canActivate handlers that need to be registered after router is set\n // Key: route name, Value: canActivate factory\n readonly #pendingCanActivate = new Map<\n string,\n ActivationFnFactory<Dependencies>\n >();\n\n #rootPath = \"\";\n #tree: RouteTree;\n #buildOptionsCache: BuildOptions | undefined;\n\n // Dependencies injected via setDependencies (for facade method calls)\n #deps: RoutesDependencies<Dependencies> | undefined;\n\n // Lifecycle handlers reference (set after construction)\n #lifecycleNamespace: RouteLifecycleNamespace<Dependencies> | undefined;\n\n // When true, skips validation for production performance\n readonly #noValidate: boolean;\n\n // =========================================================================\n // Constructor\n // =========================================================================\n\n constructor(routes: Route<Dependencies>[] = [], noValidate = false) {\n this.#noValidate = noValidate;\n // Sanitize routes to store only essential properties\n for (const route of routes) {\n this.#definitions.push(sanitizeRoute(route));\n }\n\n // Create initial tree\n this.#tree = createRouteTree(\n DEFAULT_ROUTE_NAME,\n this.#rootPath,\n this.#definitions,\n );\n\n // Register handlers for all routes (defaultParams, encoders, decoders, forwardTo)\n // Note: canActivate handlers are registered later when #lifecycleNamespace is set\n this.#registerAllRouteHandlers(routes);\n\n // Validate and cache forwardTo chains (detect cycles)\n // Skip validation in noValidate mode for production performance\n if (noValidate) {\n // Still need to cache resolved forwards, just skip validation\n this.#cacheForwardMap();\n } else {\n this.#validateAndCacheForwardMap();\n }\n }\n\n // =========================================================================\n // Static validation methods (delegated to validators.ts)\n // TypeScript requires explicit method declarations for assertion functions\n // =========================================================================\n\n static validateRemoveRouteArgs(name: unknown): asserts name is string {\n validateRemoveRouteArgs(name);\n }\n\n static validateSetRootPathArgs(\n rootPath: unknown,\n ): asserts rootPath is string {\n validateSetRootPathArgs(rootPath);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- accepts any Route type\n static validateAddRouteArgs(routes: readonly Route<any>[]): void {\n validateAddRouteArgs(routes);\n }\n\n static validateIsActiveRouteArgs(\n name: unknown,\n params: unknown,\n strictEquality: unknown,\n ignoreQueryParams: unknown,\n ): void {\n validateIsActiveRouteArgs(name, params, strictEquality, ignoreQueryParams);\n }\n\n static validateStateBuilderArgs(\n routeName: unknown,\n routeParams: unknown,\n methodName: string,\n ): void {\n validateStateBuilderArgs(routeName, routeParams, methodName);\n }\n\n static validateUpdateRouteBasicArgs<Deps extends DefaultDependencies>(\n name: unknown,\n updates: unknown,\n ): asserts updates is RouteConfigUpdate<Deps> {\n validateUpdateRouteBasicArgs<Deps>(name, updates);\n }\n\n static validateUpdateRoutePropertyTypes(\n forwardTo: unknown,\n defaultParams: unknown,\n decodeParams: unknown,\n encodeParams: unknown,\n ): void {\n validateUpdateRoutePropertyTypes(\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n );\n }\n\n static validateBuildPathArgs(route: unknown): asserts route is string {\n validateBuildPathArgs(route);\n }\n\n static validateMatchPathArgs(path: unknown): asserts path is string {\n validateMatchPathArgs(path);\n }\n\n static validateShouldUpdateNodeArgs(\n nodeName: unknown,\n ): asserts nodeName is string {\n validateShouldUpdateNodeArgs(nodeName);\n }\n\n static validateRoutes<Deps extends DefaultDependencies>(\n routes: Route<Deps>[],\n tree?: RouteTree,\n forwardMap?: Record<string, string>,\n ): void {\n validateRoutes(routes, tree, forwardMap);\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n /**\n * Sets dependencies and registers pending canActivate handlers.\n * canActivate handlers from initial routes are deferred until deps are set.\n */\n setDependencies(deps: RoutesDependencies<Dependencies>): void {\n this.#deps = deps;\n\n // Register pending canActivate handlers that were deferred during construction\n for (const [routeName, handler] of this.#pendingCanActivate) {\n deps.canActivate(routeName, handler);\n }\n\n // Clear pending handlers after registration\n this.#pendingCanActivate.clear();\n }\n\n /**\n * Sets the lifecycle namespace reference.\n */\n setLifecycleNamespace(\n namespace: RouteLifecycleNamespace<Dependencies> | undefined,\n ): void {\n this.#lifecycleNamespace = namespace;\n }\n\n // =========================================================================\n // Route tree operations\n // =========================================================================\n\n /**\n * Returns the root path.\n */\n getRootPath(): string {\n return this.#rootPath;\n }\n\n /**\n * Returns the route tree.\n * Used by facade for state-dependent validation.\n */\n getTree(): RouteTree {\n return this.#tree;\n }\n\n /**\n * Returns the forward record (route name -> forward target).\n * Used by facade for state-dependent validation.\n */\n getForwardRecord(): Record<string, string> {\n return this.#config.forwardMap;\n }\n\n /**\n * Sets the root path and rebuilds the tree.\n */\n setRootPath(newRootPath: string): void {\n this.#rootPath = newRootPath;\n this.#rebuildTree();\n }\n\n /**\n * Checks if a route exists.\n */\n hasRoute(name: string): boolean {\n return hasSegmentsByName(this.#tree, name);\n }\n\n /**\n * Gets a route by name with all its configuration.\n */\n getRoute(name: string): Route<Dependencies> | undefined {\n const segments = getSegmentsByName(this.#tree, name);\n\n if (!segments) {\n return undefined;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n const targetNode = segments.at(-1)!;\n const definition = nodeToDefinition(targetNode);\n\n return this.#enrichRoute(definition, name);\n }\n\n /**\n * Adds one or more routes to the router.\n * Input already validated by facade (properties and state-dependent checks).\n *\n * @param routes - Routes to add\n */\n addRoutes(routes: Route<Dependencies>[]): void {\n // Add to definitions\n for (const route of routes) {\n this.#definitions.push(sanitizeRoute(route));\n }\n\n // Register handlers\n this.#registerAllRouteHandlers(routes);\n\n // Rebuild tree\n this.#rebuildTree();\n\n // Validate and cache forwardTo chains\n this.#refreshForwardMap();\n }\n\n /**\n * Removes a route and all its children.\n *\n * @param name - Route name (already validated)\n * @returns true if removed, false if not found\n */\n removeRoute(name: string): boolean {\n const wasRemoved = removeFromDefinitions(this.#definitions, name);\n\n if (!wasRemoved) {\n return false;\n }\n\n // Clear configurations for removed route\n this.#clearRouteConfigurations(name);\n\n // Rebuild tree\n this.#rebuildTree();\n\n // Revalidate forward chains\n this.#refreshForwardMap();\n\n return true;\n }\n\n /**\n * Updates a route's configuration in place without rebuilding the tree.\n * This is used by Router.updateRoute to directly modify config entries\n * without destroying other routes' forwardMap references.\n *\n * @param name - Route name\n * @param updates - Config updates to apply\n * @param updates.forwardTo - Forward target route name (null to clear)\n * @param updates.defaultParams - Default parameters (null to clear)\n * @param updates.decodeParams - Params decoder function (null to clear)\n * @param updates.encodeParams - Params encoder function (null to clear)\n */\n // eslint-disable-next-line sonarjs/cognitive-complexity -- simple config updates\n updateRouteConfig(\n name: string,\n updates: {\n forwardTo?: string | null | undefined;\n defaultParams?: Params | null | undefined;\n decodeParams?: ((params: Params) => Params) | null | undefined;\n encodeParams?: ((params: Params) => Params) | null | undefined;\n },\n ): void {\n // Update forwardTo\n if (updates.forwardTo !== undefined) {\n if (updates.forwardTo === null) {\n delete this.#config.forwardMap[name];\n } else {\n this.#config.forwardMap[name] = updates.forwardTo;\n }\n\n this.#refreshForwardMap();\n }\n\n // Update defaultParams\n if (updates.defaultParams !== undefined) {\n if (updates.defaultParams === null) {\n delete this.#config.defaultParams[name];\n } else {\n this.#config.defaultParams[name] = updates.defaultParams;\n }\n }\n\n // Update decoders with fallback wrapper\n // Runtime guard: fallback to params if decoder returns undefined (bad user code)\n if (updates.decodeParams !== undefined) {\n if (updates.decodeParams === null) {\n delete this.#config.decoders[name];\n } else {\n const decoder = updates.decodeParams;\n\n this.#config.decoders[name] = (params: Params): Params =>\n (decoder(params) as Params | undefined) ?? params;\n }\n }\n\n // Update encoders with fallback wrapper\n // Runtime guard: fallback to params if encoder returns undefined (bad user code)\n if (updates.encodeParams !== undefined) {\n if (updates.encodeParams === null) {\n delete this.#config.encoders[name];\n } else {\n const encoder = updates.encodeParams;\n\n this.#config.encoders[name] = (params: Params): Params =>\n (encoder(params) as Params | undefined) ?? params;\n }\n }\n }\n\n /**\n * Clears all routes from the router.\n */\n clearRoutes(): void {\n this.#definitions.length = 0;\n\n // Clear all config entries\n for (const key in this.#config.decoders) {\n delete this.#config.decoders[key];\n }\n\n for (const key in this.#config.encoders) {\n delete this.#config.encoders[key];\n }\n\n for (const key in this.#config.defaultParams) {\n delete this.#config.defaultParams[key];\n }\n\n for (const key in this.#config.forwardMap) {\n delete this.#config.forwardMap[key];\n }\n\n // Clear forward cache\n for (const key in this.#resolvedForwardMap) {\n delete this.#resolvedForwardMap[key];\n }\n\n // Rebuild empty tree\n this.#rebuildTree();\n }\n\n // =========================================================================\n // Path operations\n // =========================================================================\n\n /**\n * Builds a URL path for a route.\n * Note: Argument validation is done by facade (Router.ts) via validateBuildPathArgs.\n *\n * @param route - Route name\n * @param params - Route parameters\n * @param options - Router options\n * @param segments - Optional pre-computed segments to avoid duplicate lookup\n */\n buildPath(\n route: string,\n params?: Params,\n options?: Options,\n segments?: readonly unknown[],\n ): string {\n if (route === constants.UNKNOWN_ROUTE) {\n return isString(params?.path) ? params.path : \"\";\n }\n\n // R2 optimization: avoid spread when no defaultParams\n const paramsWithDefault = Object.hasOwn(this.#config.defaultParams, route)\n ? { ...this.#config.defaultParams[route], ...params }\n : (params ?? {});\n\n // Apply custom encoder if defined\n const encodedParams =\n typeof this.#config.encoders[route] === \"function\"\n ? this.#config.encoders[route]({ ...paramsWithDefault })\n : paramsWithDefault;\n\n // Use cached buildOptions if available\n const buildOptions =\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- Router.ts always passes options\n this.#buildOptionsCache ?? createBuildOptions(options!);\n\n return routeNodeBuildPath(\n this.#tree,\n route,\n encodedParams,\n buildOptions,\n // Cast to RouteTree[] - segments come from getSegmentsByName which returns RouteTree[]\n segments as readonly RouteTree[] | undefined,\n );\n }\n\n /**\n * Matches a URL path to a route in the tree.\n * Note: Argument validation is done by facade (Router.ts) via validateMatchPathArgs.\n */\n matchPath<P extends Params = Params, MP extends Params = Params>(\n path: string,\n source?: string,\n options?: Options,\n ): State<P, MP> | undefined {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- Router.ts always passes options\n const opts = options!;\n const matchOptions = createMatchOptions(opts);\n const matchResult = matchSegments(this.#tree, path, matchOptions);\n\n if (matchResult) {\n const routeState = createRouteState(matchResult);\n const { name, params, meta } = routeState;\n\n const decodedParams =\n typeof this.#config.decoders[name] === \"function\"\n ? this.#config.decoders[name](params as Params)\n : params;\n\n const { name: routeName, params: routeParams } = this.forwardState<P>(\n name,\n decodedParams as P,\n );\n\n const builtPath = opts.rewritePathOnMatch\n ? this.buildPath(routeName, routeParams, opts)\n : path;\n\n // Create state using deps.makeState\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- deps is always set by Router.ts\n return this.#deps!.makeState<P, MP>(routeName, routeParams, builtPath, {\n params: meta as MP,\n options: {},\n source,\n redirected: false,\n });\n }\n\n return undefined;\n }\n\n /**\n * Applies forwardTo and returns resolved state with merged defaultParams.\n *\n * Merges params in order:\n * 1. Source route defaultParams\n * 2. Provided params\n * 3. Target route defaultParams (after resolving forwardTo)\n */\n forwardState<P extends Params = Params>(\n name: string,\n params: P,\n ): { name: string; params: P } {\n const resolvedName = this.#resolvedForwardMap[name] ?? name;\n\n // Merge source route's defaultParams with provided params\n const paramsWithSource = Object.hasOwn(this.#config.defaultParams, name)\n ? { ...this.#config.defaultParams[name], ...params }\n : { ...params };\n\n // If forwarded to different route, merge target's defaultParams\n if (\n resolvedName !== name &&\n Object.hasOwn(this.#config.defaultParams, resolvedName)\n ) {\n return {\n name: resolvedName,\n params: {\n ...this.#config.defaultParams[resolvedName],\n ...paramsWithSource,\n } as P,\n };\n }\n\n return { name: resolvedName, params: paramsWithSource };\n }\n\n /**\n * Builds a RouteTreeState from already-resolved route name and params.\n * Called by Router.buildState after forwardState is applied at facade level.\n * This allows plugins to intercept forwardState.\n */\n buildStateResolved(\n resolvedName: string,\n resolvedParams: Params,\n ): RouteTreeState | undefined {\n const segments = getSegmentsByName(this.#tree, resolvedName);\n\n if (!segments) {\n return undefined;\n }\n\n return createRouteState({ segments, params: resolvedParams }, resolvedName);\n }\n\n /**\n * Builds a RouteTreeState with segments from already-resolved route name and params.\n * Called by Router.buildStateWithSegments after forwardState is applied at facade level.\n * This allows plugins to intercept forwardState.\n */\n buildStateWithSegmentsResolved<P extends Params = Params>(\n resolvedName: string,\n resolvedParams: P,\n ): BuildStateResultWithSegments<P> | undefined {\n const segments = getSegmentsByName(this.#tree, resolvedName);\n\n if (!segments) {\n return undefined;\n }\n\n const state = createRouteState<P>(\n { segments, params: resolvedParams },\n resolvedName,\n );\n\n return { state, segments };\n }\n\n /**\n * Initializes buildOptions cache.\n * Called from routerLifecycle at router.start().\n */\n initBuildOptionsCache(options: Options): void {\n this.#buildOptionsCache = createBuildOptions(options);\n }\n\n /**\n * Clears buildOptions cache.\n * Called from routerLifecycle at router.stop().\n */\n clearBuildOptionsCache(): void {\n this.#buildOptionsCache = undefined;\n }\n\n // =========================================================================\n // Query operations\n // =========================================================================\n\n /**\n * Checks if a route is currently active.\n */\n isActiveRoute(\n name: string,\n params: Params = {},\n strictEquality = false,\n ignoreQueryParams = true,\n ): boolean {\n // Fast path: skip regex validation for already-validated route names\n if (!validatedRouteNames.has(name)) {\n validateRouteName(name, \"isActiveRoute\");\n validatedRouteNames.add(name);\n }\n\n // Note: empty string check is handled by Router.ts facade\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- deps is always set by Router.ts\n const activeState = this.#deps!.getState();\n\n if (!activeState) {\n return false;\n }\n\n const activeName = activeState.name;\n\n // Fast path: check if routes are related before expensive operations\n if (\n activeName !== name &&\n !activeName.startsWith(`${name}.`) &&\n !name.startsWith(`${activeName}.`)\n ) {\n return false;\n }\n\n const defaultParams = this.#config.defaultParams[name] as\n | Params\n | undefined;\n\n // Exact match case\n if (strictEquality || activeName === name) {\n const effectiveParams = defaultParams\n ? { ...defaultParams, ...params }\n : params;\n\n const targetState: State = {\n name,\n params: effectiveParams,\n path: \"\",\n };\n\n return (\n /* v8 ignore next -- @preserve unreachable: #deps always set by Router constructor */\n this.#deps?.areStatesEqual(\n targetState,\n activeState,\n ignoreQueryParams,\n ) ?? false\n );\n }\n\n // Hierarchical check: activeState is a descendant of target (name)\n const activeParams = activeState.params;\n\n if (!paramsMatch(params, activeParams)) {\n return false;\n }\n\n // Check defaultParams (skip keys already in params)\n return (\n !defaultParams ||\n paramsMatchExcluding(defaultParams, activeParams, params)\n );\n }\n\n /**\n * Creates a predicate function to check if a route node should be updated.\n * Note: Argument validation is done by facade (Router.ts) via validateShouldUpdateNodeArgs.\n */\n shouldUpdateNode(\n nodeName: string,\n ): (toState: State, fromState?: State) => boolean {\n return (toState: State, fromState?: State): boolean => {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!(toState && typeof toState === \"object\" && \"name\" in toState)) {\n throw new TypeError(\n \"[router.shouldUpdateNode] toState must be valid State object\",\n );\n }\n\n if (toState.meta?.options.reload) {\n return true;\n }\n\n if (nodeName === DEFAULT_ROUTE_NAME && !fromState) {\n return true;\n }\n\n const { intersection, toActivate, toDeactivate } = getTransitionPath(\n toState,\n fromState,\n );\n\n if (nodeName === intersection) {\n return true;\n }\n\n if (toActivate.includes(nodeName)) {\n return true;\n }\n\n return toDeactivate.includes(nodeName);\n };\n }\n\n /**\n * Returns the config object.\n */\n getConfig(): RouteConfig {\n return this.#config;\n }\n\n /**\n * Returns URL params for a route.\n * Used by StateNamespace.\n */\n getUrlParams(name: string): string[] {\n const segments = getSegmentsByName(this.#tree, name);\n\n if (!segments) {\n return [];\n }\n\n return this.#collectUrlParamsArray(segments);\n }\n\n /**\n * Returns the resolved forward map.\n */\n getResolvedForwardMap(): Record<string, string> {\n return this.#resolvedForwardMap;\n }\n\n /**\n * Sets resolved forward map (used by clone).\n */\n setResolvedForwardMap(map: Record<string, string>): void {\n Object.assign(this.#resolvedForwardMap, map);\n }\n\n /**\n * Creates a clone of the routes for a new router (from tree).\n */\n cloneRoutes(): Route<Dependencies>[] {\n return routeTreeToDefinitions(this.#tree) as Route<Dependencies>[];\n }\n\n // =========================================================================\n // Public validation methods (used by Router facade)\n // =========================================================================\n\n /**\n * Validates that forwardTo target doesn't require params that source doesn't have.\n * Used by updateRoute for forwardTo validation.\n */\n validateForwardToParamCompatibility(\n sourceName: string,\n targetName: string,\n ): void {\n // Note: hasRoute() is always called before this method, so segments are guaranteed to exist\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- hasRoute() validates existence\n const sourceSegments = getSegmentsByName(this.#tree, sourceName)!;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- hasRoute() validates existence\n const targetSegments = getSegmentsByName(this.#tree, targetName)!;\n\n // Get source and target URL params using helper\n const sourceParams = this.#collectUrlParams(sourceSegments);\n const targetParams = this.#collectUrlParamsArray(targetSegments);\n\n // Check if target requires params that source doesn't have\n const missingParams = targetParams.filter(\n (param) => !sourceParams.has(param),\n );\n\n if (missingParams.length > 0) {\n throw new Error(\n `[real-router] forwardTo target \"${targetName}\" requires params ` +\n `[${missingParams.join(\", \")}] that are not available in source route \"${sourceName}\"`,\n );\n }\n }\n\n /**\n * Validates that adding forwardTo doesn't create a cycle.\n * Creates a test map with the new entry and uses resolveForwardChain\n * to detect cycles before any mutation happens.\n * Used by updateRoute for forwardTo validation.\n */\n validateForwardToCycle(sourceName: string, targetName: string): void {\n // Create a test map with the new entry to validate BEFORE mutation\n const testMap = {\n ...this.#config.forwardMap,\n [sourceName]: targetName,\n };\n\n // resolveForwardChain will throw if cycle is detected or max depth exceeded\n resolveForwardChain(sourceName, testMap);\n }\n\n /**\n * Validates removeRoute constraints.\n * Returns false if removal should be blocked (route is active).\n * Logs warnings for edge cases.\n *\n * @param name - Route name to remove\n * @param currentStateName - Current active route name (or undefined)\n * @param isNavigating - Whether navigation is in progress\n * @returns true if removal can proceed, false if blocked\n */\n validateRemoveRoute(\n name: string,\n currentStateName: string | undefined,\n isNavigating: boolean,\n ): boolean {\n // Check if trying to remove currently active route (or its parent)\n if (currentStateName) {\n const isExactMatch = currentStateName === name;\n const isParentOfCurrent = currentStateName.startsWith(`${name}.`);\n\n if (isExactMatch || isParentOfCurrent) {\n const suffix = isExactMatch ? \"\" : ` (current: \"${currentStateName}\")`;\n\n logger.warn(\n \"router.removeRoute\",\n `Cannot remove route \"${name}\" â it is currently active${suffix}. Navigate away first.`,\n );\n\n return false;\n }\n }\n\n // Warn if navigation is in progress (but allow removal)\n if (isNavigating) {\n logger.warn(\n \"router.removeRoute\",\n `Route \"${name}\" removed while navigation is in progress. This may cause unexpected behavior.`,\n );\n }\n\n return true;\n }\n\n /**\n * Validates clearRoutes operation.\n * Returns false if operation should be blocked (navigation in progress).\n *\n * @param isNavigating - Whether navigation is in progress\n * @returns true if clearRoutes can proceed, false if blocked\n */\n validateClearRoutes(isNavigating: boolean): boolean {\n if (isNavigating) {\n logger.error(\n \"router.clearRoutes\",\n \"Cannot clear routes while navigation is in progress. Wait for navigation to complete.\",\n );\n\n return false;\n }\n\n return true;\n }\n\n /**\n * Validates updateRoute instance-level constraints (route existence, forwardTo).\n * Called after static validation passes.\n *\n * @param name - Route name (already validated by static method)\n * @param forwardTo - Cached forwardTo value (to avoid calling getter twice)\n */\n validateUpdateRoute(\n name: string,\n forwardTo: string | null | undefined,\n ): void {\n // Validate route exists\n if (!this.hasRoute(name)) {\n throw new ReferenceError(\n `[real-router] updateRoute: route \"${name}\" does not exist`,\n );\n }\n\n // Validate forwardTo target exists and is valid\n if (forwardTo !== undefined && forwardTo !== null) {\n if (!this.hasRoute(forwardTo)) {\n throw new Error(\n `[real-router] updateRoute: forwardTo target \"${forwardTo}\" does not exist`,\n );\n }\n\n // Check forwardTo param compatibility\n this.validateForwardToParamCompatibility(name, forwardTo);\n\n // Check for cycle detection\n this.validateForwardToCycle(name, forwardTo);\n }\n }\n\n // =========================================================================\n // Private methods\n // =========================================================================\n\n #rebuildTree(): void {\n this.#tree = createRouteTree(\n DEFAULT_ROUTE_NAME,\n this.#rootPath,\n this.#definitions,\n );\n }\n\n /**\n * Collects URL params from segments into a Set.\n *\n * @param segments - Non-null segments (caller must validate existence first)\n */\n #collectUrlParams(segments: readonly RouteTree[]): Set<string> {\n const params = new Set<string>();\n\n for (const segment of segments) {\n // Named routes always have parsers (null only for root without path)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- route-tree guarantees parser for named routes\n for (const param of segment.parser!.urlParams) {\n params.add(param);\n }\n }\n\n return params;\n }\n\n /**\n * Collects URL params from segments into an array.\n *\n * @param segments - Non-null segments (caller must validate existence first)\n */\n #collectUrlParamsArray(segments: readonly RouteTree[]): string[] {\n const params: string[] = [];\n\n for (const segment of segments) {\n // Named routes always have parsers (null only for root without path)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- route-tree guarantees parser for named routes\n for (const param of segment.parser!.urlParams) {\n params.push(param);\n }\n }\n\n return params;\n }\n\n /**\n * Refreshes forward map cache, conditionally validating based on noValidate flag.\n */\n #refreshForwardMap(): void {\n if (this.#noValidate) {\n this.#cacheForwardMap();\n } else {\n this.#validateAndCacheForwardMap();\n }\n }\n\n #validateAndCacheForwardMap(): void {\n // Clear existing cache\n for (const key in this.#resolvedForwardMap) {\n delete this.#resolvedForwardMap[key];\n }\n\n // Resolve all chains\n for (const fromRoute of Object.keys(this.#config.forwardMap)) {\n this.#resolvedForwardMap[fromRoute] = resolveForwardChain(\n fromRoute,\n this.#config.forwardMap,\n );\n }\n }\n\n /**\n * Caches forward chains without validation (noValidate mode).\n * Simply resolves chains without cycle detection or max depth checks.\n */\n #cacheForwardMap(): void {\n // Clear existing cache\n for (const key in this.#resolvedForwardMap) {\n delete this.#resolvedForwardMap[key];\n }\n\n // Resolve chains without validation\n for (const fromRoute of Object.keys(this.#config.forwardMap)) {\n let current = fromRoute;\n\n while (this.#config.forwardMap[current]) {\n current = this.#config.forwardMap[current];\n }\n\n this.#resolvedForwardMap[fromRoute] = current;\n }\n }\n\n #clearRouteConfigurations(routeName: string): void {\n const shouldClear = (n: string): boolean =>\n n === routeName || n.startsWith(`${routeName}.`);\n\n clearConfigEntries(this.#config.decoders, shouldClear);\n clearConfigEntries(this.#config.encoders, shouldClear);\n clearConfigEntries(this.#config.defaultParams, shouldClear);\n clearConfigEntries(this.#config.forwardMap, shouldClear);\n\n // Clear forwardMap entries pointing TO deleted route\n clearConfigEntries(this.#config.forwardMap, (key) =>\n shouldClear(this.#config.forwardMap[key]),\n );\n\n // Clear lifecycle handlers if namespace is set\n /* v8 ignore next -- @preserve unreachable: Router always sets lifecycleNamespace */\n if (this.#lifecycleNamespace) {\n const [canDeactivateFactories, canActivateFactories] =\n this.#lifecycleNamespace.getFactories();\n\n for (const n of Object.keys(canActivateFactories)) {\n if (shouldClear(n)) {\n this.#lifecycleNamespace.clearCanActivate(n, true);\n }\n }\n\n for (const n of Object.keys(canDeactivateFactories)) {\n if (shouldClear(n)) {\n this.#lifecycleNamespace.clearCanDeactivate(n, true);\n }\n }\n }\n }\n\n #registerAllRouteHandlers(\n routes: readonly Route<Dependencies>[],\n parentName = \"\",\n ): void {\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n\n this.#registerSingleRouteHandlers(route, fullName);\n\n if (route.children) {\n this.#registerAllRouteHandlers(route.children, fullName);\n }\n }\n }\n\n #registerSingleRouteHandlers(\n route: Route<Dependencies>,\n fullName: string,\n ): void {\n // Register canActivate via deps.canActivate (allows tests to spy on router.canActivate)\n if (route.canActivate) {\n if (this.#deps) {\n // Deps available, register immediately\n this.#deps.canActivate(fullName, route.canActivate);\n } else {\n // Deps not set yet, store for later registration\n this.#pendingCanActivate.set(fullName, route.canActivate);\n }\n }\n\n // Register forwardTo\n if (route.forwardTo) {\n this.#registerForwardTo(route, fullName);\n }\n\n // Register transformers with fallback wrapper\n if (route.decodeParams) {\n this.#config.decoders[fullName] = (params: Params): Params =>\n route.decodeParams?.(params) ?? params;\n }\n\n if (route.encodeParams) {\n this.#config.encoders[fullName] = (params: Params): Params =>\n route.encodeParams?.(params) ?? params;\n }\n\n // Register defaults\n if (route.defaultParams) {\n this.#config.defaultParams[fullName] = route.defaultParams;\n }\n }\n\n #registerForwardTo(route: Route<Dependencies>, fullName: string): void {\n if (route.canActivate) {\n logger.warn(\n \"real-router\",\n `Route \"${fullName}\" has both forwardTo and canActivate. ` +\n `canActivate will be ignored because forwardTo creates a redirect (industry standard). ` +\n `Move canActivate to the target route \"${route.forwardTo}\".`,\n );\n }\n\n // forwardTo is guaranteed to exist at this point\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.#config.forwardMap[fullName] = route.forwardTo!;\n }\n\n #enrichRoute(\n routeDef: RouteDefinition,\n routeName: string,\n ): Route<Dependencies> {\n const route: Route<Dependencies> = {\n name: routeDef.name,\n path: routeDef.path,\n };\n\n const forwardTo = this.#config.forwardMap[routeName];\n\n if (forwardTo) {\n route.forwardTo = forwardTo;\n }\n\n if (routeName in this.#config.defaultParams) {\n route.defaultParams = this.#config.defaultParams[routeName];\n }\n\n if (routeName in this.#config.decoders) {\n route.decodeParams = this.#config.decoders[routeName];\n }\n\n if (routeName in this.#config.encoders) {\n route.encodeParams = this.#config.encoders[routeName];\n }\n\n /* v8 ignore next -- @preserve unreachable: Router always sets lifecycleNamespace */\n if (this.#lifecycleNamespace) {\n const [, canActivateFactories] = this.#lifecycleNamespace.getFactories();\n\n if (routeName in canActivateFactories) {\n route.canActivate = canActivateFactories[routeName];\n }\n }\n\n if (routeDef.children) {\n route.children = routeDef.children.map((child) =>\n this.#enrichRoute(child, `${routeName}.${child.name}`),\n );\n }\n\n return route;\n }\n}\n","import { logger } from \"@real-router/logger\";\n\nimport type { RouterError } from \"../../RouterError\";\nimport type { DoneFn, State } from \"@real-router/types\";\n\nexport const noop = (): void => {};\n\n/**\n * Safely invokes a callback, catching and logging any errors.\n * Prevents user callback errors from crashing the router.\n */\nexport function safeCallback(\n callback: DoneFn,\n ...args: [error?: RouterError, state?: State]\n): void {\n try {\n callback(...args);\n } catch (error) {\n logger.error(\"router.navigate\", \"Error in navigation callback:\", error);\n }\n}\n","// packages/logger/modules/constants.ts\n\nimport type { LogLevel, LogLevelConfig } from \"./types\";\n\n/**\n * Numeric mapping for log message severity levels.\n *\n * Maps each severity level to a numeric value for threshold comparison.\n * Lower values = lower severity, higher values = higher severity.\n *\n * Used internally to determine if a message should be filtered based on\n * the configured threshold level.\n *\n * Mapping:\n * - `log`: 0 (lowest severity - informational)\n * - `warn`: 1 (medium severity - warnings)\n * - `error`: 2 (highest severity - critical errors)\n *\n * @example\n * ```ts\n * const messageLevel = LOG_LEVELS['warn']; // 1\n * const threshold = 2; // error-only\n * const shouldFilter = messageLevel < threshold; // true (warn is filtered)\n * ```\n *\n * @internal This is used for internal filtering logic\n */\nexport const LOG_LEVELS: Record<LogLevel, number> = {\n log: 0,\n warn: 1,\n error: 2,\n};\n\n/**\n * Numeric thresholds for logger configuration levels.\n *\n * Maps each configuration level to a minimum threshold value.\n * Messages with a severity level below this threshold are filtered out.\n *\n * Threshold logic:\n * - A message is shown if: `LOG_LEVELS[messageLevel] >= LEVEL_CONFIGS[configLevel]`\n * - Higher threshold value = stricter filtering = fewer messages shown\n *\n * Mapping:\n * - `all`: 0 (no filtering - show everything)\n * - Shows: log (0), warn (1), error (2) â\n * - `warn-error`: 1 (filter log messages)\n * - Shows: warn (1), error (2) â\n * - Filters: log (0) â\n * - `error-only`: 2 (filter log and warn messages)\n * - Shows: error (2) â\n * - Filters: log (0), warn (1) â\n * - `none`: 3 (filter all messages - complete silence)\n * - Filters: log (0), warn (1), error (2) â\n *\n * @example\n * ```ts\n * // Configuration: warn-error\n * const threshold = LEVEL_CONFIGS['warn-error']; // 1\n *\n * // Check if 'log' message should be shown\n * LOG_LEVELS['log'] >= threshold // 0 >= 1 = false (filtered)\n *\n * // Check if 'warn' message should be shown\n * LOG_LEVELS['warn'] >= threshold // 1 >= 1 = true (shown)\n *\n * // Check if 'error' message should be shown\n * LOG_LEVELS['error'] >= threshold // 2 >= 1 = true (shown)\n * ```\n *\n * @internal This is used for internal threshold comparison\n */\nexport const LEVEL_CONFIGS: Record<LogLevelConfig, number> = {\n all: 0,\n \"warn-error\": 1,\n \"error-only\": 2,\n none: 3,\n};\n","// packages/logger/modules/Logger.ts\n\nimport { LOG_LEVELS, LEVEL_CONFIGS } from \"./constants\";\n\nimport type {\n LogLevel,\n LoggerConfig,\n LogLevelConfig,\n LogCallback,\n} from \"./types\";\n\n/**\n * Internal config type with required callbackIgnoresLevel\n * (always initialized to false)\n */\ninterface InternalLoggerConfig {\n level: LogLevelConfig;\n callback?: LogCallback | undefined;\n callbackIgnoresLevel: boolean;\n}\n\n/**\n * Logger class for centralized logging with configurable levels and callbacks.\n *\n * Features:\n * - Three log levels: log, warn, error\n * - Configurable threshold filtering (all, warn, error, none)\n * - Optional callback for custom log processing\n * - Callback can optionally ignore level threshold\n * - Context-based message formatting\n *\n * @example\n * ```ts\n * import { logger } from './Logger';\n *\n * // Configure logger\n * logger.configure({ level: 'warn' });\n *\n * // Use logger\n * logger.log('Router', 'Navigation started'); // Won't show (below threshold)\n * logger.warn('Router', 'Deprecated API used'); // Will show\n * ```\n */\nclass Logger {\n /** Internal configuration storage using private field */\n #config: InternalLoggerConfig = {\n level: \"all\",\n callbackIgnoresLevel: false,\n };\n\n /** Cached numeric threshold value for performance (avoids repeated lookups) */\n #currentThreshold = 0;\n\n /**\n * Configures the logger with new settings.\n *\n * @param config - Partial configuration to merge with existing config\n * @param config.level - Minimum log level to output ('all' | 'warn' | 'error' | 'none')\n * @param config.callback - Optional callback function to receive log messages\n * @param config.callbackIgnoresLevel - If true, callback receives all messages regardless of level\n *\n * @example\n * ```ts\n * // Set minimum level to warnings\n * logger.configure({ level: 'warn' });\n *\n * // Add custom callback that ignores level\n * logger.configure({\n * callback: (level, context, message) => {\n * sendToAnalytics({ level, context, message });\n * },\n * callbackIgnoresLevel: true\n * });\n * ```\n */\n configure(config: Partial<LoggerConfig>): void {\n if (config.level !== undefined) {\n // Validate that the provided level is a valid configuration level\n if (!(config.level in LEVEL_CONFIGS)) {\n throw new Error(\n `Invalid log level: \"${config.level}\". Valid levels are: ${Object.keys(LEVEL_CONFIGS).join(\", \")}`,\n );\n }\n\n this.#config.level = config.level;\n this.#currentThreshold = LEVEL_CONFIGS[config.level];\n }\n if (\"callback\" in config) {\n this.#config.callback = config.callback;\n }\n if (config.callbackIgnoresLevel !== undefined) {\n this.#config.callbackIgnoresLevel = config.callbackIgnoresLevel;\n }\n }\n\n /**\n * Returns the current logger configuration.\n *\n * @returns Current configuration object with level, callback, and callbackIgnoresLevel\n *\n * @example\n * ```ts\n * const config = logger.getConfig();\n * console.log(config.level); // 'warn'\n * console.log(config.callbackIgnoresLevel); // false\n * ```\n */\n getConfig(): LoggerConfig {\n return {\n level: this.#config.level,\n callback: this.#config.callback,\n callbackIgnoresLevel: this.#config.callbackIgnoresLevel,\n };\n }\n\n /**\n * Logs an informational message at 'log' level.\n *\n * This is the lowest severity level. Messages are shown when level is 'all'.\n *\n * @param context - Context identifier (e.g., 'Router', 'Plugin')\n * @param message - Main log message\n * @param args - Additional arguments to log (objects, arrays, etc.)\n *\n * @example\n * ```ts\n * logger.log('Router', 'Navigation started', { from: '/home', to: '/about' });\n * // Output: [Router] Navigation started { from: '/home', to: '/about' }\n * ```\n */\n log(context: string, message: string, ...args: unknown[]): void {\n this.#writeLog(\"log\", context, message, args);\n }\n\n /**\n * Logs a warning message at 'warn' level.\n *\n * Use for deprecation notices, non-critical issues, or potential problems.\n * Messages are shown when level is 'all' or 'warn'.\n *\n * @param context - Context identifier (e.g., 'Router', 'Plugin')\n * @param message - Warning message\n * @param args - Additional arguments to log\n *\n * @example\n * ```ts\n * logger.warn('Router', 'Using deprecated API', { method: 'oldNavigate' });\n * // Output: [Router] Using deprecated API { method: 'oldNavigate' }\n * ```\n */\n warn(context: string, message: string, ...args: unknown[]): void {\n this.#writeLog(\"warn\", context, message, args);\n }\n\n /**\n * Logs an error message at 'error' level.\n *\n * Use for critical errors, exceptions, or failures that require attention.\n * Messages are shown when level is 'all', 'warn', or 'error'.\n *\n * @param context - Context identifier (e.g., 'Router', 'Plugin')\n * @param message - Error message\n * @param args - Additional arguments to log (often error objects)\n *\n * @example\n * ```ts\n * logger.error('Router', 'Navigation failed', new Error('Route not found'));\n * // Output: [Router] Navigation failed Error: Route not found\n * ```\n */\n error(context: string, message: string, ...args: unknown[]): void {\n this.#writeLog(\"error\", context, message, args);\n }\n\n /**\n * Central logging method that coordinates console output and callback invocation.\n *\n * This method implements the core logging logic:\n * 1. Early exit optimization for 'none' level (unless callback ignores level)\n * 2. Level threshold comparison for console output filtering\n * 3. Delegates to #writeToConsole and #invokeCallback\n *\n * @param level - Log level ('log' | 'warn' | 'error')\n * @param context - Context identifier\n * @param message - Log message\n * @param args - Additional arguments\n *\n * @private\n */\n #writeLog(\n level: LogLevel,\n context: string,\n message: string,\n args: unknown[],\n ): void {\n // Early exit optimization: if level is 'none' and callback doesn't ignore level,\n // skip all processing (both console and callback)\n if (this.#config.level === \"none\" && !this.#config.callbackIgnoresLevel) {\n return;\n }\n\n // Convert message level to numeric value for threshold comparison\n // LOG_LEVELS: { log: 0, warn: 1, error: 2 }\n const messageLevelValue = LOG_LEVELS[level];\n\n // Determine if this message should skip console output\n // Example: if threshold is 'warn' (1), then 'log' messages (0) are skipped\n const shouldSkipConsole = messageLevelValue < this.#currentThreshold;\n\n // Console output (respects level threshold)\n if (!shouldSkipConsole) {\n this.#writeToConsole(level, context, message, args);\n }\n\n // Callback handling (may ignore level threshold based on config)\n this.#invokeCallback(level, context, message, shouldSkipConsole, args);\n }\n\n /**\n * Writes a formatted log message to the console.\n *\n * Features:\n * - Formats message with context: \"[Context] message\"\n * - Uses appropriate console method (log/warn/error)\n * - Safe: checks for console existence (for non-browser environments)\n *\n * @param level - Console method to use ('log' | 'warn' | 'error')\n * @param context - Context identifier (prepended to message if present)\n * @param message - Log message\n * @param args - Additional arguments to pass to console\n *\n * @private\n */\n #writeToConsole(\n level: LogLevel,\n context: string,\n message: string,\n args: unknown[],\n ): void {\n // Safety check: ensure console exists and has the required method\n // This is important for environments like Node.js tests or edge cases\n if (\n typeof console !== \"undefined\" &&\n typeof console[level] === \"function\"\n ) {\n // Format message with context bracket notation for visual clarity\n // Note: formatting is done inside the check to avoid unnecessary string allocation\n // when console is not available\n const formattedMessage = context ? `[${context}] ${message}` : message;\n\n console[level](formattedMessage, ...args);\n }\n }\n\n /**\n * Invokes the configured callback with log data, respecting level settings.\n *\n * Complex logic handling:\n * 1. Skip if no callback configured\n * 2. Skip if callback respects level AND message is below threshold\n * 3. Call callback with error handling (prevents callback errors from breaking logger)\n *\n * The callbackIgnoresLevel flag enables two modes:\n * - false (default): callback only receives messages that pass threshold (same as console)\n * - true: callback receives ALL messages regardless of threshold (useful for analytics)\n *\n * @param level - Log level\n * @param context - Context identifier\n * @param message - Log message\n * @param shouldSkipConsole - Whether console output was skipped (used for level logic)\n * @param args - Additional arguments\n *\n * @private\n */\n #invokeCallback(\n level: LogLevel,\n context: string,\n message: string,\n shouldSkipConsole: boolean,\n args: unknown[],\n ): void {\n // Early exit: no callback configured, or callback respects level and message is filtered\n if (\n !this.#config.callback ||\n (!this.#config.callbackIgnoresLevel && shouldSkipConsole)\n ) {\n return;\n }\n\n // Wrap callback invocation in try-catch to prevent user code errors\n // from breaking the logger or causing cascading failures\n try {\n this.#config.callback(level, context, message, ...args);\n } catch (error) {\n // Fallback error reporting if callback throws\n // Use console.error directly (don't call logger to avoid infinite loops)\n if (\n typeof console !== \"undefined\" &&\n typeof console.error === \"function\"\n ) {\n console.error(\"[Logger] Error in callback:\", error);\n }\n }\n }\n}\n\n/**\n * Singleton logger instance for application-wide logging.\n *\n * This is the main export that should be used throughout the application.\n * Using a singleton ensures consistent configuration across all modules.\n *\n * @example\n * ```ts\n * import { logger } from '@core/logger';\n *\n * // Configure once at application startup\n * logger.configure({ level: 'warn' });\n *\n * // Use anywhere in your app\n * logger.log('MyModule', 'Operation completed');\n * logger.warn('MyModule', 'Deprecated feature used');\n * logger.error('MyModule', 'Operation failed', error);\n * ```\n */\nexport const logger = new Logger();\n","// packages/real-router/modules/transition/makeError.ts\n\nimport type { RouterError } from \"../../../RouterError\";\n\n// Helper: Creating an error with code\nexport const makeError = (\n code: string,\n err?: RouterError,\n): RouterError | undefined => {\n if (!err) {\n return undefined;\n }\n\n err.setCode(code);\n\n return err;\n};\n","// packages/real-router/modules/transition/mergeStates.ts\n\nimport type { Params, State, StateMeta } from \"@real-router/types\";\n\n/**\n * Merges two states with toState taking priority over fromState.\n *\n * Priority order for state fields: toState > fromState\n * Priority order for meta fields: toState.meta > fromState.meta > defaults\n *\n * Special case: meta.params are merged (not replaced):\n * { ...toState.meta.params, ...fromState.meta.params }\n *\n * @param toState - Target state (higher priority)\n * @param fromState - Source state (lower priority)\n * @returns New merged state object\n */\nexport const mergeStates = (toState: State, fromState: State): State => {\n const toMeta = toState.meta;\n const fromMeta = fromState.meta;\n\n // Optimization #1: Conditional merge for params\n // Use spread only when both are defined\n const toParams = toMeta?.params;\n const fromParams = fromMeta?.params;\n\n // Both have params - need to merge; otherwise use whichever is defined\n const metaParams: Params =\n toParams && fromParams\n ? { ...toParams, ...fromParams }\n : (toParams ?? fromParams ?? {});\n\n // Optimization #2: Build meta with defaults, then apply fromMeta, then toMeta\n // Note: StateMeta can have custom fields added by guards/middleware, so we preserve them\n const resultMeta: StateMeta = {\n // Defaults first\n id: 1,\n options: {},\n redirected: false,\n // fromMeta fields (lower priority, may include custom fields)\n ...fromMeta,\n // toMeta fields (higher priority, may include custom fields)\n ...toMeta,\n // Explicitly set params to our merged version (override spread)\n params: metaParams,\n };\n\n // Optimization #4: Copy all toState fields (including custom ones)\n // then explicitly set meta to our merged version\n // Note: State can have custom fields added by middleware, so we must preserve them\n return {\n ...toState,\n meta: resultMeta,\n };\n};\n","// packages/real-router/modules/RouterError.ts\n\nimport { errorCodes } from \"./constants\";\nimport { deepFreezeState } from \"./helpers\";\n\nimport type { State } from \"@real-router/types\";\n\n// Pre-compute Set of error code values for O(1) lookup in setCode()\n// This avoids creating array and doing linear search on every setCode() call\nconst errorCodeValues = new Set(Object.values(errorCodes));\n\n// Reserved built-in properties - throw error if user tries to set these\nconst reservedProperties = new Set([\"code\", \"segment\", \"path\", \"redirect\"]);\n\n// Reserved method names - silently ignore attempts to overwrite these\nconst reservedMethods = new Set([\n \"setCode\",\n \"setErrorInstance\",\n \"setAdditionalFields\",\n \"hasField\",\n \"getField\",\n \"toJSON\",\n]);\n\nexport class RouterError extends Error {\n [key: string]: unknown;\n\n // Using public properties to ensure structural compatibility\n // with RouterError interface in core-types\n readonly segment: string | undefined;\n readonly path: string | undefined;\n readonly redirect: State | undefined;\n\n // Note: code appears to be writable but setCode() should be used\n // to properly update both code and message together\n code: string;\n\n /**\n * Creates a new RouterError instance.\n *\n * The options object accepts built-in fields (message, segment, path, redirect)\n * and any additional custom fields, which will all be attached to the error instance.\n *\n * @param code - The error code (e.g., \"ROUTE_NOT_FOUND\", \"CANNOT_ACTIVATE\")\n * @param options - Optional configuration object\n * @param options.message - Custom error message (defaults to code if not provided)\n * @param options.segment - The route segment where the error occurred\n * @param options.path - The full path where the error occurred\n * @param options.redirect - Optional redirect state for navigation errors\n *\n * @example\n * ```typescript\n * // Basic error\n * const err1 = new RouterError(\"ROUTE_NOT_FOUND\");\n *\n * // Error with custom message\n * const err2 = new RouterError(\"ERR\", { message: \"Something went wrong\" });\n *\n * // Error with context and custom fields\n * const err3 = new RouterError(\"CANNOT_ACTIVATE\", {\n * message: \"Insufficient permissions\",\n * segment: \"admin\",\n * path: \"/admin/users\",\n * userId: \"123\" // custom field\n * });\n *\n * // Error with redirect\n * const err4 = new RouterError(\"TRANSITION_ERR\", {\n * redirect: { name: \"home\", path: \"/\", params: {} }\n * });\n * ```\n */\n constructor(\n code: string,\n {\n message,\n segment,\n path,\n redirect,\n ...rest\n }: {\n [key: string]: unknown;\n message?: string | undefined;\n segment?: string | undefined;\n path?: string | undefined;\n redirect?: State | undefined;\n } = {},\n ) {\n super(message ?? code);\n\n this.code = code;\n this.segment = segment;\n this.path = path;\n // Deep freeze redirect to prevent mutations (creates a frozen clone)\n this.redirect = redirect ? deepFreezeState(redirect) : undefined;\n\n // Assign custom fields, checking reserved properties and filtering out reserved method names\n // Issue #39: Throw for reserved properties to match setAdditionalFields behavior\n for (const [key, value] of Object.entries(rest)) {\n if (reservedProperties.has(key)) {\n throw new TypeError(\n `[RouterError] Cannot set reserved property \"${key}\"`,\n );\n }\n\n if (!reservedMethods.has(key)) {\n this[key] = value;\n }\n }\n }\n\n /**\n * Updates the error code and conditionally updates the message.\n *\n * If the current message is one of the standard error code values\n * (e.g., \"ROUTE_NOT_FOUND\", \"SAME_STATES\"), it will be replaced with the new code.\n * This allows keeping error messages in sync with codes when using standard error codes.\n *\n * If the message is custom (not a standard error code), it will be preserved.\n *\n * @param newCode - The new error code to set\n *\n * @example\n * // Message follows code (standard error code as message)\n * const err = new RouterError(\"ROUTE_NOT_FOUND\", { message: \"ROUTE_NOT_FOUND\" });\n * err.setCode(\"CUSTOM_ERROR\"); // message becomes \"CUSTOM_ERROR\"\n *\n * @example\n * // Custom message is preserved\n * const err = new RouterError(\"ERR\", { message: \"Custom error message\" });\n * err.setCode(\"NEW_CODE\"); // message stays \"Custom error message\"\n */\n setCode(newCode: string): void {\n this.code = newCode;\n\n // Only update message if it's a standard error code value (not a custom message)\n if (errorCodeValues.has(this.message)) {\n this.message = newCode;\n }\n }\n\n /**\n * Copies properties from another Error instance to this RouterError.\n *\n * This method updates the message, cause, and stack trace from the provided error.\n * Useful for wrapping native errors while preserving error context.\n *\n * @param err - The Error instance to copy properties from\n * @throws {TypeError} If err is null or undefined\n *\n * @example\n * ```typescript\n * const routerErr = new RouterError(\"TRANSITION_ERR\");\n * try {\n * // some operation that might fail\n * } catch (nativeErr) {\n * routerErr.setErrorInstance(nativeErr);\n * throw routerErr;\n * }\n * ```\n */\n setErrorInstance(err: Error): void {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!err) {\n throw new TypeError(\n \"[RouterError.setErrorInstance] err parameter is required and must be an Error instance\",\n );\n }\n\n this.message = err.message;\n this.cause = err.cause;\n this.stack = err.stack ?? \"\";\n }\n\n /**\n * Adds custom fields to the error object.\n *\n * This method allows attaching arbitrary data to the error for debugging or logging purposes.\n * All fields become accessible as properties on the error instance and are included in JSON serialization.\n *\n * Reserved method names (setCode, setErrorInstance, setAdditionalFields, hasField, getField, toJSON)\n * are automatically filtered out to prevent accidental overwriting of class methods.\n *\n * @param fields - Object containing custom fields to add to the error\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"CANNOT_ACTIVATE\");\n * err.setAdditionalFields({\n * userId: \"123\",\n * attemptedRoute: \"/admin\",\n * reason: \"insufficient permissions\"\n * });\n *\n * console.log(err.userId); // \"123\"\n * console.log(JSON.stringify(err)); // includes all custom fields\n * ```\n */\n setAdditionalFields(fields: Record<string, unknown>): void {\n // Assign fields, throwing for reserved properties, silently ignoring methods\n for (const [key, value] of Object.entries(fields)) {\n if (reservedProperties.has(key)) {\n throw new TypeError(\n `[RouterError.setAdditionalFields] Cannot set reserved property \"${key}\"`,\n );\n }\n\n if (!reservedMethods.has(key)) {\n this[key] = value;\n }\n }\n }\n\n /**\n * Checks if a custom field exists on the error object.\n *\n * This method checks for both custom fields added via setAdditionalFields()\n * and built-in fields (code, message, segment, etc.).\n *\n * @param key - The field name to check\n * @returns `true` if the field exists, `false` otherwise\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"ERR\", { segment: \"users\" });\n * err.setAdditionalFields({ userId: \"123\" });\n *\n * err.hasField(\"userId\"); // true\n * err.hasField(\"segment\"); // true\n * err.hasField(\"unknown\"); // false\n * ```\n */\n hasField(key: string): boolean {\n return key in this;\n }\n\n /**\n * Retrieves a custom field value from the error object.\n *\n * This method can access both custom fields and built-in fields.\n * Returns `undefined` if the field doesn't exist.\n *\n * @param key - The field name to retrieve\n * @returns The field value, or `undefined` if it doesn't exist\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"ERR\");\n * err.setAdditionalFields({ userId: \"123\", role: \"admin\" });\n *\n * err.getField(\"userId\"); // \"123\"\n * err.getField(\"role\"); // \"admin\"\n * err.getField(\"code\"); // \"ERR\" (built-in field)\n * err.getField(\"unknown\"); // undefined\n * ```\n */\n getField(key: string): unknown {\n return this[key];\n }\n\n /**\n * Serializes the error to a JSON-compatible object.\n *\n * This method is automatically called by JSON.stringify() and includes:\n * - Built-in fields: code, message, segment (if set), path (if set), redirect (if set)\n * - All custom fields added via setAdditionalFields() or constructor\n * - Excludes: stack trace (for security/cleanliness)\n *\n * @returns A plain object representation of the error, suitable for JSON serialization\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"ROUTE_NOT_FOUND\", {\n * message: \"Route not found\",\n * path: \"/admin/users/123\"\n * });\n * err.setAdditionalFields({ userId: \"123\" });\n *\n * JSON.stringify(err);\n * // {\n * // \"code\": \"ROUTE_NOT_FOUND\",\n * // \"message\": \"Route not found\",\n * // \"path\": \"/admin/users/123\",\n * // \"userId\": \"123\"\n * // }\n * ```\n */\n toJSON(): Record<string, unknown> {\n const result: Record<string, unknown> = {\n code: this.code,\n message: this.message,\n };\n\n if (this.segment !== undefined) {\n result.segment = this.segment;\n }\n if (this.path !== undefined) {\n result.path = this.path;\n }\n if (this.redirect !== undefined) {\n result.redirect = this.redirect;\n }\n\n // add all public fields\n // Using Set.has() for O(1) lookup instead of Array.includes() O(n)\n // Overall complexity: O(n) instead of O(n*m)\n const excludeKeys = new Set([\n \"code\",\n \"message\",\n \"segment\",\n \"path\",\n \"redirect\",\n \"stack\",\n ]);\n\n for (const key in this) {\n if (Object.hasOwn(this, key) && !excludeKeys.has(key)) {\n result[key] = this[key];\n }\n }\n\n return result;\n }\n}\n","// packages/real-router/modules/transition/processLifecycleResult.ts\n\n/* eslint-disable promise/always-return, promise/no-callback-in-promise */\nimport { isPromise, isState } from \"type-guards\";\n\nimport { errorCodes } from \"../../../constants\";\nimport { RouterError } from \"../../../RouterError\";\n\nimport type { DoneFn, State, ActivationFn } from \"@real-router/types\";\n\n// Helper: Lifecycle results Processing Function\nexport const processLifecycleResult = (\n result: ReturnType<ActivationFn>,\n done: DoneFn,\n segment?: string,\n): void => {\n const errorData = segment ? { segment } : {};\n\n if (result === undefined) {\n // We expect a Done call\n return;\n }\n\n if (typeof result === \"boolean\") {\n if (result) {\n done();\n } else {\n done(new RouterError(errorCodes.TRANSITION_ERR, errorData));\n }\n\n return;\n }\n\n if (isState(result)) {\n // Type guard should narrow, but TypeScript needs help\n done(undefined, result);\n\n return;\n }\n\n if (isPromise<State | boolean | undefined>(result)) {\n // Callback-based API: promise handled internally, not returned\n // Mixing promises with callbacks is intentional for backward compatibility\n // Type assertion needed due to complex union type narrowing\n // Optimization: .then(onFulfill, onReject) instead of .then().catch()\n // This saves 1 Promise allocation per async middleware call\n void result.then(\n (resVal) => {\n // Issue #38: Handle Promise<boolean> same as sync boolean\n if (typeof resVal === \"boolean\") {\n if (resVal) {\n done();\n } else {\n done(new RouterError(errorCodes.TRANSITION_ERR, errorData));\n }\n } else {\n done(undefined, resVal);\n }\n },\n (error_: unknown) => {\n let error: {\n [key: string]: unknown;\n message?: string | undefined;\n segment?: string | undefined;\n } = errorData;\n\n if (error_ instanceof Error) {\n error = {\n ...errorData,\n message: error_.message,\n stack: error_.stack,\n };\n\n // Error.cause requires ES2022+ - safely access it if present\n if (\"cause\" in error_ && error_.cause !== undefined) {\n error.cause = error_.cause;\n }\n } else if (error_ && typeof error_ === \"object\") {\n error = { ...errorData, ...error_ };\n }\n\n done(new RouterError(errorCodes.TRANSITION_ERR, error));\n },\n );\n\n return;\n }\n\n // This should never be reached - all valid ActivationFn return types are handled above\n // If we get here, it means the activation function returned an unexpected type\n done(\n new RouterError(errorCodes.TRANSITION_ERR, {\n ...errorData,\n message: `Invalid lifecycle result type: ${typeof result}`,\n }),\n );\n};\n","import { logger } from \"logger\";\n\nimport type { State, RouterError as RouterErrorType } from \"@real-router/types\";\n\n/**\n * Strict callback type where state is always provided.\n * Used internally in transition chain where state is guaranteed.\n *\n * @internal\n */\nexport type StrictDoneFn = (\n error: RouterErrorType | undefined,\n state: State,\n) => void;\n\n/**\n * Safely invokes a callback, catching and logging any errors.\n *\n * @internal\n */\nexport function safeCallback(\n callback: StrictDoneFn,\n error: RouterErrorType | undefined,\n state: State,\n logTag: string,\n): void {\n try {\n callback(error, state);\n } catch (error_) {\n logger.error(logTag, \"Error in callback:\", error_);\n }\n}\n","// packages/real-router/modules/transition/wrapSyncError.ts\n\n/**\n * Error metadata structure for transition errors.\n * Contains information extracted from caught exceptions.\n */\nexport interface SyncErrorMetadata {\n [key: string]: unknown;\n message?: string;\n stack?: string | undefined;\n cause?: unknown;\n segment?: string;\n}\n\n// Reserved properties that conflict with RouterError constructor\n// Issue #39: Filter these when wrapping sync errors to avoid TypeError\nconst reservedRouterErrorProps = new Set([\n \"code\",\n \"segment\",\n \"path\",\n \"redirect\",\n]);\n\n/**\n * Wraps a synchronously thrown value into structured error metadata.\n *\n * This helper extracts useful debugging information from various thrown values:\n * - Error instances: extracts message, stack, and cause (ES2022+)\n * - Plain objects: spreads properties into metadata\n * - Primitives (string, number, etc.): returns minimal metadata\n *\n * @param thrown - The value caught in a try-catch block\n * @param segment - Optional route segment name (for lifecycle hooks)\n * @returns Structured error metadata for RouterError\n *\n * @example\n * ```typescript\n * try {\n * hookFn();\n * } catch (error) {\n * const metadata = wrapSyncError(error, \"users.profile\");\n * done(new RouterError(errorCodes.TRANSITION_ERR, metadata));\n * }\n * ```\n */\nexport function wrapSyncError(\n thrown: unknown,\n segment?: string,\n): SyncErrorMetadata {\n // Base metadata - always include segment if provided\n const base: SyncErrorMetadata = segment ? { segment } : {};\n\n // Handle Error instances - extract all useful properties\n if (thrown instanceof Error) {\n return {\n ...base,\n message: thrown.message,\n stack: thrown.stack,\n // Error.cause requires ES2022+ - safely access if present\n ...(\"cause\" in thrown &&\n thrown.cause !== undefined && { cause: thrown.cause }),\n };\n }\n\n // Handle plain objects - spread properties into metadata, filtering reserved props\n if (thrown && typeof thrown === \"object\") {\n const filtered: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(thrown)) {\n // Issue #39: Skip reserved properties to avoid RouterError constructor TypeError\n if (!reservedRouterErrorProps.has(key)) {\n filtered[key] = value;\n }\n }\n\n return { ...base, ...filtered };\n }\n\n // Primitives (string, number, boolean, null, undefined, symbol, bigint)\n // Return base metadata only - the primitive value isn't useful as metadata\n return base;\n}\n","// packages/real-router/modules/transition/executeLifecycleHooks.ts\n\nimport { logger } from \"logger\";\nimport { isState } from \"type-guards\";\n\nimport { RouterError, errorCodes } from \"@real-router/core\";\n\nimport { makeError } from \"./makeError\";\nimport { mergeStates } from \"./mergeStates\";\nimport { processLifecycleResult } from \"./processLifecycleResult\";\nimport { safeCallback, type StrictDoneFn } from \"./shared\";\nimport { wrapSyncError } from \"./wrapSyncError\";\n\nimport type {\n DoneFn,\n State,\n ActivationFn,\n RouterError as RouterErrorType,\n} from \"@real-router/types\";\n\nconst LOG_TAG = \"core:lifecycle\";\n\n// Helper: execution of the Lifecycle Hooks group\nexport const executeLifecycleHooks = (\n hooks: Map<string, ActivationFn>,\n toState: State,\n fromState: State | undefined,\n segments: string[],\n errorCode: string,\n isCancelled: () => boolean,\n callback: StrictDoneFn,\n): void => {\n let currentState = toState;\n const segmentsToProcess = segments.filter((name) => hooks.has(name));\n\n if (segmentsToProcess.length === 0) {\n safeCallback(callback, undefined, currentState, LOG_TAG);\n\n return;\n }\n\n let index = 0;\n\n // If the transition is cancelled, we will not process the hooks\n // Guards cannot redirect - they can only allow (true/undefined) or block (false/error)\n const done: DoneFn = (err, state) => {\n if (err) {\n // Guards cannot redirect - convert any redirect to error\n if (err.redirect) {\n const errorWithoutRedirect = new RouterError(errorCode, {\n message: \"Guards cannot redirect. Use middleware for redirects.\",\n attemptedRedirect: err.redirect,\n });\n\n processNext(errorWithoutRedirect);\n } else {\n processNext(err);\n }\n } else {\n processNext(undefined, state);\n }\n };\n\n const processNext = (err?: RouterErrorType, newState?: State): void => {\n if (isCancelled()) {\n safeCallback(\n callback,\n new RouterError(errorCodes.TRANSITION_CANCELLED),\n currentState,\n LOG_TAG,\n );\n\n return;\n }\n\n if (err) {\n safeCallback(callback, makeError(errorCode, err), currentState, LOG_TAG);\n\n return;\n }\n\n // Processing a new state\n // Optimization: Early return for undefined newState (most common case ~90%+)\n // This avoids isState() call and subsequent checks\n if (!newState) {\n // Fast path: skip all checks\n } else if (newState !== currentState && isState(newState)) {\n // Guards cannot redirect to a different route\n if (newState.name !== currentState.name) {\n const redirectNotAllowedErr = new RouterError(errorCode, {\n message: \"Guards cannot redirect to different route. Use middleware.\",\n attemptedRedirect: {\n name: newState.name,\n params: newState.params,\n path: newState.path,\n },\n });\n\n safeCallback(callback, redirectNotAllowedErr, currentState, LOG_TAG);\n\n return;\n }\n\n // Same route - safe to merge (param modifications, meta changes)\n const hasChanged =\n newState.params !== currentState.params ||\n newState.path !== currentState.path;\n\n if (hasChanged) {\n logger.error(\n \"core:transition\",\n \"Warning: State mutated during transition\",\n { from: currentState, to: newState },\n );\n }\n\n currentState = mergeStates(newState, currentState);\n }\n\n if (index >= segmentsToProcess.length) {\n safeCallback(callback, undefined, currentState, LOG_TAG);\n\n return;\n }\n\n const segment = segmentsToProcess[index++];\n // Safe cast: segmentsToProcess only contains names that exist in hooks (filtered above)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- guaranteed by filter\n const hookFn = hooks.get(segment)!;\n\n try {\n const result = hookFn(currentState, fromState, done);\n\n processLifecycleResult(result, done, segment);\n } catch (syncError: unknown) {\n // Note: TRANSITION_ERR is placeholder - makeError() will set correct code\n done(\n new RouterError(\n errorCodes.TRANSITION_ERR,\n wrapSyncError(syncError, segment),\n ),\n );\n }\n };\n\n processNext();\n};\n","// packages/real-router/modules/transition/executeMiddleware.ts\n\nimport { logger } from \"logger\";\nimport { isState } from \"type-guards\";\n\nimport { makeError } from \"./makeError\";\nimport { mergeStates } from \"./mergeStates\";\nimport { processLifecycleResult } from \"./processLifecycleResult\";\nimport { safeCallback, type StrictDoneFn } from \"./shared\";\nimport { wrapSyncError } from \"./wrapSyncError\";\nimport { errorCodes } from \"../../../constants\";\nimport { RouterError } from \"../../../RouterError\";\n\nimport type {\n DoneFn,\n State,\n ActivationFn,\n RouterError as RouterErrorType,\n} from \"@real-router/types\";\n\nconst LOG_TAG = \"core:middleware\";\n\n// Helper: processing middleware\nexport const executeMiddleware = (\n middlewareFunctions: ActivationFn[],\n toState: State,\n fromState: State | undefined,\n isCancelled: () => boolean,\n callback: StrictDoneFn,\n): void => {\n let currentState = toState;\n let index = 0;\n\n // If the transition is cancelled, we will not process the middleware\n // Note: Middleware redirects are not supported - errors pass through\n const done: DoneFn = (err, state) => {\n if (err) {\n processNext(err);\n } else {\n processNext(undefined, state);\n }\n };\n\n const processNext = (err?: RouterErrorType, newState?: State): void => {\n if (isCancelled()) {\n safeCallback(\n callback,\n new RouterError(errorCodes.TRANSITION_CANCELLED),\n currentState,\n LOG_TAG,\n );\n\n return;\n }\n\n if (err) {\n safeCallback(\n callback,\n makeError(errorCodes.TRANSITION_ERR, err),\n currentState,\n LOG_TAG,\n );\n\n return;\n }\n\n // Processing a new state\n // Optimization: Early return for undefined newState (most common case ~90%+)\n // This avoids isState() call and subsequent checks\n if (!newState) {\n // Fast path: skip all checks\n } else if (newState !== currentState && isState(newState)) {\n const hasChanged =\n newState.name !== currentState.name ||\n newState.params !== currentState.params ||\n newState.path !== currentState.path;\n\n if (hasChanged) {\n logger.error(\n LOG_TAG,\n \"Warning: State mutated during middleware execution\",\n { from: currentState, to: newState },\n );\n }\n\n currentState = mergeStates(newState, currentState);\n }\n\n if (index >= middlewareFunctions.length) {\n safeCallback(callback, undefined, currentState, LOG_TAG);\n\n return;\n }\n\n const middlewareFn = middlewareFunctions[index++];\n\n try {\n const result = middlewareFn(currentState, fromState, done);\n\n processLifecycleResult(result, done);\n } catch (syncError: unknown) {\n done(\n new RouterError(errorCodes.TRANSITION_ERR, wrapSyncError(syncError)),\n );\n }\n };\n\n processNext();\n};\n","// packages/real-router/modules/transition/index.ts\n\nimport { executeLifecycleHooks } from \"./executeLifecycleHooks\";\nimport { executeMiddleware } from \"./executeMiddleware\";\nimport { constants, errorCodes } from \"../../../constants\";\nimport { RouterError } from \"../../../RouterError\";\nimport { getTransitionPath, nameToIDs } from \"../../../transitionPath\";\n\nimport type { TransitionDependencies } from \"../types\";\nimport type {\n NavigationOptions,\n CancelFn,\n State,\n RouterError as RouterErrorType,\n} from \"@real-router/types\";\n\n/**\n * Strict callback type where state is always provided.\n * Used internally in transition chain where state is guaranteed.\n */\ntype StrictDoneFn = (error: RouterErrorType | undefined, state: State) => void;\n\nexport function transition(\n deps: TransitionDependencies,\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n transitionCallback: (err: RouterErrorType | undefined, state: State) => void,\n): CancelFn {\n // The state of transaction\n let cancelled = false;\n let completed = false;\n\n // We're caching the necessary data\n const [canDeactivateFunctions, canActivateFunctions] =\n deps.getLifecycleFunctions();\n const middlewareFunctions = deps.getMiddlewareFunctions();\n const isUnknownRoute = toState.name === constants.UNKNOWN_ROUTE;\n\n // State management functions\n // Issue #36: Check both explicit cancellation AND router shutdown\n // Issue #50: Use isActive() instead of isStarted() for two-phase start support\n // isActive() is true during initial start transition, isStarted() is false\n const isCancelled = () => cancelled || !deps.isActive();\n\n const cancel = () => {\n if (!cancelled && !completed) {\n cancelled = true;\n complete(new RouterError(errorCodes.TRANSITION_CANCELLED));\n }\n };\n\n const complete = (err: RouterErrorType | undefined, state?: State) => {\n if (completed) {\n return;\n }\n\n completed = true;\n transitionCallback(err, state ?? toState);\n };\n\n // The main transaction logic\n const runTransition = (): void => {\n const { toDeactivate, toActivate } = getTransitionPath(toState, fromState);\n\n // determine the necessary steps\n const shouldDeactivate =\n fromState && !opts.forceDeactivate && toDeactivate.length > 0;\n const shouldActivate = !isUnknownRoute && toActivate.length > 0;\n const shouldRunMiddleware = middlewareFunctions.length > 0;\n\n // The chain of execution\n const runDeactivation = (callback: StrictDoneFn) => {\n if (shouldDeactivate) {\n executeLifecycleHooks(\n canDeactivateFunctions,\n toState,\n fromState,\n toDeactivate,\n errorCodes.CANNOT_DEACTIVATE,\n isCancelled,\n callback,\n );\n } else {\n callback(undefined, toState);\n }\n };\n\n const runActivation = (state: State, callback: StrictDoneFn) => {\n if (shouldActivate) {\n executeLifecycleHooks(\n canActivateFunctions,\n state,\n fromState,\n toActivate,\n errorCodes.CANNOT_ACTIVATE,\n isCancelled,\n (err, newState) => {\n callback(err, newState);\n },\n );\n } else {\n // State is already frozen from makeState()\n callback(undefined, state);\n }\n };\n\n const runMiddleware = (state: State, callback: StrictDoneFn) => {\n if (shouldRunMiddleware) {\n executeMiddleware(\n middlewareFunctions,\n state,\n fromState,\n isCancelled,\n (err, newState) => {\n callback(err, newState);\n },\n );\n } else {\n // State is already frozen from makeState()\n callback(undefined, state);\n }\n };\n\n // Callback handlers extracted to reduce nesting depth\n const handleMiddlewareComplete: StrictDoneFn = (\n runMiddlewareErr,\n runMiddlewareState,\n ) => {\n if (runMiddlewareErr) {\n complete(runMiddlewareErr, runMiddlewareState);\n\n return;\n }\n\n // Automatic cleaning of inactive segments\n if (fromState) {\n const activeSegments = nameToIDs(toState.name);\n const previousActiveSegments = nameToIDs(fromState.name);\n const activeSet = new Set(activeSegments);\n\n for (const name of previousActiveSegments) {\n if (!activeSet.has(name) && canDeactivateFunctions.has(name)) {\n deps.clearCanDeactivate(name);\n }\n }\n }\n\n complete(undefined, runMiddlewareState);\n };\n\n const handleActivationComplete: StrictDoneFn = (\n runActivationErr,\n runActivationState,\n ) => {\n if (runActivationErr) {\n complete(runActivationErr, runActivationState);\n\n return;\n }\n\n runMiddleware(runActivationState, handleMiddlewareComplete);\n };\n\n const handleDeactivationComplete: StrictDoneFn = (err, state) => {\n if (err) {\n complete(err, state);\n\n return;\n }\n\n runActivation(state, handleActivationComplete);\n };\n\n // perform a chain\n runDeactivation(handleDeactivationComplete);\n };\n\n // Launch transition\n runTransition();\n\n return cancel;\n}\n","// packages/core/src/namespaces/NavigationNamespace/validators.ts\n\n/**\n * Static validation functions for NavigationNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { getTypeDescription, isNavigationOptions } from \"type-guards\";\n\nimport type { ParsedNavigateArgs, ParsedNavigateDefaultArgs } from \"./types\";\nimport type {\n DoneFn,\n NavigationOptions,\n Params,\n State,\n} from \"@real-router/types\";\n\nconst noop = (): void => {};\n\n/**\n * Cached frozen empty objects to reduce GC pressure.\n * Safe because they're frozen and cannot be mutated.\n */\nconst EMPTY_PARAMS: Params = Object.freeze({});\nconst EMPTY_OPTS: NavigationOptions = Object.freeze({});\n\n/**\n * Validates navigate route name argument.\n */\nexport function validateNavigateArgs(name: unknown): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.navigate] Invalid route name: expected string, got ${getTypeDescription(name)}`,\n );\n }\n}\n\n/**\n * Validates navigateToState arguments.\n */\nexport function validateNavigateToStateArgs(\n toState: unknown,\n fromState: unknown,\n opts: unknown,\n callback: unknown,\n emitSuccess: unknown,\n): void {\n // toState must be a valid state object\n if (\n !toState ||\n typeof toState !== \"object\" ||\n typeof (toState as State).name !== \"string\" ||\n typeof (toState as State).path !== \"string\"\n ) {\n throw new TypeError(\n `[router.navigateToState] Invalid toState: expected State object with name and path`,\n );\n }\n\n // fromState can be undefined or a valid state\n if (\n fromState !== undefined &&\n (!fromState ||\n typeof fromState !== \"object\" ||\n typeof (fromState as State).name !== \"string\")\n ) {\n throw new TypeError(\n `[router.navigateToState] Invalid fromState: expected State object or undefined`,\n );\n }\n\n // opts must be an object\n if (typeof opts !== \"object\" || opts === null) {\n throw new TypeError(\n `[router.navigateToState] Invalid opts: expected NavigationOptions object, got ${getTypeDescription(opts)}`,\n );\n }\n\n // callback must be a function\n if (typeof callback !== \"function\") {\n throw new TypeError(\n `[router.navigateToState] Invalid callback: expected function, got ${getTypeDescription(callback)}`,\n );\n }\n\n // emitSuccess must be a boolean\n if (typeof emitSuccess !== \"boolean\") {\n throw new TypeError(\n `[router.navigateToState] Invalid emitSuccess: expected boolean, got ${getTypeDescription(emitSuccess)}`,\n );\n }\n}\n\n/**\n * Validates navigateToDefault arguments (before parsing).\n */\nexport function validateNavigateToDefaultArgs(\n optsOrDone: unknown,\n done: unknown,\n): void {\n // If first arg is provided and not a function, it must be an object (options)\n if (\n optsOrDone !== undefined &&\n typeof optsOrDone !== \"function\" &&\n (typeof optsOrDone !== \"object\" || optsOrDone === null)\n ) {\n throw new TypeError(\n `[router.navigateToDefault] Invalid options: ${getTypeDescription(optsOrDone)}. Expected NavigationOptions object or callback function.`,\n );\n }\n\n // If second arg is provided, it must be a function\n if (done !== undefined && typeof done !== \"function\") {\n throw new TypeError(\n `[router.navigateToDefault] Invalid callback: expected function, got ${getTypeDescription(done)}`,\n );\n }\n}\n\n/**\n * Validates that opts is a valid NavigationOptions object.\n */\nexport function validateNavigationOptions(\n opts: unknown,\n methodName: string,\n): asserts opts is NavigationOptions {\n if (!isNavigationOptions(opts)) {\n throw new TypeError(\n `[router.${methodName}] Invalid options: ${getTypeDescription(opts)}. Expected NavigationOptions object.`,\n );\n }\n}\n\n/**\n * Parses the polymorphic arguments of navigate().\n *\n * Handles all valid call signatures:\n * - navigate(name, callback)\n * - navigate(name, params)\n * - navigate(name, params, callback)\n * - navigate(name, params, opts)\n * - navigate(name, params, opts, callback)\n */\nexport function parseNavigateArgs(\n paramsOrDone?: Params | DoneFn,\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n): ParsedNavigateArgs {\n if (typeof paramsOrDone === \"function\") {\n // Form: navigate(name, callback)\n return { params: EMPTY_PARAMS, opts: EMPTY_OPTS, callback: paramsOrDone };\n }\n\n // Forms: navigate(name), navigate(name, params), navigate(name, params, callback),\n // navigate(name, params, opts), navigate(name, params, opts, callback)\n // Also handles: navigate(name, null/undefined, callback) - runtime defense\n const params = paramsOrDone ?? EMPTY_PARAMS;\n\n if (typeof optsOrDone === \"function\") {\n return { params, opts: EMPTY_OPTS, callback: optsOrDone };\n }\n\n return {\n params,\n opts: optsOrDone ?? EMPTY_OPTS,\n callback: done ?? noop,\n };\n}\n\n/**\n * Parses the polymorphic arguments of navigateToDefault().\n */\nexport function parseNavigateToDefaultArgs(\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n): ParsedNavigateDefaultArgs {\n if (typeof optsOrDone === \"function\") {\n return { opts: EMPTY_OPTS, callback: optsOrDone };\n }\n\n return {\n opts: optsOrDone ?? EMPTY_OPTS,\n callback: done ?? noop,\n };\n}\n","// packages/core/src/namespaces/NavigationNamespace/NavigationNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport { noop, safeCallback } from \"./helpers\";\nimport { transition } from \"./transition\";\nimport {\n parseNavigateArgs,\n parseNavigateToDefaultArgs,\n validateNavigateArgs,\n validateNavigateToDefaultArgs,\n validateNavigateToStateArgs,\n validateNavigationOptions,\n} from \"./validators\";\nimport { events, errorCodes, constants } from \"../../constants\";\nimport { RouterError } from \"../../RouterError\";\n\nimport type {\n NavigationDependencies,\n ParsedNavigateArgs,\n ParsedNavigateDefaultArgs,\n TransitionDependencies,\n} from \"./types\";\nimport type {\n CancelFn,\n DoneFn,\n NavigationOptions,\n Params,\n State,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing navigation.\n *\n * Handles navigate(), navigateToDefault(), navigateToState(), and transition state.\n */\nexport class NavigationNamespace {\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n // Functional reference for cyclic dependency\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n\n /**\n * Functional reference to RouterLifecycleNamespace.isStarted().\n * Must be set before calling navigate().\n */\n\n isRouterStarted!: () => boolean;\n\n #navigating = false;\n #cancelCurrentTransition: CancelFn | null = null;\n\n // Dependencies injected via setDependencies (replaces full router reference)\n #deps: NavigationDependencies | undefined;\n #transitionDeps: TransitionDependencies | undefined;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateNavigateArgs(name: unknown): asserts name is string {\n validateNavigateArgs(name);\n }\n\n static validateNavigateToStateArgs(\n toState: unknown,\n fromState: unknown,\n opts: unknown,\n callback: unknown,\n emitSuccess: unknown,\n ): void {\n validateNavigateToStateArgs(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n }\n\n static validateNavigateToDefaultArgs(\n optsOrDone: unknown,\n done: unknown,\n ): void {\n validateNavigateToDefaultArgs(optsOrDone, done);\n }\n\n static validateNavigationOptions(\n opts: unknown,\n methodName: string,\n ): asserts opts is NavigationOptions {\n validateNavigationOptions(opts, methodName);\n }\n\n static parseNavigateArgs(\n paramsOrDone?: Params | DoneFn,\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): ParsedNavigateArgs {\n return parseNavigateArgs(paramsOrDone, optsOrDone, done);\n }\n\n static parseNavigateToDefaultArgs(\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): ParsedNavigateDefaultArgs {\n return parseNavigateToDefaultArgs(optsOrDone, done);\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n /**\n * Sets dependencies for navigation operations.\n * Must be called before using navigation methods.\n */\n setDependencies(deps: NavigationDependencies): void {\n this.#deps = deps;\n }\n\n /**\n * Sets dependencies for transition operations.\n * Must be called before using navigation methods.\n */\n setTransitionDependencies(deps: TransitionDependencies): void {\n this.#transitionDeps = deps;\n }\n\n // =========================================================================\n // Instance methods\n // =========================================================================\n\n /**\n * Checks if a navigation transition is currently in progress.\n */\n isNavigating(): boolean {\n return this.isRouterStarted() && this.#navigating;\n }\n\n /**\n * Cancels the current transition if one is in progress.\n */\n cancel(): void {\n if (this.#cancelCurrentTransition) {\n this.#cancelCurrentTransition();\n this.#cancelCurrentTransition = null;\n }\n\n this.#navigating = false;\n }\n\n /**\n * Internal navigation function that accepts pre-built state.\n * Used by RouterLifecycleNamespace for start() transitions.\n */\n navigateToState(\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ): CancelFn {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const deps = this.#deps!;\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const transitionDeps = this.#transitionDeps!;\n\n // Warn about concurrent navigation (potential SSR race condition)\n if (this.#navigating) {\n logger.warn(\n \"router.navigate\",\n \"Concurrent navigation detected on shared router instance. \" +\n \"For SSR, use router.clone() to create isolated instance per request.\",\n );\n }\n\n // Cancel previous transition\n this.cancel();\n\n // Set navigating flag BEFORE emitting TRANSITION_START\n // This ensures isNavigating() returns true during event handlers\n this.#navigating = true;\n\n // Emit TRANSITION_START (after navigating flag is set)\n deps.invokeEventListeners(events.TRANSITION_START, toState, fromState);\n\n // Create callback for transition\n const transitionCallback = (err: RouterError | undefined, state: State) => {\n this.#navigating = false;\n this.#cancelCurrentTransition = null;\n\n if (!err) {\n // Route was already validated in navigate() via buildState().\n // Since guards can no longer redirect (Issue #55), the state.name cannot change.\n // However, routes can be dynamically removed during async navigation,\n // so we do a lightweight check with hasRoute() instead of full buildState().\n // UNKNOWN_ROUTE is always valid (used for 404 handling).\n if (\n state.name === constants.UNKNOWN_ROUTE ||\n deps.hasRoute(state.name)\n ) {\n deps.setState(state);\n\n // Emit TRANSITION_SUCCESS only if requested\n if (emitSuccess) {\n deps.invokeEventListeners(\n events.TRANSITION_SUCCESS,\n state,\n fromState,\n opts,\n );\n }\n\n // State is already frozen from transition module\n safeCallback(callback, undefined, state);\n } else {\n // Route was removed during async navigation\n const notFoundErr = new RouterError(errorCodes.ROUTE_NOT_FOUND, {\n routeName: state.name,\n });\n\n safeCallback(callback, notFoundErr);\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n deps.getState(),\n notFoundErr,\n );\n }\n\n return;\n }\n\n // Error handling\n if (err.code === errorCodes.TRANSITION_CANCELLED) {\n deps.invokeEventListeners(events.TRANSITION_CANCEL, toState, fromState);\n } else {\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n toState,\n fromState,\n err,\n );\n }\n\n safeCallback(callback, err);\n };\n\n // Launch transition\n this.#cancelCurrentTransition = transition(\n transitionDeps,\n toState,\n fromState,\n opts,\n transitionCallback,\n );\n\n return this.#cancelCurrentTransition;\n }\n\n /**\n * Navigates to a route by name.\n * Arguments should be pre-parsed and validated by facade.\n */\n navigate(\n name: string,\n params: Params,\n opts: NavigationOptions,\n callback: DoneFn,\n ): CancelFn {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const deps = this.#deps!;\n\n // Quick check of the state of the router\n if (!this.isRouterStarted()) {\n const err = new RouterError(errorCodes.ROUTER_NOT_STARTED);\n\n safeCallback(callback, err);\n\n return noop;\n }\n\n // build route state with segments (avoids duplicate getSegmentsByName call)\n const result = deps.buildStateWithSegments(name, params);\n\n if (!result) {\n const err = new RouterError(errorCodes.ROUTE_NOT_FOUND);\n\n safeCallback(callback, err);\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n deps.getState(),\n err,\n );\n\n return noop;\n }\n\n const { state: route, segments } = result;\n\n // create a target state\n const toState = deps.makeState(\n route.name,\n route.params,\n deps.buildPath(route.name, route.params, segments),\n {\n params: route.meta,\n options: opts,\n redirected: opts.redirected ?? false,\n },\n );\n\n // Early return for skipTransition - no state equality check needed\n // eslint-disable-next-line @typescript-eslint/no-deprecated,sonarjs/deprecation\n if (opts.skipTransition) {\n // toState is already frozen from makeState()\n safeCallback(callback, undefined, toState);\n\n return noop;\n }\n\n const fromState = deps.getState();\n\n // Fast verification for the same states\n if (\n !opts.reload &&\n !opts.force &&\n deps.areStatesEqual(fromState, toState, false)\n ) {\n const err = new RouterError(errorCodes.SAME_STATES);\n\n safeCallback(callback, err);\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n toState,\n fromState,\n err,\n );\n\n return noop;\n }\n\n // transition execution with TRANSITION_SUCCESS emission\n // Note: Guards cannot redirect - redirects are handled in middleware only\n return this.navigateToState(toState, fromState, opts, callback, true); // emitSuccess = true for public navigate()\n }\n\n /**\n * Navigates to the default route if configured.\n * Arguments should be pre-parsed and validated by facade.\n */\n navigateToDefault(opts: NavigationOptions, callback: DoneFn): CancelFn {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const deps = this.#deps!;\n const options = deps.getOptions();\n\n if (!options.defaultRoute) {\n return noop;\n }\n\n return this.navigate(\n options.defaultRoute,\n options.defaultParams,\n opts,\n callback,\n );\n }\n}\n","// packages/core/src/namespaces/RouterLifecycleNamespace/constants.ts\n\nimport { errorCodes } from \"../../constants\";\nimport { RouterError } from \"../../RouterError\";\n\n/**\n * No-op function for default callbacks.\n */\nexport const noop = (): void => {};\n\n// =============================================================================\n// Cached Errors (Performance Optimization)\n// =============================================================================\n// Pre-create error instances to avoid object allocation on hot paths.\n// Error creation involves: new object, stack trace capture (~500ns-2Ξs).\n// Cached errors skip this overhead entirely.\n//\n// Trade-off: All error instances share the same stack trace (points here).\n// This is acceptable because:\n// 1. These errors indicate user misconfiguration, not internal bugs\n// 2. Error code and message are sufficient for debugging\n// 3. Performance gain (~80% for error paths) outweighs stack trace loss\n// =============================================================================\n\n/**\n * Cached error for start() called without path/state and no defaultRoute.\n */\nexport const CACHED_NO_START_PATH_ERROR = new RouterError(\n errorCodes.NO_START_PATH_OR_STATE,\n);\n\n/**\n * Cached error for start() called when router is already started/starting.\n */\nexport const CACHED_ALREADY_STARTED_ERROR = new RouterError(\n errorCodes.ROUTER_ALREADY_STARTED,\n);\n","// packages/core/src/namespaces/RouterLifecycleNamespace/helpers.ts\n\nimport { isState } from \"type-guards\";\n\nimport { noop } from \"./constants\";\n\nimport type {\n RouterLifecycleDependencies,\n StartRouterArguments,\n} from \"./types\";\nimport type { DoneFn, State } from \"@real-router/types\";\n\n/**\n * Dependencies required for resolveStartState helper.\n */\ntype ResolveStartStateDeps = Pick<\n RouterLifecycleDependencies,\n \"matchPath\" | \"buildPath\"\n>;\n\n/**\n * Parses start() arguments into a normalized tuple.\n */\nexport const getStartRouterArguments = (\n args: StartRouterArguments,\n): [startPathOrState: string | State | undefined, done: DoneFn] => {\n const [first, second] = args;\n\n if (!first) {\n return [undefined, noop];\n }\n if (typeof first === \"function\") {\n return [undefined, first];\n }\n\n return [first, second ?? noop];\n};\n\n/**\n * Resolves a path or state to a valid State object.\n */\nexport const resolveStartState = (\n pathOrState: string | State,\n deps: ResolveStartStateDeps,\n): State | undefined => {\n if (typeof pathOrState === \"string\") {\n return deps.matchPath(pathOrState);\n }\n\n // Validate state object structure using isState type guard\n // This validates: name (non-empty string), path (string), params (plain object)\n // Rejects: missing fields, wrong types, functions, symbols, class instances\n if (!isState(pathOrState)) {\n return undefined;\n }\n\n // Validate that the route exists\n // buildPath throws RouteNotFoundError for invalid routes, so we wrap in try-catch\n // to gracefully return undefined instead of propagating the error\n // See: https://github.com/greydragon888/real-router/issues/42\n try {\n deps.buildPath(pathOrState.name, pathOrState.params);\n } catch {\n return undefined;\n }\n\n return pathOrState;\n};\n","// packages/core/src/namespaces/RouterLifecycleNamespace/RouterLifecycleNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport {\n CACHED_ALREADY_STARTED_ERROR,\n CACHED_NO_START_PATH_ERROR,\n} from \"./constants\";\nimport { getStartRouterArguments, resolveStartState } from \"./helpers\";\nimport { errorCodes, events } from \"../../constants\";\nimport { RouterError } from \"../../RouterError\";\n\nimport type {\n RouterLifecycleDependencies,\n StartRouterArguments,\n} from \"./types\";\nimport type {\n CancelFn,\n DoneFn,\n NavigationOptions,\n Params,\n RouterError as RouterErrorType,\n State,\n} from \"@real-router/types\";\n\n// âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n// CYCLIC DEPENDENCIES\n// âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n// RouterLifecycle â Navigation.navigateToState() (for start transitions)\n// RouterLifecycle â Navigation.isNavigating() (check before stop)\n//\n// Solution: functional references configured in Router.#setupDependencies()\n// âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n\n/**\n * Independent namespace for managing router lifecycle.\n *\n * Handles start(), stop(), isStarted(), and isActive().\n */\nexport class RouterLifecycleNamespace {\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n // Functional references for cyclic dependencies\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n\n /**\n * Functional reference to NavigationNamespace.navigateToState().\n * Must be set before calling start().\n */\n\n navigateToState!: (\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ) => CancelFn;\n\n #started = false;\n #active = false;\n\n // Dependencies injected via setDependencies (replaces full router reference)\n #deps: RouterLifecycleDependencies | undefined;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates start() arguments.\n */\n static validateStartArgs(args: unknown[]): void {\n if (args.length > 2) {\n throw new Error(\n \"[router.start] Invalid number of arguments. Expected 0-2 arguments.\",\n );\n }\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n /**\n * Sets dependencies for lifecycle operations.\n * Must be called before using lifecycle methods.\n */\n setDependencies(deps: RouterLifecycleDependencies): void {\n this.#deps = deps;\n }\n\n // =========================================================================\n // Instance methods\n // =========================================================================\n\n /**\n * Checks if the router has completed its initial start.\n */\n isStarted(): boolean {\n return this.#started;\n }\n\n /**\n * Checks if the router is starting or started (allows transitions).\n * Used by transition to check if transitions should be cancelled.\n */\n isActive(): boolean {\n return this.#active;\n }\n\n /**\n * Starts the router with an optional path or state.\n */\n start(...args: StartRouterArguments): void {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const deps = this.#deps!;\n const options = deps.getOptions();\n const [startPathOrState, done] = getStartRouterArguments(args);\n\n let callbackInvoked = false;\n\n // Early return if already started or starting (concurrent start() protection)\n // Issue #50: Check both isStarted() and isActive() to block concurrent start() calls\n // - isStarted(): Router has completed initial start\n // - isActive(): Router is in the process of starting (async transition in progress)\n // Performance: Uses cached error to avoid object allocation (~500ns-2Ξs saved)\n if (this.#started || this.#active) {\n callbackInvoked = true;\n\n done(CACHED_ALREADY_STARTED_ERROR);\n\n return;\n }\n\n // ==========================================================================\n // Early return for NO_START_PATH_OR_STATE (Performance Optimization)\n // ==========================================================================\n // Check BEFORE setIsActive() to avoid:\n // - setIsActive/unsetIsActive calls\n // - handleTransitionComplete overhead\n // - Event emission setup\n //\n // This is a common error case: start() called without path and no defaultRoute.\n // Optimizing this path saves ~80% of error handling overhead.\n // ==========================================================================\n if (!startPathOrState && !options.defaultRoute) {\n callbackInvoked = true;\n\n // Lazy emit: only invoke if listeners exist\n // hasListeners check (~5ns) vs invokeEventListeners validation (~100ns+)\n if (deps.hasListeners(events.TRANSITION_ERROR)) {\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n undefined,\n CACHED_NO_START_PATH_ERROR,\n );\n }\n\n done(CACHED_NO_START_PATH_ERROR);\n\n return;\n }\n\n // Issue #50: Mark router as active BEFORE attempting transition\n // This allows the transition to proceed (isCancelled() checks isActive())\n this.#active = true;\n\n const protectedDone = (err?: RouterError, state?: State) => {\n /* v8 ignore next 5 -- @preserve defensive: protects against user callback bugs */\n if (callbackInvoked) {\n logger.warn(\"real-router\", \"Callback already invoked\");\n\n return;\n }\n\n callbackInvoked = true;\n // State is already frozen from makeState() in start flow\n done(err, state);\n };\n\n // Base options for all operations in start() method\n const startOptions: NavigationOptions = {\n replace: true, // start() always replace history\n };\n\n // Centralized callback for transition completion\n // See: https://github.com/greydragon888/real-router/issues/44\n // Transition errors are always reported (no silent fallback to defaultRoute)\n //\n // See: https://github.com/greydragon888/real-router/issues/50\n // Two-phase start: Only mark router as started AFTER successful transition\n // This prevents inconsistent state where isStarted()=true but getState()=undefined\n //\n // Note: emitErrorEvent controls whether TRANSITION_ERROR event is emitted:\n // - true: for errors NOT going through navigateToState (ROUTE_NOT_FOUND, NO_START_PATH_OR_STATE)\n // - false: for errors from performTransition (navigateToState already emits TRANSITION_ERROR)\n const handleTransitionComplete = (\n err?: RouterError,\n state?: State,\n emitErrorEvent = false,\n ) => {\n if (err) {\n // Issue #50: Unset active flag on failure (router is no longer starting)\n this.#active = false;\n\n if (emitErrorEvent && deps.hasListeners(events.TRANSITION_ERROR)) {\n // Emit TRANSITION_ERROR for errors not going through navigateToState\n // Performance: Skip emission if no listeners\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n undefined,\n err,\n );\n }\n } else {\n // Two-phase start: Only set started and emit ROUTER_START on success\n // See: https://github.com/greydragon888/real-router/issues/50\n this.#started = true;\n deps.invokeEventListeners(events.ROUTER_START);\n\n deps.invokeEventListeners(events.TRANSITION_SUCCESS, state, undefined, {\n replace: true,\n });\n }\n // For performTransition errors, TRANSITION_ERROR is already emitted by navigateToState\n\n protectedDone(err, state);\n };\n\n // Perform the actual transition\n // See: https://github.com/greydragon888/real-router/issues/44\n // On error, always report to handleTransitionComplete (no silent fallback)\n const performTransition = (\n toState: State,\n navOptions: NavigationOptions = {},\n ) => {\n // Use functional reference to NavigationNamespace.navigateToState\n this.navigateToState(\n toState,\n undefined,\n navOptions,\n (err: RouterErrorType | undefined, resultState: State | undefined) => {\n handleTransitionComplete(err, resultState);\n },\n false, // emitSuccess = false - handleTransitionComplete will emit\n );\n };\n\n // Build state for default route and perform transition\n // Uses performTransition to properly handle two-phase start\n const navigateToDefault = (\n defaultRouteName: string,\n defaultParams: Params,\n navOptions: NavigationOptions,\n ) => {\n const defaultRoute = deps.buildState(defaultRouteName, defaultParams);\n\n if (!defaultRoute) {\n handleTransitionComplete(\n new RouterError(errorCodes.ROUTE_NOT_FOUND, {\n routeName: defaultRouteName,\n }),\n undefined,\n true,\n );\n\n return;\n }\n\n const toState = deps.makeState(\n defaultRoute.name,\n defaultRoute.params,\n deps.buildPath(defaultRoute.name, defaultRoute.params),\n {\n params: defaultRoute.meta,\n options: navOptions,\n redirected: false,\n },\n );\n\n performTransition(toState, navOptions);\n };\n\n // Resolve start path/state: use defaultRoute if no explicit path provided\n // Note: Early return for \"no path AND no defaultRoute\" is handled above\n const resolvedStartPathOrState = startPathOrState ?? options.defaultRoute;\n\n // Parse the start path or state\n const startState = resolveStartState(resolvedStartPathOrState, deps);\n\n // Determine the target state and path\n const targetPath =\n typeof resolvedStartPathOrState === \"string\"\n ? resolvedStartPathOrState\n : \"\";\n\n // Perform transition based on conditions\n // All start() transitions should use replace: true\n // See: https://github.com/greydragon888/real-router/issues/43\n if (startState) {\n performTransition(startState, startOptions);\n } else if (options.defaultRoute && !startPathOrState) {\n // IMPORTANT: Check !startPathOrState (original argument), NOT !resolvedStartPathOrState\n // This distinguishes between:\n // - User called start() without path â use defaultRoute (this branch)\n // - User called start('/invalid') with explicit path â error, no silent fallback\n // See: https://github.com/greydragon888/real-router/issues/44\n\n const params = options.defaultParams;\n\n navigateToDefault(options.defaultRoute, params, startOptions);\n } else if (options.allowNotFound) {\n performTransition(\n deps.makeNotFoundState(targetPath, startOptions),\n startOptions,\n );\n } else {\n handleTransitionComplete(\n new RouterError(errorCodes.ROUTE_NOT_FOUND, { path: targetPath }),\n undefined,\n true, // emitErrorEvent: doesn't go through navigateToState\n );\n }\n }\n\n /**\n * Stops the router and resets state.\n */\n stop(): void {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const deps = this.#deps!;\n\n // Issue #50: Always unset active flag when stopping\n // This cancels any in-flight transitions via isCancelled() check\n this.#active = false;\n\n if (this.#started) {\n this.#started = false;\n\n deps.setState();\n\n deps.invokeEventListeners(events.ROUTER_STOP);\n }\n }\n}\n","// packages/core/src/namespaces/CloneNamespace/CloneNamespace.ts\n\nimport { getTypeDescription } from \"type-guards\";\n\nimport type { ApplyConfigFn, CloneData, RouterFactory } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Independent namespace for router cloning operations.\n *\n * This namespace handles the logic of collecting data from a source router\n * and creating a configured clone. It requires a factory function to create\n * the new router instance.\n */\nexport class CloneNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n // =========================================================================\n // Instance fields\n // =========================================================================\n\n /**\n * Function to get cloning data from the source router.\n */\n #getCloneData: (() => CloneData<Dependencies>) | undefined;\n\n /**\n * Function to apply config to a new router.\n */\n #applyConfig: ApplyConfigFn | undefined;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates clone arguments.\n * Dependencies can be undefined or a plain object without getters.\n */\n static validateCloneArgs(dependencies: unknown): void {\n // undefined is valid (no new dependencies)\n if (dependencies === undefined) {\n return;\n }\n\n // Must be a plain object\n if (\n !(\n dependencies &&\n typeof dependencies === \"object\" &&\n dependencies.constructor === Object\n )\n ) {\n throw new TypeError(\n `[router.clone] Invalid dependencies: expected plain object or undefined, received ${getTypeDescription(dependencies)}`,\n );\n }\n\n // Getters can throw, return different values, or have side effects\n for (const key in dependencies) {\n if (Object.getOwnPropertyDescriptor(dependencies, key)?.get) {\n throw new TypeError(\n `[router.clone] Getters not allowed in dependencies: \"${key}\"`,\n );\n }\n }\n }\n\n /**\n * Sets the cloning functions.\n */\n setCallbacks(\n getCloneData: () => CloneData<Dependencies>,\n applyConfig: ApplyConfigFn,\n ): void {\n this.#getCloneData = getCloneData;\n this.#applyConfig = applyConfig;\n }\n\n /**\n * Creates a clone of the router with optional new dependencies.\n *\n * @param dependencies - Optional new dependencies for the cloned router\n * @param factory - Factory function to create the new router instance\n */\n clone(\n dependencies: Dependencies | undefined,\n factory: RouterFactory<Dependencies>,\n ): Router<Dependencies> {\n // Collect all data from source router\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n const data = this.#getCloneData!();\n\n // Merge dependencies\n const mergedDeps = {\n ...data.dependencies,\n ...dependencies,\n } as Dependencies;\n\n // Create new router instance\n const newRouter = factory(data.routes, data.options, mergedDeps);\n\n // Copy lifecycle factories\n for (const [name, handler] of Object.entries(data.canDeactivateFactories)) {\n newRouter.canDeactivate(name, handler);\n }\n\n for (const [name, handler] of Object.entries(data.canActivateFactories)) {\n newRouter.canActivate(name, handler);\n }\n\n // Copy middleware factories\n if (data.middlewareFactories.length > 0) {\n newRouter.useMiddleware(...data.middlewareFactories);\n }\n\n // Copy plugin factories\n if (data.pluginFactories.length > 0) {\n newRouter.usePlugin(...data.pluginFactories);\n }\n\n // Apply route config (decoders, encoders, defaultParams, forwardMap)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- always set by Router\n this.#applyConfig!(\n newRouter as unknown as Router,\n data.routeConfig,\n data.resolvedForwardMap,\n );\n\n return newRouter;\n }\n}\n","// packages/real-router/modules/typeGuards.ts\n\n/**\n * Re-export common type guards from centralized type-guards package\n */\nimport type { LoggerConfig, LogLevelConfig } from \"@real-router/logger\";\n\nexport {\n isObjKey,\n isString,\n isState,\n isParams,\n isNavigationOptions,\n isPromise,\n isBoolean,\n validateRouteName,\n} from \"type-guards\";\n\n/**\n * RealRouter-specific type guards for logger configuration\n */\n\nconst VALID_LEVELS_SET = new Set<string>([\"all\", \"warn-error\", \"error-only\"]);\n\nfunction isValidLevel(value: unknown): value is LogLevelConfig {\n return typeof value === \"string\" && VALID_LEVELS_SET.has(value);\n}\n\nfunction formatValue(value: unknown): string {\n if (typeof value === \"string\") {\n return `\"${value}\"`;\n }\n if (typeof value === \"object\") {\n return JSON.stringify(value);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-base-to-string\n return String(value);\n}\n\nexport function isLoggerConfig(config: unknown): config is LoggerConfig {\n if (typeof config !== \"object\" || config === null) {\n throw new TypeError(\"Logger config must be an object\");\n }\n\n const obj = config;\n\n // Check for unknown properties\n for (const key of Object.keys(obj)) {\n if (key !== \"level\" && key !== \"callback\") {\n throw new TypeError(`Unknown logger config property: \"${key}\"`);\n }\n }\n\n // Validate level if present\n if (\"level\" in obj && obj.level !== undefined && !isValidLevel(obj.level)) {\n throw new TypeError(\n `Invalid logger level: ${formatValue(obj.level)}. Expected: \"all\" | \"warn-error\" | \"error-only\"`,\n );\n }\n\n // Validate callback if present\n if (\n \"callback\" in obj &&\n obj.callback !== undefined &&\n typeof obj.callback !== \"function\"\n ) {\n throw new TypeError(\n `Logger callback must be a function, got ${typeof obj.callback}`,\n );\n }\n\n return true;\n}\n","// packages/core/src/Router.ts\n\n/**\n * Router class - facade with integrated namespaces.\n *\n * All functionality is now provided by namespace classes.\n */\n\nimport { logger } from \"@real-router/logger\";\nimport { validateRouteName } from \"type-guards\";\n\nimport { createLimits } from \"./helpers\";\nimport {\n CloneNamespace,\n DependenciesNamespace,\n MiddlewareNamespace,\n NavigationNamespace,\n ObservableNamespace,\n OptionsNamespace,\n PluginsNamespace,\n RouteLifecycleNamespace,\n RouterLifecycleNamespace,\n RoutesNamespace,\n StateNamespace,\n} from \"./namespaces\";\nimport { isLoggerConfig } from \"./typeGuards\";\n\nimport type { EventMethodMap } from \"./namespaces\";\nimport type { MiddlewareDependencies } from \"./namespaces/MiddlewareNamespace\";\nimport type {\n NavigationDependencies,\n TransitionDependencies,\n} from \"./namespaces/NavigationNamespace\";\nimport type { PluginsDependencies } from \"./namespaces/PluginsNamespace\";\nimport type { RouteLifecycleDependencies } from \"./namespaces/RouteLifecycleNamespace\";\nimport type { RouterLifecycleDependencies } from \"./namespaces/RouterLifecycleNamespace\";\nimport type { RoutesDependencies } from \"./namespaces/RoutesNamespace\";\nimport type {\n ActivationFnFactory,\n Limits,\n MiddlewareFactory,\n PluginFactory,\n Route,\n RouteConfigUpdate,\n} from \"./types\";\nimport type {\n CancelFn,\n DefaultDependencies,\n DoneFn,\n EventName,\n NavigationOptions,\n Navigator,\n Options,\n Params,\n Plugin,\n RouteTreeState,\n SimpleState,\n State,\n StateMetaInput,\n SubscribeFn,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Router class with integrated namespace architecture.\n *\n * All functionality is provided by namespace classes:\n * - OptionsNamespace: getOptions, setOption\n * - DependenciesNamespace: get/set/remove dependencies\n * - ObservableNamespace: event listeners, subscribe\n * - StateNamespace: state storage (getState, setState, getPreviousState)\n * - RoutesNamespace: route tree operations\n * - RouteLifecycleNamespace: canActivate/canDeactivate guards\n * - MiddlewareNamespace: middleware chain\n * - PluginsNamespace: plugin lifecycle\n * - NavigationNamespace: navigate, navigateToState\n * - RouterLifecycleNamespace: start, stop, isStarted\n *\n * @internal This class implementation is internal. Use createRouter() instead.\n */\nexport class Router<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n // Index signatures to satisfy interface\n [key: string]: unknown;\n\n // ============================================================================\n // Namespaces\n // ============================================================================\n\n readonly #options: OptionsNamespace;\n readonly #limits: Limits;\n readonly #dependencies: DependenciesNamespace<Dependencies>;\n readonly #observable: ObservableNamespace;\n readonly #state: StateNamespace;\n readonly #routes: RoutesNamespace<Dependencies>;\n readonly #routeLifecycle: RouteLifecycleNamespace<Dependencies>;\n readonly #middleware: MiddlewareNamespace<Dependencies>;\n readonly #plugins: PluginsNamespace<Dependencies>;\n readonly #navigation: NavigationNamespace;\n readonly #lifecycle: RouterLifecycleNamespace;\n readonly #clone: CloneNamespace<Dependencies>;\n\n /**\n * Cached Navigator instance. Lazily created on first getNavigator() call.\n */\n #navigator: Navigator | null = null;\n\n /**\n * When true, skips argument validation in public methods for production performance.\n * Constructor options are always validated (needed to validate noValidate itself).\n */\n readonly #noValidate: boolean;\n\n // ============================================================================\n // Constructor\n // ============================================================================\n\n /**\n * @param routes - Route definitions\n * @param options - Router options\n * @param dependencies - DI dependencies\n */\n constructor(\n routes: Route<Dependencies>[] = [],\n options: Partial<Options> = {},\n dependencies: Dependencies = {} as Dependencies,\n ) {\n // Configure logger if provided\n if (options.logger && isLoggerConfig(options.logger)) {\n logger.configure(options.logger);\n delete options.logger;\n }\n\n // =========================================================================\n // Validate inputs before creating namespaces\n // =========================================================================\n\n // Always validate options (needed to validate noValidate itself)\n OptionsNamespace.validateOptions(options, \"constructor\");\n\n // Extract noValidate BEFORE creating namespaces\n const noValidate = options.noValidate ?? false;\n\n // Conditional validation for dependencies\n if (!noValidate) {\n DependenciesNamespace.validateDependenciesObject(\n dependencies,\n \"constructor\",\n );\n }\n\n // Conditional validation for initial routes - structure and batch duplicates\n // Validation happens BEFORE tree is built, so tree is not passed\n if (!noValidate && routes.length > 0) {\n RoutesNamespace.validateAddRouteArgs(routes);\n RoutesNamespace.validateRoutes(routes);\n }\n\n // =========================================================================\n // Create Namespaces\n // =========================================================================\n\n this.#options = new OptionsNamespace(options);\n this.#limits = createLimits(options.limits);\n this.#dependencies = new DependenciesNamespace<Dependencies>(dependencies);\n this.#observable = new ObservableNamespace();\n this.#state = new StateNamespace();\n this.#routes = new RoutesNamespace<Dependencies>(routes, noValidate);\n this.#routeLifecycle = new RouteLifecycleNamespace<Dependencies>();\n this.#middleware = new MiddlewareNamespace<Dependencies>();\n this.#plugins = new PluginsNamespace<Dependencies>();\n this.#navigation = new NavigationNamespace();\n this.#lifecycle = new RouterLifecycleNamespace();\n this.#clone = new CloneNamespace<Dependencies>();\n this.#noValidate = noValidate;\n\n // =========================================================================\n // Setup Dependencies\n // =========================================================================\n\n this.#setupDependencies();\n\n // =========================================================================\n // Bind Public Methods\n // =========================================================================\n // All public methods that access private fields must be bound to preserve\n // `this` context when methods are extracted as references.\n // See: https://github.com/nicolo-ribaudo/tc39-proposal-bind-operator\n // =========================================================================\n\n // Route Management\n this.addRoute = this.addRoute.bind(this);\n this.removeRoute = this.removeRoute.bind(this);\n this.clearRoutes = this.clearRoutes.bind(this);\n this.getRoute = this.getRoute.bind(this);\n this.hasRoute = this.hasRoute.bind(this);\n this.updateRoute = this.updateRoute.bind(this);\n\n // Path & State Building\n this.isActiveRoute = this.isActiveRoute.bind(this);\n this.buildPath = this.buildPath.bind(this);\n this.matchPath = this.matchPath.bind(this);\n this.setRootPath = this.setRootPath.bind(this);\n this.getRootPath = this.getRootPath.bind(this);\n\n // State Management\n this.makeState = this.makeState.bind(this);\n this.getState = this.getState.bind(this);\n this.getPreviousState = this.getPreviousState.bind(this);\n this.areStatesEqual = this.areStatesEqual.bind(this);\n this.forwardState = this.forwardState.bind(this);\n this.buildState = this.buildState.bind(this);\n this.shouldUpdateNode = this.shouldUpdateNode.bind(this);\n\n // Options\n this.getOptions = this.getOptions.bind(this);\n this.getOption = this.getOption.bind(this);\n this.setOption = this.setOption.bind(this);\n\n // Router Lifecycle\n this.isActive = this.isActive.bind(this);\n this.start = this.start.bind(this);\n this.stop = this.stop.bind(this);\n\n // Route Lifecycle (Guards)\n this.canDeactivate = this.canDeactivate.bind(this);\n this.canActivate = this.canActivate.bind(this);\n\n // Plugins\n this.usePlugin = this.usePlugin.bind(this);\n\n // Middleware\n this.useMiddleware = this.useMiddleware.bind(this);\n this.clearMiddleware = this.clearMiddleware.bind(this);\n\n // Dependencies\n this.setDependency = this.setDependency.bind(this);\n this.setDependencies = this.setDependencies.bind(this);\n this.getDependency = this.getDependency.bind(this);\n this.getDependencies = this.getDependencies.bind(this);\n this.removeDependency = this.removeDependency.bind(this);\n this.hasDependency = this.hasDependency.bind(this);\n this.resetDependencies = this.resetDependencies.bind(this);\n\n // Events\n this.addEventListener = this.addEventListener.bind(this);\n\n // Navigation\n this.navigate = this.navigate.bind(this);\n this.navigateToDefault = this.navigateToDefault.bind(this);\n this.navigateToState = this.navigateToState.bind(this);\n\n // Subscription\n this.subscribe = this.subscribe.bind(this);\n\n // Cloning\n this.clone = this.clone.bind(this);\n }\n\n // ============================================================================\n // Route Management\n // ============================================================================\n\n addRoute(routes: Route<Dependencies>[] | Route<Dependencies>): this {\n const routeArray = Array.isArray(routes) ? routes : [routes];\n\n if (!this.#noValidate) {\n // 1. Static validation (route structure and properties)\n RoutesNamespace.validateAddRouteArgs(routeArray);\n\n // 2. State-dependent validation (duplicates, parent exists, forwardTo)\n RoutesNamespace.validateRoutes(\n routeArray,\n this.#routes.getTree(),\n this.#routes.getForwardRecord(),\n );\n }\n\n // 3. Execute (add definitions, register handlers, rebuild tree)\n this.#routes.addRoutes(routeArray);\n\n return this;\n }\n\n removeRoute(name: string): this {\n // Static validation\n if (!this.#noValidate) {\n RoutesNamespace.validateRemoveRouteArgs(name);\n }\n\n // Instance validation (checks active route, navigation state)\n const canRemove = this.#routes.validateRemoveRoute(\n name,\n this.#state.get()?.name,\n this.#navigation.isNavigating(),\n );\n\n if (!canRemove) {\n return this;\n }\n\n // Perform removal\n const wasRemoved = this.#routes.removeRoute(name);\n\n if (!wasRemoved) {\n logger.warn(\n \"router.removeRoute\",\n `Route \"${name}\" not found. No changes made.`,\n );\n }\n\n return this;\n }\n\n clearRoutes(): this {\n // Validate operation can proceed\n const canClear = this.#routes.validateClearRoutes(\n this.#navigation.isNavigating(),\n );\n\n if (!canClear) {\n return this;\n }\n\n // Clear routes config (definitions, decoders, encoders, defaultParams, forwardMap)\n this.#routes.clearRoutes();\n\n // Clear all lifecycle handlers\n this.#routeLifecycle.clearAll();\n\n // Clear router state since all routes are removed\n this.#state.set(undefined);\n\n return this;\n }\n\n getRoute(name: string): Route<Dependencies> | undefined {\n if (!this.#noValidate) {\n validateRouteName(name, \"getRoute\");\n }\n\n return this.#routes.getRoute(name);\n }\n\n hasRoute(name: string): boolean {\n if (!this.#noValidate) {\n validateRouteName(name, \"hasRoute\");\n }\n\n return this.#routes.hasRoute(name);\n }\n\n updateRoute(name: string, updates: RouteConfigUpdate<Dependencies>): this {\n // Validate name and updates object structure (basic checks only)\n if (!this.#noValidate) {\n RoutesNamespace.validateUpdateRouteBasicArgs(name, updates);\n }\n\n // Cache all property values upfront to protect against mutating getters.\n // This ensures consistent behavior regardless of getter side effects.\n // Must happen AFTER basic validation but BEFORE property type validation.\n const {\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n canActivate,\n } = updates;\n\n // Validate cached property values\n if (!this.#noValidate) {\n RoutesNamespace.validateUpdateRoutePropertyTypes(\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n );\n }\n\n // Warn if navigation is in progress\n if (this.#navigation.isNavigating()) {\n logger.error(\n \"router.updateRoute\",\n `Updating route \"${name}\" while navigation is in progress. This may cause unexpected behavior.`,\n );\n }\n\n // Instance validation (route existence, forwardTo checks) - use cached values\n if (!this.#noValidate) {\n this.#routes.validateUpdateRoute(name, forwardTo);\n }\n\n // Update route config\n this.#routes.updateRouteConfig(name, {\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n });\n\n // Handle canActivate separately (uses RouteLifecycleNamespace)\n // Use facade method for proper validation\n if (canActivate !== undefined) {\n if (canActivate === null) {\n this.#routeLifecycle.clearCanActivate(name, true);\n } else {\n this.canActivate(name, canActivate);\n }\n }\n\n return this;\n }\n\n // ============================================================================\n // Path & State Building\n // ============================================================================\n\n isActiveRoute(\n name: string,\n params?: Params,\n strictEquality?: boolean,\n ignoreQueryParams?: boolean,\n ): boolean {\n if (!this.#noValidate) {\n RoutesNamespace.validateIsActiveRouteArgs(\n name,\n params,\n strictEquality,\n ignoreQueryParams,\n );\n }\n\n // Empty string is special case - warn and return false (root node is not a parent)\n if (name === \"\") {\n logger.warn(\n \"real-router\",\n 'isActiveRoute(\"\") called with empty string. Root node is not considered a parent of any route.',\n );\n\n return false;\n }\n\n return this.#routes.isActiveRoute(\n name,\n params,\n strictEquality,\n ignoreQueryParams,\n );\n }\n\n buildPath(route: string, params?: Params): string {\n if (!this.#noValidate) {\n RoutesNamespace.validateBuildPathArgs(route);\n }\n\n return this.#routes.buildPath(route, params, this.#options.get());\n }\n\n matchPath<P extends Params = Params, MP extends Params = Params>(\n path: string,\n source?: string,\n ): State<P, MP> | undefined {\n if (!this.#noValidate) {\n RoutesNamespace.validateMatchPathArgs(path);\n }\n\n return this.#routes.matchPath<P, MP>(path, source, this.#options.get());\n }\n\n setRootPath(rootPath: string): void {\n if (!this.#noValidate) {\n RoutesNamespace.validateSetRootPathArgs(rootPath);\n }\n\n this.#routes.setRootPath(rootPath);\n }\n\n getRootPath(): string {\n return this.#routes.getRootPath();\n }\n\n // ============================================================================\n // State Management (delegated to StateNamespace)\n // ============================================================================\n\n makeState<P extends Params = Params, MP extends Params = Params>(\n name: string,\n params?: P,\n path?: string,\n meta?: StateMetaInput<MP>,\n forceId?: number,\n ): State<P, MP> {\n if (!this.#noValidate) {\n StateNamespace.validateMakeStateArgs(name, params, path, forceId);\n }\n\n return this.#state.makeState<P, MP>(name, params, path, meta, forceId);\n }\n\n getState<P extends Params = Params, MP extends Params = Params>():\n | State<P, MP>\n | undefined {\n return this.#state.get<P, MP>();\n }\n\n getPreviousState(): State | undefined {\n return this.#state.getPrevious();\n }\n\n areStatesEqual(\n state1: State | undefined,\n state2: State | undefined,\n ignoreQueryParams = true,\n ): boolean {\n if (!this.#noValidate) {\n StateNamespace.validateAreStatesEqualArgs(\n state1,\n state2,\n ignoreQueryParams,\n );\n }\n\n return this.#state.areStatesEqual(state1, state2, ignoreQueryParams);\n }\n\n forwardState<P extends Params = Params>(\n routeName: string,\n routeParams: P,\n ): SimpleState<P> {\n if (!this.#noValidate) {\n RoutesNamespace.validateStateBuilderArgs(\n routeName,\n routeParams,\n \"forwardState\",\n );\n }\n\n return this.#routes.forwardState<P>(routeName, routeParams);\n }\n\n buildState(\n routeName: string,\n routeParams: Params,\n ): RouteTreeState | undefined {\n if (!this.#noValidate) {\n RoutesNamespace.validateStateBuilderArgs(\n routeName,\n routeParams,\n \"buildState\",\n );\n }\n\n // Call forwardState at facade level to allow plugin interception\n const { name, params } = this.forwardState(routeName, routeParams);\n\n return this.#routes.buildStateResolved(name, params);\n }\n\n shouldUpdateNode(\n nodeName: string,\n ): (toState: State, fromState?: State) => boolean {\n if (!this.#noValidate) {\n RoutesNamespace.validateShouldUpdateNodeArgs(nodeName);\n }\n\n return this.#routes.shouldUpdateNode(nodeName);\n }\n\n // ============================================================================\n // Options (backed by OptionsNamespace)\n // ============================================================================\n\n getOptions(): Options {\n return this.#options.get();\n }\n\n getOption<K extends keyof Options>(option: K): Options[K] {\n if (!this.#noValidate) {\n OptionsNamespace.validateOptionName(option, \"getOption\");\n OptionsNamespace.validateOptionExists(option, \"getOption\");\n }\n\n return this.#options.getOption(option);\n }\n\n setOption(option: keyof Options, value: Options[keyof Options]): this {\n if (!this.#noValidate) {\n OptionsNamespace.validateOptionName(option, \"setOption\");\n OptionsNamespace.validateOptionExists(option, \"setOption\");\n OptionsNamespace.validateNotLocked(this.#options.isLocked(), option);\n OptionsNamespace.validateOptionValue(option, value, \"setOption\");\n }\n\n this.#options.set(option, value);\n\n return this;\n }\n\n // ============================================================================\n // Router Lifecycle\n // ============================================================================\n\n isActive(): boolean {\n return this.#lifecycle.isActive();\n }\n\n start(\n ...args:\n | []\n | [done: DoneFn]\n | [startPathOrState: string | State]\n | [startPathOrState: string | State, done: DoneFn]\n ): this {\n // Static validation\n if (!this.#noValidate) {\n RouterLifecycleNamespace.validateStartArgs(args);\n }\n\n // Lock options when router starts\n this.#options.lock();\n\n // Initialize build options cache\n this.#routes.initBuildOptionsCache(this.#options.get());\n\n // Forward to lifecycle namespace\n this.#lifecycle.start(...args);\n\n return this;\n }\n\n stop(): this {\n this.#lifecycle.stop();\n\n // Clear build options cache\n this.#routes.clearBuildOptionsCache();\n\n // Unlock options when router stops\n this.#options.unlock();\n\n return this;\n }\n\n // ============================================================================\n // Route Lifecycle (Guards)\n // ============================================================================\n\n canDeactivate(\n name: string,\n canDeactivateHandler: ActivationFnFactory<Dependencies> | boolean,\n ): this {\n if (!this.#noValidate) {\n // 1. Validate input\n validateRouteName(name, \"canDeactivate\");\n RouteLifecycleNamespace.validateHandler(\n canDeactivateHandler,\n \"canDeactivate\",\n );\n\n // 2. Validate not registering\n RouteLifecycleNamespace.validateNotRegistering(\n this.#routeLifecycle.isRegistering(name),\n name,\n \"canDeactivate\",\n );\n }\n\n // 3. Check if overwrite and validate limit\n const isOverwrite = this.#routeLifecycle.hasCanDeactivate(name);\n\n if (!isOverwrite && !this.#noValidate) {\n RouteLifecycleNamespace.validateHandlerLimit(\n this.#routeLifecycle.countCanDeactivate() + 1,\n \"canDeactivate\",\n this.#limits.maxLifecycleHandlers,\n );\n }\n\n // 4. Execute\n this.#routeLifecycle.registerCanDeactivate(\n name,\n canDeactivateHandler,\n isOverwrite,\n );\n\n return this;\n }\n\n canActivate(\n name: string,\n canActivateHandler: ActivationFnFactory<Dependencies> | boolean,\n ): this {\n if (!this.#noValidate) {\n // 1. Validate input\n validateRouteName(name, \"canActivate\");\n RouteLifecycleNamespace.validateHandler(\n canActivateHandler,\n \"canActivate\",\n );\n\n // 2. Validate not registering\n RouteLifecycleNamespace.validateNotRegistering(\n this.#routeLifecycle.isRegistering(name),\n name,\n \"canActivate\",\n );\n }\n\n // 3. Check if overwrite and validate limit\n const isOverwrite = this.#routeLifecycle.hasCanActivate(name);\n\n if (!isOverwrite && !this.#noValidate) {\n RouteLifecycleNamespace.validateHandlerLimit(\n this.#routeLifecycle.countCanActivate() + 1,\n \"canActivate\",\n this.#limits.maxLifecycleHandlers,\n );\n }\n\n // 4. Execute\n this.#routeLifecycle.registerCanActivate(\n name,\n canActivateHandler,\n isOverwrite,\n );\n\n return this;\n }\n\n // ============================================================================\n // Plugins\n // ============================================================================\n\n usePlugin(...plugins: PluginFactory<Dependencies>[]): Unsubscribe {\n if (!this.#noValidate) {\n // 1. Validate input arguments\n PluginsNamespace.validateUsePluginArgs<Dependencies>(plugins);\n\n // 2. Validate limit\n PluginsNamespace.validatePluginLimit(\n this.#plugins.count(),\n plugins.length,\n this.#limits.maxPlugins,\n );\n\n // 3. Validate no duplicates with existing plugins\n PluginsNamespace.validateNoDuplicatePlugins(\n plugins,\n this.#plugins.has.bind(this.#plugins),\n );\n }\n\n // 4. Execute (warnings, deduplication, initialization, commit)\n return this.#plugins.use(...plugins);\n }\n\n // ============================================================================\n // Middleware\n // ============================================================================\n\n useMiddleware(\n ...middlewares: MiddlewareFactory<Dependencies>[]\n ): Unsubscribe {\n if (!this.#noValidate) {\n // 1. Validate input arguments\n MiddlewareNamespace.validateUseMiddlewareArgs<Dependencies>(middlewares);\n\n // 2. Validate no duplicates\n MiddlewareNamespace.validateNoDuplicates<Dependencies>(\n middlewares,\n this.#middleware.getFactories(),\n );\n\n // 3. Validate limit\n MiddlewareNamespace.validateMiddlewareLimit(\n this.#middleware.count(),\n middlewares.length,\n this.#limits.maxMiddleware,\n );\n }\n\n // 4. Initialize (without committing)\n const initialized = this.#middleware.initialize(...middlewares);\n\n // 5. Validate results\n if (!this.#noValidate) {\n for (const { middleware, factory } of initialized) {\n MiddlewareNamespace.validateMiddleware<Dependencies>(\n middleware,\n factory,\n );\n }\n }\n\n // 6. Commit\n return this.#middleware.commit(initialized);\n }\n\n clearMiddleware(): this {\n this.#middleware.clear();\n\n return this;\n }\n\n // ============================================================================\n // Dependencies (backed by DependenciesNamespace)\n // ============================================================================\n\n setDependency<K extends keyof Dependencies & string>(\n dependencyName: K,\n dependency: Dependencies[K],\n ): this {\n if (!this.#noValidate) {\n DependenciesNamespace.validateSetDependencyArgs(dependencyName);\n }\n\n this.#dependencies.set(dependencyName, dependency);\n\n return this;\n }\n\n setDependencies(deps: Dependencies): this {\n if (!this.#noValidate) {\n DependenciesNamespace.validateDependenciesObject(deps, \"setDependencies\");\n DependenciesNamespace.validateDependencyLimit(\n this.#dependencies.count(),\n Object.keys(deps).length,\n \"setDependencies\",\n this.#limits.maxDependencies,\n );\n }\n\n this.#dependencies.setMultiple(deps);\n\n return this;\n }\n\n getDependency<K extends keyof Dependencies>(key: K): Dependencies[K] {\n if (!this.#noValidate) {\n DependenciesNamespace.validateName(key, \"getDependency\");\n }\n\n const value = this.#dependencies.get(key);\n\n if (!this.#noValidate) {\n DependenciesNamespace.validateDependencyExists(value, key as string);\n }\n\n return value;\n }\n\n getDependencies(): Partial<Dependencies> {\n return this.#dependencies.getAll();\n }\n\n removeDependency(dependencyName: keyof Dependencies): this {\n if (!this.#noValidate) {\n DependenciesNamespace.validateName(dependencyName, \"removeDependency\");\n }\n\n this.#dependencies.remove(dependencyName);\n\n return this;\n }\n\n hasDependency(dependencyName: keyof Dependencies): boolean {\n if (!this.#noValidate) {\n DependenciesNamespace.validateName(dependencyName, \"hasDependency\");\n }\n\n return this.#dependencies.has(dependencyName);\n }\n\n resetDependencies(): this {\n this.#dependencies.reset();\n\n return this;\n }\n\n // ============================================================================\n // Events (backed by ObservableNamespace)\n // ============================================================================\n\n addEventListener<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): Unsubscribe {\n if (!this.#noValidate) {\n ObservableNamespace.validateListenerArgs(eventName, cb);\n }\n\n return this.#observable.addEventListener(eventName, cb);\n }\n\n // ============================================================================\n // Navigation\n // ============================================================================\n\n navigate(\n routeName: string,\n routeParamsOrDone?: Params | DoneFn,\n optionsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): CancelFn {\n // 1. Validate route name\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigateArgs(routeName);\n }\n\n // 2. Parse polymorphic arguments\n const { params, opts, callback } = NavigationNamespace.parseNavigateArgs(\n routeParamsOrDone,\n optionsOrDone,\n done,\n );\n\n // 3. Validate parsed options\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigationOptions(opts, \"navigate\");\n }\n\n // 4. Execute navigation with parsed arguments\n return this.#navigation.navigate(routeName, params, opts, callback);\n }\n\n navigateToDefault(\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): CancelFn {\n // 1. Validate arguments (before parsing)\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigateToDefaultArgs(optsOrDone, done);\n }\n\n // 2. Parse polymorphic arguments\n const { opts, callback } = NavigationNamespace.parseNavigateToDefaultArgs(\n optsOrDone,\n done,\n );\n\n // 3. Validate parsed options\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigationOptions(opts, \"navigateToDefault\");\n }\n\n // 4. Execute navigation with parsed arguments\n return this.#navigation.navigateToDefault(opts, callback);\n }\n\n navigateToState(\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ): CancelFn {\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigateToStateArgs(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n }\n\n return this.#navigation.navigateToState(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n }\n\n // ============================================================================\n // Subscription (backed by ObservableNamespace)\n // ============================================================================\n\n subscribe(listener: SubscribeFn): Unsubscribe {\n if (!this.#noValidate) {\n ObservableNamespace.validateSubscribeListener(listener);\n }\n\n return this.#observable.subscribe(listener);\n }\n\n // ============================================================================\n // Cloning\n // ============================================================================\n\n clone(dependencies?: Dependencies): Router<Dependencies> {\n if (!this.#noValidate) {\n CloneNamespace.validateCloneArgs(dependencies);\n }\n\n return this.#clone.clone(\n dependencies,\n (routes, options, deps) =>\n new Router<Dependencies>(routes, options, deps),\n );\n }\n\n getNavigator(): Navigator {\n this.#navigator ??= Object.freeze({\n navigate: this.navigate,\n getState: this.getState,\n isActiveRoute: this.isActiveRoute,\n subscribe: this.subscribe,\n });\n\n return this.#navigator;\n }\n\n // ============================================================================\n // Private Methods\n // ============================================================================\n\n /**\n * Sets up dependencies between namespaces.\n * Called once in constructor after all namespaces are created.\n */\n #setupDependencies(): void {\n // Set limits for all namespaces that use them\n this.#dependencies.setLimits(this.#limits);\n this.#plugins.setLimits(this.#limits);\n this.#middleware.setLimits(this.#limits);\n this.#observable.setLimits(this.#limits);\n this.#routeLifecycle.setLimits(this.#limits);\n\n // RouteLifecycleNamespace must be set up FIRST because RoutesNamespace.setDependencies()\n // will register pending canActivate handlers which need RouteLifecycleNamespace\n this.#routeLifecycle.setRouter(this);\n\n // RouteLifecycleNamespace uses function injection for getDependency\n const routeLifecycleDeps: RouteLifecycleDependencies<Dependencies> = {\n getDependency: <K extends keyof Dependencies>(dependencyName: K) =>\n this.#dependencies.get(dependencyName),\n };\n\n this.#routeLifecycle.setDependencies(routeLifecycleDeps);\n\n // RoutesNamespace uses function injection (will register pending canActivate handlers)\n // Use facade method for proper validation\n const routesDeps: RoutesDependencies<Dependencies> = {\n canActivate: (name, handler) => {\n this.canActivate(name, handler);\n },\n makeState: (name, params, path, meta) =>\n this.#state.makeState(name, params, path, meta),\n getState: () => this.#state.get(),\n areStatesEqual: (state1, state2, ignoreQueryParams) =>\n this.#state.areStatesEqual(state1, state2, ignoreQueryParams),\n };\n\n this.#routes.setDependencies(routesDeps);\n this.#routes.setLifecycleNamespace(this.#routeLifecycle);\n\n this.#middleware.setRouter(this);\n\n // MiddlewareNamespace uses function injection for getDependency\n const middlewareDeps: MiddlewareDependencies<Dependencies> = {\n getDependency: <K extends keyof Dependencies>(dependencyName: K) =>\n this.#dependencies.get(dependencyName),\n };\n\n this.#middleware.setDependencies(middlewareDeps);\n\n this.#plugins.setRouter(this);\n\n // PluginsNamespace uses function injection for internal @internal method calls\n const pluginsDeps: PluginsDependencies<Dependencies> = {\n addEventListener: (eventName, cb) =>\n this.#observable.addEventListener(eventName, cb),\n isStarted: () => this.#lifecycle.isStarted(),\n getDependency: <K extends keyof Dependencies>(dependencyName: K) =>\n this.#dependencies.get(dependencyName),\n };\n\n this.#plugins.setDependencies(pluginsDeps);\n\n // NavigationNamespace uses function injection\n const navigationDeps: NavigationDependencies = {\n getOptions: () => this.#options.get(),\n hasRoute: (name) => this.#routes.hasRoute(name),\n getState: () => this.#state.get(),\n setState: (state) => {\n this.#state.set(state);\n },\n buildStateWithSegments: (routeName, routeParams) => {\n // Call forwardState to allow plugin interception\n const { name, params } = this.forwardState(routeName, routeParams);\n\n return this.#routes.buildStateWithSegmentsResolved(name, params);\n },\n makeState: (name, params, path, meta) =>\n this.#state.makeState(name, params, path, meta),\n buildPath: (route, params, segments) =>\n this.#routes.buildPath(route, params, this.#options.get(), segments),\n areStatesEqual: (state1, state2, ignoreQueryParams) =>\n this.#state.areStatesEqual(state1, state2, ignoreQueryParams),\n invokeEventListeners: (eventName, toState, fromState, arg) => {\n this.#observable.invoke(eventName, toState, fromState, arg);\n },\n };\n\n this.#navigation.setDependencies(navigationDeps);\n\n const transitionDeps: TransitionDependencies = {\n getLifecycleFunctions: () => this.#routeLifecycle.getFunctions(),\n getMiddlewareFunctions: () => this.#middleware.getFunctions(),\n isActive: () => this.#lifecycle.isActive(),\n clearCanDeactivate: (name) => {\n this.#routeLifecycle.clearCanDeactivate(name);\n },\n };\n\n this.#navigation.setTransitionDependencies(transitionDeps);\n\n // RouterLifecycleNamespace uses function injection\n // Use facade methods to ensure spies work and plugin interception is possible\n const lifecycleDeps: RouterLifecycleDependencies = {\n getOptions: () => this.#options.get(),\n hasListeners: (eventName) => this.#observable.hasListeners(eventName),\n invokeEventListeners: (eventName, toState, fromState, arg) => {\n this.#observable.invoke(eventName, toState, fromState, arg);\n },\n buildState: (routeName, routeParams) =>\n this.buildState(routeName, routeParams),\n makeState: (name, params, path, meta) =>\n this.#state.makeState(name, params, path, meta),\n buildPath: (route, params) => this.buildPath(route, params),\n makeNotFoundState: (path, options) =>\n this.#state.makeNotFoundState(path, options),\n setState: (state) => {\n this.#state.set(state);\n },\n // RouterLifecycleNamespace only uses matchPath without source parameter\n matchPath: (path, source?: string) =>\n this.#routes.matchPath(path, source, this.#options.get()),\n };\n\n this.#lifecycle.setDependencies(lifecycleDeps);\n\n // StateNamespace needs access to route config and path building\n this.#state.setDependencies({\n getDefaultParams: () => this.#routes.getConfig().defaultParams,\n buildPath: (name, params) =>\n this.#routes.buildPath(name, params, this.#options.get()),\n getUrlParams: (name) => this.#routes.getUrlParams(name),\n });\n\n // =========================================================================\n // Setup cyclic dependencies via functional references\n // =========================================================================\n // Navigation â RouterLifecycle.isStarted() (check before navigation)\n // RouterLifecycle â Navigation.navigateToState() (for start transitions)\n // =========================================================================\n\n this.#navigation.isRouterStarted = () => this.#lifecycle.isStarted();\n\n // Use facade method so tests can spy on router.navigateToState\n this.#lifecycle.navigateToState = (\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ) =>\n this.#navigation.navigateToState(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n\n // CloneNamespace needs access to collect cloning data and apply config\n this.#clone.setCallbacks(\n // getCloneData: collect all data needed for cloning\n () => {\n const [canDeactivateFactories, canActivateFactories] =\n this.#routeLifecycle.getFactories();\n\n return {\n routes: this.#routes.cloneRoutes(),\n options: { ...this.#options.get() },\n dependencies: this.#dependencies.getAll(),\n canDeactivateFactories,\n canActivateFactories,\n middlewareFactories: this.#middleware.getFactories(),\n pluginFactories: this.#plugins.getAll(),\n routeConfig: this.#routes.getConfig(),\n resolvedForwardMap: this.#routes.getResolvedForwardMap(),\n };\n },\n // applyConfig: apply route config to new router\n (newRouter, config, resolvedForwardMap) => {\n // Access new router's internal config via type assertion\n // This is safe because we know the newRouter is a Router instance\n const typedRouter = newRouter as unknown as Router<Dependencies>;\n const newConfig = typedRouter.#routes.getConfig();\n\n Object.assign(newConfig.decoders, config.decoders);\n Object.assign(newConfig.encoders, config.encoders);\n Object.assign(newConfig.defaultParams, config.defaultParams);\n Object.assign(newConfig.forwardMap, config.forwardMap);\n\n typedRouter.#routes.setResolvedForwardMap({ ...resolvedForwardMap });\n },\n );\n }\n}\n","// packages/core/src/createRouter.ts\n\nimport { Router } from \"./Router\";\n\nimport type { Route } from \"./types\";\nimport type { DefaultDependencies, Options } from \"@real-router/types\";\n\n/**\n * Creates a new router instance.\n *\n * @param routes - Array of route definitions\n * @param options - Router configuration options\n * @param dependencies - Dependencies to inject into the router\n * @returns A new Router instance\n *\n * @example\n * const router = createRouter([\n * { name: 'home', path: '/' },\n * { name: 'users', path: '/users' },\n * ]);\n *\n * router.start('/');\n */\nexport const createRouter = <\n Dependencies extends DefaultDependencies = DefaultDependencies,\n>(\n routes: Route<Dependencies>[] = [],\n options: Partial<Options> = {},\n dependencies: Dependencies = {} as Dependencies,\n): Router<Dependencies> => {\n return new Router<Dependencies>(routes, options, dependencies);\n};\n"]}
|
|
1
|
+
{"version":3,"sources":["../../../type-guards/src/guards/navigation.ts","../../../type-guards/src/internal/router-error.ts","../../../type-guards/src/guards/routes.ts","../../../type-guards/src/guards/params.ts","../../../type-guards/src/internal/meta-fields.ts","../../../type-guards/src/guards/state.ts","../../../type-guards/src/guards/primitives.ts","../../../type-guards/src/validators/routes.ts","../../../type-guards/src/utilities/type-description.ts","../../../type-guards/src/validators/state.ts","../../src/constants.ts","../../src/helpers.ts","../../src/namespaces/DependenciesNamespace/validators.ts","../../src/namespaces/DependenciesNamespace/DependenciesNamespace.ts","../../src/namespaces/ObservableNamespace/constants.ts","../../src/namespaces/ObservableNamespace/helpers.ts","../../src/namespaces/ObservableNamespace/ObservableNamespace.ts","../../src/namespaces/OptionsNamespace/constants.ts","../../src/namespaces/OptionsNamespace/helpers.ts","../../src/namespaces/OptionsNamespace/validators.ts","../../src/namespaces/OptionsNamespace/OptionsNamespace.ts","../../src/namespaces/StateNamespace/helpers.ts","../../src/namespaces/StateNamespace/StateNamespace.ts","../../src/namespaces/MiddlewareNamespace/validators.ts","../../src/namespaces/MiddlewareNamespace/MiddlewareNamespace.ts","../../src/namespaces/PluginsNamespace/constants.ts","../../src/namespaces/PluginsNamespace/validators.ts","../../src/namespaces/PluginsNamespace/PluginsNamespace.ts","../../src/namespaces/RouteLifecycleNamespace/validators.ts","../../src/namespaces/RouteLifecycleNamespace/RouteLifecycleNamespace.ts","../../../route-tree/src/builder/buildTree.ts","../../../route-tree/src/services/buildParamMeta.ts","../../../route-tree/src/builder/computeCaches.ts","../../../route-tree/src/builder/createRouteTree.ts","../../../search-params/src/decode.ts","../../../search-params/src/strategies/array.ts","../../../search-params/src/strategies/boolean.ts","../../../search-params/src/strategies/null.ts","../../../search-params/src/strategies/index.ts","../../../search-params/src/encode.ts","../../../search-params/src/utils.ts","../../../search-params/src/searchParams.ts","../../../route-tree/src/operations/query.ts","../../../route-tree/src/services/constraintValidation.ts","../../../route-tree/src/services/encoding.ts","../../../route-tree/src/services/inject.ts","../../../route-tree/src/validation/errors.ts","../../../route-tree/src/operations/build.ts","../../../route-tree/src/operations/routeTreeToDefinitions.ts","../../../../node_modules/.pnpm/rou3@0.7.12/node_modules/rou3/dist/index.mjs","../../../route-tree/src/services/MatcherService.ts","../../../route-tree/src/validation/routes.ts","../../../route-tree/src/validation/route-batch.ts","../../src/namespaces/RoutesNamespace/constants.ts","../../src/namespaces/RoutesNamespace/helpers.ts","../../src/namespaces/RoutesNamespace/stateBuilder.ts","../../src/namespaces/RoutesNamespace/validators.ts","../../src/transitionPath.ts","../../src/namespaces/RoutesNamespace/RoutesNamespace.ts","../../src/namespaces/NavigationNamespace/helpers.ts","../../../logger/src/constants.ts","../../../logger/src/Logger.ts","../../src/namespaces/NavigationNamespace/transition/makeError.ts","../../src/namespaces/NavigationNamespace/transition/mergeStates.ts","../../src/RouterError.ts","../../src/namespaces/NavigationNamespace/transition/processLifecycleResult.ts","../../src/namespaces/NavigationNamespace/transition/shared.ts","../../src/namespaces/NavigationNamespace/transition/wrapSyncError.ts","../../src/namespaces/NavigationNamespace/transition/executeLifecycleHooks.ts","../../src/namespaces/NavigationNamespace/transition/executeMiddleware.ts","../../src/namespaces/NavigationNamespace/transition/index.ts","../../src/namespaces/NavigationNamespace/validators.ts","../../src/namespaces/NavigationNamespace/NavigationNamespace.ts","../../src/namespaces/RouterLifecycleNamespace/constants.ts","../../src/namespaces/RouterLifecycleNamespace/helpers.ts","../../src/namespaces/RouterLifecycleNamespace/RouterLifecycleNamespace.ts","../../src/namespaces/CloneNamespace/CloneNamespace.ts","../../src/typeGuards.ts","../../src/Router.ts","../../src/createRouter.ts"],"names":["logger","plugins","unsubscribed","encodeValue","nodeQueryIndex","createRouterError","FULL_ROUTE_PATTERN","HAS_NON_WHITESPACE","MAX_ROUTE_NAME_LENGTH","getTypeDescription","validateRouteName","DEFAULT_ROUTE_NAME","safeCallback","LOG_TAG","noop","createRouter"],"mappings":";;;AAKA,IAAM,yBAAA,GAA4B;AAAA,EAChC,SAAA;AAAA,EACA,QAAA;AAAA,EACA,gBAAA;AAAA,EACA,OAAA;AAAA,EACA,iBAAA;AAAA,EACA;AACF,CAAA;AAeO,SAAS,oBACd,KAAA,EAC4B;AAC5B,EAAA,IAAI,OAAO,UAAU,QAAA,IAAY,KAAA,KAAU,QAAQ,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AACvE,IAAA,OAAO,KAAA;AAAA,EACT;AAEA,EAAA,MAAM,GAAA,GAAM,KAAA;AAGZ,EAAA,KAAA,MAAW,SAAS,yBAAA,EAA2B;AAC7C,IAAA,MAAM,UAAA,GAAa,IAAI,KAAK,CAAA;AAE5B,IAAA,IAAI,UAAA,KAAe,MAAA,IAAa,OAAO,UAAA,KAAe,SAAA,EAAW;AAC/D,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;;;ACrCO,IAAM,kBAAA,GAAqB,IAAA;AAW3B,IAAM,kBAAA,GAAqB,yCAAA;AAS3B,IAAM,qBAAA,GAAwB,GAAA;AAU9B,SAAS,iBAAA,CACd,YACA,OAAA,EACW;AACX,EAAA,OAAO,IAAI,SAAA,CAAU,CAAA,QAAA,EAAW,UAAU,CAAA,EAAA,EAAK,OAAO,CAAA,CAAE,CAAA;AAC1D;;;ACHO,SAAS,YAAY,IAAA,EAA+B;AACzD,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAC5B,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAI,SAAS,EAAA,EAAI;AACf,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAI,IAAA,CAAK,SAAS,qBAAA,EAAuB;AACvC,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAI,IAAA,CAAK,UAAA,CAAW,IAAI,CAAA,EAAG;AACzB,IAAA,OAAO,IAAA;AAAA,EACT;AAIA,EAAA,OAAO,kBAAA,CAAmB,KAAK,IAAI,CAAA;AACrC;;;ACnDA,SAAS,cAAA,CACP,KAAA,EACA,OAAA,mBAAU,IAAI,SAAgB,EACrB;AAET,EAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,KAAA,KAAU,MAAA,EAAW;AACzC,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,MAAM,OAAO,OAAO,KAAA;AAGpB,EAAA,IAAI,IAAA,KAAS,QAAA,IAAY,IAAA,KAAS,SAAA,EAAW;AAC3C,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAI,SAAS,QAAA,EAAU;AACrB,IAAA,OAAO,MAAA,CAAO,SAAS,KAAK,CAAA;AAAA,EAC9B;AAGA,EAAA,IAAI,IAAA,KAAS,UAAA,IAAc,IAAA,KAAS,QAAA,EAAU;AAC5C,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AAExB,IAAA,IAAI,OAAA,CAAQ,GAAA,CAAI,KAAK,CAAA,EAAG;AACtB,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,OAAA,CAAQ,IAAI,KAAK,CAAA;AAGjB,IAAA,OAAO,MAAM,KAAA,CAAM,CAAC,SAAS,cAAA,CAAe,IAAA,EAAM,OAAO,CAAC,CAAA;AAAA,EAC5D;AAGA,EAAA,IAAI,SAAS,QAAA,EAAU;AAErB,IAAA,IAAI,OAAA,CAAQ,GAAA,CAAI,KAAK,CAAA,EAAG;AACtB,MAAA,OAAO,KAAA;AAAA,IACT;AAGA,IAAA,OAAA,CAAQ,IAAI,KAAK,CAAA;AAGjB,IAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,cAAA,CAAe,KAAK,CAAA;AAEzC,IAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,KAAA,KAAU,MAAA,CAAO,SAAA,EAAW;AAChD,MAAA,OAAO,KAAA;AAAA,IACT;AAGA,IAAA,OAAO,MAAA,CAAO,MAAA,CAAO,KAAK,CAAA,CAAE,KAAA,CAAM,CAAC,CAAA,KAAM,cAAA,CAAe,CAAA,EAAG,OAAO,CAAC,CAAA;AAAA,EACrE;AAEA,EAAA,OAAO,KAAA;AACT;AAQA,SAAS,iBAAiB,KAAA,EAAyB;AACjD,EAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,KAAA,KAAU,MAAA,EAAW;AACzC,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,MAAM,OAAO,OAAO,KAAA;AAEpB,EAAA,IAAI,IAAA,KAAS,QAAA,IAAY,IAAA,KAAS,SAAA,EAAW;AAC3C,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,IAAI,SAAS,QAAA,EAAU;AACrB,IAAA,OAAO,MAAA,CAAO,SAAS,KAAK,CAAA;AAAA,EAC9B;AAGA,EAAA,OAAO,KAAA;AACT;AAgCO,SAAS,SAAS,KAAA,EAAiC;AAExD,EAAA,IAAI,OAAO,UAAU,QAAA,IAAY,KAAA,KAAU,QAAQ,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AACvE,IAAA,OAAO,KAAA;AAAA,EACT;AAIA,EAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,cAAA,CAAe,KAAK,CAAA;AAEzC,EAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,KAAA,KAAU,MAAA,CAAO,SAAA,EAAW;AAChD,IAAA,OAAO,KAAA;AAAA,EACT;AAIA,EAAA,IAAI,cAAA,GAAiB,KAAA;AAErB,EAAA,KAAA,MAAW,OAAO,KAAA,EAAO;AAMvB,IAAA,IAAI,CAAC,MAAA,CAAO,MAAA,CAAO,KAAA,EAAO,GAAG,CAAA,EAAG;AAC9B,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,GAAA,GAAO,MAAkC,GAAG,CAAA;AAElD,IAAA,IAAI,CAAC,gBAAA,CAAiB,GAAG,CAAA,EAAG;AAG1B,MAAA,MAAM,OAAO,OAAO,GAAA;AAEpB,MAAA,IAAI,IAAA,KAAS,UAAA,IAAc,IAAA,KAAS,QAAA,EAAU;AAC5C,QAAA,OAAO,KAAA;AAAA,MACT;AAEA,MAAA,cAAA,GAAiB,IAAA;AAEjB,MAAA;AAAA,IACF;AAAA,EACF;AAGA,EAAA,IAAI,CAAC,cAAA,EAAgB;AACnB,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,OAAO,eAAe,KAAK,CAAA;AAC7B;;;AC7HO,SAAS,iBAAiB,GAAA,EAAuC;AACtE,EAAA,OACE,WAAA,CAAY,GAAA,CAAI,IAAI,CAAA,IACpB,OAAO,IAAI,IAAA,KAAS,QAAA,IACpB,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA;AAEvB;;;AC9CO,SAAS,QACd,KAAA,EACuB;AACvB,EAAA,IAAI,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,KAAU,IAAA,EAAM;AAC/C,IAAA,OAAO,KAAA;AAAA,EACT;AAEA,EAAA,MAAM,GAAA,GAAM,KAAA;AAEZ,EAAA,OAAO,iBAAiB,GAAG,CAAA;AAC7B;;;ACpBO,SAAS,SAAS,KAAA,EAAiC;AACxD,EAAA,OAAO,OAAO,KAAA,KAAU,QAAA;AAC1B;AAQO,SAAS,UAAU,KAAA,EAAkC;AAC1D,EAAA,OAAO,OAAO,KAAA,KAAU,SAAA;AAC1B;AAQO,SAAS,UAAuB,KAAA,EAAqC;AAC1E,EAAA,OACE,OAAO,UAAU,QAAA,IACjB,KAAA,KAAU,QACV,MAAA,IAAU,KAAA,IACV,OAAO,KAAA,CAAM,IAAA,KAAS,UAAA;AAE1B;AAUO,SAAS,QAAA,CACd,KACA,GAAA,EACiC;AACjC,EAAA,OAAO,GAAA,IAAO,GAAA;AAChB;;;ACPO,SAAS,iBAAA,CACd,MACA,UAAA,EACwB;AAExB,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAC5B,IAAA,MAAM,iBAAA;AAAA,MACJ,UAAA;AAAA,MACA,CAAA,iCAAA,EAAoC,OAAO,IAAI,CAAA;AAAA,KACjD;AAAA,EACF;AAGA,EAAA,IAAI,SAAS,EAAA,EAAI;AACf,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,CAAC,kBAAA,CAAmB,IAAA,CAAK,IAAI,CAAA,EAAG;AAClC,IAAA,MAAM,iBAAA;AAAA,MACJ,UAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAGA,EAAA,IAAI,IAAA,CAAK,SAAS,qBAAA,EAAuB;AACvC,IAAA,MAAM,iBAAA;AAAA,MACJ,UAAA;AAAA,MACA,wCAAwC,qBAAqB,CAAA,8CAAA;AAAA,KAC/D;AAAA,EACF;AAKA,EAAA,IAAI,IAAA,CAAK,UAAA,CAAW,IAAI,CAAA,EAAG;AACzB,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,CAAC,kBAAA,CAAmB,IAAA,CAAK,IAAI,CAAA,EAAG;AAClC,IAAA,MAAM,iBAAA;AAAA,MACJ,UAAA;AAAA,MACA,uBAAuB,IAAI,CAAA,sKAAA;AAAA,KAC7B;AAAA,EACF;AACF;;;AC1EO,SAAS,mBAAmB,KAAA,EAAwB;AAEzD,EAAA,IAAI,UAAU,IAAA,EAAM;AAClB,IAAA,OAAO,MAAA;AAAA,EACT;AAGA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AACxB,IAAA,OAAO,CAAA,MAAA,EAAS,MAAM,MAAM,CAAA,CAAA,CAAA;AAAA,EAC9B;AAEA,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAE7B,IAAA,IAAI,aAAA,IAAiB,KAAA,IAAS,KAAA,CAAM,WAAA,CAAY,SAAS,QAAA,EAAU;AACjE,MAAA,OAAO,MAAM,WAAA,CAAY,IAAA;AAAA,IAC3B;AAGA,IAAA,OAAO,QAAA;AAAA,EACT;AAIA,EAAA,OAAO,OAAO,KAAA;AAChB;;;ACpBO,SAAS,aAAA,CACd,OACA,MAAA,EACwB;AACxB,EAAA,IAAI,CAAC,OAAA,CAAQ,KAAK,CAAA,EAAG;AACnB,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,CAAA,EAAI,MAAM,CAAA,2BAAA,EAA8B,kBAAA,CAAmB,KAAK,CAAC,CAAA,+DAAA;AAAA,KAEnE;AAAA,EACF;AACF;;;ACLO,IAAM,UAAA,GAAkC,OAAO,MAAA,CAAO;AAAA,EAC3D,kBAAA,EAAoB,aAAA;AAAA;AAAA,EACpB,sBAAA,EAAwB,wBAAA;AAAA;AAAA,EACxB,sBAAA,EAAwB,iBAAA;AAAA;AAAA,EACxB,eAAA,EAAiB,iBAAA;AAAA;AAAA,EACjB,WAAA,EAAa,aAAA;AAAA;AAAA,EACb,iBAAA,EAAmB,mBAAA;AAAA;AAAA,EACnB,eAAA,EAAiB,iBAAA;AAAA;AAAA,EACjB,cAAA,EAAgB,gBAAA;AAAA;AAAA,EAChB,oBAAA,EAAsB;AAAA;AACxB,CAAC;AAMM,IAAM,SAAA,GAAuB;AAAA,EAClC,aAAA,EAAe;AAAA;AACjB;AAMO,IAAM,OAAA,GAA4B;AAAA,EACvC,YAAA,EAAc,SAAA;AAAA;AAAA,EACd,WAAA,EAAa,QAAA;AAAA;AAAA,EACb,gBAAA,EAAkB,mBAAA;AAAA;AAAA,EAClB,iBAAA,EAAmB,oBAAA;AAAA;AAAA,EACnB,kBAAA,EAAoB,qBAAA;AAAA;AAAA,EACpB,gBAAA,EAAkB;AAAA;AACpB,CAAA;AAMO,IAAM,MAAA,GAAyB;AAAA,EACpC,YAAA,EAAc,QAAA;AAAA;AAAA,EACd,WAAA,EAAa,OAAA;AAAA;AAAA,EACb,gBAAA,EAAkB,SAAA;AAAA;AAAA,EAClB,iBAAA,EAAmB,UAAA;AAAA;AAAA,EACnB,kBAAA,EAAoB,WAAA;AAAA;AAAA,EACpB,gBAAA,EAAkB;AAAA;AACpB;AAMO,IAAM,cAAA,GAAiB;AAAA,EAC5B,eAAA,EAAiB,GAAA;AAAA,EACjB,UAAA,EAAY,EAAA;AAAA,EACZ,aAAA,EAAe,EAAA;AAAA,EACf,YAAA,EAAc,GAAA;AAAA,EACd,aAAA,EAAe,CAAA;AAAA,EACf,oBAAA,EAAsB;AACxB,CAAA;AAMO,IAAM,YAAA,GAAe;AAAA,EAC1B,eAAA,EAAiB,EAAE,GAAA,EAAK,CAAA,EAAG,KAAK,GAAA,EAAO;AAAA,EACvC,UAAA,EAAY,EAAE,GAAA,EAAK,CAAA,EAAG,KAAK,GAAA,EAAK;AAAA,EAChC,aAAA,EAAe,EAAE,GAAA,EAAK,CAAA,EAAG,KAAK,GAAA,EAAK;AAAA,EACnC,YAAA,EAAc,EAAE,GAAA,EAAK,CAAA,EAAG,KAAK,GAAA,EAAQ;AAAA,EACrC,aAAA,EAAe,EAAE,GAAA,EAAK,CAAA,EAAG,KAAK,GAAA,EAAI;AAAA,EAClC,oBAAA,EAAsB,EAAE,GAAA,EAAK,CAAA,EAAG,KAAK,GAAA;AACvC,CAAA;;;ACrEA,SAAS,kBAAkB,KAAA,EAAgC;AACzD,EAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,KAAU,QAAA,EAAU;AAC/C,IAAA,OAAO,KAAA;AAAA,EACT;AAEA,EAAA,MAAM,GAAA,GAAM,KAAA;AAEZ,EAAA,OACE,OAAO,GAAA,CAAI,IAAA,KAAS,QAAA,IACpB,OAAO,GAAA,CAAI,IAAA,KAAS,QAAA,IACpB,OAAO,GAAA,CAAI,MAAA,KAAW,QAAA,IACtB,IAAI,MAAA,KAAW,IAAA;AAEnB;AAiBO,SAAS,gBAAiC,KAAA,EAAa;AAG5D,EAAA,IAAI,CAAC,KAAA,EAAO;AACV,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAI,CAAC,iBAAA,CAAkB,KAAK,CAAA,EAAG;AAC7B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,oDAAA,EAAuD,OAAO,KAAK,CAAA;AAAA,KACrE;AAAA,EACF;AAIA,EAAA,MAAM,WAAA,GAAc,gBAAgB,KAAK,CAAA;AAGzC,EAAA,MAAM,OAAA,uBAAc,OAAA,EAAgB;AAGpC,EAAA,SAAS,sBAAsB,GAAA,EAAoB;AAGjD,IAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,MAAA;AAAA,IACF;AAGA,IAAA,IAAI,OAAA,CAAQ,GAAA,CAAI,GAAG,CAAA,EAAG;AACpB,MAAA;AAAA,IACF;AAGA,IAAA,OAAA,CAAQ,IAAI,GAAG,CAAA;AAGf,IAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAGjB,IAAA,MAAM,MAAA,GAAS,MAAM,OAAA,CAAQ,GAAG,IAAI,GAAA,GAAM,MAAA,CAAO,OAAO,GAAG,CAAA;AAG3D,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,qBAAA,CAAsB,KAAK,CAAA;AAAA,IAC7B;AAAA,EACF;AAGA,EAAA,qBAAA,CAAsB,WAAW,CAAA;AAEjC,EAAA,OAAO,WAAA;AACT;AAGA,IAAM,WAAA,uBAAkB,OAAA,EAAgB;AAGxC,SAAS,gBAAgB,GAAA,EAAoB;AAE3C,EAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,MAAA,CAAO,QAAA,CAAS,GAAG,CAAA,EAAG;AACxB,IAAA;AAAA,EACF;AAGA,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAGjB,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA,EAAG;AACtB,IAAA,KAAA,MAAW,QAAQ,GAAA,EAAK;AACtB,MAAA,eAAA,CAAgB,IAAI,CAAA;AAAA,IACtB;AAAA,EACF,CAAA,MAAO;AACL,IAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,MAAA,eAAA,CAAiB,GAAA,CAAgC,GAAG,CAAC,CAAA;AAAA,IACvD;AAAA,EACF;AACF;AAaO,SAAS,mBAAoC,KAAA,EAAa;AAG/D,EAAA,IAAI,CAAC,KAAA,EAAO;AACV,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAI,WAAA,CAAY,GAAA,CAAI,KAAK,CAAA,EAAG;AAC1B,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,eAAA,CAAgB,KAAK,CAAA;AAGrB,EAAA,WAAA,CAAY,IAAI,KAAK,CAAA;AAErB,EAAA,OAAO,KAAA;AACT;AAaA,SAAS,qBACP,aAAA,EACmB;AACnB,EAAA,QAAQ,aAAA;AAAe,IACrB,KAAK,OAAA,EAAS;AACZ,MAAA,OAAO,OAAA;AAAA,IACT;AAAA,IACA,KAAK,QAAA,EAAU;AACb,MAAA,OAAO,QAAA;AAAA,IACT;AAAA,IACA,SAAS;AACP,MAAA,OAAO,SAAA;AAAA,IACT;AAAA;AAEJ;AASO,SAAS,mBAAmB,OAAA,EAAgC;AACjE,EAAA,MAAM,YAAA,GAA6B;AAAA,IACjC,iBAAA,EAAmB,oBAAA,CAAqB,OAAA,CAAQ,aAAa,CAAA;AAAA,IAC7D,iBAAiB,OAAA,CAAQ,eAAA;AAAA,IACzB,mBAAmB,OAAA,CAAQ;AAAA,GAC7B;AAGA,EAAA,IAAI,OAAA,CAAQ,gBAAgB,MAAA,EAAW;AACrC,IAAA,YAAA,CAAa,cAAc,OAAA,CAAQ,WAAA;AAAA,EACrC;AAEA,EAAA,OAAO,YAAA;AACT;AAOO,SAAS,kBAAkB,KAAA,EAGhC;AACA,EAAA,OAAO;AAAA,IACL,IAAA,EAAM,IAAA,CAAK,KAAA,CAAM,KAAA,GAAQ,GAAG,CAAA;AAAA,IAC5B,KAAA,EAAO,IAAA,CAAK,KAAA,CAAM,KAAA,GAAQ,GAAG;AAAA,GAC/B;AACF;AAMO,SAAS,YAAA,CAAa,UAAA,GAAoC,EAAC,EAAW;AAC3E,EAAA,OAAO,EAAE,GAAG,cAAA,EAAgB,GAAG,UAAA,EAAW;AAC5C;;;AClOO,SAAS,sBAAA,CACd,MACA,UAAA,EACwB;AACxB,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAC5B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,yCAAA,EAA4C,OAAO,IAAI,CAAA;AAAA,KAC9E;AAAA,EACF;AACF;AAMO,SAAS,0BACd,IAAA,EACwB;AACxB,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAC5B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,8DAAA,EAAiE,OAAO,IAAI,CAAA;AAAA,KAC9E;AAAA,EACF;AACF;AAMO,SAAS,0BAAA,CACd,MACA,UAAA,EACyC;AAEzC,EAAA,IAAI,EAAE,IAAA,IAAQ,OAAO,SAAS,QAAA,IAAY,IAAA,CAAK,gBAAgB,MAAA,CAAA,EAAS;AACtE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,oDAAA,EAAuD,kBAAA,CAAmB,IAAI,CAAC,CAAA;AAAA,KACtG;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,IAAA,IAAI,MAAA,CAAO,wBAAA,CAAyB,IAAA,EAAM,GAAG,GAAG,GAAA,EAAK;AACnD,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,QAAA,EAAW,UAAU,CAAA,wBAAA,EAA2B,GAAG,CAAA,CAAA;AAAA,OACrD;AAAA,IACF;AAAA,EACF;AACF;AAMO,SAAS,wBAAA,CACd,OACA,cAAA,EACuC;AACvC,EAAA,IAAI,UAAU,MAAA,EAAW;AACvB,IAAA,MAAM,IAAI,cAAA;AAAA,MACR,uCAAuC,cAAc,CAAA,WAAA;AAAA,KACvD;AAAA,EACF;AACF;AAMO,SAAS,wBACd,YAAA,EACA,QAAA,EACA,UAAA,EACA,eAAA,GAA0B,eAAe,eAAA,EACnC;AACN,EAAA,IAAI,oBAAoB,CAAA,EAAG;AACzB,IAAA;AAAA,EACF;AAEA,EAAA,MAAM,aAAa,YAAA,GAAe,QAAA;AAElC,EAAA,IAAI,cAAc,eAAA,EAAiB;AACjC,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,6BAAA,EAAgC,eAAe,eACtD,UAAU,CAAA,oCAAA;AAAA,KAC1B;AAAA,EACF;AACF;;;AChFO,IAAM,wBAAN,MAEL;AAAA,EACS,gCAAuC,MAAA,CAAO,MAAA;AAAA,IACrD;AAAA,GACF;AAAA,EAEA,OAAA,GAAkB,cAAA;AAAA,EAElB,WAAA,CAAY,mBAAA,GAA6C,EAAC,EAAmB;AAC3E,IAAA,IAAA,CAAK,YAAY,mBAAmB,CAAA;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,YAAA,CACL,IAAA,EACA,UAAA,EACwB;AACxB,IAAA,sBAAA,CAAuB,MAAM,UAAU,CAAA;AAAA,EACzC;AAAA,EAEA,OAAO,0BAA0B,IAAA,EAAuC;AACtE,IAAA,yBAAA,CAA0B,IAAI,CAAA;AAAA,EAChC;AAAA,EAEA,OAAO,0BAAA,CACL,IAAA,EACA,UAAA,EACyC;AACzC,IAAA,0BAAA,CAA2B,MAAM,UAAU,CAAA;AAAA,EAC7C;AAAA,EAEA,OAAO,wBAAA,CACL,KAAA,EACA,cAAA,EACuC;AACvC,IAAA,wBAAA,CAAyB,OAAO,cAAc,CAAA;AAAA,EAChD;AAAA,EAEA,OAAO,uBAAA,CACL,YAAA,EACA,QAAA,EACA,YACA,eAAA,EACM;AACN,IAAA,uBAAA;AAAA,MACE,YAAA;AAAA,MACA,QAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA,EAEA,UAAU,MAAA,EAAsB;AAC9B,IAAA,IAAA,CAAK,OAAA,GAAU,MAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,GAAA,CACE,gBACA,eAAA,EACS;AAET,IAAA,IAAI,oBAAoB,MAAA,EAAW;AACjC,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,MAAM,WAAW,CAAC,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,eAAe,cAAc,CAAA;AAElE,IAAA,IAAI,QAAA,EAAU;AAEZ,MAAA,IAAA,CAAK,sBAAsB,eAAe,CAAA;AAAA,IAC5C,CAAA,MAAO;AACL,MAAA,MAAM,QAAA,GAAW,IAAA,CAAK,aAAA,CAAc,cAAc,CAAA;AAClD,MAAA,MAAM,aAAa,QAAA,KAAa,eAAA;AAEhC,MAAA,MAAM,aACJ,MAAA,CAAO,KAAA,CAAM,QAAQ,CAAA,IAAK,MAAA,CAAO,MAAM,eAAe,CAAA;AAExD,MAAA,IAAI,UAAA,IAAc,CAAC,UAAA,EAAY;AAC7B,QAAAA,aAAA,CAAO,IAAA;AAAA,UACL,sBAAA;AAAA,UACA,4DAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA,IACF;AAEA,IAAA,IAAA,CAAK,aAAA,CAAc,cAAc,CAAA,GAAI,eAAA;AAErC,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,YAAY,IAAA,EAAmC;AAC7C,IAAA,MAAM,kBAA4B,EAAC;AAEnC,IAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,MAAA,IAAI,IAAA,CAAK,GAAG,CAAA,KAAM,MAAA,EAAW;AAC3B,QAAA,IAAI,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,aAAA,EAAe,GAAG,CAAA,EAAG;AAC1C,UAAA,eAAA,CAAgB,KAAK,GAAG,CAAA;AAAA,QAC1B;AAEA,QAAA,IAAA,CAAK,aAAA,CAAc,GAAG,CAAA,GAAI,IAAA,CAAK,GAAG,CAAA;AAAA,MACpC;AAAA,IACF;AAEA,IAAA,IAAI,eAAA,CAAgB,SAAS,CAAA,EAAG;AAC9B,MAAAA,aAAA,CAAO,IAAA;AAAA,QACL,wBAAA;AAAA,QACA,cAAA;AAAA,QACA,eAAA,CAAgB,KAAK,IAAI;AAAA,OAC3B;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,IAAkC,cAAA,EAAoC;AACpE,IAAA,OAAO,IAAA,CAAK,cAAc,cAAc,CAAA;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,MAAA,GAAgC;AAC9B,IAAA,OAAO,EAAE,GAAG,IAAA,CAAK,aAAA,EAAc;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,GAAgB;AACd,IAAA,OAAO,MAAA,CAAO,IAAA,CAAK,IAAA,CAAK,aAAa,CAAA,CAAE,MAAA;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,cAAA,EAA0C;AAC/C,IAAA,IAAI,CAAC,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,aAAA,EAAe,cAAc,CAAA,EAAG;AACtD,MAAAA,aAAA,CAAO,IAAA;AAAA,QACL,CAAA,uBAAA,CAAA;AAAA,QACA,CAAA,8CAAA,EAAiD,kBAAA,CAAmB,cAAc,CAAC,CAAA,CAAA;AAAA,OACrF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,cAAc,cAAc,CAAA;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,cAAA,EAA6C;AAC/C,IAAA,OAAO,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,aAAA,EAAe,cAAc,CAAA;AAAA,EACzD;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,GAAc;AACZ,IAAA,KAAA,MAAW,GAAA,IAAO,KAAK,aAAA,EAAe;AACpC,MAAA,OAAO,IAAA,CAAK,cAAc,GAAG,CAAA;AAAA,IAC/B;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,sBAAsB,UAAA,EAA0B;AAC9C,IAAA,MAAM,eAAA,GAAkB,KAAK,OAAA,CAAQ,eAAA;AAErC,IAAA,IAAI,oBAAoB,CAAA,EAAG;AACzB,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,YAAA,GAAe,MAAA,CAAO,IAAA,CAAK,IAAA,CAAK,aAAa,CAAA,CAAE,MAAA;AAErD,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,kBAAkB,eAAe,CAAA;AAEzD,IAAA,IAAI,iBAAiB,IAAA,EAAM;AACzB,MAAAA,aAAA,CAAO,IAAA;AAAA,QACL,UAAU,UAAU,CAAA,CAAA;AAAA,QACpB,GAAG,IAAI,CAAA,wDAAA;AAAA,OACT;AAAA,IACF,CAAA,MAAA,IAAW,iBAAiB,KAAA,EAAO;AACjC,MAAAA,aAAA,CAAO,KAAA;AAAA,QACL,UAAU,UAAU,CAAA,CAAA;AAAA,QACpB,CAAA,EAAG,KAAK,CAAA,+EAAA,EAEW,eAAe,CAAA,CAAA;AAAA,OACpC;AAAA,IACF,CAAA,MAAA,IAAW,gBAAgB,eAAA,EAAiB;AAC1C,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,QAAA,EAAW,UAAU,CAAA,6BAAA,EAAgC,eAAe,eACtD,YAAY,CAAA,kHAAA;AAAA,OAE5B;AAAA,IACF;AAAA,EACF;AACF,CAAA;;;AChPO,IAAM,eAAA,uBAAsB,GAAA,CAAe;AAAA,EAChD,MAAA,CAAO,YAAA;AAAA,EACP,MAAA,CAAO,gBAAA;AAAA,EACP,MAAA,CAAO,kBAAA;AAAA,EACP,MAAA,CAAO,gBAAA;AAAA,EACP,MAAA,CAAO,iBAAA;AAAA,EACP,MAAA,CAAO;AACT,CAAC,CAAA;ACNM,SAAS,SAAA,CACd,SAAA,EACA,GAAA,EAAA,GACG,IAAA,EACG;AACN,EAAA,IAAI,GAAA,CAAI,SAAS,CAAA,EAAG;AAClB,IAAA;AAAA,EACF;AAIA,EAAA,MAAM,SAAA,GAAY,CAAC,GAAG,GAAG,CAAA;AAEzB,EAAA,KAAA,MAAW,MAAM,SAAA,EAAW;AAC1B,IAAA,IAAI;AAEF,MAAA,QAAA,CAAS,SAAA,CAAU,KAAA,CAAM,IAAA,CAAK,EAAA,EAAgB,QAAW,IAAI,CAAA;AAAA,IAC/D,SAAS,KAAA,EAAO;AACd,MAAAA,cAAO,KAAA,CAAM,QAAA,EAAU,CAAA,sBAAA,EAAyB,SAAS,KAAK,KAAK,CAAA;AAAA,IACrE;AAAA,EACF;AACF;;;ACJO,IAAM,mBAAA,GAAN,MAAM,oBAAA,CAAoB;AAAA,EACtB,aAEL,EAAC;AAAA,EAEL,cAAA,GAAmD,IAAA;AAAA,EAEnD,OAAA,GAAkB,cAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASlB,OAAO,kBAAkB,SAAA,EAAoD;AAC3E,IAAA,IAAI,CAAC,eAAA,CAAgB,GAAA,CAAI,SAAsB,CAAA,EAAG;AAChD,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,oBAAA,EAAuB,MAAA,CAAO,SAAS,CAAC,CAAA,CAAE,CAAA;AAAA,IAC5D;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,gBAAA,CACL,EAAA,EACA,SAAA,EAEwB;AACxB,IAAA,IAAI,OAAO,OAAO,UAAA,EAAY;AAC5B,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,gDAAgD,SAAS,CAAA;AAAA,OAC3D;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAO,oBAAA,CACL,SAAA,EACA,EAAA,EACM;AACN,IAAA,oBAAA,CAAoB,kBAAkB,SAAS,CAAA;AAC/C,IAAA,oBAAA,CAAoB,gBAAA,CAAiB,IAAI,SAAS,CAAA;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,0BACL,QAAA,EACiC;AACjC,IAAA,IAAI,OAAO,aAAa,UAAA,EAAY;AAClC,MAAA,MAAM,IAAI,SAAA;AAAA,QACR;AAAA,OAEF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,UAAU,MAAA,EAAsB;AAC9B,IAAA,IAAA,CAAK,OAAA,GAAU,MAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,MAAA,CACE,SAAA,EACA,OAAA,EACA,SAAA,EACA,GAAA,EACM;AAEN,IAAA,IAAA,CAAK,qBAAqB,SAAS,CAAA;AAEnC,IAAA,MAAM,QAAA,GAAW,KAAK,iBAAA,EAAkB;AAExC,IAAA,IAAI;AACF,MAAA,QAAA,CAAS,SAAS,CAAA,EAAA;AAElB,MAAA,QAAQ,SAAA;AAAW,QACjB,KAAK,MAAA,CAAO,gBAAA;AAAA,QACZ,KAAK,OAAO,iBAAA,EAAmB;AAC7B,UAAA,SAAA;AAAA,YACE,SAAA;AAAA,YACA,IAAA,CAAK,gBAAgB,SAAS,CAAA;AAAA;AAAA,YAE9B,OAAA;AAAA,YACA;AAAA,WACF;AAEA,UAAA;AAAA,QACF;AAAA,QACA,KAAK,OAAO,gBAAA,EAAkB;AAC5B,UAAA,SAAA;AAAA,YACE,SAAA;AAAA,YACA,IAAA,CAAK,gBAAgB,SAAS,CAAA;AAAA,YAC9B,OAAA;AAAA,YACA,SAAA;AAAA,YACA;AAAA,WACF;AAEA,UAAA;AAAA,QACF;AAAA,QACA,KAAK,OAAO,kBAAA,EAAoB;AAC9B,UAAA,SAAA;AAAA,YACE,SAAA;AAAA,YACA,IAAA,CAAK,gBAAgB,SAAS,CAAA;AAAA;AAAA,YAE9B,OAAA;AAAA,YACA,SAAA;AAAA,YACA;AAAA,WACF;AAEA,UAAA;AAAA,QACF;AAAA;AAAA,QAEA,SAAS;AACP,UAAA,MAAM,gBAAA,GAE0B,SAAA;AAEhC,UAAA,SAAA,CAAU,gBAAA,EAAkB,IAAA,CAAK,eAAA,CAAgB,gBAAgB,CAAC,CAAA;AAElE,UAAA;AAAA,QACF;AAAA;AACF,IACF,CAAA,SAAE;AACA,MAAA,QAAA,CAAS,SAAS,CAAA,EAAA;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,aAAa,SAAA,EAAiD;AAC5D,IAAA,MAAM,GAAA,GAAM,IAAA,CAAK,UAAA,CAAW,SAAS,CAAA;AAErC,IAAA,OAAO,GAAA,KAAQ,MAAA,IAAa,GAAA,CAAI,IAAA,GAAO,CAAA;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,mBAAA,CACE,WACA,EAAA,EACM;AAEN,IAAA,MAAM,GAAA,GAAM,IAAA,CAAK,UAAA,CAAW,SAAS,CAAA;AAErC,IAAA,IAAI,CAAC,GAAA,IAAO,GAAA,CAAI,IAAA,KAAS,CAAA,EAAG;AAC1B,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,OAAA,GAAU,GAAA,CAAI,MAAA,CAAO,EAAE,CAAA;AAE7B,IAAA,IAAI,CAAC,OAAA,EAAS;AACZ,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,QAAA;AAAA,QACA,kDAAkD,SAAS,CAAA,gEAAA;AAAA,OAE7D;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAA,CACE,WACA,EAAA,EACa;AACb,IAAA,MAAM,GAAA,GAAM,IAAA,CAAK,eAAA,CAAgB,SAAS,CAAA;AAG1C,IAAA,IAAI,GAAA,CAAI,GAAA,CAAI,EAAE,CAAA,EAAG;AACf,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,gEAAgE,SAAS,CAAA,gIAAA;AAAA,OAG3E;AAAA,IACF;AAEA,IAAA,MAAM,YAAA,GAAe,KAAK,OAAA,CAAQ,YAAA;AAElC,IAAA,IAAI,GAAA,CAAI,SAAS,GAAA,EAAM;AACrB,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,yBAAA;AAAA,QACA,CAAA,gBAAA,EAAmB,SAAS,CAAA,MAAA,EAAS,GAAA,CAAI,IAAI,CAAA,8CAAA;AAAA,OAE/C;AAAA,IACF;AAEA,IAAA,IAAI,YAAA,KAAiB,CAAA,IAAK,GAAA,CAAI,IAAA,IAAQ,YAAA,EAAc;AAClD,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,kDAAA,EAAqD,YAAY,CAAA,qBAAA,EACzC,SAAS,CAAA,mJAAA;AAAA,OAGnC;AAAA,IACF;AAEA,IAAA,GAAA,CAAI,IAAI,EAAE,CAAA;AAEV,IAAA,OAAO,MAAM;AACX,MAAA,IAAA,CAAK,mBAAA,CAAoB,WAAW,EAAE,CAAA;AAAA,IACxC,CAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,UAAU,QAAA,EAAoC;AAC5C,IAAA,OAAO,IAAA,CAAK,gBAAA;AAAA,MACV,MAAA,CAAO,kBAAA;AAAA,MACP,CAAC,SAAgB,SAAA,KAAsB;AACrC,QAAA,QAAA,CAAS;AAAA,UACP,KAAA,EAAO,OAAA;AAAA,UACP,aAAA,EAAe;AAAA,SAChB,CAAA;AAAA,MACH;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,gBACE,SAAA,EACgC;AAChC,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,UAAA,CAAW,SAAS,CAAA;AAE1C,IAAA,IAAI,QAAA,EAAU;AACZ,MAAA,OAAO,QAAA;AAAA,IACT;AAEA,IAAA,MAAM,GAAA,uBAAU,GAAA,EAA+B;AAG/C,IAAC,IAAA,CAAK,UAAA,CAAyD,SAAS,CAAA,GACtE,GAAA;AAEF,IAAA,OAAO,GAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAA,GAA+C;AAC7C,IAAA,IAAA,CAAK,cAAA,KAAmB;AAAA,MACtB,CAAC,MAAA,CAAO,YAAY,GAAG,CAAA;AAAA,MACvB,CAAC,MAAA,CAAO,gBAAgB,GAAG,CAAA;AAAA,MAC3B,CAAC,MAAA,CAAO,kBAAkB,GAAG,CAAA;AAAA,MAC7B,CAAC,MAAA,CAAO,gBAAgB,GAAG,CAAA;AAAA,MAC3B,CAAC,MAAA,CAAO,iBAAiB,GAAG,CAAA;AAAA,MAC5B,CAAC,MAAA,CAAO,WAAW,GAAG;AAAA,KACxB;AAEA,IAAA,OAAO,IAAA,CAAK,cAAA;AAAA,EACd;AAAA,EAEA,qBAAqB,SAAA,EAA8C;AACjE,IAAA,MAAM,aAAA,GAAgB,KAAK,OAAA,CAAQ,aAAA;AAEnC,IAAA,IAAI,kBAAkB,CAAA,EAAG;AACvB,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,QAAA,GAAW,KAAK,iBAAA,EAAkB;AACxC,IAAA,MAAM,KAAA,GAAQ,SAAS,SAAS,CAAA;AAGhC,IAAA,IAAI,SAAS,aAAA,EAAe;AAC1B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,kCAAA,EAAqC,aAAa,CAAA,sBAAA,EAAyB,SAAS,CAAA;AAAA,OACtF;AAAA,IACF;AAAA,EACF;AACF,CAAA;;;AC3TO,IAAM,cAAA,GAA0B;AAAA,EACrC,YAAA,EAAc,EAAA;AAAA,EACd,eAAe,EAAC;AAAA,EAChB,aAAA,EAAe,UAAA;AAAA,EACf,eAAA,EAAiB,OAAA;AAAA,EACjB,WAAA,EAAa;AAAA,IACX,WAAA,EAAa,MAAA;AAAA,IACb,aAAA,EAAe,MAAA;AAAA,IACf,UAAA,EAAY;AAAA,GACd;AAAA,EACA,iBAAA,EAAmB,SAAA;AAAA,EACnB,aAAA,EAAe,IAAA;AAAA,EACf,kBAAA,EAAoB,IAAA;AAAA,EACpB,UAAA,EAAY;AACd,CAAA;AAMO,IAAM,mBAAA,GAAsB;AAAA,EACjC,aAAA,EAAe,CAAC,QAAA,EAAU,OAAA,EAAS,UAAU,UAAU,CAAA;AAAA,EACvD,eAAA,EAAiB,CAAC,SAAA,EAAW,QAAA,EAAU,OAAO,CAAA;AAAA,EAC9C,iBAAA,EAAmB,CAAC,SAAA,EAAW,KAAA,EAAO,gBAAgB,MAAM;AAC9D,CAAA;AAKO,IAAM,kBAAA,GAAqB;AAAA,EAChC,WAAA,EAAa,CAAC,MAAA,EAAQ,UAAA,EAAY,SAAS,OAAO,CAAA;AAAA,EAClD,aAAA,EAAe,CAAC,MAAA,EAAQ,QAAA,EAAU,YAAY,CAAA;AAAA,EAC9C,UAAA,EAAY,CAAC,SAAA,EAAW,QAAQ;AAClC,CAAA;AAKO,IAAM,gBAAA,uBAAuB,GAAA,CAAmB;AAAA,EACrD,cAAA;AAAA,EACA;AACF,CAAC,CAAA;;;ACzCM,IAAM,mBAAA,GAAsB,CACjC,MAAA,EACA,IAAA,KAEA,IAAI,eAAe,CAAA,QAAA,EAAW,MAAM,CAAA,WAAA,EAAc,IAAI,CAAA,WAAA,CAAa,CAAA;AAM9D,SAAS,WAA6B,GAAA,EAAqB;AAChE,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAEjB,EAAA,KAAA,MAAW,GAAA,IAAO,MAAA,CAAO,IAAA,CAAK,GAAG,CAAA,EAAG;AAClC,IAAA,MAAM,KAAA,GAAS,IAAgC,GAAG,CAAA;AAElD,IAAA,IAAI,SAAS,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,CAAM,gBAAgB,MAAA,EAAQ;AACtE,MAAA,UAAA,CAAW,KAAK,CAAA;AAAA,IAClB;AAAA,EACF;AAEA,EAAA,OAAO,GAAA;AACT;;;ACNO,SAAS,kBAAA,CACd,MACA,UAAA,EACwB;AACxB,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAC5B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,qCAAA,EAAwC,OAAO,IAAI,CAAA;AAAA,KAC1E;AAAA,EACF;AACF;AAKO,SAAS,oBAAA,CACd,YACA,UAAA,EACM;AACN,EAAA,IAAI,CAAC,MAAA,CAAO,MAAA,CAAO,cAAA,EAAgB,UAAU,CAAA,EAAG;AAC9C,IAAA,MAAM,mBAAA,CAAoB,YAAY,UAA2B,CAAA;AAAA,EACnE;AACF;AAKO,SAAS,iBAAA,CAAkB,UAAmB,UAAA,EAA0B;AAC7E,EAAA,IAAI,QAAA,IAAY,CAAC,gBAAA,CAAiB,GAAA,CAAI,UAA2B,CAAA,EAAG;AAClE,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,8HAAA;AAAA,KAEF;AAAA,EACF;AACF;AAKO,SAAS,mBAAA,CACd,KAAA,EACA,UAAA,EACA,UAAA,EAC0C;AAC1C,EAAA,IAAI,CAAC,KAAA,IAAS,OAAO,UAAU,QAAA,IAAY,KAAA,CAAM,gBAAgB,MAAA,EAAQ;AACvE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,oBAAA,EAAuB,UAAU,CAAA,8BAAA,EACtB,kBAAA,CAAmB,KAAK,CAAC,CAAA;AAAA,KAC3D;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,OAAO,KAAA,EAAO;AACvB,IAAA,IAAI,MAAA,CAAO,wBAAA,CAAyB,KAAA,EAAO,GAAG,GAAG,GAAA,EAAK;AACpD,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,QAAA,EAAW,UAAU,CAAA,0BAAA,EAA6B,UAAU,OAAO,GAAG,CAAA,CAAA;AAAA,OACxE;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,mBAAA,CACd,OACA,UAAA,EACM;AACN,EAAA,KAAA,MAAW,OAAO,KAAA,EAAO;AACvB,IAAA,IAAI,CAAC,QAAA,CAAS,GAAA,EAAK,kBAAkB,CAAA,EAAG;AACtC,MAAA,MAAM,SAAA,GAAY,MAAA,CAAO,IAAA,CAAK,kBAAkB,CAAA,CAC7C,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,CAAA,EAAI,CAAC,CAAA,CAAA,CAAG,CAAA,CACnB,KAAK,IAAI,CAAA;AAEZ,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,QAAA,EAAW,UAAU,CAAA,4BAAA,EAA+B,GAAG,kBACtC,SAAS,CAAA;AAAA,OAC5B;AAAA,IACF;AAEA,IAAA,MAAM,UAAA,GAAa,MAAM,GAAG,CAAA;AAC5B,IAAA,MAAM,WAAA,GAAc,mBAAmB,GAAG,CAAA;AAC1C,IAAA,MAAM,UAAW,WAAA,CAAkC,QAAA;AAAA,MACjD;AAAA,KACF;AAEA,IAAA,IAAI,CAAC,OAAA,EAAS;AACZ,MAAA,MAAM,aAAA,GAAgB,WAAA,CAAY,GAAA,CAAI,CAAC,CAAA,KAAM,IAAI,CAAC,CAAA,CAAA,CAAG,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AAEhE,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,QAAA,EAAW,UAAU,CAAA,gCAAA,EAAmC,GAAG,qBACtC,aAAa,CAAA,OAAA,EAAU,MAAA,CAAO,UAAU,CAAC,CAAA,CAAA;AAAA,OAChE;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,kBAAA,CACd,UAAA,EACA,KAAA,EACA,UAAA,EACM;AACN,EAAA,MAAM,WAAA,GAAc,oBAAoB,UAAU,CAAA;AAClD,EAAA,MAAM,OAAA,GAAW,WAAA,CAAkC,QAAA,CAAS,KAAe,CAAA;AAE3E,EAAA,IAAI,CAAC,OAAA,EAAS;AACZ,IAAA,MAAM,aAAA,GAAgB,WAAA,CAAY,GAAA,CAAI,CAAC,CAAA,KAAM,IAAI,CAAC,CAAA,CAAA,CAAG,CAAA,CAAE,IAAA,CAAK,IAAI,CAAA;AAEhE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,qBAAA,EAAwB,UAAU,sBAClC,aAAa,CAAA,OAAA,EAAU,MAAA,CAAO,KAAK,CAAC,CAAA,CAAA;AAAA,KAC3D;AAAA,EACF;AACF;AAMO,SAAS,mBAAA,CACd,UAAA,EACA,KAAA,EACA,UAAA,EACM;AACN,EAAA,MAAM,aAAA,GAAgB,eAAe,UAAU,CAAA;AAG/C,EAAA,IAAI,aAAA,IAAiB,OAAO,aAAA,KAAkB,QAAA,EAAU;AACtD,IAAA,mBAAA,CAAoB,KAAA,EAAO,YAAY,UAAU,CAAA;AAEjD,IAAA,IAAI,eAAe,aAAA,EAAe;AAChC,MAAA,mBAAA,CAAoB,OAAO,UAAU,CAAA;AAAA,IACvC;AAEA,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,OAAO,KAAA,KAAU,OAAO,aAAA,EAAe;AACzC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,oBAAA,EAAuB,UAAU,eACxC,OAAO,aAAa,CAAA,MAAA,EAAS,OAAO,KAAK,CAAA;AAAA,KACzD;AAAA,EACF;AAGA,EAAA,IAAI,cAAc,mBAAA,EAAqB;AACrC,IAAA,kBAAA;AAAA,MACE,UAAA;AAAA,MACA,KAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF;AAMA,SAAS,qBAAA,CACP,GAAA,EACA,KAAA,EACA,UAAA,EACS;AACT,EAAA,IAAI,QAAQ,QAAA,EAAU;AACpB,IAAA,IAAI,UAAU,MAAA,EAAW;AACvB,MAAA,cAAA,CAAe,OAAO,UAAU,CAAA;AAAA,IAClC;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,MAAM,IAAI,SAAA,CAAU,CAAA,QAAA,EAAW,UAAU,CAAA,mBAAA,EAAsB,GAAG,CAAA,CAAA,CAAG,CAAA;AACvE;AAMO,SAAS,eAAA,CACd,SACA,UAAA,EACqC;AACrC,EAAA,IACE,CAAC,OAAA,IACD,OAAO,YAAY,QAAA,IACnB,OAAA,CAAQ,gBAAgB,MAAA,EACxB;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,8CAAA,EAAiD,kBAAA,CAAmB,OAAO,CAAC,CAAA;AAAA,KACnG;AAAA,EACF;AAEA,EAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,OAAO,CAAA,EAAG;AAGlD,IAAA,IAAI,CAAC,QAAA,CAAS,GAAA,EAAK,cAAc,CAAA,EAAG;AAClC,MAAA,qBAAA,CAAsB,GAAA,EAAK,OAAO,UAAU,CAAA;AAC5C,MAAA;AAAA,IACF;AAGA,IAAA,IAAI,UAAU,MAAA,EAAW;AACvB,MAAA;AAAA,IACF;AAEA,IAAA,mBAAA,CAAoB,GAAA,EAAK,OAAO,UAAU,CAAA;AAAA,EAC5C;AACF;AAKO,SAAS,kBAAA,CACd,SAAA,EACA,KAAA,EACA,UAAA,EACM;AACN,EAAA,IAAI,OAAO,KAAA,KAAU,QAAA,IAAY,CAAC,MAAA,CAAO,SAAA,CAAU,KAAK,CAAA,EAAG;AACzD,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,UAAA,EAAa,SAAS,CAAA,0BAAA,EAA6B,MAAA,CAAO,KAAK,CAAC,CAAA;AAAA,KACvF;AAAA,EACF;AAEA,EAAA,MAAM,MAAA,GAAS,aAAa,SAAS,CAAA;AAErC,EAAA,IAAI,KAAA,GAAQ,MAAA,CAAO,GAAA,IAAO,KAAA,GAAQ,OAAO,GAAA,EAAK;AAC5C,IAAA,MAAM,IAAI,UAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,UAAA,EAAa,SAAS,CAAA,kBAAA,EAAqB,MAAA,CAAO,GAAG,CAAA,KAAA,EAAQ,MAAA,CAAO,GAAG,CAAA,MAAA,EAAS,KAAK,CAAA;AAAA,KAC5G;AAAA,EACF;AACF;AAKO,SAAS,cAAA,CACd,QACA,UAAA,EACyC;AACzC,EAAA,IAAI,CAAC,MAAA,IAAU,OAAO,WAAW,QAAA,IAAY,MAAA,CAAO,gBAAgB,MAAA,EAAQ;AAC1E,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,8CAAA,EAAiD,OAAO,MAAM,CAAA;AAAA,KACrF;AAAA,EACF;AAEA,EAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,MAAM,CAAA,EAAG;AACjD,IAAA,IAAI,CAAC,MAAA,CAAO,MAAA,CAAO,YAAA,EAAc,GAAG,CAAA,EAAG;AACrC,MAAA,MAAM,IAAI,SAAA,CAAU,CAAA,QAAA,EAAW,UAAU,CAAA,mBAAA,EAAsB,GAAG,CAAA,CAAA,CAAG,CAAA;AAAA,IACvE;AAEA,IAAA,IAAI,UAAU,MAAA,EAAW;AACvB,MAAA;AAAA,IACF;AAEA,IAAA,kBAAA,CAAmB,GAAA,EAA2B,OAAO,UAAU,CAAA;AAAA,EACjE;AACF;;;ACtQO,IAAM,mBAAN,MAAuB;AAAA,EAC5B,QAAA;AAAA,EACA,OAAA,GAAU,KAAA;AAAA,EAEV,WAAA,CAAY,cAAA,GAAmC,EAAC,EAAG;AAEjD,IAAA,IAAA,CAAK,WAAW,UAAA,CAAW;AAAA,MACzB,GAAG,cAAA;AAAA,MACH,GAAG;AAAA,KACJ,CAAA;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,kBAAA,CACL,IAAA,EACA,UAAA,EACwB;AACxB,IAAA,kBAAA,CAAmB,MAAM,UAAU,CAAA;AAAA,EACrC;AAAA,EAEA,OAAO,oBAAA,CAAqB,UAAA,EAAoB,UAAA,EAA0B;AACxE,IAAA,oBAAA,CAAqB,YAAY,UAAU,CAAA;AAAA,EAC7C;AAAA,EAEA,OAAO,iBAAA,CAAkB,QAAA,EAAmB,UAAA,EAA0B;AACpE,IAAA,iBAAA,CAAkB,UAAU,UAAU,CAAA;AAAA,EACxC;AAAA,EAEA,OAAO,mBAAA,CACL,UAAA,EACA,KAAA,EACA,UAAA,EACM;AACN,IAAA,mBAAA,CAAoB,UAAA,EAAY,OAAO,UAAU,CAAA;AAAA,EACnD;AAAA,EAEA,OAAO,eAAA,CACL,OAAA,EACA,UAAA,EACqC;AACrC,IAAA,eAAA,CAAgB,SAAS,UAAU,CAAA;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,GAAA,GAAyB;AACvB,IAAA,OAAO,IAAA,CAAK,QAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,UAAmC,UAAA,EAA2B;AAC5D,IAAA,OAAO,IAAA,CAAK,SAAS,UAAU,CAAA;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,GAAA,CAA6B,YAAe,KAAA,EAAyB;AAInE,IAAA,MAAM,QAAA,GACJ,KAAA,IAAS,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,CAAM,WAAA,KAAgB,MAAA,GACxD,EAAE,GAAG,KAAA,EAAM,GACX,KAAA;AAEN,IAAA,IAAA,CAAK,WAAW,UAAA,CAAW;AAAA,MACzB,GAAG,IAAA,CAAK,QAAA;AAAA,MACR,CAAC,UAAU,GAAG;AAAA,KACf,CAAA;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,QAAA,GAAoB;AAClB,IAAA,OAAO,IAAA,CAAK,OAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,IAAA,GAAa;AACX,IAAA,IAAA,CAAK,OAAA,GAAU,IAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA,EAKA,MAAA,GAAe;AACb,IAAA,IAAA,CAAK,OAAA,GAAU,KAAA;AAAA,EACjB;AACF,CAAA;;;AC7HO,SAAS,qBAAqB,IAAA,EAAoC;AACvE,EAAA,MAAM,YAAsB,EAAC;AAE7B,EAAA,KAAA,MAAW,eAAe,IAAA,EAAM;AAC9B,IAAA,MAAM,QAAA,GAAW,KAAK,WAAW,CAAA;AAEjC,IAAA,KAAA,MAAW,SAAS,QAAA,EAAU;AAC5B,MAAA,IAAI,QAAA,CAAS,KAAK,CAAA,KAAM,KAAA,EAAO;AAC7B,QAAA,SAAA,CAAU,KAAK,KAAK,CAAA;AAAA,MACtB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,SAAA;AACT;AAMO,SAAS,mBAAA,CAAoB,MAAe,IAAA,EAAwB;AACzE,EAAA,IAAI,SAAS,IAAA,EAAM;AACjB,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,IAAI,MAAM,OAAA,CAAQ,IAAI,KAAK,KAAA,CAAM,OAAA,CAAQ,IAAI,CAAA,EAAG;AAC9C,IAAA,IAAI,IAAA,CAAK,MAAA,KAAW,IAAA,CAAK,MAAA,EAAQ;AAC/B,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA,CAAK,KAAA,CAAM,CAAC,CAAA,EAAG,CAAA,KAAM,oBAAoB,CAAA,EAAG,IAAA,CAAK,CAAC,CAAC,CAAC,CAAA;AAAA,EAC7D;AAEA,EAAA,OAAO,KAAA;AACT;;;ACdO,IAAM,iBAAN,MAAqB;AAAA;AAAA;AAAA;AAAA,EAI1B,QAAA,GAAW,CAAA;AAAA;AAAA;AAAA;AAAA,EAKX,YAAA,GAAkC,MAAA;AAAA;AAAA;AAAA;AAAA,EAKlC,cAAA,GAAoC,MAAA;AAAA;AAAA;AAAA;AAAA,EAKpC,UAAA;AAAA;AAAA;AAAA;AAAA,EAKS,eAAA,uBAAsB,GAAA,EAAsB;AAAA;AAAA;AAAA;AAAA,EAKrD,IAAI,KAAA,GAAoC;AAEtC,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAO,qBAAA,CACL,IAAA,EACA,MAAA,EACA,MACA,OAAA,EACM;AAEN,IAAA,IAAI,CAAC,QAAA,CAAS,IAAI,CAAA,EAAG;AACnB,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,iCAAA,EAAoC,kBAAA,CAAmB,IAAI,CAAC,CAAA,kBAAA;AAAA,OAC9D;AAAA,IACF;AAGA,IAAA,IAAI,MAAA,KAAW,MAAA,IAAa,CAAC,QAAA,CAAS,MAAM,CAAA,EAAG;AAC7C,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,mCAAA,EAAsC,kBAAA,CAAmB,MAAM,CAAC,CAAA,wBAAA;AAAA,OAClE;AAAA,IACF;AAGA,IAAA,IAAI,IAAA,KAAS,MAAA,IAAa,CAAC,QAAA,CAAS,IAAI,CAAA,EAAG;AACzC,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,iCAAA,EAAoC,kBAAA,CAAmB,IAAI,CAAC,CAAA,kBAAA;AAAA,OAC9D;AAAA,IACF;AAGA,IAAA,IAAI,OAAA,KAAY,MAAA,IAAa,OAAO,OAAA,KAAY,QAAA,EAAU;AACxD,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,oCAAA,EAAuC,kBAAA,CAAmB,OAAO,CAAC,CAAA,kBAAA;AAAA,OACpE;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,OAAO,0BAAA,CACL,MAAA,EACA,MAAA,EACA,iBAAA,EACM;AAEN,IAAA,IAAI,UAAU,IAAA,EAAM;AAClB,MAAA,aAAA,CAAc,QAAQ,gBAAgB,CAAA;AAAA,IACxC;AAEA,IAAA,IAAI,UAAU,IAAA,EAAM;AAClB,MAAA,aAAA,CAAc,QAAQ,gBAAgB,CAAA;AAAA,IACxC;AAEA,IAAA,IACE,iBAAA,KAAsB,MAAA,IACtB,OAAO,iBAAA,KAAsB,SAAA,EAC7B;AACA,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,mDAAA,EAAsD,kBAAA,CAAmB,iBAAiB,CAAC,CAAA,mBAAA;AAAA,OAC7F;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,GAAA,GAEc;AACZ,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,IAAI,KAAA,EAAgC;AAElC,IAAA,IAAA,CAAK,iBAAiB,IAAA,CAAK,YAAA;AAI3B,IAAA,IAAI,CAAC,KAAA,EAAO;AACV,MAAA,IAAA,CAAK,YAAA,GAAe,MAAA;AAAA,IACtB,CAAA,MAAA,IAAW,MAAA,CAAO,QAAA,CAAS,KAAK,CAAA,EAAG;AAEjC,MAAA,IAAA,CAAK,YAAA,GAAe,KAAA;AAAA,IACtB,CAAA,MAAO;AAEL,MAAA,IAAA,CAAK,YAAA,GAAe,mBAAmB,KAAK,CAAA;AAAA,IAC9C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,WAAA,GAEc;AACZ,IAAA,OAAO,IAAA,CAAK,cAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,gBAAgB,IAAA,EAAwC;AACtD,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,SAAA,CACE,IAAA,EACA,MAAA,EACA,IAAA,EACA,MACA,OAAA,EACc;AACd,IAAA,MAAM,WAAW,IAAA,GACb;AAAA,MACE,GAAG,IAAA;AAAA,MACH,EAAA,EAAI,OAAA,IAAW,EAAE,IAAA,CAAK,QAAA;AAAA,MACtB,QAAQ,IAAA,CAAK,MAAA;AAAA,MACb,SAAS,IAAA,CAAK,OAAA;AAAA,MACd,YAAY,IAAA,CAAK;AAAA,KACnB,GACA,MAAA;AAGJ,IAAA,MAAM,mBAAA,GAAsB,IAAA,CAAK,KAAA,CAAM,gBAAA,EAAiB;AACxD,IAAA,MAAM,gBAAA,GAAmB,MAAA,CAAO,MAAA,CAAO,mBAAA,EAAqB,IAAI,CAAA;AAGhE,IAAA,IAAI,YAAA;AAEJ,IAAA,IAAI,gBAAA,EAAkB;AACpB,MAAA,YAAA,GAAe,EAAE,GAAG,mBAAA,CAAoB,IAAI,CAAA,EAAG,GAAG,MAAA,EAAO;AAAA,IAC3D,WAAW,MAAA,EAAQ;AACjB,MAAA,YAAA,GAAe,EAAE,GAAG,MAAA,EAAO;AAAA,IAC7B,CAAA,MAAO;AACL,MAAA,YAAA,GAAe,EAAC;AAAA,IAClB;AAEA,IAAA,MAAM,KAAA,GAAsB;AAAA,MAC1B,IAAA;AAAA,MACA,MAAA,EAAQ,YAAA;AAAA,MACR,MAAM,IAAA,IAAQ,IAAA,CAAK,KAAA,CAAM,SAAA,CAAU,MAAM,MAAM,CAAA;AAAA,MAC/C,IAAA,EAAM;AAAA,KACR;AAEA,IAAA,OAAO,mBAAmB,KAAK,CAAA;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAA,CAAkB,MAAc,OAAA,EAAmC;AACjE,IAAA,OAAO,IAAA,CAAK,SAAA;AAAA,MACV,SAAA,CAAU,aAAA;AAAA,MACV,EAAE,IAAA,EAAK;AAAA,MACP,IAAA;AAAA,MACA;AAAA,QACE,OAAA;AAAA,QACA,QAAQ,EAAC;AAAA,QACT,UAAA,EAAY;AAAA;AACd,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,cAAA,CACE,MAAA,EACA,MAAA,EACA,iBAAA,GAAoB,IAAA,EACX;AACT,IAAA,IAAI,CAAC,MAAA,IAAU,CAAC,MAAA,EAAQ;AACtB,MAAA,OAAO,CAAC,CAAC,MAAA,KAAW,CAAC,CAAC,MAAA;AAAA,IACxB;AAEA,IAAA,IAAI,MAAA,CAAO,IAAA,KAAS,MAAA,CAAO,IAAA,EAAM;AAC/B,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,IAAI,iBAAA,EAAmB;AACrB,MAAA,MAAM,SAAA,GAAa,MAAA,CAAO,IAAA,EAAM,MAAA,IAAU,OAAO,IAAA,EAAM,MAAA;AAIvD,MAAA,MAAM,SAAA,GAAY,YACd,oBAAA,CAAqB,SAAS,IAC9B,IAAA,CAAK,aAAA,CAAc,OAAO,IAAI,CAAA;AAElC,MAAA,OAAO,SAAA,CAAU,KAAA;AAAA,QAAM,CAAC,KAAA,KACtB,mBAAA,CAAoB,MAAA,CAAO,MAAA,CAAO,KAAK,CAAA,EAAG,MAAA,CAAO,MAAA,CAAO,KAAK,CAAC;AAAA,OAChE;AAAA,IACF;AAEA,IAAA,MAAM,UAAA,GAAa,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,MAAM,CAAA;AAC5C,IAAA,MAAM,UAAA,GAAa,MAAA,CAAO,IAAA,CAAK,MAAA,CAAO,MAAM,CAAA;AAE5C,IAAA,IAAI,UAAA,CAAW,MAAA,KAAW,UAAA,CAAW,MAAA,EAAQ;AAC3C,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,OAAO,UAAA,CAAW,KAAA;AAAA,MAChB,CAAC,KAAA,KACC,KAAA,IAAS,MAAA,CAAO,MAAA,IAChB,mBAAA,CAAoB,MAAA,CAAO,MAAA,CAAO,KAAK,CAAA,EAAG,MAAA,CAAO,MAAA,CAAO,KAAK,CAAC;AAAA,KAClE;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,cAAc,IAAA,EAAwB;AACpC,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,eAAA,CAAgB,GAAA,CAAI,IAAI,CAAA;AAE5C,IAAA,IAAI,WAAW,MAAA,EAAW;AACxB,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,KAAA,CAAM,YAAA,CAAa,IAAI,CAAA;AAE3C,IAAA,IAAA,CAAK,eAAA,CAAgB,GAAA,CAAI,IAAA,EAAM,MAAM,CAAA;AAErC,IAAA,OAAO,MAAA;AAAA,EACT;AACF,CAAA;;;AC3TA,SAAS,eAAe,OAAA,EAA2B;AACjD,EAAA,OAAO,QAAQ,IAAA,IAAQ,WAAA;AACzB;AAKO,SAAS,0BACd,WAAA,EAC+C;AAC/C,EAAA,KAAA,MAAW,CAAC,CAAA,EAAG,UAAU,CAAA,IAAK,WAAA,CAAY,SAAQ,EAAG;AACnD,IAAA,IAAI,OAAO,eAAe,UAAA,EAAY;AACpC,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,qEAAA,EAAwE,CAAC,CAAA,MAAA,EAChE,kBAAA,CAAmB,UAAU,CAAC,CAAA;AAAA,OACzC;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,kBAAA,CACd,YACA,OAAA,EACkC;AAClC,EAAA,IAAI,OAAO,eAAe,UAAA,EAAY;AACpC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,yEACS,kBAAA,CAAmB,UAAU,CAAC,CAAA,WAAA,EACzB,cAAA,CAAe,OAAO,CAAC,CAAA;AAAA,KACvC;AAAA,EACF;AACF;AAKO,SAAS,oBAAA,CACd,cACA,iBAAA,EACM;AACN,EAAA,MAAM,WAAA,GAAc,IAAI,GAAA,CAAI,iBAAiB,CAAA;AAE7C,EAAA,KAAA,MAAW,WAAW,YAAA,EAAc;AAClC,IAAA,IAAI,WAAA,CAAY,GAAA,CAAI,OAAO,CAAA,EAAG;AAC5B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,kIAAA,EAEc,cAAA,CAAe,OAAO,CAAC,CAAA;AAAA,OACvC;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,uBAAA,CACd,YAAA,EACA,QAAA,EACA,aAAA,GAAwB,eAAe,aAAA,EACjC;AACN,EAAA,IAAI,kBAAkB,CAAA,EAAG;AACvB,IAAA;AAAA,EACF;AAEA,EAAA,MAAM,YAAY,YAAA,GAAe,QAAA;AAEjC,EAAA,IAAI,YAAY,aAAA,EAAe;AAC7B,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,kDAAA,EAAqD,aAAa,CAAA,YAAA,EACpD,YAAY,wBAAwB,QAAQ,CAAA,6EAAA;AAAA,KAE5D;AAAA,EACF;AACF;;;ACnEO,IAAM,sBAAN,MAEL;AAAA,EACS,UAAA,uBAAiB,GAAA,EAAqC;AAAA,EACtD,oBAAA,uBAA2B,GAAA,EAGlC;AAAA,EAEF,YAAA;AAAA,EACA,UAAA;AAAA,EACA,OAAA,GAAkB,cAAA;AAAA;AAAA;AAAA;AAAA,EAKlB,IAAI,OAAA,GAAgC;AAElC,IAAA,IAAI,CAAC,KAAK,YAAA,EAAc;AACtB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,KAAA,GAA8C;AAEhD,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,0BACL,WAAA,EAC+C;AAC/C,IAAA,yBAAA,CAA6B,WAAW,CAAA;AAAA,EAC1C;AAAA,EAEA,OAAO,kBAAA,CACL,UAAA,EACA,OAAA,EACkC;AAClC,IAAA,kBAAA,CAAsB,YAAY,OAAO,CAAA;AAAA,EAC3C;AAAA,EAEA,OAAO,oBAAA,CACL,YAAA,EACA,iBAAA,EACM;AACN,IAAA,oBAAA,CAAwB,cAAc,iBAAiB,CAAA;AAAA,EACzD;AAAA,EAEA,OAAO,uBAAA,CACL,YAAA,EACA,QAAA,EACA,aAAA,EACM;AACN,IAAA,uBAAA,CAAwB,YAAA,EAAc,UAAU,aAAa,CAAA;AAAA,EAC/D;AAAA;AAAA;AAAA;AAAA,EAMA,UAAU,MAAA,EAAoC;AAC5C,IAAA,IAAA,CAAK,YAAA,GAAe,MAAA;AAAA,EACtB;AAAA,EAEA,gBAAgB,IAAA,EAAkD;AAChE,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAAA,EACpB;AAAA,EAEA,UAAU,MAAA,EAAsB;AAC9B,IAAA,IAAA,CAAK,OAAA,GAAU,MAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,KAAA,GAAgB;AACd,IAAA,OAAO,KAAK,UAAA,CAAW,IAAA;AAAA,EACzB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,cACK,SAAA,EACoC;AACvC,IAAA,MAAM,cAAqD,EAAC;AAE5D,IAAA,KAAA,MAAW,WAAW,SAAA,EAAW;AAE/B,MAAA,MAAM,aAAa,OAAA,CAAQ,IAAA,CAAK,OAAA,EAAS,IAAA,CAAK,MAAM,aAAa,CAAA;AAEjE,MAAA,WAAA,CAAY,IAAA,CAAK,EAAE,OAAA,EAAS,UAAA,EAAY,CAAA;AAAA,IAC1C;AAEA,IAAA,OAAO,WAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,OAAO,WAAA,EAAiE;AAEtE,IAAA,IAAA,CAAK,qBAAA,CAAsB,YAAY,MAAM,CAAA;AAG7C,IAAA,KAAA,MAAW,EAAE,OAAA,EAAS,UAAA,EAAW,IAAK,WAAA,EAAa;AACjD,MAAA,IAAA,CAAK,UAAA,CAAW,IAAI,OAAO,CAAA;AAC3B,MAAA,IAAA,CAAK,oBAAA,CAAqB,GAAA,CAAI,OAAA,EAAS,UAAU,CAAA;AAAA,IACnD;AAGA,IAAA,IAAI,YAAA,GAAe,KAAA;AAEnB,IAAA,OAAO,MAAY;AACjB,MAAA,IAAI,YAAA,EAAc;AAChB,QAAA;AAAA,MACF;AAEA,MAAA,YAAA,GAAe,IAAA;AAEf,MAAA,KAAA,MAAW,EAAE,OAAA,EAAQ,IAAK,WAAA,EAAa;AACrC,QAAA,IAAA,CAAK,UAAA,CAAW,OAAO,OAAO,CAAA;AAC9B,QAAA,IAAA,CAAK,oBAAA,CAAqB,OAAO,OAAO,CAAA;AAAA,MAC1C;AAAA,IACF,CAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,KAAA,GAAc;AACZ,IAAA,IAAA,CAAK,WAAW,KAAA,EAAM;AACtB,IAAA,IAAA,CAAK,qBAAqB,KAAA,EAAM;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,YAAA,GAAkD;AAChD,IAAA,OAAO,CAAC,GAAG,IAAA,CAAK,UAAU,CAAA;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA,EAKA,YAAA,GAA6B;AAC3B,IAAA,OAAO,CAAC,GAAG,IAAA,CAAK,oBAAA,CAAqB,QAAQ,CAAA;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA,EAMA,sBAAsB,QAAA,EAAwB;AAC5C,IAAA,MAAM,aAAA,GAAgB,KAAK,OAAA,CAAQ,aAAA;AAEnC,IAAA,IAAI,kBAAkB,CAAA,EAAG;AACvB,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,SAAA,GAAY,QAAA,GAAW,IAAA,CAAK,UAAA,CAAW,IAAA;AAE7C,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,kBAAkB,aAAa,CAAA;AAEvD,IAAA,IAAI,aAAa,KAAA,EAAO;AACtB,MAAAA,aAAAA,CAAO,KAAA;AAAA,QACL,sBAAA;AAAA,QACA,CAAA,EAAG,SAAS,CAAA,qFAAA,EAEO,aAAa,CAAA,CAAA;AAAA,OAClC;AAAA,IACF,CAAA,MAAA,IAAW,aAAa,IAAA,EAAM;AAC5B,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,sBAAA;AAAA,QACA,GAAG,SAAS,CAAA,sDAAA;AAAA,OAEd;AAAA,IACF;AAAA,EACF;AACF,CAAA;;;AC9NO,IAAM,UAAA,GAAa;AAAA,EACxB,CAAC,OAAA,CAAc,YAAY,GAAG,MAAA,CAAa,YAAA;AAAA,EAC3C,CAAC,OAAA,CAAc,WAAW,GAAG,MAAA,CAAa,WAAA;AAAA,EAC1C,CAAC,OAAA,CAAc,kBAAkB,GAAG,MAAA,CAAa,kBAAA;AAAA,EACjD,CAAC,OAAA,CAAc,gBAAgB,GAAG,MAAA,CAAa,gBAAA;AAAA,EAC/C,CAAC,OAAA,CAAc,gBAAgB,GAAG,MAAA,CAAa,gBAAA;AAAA,EAC/C,CAAC,OAAA,CAAc,iBAAiB,GAAG,MAAA,CAAa;AAClD,CAAA;AAQO,IAAM,kBAAA,GAAqB,MAAA,CAAO,IAAA,CAAK,UAAU,CAAA,CAAE,MAAA;AAAA,EACxD,CAAC,SAAA,KACC,QAAA,CAA4B,SAAA,EAAW,UAAU;AACrD,CAAA;AAEO,IAAM,cAAA,GAAiB,kBAAA;;;AChBvB,SAAS,sBACdC,QAAAA,EACuC;AACvC,EAAA,KAAA,MAAW,UAAUA,QAAAA,EAAS;AAC5B,IAAA,IAAI,OAAO,WAAW,UAAA,EAAY;AAChC,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,yDAAA,EAA4D,OAAO,MAAM,CAAA;AAAA,OAC3E;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,eAAe,MAAA,EAAsB;AAEnD,EAAA,IAAI,EAAE,UAAU,OAAO,MAAA,KAAW,aAAa,KAAA,CAAM,OAAA,CAAQ,MAAM,CAAA,EAAG;AACpE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,6DAAA,EAAgE,kBAAA;AAAA,QAC9D;AAAA,OACD,CAAA;AAAA,KACH;AAAA,EACF;AAGA,EAAA,IAAI,OAAQ,MAAA,CAAyC,IAAA,KAAS,UAAA,EAAY;AACxE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,mHAAA;AAAA,KAEF;AAAA,EACF;AAEA,EAAA,KAAA,MAAW,OAAO,MAAA,EAAQ;AACxB,IAAA,IAAI,EAAE,GAAA,KAAQ,UAAA,IAAc,QAAA,CAA4B,GAAA,EAAK,UAAU,CAAA,CAAA,EAAI;AACzE,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,wCAAwC,GAAG,CAAA,iEAAA;AAAA,OAE7C;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,mBAAA,CACd,YAAA,EACA,QAAA,EACA,UAAA,GAAqB,eAAe,UAAA,EAC9B;AACN,EAAA,IAAI,eAAe,CAAA,EAAG;AACpB,IAAA;AAAA,EACF;AAEA,EAAA,MAAM,aAAa,YAAA,GAAe,QAAA;AAElC,EAAA,IAAI,aAAa,UAAA,EAAY;AAC3B,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,0CAAA,EAA6C,UAAU,CAAA,CAAA,CAAG,CAAA;AAAA,EAC5E;AACF;;;AClDO,IAAM,gBAAA,GAAN,MAAM,iBAAA,CAEX;AAAA,EACS,QAAA,uBAAe,GAAA,EAAiC;AAAA,EAEzD,YAAA;AAAA,EACA,UAAA;AAAA,EACA,OAAA,GAAkB,cAAA;AAAA;AAAA;AAAA;AAAA,EAKlB,IAAI,OAAA,GAAgC;AAElC,IAAA,IAAI,CAAC,KAAK,YAAA,EAAc;AACtB,MAAA,MAAM,IAAI,MAAM,wDAAwD,CAAA;AAAA,IAC1E;AAEA,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,KAAA,GAA2C;AAE7C,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,sBACLA,QAAAA,EACuC;AACvC,IAAA,qBAAA,CAAyBA,QAAO,CAAA;AAAA,EAClC;AAAA,EAEA,OAAO,eAAe,MAAA,EAAsB;AAC1C,IAAA,cAAA,CAAe,MAAM,CAAA;AAAA,EACvB;AAAA,EAEA,OAAO,mBAAA,CACL,YAAA,EACA,QAAA,EACA,UAAA,EACM;AACN,IAAA,mBAAA,CAAoB,YAAA,EAAc,UAAU,UAAU,CAAA;AAAA,EACxD;AAAA,EAEA,OAAO,0BAAA,CACL,YAAA,EACA,SAAA,EACM;AACN,IAAA,KAAA,MAAW,WAAW,YAAA,EAAc;AAClC,MAAA,IAAI,SAAA,CAAU,OAAO,CAAA,EAAG;AACtB,QAAA,MAAM,IAAI,KAAA;AAAA,UACR,CAAA,4GAAA;AAAA,SAEF;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,UAAU,MAAA,EAAoC;AAC5C,IAAA,IAAA,CAAK,YAAA,GAAe,MAAA;AAAA,EACtB;AAAA,EAEA,gBAAgB,IAAA,EAA+C;AAC7D,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAAA,EACpB;AAAA,EAEA,UAAU,MAAA,EAAsB;AAC9B,IAAA,IAAA,CAAK,OAAA,GAAU,MAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,KAAA,GAAgB;AACd,IAAA,OAAO,KAAK,QAAA,CAAS,IAAA;AAAA,EACvB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAO,SAAA,EAAuD;AAE5D,IAAA,IAAA,CAAK,qBAAA,CAAsB,UAAU,MAAM,CAAA;AAG3C,IAAA,IAAI,SAAA,CAAU,WAAW,CAAA,EAAG;AAC1B,MAAA,MAAM,OAAA,GAAU,UAAU,CAAC,CAAA;AAC3B,MAAA,MAAM,OAAA,GAAU,IAAA,CAAK,YAAA,CAAa,OAAO,CAAA;AAEzC,MAAA,IAAA,CAAK,QAAA,CAAS,IAAI,OAAO,CAAA;AAEzB,MAAA,IAAIC,aAAAA,GAAe,KAAA;AAEnB,MAAA,OAAO,MAAM;AACX,QAAA,IAAIA,aAAAA,EAAc;AAChB,UAAA;AAAA,QACF;AAEA,QAAAA,aAAAA,GAAe,IAAA;AACf,QAAA,IAAA,CAAK,QAAA,CAAS,OAAO,OAAO,CAAA;AAC5B,QAAA,IAAI;AACF,UAAA,OAAA,EAAQ;AAAA,QACV,SAAS,KAAA,EAAO;AACd,UAAAF,aAAAA,CAAO,KAAA,CAAM,cAAA,EAAgB,uBAAA,EAAyB,KAAK,CAAA;AAAA,QAC7D;AAAA,MACF,CAAA;AAAA,IACF;AAGA,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,iBAAA,CAAkB,SAAS,CAAA;AAGpD,IAAA,MAAM,qBAGA,EAAC;AAGP,IAAA,IAAI;AACF,MAAA,KAAA,MAAW,UAAU,WAAA,EAAa;AAChC,QAAA,MAAM,OAAA,GAAU,IAAA,CAAK,YAAA,CAAa,MAAM,CAAA;AAExC,QAAA,kBAAA,CAAmB,IAAA,CAAK,EAAE,OAAA,EAAS,MAAA,EAAQ,SAAS,CAAA;AAAA,MACtD;AAAA,IACF,SAAS,KAAA,EAAO;AAEd,MAAA,KAAA,MAAW,EAAE,OAAA,EAAQ,IAAK,kBAAA,EAAoB;AAC5C,QAAA,IAAI;AACF,UAAA,OAAA,EAAQ;AAAA,QACV,SAAS,YAAA,EAAc;AACrB,UAAAA,aAAAA,CAAO,KAAA,CAAM,cAAA,EAAgB,gBAAA,EAAkB,YAAY,CAAA;AAAA,QAC7D;AAAA,MACF;AAEA,MAAA,MAAM,KAAA;AAAA,IACR;AAGA,IAAA,KAAA,MAAW,EAAE,OAAA,EAAQ,IAAK,kBAAA,EAAoB;AAC5C,MAAA,IAAA,CAAK,QAAA,CAAS,IAAI,OAAO,CAAA;AAAA,IAC3B;AAGA,IAAA,IAAI,YAAA,GAAe,KAAA;AAEnB,IAAA,OAAO,MAAM;AACX,MAAA,IAAI,YAAA,EAAc;AAChB,QAAA;AAAA,MACF;AAEA,MAAA,YAAA,GAAe,IAAA;AAEf,MAAA,KAAA,MAAW,EAAE,OAAA,EAAQ,IAAK,kBAAA,EAAoB;AAC5C,QAAA,IAAA,CAAK,QAAA,CAAS,OAAO,OAAO,CAAA;AAAA,MAC9B;AAEA,MAAA,KAAA,MAAW,EAAE,OAAA,EAAQ,IAAK,kBAAA,EAAoB;AAC5C,QAAA,IAAI;AACF,UAAA,OAAA,EAAQ;AAAA,QACV,SAAS,KAAA,EAAO;AACd,UAAAA,aAAAA,CAAO,KAAA,CAAM,cAAA,EAAgB,uBAAA,EAAyB,KAAK,CAAA;AAAA,QAC7D;AAAA,MACF;AAAA,IACF,CAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,MAAA,GAAwC;AACtC,IAAA,OAAO,CAAC,GAAG,IAAA,CAAK,QAAQ,CAAA;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,IAAI,OAAA,EAA+C;AACjD,IAAA,OAAO,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,OAAO,CAAA;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA,EAMA,sBAAsB,QAAA,EAAwB;AAC5C,IAAA,MAAM,UAAA,GAAa,KAAK,OAAA,CAAQ,UAAA;AAEhC,IAAA,IAAI,eAAe,CAAA,EAAG;AACpB,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,UAAA,GAAa,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA;AAE5C,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,kBAAkB,UAAU,CAAA;AAEpD,IAAA,IAAI,cAAc,KAAA,EAAO;AACvB,MAAAA,aAAAA,CAAO,KAAA,CAAM,cAAA,EAAgB,CAAA,EAAG,UAAU,CAAA,oBAAA,CAAsB,CAAA;AAAA,IAClE,CAAA,MAAA,IAAW,cAAc,IAAA,EAAM;AAC7B,MAAAA,aAAAA,CAAO,IAAA,CAAK,cAAA,EAAgB,CAAA,EAAG,UAAU,CAAA,mBAAA,CAAqB,CAAA;AAAA,IAChE;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,kBACEC,QAAAA,EACkC;AAClC,IAAA,MAAM,WAAA,uBAAkB,GAAA,EAAiC;AAEzD,IAAA,KAAA,MAAW,UAAUA,QAAAA,EAAS;AAC5B,MAAA,IAAI,WAAA,CAAY,GAAA,CAAI,MAAM,CAAA,EAAG;AAC3B,QAAAD,aAAAA,CAAO,IAAA;AAAA,UACL,cAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF,CAAA,MAAO;AACL,QAAA,WAAA,CAAY,IAAI,MAAM,CAAA;AAAA,MACxB;AAAA,IACF;AAEA,IAAA,OAAO,WAAA;AAAA,EACT;AAAA,EAEA,aAAa,aAAA,EAAyD;AAGpE,IAAA,MAAM,gBAAgB,aAAA,CAAc,IAAA,CAAK,OAAA,EAAS,IAAA,CAAK,MAAM,aAAa,CAAA;AAE1E,IAAA,iBAAA,CAAiB,eAAe,aAAa,CAAA;AAE7C,IAAA,MAAA,CAAO,OAAO,aAAa,CAAA;AAG3B,IAAA,MAAM,uBAAsC,EAAC;AAG7C,IAAA,KAAA,MAAW,cAAc,kBAAA,EAAoB;AAC3C,MAAA,IAAI,cAAc,aAAA,EAAe;AAC/B,QAAA,IAAI,OAAO,aAAA,CAAc,UAAU,CAAA,KAAM,UAAA,EAAY;AACnD,UAAA,oBAAA,CAAqB,IAAA;AAAA,YACnB,KAAK,KAAA,CAAM,gBAAA;AAAA,cACT,WAAW,UAAU,CAAA;AAAA,cACrB,cAAc,UAAU;AAAA;AAC1B,WACF;AAEA,UAAA,IAAI,UAAA,KAAe,SAAA,IAAa,IAAA,CAAK,KAAA,CAAM,WAAU,EAAG;AACtD,YAAAA,aAAAA,CAAO,IAAA;AAAA,cACL,cAAA;AAAA,cACA;AAAA,aACF;AAAA,UACF;AAAA,QACF,CAAA,MAAO;AACL,UAAAA,aAAAA,CAAO,IAAA;AAAA,YACL,cAAA;AAAA,YACA,aAAa,UAAU,CAAA,6BAAA;AAAA,WACzB;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAGA,IAAA,OAAO,MAAM;AACX,MAAA,KAAA,MAAW,kBAAkB,oBAAA,EAAsB;AACjD,QAAA,cAAA,EAAe;AAAA,MACjB;AAEA,MAAA,IAAI,OAAO,aAAA,CAAc,QAAA,KAAa,UAAA,EAAY;AAChD,QAAA,aAAA,CAAc,QAAA,EAAS;AAAA,MACzB;AAAA,IACF,CAAA;AAAA,EACF;AACF,CAAA;;;ACzTO,SAAS,eAAA,CACd,SACA,UAAA,EACqD;AACrD,EAAA,IAAI,CAAC,SAAA,CAAU,OAAO,CAAA,IAAK,OAAO,YAAY,UAAA,EAAY;AACxD,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,qDAAA,EACZ,kBAAA,CAAmB,OAAO,CAAC,CAAA;AAAA,KACtC;AAAA,EACF;AACF;AAMO,SAAS,sBAAA,CACd,aAAA,EACA,IAAA,EACA,UAAA,EACM;AACN,EAAA,IAAI,aAAA,EAAe;AACjB,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,uBAAA,EAA0B,IAAI,CAAA,6BAAA;AAAA,KACrD;AAAA,EACF;AACF;AAKO,SAAS,oBAAA,CACd,YAAA,EACA,UAAA,EACA,oBAAA,GAA+B,eAAe,oBAAA,EACxC;AACN,EAAA,IAAI,yBAAyB,CAAA,EAAG;AAC9B,IAAA;AAAA,EACF;AAEA,EAAA,IAAI,gBAAgB,oBAAA,EAAsB;AACxC,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,oCAAA,EAAuC,oBAAoB,CAAA,iHAAA;AAAA,KAGlF;AAAA,EACF;AACF;;;AC1CA,SAAS,iBACP,KAAA,EACmC;AACnC,EAAA,MAAM,eAA6B,MAAM,KAAA;AAEzC,EAAA,OAAO,MAAM,YAAA;AACf;AAQO,IAAM,0BAAN,MAEL;AAAA,EACS,uBAAA,uBAA8B,GAAA,EAGrC;AAAA,EACO,qBAAA,uBAA4B,GAAA,EAGnC;AAAA,EACO,uBAAA,uBAA8B,GAAA,EAA0B;AAAA,EACxD,qBAAA,uBAA4B,GAAA,EAA0B;AAAA,EAEtD,YAAA,uBAAmB,GAAA,EAAY;AAAA,EAExC,YAAA;AAAA,EACA,UAAA;AAAA,EACA,OAAA,GAAkB,cAAA;AAAA;AAAA;AAAA;AAAA,EAKlB,IAAI,OAAA,GAAgC;AAElC,IAAA,IAAI,CAAC,KAAK,YAAA,EAAc;AACtB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,YAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,KAAA,GAAkD;AAEpD,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,eAAA,CACL,OAAA,EACA,UAAA,EACqD;AACrD,IAAA,eAAA,CAAmB,SAAS,UAAU,CAAA;AAAA,EACxC;AAAA,EAEA,OAAO,sBAAA,CACL,aAAA,EACA,IAAA,EACA,UAAA,EACM;AACN,IAAA,sBAAA,CAAuB,aAAA,EAAe,MAAM,UAAU,CAAA;AAAA,EACxD;AAAA,EAEA,OAAO,oBAAA,CACL,YAAA,EACA,UAAA,EACA,oBAAA,EACM;AACN,IAAA,oBAAA,CAAqB,YAAA,EAAc,YAAY,oBAAoB,CAAA;AAAA,EACrE;AAAA,EAEA,UAAU,MAAA,EAAoC;AAC5C,IAAA,IAAA,CAAK,YAAA,GAAe,MAAA;AAAA,EACtB;AAAA,EAEA,gBAAgB,IAAA,EAAsD;AACpE,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAAA,EACpB;AAAA,EAEA,UAAU,MAAA,EAAsB;AAC9B,IAAA,IAAA,CAAK,OAAA,GAAU,MAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,cAAc,IAAA,EAAuB;AACnC,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,GAAA,CAAI,IAAI,CAAA;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAA,GAA2B;AACzB,IAAA,OAAO,KAAK,qBAAA,CAAsB,IAAA;AAAA,EACpC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,kBAAA,GAA6B;AAC3B,IAAA,OAAO,KAAK,uBAAA,CAAwB,IAAA;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,eAAe,IAAA,EAAuB;AACpC,IAAA,OAAO,IAAA,CAAK,qBAAA,CAAsB,GAAA,CAAI,IAAI,CAAA;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,iBAAiB,IAAA,EAAuB;AACtC,IAAA,OAAO,IAAA,CAAK,uBAAA,CAAwB,GAAA,CAAI,IAAI,CAAA;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcA,mBAAA,CACE,IAAA,EACA,OAAA,EACA,WAAA,EACM;AACN,IAAA,IAAA,CAAK,gBAAA;AAAA,MACH,UAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,IAAA,CAAK,qBAAA;AAAA,MACL,IAAA,CAAK,qBAAA;AAAA,MACL,aAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,qBAAA,CACE,IAAA,EACA,OAAA,EACA,WAAA,EACM;AACN,IAAA,IAAA,CAAK,gBAAA;AAAA,MACH,YAAA;AAAA,MACA,IAAA;AAAA,MACA,OAAA;AAAA,MACA,IAAA,CAAK,uBAAA;AAAA,MACL,IAAA,CAAK,uBAAA;AAAA,MACL,eAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,gBAAA,CAAiB,IAAA,EAAc,OAAA,GAAU,KAAA,EAAa;AACpD,IAAA,IAAA,CAAK,qBAAA,CAAsB,OAAO,IAAI,CAAA;AACtC,IAAA,IAAA,CAAK,qBAAA,CAAsB,OAAO,IAAI,CAAA;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,kBAAA,CAAmB,IAAA,EAAc,OAAA,GAAU,KAAA,EAAa;AACtD,IAAA,IAAA,CAAK,uBAAA,CAAwB,OAAO,IAAI,CAAA;AACxC,IAAA,IAAA,CAAK,uBAAA,CAAwB,OAAO,IAAI,CAAA;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,QAAA,GAAiB;AACf,IAAA,IAAA,CAAK,sBAAsB,KAAA,EAAM;AACjC,IAAA,IAAA,CAAK,sBAAsB,KAAA,EAAM;AACjC,IAAA,IAAA,CAAK,wBAAwB,KAAA,EAAM;AACnC,IAAA,IAAA,CAAK,wBAAwB,KAAA,EAAM;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,YAAA,GAGE;AACA,IAAA,MAAM,mBAGF,EAAC;AACL,IAAA,MAAM,iBAGF,EAAC;AAEL,IAAA,KAAA,MAAW,CAAC,IAAA,EAAM,OAAO,CAAA,IAAK,KAAK,uBAAA,EAAyB;AAC1D,MAAA,gBAAA,CAAiB,IAAI,CAAA,GAAI,OAAA;AAAA,IAC3B;AAEA,IAAA,KAAA,MAAW,CAAC,IAAA,EAAM,OAAO,CAAA,IAAK,KAAK,qBAAA,EAAuB;AACxD,MAAA,cAAA,CAAe,IAAI,CAAA,GAAI,OAAA;AAAA,IACzB;AAEA,IAAA,OAAO,CAAC,kBAAkB,cAAc,CAAA;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,YAAA,GAAuE;AACrE,IAAA,OAAO,CAAC,IAAA,CAAK,uBAAA,EAAyB,IAAA,CAAK,qBAAqB,CAAA;AAAA,EAClE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,iBACE,IAAA,EACA,IAAA,EACA,SACA,SAAA,EACA,SAAA,EACA,YACA,WAAA,EACM;AAEN,IAAA,IAAI,WAAA,EAAa;AACf,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,UAAU,UAAU,CAAA,CAAA;AAAA,QACpB,CAAA,qBAAA,EAAwB,IAAI,CAAA,oBAAA,EAAuB,IAAI,CAAA,CAAA;AAAA,OACzD;AAAA,IACF,CAAA,MAAO;AACL,MAAA,IAAA,CAAK,qBAAA,CAAsB,SAAA,CAAU,IAAA,GAAO,CAAA,EAAG,UAAU,CAAA;AAAA,IAC3D;AAGA,IAAA,MAAM,UAAU,SAAA,CAAU,OAAO,CAAA,GAC7B,gBAAA,CAA+B,OAAO,CAAA,GACtC,OAAA;AAGJ,IAAA,SAAA,CAAU,GAAA,CAAI,MAAM,OAAO,CAAA;AAG3B,IAAA,IAAA,CAAK,YAAA,CAAa,IAAI,IAAI,CAAA;AAE1B,IAAA,IAAI;AAEF,MAAA,MAAM,KAAK,OAAA,CAAQ,IAAA,CAAK,OAAA,EAAS,IAAA,CAAK,MAAM,aAAa,CAAA;AAEzD,MAAA,IAAI,OAAO,OAAO,UAAA,EAAY;AAC5B,QAAA,MAAM,IAAI,SAAA;AAAA,UACR,CAAA,QAAA,EAAW,UAAU,CAAA,sCAAA,EAAyC,kBAAA,CAAmB,EAAE,CAAC,CAAA;AAAA,SACtF;AAAA,MACF;AAEA,MAAA,SAAA,CAAU,GAAA,CAAI,MAAM,EAAE,CAAA;AAAA,IACxB,SAAS,KAAA,EAAO;AAEd,MAAA,SAAA,CAAU,OAAO,IAAI,CAAA;AAErB,MAAA,MAAM,KAAA;AAAA,IACR,CAAA,SAAE;AACA,MAAA,IAAA,CAAK,YAAA,CAAa,OAAO,IAAI,CAAA;AAAA,IAC/B;AAAA,EACF;AAAA,EAEA,qBAAA,CAAsB,aAAqB,UAAA,EAA0B;AACnE,IAAA,MAAM,oBAAA,GAAuB,KAAK,OAAA,CAAQ,oBAAA;AAE1C,IAAA,IAAI,yBAAyB,CAAA,EAAG;AAC9B,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,EAAE,IAAA,EAAM,KAAA,EAAM,GAAI,kBAAkB,oBAAoB,CAAA;AAE9D,IAAA,IAAI,eAAe,KAAA,EAAO;AACxB,MAAAA,aAAAA,CAAO,KAAA;AAAA,QACL,UAAU,UAAU,CAAA,CAAA;AAAA,QACpB,CAAA,EAAG,WAAW,CAAA,iEAAA,EACwB,oBAAoB,CAAA,CAAA;AAAA,OAC5D;AAAA,IACF,CAAA,MAAA,IAAW,eAAe,IAAA,EAAM;AAC9B,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,UAAU,UAAU,CAAA,CAAA;AAAA,QACpB,GAAG,WAAW,CAAA,6DAAA;AAAA,OAEhB;AAAA,IACF;AAAA,EACF;AACF,CAAA;;;ACzUA,SAAS,UAAA,CACP,YAKA,MAAA,EACkB;AAClB,EAAA,MAAM,OAAO,UAAA,CAAW,IAAA;AACxB,EAAA,MAAM,QAAA,GAAW,IAAA,CAAK,UAAA,CAAW,GAAG,CAAA;AACpC,EAAA,MAAM,cAAA,GAAiB,QAAA,GAAW,IAAA,CAAK,KAAA,CAAM,CAAC,CAAA,GAAI,IAAA;AAElD,EAAA,MAAM,IAAA,GAAyB;AAAA,IAC7B,MAAM,UAAA,CAAW,IAAA;AAAA,IACjB,IAAA,EAAM,cAAA;AAAA,IACN,QAAA;AAAA,IACA,UAAU,EAAC;AAAA,IACX,MAAA;AAAA;AAAA,IAEA,qBAAqB,EAAC;AAAA,IACtB,QAAA,EAAU;AAAA,GACZ;AAGA,EAAA,IAAI,WAAW,QAAA,EAAU;AACvB,IAAA,KAAA,MAAW,QAAA,IAAY,WAAW,QAAA,EAAU;AAC1C,MAAA,MAAM,SAAA,GAAY,UAAA,CAAW,QAAA,EAAU,IAAI,CAAA;AAE3C,MAAA,IAAA,CAAK,QAAA,CAAS,KAAK,SAAS,CAAA;AAAA,IAC9B;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;AAWA,SAAS,aAAA,CACP,MACA,IAAA,EACiD;AACjD,EAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,GAAG,CAAA;AAE5B,EAAA,IAAI,KAAA,CAAM,WAAW,CAAA,EAAG;AACtB,IAAA,OAAO,EAAE,MAAA,EAAQ,IAAA,EAAM,SAAA,EAAW,IAAA,EAAK;AAAA,EACzC;AAGA,EAAA,IAAI,OAAA,GAAU,IAAA;AAEd,EAAA,KAAA,IAAS,IAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,MAAA,GAAS,GAAG,CAAA,EAAA,EAAK;AACzC,IAAA,MAAM,QAAA,GAAW,MAAM,CAAC,CAAA;AAIxB,IAAA,OAAA,GAAU,QAAQ,QAAA,CAAS,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,SAAS,QAAQ,CAAA;AAAA,EAC5D;AAGA,EAAA,OAAO,EAAE,MAAA,EAAQ,OAAA,EAAS,WAAW,KAAA,CAAM,EAAA,CAAG,EAAE,CAAA,EAAG;AACrD;AAeO,SAAS,SAAA,CACd,QAAA,EACA,QAAA,EACA,MAAA,EACkB;AAElB,EAAA,MAAM,IAAA,GAAO,WAAW,EAAE,IAAA,EAAM,UAAU,IAAA,EAAM,QAAA,IAAY,IAAI,CAAA;AAGhE,EAAA,MAAM,aAAgC,EAAC;AAEvC,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,IAAA,IAAI,KAAA,CAAM,IAAA,CAAK,QAAA,CAAS,GAAG,CAAA,EAAG;AAE5B,MAAA,UAAA,CAAW,KAAK,KAAK,CAAA;AAAA,IACvB,WAAW,KAAA,CAAM,QAAA,IAAY,KAAA,CAAM,QAAA,CAAS,SAAS,CAAA,EAAG;AAEtD,MAAA,MAAM,IAAA,GAAO,UAAA,CAAW,KAAA,EAAO,IAAI,CAAA;AAEnC,MAAA,IAAA,CAAK,QAAA,CAAS,KAAK,IAAI,CAAA;AAAA,IACzB,CAAA,MAAO;AAEL,MAAA,UAAA,CAAW,KAAK,KAAK,CAAA;AAAA,IACvB;AAAA,EACF;AAGA,EAAA,KAAA,MAAW,SAAS,UAAA,EAAY;AAC9B,IAAA,MAAM,EAAE,MAAA,EAAQ,SAAA,KAAc,aAAA,CAAc,IAAA,EAAM,MAAM,IAAI,CAAA;AAE5D,IAAA,MAAM,IAAA,GAAO,UAAA;AAAA,MACX,EAAE,MAAM,SAAA,EAAW,IAAA,EAAM,MAAM,IAAA,EAAM,QAAA,EAAU,MAAM,QAAA,EAAS;AAAA,MAC9D;AAAA,KACF;AAEA,IAAA,MAAA,CAAO,QAAA,CAAS,KAAK,IAAI,CAAA;AAAA,EAC3B;AAEA,EAAA,OAAO,IAAA;AACT;;;AC1EA,SAAS,yBAAyB,UAAA,EAA4B;AAE5D,EAAA,MAAM,OAAA,GAAU,UAAA,CAAW,UAAA,CAAW,UAAA,EAAY,EAAE,CAAA;AAEpD,EAAA,OAAO,IAAI,OAAO,CAAA,CAAA,CAAA;AACpB;AA2BA,IAAM,aAAA,GAAgB,iCAAA;AAatB,IAAM,eAAA,GAAkB,SAAA;AA8CjB,SAAS,eAAe,IAAA,EAAyB;AACtD,EAAA,MAAM,YAAsB,EAAC;AAC7B,EAAA,MAAM,cAAwB,EAAC;AAC/B,EAAA,MAAM,aAAuB,EAAC;AAC9B,EAAA,MAAM,eAAgD,EAAC;AACvD,EAAA,MAAM,kBAAA,uBAAyB,GAAA,EAA+B;AAE9D,EAAA,MAAM,UAAA,GAAa,eAAA,CAAgB,IAAA,CAAK,IAAI,CAAA;AAE5C,EAAA,IAAI,eAAe,IAAA,EAAM;AACvB,IAAA,MAAM,WAAA,GAAc,WAAW,CAAC,CAAA;AAChC,IAAA,MAAM,MAAA,GAAS,WAAA,CAAY,KAAA,CAAM,GAAG,CAAA;AAEpC,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,MAAM,SAAA,GAAY,MAAM,IAAA,EAAK;AAE7B,MAAA,IAAI,SAAA,CAAU,SAAS,CAAA,EAAG;AACxB,QAAA,WAAA,CAAY,KAAK,SAAS,CAAA;AAC1B,QAAA,YAAA,CAAa,SAAS,CAAA,GAAI,OAAA;AAAA,MAC5B;AAAA,IACF;AAEA,IAAA,IAAA,GAAO,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,UAAA,CAAW,KAAK,CAAA;AAAA,EACvC;AAEA,EAAA,IAAI,KAAA;AAEJ,EAAA,OAAA,CAAQ,KAAA,GAAQ,aAAA,CAAc,IAAA,CAAK,IAAI,OAAO,IAAA,EAAM;AAClD,IAAA,MAAM,MAAA,GAAS,MAAM,CAAC,CAAA;AACtB,IAAA,MAAM,SAAA,GAAY,MAAM,CAAC,CAAA;AACzB,IAAA,MAAM,aAAA,GAAgB,MAAM,CAAC,CAAA;AAE7B,IAAA,IAAI,WAAW,GAAA,EAAK;AAClB,MAAA,UAAA,CAAW,KAAK,SAAS,CAAA;AACzB,MAAA,SAAA,CAAU,KAAK,SAAS,CAAA;AACxB,MAAA,YAAA,CAAa,SAAS,CAAA,GAAI,KAAA;AAAA,IAC5B,CAAA,MAAO;AACL,MAAA,SAAA,CAAU,KAAK,SAAS,CAAA;AACxB,MAAA,YAAA,CAAa,SAAS,CAAA,GAAI,KAAA;AAE1B,MAAA,IAAI,aAAA,EAAe;AACjB,QAAA,MAAM,YAAA,GAAe,CAAA,CAAA,EAAI,wBAAA,CAAyB,aAAa,CAAC,CAAA,CAAA,CAAA;AAEhE,QAAA,kBAAA,CAAmB,IAAI,SAAA,EAAW;AAAA,UAChC,OAAA,EAAS,IAAI,MAAA,CAAO,YAAY,CAAA;AAAA,UAChC,UAAA,EAAY;AAAA,SACb,CAAA;AAAA,MACH;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,SAAA;AAAA,IACA,WAAA;AAAA,IACA,UAAA;AAAA,IACA,YAAA;AAAA,IACA,kBAAA;AAAA,IACA,WAAA,EAAa;AAAA,GACf;AACF;;;ACzNA,SAAS,gBAAgB,IAAA,EAAyB;AAChD,EAAA,IAAI,CAAC,IAAA,CAAK,MAAA,EAAQ,IAAA,EAAM;AACtB,IAAA,OAAO,IAAA,CAAK,IAAA;AAAA,EACd;AAGA,EAAA,OAAO,GAAG,IAAA,CAAK,MAAA,CAAO,QAAQ,CAAA,CAAA,EAAI,KAAK,IAAI,CAAA,CAAA;AAC7C;AAWA,SAAS,kBAAkB,IAAA,EAAgC;AAEzD,EAAA,IAAI,CAAC,KAAK,IAAA,EAAM;AACd,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,MAAM,EAAE,SAAA,EAAW,WAAA,EAAa,UAAA,KAAe,IAAA,CAAK,SAAA;AAGpD,EAAA,IAAI,SAAA,CAAU,SAAS,CAAA,IAAK,WAAA,CAAY,SAAS,CAAA,IAAK,UAAA,CAAW,SAAS,CAAA,EAAG;AAC3E,IAAA,OAAO,IAAA;AAAA,EACT;AAIA,EAAA,MAAM,iBAA8B,EAAC;AACrC,EAAA,IAAI,UAAU,IAAA,CAAK,MAAA;AAEnB,EAAA,OAAO,SAAS,IAAA,EAAM;AACpB,IAAA,cAAA,CAAe,KAAK,OAAO,CAAA;AAC3B,IAAA,OAAA,GAAU,OAAA,CAAQ,MAAA;AAAA,EACpB;AAEA,EAAA,cAAA,CAAe,OAAA,EAAQ;AAEvB,EAAA,IAAI,IAAA,GAAO,EAAA;AAEX,EAAA,KAAA,MAAW,WAAW,cAAA,EAAgB;AACpC,IAAA,MAAM;AAAA,MACJ,SAAA,EAAW,YAAA;AAAA,MACX,WAAA,EAAa,cAAA;AAAA,MACb,UAAA,EAAY;AAAA,QACV,OAAA,CAAQ,SAAA;AAGZ,IAAA,IACE,YAAA,CAAa,SAAS,CAAA,IACtB,cAAA,CAAe,SAAS,CAAA,IACxB,aAAA,CAAc,SAAS,CAAA,EACvB;AACA,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,IAAA,GAAO,OAAA,CAAQ,QAAA,GAAW,OAAA,CAAQ,IAAA,GAAO,OAAO,OAAA,CAAQ,IAAA;AAAA,EAC1D;AAGA,EAAA,IAAA,GAAO,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,IAAA,GAAO,OAAO,IAAA,CAAK,IAAA;AAG/C,EAAA,OAAO,IAAA,CAAK,UAAA,CAAW,SAAA,EAAW,GAAG,CAAA;AACvC;AAeA,SAAS,mBACP,aAAA,EACgC;AAChC,EAAA,MAAM,GAAA,uBAAU,GAAA,EAAuB;AAEvC,EAAA,KAAA,MAAW,SAAS,aAAA,EAAe;AACjC,IAAA,GAAA,CAAI,GAAA,CAAI,KAAA,CAAM,IAAA,EAAM,KAAK,CAAA;AAAA,EAC3B;AAEA,EAAA,OAAO,GAAA;AACT;AAaA,SAAS,WAAA,CACP,OAAA,EACA,MAAA,EACA,MAAA,EACW;AACX,EAAA,MAAM,gBAA6B,EAAC;AACpC,EAAA,MAAM,sBAAmC,EAAC;AAE1C,EAAA,MAAM,SAAA,GAAY,cAAA,CAAe,OAAA,CAAQ,IAAI,CAAA;AAE7C,EAAA,MAAM,IAAA,GAAO;AAAA,IACX,MAAM,OAAA,CAAQ,IAAA;AAAA,IACd,MAAM,OAAA,CAAQ,IAAA;AAAA,IACd,UAAU,OAAA,CAAQ,QAAA;AAAA,IAClB,MAAA;AAAA,IACA,QAAA,sBAAc,GAAA,EAAuB;AAAA,IACrC,SAAA;AAAA,IACA,qBAAqB,EAAC;AAAA,IACtB,QAAA,EAAU,EAAA;AAAA,IACV,UAAA,EAAY,IAAA;AAAA,IACZ,cAAc;AAAC,GACjB;AAEA,EAAA,KAAA,MAAW,CAAA,IAAK,UAAU,SAAA,EAAW;AACnC,IAAA,IAAA,CAAK,YAAA,CAAa,CAAC,CAAA,GAAI,KAAA;AAAA,EACzB;AAEA,EAAA,KAAA,MAAW,CAAA,IAAK,UAAU,WAAA,EAAa;AACrC,IAAA,IAAA,CAAK,YAAA,CAAa,CAAC,CAAA,GAAI,OAAA;AAAA,EACzB;AAEA,EAAA,IAAA,CAAK,QAAA,GAAW,gBAAgB,IAAiB,CAAA;AAEjD,EAAA,KAAA,MAAW,YAAA,IAAgB,QAAQ,QAAA,EAAU;AAC3C,IAAA,MAAM,KAAA,GAAQ,WAAA,CAAY,YAAA,EAAc,IAAA,EAAmB,MAAM,CAAA;AAEjE,IAAA,aAAA,CAAc,KAAK,KAAK,CAAA;AAExB,IAAA,IAAI,CAAC,MAAM,QAAA,EAAU;AACnB,MAAA,mBAAA,CAAoB,KAAK,KAAK,CAAA;AAAA,IAChC;AAAA,EACF;AAEA,EAAA,IAAA,CAAK,QAAA,GAAW,mBAAmB,aAAa,CAAA;AAChD,EAAA,IAAA,CAAK,mBAAA,GAAsB,mBAAA;AAE3B,EAAA,IAAA,CAAK,UAAA,GAAa,kBAAkB,IAAiB,CAAA;AAErD,EAAA,IAAI,MAAA,EAAQ;AACV,IAAA,MAAA,CAAO,MAAA,CAAO,KAAK,mBAAmB,CAAA;AACtC,IAAA,MAAA,CAAO,MAAA,CAAO,KAAK,YAAY,CAAA;AAC/B,IAAA,MAAA,CAAO,MAAA,CAAO,KAAK,QAAQ,CAAA;AAC3B,IAAA,MAAA,CAAO,OAAO,IAAI,CAAA;AAAA,EACpB;AAEA,EAAA,OAAO,IAAA;AACT;AAYO,SAAS,aAAA,CACd,WAAA,EACA,MAAA,GAAS,IAAA,EACE;AACX,EAAA,OAAO,WAAA,CAAY,WAAA,EAAa,IAAA,EAAM,MAAM,CAAA;AAC9C;;;ACvKO,SAAS,sBAAA,CACd,MACA,IAAA,EACkB;AAClB,EAAA,MAAM,SAA4B,EAAC;AAEnC,EAAA,OAAO;AAAA,IACL,IAAI,KAAA,EAA0C;AAC5C,MAAA,MAAA,CAAO,KAAK,KAAK,CAAA;AAEjB,MAAA,OAAO,IAAA;AAAA,IACT,CAAA;AAAA,IAEA,QAAQ,SAAA,EAAyD;AAC/D,MAAA,MAAA,CAAO,IAAA,CAAK,GAAG,SAAS,CAAA;AAExB,MAAA,OAAO,IAAA;AAAA,IACT,CAAA;AAAA,IAEA,MAAM,OAAA,EAAuC;AAE3C,MAAA,MAAM,WAAA,GAAc,SAAA,CAAU,IAAA,EAAM,IAAA,EAAM,MAAM,CAAA;AAGhD,MAAA,MAAM,MAAA,GAAS,CAAC,OAAA,EAAS,UAAA;AAEzB,MAAA,OAAO,aAAA,CAAc,aAAa,MAAM,CAAA;AAAA,IAC1C;AAAA,GACF;AACF;AAyBO,SAAS,eAAA,CACd,IAAA,EACA,IAAA,EACA,MAAA,EACA,OAAA,EACW;AACX,EAAA,OAAO,sBAAA,CAAuB,MAAM,IAAI,CAAA,CAAE,QAAQ,MAAM,CAAA,CAAE,MAAM,OAAO,CAAA;AACzE;;;AC5EO,IAAM,WAAA,GAAc,CAAC,KAAA,KAA0B;AACpD,EAAA,MAAM,UAAA,GAAa,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA;AACpC,EAAA,MAAM,OAAA,GAAU,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA;AAGjC,EAAA,IAAI,UAAA,KAAe,EAAA,IAAM,OAAA,KAAY,EAAA,EAAI;AACvC,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,MAAM,UAAA,GAAa,YAAY,EAAA,GAAK,KAAA,GAAQ,MAAM,KAAA,CAAM,GAAG,CAAA,CAAE,IAAA,CAAK,GAAG,CAAA;AAGrE,EAAA,OAAO,UAAA,KAAe,EAAA,GAAK,UAAA,GAAa,kBAAA,CAAmB,UAAU,CAAA;AACvE,CAAA;AAaO,IAAM,MAAA,GAAS,CACpB,KAAA,EACA,UAAA,KACiB;AAEjB,EAAA,IAAI,UAAU,MAAA,EAAW;AACvB,IAAA,OAAO,UAAA,CAAW,QAAQ,eAAA,EAAgB;AAAA,EAC5C;AAGA,EAAA,MAAM,SAAA,GAAY,UAAA,CAAW,OAAA,CAAQ,SAAA,CAAU,KAAK,CAAA;AAEpD,EAAA,IAAI,cAAc,IAAA,EAAM;AACtB,IAAA,OAAO,SAAA;AAAA,EACT;AAGA,EAAA,MAAM,OAAA,GAAU,YAAY,KAAK,CAAA;AAEjC,EAAA,OAAO,UAAA,CAAW,OAAA,CAAQ,WAAA,CAAY,OAAO,CAAA;AAC/C,CAAA;;;ACvCA,IAAM,WAAA,GAAc,CAAC,KAAA,KACnB,kBAAA,CAAmB,KAAkC,CAAA;AAUhD,IAAM,iBAAA,GAAmC;AAAA,EAC9C,aAAa,CAAC,IAAA,EAAM,MAAA,KAClB,MAAA,CAAO,IAAI,CAAC,GAAA,KAAQ,CAAA,EAAG,IAAI,IAAI,WAAA,CAAY,GAAG,CAAC,CAAA,CAAE,CAAA,CAAE,KAAK,GAAG;AAC/D,CAAA;AAMO,IAAM,qBAAA,GAAuC;AAAA,EAClD,aAAa,CAAC,IAAA,EAAM,MAAA,KAClB,MAAA,CAAO,IAAI,CAAC,GAAA,KAAQ,CAAA,EAAG,IAAI,MAAM,WAAA,CAAY,GAAG,CAAC,CAAA,CAAE,CAAA,CAAE,KAAK,GAAG;AACjE,CAAA;AAMO,IAAM,kBAAA,GAAoC;AAAA,EAC/C,WAAA,EAAa,CAAC,IAAA,EAAM,MAAA,KAClB,OAAO,GAAA,CAAI,CAAC,KAAK,CAAA,KAAM,CAAA,EAAG,IAAI,CAAA,CAAA,EAAI,CAAC,KAAK,WAAA,CAAY,GAAG,CAAC,CAAA,CAAE,CAAA,CAAE,KAAK,GAAG;AACxE,CAAA;AAMO,IAAM,kBAAA,GAAoC;AAAA,EAC/C,aAAa,CAAC,IAAA,EAAM,MAAA,KAClB,CAAA,EAAG,IAAI,CAAA,CAAA,EAAI,MAAA,CAAO,GAAA,CAAI,CAAC,QAAQ,WAAA,CAAY,GAAG,CAAC,CAAA,CAAE,IAAA,CAAK,GAAG,CAAC,CAAA;AAC9D,CAAA;AAKO,IAAM,eAAA,GAAsD;AAAA,EACjE,IAAA,EAAM,iBAAA;AAAA,EACN,QAAA,EAAU,qBAAA;AAAA,EACV,KAAA,EAAO,kBAAA;AAAA,EACP,KAAA,EAAO;AACT,CAAA;;;ACpBO,IAAM,mBAAA,GAAuC;AAAA,EAClD,QAAQ,CAAC,IAAA,EAAM,UAAU,CAAA,EAAG,IAAI,IAAI,KAAK,CAAA,CAAA;AAAA,EACzC,iBAAiB,MAAM,IAAA;AAAA,EACvB,WAAW,MAAM,IAAA;AAAA;AAAA,EACjB,WAAA,EAAa,CAAC,OAAA,KAAY;AAAA;AAC5B,CAAA;AAMO,IAAM,qBAAA,GAAyC;AAAA,EACpD,QAAQ,CAAC,IAAA,EAAM,UAAU,CAAA,EAAG,IAAI,IAAI,KAAK,CAAA,CAAA;AAAA,EACzC,iBAAiB,MAAM,IAAA;AAAA,EACvB,SAAA,EAAW,CAAC,GAAA,KAAQ;AAClB,IAAA,IAAI,QAAQ,MAAA,EAAQ;AAClB,MAAA,OAAO,IAAA;AAAA,IACT;AACA,IAAA,IAAI,QAAQ,OAAA,EAAS;AACnB,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA;AAAA,EACT,CAAA;AAAA,EACA,WAAA,EAAa,CAAC,OAAA,KAAY;AAAA;AAC5B,CAAA;AAMO,IAAM,wBAAA,GAA4C;AAAA,EACvD,QAAQ,CAAC,IAAA,EAAM,UAAW,KAAA,GAAQ,IAAA,GAAO,GAAG,IAAI,CAAA,MAAA,CAAA;AAAA,EAChD,iBAAiB,MAAM,IAAA;AAAA;AAAA,EACvB,WAAW,MAAM,IAAA;AAAA;AAAA,EACjB,WAAA,EAAa,CAAC,OAAA,KAAY;AAAA;AAC5B,CAAA;AAKO,IAAM,iBAAA,GAA4D;AAAA,EACvE,IAAA,EAAM,mBAAA;AAAA,EACN,MAAA,EAAQ,qBAAA;AAAA,EACR,YAAA,EAAc;AAChB,CAAA;;;ACrEO,IAAM,mBAAA,GAAoC;AAAA,EAC/C,MAAA,EAAQ,CAAC,IAAA,KAAS;AACpB,CAAA;AAMO,IAAM,kBAAA,GAAmC;AAAA,EAC9C,QAAQ,MAAM;AAChB,CAAA;AAKO,IAAM,cAAA,GAAmD;AAAA,EAC9D,OAAA,EAAS,mBAAA;AAAA,EACT,MAAA,EAAQ;AACV,CAAA;;;ACPO,IAAM,iBAAA,GAAoB,CAC/B,WAAA,EACA,aAAA,EACA,UAAA,MACwB;AAAA,EACxB,OAAA,EAAS,kBAAkB,aAAa,CAAA;AAAA,EACxC,IAAA,EAAM,eAAe,UAAU,CAAA;AAAA,EAC/B,KAAA,EAAO,gBAAgB,WAAW;AACpC,CAAA,CAAA;AAUO,IAAM,kBAAA,GAAyC;AAAA,EACpD,SAAS,iBAAA,CAAkB,IAAA;AAAA,EAC3B,MAAM,cAAA,CAAe,OAAA;AAAA,EACrB,OAAO,eAAA,CAAgB;AACzB,CAAA;;;ACvCA,IAAM,eAAA,GAAyC;AAAA,EAC7C,WAAA,EAAa,MAAA;AAAA,EACb,aAAA,EAAe,MAAA;AAAA,EACf,UAAA,EAAY,SAAA;AAAA,EACZ,UAAA,EAAY;AACd,CAAA;AAMO,IAAM,WAAA,GAAc,CAAC,IAAA,KAA0C;AACpE,EAAA,IACE,CAAC,IAAA,IACA,IAAA,CAAK,WAAA,KAAgB,MAAA,IACpB,KAAK,aAAA,KAAkB,MAAA,IACvB,IAAA,CAAK,UAAA,KAAe,MAAA,EACtB;AACA,IAAA,OAAO,eAAA;AAAA,EACT;AAGA,EAAA,MAAM,WAAA,GAAc,KAAK,WAAA,IAAe,MAAA;AACxC,EAAA,MAAM,aAAA,GAAgB,KAAK,aAAA,IAAiB,MAAA;AAC5C,EAAA,MAAM,UAAA,GAAa,KAAK,UAAA,IAAc,SAAA;AAEtC,EAAA,OAAO;AAAA,IACL,WAAA;AAAA,IACA,aAAA;AAAA,IACA,UAAA;AAAA,IACA,UAAA,EAAY,iBAAA,CAAkB,WAAA,EAAa,aAAA,EAAe,UAAU;AAAA,GACtE;AACF,CAAA;AAUO,IAAMG,YAAAA,GAAc,CAAC,KAAA,KAAuB,kBAAA,CAAmB,KAAK,CAAA;AAkBpE,IAAM,MAAA,GAAS,CACpB,IAAA,EACA,KAAA,EACA,IAAA,KACW;AACX,EAAA,MAAM,WAAA,GAAcA,aAAY,IAAI,CAAA;AAGpC,EAAA,QAAQ,OAAO,KAAA;AAAO,IACpB,KAAK,QAAA;AAAA,IACL,KAAK,QAAA,EAAU;AACb,MAAA,OAAO,CAAA,EAAG,WAAW,CAAA,CAAA,EAAIA,YAAAA,CAAY,KAAK,CAAC,CAAA,CAAA;AAAA,IAC7C;AAAA,IACA,KAAK,SAAA,EAAW;AACd,MAAA,OAAO,IAAA,CAAK,UAAA,CAAW,OAAA,CAAQ,MAAA,CAAO,aAAa,KAAK,CAAA;AAAA,IAC1D;AAAA,IACA,KAAK,QAAA,EAAU;AAEb,MAAA,IAAI,UAAU,IAAA,EAAM;AAClB,QAAA,OAAO,IAAA,CAAK,UAAA,CAAW,IAAA,CAAK,MAAA,CAAO,WAAW,CAAA;AAAA,MAChD;AAEA,MAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AACxB,QAAA,OAAO,IAAA,CAAK,UAAA,CAAW,KAAA,CAAM,WAAA,CAAY,aAAa,KAAK,CAAA;AAAA,MAC7D;AAGA,MAAA,OAAO,CAAA,EAAG,WAAW,CAAA,CAAA,EAAIA,YAAAA,CAAY,KAAK,CAAC,CAAA,CAAA;AAAA,IAC7C;AAAA,IACA,SAAS;AAEP,MAAA,OAAO,CAAA,EAAG,WAAW,CAAA,CAAA,EAAIA,YAAAA,CAAY,KAAK,CAAC,CAAA,CAAA;AAAA,IAC7C;AAAA;AAEJ,CAAA;;;AC7GO,IAAM,SAAA,GAAY,CAAC,IAAA,KAAyB;AACjD,EAAA,MAAM,GAAA,GAAM,IAAA,CAAK,OAAA,CAAQ,GAAG,CAAA;AAE5B,EAAA,IAAI,QAAQ,EAAA,EAAI;AACd,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,OAAO,IAAA,CAAK,KAAA,CAAM,GAAA,GAAM,CAAC,CAAA;AAC3B,CAAA;;;ACCA,SAAS,iBAAiB,OAAA,EAGxB;AACA,EAAA,MAAM,UAAA,GAAa,OAAA,CAAQ,OAAA,CAAQ,GAAG,CAAA;AAEtC,EAAA,OAAO,eAAe,EAAA,GAClB,EAAE,IAAA,EAAM,OAAA,EAAS,aAAa,KAAA,EAAM,GACpC,EAAE,IAAA,EAAM,QAAQ,KAAA,CAAM,CAAA,EAAG,UAAU,CAAA,EAAG,aAAa,IAAA,EAAK;AAC9D;AAOA,SAAS,WAAA,CACP,MAAA,EACA,WAAA,EACA,YAAA,EACA,WAAA,EACM;AACN,EAAA,MAAM,YAAA,GAAe,OAAO,WAAW,CAAA;AAEvC,EAAA,IAAI,iBAAiB,MAAA,EAAW;AAC9B,IAAA,MAAA,CAAO,WAAW,CAAA,GAAI,WAAA,GAAc,CAAC,YAAY,CAAA,GAAI,YAAA;AAAA,EACvD,CAAA,MAAA,IAAW,KAAA,CAAM,OAAA,CAAQ,YAAY,CAAA,EAAG;AACtC,IAAA,YAAA,CAAa,KAAK,YAAY,CAAA;AAAA,EAChC,CAAA,MAAO;AACL,IAAA,MAAA,CAAO,WAAW,CAAA,GAAI,CAAC,YAAA,EAAc,YAAY,CAAA;AAAA,EACnD;AACF;AAOA,SAAS,gBAAA,CACP,UAAA,EACA,KAAA,EACA,GAAA,EACA,UACA,UAAA,EACS;AACT,EAAA,IAAI,UAAA,EAAY;AACd,IAAA,MAAM,WAAW,QAAA,GAAW,UAAA,CAAW,MAAM,KAAA,GAAQ,CAAA,EAAG,GAAG,CAAA,GAAI,MAAA;AAE/D,IAAA,OAAO,MAAA,CAAO,UAAU,UAAU,CAAA;AAAA,EACpC;AAEA,EAAA,OAAO,QAAA,GAAW,YAAY,UAAA,CAAW,KAAA,CAAM,QAAQ,CAAA,EAAG,GAAG,CAAC,CAAA,GAAI,IAAA;AACpE;AAOA,SAAS,iBAAA,CACP,UAAA,EACA,KAAA,EACA,GAAA,EACA,QACA,UAAA,EACM;AACN,EAAA,MAAM,KAAA,GAAQ,UAAA,CAAW,OAAA,CAAQ,GAAA,EAAK,KAAK,CAAA;AAC3C,EAAA,MAAM,QAAA,GAAW,KAAA,KAAU,EAAA,IAAM,KAAA,GAAQ,GAAA;AAEzC,EAAA,MAAM,OAAA,GAAU,QAAA,GACZ,UAAA,CAAW,KAAA,CAAM,KAAA,EAAO,KAAK,CAAA,GAC7B,UAAA,CAAW,KAAA,CAAM,KAAA,EAAO,GAAG,CAAA;AAE/B,EAAA,MAAM,EAAE,IAAA,EAAM,WAAA,EAAY,GAAI,iBAAiB,OAAO,CAAA;AACtD,EAAA,MAAM,WAAA,GAAc,YAAY,IAAI,CAAA;AACpC,EAAA,MAAM,YAAA,GAAe,gBAAA;AAAA,IACnB,UAAA;AAAA,IACA,KAAA;AAAA,IACA,GAAA;AAAA,IACA,QAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,WAAA,CAAY,MAAA,EAAQ,WAAA,EAAa,YAAA,EAAc,WAAW,CAAA;AAC5D;AA0CO,IAAM,KAAA,GAAQ,CACnB,IAAA,EACA,IAAA,KAC4B;AAC5B,EAAA,MAAM,UAAA,GAAa,UAAU,IAAI,CAAA;AAGjC,EAAA,IAAI,UAAA,KAAe,EAAA,IAAM,UAAA,KAAe,GAAA,EAAK;AAC3C,IAAA,OAAO,EAAC;AAAA,EACV;AAGA,EAAA,IAAI,CAAC,IAAA,EAAM;AACT,IAAA,OAAO,YAAY,UAAU,CAAA;AAAA,EAC/B;AAEA,EAAA,MAAM,OAAA,GAAU,YAAY,IAAI,CAAA;AAChC,EAAA,MAAM,SAAkC,EAAC;AAGzC,EAAA,IAAI,KAAA,GAAQ,CAAA;AACZ,EAAA,MAAM,MAAM,UAAA,CAAW,MAAA;AAEvB,EAAA,OAAO,QAAQ,GAAA,EAAK;AAClB,IAAA,IAAI,GAAA,GAAM,UAAA,CAAW,OAAA,CAAQ,GAAA,EAAK,KAAK,CAAA;AAEvC,IAAA,IAAI,QAAQ,EAAA,EAAI;AACd,MAAA,GAAA,GAAM,GAAA;AAAA,IACR;AAEA,IAAA,iBAAA,CAAkB,UAAA,EAAY,KAAA,EAAO,GAAA,EAAK,MAAA,EAAQ,QAAQ,UAAU,CAAA;AACpE,IAAA,KAAA,GAAQ,GAAA,GAAM,CAAA;AAAA,EAChB;AAEA,EAAA,OAAO,MAAA;AACT,CAAA;AASA,SAAS,YAAY,UAAA,EAA6C;AAChE,EAAA,MAAM,SAAkC,EAAC;AAEzC,EAAA,iBAAA,CAAkB,YAAY,MAAM,CAAA;AAEpC,EAAA,OAAO,MAAA;AACT;AA2BA,SAAS,iBAAA,CACP,YACA,MAAA,EACM;AACN,EAAA,IAAI,KAAA,GAAQ,CAAA;AACZ,EAAA,MAAM,MAAM,UAAA,CAAW,MAAA;AAEvB,EAAA,OAAO,QAAQ,GAAA,EAAK;AAClB,IAAA,IAAI,GAAA,GAAM,UAAA,CAAW,OAAA,CAAQ,GAAA,EAAK,KAAK,CAAA;AAEvC,IAAA,IAAI,QAAQ,EAAA,EAAI;AACd,MAAA,GAAA,GAAM,GAAA;AAAA,IACR;AAGA,IAAA,iBAAA,CAAkB,UAAA,EAAY,KAAA,EAAO,GAAA,EAAK,MAAM,CAAA;AAChD,IAAA,KAAA,GAAQ,GAAA,GAAM,CAAA;AAAA,EAChB;AACF;AAkBO,IAAM,KAAA,GAAQ,CACnB,MAAA,EACA,IAAA,KACW;AAEX,EAAA,MAAM,IAAA,GAAO,MAAA,CAAO,IAAA,CAAK,MAAM,CAAA;AAE/B,EAAA,IAAI,IAAA,CAAK,WAAW,CAAA,EAAG;AACrB,IAAA,OAAO,EAAA;AAAA,EACT;AAEA,EAAA,MAAM,OAAA,GAAU,YAAY,IAAI,CAAA;AAIhC,EAAA,MAAM,QAAkB,EAAC;AAEzB,EAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,IAAA,MAAM,KAAA,GAAQ,OAAO,GAAG,CAAA;AAGxB,IAAA,IAAI,UAAU,MAAA,EAAW;AACvB,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,OAAA,GAAU,MAAA,CAAO,GAAA,EAAK,KAAA,EAAO,OAAO,CAAA;AAG1C,IAAA,IAAI,OAAA,EAAS;AACX,MAAA,KAAA,CAAM,KAAK,OAAO,CAAA;AAAA,IACpB;AAAA,EACF;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,GAAG,CAAA;AACvB,CAAA;;;AC3QO,SAAS,iBAAA,CACd,MACA,SAAA,EAC6B;AAC7B,EAAA,MAAM,WAAwB,EAAC;AAG/B,EAAA,MAAM,KAAA,GAAQ,SAAA,CAAU,QAAA,CAAS,GAAG,CAAA,GAAI,UAAU,KAAA,CAAM,GAAG,CAAA,GAAI,CAAC,SAAS,CAAA;AAGzE,EAAA,IAAI,IAAA,CAAK,SAAS,EAAA,EAAI;AACpB,IAAA,QAAA,CAAS,KAAK,IAAI,CAAA;AAAA,EACpB;AAGA,EAAA,IAAI,WAAA,GAAyB,IAAA;AAE7B,EAAA,KAAA,MAAW,QAAQ,KAAA,EAAO;AACxB,IAAA,MAAM,OAAA,GAAU,WAAA,CAAY,QAAA,CAAS,GAAA,CAAI,IAAI,CAAA;AAE7C,IAAA,IAAI,CAAC,OAAA,EAAS;AACZ,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,QAAA,CAAS,KAAK,OAAO,CAAA;AACrB,IAAA,WAAA,GAAc,OAAA;AAAA,EAChB;AAEA,EAAA,OAAO,QAAA;AACT;;;AC1BO,SAAS,mBAAA,CACd,MAAA,EACA,kBAAA,EACA,IAAA,EACM;AACN,EAAA,KAAA,MAAW,CAAC,SAAA,EAAW,EAAE,SAAS,UAAA,EAAY,KAAK,kBAAA,EAAoB;AACrE,IAAA,MAAM,KAAA,GAAQ,MAAA,CAAO,MAAA,CAAO,SAAS,CAAC,CAAA;AAEtC,IAAA,IAAI,CAAC,OAAA,CAAQ,IAAA,CAAK,KAAK,CAAA,EAAG;AACxB,MAAA,MAAM,oBAAoB,UAAA,GACtB,UAAA,CAAW,UAAA,CAAW,YAAA,EAAc,EAAE,CAAA,GACtC,OAAA;AAEJ,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,cAAc,SAAS,CAAA,MAAA,EAAS,IAAI,CAAA,2BAAA,EAC1B,KAAK,yBAAyB,iBAAiB,CAAA,CAAA;AAAA,OAC3D;AAAA,IACF;AAAA,EACF;AACF;;;AClBA,IAAM,oBAAA,GAAuB,uBAAA;AAQ7B,IAAM,mBAAA,GAAsB,sBAAA;AAcrB,IAAM,oCAAA,GAAuC,CAClD,OAAA,KACW;AAEX,EAAA,IAAI,CAAC,mBAAA,CAAoB,IAAA,CAAK,OAAO,CAAA,EAAG;AACtC,IAAA,OAAO,OAAA;AAAA,EACT;AAGA,EAAA,OAAO,OAAA,CAAQ,UAAA;AAAA,IAAW,oBAAA;AAAA,IAAsB,CAAC,KAAA,KAC/C,kBAAA,CAAmB,KAAK;AAAA,GAC1B;AACF,CAAA;AAeO,IAAM,gBAAA,GAGT;AAAA,EACF,OAAA,EAAS,oCAAA;AAAA,EACT,GAAA,EAAK,SAAA;AAAA,EACL,YAAA,EAAc,kBAAA;AAAA,EACd,IAAA,EAAM,CAAC,GAAA,KAAQ;AACjB,CAAA;AAKO,IAAM,gBAAA,GAGT;AAAA,EACF,OAAA,EAAS,kBAAA;AAAA,EACT,GAAA,EAAK,SAAA;AAAA,EACL,YAAA,EAAc,kBAAA;AAAA;AAAA,EAEd,IAAA,EAAM,CAAC,GAAA,KAAQ;AACjB,CAAA;AA0BO,IAAM,WAAA,GAAc,CACzB,KAAA,EACA,QAAA,EACA,WAAA,KACW;AACX,EAAA,MAAM,OAAA,GAAU,iBAAiB,QAAQ,CAAA;AACzC,EAAA,MAAM,GAAA,GAAM,OAAO,KAAK,CAAA;AAExB,EAAA,IAAI,CAAC,WAAA,EAAa;AAChB,IAAA,OAAO,QAAQ,GAAG,CAAA;AAAA,EACpB;AAIA,EAAA,MAAM,QAAA,GAAW,GAAA,CAAI,KAAA,CAAM,GAAG,CAAA;AAC9B,EAAA,IAAI,MAAA,GAAS,OAAA,CAAQ,QAAA,CAAS,CAAC,CAAC,CAAA;AAEhC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,QAAA,CAAS,QAAQ,CAAA,EAAA,EAAK;AACxC,IAAA,MAAA,IAAU,GAAA,GAAM,OAAA,CAAQ,QAAA,CAAS,CAAC,CAAC,CAAA;AAAA,EACrC;AAEA,EAAA,OAAO,MAAA;AACT,CAAA;;;AChHA,IAAM,GAAA,GAAM,+CAAA;AAgDL,SAAS,MAAA,CAAO,OAAe,MAAA,EAAwC;AAC5E,EAAA,OAAO,KAAA,CAAM,UAAA;AAAA,IACX,GAAA;AAAA,IACA,CACE,MAAA,EACA,IAAA,EACA,GAAA,EACA,aACA,QAAA,KACG;AACH,MAAA,MAAM,OAAA,GAAU,GAAA,CAAI,UAAA,CAAW,GAAG,CAAA;AAElC,MAAA,IAAI,SAAA;AAEJ,MAAA,IAAI,OAAA,EAAS;AACX,QAAA,SAAA,GAAY,IAAI,MAAA,GAAS,CAAA,GAAI,GAAA,CAAI,KAAA,CAAM,CAAC,CAAA,GAAI,MAAA;AAAA,MAC9C,CAAA,MAAO;AACL,QAAA,SAAA,GAAY,GAAA,CAAI,MAAM,CAAC,CAAA;AAAA,MACzB;AAEA,MAAA,MAAM,KAAA,GAAQ,OAAO,SAAS,CAAA;AAG9B,MAAA,IAAI,UAAU,MAAA,EAAW;AACvB,QAAA,OAAO,IAAA,GAAO,KAAA;AAAA,MAChB;AAEA,MAAA,IAAI,QAAA,KAAa,UAAa,OAAA,EAAS;AACrC,QAAA,OAAO,EAAA;AAAA,MACT;AAEA,MAAA,OAAO,IAAA,GAAO,GAAA;AAAA,IAChB;AAAA,GACF;AACF;;;AClGO,IAAM,cAAA,GAAN,cAA6B,KAAA,CAAM;AAAA,EACxC,YAAY,OAAA,EAAiB;AAC3B,IAAA,KAAA,CAAM,OAAO,CAAA;AACb,IAAA,IAAA,CAAK,IAAA,GAAO,gBAAA;AAEZ,IAAA,MAAA,CAAO,cAAA,CAAe,IAAA,EAAM,GAAA,CAAA,MAAA,CAAW,SAAS,CAAA;AAAA,EAClD;AACF,CAAA;AA4DO,IAAM,kBAAA,GAAN,cAAiC,cAAA,CAAe;AAAA;AAAA,EAErC,SAAA;AAAA,EAEhB,WAAA,CAAY,SAAiB,SAAA,EAAmB;AAC9C,IAAA,KAAA,CAAM,OAAO,CAAA;AACb,IAAA,IAAA,CAAK,IAAA,GAAO,oBAAA;AACZ,IAAA,IAAA,CAAK,SAAA,GAAY,SAAA;AAAA,EACnB;AACF,CAAA;;;ACtEA,IAAM,WAAA,GAAiC,MAAA,CAAO,MAAA,CAAO,EAAE,CAAA;AAUvD,SAAS,WAAW,GAAA,EAAsB;AACxC,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT;AAYA,SAAS,qBAAqB,OAAA,EAAgC;AAC5D,EAAA,OACG,QAAQ,iBAAA,KAAsB,MAAA,IAC7B,QAAQ,iBAAA,KAAsB,SAAA,IAC/B,QAAQ,eAAA,KAAoB,MAAA,IAC3B,QAAQ,eAAA,KAAoB,SAAA,IAC9B,QAAQ,WAAA,KAAgB,MAAA,IACvB,QAAQ,iBAAA,KAAsB,MAAA,IAC7B,QAAQ,iBAAA,KAAsB,SAAA;AAEpC;AAsBA,SAAS,iBAAA,CAAkB,MAAiB,SAAA,EAAkC;AAC5E,EAAA,IAAI,SAAA,CAAU,QAAA,CAAS,GAAG,CAAA,EAAG;AAC3B,IAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,IAAA,EAAM,SAAS,CAAA;AAClD,IAAA,MAAM,UAAA,GAAa,QAAA,EAAU,EAAA,CAAG,EAAE,CAAA,EAAG,UAAA;AAErC,IAAA,OAAO,UAAA,IAAc,IAAA;AAAA,EACvB;AAEA,EAAA,OAAO,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,SAAS,GAAG,UAAA,IAAc,IAAA;AACrD;AAuBO,SAAS,SAAA,CACd,MACA,SAAA,EACA,MAAA,GAAsB,EAAC,EACvB,OAAA,GAAwB,EAAC,EACzB,QAAA,EACQ;AAER,EAAA,IAAI,QAAA,EAAU;AACZ,IAAA,OAAO,qBAAA,CAAsB,QAAA,EAAU,MAAA,EAAQ,OAAO,CAAA;AAAA,EACxD;AAKA,EAAA,MAAM,SAAA,GAAY,WAAW,MAAM,CAAA;AACnC,EAAA,MAAM,cAAA,GAAiB,qBAAqB,OAAO,CAAA;AAEnD,EAAA,IAAI,CAAC,SAAA,IAAa,CAAC,cAAA,EAAgB;AACjC,IAAA,MAAM,UAAA,GAAa,iBAAA,CAAkB,IAAA,EAAM,SAAS,CAAA;AAEpD,IAAA,IAAI,eAAe,IAAA,EAAM;AACvB,MAAA,OAAO,UAAA;AAAA,IACT;AAAA,EACF;AAGA,EAAA,MAAM,aAAA,GAAgB,iBAAA,CAAkB,IAAA,EAAM,SAAS,CAAA;AAEvD,EAAA,IAAI,CAAC,aAAA,EAAe;AAClB,IAAA,MAAM,IAAI,kBAAA;AAAA,MACR,4BAA4B,SAAS,CAAA,gBAAA,CAAA;AAAA,MACrC;AAAA,KACF;AAAA,EACF;AAEA,EAAA,OAAO,qBAAA,CAAsB,aAAA,EAAe,MAAA,EAAQ,OAAO,CAAA;AAC7D;AAYA,SAAS,qBAAA,CACP,QAAA,EACA,MAAA,EACA,OAAA,EACQ;AACR,EAAA,MAAM,EAAE,eAAA,GAAkB,SAAA,EAAW,iBAAA,GAAoB,WAAU,GACjE,OAAA;AAEF,EAAA,MAAM,SAAA,GAAY,0BAA0B,QAAQ,CAAA;AACpD,EAAA,MAAM,YAAA,GAAe,mBAAA,CAAoB,SAAA,EAAW,MAAA,EAAQ,eAAe,CAAA;AAC3E,EAAA,MAAM,UAAA,GAAa,iBAAA,CAAkB,YAAA,EAAc,MAAA,EAAQ,OAAO,CAAA;AAClE,EAAA,MAAM,UAAA,GAAa,eAAA,CAAgB,QAAA,EAAU,MAAA,EAAQ,OAAO,CAAA;AAC5D,EAAA,MAAM,SAAA,GAAY,sBAAA,CAAuB,UAAA,EAAY,iBAAiB,CAAA;AAEtE,EAAA,OAAO,SAAA,IAAa,UAAA,GAAa,CAAA,CAAA,EAAI,UAAU,CAAA,CAAA,GAAK,EAAA,CAAA;AACtD;AAMA,SAAS,0BACP,QAAA,EACiB;AACjB,EAAA,IAAI,YAAA,GAAgC,IAAA;AACpC,EAAA,IAAI,eAAA,GAAmC,IAAA;AAEvC,EAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,IAAA,MAAM,EAAE,WAAA,EAAa,SAAA,EAAW,UAAA,KAAe,OAAA,CAAQ,SAAA;AAIvD,IAAA,IAAI,WAAA,CAAY,SAAS,CAAA,EAAG;AAC1B,MAAA,YAAA,KAAiB,EAAC;AAElB,MAAA,KAAA,MAAW,cAAc,WAAA,EAAa;AACpC,QAAA,YAAA,CAAa,KAAK,UAAU,CAAA;AAAA,MAC9B;AAAA,IACF;AAEA,IAAA,IAAI,SAAA,CAAU,MAAA,GAAS,CAAA,IAAK,UAAA,CAAW,SAAS,CAAA,EAAG;AACjD,MAAA,eAAA,KAAoB,EAAC;AAErB,MAAA,KAAA,MAAW,YAAY,SAAA,EAAW;AAChC,QAAA,eAAA,CAAgB,KAAK,QAAQ,CAAA;AAAA,MAC/B;AAEA,MAAA,KAAA,MAAW,aAAa,UAAA,EAAY;AAClC,QAAA,eAAA,CAAgB,KAAK,SAAS,CAAA;AAAA,MAChC;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,cAAc,YAAA,IAAgB,WAAA;AAAA,IAC9B,iBAAiB,eAAA,IAAmB;AAAA,GACtC;AACF;AAKA,SAAS,mBAAA,CACP,SAAA,EACA,MAAA,EACA,eAAA,EACmB;AACnB,EAAA,IAAI,oBAAoB,OAAA,EAAS;AAC/B,IAAA,OAAO,SAAA,CAAU,YAAA;AAAA,EACnB;AAGA,EAAA,MAAM,YAAA,GAAe,CAAC,GAAI,SAAA,CAAU,YAAyB,CAAA;AAC7D,EAAA,MAAM,eAAA,GAAkB,IAAI,GAAA,CAAI,SAAA,CAAU,YAAY,CAAA;AACtD,EAAA,MAAM,kBAAA,GAAqB,IAAI,GAAA,CAAI,SAAA,CAAU,eAAe,CAAA;AAG5D,EAAA,KAAA,MAAW,KAAK,MAAA,EAAQ;AACtB,IAAA,IACE,MAAA,CAAO,MAAA,CAAO,MAAA,EAAQ,CAAC,KACvB,CAAC,eAAA,CAAgB,GAAA,CAAI,CAAC,CAAA,IACtB,CAAC,kBAAA,CAAmB,GAAA,CAAI,CAAC,CAAA,EACzB;AACA,MAAA,YAAA,CAAa,KAAK,CAAC,CAAA;AAAA,IACrB;AAAA,EACF;AAEA,EAAA,OAAO,YAAA;AACT;AAKA,SAAS,iBAAA,CACP,YAAA,EACA,MAAA,EACA,OAAA,EACQ;AACR,EAAA,MAAM,qBAAkC,EAAC;AAEzC,EAAA,KAAA,MAAW,aAAa,YAAA,EAAc;AACpC,IAAA,IAAI,aAAa,MAAA,EAAQ;AACvB,MAAA,kBAAA,CAAmB,SAAS,CAAA,GAAI,MAAA,CAAO,SAAS,CAAA;AAAA,IAClD;AAAA,EACF;AAEA,EAAA,OAAO,KAAA,CAAiB,kBAAA,EAAoB,OAAA,CAAQ,WAAW,CAAA;AACjE;AAKA,SAAS,mBAAA,CACP,MAAA,EACA,SAAA,EACA,UAAA,EACA,QAAA,EACwB;AACxB,EAAA,MAAM,gBAAwC,EAAC;AAE/C,EAAA,KAAA,MAAW,aAAa,SAAA,EAAW;AACjC,IAAA,MAAM,KAAA,GAAQ,OAAO,SAAS,CAAA;AAE9B,IAAA,IAAI,KAAA,KAAU,MAAA,IAAa,KAAA,KAAU,IAAA,EAAM;AACzC,MAAA,MAAM,YAAA,GAAe,UAAA,CAAW,QAAA,CAAS,SAAS,CAAA;AAClD,MAAA,MAAM,WAAA,GACJ,OAAO,KAAA,KAAU,QAAA,GAAW,KAAK,SAAA,CAAU,KAAK,CAAA,GAAI,MAAA,CAAO,KAAK,CAAA;AAElE,MAAA,aAAA,CAAc,SAAS,CAAA,GAAI,WAAA;AAAA,QACzB,WAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,aAAA;AACT;AAKA,SAAS,eAAA,CACP,QAAA,EACA,MAAA,EACA,OAAA,EACQ;AACR,EAAA,IAAI,IAAA,GAAO,EAAA;AACX,EAAA,MAAM,QAAA,GAAW,QAAQ,iBAAA,IAAqB,SAAA;AAC9C,EAAA,MAAM,iBAAA,GAAoB,QAAQ,iBAAA,IAAqB,KAAA;AAEvD,EAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,IAAA,MAAM,EAAE,kBAAA,EAAoB,SAAA,EAAW,UAAA,KAAe,OAAA,CAAQ,SAAA;AAG9D,IAAA,IAAI,kBAAA,CAAmB,IAAA,GAAO,CAAA,IAAK,CAAC,iBAAA,EAAmB;AACrD,MAAA,mBAAA,CAAoB,MAAA,EAAQ,kBAAA,EAAoB,OAAA,CAAQ,IAAI,CAAA;AAAA,IAC9D;AAGA,IAAA,MAAM,aAAA,GAAgB,mBAAA;AAAA,MACpB,MAAA;AAAA,MACA,SAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,MAAM,WAAA,GAAc,MAAA,CAAO,OAAA,CAAQ,SAAA,CAAU,aAAa,aAAa,CAAA;AAEvE,IAAA,IAAA,GAAO,OAAA,CAAQ,QAAA,GAAW,WAAA,GAAc,IAAA,GAAO,WAAA;AAAA,EACjD;AAGA,EAAA,OAAO,IAAA,CAAK,SAAS,IAAI,CAAA,GAAI,KAAK,UAAA,CAAW,SAAA,EAAW,GAAG,CAAA,GAAI,IAAA;AACjE;AAKA,SAAS,sBAAA,CAAuB,MAAc,IAAA,EAAiC;AAC7E,EAAA,IAAI,SAAS,QAAA,EAAU;AACrB,IAAA,OAAO,KAAK,QAAA,CAAS,GAAG,CAAA,GAAI,IAAA,GAAO,GAAG,IAAI,CAAA,CAAA,CAAA;AAAA,EAC5C;AAEA,EAAA,IAAI,IAAA,KAAS,OAAA,IAAW,IAAA,KAAS,GAAA,EAAK;AACpC,IAAA,OAAO,IAAA,CAAK,SAAS,GAAG,CAAA,GAAI,KAAK,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,GAAI,IAAA;AAAA,EAClD;AAEA,EAAA,OAAO,IAAA;AACT;;;ACvVO,SAAS,iBAAiB,IAAA,EAAkC;AAEjE,EAAA,MAAM,OAAO,IAAA,CAAK,QAAA,GAAW,IAAI,IAAA,CAAK,IAAI,KAAK,IAAA,CAAK,IAAA;AAEpD,EAAA,MAAM,GAAA,GAAuB;AAAA,IAC3B,MAAM,IAAA,CAAK,IAAA;AAAA,IACX;AAAA,GACF;AAEA,EAAA,IAAI,IAAA,CAAK,QAAA,CAAS,IAAA,GAAO,CAAA,EAAG;AAC1B,IAAA,GAAA,CAAI,WAAW,CAAC,GAAG,KAAK,QAAA,CAAS,MAAA,EAAQ,CAAA,CAAE,GAAA;AAAA,MAAI,CAAC,KAAA,KAC9C,gBAAA,CAAiB,KAAK;AAAA,KACxB;AAAA,EACF;AAEA,EAAA,OAAO,GAAA;AACT;AA2BO,SAAS,uBAAuB,IAAA,EAAoC;AACzE,EAAA,OAAO,CAAC,GAAG,IAAA,CAAK,QAAA,CAAS,MAAA,EAAQ,CAAA,CAAE,GAAA,CAAI,CAAC,KAAA,KAAU,gBAAA,CAAiB,KAAK,CAAC,CAAA;AAC3E;;;ACnEA,IAAM,+BAAgC,CAAA,MAAM;AAC3C,EAAA,MAAM,IAAI,WAAW;AAAA,EAAC,CAAA;AACtB,EAAA,OAAO,CAAA,CAAE,SAAA,mBAAY,MAAA,CAAO,MAAA,CAAO,IAAI,GAAG,MAAA,CAAO,MAAA,CAAO,CAAA,CAAE,SAAS,CAAA,EAAG,CAAA;AACvE,CAAA,GAAG;AAKH,SAAS,YAAA,GAAe;AACvB,EAAA,OAAO;AAAA,IACN,IAAA,EAAM,EAAE,GAAA,EAAK,EAAA,EAAG;AAAA,IAChB,MAAA,EAAQ,IAAI,YAAA;AAAa,GAC1B;AACD;AAEA,SAAS,UAAU,IAAA,EAAM;AACxB,EAAA,MAAM,CAAC,CAAA,EAAG,GAAG,CAAC,CAAA,GAAI,IAAA,CAAK,MAAM,GAAG,CAAA;AAChC,EAAA,OAAO,CAAA,CAAE,CAAA,CAAE,MAAA,GAAS,CAAC,CAAA,KAAM,KAAK,CAAA,CAAE,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,GAAI,CAAA;AAClD;AACA,SAAS,cAAA,CAAe,UAAU,SAAA,EAAW;AAC5C,EAAA,MAAM,MAAA,GAAS,IAAI,YAAA,EAAa;AAChC,EAAA,KAAA,MAAW,CAAC,KAAA,EAAO,IAAI,CAAA,IAAK,SAAA,EAAW;AACtC,IAAA,MAAM,OAAA,GAAU,KAAA,GAAQ,CAAA,GAAI,QAAA,CAAS,KAAA,CAAM,EAAE,KAAA,GAAQ,CAAA,CAAE,CAAA,CAAE,IAAA,CAAK,GAAG,CAAA,GAAI,SAAS,KAAK,CAAA;AACnF,IAAA,IAAI,OAAO,IAAA,KAAS,QAAA,EAAU,MAAA,CAAO,IAAI,CAAA,GAAI,OAAA;AAAA,SACxC;AACJ,MAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,IAAI,CAAA;AAChC,MAAA,IAAI,KAAA,EAAO,KAAA,MAAW,GAAA,IAAO,KAAA,CAAM,MAAA,SAAe,GAAG,CAAA,GAAI,KAAA,CAAM,MAAA,CAAO,GAAG,CAAA;AAAA,IAC1E;AAAA,EACD;AACA,EAAA,OAAO,MAAA;AACR;AAKA,SAAS,QAAA,CAAS,GAAA,EAAK,MAAA,GAAS,EAAA,EAAI,MAAM,IAAA,EAAM;AAC/C,EAAA,MAAA,GAAS,OAAO,WAAA,EAAY;AAC5B,EAAA,IAAI,KAAK,UAAA,CAAW,CAAC,MAAM,EAAA,EAAI,IAAA,GAAO,IAAI,IAAI,CAAA,CAAA;AAC9C,EAAA,IAAA,GAAO,IAAA,CAAK,OAAA,CAAQ,MAAA,EAAQ,KAAK,CAAA;AACjC,EAAA,MAAM,QAAA,GAAW,UAAU,IAAI,CAAA;AAC/B,EAAA,IAAI,OAAO,GAAA,CAAI,IAAA;AACf,EAAA,IAAI,kBAAA,GAAqB,CAAA;AACzB,EAAA,MAAM,YAAY,EAAC;AACnB,EAAA,MAAM,eAAe,EAAC;AACtB,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,QAAA,CAAS,QAAQ,CAAA,EAAA,EAAK;AACzC,IAAA,IAAI,OAAA,GAAU,SAAS,CAAC,CAAA;AACxB,IAAA,IAAI,OAAA,CAAQ,UAAA,CAAW,IAAI,CAAA,EAAG;AAC7B,MAAA,IAAI,CAAC,IAAA,CAAK,QAAA,OAAe,QAAA,GAAW,EAAE,KAAK,IAAA,EAAK;AAChD,MAAA,IAAA,GAAO,IAAA,CAAK,QAAA;AACZ,MAAA,SAAA,CAAU,IAAA,CAAK;AAAA,QACd,EAAE,CAAA,GAAI,CAAA,CAAA;AAAA,QACN,OAAA,CAAQ,KAAA,CAAM,GAAG,CAAA,CAAE,CAAC,CAAA,IAAK,GAAA;AAAA,QACzB,QAAQ,MAAA,KAAW;AAAA,OACnB,CAAA;AACD,MAAA;AAAA,IACD;AACA,IAAA,IAAI,OAAA,KAAY,GAAA,IAAO,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA,EAAG;AAC7C,MAAA,IAAI,CAAC,IAAA,CAAK,KAAA,OAAY,KAAA,GAAQ,EAAE,KAAK,GAAA,EAAI;AACzC,MAAA,IAAA,GAAO,IAAA,CAAK,KAAA;AACZ,MAAA,IAAI,OAAA,KAAY,GAAA,EAAK,SAAA,CAAU,IAAA,CAAK;AAAA,QACnC,CAAA;AAAA,QACA,IAAI,kBAAA,EAAoB,CAAA,CAAA;AAAA,QACxB;AAAA,OACA,CAAA;AAAA,WAAA,IACQ,OAAA,CAAQ,QAAA,CAAS,GAAA,EAAK,CAAC,CAAA,EAAG;AAClC,QAAA,MAAM,MAAA,GAAS,eAAe,OAAO,CAAA;AACrC,QAAA,YAAA,CAAa,CAAC,CAAA,GAAI,MAAA;AAClB,QAAA,IAAA,CAAK,aAAA,GAAgB,IAAA;AACrB,QAAA,SAAA,CAAU,IAAA,CAAK;AAAA,UACd,CAAA;AAAA,UACA,MAAA;AAAA,UACA;AAAA,SACA,CAAA;AAAA,MACF,CAAA,gBAAiB,IAAA,CAAK;AAAA,QACrB,CAAA;AAAA,QACA,OAAA,CAAQ,MAAM,CAAC,CAAA;AAAA,QACf;AAAA,OACA,CAAA;AACD,MAAA;AAAA,IACD;AACA,IAAA,IAAI,OAAA,KAAY,KAAA,EAAO,OAAA,GAAU,QAAA,CAAS,CAAC,CAAA,GAAI,GAAA;AAAA,SAAA,IACtC,OAAA,KAAY,QAAA,EAAU,OAAA,GAAU,QAAA,CAAS,CAAC,CAAA,GAAI,IAAA;AACvD,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,MAAA,GAAS,OAAO,CAAA;AACnC,IAAA,IAAI,OAAO,IAAA,GAAO,KAAA;AAAA,SACb;AACJ,MAAA,MAAM,UAAA,GAAa,EAAE,GAAA,EAAK,OAAA,EAAQ;AAClC,MAAA,IAAI,CAAC,IAAA,CAAK,MAAA,EAAQ,IAAA,CAAK,MAAA,GAAS,IAAI,YAAA,EAAa;AACjD,MAAA,IAAA,CAAK,MAAA,CAAO,OAAO,CAAA,GAAI,UAAA;AACvB,MAAA,IAAA,GAAO,UAAA;AAAA,IACR;AAAA,EACD;AACA,EAAA,MAAM,SAAA,GAAY,UAAU,MAAA,GAAS,CAAA;AACrC,EAAA,IAAI,CAAC,IAAA,CAAK,OAAA,EAAS,IAAA,CAAK,OAAA,GAAU,IAAI,YAAA,EAAa;AACnD,EAAA,IAAA,CAAK,OAAA,CAAQ,MAAM,CAAA,KAAM,EAAC;AAC1B,EAAA,IAAA,CAAK,OAAA,CAAQ,MAAM,CAAA,CAAE,IAAA,CAAK;AAAA,IACzB,MAAM,IAAA,IAAQ,IAAA;AAAA,IACd,YAAA;AAAA,IACA,SAAA,EAAW,YAAY,SAAA,GAAY;AAAA,GACnC,CAAA;AACD,EAAA,IAAI,CAAC,WAAW,GAAA,CAAI,MAAA,CAAO,MAAM,QAAA,CAAS,IAAA,CAAK,GAAG,CAAC,CAAA,GAAI,IAAA;AACxD;AACA,SAAS,eAAe,OAAA,EAAS;AAChC,EAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,OAAA,CAAQ,SAAA,EAAW,CAAC,CAAA,EAAG,EAAA,KAAO,CAAA,GAAA,EAAM,EAAE,CAAA,OAAA,CAAS,CAAA,CAAE,OAAA,CAAQ,OAAO,KAAK,CAAA;AAC3F,EAAA,uBAAuB,IAAI,MAAA,CAAO,CAAA,CAAA,EAAI,KAAK,CAAA,CAAA,CAAG,CAAA;AAC/C;AAKA,SAAS,SAAA,CAAU,GAAA,EAAK,MAAA,GAAS,EAAA,EAAI,MAAM,IAAA,EAAM;AAChD,EAAA,IAAI,IAAA,CAAK,UAAA,CAAW,IAAA,CAAK,MAAA,GAAS,CAAC,CAAA,KAAM,EAAA,EAAI,IAAA,GAAO,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA;AACpE,EAAA,MAAM,UAAA,GAAa,GAAA,CAAI,MAAA,CAAO,IAAI,CAAA;AAClC,EAAA,IAAI,UAAA,IAAc,WAAW,OAAA,EAAS;AACrC,IAAA,MAAM,cAAc,UAAA,CAAW,OAAA,CAAQ,MAAM,CAAA,IAAK,UAAA,CAAW,QAAQ,EAAE,CAAA;AACvE,IAAA,IAAI,WAAA,KAAgB,MAAA,EAAQ,OAAO,WAAA,CAAY,CAAC,CAAA;AAAA,EACjD;AACA,EAAA,MAAM,QAAA,GAAW,UAAU,IAAI,CAAA;AAC/B,EAAA,MAAM,KAAA,GAAQ,YAAY,GAAA,EAAK,GAAA,CAAI,MAAM,MAAA,EAAQ,QAAA,EAAU,CAAC,CAAA,GAAI,CAAC,CAAA;AACjE,EAAA,IAAI,UAAU,MAAA,EAAQ;AAEtB,EAAA,OAAO;AAAA,IACN,MAAM,KAAA,CAAM,IAAA;AAAA,IACZ,QAAQ,KAAA,CAAM,SAAA,GAAY,eAAe,QAAA,EAAU,KAAA,CAAM,SAAS,CAAA,GAAI;AAAA,GACvE;AACD;AACA,SAAS,WAAA,CAAY,GAAA,EAAK,IAAA,EAAM,MAAA,EAAQ,UAAU,KAAA,EAAO;AACxD,EAAA,IAAI,KAAA,KAAU,SAAS,MAAA,EAAQ;AAC9B,IAAA,IAAI,KAAK,OAAA,EAAS;AACjB,MAAA,MAAM,QAAQ,IAAA,CAAK,OAAA,CAAQ,MAAM,CAAA,IAAK,IAAA,CAAK,QAAQ,EAAE,CAAA;AACrD,MAAA,IAAI,OAAO,OAAO,KAAA;AAAA,IACnB;AACA,IAAA,IAAI,IAAA,CAAK,KAAA,IAAS,IAAA,CAAK,KAAA,CAAM,OAAA,EAAS;AACrC,MAAA,MAAM,KAAA,GAAQ,KAAK,KAAA,CAAM,OAAA,CAAQ,MAAM,CAAA,IAAK,IAAA,CAAK,KAAA,CAAM,OAAA,CAAQ,EAAE,CAAA;AACjE,MAAA,IAAI,KAAA,EAAO;AACV,QAAA,MAAM,IAAA,GAAO,KAAA,CAAM,CAAC,CAAA,CAAE,SAAA;AACtB,QAAA,IAAI,OAAO,IAAA,EAAM,MAAA,GAAS,CAAC,CAAA,GAAI,CAAC,GAAG,OAAO,KAAA;AAAA,MAC3C;AAAA,IACD;AACA,IAAA,IAAI,IAAA,CAAK,QAAA,IAAY,IAAA,CAAK,QAAA,CAAS,OAAA,EAAS;AAC3C,MAAA,MAAM,KAAA,GAAQ,KAAK,QAAA,CAAS,OAAA,CAAQ,MAAM,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,OAAA,CAAQ,EAAE,CAAA;AACvE,MAAA,IAAI,KAAA,EAAO;AACV,QAAA,MAAM,IAAA,GAAO,KAAA,CAAM,CAAC,CAAA,CAAE,SAAA;AACtB,QAAA,IAAI,OAAO,IAAA,EAAM,MAAA,GAAS,CAAC,CAAA,GAAI,CAAC,GAAG,OAAO,KAAA;AAAA,MAC3C;AAAA,IACD;AACA,IAAA;AAAA,EACD;AACA,EAAA,MAAM,OAAA,GAAU,SAAS,KAAK,CAAA;AAC9B,EAAA,IAAI,KAAK,MAAA,EAAQ;AAChB,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,MAAA,CAAO,OAAO,CAAA;AACvC,IAAA,IAAI,WAAA,EAAa;AAChB,MAAA,MAAM,QAAQ,WAAA,CAAY,GAAA,EAAK,aAAa,MAAA,EAAQ,QAAA,EAAU,QAAQ,CAAC,CAAA;AACvE,MAAA,IAAI,OAAO,OAAO,KAAA;AAAA,IACnB;AAAA,EACD;AACA,EAAA,IAAI,KAAK,KAAA,EAAO;AACf,IAAA,MAAM,KAAA,GAAQ,YAAY,GAAA,EAAK,IAAA,CAAK,OAAO,MAAA,EAAQ,QAAA,EAAU,QAAQ,CAAC,CAAA;AACtE,IAAA,IAAI,KAAA,EAAO;AACV,MAAA,IAAI,IAAA,CAAK,MAAM,aAAA,EAAe;AAC7B,QAAA,MAAM,UAAA,GAAa,MAAM,IAAA,CAAK,CAAC,MAAM,CAAA,CAAE,YAAA,CAAa,KAAK,CAAA,EAAG,IAAA,CAAK,OAAO,CAAC,CAAA,IAAK,MAAM,IAAA,CAAK,CAAC,MAAM,CAAC,CAAA,CAAE,YAAA,CAAa,KAAK,CAAC,CAAA;AACtH,QAAA,OAAO,UAAA,GAAa,CAAC,UAAU,CAAA,GAAI,MAAA;AAAA,MACpC;AACA,MAAA,OAAO,KAAA;AAAA,IACR;AAAA,EACD;AACA,EAAA,IAAI,IAAA,CAAK,QAAA,IAAY,IAAA,CAAK,QAAA,CAAS,SAAS,OAAO,IAAA,CAAK,QAAA,CAAS,OAAA,CAAQ,MAAM,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,QAAQ,EAAE,CAAA;AAC7G;;;AClJA,IAAM,mBAAA,GAAsB,iBAAA;AAkBrB,IAAM,iBAAN,MAAgD;AAAA,EAC5C,UAAU,YAAA,EAAa;AAAA,EACvB,aAAA,uBAAoB,GAAA,EAAkC;AAAA,EACtD,WAAA,uBAAkB,GAAA,EAA0C;AAAA,EAErE,YAAA,CAAa,IAAA,EAAiB,UAAA,GAAa,EAAA,EAAU;AACnD,IAAA,MAAM,WAAwB,EAAC;AAE/B,IAAA,IAAA,CAAK,aAAA,CAAc,IAAA,EAAM,UAAA,EAAY,QAAQ,CAAA;AAAA,EAC/C;AAAA,EAEA,KAAA,CAAM,MAAc,OAAA,EAAiD;AACnE,IAAA,MAAM,cAAA,GAAiB,IAAA,KAAS,EAAA,GAAK,GAAA,GAAM,IAAA;AAE3C,IAAA,IACE,CAAC,eAAe,UAAA,CAAW,GAAG,KAC9B,IAAA,CAAK,cAAA,CAAe,cAAc,CAAA,EAClC;AACA,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,MAAM,UAAA,GAAa,cAAA,CAAe,OAAA,CAAQ,GAAG,CAAA;AAC7C,IAAA,MAAM,2BACJ,UAAA,KAAe,EAAA,GAAK,iBAAiB,cAAA,CAAe,KAAA,CAAM,GAAG,UAAU,CAAA;AACzE,IAAA,MAAM,cACJ,UAAA,KAAe,EAAA,GAAK,KAAK,cAAA,CAAe,KAAA,CAAM,aAAa,CAAC,CAAA;AAC9D,IAAA,MAAM,mBAAA,GAAsB,SAAS,mBAAA,IAAuB,KAAA;AAC5D,IAAA,MAAM,gBAAA,GAAmB,mBAAA,GACrB,wBAAA,GACA,IAAA,CAAK,wBAAwB,wBAAwB,CAAA;AAEzD,IAAA,MAAM,MAAA,GAAS,SAAA,CAAU,IAAA,CAAK,OAAA,EAAS,OAAO,gBAAgB,CAAA;AAE9D,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,MAAM,OAAO,MAAA,CAAO,IAAA;AAEpB,IAAA,IAAI,CAAC,IAAA,CAAK,sBAAA,CAAuB,gBAAA,EAAkB,IAAA,EAAM,OAAO,CAAA,EAAG;AACjE,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,MAAM,MAAA,GAAsB,OAAO,MAAA,GAC9B,EAAE,GAAG,MAAA,CAAO,MAAA,KACb,EAAC;AAEL,IAAA,IAAA,CAAK,gBAAA,CAAiB,MAAA,EAAQ,OAAA,EAAS,iBAAA,IAAqB,SAAS,CAAA;AAErE,IAAA,IACE,IAAA,CAAK,cAAA,IACL,CAAC,IAAA,CAAK,yBAAA;AAAA,MACJ,MAAA;AAAA,MACA,IAAA,CAAK,kBAAA;AAAA,MACL;AAAA,KACF,EACA;AACA,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,IAAI,WAAA,EAAa;AACf,MAAA,MAAM,UAAU,IAAA,CAAK,mBAAA;AAAA,QACnB,MAAA;AAAA,QACA,WAAA;AAAA,QACA,IAAA,CAAK,sBAAA;AAAA,QACL;AAAA,OACF;AAEA,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,OAAO,MAAA;AAAA,MACT;AAAA,IACF;AAEA,IAAA,OAAO;AAAA,MACL,UAAU,IAAA,CAAK,aAAA;AAAA,MACf,eAAe,IAAA,CAAK,QAAA;AAAA,MACpB,MAAA;AAAA,MACA,MAAM,IAAA,CAAK;AAAA,KACb;AAAA,EACF;AAAA,EAEA,kBAAkB,IAAA,EAAgD;AAChE,IAAA,OAAO,IAAA,CAAK,aAAA,CAAc,GAAA,CAAI,IAAI,CAAA;AAAA,EACpC;AAAA,EAEA,cAAc,IAAA,EAAwD;AACpE,IAAA,OAAO,IAAA,CAAK,WAAA,CAAY,GAAA,CAAI,IAAI,CAAA;AAAA,EAClC;AAAA,EAEA,SAAS,IAAA,EAAuB;AAC9B,IAAA,OAAO,IAAA,CAAK,aAAA,CAAc,GAAA,CAAI,IAAI,CAAA;AAAA,EACpC;AAAA,EAEA,sBAAA,CACE,gBAAA,EACA,IAAA,EACA,OAAA,EACS;AACT,IAAA,IAAI,CAAC,SAAS,mBAAA,EAAqB;AACjC,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,MAAM,wBACJ,gBAAA,CAAiB,MAAA,GAAS,CAAA,IAAK,gBAAA,CAAiB,SAAS,GAAG,CAAA;AAE9D,IAAA,OAAO,0BAA0B,IAAA,CAAK,gBAAA;AAAA,EACxC;AAAA,EAEA,gBAAA,CAAiB,QAAqB,QAAA,EAAuC;AAC3E,IAAA,IAAI,aAAa,MAAA,EAAQ;AACvB,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,OAAA,GAAU,iBAAiB,QAAQ,CAAA;AAEzC,IAAA,KAAA,MAAW,OAAO,MAAA,EAAQ;AACxB,MAAA,MAAM,KAAA,GAAQ,OAAO,GAAG,CAAA;AAIxB,MAAA,IAAI,OAAO,KAAA,KAAU,QAAA,IAAY,KAAA,CAAM,QAAA,CAAS,GAAG,CAAA,EAAG;AACpD,QAAA,MAAA,CAAO,GAAG,CAAA,GAAI,OAAA,CAAQ,KAAK,CAAA;AAAA,MAC7B;AAAA,IACF;AAAA,EACF;AAAA,EAEA,yBAAA,CACE,MAAA,EACA,kBAAA,EACA,IAAA,EACS;AACT,IAAA,IAAI;AACF,MAAA,mBAAA,CAAoB,MAAA,EAAQ,oBAAoB,IAAI,CAAA;AAEpD,MAAA,OAAO,IAAA;AAAA,IACT,CAAA,CAAA,MAAQ;AACN,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AAAA,EAEA,mBAAA,CACE,MAAA,EACA,WAAA,EACA,sBAAA,EACA,OAAA,EACS;AACT,IAAA,MAAM,iBAAiB,IAAA,CAAK,iBAAA;AAAA,MAC1B,WAAA;AAAA,MACA,OAAA,EAAS;AAAA,KACX;AACA,IAAA,MAAM,eAAA,GAAkB,SAAS,eAAA,IAAmB,SAAA;AAEpD,IAAA,IAAI,oBAAoB,QAAA,EAAU;AAChC,MAAA,MAAA,CAAO,MAAA,CAAO,QAAQ,cAAc,CAAA;AAEpC,MAAA,OAAO,IAAA;AAAA,IACT;AAGA,IAAA,KAAA,MAAW,GAAA,IAAO,MAAA,CAAO,IAAA,CAAK,cAAc,CAAA,EAAG;AAC7C,MAAA,IAAI,CAAC,sBAAA,CAAuB,GAAA,CAAI,GAAG,CAAA,EAAG;AACpC,QAAA,OAAO,KAAA;AAAA,MACT;AAAA,IACF;AAEA,IAAA,KAAA,MAAW,OAAO,sBAAA,EAAwB;AACxC,MAAA,IAAI,OAAO,cAAA,EAAgB;AACzB,QAAA,MAAA,CAAO,GAAG,CAAA,GAAI,cAAA,CAAe,GAAG,CAAA;AAAA,MAClC;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,aAAA,CACE,IAAA,EACA,UAAA,EACA,QAAA,EACM;AACN,IAAA,QAAA,CAAS,KAAK,IAAI,CAAA;AAGlB,IAAA,MAAM,aAAa,IAAA,CAAK,QAAA;AACxB,IAAA,MAAM,gBAAA,GAAmB,aAAa,EAAA,GAAK,UAAA;AAC3C,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,cAAA,CAAe,gBAAA,EAAkB,KAAK,IAAI,CAAA;AACnE,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,oBAAA,CAAqB,WAAW,CAAA;AACtD,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,uBAAA,CAAwB,QAAQ,CAAA;AAExD,IAAA,IAAI,KAAK,QAAA,EAAU;AACjB,MAAA,MAAM,mBAAA,GAAsB,IAAA,CAAK,2BAAA,CAA4B,QAAQ,CAAA;AACrE,MAAA,MAAM,mBAAmB,QAAA,CAAS,MAAA,GAAS,CAAA,IAAK,QAAA,CAAS,SAAS,GAAG,CAAA;AAGrE,MAAA,MAAM,mBAAmB,QAAA,CAAS,MAAA,CAAO,CAAC,GAAA,KAAQ,GAAA,CAAI,SAAS,EAAE,CAAA;AACjE,MAAA,MAAM,iBAAiB,MAAA,CAAO,MAAA,CAAO,CAAC,GAAG,gBAAgB,CAAC,CAAA;AAG1D,MAAA,MAAM,UAAA,GAAa,IAAA,CAAK,eAAA,CAAgB,gBAAgB,CAAA;AACxD,MAAA,MAAM,mBAAA,GAAsB,aACxB,MAAA,CAAO,MAAA,CAAO,CAAC,GAAG,gBAAA,EAAkB,UAAU,CAAC,CAAA,GAC/C,cAAA;AAGJ,MAAA,MAAM,kBAAA,GACJ,IAAA,CAAK,0BAAA,CAA2B,gBAAgB,CAAA;AAGlD,MAAA,MAAM,OAA2B,EAAC;AAElC,MAAA,KAAA,MAAW,WAAW,mBAAA,EAAqB;AACzC,QAAA,IAAA,CAAK,OAAA,CAAQ,QAAQ,CAAA,GAAI,OAAA,CAAQ,YAAA;AAAA,MACnC;AAEA,MAAA,MAAM,SAAA,GAAuB;AAAA,QAC3B,aAAA,EAAe,mBAAA;AAAA,QACf,QAAA,EAAU,cAAA;AAAA,QACV,mBAAA;AAAA,QACA,gBAAA;AAAA,QACA,cAAA,EAAgB,mBAAmB,IAAA,GAAO,CAAA;AAAA,QAC1C,kBAAA;AAAA,QACA,sBAAA,EAAwB,IAAI,GAAA,CAAI,mBAAmB,CAAA;AAAA,QACnD,IAAA,EAAM,MAAA,CAAO,MAAA,CAAO,IAAI;AAAA,OAC1B;AAEA,MAAA,IAAA,CAAK,aAAA,CAAc,GAAA,CAAI,IAAA,CAAK,QAAA,EAAU,cAAc,CAAA;AACpD,MAAA,IAAA,CAAK,WAAA,CAAY,GAAA,CAAI,IAAA,CAAK,QAAA,EAAU,UAAU,IAAI,CAAA;AAClD,MAAA,QAAA,CAAS,IAAA,CAAK,OAAA,EAAS,KAAA,EAAO,UAAA,EAAY,SAAS,CAAA;AAAA,IACrD;AAGA,IAAA,MAAM,eAAA,GAAkB,WAAA;AAExB,IAAA,KAAA,MAAW,KAAA,IAAS,IAAA,CAAK,QAAA,CAAS,MAAA,EAAO,EAAG;AAC1C,MAAA,IAAA,CAAK,aAAA,CAAc,KAAA,EAAO,eAAA,EAAiB,QAAQ,CAAA;AAAA,IACrD;AAEA,IAAA,QAAA,CAAS,GAAA,EAAI;AAAA,EACf;AAAA,EAEA,4BACE,QAAA,EACmB;AACnB,IAAA,MAAM,cAAwB,EAAC;AAE/B,IAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,MAAA,IAAI,OAAA,CAAQ,SAAA,CAAU,WAAA,CAAY,MAAA,GAAS,CAAA,EAAG;AAC5C,QAAA,WAAA,CAAY,IAAA,CAAK,GAAG,OAAA,CAAQ,SAAA,CAAU,WAAW,CAAA;AAAA,MACnD;AAAA,IACF;AAEA,IAAA,OAAO,WAAA;AAAA,EACT;AAAA,EAEA,2BACE,QAAA,EACwC;AACxC,IAAA,MAAM,QAAA,uBAAe,GAAA,EAA+B;AAEpD,IAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,MAAA,KAAA,MAAW,CAAC,SAAA,EAAW,OAAO,CAAA,IAAK,OAAA,CAAQ,UAAU,kBAAA,EAAoB;AACvE,QAAA,QAAA,CAAS,GAAA,CAAI,WAAW,OAAO,CAAA;AAAA,MACjC;AAAA,IACF;AAEA,IAAA,OAAO,QAAA;AAAA,EACT;AAAA,EAEA,wBAAwB,IAAA,EAAsB;AAC5C,IAAA,IAAI,KAAK,MAAA,GAAS,CAAA,IAAK,IAAA,CAAK,QAAA,CAAS,GAAG,CAAA,EAAG;AACzC,MAAA,OAAO,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA;AAAA,IACzB;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,cAAA,CAAe,YAAoB,QAAA,EAA0B;AAE3D,IAAA,IAAI,eAAe,EAAA,EAAI;AACrB,MAAA,OAAO,QAAA;AAAA,IACT;AAIA,IAAA,IAAI,UAAA,CAAW,UAAA,CAAW,GAAG,CAAA,EAAG;AAC9B,MAAA,IAAI,aAAa,EAAA,EAAI;AACnB,QAAA,OAAO,UAAA;AAAA,MACT;AAEA,MAAA,MAAMC,eAAAA,GAAiB,QAAA,CAAS,OAAA,CAAQ,GAAG,CAAA;AAE3C,MAAA,IAAIA,oBAAmB,EAAA,EAAI;AACzB,QAAA,MAAM,YAAA,GAAe,QAAA,CAAS,KAAA,CAAM,CAAA,EAAGA,eAAc,CAAA;AACrD,QAAA,MAAM,aAAA,GAAgB,QAAA,CAAS,KAAA,CAAMA,eAAAA,GAAiB,CAAC,CAAA;AAEvD,QAAA,OAAO,CAAA,EAAG,YAAY,CAAA,CAAA,EAAI,UAAA,CAAW,MAAM,CAAC,CAAC,IAAI,aAAa,CAAA,CAAA;AAAA,MAChE;AAEA,MAAA,OAAO,CAAA,EAAG,QAAQ,CAAA,EAAG,UAAU,CAAA,CAAA;AAAA,IACjC;AAEA,IAAA,IAAI,aAAa,EAAA,EAAI;AACnB,MAAA,OAAO,UAAA;AAAA,IACT;AAEA,IAAA,MAAM,gBAAA,GAAmB,UAAA,CAAW,OAAA,CAAQ,GAAG,CAAA;AAC/C,IAAA,MAAM,cAAA,GAAiB,QAAA,CAAS,OAAA,CAAQ,GAAG,CAAA;AAE3C,IAAA,IAAI,qBAAqB,EAAA,EAAI;AAC3B,MAAA,MAAM,cAAA,GAAiB,UAAA,CAAW,KAAA,CAAM,CAAA,EAAG,gBAAgB,CAAA;AAC3D,MAAA,MAAM,eAAA,GAAkB,UAAA,CAAW,KAAA,CAAM,gBAAA,GAAmB,CAAC,CAAA;AAE7D,MAAA,IAAI,mBAAmB,EAAA,EAAI;AACzB,QAAA,MAAM,YAAA,GAAe,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,cAAc,CAAA;AACrD,QAAA,MAAM,aAAA,GAAgB,QAAA,CAAS,KAAA,CAAM,cAAA,GAAiB,CAAC,CAAA;AAEvD,QAAA,OAAO,GAAG,cAAc,CAAA,EAAG,YAAY,CAAA,CAAA,EAAI,eAAe,IAAI,aAAa,CAAA,CAAA;AAAA,MAC7E;AAEA,MAAA,OAAO,CAAA,EAAG,cAAc,CAAA,EAAG,QAAQ,IAAI,eAAe,CAAA,CAAA;AAAA,IACxD;AAEA,IAAA,IAAI,mBAAmB,EAAA,EAAI;AACzB,MAAA,MAAM,QAAA,GAAW,QAAA,CAAS,KAAA,CAAM,CAAA,EAAG,cAAc,CAAA;AACjD,MAAA,MAAM,SAAA,GAAY,QAAA,CAAS,KAAA,CAAM,cAAc,CAAA;AAE/C,MAAA,OAAO,aAAa,QAAA,GAAW,SAAA;AAAA,IACjC;AAEA,IAAA,OAAO,UAAA,GAAa,QAAA;AAAA,EACtB;AAAA,EAEA,qBAAqB,IAAA,EAAsB;AACzC,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,OAAA,CAAQ,GAAG,CAAA;AACnC,IAAA,IAAI,WAAW,UAAA,KAAe,EAAA,GAAK,OAAO,IAAA,CAAK,KAAA,CAAM,GAAG,UAAU,CAAA;AAGlE,IAAA,QAAA,GAAW,QAAA,CAAS,UAAA,CAAW,UAAA,EAAY,EAAE,CAAA;AAE7C,IAAA,QAAA,GAAW,QAAA,CAAS,UAAA,CAAW,aAAA,EAAe,OAAO,CAAA;AAErD,IAAA,QAAA,GAAW,QAAA,CAAS,UAAA,CAAW,eAAA,EAAiB,IAAI,CAAA;AAEpD,IAAA,OAAO,QAAA;AAAA,EACT;AAAA,EAEA,iBAAA,CACE,aACA,kBAAA,EACa;AACb,IAAA,OAAO,KAAA,CAAiB,aAAa,kBAAkB,CAAA;AAAA,EACzD;AAAA,EAEA,eAAe,IAAA,EAAuB;AACpC,IAAA,OAAO,mBAAA,CAAoB,KAAK,IAAI,CAAA;AAAA,EACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,gBACE,gBAAA,EACuB;AACvB,IAAA,MAAM,WAAA,GAAc,gBAAA,CAAiB,EAAA,CAAG,EAAE,CAAA;AAG1C,IAAA,IAAI,CAAC,WAAA,EAAa;AAChB,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,OAAO,YAAY,mBAAA,CAAoB,IAAA;AAAA,MACrC,CAAC,UAAU,KAAA,CAAM,IAAA,KAAS,MAAM,WAAA,CAAY,IAAA,CAAK,MAAM,IAAI;AAAA,KAC7D;AAAA,EACF;AACF,CAAA;;;ACnZA,SAASC,kBAAAA,CAAkB,YAAoB,OAAA,EAA4B;AACzE,EAAA,OAAO,IAAI,SAAA,CAAU,CAAA,QAAA,EAAW,UAAU,CAAA,EAAA,EAAK,OAAO,CAAA,CAAE,CAAA;AAC1D;AAoCO,SAAS,iBAAA,CACd,IAAA,EACA,SAAA,EACA,UAAA,EACA,UAAA,EACwB;AAExB,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAE5B,IAAA,IAAI,QAAA;AAEJ,IAAA,IAAI,SAAS,IAAA,EAAM;AACjB,MAAA,QAAA,GAAW,MAAA;AAAA,IACb,CAAA,MAAA,IAAW,KAAA,CAAM,OAAA,CAAQ,IAAI,CAAA,EAAG;AAC9B,MAAA,QAAA,GAAW,OAAA;AAAA,IACb,CAAA,MAAO;AACL,MAAA,QAAA,GAAW,OAAO,IAAA;AAAA,IACpB;AAEA,IAAA,MAAMA,kBAAAA;AAAA,MACJ,UAAA;AAAA,MACA,oCAAoC,QAAQ,CAAA;AAAA,KAC9C;AAAA,EACF;AAGA,EAAA,IAAI,SAAS,EAAA,EAAI;AACf,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,IAAA,CAAK,IAAA,CAAK,IAAI,CAAA,EAAG;AACnB,IAAA,MAAMA,kBAAAA;AAAA,MACJ,UAAA;AAAA,MACA,CAAA,wBAAA,EAA2B,SAAS,CAAA,8BAAA,EAAiC,IAAI,CAAA,CAAA;AAAA,KAC3E;AAAA,EACF;AAGA,EAAA,IAAI,CAAC,iBAAA,CAAkB,IAAA,CAAK,IAAI,CAAA,EAAG;AACjC,IAAA,MAAMA,kBAAAA;AAAA,MACJ,UAAA;AAAA,MACA,CAAA,OAAA,EAAU,SAAS,CAAA,4BAAA,EAA+B,IAAI,CAAA,iEAAA;AAAA,KACxD;AAAA,EACF;AAGA,EAAA,IAAI,IAAA,CAAK,QAAA,CAAS,IAAI,CAAA,EAAG;AACvB,IAAA,MAAMA,kBAAAA;AAAA,MACJ,UAAA;AAAA,MACA,CAAA,wBAAA,EAA2B,SAAS,CAAA,kCAAA,EAAqC,IAAI,CAAA,CAAA;AAAA,KAC/E;AAAA,EACF;AAIA,EAAA,MAAM,YAAA,GACJ,cAAc,MAAA,CAAO,MAAA,CAAO,WAAW,YAAY,CAAA,CAAE,SAAS,KAAK,CAAA;AAErE,EAAA,IAAI,IAAA,CAAK,UAAA,CAAW,GAAG,CAAA,IAAK,YAAA,EAAc;AACxC,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,iBAAA,EAAoB,IAAI,CAAA,uDAAA;AAAA,KAC/C;AAAA,EACF;AACF;;;AC/FA,IAAMC,mBAAAA,GAAqB,yCAAA;AAK3B,IAAMC,mBAAAA,GAAqB,IAAA;AAK3B,IAAMC,sBAAAA,GAAwB,GAAA;AAM9B,SAASC,oBAAmB,KAAA,EAAwB;AAElD,EAAA,IAAI,UAAU,IAAA,EAAM;AAClB,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAE7B,IAAA,IAAI,aAAA,IAAiB,KAAA,IAAS,KAAA,CAAM,WAAA,CAAY,SAAS,QAAA,EAAU;AACjE,MAAA,OAAO,MAAM,WAAA,CAAY,IAAA;AAAA,IAC3B;AAGA,IAAA,OAAO,QAAA;AAAA,EACT;AAGA,EAAA,OAAO,OAAO,KAAA;AAChB;AASA,SAAS,oBAAoB,GAAA,EAAuC;AAClE,EAAA,KAAA,MAAW,GAAA,IAAO,MAAA,CAAO,IAAA,CAAK,GAAG,CAAA,EAAG;AAClC,IAAA,MAAM,UAAA,GAAa,MAAA,CAAO,wBAAA,CAAyB,GAAA,EAAK,GAAG,CAAA;AAE3D,IAAA,IAAI,UAAA,KAAe,UAAA,CAAW,GAAA,IAAO,UAAA,CAAW,GAAA,CAAA,EAAM;AACpD,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT;AAUA,SAAS,iBAAA,CACP,OACA,UAAA,EAC0C;AAC1C,EAAA,IAAI,CAAC,KAAA,IAAS,OAAO,KAAA,KAAU,QAAA,EAAU;AACvC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,+BAAA,EAAkCA,mBAAAA,CAAmB,KAAK,CAAC,CAAA;AAAA,KAClF;AAAA,EACF;AAGA,EAAA,MAAM,KAAA,GAAuB,MAAA,CAAO,cAAA,CAAe,KAAK,CAAA;AAExD,EAAA,IAAI,KAAA,KAAU,MAAA,CAAO,SAAA,IAAa,KAAA,KAAU,IAAA,EAAM;AAChD,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,oCAAA,EAAuCA,mBAAAA,CAAmB,KAAK,CAAC,CAAA;AAAA,KACvF;AAAA,EACF;AAGA,EAAA,IAAI,mBAAA,CAAoB,KAAgC,CAAA,EAAG;AACzD,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,wCAAA;AAAA,KACvB;AAAA,EACF;AACF;AASA,SAAS,oBAAA,CACP,OACA,UAAA,EACM;AACN,EAAA,IACE,MAAM,YAAA,KAAiB,MAAA,IACvB,OAAO,KAAA,CAAM,iBAAiB,UAAA,EAC9B;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,SAAA,EAAY,MAAA,CAAO,KAAA,CAAM,IAAI,CAAC,CAAA,iCAAA;AAAA,KACrD;AAAA,EACF;AACF;AASA,SAAS,oBAAA,CACP,OACA,UAAA,EACM;AACN,EAAA,IACE,MAAM,YAAA,KAAiB,MAAA,IACvB,OAAO,KAAA,CAAM,iBAAiB,UAAA,EAC9B;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,SAAA,EAAY,MAAA,CAAO,KAAA,CAAM,IAAI,CAAC,CAAA,iCAAA;AAAA,KACrD;AAAA,EACF;AACF;AAgBA,SAASC,kBAAAA,CACP,OACA,UAAA,EAC6D;AAC7D,EAAA,IAAI,OAAO,KAAA,CAAM,IAAA,KAAS,QAAA,EAAU;AAClC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,mCAAA,EAAsCD,mBAAAA,CAAmB,KAAA,CAAM,IAAI,CAAC,CAAA;AAAA,KAC3F;AAAA,EACF;AAEA,EAAA,MAAM,OAAO,KAAA,CAAM,IAAA;AAGnB,EAAA,IAAI,SAAS,EAAA,EAAI;AACf,IAAA,MAAM,IAAI,SAAA,CAAU,CAAA,QAAA,EAAW,UAAU,CAAA,4BAAA,CAA8B,CAAA;AAAA,EACzE;AAGA,EAAA,IAAI,CAACF,mBAAAA,CAAmB,IAAA,CAAK,IAAI,CAAA,EAAG;AAClC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,WAAW,UAAU,CAAA,2CAAA;AAAA,KACvB;AAAA,EACF;AAGA,EAAA,IAAI,IAAA,CAAK,SAASC,sBAAAA,EAAuB;AACvC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,uCAAA,EAA0CA,sBAAqB,CAAA,WAAA;AAAA,KACtF;AAAA,EACF;AAGA,EAAA,IAAI,IAAA,CAAK,UAAA,CAAW,IAAI,CAAA,EAAG;AACzB,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,CAACF,mBAAAA,CAAmB,IAAA,CAAK,IAAI,CAAA,EAAG;AAClC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,sBAAA,EAAyB,IAAI,CAAA,sKAAA;AAAA,KAIpD;AAAA,EACF;AACF;AAUA,SAAS,sBAAA,CACP,QAAA,EACA,QAAA,EACA,UAAA,EACM;AAEN,EAAA,MAAM,QAAA,GAAW,QAAA,CAAS,KAAA,CAAM,GAAG,CAAA;AACnC,EAAA,IAAI,OAAA,GAAiC,QAAA;AAErC,EAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,IAAA,OAAA,GAAU,OAAA,CAAQ,QAAA,CAAS,GAAA,CAAI,OAAO,CAAA;AAEtC,IAAA,IAAI,CAAC,OAAA,EAAS;AACZ,MAAA;AAAA,IACF;AAAA,EACF;AAEA,EAAA,MAAM,IAAI,KAAA,CAAM,CAAA,QAAA,EAAW,UAAU,CAAA,SAAA,EAAY,QAAQ,CAAA,gBAAA,CAAkB,CAAA;AAC7E;AAUA,SAAS,uBAAA,CACP,SAAA,EACA,QAAA,EACA,UAAA,EACM;AACN,EAAA,IAAI,SAAA,CAAU,GAAA,CAAI,QAAQ,CAAA,EAAG;AAC3B,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,mBAAA,EAAsB,QAAQ,CAAA,UAAA;AAAA,KACrD;AAAA,EACF;AAEA,EAAA,SAAA,CAAU,IAAI,QAAQ,CAAA;AACxB;AAUA,SAAS,sBAAA,CACP,QAAA,EACA,UAAA,EACA,SAAA,EACM;AAEN,EAAA,IAAI,UAAA,GAAoC,QAAA;AAExC,EAAA,IAAI,eAAe,EAAA,EAAI;AACrB,IAAA,MAAM,QAAA,GAAW,UAAA,CAAW,KAAA,CAAM,GAAG,CAAA;AAErC,IAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,MAAA,UAAA,GAAa,UAAA,CAAW,QAAA,CAAS,GAAA,CAAI,OAAO,CAAA;AAE5C,MAAA,IAAI,CAAC,UAAA,EAAY;AACf,QAAA;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAEA,EAAA,KAAA,MAAW,KAAA,IAAS,UAAA,CAAW,QAAA,CAAS,MAAA,EAAO,EAAG;AAChD,IAAA,IAAI,KAAA,CAAM,SAAS,SAAA,EAAW;AAC5B,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,MAAA,EAAS,SAAS,CAAA,oBAAA,CAAsB,CAAA;AAAA,IAC1D;AAAA,EACF;AACF;AAeA,SAAS,iBAAA,CACP,QAAA,EACA,SAAA,EACA,UAAA,EACA,SAAA,EACM;AACN,EAAA,MAAM,KAAA,GAAQ,SAAA,CAAU,KAAA,CAAM,GAAG,CAAA;AAEjC,EAAA,KAAA,CAAM,GAAA,EAAI;AAEV,EAAA,MAAM,UAAA,GAAa,KAAA,CAAM,IAAA,CAAK,GAAG,CAAA;AAGjC,EAAA,IAAI,SAAA,EAAW,GAAA,CAAI,UAAU,CAAA,EAAG;AAC9B,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,QAAA,EAAU;AACZ,IAAA,MAAM,QAAA,GAAW,UAAA,CAAW,KAAA,CAAM,GAAG,CAAA;AACrC,IAAA,IAAI,OAAA,GAAiC,QAAA;AAErC,IAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,MAAA,OAAA,GAAU,OAAA,CAAQ,QAAA,CAAS,GAAA,CAAI,OAAO,CAAA;AAEtC,MAAA,IAAI,CAAC,OAAA,EAAS;AACZ,QAAA,MAAM,IAAI,KAAA;AAAA,UACR,CAAA,QAAA,EAAW,UAAU,CAAA,gBAAA,EAAmB,UAAU,+BAA+B,SAAS,CAAA,CAAA;AAAA,SAC5F;AAAA,MACF;AAAA,IACF;AAEA,IAAA;AAAA,EACF;AAGA,EAAA,MAAM,IAAI,KAAA;AAAA,IACR,CAAA,QAAA,EAAW,UAAU,CAAA,gBAAA,EAAmB,UAAU,+BAA+B,SAAS,CAAA,CAAA;AAAA,GAC5F;AACF;AAUA,SAAS,uBAAA,CACP,iBAAA,EACA,UAAA,EACA,SAAA,EACM;AACN,EAAA,MAAM,YAAA,GAAe,iBAAA,CAAkB,GAAA,CAAI,UAAU,CAAA;AAErD,EAAA,IAAI,YAAA,EAAc,GAAA,CAAI,SAAS,CAAA,EAAG;AAChC,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,MAAA,EAAS,SAAS,CAAA,oBAAA,CAAsB,CAAA;AAAA,EAC1D;AAEA,EAAA,IAAI,YAAA,EAAc;AAChB,IAAA,YAAA,CAAa,IAAI,SAAS,CAAA;AAAA,EAC5B,CAAA,MAAO;AACL,IAAA,iBAAA,CAAkB,IAAI,UAAA,kBAAY,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAA;AAAA,EACxD;AACF;AAkCO,SAAS,cACd,KAAA,EACA,UAAA,EACA,UACA,UAAA,GAAa,EAAA,EACb,WACA,iBAAA,EACkC;AAClC,EAAA,iBAAA,CAAkB,OAAO,UAAU,CAAA;AAEnC,EAAA,MAAM,CAAA,GAAI,KAAA;AAGV,EAAAI,kBAAAA,CAAkB,GAAG,UAAU,CAAA;AAG/B,EAAA,iBAAA,CAAkB,CAAA,CAAE,IAAA,EAAM,CAAA,CAAE,IAAA,EAAM,YAAY,QAAQ,CAAA;AAGtD,EAAA,oBAAA,CAAqB,GAAG,UAAU,CAAA;AAClC,EAAA,oBAAA,CAAqB,GAAG,UAAU,CAAA;AAElC,EAAA,MAAM,YAAY,CAAA,CAAE,IAAA;AACpB,EAAA,MAAM,WAAW,UAAA,GAAa,CAAA,EAAG,UAAU,CAAA,CAAA,EAAI,SAAS,CAAA,CAAA,GAAK,SAAA;AAI7D,EAAA,IAAI,CAAC,UAAA,IAAc,QAAA,CAAS,QAAA,CAAS,GAAG,CAAA,EAAG;AACzC,IAAA,iBAAA,CAAkB,QAAA,EAAU,QAAA,EAAU,UAAA,EAAY,SAAS,CAAA;AAAA,EAC7D;AAGA,EAAA,IAAI,YAAY,QAAA,EAAU;AACxB,IAAA,sBAAA,CAAuB,QAAA,EAAU,UAAU,UAAU,CAAA;AAAA,EACvD;AAGA,EAAA,IAAI,SAAA,EAAW;AACb,IAAA,uBAAA,CAAwB,SAAA,EAAW,UAAU,UAAU,CAAA;AAAA,EACzD;AAEA,EAAA,MAAM,YAAY,CAAA,CAAE,IAAA;AAKpB,EAAA,IAAI,eAAA,GAAkB,UAAA;AAEtB,EAAA,IAAI,SAAA,CAAU,QAAA,CAAS,GAAG,CAAA,IAAK,CAAC,UAAA,EAAY;AAC1C,IAAA,MAAM,KAAA,GAAQ,SAAA,CAAU,KAAA,CAAM,GAAG,CAAA;AAEjC,IAAA,KAAA,CAAM,GAAA,EAAI;AAEV,IAAA,eAAA,GAAkB,KAAA,CAAM,KAAK,GAAG,CAAA;AAAA,EAClC;AAGA,EAAA,IAAI,QAAA,EAAU;AACZ,IAAA,sBAAA,CAAuB,QAAA,EAAU,iBAAiB,SAAS,CAAA;AAAA,EAC7D;AAGA,EAAA,IAAI,iBAAA,EAAmB;AACrB,IAAA,uBAAA,CAAwB,iBAAA,EAAmB,iBAAiB,SAAS,CAAA;AAAA,EACvE;AAGA,EAAA,IAAI,CAAA,CAAE,aAAa,MAAA,EAAW;AAC5B,IAAA,IAAI,CAAC,KAAA,CAAM,OAAA,CAAQ,CAAA,CAAE,QAAQ,CAAA,EAAG;AAC9B,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,QAAA,EAAW,UAAU,CAAA,SAAA,EAAY,SAAS,oCAAoCD,mBAAAA,CAAmB,CAAA,CAAE,QAAQ,CAAC,CAAA;AAAA,OAC9G;AAAA,IACF;AAEA,IAAA,KAAA,MAAW,KAAA,IAAS,EAAE,QAAA,EAAU;AAC9B,MAAA,aAAA;AAAA,QACE,KAAA;AAAA,QACA,UAAA;AAAA,QACA,QAAA;AAAA,QACA,QAAA;AAAA,QACA,SAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAAA,EACF;AACF;;;ACzeO,IAAM,kBAAA,GAAqB,EAAA;AAQ3B,IAAM,mBAAA,uBAA0B,GAAA,EAAY;;;ACE5C,SAAS,iBAAA,GAAiC;AAC/C,EAAA,OAAO;AAAA,IACL,QAAA,kBAAU,MAAA,CAAO,MAAA,CAAO,IAAI,CAAA;AAAA,IAC5B,QAAA,kBAAU,MAAA,CAAO,MAAA,CAAO,IAAI,CAAA;AAAA,IAC5B,aAAA,kBAAe,MAAA,CAAO,MAAA,CAAO,IAAI,CAAA;AAAA,IACjC,UAAA,kBAAY,MAAA,CAAO,MAAA,CAAO,IAAI;AAAA,GAChC;AACF;AAKO,SAAS,mBAAmB,OAAA,EAAgC;AACjE,EAAA,OAAO;AAAA,IACL,GAAG,mBAAmB,OAAO,CAAA;AAAA,IAC7B,mBAAA,EAAqB,QAAQ,aAAA,KAAkB,QAAA;AAAA,IAC/C,cAAA,EAAgB;AAAA,GAClB;AACF;AAUO,SAAS,WAAA,CAAY,QAAgB,MAAA,EAAyB;AACnE,EAAA,KAAA,MAAW,OAAO,MAAA,EAAQ;AACxB,IAAA,IAAI,MAAA,CAAO,GAAG,CAAA,KAAM,MAAA,CAAO,GAAG,CAAA,EAAG;AAC/B,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;AAKO,SAAS,oBAAA,CACd,MAAA,EACA,MAAA,EACA,QAAA,EACS;AACT,EAAA,KAAA,MAAW,OAAO,MAAA,EAAQ;AACxB,IAAA,IAAI,OAAO,QAAA,EAAU;AACnB,MAAA;AAAA,IACF;AACA,IAAA,IAAI,MAAA,CAAO,GAAG,CAAA,KAAM,MAAA,CAAO,GAAG,CAAA,EAAG;AAC/B,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;AAKO,SAAS,cACd,KAAA,EACiB;AACjB,EAAA,MAAM,SAAA,GAA6B;AAAA,IACjC,MAAM,KAAA,CAAM,IAAA;AAAA,IACZ,MAAM,KAAA,CAAM;AAAA,GACd;AAEA,EAAA,IAAI,MAAM,QAAA,EAAU;AAClB,IAAA,SAAA,CAAU,QAAA,GAAW,MAAM,QAAA,CAAS,GAAA,CAAI,CAAC,KAAA,KAAU,aAAA,CAAc,KAAK,CAAC,CAAA;AAAA,EACzE;AAEA,EAAA,OAAO,SAAA;AACT;AAKO,SAAS,qBAAA,CACd,WAAA,EACA,SAAA,EACA,YAAA,GAAe,EAAA,EACN;AACT,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,WAAA,CAAY,QAAQ,CAAA,EAAA,EAAK;AAC3C,IAAA,MAAM,KAAA,GAAQ,YAAY,CAAC,CAAA;AAC3B,IAAA,MAAM,QAAA,GAAW,eACb,CAAA,EAAG,YAAY,IAAI,KAAA,CAAM,IAAI,KAC7B,KAAA,CAAM,IAAA;AAEV,IAAA,IAAI,aAAa,SAAA,EAAW;AAC1B,MAAA,WAAA,CAAY,MAAA,CAAO,GAAG,CAAC,CAAA;AAEvB,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,IACE,KAAA,CAAM,QAAA,IACN,SAAA,CAAU,UAAA,CAAW,CAAA,EAAG,QAAQ,CAAA,CAAA,CAAG,CAAA,IACnC,qBAAA,CAAsB,KAAA,CAAM,QAAA,EAAU,SAAA,EAAW,QAAQ,CAAA,EACzD;AACA,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT;AAKO,SAAS,kBAAA,CACd,QACA,OAAA,EACM;AACN,EAAA,KAAA,MAAW,GAAA,IAAO,MAAA,CAAO,IAAA,CAAK,MAAM,CAAA,EAAG;AACrC,IAAA,IAAI,OAAA,CAAQ,GAAG,CAAA,EAAG;AAChB,MAAA,OAAO,OAAO,GAAG,CAAA;AAAA,IACnB;AAAA,EACF;AACF;AAgBO,SAAS,uBAAA,CAEd,OAA4B,QAAA,EAAwB;AAEpD,EAAA,IACE,MAAM,WAAA,KAAgB,MAAA,IACtB,OAAO,KAAA,CAAM,gBAAgB,UAAA,EAC7B;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,+DAA+D,QAAQ,CAAA,OAAA,EAC9D,kBAAA,CAAmB,KAAA,CAAM,WAAW,CAAC,CAAA;AAAA,KAChD;AAAA,EACF;AAGA,EAAA,IACE,MAAM,aAAA,KAAkB,MAAA,IACxB,OAAO,KAAA,CAAM,kBAAkB,UAAA,EAC/B;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,iEAAiE,QAAQ,CAAA,OAAA,EAChE,kBAAA,CAAmB,KAAA,CAAM,aAAa,CAAC,CAAA;AAAA,KAClD;AAAA,EACF;AAIA,EAAA,IAAI,KAAA,CAAM,kBAAkB,MAAA,EAAW;AACrC,IAAA,MAAM,SAAkB,KAAA,CAAM,aAAA;AAE9B,IAAA,IACE,MAAA,KAAW,QACX,OAAO,MAAA,KAAW,YAClB,KAAA,CAAM,OAAA,CAAQ,MAAM,CAAA,EACpB;AACA,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,gEAAgE,QAAQ,CAAA,OAAA,EAC/D,kBAAA,CAAmB,KAAA,CAAM,aAAa,CAAC,CAAA;AAAA,OAClD;AAAA,IACF;AAAA,EACF;AAGA,EAAA,IAAI,KAAA,CAAM,YAAA,EAAc,WAAA,CAAY,IAAA,KAAS,eAAA,EAAiB;AAC5D,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,6DAA6D,QAAQ,CAAA,6CAAA;AAAA,KACvE;AAAA,EACF;AAGA,EAAA,IAAI,KAAA,CAAM,YAAA,EAAc,WAAA,CAAY,IAAA,KAAS,eAAA,EAAiB;AAC5D,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,6DAA6D,QAAQ,CAAA,6CAAA;AAAA,KACvE;AAAA,EACF;AAGA,EAAA,IAAI,MAAM,QAAA,EAAU;AAClB,IAAA,KAAA,MAAW,KAAA,IAAS,MAAM,QAAA,EAAU;AAClC,MAAA,MAAM,aAAA,GAAgB,CAAA,EAAG,QAAQ,CAAA,CAAA,EAAI,MAAM,IAAI,CAAA,CAAA;AAE/C,MAAA,uBAAA,CAAwB,OAAO,aAAa,CAAA;AAAA,IAC9C;AAAA,EACF;AACF;AAUA,SAAS,sBAAsB,IAAA,EAA2B;AACxD,EAAA,MAAM,MAAA,uBAAa,GAAA,EAAY;AAC/B,EAAA,MAAM,UAAA,GAAa,qBAAA;AACnB,EAAA,IAAI,KAAA;AAEJ,EAAA,OAAA,CAAQ,KAAA,GAAQ,UAAA,CAAW,IAAA,CAAK,IAAI,OAAO,IAAA,EAAM;AAC/C,IAAA,MAAA,CAAO,GAAA,CAAI,KAAA,CAAM,CAAC,CAAC,CAAA;AAAA,EACrB;AAEA,EAAA,OAAO,MAAA;AACT;AAKA,SAAS,uBAAuB,KAAA,EAAuC;AACrE,EAAA,MAAM,MAAA,uBAAa,GAAA,EAAY;AAE/B,EAAA,KAAA,MAAW,QAAQ,KAAA,EAAO;AACxB,IAAA,KAAA,MAAW,KAAA,IAAS,qBAAA,CAAsB,IAAI,CAAA,EAAG;AAC/C,MAAA,MAAA,CAAO,IAAI,KAAK,CAAA;AAAA,IAClB;AAAA,EACF;AAEA,EAAA,OAAO,MAAA;AACT;AAMA,SAAS,oBACP,MAAA,EACA,SAAA,EACA,aAAa,EAAA,EACb,KAAA,GAAkB,EAAC,EACT;AACV,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,IAAA,MAAM,QAAA,GAAW,aAAa,CAAA,EAAG,UAAU,IAAI,KAAA,CAAM,IAAI,KAAK,KAAA,CAAM,IAAA;AACpE,IAAA,MAAM,YAAA,GAAe,CAAC,GAAG,KAAA,EAAO,MAAM,IAAI,CAAA;AAE1C,IAAA,IAAI,aAAa,SAAA,EAAW;AAC1B,MAAA,OAAO,YAAA;AAAA,IACT;AAEA,IAAA,IAAI,MAAM,QAAA,IAAY,SAAA,CAAU,WAAW,CAAA,EAAG,QAAQ,GAAG,CAAA,EAAG;AAC1D,MAAA,OAAO,mBAAA;AAAA,QACL,KAAA,CAAM,QAAA;AAAA,QACN,SAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAAA,EACF;AAGA,EAAA,MAAM,IAAI,KAAA;AAAA,IACR,0CAA0C,SAAS,CAAA,WAAA;AAAA,GACrD;AACF;AAKA,SAAS,iBAAA,CACP,MAAA,EACA,UAAA,GAAa,EAAA,EACA;AACb,EAAA,MAAM,KAAA,uBAAY,GAAA,EAAY;AAE9B,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,IAAA,MAAM,QAAA,GAAW,aAAa,CAAA,EAAG,UAAU,IAAI,KAAA,CAAM,IAAI,KAAK,KAAA,CAAM,IAAA;AAEpE,IAAA,KAAA,CAAM,IAAI,QAAQ,CAAA;AAElB,IAAA,IAAI,MAAM,QAAA,EAAU;AAClB,MAAA,KAAA,MAAW,SAAA,IAAa,iBAAA,CAAkB,KAAA,CAAM,QAAA,EAAU,QAAQ,CAAA,EAAG;AACnE,QAAA,KAAA,CAAM,IAAI,SAAS,CAAA;AAAA,MACrB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,KAAA;AACT;AAKA,SAAS,sBAAA,CACP,MAAA,EACA,UAAA,GAAa,EAAA,EACQ;AACrB,EAAA,MAAM,QAAA,uBAAe,GAAA,EAAoB;AAEzC,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,IAAA,MAAM,QAAA,GAAW,aAAa,CAAA,EAAG,UAAU,IAAI,KAAA,CAAM,IAAI,KAAK,KAAA,CAAM,IAAA;AAEpE,IAAA,IAAI,MAAM,SAAA,EAAW;AACnB,MAAA,QAAA,CAAS,GAAA,CAAI,QAAA,EAAU,KAAA,CAAM,SAAS,CAAA;AAAA,IACxC;AAEA,IAAA,IAAI,MAAM,QAAA,EAAU;AAClB,MAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,CAAA,IAAK,sBAAA;AAAA,QACzB,KAAA,CAAM,QAAA;AAAA,QACN;AAAA,OACF,EAAG;AACD,QAAA,QAAA,CAAS,GAAA,CAAI,KAAK,KAAK,CAAA;AAAA,MACzB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,QAAA;AACT;AAKA,SAAS,kBAAkB,QAAA,EAA6C;AACtE,EAAA,MAAM,MAAA,uBAAa,GAAA,EAAY;AAE/B,EAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAE9B,IAAA,KAAA,MAAW,KAAA,IAAS,OAAA,CAAQ,SAAA,CAAU,SAAA,EAAW;AAC/C,MAAA,MAAA,CAAO,IAAI,KAAK,CAAA;AAAA,IAClB;AAEA,IAAA,KAAA,MAAW,KAAA,IAAS,OAAA,CAAQ,SAAA,CAAU,UAAA,EAAY;AAChD,MAAA,MAAA,CAAO,IAAI,KAAK,CAAA;AAAA,IAClB;AAAA,EACF;AAEA,EAAA,OAAO,MAAA;AACT;AAKA,SAAS,iBAAA,CAAkB,MAAiB,SAAA,EAA4B;AACtE,EAAA,MAAM,QAAA,GAAW,SAAA,CAAU,KAAA,CAAM,GAAG,CAAA;AACpC,EAAA,IAAI,OAAA,GAAiC,IAAA;AAErC,EAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAC9B,IAAA,OAAA,GAAU,OAAA,CAAQ,QAAA,CAAS,GAAA,CAAI,OAAO,CAAA;AAEtC,IAAA,IAAI,CAAC,OAAA,EAAS;AACZ,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;AAKA,SAAS,eAAA,CACP,WAAA,EACA,YAAA,EACA,IAAA,EACA,MAAA,EACa;AACb,EAAA,IAAI,YAAA,EAAc;AAChB,IAAA,MAAM,UAAA,GAAa,iBAAA,CAAkB,IAAA,EAAM,WAAW,CAAA;AAItD,IAAA,OAAO,kBAAkB,UAAW,CAAA;AAAA,EACtC;AAGA,EAAA,OAAO,sBAAA,CAAuB,mBAAA,CAAoB,MAAA,EAAQ,WAAW,CAAC,CAAA;AACxE;AAKA,SAAS,qBAAA,CACP,SAAA,EACA,WAAA,EACA,MAAA,EACA,YACA,IAAA,EACM;AACN,EAAA,MAAM,YAAA,GAAe,iBAAA,CAAkB,IAAA,EAAM,WAAW,CAAA;AACxD,EAAA,MAAM,aAAA,GAAgB,UAAA,CAAW,GAAA,CAAI,WAAW,CAAA;AAEhD,EAAA,IAAI,CAAC,YAAA,IAAgB,CAAC,aAAA,EAAe;AACnC,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,oCAAA,EAAuC,WAAW,CAAA,4BAAA,EAClC,SAAS,CAAA,CAAA;AAAA,KAC3B;AAAA,EACF;AAGA,EAAA,MAAM,UAAA,GAAa,sBAAA;AAAA,IACjB,mBAAA,CAAoB,QAAQ,SAAS;AAAA,GACvC;AAGA,EAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,WAAA,EAAa,YAAA,EAAc,MAAM,MAAM,CAAA;AAGxE,EAAA,MAAM,aAAA,GAAgB,CAAC,GAAG,QAAQ,CAAA,CAAE,MAAA,CAAO,CAAC,CAAA,KAAM,CAAC,UAAA,CAAW,GAAA,CAAI,CAAC,CAAC,CAAA;AAEpE,EAAA,IAAI,aAAA,CAAc,SAAS,CAAA,EAAG;AAC5B,IAAA,MAAM,IAAI,KAAA;AAAA,MACR,CAAA,oCAAA,EAAuC,WAAW,CAAA,mBAAA,EAC5C,aAAA,CAAc,KAAK,IAAI,CAAC,6CAA6C,SAAS,CAAA,CAAA;AAAA,KACtF;AAAA,EACF;AACF;AAMO,SAAS,mBAAA,CACd,UAAA,EACA,UAAA,EACA,QAAA,GAAW,GAAA,EACH;AACR,EAAA,MAAM,OAAA,uBAAc,GAAA,EAAY;AAChC,EAAA,MAAM,KAAA,GAAkB,CAAC,UAAU,CAAA;AACnC,EAAA,IAAI,OAAA,GAAU,UAAA;AAEd,EAAA,OAAO,UAAA,CAAW,OAAO,CAAA,EAAG;AAC1B,IAAA,MAAM,IAAA,GAAO,WAAW,OAAO,CAAA;AAE/B,IAAA,IAAI,OAAA,CAAQ,GAAA,CAAI,IAAI,CAAA,EAAG;AACrB,MAAA,MAAM,UAAA,GAAa,KAAA,CAAM,OAAA,CAAQ,IAAI,CAAA;AACrC,MAAA,MAAM,QAAQ,CAAC,GAAG,MAAM,KAAA,CAAM,UAAU,GAAG,IAAI,CAAA;AAE/C,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,oBAAA,EAAuB,MAAM,IAAA,CAAK,UAAK,CAAC,CAAA,CAAE,CAAA;AAAA,IAC5D;AAEA,IAAA,OAAA,CAAQ,IAAI,OAAO,CAAA;AACnB,IAAA,KAAA,CAAM,KAAK,IAAI,CAAA;AACf,IAAA,OAAA,GAAU,IAAA;AAEV,IAAA,IAAI,KAAA,CAAM,SAAS,QAAA,EAAU;AAC3B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,0CAA0C,QAAQ,CAAA,GAAA,EAAM,KAAA,CAAM,IAAA,CAAK,UAAK,CAAC,CAAA;AAAA,OAC3E;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,OAAA;AACT;AAaO,SAAS,wBAAA,CAGd,MAAA,EACA,kBAAA,EACA,IAAA,EACM;AACN,EAAA,MAAM,UAAA,GAAa,kBAAkB,MAAM,CAAA;AAC3C,EAAA,MAAM,aAAA,GAAgB,uBAAuB,MAAM,CAAA;AAGnD,EAAA,MAAM,kBAAA,GAA6C,EAAE,GAAG,kBAAA,EAAmB;AAE3E,EAAA,KAAA,MAAW,CAAC,IAAA,EAAM,EAAE,CAAA,IAAK,aAAA,EAAe;AACtC,IAAA,kBAAA,CAAmB,IAAI,CAAA,GAAI,EAAA;AAAA,EAC7B;AAGA,EAAA,KAAA,MAAW,CAAC,SAAA,EAAW,WAAW,CAAA,IAAK,aAAA,EAAe;AACpD,IAAA,qBAAA,CAAsB,SAAA,EAAW,WAAA,EAAa,MAAA,EAAQ,UAAA,EAAY,IAAI,CAAA;AAAA,EACxE;AAGA,EAAA,KAAA,MAAW,SAAA,IAAa,MAAA,CAAO,IAAA,CAAK,kBAAkB,CAAA,EAAG;AACvD,IAAA,mBAAA,CAAoB,WAAW,kBAAkB,CAAA;AAAA,EACnD;AACF;;;ACheO,SAAS,sBAAsB,QAAA,EAAwC;AAC5E,EAAA,OAAO,QAAA,CAAS,EAAA,CAAG,EAAE,CAAA,EAAG,QAAA,IAAY,EAAA;AACtC;AAqBO,SAAS,gBAAA,CACd,aACA,IAAA,EACmB;AACnB,EAAA,MAAM,YAAA,GAAe,IAAA,IAAQ,qBAAA,CAAsB,WAAA,CAAY,QAAQ,CAAA;AAEvE,EAAA,OAAO;AAAA,IACL,IAAA,EAAM,YAAA;AAAA,IACN,QAAQ,WAAA,CAAY,MAAA;AAAA,IACpB,MAAM,WAAA,CAAY;AAAA,GACpB;AACF;;;ACvCO,SAAS,wBAAwB,IAAA,EAAuC;AAC7E,EAAA,iBAAA,CAAkB,MAAM,aAAa,CAAA;AACvC;AAKO,SAAS,wBACd,QAAA,EAC4B;AAC5B,EAAA,IAAI,OAAO,aAAa,QAAA,EAAU;AAChC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,oDAAA,EAAuD,kBAAA,CAAmB,QAAQ,CAAC,CAAA;AAAA,KACrF;AAAA,EACF;AACF;AAOO,SAAS,qBAAqB,MAAA,EAAqC;AACxE,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAI1B,IAAA,IAAI,KAAA,KAAU,QAAQ,OAAO,KAAA,KAAU,YAAY,KAAA,CAAM,OAAA,CAAQ,KAAK,CAAA,EAAG;AACvE,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,+CAAA,EAAkD,kBAAA,CAAmB,KAAK,CAAC,CAAA;AAAA,OAC7E;AAAA,IACF;AAIA,IAAA,uBAAA,CAAwB,KAAA,EAAO,MAAM,IAAI,CAAA;AAAA,EAC3C;AACF;AAKO,SAAS,yBAAA,CACd,IAAA,EACA,MAAA,EACA,cAAA,EACA,iBAAA,EACM;AAEN,EAAA,IAAI,CAAC,QAAA,CAAS,IAAI,CAAA,EAAG;AACnB,IAAA,MAAM,IAAI,UAAU,CAAA,2BAAA,CAA6B,CAAA;AAAA,EACnD;AAGA,EAAA,IAAI,MAAA,KAAW,MAAA,IAAa,CAAC,QAAA,CAAS,MAAM,CAAA,EAAG;AAC7C,IAAA,MAAM,IAAI,UAAU,CAAA,+CAAA,CAAiD,CAAA;AAAA,EACvE;AAGA,EAAA,IAAI,cAAA,KAAmB,MAAA,IAAa,OAAO,cAAA,KAAmB,SAAA,EAAW;AACvE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,6DAAA,EAAgE,OAAO,cAAc,CAAA;AAAA,KACvF;AAAA,EACF;AAGA,EAAA,IACE,iBAAA,KAAsB,MAAA,IACtB,OAAO,iBAAA,KAAsB,SAAA,EAC7B;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,gEAAA,EAAmE,OAAO,iBAAiB,CAAA;AAAA,KAC7F;AAAA,EACF;AACF;AAKO,SAAS,wBAAA,CACd,SAAA,EACA,WAAA,EACA,UAAA,EACM;AACN,EAAA,IAAI,CAAC,QAAA,CAAS,SAAS,CAAA,EAAG;AACxB,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,qBAAA,EAAwB,kBAAA,CAAmB,SAAS,CAAC,CAAA,kBAAA;AAAA,KAC5E;AAAA,EACF;AAEA,EAAA,IAAI,CAAC,QAAA,CAAS,WAAW,CAAA,EAAG;AAC1B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,uBAAA,EAA0B,kBAAA,CAAmB,WAAW,CAAC,CAAA,wBAAA;AAAA,KAChF;AAAA,EACF;AACF;AAMO,SAAS,4BAAA,CAGd,MACA,OAAA,EACoD;AAEpD,EAAA,iBAAA,CAAkB,MAAM,aAAa,CAAA;AAErC,EAAA,IAAI,SAAS,EAAA,EAAI;AACf,IAAA,MAAM,IAAI,cAAA;AAAA,MACR,CAAA,yEAAA;AAAA,KACF;AAAA,EACF;AAIA,EAAA,IAAI,YAAY,IAAA,EAAM;AACpB,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,8DAAA;AAAA,KACF;AAAA,EACF;AAGA,EAAA,IAAI,OAAO,OAAA,KAAY,QAAA,IAAY,KAAA,CAAM,OAAA,CAAQ,OAAO,CAAA,EAAG;AACzD,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,0DAAA,EAA6D,kBAAA,CAAmB,OAAO,CAAC,CAAA;AAAA,KAC1F;AAAA,EACF;AACF;AAOO,SAAS,gCAAA,CACd,SAAA,EACA,aAAA,EACA,YAAA,EACA,YAAA,EACM;AAEN,EAAA,IAAI,cAAc,MAAA,IAAa,SAAA,KAAc,QAAQ,CAAC,QAAA,CAAS,SAAS,CAAA,EAAG;AACzE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,mEAAA,EAAsE,kBAAA,CAAmB,SAAS,CAAC,CAAA;AAAA,KACrG;AAAA,EACF;AAGA,EAAA,IACE,aAAA,KAAkB,MAAA,IAClB,aAAA,KAAkB,IAAA,KACjB,OAAO,kBAAkB,QAAA,IAAY,KAAA,CAAM,OAAA,CAAQ,aAAa,CAAA,CAAA,EACjE;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,wEAAA,EAA2E,kBAAA,CAAmB,aAAa,CAAC,CAAA;AAAA,KAC9G;AAAA,EACF;AAGA,EAAA,IAAI,YAAA,KAAiB,MAAA,IAAa,YAAA,KAAiB,IAAA,EAAM;AACvD,IAAA,IAAI,OAAO,iBAAiB,UAAA,EAAY;AACtC,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,wEAAA,EAA2E,OAAO,YAAY,CAAA;AAAA,OAChG;AAAA,IACF;AAGA,IAAA,IACG,YAAA,CAAmD,YAAY,IAAA,KAC9D,eAAA,IACD,aACE,QAAA,EAAS,CACT,QAAA,CAAS,WAAW,CAAA,EACvB;AACA,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,mEAAA;AAAA,OACF;AAAA,IACF;AAAA,EACF;AAGA,EAAA,IAAI,YAAA,KAAiB,MAAA,IAAa,YAAA,KAAiB,IAAA,EAAM;AACvD,IAAA,IAAI,OAAO,iBAAiB,UAAA,EAAY;AACtC,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,wEAAA,EAA2E,OAAO,YAAY,CAAA;AAAA,OAChG;AAAA,IACF;AAGA,IAAA,IACG,YAAA,CAAmD,YAAY,IAAA,KAC9D,eAAA,IACD,aACE,QAAA,EAAS,CACT,QAAA,CAAS,WAAW,CAAA,EACvB;AACA,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,mEAAA;AAAA,OACF;AAAA,IACF;AAAA,EACF;AACF;AAKO,SAAS,sBAAsB,KAAA,EAAyC;AAC7E,EAAA,IAAI,CAAC,QAAA,CAAS,KAAK,CAAA,IAAK,UAAU,EAAA,EAAI;AACpC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,kEAAkE,OAAO,KAAA,KAAU,QAAA,GAAW,IAAA,GAAO,OAAO,KAAK,CAAA;AAAA,KACnH;AAAA,EACF;AACF;AAKO,SAAS,sBAAsB,IAAA,EAAuC;AAC3E,EAAA,IAAI,CAAC,QAAA,CAAS,IAAI,CAAA,EAAG;AACnB,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,oDAAA,EAAuD,OAAO,IAAI,CAAA;AAAA,KACpE;AAAA,EACF;AACF;AAKO,SAAS,6BACd,QAAA,EAC4B;AAC5B,EAAA,IAAI,CAAC,QAAA,CAAS,QAAQ,CAAA,EAAG;AACvB,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,yDAAA,EAA4D,OAAO,QAAQ,CAAA;AAAA,KAC7E;AAAA,EACF;AACF;AAUO,SAAS,cAAA,CACd,MAAA,EACA,IAAA,EACA,UAAA,EACM;AAEN,EAAA,MAAM,SAAA,uBAAgB,GAAA,EAAY;AAClC,EAAA,MAAM,iBAAA,uBAAwB,GAAA,EAAyB;AAEvD,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAK1B,IAAA,aAAA,CAAc,KAAA,EAAO,UAAA,EAAY,IAAA,EAAM,EAAA,EAAI,WAAW,iBAAiB,CAAA;AAAA,EACzE;AAGA,EAAA,IAAI,QAAQ,UAAA,EAAY;AACtB,IAAA,wBAAA,CAAyB,MAAA,EAAQ,YAAY,IAAI,CAAA;AAAA,EACnD;AACF;;;AChRA,IAAM,uBAAA,GAA0B,GAAA;AAChC,IAAM,kBAAA,GAAqB,EAAA;AAC3B,IAAME,mBAAAA,GAAqB,EAAA;AAU3B,SAAS,aAAa,GAAA,EAAyB;AAC7C,EAAA,MAAM,MAAM,GAAA,CAAI,MAAA;AAChB,EAAA,MAAM,SAAmB,EAAC;AAE1B,EAAA,KAAA,IAAS,CAAA,GAAI,GAAA,GAAM,CAAA,EAAG,CAAA,IAAK,GAAG,CAAA,EAAA,EAAK;AACjC,IAAA,MAAA,CAAO,IAAA,CAAK,GAAA,CAAI,CAAC,CAAC,CAAA;AAAA,EACpB;AAEA,EAAA,OAAO,MAAA;AACT;AAeA,SAAS,iBAAiB,IAAA,EAAwB;AAEhD,EAAA,MAAM,QAAA,GAAW,IAAA,CAAK,KAAA,CAAM,uBAAuB,CAAA;AACnD,EAAA,MAAM,eAAe,QAAA,CAAS,MAAA;AAG9B,EAAA,MAAM,GAAA,GAAgB,CAAC,QAAA,CAAS,CAAC,CAAC,CAAA;AAIlC,EAAA,IAAI,aAAA,GAAgB,QAAA,CAAS,CAAC,CAAA,CAAE,MAAA;AAEhC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,YAAA,GAAe,GAAG,CAAA,EAAA,EAAK;AACzC,IAAA,aAAA,IAAiB,CAAA,GAAI,QAAA,CAAS,CAAC,CAAA,CAAE,MAAA;AACjC,IAAA,GAAA,CAAI,IAAA,CAAK,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,aAAa,CAAC,CAAA;AAAA,EACvC;AAGA,EAAA,GAAA,CAAI,KAAK,IAAI,CAAA;AAEb,EAAA,OAAO,GAAA;AACT;AAUA,SAAS,oBAAA,CAAqB,MAAc,KAAA,EAA6B;AACvE,EAAA,MAAM,IAAA,GAAO,KAAA,CAAM,IAAA,EAAM,MAAA,CAAO,IAAI,CAAA;AAGpC,EAAA,IAAI,CAAC,IAAA,IAAQ,OAAO,IAAA,KAAS,QAAA,EAAU;AACrC,IAAA,OAAO,EAAC;AAAA,EACV;AAEA,EAAA,MAAM,SAAwB,EAAC;AAE/B,EAAA,KAAA,MAAW,OAAO,IAAA,EAAgB;AAEhC,IAAA,IAAI,CAAC,MAAA,CAAO,MAAA,CAAO,IAAA,EAAM,GAAG,CAAA,EAAG;AAC7B,MAAA;AAAA,IACF;AAKA,IAAA,IAAI,IAAA,CAAK,GAAG,CAAA,KAAM,MAAA,EAAW;AAC3B,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,KAAA,GAAQ,KAAA,CAAM,MAAA,CAAO,GAAG,CAAA;AAG9B,IAAA,IAAI,SAAS,IAAA,EAAM;AACjB,MAAA;AAAA,IACF;AAKA,IAAA,IACE,OAAO,UAAU,QAAA,IACjB,OAAO,UAAU,QAAA,IACjB,OAAO,UAAU,SAAA,EACjB;AACA,MAAA,MAAA,CAAO,GAAG,CAAA,GAAI,MAAA,CAAO,KAAK,CAAA;AAAA,IAC5B;AAAA,EAEF;AAEA,EAAA,OAAO,MAAA;AACT;AAaA,SAAS,iBAAA,CACP,OAAA,EACA,SAAA,EACA,UAAA,EACA,cACA,IAAA,EACQ;AACR,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,IAAA,EAAM,CAAA,EAAA,EAAK;AAC7B,IAAA,MAAM,SAAA,GAAY,WAAW,CAAC,CAAA;AAC9B,IAAA,MAAM,WAAA,GAAc,aAAa,CAAC,CAAA;AAGlC,IAAA,IAAI,cAAc,WAAA,EAAa;AAC7B,MAAA,OAAO,CAAA;AAAA,IACT;AAGA,IAAA,MAAM,QAAA,GAAW,oBAAA,CAAqB,SAAA,EAAW,OAAO,CAAA;AACxD,IAAA,MAAM,UAAA,GAAa,oBAAA,CAAqB,WAAA,EAAa,SAAS,CAAA;AAG9D,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,IAAA,CAAK,QAAQ,CAAA;AACnC,IAAA,MAAM,QAAA,GAAW,MAAA,CAAO,IAAA,CAAK,UAAU,CAAA;AAEvC,IAAA,IAAI,MAAA,CAAO,MAAA,KAAW,QAAA,CAAS,MAAA,EAAQ;AACrC,MAAA,OAAO,CAAA;AAAA,IACT;AAGA,IAAA,KAAA,MAAW,OAAO,MAAA,EAAQ;AACxB,MAAA,IAAI,QAAA,CAAS,GAAG,CAAA,KAAM,UAAA,CAAW,GAAG,CAAA,EAAG;AACrC,QAAA,OAAO,CAAA;AAAA,MACT;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;AA8BO,SAAS,UAAU,IAAA,EAAwB;AAGhD,EAAA,IAAI,CAAC,IAAA,EAAM;AACT,IAAA,OAAO,CAACA,mBAAkB,CAAA;AAAA,EAC5B;AAIA,EAAA,MAAM,QAAA,GAAW,IAAA,CAAK,OAAA,CAAQ,uBAAuB,CAAA;AAErD,EAAA,IAAI,aAAa,EAAA,EAAI;AACnB,IAAA,OAAO,CAAC,IAAI,CAAA;AAAA,EACd;AAIA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,OAAA,CAAQ,uBAAA,EAAyB,WAAW,CAAC,CAAA;AAEpE,EAAA,IAAI,cAAc,EAAA,EAAI;AACpB,IAAA,OAAO;AAAA,MACL,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,QAAQ,CAAA;AAAA;AAAA,MACtB;AAAA;AAAA,KACF;AAAA,EACF;AAIA,EAAA,MAAM,QAAA,GAAW,IAAA,CAAK,OAAA,CAAQ,uBAAA,EAAyB,YAAY,CAAC,CAAA;AAEpE,EAAA,IAAI,aAAa,EAAA,EAAI;AACnB,IAAA,OAAO;AAAA,MACL,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,QAAQ,CAAA;AAAA;AAAA,MACtB,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,SAAS,CAAA;AAAA;AAAA,MACvB;AAAA;AAAA,KACF;AAAA,EACF;AAGA,EAAA,MAAM,SAAA,GAAY,IAAA,CAAK,OAAA,CAAQ,uBAAA,EAAyB,WAAW,CAAC,CAAA;AAEpE,EAAA,IAAI,cAAc,EAAA,EAAI;AACpB,IAAA,OAAO;AAAA,MACL,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,QAAQ,CAAA;AAAA,MACtB,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,SAAS,CAAA;AAAA,MACvB,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,QAAQ,CAAA;AAAA,MACtB;AAAA,KACF;AAAA,EACF;AAIA,EAAA,OAAO,iBAAiB,IAAI,CAAA;AAC9B;AA8EO,SAAS,iBAAA,CACd,SACA,SAAA,EACgB;AAGhB,EAAA,IAAI,CAAC,SAAA,EAAW;AACd,IAAA,OAAO;AAAA,MACL,YAAA,EAAc,kBAAA;AAAA,MACd,UAAA,EAAY,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA;AAAA,MAClC,cAAc;AAAC,KACjB;AAAA,EACF;AAEA,EAAA,MAAM,cAAA,GAAiB,OAAA,CAAQ,IAAA,EAAM,OAAA,IAAW,EAAC;AAIjD,EAAA,IAAI,eAAe,MAAA,EAAQ;AACzB,IAAA,OAAO;AAAA,MACL,YAAA,EAAc,kBAAA;AAAA,MACd,UAAA,EAAY,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA;AAAA,MAClC,YAAA,EAAc,YAAA,CAAa,SAAA,CAAU,SAAA,CAAU,IAAI,CAAC;AAAA,KACtD;AAAA,EACF;AAIA,EAAA,MAAM,SAAA,GAAY,OAAA,CAAQ,IAAA,EAAM,MAAA,KAAW,MAAA;AAC3C,EAAA,MAAM,WAAA,GAAc,SAAA,CAAU,IAAA,EAAM,MAAA,KAAW,MAAA;AAE/C,EAAA,IAAI,CAAC,SAAA,IAAa,CAAC,WAAA,EAAa;AAE9B,IAAA,OAAO;AAAA,MACL,YAAA,EAAc,kBAAA;AAAA,MACd,UAAA,EAAY,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA;AAAA,MAClC,YAAA,EAAc,YAAA,CAAa,SAAA,CAAU,SAAA,CAAU,IAAI,CAAC;AAAA,KACtD;AAAA,EACF;AAIA,EAAA,IAAI,OAAA,CAAQ,IAAA,KAAS,SAAA,CAAU,IAAA,IAAQ,aAAa,WAAA,EAAa;AAC/D,IAAA,MAAM,aAAA,GACJ,QAAQ,IAAA,IAAQ,MAAA,CAAO,KAAK,OAAA,CAAQ,IAAA,CAAK,MAAM,CAAA,CAAE,MAAA,KAAW,CAAA;AAC9D,IAAA,MAAM,eAAA,GACJ,UAAU,IAAA,IAAQ,MAAA,CAAO,KAAK,SAAA,CAAU,IAAA,CAAK,MAAM,CAAA,CAAE,MAAA,KAAW,CAAA;AAElE,IAAA,IAAI,iBAAiB,eAAA,EAAiB;AAEpC,MAAA,OAAO;AAAA,QACL,cAAc,OAAA,CAAQ,IAAA;AAAA,QACtB,YAAY,EAAC;AAAA,QACb,cAAc;AAAC,OACjB;AAAA,IACF;AAAA,EACF;AAIA,EAAA,MAAM,UAAA,GAAa,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA;AACzC,EAAA,MAAM,YAAA,GAAe,SAAA,CAAU,SAAA,CAAU,IAAI,CAAA;AAC7C,EAAA,MAAM,OAAO,IAAA,CAAK,GAAA,CAAI,YAAA,CAAa,MAAA,EAAQ,WAAW,MAAM,CAAA;AAI5D,EAAA,MAAM,CAAA,GAAI,iBAAA;AAAA,IACR,OAAA;AAAA,IACA,SAAA;AAAA,IACA,UAAA;AAAA,IACA,YAAA;AAAA,IACA;AAAA,GACF;AAIA,EAAA,MAAM,eAAyB,EAAC;AAEhC,EAAA,KAAA,IAAS,IAAI,YAAA,CAAa,MAAA,GAAS,CAAA,EAAG,CAAA,IAAK,GAAG,CAAA,EAAA,EAAK;AACjD,IAAA,YAAA,CAAa,IAAA,CAAK,YAAA,CAAa,CAAC,CAAC,CAAA;AAAA,EACnC;AAGA,EAAA,MAAM,UAAA,GAAa,UAAA,CAAW,KAAA,CAAM,CAAC,CAAA;AAIrC,EAAA,MAAM,eAAe,CAAA,GAAI,CAAA,GAAI,YAAA,CAAa,CAAA,GAAI,CAAC,CAAA,GAAI,kBAAA;AAEnD,EAAA,OAAO;AAAA,IACL,YAAA;AAAA,IACA,YAAA;AAAA,IACA;AAAA,GACF;AACF;;;ACzXA,IAAM,aAAA,GAAgB,MAAA,CAAO,MAAA,CAAO,EAAE,CAAA;AAQ/B,IAAM,kBAAN,MAEL;AAAA;AAAA;AAAA;AAAA,EAKS,eAAkC,EAAC;AAAA,EACnC,UAAuB,iBAAA,EAAkB;AAAA,EACzC,sCAA8C,MAAA,CAAO,MAAA;AAAA,IAC5D;AAAA,GACF;AAAA;AAAA;AAAA,EAIS,mBAAA,uBAA0B,GAAA,EAGjC;AAAA,EAEF,SAAA,GAAY,EAAA;AAAA,EACZ,KAAA;AAAA,EACA,eAAA;AAAA,EACA,kBAAA;AAAA,EACA,kBAAA;AAAA;AAAA,EAGA,UAAA;AAAA;AAAA,EAGA,mBAAA;AAAA;AAAA,EAGS,WAAA;AAAA;AAAA;AAAA;AAAA,EAKT,IAAI,KAAA,GAA0C;AAE5C,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAMA,WAAA,CAAY,MAAA,GAAgC,EAAC,EAAG,aAAa,KAAA,EAAO;AAClE,IAAA,IAAA,CAAK,WAAA,GAAc,UAAA;AAEnB,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,IAAA,CAAK,YAAA,CAAa,IAAA,CAAK,aAAA,CAAc,KAAK,CAAC,CAAA;AAAA,IAC7C;AAGA,IAAA,IAAA,CAAK,KAAA,GAAQ,eAAA;AAAA,MACX,kBAAA;AAAA,MACA,IAAA,CAAK,SAAA;AAAA,MACL,IAAA,CAAK;AAAA,KACP;AAGA,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAI,cAAA,EAAe;AAC1C,IAAA,IAAA,CAAK,eAAA,CAAgB,YAAA,CAAa,IAAA,CAAK,KAAK,CAAA;AAI5C,IAAA,IAAA,CAAK,0BAA0B,MAAM,CAAA;AAIrC,IAAA,IAAI,UAAA,EAAY;AAEd,MAAA,IAAA,CAAK,gBAAA,EAAiB;AAAA,IACxB,CAAA,MAAO;AACL,MAAA,IAAA,CAAK,2BAAA,EAA4B;AAAA,IACnC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,wBAAwB,IAAA,EAAuC;AACpE,IAAA,uBAAA,CAAwB,IAAI,CAAA;AAAA,EAC9B;AAAA,EAEA,OAAO,wBACL,QAAA,EAC4B;AAC5B,IAAA,uBAAA,CAAwB,QAAQ,CAAA;AAAA,EAClC;AAAA;AAAA,EAGA,OAAO,qBAAqB,MAAA,EAAqC;AAC/D,IAAA,oBAAA,CAAqB,MAAM,CAAA;AAAA,EAC7B;AAAA,EAEA,OAAO,yBAAA,CACL,IAAA,EACA,MAAA,EACA,gBACA,iBAAA,EACM;AACN,IAAA,yBAAA,CAA0B,IAAA,EAAM,MAAA,EAAQ,cAAA,EAAgB,iBAAiB,CAAA;AAAA,EAC3E;AAAA,EAEA,OAAO,wBAAA,CACL,SAAA,EACA,WAAA,EACA,UAAA,EACM;AACN,IAAA,wBAAA,CAAyB,SAAA,EAAW,aAAa,UAAU,CAAA;AAAA,EAC7D;AAAA,EAEA,OAAO,4BAAA,CACL,IAAA,EACA,OAAA,EAC4C;AAC5C,IAAA,4BAAA,CAAmC,MAAM,OAAO,CAAA;AAAA,EAClD;AAAA,EAEA,OAAO,gCAAA,CACL,SAAA,EACA,aAAA,EACA,cACA,YAAA,EACM;AACN,IAAA,gCAAA;AAAA,MACE,SAAA;AAAA,MACA,aAAA;AAAA,MACA,YAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA,EAEA,OAAO,sBAAsB,KAAA,EAAyC;AACpE,IAAA,qBAAA,CAAsB,KAAK,CAAA;AAAA,EAC7B;AAAA,EAEA,OAAO,sBAAsB,IAAA,EAAuC;AAClE,IAAA,qBAAA,CAAsB,IAAI,CAAA;AAAA,EAC5B;AAAA,EAEA,OAAO,6BACL,QAAA,EAC4B;AAC5B,IAAA,4BAAA,CAA6B,QAAQ,CAAA;AAAA,EACvC;AAAA,EAEA,OAAO,cAAA,CACL,MAAA,EACA,IAAA,EACA,UAAA,EACM;AACN,IAAA,cAAA,CAAe,MAAA,EAAQ,MAAM,UAAU,CAAA;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,gBAAgB,IAAA,EAA8C;AAC5D,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAGlB,IAAA,KAAA,MAAW,CAAC,SAAA,EAAW,OAAO,CAAA,IAAK,KAAK,mBAAA,EAAqB;AAC3D,MAAA,IAAA,CAAK,WAAA,CAAY,WAAW,OAAO,CAAA;AAAA,IACrC;AAGA,IAAA,IAAA,CAAK,oBAAoB,KAAA,EAAM;AAAA,EACjC;AAAA;AAAA;AAAA;AAAA,EAKA,sBACE,SAAA,EACM;AACN,IAAA,IAAA,CAAK,mBAAA,GAAsB,SAAA;AAAA,EAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,WAAA,GAAsB;AACpB,IAAA,OAAO,IAAA,CAAK,SAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,OAAA,GAAqB;AACnB,IAAA,OAAO,IAAA,CAAK,KAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAA,GAA2C;AACzC,IAAA,OAAO,KAAK,OAAA,CAAQ,UAAA;AAAA,EACtB;AAAA;AAAA;AAAA;AAAA,EAKA,YAAY,WAAA,EAA2B;AACrC,IAAA,IAAA,CAAK,SAAA,GAAY,WAAA;AACjB,IAAA,IAAA,CAAK,YAAA,EAAa;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,IAAA,EAAuB;AAC9B,IAAA,OAAO,IAAA,CAAK,eAAA,CAAgB,QAAA,CAAS,IAAI,CAAA;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,IAAA,EAA+C;AACtD,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,iBAAA,CAAkB,IAAI,CAAA;AAE5D,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,OAAO,MAAA;AAAA,IACT;AAEA,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,eAAA,CAAgB,QAAQ,CAAA;AAChD,IAAA,MAAM,UAAA,GAAa,iBAAiB,UAAU,CAAA;AAE9C,IAAA,OAAO,IAAA,CAAK,YAAA,CAAa,UAAA,EAAY,IAAI,CAAA;AAAA,EAC3C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,UAAU,MAAA,EAAqC;AAE7C,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,IAAA,CAAK,YAAA,CAAa,IAAA,CAAK,aAAA,CAAc,KAAK,CAAC,CAAA;AAAA,IAC7C;AAGA,IAAA,IAAA,CAAK,0BAA0B,MAAM,CAAA;AAGrC,IAAA,IAAA,CAAK,YAAA,EAAa;AAGlB,IAAA,IAAA,CAAK,kBAAA,EAAmB;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,YAAY,IAAA,EAAuB;AACjC,IAAA,MAAM,UAAA,GAAa,qBAAA,CAAsB,IAAA,CAAK,YAAA,EAAc,IAAI,CAAA;AAEhE,IAAA,IAAI,CAAC,UAAA,EAAY;AACf,MAAA,OAAO,KAAA;AAAA,IACT;AAGA,IAAA,IAAA,CAAK,0BAA0B,IAAI,CAAA;AAGnC,IAAA,IAAA,CAAK,YAAA,EAAa;AAGlB,IAAA,IAAA,CAAK,kBAAA,EAAmB;AAExB,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeA,iBAAA,CACE,MACA,OAAA,EAMM;AAEN,IAAA,IAAI,OAAA,CAAQ,cAAc,MAAA,EAAW;AACnC,MAAA,IAAI,OAAA,CAAQ,cAAc,IAAA,EAAM;AAC9B,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,IAAI,CAAA;AAAA,MACrC,CAAA,MAAO;AACL,QAAA,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,IAAI,CAAA,GAAI,OAAA,CAAQ,SAAA;AAAA,MAC1C;AAEA,MAAA,IAAA,CAAK,kBAAA,EAAmB;AAAA,IAC1B;AAGA,IAAA,IAAI,OAAA,CAAQ,kBAAkB,MAAA,EAAW;AACvC,MAAA,IAAI,OAAA,CAAQ,kBAAkB,IAAA,EAAM;AAClC,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,IAAI,CAAA;AAAA,MACxC,CAAA,MAAO;AACL,QAAA,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,IAAI,CAAA,GAAI,OAAA,CAAQ,aAAA;AAAA,MAC7C;AAAA,IACF;AAIA,IAAA,IAAI,OAAA,CAAQ,iBAAiB,MAAA,EAAW;AACtC,MAAA,IAAI,OAAA,CAAQ,iBAAiB,IAAA,EAAM;AACjC,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA;AAAA,MACnC,CAAA,MAAO;AACL,QAAA,MAAM,UAAU,OAAA,CAAQ,YAAA;AAExB,QAAA,IAAA,CAAK,OAAA,CAAQ,SAAS,IAAI,CAAA,GAAI,CAAC,MAAA,KAC5B,OAAA,CAAQ,MAAM,CAAA,IAA4B,MAAA;AAAA,MAC/C;AAAA,IACF;AAIA,IAAA,IAAI,OAAA,CAAQ,iBAAiB,MAAA,EAAW;AACtC,MAAA,IAAI,OAAA,CAAQ,iBAAiB,IAAA,EAAM;AACjC,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA;AAAA,MACnC,CAAA,MAAO;AACL,QAAA,MAAM,UAAU,OAAA,CAAQ,YAAA;AAExB,QAAA,IAAA,CAAK,OAAA,CAAQ,SAAS,IAAI,CAAA,GAAI,CAAC,MAAA,KAC5B,OAAA,CAAQ,MAAM,CAAA,IAA4B,MAAA;AAAA,MAC/C;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,WAAA,GAAoB;AAClB,IAAA,IAAA,CAAK,aAAa,MAAA,GAAS,CAAA;AAG3B,IAAA,KAAA,MAAW,GAAA,IAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU;AACvC,MAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA;AAAA,IAClC;AAEA,IAAA,KAAA,MAAW,GAAA,IAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU;AACvC,MAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA;AAAA,IAClC;AAEA,IAAA,KAAA,MAAW,GAAA,IAAO,IAAA,CAAK,OAAA,CAAQ,aAAA,EAAe;AAC5C,MAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,GAAG,CAAA;AAAA,IACvC;AAEA,IAAA,KAAA,MAAW,GAAA,IAAO,IAAA,CAAK,OAAA,CAAQ,UAAA,EAAY;AACzC,MAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAA;AAAA,IACpC;AAGA,IAAA,KAAA,MAAW,GAAA,IAAO,KAAK,mBAAA,EAAqB;AAC1C,MAAA,OAAO,IAAA,CAAK,oBAAoB,GAAG,CAAA;AAAA,IACrC;AAGA,IAAA,IAAA,CAAK,YAAA,EAAa;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeA,SAAA,CACE,KAAA,EACA,MAAA,EACA,OAAA,EACA,QAAA,EACQ;AACR,IAAA,IAAI,KAAA,KAAU,UAAU,aAAA,EAAe;AACrC,MAAA,OAAO,QAAA,CAAS,MAAA,EAAQ,IAAI,CAAA,GAAI,OAAO,IAAA,GAAO,EAAA;AAAA,IAChD;AAGA,IAAA,MAAM,oBAAoB,MAAA,CAAO,MAAA,CAAO,KAAK,OAAA,CAAQ,aAAA,EAAe,KAAK,CAAA,GACrE,EAAE,GAAG,IAAA,CAAK,OAAA,CAAQ,cAAc,KAAK,CAAA,EAAG,GAAG,MAAA,EAAO,GACjD,UAAU,EAAC;AAGhB,IAAA,MAAM,gBACJ,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,KAAK,CAAA,KAAM,UAAA,GACpC,IAAA,CAAK,OAAA,CAAQ,SAAS,KAAK,CAAA,CAAE,EAAE,GAAG,iBAAA,EAAmB,CAAA,GACrD,iBAAA;AAGN,IAAA,MAAM,YAAA;AAAA;AAAA,MAEJ,IAAA,CAAK,kBAAA,IAAsB,kBAAA,CAAmB,OAAQ;AAAA,KAAA;AAExD,IAAA,OAAO,SAAA;AAAA,MACL,IAAA,CAAK,KAAA;AAAA,MACL,KAAA;AAAA,MACA,aAAA;AAAA,MACA,YAAA;AAAA;AAAA,MAEA;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,SAAA,CACE,IAAA,EACA,MAAA,EACA,OAAA,EAC0B;AAE1B,IAAA,MAAM,IAAA,GAAO,OAAA;AACb,IAAA,MAAM,eACJ,IAAA,CAAK,kBAAA,KACJ,IAAA,CAAK,kBAAA,GAAqB,mBAAmB,IAAI,CAAA,CAAA;AACpD,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,eAAA,CAAgB,KAAA,CAAM,MAAM,YAAY,CAAA;AAEjE,IAAA,IAAI,WAAA,EAAa;AACf,MAAA,MAAM,UAAA,GAAa,iBAAiB,WAAW,CAAA;AAC/C,MAAA,MAAM,EAAE,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAK,GAAI,UAAA;AAE/B,MAAA,MAAM,aAAA,GACJ,OAAO,IAAA,CAAK,OAAA,CAAQ,SAAS,IAAI,CAAA,KAAM,UAAA,GACnC,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA,CAAE,MAAgB,CAAA,GAC5C,MAAA;AAEN,MAAA,MAAM,EAAE,IAAA,EAAM,SAAA,EAAW,MAAA,EAAQ,WAAA,KAAgB,IAAA,CAAK,YAAA;AAAA,QACpD,IAAA;AAAA,QACA;AAAA,OACF;AAEA,MAAA,IAAI,SAAA,GAAY,IAAA;AAEhB,MAAA,IAAI,KAAK,kBAAA,EAAoB;AAC3B,QAAA,MAAM,cAAA,GACJ,SAAA,KAAc,IAAA,GAAO,WAAA,CAAY,aAAA,GAAgB,MAAA;AAEnD,QAAA,SAAA,GAAY,IAAA,CAAK,SAAA;AAAA,UACf,SAAA;AAAA,UACA,WAAA;AAAA,UACA,IAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAGA,MAAA,OAAO,IAAA,CAAK,KAAA,CAAM,SAAA,CAAiB,SAAA,EAAW,aAAa,SAAA,EAAW;AAAA,QACpE,MAAA,EAAQ,IAAA;AAAA,QACR,OAAA,EAAS,aAAA;AAAA,QACT,MAAA;AAAA,QACA,UAAA,EAAY;AAAA,OACb,CAAA;AAAA,IACH;AAEA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,YAAA,CACE,MACA,MAAA,EAC6B;AAC7B,IAAA,MAAM,YAAA,GAAe,IAAA,CAAK,mBAAA,CAAoB,IAAI,CAAA,IAAK,IAAA;AAGvD,IAAA,MAAM,mBAAmB,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,OAAA,CAAQ,eAAe,IAAI,CAAA,GACnE,EAAE,GAAG,KAAK,OAAA,CAAQ,aAAA,CAAc,IAAI,CAAA,EAAG,GAAG,QAAO,GACjD,MAAA;AAGJ,IAAA,IACE,YAAA,KAAiB,QACjB,MAAA,CAAO,MAAA,CAAO,KAAK,OAAA,CAAQ,aAAA,EAAe,YAAY,CAAA,EACtD;AACA,MAAA,OAAO;AAAA,QACL,IAAA,EAAM,YAAA;AAAA,QACN,MAAA,EAAQ;AAAA,UACN,GAAG,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,YAAY,CAAA;AAAA,UAC1C,GAAG;AAAA;AACL,OACF;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,IAAA,EAAM,YAAA,EAAc,MAAA,EAAQ,gBAAA,EAAiB;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,kBAAA,CACE,cACA,cAAA,EAC4B;AAC5B,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,iBAAA,CAAkB,YAAY,CAAA;AAEpE,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,OAAO,MAAA;AAAA,IACT;AAGA,IAAA,MAAM,OAAO,IAAA,CAAK,eAAA,CAAgB,aAAA,CAAc,YAAY,KAAK,EAAC;AAElE,IAAA,OAAO,gBAAA;AAAA,MACL,EAAE,QAAA,EAAmC,MAAA,EAAQ,gBAAgB,IAAA,EAAK;AAAA,MAClE;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,8BAAA,CACE,cACA,cAAA,EAC6C;AAC7C,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,iBAAA,CAAkB,YAAY,CAAA;AAEpE,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,OAAO,MAAA;AAAA,IACT;AAGA,IAAA,MAAM,OAAO,IAAA,CAAK,eAAA,CAAgB,aAAA,CAAc,YAAY,KAAK,EAAC;AAClE,IAAA,MAAM,KAAA,GAAQ,gBAAA;AAAA,MACZ,EAAE,QAAA,EAAmC,MAAA,EAAQ,gBAAgB,IAAA,EAAK;AAAA,MAClE;AAAA,KACF;AAEA,IAAA,OAAO,EAAE,OAAO,QAAA,EAAS;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,sBAAsB,OAAA,EAAwB;AAC5C,IAAA,IAAA,CAAK,kBAAA,GAAqB,mBAAmB,OAAO,CAAA;AACpD,IAAA,IAAA,CAAK,kBAAA,GAAqB,mBAAmB,OAAO,CAAA;AAAA,EACtD;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,sBAAA,GAA+B;AAC7B,IAAA,IAAA,CAAK,kBAAA,GAAqB,MAAA;AAC1B,IAAA,IAAA,CAAK,kBAAA,GAAqB,MAAA;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,aAAA,CACE,MACA,MAAA,GAAiB,IACjB,cAAA,GAAiB,KAAA,EACjB,oBAAoB,IAAA,EACX;AAET,IAAA,IAAI,CAAC,mBAAA,CAAoB,GAAA,CAAI,IAAI,CAAA,EAAG;AAClC,MAAA,iBAAA,CAAkB,MAAM,eAAe,CAAA;AACvC,MAAA,mBAAA,CAAoB,IAAI,IAAI,CAAA;AAAA,IAC9B;AAGA,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,KAAA,CAAM,QAAA,EAAS;AAExC,IAAA,IAAI,CAAC,WAAA,EAAa;AAChB,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,MAAM,aAAa,WAAA,CAAY,IAAA;AAG/B,IAAA,IACE,UAAA,KAAe,IAAA,IACf,CAAC,UAAA,CAAW,WAAW,CAAA,EAAG,IAAI,CAAA,CAAA,CAAG,CAAA,IACjC,CAAC,IAAA,CAAK,UAAA,CAAW,CAAA,EAAG,UAAU,GAAG,CAAA,EACjC;AACA,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,MAAM,aAAA,GAAgB,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,IAAI,CAAA;AAKrD,IAAA,IAAI,cAAA,IAAkB,eAAe,IAAA,EAAM;AACzC,MAAA,MAAM,kBAAkB,aAAA,GACpB,EAAE,GAAG,aAAA,EAAe,GAAG,QAAO,GAC9B,MAAA;AAEJ,MAAA,MAAM,WAAA,GAAqB;AAAA,QACzB,IAAA;AAAA,QACA,MAAA,EAAQ,eAAA;AAAA,QACR,IAAA,EAAM;AAAA,OACR;AAEA,MAAA,OAAO,KAAK,KAAA,CAAM,cAAA;AAAA,QAChB,WAAA;AAAA,QACA,WAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,MAAM,eAAe,WAAA,CAAY,MAAA;AAEjC,IAAA,IAAI,CAAC,WAAA,CAAY,MAAA,EAAQ,YAAY,CAAA,EAAG;AACtC,MAAA,OAAO,KAAA;AAAA,IACT;AAGA,IAAA,OACE,CAAC,aAAA,IACD,oBAAA,CAAqB,aAAA,EAAe,cAAc,MAAM,CAAA;AAAA,EAE5D;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,iBACE,QAAA,EACgD;AAChD,IAAA,OAAO,CAAC,SAAgB,SAAA,KAA+B;AAErD,MAAA,IAAI,EAAE,OAAA,IAAW,OAAO,OAAA,KAAY,QAAA,IAAY,UAAU,OAAA,CAAA,EAAU;AAClE,QAAA,MAAM,IAAI,SAAA;AAAA,UACR;AAAA,SACF;AAAA,MACF;AAEA,MAAA,IAAI,OAAA,CAAQ,IAAA,EAAM,OAAA,CAAQ,MAAA,EAAQ;AAChC,QAAA,OAAO,IAAA;AAAA,MACT;AAEA,MAAA,IAAI,QAAA,KAAa,kBAAA,IAAsB,CAAC,SAAA,EAAW;AACjD,QAAA,OAAO,IAAA;AAAA,MACT;AAEA,MAAA,MAAM,EAAE,YAAA,EAAc,UAAA,EAAY,YAAA,EAAa,GAAI,iBAAA;AAAA,QACjD,OAAA;AAAA,QACA;AAAA,OACF;AAEA,MAAA,IAAI,aAAa,YAAA,EAAc;AAC7B,QAAA,OAAO,IAAA;AAAA,MACT;AAEA,MAAA,IAAI,UAAA,CAAW,QAAA,CAAS,QAAQ,CAAA,EAAG;AACjC,QAAA,OAAO,IAAA;AAAA,MACT;AAEA,MAAA,OAAO,YAAA,CAAa,SAAS,QAAQ,CAAA;AAAA,IACvC,CAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,SAAA,GAAyB;AACvB,IAAA,OAAO,IAAA,CAAK,OAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,aAAa,IAAA,EAAwB;AACnC,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,iBAAA,CAAkB,IAAI,CAAA;AAE5D,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,OAAO,EAAC;AAAA,IACV;AAEA,IAAA,OAAO,IAAA,CAAK,uBAAuB,QAAQ,CAAA;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA,EAKA,qBAAA,GAAgD;AAC9C,IAAA,OAAO,IAAA,CAAK,mBAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,sBAAsB,GAAA,EAAmC;AACvD,IAAA,MAAA,CAAO,MAAA,CAAO,IAAA,CAAK,mBAAA,EAAqB,GAAG,CAAA;AAAA,EAC7C;AAAA;AAAA;AAAA;AAAA,EAKA,WAAA,GAAqC;AACnC,IAAA,OAAO,sBAAA,CAAuB,KAAK,KAAK,CAAA;AAAA,EAC1C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,mCAAA,CACE,YACA,UAAA,EACM;AACN,IAAA,MAAM,OAAA,GAAU,qCAAA;AAChB,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,mBAAA,CAAoB,UAAA,EAAY,OAAO,CAAA;AACnE,IAAA,MAAM,cAAA,GAAiB,IAAA,CAAK,mBAAA,CAAoB,UAAA,EAAY,OAAO,CAAA;AAGnE,IAAA,MAAM,YAAA,GAAe,IAAA,CAAK,iBAAA,CAAkB,cAAc,CAAA;AAC1D,IAAA,MAAM,YAAA,GAAe,IAAA,CAAK,sBAAA,CAAuB,cAAc,CAAA;AAG/D,IAAA,MAAM,gBAAgB,YAAA,CAAa,MAAA;AAAA,MACjC,CAAC,KAAA,KAAU,CAAC,YAAA,CAAa,IAAI,KAAK;AAAA,KACpC;AAEA,IAAA,IAAI,aAAA,CAAc,SAAS,CAAA,EAAG;AAC5B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,CAAA,gCAAA,EAAmC,UAAU,CAAA,mBAAA,EACvC,aAAA,CAAc,KAAK,IAAI,CAAC,6CAA6C,UAAU,CAAA,CAAA;AAAA,OACvF;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,sBAAA,CAAuB,YAAoB,UAAA,EAA0B;AAEnE,IAAA,MAAM,OAAA,GAAU;AAAA,MACd,GAAG,KAAK,OAAA,CAAQ,UAAA;AAAA,MAChB,CAAC,UAAU,GAAG;AAAA,KAChB;AAGA,IAAA,mBAAA,CAAoB,YAAY,OAAO,CAAA;AAAA,EACzC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,mBAAA,CACE,IAAA,EACA,gBAAA,EACA,YAAA,EACS;AAET,IAAA,IAAI,gBAAA,EAAkB;AACpB,MAAA,MAAM,eAAe,gBAAA,KAAqB,IAAA;AAC1C,MAAA,MAAM,iBAAA,GAAoB,gBAAA,CAAiB,UAAA,CAAW,CAAA,EAAG,IAAI,CAAA,CAAA,CAAG,CAAA;AAEhE,MAAA,IAAI,gBAAgB,iBAAA,EAAmB;AACrC,QAAA,MAAM,MAAA,GAAS,YAAA,GAAe,EAAA,GAAK,CAAA,YAAA,EAAe,gBAAgB,CAAA,EAAA,CAAA;AAElE,QAAAX,aAAAA,CAAO,IAAA;AAAA,UACL,oBAAA;AAAA,UACA,CAAA,qBAAA,EAAwB,IAAI,CAAA,+BAAA,EAA6B,MAAM,CAAA,sBAAA;AAAA,SACjE;AAEA,QAAA,OAAO,KAAA;AAAA,MACT;AAAA,IACF;AAGA,IAAA,IAAI,YAAA,EAAc;AAChB,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,oBAAA;AAAA,QACA,UAAU,IAAI,CAAA,8EAAA;AAAA,OAChB;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,oBAAoB,YAAA,EAAgC;AAClD,IAAA,IAAI,YAAA,EAAc;AAChB,MAAAA,aAAAA,CAAO,KAAA;AAAA,QACL,oBAAA;AAAA,QACA;AAAA,OACF;AAEA,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,mBAAA,CACE,MACA,SAAA,EACM;AAEN,IAAA,IAAI,CAAC,IAAA,CAAK,QAAA,CAAS,IAAI,CAAA,EAAG;AACxB,MAAA,MAAM,IAAI,cAAA;AAAA,QACR,qCAAqC,IAAI,CAAA,gBAAA;AAAA,OAC3C;AAAA,IACF;AAGA,IAAA,IAAI,SAAA,KAAc,MAAA,IAAa,SAAA,KAAc,IAAA,EAAM;AACjD,MAAA,IAAI,CAAC,IAAA,CAAK,QAAA,CAAS,SAAS,CAAA,EAAG;AAC7B,QAAA,MAAM,IAAI,KAAA;AAAA,UACR,gDAAgD,SAAS,CAAA,gBAAA;AAAA,SAC3D;AAAA,MACF;AAGA,MAAA,IAAA,CAAK,mCAAA,CAAoC,MAAM,SAAS,CAAA;AAGxD,MAAA,IAAA,CAAK,sBAAA,CAAuB,MAAM,SAAS,CAAA;AAAA,IAC7C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,YAAA,GAAqB;AACnB,IAAA,IAAA,CAAK,KAAA,GAAQ,eAAA;AAAA,MACX,kBAAA;AAAA,MACA,IAAA,CAAK,SAAA;AAAA,MACL,IAAA,CAAK;AAAA,KACP;AAGA,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAI,cAAA,EAAe;AAC1C,IAAA,IAAA,CAAK,eAAA,CAAgB,YAAA,CAAa,IAAA,CAAK,KAAK,CAAA;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,mBAAA,CAAoB,MAAc,OAAA,EAAuC;AACvE,IAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,iBAAA,CAAkB,IAAI,CAAA;AAG5D,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,MAAM,IAAI,cAAA;AAAA,QACR,CAAA,cAAA,EAAiB,OAAO,CAAA,SAAA,EAAY,IAAI,CAAA,gBAAA;AAAA,OAC1C;AAAA,IACF;AAEA,IAAA,OAAO,QAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAgB,QAAA,EAA2C;AACzD,IAAA,MAAM,IAAA,GAAO,QAAA,CAAS,EAAA,CAAG,EAAE,CAAA;AAG3B,IAAA,IAAI,CAAC,IAAA,EAAM;AACT,MAAA,MAAM,IAAI,MAAM,oDAAoD,CAAA;AAAA,IACtE;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,kBAAkB,QAAA,EAA6C;AAC7D,IAAA,MAAM,MAAA,uBAAa,GAAA,EAAY;AAE/B,IAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAE9B,MAAA,KAAA,MAAW,KAAA,IAAS,OAAA,CAAQ,SAAA,CAAU,SAAA,EAAW;AAC/C,QAAA,MAAA,CAAO,IAAI,KAAK,CAAA;AAAA,MAClB;AAAA,IACF;AAEA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,uBAAuB,QAAA,EAA0C;AAC/D,IAAA,MAAM,SAAmB,EAAC;AAE1B,IAAA,KAAA,MAAW,WAAW,QAAA,EAAU;AAE9B,MAAA,KAAA,MAAW,KAAA,IAAS,OAAA,CAAQ,SAAA,CAAU,SAAA,EAAW;AAC/C,QAAA,MAAA,CAAO,KAAK,KAAK,CAAA;AAAA,MACnB;AAAA,IACF;AAEA,IAAA,OAAO,MAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,kBAAA,GAA2B;AACzB,IAAA,IAAI,KAAK,WAAA,EAAa;AACpB,MAAA,IAAA,CAAK,gBAAA,EAAiB;AAAA,IACxB,CAAA,MAAO;AACL,MAAA,IAAA,CAAK,2BAAA,EAA4B;AAAA,IACnC;AAAA,EACF;AAAA,EAEA,2BAAA,GAAoC;AAElC,IAAA,KAAA,MAAW,GAAA,IAAO,KAAK,mBAAA,EAAqB;AAC1C,MAAA,OAAO,IAAA,CAAK,oBAAoB,GAAG,CAAA;AAAA,IACrC;AAGA,IAAA,KAAA,MAAW,aAAa,MAAA,CAAO,IAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,UAAU,CAAA,EAAG;AAC5D,MAAA,IAAA,CAAK,mBAAA,CAAoB,SAAS,CAAA,GAAI,mBAAA;AAAA,QACpC,SAAA;AAAA,QACA,KAAK,OAAA,CAAQ;AAAA,OACf;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAA,GAAyB;AAEvB,IAAA,KAAA,MAAW,GAAA,IAAO,KAAK,mBAAA,EAAqB;AAC1C,MAAA,OAAO,IAAA,CAAK,oBAAoB,GAAG,CAAA;AAAA,IACrC;AAGA,IAAA,KAAA,MAAW,aAAa,MAAA,CAAO,IAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,UAAU,CAAA,EAAG;AAC5D,MAAA,IAAI,OAAA,GAAU,SAAA;AAEd,MAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,OAAO,CAAA,EAAG;AACvC,QAAA,OAAA,GAAU,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,OAAO,CAAA;AAAA,MAC3C;AAEA,MAAA,IAAA,CAAK,mBAAA,CAAoB,SAAS,CAAA,GAAI,OAAA;AAAA,IACxC;AAAA,EACF;AAAA,EAEA,0BAA0B,SAAA,EAAyB;AACjD,IAAA,MAAM,WAAA,GAAc,CAAC,CAAA,KACnB,CAAA,KAAM,aAAa,CAAA,CAAE,UAAA,CAAW,CAAA,EAAG,SAAS,CAAA,CAAA,CAAG,CAAA;AAEjD,IAAA,kBAAA,CAAmB,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU,WAAW,CAAA;AACrD,IAAA,kBAAA,CAAmB,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU,WAAW,CAAA;AACrD,IAAA,kBAAA,CAAmB,IAAA,CAAK,OAAA,CAAQ,aAAA,EAAe,WAAW,CAAA;AAC1D,IAAA,kBAAA,CAAmB,IAAA,CAAK,OAAA,CAAQ,UAAA,EAAY,WAAW,CAAA;AAGvD,IAAA,kBAAA;AAAA,MAAmB,KAAK,OAAA,CAAQ,UAAA;AAAA,MAAY,CAAC,GAAA,KAC3C,WAAA,CAAY,KAAK,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAC;AAAA,KAC1C;AAIA,IAAA,IAAI,KAAK,mBAAA,EAAqB;AAC5B,MAAA,MAAM,CAAC,sBAAA,EAAwB,oBAAoB,CAAA,GACjD,IAAA,CAAK,oBAAoB,YAAA,EAAa;AAExC,MAAA,KAAA,MAAW,CAAA,IAAK,MAAA,CAAO,IAAA,CAAK,oBAAoB,CAAA,EAAG;AACjD,QAAA,IAAI,WAAA,CAAY,CAAC,CAAA,EAAG;AAClB,UAAA,IAAA,CAAK,mBAAA,CAAoB,gBAAA,CAAiB,CAAA,EAAG,IAAI,CAAA;AAAA,QACnD;AAAA,MACF;AAEA,MAAA,KAAA,MAAW,CAAA,IAAK,MAAA,CAAO,IAAA,CAAK,sBAAsB,CAAA,EAAG;AACnD,QAAA,IAAI,WAAA,CAAY,CAAC,CAAA,EAAG;AAClB,UAAA,IAAA,CAAK,mBAAA,CAAoB,kBAAA,CAAmB,CAAA,EAAG,IAAI,CAAA;AAAA,QACrD;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA,EAEA,yBAAA,CACE,MAAA,EACA,UAAA,GAAa,EAAA,EACP;AACN,IAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,MAAA,MAAM,QAAA,GAAW,aAAa,CAAA,EAAG,UAAU,IAAI,KAAA,CAAM,IAAI,KAAK,KAAA,CAAM,IAAA;AAEpE,MAAA,IAAA,CAAK,4BAAA,CAA6B,OAAO,QAAQ,CAAA;AAEjD,MAAA,IAAI,MAAM,QAAA,EAAU;AAClB,QAAA,IAAA,CAAK,yBAAA,CAA0B,KAAA,CAAM,QAAA,EAAU,QAAQ,CAAA;AAAA,MACzD;AAAA,IACF;AAAA,EACF;AAAA,EAEA,4BAAA,CACE,OACA,QAAA,EACM;AAEN,IAAA,IAAI,MAAM,WAAA,EAAa;AAGrB,MAAA,IAAI,KAAK,UAAA,EAAY;AAEnB,QAAA,IAAA,CAAK,UAAA,CAAW,WAAA,CAAY,QAAA,EAAU,KAAA,CAAM,WAAW,CAAA;AAAA,MACzD,CAAA,MAAO;AAEL,QAAA,IAAA,CAAK,mBAAA,CAAoB,GAAA,CAAI,QAAA,EAAU,KAAA,CAAM,WAAW,CAAA;AAAA,MAC1D;AAAA,IACF;AAGA,IAAA,IAAI,MAAM,SAAA,EAAW;AACnB,MAAA,IAAA,CAAK,kBAAA,CAAmB,OAAO,QAAQ,CAAA;AAAA,IACzC;AAGA,IAAA,IAAI,MAAM,YAAA,EAAc;AACtB,MAAA,IAAA,CAAK,OAAA,CAAQ,SAAS,QAAQ,CAAA,GAAI,CAAC,MAAA,KACjC,KAAA,CAAM,YAAA,GAAe,MAAM,CAAA,IAAK,MAAA;AAAA,IACpC;AAEA,IAAA,IAAI,MAAM,YAAA,EAAc;AACtB,MAAA,IAAA,CAAK,OAAA,CAAQ,SAAS,QAAQ,CAAA,GAAI,CAAC,MAAA,KACjC,KAAA,CAAM,YAAA,GAAe,MAAM,CAAA,IAAK,MAAA;AAAA,IACpC;AAGA,IAAA,IAAI,MAAM,aAAA,EAAe;AACvB,MAAA,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,QAAQ,CAAA,GAAI,KAAA,CAAM,aAAA;AAAA,IAC/C;AAAA,EACF;AAAA,EAEA,kBAAA,CAAmB,OAA4B,QAAA,EAAwB;AACrE,IAAA,IAAI,MAAM,WAAA,EAAa;AACrB,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,aAAA;AAAA,QACA,CAAA,OAAA,EAAU,QAAQ,CAAA,kKAAA,EAEyB,KAAA,CAAM,SAAS,CAAA,EAAA;AAAA,OAC5D;AAAA,IACF;AAIA,IAAA,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,QAAQ,CAAA,GAAI,KAAA,CAAM,SAAA;AAAA,EAC5C;AAAA,EAEA,YAAA,CACE,UACA,SAAA,EACqB;AACrB,IAAA,MAAM,KAAA,GAA6B;AAAA,MACjC,MAAM,QAAA,CAAS,IAAA;AAAA,MACf,MAAM,QAAA,CAAS;AAAA,KACjB;AAEA,IAAA,MAAM,SAAA,GAAY,IAAA,CAAK,OAAA,CAAQ,UAAA,CAAW,SAAS,CAAA;AAEnD,IAAA,IAAI,SAAA,EAAW;AACb,MAAA,KAAA,CAAM,SAAA,GAAY,SAAA;AAAA,IACpB;AAEA,IAAA,IAAI,SAAA,IAAa,IAAA,CAAK,OAAA,CAAQ,aAAA,EAAe;AAC3C,MAAA,KAAA,CAAM,aAAA,GAAgB,IAAA,CAAK,OAAA,CAAQ,aAAA,CAAc,SAAS,CAAA;AAAA,IAC5D;AAEA,IAAA,IAAI,SAAA,IAAa,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU;AACtC,MAAA,KAAA,CAAM,YAAA,GAAe,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,SAAS,CAAA;AAAA,IACtD;AAEA,IAAA,IAAI,SAAA,IAAa,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU;AACtC,MAAA,KAAA,CAAM,YAAA,GAAe,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,SAAS,CAAA;AAAA,IACtD;AAGA,IAAA,IAAI,KAAK,mBAAA,EAAqB;AAC5B,MAAA,MAAM,GAAG,oBAAoB,CAAA,GAAI,IAAA,CAAK,oBAAoB,YAAA,EAAa;AAEvE,MAAA,IAAI,aAAa,oBAAA,EAAsB;AACrC,QAAA,KAAA,CAAM,WAAA,GAAc,qBAAqB,SAAS,CAAA;AAAA,MACpD;AAAA,IACF;AAEA,IAAA,IAAI,SAAS,QAAA,EAAU;AACrB,MAAA,KAAA,CAAM,QAAA,GAAW,SAAS,QAAA,CAAS,GAAA;AAAA,QAAI,CAAC,KAAA,KACtC,IAAA,CAAK,YAAA,CAAa,KAAA,EAAO,GAAG,SAAS,CAAA,CAAA,EAAI,KAAA,CAAM,IAAI,CAAA,CAAE;AAAA,OACvD;AAAA,IACF;AAEA,IAAA,OAAO,KAAA;AAAA,EACT;AACF,CAAA;ACtuCO,IAAM,OAAO,MAAY;AAAC,CAAA;AAM1B,SAAS,YAAA,CACd,aACG,IAAA,EACG;AACN,EAAA,IAAI;AACF,IAAA,QAAA,CAAS,GAAG,IAAI,CAAA;AAAA,EAClB,SAAS,KAAA,EAAO;AACd,IAAAA,aAAAA,CAAO,KAAA,CAAM,iBAAA,EAAmB,+BAAA,EAAiC,KAAK,CAAA;AAAA,EACxE;AACF;;;ACOO,IAAM,UAAA,GAAuC;AAAA,EAClD,GAAA,EAAK,CAAA;AAAA,EACL,IAAA,EAAM,CAAA;AAAA,EACN,KAAA,EAAO;AACT,CAAA;AAyCO,IAAM,aAAA,GAAgD;AAAA,EAC3D,GAAA,EAAK,CAAA;AAAA,EACL,YAAA,EAAc,CAAA;AAAA,EACd,YAAA,EAAc,CAAA;AAAA,EACd,IAAA,EAAM;AACR,CAAA;;;AClCA,IAAM,SAAN,MAAa;AAAA;AAAA,EAEX,OAAA,GAAgC;AAAA,IAC9B,KAAA,EAAO,KAAA;AAAA,IACP,oBAAA,EAAsB;AAAA,GACxB;AAAA;AAAA,EAGA,iBAAA,GAAoB,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAwBpB,UAAU,MAAA,EAAqC;AAC7C,IAAA,IAAI,MAAA,CAAO,UAAU,MAAA,EAAW;AAE9B,MAAA,IAAI,EAAE,MAAA,CAAO,KAAA,IAAS,aAAA,CAAA,EAAgB;AACpC,QAAA,MAAM,IAAI,KAAA;AAAA,UACR,CAAA,oBAAA,EAAuB,MAAA,CAAO,KAAK,CAAA,qBAAA,EAAwB,MAAA,CAAO,KAAK,aAAa,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,CAAA;AAAA,SAClG;AAAA,MACF;AAEA,MAAA,IAAA,CAAK,OAAA,CAAQ,QAAQ,MAAA,CAAO,KAAA;AAC5B,MAAA,IAAA,CAAK,iBAAA,GAAoB,aAAA,CAAc,MAAA,CAAO,KAAK,CAAA;AAAA,IACrD;AACA,IAAA,IAAI,cAAc,MAAA,EAAQ;AACxB,MAAA,IAAA,CAAK,OAAA,CAAQ,WAAW,MAAA,CAAO,QAAA;AAAA,IACjC;AACA,IAAA,IAAI,MAAA,CAAO,yBAAyB,MAAA,EAAW;AAC7C,MAAA,IAAA,CAAK,OAAA,CAAQ,uBAAuB,MAAA,CAAO,oBAAA;AAAA,IAC7C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcA,SAAA,GAA0B;AACxB,IAAA,OAAO;AAAA,MACL,KAAA,EAAO,KAAK,OAAA,CAAQ,KAAA;AAAA,MACpB,QAAA,EAAU,KAAK,OAAA,CAAQ,QAAA;AAAA,MACvB,oBAAA,EAAsB,KAAK,OAAA,CAAQ;AAAA,KACrC;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBA,GAAA,CAAI,OAAA,EAAiB,OAAA,EAAA,GAAoB,IAAA,EAAuB;AAC9D,IAAA,IAAA,CAAK,SAAA,CAAU,KAAA,EAAO,OAAA,EAAS,OAAA,EAAS,IAAI,CAAA;AAAA,EAC9C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,IAAA,CAAK,OAAA,EAAiB,OAAA,EAAA,GAAoB,IAAA,EAAuB;AAC/D,IAAA,IAAA,CAAK,SAAA,CAAU,MAAA,EAAQ,OAAA,EAAS,OAAA,EAAS,IAAI,CAAA;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAkBA,KAAA,CAAM,OAAA,EAAiB,OAAA,EAAA,GAAoB,IAAA,EAAuB;AAChE,IAAA,IAAA,CAAK,SAAA,CAAU,OAAA,EAAS,OAAA,EAAS,OAAA,EAAS,IAAI,CAAA;AAAA,EAChD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBA,SAAA,CACE,KAAA,EACA,OAAA,EACA,OAAA,EACA,IAAA,EACM;AAGN,IAAA,IAAI,KAAK,OAAA,CAAQ,KAAA,KAAU,UAAU,CAAC,IAAA,CAAK,QAAQ,oBAAA,EAAsB;AACvE,MAAA;AAAA,IACF;AAIA,IAAA,MAAM,iBAAA,GAAoB,WAAW,KAAK,CAAA;AAI1C,IAAA,MAAM,iBAAA,GAAoB,oBAAoB,IAAA,CAAK,iBAAA;AAGnD,IAAA,IAAI,CAAC,iBAAA,EAAmB;AACtB,MAAA,IAAA,CAAK,eAAA,CAAgB,KAAA,EAAO,OAAA,EAAS,OAAA,EAAS,IAAI,CAAA;AAAA,IACpD;AAGA,IAAA,IAAA,CAAK,eAAA,CAAgB,KAAA,EAAO,OAAA,EAAS,OAAA,EAAS,mBAAmB,IAAI,CAAA;AAAA,EACvE;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAiBA,eAAA,CACE,KAAA,EACA,OAAA,EACA,OAAA,EACA,IAAA,EACM;AAGN,IAAA,IACE,OAAO,OAAA,KAAY,WAAA,IACnB,OAAO,OAAA,CAAQ,KAAK,MAAM,UAAA,EAC1B;AAIA,MAAA,MAAM,mBAAmB,OAAA,GAAU,CAAA,CAAA,EAAI,OAAO,CAAA,EAAA,EAAK,OAAO,CAAA,CAAA,GAAK,OAAA;AAE/D,MAAA,OAAA,CAAQ,KAAK,CAAA,CAAE,gBAAA,EAAkB,GAAG,IAAI,CAAA;AAAA,IAC1C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAsBA,eAAA,CACE,KAAA,EACA,OAAA,EACA,OAAA,EACA,mBACA,IAAA,EACM;AAEN,IAAA,IACE,CAAC,KAAK,OAAA,CAAQ,QAAA,IACb,CAAC,IAAA,CAAK,OAAA,CAAQ,wBAAwB,iBAAA,EACvC;AACA,MAAA;AAAA,IACF;AAIA,IAAA,IAAI;AACF,MAAA,IAAA,CAAK,QAAQ,QAAA,CAAS,KAAA,EAAO,OAAA,EAAS,OAAA,EAAS,GAAG,IAAI,CAAA;AAAA,IACxD,SAAS,KAAA,EAAO;AAGd,MAAA,IACE,OAAO,OAAA,KAAY,WAAA,IACnB,OAAO,OAAA,CAAQ,UAAU,UAAA,EACzB;AACA,QAAA,OAAA,CAAQ,KAAA,CAAM,+BAA+B,KAAK,CAAA;AAAA,MACpD;AAAA,IACF;AAAA,EACF;AACF,CAAA;AAqBO,IAAMA,OAAAA,GAAS,IAAI,MAAA,EAAO;;;AChU1B,IAAM,SAAA,GAAY,CACvB,IAAA,EACA,GAAA,KAC4B;AAC5B,EAAA,IAAI,CAAC,GAAA,EAAK;AACR,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,GAAA,CAAI,QAAQ,IAAI,CAAA;AAEhB,EAAA,OAAO,GAAA;AACT,CAAA;;;ACCO,IAAM,WAAA,GAAc,CAAC,OAAA,EAAgB,SAAA,KAA4B;AACtE,EAAA,MAAM,SAAS,OAAA,CAAQ,IAAA;AACvB,EAAA,MAAM,WAAW,SAAA,CAAU,IAAA;AAI3B,EAAA,MAAM,WAAW,MAAA,EAAQ,MAAA;AACzB,EAAA,MAAM,aAAa,QAAA,EAAU,MAAA;AAG7B,EAAA,MAAM,UAAA,GACJ,QAAA,IAAY,UAAA,GACR,EAAE,GAAG,QAAA,EAAU,GAAG,UAAA,EAAW,GAC5B,QAAA,IAAY,UAAA,IAAc,EAAC;AAIlC,EAAA,MAAM,UAAA,GAAwB;AAAA;AAAA,IAE5B,EAAA,EAAI,CAAA;AAAA,IACJ,SAAS,EAAC;AAAA,IACV,UAAA,EAAY,KAAA;AAAA;AAAA,IAEZ,GAAG,QAAA;AAAA;AAAA,IAEH,GAAG,MAAA;AAAA;AAAA,IAEH,MAAA,EAAQ;AAAA,GACV;AAKA,EAAA,OAAO;AAAA,IACL,GAAG,OAAA;AAAA,IACH,IAAA,EAAM;AAAA,GACR;AACF,CAAA;;;AC7CA,IAAM,kBAAkB,IAAI,GAAA,CAAI,MAAA,CAAO,MAAA,CAAO,UAAU,CAAC,CAAA;AAGzD,IAAM,kBAAA,uBAAyB,GAAA,CAAI,CAAC,QAAQ,SAAA,EAAW,MAAA,EAAQ,UAAU,CAAC,CAAA;AAG1E,IAAM,eAAA,uBAAsB,GAAA,CAAI;AAAA,EAC9B,SAAA;AAAA,EACA,kBAAA;AAAA,EACA,qBAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA;AACF,CAAC,CAAA;AAEM,IAAM,WAAA,GAAN,cAA0B,KAAA,CAAM;AAAA;AAAA;AAAA,EAK5B,OAAA;AAAA,EACA,IAAA;AAAA,EACA,QAAA;AAAA;AAAA;AAAA,EAIT,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAqCA,YACE,IAAA,EACA;AAAA,IACE,OAAA;AAAA,IACA,OAAA;AAAA,IACA,IAAA;AAAA,IACA,QAAA;AAAA,IACA,GAAG;AAAA,GACL,GAMI,EAAC,EACL;AACA,IAAA,KAAA,CAAM,WAAW,IAAI,CAAA;AAErB,IAAA,IAAA,CAAK,IAAA,GAAO,IAAA;AACZ,IAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AACf,IAAA,IAAA,CAAK,IAAA,GAAO,IAAA;AAEZ,IAAA,IAAA,CAAK,QAAA,GAAW,QAAA,GAAW,eAAA,CAAgB,QAAQ,CAAA,GAAI,MAAA;AAIvD,IAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,IAAI,CAAA,EAAG;AAC/C,MAAA,IAAI,kBAAA,CAAmB,GAAA,CAAI,GAAG,CAAA,EAAG;AAC/B,QAAA,MAAM,IAAI,SAAA;AAAA,UACR,+CAA+C,GAAG,CAAA,CAAA;AAAA,SACpD;AAAA,MACF;AAEA,MAAA,IAAI,CAAC,eAAA,CAAgB,GAAA,CAAI,GAAG,CAAA,EAAG;AAC7B,QAAA,IAAA,CAAK,GAAG,CAAA,GAAI,KAAA;AAAA,MACd;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAuBA,QAAQ,OAAA,EAAuB;AAC7B,IAAA,IAAA,CAAK,IAAA,GAAO,OAAA;AAGZ,IAAA,IAAI,eAAA,CAAgB,GAAA,CAAI,IAAA,CAAK,OAAO,CAAA,EAAG;AACrC,MAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AAAA,IACjB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAsBA,iBAAiB,GAAA,EAAkB;AAEjC,IAAA,IAAI,CAAC,GAAA,EAAK;AACR,MAAA,MAAM,IAAI,SAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,IAAA,CAAK,UAAU,GAAA,CAAI,OAAA;AACnB,IAAA,IAAA,CAAK,QAAQ,GAAA,CAAI,KAAA;AACjB,IAAA,IAAA,CAAK,KAAA,GAAQ,IAAI,KAAA,IAAS,EAAA;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA0BA,oBAAoB,MAAA,EAAuC;AAEzD,IAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,MAAM,CAAA,EAAG;AACjD,MAAA,IAAI,kBAAA,CAAmB,GAAA,CAAI,GAAG,CAAA,EAAG;AAC/B,QAAA,MAAM,IAAI,SAAA;AAAA,UACR,mEAAmE,GAAG,CAAA,CAAA;AAAA,SACxE;AAAA,MACF;AAEA,MAAA,IAAI,CAAC,eAAA,CAAgB,GAAA,CAAI,GAAG,CAAA,EAAG;AAC7B,QAAA,IAAA,CAAK,GAAG,CAAA,GAAI,KAAA;AAAA,MACd;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAqBA,SAAS,GAAA,EAAsB;AAC7B,IAAA,OAAO,GAAA,IAAO,IAAA;AAAA,EAChB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAsBA,SAAS,GAAA,EAAsB;AAC7B,IAAA,OAAO,KAAK,GAAG,CAAA;AAAA,EACjB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA6BA,MAAA,GAAkC;AAChC,IAAA,MAAM,MAAA,GAAkC;AAAA,MACtC,MAAM,IAAA,CAAK,IAAA;AAAA,MACX,SAAS,IAAA,CAAK;AAAA,KAChB;AAEA,IAAA,IAAI,IAAA,CAAK,YAAY,MAAA,EAAW;AAC9B,MAAA,MAAA,CAAO,UAAU,IAAA,CAAK,OAAA;AAAA,IACxB;AACA,IAAA,IAAI,IAAA,CAAK,SAAS,MAAA,EAAW;AAC3B,MAAA,MAAA,CAAO,OAAO,IAAA,CAAK,IAAA;AAAA,IACrB;AACA,IAAA,IAAI,IAAA,CAAK,aAAa,MAAA,EAAW;AAC/B,MAAA,MAAA,CAAO,WAAW,IAAA,CAAK,QAAA;AAAA,IACzB;AAKA,IAAA,MAAM,WAAA,uBAAkB,GAAA,CAAI;AAAA,MAC1B,MAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,MAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA,KACD,CAAA;AAED,IAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,MAAA,IAAI,MAAA,CAAO,OAAO,IAAA,EAAM,GAAG,KAAK,CAAC,WAAA,CAAY,GAAA,CAAI,GAAG,CAAA,EAAG;AACrD,QAAA,MAAA,CAAO,GAAG,CAAA,GAAI,IAAA,CAAK,GAAG,CAAA;AAAA,MACxB;AAAA,IACF;AAEA,IAAA,OAAO,MAAA;AAAA,EACT;AACF;;;ACxTO,IAAM,sBAAA,GAAyB,CACpC,MAAA,EACA,IAAA,EACA,OAAA,KACS;AACT,EAAA,MAAM,SAAA,GAAY,OAAA,GAAU,EAAE,OAAA,KAAY,EAAC;AAE3C,EAAA,IAAI,WAAW,MAAA,EAAW;AAExB,IAAA;AAAA,EACF;AAEA,EAAA,IAAI,OAAO,WAAW,SAAA,EAAW;AAC/B,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,IAAA,EAAK;AAAA,IACP,CAAA,MAAO;AACL,MAAA,IAAA,CAAK,IAAI,WAAA,CAAY,UAAA,CAAW,cAAA,EAAgB,SAAS,CAAC,CAAA;AAAA,IAC5D;AAEA,IAAA;AAAA,EACF;AAEA,EAAA,IAAI,OAAA,CAAQ,MAAM,CAAA,EAAG;AAEnB,IAAA,IAAA,CAAK,QAAW,MAAM,CAAA;AAEtB,IAAA;AAAA,EACF;AAEA,EAAA,IAAI,SAAA,CAAuC,MAAM,CAAA,EAAG;AAMlD,IAAA,KAAK,MAAA,CAAO,IAAA;AAAA,MACV,CAAC,MAAA,KAAW;AAEV,QAAA,IAAI,OAAO,WAAW,SAAA,EAAW;AAC/B,UAAA,IAAI,MAAA,EAAQ;AACV,YAAA,IAAA,EAAK;AAAA,UACP,CAAA,MAAO;AACL,YAAA,IAAA,CAAK,IAAI,WAAA,CAAY,UAAA,CAAW,cAAA,EAAgB,SAAS,CAAC,CAAA;AAAA,UAC5D;AAAA,QACF,CAAA,MAAO;AACL,UAAA,IAAA,CAAK,QAAW,MAAM,CAAA;AAAA,QACxB;AAAA,MACF,CAAA;AAAA,MACA,CAAC,MAAA,KAAoB;AACnB,QAAA,IAAI,KAAA,GAIA,SAAA;AAEJ,QAAA,IAAI,kBAAkB,KAAA,EAAO;AAC3B,UAAA,KAAA,GAAQ;AAAA,YACN,GAAG,SAAA;AAAA,YACH,SAAS,MAAA,CAAO,OAAA;AAAA,YAChB,OAAO,MAAA,CAAO;AAAA,WAChB;AAGA,UAAA,IAAI,OAAA,IAAW,MAAA,IAAU,MAAA,CAAO,KAAA,KAAU,MAAA,EAAW;AACnD,YAAA,KAAA,CAAM,QAAQ,MAAA,CAAO,KAAA;AAAA,UACvB;AAAA,QACF,CAAA,MAAA,IAAW,MAAA,IAAU,OAAO,MAAA,KAAW,QAAA,EAAU;AAC/C,UAAA,KAAA,GAAQ,EAAE,GAAG,SAAA,EAAW,GAAG,MAAA,EAAO;AAAA,QACpC;AAEA,QAAA,IAAA,CAAK,IAAI,WAAA,CAAY,UAAA,CAAW,cAAA,EAAgB,KAAK,CAAC,CAAA;AAAA,MACxD;AAAA,KACF;AAEA,IAAA;AAAA,EACF;AAIA,EAAA,IAAA;AAAA,IACE,IAAI,WAAA,CAAY,UAAA,CAAW,cAAA,EAAgB;AAAA,MACzC,GAAG,SAAA;AAAA,MACH,OAAA,EAAS,CAAA,+BAAA,EAAkC,OAAO,MAAM,CAAA;AAAA,KACzD;AAAA,GACH;AACF,CAAA;;;AC5EO,SAASY,aAAAA,CACd,QAAA,EACA,KAAA,EACA,KAAA,EACA,MAAA,EACM;AACN,EAAA,IAAI;AACF,IAAA,QAAA,CAAS,OAAO,KAAK,CAAA;AAAA,EACvB,SAAS,MAAA,EAAQ;AACf,IAAAZ,OAAAA,CAAO,KAAA,CAAM,MAAA,EAAQ,oBAAA,EAAsB,MAAM,CAAA;AAAA,EACnD;AACF;;;ACfA,IAAM,wBAAA,uBAA+B,GAAA,CAAI;AAAA,EACvC,MAAA;AAAA,EACA,SAAA;AAAA,EACA,MAAA;AAAA,EACA;AACF,CAAC,CAAA;AAwBM,SAAS,aAAA,CACd,QACA,OAAA,EACmB;AAEnB,EAAA,MAAM,IAAA,GAA0B,OAAA,GAAU,EAAE,OAAA,KAAY,EAAC;AAGzD,EAAA,IAAI,kBAAkB,KAAA,EAAO;AAC3B,IAAA,OAAO;AAAA,MACL,GAAG,IAAA;AAAA,MACH,SAAS,MAAA,CAAO,OAAA;AAAA,MAChB,OAAO,MAAA,CAAO,KAAA;AAAA;AAAA,MAEd,GAAI,WAAW,MAAA,IACb,MAAA,CAAO,UAAU,MAAA,IAAa,EAAE,KAAA,EAAO,MAAA,CAAO,KAAA;AAAM,KACxD;AAAA,EACF;AAGA,EAAA,IAAI,MAAA,IAAU,OAAO,MAAA,KAAW,QAAA,EAAU;AACxC,IAAA,MAAM,WAAoC,EAAC;AAE3C,IAAA,KAAA,MAAW,CAAC,GAAA,EAAK,KAAK,KAAK,MAAA,CAAO,OAAA,CAAQ,MAAM,CAAA,EAAG;AAEjD,MAAA,IAAI,CAAC,wBAAA,CAAyB,GAAA,CAAI,GAAG,CAAA,EAAG;AACtC,QAAA,QAAA,CAAS,GAAG,CAAA,GAAI,KAAA;AAAA,MAClB;AAAA,IACF;AAEA,IAAA,OAAO,EAAE,GAAG,IAAA,EAAM,GAAG,QAAA,EAAS;AAAA,EAChC;AAIA,EAAA,OAAO,IAAA;AACT;;;AC7DA,IAAM,OAAA,GAAU,gBAAA;AAGT,IAAM,qBAAA,GAAwB,CACnC,KAAA,EACA,OAAA,EACA,WACA,QAAA,EACA,SAAA,EACA,aACA,QAAA,KACS;AACT,EAAA,IAAI,YAAA,GAAe,OAAA;AACnB,EAAA,MAAM,iBAAA,GAAoB,SAAS,MAAA,CAAO,CAAC,SAAS,KAAA,CAAM,GAAA,CAAI,IAAI,CAAC,CAAA;AAEnE,EAAA,IAAI,iBAAA,CAAkB,WAAW,CAAA,EAAG;AAClC,IAAAY,aAAAA,CAAa,QAAA,EAAU,MAAA,EAAW,YAAA,EAAc,OAAO,CAAA;AAEvD,IAAA;AAAA,EACF;AAEA,EAAA,IAAI,KAAA,GAAQ,CAAA;AAIZ,EAAA,MAAM,IAAA,GAAe,CAAC,GAAA,EAAK,KAAA,KAAU;AACnC,IAAA,IAAI,GAAA,EAAK;AAEP,MAAA,IAAI,IAAI,QAAA,EAAU;AAChB,QAAA,MAAM,oBAAA,GAAuB,IAAI,WAAA,CAAY,SAAA,EAAW;AAAA,UACtD,OAAA,EAAS,uDAAA;AAAA,UACT,mBAAmB,GAAA,CAAI;AAAA,SACxB,CAAA;AAED,QAAA,WAAA,CAAY,oBAAoB,CAAA;AAAA,MAClC,CAAA,MAAO;AACL,QAAA,WAAA,CAAY,GAAG,CAAA;AAAA,MACjB;AAAA,IACF,CAAA,MAAO;AACL,MAAA,WAAA,CAAY,QAAW,KAAK,CAAA;AAAA,IAC9B;AAAA,EACF,CAAA;AAEA,EAAA,MAAM,WAAA,GAAc,CAAC,GAAA,EAAuB,QAAA,KAA2B;AACrE,IAAA,IAAI,aAAY,EAAG;AACjB,MAAAA,aAAAA;AAAA,QACE,QAAA;AAAA,QACA,IAAI,WAAA,CAAY,UAAA,CAAW,oBAAoB,CAAA;AAAA,QAC/C,YAAA;AAAA,QACA;AAAA,OACF;AAEA,MAAA;AAAA,IACF;AAEA,IAAA,IAAI,GAAA,EAAK;AACP,MAAAA,cAAa,QAAA,EAAU,SAAA,CAAU,WAAW,GAAG,CAAA,EAAG,cAAc,OAAO,CAAA;AAEvE,MAAA;AAAA,IACF;AAKA,IAAA,IAAI,CAAC,QAAA,EAAU,CAEf,MAAA,IAAW,QAAA,KAAa,YAAA,IAAgB,OAAA,CAAQ,QAAQ,CAAA,EAAG;AAEzD,MAAA,IAAI,QAAA,CAAS,IAAA,KAAS,YAAA,CAAa,IAAA,EAAM;AACvC,QAAA,MAAM,qBAAA,GAAwB,IAAI,WAAA,CAAY,SAAA,EAAW;AAAA,UACvD,OAAA,EAAS,4DAAA;AAAA,UACT,iBAAA,EAAmB;AAAA,YACjB,MAAM,QAAA,CAAS,IAAA;AAAA,YACf,QAAQ,QAAA,CAAS,MAAA;AAAA,YACjB,MAAM,QAAA,CAAS;AAAA;AACjB,SACD,CAAA;AAED,QAAAA,aAAAA,CAAa,QAAA,EAAU,qBAAA,EAAuB,YAAA,EAAc,OAAO,CAAA;AAEnE,QAAA;AAAA,MACF;AAGA,MAAA,MAAM,aACJ,QAAA,CAAS,MAAA,KAAW,aAAa,MAAA,IACjC,QAAA,CAAS,SAAS,YAAA,CAAa,IAAA;AAEjC,MAAA,IAAI,UAAA,EAAY;AACd,QAAAZ,OAAAA,CAAO,KAAA;AAAA,UACL,iBAAA;AAAA,UACA,0CAAA;AAAA,UACA,EAAE,IAAA,EAAM,YAAA,EAAc,EAAA,EAAI,QAAA;AAAS,SACrC;AAAA,MACF;AAEA,MAAA,YAAA,GAAe,WAAA,CAAY,UAAU,YAAY,CAAA;AAAA,IACnD;AAEA,IAAA,IAAI,KAAA,IAAS,kBAAkB,MAAA,EAAQ;AACrC,MAAAY,aAAAA,CAAa,QAAA,EAAU,MAAA,EAAW,YAAA,EAAc,OAAO,CAAA;AAEvD,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,OAAA,GAAU,kBAAkB,KAAA,EAAO,CAAA;AAGzC,IAAA,MAAM,MAAA,GAAS,KAAA,CAAM,GAAA,CAAI,OAAO,CAAA;AAEhC,IAAA,IAAI;AACF,MAAA,MAAM,MAAA,GAAS,MAAA,CAAO,YAAA,EAAc,SAAA,EAAW,IAAI,CAAA;AAEnD,MAAA,sBAAA,CAAuB,MAAA,EAAQ,MAAM,OAAO,CAAA;AAAA,IAC9C,SAAS,SAAA,EAAoB;AAE3B,MAAA,IAAA;AAAA,QACE,IAAI,WAAA;AAAA,UACF,UAAA,CAAW,cAAA;AAAA,UACX,aAAA,CAAc,WAAW,OAAO;AAAA;AAClC,OACF;AAAA,IACF;AAAA,EACF,CAAA;AAEA,EAAA,WAAA,EAAY;AACd,CAAA;;;AC9HA,IAAMC,QAAAA,GAAU,iBAAA;AAGT,IAAM,oBAAoB,CAC/B,mBAAA,EACA,OAAA,EACA,SAAA,EACA,aACA,QAAA,KACS;AACT,EAAA,IAAI,YAAA,GAAe,OAAA;AACnB,EAAA,IAAI,KAAA,GAAQ,CAAA;AAIZ,EAAA,MAAM,IAAA,GAAe,CAAC,GAAA,EAAK,KAAA,KAAU;AACnC,IAAA,IAAI,GAAA,EAAK;AACP,MAAA,WAAA,CAAY,GAAG,CAAA;AAAA,IACjB,CAAA,MAAO;AACL,MAAA,WAAA,CAAY,QAAW,KAAK,CAAA;AAAA,IAC9B;AAAA,EACF,CAAA;AAEA,EAAA,MAAM,WAAA,GAAc,CAAC,GAAA,EAAuB,QAAA,KAA2B;AACrE,IAAA,IAAI,aAAY,EAAG;AACjB,MAAAD,aAAAA;AAAA,QACE,QAAA;AAAA,QACA,IAAI,WAAA,CAAY,UAAA,CAAW,oBAAoB,CAAA;AAAA,QAC/C,YAAA;AAAA,QACAC;AAAA,OACF;AAEA,MAAA;AAAA,IACF;AAEA,IAAA,IAAI,GAAA,EAAK;AACP,MAAAD,aAAAA;AAAA,QACE,QAAA;AAAA,QACA,SAAA,CAAU,UAAA,CAAW,cAAA,EAAgB,GAAG,CAAA;AAAA,QACxC,YAAA;AAAA,QACAC;AAAA,OACF;AAEA,MAAA;AAAA,IACF;AAKA,IAAA,IAAI,CAAC,QAAA,EAAU,CAEf,MAAA,IAAW,QAAA,KAAa,YAAA,IAAgB,OAAA,CAAQ,QAAQ,CAAA,EAAG;AACzD,MAAA,MAAM,UAAA,GACJ,QAAA,CAAS,IAAA,KAAS,YAAA,CAAa,IAAA,IAC/B,QAAA,CAAS,MAAA,KAAW,YAAA,CAAa,MAAA,IACjC,QAAA,CAAS,IAAA,KAAS,YAAA,CAAa,IAAA;AAEjC,MAAA,IAAI,UAAA,EAAY;AACd,QAAAb,OAAAA,CAAO,KAAA;AAAA,UACLa,QAAAA;AAAA,UACA,oDAAA;AAAA,UACA,EAAE,IAAA,EAAM,YAAA,EAAc,EAAA,EAAI,QAAA;AAAS,SACrC;AAAA,MACF;AAEA,MAAA,YAAA,GAAe,WAAA,CAAY,UAAU,YAAY,CAAA;AAAA,IACnD;AAEA,IAAA,IAAI,KAAA,IAAS,oBAAoB,MAAA,EAAQ;AACvC,MAAAD,aAAAA,CAAa,QAAA,EAAU,MAAA,EAAW,YAAA,EAAcC,QAAO,CAAA;AAEvD,MAAA;AAAA,IACF;AAEA,IAAA,MAAM,YAAA,GAAe,oBAAoB,KAAA,EAAO,CAAA;AAEhD,IAAA,IAAI;AACF,MAAA,MAAM,MAAA,GAAS,YAAA,CAAa,YAAA,EAAc,SAAA,EAAW,IAAI,CAAA;AAEzD,MAAA,sBAAA,CAAuB,QAAQ,IAAI,CAAA;AAAA,IACrC,SAAS,SAAA,EAAoB;AAC3B,MAAA,IAAA;AAAA,QACE,IAAI,WAAA,CAAY,UAAA,CAAW,cAAA,EAAgB,aAAA,CAAc,SAAS,CAAC;AAAA,OACrE;AAAA,IACF;AAAA,EACF,CAAA;AAEA,EAAA,WAAA,EAAY;AACd,CAAA;;;ACtFO,SAAS,UAAA,CACd,IAAA,EACA,OAAA,EACA,SAAA,EACA,MACA,kBAAA,EACU;AAEV,EAAA,IAAI,SAAA,GAAY,KAAA;AAChB,EAAA,IAAI,SAAA,GAAY,KAAA;AAGhB,EAAA,MAAM,CAAC,sBAAA,EAAwB,oBAAoB,CAAA,GACjD,KAAK,qBAAA,EAAsB;AAC7B,EAAA,MAAM,mBAAA,GAAsB,KAAK,sBAAA,EAAuB;AACxD,EAAA,MAAM,cAAA,GAAiB,OAAA,CAAQ,IAAA,KAAS,SAAA,CAAU,aAAA;AAMlD,EAAA,MAAM,WAAA,GAAc,MAAM,SAAA,IAAa,CAAC,KAAK,QAAA,EAAS;AAEtD,EAAA,MAAM,SAAS,MAAM;AACnB,IAAA,IAAI,CAAC,SAAA,IAAa,CAAC,SAAA,EAAW;AAC5B,MAAA,SAAA,GAAY,IAAA;AACZ,MAAA,QAAA,CAAS,IAAI,WAAA,CAAY,UAAA,CAAW,oBAAoB,CAAC,CAAA;AAAA,IAC3D;AAAA,EACF,CAAA;AAEA,EAAA,MAAM,QAAA,GAAW,CAAC,GAAA,EAAkC,KAAA,KAAkB;AACpE,IAAA,IAAI,SAAA,EAAW;AACb,MAAA;AAAA,IACF;AAEA,IAAA,SAAA,GAAY,IAAA;AACZ,IAAA,kBAAA,CAAmB,GAAA,EAAK,SAAS,OAAO,CAAA;AAAA,EAC1C,CAAA;AAGA,EAAA,MAAM,gBAAgB,MAAY;AAChC,IAAA,MAAM,EAAE,YAAA,EAAc,UAAA,EAAW,GAAI,iBAAA,CAAkB,SAAS,SAAS,CAAA;AAGzE,IAAA,MAAM,mBACJ,SAAA,IAAa,CAAC,IAAA,CAAK,eAAA,IAAmB,aAAa,MAAA,GAAS,CAAA;AAC9D,IAAA,MAAM,cAAA,GAAiB,CAAC,cAAA,IAAkB,UAAA,CAAW,MAAA,GAAS,CAAA;AAC9D,IAAA,MAAM,mBAAA,GAAsB,oBAAoB,MAAA,GAAS,CAAA;AAGzD,IAAA,MAAM,eAAA,GAAkB,CAAC,QAAA,KAA2B;AAClD,MAAA,IAAI,gBAAA,EAAkB;AACpB,QAAA,qBAAA;AAAA,UACE,sBAAA;AAAA,UACA,OAAA;AAAA,UACA,SAAA;AAAA,UACA,YAAA;AAAA,UACA,UAAA,CAAW,iBAAA;AAAA,UACX,WAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF,CAAA,MAAO;AACL,QAAA,QAAA,CAAS,QAAW,OAAO,CAAA;AAAA,MAC7B;AAAA,IACF,CAAA;AAEA,IAAA,MAAM,aAAA,GAAgB,CAAC,KAAA,EAAc,QAAA,KAA2B;AAC9D,MAAA,IAAI,cAAA,EAAgB;AAClB,QAAA,qBAAA;AAAA,UACE,oBAAA;AAAA,UACA,KAAA;AAAA,UACA,SAAA;AAAA,UACA,UAAA;AAAA,UACA,UAAA,CAAW,eAAA;AAAA,UACX,WAAA;AAAA,UACA,CAAC,KAAK,QAAA,KAAa;AACjB,YAAA,QAAA,CAAS,KAAK,QAAQ,CAAA;AAAA,UACxB;AAAA,SACF;AAAA,MACF,CAAA,MAAO;AAEL,QAAA,QAAA,CAAS,QAAW,KAAK,CAAA;AAAA,MAC3B;AAAA,IACF,CAAA;AAEA,IAAA,MAAM,aAAA,GAAgB,CAAC,KAAA,EAAc,QAAA,KAA2B;AAC9D,MAAA,IAAI,mBAAA,EAAqB;AACvB,QAAA,iBAAA;AAAA,UACE,mBAAA;AAAA,UACA,KAAA;AAAA,UACA,SAAA;AAAA,UACA,WAAA;AAAA,UACA,CAAC,KAAK,QAAA,KAAa;AACjB,YAAA,QAAA,CAAS,KAAK,QAAQ,CAAA;AAAA,UACxB;AAAA,SACF;AAAA,MACF,CAAA,MAAO;AAEL,QAAA,QAAA,CAAS,QAAW,KAAK,CAAA;AAAA,MAC3B;AAAA,IACF,CAAA;AAGA,IAAA,MAAM,wBAAA,GAAyC,CAC7C,gBAAA,EACA,kBAAA,KACG;AACH,MAAA,IAAI,gBAAA,EAAkB;AACpB,QAAA,QAAA,CAAS,kBAAkB,kBAAkB,CAAA;AAE7C,QAAA;AAAA,MACF;AAGA,MAAA,IAAI,SAAA,EAAW;AACb,QAAA,MAAM,cAAA,GAAiB,SAAA,CAAU,OAAA,CAAQ,IAAI,CAAA;AAC7C,QAAA,MAAM,sBAAA,GAAyB,SAAA,CAAU,SAAA,CAAU,IAAI,CAAA;AACvD,QAAA,MAAM,SAAA,GAAY,IAAI,GAAA,CAAI,cAAc,CAAA;AAExC,QAAA,KAAA,MAAW,QAAQ,sBAAA,EAAwB;AACzC,UAAA,IAAI,CAAC,UAAU,GAAA,CAAI,IAAI,KAAK,sBAAA,CAAuB,GAAA,CAAI,IAAI,CAAA,EAAG;AAC5D,YAAA,IAAA,CAAK,mBAAmB,IAAI,CAAA;AAAA,UAC9B;AAAA,QACF;AAAA,MACF;AAEA,MAAA,QAAA,CAAS,QAAW,kBAAkB,CAAA;AAAA,IACxC,CAAA;AAEA,IAAA,MAAM,wBAAA,GAAyC,CAC7C,gBAAA,EACA,kBAAA,KACG;AACH,MAAA,IAAI,gBAAA,EAAkB;AACpB,QAAA,QAAA,CAAS,kBAAkB,kBAAkB,CAAA;AAE7C,QAAA;AAAA,MACF;AAEA,MAAA,aAAA,CAAc,oBAAoB,wBAAwB,CAAA;AAAA,IAC5D,CAAA;AAEA,IAAA,MAAM,0BAAA,GAA2C,CAAC,GAAA,EAAK,KAAA,KAAU;AAC/D,MAAA,IAAI,GAAA,EAAK;AACP,QAAA,QAAA,CAAS,KAAK,KAAK,CAAA;AAEnB,QAAA;AAAA,MACF;AAEA,MAAA,aAAA,CAAc,OAAO,wBAAwB,CAAA;AAAA,IAC/C,CAAA;AAGA,IAAA,eAAA,CAAgB,0BAA0B,CAAA;AAAA,EAC5C,CAAA;AAGA,EAAA,aAAA,EAAc;AAEd,EAAA,OAAO,MAAA;AACT;;;ACrKA,IAAMC,QAAO,MAAY;AAAC,CAAA;AAM1B,IAAM,YAAA,GAAuB,MAAA,CAAO,MAAA,CAAO,EAAE,CAAA;AAC7C,IAAM,UAAA,GAAgC,MAAA,CAAO,MAAA,CAAO,EAAE,CAAA;AAK/C,SAAS,qBAAqB,IAAA,EAAuC;AAC1E,EAAA,IAAI,OAAO,SAAS,QAAA,EAAU;AAC5B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,2DAAA,EAA8D,kBAAA,CAAmB,IAAI,CAAC,CAAA;AAAA,KACxF;AAAA,EACF;AACF;AAKO,SAAS,2BAAA,CACd,OAAA,EACA,SAAA,EACA,IAAA,EACA,UACA,WAAA,EACM;AAEN,EAAA,IACE,CAAC,OAAA,IACD,OAAO,OAAA,KAAY,QAAA,IACnB,OAAQ,OAAA,CAAkB,IAAA,KAAS,QAAA,IACnC,OAAQ,OAAA,CAAkB,IAAA,KAAS,QAAA,EACnC;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,kFAAA;AAAA,KACF;AAAA,EACF;AAGA,EAAA,IACE,SAAA,KAAc,MAAA,KACb,CAAC,SAAA,IACA,OAAO,cAAc,QAAA,IACrB,OAAQ,SAAA,CAAoB,IAAA,KAAS,QAAA,CAAA,EACvC;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,8EAAA;AAAA,KACF;AAAA,EACF;AAGA,EAAA,IAAI,OAAO,IAAA,KAAS,QAAA,IAAY,IAAA,KAAS,IAAA,EAAM;AAC7C,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,8EAAA,EAAiF,kBAAA,CAAmB,IAAI,CAAC,CAAA;AAAA,KAC3G;AAAA,EACF;AAGA,EAAA,IAAI,OAAO,aAAa,UAAA,EAAY;AAClC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,kEAAA,EAAqE,kBAAA,CAAmB,QAAQ,CAAC,CAAA;AAAA,KACnG;AAAA,EACF;AAGA,EAAA,IAAI,OAAO,gBAAgB,SAAA,EAAW;AACpC,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,oEAAA,EAAuE,kBAAA,CAAmB,WAAW,CAAC,CAAA;AAAA,KACxG;AAAA,EACF;AACF;AAKO,SAAS,6BAAA,CACd,YACA,IAAA,EACM;AAEN,EAAA,IACE,UAAA,KAAe,UACf,OAAO,UAAA,KAAe,eACrB,OAAO,UAAA,KAAe,QAAA,IAAY,UAAA,KAAe,IAAA,CAAA,EAClD;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,4CAAA,EAA+C,kBAAA,CAAmB,UAAU,CAAC,CAAA,yDAAA;AAAA,KAC/E;AAAA,EACF;AAGA,EAAA,IAAI,IAAA,KAAS,MAAA,IAAa,OAAO,IAAA,KAAS,UAAA,EAAY;AACpD,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,oEAAA,EAAuE,kBAAA,CAAmB,IAAI,CAAC,CAAA;AAAA,KACjG;AAAA,EACF;AACF;AAKO,SAAS,yBAAA,CACd,MACA,UAAA,EACmC;AACnC,EAAA,IAAI,CAAC,mBAAA,CAAoB,IAAI,CAAA,EAAG;AAC9B,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,QAAA,EAAW,UAAU,CAAA,mBAAA,EAAsB,kBAAA,CAAmB,IAAI,CAAC,CAAA,oCAAA;AAAA,KACrE;AAAA,EACF;AACF;AAYO,SAAS,iBAAA,CACd,YAAA,EACA,UAAA,EACA,IAAA,EACoB;AACpB,EAAA,IAAI,OAAO,iBAAiB,UAAA,EAAY;AAEtC,IAAA,OAAO,EAAE,MAAA,EAAQ,YAAA,EAAc,IAAA,EAAM,UAAA,EAAY,UAAU,YAAA,EAAa;AAAA,EAC1E;AAKA,EAAA,MAAM,SAAS,YAAA,IAAgB,YAAA;AAE/B,EAAA,IAAI,OAAO,eAAe,UAAA,EAAY;AACpC,IAAA,OAAO,EAAE,MAAA,EAAQ,IAAA,EAAM,UAAA,EAAY,UAAU,UAAA,EAAW;AAAA,EAC1D;AAEA,EAAA,OAAO;AAAA,IACL,MAAA;AAAA,IACA,MAAM,UAAA,IAAc,UAAA;AAAA,IACpB,UAAU,IAAA,IAAQA;AAAA,GACpB;AACF;AAKO,SAAS,0BAAA,CACd,YACA,IAAA,EAC2B;AAC3B,EAAA,IAAI,OAAO,eAAe,UAAA,EAAY;AACpC,IAAA,OAAO,EAAE,IAAA,EAAM,UAAA,EAAY,QAAA,EAAU,UAAA,EAAW;AAAA,EAClD;AAEA,EAAA,OAAO;AAAA,IACL,MAAM,UAAA,IAAc,UAAA;AAAA,IACpB,UAAU,IAAA,IAAQA;AAAA,GACpB;AACF;;;ACpJO,IAAM,sBAAN,MAA0B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAU/B,eAAA;AAAA,EAEA,WAAA,GAAc,KAAA;AAAA,EACd,wBAAA,GAA4C,IAAA;AAAA;AAAA,EAG5C,UAAA;AAAA,EACA,oBAAA;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,KAAA,GAAgC;AAElC,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,eAAA,GAA0C;AAE5C,IAAA,IAAI,CAAC,KAAK,oBAAA,EAAsB;AAC9B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,oBAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,OAAO,qBAAqB,IAAA,EAAuC;AACjE,IAAA,oBAAA,CAAqB,IAAI,CAAA;AAAA,EAC3B;AAAA,EAEA,OAAO,2BAAA,CACL,OAAA,EACA,SAAA,EACA,IAAA,EACA,UACA,WAAA,EACM;AACN,IAAA,2BAAA;AAAA,MACE,OAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,QAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA,EAEA,OAAO,6BAAA,CACL,UAAA,EACA,IAAA,EACM;AACN,IAAA,6BAAA,CAA8B,YAAY,IAAI,CAAA;AAAA,EAChD;AAAA,EAEA,OAAO,yBAAA,CACL,IAAA,EACA,UAAA,EACmC;AACnC,IAAA,yBAAA,CAA0B,MAAM,UAAU,CAAA;AAAA,EAC5C;AAAA,EAEA,OAAO,iBAAA,CACL,YAAA,EACA,UAAA,EACA,IAAA,EACoB;AACpB,IAAA,OAAO,iBAAA,CAAkB,YAAA,EAAc,UAAA,EAAY,IAAI,CAAA;AAAA,EACzD;AAAA,EAEA,OAAO,0BAAA,CACL,UAAA,EACA,IAAA,EAC2B;AAC3B,IAAA,OAAO,0BAAA,CAA2B,YAAY,IAAI,CAAA;AAAA,EACpD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,gBAAgB,IAAA,EAAoC;AAClD,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,0BAA0B,IAAA,EAAoC;AAC5D,IAAA,IAAA,CAAK,oBAAA,GAAuB,IAAA;AAAA,EAC9B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,YAAA,GAAwB;AACtB,IAAA,OAAO,IAAA,CAAK,eAAA,EAAgB,IAAK,IAAA,CAAK,WAAA;AAAA,EACxC;AAAA;AAAA;AAAA;AAAA,EAKA,MAAA,GAAe;AACb,IAAA,IAAI,KAAK,wBAAA,EAA0B;AACjC,MAAA,IAAA,CAAK,wBAAA,EAAyB;AAC9B,MAAA,IAAA,CAAK,wBAAA,GAA2B,IAAA;AAAA,IAClC;AAEA,IAAA,IAAA,CAAK,WAAA,GAAc,KAAA;AAAA,EACrB;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,eAAA,CACE,OAAA,EACA,SAAA,EACA,IAAA,EACA,UACA,WAAA,EACU;AACV,IAAA,MAAM,OAAO,IAAA,CAAK,KAAA;AAClB,IAAA,MAAM,iBAAiB,IAAA,CAAK,eAAA;AAG5B,IAAA,IAAI,KAAK,WAAA,EAAa;AACpB,MAAAd,aAAAA,CAAO,IAAA;AAAA,QACL,iBAAA;AAAA,QACA;AAAA,OAEF;AAAA,IACF;AAGA,IAAA,IAAA,CAAK,MAAA,EAAO;AAIZ,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA;AAGnB,IAAA,IAAA,CAAK,oBAAA,CAAqB,MAAA,CAAO,gBAAA,EAAkB,OAAA,EAAS,SAAS,CAAA;AAGrE,IAAA,MAAM,kBAAA,GAAqB,CAAC,GAAA,EAA8B,KAAA,KAAiB;AACzE,MAAA,IAAA,CAAK,WAAA,GAAc,KAAA;AACnB,MAAA,IAAA,CAAK,wBAAA,GAA2B,IAAA;AAEhC,MAAA,IAAI,CAAC,GAAA,EAAK;AAMR,QAAA,IACE,KAAA,CAAM,SAAS,SAAA,CAAU,aAAA,IACzB,KAAK,QAAA,CAAS,KAAA,CAAM,IAAI,CAAA,EACxB;AACA,UAAA,IAAA,CAAK,SAAS,KAAK,CAAA;AAGnB,UAAA,IAAI,WAAA,EAAa;AACf,YAAA,IAAA,CAAK,oBAAA;AAAA,cACH,MAAA,CAAO,kBAAA;AAAA,cACP,KAAA;AAAA,cACA,SAAA;AAAA,cACA;AAAA,aACF;AAAA,UACF;AAGA,UAAA,YAAA,CAAa,QAAA,EAAU,QAAW,KAAK,CAAA;AAAA,QACzC,CAAA,MAAO;AAEL,UAAA,MAAM,WAAA,GAAc,IAAI,WAAA,CAAY,UAAA,CAAW,eAAA,EAAiB;AAAA,YAC9D,WAAW,KAAA,CAAM;AAAA,WAClB,CAAA;AAED,UAAA,YAAA,CAAa,UAAU,WAAW,CAAA;AAClC,UAAA,IAAA,CAAK,oBAAA;AAAA,YACH,MAAA,CAAO,gBAAA;AAAA,YACP,MAAA;AAAA,YACA,KAAK,QAAA,EAAS;AAAA,YACd;AAAA,WACF;AAAA,QACF;AAEA,QAAA;AAAA,MACF;AAGA,MAAA,IAAI,GAAA,CAAI,IAAA,KAAS,UAAA,CAAW,oBAAA,EAAsB;AAChD,QAAA,IAAA,CAAK,oBAAA,CAAqB,MAAA,CAAO,iBAAA,EAAmB,OAAA,EAAS,SAAS,CAAA;AAAA,MACxE,CAAA,MAAO;AACL,QAAA,IAAA,CAAK,oBAAA;AAAA,UACH,MAAA,CAAO,gBAAA;AAAA,UACP,OAAA;AAAA,UACA,SAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAEA,MAAA,YAAA,CAAa,UAAU,GAAG,CAAA;AAAA,IAC5B,CAAA;AAGA,IAAA,IAAA,CAAK,wBAAA,GAA2B,UAAA;AAAA,MAC9B,cAAA;AAAA,MACA,OAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA;AAAA,KACF;AAEA,IAAA,OAAO,IAAA,CAAK,wBAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,QAAA,CACE,IAAA,EACA,MAAA,EACA,IAAA,EACA,QAAA,EACU;AACV,IAAA,MAAM,OAAO,IAAA,CAAK,KAAA;AAGlB,IAAA,IAAI,CAAC,IAAA,CAAK,eAAA,EAAgB,EAAG;AAC3B,MAAA,MAAM,GAAA,GAAM,IAAI,WAAA,CAAY,UAAA,CAAW,kBAAkB,CAAA;AAEzD,MAAA,YAAA,CAAa,UAAU,GAAG,CAAA;AAE1B,MAAA,OAAO,IAAA;AAAA,IACT;AAGA,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,sBAAA,CAAuB,IAAA,EAAM,MAAM,CAAA;AAEvD,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAM,GAAA,GAAM,IAAI,WAAA,CAAY,UAAA,CAAW,eAAe,CAAA;AAEtD,MAAA,YAAA,CAAa,UAAU,GAAG,CAAA;AAC1B,MAAA,IAAA,CAAK,oBAAA;AAAA,QACH,MAAA,CAAO,gBAAA;AAAA,QACP,MAAA;AAAA,QACA,KAAK,QAAA,EAAS;AAAA,QACd;AAAA,OACF;AAEA,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,MAAM,EAAE,KAAA,EAAO,KAAA,EAAO,QAAA,EAAS,GAAI,MAAA;AAGnC,IAAA,MAAM,UAAU,IAAA,CAAK,SAAA;AAAA,MACnB,KAAA,CAAM,IAAA;AAAA,MACN,KAAA,CAAM,MAAA;AAAA,MACN,KAAK,SAAA,CAAU,KAAA,CAAM,IAAA,EAAM,KAAA,CAAM,QAAQ,QAAQ,CAAA;AAAA,MACjD;AAAA,QACE,QAAQ,KAAA,CAAM,IAAA;AAAA,QACd,OAAA,EAAS,IAAA;AAAA,QACT,UAAA,EAAY,KAAK,UAAA,IAAc;AAAA;AACjC,KACF;AAIA,IAAA,IAAI,KAAK,cAAA,EAAgB;AAEvB,MAAA,YAAA,CAAa,QAAA,EAAU,QAAW,OAAO,CAAA;AAEzC,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,MAAM,SAAA,GAAY,KAAK,QAAA,EAAS;AAGhC,IAAA,IACE,CAAC,IAAA,CAAK,MAAA,IACN,CAAC,IAAA,CAAK,KAAA,IACN,IAAA,CAAK,cAAA,CAAe,SAAA,EAAW,OAAA,EAAS,KAAK,CAAA,EAC7C;AACA,MAAA,MAAM,GAAA,GAAM,IAAI,WAAA,CAAY,UAAA,CAAW,WAAW,CAAA;AAElD,MAAA,YAAA,CAAa,UAAU,GAAG,CAAA;AAC1B,MAAA,IAAA,CAAK,oBAAA;AAAA,QACH,MAAA,CAAO,gBAAA;AAAA,QACP,OAAA;AAAA,QACA,SAAA;AAAA,QACA;AAAA,OACF;AAEA,MAAA,OAAO,IAAA;AAAA,IACT;AAIA,IAAA,OAAO,KAAK,eAAA,CAAgB,OAAA,EAAS,SAAA,EAAW,IAAA,EAAM,UAAU,IAAI,CAAA;AAAA,EACtE;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,iBAAA,CAAkB,MAAyB,QAAA,EAA4B;AACrE,IAAA,MAAM,OAAO,IAAA,CAAK,KAAA;AAClB,IAAA,MAAM,OAAA,GAAU,KAAK,UAAA,EAAW;AAEhC,IAAA,IAAI,CAAC,QAAQ,YAAA,EAAc;AACzB,MAAA,OAAO,IAAA;AAAA,IACT;AAEA,IAAA,OAAO,IAAA,CAAK,QAAA;AAAA,MACV,OAAA,CAAQ,YAAA;AAAA,MACR,OAAA,CAAQ,aAAA;AAAA,MACR,IAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF,CAAA;;;ACjYO,IAAMc,QAAO,MAAY;AAAC,CAAA;AAmB1B,IAAM,6BAA6B,IAAI,WAAA;AAAA,EAC5C,UAAA,CAAW;AACb,CAAA;AAKO,IAAM,+BAA+B,IAAI,WAAA;AAAA,EAC9C,UAAA,CAAW;AACb,CAAA;;;ACbO,IAAM,uBAAA,GAA0B,CACrC,IAAA,KACiE;AACjE,EAAA,MAAM,CAAC,KAAA,EAAO,MAAM,CAAA,GAAI,IAAA;AAExB,EAAA,IAAI,CAAC,KAAA,EAAO;AACV,IAAA,OAAO,CAAC,QAAWA,KAAI,CAAA;AAAA,EACzB;AACA,EAAA,IAAI,OAAO,UAAU,UAAA,EAAY;AAC/B,IAAA,OAAO,CAAC,QAAW,KAAK,CAAA;AAAA,EAC1B;AAEA,EAAA,OAAO,CAAC,KAAA,EAAO,MAAA,IAAUA,KAAI,CAAA;AAC/B,CAAA;AAKO,IAAM,iBAAA,GAAoB,CAC/B,WAAA,EACA,IAAA,KACsB;AACtB,EAAA,IAAI,OAAO,gBAAgB,QAAA,EAAU;AACnC,IAAA,OAAO,IAAA,CAAK,UAAU,WAAW,CAAA;AAAA,EACnC;AAKA,EAAA,IAAI,CAAC,OAAA,CAAQ,WAAW,CAAA,EAAG;AACzB,IAAA,OAAO,MAAA;AAAA,EACT;AAMA,EAAA,IAAI;AACF,IAAA,IAAA,CAAK,SAAA,CAAU,WAAA,CAAY,IAAA,EAAM,WAAA,CAAY,MAAM,CAAA;AAAA,EACrD,CAAA,CAAA,MAAQ;AACN,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,OAAO,WAAA;AACT,CAAA;;;AC5BO,IAAM,2BAAN,MAA+B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUpC,eAAA;AAAA,EAQA,QAAA,GAAW,KAAA;AAAA,EACX,OAAA,GAAU,KAAA;AAAA;AAAA,EAGV,UAAA;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,KAAA,GAAqC;AAEvC,IAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,OAAO,kBAAkB,IAAA,EAAuB;AAC9C,IAAA,IAAI,IAAA,CAAK,SAAS,CAAA,EAAG;AACnB,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,gBAAgB,IAAA,EAAyC;AACvD,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA;AAAA,EACpB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,SAAA,GAAqB;AACnB,IAAA,OAAO,IAAA,CAAK,QAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,QAAA,GAAoB;AAClB,IAAA,OAAO,IAAA,CAAK,OAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,SAAS,IAAA,EAAkC;AACzC,IAAA,MAAM,OAAO,IAAA,CAAK,KAAA;AAClB,IAAA,MAAM,OAAA,GAAU,KAAK,UAAA,EAAW;AAChC,IAAA,MAAM,CAAC,gBAAA,EAAkB,IAAI,CAAA,GAAI,wBAAwB,IAAI,CAAA;AAE7D,IAAA,IAAI,eAAA,GAAkB,KAAA;AAOtB,IAAA,IAAI,IAAA,CAAK,QAAA,IAAY,IAAA,CAAK,OAAA,EAAS;AACjC,MAAA,eAAA,GAAkB,IAAA;AAElB,MAAA,IAAA,CAAK,4BAA4B,CAAA;AAEjC,MAAA;AAAA,IACF;AAaA,IAAA,IAAI,CAAC,gBAAA,IAAoB,CAAC,OAAA,CAAQ,YAAA,EAAc;AAC9C,MAAA,eAAA,GAAkB,IAAA;AAIlB,MAAA,IAAI,IAAA,CAAK,YAAA,CAAa,MAAA,CAAO,gBAAgB,CAAA,EAAG;AAC9C,QAAA,IAAA,CAAK,oBAAA;AAAA,UACH,MAAA,CAAO,gBAAA;AAAA,UACP,MAAA;AAAA,UACA,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAEA,MAAA,IAAA,CAAK,0BAA0B,CAAA;AAE/B,MAAA;AAAA,IACF;AAIA,IAAA,IAAA,CAAK,OAAA,GAAU,IAAA;AAEf,IAAA,MAAM,aAAA,GAAgB,CAAC,GAAA,EAAmB,KAAA,KAAkB;AAE1D,MAAA,IAAI,eAAA,EAAiB;AACnB,QAAAd,aAAAA,CAAO,IAAA,CAAK,aAAA,EAAe,0BAA0B,CAAA;AAErD,QAAA;AAAA,MACF;AAEA,MAAA,eAAA,GAAkB,IAAA;AAElB,MAAA,IAAA,CAAK,KAAK,KAAK,CAAA;AAAA,IACjB,CAAA;AAGA,IAAA,MAAM,YAAA,GAAkC;AAAA,MACtC,OAAA,EAAS;AAAA;AAAA,KACX;AAaA,IAAA,MAAM,wBAAA,GAA2B,CAC/B,GAAA,EACA,KAAA,EACA,iBAAiB,KAAA,KACd;AACH,MAAA,IAAI,GAAA,EAAK;AAEP,QAAA,IAAA,CAAK,OAAA,GAAU,KAAA;AAEf,QAAA,IAAI,cAAA,IAAkB,IAAA,CAAK,YAAA,CAAa,MAAA,CAAO,gBAAgB,CAAA,EAAG;AAGhE,UAAA,IAAA,CAAK,oBAAA;AAAA,YACH,MAAA,CAAO,gBAAA;AAAA,YACP,MAAA;AAAA,YACA,MAAA;AAAA,YACA;AAAA,WACF;AAAA,QACF;AAAA,MACF,CAAA,MAAO;AAGL,QAAA,IAAA,CAAK,QAAA,GAAW,IAAA;AAChB,QAAA,IAAA,CAAK,oBAAA,CAAqB,OAAO,YAAY,CAAA;AAE7C,QAAA,IAAA,CAAK,oBAAA,CAAqB,MAAA,CAAO,kBAAA,EAAoB,KAAA,EAAO,MAAA,EAAW;AAAA,UACrE,OAAA,EAAS;AAAA,SACV,CAAA;AAAA,MACH;AAGA,MAAA,aAAA,CAAc,KAAK,KAAK,CAAA;AAAA,IAC1B,CAAA;AAKA,IAAA,MAAM,iBAAA,GAAoB,CACxB,OAAA,EACA,UAAA,GAAgC,EAAC,KAC9B;AAEH,MAAA,IAAA,CAAK,eAAA;AAAA,QACH,OAAA;AAAA,QACA,MAAA;AAAA,QACA,UAAA;AAAA,QACA,CAAC,KAAkC,WAAA,KAAmC;AACpE,UAAA,wBAAA,CAAyB,KAAK,WAAW,CAAA;AAAA,QAC3C,CAAA;AAAA,QACA;AAAA;AAAA,OACF;AAAA,IACF,CAAA;AAIA,IAAA,MAAM,iBAAA,GAAoB,CACxB,gBAAA,EACA,aAAA,EACA,UAAA,KACG;AACH,MAAA,MAAM,YAAA,GAAe,IAAA,CAAK,UAAA,CAAW,gBAAA,EAAkB,aAAa,CAAA;AAEpE,MAAA,IAAI,CAAC,YAAA,EAAc;AACjB,QAAA,wBAAA;AAAA,UACE,IAAI,WAAA,CAAY,UAAA,CAAW,eAAA,EAAiB;AAAA,YAC1C,SAAA,EAAW;AAAA,WACZ,CAAA;AAAA,UACD,MAAA;AAAA,UACA;AAAA,SACF;AAEA,QAAA;AAAA,MACF;AAEA,MAAA,MAAM,UAAU,IAAA,CAAK,SAAA;AAAA,QACnB,YAAA,CAAa,IAAA;AAAA,QACb,YAAA,CAAa,MAAA;AAAA,QACb,IAAA,CAAK,SAAA,CAAU,YAAA,CAAa,IAAA,EAAM,aAAa,MAAM,CAAA;AAAA,QACrD;AAAA,UACE,QAAQ,YAAA,CAAa,IAAA;AAAA,UACrB,OAAA,EAAS,UAAA;AAAA,UACT,UAAA,EAAY;AAAA;AACd,OACF;AAEA,MAAA,iBAAA,CAAkB,SAAS,UAAU,CAAA;AAAA,IACvC,CAAA;AAIA,IAAA,MAAM,wBAAA,GAA2B,oBAAoB,OAAA,CAAQ,YAAA;AAG7D,IAAA,MAAM,UAAA,GAAa,iBAAA,CAAkB,wBAAA,EAA0B,IAAI,CAAA;AAGnE,IAAA,MAAM,UAAA,GACJ,OAAO,wBAAA,KAA6B,QAAA,GAChC,wBAAA,GACA,EAAA;AAKN,IAAA,IAAI,UAAA,EAAY;AACd,MAAA,iBAAA,CAAkB,YAAY,YAAY,CAAA;AAAA,IAC5C,CAAA,MAAA,IAAW,OAAA,CAAQ,YAAA,IAAgB,CAAC,gBAAA,EAAkB;AAOpD,MAAA,MAAM,SAAS,OAAA,CAAQ,aAAA;AAEvB,MAAA,iBAAA,CAAkB,OAAA,CAAQ,YAAA,EAAc,MAAA,EAAQ,YAAY,CAAA;AAAA,IAC9D,CAAA,MAAA,IAAW,QAAQ,aAAA,EAAe;AAChC,MAAA,iBAAA;AAAA,QACE,IAAA,CAAK,iBAAA,CAAkB,UAAA,EAAY,YAAY,CAAA;AAAA,QAC/C;AAAA,OACF;AAAA,IACF,CAAA,MAAO;AACL,MAAA,wBAAA;AAAA,QACE,IAAI,WAAA,CAAY,UAAA,CAAW,iBAAiB,EAAE,IAAA,EAAM,YAAY,CAAA;AAAA,QAChE,MAAA;AAAA,QACA;AAAA;AAAA,OACF;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,IAAA,GAAa;AACX,IAAA,MAAM,OAAO,IAAA,CAAK,KAAA;AAIlB,IAAA,IAAA,CAAK,OAAA,GAAU,KAAA;AAEf,IAAA,IAAI,KAAK,QAAA,EAAU;AACjB,MAAA,IAAA,CAAK,QAAA,GAAW,KAAA;AAEhB,MAAA,IAAA,CAAK,QAAA,EAAS;AAEd,MAAA,IAAA,CAAK,oBAAA,CAAqB,OAAO,WAAW,CAAA;AAAA,IAC9C;AAAA,EACF;AACF,CAAA;;;ACtVO,IAAM,iBAAN,MAEL;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,kBAAA;AAAA;AAAA;AAAA;AAAA,EAKA,iBAAA;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,aAAA,GAA+C;AAEjD,IAAA,IAAI,CAAC,KAAK,kBAAA,EAAoB;AAC5B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,kBAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA,EAKA,IAAI,YAAA,GAA8B;AAEhC,IAAA,IAAI,CAAC,KAAK,iBAAA,EAAmB;AAC3B,MAAA,MAAM,IAAI,KAAA;AAAA,QACR;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,iBAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,OAAO,kBAAkB,YAAA,EAA6B;AAEpD,IAAA,IAAI,iBAAiB,MAAA,EAAW;AAC9B,MAAA;AAAA,IACF;AAGA,IAAA,IACE,EACE,YAAA,IACA,OAAO,iBAAiB,QAAA,IACxB,YAAA,CAAa,gBAAgB,MAAA,CAAA,EAE/B;AACA,MAAA,MAAM,IAAI,SAAA;AAAA,QACR,CAAA,kFAAA,EAAqF,kBAAA,CAAmB,YAAY,CAAC,CAAA;AAAA,OACvH;AAAA,IACF;AAGA,IAAA,KAAA,MAAW,OAAO,YAAA,EAAc;AAC9B,MAAA,IAAI,MAAA,CAAO,wBAAA,CAAyB,YAAA,EAAc,GAAG,GAAG,GAAA,EAAK;AAC3D,QAAA,MAAM,IAAI,SAAA;AAAA,UACR,wDAAwD,GAAG,CAAA,CAAA;AAAA,SAC7D;AAAA,MACF;AAAA,IACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKA,YAAA,CACE,cACA,WAAA,EACM;AACN,IAAA,IAAA,CAAK,kBAAA,GAAqB,YAAA;AAC1B,IAAA,IAAA,CAAK,iBAAA,GAAoB,WAAA;AAAA,EAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,KAAA,CACE,cACA,OAAA,EACsB;AAEtB,IAAA,MAAM,IAAA,GAAO,KAAK,aAAA,EAAc;AAGhC,IAAA,MAAM,UAAA,GAAa;AAAA,MACjB,GAAG,IAAA,CAAK,YAAA;AAAA,MACR,GAAG;AAAA,KACL;AAGA,IAAA,MAAM,YAAY,OAAA,CAAQ,IAAA,CAAK,MAAA,EAAQ,IAAA,CAAK,SAAS,UAAU,CAAA;AAG/D,IAAA,KAAA,MAAW,CAAC,MAAM,OAAO,CAAA,IAAK,OAAO,OAAA,CAAQ,IAAA,CAAK,sBAAsB,CAAA,EAAG;AACzE,MAAA,SAAA,CAAU,aAAA,CAAc,MAAM,OAAO,CAAA;AAAA,IACvC;AAEA,IAAA,KAAA,MAAW,CAAC,MAAM,OAAO,CAAA,IAAK,OAAO,OAAA,CAAQ,IAAA,CAAK,oBAAoB,CAAA,EAAG;AACvE,MAAA,SAAA,CAAU,WAAA,CAAY,MAAM,OAAO,CAAA;AAAA,IACrC;AAGA,IAAA,IAAI,IAAA,CAAK,mBAAA,CAAoB,MAAA,GAAS,CAAA,EAAG;AACvC,MAAA,SAAA,CAAU,aAAA,CAAc,GAAG,IAAA,CAAK,mBAAmB,CAAA;AAAA,IACrD;AAGA,IAAA,IAAI,IAAA,CAAK,eAAA,CAAgB,MAAA,GAAS,CAAA,EAAG;AACnC,MAAA,SAAA,CAAU,SAAA,CAAU,GAAG,IAAA,CAAK,eAAe,CAAA;AAAA,IAC7C;AAGA,IAAA,IAAA,CAAK,YAAA;AAAA,MACH,SAAA;AAAA,MACA,IAAA,CAAK,WAAA;AAAA,MACL,IAAA,CAAK;AAAA,KACP;AAEA,IAAA,OAAO,SAAA;AAAA,EACT;AACF,CAAA;;;ACxIA,IAAM,mCAAmB,IAAI,GAAA,CAAY,CAAC,KAAA,EAAO,YAAA,EAAc,YAAY,CAAC,CAAA;AAE5E,SAAS,aAAa,KAAA,EAAyC;AAC7D,EAAA,OAAO,OAAO,KAAA,KAAU,QAAA,IAAY,gBAAA,CAAiB,IAAI,KAAK,CAAA;AAChE;AAEA,SAAS,YAAY,KAAA,EAAwB;AAC3C,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAC7B,IAAA,OAAO,IAAI,KAAK,CAAA,CAAA,CAAA;AAAA,EAClB;AACA,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAC7B,IAAA,OAAO,IAAA,CAAK,UAAU,KAAK,CAAA;AAAA,EAC7B;AAGA,EAAA,OAAO,OAAO,KAAK,CAAA;AACrB;AAEO,SAAS,eAAe,MAAA,EAAyC;AACtE,EAAA,IAAI,OAAO,MAAA,KAAW,QAAA,IAAY,MAAA,KAAW,IAAA,EAAM;AACjD,IAAA,MAAM,IAAI,UAAU,iCAAiC,CAAA;AAAA,EACvD;AAEA,EAAA,MAAM,GAAA,GAAM,MAAA;AAGZ,EAAA,KAAA,MAAW,GAAA,IAAO,MAAA,CAAO,IAAA,CAAK,GAAG,CAAA,EAAG;AAClC,IAAA,IAAI,GAAA,KAAQ,OAAA,IAAW,GAAA,KAAQ,UAAA,EAAY;AACzC,MAAA,MAAM,IAAI,SAAA,CAAU,CAAA,iCAAA,EAAoC,GAAG,CAAA,CAAA,CAAG,CAAA;AAAA,IAChE;AAAA,EACF;AAGA,EAAA,IAAI,OAAA,IAAW,OAAO,GAAA,CAAI,KAAA,KAAU,UAAa,CAAC,YAAA,CAAa,GAAA,CAAI,KAAK,CAAA,EAAG;AACzE,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,sBAAA,EAAyB,WAAA,CAAY,GAAA,CAAI,KAAK,CAAC,CAAA,+CAAA;AAAA,KACjD;AAAA,EACF;AAGA,EAAA,IACE,UAAA,IAAc,OACd,GAAA,CAAI,QAAA,KAAa,UACjB,OAAO,GAAA,CAAI,aAAa,UAAA,EACxB;AACA,IAAA,MAAM,IAAI,SAAA;AAAA,MACR,CAAA,wCAAA,EAA2C,OAAO,GAAA,CAAI,QAAQ,CAAA;AAAA,KAChE;AAAA,EACF;AAEA,EAAA,OAAO,IAAA;AACT;;;ACOO,IAAM,MAAA,GAAN,MAAM,OAAA,CAEX;AAAA;AAAA;AAAA;AAAA,EAQS,QAAA;AAAA,EACA,OAAA;AAAA,EACA,aAAA;AAAA,EACA,WAAA;AAAA,EACA,MAAA;AAAA,EACA,OAAA;AAAA,EACA,eAAA;AAAA,EACA,WAAA;AAAA,EACA,QAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,MAAA;AAAA;AAAA;AAAA;AAAA,EAKT,UAAA,GAA+B,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMtB,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWT,WAAA,CACE,SAAgC,EAAC,EACjC,UAA4B,EAAC,EAC7B,YAAA,GAA6B,EAAC,EAC9B;AAEA,IAAA,IAAI,OAAA,CAAQ,MAAA,IAAU,cAAA,CAAe,OAAA,CAAQ,MAAM,CAAA,EAAG;AACpD,MAAAA,aAAAA,CAAO,SAAA,CAAU,OAAA,CAAQ,MAAM,CAAA;AAC/B,MAAA,OAAO,OAAA,CAAQ,MAAA;AAAA,IACjB;AAOA,IAAA,gBAAA,CAAiB,eAAA,CAAgB,SAAS,aAAa,CAAA;AAGvD,IAAA,MAAM,UAAA,GAAa,QAAQ,UAAA,IAAc,KAAA;AAGzC,IAAA,IAAI,CAAC,UAAA,EAAY;AACf,MAAA,qBAAA,CAAsB,0BAAA;AAAA,QACpB,YAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAIA,IAAA,IAAI,CAAC,UAAA,IAAc,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG;AACpC,MAAA,eAAA,CAAgB,qBAAqB,MAAM,CAAA;AAC3C,MAAA,eAAA,CAAgB,eAAe,MAAM,CAAA;AAAA,IACvC;AAMA,IAAA,IAAA,CAAK,QAAA,GAAW,IAAI,gBAAA,CAAiB,OAAO,CAAA;AAC5C,IAAA,IAAA,CAAK,OAAA,GAAU,YAAA,CAAa,OAAA,CAAQ,MAAM,CAAA;AAC1C,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAI,qBAAA,CAAoC,YAAY,CAAA;AACzE,IAAA,IAAA,CAAK,WAAA,GAAc,IAAI,mBAAA,EAAoB;AAC3C,IAAA,IAAA,CAAK,MAAA,GAAS,IAAI,cAAA,EAAe;AACjC,IAAA,IAAA,CAAK,OAAA,GAAU,IAAI,eAAA,CAA8B,MAAA,EAAQ,UAAU,CAAA;AACnE,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAI,uBAAA,EAAsC;AACjE,IAAA,IAAA,CAAK,WAAA,GAAc,IAAI,mBAAA,EAAkC;AACzD,IAAA,IAAA,CAAK,QAAA,GAAW,IAAI,gBAAA,EAA+B;AACnD,IAAA,IAAA,CAAK,WAAA,GAAc,IAAI,mBAAA,EAAoB;AAC3C,IAAA,IAAA,CAAK,UAAA,GAAa,IAAI,wBAAA,EAAyB;AAC/C,IAAA,IAAA,CAAK,MAAA,GAAS,IAAI,cAAA,EAA6B;AAC/C,IAAA,IAAA,CAAK,WAAA,GAAc,UAAA;AAMnB,IAAA,IAAA,CAAK,kBAAA,EAAmB;AAWxB,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA,CAAK,IAAI,CAAA;AACvC,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,IAAI,CAAA;AAC7C,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,IAAI,CAAA;AAC7C,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA,CAAK,IAAI,CAAA;AACvC,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA,CAAK,IAAI,CAAA;AACvC,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,IAAI,CAAA;AAG7C,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAA,CAAK,aAAA,CAAc,IAAA,CAAK,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AACzC,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AACzC,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,IAAI,CAAA;AAC7C,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,IAAI,CAAA;AAG7C,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AACzC,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA,CAAK,IAAI,CAAA;AACvC,IAAA,IAAA,CAAK,gBAAA,GAAmB,IAAA,CAAK,gBAAA,CAAiB,IAAA,CAAK,IAAI,CAAA;AACvD,IAAA,IAAA,CAAK,cAAA,GAAiB,IAAA,CAAK,cAAA,CAAe,IAAA,CAAK,IAAI,CAAA;AACnD,IAAA,IAAA,CAAK,YAAA,GAAe,IAAA,CAAK,YAAA,CAAa,IAAA,CAAK,IAAI,CAAA;AAC/C,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA,CAAK,UAAA,CAAW,IAAA,CAAK,IAAI,CAAA;AAC3C,IAAA,IAAA,CAAK,gBAAA,GAAmB,IAAA,CAAK,gBAAA,CAAiB,IAAA,CAAK,IAAI,CAAA;AAGvD,IAAA,IAAA,CAAK,UAAA,GAAa,IAAA,CAAK,UAAA,CAAW,IAAA,CAAK,IAAI,CAAA;AAC3C,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AACzC,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AAGzC,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA,CAAK,IAAI,CAAA;AACvC,IAAA,IAAA,CAAK,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,IAAA,CAAK,IAAI,CAAA;AACjC,IAAA,IAAA,CAAK,IAAA,GAAO,IAAA,CAAK,IAAA,CAAK,IAAA,CAAK,IAAI,CAAA;AAG/B,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAA,CAAK,aAAA,CAAc,IAAA,CAAK,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,IAAA,CAAK,IAAI,CAAA;AAG7C,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AAGzC,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAA,CAAK,aAAA,CAAc,IAAA,CAAK,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAA,CAAK,eAAA,CAAgB,IAAA,CAAK,IAAI,CAAA;AAGrD,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAA,CAAK,aAAA,CAAc,IAAA,CAAK,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAA,CAAK,eAAA,CAAgB,IAAA,CAAK,IAAI,CAAA;AACrD,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAA,CAAK,aAAA,CAAc,IAAA,CAAK,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAA,CAAK,eAAA,CAAgB,IAAA,CAAK,IAAI,CAAA;AACrD,IAAA,IAAA,CAAK,gBAAA,GAAmB,IAAA,CAAK,gBAAA,CAAiB,IAAA,CAAK,IAAI,CAAA;AACvD,IAAA,IAAA,CAAK,aAAA,GAAgB,IAAA,CAAK,aAAA,CAAc,IAAA,CAAK,IAAI,CAAA;AACjD,IAAA,IAAA,CAAK,iBAAA,GAAoB,IAAA,CAAK,iBAAA,CAAkB,IAAA,CAAK,IAAI,CAAA;AAGzD,IAAA,IAAA,CAAK,gBAAA,GAAmB,IAAA,CAAK,gBAAA,CAAiB,IAAA,CAAK,IAAI,CAAA;AAGvD,IAAA,IAAA,CAAK,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,IAAA,CAAK,IAAI,CAAA;AACvC,IAAA,IAAA,CAAK,iBAAA,GAAoB,IAAA,CAAK,iBAAA,CAAkB,IAAA,CAAK,IAAI,CAAA;AACzD,IAAA,IAAA,CAAK,eAAA,GAAkB,IAAA,CAAK,eAAA,CAAgB,IAAA,CAAK,IAAI,CAAA;AAGrD,IAAA,IAAA,CAAK,SAAA,GAAY,IAAA,CAAK,SAAA,CAAU,IAAA,CAAK,IAAI,CAAA;AAGzC,IAAA,IAAA,CAAK,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,IAAA,CAAK,IAAI,CAAA;AAAA,EACnC;AAAA;AAAA;AAAA;AAAA,EAMA,SAAS,MAAA,EAA2D;AAClE,IAAA,MAAM,aAAa,KAAA,CAAM,OAAA,CAAQ,MAAM,CAAA,GAAI,MAAA,GAAS,CAAC,MAAM,CAAA;AAE3D,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AAErB,MAAA,eAAA,CAAgB,qBAAqB,UAAU,CAAA;AAG/C,MAAA,eAAA,CAAgB,cAAA;AAAA,QACd,UAAA;AAAA,QACA,IAAA,CAAK,QAAQ,OAAA,EAAQ;AAAA,QACrB,IAAA,CAAK,QAAQ,gBAAA;AAAiB,OAChC;AAAA,IACF;AAGA,IAAA,IAAA,CAAK,OAAA,CAAQ,UAAU,UAAU,CAAA;AAEjC,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,YAAY,IAAA,EAAoB;AAE9B,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,wBAAwB,IAAI,CAAA;AAAA,IAC9C;AAGA,IAAA,MAAM,SAAA,GAAY,KAAK,OAAA,CAAQ,mBAAA;AAAA,MAC7B,IAAA;AAAA,MACA,IAAA,CAAK,MAAA,CAAO,GAAA,EAAI,EAAG,IAAA;AAAA,MACnB,IAAA,CAAK,YAAY,YAAA;AAAa,KAChC;AAEA,IAAA,IAAI,CAAC,SAAA,EAAW;AACd,MAAA,OAAO,IAAA;AAAA,IACT;AAGA,IAAA,MAAM,UAAA,GAAa,IAAA,CAAK,OAAA,CAAQ,WAAA,CAAY,IAAI,CAAA;AAEhD,IAAA,IAAI,CAAC,UAAA,EAAY;AACf,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,oBAAA;AAAA,QACA,UAAU,IAAI,CAAA,6BAAA;AAAA,OAChB;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,WAAA,GAAoB;AAElB,IAAA,MAAM,QAAA,GAAW,KAAK,OAAA,CAAQ,mBAAA;AAAA,MAC5B,IAAA,CAAK,YAAY,YAAA;AAAa,KAChC;AAEA,IAAA,IAAI,CAAC,QAAA,EAAU;AACb,MAAA,OAAO,IAAA;AAAA,IACT;AAGA,IAAA,IAAA,CAAK,QAAQ,WAAA,EAAY;AAGzB,IAAA,IAAA,CAAK,gBAAgB,QAAA,EAAS;AAG9B,IAAA,IAAA,CAAK,MAAA,CAAO,IAAI,MAAS,CAAA;AAEzB,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,SAAS,IAAA,EAA+C;AACtD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,iBAAA,CAAkB,MAAM,UAAU,CAAA;AAAA,IACpC;AAEA,IAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA;AAAA,EACnC;AAAA,EAEA,SAAS,IAAA,EAAuB;AAC9B,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,iBAAA,CAAkB,MAAM,UAAU,CAAA;AAAA,IACpC;AAEA,IAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,QAAA,CAAS,IAAI,CAAA;AAAA,EACnC;AAAA,EAEA,WAAA,CAAY,MAAc,OAAA,EAAgD;AAExE,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,4BAAA,CAA6B,MAAM,OAAO,CAAA;AAAA,IAC5D;AAKA,IAAA,MAAM;AAAA,MACJ,SAAA;AAAA,MACA,aAAA;AAAA,MACA,YAAA;AAAA,MACA,YAAA;AAAA,MACA;AAAA,KACF,GAAI,OAAA;AAGJ,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,gCAAA;AAAA,QACd,SAAA;AAAA,QACA,aAAA;AAAA,QACA,YAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,IAAI,IAAA,CAAK,WAAA,CAAY,YAAA,EAAa,EAAG;AACnC,MAAAA,aAAAA,CAAO,KAAA;AAAA,QACL,oBAAA;AAAA,QACA,mBAAmB,IAAI,CAAA,sEAAA;AAAA,OACzB;AAAA,IACF;AAGA,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,IAAA,CAAK,OAAA,CAAQ,mBAAA,CAAoB,IAAA,EAAM,SAAS,CAAA;AAAA,IAClD;AAGA,IAAA,IAAA,CAAK,OAAA,CAAQ,kBAAkB,IAAA,EAAM;AAAA,MACnC,SAAA;AAAA,MACA,aAAA;AAAA,MACA,YAAA;AAAA,MACA;AAAA,KACD,CAAA;AAID,IAAA,IAAI,gBAAgB,MAAA,EAAW;AAC7B,MAAA,IAAI,gBAAgB,IAAA,EAAM;AACxB,QAAA,IAAA,CAAK,eAAA,CAAgB,gBAAA,CAAiB,IAAA,EAAM,IAAI,CAAA;AAAA,MAClD,CAAA,MAAO;AACL,QAAA,IAAA,CAAK,WAAA,CAAY,MAAM,WAAW,CAAA;AAAA,MACpC;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAMA,aAAA,CACE,IAAA,EACA,MAAA,EACA,cAAA,EACA,iBAAA,EACS;AACT,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,yBAAA;AAAA,QACd,IAAA;AAAA,QACA,MAAA;AAAA,QACA,cAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,IAAI,SAAS,EAAA,EAAI;AACf,MAAAA,aAAAA,CAAO,IAAA;AAAA,QACL,aAAA;AAAA,QACA;AAAA,OACF;AAEA,MAAA,OAAO,KAAA;AAAA,IACT;AAEA,IAAA,OAAO,KAAK,OAAA,CAAQ,aAAA;AAAA,MAClB,IAAA;AAAA,MACA,MAAA;AAAA,MACA,cAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA,EAEA,SAAA,CAAU,OAAe,MAAA,EAAyB;AAChD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,sBAAsB,KAAK,CAAA;AAAA,IAC7C;AAEA,IAAA,OAAO,IAAA,CAAK,QAAQ,SAAA,CAAU,KAAA,EAAO,QAAQ,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA;AAAA,EAClE;AAAA,EAEA,SAAA,CACE,MACA,MAAA,EAC0B;AAC1B,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,sBAAsB,IAAI,CAAA;AAAA,IAC5C;AAEA,IAAA,OAAO,IAAA,CAAK,QAAQ,SAAA,CAAiB,IAAA,EAAM,QAAQ,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA;AAAA,EACxE;AAAA,EAEA,YAAY,QAAA,EAAwB;AAClC,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,wBAAwB,QAAQ,CAAA;AAAA,IAClD;AAEA,IAAA,IAAA,CAAK,OAAA,CAAQ,YAAY,QAAQ,CAAA;AAAA,EACnC;AAAA,EAEA,WAAA,GAAsB;AACpB,IAAA,OAAO,IAAA,CAAK,QAAQ,WAAA,EAAY;AAAA,EAClC;AAAA;AAAA;AAAA;AAAA,EAMA,SAAA,CACE,IAAA,EACA,MAAA,EACA,IAAA,EACA,MACA,OAAA,EACc;AACd,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,cAAA,CAAe,qBAAA,CAAsB,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,OAAO,CAAA;AAAA,IAClE;AAEA,IAAA,OAAO,KAAK,MAAA,CAAO,SAAA,CAAiB,MAAM,MAAA,EAAQ,IAAA,EAAM,MAAM,OAAO,CAAA;AAAA,EACvE;AAAA,EAEA,QAAA,GAEc;AACZ,IAAA,OAAO,IAAA,CAAK,OAAO,GAAA,EAAW;AAAA,EAChC;AAAA,EAEA,gBAAA,GAAsC;AACpC,IAAA,OAAO,IAAA,CAAK,OAAO,WAAA,EAAY;AAAA,EACjC;AAAA,EAEA,cAAA,CACE,MAAA,EACA,MAAA,EACA,iBAAA,GAAoB,IAAA,EACX;AACT,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,cAAA,CAAe,0BAAA;AAAA,QACb,MAAA;AAAA,QACA,MAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,MAAA,CAAO,cAAA,CAAe,MAAA,EAAQ,QAAQ,iBAAiB,CAAA;AAAA,EACrE;AAAA,EAEA,YAAA,CACE,WACA,WAAA,EACgB;AAChB,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,wBAAA;AAAA,QACd,SAAA;AAAA,QACA,WAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,YAAA,CAAgB,SAAA,EAAW,WAAW,CAAA;AAAA,EAC5D;AAAA,EAEA,UAAA,CACE,WACA,WAAA,EAC4B;AAC5B,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,wBAAA;AAAA,QACd,SAAA;AAAA,QACA,WAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,MAAM,EAAE,IAAA,EAAM,MAAA,KAAW,IAAA,CAAK,YAAA,CAAa,WAAW,WAAW,CAAA;AAEjE,IAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,kBAAA,CAAmB,IAAA,EAAM,MAAM,CAAA;AAAA,EACrD;AAAA,EAEA,iBACE,QAAA,EACgD;AAChD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,eAAA,CAAgB,6BAA6B,QAAQ,CAAA;AAAA,IACvD;AAEA,IAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,gBAAA,CAAiB,QAAQ,CAAA;AAAA,EAC/C;AAAA;AAAA;AAAA;AAAA,EAMA,UAAA,GAAsB;AACpB,IAAA,OAAO,IAAA,CAAK,SAAS,GAAA,EAAI;AAAA,EAC3B;AAAA,EAEA,UAAmC,MAAA,EAAuB;AACxD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,gBAAA,CAAiB,kBAAA,CAAmB,QAAQ,WAAW,CAAA;AACvD,MAAA,gBAAA,CAAiB,oBAAA,CAAqB,QAAQ,WAAW,CAAA;AAAA,IAC3D;AAEA,IAAA,OAAO,IAAA,CAAK,QAAA,CAAS,SAAA,CAAU,MAAM,CAAA;AAAA,EACvC;AAAA,EAEA,SAAA,CAAU,QAAuB,KAAA,EAAqC;AACpE,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,gBAAA,CAAiB,kBAAA,CAAmB,QAAQ,WAAW,CAAA;AACvD,MAAA,gBAAA,CAAiB,oBAAA,CAAqB,QAAQ,WAAW,CAAA;AACzD,MAAA,gBAAA,CAAiB,iBAAA,CAAkB,IAAA,CAAK,QAAA,CAAS,QAAA,IAAY,MAAM,CAAA;AACnE,MAAA,gBAAA,CAAiB,mBAAA,CAAoB,MAAA,EAAQ,KAAA,EAAO,WAAW,CAAA;AAAA,IACjE;AAEA,IAAA,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,MAAA,EAAQ,KAAK,CAAA;AAE/B,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAMA,QAAA,GAAoB;AAClB,IAAA,OAAO,IAAA,CAAK,WAAW,QAAA,EAAS;AAAA,EAClC;AAAA,EAEA,SACK,IAAA,EAKG;AAEN,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,wBAAA,CAAyB,kBAAkB,IAAI,CAAA;AAAA,IACjD;AAGA,IAAA,IAAA,CAAK,SAAS,IAAA,EAAK;AAGnB,IAAA,IAAA,CAAK,OAAA,CAAQ,qBAAA,CAAsB,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA;AAGtD,IAAA,IAAA,CAAK,UAAA,CAAW,KAAA,CAAM,GAAG,IAAI,CAAA;AAE7B,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,IAAA,GAAa;AACX,IAAA,IAAA,CAAK,WAAW,IAAA,EAAK;AAGrB,IAAA,IAAA,CAAK,QAAQ,sBAAA,EAAuB;AAGpC,IAAA,IAAA,CAAK,SAAS,MAAA,EAAO;AAErB,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAMA,aAAA,CACE,MACA,oBAAA,EACM;AACN,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AAErB,MAAA,iBAAA,CAAkB,MAAM,eAAe,CAAA;AACvC,MAAA,uBAAA,CAAwB,eAAA;AAAA,QACtB,oBAAA;AAAA,QACA;AAAA,OACF;AAGA,MAAA,uBAAA,CAAwB,sBAAA;AAAA,QACtB,IAAA,CAAK,eAAA,CAAgB,aAAA,CAAc,IAAI,CAAA;AAAA,QACvC,IAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,eAAA,CAAgB,gBAAA,CAAiB,IAAI,CAAA;AAE9D,IAAA,IAAI,CAAC,WAAA,IAAe,CAAC,IAAA,CAAK,WAAA,EAAa;AACrC,MAAA,uBAAA,CAAwB,oBAAA;AAAA,QACtB,IAAA,CAAK,eAAA,CAAgB,kBAAA,EAAmB,GAAI,CAAA;AAAA,QAC5C,eAAA;AAAA,QACA,KAAK,OAAA,CAAQ;AAAA,OACf;AAAA,IACF;AAGA,IAAA,IAAA,CAAK,eAAA,CAAgB,qBAAA;AAAA,MACnB,IAAA;AAAA,MACA,oBAAA;AAAA,MACA;AAAA,KACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,WAAA,CACE,MACA,kBAAA,EACM;AACN,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AAErB,MAAA,iBAAA,CAAkB,MAAM,aAAa,CAAA;AACrC,MAAA,uBAAA,CAAwB,eAAA;AAAA,QACtB,kBAAA;AAAA,QACA;AAAA,OACF;AAGA,MAAA,uBAAA,CAAwB,sBAAA;AAAA,QACtB,IAAA,CAAK,eAAA,CAAgB,aAAA,CAAc,IAAI,CAAA;AAAA,QACvC,IAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAGA,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,eAAA,CAAgB,cAAA,CAAe,IAAI,CAAA;AAE5D,IAAA,IAAI,CAAC,WAAA,IAAe,CAAC,IAAA,CAAK,WAAA,EAAa;AACrC,MAAA,uBAAA,CAAwB,oBAAA;AAAA,QACtB,IAAA,CAAK,eAAA,CAAgB,gBAAA,EAAiB,GAAI,CAAA;AAAA,QAC1C,aAAA;AAAA,QACA,KAAK,OAAA,CAAQ;AAAA,OACf;AAAA,IACF;AAGA,IAAA,IAAA,CAAK,eAAA,CAAgB,mBAAA;AAAA,MACnB,IAAA;AAAA,MACA,kBAAA;AAAA,MACA;AAAA,KACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAMA,aAAaC,QAAAA,EAAqD;AAChE,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AAErB,MAAA,gBAAA,CAAiB,sBAAoCA,QAAO,CAAA;AAG5D,MAAA,gBAAA,CAAiB,mBAAA;AAAA,QACf,IAAA,CAAK,SAAS,KAAA,EAAM;AAAA,QACpBA,QAAAA,CAAQ,MAAA;AAAA,QACR,KAAK,OAAA,CAAQ;AAAA,OACf;AAGA,MAAA,gBAAA,CAAiB,0BAAA;AAAA,QACfA,QAAAA;AAAA,QACA,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,IAAA,CAAK,KAAK,QAAQ;AAAA,OACtC;AAAA,IACF;AAGA,IAAA,OAAO,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,GAAGA,QAAO,CAAA;AAAA,EACrC;AAAA;AAAA;AAAA;AAAA,EAMA,iBACK,WAAA,EACU;AACb,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AAErB,MAAA,mBAAA,CAAoB,0BAAwC,WAAW,CAAA;AAGvE,MAAA,mBAAA,CAAoB,oBAAA;AAAA,QAClB,WAAA;AAAA,QACA,IAAA,CAAK,YAAY,YAAA;AAAa,OAChC;AAGA,MAAA,mBAAA,CAAoB,uBAAA;AAAA,QAClB,IAAA,CAAK,YAAY,KAAA,EAAM;AAAA,QACvB,WAAA,CAAY,MAAA;AAAA,QACZ,KAAK,OAAA,CAAQ;AAAA,OACf;AAAA,IACF;AAGA,IAAA,MAAM,WAAA,GAAc,IAAA,CAAK,WAAA,CAAY,UAAA,CAAW,GAAG,WAAW,CAAA;AAG9D,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,KAAA,MAAW,EAAE,UAAA,EAAY,OAAA,EAAQ,IAAK,WAAA,EAAa;AACjD,QAAA,mBAAA,CAAoB,kBAAA;AAAA,UAClB,UAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA,IACF;AAGA,IAAA,OAAO,IAAA,CAAK,WAAA,CAAY,MAAA,CAAO,WAAW,CAAA;AAAA,EAC5C;AAAA,EAEA,eAAA,GAAwB;AACtB,IAAA,IAAA,CAAK,YAAY,KAAA,EAAM;AAEvB,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAMA,aAAA,CACE,gBACA,UAAA,EACM;AACN,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,qBAAA,CAAsB,0BAA0B,cAAc,CAAA;AAAA,IAChE;AAEA,IAAA,IAAA,CAAK,aAAA,CAAc,GAAA,CAAI,cAAA,EAAgB,UAAU,CAAA;AAEjD,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,gBAAgB,IAAA,EAA0B;AACxC,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,qBAAA,CAAsB,0BAAA,CAA2B,MAAM,iBAAiB,CAAA;AACxE,MAAA,qBAAA,CAAsB,uBAAA;AAAA,QACpB,IAAA,CAAK,cAAc,KAAA,EAAM;AAAA,QACzB,MAAA,CAAO,IAAA,CAAK,IAAI,CAAA,CAAE,MAAA;AAAA,QAClB,iBAAA;AAAA,QACA,KAAK,OAAA,CAAQ;AAAA,OACf;AAAA,IACF;AAEA,IAAA,IAAA,CAAK,aAAA,CAAc,YAAY,IAAI,CAAA;AAEnC,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,cAA4C,GAAA,EAAyB;AACnE,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,qBAAA,CAAsB,YAAA,CAAa,KAAK,eAAe,CAAA;AAAA,IACzD;AAEA,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,aAAA,CAAc,GAAA,CAAI,GAAG,CAAA;AAExC,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,qBAAA,CAAsB,wBAAA,CAAyB,OAAO,GAAa,CAAA;AAAA,IACrE;AAEA,IAAA,OAAO,KAAA;AAAA,EACT;AAAA,EAEA,eAAA,GAAyC;AACvC,IAAA,OAAO,IAAA,CAAK,cAAc,MAAA,EAAO;AAAA,EACnC;AAAA,EAEA,iBAAiB,cAAA,EAA0C;AACzD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,qBAAA,CAAsB,YAAA,CAAa,gBAAgB,kBAAkB,CAAA;AAAA,IACvE;AAEA,IAAA,IAAA,CAAK,aAAA,CAAc,OAAO,cAAc,CAAA;AAExC,IAAA,OAAO,IAAA;AAAA,EACT;AAAA,EAEA,cAAc,cAAA,EAA6C;AACzD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,qBAAA,CAAsB,YAAA,CAAa,gBAAgB,eAAe,CAAA;AAAA,IACpE;AAEA,IAAA,OAAO,IAAA,CAAK,aAAA,CAAc,GAAA,CAAI,cAAc,CAAA;AAAA,EAC9C;AAAA,EAEA,iBAAA,GAA0B;AACxB,IAAA,IAAA,CAAK,cAAc,KAAA,EAAM;AAEzB,IAAA,OAAO,IAAA;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAMA,gBAAA,CACE,WACA,EAAA,EACa;AACb,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,oBAAA,CAAqB,WAAW,EAAE,CAAA;AAAA,IACxD;AAEA,IAAA,OAAO,IAAA,CAAK,WAAA,CAAY,gBAAA,CAAiB,SAAA,EAAW,EAAE,CAAA;AAAA,EACxD;AAAA;AAAA;AAAA;AAAA,EAMA,QAAA,CACE,SAAA,EACA,iBAAA,EACA,aAAA,EACA,IAAA,EACU;AAEV,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,qBAAqB,SAAS,CAAA;AAAA,IACpD;AAGA,IAAA,MAAM,EAAE,MAAA,EAAQ,IAAA,EAAM,QAAA,KAAa,mBAAA,CAAoB,iBAAA;AAAA,MACrD,iBAAA;AAAA,MACA,aAAA;AAAA,MACA;AAAA,KACF;AAGA,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,yBAAA,CAA0B,MAAM,UAAU,CAAA;AAAA,IAChE;AAGA,IAAA,OAAO,KAAK,WAAA,CAAY,QAAA,CAAS,SAAA,EAAW,MAAA,EAAQ,MAAM,QAAQ,CAAA;AAAA,EACpE;AAAA,EAEA,iBAAA,CACE,YACA,IAAA,EACU;AAEV,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,6BAAA,CAA8B,YAAY,IAAI,CAAA;AAAA,IACpE;AAGA,IAAA,MAAM,EAAE,IAAA,EAAM,QAAA,EAAS,GAAI,mBAAA,CAAoB,0BAAA;AAAA,MAC7C,UAAA;AAAA,MACA;AAAA,KACF;AAGA,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,yBAAA,CAA0B,MAAM,mBAAmB,CAAA;AAAA,IACzE;AAGA,IAAA,OAAO,IAAA,CAAK,WAAA,CAAY,iBAAA,CAAkB,IAAA,EAAM,QAAQ,CAAA;AAAA,EAC1D;AAAA,EAEA,eAAA,CACE,OAAA,EACA,SAAA,EACA,IAAA,EACA,UACA,WAAA,EACU;AACV,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,2BAAA;AAAA,QAClB,OAAA;AAAA,QACA,SAAA;AAAA,QACA,IAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF;AAEA,IAAA,OAAO,KAAK,WAAA,CAAY,eAAA;AAAA,MACtB,OAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,QAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAMA,UAAU,QAAA,EAAoC;AAC5C,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,mBAAA,CAAoB,0BAA0B,QAAQ,CAAA;AAAA,IACxD;AAEA,IAAA,OAAO,IAAA,CAAK,WAAA,CAAY,SAAA,CAAU,QAAQ,CAAA;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA,EAMA,MAAM,YAAA,EAAmD;AACvD,IAAA,IAAI,CAAC,KAAK,WAAA,EAAa;AACrB,MAAA,cAAA,CAAe,kBAAkB,YAAY,CAAA;AAAA,IAC/C;AAEA,IAAA,OAAO,KAAK,MAAA,CAAO,KAAA;AAAA,MACjB,YAAA;AAAA,MACA,CAAC,QAAQ,OAAA,EAAS,IAAA,KAChB,IAAI,OAAA,CAAqB,MAAA,EAAQ,SAAS,IAAI;AAAA,KAClD;AAAA,EACF;AAAA,EAEA,YAAA,GAA0B;AACxB,IAAA,IAAA,CAAK,UAAA,KAAe,OAAO,MAAA,CAAO;AAAA,MAChC,UAAU,IAAA,CAAK,QAAA;AAAA,MACf,UAAU,IAAA,CAAK,QAAA;AAAA,MACf,eAAe,IAAA,CAAK,aAAA;AAAA,MACpB,WAAW,IAAA,CAAK;AAAA,KACjB,CAAA;AAED,IAAA,OAAO,IAAA,CAAK,UAAA;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,kBAAA,GAA2B;AAEzB,IAAA,IAAA,CAAK,aAAA,CAAc,SAAA,CAAU,IAAA,CAAK,OAAO,CAAA;AACzC,IAAA,IAAA,CAAK,QAAA,CAAS,SAAA,CAAU,IAAA,CAAK,OAAO,CAAA;AACpC,IAAA,IAAA,CAAK,WAAA,CAAY,SAAA,CAAU,IAAA,CAAK,OAAO,CAAA;AACvC,IAAA,IAAA,CAAK,WAAA,CAAY,SAAA,CAAU,IAAA,CAAK,OAAO,CAAA;AACvC,IAAA,IAAA,CAAK,eAAA,CAAgB,SAAA,CAAU,IAAA,CAAK,OAAO,CAAA;AAI3C,IAAA,IAAA,CAAK,eAAA,CAAgB,UAAU,IAAI,CAAA;AAGnC,IAAA,MAAM,kBAAA,GAA+D;AAAA,MACnE,eAAe,CAA+B,cAAA,KAC5C,IAAA,CAAK,aAAA,CAAc,IAAI,cAAc;AAAA,KACzC;AAEA,IAAA,IAAA,CAAK,eAAA,CAAgB,gBAAgB,kBAAkB,CAAA;AAIvD,IAAA,MAAM,UAAA,GAA+C;AAAA,MACnD,WAAA,EAAa,CAAC,IAAA,EAAM,OAAA,KAAY;AAC9B,QAAA,IAAA,CAAK,WAAA,CAAY,MAAM,OAAO,CAAA;AAAA,MAChC,CAAA;AAAA,MACA,SAAA,EAAW,CAAC,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,IAAA,KAC9B,IAAA,CAAK,MAAA,CAAO,SAAA,CAAU,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,IAAI,CAAA;AAAA,MAChD,QAAA,EAAU,MAAM,IAAA,CAAK,MAAA,CAAO,GAAA,EAAI;AAAA,MAChC,cAAA,EAAgB,CAAC,MAAA,EAAQ,MAAA,EAAQ,iBAAA,KAC/B,KAAK,MAAA,CAAO,cAAA,CAAe,MAAA,EAAQ,MAAA,EAAQ,iBAAiB;AAAA,KAChE;AAEA,IAAA,IAAA,CAAK,OAAA,CAAQ,gBAAgB,UAAU,CAAA;AACvC,IAAA,IAAA,CAAK,OAAA,CAAQ,qBAAA,CAAsB,IAAA,CAAK,eAAe,CAAA;AAEvD,IAAA,IAAA,CAAK,WAAA,CAAY,UAAU,IAAI,CAAA;AAG/B,IAAA,MAAM,cAAA,GAAuD;AAAA,MAC3D,eAAe,CAA+B,cAAA,KAC5C,IAAA,CAAK,aAAA,CAAc,IAAI,cAAc;AAAA,KACzC;AAEA,IAAA,IAAA,CAAK,WAAA,CAAY,gBAAgB,cAAc,CAAA;AAE/C,IAAA,IAAA,CAAK,QAAA,CAAS,UAAU,IAAI,CAAA;AAG5B,IAAA,MAAM,WAAA,GAAiD;AAAA,MACrD,gBAAA,EAAkB,CAAC,SAAA,EAAW,EAAA,KAC5B,KAAK,WAAA,CAAY,gBAAA,CAAiB,WAAW,EAAE,CAAA;AAAA,MACjD,SAAA,EAAW,MAAM,IAAA,CAAK,UAAA,CAAW,SAAA,EAAU;AAAA,MAC3C,eAAe,CAA+B,cAAA,KAC5C,IAAA,CAAK,aAAA,CAAc,IAAI,cAAc;AAAA,KACzC;AAEA,IAAA,IAAA,CAAK,QAAA,CAAS,gBAAgB,WAAW,CAAA;AAGzC,IAAA,MAAM,cAAA,GAAyC;AAAA,MAC7C,UAAA,EAAY,MAAM,IAAA,CAAK,QAAA,CAAS,GAAA,EAAI;AAAA,MACpC,UAAU,CAAC,IAAA,KAAS,IAAA,CAAK,OAAA,CAAQ,SAAS,IAAI,CAAA;AAAA,MAC9C,QAAA,EAAU,MAAM,IAAA,CAAK,MAAA,CAAO,GAAA,EAAI;AAAA,MAChC,QAAA,EAAU,CAAC,KAAA,KAAU;AACnB,QAAA,IAAA,CAAK,MAAA,CAAO,IAAI,KAAK,CAAA;AAAA,MACvB,CAAA;AAAA,MACA,sBAAA,EAAwB,CAAC,SAAA,EAAW,WAAA,KAAgB;AAElD,QAAA,MAAM,EAAE,IAAA,EAAM,MAAA,KAAW,IAAA,CAAK,YAAA,CAAa,WAAW,WAAW,CAAA;AAEjE,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,8BAAA,CAA+B,IAAA,EAAM,MAAM,CAAA;AAAA,MACjE,CAAA;AAAA,MACA,SAAA,EAAW,CAAC,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,IAAA,KAC9B,IAAA,CAAK,MAAA,CAAO,SAAA,CAAU,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,IAAI,CAAA;AAAA,MAChD,SAAA,EAAW,CAAC,KAAA,EAAO,MAAA,EAAQ,aACzB,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,KAAA,EAAO,MAAA,EAAQ,IAAA,CAAK,QAAA,CAAS,GAAA,IAAO,QAAQ,CAAA;AAAA,MACrE,cAAA,EAAgB,CAAC,MAAA,EAAQ,MAAA,EAAQ,iBAAA,KAC/B,KAAK,MAAA,CAAO,cAAA,CAAe,MAAA,EAAQ,MAAA,EAAQ,iBAAiB,CAAA;AAAA,MAC9D,oBAAA,EAAsB,CAAC,SAAA,EAAW,OAAA,EAAS,WAAW,GAAA,KAAQ;AAC5D,QAAA,IAAA,CAAK,WAAA,CAAY,MAAA,CAAO,SAAA,EAAW,OAAA,EAAS,WAAW,GAAG,CAAA;AAAA,MAC5D;AAAA,KACF;AAEA,IAAA,IAAA,CAAK,WAAA,CAAY,gBAAgB,cAAc,CAAA;AAE/C,IAAA,MAAM,cAAA,GAAyC;AAAA,MAC7C,qBAAA,EAAuB,MAAM,IAAA,CAAK,eAAA,CAAgB,YAAA,EAAa;AAAA,MAC/D,sBAAA,EAAwB,MAAM,IAAA,CAAK,WAAA,CAAY,YAAA,EAAa;AAAA,MAC5D,QAAA,EAAU,MAAM,IAAA,CAAK,UAAA,CAAW,QAAA,EAAS;AAAA,MACzC,kBAAA,EAAoB,CAAC,IAAA,KAAS;AAC5B,QAAA,IAAA,CAAK,eAAA,CAAgB,mBAAmB,IAAI,CAAA;AAAA,MAC9C;AAAA,KACF;AAEA,IAAA,IAAA,CAAK,WAAA,CAAY,0BAA0B,cAAc,CAAA;AAIzD,IAAA,MAAM,aAAA,GAA6C;AAAA,MACjD,UAAA,EAAY,MAAM,IAAA,CAAK,QAAA,CAAS,GAAA,EAAI;AAAA,MACpC,cAAc,CAAC,SAAA,KAAc,IAAA,CAAK,WAAA,CAAY,aAAa,SAAS,CAAA;AAAA,MACpE,oBAAA,EAAsB,CAAC,SAAA,EAAW,OAAA,EAAS,WAAW,GAAA,KAAQ;AAC5D,QAAA,IAAA,CAAK,WAAA,CAAY,MAAA,CAAO,SAAA,EAAW,OAAA,EAAS,WAAW,GAAG,CAAA;AAAA,MAC5D,CAAA;AAAA,MACA,YAAY,CAAC,SAAA,EAAW,gBACtB,IAAA,CAAK,UAAA,CAAW,WAAW,WAAW,CAAA;AAAA,MACxC,SAAA,EAAW,CAAC,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,IAAA,KAC9B,IAAA,CAAK,MAAA,CAAO,SAAA,CAAU,IAAA,EAAM,MAAA,EAAQ,IAAA,EAAM,IAAI,CAAA;AAAA,MAChD,WAAW,CAAC,KAAA,EAAO,WAAW,IAAA,CAAK,SAAA,CAAU,OAAO,MAAM,CAAA;AAAA,MAC1D,iBAAA,EAAmB,CAAC,IAAA,EAAM,OAAA,KACxB,KAAK,MAAA,CAAO,iBAAA,CAAkB,MAAM,OAAO,CAAA;AAAA,MAC7C,QAAA,EAAU,CAAC,KAAA,KAAU;AACnB,QAAA,IAAA,CAAK,MAAA,CAAO,IAAI,KAAK,CAAA;AAAA,MACvB,CAAA;AAAA;AAAA,MAEA,SAAA,EAAW,CAAC,IAAA,EAAM,MAAA,KAChB,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,IAAA,EAAM,MAAA,EAAQ,IAAA,CAAK,QAAA,CAAS,GAAA,EAAK;AAAA,KAC5D;AAEA,IAAA,IAAA,CAAK,UAAA,CAAW,gBAAgB,aAAa,CAAA;AAG7C,IAAA,IAAA,CAAK,OAAO,eAAA,CAAgB;AAAA,MAC1B,gBAAA,EAAkB,MAAM,IAAA,CAAK,OAAA,CAAQ,WAAU,CAAE,aAAA;AAAA,MACjD,SAAA,EAAW,CAAC,IAAA,EAAM,MAAA,KAChB,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,IAAA,EAAM,MAAA,EAAQ,IAAA,CAAK,QAAA,CAAS,GAAA,EAAK,CAAA;AAAA,MAC1D,cAAc,CAAC,IAAA,KAAS,IAAA,CAAK,OAAA,CAAQ,aAAa,IAAI;AAAA,KACvD,CAAA;AASD,IAAA,IAAA,CAAK,WAAA,CAAY,eAAA,GAAkB,MAAM,IAAA,CAAK,WAAW,SAAA,EAAU;AAGnE,IAAA,IAAA,CAAK,UAAA,CAAW,kBAAkB,CAChC,OAAA,EACA,WACA,IAAA,EACA,QAAA,EACA,WAAA,KAEA,IAAA,CAAK,WAAA,CAAY,eAAA;AAAA,MACf,OAAA;AAAA,MACA,SAAA;AAAA,MACA,IAAA;AAAA,MACA,QAAA;AAAA,MACA;AAAA,KACF;AAGF,IAAA,IAAA,CAAK,MAAA,CAAO,YAAA;AAAA;AAAA,MAEV,MAAM;AACJ,QAAA,MAAM,CAAC,sBAAA,EAAwB,oBAAoB,CAAA,GACjD,IAAA,CAAK,gBAAgB,YAAA,EAAa;AAEpC,QAAA,OAAO;AAAA,UACL,MAAA,EAAQ,IAAA,CAAK,OAAA,CAAQ,WAAA,EAAY;AAAA,UACjC,SAAS,EAAE,GAAG,IAAA,CAAK,QAAA,CAAS,KAAI,EAAE;AAAA,UAClC,YAAA,EAAc,IAAA,CAAK,aAAA,CAAc,MAAA,EAAO;AAAA,UACxC,sBAAA;AAAA,UACA,oBAAA;AAAA,UACA,mBAAA,EAAqB,IAAA,CAAK,WAAA,CAAY,YAAA,EAAa;AAAA,UACnD,eAAA,EAAiB,IAAA,CAAK,QAAA,CAAS,MAAA,EAAO;AAAA,UACtC,WAAA,EAAa,IAAA,CAAK,OAAA,CAAQ,SAAA,EAAU;AAAA,UACpC,kBAAA,EAAoB,IAAA,CAAK,OAAA,CAAQ,qBAAA;AAAsB,SACzD;AAAA,MACF,CAAA;AAAA;AAAA,MAEA,CAAC,SAAA,EAAW,MAAA,EAAQ,kBAAA,KAAuB;AAGzC,QAAA,MAAM,WAAA,GAAc,SAAA;AACpB,QAAA,MAAM,SAAA,GAAY,WAAA,CAAY,OAAA,CAAQ,SAAA,EAAU;AAEhD,QAAA,MAAA,CAAO,MAAA,CAAO,SAAA,CAAU,QAAA,EAAU,MAAA,CAAO,QAAQ,CAAA;AACjD,QAAA,MAAA,CAAO,MAAA,CAAO,SAAA,CAAU,QAAA,EAAU,MAAA,CAAO,QAAQ,CAAA;AACjD,QAAA,MAAA,CAAO,MAAA,CAAO,SAAA,CAAU,aAAA,EAAe,MAAA,CAAO,aAAa,CAAA;AAC3D,QAAA,MAAA,CAAO,MAAA,CAAO,SAAA,CAAU,UAAA,EAAY,MAAA,CAAO,UAAU,CAAA;AAErD,QAAA,WAAA,CAAY,OAAA,CAAQ,qBAAA,CAAsB,EAAE,GAAG,oBAAoB,CAAA;AAAA,MACrE;AAAA,KACF;AAAA,EACF;AACF;;;ACrqCO,IAAMc,aAAAA,GAAe,CAG1B,MAAA,GAAgC,EAAC,EACjC,UAA4B,EAAC,EAC7B,YAAA,GAA6B,EAAC,KACL;AACzB,EAAA,OAAO,IAAI,MAAA,CAAqB,MAAA,EAAQ,OAAA,EAAS,YAAY,CAAA;AAC/D","file":"index.js","sourcesContent":["// packages/type-guards/modules/guards/navigation.ts\n\nimport type { NavigationOptions } from \"@real-router/types\";\n\n// Constant in module scope - created once, not on every call\nconst NAVIGATION_OPTIONS_FIELDS = [\n \"replace\",\n \"reload\",\n \"skipTransition\",\n \"force\",\n \"forceDeactivate\",\n \"redirected\",\n] as const;\n\n/**\n * Type guard for NavigationOptions.\n * Validates all optional boolean fields.\n *\n * @param value - Value to check\n * @returns true if value is a valid NavigationOptions object\n *\n * @example\n * isNavigationOptions({ replace: true }); // true\n * isNavigationOptions({ reload: false, force: true }); // true\n * isNavigationOptions({ replace: \"true\" }); // false (not boolean)\n * isNavigationOptions(null); // false\n */\nexport function isNavigationOptions(\n value: unknown,\n): value is NavigationOptions {\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n // for-of instead of .every() - no iterator/callback allocation\n for (const field of NAVIGATION_OPTIONS_FIELDS) {\n const fieldValue = obj[field];\n\n if (fieldValue !== undefined && typeof fieldValue !== \"boolean\") {\n return false;\n }\n }\n\n return true;\n}\n","// packages/type-guards/modules/internal/router-error.ts\n\n/**\n * Checks if string contains at least one non-whitespace character.\n * Used to validate that route name is not empty or only whitespace.\n * Matches: any non-whitespace character (\\S = [^ \\t\\n\\r\\f])\n *\n * @internal\n */\nexport const HAS_NON_WHITESPACE = /\\S/;\n\n/**\n * Pattern for complete route validation (all segments at once).\n * Matches: single segment or multiple segments separated by dots.\n * Each segment must start with letter/underscore, followed by alphanumeric/hyphen/underscore.\n * Rejects: leading/trailing/consecutive dots, segments starting with numbers/hyphens.\n * Note: Empty string is handled by early return in validateRouteName.\n *\n * @internal\n */\nexport const FULL_ROUTE_PATTERN = /^[A-Z_a-z][\\w-]*(?:\\.[A-Z_a-z][\\w-]*)*$/;\n\n/**\n * Maximum route name length to prevent DoS and performance issues.\n * This is a technical limit, not a business constraint.\n * Real route names rarely exceed 200 characters even with deep nesting.\n *\n * @internal\n */\nexport const MAX_ROUTE_NAME_LENGTH = 10_000;\n\n/**\n * Creates a TypeError with consistent router error message format.\n *\n * @param methodName - Name of the method that triggered the error\n * @param message - Error message\n * @returns TypeError with formatted message\n * @internal\n */\nexport function createRouterError(\n methodName: string,\n message: string,\n): TypeError {\n return new TypeError(`[router.${methodName}] ${message}`);\n}\n","// packages/type-guards/modules/guards/routes.ts\n\nimport {\n FULL_ROUTE_PATTERN,\n MAX_ROUTE_NAME_LENGTH,\n} from \"../internal/router-error\";\n\n/**\n * Type guard that checks if a value is a valid route name.\n *\n * Route name rules:\n * - Must be a string\n * - Empty string (\"\") is valid and represents the root node\n * - Can use dots (.) for hierarchy (e.g., \"users.profile\")\n * - Each segment must match [a-zA-Z_][a-zA-Z0-9_-]*\n * - No consecutive dots (..)\n * - No leading/trailing dots\n * - Cannot contain only whitespace\n * - System routes (starting with @@) bypass pattern validation\n *\n * @param name - Value to check\n * @returns true if name is a valid route name string\n *\n * @example\n * // Valid names\n * isRouteName(\"\"); // true (root node)\n * isRouteName(\"home\"); // true\n * isRouteName(\"users.profile\"); // true\n * isRouteName(\"admin_panel\"); // true\n * isRouteName(\"api-v2\"); // true\n * isRouteName(\"@@router/UNKNOWN_ROUTE\"); // true (system route)\n *\n * @example\n * // Invalid names\n * isRouteName(\" \"); // false (only whitespace)\n * isRouteName(\".users\"); // false (leading dot)\n * isRouteName(\"users.\"); // false (trailing dot)\n * isRouteName(\"users..profile\"); // false (consecutive dots)\n * isRouteName(\"users.123\"); // false (segment starts with number)\n * isRouteName(\"users profile\"); // false (contains space)\n */\nexport function isRouteName(name: unknown): name is string {\n if (typeof name !== \"string\") {\n return false;\n }\n\n // Empty string is valid (represents root node)\n if (name === \"\") {\n return true;\n }\n\n // Too long is invalid\n if (name.length > MAX_ROUTE_NAME_LENGTH) {\n return false;\n }\n\n // System routes are valid (bypass pattern validation)\n if (name.startsWith(\"@@\")) {\n return true;\n }\n\n // Regular routes must match pattern\n // Note: FULL_ROUTE_PATTERN rejects whitespace-only strings\n return FULL_ROUTE_PATTERN.test(name);\n}\n","// packages/type-guards/modules/guards/params.ts\n\nimport type { Params } from \"@real-router/types\";\n\n/**\n * Internal helper to check if value is serializable (no circular refs, functions, instances).\n * Recursively validates the entire object tree with protection against circular references.\n *\n * @param value - Value to check\n * @param visited - Set of visited objects to detect circular references\n * @returns true if value can be serialized\n * @internal\n */\nfunction isSerializable(\n value: unknown,\n visited = new WeakSet<object>(),\n): boolean {\n // null/undefined are serializable (JSON.stringify handles them)\n if (value === null || value === undefined) {\n return true;\n }\n\n const type = typeof value;\n\n // Primitives: string, boolean\n if (type === \"string\" || type === \"boolean\") {\n return true;\n }\n\n // Numbers: must be finite (reject NaN and Infinity)\n if (type === \"number\") {\n return Number.isFinite(value);\n }\n\n // Functions and symbols cannot be serialized\n if (type === \"function\" || type === \"symbol\") {\n return false;\n }\n\n // Arrays (including nested arrays)\n if (Array.isArray(value)) {\n // Circular reference detection\n if (visited.has(value)) {\n return false;\n }\n\n visited.add(value);\n\n // Recursively check all items\n return value.every((item) => isSerializable(item, visited));\n }\n\n // Objects\n if (type === \"object\") {\n // Circular reference detection\n if (visited.has(value)) {\n return false;\n }\n\n // Add to visited set\n visited.add(value);\n\n // Only allow plain objects (reject Date, RegExp, Map, Set, etc.)\n const proto = Object.getPrototypeOf(value) as object | null;\n\n if (proto !== null && proto !== Object.prototype) {\n return false; // Instance of a class\n }\n\n // Recursively check all values\n return Object.values(value).every((v) => isSerializable(v, visited));\n }\n\n return false;\n}\n\n/**\n * Fast path check for primitive values (no recursion needed).\n * Returns true if primitive, false if needs deeper inspection.\n *\n * @internal\n */\nfunction isPrimitiveValue(value: unknown): boolean {\n if (value === null || value === undefined) {\n return true;\n }\n\n const type = typeof value;\n\n if (type === \"string\" || type === \"boolean\") {\n return true;\n }\n\n if (type === \"number\") {\n return Number.isFinite(value);\n }\n\n // object, array, function, symbol â need deeper check\n return false;\n}\n\n/**\n * Type guard for Params object.\n * Validates that all values are serializable (primitives, arrays, nested arrays, or nested objects).\n * Rejects circular references, functions, symbols, and class instances.\n * Allows null/undefined anywhere (objects and arrays).\n *\n * Performance optimization: Uses two-phase validation.\n * Phase 1 (fast path): Check if all values are primitives â O(p) without recursion.\n * Phase 2 (slow path): Full recursive validation only if nested structures detected.\n *\n * @param value - Value to check\n * @returns true if value is a valid Params object\n *\n * @example\n * // Valid\n * isParams({ id: '123', page: 1 }); // true (fast path)\n * isParams({ sort: ['name', 'age'] }); // true (slow path)\n * isParams({ filter: { status: 'active' } }); // true (slow path)\n * isParams({ teamId: null, orgId: undefined }); // true (fast path)\n * isParams({ matrix: [[1, 2], [3, 4]] }); // true (slow path)\n * isParams({ users: [{ id: 1 }, { id: 2 }] }); // true (slow path)\n * isParams({ scores: [100, null, 85] }); // true (slow path)\n *\n * // Invalid\n * isParams({ fn: () => {} }); // false (function)\n * isParams({ date: new Date() }); // false (class instance)\n * isParams({ self: circularRef }); // false (circular reference)\n * isParams(null); // false (not an object)\n * isParams([]); // false (array, not object)\n */\nexport function isParams(value: unknown): value is Params {\n // Reject null, undefined, and arrays (must be a plain object)\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n return false;\n }\n\n // Reject objects with custom prototype (e.g., Object.create(proto), class instances)\n // This check is required for both fast and slow paths\n const proto = Object.getPrototypeOf(value) as object | null;\n\n if (proto !== null && proto !== Object.prototype) {\n return false;\n }\n\n // Phase 1: Fast path for flat objects (95%+ of real-world params)\n // Check if all values are primitives â no recursion, no WeakSet allocation\n let needsDeepCheck = false;\n\n for (const key in value) {\n // Skip inherited properties (only check own properties for fast path)\n // Note: With proto === Object.prototype check above, inherited properties\n // would only come from Object.prototype, which has no enumerable properties.\n // This check is defensive against Object.prototype pollution.\n /* v8 ignore next 3 -- @preserve Defensive: Object.prototype pollution */\n if (!Object.hasOwn(value, key)) {\n continue;\n }\n\n const val = (value as Record<string, unknown>)[key];\n\n if (!isPrimitiveValue(val)) {\n // Found non-primitive â need full validation\n // But first check for obvious invalids (functions, symbols)\n const type = typeof val;\n\n if (type === \"function\" || type === \"symbol\") {\n return false; // Early reject\n }\n\n needsDeepCheck = true;\n\n break; // Exit fast path, proceed to slow path\n }\n }\n\n // Fast path: all primitives, valid params\n if (!needsDeepCheck) {\n return true;\n }\n\n // Phase 2: Slow path â full recursive validation\n return isSerializable(value);\n}\n\n/**\n * Internal helper for strict param validation (browser plugin).\n * Only allows primitives and arrays of primitives, no nested objects.\n *\n * @param value - Value to check\n * @returns true if value is valid\n * @internal\n */\nexport function isValidParamValueStrict(value: unknown): boolean {\n if (value === null || value === undefined) {\n return true;\n }\n\n const type = typeof value;\n\n // Primitives: string, boolean, finite number\n if (type === \"string\" || type === \"boolean\") {\n return true;\n }\n\n if (type === \"number\") {\n return Number.isFinite(value as number);\n }\n\n // Arrays of primitives only\n if (Array.isArray(value)) {\n return value.every((item) => {\n const itemType = typeof item;\n\n // Primitives: string, boolean, finite number\n if (itemType === \"string\" || itemType === \"boolean\") {\n return true;\n }\n\n if (itemType === \"number\") {\n return Number.isFinite(item);\n }\n\n // Reject everything else (objects, arrays, functions, symbols, etc.)\n return false;\n });\n }\n\n // Reject objects, functions, symbols, etc.\n return false;\n}\n\n/**\n * Strict type guard for Params (browser plugin version).\n * Only allows primitives and arrays of primitives, no nested objects.\n *\n * @param value - Value to check\n * @returns true if value is a valid Params object\n */\nexport function isParamsStrict(value: unknown): value is Params {\n // Check if value is an object (null returns \"object\" but fails Array.isArray and other checks)\n if (typeof value !== \"object\" || value === null || Array.isArray(value)) {\n return false;\n }\n\n // Check all own properties have valid param values\n for (const key in value) {\n if (!Object.hasOwn(value, key)) {\n continue; // Skip inherited properties\n }\n\n const val = (value as Record<string, unknown>)[key];\n\n if (!isValidParamValueStrict(val)) {\n return false;\n }\n }\n\n return true;\n}\n","// packages/type-guards/modules/internal/meta-fields.ts\n\nimport { isParams, isParamsStrict } from \"../guards/params\";\nimport { isRouteName } from \"../guards/routes\";\n\nimport type { Params, StateMeta } from \"@real-router/types\";\n\n/**\n * Type guard for meta object fields if present.\n * Used by both isStateStrict and isHistoryState.\n *\n * @param meta - Value to check\n * @returns true if meta has valid StateMeta structure\n * @internal\n */\nexport function isMetaFields<MP extends Params = Params>(\n meta: unknown,\n): meta is StateMeta<MP> {\n // Early check: must be a non-null object\n if (typeof meta !== \"object\" || meta === null) {\n return false;\n }\n\n const obj = meta as Record<string, unknown>;\n\n // Check params field if present\n if (\"params\" in obj && !isParamsStrict(obj.params)) {\n return false;\n }\n\n // Check options field if present\n if (\"options\" in obj && typeof obj.options !== \"object\") {\n return false;\n }\n\n // Check id field if present\n if (\"id\" in obj && typeof obj.id !== \"number\") {\n return false;\n }\n\n // Check redirected field if present\n if (\"redirected\" in obj && typeof obj.redirected !== \"boolean\") {\n return false;\n }\n\n // Check source field if present\n return !(\"source\" in obj && typeof obj.source !== \"string\");\n}\n\n/**\n * Type guard helper that checks if required State fields have valid types.\n * Validates that name, path, and params exist and have correct types.\n * Used by both isStateStrict and isHistoryState.\n *\n * @param obj - Object to check\n * @returns true if object has valid required fields\n * @internal\n */\nexport function isRequiredFields(obj: Record<string, unknown>): boolean {\n return (\n isRouteName(obj.name) &&\n typeof obj.path === \"string\" &&\n isParams(obj.params)\n );\n}\n","// packages/type-guards/modules/guards/state.ts\n\nimport { isMetaFields, isRequiredFields } from \"../internal/meta-fields\";\n\nimport type { Params, State } from \"@real-router/types\";\n\n/**\n * Type guard for State object.\n * Checks for required fields: name, params, path.\n * Does NOT validate meta field deeply.\n *\n * @param value - Value to check\n * @returns true if value is a valid State object\n *\n * @example\n * isState({ name: 'home', params: {}, path: '/' }); // true\n * isState({ name: 'home', path: '/' }); // false (missing params)\n */\nexport function isState<P extends Params = Params, MP extends Params = Params>(\n value: unknown,\n): value is State<P, MP> {\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n return isRequiredFields(obj);\n}\n\n/**\n * Enhanced type guard for State with deep validation.\n * Checks not only presence but also types of all required fields.\n * Validates params using isParams and meta structure if present.\n *\n * @param value - Value to check\n * @returns true if value is a valid State object with correct types\n *\n * @example\n * isStateStrict({ name: 'home', params: {}, path: '/', meta: { id: 1 } }); // true\n * isStateStrict({ name: 'home', params: 'invalid', path: '/' }); // false\n */\nexport function isStateStrict<\n P extends Params = Params,\n MP extends Params = Params,\n>(value: unknown): value is State<P, MP> {\n // Basic structure check\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n // Check required fields and their types\n if (!isRequiredFields(obj)) {\n return false;\n }\n\n // Validate meta if present\n if (obj.meta !== undefined) {\n return isMetaFields(obj.meta);\n }\n\n return true;\n}\n\n/**\n * Type guard for HistoryState (browser plugin).\n * HistoryState must have meta object with specific structure.\n * This is stricter than regular State validation.\n *\n * @param value - Value to check\n * @returns true if value is a valid HistoryState object\n */\nexport function isHistoryState(value: unknown): value is State & {\n meta: NonNullable<State[\"meta\"]>;\n} {\n // Basic structure check\n if (typeof value !== \"object\" || value === null) {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n // Check required fields and their types\n if (!isRequiredFields(obj)) {\n return false;\n }\n\n // HistoryState requires meta to be present and valid\n // Note: The check !(\"meta\" in obj) is redundant because isMetaFields(undefined) returns false\n // However, we keep it for clarity and explicit error semantics\n return \"meta\" in obj && isMetaFields(obj.meta);\n}\n","// packages/type-guards/modules/primitives.ts\n\n/**\n * Type guard for string type.\n *\n * @param value - Value to check\n * @returns true if value is a string\n */\nexport function isString(value: unknown): value is string {\n return typeof value === \"string\";\n}\n\n/**\n * Type guard for boolean type.\n *\n * @param value - Value to check\n * @returns true if value is a boolean\n */\nexport function isBoolean(value: unknown): value is boolean {\n return typeof value === \"boolean\";\n}\n\n/**\n * Type guard for Promise type.\n *\n * @param value - Value to check\n * @returns true if value is a Promise\n */\nexport function isPromise<T = unknown>(value: unknown): value is Promise<T> {\n return (\n typeof value === \"object\" &&\n value !== null &&\n \"then\" in value &&\n typeof value.then === \"function\"\n );\n}\n\n/**\n * Type guard for object key existence.\n * Narrows the key type to a valid key of the object.\n *\n * @param key - Key to check\n * @param obj - Object to check in\n * @returns true if key exists in object\n */\nexport function isObjKey<T extends object>(\n key: string,\n obj: T,\n): key is Extract<keyof T, string> {\n return key in obj;\n}\n\n/**\n * Type guard for primitive values suitable for URL parameters.\n * Only string, number, and boolean are allowed.\n * Rejects NaN and Infinity for numbers.\n *\n * @param value - Value to check\n * @returns true if value is string, number, or boolean\n */\nexport function isPrimitiveValue(\n value: unknown,\n): value is string | number | boolean {\n if (typeof value === \"number\") {\n return Number.isFinite(value);\n }\n\n return typeof value === \"string\" || typeof value === \"boolean\";\n}\n","// packages/type-guards/modules/validators/routes.ts\n\nimport {\n createRouterError,\n FULL_ROUTE_PATTERN,\n HAS_NON_WHITESPACE,\n MAX_ROUTE_NAME_LENGTH,\n} from \"../internal/router-error\";\n\n/**\n * Validates that a route name is a valid string and matches the expected format.\n * Throws a descriptive error if validation fails.\n *\n * Route name rules:\n * - Must be a string\n * - Empty string (\"\") is valid and represents the root node\n * - Can use dots (.) for hierarchy (e.g., \"users.profile\")\n * - Each segment must match [a-zA-Z_][a-zA-Z0-9_-]*\n * - No consecutive dots (..)\n * - No leading/trailing dots\n * - Cannot contain only whitespace\n * - System routes (starting with @@) bypass pattern validation\n *\n * @param name - Route name to validate\n * @param methodName - Name of calling method for error messages\n * @throws {TypeError} If name is invalid\n *\n * @example\n * // Valid names\n * validateRouteName(\"\", \"add\"); // ok (root node)\n * validateRouteName(\"home\", \"add\"); // ok\n * validateRouteName(\"users.profile\", \"add\"); // ok\n * validateRouteName(\"@@router/UNKNOWN_ROUTE\", \"add\"); // ok (system route)\n *\n * @example\n * // Invalid names (throws)\n * validateRouteName(\" \", \"add\"); // throws (only whitespace)\n * validateRouteName(\".users\", \"add\"); // throws (leading dot)\n * validateRouteName(\"users.\", \"add\"); // throws (trailing dot)\n * validateRouteName(\"users..profile\", \"add\"); // throws (consecutive dots)\n * validateRouteName(\"users.123\", \"add\"); // throws (segment starts with number)\n * validateRouteName(\"users profile\", \"add\"); // throws (contains space)\n */\nexport function validateRouteName(\n name: unknown,\n methodName: string,\n): asserts name is string {\n // Type check\n if (typeof name !== \"string\") {\n throw createRouterError(\n methodName,\n `Route name must be a string, got ${typeof name}`,\n );\n }\n\n // Empty string is valid (represents root node) - fast path\n if (name === \"\") {\n return;\n }\n\n // Whitespace-only strings are invalid\n if (!HAS_NON_WHITESPACE.test(name)) {\n throw createRouterError(\n methodName,\n \"Route name cannot contain only whitespace\",\n );\n }\n\n // Length check for technical safety\n if (name.length > MAX_ROUTE_NAME_LENGTH) {\n throw createRouterError(\n methodName,\n `Route name exceeds maximum length of ${MAX_ROUTE_NAME_LENGTH} characters. This is a technical safety limit.`,\n );\n }\n\n // System routes bypass validation (e.g., @@router/UNKNOWN_ROUTE)\n // SECURITY NOTE: System routes are currently created ONLY in router code,\n // not from user input. If this changes, add sanitization for <>\"'&\\x00-\\x1F\n if (name.startsWith(\"@@\")) {\n return;\n }\n\n // Validate route pattern\n if (!FULL_ROUTE_PATTERN.test(name)) {\n throw createRouterError(\n methodName,\n `Invalid route name \"${name}\". Each segment must start with a letter or underscore, followed by letters, numbers, underscores, or hyphens. Segments are separated by dots (e.g., \"users.profile\").`,\n );\n }\n}\n","// packages/type-guards/modules/internal/type-description.ts\n\n/**\n * Gets a human-readable description of a value's type.\n * Used for error messages to provide helpful debugging information.\n *\n * @param value - Value to describe\n * @returns String description of the value's type\n *\n * @example\n * getTypeDescription(null); // \"null\"\n * getTypeDescription([1, 2, 3]); // \"array[3]\"\n * getTypeDescription(new Date()); // \"Date\"\n * getTypeDescription({}); // \"object\"\n * getTypeDescription(\"hello\"); // \"string\"\n */\nexport function getTypeDescription(value: unknown): string {\n // Handle null explicitly (typeof null === \"object\")\n if (value === null) {\n return \"null\";\n }\n\n // Array with length info\n if (Array.isArray(value)) {\n return `array[${value.length}]`;\n }\n\n if (typeof value === \"object\") {\n // Return constructor name for class instances\n if (\"constructor\" in value && value.constructor.name !== \"Object\") {\n return value.constructor.name;\n }\n\n // Plain object\n return \"object\";\n }\n\n // Primitive types (string, number, boolean, undefined, etc.)\n // Note: typeof undefined === \"undefined\", so we don't need explicit check\n return typeof value;\n}\n","// packages/type-guards/modules/validators/state.ts\n\nimport { isState } from \"../guards\";\nimport { getTypeDescription } from \"../utilities/type-description\";\n\nimport type { State } from \"@real-router/types\";\n\n/**\n * Validates that a state has the correct structure.\n * Throws a descriptive error if validation fails.\n *\n * @param state - State to validate\n * @param method - Context for error message\n * @throws {TypeError} If state structure is invalid\n *\n * @example\n * validateState({ name: 'home', params: {}, path: '/' }, 'navigate'); // ok\n * validateState({ name: 'home' }, 'navigate'); // throws (missing params, path)\n * validateState(null, 'navigate'); // throws (not an object)\n */\nexport function validateState(\n state: unknown,\n method: string,\n): asserts state is State {\n if (!isState(state)) {\n throw new TypeError(\n `[${method}] Invalid state structure: ${getTypeDescription(state)}. ` +\n `Expected State object with name, params, and path properties.`,\n );\n }\n}\n","// packages/real-router/modules/constants.ts\n\nimport type {\n EventToNameMap,\n EventToPluginMap,\n ErrorCodeToValueMap,\n ErrorCodeKeys,\n ErrorCodeValues,\n} from \"@real-router/types\";\n\nexport type ConstantsKeys = \"UNKNOWN_ROUTE\";\n\nexport type Constants = Record<ConstantsKeys, string>;\n\n// =============================================================================\n// Error Codes (migrated from router-error)\n// =============================================================================\n\nexport type ErrorCodes = Record<ErrorCodeKeys, ErrorCodeValues>;\n\n/**\n * Error codes for router operations.\n * Used to identify specific failure scenarios in navigation and lifecycle.\n * Frozen to prevent accidental modifications.\n */\nexport const errorCodes: ErrorCodeToValueMap = Object.freeze({\n ROUTER_NOT_STARTED: \"NOT_STARTED\", // navigate() called before start()\n NO_START_PATH_OR_STATE: \"NO_START_PATH_OR_STATE\", // start() without initial route\n ROUTER_ALREADY_STARTED: \"ALREADY_STARTED\", // start() called twice\n ROUTE_NOT_FOUND: \"ROUTE_NOT_FOUND\", // Navigation to non-existent route\n SAME_STATES: \"SAME_STATES\", // Navigate to current route without reload\n CANNOT_DEACTIVATE: \"CANNOT_DEACTIVATE\", // canDeactivate guard blocked navigation\n CANNOT_ACTIVATE: \"CANNOT_ACTIVATE\", // canActivate guard blocked navigation\n TRANSITION_ERR: \"TRANSITION_ERR\", // Generic transition failure\n TRANSITION_CANCELLED: \"CANCELLED\", // Navigation cancelled by user or new navigation\n});\n\n/**\n * General router constants.\n * Special route names and identifiers.\n */\nexport const constants: Constants = {\n UNKNOWN_ROUTE: \"@@router/UNKNOWN_ROUTE\", // Special route for 404/not found states\n};\n\n/**\n * Plugin method names.\n * Maps to methods that plugins can implement to hook into router lifecycle.\n */\nexport const plugins: EventToPluginMap = {\n ROUTER_START: \"onStart\", // Plugin method called when router starts\n ROUTER_STOP: \"onStop\", // Plugin method called when router stops\n TRANSITION_START: \"onTransitionStart\", // Plugin method called when navigation begins\n TRANSITION_CANCEL: \"onTransitionCancel\", // Plugin method called when navigation cancelled\n TRANSITION_SUCCESS: \"onTransitionSuccess\", // Plugin method called when navigation succeeds\n TRANSITION_ERROR: \"onTransitionError\", // Plugin method called when navigation fails\n};\n\n/**\n * Event names for router event system.\n * Used with addEventListener/removeEventListener for reactive subscriptions.\n */\nexport const events: EventToNameMap = {\n ROUTER_START: \"$start\", // Emitted when router.start() succeeds\n ROUTER_STOP: \"$stop\", // Emitted when router.stop() is called\n TRANSITION_START: \"$$start\", // Emitted when navigation begins\n TRANSITION_CANCEL: \"$$cancel\", // Emitted when navigation is cancelled\n TRANSITION_SUCCESS: \"$$success\", // Emitted when navigation completes successfully\n TRANSITION_ERROR: \"$$error\", // Emitted when navigation fails\n};\n\n/**\n * Default limits configuration for the router.\n * These values match the hardcoded constants from the current codebase.\n */\nexport const DEFAULT_LIMITS = {\n maxDependencies: 100,\n maxPlugins: 50,\n maxMiddleware: 50,\n maxListeners: 10_000,\n maxEventDepth: 5,\n maxLifecycleHandlers: 200,\n} as const;\n\n/**\n * Bounds for each limit - defines min and max allowed values.\n * Used for runtime validation in setLimit/withLimits.\n */\nexport const LIMIT_BOUNDS = {\n maxDependencies: { min: 0, max: 10_000 },\n maxPlugins: { min: 0, max: 1000 },\n maxMiddleware: { min: 0, max: 1000 },\n maxListeners: { min: 0, max: 100_000 },\n maxEventDepth: { min: 0, max: 100 },\n maxLifecycleHandlers: { min: 0, max: 10_000 },\n} as const;\n","// packages/real-router/modules/helpers.ts\n\nimport { DEFAULT_LIMITS } from \"./constants\";\n\nimport type { Limits } from \"./types\";\nimport type { State, Options, LimitsConfig } from \"@real-router/types\";\nimport type { BuildOptions, TrailingSlashMode } from \"route-tree\";\n\nexport { getTypeDescription } from \"type-guards\";\n\n// =============================================================================\n// State Helpers\n// =============================================================================\n\n/**\n * Structural type guard for State object.\n * Only checks required fields exist with correct types.\n * Does NOT validate params serializability (allows circular refs).\n *\n * Use `isState` from type-guards for full validation (serializable params).\n * Use this for internal operations like deepFreezeState that handle any object structure.\n *\n * @param value - Value to check\n * @returns true if value has State structure\n * @internal\n */\nfunction isStateStructural(value: unknown): value is State {\n if (value === null || typeof value !== \"object\") {\n return false;\n }\n\n const obj = value as Record<string, unknown>;\n\n return (\n typeof obj.name === \"string\" &&\n typeof obj.path === \"string\" &&\n typeof obj.params === \"object\" &&\n obj.params !== null\n );\n}\n\n/**\n * Deep freezes State object to prevent mutations.\n * Creates a deep clone first, then recursively freezes the clone and all nested objects.\n * Uses simple recursive freezing after cloning (no need for WeakSet since clone has no circular refs).\n *\n * @param state - The State object to freeze\n * @returns A frozen deep clone of the state\n * @throws {TypeError} If state is not a valid State object\n *\n * @example\n * const state = { name: 'home', params: {}, path: '/' };\n * const frozen = deepFreezeState(state);\n * // frozen.params is now immutable\n * // original state is unchanged\n */\nexport function deepFreezeState<T extends State>(state: T): T {\n // Early return for null/undefined\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!state) {\n return state;\n }\n\n // Validate State structure (structural check, allows circular refs)\n if (!isStateStructural(state)) {\n throw new TypeError(\n `[deepFreezeState] Expected valid State object, got: ${typeof state}`,\n );\n }\n\n // Create a deep clone to avoid mutating the original\n // structuredClone preserves circular references, so we need to track visited objects\n const clonedState = structuredClone(state);\n\n // WeakSet to track visited objects (prevent infinite recursion with circular refs)\n const visited = new WeakSet<object>();\n\n // Recursive freeze function with circular reference protection\n function freezeClonedRecursive(obj: unknown): void {\n // Skip primitives, null, undefined\n // Note: typeof undefined === \"undefined\" !== \"object\", so checking undefined is redundant\n if (obj === null || typeof obj !== \"object\") {\n return;\n }\n\n // Skip already visited objects (circular reference protection)\n if (visited.has(obj)) {\n return;\n }\n\n // Mark as visited\n visited.add(obj);\n\n // Freeze the object/array itself\n Object.freeze(obj);\n\n // Get all values to freeze recursively\n const values = Array.isArray(obj) ? obj : Object.values(obj);\n\n // Recursively freeze nested values\n for (const value of values) {\n freezeClonedRecursive(value);\n }\n }\n\n // Freeze the entire cloned state tree\n freezeClonedRecursive(clonedState);\n\n return clonedState;\n}\n\n// WeakSet to track already frozen root objects for O(1) re-freeze check\nconst frozenRoots = new WeakSet<object>();\n\n// Module-scope recursive freeze function - better JIT optimization, no allocation per call\nfunction freezeRecursive(obj: unknown): void {\n // Skip primitives, null\n if (obj === null || typeof obj !== \"object\") {\n return;\n }\n\n // Skip already frozen objects (handles potential shared refs)\n if (Object.isFrozen(obj)) {\n return;\n }\n\n // Freeze the object/array\n Object.freeze(obj);\n\n // Iterate without Object.values() allocation\n if (Array.isArray(obj)) {\n for (const item of obj) {\n freezeRecursive(item);\n }\n } else {\n for (const key in obj) {\n freezeRecursive((obj as Record<string, unknown>)[key]);\n }\n }\n}\n\n/**\n * Freezes State object in-place without cloning.\n * Optimized for hot paths where state is known to be a fresh object.\n *\n * IMPORTANT: Only use this when you know the state is a fresh object\n * that hasn't been exposed to external code yet (e.g., from makeState()).\n *\n * @param state - The State object to freeze (must be a fresh object)\n * @returns The same state object, now frozen\n * @internal\n */\nexport function freezeStateInPlace<T extends State>(state: T): T {\n // Early return for null/undefined - state from makeState() is never null\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!state) {\n return state;\n }\n\n // Fast path: already processed root object - O(1) check\n if (frozenRoots.has(state)) {\n return state;\n }\n\n // Freeze the entire state tree\n freezeRecursive(state);\n\n // Mark root as processed for future calls\n frozenRoots.add(state);\n\n return state;\n}\n\n// =============================================================================\n// Route Options Helpers\n// =============================================================================\n\n/**\n * Maps real-router trailingSlash option to route-tree's trailingSlashMode.\n *\n * @param trailingSlash - real-router trailing slash option\n * @returns route-tree trailing slash mode\n * @internal\n */\nfunction mapTrailingSlashMode(\n trailingSlash: Options[\"trailingSlash\"],\n): TrailingSlashMode {\n switch (trailingSlash) {\n case \"never\": {\n return \"never\";\n }\n case \"always\": {\n return \"always\";\n }\n default: {\n return \"default\";\n }\n }\n}\n\n/**\n * Creates route-tree BuildOptions from real-router Options.\n * Used for buildPath caching in routerLifecycle.ts.\n *\n * @param options - real-router options\n * @returns route-tree build options\n */\nexport function createBuildOptions(options: Options): BuildOptions {\n const buildOptions: BuildOptions = {\n trailingSlashMode: mapTrailingSlashMode(options.trailingSlash),\n queryParamsMode: options.queryParamsMode,\n urlParamsEncoding: options.urlParamsEncoding,\n };\n\n // Only include queryParams if defined (exactOptionalPropertyTypes)\n if (options.queryParams !== undefined) {\n buildOptions.queryParams = options.queryParams;\n }\n\n return buildOptions;\n}\n\n/**\n * Computes warning and error thresholds for a given limit.\n * WARN threshold: 20% of limit\n * ERROR threshold: 50% of limit\n */\nexport function computeThresholds(limit: number): {\n warn: number;\n error: number;\n} {\n return {\n warn: Math.floor(limit * 0.2),\n error: Math.floor(limit * 0.5),\n };\n}\n\n/**\n * Merges user limits with defaults.\n * Returns frozen object for immutability.\n */\nexport function createLimits(userLimits: Partial<LimitsConfig> = {}): Limits {\n return { ...DEFAULT_LIMITS, ...userLimits };\n}\n","// packages/core/src/namespaces/DependenciesNamespace/validators.ts\n\n/**\n * Static validation functions for DependenciesNamespace.\n * Called by Router facade before instance methods.\n *\n * Extracted from DependenciesNamespace class for better separation of concerns.\n */\n\nimport { getTypeDescription } from \"type-guards\";\n\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\n/**\n * Validates that dependency name is a string.\n * Called by facade before get/remove/has operations.\n */\nexport function validateDependencyName(\n name: unknown,\n methodName: string,\n): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.${methodName}]: dependency name must be a string, got ${typeof name}`,\n );\n }\n}\n\n/**\n * Validates setDependency name argument.\n * Value is not validated - any value is valid.\n */\nexport function validateSetDependencyArgs(\n name: unknown,\n): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.setDependency]: dependency name must be a string, got ${typeof name}`,\n );\n }\n}\n\n/**\n * Validates that dependencies object is a plain object without getters.\n * Called by facade before setMultiple/constructor.\n */\nexport function validateDependenciesObject(\n deps: unknown,\n methodName: string,\n): asserts deps is Record<string, unknown> {\n // Reject non-plain objects (classes, Date, Map, Array)\n if (!(deps && typeof deps === \"object\" && deps.constructor === Object)) {\n throw new TypeError(\n `[router.${methodName}] Invalid argument: expected plain object, received ${getTypeDescription(deps)}`,\n );\n }\n\n // Getters can throw, return different values, or have side effects\n for (const key in deps) {\n if (Object.getOwnPropertyDescriptor(deps, key)?.get) {\n throw new TypeError(\n `[router.${methodName}] Getters not allowed: \"${key}\"`,\n );\n }\n }\n}\n\n/**\n * Validates that dependency exists (not undefined).\n * Throws ReferenceError if dependency is not found.\n */\nexport function validateDependencyExists(\n value: unknown,\n dependencyName: string,\n): asserts value is NonNullable<unknown> {\n if (value === undefined) {\n throw new ReferenceError(\n `[router.getDependency]: dependency \"${dependencyName}\" not found`,\n );\n }\n}\n\n/**\n * Validates that adding dependencies won't exceed the hard limit.\n * Called before bulk operations to ensure atomicity.\n */\nexport function validateDependencyLimit(\n currentCount: number,\n newCount: number,\n methodName: string,\n maxDependencies: number = DEFAULT_LIMITS.maxDependencies,\n): void {\n if (maxDependencies === 0) {\n return;\n }\n\n const totalCount = currentCount + newCount;\n\n if (totalCount >= maxDependencies) {\n throw new Error(\n `[router.${methodName}] Dependency limit exceeded (${maxDependencies}). ` +\n `Current: ${totalCount}. This is likely a bug in your code.`,\n );\n }\n}\n","// packages/core/src/namespaces/DependenciesNamespace/DependenciesNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\nimport { getTypeDescription } from \"type-guards\";\n\nimport {\n validateDependencyExists,\n validateDependencyLimit,\n validateDependencyName,\n validateDependenciesObject,\n validateSetDependencyArgs,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { Limits } from \"../../types\";\nimport type { DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Independent namespace for managing router dependencies.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic (limits, warnings).\n */\nexport class DependenciesNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #dependencies: Partial<Dependencies> = Object.create(\n null,\n ) as Partial<Dependencies>;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n constructor(initialDependencies: Partial<Dependencies> = {} as Dependencies) {\n this.setMultiple(initialDependencies);\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateName(\n name: unknown,\n methodName: string,\n ): asserts name is string {\n validateDependencyName(name, methodName);\n }\n\n static validateSetDependencyArgs(name: unknown): asserts name is string {\n validateSetDependencyArgs(name);\n }\n\n static validateDependenciesObject(\n deps: unknown,\n methodName: string,\n ): asserts deps is Record<string, unknown> {\n validateDependenciesObject(deps, methodName);\n }\n\n static validateDependencyExists(\n value: unknown,\n dependencyName: string,\n ): asserts value is NonNullable<unknown> {\n validateDependencyExists(value, dependencyName);\n }\n\n static validateDependencyLimit(\n currentCount: number,\n newCount: number,\n methodName: string,\n maxDependencies?: number,\n ): void {\n validateDependencyLimit(\n currentCount,\n newCount,\n methodName,\n maxDependencies,\n );\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Sets a single dependency.\n * Returns true if set, false if value was undefined (no-op).\n *\n * @param dependencyName - Already validated by facade\n * @param dependencyValue - Value to set\n */\n set<K extends keyof Dependencies & string>(\n dependencyName: K,\n dependencyValue: Dependencies[K],\n ): boolean {\n // undefined = \"don't set\" (feature for conditional setting)\n if (dependencyValue === undefined) {\n return false;\n }\n\n const isNewKey = !Object.hasOwn(this.#dependencies, dependencyName);\n\n if (isNewKey) {\n // Only check limit when adding new keys (overwrites don't increase count)\n this.#checkDependencyCount(\"setDependency\");\n } else {\n const oldValue = this.#dependencies[dependencyName];\n const isChanging = oldValue !== dependencyValue;\n // Special case for NaN idempotency (NaN !== NaN is always true)\n const bothAreNaN =\n Number.isNaN(oldValue) && Number.isNaN(dependencyValue);\n\n if (isChanging && !bothAreNaN) {\n logger.warn(\n \"router.setDependency\",\n \"Router dependency already exists and is being overwritten:\",\n dependencyName,\n );\n }\n }\n\n this.#dependencies[dependencyName] = dependencyValue;\n\n return true;\n }\n\n /**\n * Sets multiple dependencies at once.\n * Limit check should be done by facade before calling this method.\n *\n * @param deps - Already validated by facade\n */\n setMultiple(deps: Partial<Dependencies>): void {\n const overwrittenKeys: string[] = [];\n\n for (const key in deps) {\n if (deps[key] !== undefined) {\n if (Object.hasOwn(this.#dependencies, key)) {\n overwrittenKeys.push(key);\n }\n\n this.#dependencies[key] = deps[key];\n }\n }\n\n if (overwrittenKeys.length > 0) {\n logger.warn(\n \"router.setDependencies\",\n \"Overwritten:\",\n overwrittenKeys.join(\", \"),\n );\n }\n }\n\n /**\n * Gets a single dependency.\n * Throws if not found.\n *\n * @param dependencyName - Already validated by facade\n */\n get<K extends keyof Dependencies>(dependencyName: K): Dependencies[K] {\n return this.#dependencies[dependencyName] as Dependencies[K];\n }\n\n /**\n * Gets all dependencies as a shallow copy.\n */\n getAll(): Partial<Dependencies> {\n return { ...this.#dependencies };\n }\n\n /**\n * Gets the current number of dependencies.\n */\n count(): number {\n return Object.keys(this.#dependencies).length;\n }\n\n /**\n * Removes a dependency by name.\n * Logs warning if dependency doesn't exist.\n */\n remove(dependencyName: keyof Dependencies): void {\n if (!Object.hasOwn(this.#dependencies, dependencyName)) {\n logger.warn(\n `router.removeDependency`,\n `Attempted to remove non-existent dependency: \"${getTypeDescription(dependencyName)}\"`,\n );\n }\n\n delete this.#dependencies[dependencyName];\n }\n\n /**\n * Checks if a dependency exists.\n */\n has(dependencyName: keyof Dependencies): boolean {\n return Object.hasOwn(this.#dependencies, dependencyName);\n }\n\n /**\n * Removes all dependencies.\n */\n reset(): void {\n for (const key in this.#dependencies) {\n delete this.#dependencies[key];\n }\n }\n\n // =========================================================================\n // Private methods (business logic)\n // =========================================================================\n\n #checkDependencyCount(methodName: string): void {\n const maxDependencies = this.#limits.maxDependencies;\n\n if (maxDependencies === 0) {\n return;\n }\n\n const currentCount = Object.keys(this.#dependencies).length;\n\n const { warn, error } = computeThresholds(maxDependencies);\n\n if (currentCount === warn) {\n logger.warn(\n `router.${methodName}`,\n `${warn} dependencies registered. ` + `Consider if all are necessary.`,\n );\n } else if (currentCount === error) {\n logger.error(\n `router.${methodName}`,\n `${error} dependencies registered! ` +\n `This indicates architectural problems. ` +\n `Hard limit at ${maxDependencies}.`,\n );\n } else if (currentCount >= maxDependencies) {\n throw new Error(\n `[router.${methodName}] Dependency limit exceeded (${maxDependencies}). ` +\n `Current: ${currentCount}. This is likely a bug in your code. ` +\n `If you genuinely need more dependencies, your architecture needs refactoring.`,\n );\n }\n }\n}\n","// packages/core/src/namespaces/ObservableNamespace/constants.ts\n\nimport { events } from \"../../constants\";\n\nimport type { EventName } from \"@real-router/types\";\n\n/**\n * Valid event names for validation\n */\nexport const validEventNames = new Set<EventName>([\n events.ROUTER_START,\n events.TRANSITION_START,\n events.TRANSITION_SUCCESS,\n events.TRANSITION_ERROR,\n events.TRANSITION_CANCEL,\n events.ROUTER_STOP,\n]);\n","// packages/core/src/namespaces/ObservableNamespace/helpers.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport type { EventMethodMap } from \"./types\";\nimport type { EventName, Plugin } from \"@real-router/types\";\n\n/**\n * Invoke all listeners for a given event.\n */\nexport function invokeFor<E extends EventName>(\n eventName: E,\n set: Set<Plugin[EventMethodMap[E]]>,\n ...args: Parameters<NonNullable<Plugin[EventMethodMap[E]]>>\n): void {\n if (set.size === 0) {\n return;\n }\n\n // Clone the listeners array so that removals/additions\n // during iteration won't affect this loop.\n const listeners = [...set];\n\n for (const cb of listeners) {\n try {\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type -- Function.prototype.apply requires Function type\n Function.prototype.apply.call(cb as Function, undefined, args);\n } catch (error) {\n logger.error(\"Router\", `Error in listener for ${eventName}:`, error);\n }\n }\n}\n","// packages/core/src/namespaces/ObservableNamespace/ObservableNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport { validEventNames } from \"./constants\";\nimport { invokeFor } from \"./helpers\";\nimport { DEFAULT_LIMITS, events } from \"../../constants\";\n\nimport type { EventMethodMap } from \"./types\";\nimport type { Limits } from \"../../types\";\nimport type {\n EventName,\n EventsKeys,\n NavigationOptions,\n Plugin,\n RouterError as RouterErrorType,\n State,\n SubscribeFn,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing router observability (events).\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle listener storage and invocation.\n */\nexport class ObservableNamespace {\n readonly #callbacks: {\n [E in EventName]?: Set<Plugin[EventMethodMap[E]]>;\n } = {};\n\n #eventDepthMap: Record<EventName, number> | null = null;\n\n #limits: Limits = DEFAULT_LIMITS;\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates that event name is valid.\n */\n static validateEventName(eventName: unknown): asserts eventName is EventName {\n if (!validEventNames.has(eventName as EventName)) {\n throw new Error(`Invalid event name: ${String(eventName)}`);\n }\n }\n\n /**\n * Validates callback is a function.\n */\n static validateCallback(\n cb: unknown,\n eventName: EventName,\n // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\n ): asserts cb is Function {\n if (typeof cb !== \"function\") {\n throw new TypeError(\n `Expected callback to be a function for event ${eventName}`,\n );\n }\n }\n\n /**\n * Validates listener arguments (event name + callback).\n * Called by facade before addEventListener/removeEventListener.\n */\n static validateListenerArgs<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): void {\n ObservableNamespace.validateEventName(eventName);\n ObservableNamespace.validateCallback(cb, eventName);\n }\n\n /**\n * Validates subscribe listener is a function.\n */\n static validateSubscribeListener(\n listener: unknown,\n ): asserts listener is SubscribeFn {\n if (typeof listener !== \"function\") {\n throw new TypeError(\n \"[router.subscribe] Expected a function. \" +\n \"For Observable pattern use @real-router/rx package\",\n );\n }\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Central event dispatcher.\n * Input should be validated by facade before calling.\n */\n invoke(\n eventName: (typeof events)[EventsKeys],\n toState?: State,\n fromState?: State,\n arg?: RouterErrorType | NavigationOptions,\n ): void {\n // Check recursion depth (business logic, not input validation)\n this.#checkRecursionDepth(eventName);\n\n const depthMap = this.#getEventDepthMap();\n\n try {\n depthMap[eventName]++;\n\n switch (eventName) {\n case events.TRANSITION_START:\n case events.TRANSITION_CANCEL: {\n invokeFor(\n eventName,\n this.#getCallbackSet(eventName),\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- validated by facade\n toState!,\n fromState,\n );\n\n break;\n }\n case events.TRANSITION_ERROR: {\n invokeFor(\n eventName,\n this.#getCallbackSet(eventName),\n toState,\n fromState,\n arg as RouterErrorType,\n );\n\n break;\n }\n case events.TRANSITION_SUCCESS: {\n invokeFor(\n eventName,\n this.#getCallbackSet(eventName),\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- validated by facade\n toState!,\n fromState,\n arg as NavigationOptions,\n );\n\n break;\n }\n // for events.ROUTER_START, events.ROUTER_STOP\n default: {\n const _exhaustiveCheck:\n | typeof events.ROUTER_START\n | typeof events.ROUTER_STOP = eventName;\n\n invokeFor(_exhaustiveCheck, this.#getCallbackSet(_exhaustiveCheck));\n\n break;\n }\n }\n } finally {\n depthMap[eventName]--;\n }\n }\n\n /**\n * Checks if there are any listeners registered for a given event.\n */\n hasListeners(eventName: (typeof events)[EventsKeys]): boolean {\n const set = this.#callbacks[eventName];\n\n return set !== undefined && set.size > 0;\n }\n\n /**\n * Removes an event listener.\n * Input should be validated by facade before calling.\n */\n removeEventListener<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): void {\n // Don't create Set just for removal - check if it exists first\n const set = this.#callbacks[eventName];\n\n if (!set || set.size === 0) {\n return;\n }\n\n const deleted = set.delete(cb);\n\n if (!deleted) {\n logger.warn(\n \"Router\",\n `Attempted to remove non-existent listener for \"${eventName}\". ` +\n `This might indicate a memory leak or incorrect cleanup logic.`,\n );\n }\n }\n\n /**\n * Adds an event listener and returns an unsubscribe function.\n * Input should be validated by facade before calling.\n */\n addEventListener<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): Unsubscribe {\n const set = this.#getCallbackSet(eventName);\n\n // Duplicate check (business logic)\n if (set.has(cb)) {\n throw new Error(\n `[router.addEventListener] Listener already exists for event \"${eventName}\". ` +\n `Each listener function can only be registered once per event. ` +\n `Store the returned unsubscribe function to remove the listener.`,\n );\n }\n\n const maxListeners = this.#limits.maxListeners;\n\n if (set.size === 1000) {\n logger.warn(\n \"router.addEventListener\",\n `Warning: Event \"${eventName}\" has ${set.size} listeners. ` +\n `This might indicate a memory leak.`,\n );\n }\n\n if (maxListeners !== 0 && set.size >= maxListeners) {\n throw new Error(\n `[router.addEventListener] Maximum listener limit (${maxListeners}) ` +\n `reached for event \"${eventName}\". ` +\n `This is a critical memory leak. The application is creating listeners ` +\n `exponentially. Check for loops or recursive calls that register listeners.`,\n );\n }\n\n set.add(cb);\n\n return () => {\n this.removeEventListener(eventName, cb);\n };\n }\n\n /**\n * Simple subscription API for navigation success events.\n * Input should be validated by facade before calling.\n */\n subscribe(listener: SubscribeFn): Unsubscribe {\n return this.addEventListener(\n events.TRANSITION_SUCCESS,\n (toState: State, fromState?: State) => {\n listener({\n route: toState,\n previousRoute: fromState,\n });\n },\n );\n }\n\n // =========================================================================\n // Private methods (business logic)\n // =========================================================================\n\n /**\n * Gets or creates a Set for the given event name (lazy initialization)\n */\n #getCallbackSet<E extends EventName>(\n eventName: E,\n ): Set<Plugin[EventMethodMap[E]]> {\n const existing = this.#callbacks[eventName];\n\n if (existing) {\n return existing;\n }\n\n const set = new Set<Plugin[EventMethodMap[E]]>();\n\n // Type assertion needed: TS can't narrow generic E to specific event name\n (this.#callbacks as Record<E, Set<Plugin[EventMethodMap[E]]>>)[eventName] =\n set;\n\n return set;\n }\n\n /**\n * Gets or creates the event depth map (lazy initialization)\n */\n #getEventDepthMap(): Record<EventName, number> {\n this.#eventDepthMap ??= {\n [events.ROUTER_START]: 0,\n [events.TRANSITION_START]: 0,\n [events.TRANSITION_SUCCESS]: 0,\n [events.TRANSITION_ERROR]: 0,\n [events.TRANSITION_CANCEL]: 0,\n [events.ROUTER_STOP]: 0,\n };\n\n return this.#eventDepthMap;\n }\n\n #checkRecursionDepth(eventName: (typeof events)[EventsKeys]): void {\n const maxEventDepth = this.#limits.maxEventDepth;\n\n if (maxEventDepth === 0) {\n return;\n }\n\n const depthMap = this.#getEventDepthMap();\n const depth = depthMap[eventName];\n\n /* v8 ignore next 5 -- @preserve defensive: protects against recursive plugins */\n if (depth >= maxEventDepth) {\n throw new Error(\n `[Router] Maximum recursion depth (${maxEventDepth}) exceeded for event: ${eventName}`,\n );\n }\n }\n}\n","// packages/core/src/namespaces/OptionsNamespace/constants.ts\n\nimport type { Options } from \"@real-router/types\";\n\n/**\n * Default options for the router.\n */\nexport const defaultOptions: Options = {\n defaultRoute: \"\",\n defaultParams: {},\n trailingSlash: \"preserve\",\n queryParamsMode: \"loose\",\n queryParams: {\n arrayFormat: \"none\",\n booleanFormat: \"none\",\n nullFormat: \"default\",\n },\n urlParamsEncoding: \"default\",\n allowNotFound: true,\n rewritePathOnMatch: true,\n noValidate: false,\n} satisfies Options;\n\n/**\n * Valid values for string enum options.\n * Used for runtime validation in setOption/withOptions.\n */\nexport const VALID_OPTION_VALUES = {\n trailingSlash: [\"strict\", \"never\", \"always\", \"preserve\"] as const,\n queryParamsMode: [\"default\", \"strict\", \"loose\"] as const,\n urlParamsEncoding: [\"default\", \"uri\", \"uriComponent\", \"none\"] as const,\n} as const;\n\n/**\n * Valid keys and values for queryParams option.\n */\nexport const VALID_QUERY_PARAMS = {\n arrayFormat: [\"none\", \"brackets\", \"index\", \"comma\"] as const,\n booleanFormat: [\"none\", \"string\", \"empty-true\"] as const,\n nullFormat: [\"default\", \"hidden\"] as const,\n} as const;\n\n/**\n * Options that can be changed after router is locked (started).\n */\nexport const UNLOCKED_OPTIONS = new Set<keyof Options>([\n \"defaultRoute\",\n \"defaultParams\",\n]);\n","// packages/core/src/namespaces/OptionsNamespace/helpers.ts\n\nimport type { Options } from \"@real-router/types\";\n\n/**\n * Creates a ReferenceError for option not found.\n */\nexport const optionNotFoundError = (\n method: string,\n name: keyof Options,\n): ReferenceError =>\n new ReferenceError(`[router.${method}]: option \"${name}\" not found`);\n\n/**\n * Recursively freezes an object and all nested objects.\n * Only freezes plain objects, not primitives or special objects.\n */\nexport function deepFreeze<T extends object>(obj: T): Readonly<T> {\n Object.freeze(obj);\n\n for (const key of Object.keys(obj)) {\n const value = (obj as Record<string, unknown>)[key];\n\n if (value && typeof value === \"object\" && value.constructor === Object) {\n deepFreeze(value);\n }\n }\n\n return obj;\n}\n","// packages/core/src/namespaces/OptionsNamespace/validators.ts\n\n/**\n * Static validation functions for OptionsNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { isObjKey, getTypeDescription } from \"type-guards\";\n\nimport {\n defaultOptions,\n UNLOCKED_OPTIONS,\n VALID_OPTION_VALUES,\n VALID_QUERY_PARAMS,\n} from \"./constants\";\nimport { optionNotFoundError } from \"./helpers\";\nimport { LIMIT_BOUNDS } from \"../../constants\";\n\nimport type { LimitsConfig, Options } from \"@real-router/types\";\n\n/**\n * Validates that option name is a string.\n */\nexport function validateOptionName(\n name: unknown,\n methodName: string,\n): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.${methodName}]: option name must be a string, got ${typeof name}`,\n );\n }\n}\n\n/**\n * Validates that option exists in defaults.\n */\nexport function validateOptionExists(\n optionName: string,\n methodName: string,\n): void {\n if (!Object.hasOwn(defaultOptions, optionName)) {\n throw optionNotFoundError(methodName, optionName as keyof Options);\n }\n}\n\n/**\n * Validates that options are not locked for this option.\n */\nexport function validateNotLocked(isLocked: boolean, optionName: string): void {\n if (isLocked && !UNLOCKED_OPTIONS.has(optionName as keyof Options)) {\n throw new Error(\n `[router.setOption] Options cannot be changed after router.start(). ` +\n `Only defaultRoute/defaultParams can be changed after start.`,\n );\n }\n}\n\n/**\n * Validates that value is a plain object without getters.\n */\nexport function validatePlainObject(\n value: unknown,\n optionName: string,\n methodName: string,\n): asserts value is Record<string, unknown> {\n if (!value || typeof value !== \"object\" || value.constructor !== Object) {\n throw new TypeError(\n `[router.${methodName}] Invalid type for \"${optionName}\": ` +\n `expected plain object, got ${getTypeDescription(value)}`,\n );\n }\n\n // Getters can throw, return different values, or have side effects\n for (const key in value) {\n if (Object.getOwnPropertyDescriptor(value, key)?.get) {\n throw new TypeError(\n `[router.${methodName}] Getters not allowed in \"${optionName}\": \"${key}\"`,\n );\n }\n }\n}\n\n/**\n * Validates queryParams keys and values against allowed enums.\n */\nexport function validateQueryParams(\n value: Record<string, unknown>,\n methodName: string,\n): void {\n for (const key in value) {\n if (!isObjKey(key, VALID_QUERY_PARAMS)) {\n const validKeys = Object.keys(VALID_QUERY_PARAMS)\n .map((k) => `\"${k}\"`)\n .join(\", \");\n\n throw new TypeError(\n `[router.${methodName}] Unknown queryParams key: \"${key}\". ` +\n `Valid keys: ${validKeys}`,\n );\n }\n\n const paramValue = value[key];\n const validValues = VALID_QUERY_PARAMS[key];\n const isValid = (validValues as readonly string[]).includes(\n paramValue as string,\n );\n\n if (!isValid) {\n const allowedValues = validValues.map((v) => `\"${v}\"`).join(\", \");\n\n throw new TypeError(\n `[router.${methodName}] Invalid value for queryParams.${key}: ` +\n `expected one of ${allowedValues}, got \"${String(paramValue)}\"`,\n );\n }\n }\n}\n\n/**\n * Validates string enum options against allowed values.\n */\nexport function validateEnumOption(\n optionName: keyof typeof VALID_OPTION_VALUES,\n value: unknown,\n methodName: string,\n): void {\n const validValues = VALID_OPTION_VALUES[optionName];\n const isValid = (validValues as readonly string[]).includes(value as string);\n\n if (!isValid) {\n const allowedValues = validValues.map((v) => `\"${v}\"`).join(\", \");\n\n throw new TypeError(\n `[router.${methodName}] Invalid value for \"${optionName}\": ` +\n `expected one of ${allowedValues}, got \"${String(value)}\"`,\n );\n }\n}\n\n/**\n * Validates a single option value against expected type and constraints.\n * Skips validation for unknown options - validateOptionExists handles that.\n */\nexport function validateOptionValue(\n optionName: keyof Options,\n value: unknown,\n methodName: string,\n): void {\n const expectedValue = defaultOptions[optionName];\n\n // For object options - ensure plain objects only (not null, arrays, Date, etc)\n if (expectedValue && typeof expectedValue === \"object\") {\n validatePlainObject(value, optionName, methodName);\n\n if (optionName === \"queryParams\") {\n validateQueryParams(value, methodName);\n }\n\n return;\n }\n\n // For primitives - typeof check first\n if (typeof value !== typeof expectedValue) {\n throw new TypeError(\n `[router.${methodName}] Invalid type for \"${optionName}\": ` +\n `expected ${typeof expectedValue}, got ${typeof value}`,\n );\n }\n\n // For string enum options - validate against allowed values\n if (optionName in VALID_OPTION_VALUES) {\n validateEnumOption(\n optionName as keyof typeof VALID_OPTION_VALUES,\n value,\n methodName,\n );\n }\n}\n\n/**\n * Validates optional fields not in defaultOptions.\n * Note: logger is handled before validateOptions in Router constructor.\n */\nfunction validateOptionalField(\n key: string,\n value: unknown,\n methodName: string,\n): boolean {\n if (key === \"limits\") {\n if (value !== undefined) {\n validateLimits(value, methodName);\n }\n\n return true;\n }\n\n throw new TypeError(`[router.${methodName}] Unknown option: \"${key}\"`);\n}\n\n/**\n * Validates a partial options object.\n * Called by facade before constructor/withOptions.\n */\nexport function validateOptions(\n options: unknown,\n methodName: string,\n): asserts options is Partial<Options> {\n if (\n !options ||\n typeof options !== \"object\" ||\n options.constructor !== Object\n ) {\n throw new TypeError(\n `[router.${methodName}] Invalid options: expected plain object, got ${getTypeDescription(options)}`,\n );\n }\n\n for (const [key, value] of Object.entries(options)) {\n // Skip optional fields that aren't in defaultOptions (limits, logger, etc.)\n /* v8 ignore next -- @preserve branch: optional field handled separately */\n if (!isObjKey(key, defaultOptions)) {\n validateOptionalField(key, value, methodName);\n continue;\n }\n\n // Skip undefined values for conditional configuration\n if (value === undefined) {\n continue;\n }\n\n validateOptionValue(key, value, methodName);\n }\n}\n\n/**\n * Validates that a limit value is within bounds.\n */\nexport function validateLimitValue(\n limitName: keyof LimitsConfig,\n value: unknown,\n methodName: string,\n): void {\n if (typeof value !== \"number\" || !Number.isInteger(value)) {\n throw new TypeError(\n `[router.${methodName}]: limit \"${limitName}\" must be an integer, got ${String(value)}`,\n );\n }\n\n const bounds = LIMIT_BOUNDS[limitName];\n\n if (value < bounds.min || value > bounds.max) {\n throw new RangeError(\n `[router.${methodName}]: limit \"${limitName}\" must be between ${bounds.min} and ${bounds.max}, got ${value}`,\n );\n }\n}\n\n/**\n * Validates a partial limits object.\n */\nexport function validateLimits(\n limits: unknown,\n methodName: string,\n): asserts limits is Partial<LimitsConfig> {\n if (!limits || typeof limits !== \"object\" || limits.constructor !== Object) {\n throw new TypeError(\n `[router.${methodName}]: invalid limits: expected plain object, got ${typeof limits}`,\n );\n }\n\n for (const [key, value] of Object.entries(limits)) {\n if (!Object.hasOwn(LIMIT_BOUNDS, key)) {\n throw new TypeError(`[router.${methodName}]: unknown limit: \"${key}\"`);\n }\n\n if (value === undefined) {\n continue;\n }\n\n validateLimitValue(key as keyof LimitsConfig, value, methodName);\n }\n}\n","// packages/core/src/namespaces/OptionsNamespace/OptionsNamespace.ts\n\nimport { defaultOptions } from \"./constants\";\nimport { deepFreeze } from \"./helpers\";\nimport {\n validateNotLocked,\n validateOptionExists,\n validateOptionName,\n validateOptions,\n validateOptionValue,\n} from \"./validators\";\n\nimport type { Options } from \"@real-router/types\";\n\n/**\n * Independent namespace for managing router options.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and lock state.\n */\nexport class OptionsNamespace {\n #options: Readonly<Options>;\n #locked = false;\n\n constructor(initialOptions: Partial<Options> = {}) {\n // Note: validation should be done by facade before calling constructor\n this.#options = deepFreeze({\n ...defaultOptions,\n ...initialOptions,\n });\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateOptionName(\n name: unknown,\n methodName: string,\n ): asserts name is string {\n validateOptionName(name, methodName);\n }\n\n static validateOptionExists(optionName: string, methodName: string): void {\n validateOptionExists(optionName, methodName);\n }\n\n static validateNotLocked(isLocked: boolean, optionName: string): void {\n validateNotLocked(isLocked, optionName);\n }\n\n static validateOptionValue(\n optionName: keyof Options,\n value: unknown,\n methodName: string,\n ): void {\n validateOptionValue(optionName, value, methodName);\n }\n\n static validateOptions(\n options: unknown,\n methodName: string,\n ): asserts options is Partial<Options> {\n validateOptions(options, methodName);\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the frozen options object.\n * Safe to return directly - mutations will throw in strict mode.\n */\n get(): Readonly<Options> {\n return this.#options;\n }\n\n /**\n * Gets a single option value.\n * Input already validated by facade.\n *\n * @param optionName - Already validated by facade\n */\n getOption<K extends keyof Options>(optionName: K): Options[K] {\n return this.#options[optionName];\n }\n\n /**\n * Sets a single option value.\n * Input already validated by facade (including lock check).\n *\n * @param optionName - Already validated by facade\n * @param value - Already validated by facade\n */\n set<K extends keyof Options>(optionName: K, value: Options[K]): void {\n // Recreate frozen options with new value\n // For nested objects (defaultParams), create a shallow copy to avoid\n // sharing mutable references\n const newValue =\n value && typeof value === \"object\" && value.constructor === Object\n ? { ...value }\n : value;\n\n this.#options = deepFreeze({\n ...this.#options,\n [optionName]: newValue,\n });\n }\n\n /**\n * Returns true if options are locked.\n * Used by facade for lock validation.\n */\n isLocked(): boolean {\n return this.#locked;\n }\n\n /**\n * Locks options - called when router starts.\n * After locking, only UNLOCKED_OPTIONS can be changed.\n */\n lock(): void {\n this.#locked = true;\n }\n\n /**\n * Unlocks options - called when router stops.\n */\n unlock(): void {\n this.#locked = false;\n }\n}\n","// packages/core/src/namespaces/StateNamespace/helpers.ts\n\nimport type { RouteTreeStateMeta } from \"route-tree\";\n\n/**\n * Extracts URL param names from RouteTreeStateMeta.\n * This is an O(segments à params) operation but avoids tree traversal.\n */\nexport function getUrlParamsFromMeta(meta: RouteTreeStateMeta): string[] {\n const urlParams: string[] = [];\n\n for (const segmentName in meta) {\n const paramMap = meta[segmentName];\n\n for (const param in paramMap) {\n if (paramMap[param] === \"url\") {\n urlParams.push(param);\n }\n }\n }\n\n return urlParams;\n}\n\n/**\n * Compares two parameter values for equality.\n * Supports deep equality for arrays (common in route params like tags, ids).\n */\nexport function areParamValuesEqual(val1: unknown, val2: unknown): boolean {\n if (val1 === val2) {\n return true;\n }\n\n if (Array.isArray(val1) && Array.isArray(val2)) {\n if (val1.length !== val2.length) {\n return false;\n }\n\n return val1.every((v, i) => areParamValuesEqual(v, val2[i]));\n }\n\n return false;\n}\n","// packages/core/src/namespaces/StateNamespace/StateNamespace.ts\n\nimport {\n getTypeDescription,\n isParams,\n isString,\n validateState,\n} from \"type-guards\";\n\nimport { areParamValuesEqual, getUrlParamsFromMeta } from \"./helpers\";\nimport { constants } from \"../../constants\";\nimport { freezeStateInPlace } from \"../../helpers\";\n\nimport type { StateNamespaceDependencies } from \"./types\";\nimport type {\n NavigationOptions,\n Params,\n State,\n StateMetaInput,\n} from \"@real-router/types\";\nimport type { RouteTreeStateMeta } from \"route-tree\";\n\n/**\n * Independent namespace for managing router state storage and creation.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle state storage, freezing, and creation.\n */\nexport class StateNamespace {\n /**\n * Auto-incrementing state ID for tracking navigation history.\n */\n #stateId = 0;\n\n /**\n * Cached frozen state - avoids structuredClone on every getState() call.\n */\n #frozenState: State | undefined = undefined;\n\n /**\n * Previous state before the last setState call.\n */\n #previousState: State | undefined = undefined;\n\n /**\n * Dependencies injected from Router.\n */\n #depsStore: StateNamespaceDependencies | undefined;\n\n /**\n * Cache for URL params by route name.\n */\n readonly #urlParamsCache = new Map<string, string[]>();\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): StateNamespaceDependencies {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] StateNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates makeState arguments.\n */\n static validateMakeStateArgs(\n name: unknown,\n params: unknown,\n path: unknown,\n forceId: unknown,\n ): void {\n // Validate name is a string\n if (!isString(name)) {\n throw new TypeError(\n `[router.makeState] Invalid name: ${getTypeDescription(name)}. Expected string.`,\n );\n }\n\n // Validate params if provided\n if (params !== undefined && !isParams(params)) {\n throw new TypeError(\n `[router.makeState] Invalid params: ${getTypeDescription(params)}. Expected plain object.`,\n );\n }\n\n // Validate path if provided\n if (path !== undefined && !isString(path)) {\n throw new TypeError(\n `[router.makeState] Invalid path: ${getTypeDescription(path)}. Expected string.`,\n );\n }\n\n // Validate forceId if provided\n if (forceId !== undefined && typeof forceId !== \"number\") {\n throw new TypeError(\n `[router.makeState] Invalid forceId: ${getTypeDescription(forceId)}. Expected number.`,\n );\n }\n }\n\n /**\n * Validates areStatesEqual arguments.\n */\n static validateAreStatesEqualArgs(\n state1: unknown,\n state2: unknown,\n ignoreQueryParams: unknown,\n ): void {\n // null/undefined are valid (represent \"no state\")\n if (state1 != null) {\n validateState(state1, \"areStatesEqual\");\n }\n\n if (state2 != null) {\n validateState(state2, \"areStatesEqual\");\n }\n\n if (\n ignoreQueryParams !== undefined &&\n typeof ignoreQueryParams !== \"boolean\"\n ) {\n throw new TypeError(\n `[router.areStatesEqual] Invalid ignoreQueryParams: ${getTypeDescription(ignoreQueryParams)}. Expected boolean.`,\n );\n }\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the current router state.\n *\n * The returned state is deeply frozen (immutable) for safety.\n * Returns `undefined` if the router has not been started or has been stopped.\n */\n get<P extends Params = Params, MP extends Params = Params>():\n | State<P, MP>\n | undefined {\n return this.#frozenState as State<P, MP> | undefined;\n }\n\n /**\n * Sets the current router state.\n *\n * The state is deeply frozen before storage to ensure immutability.\n * The previous state is preserved and accessible via `getPrevious()`.\n *\n * @param state - Already validated by facade, or undefined to clear\n */\n set(state: State | undefined): void {\n // Preserve current state as previous before updating\n this.#previousState = this.#frozenState;\n\n // If state is already frozen (from makeState()), use it directly.\n // For external states, freeze in place without cloning.\n if (!state) {\n this.#frozenState = undefined;\n } else if (Object.isFrozen(state)) {\n // State is already frozen (typically from makeState)\n this.#frozenState = state;\n } else {\n // External state - freeze in place without cloning.\n this.#frozenState = freezeStateInPlace(state);\n }\n }\n\n /**\n * Returns the previous router state (before the last navigation).\n */\n getPrevious<P extends Params = Params, MP extends Params = Params>():\n | State<P, MP>\n | undefined {\n return this.#previousState as State<P, MP> | undefined;\n }\n\n // =========================================================================\n // Dependency Injection\n // =========================================================================\n\n /**\n * Sets dependencies for state creation methods.\n * Must be called before using makeState, areStatesEqual, etc.\n */\n setDependencies(deps: StateNamespaceDependencies): void {\n this.#depsStore = deps;\n }\n\n // =========================================================================\n // State Creation Methods\n // =========================================================================\n\n /**\n * Creates a frozen state object for a route.\n */\n makeState<P extends Params = Params, MP extends Params = Params>(\n name: string,\n params?: P,\n path?: string,\n meta?: StateMetaInput<MP>,\n forceId?: number,\n ): State<P, MP> {\n const madeMeta = meta\n ? {\n ...meta,\n id: forceId ?? ++this.#stateId,\n params: meta.params,\n options: meta.options,\n redirected: meta.redirected,\n }\n : undefined;\n\n // Optimization: O(1) lookup instead of O(depth) ancestor iteration\n const defaultParamsConfig = this.#deps.getDefaultParams();\n const hasDefaultParams = Object.hasOwn(defaultParamsConfig, name);\n\n // Conditional allocation: avoid spreading when no defaultParams exist\n let mergedParams: P;\n\n if (hasDefaultParams) {\n mergedParams = { ...defaultParamsConfig[name], ...params } as P;\n } else if (params) {\n mergedParams = { ...params };\n } else {\n mergedParams = {} as P;\n }\n\n const state: State<P, MP> = {\n name,\n params: mergedParams,\n path: path ?? this.#deps.buildPath(name, params),\n meta: madeMeta,\n };\n\n return freezeStateInPlace(state);\n }\n\n /**\n * Creates a frozen state object for the \"not found\" route.\n */\n makeNotFoundState(path: string, options: NavigationOptions): State {\n return this.makeState<{ path: string }>(\n constants.UNKNOWN_ROUTE,\n { path },\n path,\n {\n options,\n params: {},\n redirected: false,\n },\n );\n }\n\n // =========================================================================\n // State Comparison Methods\n // =========================================================================\n\n /**\n * Compares two states for equality.\n * By default, ignores query params (only compares URL params).\n */\n areStatesEqual(\n state1: State | undefined,\n state2: State | undefined,\n ignoreQueryParams = true,\n ): boolean {\n if (!state1 || !state2) {\n return !!state1 === !!state2;\n }\n\n if (state1.name !== state2.name) {\n return false;\n }\n\n if (ignoreQueryParams) {\n const stateMeta = (state1.meta?.params ?? state2.meta?.params) as\n | RouteTreeStateMeta\n | undefined;\n\n const urlParams = stateMeta\n ? getUrlParamsFromMeta(stateMeta)\n : this.#getUrlParams(state1.name);\n\n return urlParams.every((param) =>\n areParamValuesEqual(state1.params[param], state2.params[param]),\n );\n }\n\n const state1Keys = Object.keys(state1.params);\n const state2Keys = Object.keys(state2.params);\n\n if (state1Keys.length !== state2Keys.length) {\n return false;\n }\n\n return state1Keys.every(\n (param) =>\n param in state2.params &&\n areParamValuesEqual(state1.params[param], state2.params[param]),\n );\n }\n\n // =========================================================================\n // Private Helpers\n // =========================================================================\n\n /**\n * Gets URL params for a route name, using cache for performance.\n */\n #getUrlParams(name: string): string[] {\n const cached = this.#urlParamsCache.get(name);\n\n if (cached !== undefined) {\n return cached;\n }\n\n const result = this.#deps.getUrlParams(name);\n\n this.#urlParamsCache.set(name, result);\n\n return result;\n }\n}\n","// packages/core/src/namespaces/MiddlewareNamespace/validators.ts\n\n/**\n * Static validation functions for MiddlewareNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { getTypeDescription } from \"type-guards\";\n\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\nimport type { MiddlewareFactory } from \"../../types\";\nimport type { DefaultDependencies, Middleware } from \"@real-router/types\";\n\n/**\n * Gets a displayable name for a factory function.\n */\n// eslint-disable-next-line @typescript-eslint/no-unsafe-function-type\nfunction getFactoryName(factory: Function): string {\n return factory.name || \"anonymous\";\n}\n\n/**\n * Validates useMiddleware arguments - each must be a function.\n */\nexport function validateUseMiddlewareArgs<D extends DefaultDependencies>(\n middlewares: unknown[],\n): asserts middlewares is MiddlewareFactory<D>[] {\n for (const [i, middleware] of middlewares.entries()) {\n if (typeof middleware !== \"function\") {\n throw new TypeError(\n `[router.useMiddleware] Expected middleware factory function at index ${i}, ` +\n `got ${getTypeDescription(middleware)}`,\n );\n }\n }\n}\n\n/**\n * Validates that a middleware factory returned a valid middleware function.\n */\nexport function validateMiddleware<D extends DefaultDependencies>(\n middleware: unknown,\n factory: MiddlewareFactory<D>,\n): asserts middleware is Middleware {\n if (typeof middleware !== \"function\") {\n throw new TypeError(\n `[router.useMiddleware] Middleware factory must return a function, ` +\n `got ${getTypeDescription(middleware)}. ` +\n `Factory: ${getFactoryName(factory)}`,\n );\n }\n}\n\n/**\n * Validates that no duplicate factories are being registered.\n */\nexport function validateNoDuplicates<D extends DefaultDependencies>(\n newFactories: MiddlewareFactory<D>[],\n existingFactories: MiddlewareFactory<D>[],\n): void {\n const existingSet = new Set(existingFactories);\n\n for (const factory of newFactories) {\n if (existingSet.has(factory)) {\n throw new Error(\n `[router.useMiddleware] Middleware factory already registered. ` +\n `To re-register, first unsubscribe the existing middleware. ` +\n `Factory: ${getFactoryName(factory)}`,\n );\n }\n }\n}\n\n/**\n * Validates that adding middleware won't exceed the hard limit.\n */\nexport function validateMiddlewareLimit(\n currentCount: number,\n newCount: number,\n maxMiddleware: number = DEFAULT_LIMITS.maxMiddleware,\n): void {\n if (maxMiddleware === 0) {\n return;\n }\n\n const totalSize = currentCount + newCount;\n\n if (totalSize > maxMiddleware) {\n throw new Error(\n `[router.useMiddleware] Middleware limit exceeded (${maxMiddleware}). ` +\n `Current: ${currentCount}, Attempting to add: ${newCount}. ` +\n `This indicates an architectural problem. Consider consolidating middleware.`,\n );\n }\n}\n","// packages/core/src/namespaces/MiddlewareNamespace/MiddlewareNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport {\n validateMiddleware,\n validateMiddlewareLimit,\n validateNoDuplicates,\n validateUseMiddlewareArgs,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { InitializedMiddleware, MiddlewareDependencies } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { Limits, MiddlewareFactory } from \"../../types\";\nimport type {\n DefaultDependencies,\n Middleware,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing middleware.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class MiddlewareNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #factories = new Set<MiddlewareFactory<Dependencies>>();\n readonly #factoryToMiddleware = new Map<\n MiddlewareFactory<Dependencies>,\n Middleware\n >();\n\n #routerStore: Router<Dependencies> | undefined;\n #depsStore: MiddlewareDependencies<Dependencies> | undefined;\n #limits: Limits = DEFAULT_LIMITS;\n\n /**\n * Gets router or throws if not initialized.\n */\n get #router(): Router<Dependencies> {\n /* v8 ignore next 3 -- @preserve: router always set by Router.ts */\n if (!this.#routerStore) {\n throw new Error(\n \"[real-router] MiddlewareNamespace: router not initialized\",\n );\n }\n\n return this.#routerStore;\n }\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): MiddlewareDependencies<Dependencies> {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] MiddlewareNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateUseMiddlewareArgs<D extends DefaultDependencies>(\n middlewares: unknown[],\n ): asserts middlewares is MiddlewareFactory<D>[] {\n validateUseMiddlewareArgs<D>(middlewares);\n }\n\n static validateMiddleware<D extends DefaultDependencies>(\n middleware: unknown,\n factory: MiddlewareFactory<D>,\n ): asserts middleware is Middleware {\n validateMiddleware<D>(middleware, factory);\n }\n\n static validateNoDuplicates<D extends DefaultDependencies>(\n newFactories: MiddlewareFactory<D>[],\n existingFactories: MiddlewareFactory<D>[],\n ): void {\n validateNoDuplicates<D>(newFactories, existingFactories);\n }\n\n static validateMiddlewareLimit(\n currentCount: number,\n newCount: number,\n maxMiddleware?: number,\n ): void {\n validateMiddlewareLimit(currentCount, newCount, maxMiddleware);\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n setRouter(router: Router<Dependencies>): void {\n this.#routerStore = router;\n }\n\n setDependencies(deps: MiddlewareDependencies<Dependencies>): void {\n this.#depsStore = deps;\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the current number of registered middleware.\n */\n count(): number {\n return this.#factories.size;\n }\n\n /**\n * Initializes middleware factories without committing to storage.\n * Returns array of initialized middleware for validation by facade.\n *\n * @param factories - Already validated by facade\n */\n initialize(\n ...factories: MiddlewareFactory<Dependencies>[]\n ): InitializedMiddleware<Dependencies>[] {\n const initialized: InitializedMiddleware<Dependencies>[] = [];\n\n for (const factory of factories) {\n // Middleware factories receive full router as part of their public API\n const middleware = factory(this.#router, this.#deps.getDependency);\n\n initialized.push({ factory, middleware });\n }\n\n return initialized;\n }\n\n /**\n * Commits initialized middleware to storage.\n * Returns unsubscribe function to remove all added middleware.\n *\n * @param initialized - Already validated by facade\n */\n commit(initialized: InitializedMiddleware<Dependencies>[]): Unsubscribe {\n // Check count thresholds and log warnings if needed\n this.#checkCountThresholds(initialized.length);\n\n // Add to storage\n for (const { factory, middleware } of initialized) {\n this.#factories.add(factory);\n this.#factoryToMiddleware.set(factory, middleware);\n }\n\n // Return unsubscribe function specific to THIS call's middleware\n let unsubscribed = false;\n\n return (): void => {\n if (unsubscribed) {\n return;\n }\n\n unsubscribed = true;\n\n for (const { factory } of initialized) {\n this.#factories.delete(factory);\n this.#factoryToMiddleware.delete(factory);\n }\n };\n }\n\n /**\n * Removes all registered middleware.\n */\n clear(): void {\n this.#factories.clear();\n this.#factoryToMiddleware.clear();\n }\n\n /**\n * Returns a copy of registered middleware factories.\n * Preserves insertion order.\n */\n getFactories(): MiddlewareFactory<Dependencies>[] {\n return [...this.#factories];\n }\n\n /**\n * Returns the actual middleware functions in execution order.\n */\n getFunctions(): Middleware[] {\n return [...this.#factoryToMiddleware.values()];\n }\n\n // =========================================================================\n // Private methods\n // =========================================================================\n\n #checkCountThresholds(newCount: number): void {\n const maxMiddleware = this.#limits.maxMiddleware;\n\n if (maxMiddleware === 0) {\n return;\n }\n\n const totalSize = newCount + this.#factories.size;\n\n const { warn, error } = computeThresholds(maxMiddleware);\n\n if (totalSize >= error) {\n logger.error(\n \"router.useMiddleware\",\n `${totalSize} middleware registered! ` +\n `This is excessive and will impact performance. ` +\n `Hard limit at ${maxMiddleware}.`,\n );\n } else if (totalSize >= warn) {\n logger.warn(\n \"router.useMiddleware\",\n `${totalSize} middleware registered. ` +\n `Consider if all are necessary.`,\n );\n }\n }\n}\n","// packages/core/src/namespaces/PluginsNamespace/constants.ts\n\nimport { isObjKey } from \"type-guards\";\n\nimport {\n events as EVENTS_CONST,\n plugins as PLUGINS_CONST,\n} from \"../../constants\";\n\nimport type { EventName } from \"@real-router/types\";\n\n/**\n * Maps plugin method names to router event names.\n */\nexport const EVENTS_MAP = {\n [PLUGINS_CONST.ROUTER_START]: EVENTS_CONST.ROUTER_START,\n [PLUGINS_CONST.ROUTER_STOP]: EVENTS_CONST.ROUTER_STOP,\n [PLUGINS_CONST.TRANSITION_SUCCESS]: EVENTS_CONST.TRANSITION_SUCCESS,\n [PLUGINS_CONST.TRANSITION_START]: EVENTS_CONST.TRANSITION_START,\n [PLUGINS_CONST.TRANSITION_ERROR]: EVENTS_CONST.TRANSITION_ERROR,\n [PLUGINS_CONST.TRANSITION_CANCEL]: EVENTS_CONST.TRANSITION_CANCEL,\n} as const satisfies Record<\n (typeof PLUGINS_CONST)[keyof typeof PLUGINS_CONST],\n EventName\n>;\n\n/**\n * Plugin method names that correspond to router events.\n */\nexport const EVENT_METHOD_NAMES = Object.keys(EVENTS_MAP).filter(\n (eventName): eventName is keyof typeof EVENTS_MAP =>\n isObjKey<typeof EVENTS_MAP>(eventName, EVENTS_MAP),\n);\n\nexport const LOGGER_CONTEXT = \"router.usePlugin\";\n","// packages/core/src/namespaces/PluginsNamespace/validators.ts\n\n/**\n * Static validation functions for PluginsNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { getTypeDescription, isObjKey } from \"type-guards\";\n\nimport { EVENTS_MAP } from \"./constants\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\nimport type { PluginFactory } from \"../../types\";\nimport type { DefaultDependencies, Plugin } from \"@real-router/types\";\n\n/**\n * Validates usePlugin arguments - all must be functions.\n */\nexport function validateUsePluginArgs<D extends DefaultDependencies>(\n plugins: unknown[],\n): asserts plugins is PluginFactory<D>[] {\n for (const plugin of plugins) {\n if (typeof plugin !== \"function\") {\n throw new TypeError(\n `[router.usePlugin] Expected plugin factory function, got ${typeof plugin}`,\n );\n }\n }\n}\n\n/**\n * Validates that a plugin factory returned a valid plugin object.\n */\nexport function validatePlugin(plugin: Plugin): void {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!(plugin && typeof plugin === \"object\") || Array.isArray(plugin)) {\n throw new TypeError(\n `[router.usePlugin] Plugin factory must return an object, got ${getTypeDescription(\n plugin,\n )}`,\n );\n }\n\n // Detect async factory (returns Promise)\n if (typeof (plugin as unknown as { then?: unknown }).then === \"function\") {\n throw new TypeError(\n `[router.usePlugin] Async plugin factories are not supported. ` +\n `Factory returned a Promise instead of a plugin object.`,\n );\n }\n\n for (const key in plugin) {\n if (!(key === \"teardown\" || isObjKey<typeof EVENTS_MAP>(key, EVENTS_MAP))) {\n throw new TypeError(\n `[router.usePlugin] Unknown property '${key}'. ` +\n `Plugin must only contain event handlers and optional teardown.`,\n );\n }\n }\n}\n\n/**\n * Validates that adding new plugins won't exceed the hard limit.\n */\nexport function validatePluginLimit(\n currentCount: number,\n newCount: number,\n maxPlugins: number = DEFAULT_LIMITS.maxPlugins,\n): void {\n if (maxPlugins === 0) {\n return;\n }\n\n const totalCount = currentCount + newCount;\n\n if (totalCount > maxPlugins) {\n throw new Error(`[router.usePlugin] Plugin limit exceeded (${maxPlugins})`);\n }\n}\n","// packages/core/src/namespaces/PluginsNamespace/PluginsNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport { EVENTS_MAP, EVENT_METHOD_NAMES, LOGGER_CONTEXT } from \"./constants\";\nimport {\n validatePlugin,\n validatePluginLimit,\n validateUsePluginArgs,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { PluginsDependencies } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { Limits, PluginFactory } from \"../../types\";\nimport type {\n DefaultDependencies,\n Plugin,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing plugins.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class PluginsNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #plugins = new Set<PluginFactory<Dependencies>>();\n\n #routerStore: Router<Dependencies> | undefined;\n #depsStore: PluginsDependencies<Dependencies> | undefined;\n #limits: Limits = DEFAULT_LIMITS;\n\n /**\n * Gets router or throws if not initialized.\n */\n get #router(): Router<Dependencies> {\n /* v8 ignore next 3 -- @preserve: router always set by Router.ts */\n if (!this.#routerStore) {\n throw new Error(\"[real-router] PluginsNamespace: router not initialized\");\n }\n\n return this.#routerStore;\n }\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): PluginsDependencies<Dependencies> {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] PluginsNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateUsePluginArgs<D extends DefaultDependencies>(\n plugins: unknown[],\n ): asserts plugins is PluginFactory<D>[] {\n validateUsePluginArgs<D>(plugins);\n }\n\n static validatePlugin(plugin: Plugin): void {\n validatePlugin(plugin);\n }\n\n static validatePluginLimit(\n currentCount: number,\n newCount: number,\n maxPlugins?: number,\n ): void {\n validatePluginLimit(currentCount, newCount, maxPlugins);\n }\n\n static validateNoDuplicatePlugins<D extends DefaultDependencies>(\n newFactories: PluginFactory<D>[],\n hasPlugin: (factory: PluginFactory<D>) => boolean,\n ): void {\n for (const factory of newFactories) {\n if (hasPlugin(factory)) {\n throw new Error(\n `[router.usePlugin] Plugin factory already registered. ` +\n `To re-register, first unsubscribe the existing plugin.`,\n );\n }\n }\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n setRouter(router: Router<Dependencies>): void {\n this.#routerStore = router;\n }\n\n setDependencies(deps: PluginsDependencies<Dependencies>): void {\n this.#depsStore = deps;\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Returns the number of registered plugins.\n * Used by facade for limit validation.\n */\n count(): number {\n return this.#plugins.size;\n }\n\n /**\n * Registers one or more plugin factories.\n * Returns unsubscribe function to remove all added plugins.\n * Input already validated by facade (limit, duplicates).\n *\n * @param factories - Already validated by facade\n */\n use(...factories: PluginFactory<Dependencies>[]): Unsubscribe {\n // Emit warnings for count thresholds (not validation, just warnings)\n this.#checkCountThresholds(factories.length);\n\n // Fast path for single plugin (common case)\n if (factories.length === 1) {\n const factory = factories[0];\n const cleanup = this.#startPlugin(factory);\n\n this.#plugins.add(factory);\n\n let unsubscribed = false;\n\n return () => {\n if (unsubscribed) {\n return;\n }\n\n unsubscribed = true;\n this.#plugins.delete(factory);\n try {\n cleanup();\n } catch (error) {\n logger.error(LOGGER_CONTEXT, \"Error during cleanup:\", error);\n }\n };\n }\n\n // Deduplicate batch with warning (validation already done by facade)\n const seenInBatch = this.#deduplicateBatch(factories);\n\n // Track successfully initialized plugins for cleanup\n const initializedPlugins: {\n factory: PluginFactory<Dependencies>;\n cleanup: Unsubscribe;\n }[] = [];\n\n // Initialize deduplicated plugins sequentially\n try {\n for (const plugin of seenInBatch) {\n const cleanup = this.#startPlugin(plugin);\n\n initializedPlugins.push({ factory: plugin, cleanup });\n }\n } catch (error) {\n // Rollback on failure - cleanup all initialized plugins\n for (const { cleanup } of initializedPlugins) {\n try {\n cleanup();\n } catch (cleanupError) {\n logger.error(LOGGER_CONTEXT, \"Cleanup error:\", cleanupError);\n }\n }\n\n throw error;\n }\n\n // Commit phase - add to registry\n for (const { factory } of initializedPlugins) {\n this.#plugins.add(factory);\n }\n\n // Return unsubscribe function\n let unsubscribed = false;\n\n return () => {\n if (unsubscribed) {\n return;\n }\n\n unsubscribed = true;\n\n for (const { factory } of initializedPlugins) {\n this.#plugins.delete(factory);\n }\n\n for (const { cleanup } of initializedPlugins) {\n try {\n cleanup();\n } catch (error) {\n logger.error(LOGGER_CONTEXT, \"Error during cleanup:\", error);\n }\n }\n };\n }\n\n /**\n * Returns registered plugin factories.\n */\n getAll(): PluginFactory<Dependencies>[] {\n return [...this.#plugins];\n }\n\n /**\n * Checks if a plugin factory is registered.\n * Used internally by validation to avoid array allocation.\n */\n has(factory: PluginFactory<Dependencies>): boolean {\n return this.#plugins.has(factory);\n }\n\n // =========================================================================\n // Private methods\n // =========================================================================\n\n #checkCountThresholds(newCount: number): void {\n const maxPlugins = this.#limits.maxPlugins;\n\n if (maxPlugins === 0) {\n return;\n }\n\n const totalCount = newCount + this.#plugins.size;\n\n const { warn, error } = computeThresholds(maxPlugins);\n\n if (totalCount >= error) {\n logger.error(LOGGER_CONTEXT, `${totalCount} plugins registered!`);\n } else if (totalCount >= warn) {\n logger.warn(LOGGER_CONTEXT, `${totalCount} plugins registered`);\n }\n }\n\n /**\n * Deduplicates batch with warning for duplicates within batch.\n * Validation (existing duplicates) is done by facade.\n */\n #deduplicateBatch(\n plugins: PluginFactory<Dependencies>[],\n ): Set<PluginFactory<Dependencies>> {\n const seenInBatch = new Set<PluginFactory<Dependencies>>();\n\n for (const plugin of plugins) {\n if (seenInBatch.has(plugin)) {\n logger.warn(\n LOGGER_CONTEXT,\n \"Duplicate factory in batch, will be registered once\",\n );\n } else {\n seenInBatch.add(plugin);\n }\n }\n\n return seenInBatch;\n }\n\n #startPlugin(pluginFactory: PluginFactory<Dependencies>): Unsubscribe {\n // Bind getDependency to preserve 'this' context when called from factory\n // Plugin factories receive full router as part of their public API\n const appliedPlugin = pluginFactory(this.#router, this.#deps.getDependency);\n\n PluginsNamespace.validatePlugin(appliedPlugin);\n\n Object.freeze(appliedPlugin);\n\n // Collect all unsubscribe functions\n const removeEventListeners: Unsubscribe[] = [];\n\n // Subscribe plugin methods to corresponding router events\n for (const methodName of EVENT_METHOD_NAMES) {\n if (methodName in appliedPlugin) {\n if (typeof appliedPlugin[methodName] === \"function\") {\n removeEventListeners.push(\n this.#deps.addEventListener(\n EVENTS_MAP[methodName],\n appliedPlugin[methodName],\n ),\n );\n\n if (methodName === \"onStart\" && this.#deps.isStarted()) {\n logger.warn(\n LOGGER_CONTEXT,\n \"Router already started, onStart will not be called\",\n );\n }\n } else {\n logger.warn(\n LOGGER_CONTEXT,\n `Property '${methodName}' is not a function, skipping`,\n );\n }\n }\n }\n\n // Return composite cleanup function\n return () => {\n for (const removeListener of removeEventListeners) {\n removeListener();\n }\n\n if (typeof appliedPlugin.teardown === \"function\") {\n appliedPlugin.teardown();\n }\n };\n }\n}\n","// packages/core/src/namespaces/RouteLifecycleNamespace/validators.ts\n\n/**\n * Static validation functions for RouteLifecycleNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { isBoolean, getTypeDescription } from \"type-guards\";\n\nimport { DEFAULT_LIMITS } from \"../../constants\";\n\nimport type { ActivationFnFactory } from \"../../types\";\nimport type { DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Validates that a handler is either a boolean or a factory function.\n */\nexport function validateHandler<D extends DefaultDependencies>(\n handler: unknown,\n methodName: string,\n): asserts handler is ActivationFnFactory<D> | boolean {\n if (!isBoolean(handler) && typeof handler !== \"function\") {\n throw new TypeError(\n `[router.${methodName}] Handler must be a boolean or factory function, ` +\n `got ${getTypeDescription(handler)}`,\n );\n }\n}\n\n/**\n * Validates that a route is not currently being registered.\n * Prevents self-modification during factory compilation.\n */\nexport function validateNotRegistering(\n isRegistering: boolean,\n name: string,\n methodName: string,\n): void {\n if (isRegistering) {\n throw new Error(\n `[router.${methodName}] Cannot modify route \"${name}\" during its own registration`,\n );\n }\n}\n\n/**\n * Validates that adding a new handler won't exceed the hard limit.\n */\nexport function validateHandlerLimit(\n currentCount: number,\n methodName: string,\n maxLifecycleHandlers: number = DEFAULT_LIMITS.maxLifecycleHandlers,\n): void {\n if (maxLifecycleHandlers === 0) {\n return;\n }\n\n if (currentCount >= maxLifecycleHandlers) {\n throw new Error(\n `[router.${methodName}] Lifecycle handler limit exceeded (${maxLifecycleHandlers}). ` +\n `This indicates too many routes with individual handlers. ` +\n `Consider using middleware for cross-cutting concerns.`,\n );\n }\n}\n","// packages/core/src/namespaces/RouteLifecycleNamespace/RouteLifecycleNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\nimport { isBoolean, getTypeDescription } from \"type-guards\";\n\nimport {\n validateHandler,\n validateHandlerLimit,\n validateNotRegistering,\n} from \"./validators\";\nimport { DEFAULT_LIMITS } from \"../../constants\";\nimport { computeThresholds } from \"../../helpers\";\n\nimport type { RouteLifecycleDependencies } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { ActivationFnFactory, Limits } from \"../../types\";\nimport type { ActivationFn, DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Converts a boolean value to an activation function factory.\n * Used for the shorthand syntax where true/false is passed instead of a function.\n */\nfunction booleanToFactory<Dependencies extends DefaultDependencies>(\n value: boolean,\n): ActivationFnFactory<Dependencies> {\n const activationFn: ActivationFn = () => value;\n\n return () => activationFn;\n}\n\n/**\n * Independent namespace for managing route lifecycle handlers.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class RouteLifecycleNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n readonly #canDeactivateFactories = new Map<\n string,\n ActivationFnFactory<Dependencies>\n >();\n readonly #canActivateFactories = new Map<\n string,\n ActivationFnFactory<Dependencies>\n >();\n readonly #canDeactivateFunctions = new Map<string, ActivationFn>();\n readonly #canActivateFunctions = new Map<string, ActivationFn>();\n\n readonly #registering = new Set<string>();\n\n #routerStore: Router<Dependencies> | undefined;\n #depsStore: RouteLifecycleDependencies<Dependencies> | undefined;\n #limits: Limits = DEFAULT_LIMITS;\n\n /**\n * Gets router or throws if not initialized.\n */\n get #router(): Router<Dependencies> {\n /* v8 ignore next 3 -- @preserve: router always set by Router.ts */\n if (!this.#routerStore) {\n throw new Error(\n \"[real-router] RouteLifecycleNamespace: router not initialized\",\n );\n }\n\n return this.#routerStore;\n }\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): RouteLifecycleDependencies<Dependencies> {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] RouteLifecycleNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateHandler<D extends DefaultDependencies>(\n handler: unknown,\n methodName: string,\n ): asserts handler is ActivationFnFactory<D> | boolean {\n validateHandler<D>(handler, methodName);\n }\n\n static validateNotRegistering(\n isRegistering: boolean,\n name: string,\n methodName: string,\n ): void {\n validateNotRegistering(isRegistering, name, methodName);\n }\n\n static validateHandlerLimit(\n currentCount: number,\n methodName: string,\n maxLifecycleHandlers?: number,\n ): void {\n validateHandlerLimit(currentCount, methodName, maxLifecycleHandlers);\n }\n\n setRouter(router: Router<Dependencies>): void {\n this.#routerStore = router;\n }\n\n setDependencies(deps: RouteLifecycleDependencies<Dependencies>): void {\n this.#depsStore = deps;\n }\n\n setLimits(limits: Limits): void {\n this.#limits = limits;\n }\n\n // =========================================================================\n // State accessors (for facade validation)\n // =========================================================================\n\n /**\n * Returns true if route is currently being registered.\n * Used by facade for self-modification validation.\n */\n isRegistering(name: string): boolean {\n return this.#registering.has(name);\n }\n\n /**\n * Returns the number of canActivate handlers.\n * Used by facade for limit validation.\n */\n countCanActivate(): number {\n return this.#canActivateFactories.size;\n }\n\n /**\n * Returns the number of canDeactivate handlers.\n * Used by facade for limit validation.\n */\n countCanDeactivate(): number {\n return this.#canDeactivateFactories.size;\n }\n\n /**\n * Returns true if canActivate handler exists for route.\n * Used by facade to determine if this is an overwrite.\n */\n hasCanActivate(name: string): boolean {\n return this.#canActivateFactories.has(name);\n }\n\n /**\n * Returns true if canDeactivate handler exists for route.\n * Used by facade to determine if this is an overwrite.\n */\n hasCanDeactivate(name: string): boolean {\n return this.#canDeactivateFactories.has(name);\n }\n\n // =========================================================================\n // Instance methods (trust input - already validated by facade)\n // =========================================================================\n\n /**\n * Registers a canActivate guard for a route.\n * Input already validated by facade (not registering, limit).\n *\n * @param name - Route name (already validated by facade)\n * @param handler - Guard function or boolean (already validated)\n * @param isOverwrite - True if overwriting existing handler (computed by facade)\n */\n registerCanActivate(\n name: string,\n handler: ActivationFnFactory<Dependencies> | boolean,\n isOverwrite: boolean,\n ): void {\n this.#registerHandler(\n \"activate\",\n name,\n handler,\n this.#canActivateFactories,\n this.#canActivateFunctions,\n \"canActivate\",\n isOverwrite,\n );\n }\n\n /**\n * Registers a canDeactivate guard for a route.\n * Input already validated by facade (not registering, limit).\n *\n * @param name - Route name (already validated by facade)\n * @param handler - Guard function or boolean (already validated)\n * @param isOverwrite - True if overwriting existing handler (computed by facade)\n */\n registerCanDeactivate(\n name: string,\n handler: ActivationFnFactory<Dependencies> | boolean,\n isOverwrite: boolean,\n ): void {\n this.#registerHandler(\n \"deactivate\",\n name,\n handler,\n this.#canDeactivateFactories,\n this.#canDeactivateFunctions,\n \"canDeactivate\",\n isOverwrite,\n );\n }\n\n /**\n * Removes a canActivate guard for a route.\n * Input already validated by facade (not registering).\n *\n * @param name - Route name (already validated by facade)\n * @param _silent - Unused (kept for API compatibility)\n */\n clearCanActivate(name: string, _silent = false): void {\n this.#canActivateFactories.delete(name);\n this.#canActivateFunctions.delete(name);\n }\n\n /**\n * Removes a canDeactivate guard for a route.\n * Input already validated by facade (not registering).\n *\n * @param name - Route name (already validated by facade)\n * @param _silent - Unused (kept for API compatibility)\n */\n clearCanDeactivate(name: string, _silent = false): void {\n this.#canDeactivateFactories.delete(name);\n this.#canDeactivateFunctions.delete(name);\n }\n\n /**\n * Clears all lifecycle handlers (canActivate and canDeactivate).\n * Used by clearRoutes to reset all lifecycle state.\n */\n clearAll(): void {\n this.#canActivateFactories.clear();\n this.#canActivateFunctions.clear();\n this.#canDeactivateFactories.clear();\n this.#canDeactivateFunctions.clear();\n }\n\n /**\n * Returns lifecycle factories as records for cloning.\n *\n * @returns Tuple of [canDeactivateFactories, canActivateFactories]\n */\n getFactories(): [\n Record<string, ActivationFnFactory<Dependencies>>,\n Record<string, ActivationFnFactory<Dependencies>>,\n ] {\n const deactivateRecord: Record<\n string,\n ActivationFnFactory<Dependencies>\n > = {};\n const activateRecord: Record<\n string,\n ActivationFnFactory<Dependencies>\n > = {};\n\n for (const [name, factory] of this.#canDeactivateFactories) {\n deactivateRecord[name] = factory;\n }\n\n for (const [name, factory] of this.#canActivateFactories) {\n activateRecord[name] = factory;\n }\n\n return [deactivateRecord, activateRecord];\n }\n\n /**\n * Returns compiled lifecycle functions for transition execution.\n *\n * @returns Tuple of [canDeactivateFunctions, canActivateFunctions] as Maps\n */\n getFunctions(): [Map<string, ActivationFn>, Map<string, ActivationFn>] {\n return [this.#canDeactivateFunctions, this.#canActivateFunctions];\n }\n\n // =========================================================================\n // Private methods (business logic)\n // =========================================================================\n\n /**\n * Registers a handler. Input already validated by facade.\n * Handles overwrite warning, count threshold warnings, and factory compilation.\n */\n #registerHandler(\n type: \"activate\" | \"deactivate\",\n name: string,\n handler: ActivationFnFactory<Dependencies> | boolean,\n factories: Map<string, ActivationFnFactory<Dependencies>>,\n functions: Map<string, ActivationFn>,\n methodName: string,\n isOverwrite: boolean,\n ): void {\n // Emit warnings (validation done by facade)\n if (isOverwrite) {\n logger.warn(\n `router.${methodName}`,\n `Overwriting existing ${type} handler for route \"${name}\"`,\n );\n } else {\n this.#checkCountThresholds(factories.size + 1, methodName);\n }\n\n // Convert boolean to factory if needed\n const factory = isBoolean(handler)\n ? booleanToFactory<Dependencies>(handler)\n : handler;\n\n // Store factory\n factories.set(name, factory);\n\n // Mark route as being registered before calling user factory\n this.#registering.add(name);\n\n try {\n // Lifecycle factories receive full router as part of their public API\n const fn = factory(this.#router, this.#deps.getDependency);\n\n if (typeof fn !== \"function\") {\n throw new TypeError(\n `[router.${methodName}] Factory must return a function, got ${getTypeDescription(fn)}`,\n );\n }\n\n functions.set(name, fn);\n } catch (error) {\n // Rollback on failure to maintain consistency\n factories.delete(name);\n\n throw error;\n } finally {\n this.#registering.delete(name);\n }\n }\n\n #checkCountThresholds(currentSize: number, methodName: string): void {\n const maxLifecycleHandlers = this.#limits.maxLifecycleHandlers;\n\n if (maxLifecycleHandlers === 0) {\n return;\n }\n\n const { warn, error } = computeThresholds(maxLifecycleHandlers);\n\n if (currentSize >= error) {\n logger.error(\n `router.${methodName}`,\n `${currentSize} lifecycle handlers registered! ` +\n `This is excessive. Hard limit at ${maxLifecycleHandlers}.`,\n );\n } else if (currentSize >= warn) {\n logger.warn(\n `router.${methodName}`,\n `${currentSize} lifecycle handlers registered. ` +\n `Consider consolidating logic.`,\n );\n }\n }\n}\n","// packages/route-node/modules/builder/buildTree.ts\n\n/**\n * Tree Building.\n *\n * Constructs the mutable tree structure from route definitions.\n *\n * @module builder/buildTree\n */\n\nimport type { RouteDefinition } from \"../types\";\n\n// =============================================================================\n// Mutable Node Type (internal)\n// =============================================================================\n\n/**\n * Mutable version of RouteTree used during building.\n * After building, this is converted to immutable RouteTree.\n */\nexport interface MutableRouteNode {\n name: string;\n path: string;\n absolute: boolean;\n children: MutableRouteNode[];\n parent: MutableRouteNode | null;\n\n // These are computed later by computeCaches\n nonAbsoluteChildren: MutableRouteNode[];\n fullName: string;\n}\n\n// =============================================================================\n// Building Functions\n// =============================================================================\n\n/**\n * Creates a mutable node from a route definition.\n *\n * @param definition - Route definition object\n * @param definition.name - Route name\n * @param definition.path - Route path\n * @param definition.children - Optional child routes\n * @param parent - Parent node (null for root)\n * @returns Mutable node\n */\nfunction createNode(\n definition: {\n name: string;\n path: string;\n children?: RouteDefinition[] | undefined;\n },\n parent: MutableRouteNode | null,\n): MutableRouteNode {\n const path = definition.path;\n const absolute = path.startsWith(\"~\");\n const normalizedPath = absolute ? path.slice(1) : path;\n\n const node: MutableRouteNode = {\n name: definition.name,\n path: normalizedPath,\n absolute,\n children: [],\n parent,\n // These will be computed by computeCaches\n nonAbsoluteChildren: [],\n fullName: \"\",\n };\n\n // Recursively add children\n if (definition.children) {\n for (const childDef of definition.children) {\n const childNode = createNode(childDef, node);\n\n node.children.push(childNode);\n }\n }\n\n return node;\n}\n\n/**\n * Resolves parent node for dot-notation names.\n *\n * For example, \"users.profile\" needs to find the \"users\" node first.\n *\n * @param root - Root node\n * @param name - Route name (possibly with dots)\n * @returns Parent node and final name segment\n */\nfunction resolveParent(\n root: MutableRouteNode,\n name: string,\n): { parent: MutableRouteNode; finalName: string } {\n const parts = name.split(\".\");\n\n if (parts.length === 1) {\n return { parent: root, finalName: name };\n }\n\n // Navigate to parent\n let current = root;\n\n for (let i = 0; i < parts.length - 1; i++) {\n const partName = parts[i];\n\n // validateRoutes ensures parent exists before building\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n current = current.children.find((c) => c.name === partName)!;\n }\n\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return { parent: current, finalName: parts.at(-1)! };\n}\n\n/**\n * Builds the mutable tree structure from route definitions.\n *\n * Handles:\n * - Creating root node\n * - Processing flat and nested routes\n * - Dot-notation names (e.g., \"users.profile\")\n *\n * @param rootName - Root node name (typically \"\")\n * @param rootPath - Root node path (typically \"\")\n * @param routes - Route definitions\n * @returns Mutable root node\n */\nexport function buildTree(\n rootName: string,\n rootPath: string,\n routes: readonly RouteDefinition[],\n): MutableRouteNode {\n // Create root node\n const root = createNode({ name: rootName, path: rootPath }, null);\n\n // First pass: add routes with nested children\n const flatRoutes: RouteDefinition[] = [];\n\n for (const route of routes) {\n if (route.name.includes(\".\")) {\n // Dot-notation name - process later\n flatRoutes.push(route);\n } else if (route.children && route.children.length > 0) {\n // Has children - add directly\n const node = createNode(route, root);\n\n root.children.push(node);\n } else {\n // Simple route without children\n flatRoutes.push(route);\n }\n }\n\n // Second pass: add flat routes and dot-notation names\n for (const route of flatRoutes) {\n const { parent, finalName } = resolveParent(root, route.name);\n\n const node = createNode(\n { name: finalName, path: route.path, children: route.children },\n parent,\n );\n\n parent.children.push(node);\n }\n\n return root;\n}\n","// packages/route-tree/src/services/buildParamMeta.ts\n\n/**\n * Route Parameter Metadata Extraction.\n *\n * Extracts parameter metadata from route path patterns without requiring\n * a full path-parser instance. Replaces parser.urlParams/queryParams/spatParams.\n *\n * @module services/buildParamMeta\n */\n\n/**\n * Constraint pattern for a URL parameter.\n */\nexport interface ConstraintPattern {\n /**\n * Compiled RegExp for validating the parameter value.\n *\n * @example /^(\\d+)$/ for constraint \"<\\\\d+>\"\n */\n readonly pattern: RegExp;\n\n /**\n * Raw constraint string from the route pattern.\n *\n * @example \"<\\\\d+>\"\n */\n readonly constraint: string;\n}\n\n/**\n * Parameter metadata extracted from a route path pattern.\n */\nexport interface ParamMeta {\n /**\n * URL parameter names extracted from the path pattern.\n *\n * @example [\":id\", \":postId\"] from \"/users/:id/posts/:postId\"\n */\n readonly urlParams: readonly string[];\n\n /**\n * Query parameter names extracted from the path pattern.\n *\n * @example [\"q\", \"page\"] from \"/search?q&page\"\n */\n readonly queryParams: readonly string[];\n\n /**\n * Splat parameter names extracted from the path pattern.\n *\n * @example [\"path\"] from \"/files/*path\"\n */\n readonly spatParams: readonly string[];\n\n /**\n * Map of parameter names to their type (url or query).\n *\n * @example { id: \"url\", q: \"query\" }\n */\n readonly paramTypeMap: Readonly<Record<string, \"url\" | \"query\">>;\n\n /**\n * Map of parameter names to their constraint patterns.\n *\n * Only includes parameters with explicit constraints (e.g., `:id<\\\\d+>`).\n * Parameters without constraints are not included in this map.\n *\n * @example\n * ```typescript\n * buildParamMeta(\"/users/:id<\\\\d+>\").constraintPatterns.get(\"id\")\n * // â { pattern: /^(\\d+)$/, constraint: \"<\\\\d+>\" }\n *\n * buildParamMeta(\"/users/:id\").constraintPatterns.size\n * // â 0 (no constraints)\n * ```\n */\n readonly constraintPatterns: ReadonlyMap<string, ConstraintPattern>;\n\n /**\n * Path pattern without query string, pre-computed for buildPath.\n *\n * @example \"/users/:id\" from \"/users/:id?q&page\"\n */\n readonly pathPattern: string;\n}\n\n/**\n * Extracts the regex pattern from a constraint string.\n *\n * @param constraint - Constraint string (e.g., \"<\\\\d+>\")\n * @returns Regex capture group pattern (e.g., \"(\\\\d+)\")\n */\nfunction extractConstraintPattern(constraint: string): string {\n // Strip leading \"<\" and trailing \">\" from constraint\n const pattern = constraint.replaceAll(/(^<|>$)/g, \"\");\n\n return `(${pattern})`;\n}\n\n/**\n * Regex for matching URL parameters in path patterns.\n *\n * Matches:\n * - `:paramName` - named URL parameter\n * - `:paramName<constraint>` - constrained parameter\n * - `:paramName?` - optional parameter\n * - `*paramName` - splat parameter\n * - `*` - unnamed splat\n *\n * Groups:\n * - [1]: marker (`:` or `*`)\n * - [2]: parameter name\n * - [3]: constraint (e.g., `<\\\\d+>`) or undefined\n * - [4]: optional marker (`?`) or undefined\n *\n * @example\n * ```\n * \"/users/:id\" â matches \":id\"\n * \"/users/:id<\\\\d+>\" â matches \":id<\\\\d+>\"\n * \"/users/:id?\" â matches \":id?\"\n * \"/files/*path\" â matches \"*path\"\n * ```\n */\n\nconst URL_PARAM_RGX = /([:*])([^/?<]+)(<[^>]+>)?(\\?)?/g;\n\n/**\n * Regex for matching query parameters in path patterns.\n *\n * Matches query string portion after \"?\" in path.\n *\n * @example\n * ```\n * \"/search?q&page\" â matches \"q&page\"\n * ```\n */\n// eslint-disable-next-line sonarjs/slow-regex\nconst QUERY_PARAM_RGX = /\\?(.+)$/;\n\n/**\n * Builds parameter metadata from a route path pattern.\n *\n * Extracts URL parameters, query parameters, and splat parameters\n * from the path pattern string.\n *\n * @param path - Route path pattern (e.g., \"/users/:id/posts/:postId?q\")\n * @returns Parameter metadata object\n *\n * @example\n * ```typescript\n * buildParamMeta(\"/users/:id\")\n * // â {\n * // urlParams: [\"id\"],\n * // queryParams: [],\n * // spatParams: [],\n * // paramTypeMap: { id: \"url\" }\n * // }\n *\n * buildParamMeta(\"/search?q&page\")\n * // â {\n * // urlParams: [],\n * // queryParams: [\"q\", \"page\"],\n * // spatParams: [],\n * // paramTypeMap: { q: \"query\", page: \"query\" }\n * // }\n *\n * buildParamMeta(\"/files/*path\")\n * // â {\n * // urlParams: [\"path\"],\n * // queryParams: [],\n * // spatParams: [\"path\"],\n * // paramTypeMap: { path: \"url\" }\n * // }\n *\n * buildParamMeta(\"/users/:id/posts/:postId?q&page\")\n * // â {\n * // urlParams: [\"id\", \"postId\"],\n * // queryParams: [\"q\", \"page\"],\n * // spatParams: [],\n * // paramTypeMap: { id: \"url\", postId: \"url\", q: \"query\", page: \"query\" }\n * // }\n * ```\n */\nexport function buildParamMeta(path: string): ParamMeta {\n const urlParams: string[] = [];\n const queryParams: string[] = [];\n const spatParams: string[] = [];\n const paramTypeMap: Record<string, \"url\" | \"query\"> = {};\n const constraintPatterns = new Map<string, ConstraintPattern>();\n\n const queryMatch = QUERY_PARAM_RGX.exec(path);\n\n if (queryMatch !== null) {\n const queryString = queryMatch[1];\n const params = queryString.split(\"&\");\n\n for (const param of params) {\n const paramName = param.trim();\n\n if (paramName.length > 0) {\n queryParams.push(paramName);\n paramTypeMap[paramName] = \"query\";\n }\n }\n\n path = path.slice(0, queryMatch.index);\n }\n\n let match: RegExpExecArray | null;\n\n while ((match = URL_PARAM_RGX.exec(path)) !== null) {\n const marker = match[1];\n const paramName = match[2];\n const constraintStr = match[3];\n\n if (marker === \"*\") {\n spatParams.push(paramName);\n urlParams.push(paramName);\n paramTypeMap[paramName] = \"url\";\n } else {\n urlParams.push(paramName);\n paramTypeMap[paramName] = \"url\";\n\n if (constraintStr) {\n const regexPattern = `^${extractConstraintPattern(constraintStr)}$`;\n\n constraintPatterns.set(paramName, {\n pattern: new RegExp(regexPattern),\n constraint: constraintStr,\n });\n }\n }\n }\n\n return {\n urlParams,\n queryParams,\n spatParams,\n paramTypeMap,\n constraintPatterns,\n pathPattern: path,\n };\n}\n","// packages/route-node/modules/builder/computeCaches.ts\n\n/**\n * Cache Computation.\n *\n * Computes all pre-computed caches and freezes the tree.\n *\n * @module builder/computeCaches\n */\n\nimport { buildParamMeta } from \"../services/buildParamMeta\";\n\nimport type { MutableRouteNode } from \"./buildTree\";\nimport type { RouteTree } from \"../types\";\n\n// =============================================================================\n// Cache Computation Functions\n// =============================================================================\n\n/**\n * Computes the full dot-notation name for a node.\n * Parent fullName is always computed before children.\n *\n * @param node - Node to compute for\n * @returns Full name (e.g., \"users.profile\")\n */\nfunction computeFullName(node: RouteTree): string {\n if (!node.parent?.name) {\n return node.name;\n }\n\n // Parent fullName is always set before children are processed\n return `${node.parent.fullName}.${node.name}`;\n}\n\n/**\n * Computes static path for routes without parameters.\n *\n * Returns pre-built path string for fast buildPath lookup,\n * or null if the route has any dynamic parameters.\n *\n * @param node - Node to compute for\n * @returns Static path or null\n */\nfunction computeStaticPath(node: RouteTree): string | null {\n // Root nodes without path patterns can't have static paths\n if (!node.path) {\n return null;\n }\n\n const { urlParams, queryParams, spatParams } = node.paramMeta;\n\n // If route has any parameters, we can't pre-compute\n if (urlParams.length > 0 || queryParams.length > 0 || spatParams.length > 0) {\n return null;\n }\n\n // Build the full path from parent segments + this segment\n // Collect parent segments via parent chain (same logic as computeParentSegments)\n const parentSegments: RouteTree[] = [];\n let current = node.parent;\n\n while (current?.path) {\n parentSegments.push(current);\n current = current.parent;\n }\n\n parentSegments.reverse();\n\n let path = \"\";\n\n for (const segment of parentSegments) {\n const {\n urlParams: segUrlParams,\n queryParams: segQueryParams,\n spatParams: segSpatParams,\n } = segment.paramMeta;\n\n // Parent segments with params invalidate static path\n if (\n segUrlParams.length > 0 ||\n segQueryParams.length > 0 ||\n segSpatParams.length > 0\n ) {\n return null;\n }\n\n path = segment.absolute ? segment.path : path + segment.path;\n }\n\n // Add this node's path\n path = node.absolute ? node.path : path + node.path;\n\n // Normalize double slashes - always apply regex (avoids equivalent mutants)\n return path.replaceAll(/\\/{2,}/g, \"/\");\n}\n\n// =============================================================================\n// Main Computation Function\n// =============================================================================\n\n/**\n * Computes children Map from mutable children array.\n *\n * Children are stored in definition order. Matching priority is handled\n * by rou3's radix tree, not by iteration order.\n *\n * @param childrenArray - Array of processed child nodes\n * @returns ReadonlyMap of child name -> child node (in definition order)\n */\nfunction computeChildrenMap(\n childrenArray: RouteTree[],\n): ReadonlyMap<string, RouteTree> {\n const map = new Map<string, RouteTree>();\n\n for (const child of childrenArray) {\n map.set(child.name, child);\n }\n\n return map;\n}\n\n/**\n * Recursively processes a mutable node into a RouteTree.\n *\n * This creates a new object with all caches computed.\n * Optionally freezes the result for immutability.\n *\n * @param mutable - Mutable node to process\n * @param parent - Already-processed parent node (null for root)\n * @param freeze - Whether to freeze the result\n * @returns RouteTree (frozen if freeze=true)\n */\nfunction processNode(\n mutable: MutableRouteNode,\n parent: RouteTree | null,\n freeze: boolean,\n): RouteTree {\n const childrenArray: RouteTree[] = [];\n const nonAbsoluteChildren: RouteTree[] = [];\n\n const paramMeta = buildParamMeta(mutable.path);\n\n const node = {\n name: mutable.name,\n path: mutable.path,\n absolute: mutable.absolute,\n parent,\n children: new Map<string, RouteTree>() as ReadonlyMap<string, RouteTree>,\n paramMeta,\n nonAbsoluteChildren: [] as RouteTree[],\n fullName: \"\",\n staticPath: null as string | null,\n paramTypeMap: {} as Record<string, \"url\" | \"query\">,\n };\n\n for (const p of paramMeta.urlParams) {\n node.paramTypeMap[p] = \"url\";\n }\n\n for (const p of paramMeta.queryParams) {\n node.paramTypeMap[p] = \"query\";\n }\n\n node.fullName = computeFullName(node as RouteTree);\n\n for (const childMutable of mutable.children) {\n const child = processNode(childMutable, node as RouteTree, freeze);\n\n childrenArray.push(child);\n\n if (!child.absolute) {\n nonAbsoluteChildren.push(child);\n }\n }\n\n node.children = computeChildrenMap(childrenArray);\n node.nonAbsoluteChildren = nonAbsoluteChildren;\n\n node.staticPath = computeStaticPath(node as RouteTree);\n\n if (freeze) {\n Object.freeze(node.nonAbsoluteChildren);\n Object.freeze(node.paramTypeMap);\n Object.freeze(node.children);\n Object.freeze(node);\n }\n\n return node as RouteTree;\n}\n\n/**\n * Computes all caches and optionally freezes the tree.\n *\n * This is the final step in building a RouteTree.\n * When freeze=true (default), the tree is completely immutable.\n *\n * @param mutableRoot - Mutable root node\n * @param freeze - Whether to freeze the result (default: true)\n * @returns RouteTree (frozen if freeze=true)\n */\nexport function computeCaches(\n mutableRoot: MutableRouteNode,\n freeze = true,\n): RouteTree {\n return processNode(mutableRoot, null, freeze);\n}\n","// packages/route-node/modules/builder/createRouteTree.ts\n\n/**\n * Route Tree Builder.\n *\n * Creates immutable RouteTree from route definitions.\n *\n * @module builder/createRouteTree\n */\n\nimport { buildTree } from \"./buildTree\";\nimport { computeCaches } from \"./computeCaches\";\n\nimport type {\n RouteDefinition,\n RouteTree,\n RouteTreeBuilder,\n TreeBuildOptions,\n} from \"../types\";\n\n// =============================================================================\n// Builder Implementation\n// =============================================================================\n\n/**\n * Creates a RouteTreeBuilder for constructing route trees.\n *\n * @param name - Root node name (typically empty string)\n * @param path - Root node path (typically empty string)\n * @returns RouteTreeBuilder instance\n *\n * @example\n * ```typescript\n * const tree = createRouteTreeBuilder(\"\", \"\")\n * .add({ name: \"users\", path: \"/users\" })\n * .add({ name: \"users.profile\", path: \"/:id\" })\n * .build();\n * ```\n */\nexport function createRouteTreeBuilder(\n name: string,\n path: string,\n): RouteTreeBuilder {\n const routes: RouteDefinition[] = [];\n\n return {\n add(route: RouteDefinition): RouteTreeBuilder {\n routes.push(route);\n\n return this;\n },\n\n addMany(newRoutes: readonly RouteDefinition[]): RouteTreeBuilder {\n routes.push(...newRoutes);\n\n return this;\n },\n\n build(options?: TreeBuildOptions): RouteTree {\n // Step 1: Build mutable tree structure\n const mutableTree = buildTree(name, path, routes);\n\n // Step 2: Compute all caches and optionally freeze\n const freeze = !options?.skipFreeze;\n\n return computeCaches(mutableTree, freeze);\n },\n };\n}\n\n// =============================================================================\n// Convenience Function\n// =============================================================================\n\n/**\n * Creates a RouteTree directly from route definitions.\n *\n * Convenience wrapper around createRouteTreeBuilder().\n *\n * @param name - Root node name (typically empty string)\n * @param path - Root node path (typically empty string)\n * @param routes - Route definitions to add\n * @param options - Build options (e.g., skipFreeze)\n * @returns Immutable RouteTree\n *\n * @example\n * ```typescript\n * const tree = createRouteTree(\"\", \"\", [\n * { name: \"users\", path: \"/users\" },\n * { name: \"users.profile\", path: \"/:id\" },\n * ]);\n * ```\n */\nexport function createRouteTree(\n name: string,\n path: string,\n routes: readonly RouteDefinition[],\n options?: TreeBuildOptions,\n): RouteTree {\n return createRouteTreeBuilder(name, path).addMany(routes).build(options);\n}\n","// packages/route-node/modules/search-params/decode.ts\n\n/**\n * Decoding functions for search-params.\n *\n * Extracted from encode.ts for better separation of concerns.\n *\n * @module search-params/decode\n */\n\nimport type { ResolvedStrategies } from \"./strategies\";\nimport type { DecodeResult } from \"./types\";\n\n// =============================================================================\n// Value Decoding\n// =============================================================================\n\n/**\n * Decodes a URL-encoded value, handling + as space.\n * Optimized: only replaces + if present, skips decodeURIComponent if not needed.\n *\n * Uses indexOf for checking presence - more mutation-resistant than includes\n * because indexOf(\"x\") returns -1 when not found, while includes(\"\") always returns true.\n */\nexport const decodeValue = (value: string): string => {\n const percentIdx = value.indexOf(\"%\");\n const plusIdx = value.indexOf(\"+\");\n\n // Fast path: no encoding needed (common case - most values are simple)\n if (percentIdx === -1 && plusIdx === -1) {\n return value;\n }\n\n // Only replace + if present (avoid regex overhead)\n const withSpaces = plusIdx === -1 ? value : value.split(\"+\").join(\" \");\n\n // Only decode if % is present\n return percentIdx === -1 ? withSpaces : decodeURIComponent(withSpaces);\n};\n\n// =============================================================================\n// Main Decode\n// =============================================================================\n\n/**\n * Decodes a query parameter value using resolved strategies.\n *\n * @param value - Raw value from query string (undefined for key-only params)\n * @param strategies - Pre-resolved format strategies\n * @returns Decoded value (string, boolean, or null)\n */\nexport const decode = (\n value: string | undefined,\n strategies: ResolvedStrategies,\n): DecodeResult => {\n // Handle undefined (key-only params like ?flag)\n if (value === undefined) {\n return strategies.boolean.decodeUndefined();\n }\n\n // Check raw value for boolean formats (e.g., \"true\"/\"false\")\n const rawResult = strategies.boolean.decodeRaw(value);\n\n if (rawResult !== null) {\n return rawResult;\n }\n\n // Decode URI and check decoded value for boolean formats (e.g., â/â)\n const decoded = decodeValue(value);\n\n return strategies.boolean.decodeValue(decoded);\n};\n","// packages/route-node/modules/search-params/strategies/array.ts\n\n/**\n * Array encoding strategies.\n *\n * @module search-params/strategies/array\n */\n\nimport type { ArrayFormat } from \"../types\";\n\n// =============================================================================\n// Strategy Interface\n// =============================================================================\n\n/**\n * Strategy for encoding array values.\n */\nexport interface ArrayStrategy {\n /**\n * Encodes an array as a query string segment.\n *\n * @param name - URL-encoded parameter name\n * @param values - Array values to encode\n * @returns Query string segment (e.g., \"items=a&items=b\" or \"items=a,b\")\n */\n encodeArray: (name: string, values: unknown[]) => string;\n}\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\nconst encodeValue = (value: unknown): string =>\n encodeURIComponent(value as string | number | boolean);\n\n// =============================================================================\n// Strategy Implementations\n// =============================================================================\n\n/**\n * Repeated keys without brackets.\n * Example: items=a&items=b\n */\nexport const noneArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n values.map((val) => `${name}=${encodeValue(val)}`).join(\"&\"),\n};\n\n/**\n * Bracket notation without index.\n * Example: items[]=a&items[]=b\n */\nexport const bracketsArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n values.map((val) => `${name}[]=${encodeValue(val)}`).join(\"&\"),\n};\n\n/**\n * Indexed bracket notation.\n * Example: items[0]=a&items[1]=b\n */\nexport const indexArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n values.map((val, i) => `${name}[${i}]=${encodeValue(val)}`).join(\"&\"),\n};\n\n/**\n * Comma-separated values.\n * Example: items=a,b,c\n */\nexport const commaArrayStrategy: ArrayStrategy = {\n encodeArray: (name, values) =>\n `${name}=${values.map((val) => encodeValue(val)).join(\",\")}`,\n};\n\n/**\n * Map of array format to strategy implementation.\n */\nexport const arrayStrategies: Record<ArrayFormat, ArrayStrategy> = {\n none: noneArrayStrategy,\n brackets: bracketsArrayStrategy,\n index: indexArrayStrategy,\n comma: commaArrayStrategy,\n};\n","// packages/route-node/modules/search-params/strategies/boolean.ts\n\n/**\n * Boolean encoding/decoding strategies.\n *\n * @module search-params/strategies/boolean\n */\n\nimport type { DecodeResult, BooleanFormat } from \"../types\";\n\n// =============================================================================\n// Strategy Map\n// =============================================================================\n\n// =============================================================================\n// Strategy Interface\n// =============================================================================\n\n/**\n * Strategy for encoding/decoding boolean values.\n */\nexport interface BooleanStrategy {\n /**\n * Encodes a boolean value as a query string segment.\n *\n * @param name - URL-encoded parameter name\n * @param value - Boolean value to encode\n * @returns Query string segment (e.g., \"flag=true\" or just \"flag\")\n */\n encode: (name: string, value: boolean) => string;\n\n /**\n * Handles undefined value (key-only params like ?flag).\n *\n * @returns Decoded value for undefined\n */\n decodeUndefined: () => DecodeResult;\n\n /**\n * Decodes a raw (not URI-decoded) value before decodeValue() is called.\n * Used for formats that check raw values (e.g., \"string\" checks \"true\"/\"false\").\n *\n * @param rawValue - Raw value before URI decoding\n * @returns boolean if matched, null to continue with URI decoding\n */\n decodeRaw: (rawValue: string) => boolean | null;\n\n /**\n * Decodes a URI-decoded value.\n *\n * @param decodedValue - Value after URI decoding\n * @returns Decoded value (boolean or the same string)\n */\n decodeValue: (decodedValue: string) => DecodeResult;\n}\n\n// =============================================================================\n// Strategy Implementations\n// =============================================================================\n\n/**\n * No special boolean handling - values are treated as strings.\n */\nexport const noneBooleanStrategy: BooleanStrategy = {\n encode: (name, value) => `${name}=${value}`,\n decodeUndefined: () => null,\n decodeRaw: () => null, // No raw value matching\n decodeValue: (decoded) => decoded, // Return as-is\n};\n\n/**\n * Parse \"true\"/\"false\" strings as boolean values.\n * Checks raw value before URI decoding.\n */\nexport const stringBooleanStrategy: BooleanStrategy = {\n encode: (name, value) => `${name}=${value}`,\n decodeUndefined: () => null,\n decodeRaw: (raw) => {\n if (raw === \"true\") {\n return true;\n }\n if (raw === \"false\") {\n return false;\n }\n\n return null; // Continue with URI decoding\n },\n decodeValue: (decoded) => decoded, // Return decoded string\n};\n\n/**\n * True values are key-only (no =value), false values are omitted.\n * Example: ?flag instead of ?flag=true\n */\nexport const emptyTrueBooleanStrategy: BooleanStrategy = {\n encode: (name, value) => (value ? name : `${name}=false`),\n decodeUndefined: () => true, // Key-only means true\n decodeRaw: () => null, // No raw value matching\n decodeValue: (decoded) => decoded, // Return as-is\n};\n\n/**\n * Map of boolean format to strategy implementation.\n */\nexport const booleanStrategies: Record<BooleanFormat, BooleanStrategy> = {\n none: noneBooleanStrategy,\n string: stringBooleanStrategy,\n \"empty-true\": emptyTrueBooleanStrategy,\n};\n","// packages/route-node/modules/search-params/strategies/null.ts\n\n/**\n * Null encoding/decoding strategies.\n *\n * @module search-params/strategies/null\n */\n\n// =============================================================================\n// Strategy Interface\n// =============================================================================\n\n/**\n * Strategy for encoding/decoding null values.\n */\n// =============================================================================\n// Strategy Map\n// =============================================================================\n\nimport type { NullFormat } from \"../types\";\n\nexport interface NullStrategy {\n /**\n * Encodes a null value as a query string segment.\n *\n * @param name - URL-encoded parameter name\n * @returns Query string segment (e.g., \"key\" or \"\")\n */\n encode: (name: string) => string;\n}\n\n// =============================================================================\n// Strategy Implementations\n// =============================================================================\n\n/**\n * Default null format - key only without value.\n * Example: ?key (no equals sign)\n */\nexport const defaultNullStrategy: NullStrategy = {\n encode: (name) => name,\n};\n\n/**\n * Null values are hidden (omitted from query string).\n * Example: (nothing)\n */\nexport const hiddenNullStrategy: NullStrategy = {\n encode: () => \"\",\n};\n\n/**\n * Map of null format to strategy implementation.\n */\nexport const nullStrategies: Record<NullFormat, NullStrategy> = {\n default: defaultNullStrategy,\n hidden: hiddenNullStrategy,\n};\n","// packages/route-node/modules/search-params/strategies/index.ts\n\n/**\n * Search Params Strategies - Factory and Types.\n *\n * Provides a unified interface for format-specific encoding/decoding strategies.\n * Strategies are resolved once when options are created, avoiding repeated\n * format checks during encode/decode operations.\n *\n * @module search-params/strategies\n */\n\nimport { arrayStrategies, type ArrayStrategy } from \"./array\";\nimport { booleanStrategies, type BooleanStrategy } from \"./boolean\";\nimport { nullStrategies, type NullStrategy } from \"./null\";\n\nimport type { FinalOptions } from \"../types\";\n\n// =============================================================================\n// Exports\n// =============================================================================\n\nexport type { ArrayStrategy } from \"./array\";\n\nexport type { BooleanStrategy } from \"./boolean\";\n\nexport type { NullStrategy } from \"./null\";\n\n// =============================================================================\n// Resolved Strategies\n// =============================================================================\n\n/**\n * Pre-resolved strategies based on options.\n * Created once when makeOptions() is called, avoiding repeated lookups.\n */\nexport interface ResolvedStrategies {\n readonly boolean: BooleanStrategy;\n readonly null: NullStrategy;\n readonly array: ArrayStrategy;\n}\n\n/**\n * Resolves strategies based on format options.\n *\n * @param arrayFormat - Array format\n * @param booleanFormat - Boolean format\n * @param nullFormat - Null format\n * @returns Resolved strategy implementations\n */\nexport const resolveStrategies = (\n arrayFormat: FinalOptions[\"arrayFormat\"],\n booleanFormat: FinalOptions[\"booleanFormat\"],\n nullFormat: FinalOptions[\"nullFormat\"],\n): ResolvedStrategies => ({\n boolean: booleanStrategies[booleanFormat],\n null: nullStrategies[nullFormat],\n array: arrayStrategies[arrayFormat],\n});\n\n// =============================================================================\n// Default Strategies\n// =============================================================================\n\n/**\n * Default strategies matching DEFAULT_OPTIONS.\n * Used when no custom options are provided.\n */\nexport const DEFAULT_STRATEGIES: ResolvedStrategies = {\n boolean: booleanStrategies.none,\n null: nullStrategies.default,\n array: arrayStrategies.none,\n};\n","// packages/route-node/modules/search-params/encode.ts\n\n/**\n * Encoding functions for search-params.\n *\n * Uses Strategy pattern for format-specific encoding.\n * Strategies are resolved once when options are created.\n *\n * @module search-params/encode\n */\n\nimport {\n DEFAULT_STRATEGIES,\n resolveStrategies,\n type ResolvedStrategies,\n} from \"./strategies\";\n\nimport type { FinalOptions, Options } from \"./types\";\n\n// =============================================================================\n// Options with Strategies\n// =============================================================================\n\n/**\n * Extended options with pre-resolved strategies.\n */\nexport interface OptionsWithStrategies extends FinalOptions {\n readonly strategies: ResolvedStrategies;\n}\n\n/**\n * Cached default options with strategies - avoids allocation when no options passed.\n */\nconst DEFAULT_OPTIONS: OptionsWithStrategies = {\n arrayFormat: \"none\",\n booleanFormat: \"none\",\n nullFormat: \"default\",\n strategies: DEFAULT_STRATEGIES,\n};\n\n/**\n * Creates options with defaults and pre-resolved strategies.\n * Returns cached DEFAULT_OPTIONS when no custom options are specified.\n */\nexport const makeOptions = (opts?: Options): OptionsWithStrategies => {\n if (\n !opts ||\n (opts.arrayFormat === undefined &&\n opts.booleanFormat === undefined &&\n opts.nullFormat === undefined)\n ) {\n return DEFAULT_OPTIONS;\n }\n\n // Avoid object spread - direct property assignment is faster\n const arrayFormat = opts.arrayFormat ?? \"none\";\n const booleanFormat = opts.booleanFormat ?? \"none\";\n const nullFormat = opts.nullFormat ?? \"default\";\n\n return {\n arrayFormat,\n booleanFormat,\n nullFormat,\n strategies: resolveStrategies(arrayFormat, booleanFormat, nullFormat),\n };\n};\n\n// =============================================================================\n// Value Encoding\n// =============================================================================\n\n/**\n * Encodes a value for use in a URL query string.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unsafe-argument\nexport const encodeValue = (value: any): string => encodeURIComponent(value);\n\n// =============================================================================\n// Main Encode\n// =============================================================================\n\n/**\n * Encodes a parameter name and value as a query string segment.\n *\n * Uses pre-resolved strategies for format-specific encoding.\n * Strategies handle all formats uniformly - no inline optimizations\n * to avoid equivalent mutants in mutation testing.\n *\n * @param name - Parameter name\n * @param value - Parameter value\n * @param opts - Options with pre-resolved strategies\n * @returns Query string segment (e.g., \"key=value\")\n */\nexport const encode = (\n name: string,\n value: unknown,\n opts: OptionsWithStrategies,\n): string => {\n const encodedName = encodeValue(name);\n\n // Handle each type using strategies\n switch (typeof value) {\n case \"string\":\n case \"number\": {\n return `${encodedName}=${encodeValue(value)}`;\n }\n case \"boolean\": {\n return opts.strategies.boolean.encode(encodedName, value);\n }\n case \"object\": {\n // Null check\n if (value === null) {\n return opts.strategies.null.encode(encodedName);\n }\n // Array check\n if (Array.isArray(value)) {\n return opts.strategies.array.encodeArray(encodedName, value);\n }\n\n // Fallback for other objects - treat as string\n return `${encodedName}=${encodeValue(value)}`;\n }\n default: {\n // Fallback for other types (undefined handled by caller)\n return `${encodedName}=${encodeValue(value)}`;\n }\n }\n};\n","// packages/route-node/modules/search-params/utils.ts\n\n/**\n * Utility functions for search-params.\n *\n * Internalized from https://github.com/troch/search-params\n *\n * @module search-params/utils\n */\n\n// =============================================================================\n// Query String Extraction\n// =============================================================================\n\n/**\n * Extracts the query string portion from a path.\n * Returns everything after \"?\" or the entire string if no \"?\" exists.\n */\nexport const getSearch = (path: string): string => {\n const pos = path.indexOf(\"?\");\n\n if (pos === -1) {\n return path;\n }\n\n return path.slice(pos + 1);\n};\n","// packages/route-node/modules/search-params/searchParams.ts\n\n/**\n * Search Params - Query String Parsing and Building.\n *\n * Internalized from https://github.com/troch/search-params (MIT License)\n * for better code control and optimization.\n *\n * @module search-params/searchParams\n */\n\nimport { decode, decodeValue } from \"./decode\";\nimport { encode, makeOptions } from \"./encode\";\nimport { getSearch } from \"./utils\";\n\nimport type { ResolvedStrategies } from \"./strategies\";\nimport type { KeepResponse, OmitResponse, Options } from \"./types\";\n\n// =============================================================================\n// Internal Helpers\n// =============================================================================\n\n/**\n * Extracts parameter name from raw name (removes bracket suffix).\n *\n * @internal\n */\nfunction extractParamName(rawName: string): {\n name: string;\n hasBrackets: boolean;\n} {\n const bracketPos = rawName.indexOf(\"[\");\n\n return bracketPos === -1\n ? { name: rawName, hasBrackets: false }\n : { name: rawName.slice(0, bracketPos), hasBrackets: true };\n}\n\n/**\n * Adds a decoded value to params object, handling array accumulation.\n *\n * @internal\n */\nfunction addToParams(\n params: Record<string, unknown>,\n decodedName: string,\n decodedValue: unknown,\n hasBrackets: boolean,\n): void {\n const currentValue = params[decodedName];\n\n if (currentValue === undefined) {\n params[decodedName] = hasBrackets ? [decodedValue] : decodedValue;\n } else if (Array.isArray(currentValue)) {\n currentValue.push(decodedValue);\n } else {\n params[decodedName] = [currentValue, decodedValue];\n }\n}\n\n/**\n * Decodes a parameter value based on whether strategies are provided.\n *\n * @internal\n */\nfunction decodeParamValue(\n searchPart: string,\n eqPos: number,\n end: number,\n hasValue: boolean,\n strategies: ResolvedStrategies | undefined,\n): unknown {\n if (strategies) {\n const rawValue = hasValue ? searchPart.slice(eqPos + 1, end) : undefined;\n\n return decode(rawValue, strategies);\n }\n\n return hasValue ? decodeValue(searchPart.slice(eqPos + 1, end)) : null;\n}\n\n/**\n * Processes a single query parameter chunk and adds to params.\n *\n * @internal\n */\nfunction processParamChunk(\n searchPart: string,\n start: number,\n end: number,\n params: Record<string, unknown>,\n strategies?: ResolvedStrategies,\n): void {\n const eqPos = searchPart.indexOf(\"=\", start);\n const hasValue = eqPos !== -1 && eqPos < end;\n\n const rawName = hasValue\n ? searchPart.slice(start, eqPos)\n : searchPart.slice(start, end);\n\n const { name, hasBrackets } = extractParamName(rawName);\n const decodedName = decodeValue(name);\n const decodedValue = decodeParamValue(\n searchPart,\n eqPos,\n end,\n hasValue,\n strategies,\n );\n\n addToParams(params, decodedName, decodedValue, hasBrackets);\n}\n\n/**\n * Iterates over query string parameters, calling handler for each chunk.\n *\n * @internal\n */\nfunction forEachParam(\n searchPart: string,\n handler: (chunk: string, start: number, end: number) => void,\n): void {\n let start = 0;\n const len = searchPart.length;\n\n while (start < len) {\n let end = searchPart.indexOf(\"&\", start);\n\n if (end === -1) {\n end = len;\n }\n\n handler(searchPart.slice(start, end), start, end);\n start = end + 1;\n }\n}\n\n// =============================================================================\n// Parse\n// =============================================================================\n\n/**\n * Parse a querystring and return an object of parameters.\n *\n * @example\n * ```typescript\n * parse(\"page=1&sort=name\");\n * // => { page: \"1\", sort: \"name\" }\n *\n * parse(\"items[]=a&items[]=b\", { arrayFormat: \"brackets\" });\n * // => { items: [\"a\", \"b\"] }\n * ```\n */\nexport const parse = (\n path: string,\n opts?: Options,\n): Record<string, unknown> => {\n const searchPart = getSearch(path);\n\n // Fast path: empty query string\n if (searchPart === \"\" || searchPart === \"?\") {\n return {};\n }\n\n // Fast path: no options - use simplified parser (skip strategy resolution)\n if (!opts) {\n return parseSimple(searchPart);\n }\n\n const options = makeOptions(opts);\n const params: Record<string, unknown> = {};\n\n // Process each parameter\n let start = 0;\n const len = searchPart.length;\n\n while (start < len) {\n let end = searchPart.indexOf(\"&\", start);\n\n if (end === -1) {\n end = len;\n }\n\n processParamChunk(searchPart, start, end, params, options.strategies);\n start = end + 1;\n }\n\n return params;\n};\n\n/**\n * Simplified parse without strategy resolution.\n * Used when no options are provided (most common case).\n * Returns string values only (no boolean/null conversion).\n *\n * @internal\n */\nfunction parseSimple(searchPart: string): Record<string, unknown> {\n const params: Record<string, unknown> = {};\n\n parseIntoInternal(searchPart, params);\n\n return params;\n}\n\n/**\n * Parse query string directly into a target object.\n * Avoids creating intermediate object and Object.assign.\n * Optimized for loose mode query params handling.\n *\n * @param queryString - Query string without leading \"?\"\n * @param target - Object to add params to\n */\nexport function parseInto(\n queryString: string,\n target: Record<string, unknown>,\n): void {\n if (queryString === \"\") {\n return;\n }\n\n parseIntoInternal(queryString, target);\n}\n\n/**\n * Internal function to parse query string into target object.\n * Shared by parseSimple and parseInto.\n *\n * @internal\n */\nfunction parseIntoInternal(\n searchPart: string,\n params: Record<string, unknown>,\n): void {\n let start = 0;\n const len = searchPart.length;\n\n while (start < len) {\n let end = searchPart.indexOf(\"&\", start);\n\n if (end === -1) {\n end = len;\n }\n\n // No strategies = simple decoding\n processParamChunk(searchPart, start, end, params);\n start = end + 1;\n }\n}\n\n// =============================================================================\n// Build\n// =============================================================================\n\n/**\n * Build a querystring from an object of parameters.\n *\n * @example\n * ```typescript\n * build({ page: 1, sort: \"name\" });\n * // => \"page=1&sort=name\"\n *\n * build({ items: [\"a\", \"b\"] }, { arrayFormat: \"brackets\" });\n * // => \"items[]=a&items[]=b\"\n * ```\n */\nexport const build = (\n params: Record<string, unknown>,\n opts?: Options,\n): string => {\n // Fast path for empty params (common case)\n const keys = Object.keys(params);\n\n if (keys.length === 0) {\n return \"\";\n }\n\n const options = makeOptions(opts);\n\n // Optimized: single loop instead of filter().map().filter().join()\n // Avoids creating 3 intermediate arrays\n const parts: string[] = [];\n\n for (const key of keys) {\n const value = params[key];\n\n // Skip undefined values (not serialisable)\n if (value === undefined) {\n continue;\n }\n\n const encoded = encode(key, value, options);\n\n // Skip empty strings (e.g., from nullFormat: \"hidden\")\n if (encoded) {\n parts.push(encoded);\n }\n }\n\n return parts.join(\"&\");\n};\n\n// =============================================================================\n// Omit\n// =============================================================================\n\n/**\n * Remove a list of parameters from a querystring.\n *\n * @example\n * ```typescript\n * omit(\"page=1&sort=name&limit=10\", [\"sort\", \"limit\"]);\n * // => { querystring: \"page=1\", removedParams: { sort: \"name\", limit: \"10\" } }\n * ```\n */\nexport const omit = (\n path: string,\n paramsToOmit: string[],\n opts?: Options,\n): OmitResponse => {\n const searchPart = getSearch(path);\n\n if (searchPart === \"\") {\n return { querystring: \"\", removedParams: {} };\n }\n\n // Fast path: no params to omit - keep entire querystring\n if (paramsToOmit.length === 0) {\n const hasPrefix = path.startsWith(\"?\");\n\n return {\n querystring: hasPrefix ? path : searchPart,\n removedParams: {},\n };\n }\n\n const options = makeOptions(opts);\n const hasPrefix = path.startsWith(\"?\");\n const omitSet = new Set(paramsToOmit);\n const kept: string[] = [];\n const removed: string[] = [];\n\n forEachParam(searchPart, (chunk) => {\n const eqPos = chunk.indexOf(\"=\");\n const rawName = eqPos === -1 ? chunk : chunk.slice(0, eqPos);\n const { name } = extractParamName(rawName);\n\n if (omitSet.has(name)) {\n removed.push(chunk);\n } else {\n kept.push(chunk);\n }\n });\n\n const querystring = kept.join(\"&\");\n\n return {\n querystring: hasPrefix && querystring ? `?${querystring}` : querystring,\n removedParams: parse(removed.join(\"&\"), options),\n };\n};\n\n// =============================================================================\n// Keep\n// =============================================================================\n\n/**\n * Keep only specified parameters from a querystring.\n *\n * @example\n * ```typescript\n * keep(\"page=1&sort=name&limit=10\", [\"page\"]);\n * // => { querystring: \"page=1\", keptParams: { page: \"1\" } }\n * ```\n */\nexport const keep = (\n path: string,\n paramsToKeep: string[],\n opts?: Options,\n): KeepResponse => {\n const searchPart = getSearch(path);\n\n if (searchPart === \"\") {\n return { keptParams: {}, querystring: \"\" };\n }\n\n // Fast path: no params to keep\n if (paramsToKeep.length === 0) {\n return { keptParams: {}, querystring: \"\" };\n }\n\n const options = makeOptions(opts);\n const keepSet = new Set(paramsToKeep);\n const kept: string[] = [];\n\n forEachParam(searchPart, (chunk) => {\n const eqPos = chunk.indexOf(\"=\");\n const rawName = eqPos === -1 ? chunk : chunk.slice(0, eqPos);\n const { name } = extractParamName(rawName);\n\n if (keepSet.has(name)) {\n kept.push(chunk);\n }\n });\n\n const querystring = kept.join(\"&\");\n\n return { keptParams: parse(querystring, options), querystring };\n};\n","// packages/route-node/modules/operations/query.ts\n\n/**\n * Route Query Operations.\n *\n * Pure functions for querying route information from the tree.\n *\n * @module operations/query\n */\n\nimport type { RouteTree } from \"../types\";\n\n// =============================================================================\n// Public API\n// =============================================================================\n\n/**\n * Finds route nodes by dot-notation name.\n *\n * Returns an array of segments from root to the target node.\n * All returned segments have parsers (root included only if it has parser).\n * Uses children Map for O(1) lookup at each level.\n *\n * @param tree - Route tree to search in\n * @param routeName - Dot-notation route name (e.g., \"users.profile\")\n * @returns Array of route segments or null if not found\n *\n * @example\n * ```typescript\n * const segments = getSegmentsByName(tree, \"users.profile\");\n * // â [usersNode, profileNode]\n * ```\n */\nexport function getSegmentsByName(\n tree: RouteTree,\n routeName: string,\n): readonly RouteTree[] | null {\n const segments: RouteTree[] = [];\n\n // Optimize: avoid split() allocation for simple names without dots\n const names = routeName.includes(\".\") ? routeName.split(\".\") : [routeName];\n\n // Handle root with path (include it as first segment)\n if (tree.path !== \"\") {\n segments.push(tree);\n }\n\n // Navigate through the tree using O(1) Map lookups\n let currentNode: RouteTree = tree;\n\n for (const name of names) {\n const segment = currentNode.children.get(name);\n\n if (!segment) {\n return null;\n }\n\n segments.push(segment);\n currentNode = segment;\n }\n\n return segments;\n}\n\n/**\n * Checks if a route exists in the tree by dot-notation name.\n * More efficient than getSegmentsByName when only existence check is needed.\n *\n * Avoids:\n * - Array allocation\n * - Array push operations\n *\n * @param tree - Route tree to search in\n * @param routeName - Dot-notation route name (e.g., \"users.profile\")\n * @returns true if route exists, false otherwise\n *\n * @example\n * ```typescript\n * const exists = hasSegmentsByName(tree, \"users.profile\");\n * // â true\n * ```\n */\nexport function hasSegmentsByName(tree: RouteTree, routeName: string): boolean {\n // Optimize: avoid split() allocation for simple names without dots\n const names = routeName.includes(\".\") ? routeName.split(\".\") : [routeName];\n\n // Navigate through the tree using O(1) Map lookups\n let currentNode: RouteTree = tree;\n\n for (const name of names) {\n const segment = currentNode.children.get(name);\n\n if (!segment) {\n return false;\n }\n\n currentNode = segment;\n }\n\n return true;\n}\n","// packages/route-tree/src/services/constraintValidation.ts\n\n/**\n * Constraint Validation.\n *\n * Validates parameter values against constraint patterns.\n *\n * @module services/constraintValidation\n */\n\nimport type { ConstraintPattern } from \"./buildParamMeta\";\n\n/**\n * Validates parameters against constraint patterns.\n *\n * Throws an error if any parameter value doesn't match its constraint pattern.\n * Error message format is exact-matched by tests.\n *\n * @param params - Parameter values to validate\n * @param constraintPatterns - Map of parameter names to constraint patterns\n * @param path - Route path pattern (used in error message)\n * @throws Error if validation fails\n *\n * @example\n * ```typescript\n * const patterns = new Map([\n * [\"id\", { pattern: /^(\\d+)$/, constraint: \"<\\\\d+>\" }]\n * ]);\n *\n * validateConstraints({ id: \"123\" }, patterns, \"/users/:id<\\\\d+>\");\n * // â No error\n *\n * validateConstraints({ id: \"abc\" }, patterns, \"/users/:id<\\\\d+>\");\n * // â Error: Parameter 'id' of '/users/:id<\\\\d+>' has invalid format: got 'abc', expected to match '\\\\d+'\n * ```\n */\nexport function validateConstraints(\n params: Record<string, unknown>,\n constraintPatterns: ReadonlyMap<string, ConstraintPattern>,\n path: string,\n): void {\n for (const [paramName, { pattern, constraint }] of constraintPatterns) {\n const value = String(params[paramName]);\n\n if (!pattern.test(value)) {\n const constraintPattern = constraint\n ? constraint.replaceAll(/(^<)|(>$)/g, \"\")\n : \"[^/]+\";\n\n throw new Error(\n `Parameter '${paramName}' of '${path}' has invalid format: ` +\n `got '${value}', expected to match '${constraintPattern}'`,\n );\n }\n }\n}\n","// packages/route-tree/src/services/encoding.ts\n\n/**\n * URL Parameter Encoding.\n *\n * Encoding strategies for URL parameters.\n *\n * @module services/encoding\n */\n\n/**\n * Performance-critical code: string concatenation is 2x faster than template\n * literals/String.raw in V8 hot paths. See benchmarks for details.\n */\n/* eslint-disable prefer-template */\n\nimport type { URLParamsEncodingType } from \"../operations/types\";\n\n// =============================================================================\n// Encoding Constants\n// =============================================================================\n\n/**\n * Optimized regex: only matches characters that ACTUALLY need encoding.\n * Excludes:\n * - A-Za-z0-9: alphanumeric (unreserved per RFC 3986)\n * - -._~: unreserved characters per RFC 3986\n * - !$'()*+,:;|: sub-delimiters we want to preserve\n *\n * Performance: This regex skips alphanumeric characters entirely,\n * avoiding unnecessary encodeURIComponent calls that return the same value.\n *\n * IMPORTANT: The 'u' (Unicode) flag is required to handle emoji and other\n * characters outside the Basic Multilingual Plane (BMP). Without it, the regex\n * matches individual UTF-16 code units (surrogates), and encodeURIComponent\n * fails on lone surrogates with \"URI malformed\" error.\n */\nconst NEEDS_ENCODING_REGEX = /[^\\w!$'()*+,.:;|~-]/gu;\n\n/**\n * Fast check regex (without global flag) to test if encoding is needed at all.\n * Used for pre-check optimization: if string contains only safe chars, skip encoding.\n *\n * IMPORTANT: The 'u' flag ensures proper handling of emoji/surrogate pairs.\n */\nconst NEEDS_ENCODING_TEST = /[^\\w!$'()*+,.:;|~-]/u;\n\n// =============================================================================\n// Encoding Helper Functions\n// =============================================================================\n\n/**\n * Encode a segment while preserving sub-delimiters.\n * Uses pre-check optimization: fast path for strings without special chars.\n *\n * Performance improvement over naive approach:\n * - Alphanumeric strings: 29-57x faster\n * - Strings with special chars: 2-3x faster\n */\nexport const encodeURIComponentExcludingSubDelims = (\n segment: string,\n): string => {\n // Fast path: if no special chars, return as-is\n if (!NEEDS_ENCODING_TEST.test(segment)) {\n return segment;\n }\n\n /* v8 ignore next 2 */\n return segment.replaceAll(NEEDS_ENCODING_REGEX, (match) =>\n encodeURIComponent(match),\n );\n};\n\n// =============================================================================\n// Encoding Methods Map\n// =============================================================================\n\n/**\n * Encoding functions for each encoding type.\n *\n * Modes:\n * - `default` - encodeURIComponent preserving sub-delimiters (+, :, ', !, ,, ;, *)\n * - `uri` - encodeURI/decodeURI\n * - `uriComponent` - encodeURIComponent/decodeURIComponent\n * - `none` - no encoding/decoding\n */\nexport const ENCODING_METHODS: Record<\n URLParamsEncodingType,\n (param: string) => string\n> = {\n default: encodeURIComponentExcludingSubDelims,\n uri: encodeURI,\n uriComponent: encodeURIComponent,\n none: (val) => val,\n};\n\n/**\n * Decoding functions for each encoding type.\n */\nexport const DECODING_METHODS: Record<\n URLParamsEncodingType,\n (param: string) => string\n> = {\n default: decodeURIComponent,\n uri: decodeURI,\n uriComponent: decodeURIComponent,\n /* v8 ignore next */\n none: (val) => val,\n};\n\n// =============================================================================\n// Main Encoding Function\n// =============================================================================\n\n/**\n * Encodes a URL parameter value using the specified encoding strategy.\n *\n * For splat parameters (*path), encodes each path segment separately\n * while preserving \"/\" characters.\n *\n * @param param - The parameter value to encode\n * @param encoding - The encoding strategy to use\n * @param isSpatParam - Whether this is a splat parameter\n * @returns The encoded parameter string\n *\n * @example\n * ```typescript\n * encodeParam('hello world', 'default', false);\n * // => 'hello%20world'\n *\n * encodeParam('docs/readme.md', 'default', true);\n * // => 'docs/readme.md' (splat preserves slashes)\n * ```\n */\nexport const encodeParam = (\n param: string | number | boolean,\n encoding: URLParamsEncodingType,\n isSpatParam: boolean,\n): string => {\n const encoder = ENCODING_METHODS[encoding];\n const str = String(param);\n\n if (!isSpatParam) {\n return encoder(str);\n }\n\n // Splat params: encode each segment separately, preserving \"/\"\n // H6 optimization: string concatenation is 2x faster than template literals\n const segments = str.split(\"/\");\n let result = encoder(segments[0]);\n\n for (let i = 1; i < segments.length; i++) {\n result += \"/\" + encoder(segments[i]);\n }\n\n return result;\n};\n","// packages/route-tree/src/services/inject.ts\n\n/**\n * Enhanced Path Parameter Injection.\n *\n * Lightweight implementation for injecting pre-encoded parameters into route\n * patterns. Replaces the path-parser's build() method for path construction.\n *\n * Handles:\n * - Named parameters (`:id`) - values used as-is (must be pre-encoded)\n * - Optional parameters (`:id?`)\n * - Splat parameters (`*path`)\n * - Unnamed splats (`*`) accessed as 'wild'\n *\n * @module services/inject\n */\n\n/**\n * Regex pattern for matching route parameters.\n *\n * Matches:\n * - `:paramName` - named URL parameter\n * - `:paramName<constraint>` - parameter with constraint pattern\n * - `:paramName?` - optional parameter\n * - `:paramName<constraint>?` - optional parameter with constraint\n * - `*paramName` - splat parameter (matches rest of path)\n * - `*` - unnamed splat\n *\n * Captures:\n * 1. `lead` - leading character (/ or start of string)\n * 2. `key` - parameter marker and name (`:id`, `*path`, etc.) - excludes constraint\n * 3. `constraint` - optional constraint pattern (e.g., `<\\d+>`)\n * 4. `optional` - optional marker (?)\n *\n * @example\n * ```\n * \"/users/:id\" â matches \":id\"\n * \"/users/:id<\\\\d+>\" â matches \":id\" with constraint \"<\\\\d+>\"\n * \"/users/:id?\" â matches \":id?\"\n * \"/users/:id<\\\\d+>?\" â matches \":id\" with constraint and optional\n * \"/files/*path\" â matches \"*path\"\n * \"/files/*\" â matches \"*\"\n * ```\n */\nconst RGX = /(\\/|^)([:*][^/?<]*)(<[^>]+>)?(\\?)?(?=[/.]|$)/g;\n\n/**\n * Injects parameter values into a route pattern string.\n *\n * Values are expected to be pre-encoded. Use with encodeParam() for proper encoding.\n *\n * @param route - Route pattern string (e.g., \"/users/:id/posts/:postId\")\n * @param values - Object mapping parameter names to pre-encoded string values\n * @returns Path with parameters replaced by values\n *\n * @example\n * ```typescript\n * // Named parameters (pre-encoded)\n * inject(\"/users/:id\", { id: \"123\" })\n * // â \"/users/123\"\n *\n * // Optional parameters\n * inject(\"/users/:id?\", {})\n * // â \"/users\"\n *\n * inject(\"/users/:id?\", { id: \"123\" })\n * // â \"/users/123\"\n *\n * // Splat parameters\n * inject(\"/files/*path\", { path: \"a/b/c\" })\n * // â \"/files/a/b/c\"\n *\n * // Pre-encoded values\n * inject(\"/search/:q\", { q: \"hello%20world\" })\n * // â \"/search/hello%20world\"\n *\n * // Complex routes\n * inject(\"/posts/:id/comments/*rest\", { id: \"42\", rest: \"123/456\" })\n * // â \"/posts/42/comments/123/456\"\n *\n * // Unnamed splat\n * inject(\"/files/*\", { wild: \"docs/readme.md\" })\n * // â \"/files/docs/readme.md\"\n * ```\n *\n * @remarks\n * - Values are used as-is (no encoding applied by inject)\n * - Caller must pre-encode values using encodeParam() or similar\n * - Optional parameters (`:param?`) are omitted if value is undefined/null\n * - Unnamed splats (`*`) are accessed via the 'wild' key\n * - Missing required parameters are replaced with the original placeholder\n */\nexport function inject(route: string, values: Record<string, string>): string {\n return route.replaceAll(\n RGX,\n (\n _match: string,\n lead: string,\n key: string,\n _constraint: string | undefined,\n optional?: string,\n ) => {\n const isSplat = key.startsWith(\"*\");\n\n let paramName: string;\n\n if (isSplat) {\n paramName = key.length > 1 ? key.slice(1) : \"wild\";\n } else {\n paramName = key.slice(1);\n }\n\n const value = values[paramName];\n\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (value !== undefined) {\n return lead + value;\n }\n\n if (optional !== undefined || isSplat) {\n return \"\";\n }\n\n return lead + key;\n },\n );\n}\n","// packages/route-node/modules/validation/errors.ts\n\n/**\n * Custom error types for route-node package.\n *\n * Provides structured error handling with specific error types\n * for different failure scenarios.\n *\n * @module errors\n */\n\n/**\n * Base error class for all route-node errors.\n *\n * All route-node specific errors inherit from this class,\n * allowing for unified error handling.\n *\n * @example\n * ```typescript\n * try {\n * node.add(invalidRoute);\n * } catch (error) {\n * if (error instanceof RouteNodeError) {\n * console.error(\"Route configuration error:\", error.message);\n * }\n * }\n * ```\n */\nexport class RouteNodeError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"RouteNodeError\";\n // Maintains proper prototype chain for instanceof checks\n Object.setPrototypeOf(this, new.target.prototype);\n }\n}\n\n/**\n * Error thrown when attempting to add a route with a duplicate name or path.\n *\n * @example\n * ```typescript\n * // Throws DuplicateRouteError: Alias \"home\" is already defined in route node\n * node.add({ name: \"home\", path: \"/\" });\n * node.add({ name: \"home\", path: \"/home\" }); // Duplicate name!\n * ```\n */\nexport class DuplicateRouteError extends RouteNodeError {\n /** The duplicate name or path that caused the error */\n public readonly duplicateValue: string;\n /** Whether the duplicate is a name (\"name\") or path (\"path\") */\n public readonly duplicateType: \"name\" | \"path\";\n\n constructor(\n message: string,\n duplicateValue: string,\n duplicateType: \"name\" | \"path\",\n ) {\n super(message);\n this.name = \"DuplicateRouteError\";\n this.duplicateValue = duplicateValue;\n this.duplicateType = duplicateType;\n }\n}\n\n/**\n * Error thrown when a route definition is invalid.\n *\n * Common causes:\n * - Missing required name or path property\n * - Invalid route type (not an object or RouteNode)\n * - Absolute path with parameterized parents\n *\n * @example\n * ```typescript\n * // Throws InvalidRouteError: RouteNode.add() expects routes to have a name and a path defined.\n * node.add({ name: \"incomplete\" }); // Missing path!\n * ```\n */\nexport class InvalidRouteError extends RouteNodeError {\n constructor(message: string) {\n super(message);\n this.name = \"InvalidRouteError\";\n }\n}\n\n/**\n * Error thrown when a referenced route cannot be found.\n *\n * @example\n * ```typescript\n * // Throws RouteNotFoundError: [route-node][buildPath] 'nonexistent' is not defined\n * node.buildPath(\"nonexistent\", {});\n * ```\n */\nexport class RouteNotFoundError extends RouteNodeError {\n /** The route name that was not found */\n public readonly routeName: string;\n\n constructor(message: string, routeName: string) {\n super(message);\n this.name = \"RouteNotFoundError\";\n this.routeName = routeName;\n }\n}\n\n/**\n * Error thrown when a parent route cannot be found for nested route addition.\n *\n * @example\n * ```typescript\n * // Throws ParentNotFoundError when parent \"users\" doesn't exist\n * node.add({ name: \"users.profile\", path: \"/profile\" });\n * ```\n */\nexport class ParentNotFoundError extends RouteNodeError {\n /** The route name whose parent was not found */\n public readonly routeName: string;\n\n constructor(message: string, routeName: string) {\n super(message);\n this.name = \"ParentNotFoundError\";\n this.routeName = routeName;\n }\n}\n","// packages/route-node/modules/operations/build.ts\n\n/**\n * Path Building Operations.\n *\n * Pure functions for building URL paths from route names and parameters.\n *\n * @module operations/build\n */\n\nimport { build as buildQueryString } from \"search-params\";\n\nimport { getSegmentsByName } from \"./query\";\nimport { validateConstraints } from \"../services/constraintValidation\";\nimport { encodeParam } from \"../services/encoding\";\nimport { inject } from \"../services/inject\";\nimport { RouteNotFoundError } from \"../validation/errors\";\n\nimport type {\n BuildOptions,\n RouteParams,\n RouteTree,\n TrailingSlashMode,\n URLParamsEncodingType,\n} from \"../types\";\n\n// =============================================================================\n// Constants\n// =============================================================================\n\n/**\n * Shared empty array for lazy allocation optimization.\n * Avoids creating new empty arrays for routes without params.\n */\nconst EMPTY_ARRAY: readonly string[] = Object.freeze([]);\n\n// =============================================================================\n// Helpers\n// =============================================================================\n\n/**\n * Checks if object has any own enumerable keys.\n * More efficient than Object.keys().length > 0 (avoids array allocation).\n */\nfunction hasOwnKeys(obj: object): boolean {\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Checks if BuildOptions contains any non-default values.\n * Used to determine if fast path can be taken.\n *\n * Default values that allow fast path:\n * - trailingSlashMode: \"default\" or undefined\n * - queryParamsMode: \"default\" or undefined\n * - queryParams: undefined\n * - urlParamsEncoding: \"default\" or undefined\n */\nfunction hasNonDefaultOptions(options: BuildOptions): boolean {\n return (\n (options.trailingSlashMode !== undefined &&\n options.trailingSlashMode !== \"default\") ||\n (options.queryParamsMode !== undefined &&\n options.queryParamsMode !== \"default\") ||\n options.queryParams !== undefined ||\n (options.urlParamsEncoding !== undefined &&\n options.urlParamsEncoding !== \"default\")\n );\n}\n\n// =============================================================================\n// Types\n// =============================================================================\n\n/**\n * Collected parameters from route segments.\n */\ninterface CollectedParams {\n readonly searchParams: readonly string[];\n readonly nonSearchParams: readonly string[];\n}\n\n// =============================================================================\n// Public API\n// =============================================================================\n\n/**\n * Tries fast path for simple route names without parameters.\n * Returns staticPath if available, null otherwise.\n */\nfunction tryStaticPathFast(tree: RouteTree, routeName: string): string | null {\n if (routeName.includes(\".\")) {\n const segments = getSegmentsByName(tree, routeName);\n const staticPath = segments?.at(-1)?.staticPath;\n\n return staticPath ?? null;\n }\n\n return tree.children.get(routeName)?.staticPath ?? null;\n}\n\n/**\n * Builds a URL path for the given route name and parameters.\n *\n * @param tree - Route tree to use\n * @param routeName - Dot-notation route name (e.g., \"users.profile\")\n * @param params - Route parameters\n * @param options - Build options\n * @param segments - Optional pre-computed segments (avoids getSegmentsByName call)\n * @returns Built URL path\n * @throws {RouteNotFoundError} If route not found\n *\n * @example\n * ```typescript\n * const url = buildPath(tree, \"users.profile\", { id: \"123\" });\n * // â \"/users/123\"\n *\n * // With pre-computed segments (avoids duplicate lookup)\n * const segments = getSegmentsByName(tree, \"users.profile\");\n * const url = buildPath(tree, \"users.profile\", { id: \"123\" }, {}, segments);\n * ```\n */\nexport function buildPath(\n tree: RouteTree,\n routeName: string,\n params: RouteParams = {},\n options: BuildOptions = {},\n segments?: readonly RouteTree[],\n): string {\n // If segments provided, skip lookup and fast path (caller already has segments)\n if (segments) {\n return buildPathFromSegments(segments, params, options);\n }\n\n // Fast path: no params, default options - try pre-computed staticPath\n // R6 optimization: use hasOwnKeys instead of Object.keys().length (avoids array allocation)\n // R7 optimization: check option VALUES not just keys (enables fast path for real-router)\n const hasParams = hasOwnKeys(params);\n const hasNonDefaults = hasNonDefaultOptions(options);\n\n if (!hasParams && !hasNonDefaults) {\n const staticPath = tryStaticPathFast(tree, routeName);\n\n if (staticPath !== null) {\n return staticPath;\n }\n }\n\n // Regular path: find segments and build\n const foundSegments = getSegmentsByName(tree, routeName);\n\n if (!foundSegments) {\n throw new RouteNotFoundError(\n `[route-node][buildPath] '${routeName}' is not defined`,\n routeName,\n );\n }\n\n return buildPathFromSegments(foundSegments, params, options);\n}\n\n// =============================================================================\n// Internal: Path Building\n// =============================================================================\n\n/**\n * Builds a URL path from route segments.\n *\n * Note: All segments from getSegmentsByName have parsers -\n * root is only included if it has a parser, and children always have parsers.\n */\nfunction buildPathFromSegments(\n segments: readonly RouteTree[],\n params: RouteParams,\n options: BuildOptions,\n): string {\n const { queryParamsMode = \"default\", trailingSlashMode = \"default\" } =\n options;\n\n const collected = collectParamsFromSegments(segments);\n const searchParams = resolveSearchParams(collected, params, queryParamsMode);\n const searchPart = buildSearchString(searchParams, params, options);\n const pathString = buildPathString(segments, params, options);\n const finalPath = applyTrailingSlashMode(pathString, trailingSlashMode);\n\n return finalPath + (searchPart ? `?${searchPart}` : \"\");\n}\n\n/**\n * Collects search and non-search parameters from segments.\n * Uses lazy allocation - arrays only created when params exist.\n */\nfunction collectParamsFromSegments(\n segments: readonly RouteTree[],\n): CollectedParams {\n let searchParams: string[] | null = null;\n let nonSearchParams: string[] | null = null;\n\n for (const segment of segments) {\n const { queryParams, urlParams, spatParams } = segment.paramMeta;\n\n // Use for-loop instead of spread (1.49x faster)\n\n if (queryParams.length > 0) {\n searchParams ??= [];\n\n for (const queryParam of queryParams) {\n searchParams.push(queryParam);\n }\n }\n\n if (urlParams.length > 0 || spatParams.length > 0) {\n nonSearchParams ??= [];\n\n for (const urlParam of urlParams) {\n nonSearchParams.push(urlParam);\n }\n\n for (const spatParam of spatParams) {\n nonSearchParams.push(spatParam);\n }\n }\n }\n\n return {\n searchParams: searchParams ?? EMPTY_ARRAY,\n nonSearchParams: nonSearchParams ?? EMPTY_ARRAY,\n };\n}\n\n/**\n * Resolves final search params, adding loose params if needed.\n */\nfunction resolveSearchParams(\n collected: CollectedParams,\n params: RouteParams,\n queryParamsMode: BuildOptions[\"queryParamsMode\"],\n): readonly string[] {\n if (queryParamsMode !== \"loose\") {\n return collected.searchParams;\n }\n\n // Use slice() instead of spread (1.15x faster)\n const searchParams = [...(collected.searchParams as string[])];\n const searchParamsSet = new Set(collected.searchParams);\n const nonSearchParamsSet = new Set(collected.nonSearchParams);\n\n // Object.hasOwn filters inherited properties (prototype pollution protection)\n for (const p in params) {\n if (\n Object.hasOwn(params, p) &&\n !searchParamsSet.has(p) &&\n !nonSearchParamsSet.has(p)\n ) {\n searchParams.push(p);\n }\n }\n\n return searchParams;\n}\n\n/**\n * Builds the query string from search params.\n */\nfunction buildSearchString(\n searchParams: readonly string[],\n params: RouteParams,\n options: BuildOptions,\n): string {\n const searchParamsObject: RouteParams = {};\n\n for (const paramName of searchParams) {\n if (paramName in params) {\n searchParamsObject[paramName] = params[paramName];\n }\n }\n\n return buildQueryString(searchParamsObject, options.queryParams);\n}\n\n/**\n * Encodes URL parameters for a segment.\n */\nfunction encodeSegmentParams(\n params: RouteParams,\n urlParams: readonly string[],\n spatParams: readonly string[],\n encoding: URLParamsEncodingType,\n): Record<string, string> {\n const encodedParams: Record<string, string> = {};\n\n for (const paramName of urlParams) {\n const value = params[paramName];\n\n if (value !== undefined && value !== null) {\n const isSplatParam = spatParams.includes(paramName);\n const stringValue =\n typeof value === \"object\" ? JSON.stringify(value) : String(value);\n\n encodedParams[paramName] = encodeParam(\n stringValue,\n encoding,\n isSplatParam,\n );\n }\n }\n\n return encodedParams;\n}\n\n/**\n * Builds the path string from segments.\n */\nfunction buildPathString(\n segments: readonly RouteTree[],\n params: RouteParams,\n options: BuildOptions,\n): string {\n let path = \"\";\n const encoding = options.urlParamsEncoding ?? \"default\";\n const ignoreConstraints = options.ignoreConstraints ?? false;\n\n for (const segment of segments) {\n const { constraintPatterns, urlParams, spatParams } = segment.paramMeta;\n\n // Validate constraints (unless ignoreConstraints)\n if (constraintPatterns.size > 0 && !ignoreConstraints) {\n validateConstraints(params, constraintPatterns, segment.path);\n }\n\n // Encode and inject params\n const encodedParams = encodeSegmentParams(\n params,\n urlParams,\n spatParams,\n encoding,\n );\n const segmentPath = inject(segment.paramMeta.pathPattern, encodedParams);\n\n path = segment.absolute ? segmentPath : path + segmentPath;\n }\n\n // Only normalize when double slashes are actually present\n return path.includes(\"//\") ? path.replaceAll(/\\/{2,}/g, \"/\") : path;\n}\n\n/**\n * Applies trailing slash mode to the path.\n */\nfunction applyTrailingSlashMode(path: string, mode: TrailingSlashMode): string {\n if (mode === \"always\") {\n return path.endsWith(\"/\") ? path : `${path}/`;\n }\n\n if (mode === \"never\" && path !== \"/\") {\n return path.endsWith(\"/\") ? path.slice(0, -1) : path;\n }\n\n return path;\n}\n","// packages/route-tree/modules/operations/routeTreeToDefinitions.ts\n\n/**\n * RouteTree to RouteDefinition Converter.\n *\n * Converts a RouteTree back to an array of RouteDefinition objects.\n * Used for serialization and router cloning.\n *\n * @module operations/routeTreeToDefinitions\n */\n\nimport type { RouteDefinition, RouteTree } from \"../types\";\n\n/**\n * Converts a single RouteTree node to a RouteDefinition.\n *\n * If the node has absolute=true, the path is prefixed with '~'\n * to reconstruct the original definition format.\n *\n * @param node - RouteTree node to convert\n * @returns RouteDefinition with name, path, and optional children\n */\nexport function nodeToDefinition(node: RouteTree): RouteDefinition {\n // Reconstruct absolute path marker if needed\n const path = node.absolute ? `~${node.path}` : node.path;\n\n const def: RouteDefinition = {\n name: node.name,\n path,\n };\n\n if (node.children.size > 0) {\n def.children = [...node.children.values()].map((child) =>\n nodeToDefinition(child),\n );\n }\n\n return def;\n}\n\n/**\n * Converts a RouteTree back to an array of RouteDefinition objects.\n *\n * This is the inverse of createRouteTree - it extracts the minimal\n * definition data (name, path, children) from the computed tree.\n *\n * Note: Extra properties stored in RouteDefinition (like canActivate,\n * forwardTo, encodeParams, etc.) are NOT preserved in RouteTree,\n * so they won't be present in the output.\n *\n * @example\n * ```ts\n * const tree = createRouteTree(\"\", \"\", [\n * { name: \"users\", path: \"/users\", children: [\n * { name: \"profile\", path: \"/:id\" }\n * ]}\n * ]);\n *\n * const definitions = routeTreeToDefinitions(tree);\n * // [{ name: \"users\", path: \"/users\", children: [{ name: \"profile\", path: \"/:id\" }] }]\n * ```\n *\n * @param tree - RouteTree to convert\n * @returns Array of RouteDefinition objects (top-level routes only)\n */\nexport function routeTreeToDefinitions(tree: RouteTree): RouteDefinition[] {\n return [...tree.children.values()].map((child) => nodeToDefinition(child));\n}\n","const NullProtoObj = /* @__PURE__ */ (() => {\n\tconst e = function() {};\n\treturn e.prototype = Object.create(null), Object.freeze(e.prototype), e;\n})();\n\n/**\n* Create a new router context.\n*/\nfunction createRouter() {\n\treturn {\n\t\troot: { key: \"\" },\n\t\tstatic: new NullProtoObj()\n\t};\n}\n\nfunction splitPath(path) {\n\tconst [_, ...s] = path.split(\"/\");\n\treturn s[s.length - 1] === \"\" ? s.slice(0, -1) : s;\n}\nfunction getMatchParams(segments, paramsMap) {\n\tconst params = new NullProtoObj();\n\tfor (const [index, name] of paramsMap) {\n\t\tconst segment = index < 0 ? segments.slice(-(index + 1)).join(\"/\") : segments[index];\n\t\tif (typeof name === \"string\") params[name] = segment;\n\t\telse {\n\t\t\tconst match = segment.match(name);\n\t\t\tif (match) for (const key in match.groups) params[key] = match.groups[key];\n\t\t}\n\t}\n\treturn params;\n}\n\n/**\n* Add a route to the router context.\n*/\nfunction addRoute(ctx, method = \"\", path, data) {\n\tmethod = method.toUpperCase();\n\tif (path.charCodeAt(0) !== 47) path = `/${path}`;\n\tpath = path.replace(/\\\\:/g, \"%3A\");\n\tconst segments = splitPath(path);\n\tlet node = ctx.root;\n\tlet _unnamedParamIndex = 0;\n\tconst paramsMap = [];\n\tconst paramsRegexp = [];\n\tfor (let i = 0; i < segments.length; i++) {\n\t\tlet segment = segments[i];\n\t\tif (segment.startsWith(\"**\")) {\n\t\t\tif (!node.wildcard) node.wildcard = { key: \"**\" };\n\t\t\tnode = node.wildcard;\n\t\t\tparamsMap.push([\n\t\t\t\t-(i + 1),\n\t\t\t\tsegment.split(\":\")[1] || \"_\",\n\t\t\t\tsegment.length === 2\n\t\t\t]);\n\t\t\tbreak;\n\t\t}\n\t\tif (segment === \"*\" || segment.includes(\":\")) {\n\t\t\tif (!node.param) node.param = { key: \"*\" };\n\t\t\tnode = node.param;\n\t\t\tif (segment === \"*\") paramsMap.push([\n\t\t\t\ti,\n\t\t\t\t`_${_unnamedParamIndex++}`,\n\t\t\t\ttrue\n\t\t\t]);\n\t\t\telse if (segment.includes(\":\", 1)) {\n\t\t\t\tconst regexp = getParamRegexp(segment);\n\t\t\t\tparamsRegexp[i] = regexp;\n\t\t\t\tnode.hasRegexParam = true;\n\t\t\t\tparamsMap.push([\n\t\t\t\t\ti,\n\t\t\t\t\tregexp,\n\t\t\t\t\tfalse\n\t\t\t\t]);\n\t\t\t} else paramsMap.push([\n\t\t\t\ti,\n\t\t\t\tsegment.slice(1),\n\t\t\t\tfalse\n\t\t\t]);\n\t\t\tcontinue;\n\t\t}\n\t\tif (segment === \"\\\\*\") segment = segments[i] = \"*\";\n\t\telse if (segment === \"\\\\*\\\\*\") segment = segments[i] = \"**\";\n\t\tconst child = node.static?.[segment];\n\t\tif (child) node = child;\n\t\telse {\n\t\t\tconst staticNode = { key: segment };\n\t\t\tif (!node.static) node.static = new NullProtoObj();\n\t\t\tnode.static[segment] = staticNode;\n\t\t\tnode = staticNode;\n\t\t}\n\t}\n\tconst hasParams = paramsMap.length > 0;\n\tif (!node.methods) node.methods = new NullProtoObj();\n\tnode.methods[method] ??= [];\n\tnode.methods[method].push({\n\t\tdata: data || null,\n\t\tparamsRegexp,\n\t\tparamsMap: hasParams ? paramsMap : void 0\n\t});\n\tif (!hasParams) ctx.static[\"/\" + segments.join(\"/\")] = node;\n}\nfunction getParamRegexp(segment) {\n\tconst regex = segment.replace(/:(\\w+)/g, (_, id) => `(?<${id}>[^/]+)`).replace(/\\./g, \"\\\\.\");\n\treturn /* @__PURE__ */ new RegExp(`^${regex}$`);\n}\n\n/**\n* Find a route by path.\n*/\nfunction findRoute(ctx, method = \"\", path, opts) {\n\tif (path.charCodeAt(path.length - 1) === 47) path = path.slice(0, -1);\n\tconst staticNode = ctx.static[path];\n\tif (staticNode && staticNode.methods) {\n\t\tconst staticMatch = staticNode.methods[method] || staticNode.methods[\"\"];\n\t\tif (staticMatch !== void 0) return staticMatch[0];\n\t}\n\tconst segments = splitPath(path);\n\tconst match = _lookupTree(ctx, ctx.root, method, segments, 0)?.[0];\n\tif (match === void 0) return;\n\tif (opts?.params === false) return match;\n\treturn {\n\t\tdata: match.data,\n\t\tparams: match.paramsMap ? getMatchParams(segments, match.paramsMap) : void 0\n\t};\n}\nfunction _lookupTree(ctx, node, method, segments, index) {\n\tif (index === segments.length) {\n\t\tif (node.methods) {\n\t\t\tconst match = node.methods[method] || node.methods[\"\"];\n\t\t\tif (match) return match;\n\t\t}\n\t\tif (node.param && node.param.methods) {\n\t\t\tconst match = node.param.methods[method] || node.param.methods[\"\"];\n\t\t\tif (match) {\n\t\t\t\tconst pMap = match[0].paramsMap;\n\t\t\t\tif (pMap?.[pMap?.length - 1]?.[2]) return match;\n\t\t\t}\n\t\t}\n\t\tif (node.wildcard && node.wildcard.methods) {\n\t\t\tconst match = node.wildcard.methods[method] || node.wildcard.methods[\"\"];\n\t\t\tif (match) {\n\t\t\t\tconst pMap = match[0].paramsMap;\n\t\t\t\tif (pMap?.[pMap?.length - 1]?.[2]) return match;\n\t\t\t}\n\t\t}\n\t\treturn;\n\t}\n\tconst segment = segments[index];\n\tif (node.static) {\n\t\tconst staticChild = node.static[segment];\n\t\tif (staticChild) {\n\t\t\tconst match = _lookupTree(ctx, staticChild, method, segments, index + 1);\n\t\t\tif (match) return match;\n\t\t}\n\t}\n\tif (node.param) {\n\t\tconst match = _lookupTree(ctx, node.param, method, segments, index + 1);\n\t\tif (match) {\n\t\t\tif (node.param.hasRegexParam) {\n\t\t\t\tconst exactMatch = match.find((m) => m.paramsRegexp[index]?.test(segment)) || match.find((m) => !m.paramsRegexp[index]);\n\t\t\t\treturn exactMatch ? [exactMatch] : void 0;\n\t\t\t}\n\t\t\treturn match;\n\t\t}\n\t}\n\tif (node.wildcard && node.wildcard.methods) return node.wildcard.methods[method] || node.wildcard.methods[\"\"];\n}\n\n/**\n* Remove a route from the router context.\n*/\nfunction removeRoute(ctx, method, path) {\n\tconst segments = splitPath(path);\n\treturn _remove(ctx.root, method || \"\", segments, 0);\n}\nfunction _remove(node, method, segments, index) {\n\tif (index === segments.length) {\n\t\tif (node.methods && method in node.methods) {\n\t\t\tdelete node.methods[method];\n\t\t\tif (Object.keys(node.methods).length === 0) node.methods = void 0;\n\t\t}\n\t\treturn;\n\t}\n\tconst segment = segments[index];\n\tif (segment === \"*\") {\n\t\tif (node.param) {\n\t\t\t_remove(node.param, method, segments, index + 1);\n\t\t\tif (_isEmptyNode(node.param)) node.param = void 0;\n\t\t}\n\t\treturn;\n\t}\n\tif (segment.startsWith(\"**\")) {\n\t\tif (node.wildcard) {\n\t\t\t_remove(node.wildcard, method, segments, index + 1);\n\t\t\tif (_isEmptyNode(node.wildcard)) node.wildcard = void 0;\n\t\t}\n\t\treturn;\n\t}\n\tconst childNode = node.static?.[segment];\n\tif (childNode) {\n\t\t_remove(childNode, method, segments, index + 1);\n\t\tif (_isEmptyNode(childNode)) {\n\t\t\tdelete node.static[segment];\n\t\t\tif (Object.keys(node.static).length === 0) node.static = void 0;\n\t\t}\n\t}\n}\nfunction _isEmptyNode(node) {\n\treturn node.methods === void 0 && node.static === void 0 && node.param === void 0 && node.wildcard === void 0;\n}\n\n/**\n* Find all route patterns that match the given path.\n*/\nfunction findAllRoutes(ctx, method = \"\", path, opts) {\n\tif (path.charCodeAt(path.length - 1) === 47) path = path.slice(0, -1);\n\tconst segments = splitPath(path);\n\tconst matches = _findAll(ctx, ctx.root, method, segments, 0);\n\tif (opts?.params === false) return matches;\n\treturn matches.map((m) => {\n\t\treturn {\n\t\t\tdata: m.data,\n\t\t\tparams: m.paramsMap ? getMatchParams(segments, m.paramsMap) : void 0\n\t\t};\n\t});\n}\nfunction _findAll(ctx, node, method, segments, index, matches = []) {\n\tconst segment = segments[index];\n\tif (node.wildcard && node.wildcard.methods) {\n\t\tconst match = node.wildcard.methods[method] || node.wildcard.methods[\"\"];\n\t\tif (match) matches.push(...match);\n\t}\n\tif (node.param) {\n\t\t_findAll(ctx, node.param, method, segments, index + 1, matches);\n\t\tif (index === segments.length && node.param.methods) {\n\t\t\tconst match = node.param.methods[method] || node.param.methods[\"\"];\n\t\t\tif (match) {\n\t\t\t\tconst pMap = match[0].paramsMap;\n\t\t\t\tif (pMap?.[pMap?.length - 1]?.[2]) matches.push(...match);\n\t\t\t}\n\t\t}\n\t}\n\tconst staticChild = node.static?.[segment];\n\tif (staticChild) _findAll(ctx, staticChild, method, segments, index + 1, matches);\n\tif (index === segments.length && node.methods) {\n\t\tconst match = node.methods[method] || node.methods[\"\"];\n\t\tif (match) matches.push(...match);\n\t}\n\treturn matches;\n}\n\nfunction routeToRegExp(route = \"/\") {\n\tconst reSegments = [];\n\tlet idCtr = 0;\n\tfor (const segment of route.split(\"/\")) {\n\t\tif (!segment) continue;\n\t\tif (segment === \"*\") reSegments.push(`(?<_${idCtr++}>[^/]*)`);\n\t\telse if (segment.startsWith(\"**\")) reSegments.push(segment === \"**\" ? \"?(?<_>.*)\" : `?(?<${segment.slice(3)}>.+)`);\n\t\telse if (segment.includes(\":\")) reSegments.push(segment.replace(/:(\\w+)/g, (_, id) => `(?<${id}>[^/]+)`).replace(/\\./g, \"\\\\.\"));\n\t\telse reSegments.push(segment);\n\t}\n\treturn /* @__PURE__ */ new RegExp(`^/${reSegments.join(\"/\")}/?$`);\n}\n\nexport { NullProtoObj, addRoute, createRouter, findAllRoutes, findRoute, removeRoute, routeToRegExp };","// packages/route-tree/src/services/MatcherService.ts\n\nimport { addRoute, createRouter, findRoute } from \"rou3\";\nimport { parse as parseQueryParams } from \"search-params\";\n\nimport { validateConstraints } from \"./constraintValidation\";\nimport { DECODING_METHODS } from \"./encoding\";\n\nimport type { ConstraintPattern } from \"./buildParamMeta\";\nimport type { IMatcherService } from \"./types\";\nimport type { RouteTree } from \"../builder/types\";\nimport type {\n MatchOptions,\n MatchResult,\n RouteParams,\n RouteTreeStateMeta,\n URLParamsEncodingType,\n} from \"../operations/types\";\nimport type { Options as QueryParamsOptions } from \"search-params\";\n\nconst RAW_UNICODE_PATTERN = /[\\u0080-\\uFFFF]/;\n\ninterface RouteData {\n /** Segments without root, WITH slashChild â for match() */\n readonly matchSegments: readonly RouteTree[];\n /** Segments without root, WITHOUT slashChild â for getSegmentsByName()/buildPath */\n readonly segments: readonly RouteTree[];\n readonly declaredQueryParams: readonly string[];\n readonly hasTrailingSlash: boolean;\n readonly hasConstraints: boolean;\n /** Pre-computed constraint patterns â avoids Map creation per match() */\n readonly constraintPatterns: ReadonlyMap<string, ConstraintPattern>;\n /** Pre-computed Set for strict query params mode â avoids Set creation per match() */\n readonly declaredQueryParamsSet: ReadonlySet<string>;\n /** Pre-computed meta (segment fullName â paramTypeMap) â avoids iteration per match() */\n readonly meta: Readonly<RouteTreeStateMeta>;\n}\n\nexport class MatcherService implements IMatcherService {\n readonly #router = createRouter();\n readonly #routesByName = new Map<string, readonly RouteTree[]>();\n readonly #metaByName = new Map<string, Readonly<RouteTreeStateMeta>>();\n\n registerTree(node: RouteTree, parentPath = \"\"): void {\n const segments: RouteTree[] = [];\n\n this.#registerNode(node, parentPath, segments);\n }\n\n match(path: string, options?: MatchOptions): MatchResult | undefined {\n const normalizedPath = path === \"\" ? \"/\" : path;\n\n if (\n !normalizedPath.startsWith(\"/\") ||\n this.#hasRawUnicode(normalizedPath)\n ) {\n return undefined;\n }\n\n const queryIndex = normalizedPath.indexOf(\"?\");\n const originalPathWithoutQuery =\n queryIndex === -1 ? normalizedPath : normalizedPath.slice(0, queryIndex);\n const queryString =\n queryIndex === -1 ? \"\" : normalizedPath.slice(queryIndex + 1);\n const strictTrailingSlash = options?.strictTrailingSlash ?? false;\n const pathWithoutQuery = strictTrailingSlash\n ? originalPathWithoutQuery\n : this.#normalizeTrailingSlash(originalPathWithoutQuery);\n\n const result = findRoute(this.#router, \"GET\", pathWithoutQuery);\n\n if (!result) {\n return undefined;\n }\n\n const data = result.data as RouteData;\n\n if (!this.#validateTrailingSlash(pathWithoutQuery, data, options)) {\n return undefined;\n }\n\n const params: RouteParams = result.params\n ? ({ ...result.params } as RouteParams)\n : {};\n\n this.#decodeUrlParams(params, options?.urlParamsEncoding ?? \"default\");\n\n if (\n data.hasConstraints &&\n !this.#validateRouteConstraints(\n params,\n data.constraintPatterns,\n originalPathWithoutQuery,\n )\n ) {\n return undefined;\n }\n\n if (queryString) {\n const success = this.#processQueryParams(\n params,\n queryString,\n data.declaredQueryParamsSet,\n options,\n );\n\n if (!success) {\n return undefined;\n }\n }\n\n return {\n segments: data.matchSegments,\n buildSegments: data.segments,\n params,\n meta: data.meta,\n };\n }\n\n getSegmentsByName(name: string): readonly RouteTree[] | undefined {\n return this.#routesByName.get(name);\n }\n\n getMetaByName(name: string): Readonly<RouteTreeStateMeta> | undefined {\n return this.#metaByName.get(name);\n }\n\n hasRoute(name: string): boolean {\n return this.#routesByName.has(name);\n }\n\n #validateTrailingSlash(\n pathWithoutQuery: string,\n data: RouteData,\n options?: MatchOptions,\n ): boolean {\n if (!options?.strictTrailingSlash) {\n return true;\n }\n\n const inputHasTrailingSlash =\n pathWithoutQuery.length > 1 && pathWithoutQuery.endsWith(\"/\");\n\n return inputHasTrailingSlash === data.hasTrailingSlash;\n }\n\n #decodeUrlParams(params: RouteParams, encoding: URLParamsEncodingType): void {\n if (encoding === \"none\") {\n return;\n }\n\n const decoder = DECODING_METHODS[encoding];\n\n for (const key in params) {\n const value = params[key];\n\n // rou3 always returns string params; check is defensive for type safety\n /* istanbul ignore else -- @preserve */\n if (typeof value === \"string\" && value.includes(\"%\")) {\n params[key] = decoder(value);\n }\n }\n }\n\n #validateRouteConstraints(\n params: RouteParams,\n constraintPatterns: ReadonlyMap<string, ConstraintPattern>,\n path: string,\n ): boolean {\n try {\n validateConstraints(params, constraintPatterns, path);\n\n return true;\n } catch {\n return false;\n }\n }\n\n #processQueryParams(\n params: RouteParams,\n queryString: string,\n declaredQueryParamsSet: ReadonlySet<string>,\n options?: MatchOptions,\n ): boolean {\n const allQueryParams = this.#parseQueryString(\n queryString,\n options?.queryParams,\n );\n const queryParamsMode = options?.queryParamsMode ?? \"default\";\n\n if (queryParamsMode !== \"strict\") {\n Object.assign(params, allQueryParams);\n\n return true;\n }\n\n // Strict mode: only allow declared query params\n for (const key of Object.keys(allQueryParams)) {\n if (!declaredQueryParamsSet.has(key)) {\n return false;\n }\n }\n\n for (const key of declaredQueryParamsSet) {\n if (key in allQueryParams) {\n params[key] = allQueryParams[key];\n }\n }\n\n return true;\n }\n\n #registerNode(\n node: RouteTree,\n parentPath: string,\n segments: RouteTree[],\n ): void {\n segments.push(node);\n\n // For absolute paths, register at root level but keep parent in segments\n const isAbsolute = node.absolute;\n const registrationPath = isAbsolute ? \"\" : parentPath;\n const currentPath = this.#buildFullPath(registrationPath, node.path);\n const rou3Path = this.#convertToRou3Syntax(currentPath);\n const normalized = this.#normalizeTrailingSlash(rou3Path);\n\n if (node.fullName) {\n const declaredQueryParams = this.#collectDeclaredQueryParams(segments);\n const hasTrailingSlash = rou3Path.length > 1 && rou3Path.endsWith(\"/\");\n\n // Pre-filter: remove root segment (path === \"\") once at registration\n const filteredSegments = segments.filter((seg) => seg.path !== \"\");\n const frozenSegments = Object.freeze([...filteredSegments]);\n\n // Pre-compute slashChild (was done per-match in #appendSlashChild)\n const slashChild = this.#findSlashChild(filteredSegments);\n const frozenMatchSegments = slashChild\n ? Object.freeze([...filteredSegments, slashChild])\n : frozenSegments; // reuse same array when no slashChild\n\n // Pre-compute constraint patterns (was Map creation per match)\n const constraintPatterns =\n this.#collectConstraintPatterns(filteredSegments);\n\n // Pre-compute meta (was iteration per match in createRouteState)\n const meta: RouteTreeStateMeta = {};\n\n for (const segment of frozenMatchSegments) {\n meta[segment.fullName] = segment.paramTypeMap;\n }\n\n const routeData: RouteData = {\n matchSegments: frozenMatchSegments,\n segments: frozenSegments,\n declaredQueryParams,\n hasTrailingSlash,\n hasConstraints: constraintPatterns.size > 0,\n constraintPatterns,\n declaredQueryParamsSet: new Set(declaredQueryParams),\n meta: Object.freeze(meta),\n };\n\n this.#routesByName.set(node.fullName, frozenSegments);\n this.#metaByName.set(node.fullName, routeData.meta);\n addRoute(this.#router, \"GET\", normalized, routeData);\n }\n\n // For children of absolute paths, use the absolute path as parent\n const childParentPath = currentPath;\n\n for (const child of node.children.values()) {\n this.#registerNode(child, childParentPath, segments);\n }\n\n segments.pop();\n }\n\n #collectDeclaredQueryParams(\n segments: readonly RouteTree[],\n ): readonly string[] {\n const queryParams: string[] = [];\n\n for (const segment of segments) {\n if (segment.paramMeta.queryParams.length > 0) {\n queryParams.push(...segment.paramMeta.queryParams);\n }\n }\n\n return queryParams;\n }\n\n #collectConstraintPatterns(\n segments: readonly RouteTree[],\n ): ReadonlyMap<string, ConstraintPattern> {\n const patterns = new Map<string, ConstraintPattern>();\n\n for (const segment of segments) {\n for (const [paramName, pattern] of segment.paramMeta.constraintPatterns) {\n patterns.set(paramName, pattern);\n }\n }\n\n return patterns;\n }\n\n #normalizeTrailingSlash(path: string): string {\n if (path.length > 1 && path.endsWith(\"/\")) {\n return path.slice(0, -1);\n }\n\n return path;\n }\n\n #buildFullPath(parentPath: string, nodePath: string): string {\n // Note: \"~\" prefix is already stripped in buildTree.ts, so nodePath never starts with \"~\"\n if (parentPath === \"\") {\n return nodePath;\n }\n\n // Handle query-only root paths (e.g., \"?mode\" from persistent-params-plugin)\n // These should be appended to the node path, not prepended\n if (parentPath.startsWith(\"?\")) {\n if (nodePath === \"\") {\n return parentPath;\n }\n\n const nodeQueryIndex = nodePath.indexOf(\"?\");\n\n if (nodeQueryIndex !== -1) {\n const nodePathPart = nodePath.slice(0, nodeQueryIndex);\n const nodeQueryPart = nodePath.slice(nodeQueryIndex + 1);\n\n return `${nodePathPart}?${parentPath.slice(1)}&${nodeQueryPart}`;\n }\n\n return `${nodePath}${parentPath}`;\n }\n\n if (nodePath === \"\") {\n return parentPath;\n }\n\n const parentQueryIndex = parentPath.indexOf(\"?\");\n const nodeQueryIndex = nodePath.indexOf(\"?\");\n\n if (parentQueryIndex !== -1) {\n const parentPathPart = parentPath.slice(0, parentQueryIndex);\n const parentQueryPart = parentPath.slice(parentQueryIndex + 1);\n\n if (nodeQueryIndex !== -1) {\n const nodePathPart = nodePath.slice(0, nodeQueryIndex);\n const nodeQueryPart = nodePath.slice(nodeQueryIndex + 1);\n\n return `${parentPathPart}${nodePathPart}?${parentQueryPart}&${nodeQueryPart}`;\n }\n\n return `${parentPathPart}${nodePath}?${parentQueryPart}`;\n }\n\n if (nodeQueryIndex !== -1) {\n const pathPart = nodePath.slice(0, nodeQueryIndex);\n const queryPart = nodePath.slice(nodeQueryIndex);\n\n return parentPath + pathPart + queryPart;\n }\n\n return parentPath + nodePath;\n }\n\n #convertToRou3Syntax(path: string): string {\n const queryIndex = path.indexOf(\"?\");\n let pathPart = queryIndex === -1 ? path : path.slice(0, queryIndex);\n\n // eslint-disable-next-line sonarjs/slow-regex\n pathPart = pathPart.replaceAll(/<[^>]+>/g, \"\");\n\n pathPart = pathPart.replaceAll(/\\*([^/?]+)/g, \"**:$1\");\n\n pathPart = pathPart.replaceAll(/\\*(?=[/?]|$)/g, \"**\");\n\n return pathPart;\n }\n\n #parseQueryString(\n queryString: string,\n queryParamsOptions?: QueryParamsOptions,\n ): RouteParams {\n return parseQueryParams(queryString, queryParamsOptions) as RouteParams;\n }\n\n #hasRawUnicode(path: string): boolean {\n return RAW_UNICODE_PATTERN.test(path);\n }\n\n /**\n * Finds a slash child (path \"/\" or \"/?...\") from the last segment's children.\n * Called once at registration time, not per-match.\n *\n * Limitation: only adds ONE level of slashChild. Nested slashChild\n * (slashChild with its own slashChild) is not supported.\n */\n #findSlashChild(\n filteredSegments: readonly RouteTree[],\n ): RouteTree | undefined {\n const lastSegment = filteredSegments.at(-1);\n\n /* v8 ignore next -- @preserve: defensive check, filteredSegments always has items when called */\n if (!lastSegment) {\n return undefined;\n }\n\n return lastSegment.nonAbsoluteChildren.find(\n (child) => child.path !== \"\" && /^\\/(\\?|$)/.test(child.path),\n );\n }\n}\n","// packages/route-node/modules/validation/routes.ts\n\nimport type { RouteTree } from \"../types\";\n\n/**\n * Creates a TypeError with consistent router error message format.\n *\n * @param methodName - Name of the method that triggered the error\n * @param message - Error message\n * @returns TypeError with formatted message\n * @internal\n */\nfunction createRouterError(methodName: string, message: string): TypeError {\n return new TypeError(`[router.${methodName}] ${message}`);\n}\n\n/**\n * Validates route path format.\n * Throws a descriptive error if validation fails.\n *\n * Allows:\n * - Empty string (for grouping/root routes)\n * - Absolute paths: /path, ~path\n * - Query strings: ?query\n * - Relative segments: segment\n *\n * Prevents:\n * - Non-string values\n * - Double slashes (//)\n * - Absolute paths (~) under parameterized parent nodes\n *\n * @param path - Route path to validate\n * @param routeName - Name of route (for error messages)\n * @param methodName - Name of calling method for error messages\n * @param parentNode - Optional parent node for context validation\n * @throws {TypeError} If path is invalid\n *\n * @example\n * // Valid paths\n * validateRoutePath(\"\", \"home\", \"add\"); // ok (empty for grouping)\n * validateRoutePath(\"/users\", \"users\", \"add\"); // ok (absolute)\n * validateRoutePath(\"~dashboard\", \"dash\", \"add\"); // ok (absolute, if no parameterized parent)\n * validateRoutePath(\"?tab=1\", \"home\", \"add\"); // ok (query)\n * validateRoutePath(\"profile\", \"users.profile\", \"add\"); // ok (relative)\n *\n * @example\n * // Invalid paths (throws)\n * validateRoutePath(\"/users//list\", \"users.list\", \"add\"); // throws (double slash)\n * validateRoutePath(\"~dash\", \"dash\", \"add\", paramParent); // throws (~ under parameterized parent)\n */\nexport function validateRoutePath(\n path: unknown,\n routeName: string,\n methodName: string,\n parentNode?: RouteTree,\n): asserts path is string {\n // Type check\n if (typeof path !== \"string\") {\n // Get type description for error message\n let typeDesc: string;\n\n if (path === null) {\n typeDesc = \"null\";\n } else if (Array.isArray(path)) {\n typeDesc = \"array\";\n } else {\n typeDesc = typeof path;\n }\n\n throw createRouterError(\n methodName,\n `Route path must be a string, got ${typeDesc}`,\n );\n }\n\n // Empty path is valid (for grouping/root)\n if (path === \"\") {\n return;\n }\n\n // No whitespace characters (spaces, tabs, newlines)\n if (/\\s/.test(path)) {\n throw createRouterError(\n methodName,\n `Invalid path for route \"${routeName}\": whitespace not allowed in \"${path}\"`,\n );\n }\n\n // Valid path pattern\n if (!/^([/?~]|[^/]+$)/.test(path)) {\n throw createRouterError(\n methodName,\n `Route \"${routeName}\" has invalid path format: \"${path}\". Path should start with '/', '~', '?' or be a relative segment.`,\n );\n }\n\n // No double slashes\n if (path.includes(\"//\")) {\n throw createRouterError(\n methodName,\n `Invalid path for route \"${routeName}\": double slashes not allowed in \"${path}\"`,\n );\n }\n\n // Absolute paths under parameterized parents\n // Check if parent has URL parameters via paramTypeMap\n const hasUrlParams =\n parentNode && Object.values(parentNode.paramTypeMap).includes(\"url\");\n\n if (path.startsWith(\"~\") && hasUrlParams) {\n throw new Error(\n `[router.${methodName}] Absolute path \"${path}\" cannot be used under parent route with URL parameters`,\n );\n }\n}\n","// packages/route-node/modules/validation/route-batch.ts\n\n/**\n * Batch route validation utilities.\n *\n * Provides validation for adding routes with cross-batch duplicate detection.\n * Used by router.addRoute() to ensure atomicity - all routes validated before any modification.\n */\n\nimport { validateRoutePath } from \"./routes\";\n\nimport type { RouteDefinition, RouteTree } from \"../types\";\n\n/**\n * Pattern for complete route validation (all segments at once).\n * Matches: single segment or multiple segments separated by dots.\n * Each segment must start with letter/underscore, followed by alphanumeric/hyphen/underscore.\n * Rejects: leading/trailing/consecutive dots, segments starting with numbers/hyphens.\n */\nconst FULL_ROUTE_PATTERN = /^[A-Z_a-z][\\w-]*(?:\\.[A-Z_a-z][\\w-]*)*$/;\n\n/**\n * Checks if string contains at least one non-whitespace character.\n */\nconst HAS_NON_WHITESPACE = /\\S/;\n\n/**\n * Maximum route name length to prevent DoS and performance issues.\n */\nconst MAX_ROUTE_NAME_LENGTH = 10_000;\n\n/**\n * Gets a human-readable description of a value's type.\n * Used for error messages to provide helpful debugging information.\n */\nfunction getTypeDescription(value: unknown): string {\n // Handle null explicitly (typeof null === \"object\")\n if (value === null) {\n return \"null\";\n }\n\n if (typeof value === \"object\") {\n // Return constructor name for class instances\n if (\"constructor\" in value && value.constructor.name !== \"Object\") {\n return value.constructor.name;\n }\n\n // Plain object\n return \"object\";\n }\n\n // Primitive types (string, number, boolean, undefined, etc.)\n return typeof value;\n}\n\n/**\n * Checks if an object has getters or setters.\n * Used to detect potentially malicious route objects that could mutate during processing.\n *\n * @param obj - Object to check\n * @returns true if object has getters or setters\n */\nfunction hasGettersOrSetters(obj: Record<string, unknown>): boolean {\n for (const key of Object.keys(obj)) {\n const descriptor = Object.getOwnPropertyDescriptor(obj, key);\n\n if (descriptor && (descriptor.get || descriptor.set)) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Validates that route is a plain object without getters/setters.\n * Prevents malicious objects that could mutate during processing.\n *\n * @param route - Route to validate\n * @param methodName - Calling method for error context\n * @throws {TypeError} If route is not a plain object\n */\nfunction validateRouteType(\n route: unknown,\n methodName: string,\n): asserts route is Record<string, unknown> {\n if (!route || typeof route !== \"object\") {\n throw new TypeError(\n `[router.${methodName}] Route must be an object, got ${getTypeDescription(route)}`,\n );\n }\n\n // Check for plain object (prototype must be Object.prototype or null)\n const proto: object | null = Object.getPrototypeOf(route) as object | null;\n\n if (proto !== Object.prototype && proto !== null) {\n throw new TypeError(\n `[router.${methodName}] Route must be a plain object, got ${getTypeDescription(route)}`,\n );\n }\n\n // Check for getters/setters (could cause mutations during processing)\n if (hasGettersOrSetters(route as Record<string, unknown>)) {\n throw new TypeError(\n `[router.${methodName}] Route must not have getters or setters`,\n );\n }\n}\n\n/**\n * Validates that encodeParams is a function if provided.\n *\n * @param route - Route configuration\n * @param methodName - Calling method for error context\n * @throws {TypeError} If encodeParams is not a function\n */\nfunction validateEncodeParams(\n route: Record<string, unknown>,\n methodName: string,\n): void {\n if (\n route.encodeParams !== undefined &&\n typeof route.encodeParams !== \"function\"\n ) {\n throw new TypeError(\n `[router.${methodName}] Route \"${String(route.name)}\" encodeParams must be a function`,\n );\n }\n}\n\n/**\n * Validates that decodeParams is a function if provided.\n *\n * @param route - Route configuration\n * @param methodName - Calling method for error context\n * @throws {TypeError} If decodeParams is not a function\n */\nfunction validateDecodeParams(\n route: Record<string, unknown>,\n methodName: string,\n): void {\n if (\n route.decodeParams !== undefined &&\n typeof route.decodeParams !== \"function\"\n ) {\n throw new TypeError(\n `[router.${methodName}] Route \"${String(route.name)}\" decodeParams must be a function`,\n );\n }\n}\n\n/**\n * Validates that route name is a valid string matching the expected format.\n *\n * Route name rules:\n * - Must be a string\n * - Cannot be empty or whitespace-only\n * - Each segment must match [a-zA-Z_][a-zA-Z0-9_-]*\n * - Segments are separated by dots (e.g., \"users.profile\")\n * - No consecutive dots, no leading/trailing dots\n *\n * @param route - Route configuration\n * @param methodName - Calling method for error context\n * @throws {TypeError} If name is missing, not a string, or invalid format\n */\nfunction validateRouteName(\n route: Record<string, unknown>,\n methodName: string,\n): asserts route is Record<string, unknown> & { name: string } {\n if (typeof route.name !== \"string\") {\n throw new TypeError(\n `[router.${methodName}] Route name must be a string, got ${getTypeDescription(route.name)}`,\n );\n }\n\n const name = route.name;\n\n // Empty string is not allowed for addRoute (unlike root node in type-guards)\n if (name === \"\") {\n throw new TypeError(`[router.${methodName}] Route name cannot be empty`);\n }\n\n // Whitespace-only strings are invalid\n if (!HAS_NON_WHITESPACE.test(name)) {\n throw new TypeError(\n `[router.${methodName}] Route name cannot contain only whitespace`,\n );\n }\n\n // Length check for technical safety\n if (name.length > MAX_ROUTE_NAME_LENGTH) {\n throw new TypeError(\n `[router.${methodName}] Route name exceeds maximum length of ${MAX_ROUTE_NAME_LENGTH} characters`,\n );\n }\n\n // System routes bypass pattern validation (e.g., @@router/UNKNOWN_ROUTE)\n if (name.startsWith(\"@@\")) {\n return;\n }\n\n // Validate route pattern (ASCII only: letters, numbers, underscores, hyphens, dots)\n if (!FULL_ROUTE_PATTERN.test(name)) {\n throw new TypeError(\n `[router.${methodName}] Invalid route name \"${name}\". ` +\n `Each segment must start with a letter or underscore, ` +\n `followed by letters, numbers, underscores, or hyphens. ` +\n `Segments are separated by dots (e.g., \"users.profile\").`,\n );\n }\n}\n\n/**\n * Checks for duplicate route name in existing tree.\n *\n * @param rootNode - Root node to search in\n * @param fullName - Full route name (dot-notation)\n * @param methodName - Calling method for error context\n * @throws {Error} If route name already exists\n */\nfunction checkTreeNameDuplicate(\n rootNode: RouteTree,\n fullName: string,\n methodName: string,\n): void {\n // Use children Map for O(1) lookup\n const segments = fullName.split(\".\");\n let current: RouteTree | undefined = rootNode;\n\n for (const segment of segments) {\n current = current.children.get(segment);\n\n if (!current) {\n return; // Route doesn't exist\n }\n }\n\n throw new Error(`[router.${methodName}] Route \"${fullName}\" already exists`);\n}\n\n/**\n * Checks for duplicate route name in current batch.\n *\n * @param seenNames - Set of names already seen in batch\n * @param fullName - Full route name to check\n * @param methodName - Calling method for error context\n * @throws {Error} If duplicate name in batch\n */\nfunction checkBatchNameDuplicate(\n seenNames: Set<string>,\n fullName: string,\n methodName: string,\n): void {\n if (seenNames.has(fullName)) {\n throw new Error(\n `[router.${methodName}] Duplicate route \"${fullName}\" in batch`,\n );\n }\n\n seenNames.add(fullName);\n}\n\n/**\n * Checks for duplicate path in existing tree at same parent level.\n *\n * @param rootNode - Root node to search in\n * @param parentName - Parent route name (empty string for root level)\n * @param routePath - Path to check for duplicates\n * @throws {Error} If path already exists at this level\n */\nfunction checkTreePathDuplicate(\n rootNode: RouteTree,\n parentName: string,\n routePath: string,\n): void {\n // Find parent node using children Map\n let parentNode: RouteTree | undefined = rootNode;\n\n if (parentName !== \"\") {\n const segments = parentName.split(\".\");\n\n for (const segment of segments) {\n parentNode = parentNode.children.get(segment);\n\n if (!parentNode) {\n return; // Parent doesn't exist, so no duplicate\n }\n }\n }\n\n for (const child of parentNode.children.values()) {\n if (child.path === routePath) {\n throw new Error(`Path \"${routePath}\" is already defined`);\n }\n }\n}\n\n/**\n * Checks that parent route exists for dot-notation names.\n *\n * For routes like \"users.profile\", verifies that \"users\" exists either:\n * - In the existing tree\n * - In the current batch (already added before this route)\n *\n * @param rootNode - Root node to search in\n * @param routeName - Route name (possibly with dots)\n * @param methodName - Calling method for error context\n * @param seenNames - Set of names already seen in batch\n * @throws {Error} If parent route does not exist\n */\nfunction checkParentExists(\n rootNode: RouteTree | undefined,\n routeName: string,\n methodName: string,\n seenNames?: Set<string>,\n): void {\n const parts = routeName.split(\".\");\n\n parts.pop(); // Remove last segment (actual route name)\n\n const parentName = parts.join(\".\");\n\n // Check if parent exists in current batch\n if (seenNames?.has(parentName)) {\n return; // Parent was added earlier in this batch\n }\n\n // Check if parent exists in tree\n if (rootNode) {\n const segments = parentName.split(\".\");\n let current: RouteTree | undefined = rootNode;\n\n for (const segment of segments) {\n current = current.children.get(segment);\n\n if (!current) {\n throw new Error(\n `[router.${methodName}] Parent route \"${parentName}\" does not exist for route \"${routeName}\"`,\n );\n }\n }\n\n return; // Parent exists in tree\n }\n\n // No tree and not in batch - parent doesn't exist\n throw new Error(\n `[router.${methodName}] Parent route \"${parentName}\" does not exist for route \"${routeName}\"`,\n );\n}\n\n/**\n * Checks for duplicate path in current batch at same parent level.\n *\n * @param seenPathsByParent - Map of paths by parent name\n * @param parentName - Parent route name (empty string for root level)\n * @param routePath - Path to check for duplicates\n * @throws {Error} If path already exists at this level in batch\n */\nfunction checkBatchPathDuplicate(\n seenPathsByParent: Map<string, Set<string>>,\n parentName: string,\n routePath: string,\n): void {\n const pathsAtLevel = seenPathsByParent.get(parentName);\n\n if (pathsAtLevel?.has(routePath)) {\n throw new Error(`Path \"${routePath}\" is already defined`);\n }\n\n if (pathsAtLevel) {\n pathsAtLevel.add(routePath);\n } else {\n seenPathsByParent.set(parentName, new Set([routePath]));\n }\n}\n\n/**\n * Validates route structure for add operations.\n *\n * Performs comprehensive validation including:\n * - Type check (must be object)\n * - Name validation\n * - Path validation\n * - Duplicate name detection (in tree and batch)\n * - Duplicate path detection (in tree and batch)\n * - Recursive children validation\n *\n * @param route - Route to validate\n * @param methodName - Calling method for error context\n * @param rootNode - Optional root node for duplicate checking\n * @param parentName - Parent route name for building full path (used in recursion)\n * @param seenNames - Set of names already seen in this batch\n * @param seenPathsByParent - Map of paths by parent for path duplicate detection\n * @throws {TypeError} If route structure is invalid\n * @throws {Error} If route already exists (duplicate)\n * @throws {Error} If path already defined (duplicate)\n *\n * @example\n * ```typescript\n * const seenNames = new Set<string>();\n * const seenPaths = new Map<string, Set<string>>();\n *\n * // Validate routes before adding\n * for (const route of routes) {\n * validateRoute(route, \"add\", rootNode, \"\", seenNames, seenPaths);\n * }\n * ```\n */\nexport function validateRoute(\n route: unknown,\n methodName: string,\n rootNode?: RouteTree,\n parentName = \"\",\n seenNames?: Set<string>,\n seenPathsByParent?: Map<string, Set<string>>,\n): asserts route is RouteDefinition {\n validateRouteType(route, methodName);\n\n const r = route;\n\n // Validate that name is a non-empty string\n validateRouteName(r, methodName);\n\n // Validate path structure\n validateRoutePath(r.path, r.name, methodName, rootNode);\n\n // Validate optional function properties\n validateEncodeParams(r, methodName);\n validateDecodeParams(r, methodName);\n\n const routeName = r.name;\n const fullName = parentName ? `${parentName}.${routeName}` : routeName;\n\n // Check that parent exists for dot-notation names (e.g., \"users.profile\" requires \"users\")\n // Only check for flat routes (no parentName) with dot-notation\n if (!parentName && fullName.includes(\".\")) {\n checkParentExists(rootNode, fullName, methodName, seenNames);\n }\n\n // Check for duplicate name in existing tree\n if (rootNode && fullName) {\n checkTreeNameDuplicate(rootNode, fullName, methodName);\n }\n\n // Check for duplicate name in current batch\n if (seenNames) {\n checkBatchNameDuplicate(seenNames, fullName, methodName);\n }\n\n const routePath = r.path;\n\n // For flat routes with dot-notation names (e.g., \"users.settings\"),\n // extract the parent from the name for path checking.\n // RouteNode will place such routes under their implied parent.\n let pathCheckParent = parentName;\n\n if (routeName.includes(\".\") && !parentName) {\n const parts = routeName.split(\".\");\n\n parts.pop(); // Remove last segment (actual route name)\n\n pathCheckParent = parts.join(\".\");\n }\n\n // Check for duplicate path in existing tree\n if (rootNode) {\n checkTreePathDuplicate(rootNode, pathCheckParent, routePath);\n }\n\n // Check for duplicate path in current batch\n if (seenPathsByParent) {\n checkBatchPathDuplicate(seenPathsByParent, pathCheckParent, routePath);\n }\n\n // Validate children recursively\n if (r.children !== undefined) {\n if (!Array.isArray(r.children)) {\n throw new TypeError(\n `[router.${methodName}] Route \"${routeName}\" children must be an array, got ${getTypeDescription(r.children)}`,\n );\n }\n\n for (const child of r.children) {\n validateRoute(\n child,\n methodName,\n rootNode,\n fullName,\n seenNames,\n seenPathsByParent,\n );\n }\n }\n}\n","// packages/core/src/namespaces/RoutesNamespace/constants.ts\n\n/**\n * Default route name for the root node.\n */\nexport const DEFAULT_ROUTE_NAME = \"\";\n\n/**\n * Cache for validated route names to skip regex validation on repeated calls.\n * Key insight: validateRouteName() regex takes ~40ns, but cache lookup is ~1ns.\n * This cache is module-level (shared across all router instances) since route name\n * validity is independent of router instance.\n */\nexport const validatedRouteNames = new Set<string>();\n","// packages/core/src/namespaces/RoutesNamespace/helpers.ts\n\nimport { getSegmentsByName } from \"route-tree\";\nimport { getTypeDescription } from \"type-guards\";\n\nimport { createBuildOptions } from \"../../helpers\";\n\nimport type { RouteConfig } from \"./types\";\nimport type { Route } from \"../../types\";\nimport type { DefaultDependencies, Options, Params } from \"@real-router/types\";\nimport type { MatchOptions, RouteDefinition, RouteTree } from \"route-tree\";\n\n/**\n * Creates an empty RouteConfig.\n */\nexport function createEmptyConfig(): RouteConfig {\n return {\n decoders: Object.create(null) as Record<string, (params: Params) => Params>,\n encoders: Object.create(null) as Record<string, (params: Params) => Params>,\n defaultParams: Object.create(null) as Record<string, Params>,\n forwardMap: Object.create(null) as Record<string, string>,\n };\n}\n\n/**\n * Creates RouteNode match options from real-router options.\n */\nexport function createMatchOptions(options: Options): MatchOptions {\n return {\n ...createBuildOptions(options),\n strictTrailingSlash: options.trailingSlash === \"strict\",\n strongMatching: false,\n };\n}\n\n// ============================================================================\n// Route Tree Helpers\n// ============================================================================\n\n/**\n * Checks if all params from source exist with same values in target.\n * Small function body allows V8 inlining.\n */\nexport function paramsMatch(source: Params, target: Params): boolean {\n for (const key in source) {\n if (source[key] !== target[key]) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Checks params match, skipping keys present in skipKeys.\n */\nexport function paramsMatchExcluding(\n source: Params,\n target: Params,\n skipKeys: Params,\n): boolean {\n for (const key in source) {\n if (key in skipKeys) {\n continue;\n }\n if (source[key] !== target[key]) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Sanitizes a route by keeping only essential properties.\n */\nexport function sanitizeRoute<Dependencies extends DefaultDependencies>(\n route: Route<Dependencies>,\n): RouteDefinition {\n const sanitized: RouteDefinition = {\n name: route.name,\n path: route.path,\n };\n\n if (route.children) {\n sanitized.children = route.children.map((child) => sanitizeRoute(child));\n }\n\n return sanitized;\n}\n\n/**\n * Recursively removes a route from definitions array.\n */\nexport function removeFromDefinitions(\n definitions: RouteDefinition[],\n routeName: string,\n parentPrefix = \"\",\n): boolean {\n for (let i = 0; i < definitions.length; i++) {\n const route = definitions[i];\n const fullName = parentPrefix\n ? `${parentPrefix}.${route.name}`\n : route.name;\n\n if (fullName === routeName) {\n definitions.splice(i, 1);\n\n return true;\n }\n\n if (\n route.children &&\n routeName.startsWith(`${fullName}.`) &&\n removeFromDefinitions(route.children, routeName, fullName)\n ) {\n return true;\n }\n }\n\n return false;\n}\n\n/**\n * Clears configuration entries that match the predicate.\n */\nexport function clearConfigEntries<T>(\n config: Record<string, T>,\n matcher: (key: string) => boolean,\n): void {\n for (const key of Object.keys(config)) {\n if (matcher(key)) {\n delete config[key];\n }\n }\n}\n\n// ============================================================================\n// Route Property Validation\n// ============================================================================\n\n/**\n * Validates route properties (canActivate, canDeactivate, defaultParams, async functions).\n * This ensures type safety at configuration time, not runtime.\n *\n * @param route - Route to validate\n * @param fullName - Full route name (with parent prefix)\n * @throws {TypeError} If canActivate/canDeactivate is not a function\n * @throws {TypeError} If defaultParams is not a plain object\n * @throws {TypeError} If decodeParams/encodeParams is async\n */\nexport function validateRouteProperties<\n Dependencies extends DefaultDependencies,\n>(route: Route<Dependencies>, fullName: string): void {\n // Validate canActivate is a function\n if (\n route.canActivate !== undefined &&\n typeof route.canActivate !== \"function\"\n ) {\n throw new TypeError(\n `[router.addRoute] canActivate must be a function for route \"${fullName}\", ` +\n `got ${getTypeDescription(route.canActivate)}`,\n );\n }\n\n // Validate canDeactivate is a function\n if (\n route.canDeactivate !== undefined &&\n typeof route.canDeactivate !== \"function\"\n ) {\n throw new TypeError(\n `[router.addRoute] canDeactivate must be a function for route \"${fullName}\", ` +\n `got ${getTypeDescription(route.canDeactivate)}`,\n );\n }\n\n // Validate defaultParams is a plain object\n // Runtime check for invalid types passed via `as any`\n if (route.defaultParams !== undefined) {\n const params: unknown = route.defaultParams;\n\n if (\n params === null ||\n typeof params !== \"object\" ||\n Array.isArray(params)\n ) {\n throw new TypeError(\n `[router.addRoute] defaultParams must be an object for route \"${fullName}\", ` +\n `got ${getTypeDescription(route.defaultParams)}`,\n );\n }\n }\n\n // Validate decodeParams is not async (sync required for matchPath/buildPath)\n if (route.decodeParams?.constructor.name === \"AsyncFunction\") {\n throw new TypeError(\n `[router.addRoute] decodeParams cannot be async for route \"${fullName}\". Async functions break matchPath/buildPath.`,\n );\n }\n\n // Validate encodeParams is not async (sync required for matchPath/buildPath)\n if (route.encodeParams?.constructor.name === \"AsyncFunction\") {\n throw new TypeError(\n `[router.addRoute] encodeParams cannot be async for route \"${fullName}\". Async functions break matchPath/buildPath.`,\n );\n }\n\n // Recursively validate children\n if (route.children) {\n for (const child of route.children) {\n const childFullName = `${fullName}.${child.name}`;\n\n validateRouteProperties(child, childFullName);\n }\n }\n}\n\n// ============================================================================\n// ForwardTo Validation\n// ============================================================================\n\n/**\n * Extracts parameter names from a path string.\n * Matches :param and *splat patterns.\n */\nfunction extractParamsFromPath(path: string): Set<string> {\n const params = new Set<string>();\n const paramRegex = /[*:]([A-Z_a-z]\\w*)/g;\n let match;\n\n while ((match = paramRegex.exec(path)) !== null) {\n params.add(match[1]);\n }\n\n return params;\n}\n\n/**\n * Extracts all parameters from multiple path segments.\n */\nfunction extractParamsFromPaths(paths: readonly string[]): Set<string> {\n const params = new Set<string>();\n\n for (const path of paths) {\n for (const param of extractParamsFromPath(path)) {\n params.add(param);\n }\n }\n\n return params;\n}\n\n/**\n * Collects all path segments for a route from batch definitions.\n * Traverses parent routes to include inherited path segments.\n */\nfunction collectPathsToRoute<Dependencies extends DefaultDependencies>(\n routes: readonly Route<Dependencies>[],\n routeName: string,\n parentName = \"\",\n paths: string[] = [],\n): string[] {\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n const currentPaths = [...paths, route.path];\n\n if (fullName === routeName) {\n return currentPaths;\n }\n\n if (route.children && routeName.startsWith(`${fullName}.`)) {\n return collectPathsToRoute(\n route.children,\n routeName,\n fullName,\n currentPaths,\n );\n }\n }\n\n /* v8 ignore next -- @preserve unreachable: callers validate existence */\n throw new Error(\n `[internal] collectPathsToRoute: route \"${routeName}\" not found`,\n );\n}\n\n/**\n * Collects all route names from a batch of routes (including children).\n */\nfunction collectRouteNames<Dependencies extends DefaultDependencies>(\n routes: readonly Route<Dependencies>[],\n parentName = \"\",\n): Set<string> {\n const names = new Set<string>();\n\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n\n names.add(fullName);\n\n if (route.children) {\n for (const childName of collectRouteNames(route.children, fullName)) {\n names.add(childName);\n }\n }\n }\n\n return names;\n}\n\n/**\n * Collects all forwardTo mappings from a batch of routes (including children).\n */\nfunction collectForwardMappings<Dependencies extends DefaultDependencies>(\n routes: readonly Route<Dependencies>[],\n parentName = \"\",\n): Map<string, string> {\n const mappings = new Map<string, string>();\n\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n\n if (route.forwardTo) {\n mappings.set(fullName, route.forwardTo);\n }\n\n if (route.children) {\n for (const [key, value] of collectForwardMappings(\n route.children,\n fullName,\n )) {\n mappings.set(key, value);\n }\n }\n }\n\n return mappings;\n}\n\n/**\n * Extracts required path parameters from route segments.\n */\nfunction getRequiredParams(segments: readonly RouteTree[]): Set<string> {\n const params = new Set<string>();\n\n for (const segment of segments) {\n // Named routes always have parsers (null only for root without path)\n for (const param of segment.paramMeta.urlParams) {\n params.add(param);\n }\n\n for (const param of segment.paramMeta.spatParams) {\n params.add(param);\n }\n }\n\n return params;\n}\n\n/**\n * Checks if a route exists in the tree by navigating through children Map.\n */\nfunction routeExistsInTree(tree: RouteTree, routeName: string): boolean {\n const segments = routeName.split(\".\");\n let current: RouteTree | undefined = tree;\n\n for (const segment of segments) {\n current = current.children.get(segment);\n\n if (!current) {\n return false;\n }\n }\n\n return true;\n}\n\n/**\n * Gets the target route parameters for validation.\n */\nfunction getTargetParams<Dependencies extends DefaultDependencies>(\n targetRoute: string,\n existsInTree: boolean,\n tree: RouteTree,\n routes: readonly Route<Dependencies>[],\n): Set<string> {\n if (existsInTree) {\n const toSegments = getSegmentsByName(tree, targetRoute);\n\n // toSegments won't be null since we checked existsInTree\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n return getRequiredParams(toSegments!);\n }\n\n // Target is in batch\n return extractParamsFromPaths(collectPathsToRoute(routes, targetRoute));\n}\n\n/**\n * Validates a single forward mapping for target existence and param compatibility.\n */\nfunction validateSingleForward<Dependencies extends DefaultDependencies>(\n fromRoute: string,\n targetRoute: string,\n routes: readonly Route<Dependencies>[],\n batchNames: Set<string>,\n tree: RouteTree,\n): void {\n const existsInTree = routeExistsInTree(tree, targetRoute);\n const existsInBatch = batchNames.has(targetRoute);\n\n if (!existsInTree && !existsInBatch) {\n throw new Error(\n `[router.addRoute] forwardTo target \"${targetRoute}\" does not exist ` +\n `for route \"${fromRoute}\"`,\n );\n }\n\n // Get source params\n const fromParams = extractParamsFromPaths(\n collectPathsToRoute(routes, fromRoute),\n );\n\n // Get target params\n const toParams = getTargetParams(targetRoute, existsInTree, tree, routes);\n\n // Check for missing params\n const missingParams = [...toParams].filter((p) => !fromParams.has(p));\n\n if (missingParams.length > 0) {\n throw new Error(\n `[router.addRoute] forwardTo target \"${targetRoute}\" requires params ` +\n `[${missingParams.join(\", \")}] that are not available in source route \"${fromRoute}\"`,\n );\n }\n}\n\n/**\n * Resolves a forwardTo chain to its final destination.\n * Detects cycles and enforces max depth.\n */\nexport function resolveForwardChain(\n startRoute: string,\n forwardMap: Record<string, string>,\n maxDepth = 100,\n): string {\n const visited = new Set<string>();\n const chain: string[] = [startRoute];\n let current = startRoute;\n\n while (forwardMap[current]) {\n const next = forwardMap[current];\n\n if (visited.has(next)) {\n const cycleStart = chain.indexOf(next);\n const cycle = [...chain.slice(cycleStart), next];\n\n throw new Error(`Circular forwardTo: ${cycle.join(\" â \")}`);\n }\n\n visited.add(current);\n chain.push(next);\n current = next;\n\n if (chain.length > maxDepth) {\n throw new Error(\n `forwardTo chain exceeds maximum depth (${maxDepth}): ${chain.join(\" â \")}`,\n );\n }\n }\n\n return current;\n}\n\n/**\n * Validates forwardTo targets and cycles BEFORE any modifications.\n * This ensures atomicity - if validation fails, no routes are added.\n *\n * @param routes - Routes to validate\n * @param existingForwardMap - Current forwardMap from router.config\n * @param tree - Current route tree\n *\n * @throws {Error} If forwardTo target doesn't exist\n * @throws {Error} If circular forwardTo is detected\n */\nexport function validateForwardToTargets<\n Dependencies extends DefaultDependencies,\n>(\n routes: readonly Route<Dependencies>[],\n existingForwardMap: Record<string, string>,\n tree: RouteTree,\n): void {\n const batchNames = collectRouteNames(routes);\n const batchForwards = collectForwardMappings(routes);\n\n // Merge with existing forwardMap for cycle detection\n const combinedForwardMap: Record<string, string> = { ...existingForwardMap };\n\n for (const [from, to] of batchForwards) {\n combinedForwardMap[from] = to;\n }\n\n // Validate each forwardTo target exists and params are compatible\n for (const [fromRoute, targetRoute] of batchForwards) {\n validateSingleForward(fromRoute, targetRoute, routes, batchNames, tree);\n }\n\n // Check for cycles in the combined forwardMap\n for (const fromRoute of Object.keys(combinedForwardMap)) {\n resolveForwardChain(fromRoute, combinedForwardMap);\n }\n}\n","// packages/real-router/modules/core/stateBuilder.ts\n\n/**\n * State Builder Utilities.\n *\n * Functions for building RouteTreeState from raw route segments.\n * This module handles the conversion from low-level route-node data\n * to the higher-level state representation used by real-router.\n *\n * @module core/stateBuilder\n */\n\nimport type {\n MatchResult,\n RouteParams,\n RouteTree,\n RouteTreeState,\n} from \"route-tree\";\n\n/**\n * Builds a dot-separated route name from segments.\n *\n * @param segments - Array of route segments with names\n * @returns Dot-separated route name (e.g., \"users.profile\")\n *\n * @example\n * ```typescript\n * const segments = [{ name: \"users\" }, { name: \"profile\" }];\n * buildNameFromSegments(segments); // \"users.profile\"\n * ```\n */\nexport function buildNameFromSegments(segments: readonly RouteTree[]): string {\n return segments.at(-1)?.fullName ?? \"\";\n}\n\n/**\n * Creates a RouteTreeState from a MatchResult.\n *\n * This function is the primary way to build a RouteTreeState when\n * you have a MatchResult from matchPathSegments() or other low-level APIs.\n *\n * @param matchResult - Result from matchPathSegments() containing segments and params\n * @param name - Optional explicit name (if not provided, built from segments)\n * @returns RouteTreeState with name, params, and meta\n *\n * @example\n * ```typescript\n * const matchResult = routeNode.matchPathSegments(\"/users/123\");\n * if (matchResult) {\n * const state = createRouteState(matchResult);\n * // { name: \"users.profile\", params: { id: \"123\" }, meta: {...} }\n * }\n * ```\n */\nexport function createRouteState<P extends RouteParams = RouteParams>(\n matchResult: MatchResult<P>,\n name?: string,\n): RouteTreeState<P> {\n const resolvedName = name ?? buildNameFromSegments(matchResult.segments);\n\n return {\n name: resolvedName,\n params: matchResult.params,\n meta: matchResult.meta,\n };\n}\n","// packages/core/src/namespaces/RoutesNamespace/validators.ts\n\n/**\n * Static validation functions for RoutesNamespace.\n * Called by Router facade before instance methods.\n *\n * Extracted from RoutesNamespace class for better separation of concerns.\n */\n\nimport { validateRoute } from \"route-tree\";\nimport {\n isString,\n validateRouteName,\n isParams,\n getTypeDescription,\n} from \"type-guards\";\n\nimport { validateRouteProperties, validateForwardToTargets } from \"./helpers\";\n\nimport type { Route, RouteConfigUpdate } from \"../../types\";\nimport type { DefaultDependencies } from \"@real-router/types\";\nimport type { RouteTree } from \"route-tree\";\n\n/**\n * Validates removeRoute arguments.\n */\nexport function validateRemoveRouteArgs(name: unknown): asserts name is string {\n validateRouteName(name, \"removeRoute\");\n}\n\n/**\n * Validates setRootPath arguments.\n */\nexport function validateSetRootPathArgs(\n rootPath: unknown,\n): asserts rootPath is string {\n if (typeof rootPath !== \"string\") {\n throw new TypeError(\n `[router.setRootPath] rootPath must be a string, got ${getTypeDescription(rootPath)}`,\n );\n }\n}\n\n/**\n * Validates addRoute arguments (route structure and properties).\n * State-dependent validation (duplicates, tree) happens in instance method.\n */\n// eslint-disable-next-line @typescript-eslint/no-explicit-any -- accepts any Route type\nexport function validateAddRouteArgs(routes: readonly Route<any>[]): void {\n for (const route of routes) {\n // First check if route is an object (before accessing route.name)\n // Runtime check for invalid types passed via `as any`\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition -- runtime check\n if (route === null || typeof route !== \"object\" || Array.isArray(route)) {\n throw new TypeError(\n `[router.addRoute] Route must be an object, got ${getTypeDescription(route)}`,\n );\n }\n\n // Validate route properties (canActivate, canDeactivate, defaultParams, async checks)\n // Note: validateRouteProperties handles children recursively\n validateRouteProperties(route, route.name);\n }\n}\n\n/**\n * Validates isActiveRoute arguments.\n */\nexport function validateIsActiveRouteArgs(\n name: unknown,\n params: unknown,\n strictEquality: unknown,\n ignoreQueryParams: unknown,\n): void {\n // Validate name - non-string throws\n if (!isString(name)) {\n throw new TypeError(`Route name must be a string`);\n }\n\n // Validate params if provided\n if (params !== undefined && !isParams(params)) {\n throw new TypeError(`[router.isActiveRoute] Invalid params structure`);\n }\n\n // Validate strictEquality if provided\n if (strictEquality !== undefined && typeof strictEquality !== \"boolean\") {\n throw new TypeError(\n `[router.isActiveRoute] strictEquality must be a boolean, got ${typeof strictEquality}`,\n );\n }\n\n // Validate ignoreQueryParams if provided\n if (\n ignoreQueryParams !== undefined &&\n typeof ignoreQueryParams !== \"boolean\"\n ) {\n throw new TypeError(\n `[router.isActiveRoute] ignoreQueryParams must be a boolean, got ${typeof ignoreQueryParams}`,\n );\n }\n}\n\n/**\n * Validates forwardState/buildState arguments.\n */\nexport function validateStateBuilderArgs(\n routeName: unknown,\n routeParams: unknown,\n methodName: string,\n): void {\n if (!isString(routeName)) {\n throw new TypeError(\n `[router.${methodName}] Invalid routeName: ${getTypeDescription(routeName)}. Expected string.`,\n );\n }\n\n if (!isParams(routeParams)) {\n throw new TypeError(\n `[router.${methodName}] Invalid routeParams: ${getTypeDescription(routeParams)}. Expected plain object.`,\n );\n }\n}\n\n/**\n * Validates updateRoute basic arguments (name and updates object structure).\n * Does NOT read property values to allow caller to cache them first.\n */\nexport function validateUpdateRouteBasicArgs<\n Dependencies extends DefaultDependencies,\n>(\n name: unknown,\n updates: unknown,\n): asserts updates is RouteConfigUpdate<Dependencies> {\n // Validate name\n validateRouteName(name, \"updateRoute\");\n\n if (name === \"\") {\n throw new ReferenceError(\n `[router.updateRoute] Invalid name: empty string. Cannot update root node.`,\n );\n }\n\n // Validate updates is not null\n\n if (updates === null) {\n throw new TypeError(\n `[real-router] updateRoute: updates must be an object, got null`,\n );\n }\n\n // Validate updates is an object (not array)\n if (typeof updates !== \"object\" || Array.isArray(updates)) {\n throw new TypeError(\n `[real-router] updateRoute: updates must be an object, got ${getTypeDescription(updates)}`,\n );\n }\n}\n\n/**\n * Validates updateRoute property types using pre-cached values.\n * Called AFTER properties are cached to ensure getters are called only once.\n */\n// eslint-disable-next-line sonarjs/cognitive-complexity -- validation logic is naturally verbose\nexport function validateUpdateRoutePropertyTypes(\n forwardTo: unknown,\n defaultParams: unknown,\n decodeParams: unknown,\n encodeParams: unknown,\n): void {\n // Validate forwardTo type (existence check is done by instance method)\n if (forwardTo !== undefined && forwardTo !== null && !isString(forwardTo)) {\n throw new TypeError(\n `[real-router] updateRoute: forwardTo must be a string or null, got ${getTypeDescription(forwardTo)}`,\n );\n }\n\n // Validate defaultParams\n if (\n defaultParams !== undefined &&\n defaultParams !== null &&\n (typeof defaultParams !== \"object\" || Array.isArray(defaultParams))\n ) {\n throw new TypeError(\n `[real-router] updateRoute: defaultParams must be an object or null, got ${getTypeDescription(defaultParams)}`,\n );\n }\n\n // Validate decodeParams\n if (decodeParams !== undefined && decodeParams !== null) {\n if (typeof decodeParams !== \"function\") {\n throw new TypeError(\n `[real-router] updateRoute: decodeParams must be a function or null, got ${typeof decodeParams}`,\n );\n }\n\n // Check for async function\n if (\n (decodeParams as { constructor: { name: string } }).constructor.name ===\n \"AsyncFunction\" ||\n (decodeParams as { toString: () => string })\n .toString()\n .includes(\"__awaiter\")\n ) {\n throw new TypeError(\n `[real-router] updateRoute: decodeParams cannot be an async function`,\n );\n }\n }\n\n // Validate encodeParams\n if (encodeParams !== undefined && encodeParams !== null) {\n if (typeof encodeParams !== \"function\") {\n throw new TypeError(\n `[real-router] updateRoute: encodeParams must be a function or null, got ${typeof encodeParams}`,\n );\n }\n\n // Check for async function\n if (\n (encodeParams as { constructor: { name: string } }).constructor.name ===\n \"AsyncFunction\" ||\n (encodeParams as { toString: () => string })\n .toString()\n .includes(\"__awaiter\")\n ) {\n throw new TypeError(\n `[real-router] updateRoute: encodeParams cannot be an async function`,\n );\n }\n }\n}\n\n/**\n * Validates buildPath arguments.\n */\nexport function validateBuildPathArgs(route: unknown): asserts route is string {\n if (!isString(route) || route === \"\") {\n throw new TypeError(\n `[real-router] buildPath: route must be a non-empty string, got ${typeof route === \"string\" ? '\"\"' : typeof route}`,\n );\n }\n}\n\n/**\n * Validates matchPath arguments.\n */\nexport function validateMatchPathArgs(path: unknown): asserts path is string {\n if (!isString(path)) {\n throw new TypeError(\n `[real-router] matchPath: path must be a string, got ${typeof path}`,\n );\n }\n}\n\n/**\n * Validates shouldUpdateNode arguments.\n */\nexport function validateShouldUpdateNodeArgs(\n nodeName: unknown,\n): asserts nodeName is string {\n if (!isString(nodeName)) {\n throw new TypeError(\n `[router.shouldUpdateNode] nodeName must be a string, got ${typeof nodeName}`,\n );\n }\n}\n\n/**\n * Validates routes for addition to the router.\n * Checks for duplicates, parent existence, and forwardTo targets/cycles.\n *\n * @param routes - Routes to validate\n * @param tree - Current route tree (optional for initial validation)\n * @param forwardMap - Current forward map for cycle detection\n */\nexport function validateRoutes<Dependencies extends DefaultDependencies>(\n routes: Route<Dependencies>[],\n tree?: RouteTree,\n forwardMap?: Record<string, string>,\n): void {\n // Tracking sets for duplicate detection\n const seenNames = new Set<string>();\n const seenPathsByParent = new Map<string, Set<string>>();\n\n for (const route of routes) {\n // Use route-tree's validateRoute for structural validation\n // (type, name, path, duplicates, parent exists, children array)\n // Note: validateRoute handles children recursively\n // When tree is undefined, only batch validation is performed (initial routes)\n validateRoute(route, \"addRoute\", tree, \"\", seenNames, seenPathsByParent);\n }\n\n // Validate forwardTo targets and cycles (only when tree is available)\n if (tree && forwardMap) {\n validateForwardToTargets(routes, forwardMap, tree);\n }\n}\n","// packages/real-router/modules/transitionPath.ts\n\nimport type { Params, State } from \"@real-router/types\";\n\n/**\n * Parameters extracted from a route segment.\n * Maps parameter names to their string values.\n */\ntype SegmentParams = Record<string, string>;\n\n/**\n * Represents a transition path between two router states.\n * Contains information about which route segments need to be activated/deactivated.\n */\ninterface TransitionPath {\n /** The common ancestor route segment where paths diverge */\n intersection: string;\n /** Route segments that need to be deactivated (in reverse order) */\n toDeactivate: string[];\n /** Route segments that need to be activated (in order) */\n toActivate: string[];\n}\n\n// Constants for better maintainability\nconst ROUTE_SEGMENT_SEPARATOR = \".\";\nconst EMPTY_INTERSECTION = \"\";\nconst DEFAULT_ROUTE_NAME = \"\";\n\n/**\n * Builds a reversed copy of a string array.\n * Optimization: single pass instead of creating intermediate array with .toReversed().\n *\n * @param arr - Source array\n * @returns New array with elements in reverse order\n * @internal\n */\nfunction reverseArray(arr: string[]): string[] {\n const len = arr.length;\n const result: string[] = [];\n\n for (let i = len - 1; i >= 0; i--) {\n result.push(arr[i]);\n }\n\n return result;\n}\n\n/**\n * Handles conversion of route names with many segments (5+).\n * Internal helper for nameToIDs function.\n *\n * Uses optimized hybrid approach: split to get segments, then slice original\n * string to build cumulative paths. This approach is 65-81% faster than\n * string concatenation for typical cases (5-10 segments).\n *\n * @param name - Route name with 5 or more segments\n * @returns Array of cumulative segment IDs\n * @throws {Error} If route depth exceeds maximum allowed\n * @internal\n */\nfunction nameToIDsGeneral(name: string): string[] {\n // We know there are at least 5 segments at this point (after fast paths)\n const segments = name.split(ROUTE_SEGMENT_SEPARATOR);\n const segmentCount = segments.length;\n\n // First segment is always just itself\n const ids: string[] = [segments[0]];\n\n // Calculate cumulative lengths and slice from original string\n // This avoids repeated string concatenation (O(kÂē) â O(k))\n let cumulativeLen = segments[0].length;\n\n for (let i = 1; i < segmentCount - 1; i++) {\n cumulativeLen += 1 + segments[i].length; // +1 for dot separator\n ids.push(name.slice(0, cumulativeLen));\n }\n\n // Last segment is always the full route name\n ids.push(name);\n\n return ids;\n}\n\n/**\n * Extracts segment-specific parameters from a state object.\n * Only includes parameters that are valid for serialization (primitives).\n *\n * @param name - Segment name to extract parameters for\n * @param state - State containing the parameters\n * @returns Object with extracted segment parameters\n */\nfunction extractSegmentParams(name: string, state: State): SegmentParams {\n const keys = state.meta?.params[name];\n\n // No parameters defined for this segment\n if (!keys || typeof keys !== \"object\") {\n return {};\n }\n\n const result: SegmentParams = {};\n\n for (const key in keys as Params) {\n // Skip inherited properties\n if (!Object.hasOwn(keys, key)) {\n continue;\n }\n\n // Skip undefined values for consistent behavior (treat { key: undefined } same as missing key)\n // Edge case: can appear from manual State creation or object merging\n // @ts-expect-error Params type doesn't allow undefined, but it can appear at runtime\n if (keys[key] === undefined) {\n continue;\n }\n\n const value = state.params[key];\n\n // Skip null/undefined values\n if (value == null) {\n continue;\n }\n\n // Only include primitives in segment params comparison.\n // Complex types (arrays, nested objects) are handled by query param serialization.\n // Note: symbol/function/bigint are rejected by isParams validation before reaching this code.\n if (\n typeof value === \"string\" ||\n typeof value === \"number\" ||\n typeof value === \"boolean\"\n ) {\n result[key] = String(value);\n }\n // Complex types silently skipped - they're serialized as query params elsewhere\n }\n\n return result;\n}\n\n/**\n * Finds the point where two state paths diverge based on segments and parameters.\n * Compares both segment names and their parameters to find the first difference.\n *\n * @param toState - Target state\n * @param fromState - Source state\n * @param toStateIds - Segment IDs for target state\n * @param fromStateIds - Segment IDs for source state\n * @param maxI - Maximum index to check (minimum of both arrays)\n * @returns Index of first difference, or maxI if all checked segments match\n */\nfunction pointOfDifference(\n toState: State,\n fromState: State,\n toStateIds: string[],\n fromStateIds: string[],\n maxI: number,\n): number {\n for (let i = 0; i < maxI; i++) {\n const toSegment = toStateIds[i];\n const fromSegment = fromStateIds[i];\n\n // Different segment names - immediate difference\n if (toSegment !== fromSegment) {\n return i;\n }\n\n // Same segment name - check parameters\n const toParams = extractSegmentParams(toSegment, toState);\n const fromParams = extractSegmentParams(fromSegment, fromState);\n\n // Fast check: different number of parameters\n const toKeys = Object.keys(toParams);\n const fromKeys = Object.keys(fromParams);\n\n if (toKeys.length !== fromKeys.length) {\n return i;\n }\n\n // Detailed check: compare parameter values\n for (const key of toKeys) {\n if (toParams[key] !== fromParams[key]) {\n return i;\n }\n }\n }\n\n return maxI;\n}\n\n/**\n * Converts a route name to an array of hierarchical segment identifiers.\n * Each segment ID includes all parent segments in the path.\n *\n * @param name - Route name in dot notation (e.g., 'users.profile.edit')\n * @returns Array of cumulative segment IDs\n * @throws {Error} If route depth exceeds maximum allowed depth\n *\n * @example\n * // Simple route\n * nameToIDs('users');\n * // Returns: ['users']\n *\n * @example\n * // Nested route\n * nameToIDs('users.profile.edit');\n * // Returns: ['users', 'users.profile', 'users.profile.edit']\n *\n * @example\n * // Empty string (root route)\n * nameToIDs('');\n * // Returns: ['']\n *\n * @remarks\n * Input parameter is NOT validated in this function for performance reasons.\n * Validation significantly slows down nameToIDs execution.\n * The input should be validated by the function/method that calls nameToIDs.\n */\nexport function nameToIDs(name: string): string[] {\n // ===== FAST PATH 1: Empty string (root route) =====\n // Most common in initial navigation\n if (!name) {\n return [DEFAULT_ROUTE_NAME];\n }\n\n // ===== FAST PATH 2: Single segment (no dots) =====\n // Very common: 'home', 'users', 'settings', etc.\n const firstDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR);\n\n if (firstDot === -1) {\n return [name];\n }\n\n // ===== FAST PATH 3: Two segments =====\n // Common: 'users.list', 'admin.dashboard', etc.\n const secondDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR, firstDot + 1);\n\n if (secondDot === -1) {\n return [\n name.slice(0, firstDot), // 'users'\n name, // 'users.list'\n ];\n }\n\n // ===== FAST PATH 4: Three segments =====\n // Common: 'users.profile.edit', 'app.settings.general', etc.\n const thirdDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR, secondDot + 1);\n\n if (thirdDot === -1) {\n return [\n name.slice(0, firstDot), // 'users'\n name.slice(0, secondDot), // 'users.profile'\n name, // 'users.profile.edit'\n ];\n }\n\n // ===== FAST PATH 5: Four segments =====\n const fourthDot = name.indexOf(ROUTE_SEGMENT_SEPARATOR, thirdDot + 1);\n\n if (fourthDot === -1) {\n return [\n name.slice(0, firstDot),\n name.slice(0, secondDot),\n name.slice(0, thirdDot),\n name,\n ];\n }\n\n // ===== STANDARD PATH: 5+ segments =====\n // Less common, use general algorithm with optimizations\n return nameToIDsGeneral(name);\n}\n\n/**\n * Calculates the transition path between two router states.\n * Determines which route segments need to be deactivated and activated\n * to transition from one state to another.\n *\n * @param toState - Target state to transition to\n * @param fromState - Current state to transition from (optional)\n * @returns Transition path with intersection and segments to activate/deactivate\n *\n * @throws {TypeError} When toState is null or undefined\n * @throws {TypeError} When toState is not an object\n * @throws {TypeError} When toState.name is missing or not a string\n * @throws {TypeError} When toState.params is missing or not an object\n * @throws {TypeError} When toState.path is missing or not a string\n * @throws {TypeError} When toState.name contains invalid route format:\n * - Contains only whitespace (e.g., \" \")\n * - Has consecutive dots (e.g., \"users..profile\")\n * - Has leading/trailing dots (e.g., \".users\" or \"users.\")\n * - Segments don't match pattern [a-zA-Z_][a-zA-Z0-9_-]* (e.g., \"users.123\")\n * - Contains spaces or special characters (e.g., \"users profile\")\n * - Exceeds maximum length (8192 characters)\n * @throws {TypeError} When fromState is provided and has any of the validation errors listed above for toState\n *\n * @example\n * // â
Valid calls\n * getTransitionPath({ name: 'users.profile', params: {}, path: '/users/profile' });\n * getTransitionPath(toState, fromState);\n * getTransitionPath({ name: '', params: {}, path: '/' }); // root route\n *\n * @example\n * // â Invalid calls that throw TypeError\n * getTransitionPath(null); // toState is null\n * getTransitionPath(undefined); // toState is undefined\n * getTransitionPath({}); // missing required fields\n * getTransitionPath({ name: 123, params: {}, path: '/' }); // name not a string\n * getTransitionPath({ name: 'home', path: '/' }); // missing params\n * getTransitionPath({ name: 'users..profile', params: {}, path: '/' }); // consecutive dots\n * getTransitionPath({ name: '.users', params: {}, path: '/' }); // leading dot\n * getTransitionPath({ name: 'users.', params: {}, path: '/' }); // trailing dot\n * getTransitionPath({ name: 'users profile', params: {}, path: '/' }); // contains space\n * getTransitionPath({ name: 'users.123', params: {}, path: '/' }); // segment starts with number\n * getTransitionPath(validToState, { name: 'invalid..route', params: {}, path: '/' }); // fromState invalid\n *\n * @example\n * // Full activation (no fromState)\n * getTransitionPath(makeState('users.profile'));\n * // Returns: {\n * // intersection: '',\n * // toActivate: ['users', 'users.profile'],\n * // toDeactivate: []\n * // }\n *\n * @example\n * // Partial transition with common ancestor\n * getTransitionPath(\n * makeState('users.profile'),\n * makeState('users.list')\n * );\n * // Returns: {\n * // intersection: 'users',\n * // toActivate: ['users.profile'],\n * // toDeactivate: ['users.list']\n * // }\n *\n * @example\n * // Complete route change\n * getTransitionPath(\n * makeState('admin.dashboard'),\n * makeState('users.profile')\n * );\n * // Returns: {\n * // intersection: '',\n * // toActivate: ['admin', 'admin.dashboard'],\n * // toDeactivate: ['users.profile', 'users']\n * // }\n */\nexport function getTransitionPath(\n toState: State,\n fromState?: State,\n): TransitionPath {\n // ===== FAST PATH 1: Initial navigation (no fromState) =====\n // This is the best performing case in benchmarks (5M ops/sec)\n if (!fromState) {\n return {\n intersection: EMPTY_INTERSECTION,\n toActivate: nameToIDs(toState.name),\n toDeactivate: [],\n };\n }\n\n const toStateOptions = toState.meta?.options ?? {};\n\n // ===== FAST PATH 2: Force reload =====\n // Skip all optimization when reload is requested\n if (toStateOptions.reload) {\n return {\n intersection: EMPTY_INTERSECTION,\n toActivate: nameToIDs(toState.name),\n toDeactivate: reverseArray(nameToIDs(fromState.name)),\n };\n }\n\n // ===== FAST PATH 3: Missing meta or meta.params requires full reload =====\n // Check if meta or meta.params is actually missing (not just empty)\n const toHasMeta = toState.meta?.params !== undefined;\n const fromHasMeta = fromState.meta?.params !== undefined;\n\n if (!toHasMeta && !fromHasMeta) {\n // Both states missing meta.params - require full reload\n return {\n intersection: EMPTY_INTERSECTION,\n toActivate: nameToIDs(toState.name),\n toDeactivate: reverseArray(nameToIDs(fromState.name)),\n };\n }\n\n // ===== FAST PATH 4: Same routes with empty meta.params =====\n // If both have empty meta.params {}, no parameter checking needed\n if (toState.name === fromState.name && toHasMeta && fromHasMeta) {\n const toParamsEmpty =\n toState.meta && Object.keys(toState.meta.params).length === 0;\n const fromParamsEmpty =\n fromState.meta && Object.keys(fromState.meta.params).length === 0;\n\n if (toParamsEmpty && fromParamsEmpty) {\n // Both have empty params - no transition needed\n return {\n intersection: toState.name,\n toActivate: [],\n toDeactivate: [],\n };\n }\n }\n\n // ===== STANDARD PATH: Routes with parameters =====\n // Use original algorithm for complex cases with parameters\n const toStateIds = nameToIDs(toState.name);\n const fromStateIds = nameToIDs(fromState.name);\n const maxI = Math.min(fromStateIds.length, toStateIds.length);\n\n // Find where paths diverge based on segments and parameters\n // not obvious validate toState and fromState\n const i = pointOfDifference(\n toState,\n fromState,\n toStateIds,\n fromStateIds,\n maxI,\n );\n\n // Optimization: Build deactivation list in reverse order directly\n // instead of slice(i).toReversed() which creates 2 arrays\n const toDeactivate: string[] = [];\n\n for (let j = fromStateIds.length - 1; j >= i; j--) {\n toDeactivate.push(fromStateIds[j]);\n }\n\n // Build activation list (forward order for proper initialization)\n const toActivate = toStateIds.slice(i);\n\n // Determine intersection point (common ancestor)\n // Note: fromState is guaranteed to be defined here (early return on line 366)\n const intersection = i > 0 ? fromStateIds[i - 1] : EMPTY_INTERSECTION;\n\n return {\n intersection,\n toDeactivate,\n toActivate,\n };\n}\n","// packages/core/src/namespaces/RoutesNamespace/RoutesNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\nimport {\n createRouteTree,\n nodeToDefinition,\n buildPath as routeNodeBuildPath,\n routeTreeToDefinitions,\n MatcherService,\n} from \"route-tree\";\nimport { isString, validateRouteName } from \"type-guards\";\n\nimport { DEFAULT_ROUTE_NAME, validatedRouteNames } from \"./constants\";\nimport {\n clearConfigEntries,\n createEmptyConfig,\n createMatchOptions,\n paramsMatch,\n paramsMatchExcluding,\n removeFromDefinitions,\n resolveForwardChain,\n sanitizeRoute,\n} from \"./helpers\";\nimport { createRouteState } from \"./stateBuilder\";\nimport {\n validateRemoveRouteArgs,\n validateSetRootPathArgs,\n validateAddRouteArgs,\n validateIsActiveRouteArgs,\n validateStateBuilderArgs,\n validateUpdateRouteBasicArgs,\n validateUpdateRoutePropertyTypes,\n validateBuildPathArgs,\n validateMatchPathArgs,\n validateShouldUpdateNodeArgs,\n validateRoutes,\n} from \"./validators\";\nimport { constants } from \"../../constants\";\nimport { createBuildOptions } from \"../../helpers\";\nimport { getTransitionPath } from \"../../transitionPath\";\n\nimport type { RouteConfig, RoutesDependencies } from \"./types\";\nimport type {\n ActivationFnFactory,\n BuildStateResultWithSegments,\n Route,\n RouteConfigUpdate,\n} from \"../../types\";\nimport type { RouteLifecycleNamespace } from \"../RouteLifecycleNamespace\";\nimport type {\n DefaultDependencies,\n Options,\n Params,\n State,\n} from \"@real-router/types\";\nimport type {\n BuildOptions,\n MatchOptions,\n RouteDefinition,\n RouteTree,\n RouteTreeState,\n} from \"route-tree\";\n\nconst EMPTY_OPTIONS = Object.freeze({});\n\n/**\n * Independent namespace for managing routes.\n *\n * Static methods handle validation (called by facade).\n * Instance methods handle storage and business logic.\n */\nexport class RoutesNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n // =========================================================================\n // Private instance fields\n // =========================================================================\n\n readonly #definitions: RouteDefinition[] = [];\n readonly #config: RouteConfig = createEmptyConfig();\n readonly #resolvedForwardMap: Record<string, string> = Object.create(\n null,\n ) as Record<string, string>;\n\n // Pending canActivate handlers that need to be registered after router is set\n // Key: route name, Value: canActivate factory\n readonly #pendingCanActivate = new Map<\n string,\n ActivationFnFactory<Dependencies>\n >();\n\n #rootPath = \"\";\n #tree: RouteTree;\n #matcherService: MatcherService;\n #buildOptionsCache: BuildOptions | undefined;\n #matchOptionsCache: MatchOptions | undefined;\n\n // Dependencies injected via setDependencies (for facade method calls)\n #depsStore: RoutesDependencies<Dependencies> | undefined;\n\n // Lifecycle handlers reference (set after construction)\n #lifecycleNamespace: RouteLifecycleNamespace<Dependencies> | undefined;\n\n // When true, skips validation for production performance\n readonly #noValidate: boolean;\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): RoutesDependencies<Dependencies> {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] RoutesNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n // =========================================================================\n // Constructor\n // =========================================================================\n\n constructor(routes: Route<Dependencies>[] = [], noValidate = false) {\n this.#noValidate = noValidate;\n // Sanitize routes to store only essential properties\n for (const route of routes) {\n this.#definitions.push(sanitizeRoute(route));\n }\n\n // Create initial tree\n this.#tree = createRouteTree(\n DEFAULT_ROUTE_NAME,\n this.#rootPath,\n this.#definitions,\n );\n\n // Initialize matcher service and register tree\n this.#matcherService = new MatcherService();\n this.#matcherService.registerTree(this.#tree);\n\n // Register handlers for all routes (defaultParams, encoders, decoders, forwardTo)\n // Note: canActivate handlers are registered later when #lifecycleNamespace is set\n this.#registerAllRouteHandlers(routes);\n\n // Validate and cache forwardTo chains (detect cycles)\n // Skip validation in noValidate mode for production performance\n if (noValidate) {\n // Still need to cache resolved forwards, just skip validation\n this.#cacheForwardMap();\n } else {\n this.#validateAndCacheForwardMap();\n }\n }\n\n // =========================================================================\n // Static validation methods (delegated to validators.ts)\n // TypeScript requires explicit method declarations for assertion functions\n // =========================================================================\n\n static validateRemoveRouteArgs(name: unknown): asserts name is string {\n validateRemoveRouteArgs(name);\n }\n\n static validateSetRootPathArgs(\n rootPath: unknown,\n ): asserts rootPath is string {\n validateSetRootPathArgs(rootPath);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-explicit-any -- accepts any Route type\n static validateAddRouteArgs(routes: readonly Route<any>[]): void {\n validateAddRouteArgs(routes);\n }\n\n static validateIsActiveRouteArgs(\n name: unknown,\n params: unknown,\n strictEquality: unknown,\n ignoreQueryParams: unknown,\n ): void {\n validateIsActiveRouteArgs(name, params, strictEquality, ignoreQueryParams);\n }\n\n static validateStateBuilderArgs(\n routeName: unknown,\n routeParams: unknown,\n methodName: string,\n ): void {\n validateStateBuilderArgs(routeName, routeParams, methodName);\n }\n\n static validateUpdateRouteBasicArgs<Deps extends DefaultDependencies>(\n name: unknown,\n updates: unknown,\n ): asserts updates is RouteConfigUpdate<Deps> {\n validateUpdateRouteBasicArgs<Deps>(name, updates);\n }\n\n static validateUpdateRoutePropertyTypes(\n forwardTo: unknown,\n defaultParams: unknown,\n decodeParams: unknown,\n encodeParams: unknown,\n ): void {\n validateUpdateRoutePropertyTypes(\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n );\n }\n\n static validateBuildPathArgs(route: unknown): asserts route is string {\n validateBuildPathArgs(route);\n }\n\n static validateMatchPathArgs(path: unknown): asserts path is string {\n validateMatchPathArgs(path);\n }\n\n static validateShouldUpdateNodeArgs(\n nodeName: unknown,\n ): asserts nodeName is string {\n validateShouldUpdateNodeArgs(nodeName);\n }\n\n static validateRoutes<Deps extends DefaultDependencies>(\n routes: Route<Deps>[],\n tree?: RouteTree,\n forwardMap?: Record<string, string>,\n ): void {\n validateRoutes(routes, tree, forwardMap);\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n /**\n * Sets dependencies and registers pending canActivate handlers.\n * canActivate handlers from initial routes are deferred until deps are set.\n */\n setDependencies(deps: RoutesDependencies<Dependencies>): void {\n this.#depsStore = deps;\n\n // Register pending canActivate handlers that were deferred during construction\n for (const [routeName, handler] of this.#pendingCanActivate) {\n deps.canActivate(routeName, handler);\n }\n\n // Clear pending handlers after registration\n this.#pendingCanActivate.clear();\n }\n\n /**\n * Sets the lifecycle namespace reference.\n */\n setLifecycleNamespace(\n namespace: RouteLifecycleNamespace<Dependencies> | undefined,\n ): void {\n this.#lifecycleNamespace = namespace;\n }\n\n // =========================================================================\n // Route tree operations\n // =========================================================================\n\n /**\n * Returns the root path.\n */\n getRootPath(): string {\n return this.#rootPath;\n }\n\n /**\n * Returns the route tree.\n * Used by facade for state-dependent validation.\n */\n getTree(): RouteTree {\n return this.#tree;\n }\n\n /**\n * Returns the forward record (route name -> forward target).\n * Used by facade for state-dependent validation.\n */\n getForwardRecord(): Record<string, string> {\n return this.#config.forwardMap;\n }\n\n /**\n * Sets the root path and rebuilds the tree.\n */\n setRootPath(newRootPath: string): void {\n this.#rootPath = newRootPath;\n this.#rebuildTree();\n }\n\n /**\n * Checks if a route exists.\n */\n hasRoute(name: string): boolean {\n return this.#matcherService.hasRoute(name);\n }\n\n /**\n * Gets a route by name with all its configuration.\n */\n getRoute(name: string): Route<Dependencies> | undefined {\n const segments = this.#matcherService.getSegmentsByName(name);\n\n if (!segments) {\n return undefined;\n }\n\n const targetNode = this.#getLastSegment(segments);\n const definition = nodeToDefinition(targetNode);\n\n return this.#enrichRoute(definition, name);\n }\n\n /**\n * Adds one or more routes to the router.\n * Input already validated by facade (properties and state-dependent checks).\n *\n * @param routes - Routes to add\n */\n addRoutes(routes: Route<Dependencies>[]): void {\n // Add to definitions\n for (const route of routes) {\n this.#definitions.push(sanitizeRoute(route));\n }\n\n // Register handlers\n this.#registerAllRouteHandlers(routes);\n\n // Rebuild tree\n this.#rebuildTree();\n\n // Validate and cache forwardTo chains\n this.#refreshForwardMap();\n }\n\n /**\n * Removes a route and all its children.\n *\n * @param name - Route name (already validated)\n * @returns true if removed, false if not found\n */\n removeRoute(name: string): boolean {\n const wasRemoved = removeFromDefinitions(this.#definitions, name);\n\n if (!wasRemoved) {\n return false;\n }\n\n // Clear configurations for removed route\n this.#clearRouteConfigurations(name);\n\n // Rebuild tree\n this.#rebuildTree();\n\n // Revalidate forward chains\n this.#refreshForwardMap();\n\n return true;\n }\n\n /**\n * Updates a route's configuration in place without rebuilding the tree.\n * This is used by Router.updateRoute to directly modify config entries\n * without destroying other routes' forwardMap references.\n *\n * @param name - Route name\n * @param updates - Config updates to apply\n * @param updates.forwardTo - Forward target route name (null to clear)\n * @param updates.defaultParams - Default parameters (null to clear)\n * @param updates.decodeParams - Params decoder function (null to clear)\n * @param updates.encodeParams - Params encoder function (null to clear)\n */\n // eslint-disable-next-line sonarjs/cognitive-complexity -- simple config updates\n updateRouteConfig(\n name: string,\n updates: {\n forwardTo?: string | null | undefined;\n defaultParams?: Params | null | undefined;\n decodeParams?: ((params: Params) => Params) | null | undefined;\n encodeParams?: ((params: Params) => Params) | null | undefined;\n },\n ): void {\n // Update forwardTo\n if (updates.forwardTo !== undefined) {\n if (updates.forwardTo === null) {\n delete this.#config.forwardMap[name];\n } else {\n this.#config.forwardMap[name] = updates.forwardTo;\n }\n\n this.#refreshForwardMap();\n }\n\n // Update defaultParams\n if (updates.defaultParams !== undefined) {\n if (updates.defaultParams === null) {\n delete this.#config.defaultParams[name];\n } else {\n this.#config.defaultParams[name] = updates.defaultParams;\n }\n }\n\n // Update decoders with fallback wrapper\n // Runtime guard: fallback to params if decoder returns undefined (bad user code)\n if (updates.decodeParams !== undefined) {\n if (updates.decodeParams === null) {\n delete this.#config.decoders[name];\n } else {\n const decoder = updates.decodeParams;\n\n this.#config.decoders[name] = (params: Params): Params =>\n (decoder(params) as Params | undefined) ?? params;\n }\n }\n\n // Update encoders with fallback wrapper\n // Runtime guard: fallback to params if encoder returns undefined (bad user code)\n if (updates.encodeParams !== undefined) {\n if (updates.encodeParams === null) {\n delete this.#config.encoders[name];\n } else {\n const encoder = updates.encodeParams;\n\n this.#config.encoders[name] = (params: Params): Params =>\n (encoder(params) as Params | undefined) ?? params;\n }\n }\n }\n\n /**\n * Clears all routes from the router.\n */\n clearRoutes(): void {\n this.#definitions.length = 0;\n\n // Clear all config entries\n for (const key in this.#config.decoders) {\n delete this.#config.decoders[key];\n }\n\n for (const key in this.#config.encoders) {\n delete this.#config.encoders[key];\n }\n\n for (const key in this.#config.defaultParams) {\n delete this.#config.defaultParams[key];\n }\n\n for (const key in this.#config.forwardMap) {\n delete this.#config.forwardMap[key];\n }\n\n // Clear forward cache\n for (const key in this.#resolvedForwardMap) {\n delete this.#resolvedForwardMap[key];\n }\n\n // Rebuild empty tree\n this.#rebuildTree();\n }\n\n // =========================================================================\n // Path operations\n // =========================================================================\n\n /**\n * Builds a URL path for a route.\n * Note: Argument validation is done by facade (Router.ts) via validateBuildPathArgs.\n *\n * @param route - Route name\n * @param params - Route parameters\n * @param options - Router options\n * @param segments - Optional pre-computed segments to avoid duplicate lookup\n */\n buildPath(\n route: string,\n params?: Params,\n options?: Options,\n segments?: readonly unknown[],\n ): string {\n if (route === constants.UNKNOWN_ROUTE) {\n return isString(params?.path) ? params.path : \"\";\n }\n\n // R2 optimization: avoid spread when no defaultParams\n const paramsWithDefault = Object.hasOwn(this.#config.defaultParams, route)\n ? { ...this.#config.defaultParams[route], ...params }\n : (params ?? {});\n\n // Apply custom encoder if defined\n const encodedParams =\n typeof this.#config.encoders[route] === \"function\"\n ? this.#config.encoders[route]({ ...paramsWithDefault })\n : paramsWithDefault;\n\n // Use cached buildOptions if available\n const buildOptions =\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- Router.ts always passes options\n this.#buildOptionsCache ?? createBuildOptions(options!);\n\n return routeNodeBuildPath(\n this.#tree,\n route,\n encodedParams,\n buildOptions,\n // Cast to RouteTree[] - segments come from getSegmentsByName which returns RouteTree[]\n segments as readonly RouteTree[] | undefined,\n );\n }\n\n /**\n * Matches a URL path to a route in the tree.\n * Note: Argument validation is done by facade (Router.ts) via validateMatchPathArgs.\n */\n matchPath<P extends Params = Params, MP extends Params = Params>(\n path: string,\n source?: string,\n options?: Options,\n ): State<P, MP> | undefined {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- Router.ts always passes options\n const opts = options!;\n const matchOptions =\n this.#matchOptionsCache ??\n (this.#matchOptionsCache = createMatchOptions(opts));\n const matchResult = this.#matcherService.match(path, matchOptions);\n\n if (matchResult) {\n const routeState = createRouteState(matchResult);\n const { name, params, meta } = routeState;\n\n const decodedParams =\n typeof this.#config.decoders[name] === \"function\"\n ? this.#config.decoders[name](params as Params)\n : params;\n\n const { name: routeName, params: routeParams } = this.forwardState<P>(\n name,\n decodedParams as P,\n );\n\n let builtPath = path;\n\n if (opts.rewritePathOnMatch) {\n const cachedSegments =\n routeName === name ? matchResult.buildSegments : undefined;\n\n builtPath = this.buildPath(\n routeName,\n routeParams,\n opts,\n cachedSegments,\n );\n }\n\n // Create state using deps.makeState\n return this.#deps.makeState<P, MP>(routeName, routeParams, builtPath, {\n params: meta as MP,\n options: EMPTY_OPTIONS,\n source,\n redirected: false,\n });\n }\n\n return undefined;\n }\n\n /**\n * Applies forwardTo and returns resolved state with merged defaultParams.\n *\n * Merges params in order:\n * 1. Source route defaultParams\n * 2. Provided params\n * 3. Target route defaultParams (after resolving forwardTo)\n */\n forwardState<P extends Params = Params>(\n name: string,\n params: P,\n ): { name: string; params: P } {\n const resolvedName = this.#resolvedForwardMap[name] ?? name;\n\n // Merge source route's defaultParams with provided params\n const paramsWithSource = Object.hasOwn(this.#config.defaultParams, name)\n ? { ...this.#config.defaultParams[name], ...params }\n : params;\n\n // If forwarded to different route, merge target's defaultParams\n if (\n resolvedName !== name &&\n Object.hasOwn(this.#config.defaultParams, resolvedName)\n ) {\n return {\n name: resolvedName,\n params: {\n ...this.#config.defaultParams[resolvedName],\n ...paramsWithSource,\n } as P,\n };\n }\n\n return { name: resolvedName, params: paramsWithSource };\n }\n\n /**\n * Builds a RouteTreeState from already-resolved route name and params.\n * Called by Router.buildState after forwardState is applied at facade level.\n * This allows plugins to intercept forwardState.\n */\n buildStateResolved(\n resolvedName: string,\n resolvedParams: Params,\n ): RouteTreeState | undefined {\n const segments = this.#matcherService.getSegmentsByName(resolvedName);\n\n if (!segments) {\n return undefined;\n }\n\n /* v8 ignore next -- @preserve: meta always exists when segments exist */\n const meta = this.#matcherService.getMetaByName(resolvedName) ?? {};\n\n return createRouteState(\n { segments, buildSegments: segments, params: resolvedParams, meta },\n resolvedName,\n );\n }\n\n /**\n * Builds a RouteTreeState with segments from already-resolved route name and params.\n * Called by Router.buildStateWithSegments after forwardState is applied at facade level.\n * This allows plugins to intercept forwardState.\n */\n buildStateWithSegmentsResolved<P extends Params = Params>(\n resolvedName: string,\n resolvedParams: P,\n ): BuildStateResultWithSegments<P> | undefined {\n const segments = this.#matcherService.getSegmentsByName(resolvedName);\n\n if (!segments) {\n return undefined;\n }\n\n /* v8 ignore next -- @preserve: meta always exists when segments exist */\n const meta = this.#matcherService.getMetaByName(resolvedName) ?? {};\n const state = createRouteState<P>(\n { segments, buildSegments: segments, params: resolvedParams, meta },\n resolvedName,\n );\n\n return { state, segments };\n }\n\n /**\n * Initializes buildOptions cache.\n * Called from routerLifecycle at router.start().\n */\n initBuildOptionsCache(options: Options): void {\n this.#buildOptionsCache = createBuildOptions(options);\n this.#matchOptionsCache = createMatchOptions(options);\n }\n\n /**\n * Clears buildOptions cache.\n * Called from routerLifecycle at router.stop().\n */\n clearBuildOptionsCache(): void {\n this.#buildOptionsCache = undefined;\n this.#matchOptionsCache = undefined;\n }\n\n // =========================================================================\n // Query operations\n // =========================================================================\n\n /**\n * Checks if a route is currently active.\n */\n isActiveRoute(\n name: string,\n params: Params = {},\n strictEquality = false,\n ignoreQueryParams = true,\n ): boolean {\n // Fast path: skip regex validation for already-validated route names\n if (!validatedRouteNames.has(name)) {\n validateRouteName(name, \"isActiveRoute\");\n validatedRouteNames.add(name);\n }\n\n // Note: empty string check is handled by Router.ts facade\n const activeState = this.#deps.getState();\n\n if (!activeState) {\n return false;\n }\n\n const activeName = activeState.name;\n\n // Fast path: check if routes are related before expensive operations\n if (\n activeName !== name &&\n !activeName.startsWith(`${name}.`) &&\n !name.startsWith(`${activeName}.`)\n ) {\n return false;\n }\n\n const defaultParams = this.#config.defaultParams[name] as\n | Params\n | undefined;\n\n // Exact match case\n if (strictEquality || activeName === name) {\n const effectiveParams = defaultParams\n ? { ...defaultParams, ...params }\n : params;\n\n const targetState: State = {\n name,\n params: effectiveParams,\n path: \"\",\n };\n\n return this.#deps.areStatesEqual(\n targetState,\n activeState,\n ignoreQueryParams,\n );\n }\n\n // Hierarchical check: activeState is a descendant of target (name)\n const activeParams = activeState.params;\n\n if (!paramsMatch(params, activeParams)) {\n return false;\n }\n\n // Check defaultParams (skip keys already in params)\n return (\n !defaultParams ||\n paramsMatchExcluding(defaultParams, activeParams, params)\n );\n }\n\n /**\n * Creates a predicate function to check if a route node should be updated.\n * Note: Argument validation is done by facade (Router.ts) via validateShouldUpdateNodeArgs.\n */\n shouldUpdateNode(\n nodeName: string,\n ): (toState: State, fromState?: State) => boolean {\n return (toState: State, fromState?: State): boolean => {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!(toState && typeof toState === \"object\" && \"name\" in toState)) {\n throw new TypeError(\n \"[router.shouldUpdateNode] toState must be valid State object\",\n );\n }\n\n if (toState.meta?.options.reload) {\n return true;\n }\n\n if (nodeName === DEFAULT_ROUTE_NAME && !fromState) {\n return true;\n }\n\n const { intersection, toActivate, toDeactivate } = getTransitionPath(\n toState,\n fromState,\n );\n\n if (nodeName === intersection) {\n return true;\n }\n\n if (toActivate.includes(nodeName)) {\n return true;\n }\n\n return toDeactivate.includes(nodeName);\n };\n }\n\n /**\n * Returns the config object.\n */\n getConfig(): RouteConfig {\n return this.#config;\n }\n\n /**\n * Returns URL params for a route.\n * Used by StateNamespace.\n */\n getUrlParams(name: string): string[] {\n const segments = this.#matcherService.getSegmentsByName(name);\n\n if (!segments) {\n return [];\n }\n\n return this.#collectUrlParamsArray(segments);\n }\n\n /**\n * Returns the resolved forward map.\n */\n getResolvedForwardMap(): Record<string, string> {\n return this.#resolvedForwardMap;\n }\n\n /**\n * Sets resolved forward map (used by clone).\n */\n setResolvedForwardMap(map: Record<string, string>): void {\n Object.assign(this.#resolvedForwardMap, map);\n }\n\n /**\n * Creates a clone of the routes for a new router (from tree).\n */\n cloneRoutes(): Route<Dependencies>[] {\n return routeTreeToDefinitions(this.#tree) as Route<Dependencies>[];\n }\n\n // =========================================================================\n // Public validation methods (used by Router facade)\n // =========================================================================\n\n /**\n * Validates that forwardTo target doesn't require params that source doesn't have.\n * Used by updateRoute for forwardTo validation.\n */\n validateForwardToParamCompatibility(\n sourceName: string,\n targetName: string,\n ): void {\n const context = \"validateForwardToParamCompatibility\";\n const sourceSegments = this.#getSegmentsOrThrow(sourceName, context);\n const targetSegments = this.#getSegmentsOrThrow(targetName, context);\n\n // Get source and target URL params using helper\n const sourceParams = this.#collectUrlParams(sourceSegments);\n const targetParams = this.#collectUrlParamsArray(targetSegments);\n\n // Check if target requires params that source doesn't have\n const missingParams = targetParams.filter(\n (param) => !sourceParams.has(param),\n );\n\n if (missingParams.length > 0) {\n throw new Error(\n `[real-router] forwardTo target \"${targetName}\" requires params ` +\n `[${missingParams.join(\", \")}] that are not available in source route \"${sourceName}\"`,\n );\n }\n }\n\n /**\n * Validates that adding forwardTo doesn't create a cycle.\n * Creates a test map with the new entry and uses resolveForwardChain\n * to detect cycles before any mutation happens.\n * Used by updateRoute for forwardTo validation.\n */\n validateForwardToCycle(sourceName: string, targetName: string): void {\n // Create a test map with the new entry to validate BEFORE mutation\n const testMap = {\n ...this.#config.forwardMap,\n [sourceName]: targetName,\n };\n\n // resolveForwardChain will throw if cycle is detected or max depth exceeded\n resolveForwardChain(sourceName, testMap);\n }\n\n /**\n * Validates removeRoute constraints.\n * Returns false if removal should be blocked (route is active).\n * Logs warnings for edge cases.\n *\n * @param name - Route name to remove\n * @param currentStateName - Current active route name (or undefined)\n * @param isNavigating - Whether navigation is in progress\n * @returns true if removal can proceed, false if blocked\n */\n validateRemoveRoute(\n name: string,\n currentStateName: string | undefined,\n isNavigating: boolean,\n ): boolean {\n // Check if trying to remove currently active route (or its parent)\n if (currentStateName) {\n const isExactMatch = currentStateName === name;\n const isParentOfCurrent = currentStateName.startsWith(`${name}.`);\n\n if (isExactMatch || isParentOfCurrent) {\n const suffix = isExactMatch ? \"\" : ` (current: \"${currentStateName}\")`;\n\n logger.warn(\n \"router.removeRoute\",\n `Cannot remove route \"${name}\" â it is currently active${suffix}. Navigate away first.`,\n );\n\n return false;\n }\n }\n\n // Warn if navigation is in progress (but allow removal)\n if (isNavigating) {\n logger.warn(\n \"router.removeRoute\",\n `Route \"${name}\" removed while navigation is in progress. This may cause unexpected behavior.`,\n );\n }\n\n return true;\n }\n\n /**\n * Validates clearRoutes operation.\n * Returns false if operation should be blocked (navigation in progress).\n *\n * @param isNavigating - Whether navigation is in progress\n * @returns true if clearRoutes can proceed, false if blocked\n */\n validateClearRoutes(isNavigating: boolean): boolean {\n if (isNavigating) {\n logger.error(\n \"router.clearRoutes\",\n \"Cannot clear routes while navigation is in progress. Wait for navigation to complete.\",\n );\n\n return false;\n }\n\n return true;\n }\n\n /**\n * Validates updateRoute instance-level constraints (route existence, forwardTo).\n * Called after static validation passes.\n *\n * @param name - Route name (already validated by static method)\n * @param forwardTo - Cached forwardTo value (to avoid calling getter twice)\n */\n validateUpdateRoute(\n name: string,\n forwardTo: string | null | undefined,\n ): void {\n // Validate route exists\n if (!this.hasRoute(name)) {\n throw new ReferenceError(\n `[real-router] updateRoute: route \"${name}\" does not exist`,\n );\n }\n\n // Validate forwardTo target exists and is valid\n if (forwardTo !== undefined && forwardTo !== null) {\n if (!this.hasRoute(forwardTo)) {\n throw new Error(\n `[real-router] updateRoute: forwardTo target \"${forwardTo}\" does not exist`,\n );\n }\n\n // Check forwardTo param compatibility\n this.validateForwardToParamCompatibility(name, forwardTo);\n\n // Check for cycle detection\n this.validateForwardToCycle(name, forwardTo);\n }\n }\n\n // =========================================================================\n // Private methods\n // =========================================================================\n\n #rebuildTree(): void {\n this.#tree = createRouteTree(\n DEFAULT_ROUTE_NAME,\n this.#rootPath,\n this.#definitions,\n );\n\n // Re-register tree in matcher service\n this.#matcherService = new MatcherService();\n this.#matcherService.registerTree(this.#tree);\n }\n\n /**\n * Gets segments by name or throws if not found.\n * Use when route existence has been validated by hasRoute() beforehand.\n */\n #getSegmentsOrThrow(name: string, context: string): readonly RouteTree[] {\n const segments = this.#matcherService.getSegmentsByName(name);\n\n /* v8 ignore next 4 -- @preserve: defensive check, hasRoute() validates before call */\n if (!segments) {\n throw new ReferenceError(\n `[real-router] ${context}: route \"${name}\" does not exist`,\n );\n }\n\n return segments;\n }\n\n /**\n * Gets last segment from segments array.\n * Use when segments array is guaranteed to be non-empty.\n */\n #getLastSegment(segments: readonly RouteTree[]): RouteTree {\n const last = segments.at(-1);\n\n /* v8 ignore next 3 -- @preserve: defensive check, segments always non-empty when called */\n if (!last) {\n throw new Error(\"[real-router] Internal error: empty segments array\");\n }\n\n return last;\n }\n\n /**\n * Collects URL params from segments into a Set.\n */\n #collectUrlParams(segments: readonly RouteTree[]): Set<string> {\n const params = new Set<string>();\n\n for (const segment of segments) {\n // Named routes always have parsers (null only for root without path)\n for (const param of segment.paramMeta.urlParams) {\n params.add(param);\n }\n }\n\n return params;\n }\n\n /**\n * Collects URL params from segments into an array.\n *\n * @param segments - Non-null segments (caller must validate existence first)\n */\n #collectUrlParamsArray(segments: readonly RouteTree[]): string[] {\n const params: string[] = [];\n\n for (const segment of segments) {\n // Named routes always have parsers (null only for root without path)\n for (const param of segment.paramMeta.urlParams) {\n params.push(param);\n }\n }\n\n return params;\n }\n\n /**\n * Refreshes forward map cache, conditionally validating based on noValidate flag.\n */\n #refreshForwardMap(): void {\n if (this.#noValidate) {\n this.#cacheForwardMap();\n } else {\n this.#validateAndCacheForwardMap();\n }\n }\n\n #validateAndCacheForwardMap(): void {\n // Clear existing cache\n for (const key in this.#resolvedForwardMap) {\n delete this.#resolvedForwardMap[key];\n }\n\n // Resolve all chains\n for (const fromRoute of Object.keys(this.#config.forwardMap)) {\n this.#resolvedForwardMap[fromRoute] = resolveForwardChain(\n fromRoute,\n this.#config.forwardMap,\n );\n }\n }\n\n /**\n * Caches forward chains without validation (noValidate mode).\n * Simply resolves chains without cycle detection or max depth checks.\n */\n #cacheForwardMap(): void {\n // Clear existing cache\n for (const key in this.#resolvedForwardMap) {\n delete this.#resolvedForwardMap[key];\n }\n\n // Resolve chains without validation\n for (const fromRoute of Object.keys(this.#config.forwardMap)) {\n let current = fromRoute;\n\n while (this.#config.forwardMap[current]) {\n current = this.#config.forwardMap[current];\n }\n\n this.#resolvedForwardMap[fromRoute] = current;\n }\n }\n\n #clearRouteConfigurations(routeName: string): void {\n const shouldClear = (n: string): boolean =>\n n === routeName || n.startsWith(`${routeName}.`);\n\n clearConfigEntries(this.#config.decoders, shouldClear);\n clearConfigEntries(this.#config.encoders, shouldClear);\n clearConfigEntries(this.#config.defaultParams, shouldClear);\n clearConfigEntries(this.#config.forwardMap, shouldClear);\n\n // Clear forwardMap entries pointing TO deleted route\n clearConfigEntries(this.#config.forwardMap, (key) =>\n shouldClear(this.#config.forwardMap[key]),\n );\n\n // Clear lifecycle handlers if namespace is set\n /* v8 ignore next -- @preserve unreachable: Router always sets lifecycleNamespace */\n if (this.#lifecycleNamespace) {\n const [canDeactivateFactories, canActivateFactories] =\n this.#lifecycleNamespace.getFactories();\n\n for (const n of Object.keys(canActivateFactories)) {\n if (shouldClear(n)) {\n this.#lifecycleNamespace.clearCanActivate(n, true);\n }\n }\n\n for (const n of Object.keys(canDeactivateFactories)) {\n if (shouldClear(n)) {\n this.#lifecycleNamespace.clearCanDeactivate(n, true);\n }\n }\n }\n }\n\n #registerAllRouteHandlers(\n routes: readonly Route<Dependencies>[],\n parentName = \"\",\n ): void {\n for (const route of routes) {\n const fullName = parentName ? `${parentName}.${route.name}` : route.name;\n\n this.#registerSingleRouteHandlers(route, fullName);\n\n if (route.children) {\n this.#registerAllRouteHandlers(route.children, fullName);\n }\n }\n }\n\n #registerSingleRouteHandlers(\n route: Route<Dependencies>,\n fullName: string,\n ): void {\n // Register canActivate via deps.canActivate (allows tests to spy on router.canActivate)\n if (route.canActivate) {\n // Note: Uses #depsStore directly because this method is called from constructor\n // before setDependencies(). The getter #deps would throw if deps not set.\n if (this.#depsStore) {\n // Deps available, register immediately\n this.#depsStore.canActivate(fullName, route.canActivate);\n } else {\n // Deps not set yet, store for later registration\n this.#pendingCanActivate.set(fullName, route.canActivate);\n }\n }\n\n // Register forwardTo\n if (route.forwardTo) {\n this.#registerForwardTo(route, fullName);\n }\n\n // Register transformers with fallback wrapper\n if (route.decodeParams) {\n this.#config.decoders[fullName] = (params: Params): Params =>\n route.decodeParams?.(params) ?? params;\n }\n\n if (route.encodeParams) {\n this.#config.encoders[fullName] = (params: Params): Params =>\n route.encodeParams?.(params) ?? params;\n }\n\n // Register defaults\n if (route.defaultParams) {\n this.#config.defaultParams[fullName] = route.defaultParams;\n }\n }\n\n #registerForwardTo(route: Route<Dependencies>, fullName: string): void {\n if (route.canActivate) {\n logger.warn(\n \"real-router\",\n `Route \"${fullName}\" has both forwardTo and canActivate. ` +\n `canActivate will be ignored because forwardTo creates a redirect (industry standard). ` +\n `Move canActivate to the target route \"${route.forwardTo}\".`,\n );\n }\n\n // forwardTo is guaranteed to exist at this point\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n this.#config.forwardMap[fullName] = route.forwardTo!;\n }\n\n #enrichRoute(\n routeDef: RouteDefinition,\n routeName: string,\n ): Route<Dependencies> {\n const route: Route<Dependencies> = {\n name: routeDef.name,\n path: routeDef.path,\n };\n\n const forwardTo = this.#config.forwardMap[routeName];\n\n if (forwardTo) {\n route.forwardTo = forwardTo;\n }\n\n if (routeName in this.#config.defaultParams) {\n route.defaultParams = this.#config.defaultParams[routeName];\n }\n\n if (routeName in this.#config.decoders) {\n route.decodeParams = this.#config.decoders[routeName];\n }\n\n if (routeName in this.#config.encoders) {\n route.encodeParams = this.#config.encoders[routeName];\n }\n\n /* v8 ignore next -- @preserve unreachable: Router always sets lifecycleNamespace */\n if (this.#lifecycleNamespace) {\n const [, canActivateFactories] = this.#lifecycleNamespace.getFactories();\n\n if (routeName in canActivateFactories) {\n route.canActivate = canActivateFactories[routeName];\n }\n }\n\n if (routeDef.children) {\n route.children = routeDef.children.map((child) =>\n this.#enrichRoute(child, `${routeName}.${child.name}`),\n );\n }\n\n return route;\n }\n}\n","import { logger } from \"@real-router/logger\";\n\nimport type { RouterError } from \"../../RouterError\";\nimport type { DoneFn, State } from \"@real-router/types\";\n\nexport const noop = (): void => {};\n\n/**\n * Safely invokes a callback, catching and logging any errors.\n * Prevents user callback errors from crashing the router.\n */\nexport function safeCallback(\n callback: DoneFn,\n ...args: [error?: RouterError, state?: State]\n): void {\n try {\n callback(...args);\n } catch (error) {\n logger.error(\"router.navigate\", \"Error in navigation callback:\", error);\n }\n}\n","// packages/logger/modules/constants.ts\n\nimport type { LogLevel, LogLevelConfig } from \"./types\";\n\n/**\n * Numeric mapping for log message severity levels.\n *\n * Maps each severity level to a numeric value for threshold comparison.\n * Lower values = lower severity, higher values = higher severity.\n *\n * Used internally to determine if a message should be filtered based on\n * the configured threshold level.\n *\n * Mapping:\n * - `log`: 0 (lowest severity - informational)\n * - `warn`: 1 (medium severity - warnings)\n * - `error`: 2 (highest severity - critical errors)\n *\n * @example\n * ```ts\n * const messageLevel = LOG_LEVELS['warn']; // 1\n * const threshold = 2; // error-only\n * const shouldFilter = messageLevel < threshold; // true (warn is filtered)\n * ```\n *\n * @internal This is used for internal filtering logic\n */\nexport const LOG_LEVELS: Record<LogLevel, number> = {\n log: 0,\n warn: 1,\n error: 2,\n};\n\n/**\n * Numeric thresholds for logger configuration levels.\n *\n * Maps each configuration level to a minimum threshold value.\n * Messages with a severity level below this threshold are filtered out.\n *\n * Threshold logic:\n * - A message is shown if: `LOG_LEVELS[messageLevel] >= LEVEL_CONFIGS[configLevel]`\n * - Higher threshold value = stricter filtering = fewer messages shown\n *\n * Mapping:\n * - `all`: 0 (no filtering - show everything)\n * - Shows: log (0), warn (1), error (2) â\n * - `warn-error`: 1 (filter log messages)\n * - Shows: warn (1), error (2) â\n * - Filters: log (0) â\n * - `error-only`: 2 (filter log and warn messages)\n * - Shows: error (2) â\n * - Filters: log (0), warn (1) â\n * - `none`: 3 (filter all messages - complete silence)\n * - Filters: log (0), warn (1), error (2) â\n *\n * @example\n * ```ts\n * // Configuration: warn-error\n * const threshold = LEVEL_CONFIGS['warn-error']; // 1\n *\n * // Check if 'log' message should be shown\n * LOG_LEVELS['log'] >= threshold // 0 >= 1 = false (filtered)\n *\n * // Check if 'warn' message should be shown\n * LOG_LEVELS['warn'] >= threshold // 1 >= 1 = true (shown)\n *\n * // Check if 'error' message should be shown\n * LOG_LEVELS['error'] >= threshold // 2 >= 1 = true (shown)\n * ```\n *\n * @internal This is used for internal threshold comparison\n */\nexport const LEVEL_CONFIGS: Record<LogLevelConfig, number> = {\n all: 0,\n \"warn-error\": 1,\n \"error-only\": 2,\n none: 3,\n};\n","// packages/logger/modules/Logger.ts\n\nimport { LOG_LEVELS, LEVEL_CONFIGS } from \"./constants\";\n\nimport type {\n LogLevel,\n LoggerConfig,\n LogLevelConfig,\n LogCallback,\n} from \"./types\";\n\n/**\n * Internal config type with required callbackIgnoresLevel\n * (always initialized to false)\n */\ninterface InternalLoggerConfig {\n level: LogLevelConfig;\n callback?: LogCallback | undefined;\n callbackIgnoresLevel: boolean;\n}\n\n/**\n * Logger class for centralized logging with configurable levels and callbacks.\n *\n * Features:\n * - Three log levels: log, warn, error\n * - Configurable threshold filtering (all, warn, error, none)\n * - Optional callback for custom log processing\n * - Callback can optionally ignore level threshold\n * - Context-based message formatting\n *\n * @example\n * ```ts\n * import { logger } from './Logger';\n *\n * // Configure logger\n * logger.configure({ level: 'warn' });\n *\n * // Use logger\n * logger.log('Router', 'Navigation started'); // Won't show (below threshold)\n * logger.warn('Router', 'Deprecated API used'); // Will show\n * ```\n */\nclass Logger {\n /** Internal configuration storage using private field */\n #config: InternalLoggerConfig = {\n level: \"all\",\n callbackIgnoresLevel: false,\n };\n\n /** Cached numeric threshold value for performance (avoids repeated lookups) */\n #currentThreshold = 0;\n\n /**\n * Configures the logger with new settings.\n *\n * @param config - Partial configuration to merge with existing config\n * @param config.level - Minimum log level to output ('all' | 'warn' | 'error' | 'none')\n * @param config.callback - Optional callback function to receive log messages\n * @param config.callbackIgnoresLevel - If true, callback receives all messages regardless of level\n *\n * @example\n * ```ts\n * // Set minimum level to warnings\n * logger.configure({ level: 'warn' });\n *\n * // Add custom callback that ignores level\n * logger.configure({\n * callback: (level, context, message) => {\n * sendToAnalytics({ level, context, message });\n * },\n * callbackIgnoresLevel: true\n * });\n * ```\n */\n configure(config: Partial<LoggerConfig>): void {\n if (config.level !== undefined) {\n // Validate that the provided level is a valid configuration level\n if (!(config.level in LEVEL_CONFIGS)) {\n throw new Error(\n `Invalid log level: \"${config.level}\". Valid levels are: ${Object.keys(LEVEL_CONFIGS).join(\", \")}`,\n );\n }\n\n this.#config.level = config.level;\n this.#currentThreshold = LEVEL_CONFIGS[config.level];\n }\n if (\"callback\" in config) {\n this.#config.callback = config.callback;\n }\n if (config.callbackIgnoresLevel !== undefined) {\n this.#config.callbackIgnoresLevel = config.callbackIgnoresLevel;\n }\n }\n\n /**\n * Returns the current logger configuration.\n *\n * @returns Current configuration object with level, callback, and callbackIgnoresLevel\n *\n * @example\n * ```ts\n * const config = logger.getConfig();\n * console.log(config.level); // 'warn'\n * console.log(config.callbackIgnoresLevel); // false\n * ```\n */\n getConfig(): LoggerConfig {\n return {\n level: this.#config.level,\n callback: this.#config.callback,\n callbackIgnoresLevel: this.#config.callbackIgnoresLevel,\n };\n }\n\n /**\n * Logs an informational message at 'log' level.\n *\n * This is the lowest severity level. Messages are shown when level is 'all'.\n *\n * @param context - Context identifier (e.g., 'Router', 'Plugin')\n * @param message - Main log message\n * @param args - Additional arguments to log (objects, arrays, etc.)\n *\n * @example\n * ```ts\n * logger.log('Router', 'Navigation started', { from: '/home', to: '/about' });\n * // Output: [Router] Navigation started { from: '/home', to: '/about' }\n * ```\n */\n log(context: string, message: string, ...args: unknown[]): void {\n this.#writeLog(\"log\", context, message, args);\n }\n\n /**\n * Logs a warning message at 'warn' level.\n *\n * Use for deprecation notices, non-critical issues, or potential problems.\n * Messages are shown when level is 'all' or 'warn'.\n *\n * @param context - Context identifier (e.g., 'Router', 'Plugin')\n * @param message - Warning message\n * @param args - Additional arguments to log\n *\n * @example\n * ```ts\n * logger.warn('Router', 'Using deprecated API', { method: 'oldNavigate' });\n * // Output: [Router] Using deprecated API { method: 'oldNavigate' }\n * ```\n */\n warn(context: string, message: string, ...args: unknown[]): void {\n this.#writeLog(\"warn\", context, message, args);\n }\n\n /**\n * Logs an error message at 'error' level.\n *\n * Use for critical errors, exceptions, or failures that require attention.\n * Messages are shown when level is 'all', 'warn', or 'error'.\n *\n * @param context - Context identifier (e.g., 'Router', 'Plugin')\n * @param message - Error message\n * @param args - Additional arguments to log (often error objects)\n *\n * @example\n * ```ts\n * logger.error('Router', 'Navigation failed', new Error('Route not found'));\n * // Output: [Router] Navigation failed Error: Route not found\n * ```\n */\n error(context: string, message: string, ...args: unknown[]): void {\n this.#writeLog(\"error\", context, message, args);\n }\n\n /**\n * Central logging method that coordinates console output and callback invocation.\n *\n * This method implements the core logging logic:\n * 1. Early exit optimization for 'none' level (unless callback ignores level)\n * 2. Level threshold comparison for console output filtering\n * 3. Delegates to #writeToConsole and #invokeCallback\n *\n * @param level - Log level ('log' | 'warn' | 'error')\n * @param context - Context identifier\n * @param message - Log message\n * @param args - Additional arguments\n *\n * @private\n */\n #writeLog(\n level: LogLevel,\n context: string,\n message: string,\n args: unknown[],\n ): void {\n // Early exit optimization: if level is 'none' and callback doesn't ignore level,\n // skip all processing (both console and callback)\n if (this.#config.level === \"none\" && !this.#config.callbackIgnoresLevel) {\n return;\n }\n\n // Convert message level to numeric value for threshold comparison\n // LOG_LEVELS: { log: 0, warn: 1, error: 2 }\n const messageLevelValue = LOG_LEVELS[level];\n\n // Determine if this message should skip console output\n // Example: if threshold is 'warn' (1), then 'log' messages (0) are skipped\n const shouldSkipConsole = messageLevelValue < this.#currentThreshold;\n\n // Console output (respects level threshold)\n if (!shouldSkipConsole) {\n this.#writeToConsole(level, context, message, args);\n }\n\n // Callback handling (may ignore level threshold based on config)\n this.#invokeCallback(level, context, message, shouldSkipConsole, args);\n }\n\n /**\n * Writes a formatted log message to the console.\n *\n * Features:\n * - Formats message with context: \"[Context] message\"\n * - Uses appropriate console method (log/warn/error)\n * - Safe: checks for console existence (for non-browser environments)\n *\n * @param level - Console method to use ('log' | 'warn' | 'error')\n * @param context - Context identifier (prepended to message if present)\n * @param message - Log message\n * @param args - Additional arguments to pass to console\n *\n * @private\n */\n #writeToConsole(\n level: LogLevel,\n context: string,\n message: string,\n args: unknown[],\n ): void {\n // Safety check: ensure console exists and has the required method\n // This is important for environments like Node.js tests or edge cases\n if (\n typeof console !== \"undefined\" &&\n typeof console[level] === \"function\"\n ) {\n // Format message with context bracket notation for visual clarity\n // Note: formatting is done inside the check to avoid unnecessary string allocation\n // when console is not available\n const formattedMessage = context ? `[${context}] ${message}` : message;\n\n console[level](formattedMessage, ...args);\n }\n }\n\n /**\n * Invokes the configured callback with log data, respecting level settings.\n *\n * Complex logic handling:\n * 1. Skip if no callback configured\n * 2. Skip if callback respects level AND message is below threshold\n * 3. Call callback with error handling (prevents callback errors from breaking logger)\n *\n * The callbackIgnoresLevel flag enables two modes:\n * - false (default): callback only receives messages that pass threshold (same as console)\n * - true: callback receives ALL messages regardless of threshold (useful for analytics)\n *\n * @param level - Log level\n * @param context - Context identifier\n * @param message - Log message\n * @param shouldSkipConsole - Whether console output was skipped (used for level logic)\n * @param args - Additional arguments\n *\n * @private\n */\n #invokeCallback(\n level: LogLevel,\n context: string,\n message: string,\n shouldSkipConsole: boolean,\n args: unknown[],\n ): void {\n // Early exit: no callback configured, or callback respects level and message is filtered\n if (\n !this.#config.callback ||\n (!this.#config.callbackIgnoresLevel && shouldSkipConsole)\n ) {\n return;\n }\n\n // Wrap callback invocation in try-catch to prevent user code errors\n // from breaking the logger or causing cascading failures\n try {\n this.#config.callback(level, context, message, ...args);\n } catch (error) {\n // Fallback error reporting if callback throws\n // Use console.error directly (don't call logger to avoid infinite loops)\n if (\n typeof console !== \"undefined\" &&\n typeof console.error === \"function\"\n ) {\n console.error(\"[Logger] Error in callback:\", error);\n }\n }\n }\n}\n\n/**\n * Singleton logger instance for application-wide logging.\n *\n * This is the main export that should be used throughout the application.\n * Using a singleton ensures consistent configuration across all modules.\n *\n * @example\n * ```ts\n * import { logger } from '@core/logger';\n *\n * // Configure once at application startup\n * logger.configure({ level: 'warn' });\n *\n * // Use anywhere in your app\n * logger.log('MyModule', 'Operation completed');\n * logger.warn('MyModule', 'Deprecated feature used');\n * logger.error('MyModule', 'Operation failed', error);\n * ```\n */\nexport const logger = new Logger();\n","// packages/real-router/modules/transition/makeError.ts\n\nimport type { RouterError } from \"../../../RouterError\";\n\n// Helper: Creating an error with code\nexport const makeError = (\n code: string,\n err?: RouterError,\n): RouterError | undefined => {\n if (!err) {\n return undefined;\n }\n\n err.setCode(code);\n\n return err;\n};\n","// packages/real-router/modules/transition/mergeStates.ts\n\nimport type { Params, State, StateMeta } from \"@real-router/types\";\n\n/**\n * Merges two states with toState taking priority over fromState.\n *\n * Priority order for state fields: toState > fromState\n * Priority order for meta fields: toState.meta > fromState.meta > defaults\n *\n * Special case: meta.params are merged (not replaced):\n * { ...toState.meta.params, ...fromState.meta.params }\n *\n * @param toState - Target state (higher priority)\n * @param fromState - Source state (lower priority)\n * @returns New merged state object\n */\nexport const mergeStates = (toState: State, fromState: State): State => {\n const toMeta = toState.meta;\n const fromMeta = fromState.meta;\n\n // Optimization #1: Conditional merge for params\n // Use spread only when both are defined\n const toParams = toMeta?.params;\n const fromParams = fromMeta?.params;\n\n // Both have params - need to merge; otherwise use whichever is defined\n const metaParams: Params =\n toParams && fromParams\n ? { ...toParams, ...fromParams }\n : (toParams ?? fromParams ?? {});\n\n // Optimization #2: Build meta with defaults, then apply fromMeta, then toMeta\n // Note: StateMeta can have custom fields added by guards/middleware, so we preserve them\n const resultMeta: StateMeta = {\n // Defaults first\n id: 1,\n options: {},\n redirected: false,\n // fromMeta fields (lower priority, may include custom fields)\n ...fromMeta,\n // toMeta fields (higher priority, may include custom fields)\n ...toMeta,\n // Explicitly set params to our merged version (override spread)\n params: metaParams,\n };\n\n // Optimization #4: Copy all toState fields (including custom ones)\n // then explicitly set meta to our merged version\n // Note: State can have custom fields added by middleware, so we must preserve them\n return {\n ...toState,\n meta: resultMeta,\n };\n};\n","// packages/real-router/modules/RouterError.ts\n\nimport { errorCodes } from \"./constants\";\nimport { deepFreezeState } from \"./helpers\";\n\nimport type { State } from \"@real-router/types\";\n\n// Pre-compute Set of error code values for O(1) lookup in setCode()\n// This avoids creating array and doing linear search on every setCode() call\nconst errorCodeValues = new Set(Object.values(errorCodes));\n\n// Reserved built-in properties - throw error if user tries to set these\nconst reservedProperties = new Set([\"code\", \"segment\", \"path\", \"redirect\"]);\n\n// Reserved method names - silently ignore attempts to overwrite these\nconst reservedMethods = new Set([\n \"setCode\",\n \"setErrorInstance\",\n \"setAdditionalFields\",\n \"hasField\",\n \"getField\",\n \"toJSON\",\n]);\n\nexport class RouterError extends Error {\n [key: string]: unknown;\n\n // Using public properties to ensure structural compatibility\n // with RouterError interface in core-types\n readonly segment: string | undefined;\n readonly path: string | undefined;\n readonly redirect: State | undefined;\n\n // Note: code appears to be writable but setCode() should be used\n // to properly update both code and message together\n code: string;\n\n /**\n * Creates a new RouterError instance.\n *\n * The options object accepts built-in fields (message, segment, path, redirect)\n * and any additional custom fields, which will all be attached to the error instance.\n *\n * @param code - The error code (e.g., \"ROUTE_NOT_FOUND\", \"CANNOT_ACTIVATE\")\n * @param options - Optional configuration object\n * @param options.message - Custom error message (defaults to code if not provided)\n * @param options.segment - The route segment where the error occurred\n * @param options.path - The full path where the error occurred\n * @param options.redirect - Optional redirect state for navigation errors\n *\n * @example\n * ```typescript\n * // Basic error\n * const err1 = new RouterError(\"ROUTE_NOT_FOUND\");\n *\n * // Error with custom message\n * const err2 = new RouterError(\"ERR\", { message: \"Something went wrong\" });\n *\n * // Error with context and custom fields\n * const err3 = new RouterError(\"CANNOT_ACTIVATE\", {\n * message: \"Insufficient permissions\",\n * segment: \"admin\",\n * path: \"/admin/users\",\n * userId: \"123\" // custom field\n * });\n *\n * // Error with redirect\n * const err4 = new RouterError(\"TRANSITION_ERR\", {\n * redirect: { name: \"home\", path: \"/\", params: {} }\n * });\n * ```\n */\n constructor(\n code: string,\n {\n message,\n segment,\n path,\n redirect,\n ...rest\n }: {\n [key: string]: unknown;\n message?: string | undefined;\n segment?: string | undefined;\n path?: string | undefined;\n redirect?: State | undefined;\n } = {},\n ) {\n super(message ?? code);\n\n this.code = code;\n this.segment = segment;\n this.path = path;\n // Deep freeze redirect to prevent mutations (creates a frozen clone)\n this.redirect = redirect ? deepFreezeState(redirect) : undefined;\n\n // Assign custom fields, checking reserved properties and filtering out reserved method names\n // Issue #39: Throw for reserved properties to match setAdditionalFields behavior\n for (const [key, value] of Object.entries(rest)) {\n if (reservedProperties.has(key)) {\n throw new TypeError(\n `[RouterError] Cannot set reserved property \"${key}\"`,\n );\n }\n\n if (!reservedMethods.has(key)) {\n this[key] = value;\n }\n }\n }\n\n /**\n * Updates the error code and conditionally updates the message.\n *\n * If the current message is one of the standard error code values\n * (e.g., \"ROUTE_NOT_FOUND\", \"SAME_STATES\"), it will be replaced with the new code.\n * This allows keeping error messages in sync with codes when using standard error codes.\n *\n * If the message is custom (not a standard error code), it will be preserved.\n *\n * @param newCode - The new error code to set\n *\n * @example\n * // Message follows code (standard error code as message)\n * const err = new RouterError(\"ROUTE_NOT_FOUND\", { message: \"ROUTE_NOT_FOUND\" });\n * err.setCode(\"CUSTOM_ERROR\"); // message becomes \"CUSTOM_ERROR\"\n *\n * @example\n * // Custom message is preserved\n * const err = new RouterError(\"ERR\", { message: \"Custom error message\" });\n * err.setCode(\"NEW_CODE\"); // message stays \"Custom error message\"\n */\n setCode(newCode: string): void {\n this.code = newCode;\n\n // Only update message if it's a standard error code value (not a custom message)\n if (errorCodeValues.has(this.message)) {\n this.message = newCode;\n }\n }\n\n /**\n * Copies properties from another Error instance to this RouterError.\n *\n * This method updates the message, cause, and stack trace from the provided error.\n * Useful for wrapping native errors while preserving error context.\n *\n * @param err - The Error instance to copy properties from\n * @throws {TypeError} If err is null or undefined\n *\n * @example\n * ```typescript\n * const routerErr = new RouterError(\"TRANSITION_ERR\");\n * try {\n * // some operation that might fail\n * } catch (nativeErr) {\n * routerErr.setErrorInstance(nativeErr);\n * throw routerErr;\n * }\n * ```\n */\n setErrorInstance(err: Error): void {\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (!err) {\n throw new TypeError(\n \"[RouterError.setErrorInstance] err parameter is required and must be an Error instance\",\n );\n }\n\n this.message = err.message;\n this.cause = err.cause;\n this.stack = err.stack ?? \"\";\n }\n\n /**\n * Adds custom fields to the error object.\n *\n * This method allows attaching arbitrary data to the error for debugging or logging purposes.\n * All fields become accessible as properties on the error instance and are included in JSON serialization.\n *\n * Reserved method names (setCode, setErrorInstance, setAdditionalFields, hasField, getField, toJSON)\n * are automatically filtered out to prevent accidental overwriting of class methods.\n *\n * @param fields - Object containing custom fields to add to the error\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"CANNOT_ACTIVATE\");\n * err.setAdditionalFields({\n * userId: \"123\",\n * attemptedRoute: \"/admin\",\n * reason: \"insufficient permissions\"\n * });\n *\n * console.log(err.userId); // \"123\"\n * console.log(JSON.stringify(err)); // includes all custom fields\n * ```\n */\n setAdditionalFields(fields: Record<string, unknown>): void {\n // Assign fields, throwing for reserved properties, silently ignoring methods\n for (const [key, value] of Object.entries(fields)) {\n if (reservedProperties.has(key)) {\n throw new TypeError(\n `[RouterError.setAdditionalFields] Cannot set reserved property \"${key}\"`,\n );\n }\n\n if (!reservedMethods.has(key)) {\n this[key] = value;\n }\n }\n }\n\n /**\n * Checks if a custom field exists on the error object.\n *\n * This method checks for both custom fields added via setAdditionalFields()\n * and built-in fields (code, message, segment, etc.).\n *\n * @param key - The field name to check\n * @returns `true` if the field exists, `false` otherwise\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"ERR\", { segment: \"users\" });\n * err.setAdditionalFields({ userId: \"123\" });\n *\n * err.hasField(\"userId\"); // true\n * err.hasField(\"segment\"); // true\n * err.hasField(\"unknown\"); // false\n * ```\n */\n hasField(key: string): boolean {\n return key in this;\n }\n\n /**\n * Retrieves a custom field value from the error object.\n *\n * This method can access both custom fields and built-in fields.\n * Returns `undefined` if the field doesn't exist.\n *\n * @param key - The field name to retrieve\n * @returns The field value, or `undefined` if it doesn't exist\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"ERR\");\n * err.setAdditionalFields({ userId: \"123\", role: \"admin\" });\n *\n * err.getField(\"userId\"); // \"123\"\n * err.getField(\"role\"); // \"admin\"\n * err.getField(\"code\"); // \"ERR\" (built-in field)\n * err.getField(\"unknown\"); // undefined\n * ```\n */\n getField(key: string): unknown {\n return this[key];\n }\n\n /**\n * Serializes the error to a JSON-compatible object.\n *\n * This method is automatically called by JSON.stringify() and includes:\n * - Built-in fields: code, message, segment (if set), path (if set), redirect (if set)\n * - All custom fields added via setAdditionalFields() or constructor\n * - Excludes: stack trace (for security/cleanliness)\n *\n * @returns A plain object representation of the error, suitable for JSON serialization\n *\n * @example\n * ```typescript\n * const err = new RouterError(\"ROUTE_NOT_FOUND\", {\n * message: \"Route not found\",\n * path: \"/admin/users/123\"\n * });\n * err.setAdditionalFields({ userId: \"123\" });\n *\n * JSON.stringify(err);\n * // {\n * // \"code\": \"ROUTE_NOT_FOUND\",\n * // \"message\": \"Route not found\",\n * // \"path\": \"/admin/users/123\",\n * // \"userId\": \"123\"\n * // }\n * ```\n */\n toJSON(): Record<string, unknown> {\n const result: Record<string, unknown> = {\n code: this.code,\n message: this.message,\n };\n\n if (this.segment !== undefined) {\n result.segment = this.segment;\n }\n if (this.path !== undefined) {\n result.path = this.path;\n }\n if (this.redirect !== undefined) {\n result.redirect = this.redirect;\n }\n\n // add all public fields\n // Using Set.has() for O(1) lookup instead of Array.includes() O(n)\n // Overall complexity: O(n) instead of O(n*m)\n const excludeKeys = new Set([\n \"code\",\n \"message\",\n \"segment\",\n \"path\",\n \"redirect\",\n \"stack\",\n ]);\n\n for (const key in this) {\n if (Object.hasOwn(this, key) && !excludeKeys.has(key)) {\n result[key] = this[key];\n }\n }\n\n return result;\n }\n}\n","// packages/real-router/modules/transition/processLifecycleResult.ts\n\n/* eslint-disable promise/always-return, promise/no-callback-in-promise */\nimport { isPromise, isState } from \"type-guards\";\n\nimport { errorCodes } from \"../../../constants\";\nimport { RouterError } from \"../../../RouterError\";\n\nimport type { DoneFn, State, ActivationFn } from \"@real-router/types\";\n\n// Helper: Lifecycle results Processing Function\nexport const processLifecycleResult = (\n result: ReturnType<ActivationFn>,\n done: DoneFn,\n segment?: string,\n): void => {\n const errorData = segment ? { segment } : {};\n\n if (result === undefined) {\n // We expect a Done call\n return;\n }\n\n if (typeof result === \"boolean\") {\n if (result) {\n done();\n } else {\n done(new RouterError(errorCodes.TRANSITION_ERR, errorData));\n }\n\n return;\n }\n\n if (isState(result)) {\n // Type guard should narrow, but TypeScript needs help\n done(undefined, result);\n\n return;\n }\n\n if (isPromise<State | boolean | undefined>(result)) {\n // Callback-based API: promise handled internally, not returned\n // Mixing promises with callbacks is intentional for backward compatibility\n // Type assertion needed due to complex union type narrowing\n // Optimization: .then(onFulfill, onReject) instead of .then().catch()\n // This saves 1 Promise allocation per async middleware call\n void result.then(\n (resVal) => {\n // Issue #38: Handle Promise<boolean> same as sync boolean\n if (typeof resVal === \"boolean\") {\n if (resVal) {\n done();\n } else {\n done(new RouterError(errorCodes.TRANSITION_ERR, errorData));\n }\n } else {\n done(undefined, resVal);\n }\n },\n (error_: unknown) => {\n let error: {\n [key: string]: unknown;\n message?: string | undefined;\n segment?: string | undefined;\n } = errorData;\n\n if (error_ instanceof Error) {\n error = {\n ...errorData,\n message: error_.message,\n stack: error_.stack,\n };\n\n // Error.cause requires ES2022+ - safely access it if present\n if (\"cause\" in error_ && error_.cause !== undefined) {\n error.cause = error_.cause;\n }\n } else if (error_ && typeof error_ === \"object\") {\n error = { ...errorData, ...error_ };\n }\n\n done(new RouterError(errorCodes.TRANSITION_ERR, error));\n },\n );\n\n return;\n }\n\n // This should never be reached - all valid ActivationFn return types are handled above\n // If we get here, it means the activation function returned an unexpected type\n done(\n new RouterError(errorCodes.TRANSITION_ERR, {\n ...errorData,\n message: `Invalid lifecycle result type: ${typeof result}`,\n }),\n );\n};\n","import { logger } from \"logger\";\n\nimport type { State, RouterError as RouterErrorType } from \"@real-router/types\";\n\n/**\n * Strict callback type where state is always provided.\n * Used internally in transition chain where state is guaranteed.\n *\n * @internal\n */\nexport type StrictDoneFn = (\n error: RouterErrorType | undefined,\n state: State,\n) => void;\n\n/**\n * Safely invokes a callback, catching and logging any errors.\n *\n * @internal\n */\nexport function safeCallback(\n callback: StrictDoneFn,\n error: RouterErrorType | undefined,\n state: State,\n logTag: string,\n): void {\n try {\n callback(error, state);\n } catch (error_) {\n logger.error(logTag, \"Error in callback:\", error_);\n }\n}\n","// packages/real-router/modules/transition/wrapSyncError.ts\n\n/**\n * Error metadata structure for transition errors.\n * Contains information extracted from caught exceptions.\n */\nexport interface SyncErrorMetadata {\n [key: string]: unknown;\n message?: string;\n stack?: string | undefined;\n cause?: unknown;\n segment?: string;\n}\n\n// Reserved properties that conflict with RouterError constructor\n// Issue #39: Filter these when wrapping sync errors to avoid TypeError\nconst reservedRouterErrorProps = new Set([\n \"code\",\n \"segment\",\n \"path\",\n \"redirect\",\n]);\n\n/**\n * Wraps a synchronously thrown value into structured error metadata.\n *\n * This helper extracts useful debugging information from various thrown values:\n * - Error instances: extracts message, stack, and cause (ES2022+)\n * - Plain objects: spreads properties into metadata\n * - Primitives (string, number, etc.): returns minimal metadata\n *\n * @param thrown - The value caught in a try-catch block\n * @param segment - Optional route segment name (for lifecycle hooks)\n * @returns Structured error metadata for RouterError\n *\n * @example\n * ```typescript\n * try {\n * hookFn();\n * } catch (error) {\n * const metadata = wrapSyncError(error, \"users.profile\");\n * done(new RouterError(errorCodes.TRANSITION_ERR, metadata));\n * }\n * ```\n */\nexport function wrapSyncError(\n thrown: unknown,\n segment?: string,\n): SyncErrorMetadata {\n // Base metadata - always include segment if provided\n const base: SyncErrorMetadata = segment ? { segment } : {};\n\n // Handle Error instances - extract all useful properties\n if (thrown instanceof Error) {\n return {\n ...base,\n message: thrown.message,\n stack: thrown.stack,\n // Error.cause requires ES2022+ - safely access if present\n ...(\"cause\" in thrown &&\n thrown.cause !== undefined && { cause: thrown.cause }),\n };\n }\n\n // Handle plain objects - spread properties into metadata, filtering reserved props\n if (thrown && typeof thrown === \"object\") {\n const filtered: Record<string, unknown> = {};\n\n for (const [key, value] of Object.entries(thrown)) {\n // Issue #39: Skip reserved properties to avoid RouterError constructor TypeError\n if (!reservedRouterErrorProps.has(key)) {\n filtered[key] = value;\n }\n }\n\n return { ...base, ...filtered };\n }\n\n // Primitives (string, number, boolean, null, undefined, symbol, bigint)\n // Return base metadata only - the primitive value isn't useful as metadata\n return base;\n}\n","// packages/real-router/modules/transition/executeLifecycleHooks.ts\n\nimport { logger } from \"logger\";\nimport { isState } from \"type-guards\";\n\nimport { RouterError, errorCodes } from \"@real-router/core\";\n\nimport { makeError } from \"./makeError\";\nimport { mergeStates } from \"./mergeStates\";\nimport { processLifecycleResult } from \"./processLifecycleResult\";\nimport { safeCallback, type StrictDoneFn } from \"./shared\";\nimport { wrapSyncError } from \"./wrapSyncError\";\n\nimport type {\n DoneFn,\n State,\n ActivationFn,\n RouterError as RouterErrorType,\n} from \"@real-router/types\";\n\nconst LOG_TAG = \"core:lifecycle\";\n\n// Helper: execution of the Lifecycle Hooks group\nexport const executeLifecycleHooks = (\n hooks: Map<string, ActivationFn>,\n toState: State,\n fromState: State | undefined,\n segments: string[],\n errorCode: string,\n isCancelled: () => boolean,\n callback: StrictDoneFn,\n): void => {\n let currentState = toState;\n const segmentsToProcess = segments.filter((name) => hooks.has(name));\n\n if (segmentsToProcess.length === 0) {\n safeCallback(callback, undefined, currentState, LOG_TAG);\n\n return;\n }\n\n let index = 0;\n\n // If the transition is cancelled, we will not process the hooks\n // Guards cannot redirect - they can only allow (true/undefined) or block (false/error)\n const done: DoneFn = (err, state) => {\n if (err) {\n // Guards cannot redirect - convert any redirect to error\n if (err.redirect) {\n const errorWithoutRedirect = new RouterError(errorCode, {\n message: \"Guards cannot redirect. Use middleware for redirects.\",\n attemptedRedirect: err.redirect,\n });\n\n processNext(errorWithoutRedirect);\n } else {\n processNext(err);\n }\n } else {\n processNext(undefined, state);\n }\n };\n\n const processNext = (err?: RouterErrorType, newState?: State): void => {\n if (isCancelled()) {\n safeCallback(\n callback,\n new RouterError(errorCodes.TRANSITION_CANCELLED),\n currentState,\n LOG_TAG,\n );\n\n return;\n }\n\n if (err) {\n safeCallback(callback, makeError(errorCode, err), currentState, LOG_TAG);\n\n return;\n }\n\n // Processing a new state\n // Optimization: Early return for undefined newState (most common case ~90%+)\n // This avoids isState() call and subsequent checks\n if (!newState) {\n // Fast path: skip all checks\n } else if (newState !== currentState && isState(newState)) {\n // Guards cannot redirect to a different route\n if (newState.name !== currentState.name) {\n const redirectNotAllowedErr = new RouterError(errorCode, {\n message: \"Guards cannot redirect to different route. Use middleware.\",\n attemptedRedirect: {\n name: newState.name,\n params: newState.params,\n path: newState.path,\n },\n });\n\n safeCallback(callback, redirectNotAllowedErr, currentState, LOG_TAG);\n\n return;\n }\n\n // Same route - safe to merge (param modifications, meta changes)\n const hasChanged =\n newState.params !== currentState.params ||\n newState.path !== currentState.path;\n\n if (hasChanged) {\n logger.error(\n \"core:transition\",\n \"Warning: State mutated during transition\",\n { from: currentState, to: newState },\n );\n }\n\n currentState = mergeStates(newState, currentState);\n }\n\n if (index >= segmentsToProcess.length) {\n safeCallback(callback, undefined, currentState, LOG_TAG);\n\n return;\n }\n\n const segment = segmentsToProcess[index++];\n // Safe cast: segmentsToProcess only contains names that exist in hooks (filtered above)\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion -- guaranteed by filter\n const hookFn = hooks.get(segment)!;\n\n try {\n const result = hookFn(currentState, fromState, done);\n\n processLifecycleResult(result, done, segment);\n } catch (syncError: unknown) {\n // Note: TRANSITION_ERR is placeholder - makeError() will set correct code\n done(\n new RouterError(\n errorCodes.TRANSITION_ERR,\n wrapSyncError(syncError, segment),\n ),\n );\n }\n };\n\n processNext();\n};\n","// packages/real-router/modules/transition/executeMiddleware.ts\n\nimport { logger } from \"logger\";\nimport { isState } from \"type-guards\";\n\nimport { makeError } from \"./makeError\";\nimport { mergeStates } from \"./mergeStates\";\nimport { processLifecycleResult } from \"./processLifecycleResult\";\nimport { safeCallback, type StrictDoneFn } from \"./shared\";\nimport { wrapSyncError } from \"./wrapSyncError\";\nimport { errorCodes } from \"../../../constants\";\nimport { RouterError } from \"../../../RouterError\";\n\nimport type {\n DoneFn,\n State,\n ActivationFn,\n RouterError as RouterErrorType,\n} from \"@real-router/types\";\n\nconst LOG_TAG = \"core:middleware\";\n\n// Helper: processing middleware\nexport const executeMiddleware = (\n middlewareFunctions: ActivationFn[],\n toState: State,\n fromState: State | undefined,\n isCancelled: () => boolean,\n callback: StrictDoneFn,\n): void => {\n let currentState = toState;\n let index = 0;\n\n // If the transition is cancelled, we will not process the middleware\n // Note: Middleware redirects are not supported - errors pass through\n const done: DoneFn = (err, state) => {\n if (err) {\n processNext(err);\n } else {\n processNext(undefined, state);\n }\n };\n\n const processNext = (err?: RouterErrorType, newState?: State): void => {\n if (isCancelled()) {\n safeCallback(\n callback,\n new RouterError(errorCodes.TRANSITION_CANCELLED),\n currentState,\n LOG_TAG,\n );\n\n return;\n }\n\n if (err) {\n safeCallback(\n callback,\n makeError(errorCodes.TRANSITION_ERR, err),\n currentState,\n LOG_TAG,\n );\n\n return;\n }\n\n // Processing a new state\n // Optimization: Early return for undefined newState (most common case ~90%+)\n // This avoids isState() call and subsequent checks\n if (!newState) {\n // Fast path: skip all checks\n } else if (newState !== currentState && isState(newState)) {\n const hasChanged =\n newState.name !== currentState.name ||\n newState.params !== currentState.params ||\n newState.path !== currentState.path;\n\n if (hasChanged) {\n logger.error(\n LOG_TAG,\n \"Warning: State mutated during middleware execution\",\n { from: currentState, to: newState },\n );\n }\n\n currentState = mergeStates(newState, currentState);\n }\n\n if (index >= middlewareFunctions.length) {\n safeCallback(callback, undefined, currentState, LOG_TAG);\n\n return;\n }\n\n const middlewareFn = middlewareFunctions[index++];\n\n try {\n const result = middlewareFn(currentState, fromState, done);\n\n processLifecycleResult(result, done);\n } catch (syncError: unknown) {\n done(\n new RouterError(errorCodes.TRANSITION_ERR, wrapSyncError(syncError)),\n );\n }\n };\n\n processNext();\n};\n","// packages/real-router/modules/transition/index.ts\n\nimport { executeLifecycleHooks } from \"./executeLifecycleHooks\";\nimport { executeMiddleware } from \"./executeMiddleware\";\nimport { constants, errorCodes } from \"../../../constants\";\nimport { RouterError } from \"../../../RouterError\";\nimport { getTransitionPath, nameToIDs } from \"../../../transitionPath\";\n\nimport type { TransitionDependencies } from \"../types\";\nimport type {\n NavigationOptions,\n CancelFn,\n State,\n RouterError as RouterErrorType,\n} from \"@real-router/types\";\n\n/**\n * Strict callback type where state is always provided.\n * Used internally in transition chain where state is guaranteed.\n */\ntype StrictDoneFn = (error: RouterErrorType | undefined, state: State) => void;\n\nexport function transition(\n deps: TransitionDependencies,\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n transitionCallback: (err: RouterErrorType | undefined, state: State) => void,\n): CancelFn {\n // The state of transaction\n let cancelled = false;\n let completed = false;\n\n // We're caching the necessary data\n const [canDeactivateFunctions, canActivateFunctions] =\n deps.getLifecycleFunctions();\n const middlewareFunctions = deps.getMiddlewareFunctions();\n const isUnknownRoute = toState.name === constants.UNKNOWN_ROUTE;\n\n // State management functions\n // Issue #36: Check both explicit cancellation AND router shutdown\n // Issue #50: Use isActive() instead of isStarted() for two-phase start support\n // isActive() is true during initial start transition, isStarted() is false\n const isCancelled = () => cancelled || !deps.isActive();\n\n const cancel = () => {\n if (!cancelled && !completed) {\n cancelled = true;\n complete(new RouterError(errorCodes.TRANSITION_CANCELLED));\n }\n };\n\n const complete = (err: RouterErrorType | undefined, state?: State) => {\n if (completed) {\n return;\n }\n\n completed = true;\n transitionCallback(err, state ?? toState);\n };\n\n // The main transaction logic\n const runTransition = (): void => {\n const { toDeactivate, toActivate } = getTransitionPath(toState, fromState);\n\n // determine the necessary steps\n const shouldDeactivate =\n fromState && !opts.forceDeactivate && toDeactivate.length > 0;\n const shouldActivate = !isUnknownRoute && toActivate.length > 0;\n const shouldRunMiddleware = middlewareFunctions.length > 0;\n\n // The chain of execution\n const runDeactivation = (callback: StrictDoneFn) => {\n if (shouldDeactivate) {\n executeLifecycleHooks(\n canDeactivateFunctions,\n toState,\n fromState,\n toDeactivate,\n errorCodes.CANNOT_DEACTIVATE,\n isCancelled,\n callback,\n );\n } else {\n callback(undefined, toState);\n }\n };\n\n const runActivation = (state: State, callback: StrictDoneFn) => {\n if (shouldActivate) {\n executeLifecycleHooks(\n canActivateFunctions,\n state,\n fromState,\n toActivate,\n errorCodes.CANNOT_ACTIVATE,\n isCancelled,\n (err, newState) => {\n callback(err, newState);\n },\n );\n } else {\n // State is already frozen from makeState()\n callback(undefined, state);\n }\n };\n\n const runMiddleware = (state: State, callback: StrictDoneFn) => {\n if (shouldRunMiddleware) {\n executeMiddleware(\n middlewareFunctions,\n state,\n fromState,\n isCancelled,\n (err, newState) => {\n callback(err, newState);\n },\n );\n } else {\n // State is already frozen from makeState()\n callback(undefined, state);\n }\n };\n\n // Callback handlers extracted to reduce nesting depth\n const handleMiddlewareComplete: StrictDoneFn = (\n runMiddlewareErr,\n runMiddlewareState,\n ) => {\n if (runMiddlewareErr) {\n complete(runMiddlewareErr, runMiddlewareState);\n\n return;\n }\n\n // Automatic cleaning of inactive segments\n if (fromState) {\n const activeSegments = nameToIDs(toState.name);\n const previousActiveSegments = nameToIDs(fromState.name);\n const activeSet = new Set(activeSegments);\n\n for (const name of previousActiveSegments) {\n if (!activeSet.has(name) && canDeactivateFunctions.has(name)) {\n deps.clearCanDeactivate(name);\n }\n }\n }\n\n complete(undefined, runMiddlewareState);\n };\n\n const handleActivationComplete: StrictDoneFn = (\n runActivationErr,\n runActivationState,\n ) => {\n if (runActivationErr) {\n complete(runActivationErr, runActivationState);\n\n return;\n }\n\n runMiddleware(runActivationState, handleMiddlewareComplete);\n };\n\n const handleDeactivationComplete: StrictDoneFn = (err, state) => {\n if (err) {\n complete(err, state);\n\n return;\n }\n\n runActivation(state, handleActivationComplete);\n };\n\n // perform a chain\n runDeactivation(handleDeactivationComplete);\n };\n\n // Launch transition\n runTransition();\n\n return cancel;\n}\n","// packages/core/src/namespaces/NavigationNamespace/validators.ts\n\n/**\n * Static validation functions for NavigationNamespace.\n * Called by Router facade before instance methods.\n */\n\nimport { getTypeDescription, isNavigationOptions } from \"type-guards\";\n\nimport type { ParsedNavigateArgs, ParsedNavigateDefaultArgs } from \"./types\";\nimport type {\n DoneFn,\n NavigationOptions,\n Params,\n State,\n} from \"@real-router/types\";\n\nconst noop = (): void => {};\n\n/**\n * Cached frozen empty objects to reduce GC pressure.\n * Safe because they're frozen and cannot be mutated.\n */\nconst EMPTY_PARAMS: Params = Object.freeze({});\nconst EMPTY_OPTS: NavigationOptions = Object.freeze({});\n\n/**\n * Validates navigate route name argument.\n */\nexport function validateNavigateArgs(name: unknown): asserts name is string {\n if (typeof name !== \"string\") {\n throw new TypeError(\n `[router.navigate] Invalid route name: expected string, got ${getTypeDescription(name)}`,\n );\n }\n}\n\n/**\n * Validates navigateToState arguments.\n */\nexport function validateNavigateToStateArgs(\n toState: unknown,\n fromState: unknown,\n opts: unknown,\n callback: unknown,\n emitSuccess: unknown,\n): void {\n // toState must be a valid state object\n if (\n !toState ||\n typeof toState !== \"object\" ||\n typeof (toState as State).name !== \"string\" ||\n typeof (toState as State).path !== \"string\"\n ) {\n throw new TypeError(\n `[router.navigateToState] Invalid toState: expected State object with name and path`,\n );\n }\n\n // fromState can be undefined or a valid state\n if (\n fromState !== undefined &&\n (!fromState ||\n typeof fromState !== \"object\" ||\n typeof (fromState as State).name !== \"string\")\n ) {\n throw new TypeError(\n `[router.navigateToState] Invalid fromState: expected State object or undefined`,\n );\n }\n\n // opts must be an object\n if (typeof opts !== \"object\" || opts === null) {\n throw new TypeError(\n `[router.navigateToState] Invalid opts: expected NavigationOptions object, got ${getTypeDescription(opts)}`,\n );\n }\n\n // callback must be a function\n if (typeof callback !== \"function\") {\n throw new TypeError(\n `[router.navigateToState] Invalid callback: expected function, got ${getTypeDescription(callback)}`,\n );\n }\n\n // emitSuccess must be a boolean\n if (typeof emitSuccess !== \"boolean\") {\n throw new TypeError(\n `[router.navigateToState] Invalid emitSuccess: expected boolean, got ${getTypeDescription(emitSuccess)}`,\n );\n }\n}\n\n/**\n * Validates navigateToDefault arguments (before parsing).\n */\nexport function validateNavigateToDefaultArgs(\n optsOrDone: unknown,\n done: unknown,\n): void {\n // If first arg is provided and not a function, it must be an object (options)\n if (\n optsOrDone !== undefined &&\n typeof optsOrDone !== \"function\" &&\n (typeof optsOrDone !== \"object\" || optsOrDone === null)\n ) {\n throw new TypeError(\n `[router.navigateToDefault] Invalid options: ${getTypeDescription(optsOrDone)}. Expected NavigationOptions object or callback function.`,\n );\n }\n\n // If second arg is provided, it must be a function\n if (done !== undefined && typeof done !== \"function\") {\n throw new TypeError(\n `[router.navigateToDefault] Invalid callback: expected function, got ${getTypeDescription(done)}`,\n );\n }\n}\n\n/**\n * Validates that opts is a valid NavigationOptions object.\n */\nexport function validateNavigationOptions(\n opts: unknown,\n methodName: string,\n): asserts opts is NavigationOptions {\n if (!isNavigationOptions(opts)) {\n throw new TypeError(\n `[router.${methodName}] Invalid options: ${getTypeDescription(opts)}. Expected NavigationOptions object.`,\n );\n }\n}\n\n/**\n * Parses the polymorphic arguments of navigate().\n *\n * Handles all valid call signatures:\n * - navigate(name, callback)\n * - navigate(name, params)\n * - navigate(name, params, callback)\n * - navigate(name, params, opts)\n * - navigate(name, params, opts, callback)\n */\nexport function parseNavigateArgs(\n paramsOrDone?: Params | DoneFn,\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n): ParsedNavigateArgs {\n if (typeof paramsOrDone === \"function\") {\n // Form: navigate(name, callback)\n return { params: EMPTY_PARAMS, opts: EMPTY_OPTS, callback: paramsOrDone };\n }\n\n // Forms: navigate(name), navigate(name, params), navigate(name, params, callback),\n // navigate(name, params, opts), navigate(name, params, opts, callback)\n // Also handles: navigate(name, null/undefined, callback) - runtime defense\n const params = paramsOrDone ?? EMPTY_PARAMS;\n\n if (typeof optsOrDone === \"function\") {\n return { params, opts: EMPTY_OPTS, callback: optsOrDone };\n }\n\n return {\n params,\n opts: optsOrDone ?? EMPTY_OPTS,\n callback: done ?? noop,\n };\n}\n\n/**\n * Parses the polymorphic arguments of navigateToDefault().\n */\nexport function parseNavigateToDefaultArgs(\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n): ParsedNavigateDefaultArgs {\n if (typeof optsOrDone === \"function\") {\n return { opts: EMPTY_OPTS, callback: optsOrDone };\n }\n\n return {\n opts: optsOrDone ?? EMPTY_OPTS,\n callback: done ?? noop,\n };\n}\n","// packages/core/src/namespaces/NavigationNamespace/NavigationNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport { noop, safeCallback } from \"./helpers\";\nimport { transition } from \"./transition\";\nimport {\n parseNavigateArgs,\n parseNavigateToDefaultArgs,\n validateNavigateArgs,\n validateNavigateToDefaultArgs,\n validateNavigateToStateArgs,\n validateNavigationOptions,\n} from \"./validators\";\nimport { events, errorCodes, constants } from \"../../constants\";\nimport { RouterError } from \"../../RouterError\";\n\nimport type {\n NavigationDependencies,\n ParsedNavigateArgs,\n ParsedNavigateDefaultArgs,\n TransitionDependencies,\n} from \"./types\";\nimport type {\n CancelFn,\n DoneFn,\n NavigationOptions,\n Params,\n State,\n} from \"@real-router/types\";\n\n/**\n * Independent namespace for managing navigation.\n *\n * Handles navigate(), navigateToDefault(), navigateToState(), and transition state.\n */\nexport class NavigationNamespace {\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n // Functional reference for cyclic dependency\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n\n /**\n * Functional reference to RouterLifecycleNamespace.isStarted().\n * Must be set before calling navigate().\n */\n\n isRouterStarted!: () => boolean;\n\n #navigating = false;\n #cancelCurrentTransition: CancelFn | null = null;\n\n // Dependencies injected via setDependencies (replaces full router reference)\n #depsStore: NavigationDependencies | undefined;\n #transitionDepsStore: TransitionDependencies | undefined;\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): NavigationDependencies {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] NavigationNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n /**\n * Gets transition dependencies or throws if not initialized.\n */\n get #transitionDeps(): TransitionDependencies {\n /* v8 ignore next 3 -- @preserve: transitionDeps always set by Router.ts */\n if (!this.#transitionDepsStore) {\n throw new Error(\n \"[real-router] NavigationNamespace: transition dependencies not initialized\",\n );\n }\n\n return this.#transitionDepsStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // Proxy to functions in validators.ts for separation of concerns\n // =========================================================================\n\n static validateNavigateArgs(name: unknown): asserts name is string {\n validateNavigateArgs(name);\n }\n\n static validateNavigateToStateArgs(\n toState: unknown,\n fromState: unknown,\n opts: unknown,\n callback: unknown,\n emitSuccess: unknown,\n ): void {\n validateNavigateToStateArgs(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n }\n\n static validateNavigateToDefaultArgs(\n optsOrDone: unknown,\n done: unknown,\n ): void {\n validateNavigateToDefaultArgs(optsOrDone, done);\n }\n\n static validateNavigationOptions(\n opts: unknown,\n methodName: string,\n ): asserts opts is NavigationOptions {\n validateNavigationOptions(opts, methodName);\n }\n\n static parseNavigateArgs(\n paramsOrDone?: Params | DoneFn,\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): ParsedNavigateArgs {\n return parseNavigateArgs(paramsOrDone, optsOrDone, done);\n }\n\n static parseNavigateToDefaultArgs(\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): ParsedNavigateDefaultArgs {\n return parseNavigateToDefaultArgs(optsOrDone, done);\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n /**\n * Sets dependencies for navigation operations.\n * Must be called before using navigation methods.\n */\n setDependencies(deps: NavigationDependencies): void {\n this.#depsStore = deps;\n }\n\n /**\n * Sets dependencies for transition operations.\n * Must be called before using navigation methods.\n */\n setTransitionDependencies(deps: TransitionDependencies): void {\n this.#transitionDepsStore = deps;\n }\n\n // =========================================================================\n // Instance methods\n // =========================================================================\n\n /**\n * Checks if a navigation transition is currently in progress.\n */\n isNavigating(): boolean {\n return this.isRouterStarted() && this.#navigating;\n }\n\n /**\n * Cancels the current transition if one is in progress.\n */\n cancel(): void {\n if (this.#cancelCurrentTransition) {\n this.#cancelCurrentTransition();\n this.#cancelCurrentTransition = null;\n }\n\n this.#navigating = false;\n }\n\n /**\n * Internal navigation function that accepts pre-built state.\n * Used by RouterLifecycleNamespace for start() transitions.\n */\n navigateToState(\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ): CancelFn {\n const deps = this.#deps;\n const transitionDeps = this.#transitionDeps;\n\n // Warn about concurrent navigation (potential SSR race condition)\n if (this.#navigating) {\n logger.warn(\n \"router.navigate\",\n \"Concurrent navigation detected on shared router instance. \" +\n \"For SSR, use router.clone() to create isolated instance per request.\",\n );\n }\n\n // Cancel previous transition\n this.cancel();\n\n // Set navigating flag BEFORE emitting TRANSITION_START\n // This ensures isNavigating() returns true during event handlers\n this.#navigating = true;\n\n // Emit TRANSITION_START (after navigating flag is set)\n deps.invokeEventListeners(events.TRANSITION_START, toState, fromState);\n\n // Create callback for transition\n const transitionCallback = (err: RouterError | undefined, state: State) => {\n this.#navigating = false;\n this.#cancelCurrentTransition = null;\n\n if (!err) {\n // Route was already validated in navigate() via buildState().\n // Since guards can no longer redirect (Issue #55), the state.name cannot change.\n // However, routes can be dynamically removed during async navigation,\n // so we do a lightweight check with hasRoute() instead of full buildState().\n // UNKNOWN_ROUTE is always valid (used for 404 handling).\n if (\n state.name === constants.UNKNOWN_ROUTE ||\n deps.hasRoute(state.name)\n ) {\n deps.setState(state);\n\n // Emit TRANSITION_SUCCESS only if requested\n if (emitSuccess) {\n deps.invokeEventListeners(\n events.TRANSITION_SUCCESS,\n state,\n fromState,\n opts,\n );\n }\n\n // State is already frozen from transition module\n safeCallback(callback, undefined, state);\n } else {\n // Route was removed during async navigation\n const notFoundErr = new RouterError(errorCodes.ROUTE_NOT_FOUND, {\n routeName: state.name,\n });\n\n safeCallback(callback, notFoundErr);\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n deps.getState(),\n notFoundErr,\n );\n }\n\n return;\n }\n\n // Error handling\n if (err.code === errorCodes.TRANSITION_CANCELLED) {\n deps.invokeEventListeners(events.TRANSITION_CANCEL, toState, fromState);\n } else {\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n toState,\n fromState,\n err,\n );\n }\n\n safeCallback(callback, err);\n };\n\n // Launch transition\n this.#cancelCurrentTransition = transition(\n transitionDeps,\n toState,\n fromState,\n opts,\n transitionCallback,\n );\n\n return this.#cancelCurrentTransition;\n }\n\n /**\n * Navigates to a route by name.\n * Arguments should be pre-parsed and validated by facade.\n */\n navigate(\n name: string,\n params: Params,\n opts: NavigationOptions,\n callback: DoneFn,\n ): CancelFn {\n const deps = this.#deps;\n\n // Quick check of the state of the router\n if (!this.isRouterStarted()) {\n const err = new RouterError(errorCodes.ROUTER_NOT_STARTED);\n\n safeCallback(callback, err);\n\n return noop;\n }\n\n // build route state with segments (avoids duplicate getSegmentsByName call)\n const result = deps.buildStateWithSegments(name, params);\n\n if (!result) {\n const err = new RouterError(errorCodes.ROUTE_NOT_FOUND);\n\n safeCallback(callback, err);\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n deps.getState(),\n err,\n );\n\n return noop;\n }\n\n const { state: route, segments } = result;\n\n // create a target state\n const toState = deps.makeState(\n route.name,\n route.params,\n deps.buildPath(route.name, route.params, segments),\n {\n params: route.meta,\n options: opts,\n redirected: opts.redirected ?? false,\n },\n );\n\n // Early return for skipTransition - no state equality check needed\n // eslint-disable-next-line @typescript-eslint/no-deprecated,sonarjs/deprecation\n if (opts.skipTransition) {\n // toState is already frozen from makeState()\n safeCallback(callback, undefined, toState);\n\n return noop;\n }\n\n const fromState = deps.getState();\n\n // Fast verification for the same states\n if (\n !opts.reload &&\n !opts.force &&\n deps.areStatesEqual(fromState, toState, false)\n ) {\n const err = new RouterError(errorCodes.SAME_STATES);\n\n safeCallback(callback, err);\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n toState,\n fromState,\n err,\n );\n\n return noop;\n }\n\n // transition execution with TRANSITION_SUCCESS emission\n // Note: Guards cannot redirect - redirects are handled in middleware only\n return this.navigateToState(toState, fromState, opts, callback, true); // emitSuccess = true for public navigate()\n }\n\n /**\n * Navigates to the default route if configured.\n * Arguments should be pre-parsed and validated by facade.\n */\n navigateToDefault(opts: NavigationOptions, callback: DoneFn): CancelFn {\n const deps = this.#deps;\n const options = deps.getOptions();\n\n if (!options.defaultRoute) {\n return noop;\n }\n\n return this.navigate(\n options.defaultRoute,\n options.defaultParams,\n opts,\n callback,\n );\n }\n}\n","// packages/core/src/namespaces/RouterLifecycleNamespace/constants.ts\n\nimport { errorCodes } from \"../../constants\";\nimport { RouterError } from \"../../RouterError\";\n\n/**\n * No-op function for default callbacks.\n */\nexport const noop = (): void => {};\n\n// =============================================================================\n// Cached Errors (Performance Optimization)\n// =============================================================================\n// Pre-create error instances to avoid object allocation on hot paths.\n// Error creation involves: new object, stack trace capture (~500ns-2Ξs).\n// Cached errors skip this overhead entirely.\n//\n// Trade-off: All error instances share the same stack trace (points here).\n// This is acceptable because:\n// 1. These errors indicate user misconfiguration, not internal bugs\n// 2. Error code and message are sufficient for debugging\n// 3. Performance gain (~80% for error paths) outweighs stack trace loss\n// =============================================================================\n\n/**\n * Cached error for start() called without path/state and no defaultRoute.\n */\nexport const CACHED_NO_START_PATH_ERROR = new RouterError(\n errorCodes.NO_START_PATH_OR_STATE,\n);\n\n/**\n * Cached error for start() called when router is already started/starting.\n */\nexport const CACHED_ALREADY_STARTED_ERROR = new RouterError(\n errorCodes.ROUTER_ALREADY_STARTED,\n);\n","// packages/core/src/namespaces/RouterLifecycleNamespace/helpers.ts\n\nimport { isState } from \"type-guards\";\n\nimport { noop } from \"./constants\";\n\nimport type {\n RouterLifecycleDependencies,\n StartRouterArguments,\n} from \"./types\";\nimport type { DoneFn, State } from \"@real-router/types\";\n\n/**\n * Dependencies required for resolveStartState helper.\n */\ntype ResolveStartStateDeps = Pick<\n RouterLifecycleDependencies,\n \"matchPath\" | \"buildPath\"\n>;\n\n/**\n * Parses start() arguments into a normalized tuple.\n */\nexport const getStartRouterArguments = (\n args: StartRouterArguments,\n): [startPathOrState: string | State | undefined, done: DoneFn] => {\n const [first, second] = args;\n\n if (!first) {\n return [undefined, noop];\n }\n if (typeof first === \"function\") {\n return [undefined, first];\n }\n\n return [first, second ?? noop];\n};\n\n/**\n * Resolves a path or state to a valid State object.\n */\nexport const resolveStartState = (\n pathOrState: string | State,\n deps: ResolveStartStateDeps,\n): State | undefined => {\n if (typeof pathOrState === \"string\") {\n return deps.matchPath(pathOrState);\n }\n\n // Validate state object structure using isState type guard\n // This validates: name (non-empty string), path (string), params (plain object)\n // Rejects: missing fields, wrong types, functions, symbols, class instances\n if (!isState(pathOrState)) {\n return undefined;\n }\n\n // Validate that the route exists\n // buildPath throws RouteNotFoundError for invalid routes, so we wrap in try-catch\n // to gracefully return undefined instead of propagating the error\n // See: https://github.com/greydragon888/real-router/issues/42\n try {\n deps.buildPath(pathOrState.name, pathOrState.params);\n } catch {\n return undefined;\n }\n\n return pathOrState;\n};\n","// packages/core/src/namespaces/RouterLifecycleNamespace/RouterLifecycleNamespace.ts\n\nimport { logger } from \"@real-router/logger\";\n\nimport {\n CACHED_ALREADY_STARTED_ERROR,\n CACHED_NO_START_PATH_ERROR,\n} from \"./constants\";\nimport { getStartRouterArguments, resolveStartState } from \"./helpers\";\nimport { errorCodes, events } from \"../../constants\";\nimport { RouterError } from \"../../RouterError\";\n\nimport type {\n RouterLifecycleDependencies,\n StartRouterArguments,\n} from \"./types\";\nimport type {\n CancelFn,\n DoneFn,\n NavigationOptions,\n Params,\n RouterError as RouterErrorType,\n State,\n} from \"@real-router/types\";\n\n// âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n// CYCLIC DEPENDENCIES\n// âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n// RouterLifecycle â Navigation.navigateToState() (for start transitions)\n// RouterLifecycle â Navigation.isNavigating() (check before stop)\n//\n// Solution: functional references configured in Router.#setupDependencies()\n// âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n\n/**\n * Independent namespace for managing router lifecycle.\n *\n * Handles start(), stop(), isStarted(), and isActive().\n */\nexport class RouterLifecycleNamespace {\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n // Functional references for cyclic dependencies\n // âââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââââ\n\n /**\n * Functional reference to NavigationNamespace.navigateToState().\n * Must be set before calling start().\n */\n\n navigateToState!: (\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ) => CancelFn;\n\n #started = false;\n #active = false;\n\n // Dependencies injected via setDependencies (replaces full router reference)\n #depsStore: RouterLifecycleDependencies | undefined;\n\n /**\n * Gets dependencies or throws if not initialized.\n */\n get #deps(): RouterLifecycleDependencies {\n /* v8 ignore next 3 -- @preserve: deps always set by Router.ts */\n if (!this.#depsStore) {\n throw new Error(\n \"[real-router] RouterLifecycleNamespace: dependencies not initialized\",\n );\n }\n\n return this.#depsStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates start() arguments.\n */\n static validateStartArgs(args: unknown[]): void {\n if (args.length > 2) {\n throw new Error(\n \"[router.start] Invalid number of arguments. Expected 0-2 arguments.\",\n );\n }\n }\n\n // =========================================================================\n // Dependency injection\n // =========================================================================\n\n /**\n * Sets dependencies for lifecycle operations.\n * Must be called before using lifecycle methods.\n */\n setDependencies(deps: RouterLifecycleDependencies): void {\n this.#depsStore = deps;\n }\n\n // =========================================================================\n // Instance methods\n // =========================================================================\n\n /**\n * Checks if the router has completed its initial start.\n */\n isStarted(): boolean {\n return this.#started;\n }\n\n /**\n * Checks if the router is starting or started (allows transitions).\n * Used by transition to check if transitions should be cancelled.\n */\n isActive(): boolean {\n return this.#active;\n }\n\n /**\n * Starts the router with an optional path or state.\n */\n start(...args: StartRouterArguments): void {\n const deps = this.#deps;\n const options = deps.getOptions();\n const [startPathOrState, done] = getStartRouterArguments(args);\n\n let callbackInvoked = false;\n\n // Early return if already started or starting (concurrent start() protection)\n // Issue #50: Check both isStarted() and isActive() to block concurrent start() calls\n // - isStarted(): Router has completed initial start\n // - isActive(): Router is in the process of starting (async transition in progress)\n // Performance: Uses cached error to avoid object allocation (~500ns-2Ξs saved)\n if (this.#started || this.#active) {\n callbackInvoked = true;\n\n done(CACHED_ALREADY_STARTED_ERROR);\n\n return;\n }\n\n // ==========================================================================\n // Early return for NO_START_PATH_OR_STATE (Performance Optimization)\n // ==========================================================================\n // Check BEFORE setIsActive() to avoid:\n // - setIsActive/unsetIsActive calls\n // - handleTransitionComplete overhead\n // - Event emission setup\n //\n // This is a common error case: start() called without path and no defaultRoute.\n // Optimizing this path saves ~80% of error handling overhead.\n // ==========================================================================\n if (!startPathOrState && !options.defaultRoute) {\n callbackInvoked = true;\n\n // Lazy emit: only invoke if listeners exist\n // hasListeners check (~5ns) vs invokeEventListeners validation (~100ns+)\n if (deps.hasListeners(events.TRANSITION_ERROR)) {\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n undefined,\n CACHED_NO_START_PATH_ERROR,\n );\n }\n\n done(CACHED_NO_START_PATH_ERROR);\n\n return;\n }\n\n // Issue #50: Mark router as active BEFORE attempting transition\n // This allows the transition to proceed (isCancelled() checks isActive())\n this.#active = true;\n\n const protectedDone = (err?: RouterError, state?: State) => {\n /* v8 ignore next 5 -- @preserve defensive: protects against user callback bugs */\n if (callbackInvoked) {\n logger.warn(\"real-router\", \"Callback already invoked\");\n\n return;\n }\n\n callbackInvoked = true;\n // State is already frozen from makeState() in start flow\n done(err, state);\n };\n\n // Base options for all operations in start() method\n const startOptions: NavigationOptions = {\n replace: true, // start() always replace history\n };\n\n // Centralized callback for transition completion\n // See: https://github.com/greydragon888/real-router/issues/44\n // Transition errors are always reported (no silent fallback to defaultRoute)\n //\n // See: https://github.com/greydragon888/real-router/issues/50\n // Two-phase start: Only mark router as started AFTER successful transition\n // This prevents inconsistent state where isStarted()=true but getState()=undefined\n //\n // Note: emitErrorEvent controls whether TRANSITION_ERROR event is emitted:\n // - true: for errors NOT going through navigateToState (ROUTE_NOT_FOUND, NO_START_PATH_OR_STATE)\n // - false: for errors from performTransition (navigateToState already emits TRANSITION_ERROR)\n const handleTransitionComplete = (\n err?: RouterError,\n state?: State,\n emitErrorEvent = false,\n ) => {\n if (err) {\n // Issue #50: Unset active flag on failure (router is no longer starting)\n this.#active = false;\n\n if (emitErrorEvent && deps.hasListeners(events.TRANSITION_ERROR)) {\n // Emit TRANSITION_ERROR for errors not going through navigateToState\n // Performance: Skip emission if no listeners\n deps.invokeEventListeners(\n events.TRANSITION_ERROR,\n undefined,\n undefined,\n err,\n );\n }\n } else {\n // Two-phase start: Only set started and emit ROUTER_START on success\n // See: https://github.com/greydragon888/real-router/issues/50\n this.#started = true;\n deps.invokeEventListeners(events.ROUTER_START);\n\n deps.invokeEventListeners(events.TRANSITION_SUCCESS, state, undefined, {\n replace: true,\n });\n }\n // For performTransition errors, TRANSITION_ERROR is already emitted by navigateToState\n\n protectedDone(err, state);\n };\n\n // Perform the actual transition\n // See: https://github.com/greydragon888/real-router/issues/44\n // On error, always report to handleTransitionComplete (no silent fallback)\n const performTransition = (\n toState: State,\n navOptions: NavigationOptions = {},\n ) => {\n // Use functional reference to NavigationNamespace.navigateToState\n this.navigateToState(\n toState,\n undefined,\n navOptions,\n (err: RouterErrorType | undefined, resultState: State | undefined) => {\n handleTransitionComplete(err, resultState);\n },\n false, // emitSuccess = false - handleTransitionComplete will emit\n );\n };\n\n // Build state for default route and perform transition\n // Uses performTransition to properly handle two-phase start\n const navigateToDefault = (\n defaultRouteName: string,\n defaultParams: Params,\n navOptions: NavigationOptions,\n ) => {\n const defaultRoute = deps.buildState(defaultRouteName, defaultParams);\n\n if (!defaultRoute) {\n handleTransitionComplete(\n new RouterError(errorCodes.ROUTE_NOT_FOUND, {\n routeName: defaultRouteName,\n }),\n undefined,\n true,\n );\n\n return;\n }\n\n const toState = deps.makeState(\n defaultRoute.name,\n defaultRoute.params,\n deps.buildPath(defaultRoute.name, defaultRoute.params),\n {\n params: defaultRoute.meta,\n options: navOptions,\n redirected: false,\n },\n );\n\n performTransition(toState, navOptions);\n };\n\n // Resolve start path/state: use defaultRoute if no explicit path provided\n // Note: Early return for \"no path AND no defaultRoute\" is handled above\n const resolvedStartPathOrState = startPathOrState ?? options.defaultRoute;\n\n // Parse the start path or state\n const startState = resolveStartState(resolvedStartPathOrState, deps);\n\n // Determine the target state and path\n const targetPath =\n typeof resolvedStartPathOrState === \"string\"\n ? resolvedStartPathOrState\n : \"\";\n\n // Perform transition based on conditions\n // All start() transitions should use replace: true\n // See: https://github.com/greydragon888/real-router/issues/43\n if (startState) {\n performTransition(startState, startOptions);\n } else if (options.defaultRoute && !startPathOrState) {\n // IMPORTANT: Check !startPathOrState (original argument), NOT !resolvedStartPathOrState\n // This distinguishes between:\n // - User called start() without path â use defaultRoute (this branch)\n // - User called start('/invalid') with explicit path â error, no silent fallback\n // See: https://github.com/greydragon888/real-router/issues/44\n\n const params = options.defaultParams;\n\n navigateToDefault(options.defaultRoute, params, startOptions);\n } else if (options.allowNotFound) {\n performTransition(\n deps.makeNotFoundState(targetPath, startOptions),\n startOptions,\n );\n } else {\n handleTransitionComplete(\n new RouterError(errorCodes.ROUTE_NOT_FOUND, { path: targetPath }),\n undefined,\n true, // emitErrorEvent: doesn't go through navigateToState\n );\n }\n }\n\n /**\n * Stops the router and resets state.\n */\n stop(): void {\n const deps = this.#deps;\n\n // Issue #50: Always unset active flag when stopping\n // This cancels any in-flight transitions via isCancelled() check\n this.#active = false;\n\n if (this.#started) {\n this.#started = false;\n\n deps.setState();\n\n deps.invokeEventListeners(events.ROUTER_STOP);\n }\n }\n}\n","// packages/core/src/namespaces/CloneNamespace/CloneNamespace.ts\n\nimport { getTypeDescription } from \"type-guards\";\n\nimport type { ApplyConfigFn, CloneData, RouterFactory } from \"./types\";\nimport type { Router } from \"../../Router\";\nimport type { DefaultDependencies } from \"@real-router/types\";\n\n/**\n * Independent namespace for router cloning operations.\n *\n * This namespace handles the logic of collecting data from a source router\n * and creating a configured clone. It requires a factory function to create\n * the new router instance.\n */\nexport class CloneNamespace<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n // =========================================================================\n // Instance fields\n // =========================================================================\n\n /**\n * Function to get cloning data from the source router.\n */\n #getCloneDataStore: (() => CloneData<Dependencies>) | undefined;\n\n /**\n * Function to apply config to a new router.\n */\n #applyConfigStore: ApplyConfigFn | undefined;\n\n /**\n * Gets clone data function or throws if not initialized.\n */\n get #getCloneData(): () => CloneData<Dependencies> {\n /* v8 ignore next 3 -- @preserve: always set by Router.ts */\n if (!this.#getCloneDataStore) {\n throw new Error(\n \"[real-router] CloneNamespace: getCloneData not initialized\",\n );\n }\n\n return this.#getCloneDataStore;\n }\n\n /**\n * Gets apply config function or throws if not initialized.\n */\n get #applyConfig(): ApplyConfigFn {\n /* v8 ignore next 3 -- @preserve: always set by Router.ts */\n if (!this.#applyConfigStore) {\n throw new Error(\n \"[real-router] CloneNamespace: applyConfig not initialized\",\n );\n }\n\n return this.#applyConfigStore;\n }\n\n // =========================================================================\n // Static validation methods (called by facade before instance methods)\n // =========================================================================\n\n /**\n * Validates clone arguments.\n * Dependencies can be undefined or a plain object without getters.\n */\n static validateCloneArgs(dependencies: unknown): void {\n // undefined is valid (no new dependencies)\n if (dependencies === undefined) {\n return;\n }\n\n // Must be a plain object\n if (\n !(\n dependencies &&\n typeof dependencies === \"object\" &&\n dependencies.constructor === Object\n )\n ) {\n throw new TypeError(\n `[router.clone] Invalid dependencies: expected plain object or undefined, received ${getTypeDescription(dependencies)}`,\n );\n }\n\n // Getters can throw, return different values, or have side effects\n for (const key in dependencies) {\n if (Object.getOwnPropertyDescriptor(dependencies, key)?.get) {\n throw new TypeError(\n `[router.clone] Getters not allowed in dependencies: \"${key}\"`,\n );\n }\n }\n }\n\n /**\n * Sets the cloning functions.\n */\n setCallbacks(\n getCloneData: () => CloneData<Dependencies>,\n applyConfig: ApplyConfigFn,\n ): void {\n this.#getCloneDataStore = getCloneData;\n this.#applyConfigStore = applyConfig;\n }\n\n /**\n * Creates a clone of the router with optional new dependencies.\n *\n * @param dependencies - Optional new dependencies for the cloned router\n * @param factory - Factory function to create the new router instance\n */\n clone(\n dependencies: Dependencies | undefined,\n factory: RouterFactory<Dependencies>,\n ): Router<Dependencies> {\n // Collect all data from source router\n const data = this.#getCloneData();\n\n // Merge dependencies\n const mergedDeps = {\n ...data.dependencies,\n ...dependencies,\n } as Dependencies;\n\n // Create new router instance\n const newRouter = factory(data.routes, data.options, mergedDeps);\n\n // Copy lifecycle factories\n for (const [name, handler] of Object.entries(data.canDeactivateFactories)) {\n newRouter.canDeactivate(name, handler);\n }\n\n for (const [name, handler] of Object.entries(data.canActivateFactories)) {\n newRouter.canActivate(name, handler);\n }\n\n // Copy middleware factories\n if (data.middlewareFactories.length > 0) {\n newRouter.useMiddleware(...data.middlewareFactories);\n }\n\n // Copy plugin factories\n if (data.pluginFactories.length > 0) {\n newRouter.usePlugin(...data.pluginFactories);\n }\n\n // Apply route config (decoders, encoders, defaultParams, forwardMap)\n this.#applyConfig(\n newRouter as unknown as Router,\n data.routeConfig,\n data.resolvedForwardMap,\n );\n\n return newRouter;\n }\n}\n","// packages/real-router/modules/typeGuards.ts\n\n/**\n * Re-export common type guards from centralized type-guards package\n */\nimport type { LoggerConfig, LogLevelConfig } from \"@real-router/logger\";\n\nexport {\n isObjKey,\n isString,\n isState,\n isParams,\n isNavigationOptions,\n isPromise,\n isBoolean,\n validateRouteName,\n} from \"type-guards\";\n\n/**\n * RealRouter-specific type guards for logger configuration\n */\n\nconst VALID_LEVELS_SET = new Set<string>([\"all\", \"warn-error\", \"error-only\"]);\n\nfunction isValidLevel(value: unknown): value is LogLevelConfig {\n return typeof value === \"string\" && VALID_LEVELS_SET.has(value);\n}\n\nfunction formatValue(value: unknown): string {\n if (typeof value === \"string\") {\n return `\"${value}\"`;\n }\n if (typeof value === \"object\") {\n return JSON.stringify(value);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-base-to-string\n return String(value);\n}\n\nexport function isLoggerConfig(config: unknown): config is LoggerConfig {\n if (typeof config !== \"object\" || config === null) {\n throw new TypeError(\"Logger config must be an object\");\n }\n\n const obj = config;\n\n // Check for unknown properties\n for (const key of Object.keys(obj)) {\n if (key !== \"level\" && key !== \"callback\") {\n throw new TypeError(`Unknown logger config property: \"${key}\"`);\n }\n }\n\n // Validate level if present\n if (\"level\" in obj && obj.level !== undefined && !isValidLevel(obj.level)) {\n throw new TypeError(\n `Invalid logger level: ${formatValue(obj.level)}. Expected: \"all\" | \"warn-error\" | \"error-only\"`,\n );\n }\n\n // Validate callback if present\n if (\n \"callback\" in obj &&\n obj.callback !== undefined &&\n typeof obj.callback !== \"function\"\n ) {\n throw new TypeError(\n `Logger callback must be a function, got ${typeof obj.callback}`,\n );\n }\n\n return true;\n}\n","// packages/core/src/Router.ts\n\n/**\n * Router class - facade with integrated namespaces.\n *\n * All functionality is now provided by namespace classes.\n */\n\nimport { logger } from \"@real-router/logger\";\nimport { validateRouteName } from \"type-guards\";\n\nimport { createLimits } from \"./helpers\";\nimport {\n CloneNamespace,\n DependenciesNamespace,\n MiddlewareNamespace,\n NavigationNamespace,\n ObservableNamespace,\n OptionsNamespace,\n PluginsNamespace,\n RouteLifecycleNamespace,\n RouterLifecycleNamespace,\n RoutesNamespace,\n StateNamespace,\n} from \"./namespaces\";\nimport { isLoggerConfig } from \"./typeGuards\";\n\nimport type { EventMethodMap } from \"./namespaces\";\nimport type { MiddlewareDependencies } from \"./namespaces/MiddlewareNamespace\";\nimport type {\n NavigationDependencies,\n TransitionDependencies,\n} from \"./namespaces/NavigationNamespace\";\nimport type { PluginsDependencies } from \"./namespaces/PluginsNamespace\";\nimport type { RouteLifecycleDependencies } from \"./namespaces/RouteLifecycleNamespace\";\nimport type { RouterLifecycleDependencies } from \"./namespaces/RouterLifecycleNamespace\";\nimport type { RoutesDependencies } from \"./namespaces/RoutesNamespace\";\nimport type {\n ActivationFnFactory,\n Limits,\n MiddlewareFactory,\n PluginFactory,\n Route,\n RouteConfigUpdate,\n} from \"./types\";\nimport type {\n CancelFn,\n DefaultDependencies,\n DoneFn,\n EventName,\n NavigationOptions,\n Navigator,\n Options,\n Params,\n Plugin,\n RouteTreeState,\n SimpleState,\n State,\n StateMetaInput,\n SubscribeFn,\n Unsubscribe,\n} from \"@real-router/types\";\n\n/**\n * Router class with integrated namespace architecture.\n *\n * All functionality is provided by namespace classes:\n * - OptionsNamespace: getOptions, setOption\n * - DependenciesNamespace: get/set/remove dependencies\n * - ObservableNamespace: event listeners, subscribe\n * - StateNamespace: state storage (getState, setState, getPreviousState)\n * - RoutesNamespace: route tree operations\n * - RouteLifecycleNamespace: canActivate/canDeactivate guards\n * - MiddlewareNamespace: middleware chain\n * - PluginsNamespace: plugin lifecycle\n * - NavigationNamespace: navigate, navigateToState\n * - RouterLifecycleNamespace: start, stop, isStarted\n *\n * @internal This class implementation is internal. Use createRouter() instead.\n */\nexport class Router<\n Dependencies extends DefaultDependencies = DefaultDependencies,\n> {\n // Index signatures to satisfy interface\n [key: string]: unknown;\n\n // ============================================================================\n // Namespaces\n // ============================================================================\n\n readonly #options: OptionsNamespace;\n readonly #limits: Limits;\n readonly #dependencies: DependenciesNamespace<Dependencies>;\n readonly #observable: ObservableNamespace;\n readonly #state: StateNamespace;\n readonly #routes: RoutesNamespace<Dependencies>;\n readonly #routeLifecycle: RouteLifecycleNamespace<Dependencies>;\n readonly #middleware: MiddlewareNamespace<Dependencies>;\n readonly #plugins: PluginsNamespace<Dependencies>;\n readonly #navigation: NavigationNamespace;\n readonly #lifecycle: RouterLifecycleNamespace;\n readonly #clone: CloneNamespace<Dependencies>;\n\n /**\n * Cached Navigator instance. Lazily created on first getNavigator() call.\n */\n #navigator: Navigator | null = null;\n\n /**\n * When true, skips argument validation in public methods for production performance.\n * Constructor options are always validated (needed to validate noValidate itself).\n */\n readonly #noValidate: boolean;\n\n // ============================================================================\n // Constructor\n // ============================================================================\n\n /**\n * @param routes - Route definitions\n * @param options - Router options\n * @param dependencies - DI dependencies\n */\n constructor(\n routes: Route<Dependencies>[] = [],\n options: Partial<Options> = {},\n dependencies: Dependencies = {} as Dependencies,\n ) {\n // Configure logger if provided\n if (options.logger && isLoggerConfig(options.logger)) {\n logger.configure(options.logger);\n delete options.logger;\n }\n\n // =========================================================================\n // Validate inputs before creating namespaces\n // =========================================================================\n\n // Always validate options (needed to validate noValidate itself)\n OptionsNamespace.validateOptions(options, \"constructor\");\n\n // Extract noValidate BEFORE creating namespaces\n const noValidate = options.noValidate ?? false;\n\n // Conditional validation for dependencies\n if (!noValidate) {\n DependenciesNamespace.validateDependenciesObject(\n dependencies,\n \"constructor\",\n );\n }\n\n // Conditional validation for initial routes - structure and batch duplicates\n // Validation happens BEFORE tree is built, so tree is not passed\n if (!noValidate && routes.length > 0) {\n RoutesNamespace.validateAddRouteArgs(routes);\n RoutesNamespace.validateRoutes(routes);\n }\n\n // =========================================================================\n // Create Namespaces\n // =========================================================================\n\n this.#options = new OptionsNamespace(options);\n this.#limits = createLimits(options.limits);\n this.#dependencies = new DependenciesNamespace<Dependencies>(dependencies);\n this.#observable = new ObservableNamespace();\n this.#state = new StateNamespace();\n this.#routes = new RoutesNamespace<Dependencies>(routes, noValidate);\n this.#routeLifecycle = new RouteLifecycleNamespace<Dependencies>();\n this.#middleware = new MiddlewareNamespace<Dependencies>();\n this.#plugins = new PluginsNamespace<Dependencies>();\n this.#navigation = new NavigationNamespace();\n this.#lifecycle = new RouterLifecycleNamespace();\n this.#clone = new CloneNamespace<Dependencies>();\n this.#noValidate = noValidate;\n\n // =========================================================================\n // Setup Dependencies\n // =========================================================================\n\n this.#setupDependencies();\n\n // =========================================================================\n // Bind Public Methods\n // =========================================================================\n // All public methods that access private fields must be bound to preserve\n // `this` context when methods are extracted as references.\n // See: https://github.com/nicolo-ribaudo/tc39-proposal-bind-operator\n // =========================================================================\n\n // Route Management\n this.addRoute = this.addRoute.bind(this);\n this.removeRoute = this.removeRoute.bind(this);\n this.clearRoutes = this.clearRoutes.bind(this);\n this.getRoute = this.getRoute.bind(this);\n this.hasRoute = this.hasRoute.bind(this);\n this.updateRoute = this.updateRoute.bind(this);\n\n // Path & State Building\n this.isActiveRoute = this.isActiveRoute.bind(this);\n this.buildPath = this.buildPath.bind(this);\n this.matchPath = this.matchPath.bind(this);\n this.setRootPath = this.setRootPath.bind(this);\n this.getRootPath = this.getRootPath.bind(this);\n\n // State Management\n this.makeState = this.makeState.bind(this);\n this.getState = this.getState.bind(this);\n this.getPreviousState = this.getPreviousState.bind(this);\n this.areStatesEqual = this.areStatesEqual.bind(this);\n this.forwardState = this.forwardState.bind(this);\n this.buildState = this.buildState.bind(this);\n this.shouldUpdateNode = this.shouldUpdateNode.bind(this);\n\n // Options\n this.getOptions = this.getOptions.bind(this);\n this.getOption = this.getOption.bind(this);\n this.setOption = this.setOption.bind(this);\n\n // Router Lifecycle\n this.isActive = this.isActive.bind(this);\n this.start = this.start.bind(this);\n this.stop = this.stop.bind(this);\n\n // Route Lifecycle (Guards)\n this.canDeactivate = this.canDeactivate.bind(this);\n this.canActivate = this.canActivate.bind(this);\n\n // Plugins\n this.usePlugin = this.usePlugin.bind(this);\n\n // Middleware\n this.useMiddleware = this.useMiddleware.bind(this);\n this.clearMiddleware = this.clearMiddleware.bind(this);\n\n // Dependencies\n this.setDependency = this.setDependency.bind(this);\n this.setDependencies = this.setDependencies.bind(this);\n this.getDependency = this.getDependency.bind(this);\n this.getDependencies = this.getDependencies.bind(this);\n this.removeDependency = this.removeDependency.bind(this);\n this.hasDependency = this.hasDependency.bind(this);\n this.resetDependencies = this.resetDependencies.bind(this);\n\n // Events\n this.addEventListener = this.addEventListener.bind(this);\n\n // Navigation\n this.navigate = this.navigate.bind(this);\n this.navigateToDefault = this.navigateToDefault.bind(this);\n this.navigateToState = this.navigateToState.bind(this);\n\n // Subscription\n this.subscribe = this.subscribe.bind(this);\n\n // Cloning\n this.clone = this.clone.bind(this);\n }\n\n // ============================================================================\n // Route Management\n // ============================================================================\n\n addRoute(routes: Route<Dependencies>[] | Route<Dependencies>): this {\n const routeArray = Array.isArray(routes) ? routes : [routes];\n\n if (!this.#noValidate) {\n // 1. Static validation (route structure and properties)\n RoutesNamespace.validateAddRouteArgs(routeArray);\n\n // 2. State-dependent validation (duplicates, parent exists, forwardTo)\n RoutesNamespace.validateRoutes(\n routeArray,\n this.#routes.getTree(),\n this.#routes.getForwardRecord(),\n );\n }\n\n // 3. Execute (add definitions, register handlers, rebuild tree)\n this.#routes.addRoutes(routeArray);\n\n return this;\n }\n\n removeRoute(name: string): this {\n // Static validation\n if (!this.#noValidate) {\n RoutesNamespace.validateRemoveRouteArgs(name);\n }\n\n // Instance validation (checks active route, navigation state)\n const canRemove = this.#routes.validateRemoveRoute(\n name,\n this.#state.get()?.name,\n this.#navigation.isNavigating(),\n );\n\n if (!canRemove) {\n return this;\n }\n\n // Perform removal\n const wasRemoved = this.#routes.removeRoute(name);\n\n if (!wasRemoved) {\n logger.warn(\n \"router.removeRoute\",\n `Route \"${name}\" not found. No changes made.`,\n );\n }\n\n return this;\n }\n\n clearRoutes(): this {\n // Validate operation can proceed\n const canClear = this.#routes.validateClearRoutes(\n this.#navigation.isNavigating(),\n );\n\n if (!canClear) {\n return this;\n }\n\n // Clear routes config (definitions, decoders, encoders, defaultParams, forwardMap)\n this.#routes.clearRoutes();\n\n // Clear all lifecycle handlers\n this.#routeLifecycle.clearAll();\n\n // Clear router state since all routes are removed\n this.#state.set(undefined);\n\n return this;\n }\n\n getRoute(name: string): Route<Dependencies> | undefined {\n if (!this.#noValidate) {\n validateRouteName(name, \"getRoute\");\n }\n\n return this.#routes.getRoute(name);\n }\n\n hasRoute(name: string): boolean {\n if (!this.#noValidate) {\n validateRouteName(name, \"hasRoute\");\n }\n\n return this.#routes.hasRoute(name);\n }\n\n updateRoute(name: string, updates: RouteConfigUpdate<Dependencies>): this {\n // Validate name and updates object structure (basic checks only)\n if (!this.#noValidate) {\n RoutesNamespace.validateUpdateRouteBasicArgs(name, updates);\n }\n\n // Cache all property values upfront to protect against mutating getters.\n // This ensures consistent behavior regardless of getter side effects.\n // Must happen AFTER basic validation but BEFORE property type validation.\n const {\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n canActivate,\n } = updates;\n\n // Validate cached property values\n if (!this.#noValidate) {\n RoutesNamespace.validateUpdateRoutePropertyTypes(\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n );\n }\n\n // Warn if navigation is in progress\n if (this.#navigation.isNavigating()) {\n logger.error(\n \"router.updateRoute\",\n `Updating route \"${name}\" while navigation is in progress. This may cause unexpected behavior.`,\n );\n }\n\n // Instance validation (route existence, forwardTo checks) - use cached values\n if (!this.#noValidate) {\n this.#routes.validateUpdateRoute(name, forwardTo);\n }\n\n // Update route config\n this.#routes.updateRouteConfig(name, {\n forwardTo,\n defaultParams,\n decodeParams,\n encodeParams,\n });\n\n // Handle canActivate separately (uses RouteLifecycleNamespace)\n // Use facade method for proper validation\n if (canActivate !== undefined) {\n if (canActivate === null) {\n this.#routeLifecycle.clearCanActivate(name, true);\n } else {\n this.canActivate(name, canActivate);\n }\n }\n\n return this;\n }\n\n // ============================================================================\n // Path & State Building\n // ============================================================================\n\n isActiveRoute(\n name: string,\n params?: Params,\n strictEquality?: boolean,\n ignoreQueryParams?: boolean,\n ): boolean {\n if (!this.#noValidate) {\n RoutesNamespace.validateIsActiveRouteArgs(\n name,\n params,\n strictEquality,\n ignoreQueryParams,\n );\n }\n\n // Empty string is special case - warn and return false (root node is not a parent)\n if (name === \"\") {\n logger.warn(\n \"real-router\",\n 'isActiveRoute(\"\") called with empty string. Root node is not considered a parent of any route.',\n );\n\n return false;\n }\n\n return this.#routes.isActiveRoute(\n name,\n params,\n strictEquality,\n ignoreQueryParams,\n );\n }\n\n buildPath(route: string, params?: Params): string {\n if (!this.#noValidate) {\n RoutesNamespace.validateBuildPathArgs(route);\n }\n\n return this.#routes.buildPath(route, params, this.#options.get());\n }\n\n matchPath<P extends Params = Params, MP extends Params = Params>(\n path: string,\n source?: string,\n ): State<P, MP> | undefined {\n if (!this.#noValidate) {\n RoutesNamespace.validateMatchPathArgs(path);\n }\n\n return this.#routes.matchPath<P, MP>(path, source, this.#options.get());\n }\n\n setRootPath(rootPath: string): void {\n if (!this.#noValidate) {\n RoutesNamespace.validateSetRootPathArgs(rootPath);\n }\n\n this.#routes.setRootPath(rootPath);\n }\n\n getRootPath(): string {\n return this.#routes.getRootPath();\n }\n\n // ============================================================================\n // State Management (delegated to StateNamespace)\n // ============================================================================\n\n makeState<P extends Params = Params, MP extends Params = Params>(\n name: string,\n params?: P,\n path?: string,\n meta?: StateMetaInput<MP>,\n forceId?: number,\n ): State<P, MP> {\n if (!this.#noValidate) {\n StateNamespace.validateMakeStateArgs(name, params, path, forceId);\n }\n\n return this.#state.makeState<P, MP>(name, params, path, meta, forceId);\n }\n\n getState<P extends Params = Params, MP extends Params = Params>():\n | State<P, MP>\n | undefined {\n return this.#state.get<P, MP>();\n }\n\n getPreviousState(): State | undefined {\n return this.#state.getPrevious();\n }\n\n areStatesEqual(\n state1: State | undefined,\n state2: State | undefined,\n ignoreQueryParams = true,\n ): boolean {\n if (!this.#noValidate) {\n StateNamespace.validateAreStatesEqualArgs(\n state1,\n state2,\n ignoreQueryParams,\n );\n }\n\n return this.#state.areStatesEqual(state1, state2, ignoreQueryParams);\n }\n\n forwardState<P extends Params = Params>(\n routeName: string,\n routeParams: P,\n ): SimpleState<P> {\n if (!this.#noValidate) {\n RoutesNamespace.validateStateBuilderArgs(\n routeName,\n routeParams,\n \"forwardState\",\n );\n }\n\n return this.#routes.forwardState<P>(routeName, routeParams);\n }\n\n buildState(\n routeName: string,\n routeParams: Params,\n ): RouteTreeState | undefined {\n if (!this.#noValidate) {\n RoutesNamespace.validateStateBuilderArgs(\n routeName,\n routeParams,\n \"buildState\",\n );\n }\n\n // Call forwardState at facade level to allow plugin interception\n const { name, params } = this.forwardState(routeName, routeParams);\n\n return this.#routes.buildStateResolved(name, params);\n }\n\n shouldUpdateNode(\n nodeName: string,\n ): (toState: State, fromState?: State) => boolean {\n if (!this.#noValidate) {\n RoutesNamespace.validateShouldUpdateNodeArgs(nodeName);\n }\n\n return this.#routes.shouldUpdateNode(nodeName);\n }\n\n // ============================================================================\n // Options (backed by OptionsNamespace)\n // ============================================================================\n\n getOptions(): Options {\n return this.#options.get();\n }\n\n getOption<K extends keyof Options>(option: K): Options[K] {\n if (!this.#noValidate) {\n OptionsNamespace.validateOptionName(option, \"getOption\");\n OptionsNamespace.validateOptionExists(option, \"getOption\");\n }\n\n return this.#options.getOption(option);\n }\n\n setOption(option: keyof Options, value: Options[keyof Options]): this {\n if (!this.#noValidate) {\n OptionsNamespace.validateOptionName(option, \"setOption\");\n OptionsNamespace.validateOptionExists(option, \"setOption\");\n OptionsNamespace.validateNotLocked(this.#options.isLocked(), option);\n OptionsNamespace.validateOptionValue(option, value, \"setOption\");\n }\n\n this.#options.set(option, value);\n\n return this;\n }\n\n // ============================================================================\n // Router Lifecycle\n // ============================================================================\n\n isActive(): boolean {\n return this.#lifecycle.isActive();\n }\n\n start(\n ...args:\n | []\n | [done: DoneFn]\n | [startPathOrState: string | State]\n | [startPathOrState: string | State, done: DoneFn]\n ): this {\n // Static validation\n if (!this.#noValidate) {\n RouterLifecycleNamespace.validateStartArgs(args);\n }\n\n // Lock options when router starts\n this.#options.lock();\n\n // Initialize build options cache\n this.#routes.initBuildOptionsCache(this.#options.get());\n\n // Forward to lifecycle namespace\n this.#lifecycle.start(...args);\n\n return this;\n }\n\n stop(): this {\n this.#lifecycle.stop();\n\n // Clear build options cache\n this.#routes.clearBuildOptionsCache();\n\n // Unlock options when router stops\n this.#options.unlock();\n\n return this;\n }\n\n // ============================================================================\n // Route Lifecycle (Guards)\n // ============================================================================\n\n canDeactivate(\n name: string,\n canDeactivateHandler: ActivationFnFactory<Dependencies> | boolean,\n ): this {\n if (!this.#noValidate) {\n // 1. Validate input\n validateRouteName(name, \"canDeactivate\");\n RouteLifecycleNamespace.validateHandler(\n canDeactivateHandler,\n \"canDeactivate\",\n );\n\n // 2. Validate not registering\n RouteLifecycleNamespace.validateNotRegistering(\n this.#routeLifecycle.isRegistering(name),\n name,\n \"canDeactivate\",\n );\n }\n\n // 3. Check if overwrite and validate limit\n const isOverwrite = this.#routeLifecycle.hasCanDeactivate(name);\n\n if (!isOverwrite && !this.#noValidate) {\n RouteLifecycleNamespace.validateHandlerLimit(\n this.#routeLifecycle.countCanDeactivate() + 1,\n \"canDeactivate\",\n this.#limits.maxLifecycleHandlers,\n );\n }\n\n // 4. Execute\n this.#routeLifecycle.registerCanDeactivate(\n name,\n canDeactivateHandler,\n isOverwrite,\n );\n\n return this;\n }\n\n canActivate(\n name: string,\n canActivateHandler: ActivationFnFactory<Dependencies> | boolean,\n ): this {\n if (!this.#noValidate) {\n // 1. Validate input\n validateRouteName(name, \"canActivate\");\n RouteLifecycleNamespace.validateHandler(\n canActivateHandler,\n \"canActivate\",\n );\n\n // 2. Validate not registering\n RouteLifecycleNamespace.validateNotRegistering(\n this.#routeLifecycle.isRegistering(name),\n name,\n \"canActivate\",\n );\n }\n\n // 3. Check if overwrite and validate limit\n const isOverwrite = this.#routeLifecycle.hasCanActivate(name);\n\n if (!isOverwrite && !this.#noValidate) {\n RouteLifecycleNamespace.validateHandlerLimit(\n this.#routeLifecycle.countCanActivate() + 1,\n \"canActivate\",\n this.#limits.maxLifecycleHandlers,\n );\n }\n\n // 4. Execute\n this.#routeLifecycle.registerCanActivate(\n name,\n canActivateHandler,\n isOverwrite,\n );\n\n return this;\n }\n\n // ============================================================================\n // Plugins\n // ============================================================================\n\n usePlugin(...plugins: PluginFactory<Dependencies>[]): Unsubscribe {\n if (!this.#noValidate) {\n // 1. Validate input arguments\n PluginsNamespace.validateUsePluginArgs<Dependencies>(plugins);\n\n // 2. Validate limit\n PluginsNamespace.validatePluginLimit(\n this.#plugins.count(),\n plugins.length,\n this.#limits.maxPlugins,\n );\n\n // 3. Validate no duplicates with existing plugins\n PluginsNamespace.validateNoDuplicatePlugins(\n plugins,\n this.#plugins.has.bind(this.#plugins),\n );\n }\n\n // 4. Execute (warnings, deduplication, initialization, commit)\n return this.#plugins.use(...plugins);\n }\n\n // ============================================================================\n // Middleware\n // ============================================================================\n\n useMiddleware(\n ...middlewares: MiddlewareFactory<Dependencies>[]\n ): Unsubscribe {\n if (!this.#noValidate) {\n // 1. Validate input arguments\n MiddlewareNamespace.validateUseMiddlewareArgs<Dependencies>(middlewares);\n\n // 2. Validate no duplicates\n MiddlewareNamespace.validateNoDuplicates<Dependencies>(\n middlewares,\n this.#middleware.getFactories(),\n );\n\n // 3. Validate limit\n MiddlewareNamespace.validateMiddlewareLimit(\n this.#middleware.count(),\n middlewares.length,\n this.#limits.maxMiddleware,\n );\n }\n\n // 4. Initialize (without committing)\n const initialized = this.#middleware.initialize(...middlewares);\n\n // 5. Validate results\n if (!this.#noValidate) {\n for (const { middleware, factory } of initialized) {\n MiddlewareNamespace.validateMiddleware<Dependencies>(\n middleware,\n factory,\n );\n }\n }\n\n // 6. Commit\n return this.#middleware.commit(initialized);\n }\n\n clearMiddleware(): this {\n this.#middleware.clear();\n\n return this;\n }\n\n // ============================================================================\n // Dependencies (backed by DependenciesNamespace)\n // ============================================================================\n\n setDependency<K extends keyof Dependencies & string>(\n dependencyName: K,\n dependency: Dependencies[K],\n ): this {\n if (!this.#noValidate) {\n DependenciesNamespace.validateSetDependencyArgs(dependencyName);\n }\n\n this.#dependencies.set(dependencyName, dependency);\n\n return this;\n }\n\n setDependencies(deps: Dependencies): this {\n if (!this.#noValidate) {\n DependenciesNamespace.validateDependenciesObject(deps, \"setDependencies\");\n DependenciesNamespace.validateDependencyLimit(\n this.#dependencies.count(),\n Object.keys(deps).length,\n \"setDependencies\",\n this.#limits.maxDependencies,\n );\n }\n\n this.#dependencies.setMultiple(deps);\n\n return this;\n }\n\n getDependency<K extends keyof Dependencies>(key: K): Dependencies[K] {\n if (!this.#noValidate) {\n DependenciesNamespace.validateName(key, \"getDependency\");\n }\n\n const value = this.#dependencies.get(key);\n\n if (!this.#noValidate) {\n DependenciesNamespace.validateDependencyExists(value, key as string);\n }\n\n return value;\n }\n\n getDependencies(): Partial<Dependencies> {\n return this.#dependencies.getAll();\n }\n\n removeDependency(dependencyName: keyof Dependencies): this {\n if (!this.#noValidate) {\n DependenciesNamespace.validateName(dependencyName, \"removeDependency\");\n }\n\n this.#dependencies.remove(dependencyName);\n\n return this;\n }\n\n hasDependency(dependencyName: keyof Dependencies): boolean {\n if (!this.#noValidate) {\n DependenciesNamespace.validateName(dependencyName, \"hasDependency\");\n }\n\n return this.#dependencies.has(dependencyName);\n }\n\n resetDependencies(): this {\n this.#dependencies.reset();\n\n return this;\n }\n\n // ============================================================================\n // Events (backed by ObservableNamespace)\n // ============================================================================\n\n addEventListener<E extends EventName>(\n eventName: E,\n cb: Plugin[EventMethodMap[E]],\n ): Unsubscribe {\n if (!this.#noValidate) {\n ObservableNamespace.validateListenerArgs(eventName, cb);\n }\n\n return this.#observable.addEventListener(eventName, cb);\n }\n\n // ============================================================================\n // Navigation\n // ============================================================================\n\n navigate(\n routeName: string,\n routeParamsOrDone?: Params | DoneFn,\n optionsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): CancelFn {\n // 1. Validate route name\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigateArgs(routeName);\n }\n\n // 2. Parse polymorphic arguments\n const { params, opts, callback } = NavigationNamespace.parseNavigateArgs(\n routeParamsOrDone,\n optionsOrDone,\n done,\n );\n\n // 3. Validate parsed options\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigationOptions(opts, \"navigate\");\n }\n\n // 4. Execute navigation with parsed arguments\n return this.#navigation.navigate(routeName, params, opts, callback);\n }\n\n navigateToDefault(\n optsOrDone?: NavigationOptions | DoneFn,\n done?: DoneFn,\n ): CancelFn {\n // 1. Validate arguments (before parsing)\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigateToDefaultArgs(optsOrDone, done);\n }\n\n // 2. Parse polymorphic arguments\n const { opts, callback } = NavigationNamespace.parseNavigateToDefaultArgs(\n optsOrDone,\n done,\n );\n\n // 3. Validate parsed options\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigationOptions(opts, \"navigateToDefault\");\n }\n\n // 4. Execute navigation with parsed arguments\n return this.#navigation.navigateToDefault(opts, callback);\n }\n\n navigateToState(\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ): CancelFn {\n if (!this.#noValidate) {\n NavigationNamespace.validateNavigateToStateArgs(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n }\n\n return this.#navigation.navigateToState(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n }\n\n // ============================================================================\n // Subscription (backed by ObservableNamespace)\n // ============================================================================\n\n subscribe(listener: SubscribeFn): Unsubscribe {\n if (!this.#noValidate) {\n ObservableNamespace.validateSubscribeListener(listener);\n }\n\n return this.#observable.subscribe(listener);\n }\n\n // ============================================================================\n // Cloning\n // ============================================================================\n\n clone(dependencies?: Dependencies): Router<Dependencies> {\n if (!this.#noValidate) {\n CloneNamespace.validateCloneArgs(dependencies);\n }\n\n return this.#clone.clone(\n dependencies,\n (routes, options, deps) =>\n new Router<Dependencies>(routes, options, deps),\n );\n }\n\n getNavigator(): Navigator {\n this.#navigator ??= Object.freeze({\n navigate: this.navigate,\n getState: this.getState,\n isActiveRoute: this.isActiveRoute,\n subscribe: this.subscribe,\n });\n\n return this.#navigator;\n }\n\n // ============================================================================\n // Private Methods\n // ============================================================================\n\n /**\n * Sets up dependencies between namespaces.\n * Called once in constructor after all namespaces are created.\n */\n #setupDependencies(): void {\n // Set limits for all namespaces that use them\n this.#dependencies.setLimits(this.#limits);\n this.#plugins.setLimits(this.#limits);\n this.#middleware.setLimits(this.#limits);\n this.#observable.setLimits(this.#limits);\n this.#routeLifecycle.setLimits(this.#limits);\n\n // RouteLifecycleNamespace must be set up FIRST because RoutesNamespace.setDependencies()\n // will register pending canActivate handlers which need RouteLifecycleNamespace\n this.#routeLifecycle.setRouter(this);\n\n // RouteLifecycleNamespace uses function injection for getDependency\n const routeLifecycleDeps: RouteLifecycleDependencies<Dependencies> = {\n getDependency: <K extends keyof Dependencies>(dependencyName: K) =>\n this.#dependencies.get(dependencyName),\n };\n\n this.#routeLifecycle.setDependencies(routeLifecycleDeps);\n\n // RoutesNamespace uses function injection (will register pending canActivate handlers)\n // Use facade method for proper validation\n const routesDeps: RoutesDependencies<Dependencies> = {\n canActivate: (name, handler) => {\n this.canActivate(name, handler);\n },\n makeState: (name, params, path, meta) =>\n this.#state.makeState(name, params, path, meta),\n getState: () => this.#state.get(),\n areStatesEqual: (state1, state2, ignoreQueryParams) =>\n this.#state.areStatesEqual(state1, state2, ignoreQueryParams),\n };\n\n this.#routes.setDependencies(routesDeps);\n this.#routes.setLifecycleNamespace(this.#routeLifecycle);\n\n this.#middleware.setRouter(this);\n\n // MiddlewareNamespace uses function injection for getDependency\n const middlewareDeps: MiddlewareDependencies<Dependencies> = {\n getDependency: <K extends keyof Dependencies>(dependencyName: K) =>\n this.#dependencies.get(dependencyName),\n };\n\n this.#middleware.setDependencies(middlewareDeps);\n\n this.#plugins.setRouter(this);\n\n // PluginsNamespace uses function injection for internal @internal method calls\n const pluginsDeps: PluginsDependencies<Dependencies> = {\n addEventListener: (eventName, cb) =>\n this.#observable.addEventListener(eventName, cb),\n isStarted: () => this.#lifecycle.isStarted(),\n getDependency: <K extends keyof Dependencies>(dependencyName: K) =>\n this.#dependencies.get(dependencyName),\n };\n\n this.#plugins.setDependencies(pluginsDeps);\n\n // NavigationNamespace uses function injection\n const navigationDeps: NavigationDependencies = {\n getOptions: () => this.#options.get(),\n hasRoute: (name) => this.#routes.hasRoute(name),\n getState: () => this.#state.get(),\n setState: (state) => {\n this.#state.set(state);\n },\n buildStateWithSegments: (routeName, routeParams) => {\n // Call forwardState to allow plugin interception\n const { name, params } = this.forwardState(routeName, routeParams);\n\n return this.#routes.buildStateWithSegmentsResolved(name, params);\n },\n makeState: (name, params, path, meta) =>\n this.#state.makeState(name, params, path, meta),\n buildPath: (route, params, segments) =>\n this.#routes.buildPath(route, params, this.#options.get(), segments),\n areStatesEqual: (state1, state2, ignoreQueryParams) =>\n this.#state.areStatesEqual(state1, state2, ignoreQueryParams),\n invokeEventListeners: (eventName, toState, fromState, arg) => {\n this.#observable.invoke(eventName, toState, fromState, arg);\n },\n };\n\n this.#navigation.setDependencies(navigationDeps);\n\n const transitionDeps: TransitionDependencies = {\n getLifecycleFunctions: () => this.#routeLifecycle.getFunctions(),\n getMiddlewareFunctions: () => this.#middleware.getFunctions(),\n isActive: () => this.#lifecycle.isActive(),\n clearCanDeactivate: (name) => {\n this.#routeLifecycle.clearCanDeactivate(name);\n },\n };\n\n this.#navigation.setTransitionDependencies(transitionDeps);\n\n // RouterLifecycleNamespace uses function injection\n // Use facade methods to ensure spies work and plugin interception is possible\n const lifecycleDeps: RouterLifecycleDependencies = {\n getOptions: () => this.#options.get(),\n hasListeners: (eventName) => this.#observable.hasListeners(eventName),\n invokeEventListeners: (eventName, toState, fromState, arg) => {\n this.#observable.invoke(eventName, toState, fromState, arg);\n },\n buildState: (routeName, routeParams) =>\n this.buildState(routeName, routeParams),\n makeState: (name, params, path, meta) =>\n this.#state.makeState(name, params, path, meta),\n buildPath: (route, params) => this.buildPath(route, params),\n makeNotFoundState: (path, options) =>\n this.#state.makeNotFoundState(path, options),\n setState: (state) => {\n this.#state.set(state);\n },\n // RouterLifecycleNamespace only uses matchPath without source parameter\n matchPath: (path, source?: string) =>\n this.#routes.matchPath(path, source, this.#options.get()),\n };\n\n this.#lifecycle.setDependencies(lifecycleDeps);\n\n // StateNamespace needs access to route config and path building\n this.#state.setDependencies({\n getDefaultParams: () => this.#routes.getConfig().defaultParams,\n buildPath: (name, params) =>\n this.#routes.buildPath(name, params, this.#options.get()),\n getUrlParams: (name) => this.#routes.getUrlParams(name),\n });\n\n // =========================================================================\n // Setup cyclic dependencies via functional references\n // =========================================================================\n // Navigation â RouterLifecycle.isStarted() (check before navigation)\n // RouterLifecycle â Navigation.navigateToState() (for start transitions)\n // =========================================================================\n\n this.#navigation.isRouterStarted = () => this.#lifecycle.isStarted();\n\n // Use facade method so tests can spy on router.navigateToState\n this.#lifecycle.navigateToState = (\n toState: State,\n fromState: State | undefined,\n opts: NavigationOptions,\n callback: DoneFn,\n emitSuccess: boolean,\n ) =>\n this.#navigation.navigateToState(\n toState,\n fromState,\n opts,\n callback,\n emitSuccess,\n );\n\n // CloneNamespace needs access to collect cloning data and apply config\n this.#clone.setCallbacks(\n // getCloneData: collect all data needed for cloning\n () => {\n const [canDeactivateFactories, canActivateFactories] =\n this.#routeLifecycle.getFactories();\n\n return {\n routes: this.#routes.cloneRoutes(),\n options: { ...this.#options.get() },\n dependencies: this.#dependencies.getAll(),\n canDeactivateFactories,\n canActivateFactories,\n middlewareFactories: this.#middleware.getFactories(),\n pluginFactories: this.#plugins.getAll(),\n routeConfig: this.#routes.getConfig(),\n resolvedForwardMap: this.#routes.getResolvedForwardMap(),\n };\n },\n // applyConfig: apply route config to new router\n (newRouter, config, resolvedForwardMap) => {\n // Access new router's internal config via type assertion\n // This is safe because we know the newRouter is a Router instance\n const typedRouter = newRouter as unknown as Router<Dependencies>;\n const newConfig = typedRouter.#routes.getConfig();\n\n Object.assign(newConfig.decoders, config.decoders);\n Object.assign(newConfig.encoders, config.encoders);\n Object.assign(newConfig.defaultParams, config.defaultParams);\n Object.assign(newConfig.forwardMap, config.forwardMap);\n\n typedRouter.#routes.setResolvedForwardMap({ ...resolvedForwardMap });\n },\n );\n }\n}\n","// packages/core/src/createRouter.ts\n\nimport { Router } from \"./Router\";\n\nimport type { Route } from \"./types\";\nimport type { DefaultDependencies, Options } from \"@real-router/types\";\n\n/**\n * Creates a new router instance.\n *\n * @param routes - Array of route definitions\n * @param options - Router configuration options\n * @param dependencies - Dependencies to inject into the router\n * @returns A new Router instance\n *\n * @example\n * const router = createRouter([\n * { name: 'home', path: '/' },\n * { name: 'users', path: '/users' },\n * ]);\n *\n * router.start('/');\n */\nexport const createRouter = <\n Dependencies extends DefaultDependencies = DefaultDependencies,\n>(\n routes: Route<Dependencies>[] = [],\n options: Partial<Options> = {},\n dependencies: Dependencies = {} as Dependencies,\n): Router<Dependencies> => {\n return new Router<Dependencies>(routes, options, dependencies);\n};\n"]}
|