@jeffreycao/copilot-api 1.9.0-beta.0 → 1.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.
Files changed (49) hide show
  1. package/README.md +10 -0
  2. package/README.zh-CN.md +10 -0
  3. package/dist/{auth-DCB53u05.js → auth-C3UbfaIB.js} +6 -6
  4. package/dist/{auth-DCB53u05.js.map → auth-C3UbfaIB.js.map} +1 -1
  5. package/dist/{check-usage-iKUAIfc_.js → check-usage-CELArOu5.js} +6 -6
  6. package/dist/{check-usage-iKUAIfc_.js.map → check-usage-CELArOu5.js.map} +1 -1
  7. package/dist/{config-D3dkAXQE.js → config-BQvWqYh_.js} +3 -3
  8. package/dist/{config-D3dkAXQE.js.map → config-BQvWqYh_.js.map} +1 -1
  9. package/dist/{debug-CUx-7_jF.js → debug-DcC7ZPH0.js} +4 -4
  10. package/dist/{debug-CUx-7_jF.js.map → debug-DcC7ZPH0.js.map} +1 -1
  11. package/dist/main.js +6 -6
  12. package/dist/{paths-DvrimVju.js → paths-Cla6y5eD.js} +2 -2
  13. package/dist/{paths-DvrimVju.js.map → paths-Cla6y5eD.js.map} +1 -1
  14. package/dist/{server-BGqhE4N_.js → server-CA39Gy7x.js} +45 -1647
  15. package/dist/server-CA39Gy7x.js.map +1 -0
  16. package/dist/start-DKwPr9vl.js +268 -0
  17. package/dist/start-DKwPr9vl.js.map +1 -0
  18. package/dist/{token-BCdEIfN_.js → token-CIwAFD_6.js} +9 -5
  19. package/dist/token-CIwAFD_6.js.map +1 -0
  20. package/dist/{utils-DXuuBUT_.js → utils-DG6CB51Z.js} +4 -5
  21. package/dist/{utils-DXuuBUT_.js.map → utils-DG6CB51Z.js.map} +1 -1
  22. package/package.json +2 -1
  23. package/dist/GptEncoding-TiCgsNrQ.js +0 -887
  24. package/dist/GptEncoding-TiCgsNrQ.js.map +0 -1
  25. package/dist/chunk-BZ41Y9eH.js +0 -39
  26. package/dist/cl100k_base-kiDWemr-.js +0 -101375
  27. package/dist/cl100k_base-kiDWemr-.js.map +0 -1
  28. package/dist/dist-B3jIqeb6.js +0 -961
  29. package/dist/dist-B3jIqeb6.js.map +0 -1
  30. package/dist/dist-CSEoNgAt.js +0 -334
  31. package/dist/dist-CSEoNgAt.js.map +0 -1
  32. package/dist/o200k_base-BlrOP1Jc.js +0 -204726
  33. package/dist/o200k_base-BlrOP1Jc.js.map +0 -1
  34. package/dist/p50k_base-DA6KYT1Z.js +0 -11
  35. package/dist/p50k_base-DA6KYT1Z.js.map +0 -1
  36. package/dist/p50k_base-tS38LhIO.js +0 -50483
  37. package/dist/p50k_base-tS38LhIO.js.map +0 -1
  38. package/dist/p50k_edit-BlA1HcF4.js +0 -11
  39. package/dist/p50k_edit-BlA1HcF4.js.map +0 -1
  40. package/dist/prompt-CyV2d7YW.js +0 -850
  41. package/dist/prompt-CyV2d7YW.js.map +0 -1
  42. package/dist/r50k_base-CaCWe6-8.js +0 -50466
  43. package/dist/r50k_base-CaCWe6-8.js.map +0 -1
  44. package/dist/registry-B_2v83L7.js +0 -797
  45. package/dist/registry-B_2v83L7.js.map +0 -1
  46. package/dist/server-BGqhE4N_.js.map +0 -1
  47. package/dist/start-Cxl5pgll.js +0 -27379
  48. package/dist/start-Cxl5pgll.js.map +0 -1
  49. package/dist/token-BCdEIfN_.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"server-BGqhE4N_.js","names":["path","path","#matchResult","#validatedData","#getDecodedParam","#getAllDecodedParams","#getParamValue","raw","#cachedBody","#rawRequest","#executionCtx","#notFoundHandler","#path","#matchResult","#req","#res","#preparedHeaders","#renderer","#layout","#status","#var","#newResponse","Hono","#path","#addRoute","path","#notFoundHandler","#clone","#dispatch","#handleError","Node","#index","#children","#varIndex","Node","path","#root","#context","path","#middleware","#routes","#buildAllMatchers","#buildMatcher","#routers","#routes","path","#children","#methods","#patterns","#order","path","#params","#getHandlerSets","#node","path","HonoBase","process","path","traceIdMiddleware: MiddlewareHandler","stream","flushInterval: ReturnType<typeof setInterval> | undefined","cleanupInterval: ReturnType<typeof setInterval> | undefined","stats: fs.Stats","stream","logger","state","#currentLine","split","utils.stream","utils.split","copilotRateLimitHeaders: Record<CopilotRateLimitType, string>","x","headers: Record<string, string>","logger","handleCompletion","isNonStreaming","stream","handleCompletion","newMessages: Array<Message>","contentParts: Array<ContentPart>","assistantContentBlocks: Array<AnthropicAssistantContentBlock>","headers: Record<string, string>","THINKING_TEXT","input: Array<ResponseInputItem>","raw","items: Array<ResponseInputItem>","pendingContent: Array<ResponseInputContent>","contentBlocks: Array<AnthropicAssistantContentBlock>","segments: Array<string>","parsed: unknown","result: Array<ResponseInputContent>","state","handleOutputItemAdded","handleOutputItemDone","events","blockIndex","THINKING_TEXT","result: Array<ResponseInputItem>","headers: Record<string, string>","currentAttachments","toolResults: Array<AnthropicToolResultBlock>","textBlocks: Array<AnthropicTextBlock>","attachments: Array<IndexedAttachment>","state","events: Array<AnthropicStreamEventData>","events","logger","streamState: AnthropicStreamState","events","stream","isAsyncIterable","logger","RESPONSES_ENDPOINT","logger","authHeaders: Record<string, string>","headers: Record<string, string>","logger","stream","logger","logger","stream","dropped: Array<string>"],"sources":["../node_modules/hono/dist/compose.js","../node_modules/hono/dist/request/constants.js","../node_modules/hono/dist/utils/body.js","../node_modules/hono/dist/utils/url.js","../node_modules/hono/dist/request.js","../node_modules/hono/dist/utils/html.js","../node_modules/hono/dist/context.js","../node_modules/hono/dist/router.js","../node_modules/hono/dist/utils/constants.js","../node_modules/hono/dist/hono-base.js","../node_modules/hono/dist/router/reg-exp-router/node.js","../node_modules/hono/dist/router/reg-exp-router/trie.js","../node_modules/hono/dist/router/reg-exp-router/router.js","../node_modules/hono/dist/router/smart-router/router.js","../node_modules/hono/dist/router/trie-router/node.js","../node_modules/hono/dist/router/trie-router/router.js","../node_modules/hono/dist/hono.js","../node_modules/hono/dist/middleware/cors/index.js","../node_modules/hono/dist/utils/color.js","../node_modules/hono/dist/middleware/logger/index.js","../src/lib/request-auth.ts","../src/lib/trace.ts","../node_modules/hono/dist/utils/stream.js","../node_modules/hono/dist/helper/streaming/utils.js","../node_modules/hono/dist/helper/streaming/sse.js","../src/lib/approval.ts","../src/lib/logger.ts","../src/lib/rate-limit.ts","../node_modules/fetch-event-stream/esm/deps/jsr.io/@std/streams/0.221.0/text_line_stream.js","../node_modules/fetch-event-stream/esm/utils.js","../node_modules/fetch-event-stream/esm/mod.js","../src/lib/copilot-rate-limit.ts","../src/services/copilot/create-chat-completions.ts","../src/routes/chat-completions/handler.ts","../src/routes/chat-completions/route.ts","../src/services/copilot/create-embeddings.ts","../src/routes/embeddings/route.ts","../src/lib/tokenizer.ts","../src/lib/models.ts","../src/routes/messages/utils.ts","../src/routes/messages/non-stream-translation.ts","../src/routes/messages/count-tokens-handler.ts","../src/services/copilot/create-responses.ts","../src/routes/messages/responses-translation.ts","../src/routes/messages/responses-stream-translation.ts","../src/routes/responses/utils.ts","../src/services/copilot/create-messages.ts","../src/routes/messages/preprocess.ts","../src/routes/messages/stream-translation.ts","../src/routes/messages/api-flows.ts","../src/lib/subagent.ts","../src/routes/messages/subagent-marker.ts","../src/routes/messages/handler.ts","../src/routes/messages/route.ts","../src/routes/models/route.ts","../src/routes/provider/messages/count-tokens-handler.ts","../src/services/providers/anthropic-proxy.ts","../src/routes/provider/messages/handler.ts","../src/routes/provider/messages/route.ts","../src/routes/provider/models/route.ts","../src/routes/responses/stream-id-sync.ts","../src/routes/responses/handler.ts","../src/routes/responses/route.ts","../src/routes/token/route.ts","../src/routes/usage/route.ts","../src/server.ts"],"sourcesContent":["// src/compose.ts\nvar compose = (middleware, onError, onNotFound) => {\n return (context, next) => {\n let index = -1;\n return dispatch(0);\n async function dispatch(i) {\n if (i <= index) {\n throw new Error(\"next() called multiple times\");\n }\n index = i;\n let res;\n let isError = false;\n let handler;\n if (middleware[i]) {\n handler = middleware[i][0][0];\n context.req.routeIndex = i;\n } else {\n handler = i === middleware.length && next || void 0;\n }\n if (handler) {\n try {\n res = await handler(context, () => dispatch(i + 1));\n } catch (err) {\n if (err instanceof Error && onError) {\n context.error = err;\n res = await onError(err, context);\n isError = true;\n } else {\n throw err;\n }\n }\n } else {\n if (context.finalized === false && onNotFound) {\n res = await onNotFound(context);\n }\n }\n if (res && (context.finalized === false || isError)) {\n context.res = res;\n }\n return context;\n }\n };\n};\nexport {\n compose\n};\n","// src/request/constants.ts\nvar GET_MATCH_RESULT = Symbol();\nexport {\n GET_MATCH_RESULT\n};\n","// src/utils/body.ts\nimport { HonoRequest } from \"../request.js\";\nvar parseBody = async (request, options = /* @__PURE__ */ Object.create(null)) => {\n const { all = false, dot = false } = options;\n const headers = request instanceof HonoRequest ? request.raw.headers : request.headers;\n const contentType = headers.get(\"Content-Type\");\n if (contentType?.startsWith(\"multipart/form-data\") || contentType?.startsWith(\"application/x-www-form-urlencoded\")) {\n return parseFormData(request, { all, dot });\n }\n return {};\n};\nasync function parseFormData(request, options) {\n const formData = await request.formData();\n if (formData) {\n return convertFormDataToBodyData(formData, options);\n }\n return {};\n}\nfunction convertFormDataToBodyData(formData, options) {\n const form = /* @__PURE__ */ Object.create(null);\n formData.forEach((value, key) => {\n const shouldParseAllValues = options.all || key.endsWith(\"[]\");\n if (!shouldParseAllValues) {\n form[key] = value;\n } else {\n handleParsingAllValues(form, key, value);\n }\n });\n if (options.dot) {\n Object.entries(form).forEach(([key, value]) => {\n const shouldParseDotValues = key.includes(\".\");\n if (shouldParseDotValues) {\n handleParsingNestedValues(form, key, value);\n delete form[key];\n }\n });\n }\n return form;\n}\nvar handleParsingAllValues = (form, key, value) => {\n if (form[key] !== void 0) {\n if (Array.isArray(form[key])) {\n ;\n form[key].push(value);\n } else {\n form[key] = [form[key], value];\n }\n } else {\n if (!key.endsWith(\"[]\")) {\n form[key] = value;\n } else {\n form[key] = [value];\n }\n }\n};\nvar handleParsingNestedValues = (form, key, value) => {\n let nestedForm = form;\n const keys = key.split(\".\");\n keys.forEach((key2, index) => {\n if (index === keys.length - 1) {\n nestedForm[key2] = value;\n } else {\n if (!nestedForm[key2] || typeof nestedForm[key2] !== \"object\" || Array.isArray(nestedForm[key2]) || nestedForm[key2] instanceof File) {\n nestedForm[key2] = /* @__PURE__ */ Object.create(null);\n }\n nestedForm = nestedForm[key2];\n }\n });\n};\nexport {\n parseBody\n};\n","// src/utils/url.ts\nvar splitPath = (path) => {\n const paths = path.split(\"/\");\n if (paths[0] === \"\") {\n paths.shift();\n }\n return paths;\n};\nvar splitRoutingPath = (routePath) => {\n const { groups, path } = extractGroupsFromPath(routePath);\n const paths = splitPath(path);\n return replaceGroupMarks(paths, groups);\n};\nvar extractGroupsFromPath = (path) => {\n const groups = [];\n path = path.replace(/\\{[^}]+\\}/g, (match, index) => {\n const mark = `@${index}`;\n groups.push([mark, match]);\n return mark;\n });\n return { groups, path };\n};\nvar replaceGroupMarks = (paths, groups) => {\n for (let i = groups.length - 1; i >= 0; i--) {\n const [mark] = groups[i];\n for (let j = paths.length - 1; j >= 0; j--) {\n if (paths[j].includes(mark)) {\n paths[j] = paths[j].replace(mark, groups[i][1]);\n break;\n }\n }\n }\n return paths;\n};\nvar patternCache = {};\nvar getPattern = (label, next) => {\n if (label === \"*\") {\n return \"*\";\n }\n const match = label.match(/^\\:([^\\{\\}]+)(?:\\{(.+)\\})?$/);\n if (match) {\n const cacheKey = `${label}#${next}`;\n if (!patternCache[cacheKey]) {\n if (match[2]) {\n patternCache[cacheKey] = next && next[0] !== \":\" && next[0] !== \"*\" ? [cacheKey, match[1], new RegExp(`^${match[2]}(?=/${next})`)] : [label, match[1], new RegExp(`^${match[2]}$`)];\n } else {\n patternCache[cacheKey] = [label, match[1], true];\n }\n }\n return patternCache[cacheKey];\n }\n return null;\n};\nvar tryDecode = (str, decoder) => {\n try {\n return decoder(str);\n } catch {\n return str.replace(/(?:%[0-9A-Fa-f]{2})+/g, (match) => {\n try {\n return decoder(match);\n } catch {\n return match;\n }\n });\n }\n};\nvar tryDecodeURI = (str) => tryDecode(str, decodeURI);\nvar getPath = (request) => {\n const url = request.url;\n const start = url.indexOf(\"/\", url.indexOf(\":\") + 4);\n let i = start;\n for (; i < url.length; i++) {\n const charCode = url.charCodeAt(i);\n if (charCode === 37) {\n const queryIndex = url.indexOf(\"?\", i);\n const path = url.slice(start, queryIndex === -1 ? void 0 : queryIndex);\n return tryDecodeURI(path.includes(\"%25\") ? path.replace(/%25/g, \"%2525\") : path);\n } else if (charCode === 63) {\n break;\n }\n }\n return url.slice(start, i);\n};\nvar getQueryStrings = (url) => {\n const queryIndex = url.indexOf(\"?\", 8);\n return queryIndex === -1 ? \"\" : \"?\" + url.slice(queryIndex + 1);\n};\nvar getPathNoStrict = (request) => {\n const result = getPath(request);\n return result.length > 1 && result.at(-1) === \"/\" ? result.slice(0, -1) : result;\n};\nvar mergePath = (base, sub, ...rest) => {\n if (rest.length) {\n sub = mergePath(sub, ...rest);\n }\n return `${base?.[0] === \"/\" ? \"\" : \"/\"}${base}${sub === \"/\" ? \"\" : `${base?.at(-1) === \"/\" ? \"\" : \"/\"}${sub?.[0] === \"/\" ? sub.slice(1) : sub}`}`;\n};\nvar checkOptionalParameter = (path) => {\n if (path.charCodeAt(path.length - 1) !== 63 || !path.includes(\":\")) {\n return null;\n }\n const segments = path.split(\"/\");\n const results = [];\n let basePath = \"\";\n segments.forEach((segment) => {\n if (segment !== \"\" && !/\\:/.test(segment)) {\n basePath += \"/\" + segment;\n } else if (/\\:/.test(segment)) {\n if (/\\?/.test(segment)) {\n if (results.length === 0 && basePath === \"\") {\n results.push(\"/\");\n } else {\n results.push(basePath);\n }\n const optionalSegment = segment.replace(\"?\", \"\");\n basePath += \"/\" + optionalSegment;\n results.push(basePath);\n } else {\n basePath += \"/\" + segment;\n }\n }\n });\n return results.filter((v, i, a) => a.indexOf(v) === i);\n};\nvar _decodeURI = (value) => {\n if (!/[%+]/.test(value)) {\n return value;\n }\n if (value.indexOf(\"+\") !== -1) {\n value = value.replace(/\\+/g, \" \");\n }\n return value.indexOf(\"%\") !== -1 ? tryDecode(value, decodeURIComponent_) : value;\n};\nvar _getQueryParam = (url, key, multiple) => {\n let encoded;\n if (!multiple && key && !/[%+]/.test(key)) {\n let keyIndex2 = url.indexOf(`?${key}`, 8);\n if (keyIndex2 === -1) {\n keyIndex2 = url.indexOf(`&${key}`, 8);\n }\n while (keyIndex2 !== -1) {\n const trailingKeyCode = url.charCodeAt(keyIndex2 + key.length + 1);\n if (trailingKeyCode === 61) {\n const valueIndex = keyIndex2 + key.length + 2;\n const endIndex = url.indexOf(\"&\", valueIndex);\n return _decodeURI(url.slice(valueIndex, endIndex === -1 ? void 0 : endIndex));\n } else if (trailingKeyCode == 38 || isNaN(trailingKeyCode)) {\n return \"\";\n }\n keyIndex2 = url.indexOf(`&${key}`, keyIndex2 + 1);\n }\n encoded = /[%+]/.test(url);\n if (!encoded) {\n return void 0;\n }\n }\n const results = {};\n encoded ??= /[%+]/.test(url);\n let keyIndex = url.indexOf(\"?\", 8);\n while (keyIndex !== -1) {\n const nextKeyIndex = url.indexOf(\"&\", keyIndex + 1);\n let valueIndex = url.indexOf(\"=\", keyIndex);\n if (valueIndex > nextKeyIndex && nextKeyIndex !== -1) {\n valueIndex = -1;\n }\n let name = url.slice(\n keyIndex + 1,\n valueIndex === -1 ? nextKeyIndex === -1 ? void 0 : nextKeyIndex : valueIndex\n );\n if (encoded) {\n name = _decodeURI(name);\n }\n keyIndex = nextKeyIndex;\n if (name === \"\") {\n continue;\n }\n let value;\n if (valueIndex === -1) {\n value = \"\";\n } else {\n value = url.slice(valueIndex + 1, nextKeyIndex === -1 ? void 0 : nextKeyIndex);\n if (encoded) {\n value = _decodeURI(value);\n }\n }\n if (multiple) {\n if (!(results[name] && Array.isArray(results[name]))) {\n results[name] = [];\n }\n ;\n results[name].push(value);\n } else {\n results[name] ??= value;\n }\n }\n return key ? results[key] : results;\n};\nvar getQueryParam = _getQueryParam;\nvar getQueryParams = (url, key) => {\n return _getQueryParam(url, key, true);\n};\nvar decodeURIComponent_ = decodeURIComponent;\nexport {\n checkOptionalParameter,\n decodeURIComponent_,\n getPath,\n getPathNoStrict,\n getPattern,\n getQueryParam,\n getQueryParams,\n getQueryStrings,\n mergePath,\n splitPath,\n splitRoutingPath,\n tryDecode\n};\n","// src/request.ts\nimport { GET_MATCH_RESULT } from \"./request/constants.js\";\nimport { parseBody } from \"./utils/body.js\";\nimport { decodeURIComponent_, getQueryParam, getQueryParams, tryDecode } from \"./utils/url.js\";\nvar tryDecodeURIComponent = (str) => tryDecode(str, decodeURIComponent_);\nvar HonoRequest = class {\n raw;\n #validatedData;\n #matchResult;\n routeIndex = 0;\n path;\n bodyCache = {};\n constructor(request, path = \"/\", matchResult = [[]]) {\n this.raw = request;\n this.path = path;\n this.#matchResult = matchResult;\n this.#validatedData = {};\n }\n param(key) {\n return key ? this.#getDecodedParam(key) : this.#getAllDecodedParams();\n }\n #getDecodedParam(key) {\n const paramKey = this.#matchResult[0][this.routeIndex][1][key];\n const param = this.#getParamValue(paramKey);\n return param && /\\%/.test(param) ? tryDecodeURIComponent(param) : param;\n }\n #getAllDecodedParams() {\n const decoded = {};\n const keys = Object.keys(this.#matchResult[0][this.routeIndex][1]);\n for (const key of keys) {\n const value = this.#getParamValue(this.#matchResult[0][this.routeIndex][1][key]);\n if (value !== void 0) {\n decoded[key] = /\\%/.test(value) ? tryDecodeURIComponent(value) : value;\n }\n }\n return decoded;\n }\n #getParamValue(paramKey) {\n return this.#matchResult[1] ? this.#matchResult[1][paramKey] : paramKey;\n }\n query(key) {\n return getQueryParam(this.url, key);\n }\n queries(key) {\n return getQueryParams(this.url, key);\n }\n header(name) {\n if (name) {\n return this.raw.headers.get(name) ?? void 0;\n }\n const headerData = {};\n this.raw.headers.forEach((value, key) => {\n headerData[key] = value;\n });\n return headerData;\n }\n async parseBody(options) {\n return this.bodyCache.parsedBody ??= await parseBody(this, options);\n }\n #cachedBody = (key) => {\n const { bodyCache, raw } = this;\n const cachedBody = bodyCache[key];\n if (cachedBody) {\n return cachedBody;\n }\n const anyCachedKey = Object.keys(bodyCache)[0];\n if (anyCachedKey) {\n return bodyCache[anyCachedKey].then((body) => {\n if (anyCachedKey === \"json\") {\n body = JSON.stringify(body);\n }\n return new Response(body)[key]();\n });\n }\n return bodyCache[key] = raw[key]();\n };\n json() {\n return this.#cachedBody(\"text\").then((text) => JSON.parse(text));\n }\n text() {\n return this.#cachedBody(\"text\");\n }\n arrayBuffer() {\n return this.#cachedBody(\"arrayBuffer\");\n }\n blob() {\n return this.#cachedBody(\"blob\");\n }\n formData() {\n return this.#cachedBody(\"formData\");\n }\n addValidatedData(target, data) {\n this.#validatedData[target] = data;\n }\n valid(target) {\n return this.#validatedData[target];\n }\n get url() {\n return this.raw.url;\n }\n get method() {\n return this.raw.method;\n }\n get [GET_MATCH_RESULT]() {\n return this.#matchResult;\n }\n get matchedRoutes() {\n return this.#matchResult[0].map(([[, route]]) => route);\n }\n get routePath() {\n return this.#matchResult[0].map(([[, route]]) => route)[this.routeIndex].path;\n }\n};\nexport {\n HonoRequest\n};\n","// src/utils/html.ts\nvar HtmlEscapedCallbackPhase = {\n Stringify: 1,\n BeforeStream: 2,\n Stream: 3\n};\nvar raw = (value, callbacks) => {\n const escapedString = new String(value);\n escapedString.isEscaped = true;\n escapedString.callbacks = callbacks;\n return escapedString;\n};\nvar escapeRe = /[&<>'\"]/;\nvar stringBufferToString = async (buffer, callbacks) => {\n let str = \"\";\n callbacks ||= [];\n const resolvedBuffer = await Promise.all(buffer);\n for (let i = resolvedBuffer.length - 1; ; i--) {\n str += resolvedBuffer[i];\n i--;\n if (i < 0) {\n break;\n }\n let r = resolvedBuffer[i];\n if (typeof r === \"object\") {\n callbacks.push(...r.callbacks || []);\n }\n const isEscaped = r.isEscaped;\n r = await (typeof r === \"object\" ? r.toString() : r);\n if (typeof r === \"object\") {\n callbacks.push(...r.callbacks || []);\n }\n if (r.isEscaped ?? isEscaped) {\n str += r;\n } else {\n const buf = [str];\n escapeToBuffer(r, buf);\n str = buf[0];\n }\n }\n return raw(str, callbacks);\n};\nvar escapeToBuffer = (str, buffer) => {\n const match = str.search(escapeRe);\n if (match === -1) {\n buffer[0] += str;\n return;\n }\n let escape;\n let index;\n let lastIndex = 0;\n for (index = match; index < str.length; index++) {\n switch (str.charCodeAt(index)) {\n case 34:\n escape = \"&quot;\";\n break;\n case 39:\n escape = \"&#39;\";\n break;\n case 38:\n escape = \"&amp;\";\n break;\n case 60:\n escape = \"&lt;\";\n break;\n case 62:\n escape = \"&gt;\";\n break;\n default:\n continue;\n }\n buffer[0] += str.substring(lastIndex, index) + escape;\n lastIndex = index + 1;\n }\n buffer[0] += str.substring(lastIndex, index);\n};\nvar resolveCallbackSync = (str) => {\n const callbacks = str.callbacks;\n if (!callbacks?.length) {\n return str;\n }\n const buffer = [str];\n const context = {};\n callbacks.forEach((c) => c({ phase: HtmlEscapedCallbackPhase.Stringify, buffer, context }));\n return buffer[0];\n};\nvar resolveCallback = async (str, phase, preserveCallbacks, context, buffer) => {\n if (typeof str === \"object\" && !(str instanceof String)) {\n if (!(str instanceof Promise)) {\n str = str.toString();\n }\n if (str instanceof Promise) {\n str = await str;\n }\n }\n const callbacks = str.callbacks;\n if (!callbacks?.length) {\n return Promise.resolve(str);\n }\n if (buffer) {\n buffer[0] += str;\n } else {\n buffer = [str];\n }\n const resStr = Promise.all(callbacks.map((c) => c({ phase, buffer, context }))).then(\n (res) => Promise.all(\n res.filter(Boolean).map((str2) => resolveCallback(str2, phase, false, context, buffer))\n ).then(() => buffer[0])\n );\n if (preserveCallbacks) {\n return raw(await resStr, callbacks);\n } else {\n return resStr;\n }\n};\nexport {\n HtmlEscapedCallbackPhase,\n escapeToBuffer,\n raw,\n resolveCallback,\n resolveCallbackSync,\n stringBufferToString\n};\n","// src/context.ts\nimport { HonoRequest } from \"./request.js\";\nimport { HtmlEscapedCallbackPhase, resolveCallback } from \"./utils/html.js\";\nvar TEXT_PLAIN = \"text/plain; charset=UTF-8\";\nvar setDefaultContentType = (contentType, headers) => {\n return {\n \"Content-Type\": contentType,\n ...headers\n };\n};\nvar Context = class {\n #rawRequest;\n #req;\n env = {};\n #var;\n finalized = false;\n error;\n #status;\n #executionCtx;\n #res;\n #layout;\n #renderer;\n #notFoundHandler;\n #preparedHeaders;\n #matchResult;\n #path;\n constructor(req, options) {\n this.#rawRequest = req;\n if (options) {\n this.#executionCtx = options.executionCtx;\n this.env = options.env;\n this.#notFoundHandler = options.notFoundHandler;\n this.#path = options.path;\n this.#matchResult = options.matchResult;\n }\n }\n get req() {\n this.#req ??= new HonoRequest(this.#rawRequest, this.#path, this.#matchResult);\n return this.#req;\n }\n get event() {\n if (this.#executionCtx && \"respondWith\" in this.#executionCtx) {\n return this.#executionCtx;\n } else {\n throw Error(\"This context has no FetchEvent\");\n }\n }\n get executionCtx() {\n if (this.#executionCtx) {\n return this.#executionCtx;\n } else {\n throw Error(\"This context has no ExecutionContext\");\n }\n }\n get res() {\n return this.#res ||= new Response(null, {\n headers: this.#preparedHeaders ??= new Headers()\n });\n }\n set res(_res) {\n if (this.#res && _res) {\n _res = new Response(_res.body, _res);\n for (const [k, v] of this.#res.headers.entries()) {\n if (k === \"content-type\") {\n continue;\n }\n if (k === \"set-cookie\") {\n const cookies = this.#res.headers.getSetCookie();\n _res.headers.delete(\"set-cookie\");\n for (const cookie of cookies) {\n _res.headers.append(\"set-cookie\", cookie);\n }\n } else {\n _res.headers.set(k, v);\n }\n }\n }\n this.#res = _res;\n this.finalized = true;\n }\n render = (...args) => {\n this.#renderer ??= (content) => this.html(content);\n return this.#renderer(...args);\n };\n setLayout = (layout) => this.#layout = layout;\n getLayout = () => this.#layout;\n setRenderer = (renderer) => {\n this.#renderer = renderer;\n };\n header = (name, value, options) => {\n if (this.finalized) {\n this.#res = new Response(this.#res.body, this.#res);\n }\n const headers = this.#res ? this.#res.headers : this.#preparedHeaders ??= new Headers();\n if (value === void 0) {\n headers.delete(name);\n } else if (options?.append) {\n headers.append(name, value);\n } else {\n headers.set(name, value);\n }\n };\n status = (status) => {\n this.#status = status;\n };\n set = (key, value) => {\n this.#var ??= /* @__PURE__ */ new Map();\n this.#var.set(key, value);\n };\n get = (key) => {\n return this.#var ? this.#var.get(key) : void 0;\n };\n get var() {\n if (!this.#var) {\n return {};\n }\n return Object.fromEntries(this.#var);\n }\n #newResponse(data, arg, headers) {\n const responseHeaders = this.#res ? new Headers(this.#res.headers) : this.#preparedHeaders ?? new Headers();\n if (typeof arg === \"object\" && \"headers\" in arg) {\n const argHeaders = arg.headers instanceof Headers ? arg.headers : new Headers(arg.headers);\n for (const [key, value] of argHeaders) {\n if (key.toLowerCase() === \"set-cookie\") {\n responseHeaders.append(key, value);\n } else {\n responseHeaders.set(key, value);\n }\n }\n }\n if (headers) {\n for (const [k, v] of Object.entries(headers)) {\n if (typeof v === \"string\") {\n responseHeaders.set(k, v);\n } else {\n responseHeaders.delete(k);\n for (const v2 of v) {\n responseHeaders.append(k, v2);\n }\n }\n }\n }\n const status = typeof arg === \"number\" ? arg : arg?.status ?? this.#status;\n return new Response(data, { status, headers: responseHeaders });\n }\n newResponse = (...args) => this.#newResponse(...args);\n body = (data, arg, headers) => this.#newResponse(data, arg, headers);\n text = (text, arg, headers) => {\n return !this.#preparedHeaders && !this.#status && !arg && !headers && !this.finalized ? new Response(text) : this.#newResponse(\n text,\n arg,\n setDefaultContentType(TEXT_PLAIN, headers)\n );\n };\n json = (object, arg, headers) => {\n return this.#newResponse(\n JSON.stringify(object),\n arg,\n setDefaultContentType(\"application/json\", headers)\n );\n };\n html = (html, arg, headers) => {\n const res = (html2) => this.#newResponse(html2, arg, setDefaultContentType(\"text/html; charset=UTF-8\", headers));\n return typeof html === \"object\" ? resolveCallback(html, HtmlEscapedCallbackPhase.Stringify, false, {}).then(res) : res(html);\n };\n redirect = (location, status) => {\n const locationString = String(location);\n this.header(\n \"Location\",\n !/[^\\x00-\\xFF]/.test(locationString) ? locationString : encodeURI(locationString)\n );\n return this.newResponse(null, status ?? 302);\n };\n notFound = () => {\n this.#notFoundHandler ??= () => new Response();\n return this.#notFoundHandler(this);\n };\n};\nexport {\n Context,\n TEXT_PLAIN\n};\n","// src/router.ts\nvar METHOD_NAME_ALL = \"ALL\";\nvar METHOD_NAME_ALL_LOWERCASE = \"all\";\nvar METHODS = [\"get\", \"post\", \"put\", \"delete\", \"options\", \"patch\"];\nvar MESSAGE_MATCHER_IS_ALREADY_BUILT = \"Can not add a route since the matcher is already built.\";\nvar UnsupportedPathError = class extends Error {\n};\nexport {\n MESSAGE_MATCHER_IS_ALREADY_BUILT,\n METHODS,\n METHOD_NAME_ALL,\n METHOD_NAME_ALL_LOWERCASE,\n UnsupportedPathError\n};\n","// src/utils/constants.ts\nvar COMPOSED_HANDLER = \"__COMPOSED_HANDLER\";\nexport {\n COMPOSED_HANDLER\n};\n","// src/hono-base.ts\nimport { compose } from \"./compose.js\";\nimport { Context } from \"./context.js\";\nimport { METHODS, METHOD_NAME_ALL, METHOD_NAME_ALL_LOWERCASE } from \"./router.js\";\nimport { COMPOSED_HANDLER } from \"./utils/constants.js\";\nimport { getPath, getPathNoStrict, mergePath } from \"./utils/url.js\";\nvar notFoundHandler = (c) => {\n return c.text(\"404 Not Found\", 404);\n};\nvar errorHandler = (err, c) => {\n if (\"getResponse\" in err) {\n const res = err.getResponse();\n return c.newResponse(res.body, res);\n }\n console.error(err);\n return c.text(\"Internal Server Error\", 500);\n};\nvar Hono = class {\n get;\n post;\n put;\n delete;\n options;\n patch;\n all;\n on;\n use;\n router;\n getPath;\n _basePath = \"/\";\n #path = \"/\";\n routes = [];\n constructor(options = {}) {\n const allMethods = [...METHODS, METHOD_NAME_ALL_LOWERCASE];\n allMethods.forEach((method) => {\n this[method] = (args1, ...args) => {\n if (typeof args1 === \"string\") {\n this.#path = args1;\n } else {\n this.#addRoute(method, this.#path, args1);\n }\n args.forEach((handler) => {\n this.#addRoute(method, this.#path, handler);\n });\n return this;\n };\n });\n this.on = (method, path, ...handlers) => {\n for (const p of [path].flat()) {\n this.#path = p;\n for (const m of [method].flat()) {\n handlers.map((handler) => {\n this.#addRoute(m.toUpperCase(), this.#path, handler);\n });\n }\n }\n return this;\n };\n this.use = (arg1, ...handlers) => {\n if (typeof arg1 === \"string\") {\n this.#path = arg1;\n } else {\n this.#path = \"*\";\n handlers.unshift(arg1);\n }\n handlers.forEach((handler) => {\n this.#addRoute(METHOD_NAME_ALL, this.#path, handler);\n });\n return this;\n };\n const { strict, ...optionsWithoutStrict } = options;\n Object.assign(this, optionsWithoutStrict);\n this.getPath = strict ?? true ? options.getPath ?? getPath : getPathNoStrict;\n }\n #clone() {\n const clone = new Hono({\n router: this.router,\n getPath: this.getPath\n });\n clone.errorHandler = this.errorHandler;\n clone.#notFoundHandler = this.#notFoundHandler;\n clone.routes = this.routes;\n return clone;\n }\n #notFoundHandler = notFoundHandler;\n errorHandler = errorHandler;\n route(path, app) {\n const subApp = this.basePath(path);\n app.routes.map((r) => {\n let handler;\n if (app.errorHandler === errorHandler) {\n handler = r.handler;\n } else {\n handler = async (c, next) => (await compose([], app.errorHandler)(c, () => r.handler(c, next))).res;\n handler[COMPOSED_HANDLER] = r.handler;\n }\n subApp.#addRoute(r.method, r.path, handler);\n });\n return this;\n }\n basePath(path) {\n const subApp = this.#clone();\n subApp._basePath = mergePath(this._basePath, path);\n return subApp;\n }\n onError = (handler) => {\n this.errorHandler = handler;\n return this;\n };\n notFound = (handler) => {\n this.#notFoundHandler = handler;\n return this;\n };\n mount(path, applicationHandler, options) {\n let replaceRequest;\n let optionHandler;\n if (options) {\n if (typeof options === \"function\") {\n optionHandler = options;\n } else {\n optionHandler = options.optionHandler;\n if (options.replaceRequest === false) {\n replaceRequest = (request) => request;\n } else {\n replaceRequest = options.replaceRequest;\n }\n }\n }\n const getOptions = optionHandler ? (c) => {\n const options2 = optionHandler(c);\n return Array.isArray(options2) ? options2 : [options2];\n } : (c) => {\n let executionContext = void 0;\n try {\n executionContext = c.executionCtx;\n } catch {\n }\n return [c.env, executionContext];\n };\n replaceRequest ||= (() => {\n const mergedPath = mergePath(this._basePath, path);\n const pathPrefixLength = mergedPath === \"/\" ? 0 : mergedPath.length;\n return (request) => {\n const url = new URL(request.url);\n url.pathname = url.pathname.slice(pathPrefixLength) || \"/\";\n return new Request(url, request);\n };\n })();\n const handler = async (c, next) => {\n const res = await applicationHandler(replaceRequest(c.req.raw), ...getOptions(c));\n if (res) {\n return res;\n }\n await next();\n };\n this.#addRoute(METHOD_NAME_ALL, mergePath(path, \"*\"), handler);\n return this;\n }\n #addRoute(method, path, handler) {\n method = method.toUpperCase();\n path = mergePath(this._basePath, path);\n const r = { basePath: this._basePath, path, method, handler };\n this.router.add(method, path, [handler, r]);\n this.routes.push(r);\n }\n #handleError(err, c) {\n if (err instanceof Error) {\n return this.errorHandler(err, c);\n }\n throw err;\n }\n #dispatch(request, executionCtx, env, method) {\n if (method === \"HEAD\") {\n return (async () => new Response(null, await this.#dispatch(request, executionCtx, env, \"GET\")))();\n }\n const path = this.getPath(request, { env });\n const matchResult = this.router.match(method, path);\n const c = new Context(request, {\n path,\n matchResult,\n env,\n executionCtx,\n notFoundHandler: this.#notFoundHandler\n });\n if (matchResult[0].length === 1) {\n let res;\n try {\n res = matchResult[0][0][0][0](c, async () => {\n c.res = await this.#notFoundHandler(c);\n });\n } catch (err) {\n return this.#handleError(err, c);\n }\n return res instanceof Promise ? res.then(\n (resolved) => resolved || (c.finalized ? c.res : this.#notFoundHandler(c))\n ).catch((err) => this.#handleError(err, c)) : res ?? this.#notFoundHandler(c);\n }\n const composed = compose(matchResult[0], this.errorHandler, this.#notFoundHandler);\n return (async () => {\n try {\n const context = await composed(c);\n if (!context.finalized) {\n throw new Error(\n \"Context is not finalized. Did you forget to return a Response object or `await next()`?\"\n );\n }\n return context.res;\n } catch (err) {\n return this.#handleError(err, c);\n }\n })();\n }\n fetch = (request, ...rest) => {\n return this.#dispatch(request, rest[1], rest[0], request.method);\n };\n request = (input, requestInit, Env, executionCtx) => {\n if (input instanceof Request) {\n return this.fetch(requestInit ? new Request(input, requestInit) : input, Env, executionCtx);\n }\n input = input.toString();\n return this.fetch(\n new Request(\n /^https?:\\/\\//.test(input) ? input : `http://localhost${mergePath(\"/\", input)}`,\n requestInit\n ),\n Env,\n executionCtx\n );\n };\n fire = () => {\n addEventListener(\"fetch\", (event) => {\n event.respondWith(this.#dispatch(event.request, event, void 0, event.request.method));\n });\n };\n};\nexport {\n Hono as HonoBase\n};\n","// src/router/reg-exp-router/node.ts\nvar LABEL_REG_EXP_STR = \"[^/]+\";\nvar ONLY_WILDCARD_REG_EXP_STR = \".*\";\nvar TAIL_WILDCARD_REG_EXP_STR = \"(?:|/.*)\";\nvar PATH_ERROR = Symbol();\nvar regExpMetaChars = new Set(\".\\\\+*[^]$()\");\nfunction compareKey(a, b) {\n if (a.length === 1) {\n return b.length === 1 ? a < b ? -1 : 1 : -1;\n }\n if (b.length === 1) {\n return 1;\n }\n if (a === ONLY_WILDCARD_REG_EXP_STR || a === TAIL_WILDCARD_REG_EXP_STR) {\n return 1;\n } else if (b === ONLY_WILDCARD_REG_EXP_STR || b === TAIL_WILDCARD_REG_EXP_STR) {\n return -1;\n }\n if (a === LABEL_REG_EXP_STR) {\n return 1;\n } else if (b === LABEL_REG_EXP_STR) {\n return -1;\n }\n return a.length === b.length ? a < b ? -1 : 1 : b.length - a.length;\n}\nvar Node = class {\n #index;\n #varIndex;\n #children = /* @__PURE__ */ Object.create(null);\n insert(tokens, index, paramMap, context, pathErrorCheckOnly) {\n if (tokens.length === 0) {\n if (this.#index !== void 0) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n this.#index = index;\n return;\n }\n const [token, ...restTokens] = tokens;\n const pattern = token === \"*\" ? restTokens.length === 0 ? [\"\", \"\", ONLY_WILDCARD_REG_EXP_STR] : [\"\", \"\", LABEL_REG_EXP_STR] : token === \"/*\" ? [\"\", \"\", TAIL_WILDCARD_REG_EXP_STR] : token.match(/^\\:([^\\{\\}]+)(?:\\{(.+)\\})?$/);\n let node;\n if (pattern) {\n const name = pattern[1];\n let regexpStr = pattern[2] || LABEL_REG_EXP_STR;\n if (name && pattern[2]) {\n if (regexpStr === \".*\") {\n throw PATH_ERROR;\n }\n regexpStr = regexpStr.replace(/^\\((?!\\?:)(?=[^)]+\\)$)/, \"(?:\");\n if (/\\((?!\\?:)/.test(regexpStr)) {\n throw PATH_ERROR;\n }\n }\n node = this.#children[regexpStr];\n if (!node) {\n if (Object.keys(this.#children).some(\n (k) => k !== ONLY_WILDCARD_REG_EXP_STR && k !== TAIL_WILDCARD_REG_EXP_STR\n )) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n node = this.#children[regexpStr] = new Node();\n if (name !== \"\") {\n node.#varIndex = context.varIndex++;\n }\n }\n if (!pathErrorCheckOnly && name !== \"\") {\n paramMap.push([name, node.#varIndex]);\n }\n } else {\n node = this.#children[token];\n if (!node) {\n if (Object.keys(this.#children).some(\n (k) => k.length > 1 && k !== ONLY_WILDCARD_REG_EXP_STR && k !== TAIL_WILDCARD_REG_EXP_STR\n )) {\n throw PATH_ERROR;\n }\n if (pathErrorCheckOnly) {\n return;\n }\n node = this.#children[token] = new Node();\n }\n }\n node.insert(restTokens, index, paramMap, context, pathErrorCheckOnly);\n }\n buildRegExpStr() {\n const childKeys = Object.keys(this.#children).sort(compareKey);\n const strList = childKeys.map((k) => {\n const c = this.#children[k];\n return (typeof c.#varIndex === \"number\" ? `(${k})@${c.#varIndex}` : regExpMetaChars.has(k) ? `\\\\${k}` : k) + c.buildRegExpStr();\n });\n if (typeof this.#index === \"number\") {\n strList.unshift(`#${this.#index}`);\n }\n if (strList.length === 0) {\n return \"\";\n }\n if (strList.length === 1) {\n return strList[0];\n }\n return \"(?:\" + strList.join(\"|\") + \")\";\n }\n};\nexport {\n Node,\n PATH_ERROR\n};\n","// src/router/reg-exp-router/trie.ts\nimport { Node } from \"./node.js\";\nvar Trie = class {\n #context = { varIndex: 0 };\n #root = new Node();\n insert(path, index, pathErrorCheckOnly) {\n const paramAssoc = [];\n const groups = [];\n for (let i = 0; ; ) {\n let replaced = false;\n path = path.replace(/\\{[^}]+\\}/g, (m) => {\n const mark = `@\\\\${i}`;\n groups[i] = [mark, m];\n i++;\n replaced = true;\n return mark;\n });\n if (!replaced) {\n break;\n }\n }\n const tokens = path.match(/(?::[^\\/]+)|(?:\\/\\*$)|./g) || [];\n for (let i = groups.length - 1; i >= 0; i--) {\n const [mark] = groups[i];\n for (let j = tokens.length - 1; j >= 0; j--) {\n if (tokens[j].indexOf(mark) !== -1) {\n tokens[j] = tokens[j].replace(mark, groups[i][1]);\n break;\n }\n }\n }\n this.#root.insert(tokens, index, paramAssoc, this.#context, pathErrorCheckOnly);\n return paramAssoc;\n }\n buildRegExp() {\n let regexp = this.#root.buildRegExpStr();\n if (regexp === \"\") {\n return [/^$/, [], []];\n }\n let captureIndex = 0;\n const indexReplacementMap = [];\n const paramReplacementMap = [];\n regexp = regexp.replace(/#(\\d+)|@(\\d+)|\\.\\*\\$/g, (_, handlerIndex, paramIndex) => {\n if (handlerIndex !== void 0) {\n indexReplacementMap[++captureIndex] = Number(handlerIndex);\n return \"$()\";\n }\n if (paramIndex !== void 0) {\n paramReplacementMap[Number(paramIndex)] = ++captureIndex;\n return \"\";\n }\n return \"\";\n });\n return [new RegExp(`^${regexp}`), indexReplacementMap, paramReplacementMap];\n }\n};\nexport {\n Trie\n};\n","// src/router/reg-exp-router/router.ts\nimport {\n MESSAGE_MATCHER_IS_ALREADY_BUILT,\n METHOD_NAME_ALL,\n UnsupportedPathError\n} from \"../../router.js\";\nimport { checkOptionalParameter } from \"../../utils/url.js\";\nimport { PATH_ERROR } from \"./node.js\";\nimport { Trie } from \"./trie.js\";\nvar emptyParam = [];\nvar nullMatcher = [/^$/, [], /* @__PURE__ */ Object.create(null)];\nvar wildcardRegExpCache = /* @__PURE__ */ Object.create(null);\nfunction buildWildcardRegExp(path) {\n return wildcardRegExpCache[path] ??= new RegExp(\n path === \"*\" ? \"\" : `^${path.replace(\n /\\/\\*$|([.\\\\+*[^\\]$()])/g,\n (_, metaChar) => metaChar ? `\\\\${metaChar}` : \"(?:|/.*)\"\n )}$`\n );\n}\nfunction clearWildcardRegExpCache() {\n wildcardRegExpCache = /* @__PURE__ */ Object.create(null);\n}\nfunction buildMatcherFromPreprocessedRoutes(routes) {\n const trie = new Trie();\n const handlerData = [];\n if (routes.length === 0) {\n return nullMatcher;\n }\n const routesWithStaticPathFlag = routes.map(\n (route) => [!/\\*|\\/:/.test(route[0]), ...route]\n ).sort(\n ([isStaticA, pathA], [isStaticB, pathB]) => isStaticA ? 1 : isStaticB ? -1 : pathA.length - pathB.length\n );\n const staticMap = /* @__PURE__ */ Object.create(null);\n for (let i = 0, j = -1, len = routesWithStaticPathFlag.length; i < len; i++) {\n const [pathErrorCheckOnly, path, handlers] = routesWithStaticPathFlag[i];\n if (pathErrorCheckOnly) {\n staticMap[path] = [handlers.map(([h]) => [h, /* @__PURE__ */ Object.create(null)]), emptyParam];\n } else {\n j++;\n }\n let paramAssoc;\n try {\n paramAssoc = trie.insert(path, j, pathErrorCheckOnly);\n } catch (e) {\n throw e === PATH_ERROR ? new UnsupportedPathError(path) : e;\n }\n if (pathErrorCheckOnly) {\n continue;\n }\n handlerData[j] = handlers.map(([h, paramCount]) => {\n const paramIndexMap = /* @__PURE__ */ Object.create(null);\n paramCount -= 1;\n for (; paramCount >= 0; paramCount--) {\n const [key, value] = paramAssoc[paramCount];\n paramIndexMap[key] = value;\n }\n return [h, paramIndexMap];\n });\n }\n const [regexp, indexReplacementMap, paramReplacementMap] = trie.buildRegExp();\n for (let i = 0, len = handlerData.length; i < len; i++) {\n for (let j = 0, len2 = handlerData[i].length; j < len2; j++) {\n const map = handlerData[i][j]?.[1];\n if (!map) {\n continue;\n }\n const keys = Object.keys(map);\n for (let k = 0, len3 = keys.length; k < len3; k++) {\n map[keys[k]] = paramReplacementMap[map[keys[k]]];\n }\n }\n }\n const handlerMap = [];\n for (const i in indexReplacementMap) {\n handlerMap[i] = handlerData[indexReplacementMap[i]];\n }\n return [regexp, handlerMap, staticMap];\n}\nfunction findMiddleware(middleware, path) {\n if (!middleware) {\n return void 0;\n }\n for (const k of Object.keys(middleware).sort((a, b) => b.length - a.length)) {\n if (buildWildcardRegExp(k).test(path)) {\n return [...middleware[k]];\n }\n }\n return void 0;\n}\nvar RegExpRouter = class {\n name = \"RegExpRouter\";\n #middleware;\n #routes;\n constructor() {\n this.#middleware = { [METHOD_NAME_ALL]: /* @__PURE__ */ Object.create(null) };\n this.#routes = { [METHOD_NAME_ALL]: /* @__PURE__ */ Object.create(null) };\n }\n add(method, path, handler) {\n const middleware = this.#middleware;\n const routes = this.#routes;\n if (!middleware || !routes) {\n throw new Error(MESSAGE_MATCHER_IS_ALREADY_BUILT);\n }\n if (!middleware[method]) {\n ;\n [middleware, routes].forEach((handlerMap) => {\n handlerMap[method] = /* @__PURE__ */ Object.create(null);\n Object.keys(handlerMap[METHOD_NAME_ALL]).forEach((p) => {\n handlerMap[method][p] = [...handlerMap[METHOD_NAME_ALL][p]];\n });\n });\n }\n if (path === \"/*\") {\n path = \"*\";\n }\n const paramCount = (path.match(/\\/:/g) || []).length;\n if (/\\*$/.test(path)) {\n const re = buildWildcardRegExp(path);\n if (method === METHOD_NAME_ALL) {\n Object.keys(middleware).forEach((m) => {\n middleware[m][path] ||= findMiddleware(middleware[m], path) || findMiddleware(middleware[METHOD_NAME_ALL], path) || [];\n });\n } else {\n middleware[method][path] ||= findMiddleware(middleware[method], path) || findMiddleware(middleware[METHOD_NAME_ALL], path) || [];\n }\n Object.keys(middleware).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n Object.keys(middleware[m]).forEach((p) => {\n re.test(p) && middleware[m][p].push([handler, paramCount]);\n });\n }\n });\n Object.keys(routes).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n Object.keys(routes[m]).forEach(\n (p) => re.test(p) && routes[m][p].push([handler, paramCount])\n );\n }\n });\n return;\n }\n const paths = checkOptionalParameter(path) || [path];\n for (let i = 0, len = paths.length; i < len; i++) {\n const path2 = paths[i];\n Object.keys(routes).forEach((m) => {\n if (method === METHOD_NAME_ALL || method === m) {\n routes[m][path2] ||= [\n ...findMiddleware(middleware[m], path2) || findMiddleware(middleware[METHOD_NAME_ALL], path2) || []\n ];\n routes[m][path2].push([handler, paramCount - len + i + 1]);\n }\n });\n }\n }\n match(method, path) {\n clearWildcardRegExpCache();\n const matchers = this.#buildAllMatchers();\n this.match = (method2, path2) => {\n const matcher = matchers[method2] || matchers[METHOD_NAME_ALL];\n const staticMatch = matcher[2][path2];\n if (staticMatch) {\n return staticMatch;\n }\n const match = path2.match(matcher[0]);\n if (!match) {\n return [[], emptyParam];\n }\n const index = match.indexOf(\"\", 1);\n return [matcher[1][index], match];\n };\n return this.match(method, path);\n }\n #buildAllMatchers() {\n const matchers = /* @__PURE__ */ Object.create(null);\n Object.keys(this.#routes).concat(Object.keys(this.#middleware)).forEach((method) => {\n matchers[method] ||= this.#buildMatcher(method);\n });\n this.#middleware = this.#routes = void 0;\n return matchers;\n }\n #buildMatcher(method) {\n const routes = [];\n let hasOwnRoute = method === METHOD_NAME_ALL;\n [this.#middleware, this.#routes].forEach((r) => {\n const ownRoute = r[method] ? Object.keys(r[method]).map((path) => [path, r[method][path]]) : [];\n if (ownRoute.length !== 0) {\n hasOwnRoute ||= true;\n routes.push(...ownRoute);\n } else if (method !== METHOD_NAME_ALL) {\n routes.push(\n ...Object.keys(r[METHOD_NAME_ALL]).map((path) => [path, r[METHOD_NAME_ALL][path]])\n );\n }\n });\n if (!hasOwnRoute) {\n return null;\n } else {\n return buildMatcherFromPreprocessedRoutes(routes);\n }\n }\n};\nexport {\n RegExpRouter\n};\n","// src/router/smart-router/router.ts\nimport { MESSAGE_MATCHER_IS_ALREADY_BUILT, UnsupportedPathError } from \"../../router.js\";\nvar SmartRouter = class {\n name = \"SmartRouter\";\n #routers = [];\n #routes = [];\n constructor(init) {\n this.#routers = init.routers;\n }\n add(method, path, handler) {\n if (!this.#routes) {\n throw new Error(MESSAGE_MATCHER_IS_ALREADY_BUILT);\n }\n this.#routes.push([method, path, handler]);\n }\n match(method, path) {\n if (!this.#routes) {\n throw new Error(\"Fatal error\");\n }\n const routers = this.#routers;\n const routes = this.#routes;\n const len = routers.length;\n let i = 0;\n let res;\n for (; i < len; i++) {\n const router = routers[i];\n try {\n for (let i2 = 0, len2 = routes.length; i2 < len2; i2++) {\n router.add(...routes[i2]);\n }\n res = router.match(method, path);\n } catch (e) {\n if (e instanceof UnsupportedPathError) {\n continue;\n }\n throw e;\n }\n this.match = router.match.bind(router);\n this.#routers = [router];\n this.#routes = void 0;\n break;\n }\n if (i === len) {\n throw new Error(\"Fatal error\");\n }\n this.name = `SmartRouter + ${this.activeRouter.name}`;\n return res;\n }\n get activeRouter() {\n if (this.#routes || this.#routers.length !== 1) {\n throw new Error(\"No active router has been determined yet.\");\n }\n return this.#routers[0];\n }\n};\nexport {\n SmartRouter\n};\n","// src/router/trie-router/node.ts\nimport { METHOD_NAME_ALL } from \"../../router.js\";\nimport { getPattern, splitPath, splitRoutingPath } from \"../../utils/url.js\";\nvar emptyParams = /* @__PURE__ */ Object.create(null);\nvar Node = class {\n #methods;\n #children;\n #patterns;\n #order = 0;\n #params = emptyParams;\n constructor(method, handler, children) {\n this.#children = children || /* @__PURE__ */ Object.create(null);\n this.#methods = [];\n if (method && handler) {\n const m = /* @__PURE__ */ Object.create(null);\n m[method] = { handler, possibleKeys: [], score: 0 };\n this.#methods = [m];\n }\n this.#patterns = [];\n }\n insert(method, path, handler) {\n this.#order = ++this.#order;\n let curNode = this;\n const parts = splitRoutingPath(path);\n const possibleKeys = [];\n for (let i = 0, len = parts.length; i < len; i++) {\n const p = parts[i];\n const nextP = parts[i + 1];\n const pattern = getPattern(p, nextP);\n const key = Array.isArray(pattern) ? pattern[0] : p;\n if (key in curNode.#children) {\n curNode = curNode.#children[key];\n if (pattern) {\n possibleKeys.push(pattern[1]);\n }\n continue;\n }\n curNode.#children[key] = new Node();\n if (pattern) {\n curNode.#patterns.push(pattern);\n possibleKeys.push(pattern[1]);\n }\n curNode = curNode.#children[key];\n }\n curNode.#methods.push({\n [method]: {\n handler,\n possibleKeys: possibleKeys.filter((v, i, a) => a.indexOf(v) === i),\n score: this.#order\n }\n });\n return curNode;\n }\n #getHandlerSets(node, method, nodeParams, params) {\n const handlerSets = [];\n for (let i = 0, len = node.#methods.length; i < len; i++) {\n const m = node.#methods[i];\n const handlerSet = m[method] || m[METHOD_NAME_ALL];\n const processedSet = {};\n if (handlerSet !== void 0) {\n handlerSet.params = /* @__PURE__ */ Object.create(null);\n handlerSets.push(handlerSet);\n if (nodeParams !== emptyParams || params && params !== emptyParams) {\n for (let i2 = 0, len2 = handlerSet.possibleKeys.length; i2 < len2; i2++) {\n const key = handlerSet.possibleKeys[i2];\n const processed = processedSet[handlerSet.score];\n handlerSet.params[key] = params?.[key] && !processed ? params[key] : nodeParams[key] ?? params?.[key];\n processedSet[handlerSet.score] = true;\n }\n }\n }\n }\n return handlerSets;\n }\n search(method, path) {\n const handlerSets = [];\n this.#params = emptyParams;\n const curNode = this;\n let curNodes = [curNode];\n const parts = splitPath(path);\n const curNodesQueue = [];\n for (let i = 0, len = parts.length; i < len; i++) {\n const part = parts[i];\n const isLast = i === len - 1;\n const tempNodes = [];\n for (let j = 0, len2 = curNodes.length; j < len2; j++) {\n const node = curNodes[j];\n const nextNode = node.#children[part];\n if (nextNode) {\n nextNode.#params = node.#params;\n if (isLast) {\n if (nextNode.#children[\"*\"]) {\n handlerSets.push(\n ...this.#getHandlerSets(nextNode.#children[\"*\"], method, node.#params)\n );\n }\n handlerSets.push(...this.#getHandlerSets(nextNode, method, node.#params));\n } else {\n tempNodes.push(nextNode);\n }\n }\n for (let k = 0, len3 = node.#patterns.length; k < len3; k++) {\n const pattern = node.#patterns[k];\n const params = node.#params === emptyParams ? {} : { ...node.#params };\n if (pattern === \"*\") {\n const astNode = node.#children[\"*\"];\n if (astNode) {\n handlerSets.push(...this.#getHandlerSets(astNode, method, node.#params));\n astNode.#params = params;\n tempNodes.push(astNode);\n }\n continue;\n }\n const [key, name, matcher] = pattern;\n if (!part && !(matcher instanceof RegExp)) {\n continue;\n }\n const child = node.#children[key];\n const restPathString = parts.slice(i).join(\"/\");\n if (matcher instanceof RegExp) {\n const m = matcher.exec(restPathString);\n if (m) {\n params[name] = m[0];\n handlerSets.push(...this.#getHandlerSets(child, method, node.#params, params));\n if (Object.keys(child.#children).length) {\n child.#params = params;\n const componentCount = m[0].match(/\\//)?.length ?? 0;\n const targetCurNodes = curNodesQueue[componentCount] ||= [];\n targetCurNodes.push(child);\n }\n continue;\n }\n }\n if (matcher === true || matcher.test(part)) {\n params[name] = part;\n if (isLast) {\n handlerSets.push(...this.#getHandlerSets(child, method, params, node.#params));\n if (child.#children[\"*\"]) {\n handlerSets.push(\n ...this.#getHandlerSets(child.#children[\"*\"], method, params, node.#params)\n );\n }\n } else {\n child.#params = params;\n tempNodes.push(child);\n }\n }\n }\n }\n curNodes = tempNodes.concat(curNodesQueue.shift() ?? []);\n }\n if (handlerSets.length > 1) {\n handlerSets.sort((a, b) => {\n return a.score - b.score;\n });\n }\n return [handlerSets.map(({ handler, params }) => [handler, params])];\n }\n};\nexport {\n Node\n};\n","// src/router/trie-router/router.ts\nimport { checkOptionalParameter } from \"../../utils/url.js\";\nimport { Node } from \"./node.js\";\nvar TrieRouter = class {\n name = \"TrieRouter\";\n #node;\n constructor() {\n this.#node = new Node();\n }\n add(method, path, handler) {\n const results = checkOptionalParameter(path);\n if (results) {\n for (let i = 0, len = results.length; i < len; i++) {\n this.#node.insert(method, results[i], handler);\n }\n return;\n }\n this.#node.insert(method, path, handler);\n }\n match(method, path) {\n return this.#node.search(method, path);\n }\n};\nexport {\n TrieRouter\n};\n","// src/hono.ts\nimport { HonoBase } from \"./hono-base.js\";\nimport { RegExpRouter } from \"./router/reg-exp-router/index.js\";\nimport { SmartRouter } from \"./router/smart-router/index.js\";\nimport { TrieRouter } from \"./router/trie-router/index.js\";\nvar Hono = class extends HonoBase {\n constructor(options = {}) {\n super(options);\n this.router = options.router ?? new SmartRouter({\n routers: [new RegExpRouter(), new TrieRouter()]\n });\n }\n};\nexport {\n Hono\n};\n","// src/middleware/cors/index.ts\nvar cors = (options) => {\n const defaults = {\n origin: \"*\",\n allowMethods: [\"GET\", \"HEAD\", \"PUT\", \"POST\", \"DELETE\", \"PATCH\"],\n allowHeaders: [],\n exposeHeaders: []\n };\n const opts = {\n ...defaults,\n ...options\n };\n const findAllowOrigin = ((optsOrigin) => {\n if (typeof optsOrigin === \"string\") {\n if (optsOrigin === \"*\") {\n return () => optsOrigin;\n } else {\n return (origin) => optsOrigin === origin ? origin : null;\n }\n } else if (typeof optsOrigin === \"function\") {\n return optsOrigin;\n } else {\n return (origin) => optsOrigin.includes(origin) ? origin : null;\n }\n })(opts.origin);\n const findAllowMethods = ((optsAllowMethods) => {\n if (typeof optsAllowMethods === \"function\") {\n return optsAllowMethods;\n } else if (Array.isArray(optsAllowMethods)) {\n return () => optsAllowMethods;\n } else {\n return () => [];\n }\n })(opts.allowMethods);\n return async function cors2(c, next) {\n function set(key, value) {\n c.res.headers.set(key, value);\n }\n const allowOrigin = await findAllowOrigin(c.req.header(\"origin\") || \"\", c);\n if (allowOrigin) {\n set(\"Access-Control-Allow-Origin\", allowOrigin);\n }\n if (opts.origin !== \"*\") {\n const existingVary = c.req.header(\"Vary\");\n if (existingVary) {\n set(\"Vary\", existingVary);\n } else {\n set(\"Vary\", \"Origin\");\n }\n }\n if (opts.credentials) {\n set(\"Access-Control-Allow-Credentials\", \"true\");\n }\n if (opts.exposeHeaders?.length) {\n set(\"Access-Control-Expose-Headers\", opts.exposeHeaders.join(\",\"));\n }\n if (c.req.method === \"OPTIONS\") {\n if (opts.maxAge != null) {\n set(\"Access-Control-Max-Age\", opts.maxAge.toString());\n }\n const allowMethods = await findAllowMethods(c.req.header(\"origin\") || \"\", c);\n if (allowMethods.length) {\n set(\"Access-Control-Allow-Methods\", allowMethods.join(\",\"));\n }\n let headers = opts.allowHeaders;\n if (!headers?.length) {\n const requestHeaders = c.req.header(\"Access-Control-Request-Headers\");\n if (requestHeaders) {\n headers = requestHeaders.split(/\\s*,\\s*/);\n }\n }\n if (headers?.length) {\n set(\"Access-Control-Allow-Headers\", headers.join(\",\"));\n c.res.headers.append(\"Vary\", \"Access-Control-Request-Headers\");\n }\n c.res.headers.delete(\"Content-Length\");\n c.res.headers.delete(\"Content-Type\");\n return new Response(null, {\n headers: c.res.headers,\n status: 204,\n statusText: \"No Content\"\n });\n }\n await next();\n };\n};\nexport {\n cors\n};\n","// src/utils/color.ts\nfunction getColorEnabled() {\n const { process, Deno } = globalThis;\n const isNoColor = typeof Deno?.noColor === \"boolean\" ? Deno.noColor : process !== void 0 ? \"NO_COLOR\" in process?.env : false;\n return !isNoColor;\n}\nasync function getColorEnabledAsync() {\n const { navigator } = globalThis;\n const cfWorkers = \"cloudflare:workers\";\n const isNoColor = navigator !== void 0 && navigator.userAgent === \"Cloudflare-Workers\" ? await (async () => {\n try {\n return \"NO_COLOR\" in ((await import(cfWorkers)).env ?? {});\n } catch {\n return false;\n }\n })() : !getColorEnabled();\n return !isNoColor;\n}\nexport {\n getColorEnabled,\n getColorEnabledAsync\n};\n","// src/middleware/logger/index.ts\nimport { getColorEnabledAsync } from \"../../utils/color.js\";\nvar humanize = (times) => {\n const [delimiter, separator] = [\",\", \".\"];\n const orderTimes = times.map((v) => v.replace(/(\\d)(?=(\\d\\d\\d)+(?!\\d))/g, \"$1\" + delimiter));\n return orderTimes.join(separator);\n};\nvar time = (start) => {\n const delta = Date.now() - start;\n return humanize([delta < 1e3 ? delta + \"ms\" : Math.round(delta / 1e3) + \"s\"]);\n};\nvar colorStatus = async (status) => {\n const colorEnabled = await getColorEnabledAsync();\n if (colorEnabled) {\n switch (status / 100 | 0) {\n case 5:\n return `\\x1B[31m${status}\\x1B[0m`;\n case 4:\n return `\\x1B[33m${status}\\x1B[0m`;\n case 3:\n return `\\x1B[36m${status}\\x1B[0m`;\n case 2:\n return `\\x1B[32m${status}\\x1B[0m`;\n }\n }\n return `${status}`;\n};\nasync function log(fn, prefix, method, path, status = 0, elapsed) {\n const out = prefix === \"<--\" /* Incoming */ ? `${prefix} ${method} ${path}` : `${prefix} ${method} ${path} ${await colorStatus(status)} ${elapsed}`;\n fn(out);\n}\nvar logger = (fn = console.log) => {\n return async function logger2(c, next) {\n const { method, url } = c.req;\n const path = url.slice(url.indexOf(\"/\", 8));\n await log(fn, \"<--\" /* Incoming */, method, path);\n const start = Date.now();\n await next();\n await log(fn, \"-->\" /* Outgoing */, method, path, c.res.status, time(start));\n };\n};\nexport {\n logger\n};\n","import type { Context, MiddlewareHandler } from \"hono\"\n\nimport consola from \"consola\"\n\nimport { getConfig } from \"./config\"\n\ninterface AuthMiddlewareOptions {\n getApiKeys?: () => Array<string>\n allowUnauthenticatedPaths?: Array<string>\n allowOptionsBypass?: boolean\n}\n\nexport function normalizeApiKeys(apiKeys: unknown): Array<string> {\n if (!Array.isArray(apiKeys)) {\n if (apiKeys !== undefined) {\n consola.warn(\"Invalid auth.apiKeys config. Expected an array of strings.\")\n }\n return []\n }\n\n const normalizedKeys = apiKeys\n .filter((key): key is string => typeof key === \"string\")\n .map((key) => key.trim())\n .filter((key) => key.length > 0)\n\n if (normalizedKeys.length !== apiKeys.length) {\n consola.warn(\n \"Invalid auth.apiKeys entries found. Only non-empty strings are allowed.\",\n )\n }\n\n return [...new Set(normalizedKeys)]\n}\n\nexport function getConfiguredApiKeys(): Array<string> {\n const config = getConfig()\n return normalizeApiKeys(config.auth?.apiKeys)\n}\n\nexport function extractRequestApiKey(c: Context): string | null {\n const xApiKey = c.req.header(\"x-api-key\")?.trim()\n if (xApiKey) {\n return xApiKey\n }\n\n const authorization = c.req.header(\"authorization\")\n if (!authorization) {\n return null\n }\n\n const [scheme, ...rest] = authorization.trim().split(/\\s+/)\n if (scheme.toLowerCase() !== \"bearer\") {\n return null\n }\n\n const bearerToken = rest.join(\" \").trim()\n return bearerToken || null\n}\n\nfunction createUnauthorizedResponse(c: Context): Response {\n c.header(\"WWW-Authenticate\", 'Bearer realm=\"copilot-api\"')\n return c.json(\n {\n error: {\n message: \"Unauthorized\",\n type: \"authentication_error\",\n },\n },\n 401,\n )\n}\n\nexport function createAuthMiddleware(\n options: AuthMiddlewareOptions = {},\n): MiddlewareHandler {\n const getApiKeys = options.getApiKeys ?? getConfiguredApiKeys\n const allowUnauthenticatedPaths = options.allowUnauthenticatedPaths ?? [\"/\"]\n const allowOptionsBypass = options.allowOptionsBypass ?? true\n\n return async (c, next) => {\n if (allowOptionsBypass && c.req.method === \"OPTIONS\") {\n return next()\n }\n\n if (allowUnauthenticatedPaths.includes(c.req.path)) {\n return next()\n }\n\n const apiKeys = getApiKeys()\n if (apiKeys.length === 0) {\n return next()\n }\n\n const requestApiKey = extractRequestApiKey(c)\n if (!requestApiKey || !apiKeys.includes(requestApiKey)) {\n return createUnauthorizedResponse(c)\n }\n\n return next()\n }\n}\n","import type { MiddlewareHandler } from \"hono\"\n\nimport { requestContext, resolveTraceId } from \"./request-context\"\n\nexport const traceIdMiddleware: MiddlewareHandler = async (c, next) => {\n const traceId = resolveTraceId(c.req.header(\"x-trace-id\"))\n\n c.header(\"x-trace-id\", traceId)\n\n const context = {\n traceId,\n startTime: Date.now(),\n userAgent: c.req.header(\"user-agent\") || \"\",\n sessionAffinity: c.req.header(\"x-session-affinity\"),\n parentSessionId: c.req.header(\"x-parent-session-id\"),\n }\n\n await requestContext.run(context, async () => {\n await next()\n })\n}\n","// src/utils/stream.ts\nvar StreamingApi = class {\n writer;\n encoder;\n writable;\n abortSubscribers = [];\n responseReadable;\n aborted = false;\n closed = false;\n constructor(writable, _readable) {\n this.writable = writable;\n this.writer = writable.getWriter();\n this.encoder = new TextEncoder();\n const reader = _readable.getReader();\n this.abortSubscribers.push(async () => {\n await reader.cancel();\n });\n this.responseReadable = new ReadableStream({\n async pull(controller) {\n const { done, value } = await reader.read();\n done ? controller.close() : controller.enqueue(value);\n },\n cancel: () => {\n this.abort();\n }\n });\n }\n async write(input) {\n try {\n if (typeof input === \"string\") {\n input = this.encoder.encode(input);\n }\n await this.writer.write(input);\n } catch {\n }\n return this;\n }\n async writeln(input) {\n await this.write(input + \"\\n\");\n return this;\n }\n sleep(ms) {\n return new Promise((res) => setTimeout(res, ms));\n }\n async close() {\n try {\n await this.writer.close();\n } catch {\n }\n this.closed = true;\n }\n async pipe(body) {\n this.writer.releaseLock();\n await body.pipeTo(this.writable, { preventClose: true });\n this.writer = this.writable.getWriter();\n }\n onAbort(listener) {\n this.abortSubscribers.push(listener);\n }\n abort() {\n if (!this.aborted) {\n this.aborted = true;\n this.abortSubscribers.forEach((subscriber) => subscriber());\n }\n }\n};\nexport {\n StreamingApi\n};\n","// src/helper/streaming/utils.ts\nvar isOldBunVersion = () => {\n const version = typeof Bun !== \"undefined\" ? Bun.version : void 0;\n if (version === void 0) {\n return false;\n }\n const result = version.startsWith(\"1.1\") || version.startsWith(\"1.0\") || version.startsWith(\"0.\");\n isOldBunVersion = () => result;\n return result;\n};\nexport {\n isOldBunVersion\n};\n","// src/helper/streaming/sse.ts\nimport { HtmlEscapedCallbackPhase, resolveCallback } from \"../../utils/html.js\";\nimport { StreamingApi } from \"../../utils/stream.js\";\nimport { isOldBunVersion } from \"./utils.js\";\nvar SSEStreamingApi = class extends StreamingApi {\n constructor(writable, readable) {\n super(writable, readable);\n }\n async writeSSE(message) {\n const data = await resolveCallback(message.data, HtmlEscapedCallbackPhase.Stringify, false, {});\n const dataLines = data.split(\"\\n\").map((line) => {\n return `data: ${line}`;\n }).join(\"\\n\");\n const sseData = [\n message.event && `event: ${message.event}`,\n dataLines,\n message.id && `id: ${message.id}`,\n message.retry && `retry: ${message.retry}`\n ].filter(Boolean).join(\"\\n\") + \"\\n\\n\";\n await this.write(sseData);\n }\n};\nvar run = async (stream, cb, onError) => {\n try {\n await cb(stream);\n } catch (e) {\n if (e instanceof Error && onError) {\n await onError(e, stream);\n await stream.writeSSE({\n event: \"error\",\n data: e.message\n });\n } else {\n console.error(e);\n }\n } finally {\n stream.close();\n }\n};\nvar contextStash = /* @__PURE__ */ new WeakMap();\nvar streamSSE = (c, cb, onError) => {\n const { readable, writable } = new TransformStream();\n const stream = new SSEStreamingApi(writable, readable);\n if (isOldBunVersion()) {\n c.req.raw.signal.addEventListener(\"abort\", () => {\n if (!stream.closed) {\n stream.abort();\n }\n });\n }\n contextStash.set(stream.responseReadable, c);\n c.header(\"Transfer-Encoding\", \"chunked\");\n c.header(\"Content-Type\", \"text/event-stream\");\n c.header(\"Cache-Control\", \"no-cache\");\n c.header(\"Connection\", \"keep-alive\");\n run(stream, cb, onError);\n return c.newResponse(stream.responseReadable);\n};\nexport {\n SSEStreamingApi,\n streamSSE\n};\n","import consola from \"consola\"\n\nimport { HTTPError } from \"./error\"\n\nexport const awaitApproval = async () => {\n const response = await consola.prompt(`Accept incoming request?`, {\n type: \"confirm\",\n })\n\n if (!response)\n throw new HTTPError(\n \"Request rejected\",\n Response.json({ message: \"Request rejected\" }, { status: 403 }),\n )\n}\n","import consola, { type ConsolaInstance } from \"consola\"\nimport fs from \"node:fs\"\nimport path from \"node:path\"\nimport util from \"node:util\"\n\nimport { PATHS } from \"./paths\"\nimport { requestContext } from \"./request-context\"\nimport { state } from \"./state\"\n\nconst LOG_RETENTION_DAYS = 7\nconst LOG_RETENTION_MS = LOG_RETENTION_DAYS * 24 * 60 * 60 * 1000\nconst CLEANUP_INTERVAL_MS = 24 * 60 * 60 * 1000\nconst LOG_DIR = path.join(PATHS.APP_DIR, \"logs\")\nconst FLUSH_INTERVAL_MS = 1000\nconst MAX_BUFFER_SIZE = 100\n\nconst logStreams = new Map<string, fs.WriteStream>()\nconst logBuffers = new Map<string, Array<string>>()\n\nlet runtimeInitialized = false\nlet flushInterval: ReturnType<typeof setInterval> | undefined\nlet cleanupInterval: ReturnType<typeof setInterval> | undefined\n\nconst ensureLogDirectory = () => {\n if (!fs.existsSync(LOG_DIR)) {\n fs.mkdirSync(LOG_DIR, { recursive: true })\n }\n}\n\nconst cleanupOldLogs = () => {\n if (!fs.existsSync(LOG_DIR)) {\n return\n }\n\n const now = Date.now()\n\n for (const entry of fs.readdirSync(LOG_DIR)) {\n const filePath = path.join(LOG_DIR, entry)\n\n let stats: fs.Stats\n try {\n stats = fs.statSync(filePath)\n } catch {\n continue\n }\n\n if (!stats.isFile()) {\n continue\n }\n\n if (now - stats.mtimeMs > LOG_RETENTION_MS) {\n try {\n fs.rmSync(filePath)\n } catch {\n continue\n }\n }\n }\n}\n\nconst formatArgs = (args: Array<unknown>) =>\n args\n .map((arg) =>\n typeof arg === \"string\" ? arg : (\n util.inspect(arg, { depth: null, colors: false })\n ),\n )\n .join(\" \")\n\nconst sanitizeName = (name: string) => {\n const normalized = name\n .toLowerCase()\n .replaceAll(/[^a-z0-9]+/g, \"-\")\n .replaceAll(/^-+|-+$/g, \"\")\n\n return normalized === \"\" ? \"handler\" : normalized\n}\n\nconst maybeUnref = (timer: ReturnType<typeof setInterval>) => {\n timer.unref()\n}\n\nconst flushBuffer = (filePath: string) => {\n const buffer = logBuffers.get(filePath)\n if (!buffer || buffer.length === 0) {\n return\n }\n\n const stream = getLogStream(filePath)\n const content = buffer.join(\"\\n\") + \"\\n\"\n stream.write(content, (error) => {\n if (error) {\n console.warn(\"Failed to write handler log\", error)\n }\n })\n\n logBuffers.set(filePath, [])\n}\n\nconst flushAllBuffers = () => {\n for (const filePath of logBuffers.keys()) {\n flushBuffer(filePath)\n }\n}\n\nconst cleanup = () => {\n if (flushInterval) {\n clearInterval(flushInterval)\n flushInterval = undefined\n }\n if (cleanupInterval) {\n clearInterval(cleanupInterval)\n cleanupInterval = undefined\n }\n\n flushAllBuffers()\n for (const stream of logStreams.values()) {\n stream.end()\n }\n logStreams.clear()\n logBuffers.clear()\n}\n\nconst initializeLoggerRuntime = () => {\n if (runtimeInitialized) {\n return\n }\n\n runtimeInitialized = true\n\n ensureLogDirectory()\n cleanupOldLogs()\n\n flushInterval = setInterval(flushAllBuffers, FLUSH_INTERVAL_MS)\n maybeUnref(flushInterval)\n\n cleanupInterval = setInterval(cleanupOldLogs, CLEANUP_INTERVAL_MS)\n maybeUnref(cleanupInterval)\n\n process.once(\"exit\", cleanup)\n process.once(\"SIGINT\", () => {\n cleanup()\n process.exit(0)\n })\n process.once(\"SIGTERM\", () => {\n cleanup()\n process.exit(0)\n })\n}\n\nconst getLogStream = (filePath: string): fs.WriteStream => {\n initializeLoggerRuntime()\n\n let stream = logStreams.get(filePath)\n if (!stream || stream.destroyed) {\n stream = fs.createWriteStream(filePath, { flags: \"a\" })\n logStreams.set(filePath, stream)\n\n stream.on(\"error\", (error: unknown) => {\n console.warn(\"Log stream error\", error)\n logStreams.delete(filePath)\n })\n }\n return stream\n}\n\nconst appendLine = (filePath: string, line: string) => {\n let buffer = logBuffers.get(filePath)\n if (!buffer) {\n buffer = []\n logBuffers.set(filePath, buffer)\n }\n\n buffer.push(line)\n\n if (buffer.length >= MAX_BUFFER_SIZE) {\n flushBuffer(filePath)\n }\n}\n\ntype DebugLogger = Pick<ConsolaInstance, \"debug\">\n\nexport const debugLazy = (\n logger: DebugLogger,\n factory: () => [unknown, ...Array<unknown>],\n): void => {\n if (!state.verbose) {\n return\n }\n\n logger.debug(...factory())\n}\n\nexport const debugJson = (\n logger: DebugLogger,\n label: string,\n value: unknown,\n): void => {\n debugLazy(logger, () => [label, JSON.stringify(value)])\n}\n\nexport const debugJsonTail = (\n logger: DebugLogger,\n label: string,\n { value, tailLength = 400 }: { value: unknown; tailLength?: number },\n): void => {\n debugLazy(logger, () => [label, JSON.stringify(value).slice(-tailLength)])\n}\n\nexport const createHandlerLogger = (name: string): ConsolaInstance => {\n const sanitizedName = sanitizeName(name)\n const instance = consola.withTag(name)\n\n if (state.verbose) {\n instance.level = 5\n }\n instance.setReporters([])\n\n instance.addReporter({\n log(logObj) {\n initializeLoggerRuntime()\n\n const context = requestContext.getStore()\n const traceId = context?.traceId\n const date = logObj.date\n const dateKey = date.toLocaleDateString(\"sv-SE\")\n const timestamp = date.toLocaleString(\"sv-SE\", { hour12: false })\n const filePath = path.join(LOG_DIR, `${sanitizedName}-${dateKey}.log`)\n const message = formatArgs(logObj.args as Array<unknown>)\n const traceIdStr = traceId ? ` [${traceId}]` : \"\"\n const line = `[${timestamp}] [${logObj.type}] [${logObj.tag || name}]${traceIdStr}${\n message ? ` ${message}` : \"\"\n }`\n\n appendLine(filePath, line)\n },\n })\n\n return instance\n}\n","import consola from \"consola\"\n\nimport type { State } from \"./state\"\n\nimport { HTTPError } from \"./error\"\nimport { sleep } from \"./utils\"\n\nexport async function checkRateLimit(state: State) {\n if (state.rateLimitSeconds === undefined) return\n\n const now = Date.now()\n\n if (!state.lastRequestTimestamp) {\n state.lastRequestTimestamp = now\n return\n }\n\n const elapsedSeconds = (now - state.lastRequestTimestamp) / 1000\n\n if (elapsedSeconds > state.rateLimitSeconds) {\n state.lastRequestTimestamp = now\n return\n }\n\n const waitTimeSeconds = Math.ceil(state.rateLimitSeconds - elapsedSeconds)\n\n if (!state.rateLimitWait) {\n consola.warn(\n `Rate limit exceeded. Need to wait ${waitTimeSeconds} more seconds.`,\n )\n throw new HTTPError(\n \"Rate limit exceeded\",\n Response.json({ message: \"Rate limit exceeded\" }, { status: 429 }),\n )\n }\n\n const waitTimeMs = waitTimeSeconds * 1000\n consola.warn(\n `Rate limit reached. Waiting ${waitTimeSeconds} seconds before proceeding...`,\n )\n await sleep(waitTimeMs)\n // eslint-disable-next-line require-atomic-updates\n state.lastRequestTimestamp = now\n consola.info(\"Rate limit wait completed, proceeding with request\")\n return\n}\n","// Copyright 2018-2024 the Deno authors. All rights reserved. MIT license.\n// This module is browser compatible.\n/**\n * Transform a stream into a stream where each chunk is divided by a newline,\n * be it `\\n` or `\\r\\n`. `\\r` can be enabled via the `allowCR` option.\n *\n * @example\n * ```ts\n * import { TextLineStream } from \"@std/streams/text-line-stream\";\n *\n * const res = await fetch(\"https://example.com\");\n * const lines = res.body!\n * .pipeThrough(new TextDecoderStream())\n * .pipeThrough(new TextLineStream());\n * ```\n */\nexport class TextLineStream extends TransformStream {\n #currentLine = \"\";\n /** Constructs a new instance. */\n constructor(options = { allowCR: false }) {\n super({\n transform: (chars, controller) => {\n chars = this.#currentLine + chars;\n while (true) {\n const lfIndex = chars.indexOf(\"\\n\");\n const crIndex = options.allowCR ? chars.indexOf(\"\\r\") : -1;\n if (crIndex !== -1 && crIndex !== (chars.length - 1) &&\n (lfIndex === -1 || (lfIndex - 1) > crIndex)) {\n controller.enqueue(chars.slice(0, crIndex));\n chars = chars.slice(crIndex + 1);\n continue;\n }\n if (lfIndex === -1)\n break;\n const endIndex = chars[lfIndex - 1] === \"\\r\" ? lfIndex - 1 : lfIndex;\n controller.enqueue(chars.slice(0, endIndex));\n chars = chars.slice(lfIndex + 1);\n }\n this.#currentLine = chars;\n },\n flush: (controller) => {\n if (this.#currentLine === \"\")\n return;\n const currentLine = options.allowCR && this.#currentLine.endsWith(\"\\r\")\n ? this.#currentLine.slice(0, -1)\n : this.#currentLine;\n controller.enqueue(currentLine);\n },\n });\n }\n}\n","import { TextLineStream } from './deps/jsr.io/@std/streams/0.221.0/text_line_stream.js';\nexport function stream(input) {\n let decoder = new TextDecoderStream();\n let split = new TextLineStream({ allowCR: true });\n return input.pipeThrough(decoder).pipeThrough(split);\n}\nexport function split(input) {\n let rgx = /[:]\\s*/;\n let match = rgx.exec(input);\n // \": comment\" -> index=0 -> ignore\n let idx = match && match.index;\n if (idx) {\n return [\n input.substring(0, idx),\n input.substring(idx + match[0].length),\n ];\n }\n}\nexport function fallback(headers, key, value) {\n let tmp = headers.get(key);\n if (!tmp)\n headers.set(key, value);\n}\n","import * as utils from './utils.js';\n/**\n * Convert a `Response` body containing Server Sent Events (SSE) into an Async Iterator that yields {@linkcode ServerSentEventMessage} objects.\n *\n * @see {@link https://developer.mozilla.org/en-US/docs/Web/API/Server-sent_events}\n *\n * @example\n * ```js\n * // Optional\n * let abort = new AbortController;\n *\n * // Manually fetch a Response\n * let res = await fetch('https://...', {\n * method: 'POST',\n * signal: abort.signal,\n * headers: {\n * 'api-key': 'token <value>',\n * 'content-type': 'application/json',\n * },\n * body: JSON.stringify({\n * stream: true, // <- hypothetical\n * // ...\n * })\n * });\n *\n * if (res.ok) {\n * let stream = events(res, abort.signal);\n * for await (let event of stream) {\n * console.log('<<', event.data);\n * }\n * }\n * ```\n */\nexport async function* events(res, signal) {\n // TODO: throw error?\n if (!res.body)\n return;\n let iter = utils.stream(res.body);\n let line, reader = iter.getReader();\n let event;\n for (;;) {\n if (signal && signal.aborted) {\n return reader.cancel();\n }\n line = await reader.read();\n if (line.done)\n return;\n if (!line.value) {\n if (event)\n yield event;\n event = undefined;\n continue;\n }\n let [field, value] = utils.split(line.value) || [];\n if (!field)\n continue; // comment or invalid\n if (field === 'data') {\n event ||= {};\n event[field] = event[field] ? (event[field] + '\\n' + value) : value;\n }\n else if (field === 'event') {\n event ||= {};\n event[field] = value;\n }\n else if (field === 'id') {\n event ||= {};\n event[field] = +value || value;\n }\n else if (field === 'retry') {\n event ||= {};\n event[field] = +value || undefined;\n }\n }\n}\n/**\n * Convenience function that will `fetch` with the given arguments and, if ok, will return the {@linkcode events} async iterator.\n *\n * If the response is not ok (status 200-299), the `Response` is thrown.\n *\n * @example\n * ```js\n * // NOTE: throws `Response` if not 2xx status\n * let events = await stream('https://api.openai.com/...', {\n * method: 'POST',\n * headers: {\n * 'Authorization': 'Bearer <token>',\n * 'Content-Type': 'application/json',\n * },\n * body: JSON.stringify({\n * stream: true,\n * // ...\n * })\n * });\n *\n * for await (let event of events) {\n * console.log('<<', JSON.parse(event.data));\n * }\n * ```\n */\nexport async function stream(input, init) {\n let req = new Request(input, init);\n utils.fallback(req.headers, 'Accept', 'text/event-stream');\n utils.fallback(req.headers, 'Content-Type', 'application/json');\n let r = await fetch(req);\n if (!r.ok)\n throw r;\n return events(r, req.signal);\n}\n","import consola from \"consola\"\n\nconst copilotRateLimitTypes = [\"session\", \"weekly\"] as const\n\nexport type CopilotRateLimitType = (typeof copilotRateLimitTypes)[number]\ntype HeadersMap = Record<string, string | undefined>\ntype HeadersLike = Headers | HeadersMap\n\nexport interface CopilotRateLimitUsage {\n type: CopilotRateLimitType\n remaining: string\n resetAt: string\n}\n\nconst copilotRateLimitHeaders: Record<CopilotRateLimitType, string> = {\n session: \"x-usage-ratelimit-session\",\n weekly: \"x-usage-ratelimit-weekly\",\n}\n\nconst hasGetMethod = (headers: HeadersLike): headers is Headers => {\n return \"get\" in headers && typeof headers.get === \"function\"\n}\n\nconst getHeaderValue = (\n headers: HeadersLike,\n headerName: string,\n): string | null => {\n if (hasGetMethod(headers)) {\n return headers.get(headerName)\n }\n\n const normalizedHeaderName = headerName.toLowerCase()\n const matchedEntry = Object.entries(headers).find(\n ([key]) => key.toLowerCase() === normalizedHeaderName,\n )\n\n return matchedEntry?.[1] ?? null\n}\n\nexport const parseCopilotRateLimitHeader = (\n headerValue: string,\n): Omit<CopilotRateLimitUsage, \"type\"> | null => {\n const params = new URLSearchParams(headerValue)\n const remaining = params.get(\"rem\")\n const resetAt = params.get(\"rst\")\n\n if (!remaining || !resetAt) {\n return null\n }\n\n return {\n remaining,\n resetAt,\n }\n}\n\nexport const getCopilotRateLimitUsage = (\n headers: HeadersLike,\n type: CopilotRateLimitType,\n): CopilotRateLimitUsage | null => {\n const headerName = copilotRateLimitHeaders[type]\n const headerValue = getHeaderValue(headers, headerName)\n\n if (!headerValue) {\n return null\n }\n\n const parsed = parseCopilotRateLimitHeader(headerValue)\n\n if (!parsed) {\n return null\n }\n\n return {\n type,\n ...parsed,\n }\n}\n\nexport const logCopilotRateLimits = (headers: HeadersLike): void => {\n for (const type of copilotRateLimitTypes) {\n const usage = getCopilotRateLimitUsage(headers, type)\n\n if (!usage) {\n continue\n }\n\n const d = new Date(usage.resetAt)\n const dateStr =\n Number.isNaN(d.getTime()) ? usage.resetAt : d.toLocaleString()\n consola.info(\n `Copilot ${usage.type} quota remaining: ${usage.remaining}, resets at: ${dateStr}`,\n )\n }\n}\n","import consola from \"consola\"\nimport { events } from \"fetch-event-stream\"\n\nimport type { CompactType } from \"~/lib/compact\"\nimport type { SubagentMarker } from \"~/lib/subagent\"\n\nimport {\n copilotBaseUrl,\n copilotHeaders,\n prepareForCompact,\n prepareInteractionHeaders,\n} from \"~/lib/api-config\"\nimport { logCopilotRateLimits } from \"~/lib/copilot-rate-limit\"\nimport { HTTPError } from \"~/lib/error\"\nimport { state } from \"~/lib/state\"\n\nexport const createChatCompletions = async (\n payload: ChatCompletionsPayload,\n options: {\n subagentMarker?: SubagentMarker | null\n requestId: string\n sessionId?: string\n compactType?: CompactType\n },\n) => {\n if (!state.copilotToken) throw new Error(\"Copilot token not found\")\n\n const enableVision = payload.messages.some(\n (x) =>\n typeof x.content !== \"string\"\n && x.content?.some((x) => x.type === \"image_url\"),\n )\n\n // Agent/user check for x-initiator header\n // Determine if any message is from an agent (\"assistant\" or \"tool\")\n // Refactor `isAgentCall` logic to check only the last message in the history rather than any message. This prevents valid user messages from being incorrectly flagged as agent calls due to previous assistant history, ensuring proper credit consumption for multi-turn conversations.\n let isAgentCall = false\n if (payload.messages.length > 0) {\n const lastMessage = payload.messages.at(-1)\n if (lastMessage) {\n isAgentCall = [\"assistant\", \"tool\"].includes(lastMessage.role)\n }\n }\n\n // Build headers and add x-initiator\n const headers: Record<string, string> = {\n ...copilotHeaders(state, options.requestId, enableVision),\n \"x-initiator\": isAgentCall ? \"agent\" : \"user\",\n }\n\n prepareInteractionHeaders(\n options.sessionId,\n Boolean(options.subagentMarker),\n headers,\n )\n\n prepareForCompact(headers, options.compactType)\n\n consola.log(`<-- model: ${payload.model}`)\n\n const response = await fetch(`${copilotBaseUrl(state)}/chat/completions`, {\n method: \"POST\",\n headers,\n body: JSON.stringify(payload),\n })\n\n logCopilotRateLimits(response.headers)\n\n if (!response.ok) {\n consola.error(\"Failed to create chat completions\", response)\n throw new HTTPError(\"Failed to create chat completions\", response)\n }\n\n if (payload.stream) {\n return events(response)\n }\n\n return (await response.json()) as ChatCompletionResponse\n}\n\n// Streaming types\n\nexport interface ChatCompletionChunk {\n id: string\n object: \"chat.completion.chunk\"\n created: number\n model: string\n choices: Array<Choice>\n system_fingerprint?: string\n usage?: {\n prompt_tokens: number\n completion_tokens: number\n total_tokens: number\n prompt_tokens_details?: {\n cached_tokens: number\n }\n completion_tokens_details?: {\n accepted_prediction_tokens: number\n rejected_prediction_tokens: number\n }\n }\n}\n\nexport interface Delta {\n content?: string | null\n role?: \"user\" | \"assistant\" | \"system\" | \"tool\"\n tool_calls?: Array<{\n index: number\n id?: string\n type?: \"function\"\n function?: {\n name?: string\n arguments?: string\n }\n }>\n reasoning_text?: string | null\n reasoning_opaque?: string | null\n}\n\nexport interface Choice {\n index: number\n delta: Delta\n finish_reason: \"stop\" | \"length\" | \"tool_calls\" | \"content_filter\" | null\n logprobs: object | null\n}\n\n// Non-streaming types\n\nexport interface ChatCompletionResponse {\n id: string\n object: \"chat.completion\"\n created: number\n model: string\n choices: Array<ChoiceNonStreaming>\n system_fingerprint?: string\n usage?: {\n prompt_tokens: number\n completion_tokens: number\n total_tokens: number\n prompt_tokens_details?: {\n cached_tokens: number\n }\n }\n}\n\ninterface ResponseMessage {\n role: \"assistant\"\n content: string | null\n reasoning_text?: string | null\n reasoning_opaque?: string | null\n tool_calls?: Array<ToolCall>\n}\n\ninterface ChoiceNonStreaming {\n index: number\n message: ResponseMessage\n logprobs: object | null\n finish_reason: \"stop\" | \"length\" | \"tool_calls\" | \"content_filter\"\n}\n\n// Payload types\n\nexport interface ChatCompletionsPayload {\n messages: Array<Message>\n model: string\n temperature?: number | null\n top_p?: number | null\n max_tokens?: number | null\n stop?: string | Array<string> | null\n n?: number | null\n stream?: boolean | null\n\n frequency_penalty?: number | null\n presence_penalty?: number | null\n logit_bias?: Record<string, number> | null\n logprobs?: boolean | null\n response_format?: { type: \"json_object\" } | null\n seed?: number | null\n tools?: Array<Tool> | null\n tool_choice?:\n | \"none\"\n | \"auto\"\n | \"required\"\n | { type: \"function\"; function: { name: string } }\n | null\n user?: string | null\n thinking_budget?: number\n}\n\nexport interface Tool {\n type: \"function\"\n function: {\n name: string\n description?: string\n parameters: Record<string, unknown>\n }\n}\n\nexport interface Message {\n role: \"user\" | \"assistant\" | \"system\" | \"tool\" | \"developer\"\n content: string | Array<ContentPart> | null\n\n name?: string\n tool_calls?: Array<ToolCall>\n tool_call_id?: string\n reasoning_text?: string | null\n reasoning_opaque?: string | null\n}\n\nexport interface ToolCall {\n id: string\n type: \"function\"\n function: {\n name: string\n arguments: string\n }\n}\n\nexport type ContentPart = TextPart | ImagePart\n\nexport interface TextPart {\n type: \"text\"\n text: string\n}\n\nexport interface ImagePart {\n type: \"image_url\"\n image_url: {\n url: string\n detail?: \"low\" | \"high\" | \"auto\"\n }\n}\n","import type { Context } from \"hono\"\n\nimport { streamSSE, type SSEMessage } from \"hono/streaming\"\n\nimport { awaitApproval } from \"~/lib/approval\"\nimport { createHandlerLogger, debugJson, debugJsonTail } from \"~/lib/logger\"\nimport { checkRateLimit } from \"~/lib/rate-limit\"\nimport { state } from \"~/lib/state\"\nimport { generateRequestIdFromPayload, getUUID, isNullish } from \"~/lib/utils\"\nimport {\n createChatCompletions,\n type ChatCompletionResponse,\n type ChatCompletionsPayload,\n} from \"~/services/copilot/create-chat-completions\"\n\nconst logger = createHandlerLogger(\"chat-completions-handler\")\n\nexport async function handleCompletion(c: Context) {\n await checkRateLimit(state)\n\n let payload = await c.req.json<ChatCompletionsPayload>()\n debugJsonTail(logger, \"Request payload:\", { value: payload, tailLength: 400 })\n\n // Find the selected model\n const selectedModel = state.models?.data.find(\n (model) => model.id === payload.model,\n )\n\n if (selectedModel?.id === \"gpt-5.4\") {\n return c.json(\n {\n error: {\n message: \"Please use `/v1/responses` or `/v1/messages` API\",\n type: \"invalid_request_error\",\n },\n },\n 400,\n )\n }\n\n if (state.manualApprove) await awaitApproval()\n\n if (isNullish(payload.max_tokens)) {\n payload = {\n ...payload,\n max_tokens: selectedModel?.capabilities.limits.max_output_tokens,\n }\n debugJson(logger, \"Set max_tokens to:\", payload.max_tokens)\n }\n\n // not support subagent marker for now , set sessionId = getUUID(requestId)\n const requestId = generateRequestIdFromPayload(payload)\n logger.debug(\"Generated request ID:\", requestId)\n\n const sessionId = getUUID(requestId)\n logger.debug(\"Extracted session ID:\", sessionId)\n\n const response = await createChatCompletions(payload, {\n requestId,\n sessionId,\n })\n\n if (isNonStreaming(response)) {\n debugJson(logger, \"Non-streaming response:\", response)\n return c.json(response)\n }\n\n logger.debug(\"Streaming response\")\n return streamSSE(c, async (stream) => {\n for await (const chunk of response) {\n debugJson(logger, \"Streaming chunk:\", chunk)\n await stream.writeSSE(chunk as SSEMessage)\n }\n })\n}\n\nconst isNonStreaming = (\n response: Awaited<ReturnType<typeof createChatCompletions>>,\n): response is ChatCompletionResponse => Object.hasOwn(response, \"choices\")\n","import { Hono } from \"hono\"\n\nimport { forwardError } from \"~/lib/error\"\n\nimport { handleCompletion } from \"./handler\"\n\nexport const completionRoutes = new Hono()\n\ncompletionRoutes.post(\"/\", async (c) => {\n try {\n return await handleCompletion(c)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n","import { copilotHeaders, copilotBaseUrl } from \"~/lib/api-config\"\nimport { HTTPError } from \"~/lib/error\"\nimport { state } from \"~/lib/state\"\n\nexport const createEmbeddings = async (payload: EmbeddingRequest) => {\n if (!state.copilotToken) throw new Error(\"Copilot token not found\")\n\n const response = await fetch(`${copilotBaseUrl(state)}/embeddings`, {\n method: \"POST\",\n headers: copilotHeaders(state),\n body: JSON.stringify(payload),\n })\n\n if (!response.ok) throw new HTTPError(\"Failed to create embeddings\", response)\n\n return (await response.json()) as EmbeddingResponse\n}\n\nexport interface EmbeddingRequest {\n input: string | Array<string>\n model: string\n}\n\nexport interface Embedding {\n object: string\n embedding: Array<number>\n index: number\n}\n\nexport interface EmbeddingResponse {\n object: string\n data: Array<Embedding>\n model: string\n usage: {\n prompt_tokens: number\n total_tokens: number\n }\n}\n","import { Hono } from \"hono\"\n\nimport { forwardError } from \"~/lib/error\"\nimport {\n createEmbeddings,\n type EmbeddingRequest,\n} from \"~/services/copilot/create-embeddings\"\n\nexport const embeddingRoutes = new Hono()\n\nembeddingRoutes.post(\"/\", async (c) => {\n try {\n const paylod = await c.req.json<EmbeddingRequest>()\n const response = await createEmbeddings(paylod)\n\n return c.json(response)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n","import type {\n ChatCompletionsPayload,\n ContentPart,\n Message,\n Tool,\n ToolCall,\n} from \"~/services/copilot/create-chat-completions\"\nimport type { Model } from \"~/services/copilot/get-models\"\n\n// Encoder type mapping\nconst ENCODING_MAP = {\n o200k_base: () => import(\"gpt-tokenizer/encoding/o200k_base\"),\n cl100k_base: () => import(\"gpt-tokenizer/encoding/cl100k_base\"),\n p50k_base: () => import(\"gpt-tokenizer/encoding/p50k_base\"),\n p50k_edit: () => import(\"gpt-tokenizer/encoding/p50k_edit\"),\n r50k_base: () => import(\"gpt-tokenizer/encoding/r50k_base\"),\n} as const\n\ntype SupportedEncoding = keyof typeof ENCODING_MAP\n\n// Define encoder interface\ninterface Encoder {\n encode: (text: string) => Array<number>\n}\n\n// Cache loaded encoders to avoid repeated imports\nconst encodingCache = new Map<string, Encoder>()\n\n/**\n * Calculate tokens for tool calls\n */\nconst calculateToolCallsTokens = (\n toolCalls: Array<ToolCall>,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n let tokens = 0\n for (const toolCall of toolCalls) {\n tokens += constants.funcInit\n tokens += encoder.encode(toolCall.id).length\n tokens += encoder.encode(toolCall.function.name).length\n tokens += encoder.encode(toolCall.function.arguments).length\n }\n tokens += constants.funcEnd\n return tokens\n}\n\n/**\n * Calculate tokens for content parts\n */\nconst calculateContentPartsTokens = (\n contentParts: Array<ContentPart>,\n encoder: Encoder,\n): number => {\n let tokens = 0\n for (const part of contentParts) {\n if (part.type === \"image_url\") {\n tokens += encoder.encode(part.image_url.url).length + 85\n } else if (part.text) {\n tokens += encoder.encode(part.text).length\n }\n }\n return tokens\n}\n\n/**\n * Calculate tokens for a single message\n */\nconst calculateMessageTokens = (\n message: Message,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n const tokensPerMessage = 3\n const tokensPerName = 1\n let tokens = tokensPerMessage\n for (const [key, value] of Object.entries(message)) {\n if (key === \"reasoning_opaque\") {\n continue\n }\n if (typeof value === \"string\") {\n tokens += encoder.encode(value).length\n }\n if (key === \"name\") {\n tokens += tokensPerName\n }\n if (key === \"tool_calls\") {\n tokens += calculateToolCallsTokens(\n value as Array<ToolCall>,\n encoder,\n constants,\n )\n }\n if (key === \"content\" && Array.isArray(value)) {\n tokens += calculateContentPartsTokens(\n value as Array<ContentPart>,\n encoder,\n )\n }\n }\n return tokens\n}\n\n/**\n * Calculate tokens using custom algorithm\n */\nconst calculateTokens = (\n messages: Array<Message>,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n if (messages.length === 0) {\n return 0\n }\n let numTokens = 0\n for (const message of messages) {\n numTokens += calculateMessageTokens(message, encoder, constants)\n }\n // every reply is primed with <|start|>assistant<|message|>\n numTokens += 3\n return numTokens\n}\n\n/**\n * Get the corresponding encoder module based on encoding type\n */\nconst getEncodeChatFunction = async (encoding: string): Promise<Encoder> => {\n if (encodingCache.has(encoding)) {\n const cached = encodingCache.get(encoding)\n if (cached) {\n return cached\n }\n }\n\n const supportedEncoding = encoding as SupportedEncoding\n if (!(supportedEncoding in ENCODING_MAP)) {\n const fallbackModule = (await ENCODING_MAP.o200k_base()) as Encoder\n encodingCache.set(encoding, fallbackModule)\n return fallbackModule\n }\n\n const encodingModule = (await ENCODING_MAP[supportedEncoding]()) as Encoder\n encodingCache.set(encoding, encodingModule)\n return encodingModule\n}\n\n/**\n * Get tokenizer type from model information\n */\nexport const getTokenizerFromModel = (model: Model): string => {\n return model.capabilities.tokenizer || \"o200k_base\"\n}\n\n/**\n * Get model-specific constants for token calculation\n */\nconst getModelConstants = (model: Model) => {\n return model.id === \"gpt-3.5-turbo\" || model.id === \"gpt-4\" ?\n {\n funcInit: 10,\n propInit: 3,\n propKey: 3,\n enumInit: -3,\n enumItem: 3,\n funcEnd: 12,\n isGpt: true,\n }\n : {\n funcInit: 7,\n propInit: 3,\n propKey: 3,\n enumInit: -3,\n enumItem: 3,\n funcEnd: 12,\n isGpt: model.id.startsWith(\"gpt-\"),\n }\n}\n\n/**\n * Calculate tokens for a single parameter\n */\nconst calculateParameterTokens = (\n key: string,\n prop: unknown,\n context: {\n encoder: Encoder\n constants: ReturnType<typeof getModelConstants>\n },\n): number => {\n const { encoder, constants } = context\n let tokens = constants.propKey\n\n // Early return if prop is not an object\n if (typeof prop !== \"object\" || prop === null) {\n return tokens\n }\n\n // Type assertion for parameter properties\n const param = prop as {\n type?: string\n description?: string\n enum?: Array<unknown>\n [key: string]: unknown\n }\n\n const paramName = key\n const paramType = param.type || \"string\"\n let paramDesc = param.description || \"\"\n\n // Handle enum values\n if (param.enum && Array.isArray(param.enum)) {\n tokens += constants.enumInit\n for (const item of param.enum) {\n tokens += constants.enumItem\n tokens += encoder.encode(String(item)).length\n }\n }\n\n // Clean up description\n if (paramDesc.endsWith(\".\")) {\n paramDesc = paramDesc.slice(0, -1)\n }\n\n // Encode the main parameter line\n const line = `${paramName}:${paramType}:${paramDesc}`\n tokens += encoder.encode(line).length\n\n if (param.type === \"array\" && param[\"items\"]) {\n tokens += calculateParametersTokens(param[\"items\"], encoder, constants)\n }\n\n // Handle additional properties (excluding standard ones)\n const excludedKeys = new Set([\"type\", \"description\", \"enum\", \"items\"])\n for (const propertyName of Object.keys(param)) {\n if (!excludedKeys.has(propertyName)) {\n const propertyValue = param[propertyName]\n const propertyText =\n typeof propertyValue === \"string\" ? propertyValue : (\n JSON.stringify(propertyValue)\n )\n tokens += encoder.encode(`${propertyName}:${propertyText}`).length\n }\n }\n\n return tokens\n}\n\n/**\n * Calculate tokens for properties object\n */\nconst calculatePropertiesTokens = (\n properties: Record<string, unknown>,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n let tokens = 0\n if (Object.keys(properties).length > 0) {\n tokens += constants.propInit\n for (const propKey of Object.keys(properties)) {\n tokens += calculateParameterTokens(propKey, properties[propKey], {\n encoder,\n constants,\n })\n }\n }\n return tokens\n}\n\n/**\n * Calculate tokens for function parameters\n */\nconst calculateParametersTokens = (\n parameters: unknown,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n if (!parameters || typeof parameters !== \"object\") {\n return 0\n }\n\n const params = parameters as Record<string, unknown>\n let tokens = 0\n\n const excludedKeys = new Set([\"$schema\", \"additionalProperties\"])\n for (const [key, value] of Object.entries(params)) {\n if (excludedKeys.has(key)) {\n continue\n }\n if (key === \"properties\") {\n tokens += calculatePropertiesTokens(\n value as Record<string, unknown>,\n encoder,\n constants,\n )\n } else {\n const paramText =\n typeof value === \"string\" ? value : JSON.stringify(value)\n tokens += encoder.encode(`${key}:${paramText}`).length\n }\n }\n\n return tokens\n}\n\n/**\n * Calculate tokens for a single tool\n */\nconst calculateToolTokens = (\n tool: Tool,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n let tokens = constants.funcInit\n const func = tool.function\n const fName = func.name\n let fDesc = func.description || \"\"\n if (fDesc.endsWith(\".\")) {\n fDesc = fDesc.slice(0, -1)\n }\n const line = fName + \":\" + fDesc\n tokens += encoder.encode(line).length\n if (\n typeof func.parameters === \"object\" // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n && func.parameters !== null\n ) {\n tokens += calculateParametersTokens(func.parameters, encoder, constants)\n }\n return tokens\n}\n\n/**\n * Calculate token count for tools based on model\n */\nexport const numTokensForTools = (\n tools: Array<Tool>,\n encoder: Encoder,\n constants: ReturnType<typeof getModelConstants>,\n): number => {\n let funcTokenCount = 0\n if (constants.isGpt) {\n for (const tool of tools) {\n funcTokenCount += calculateToolTokens(tool, encoder, constants)\n }\n funcTokenCount += constants.funcEnd\n } else {\n for (const tool of tools) {\n funcTokenCount += encoder.encode(JSON.stringify(tool)).length\n }\n }\n return funcTokenCount\n}\n\n/**\n * Calculate the token count of messages, supporting multiple GPT encoders\n */\nexport const getTokenCount = async (\n payload: ChatCompletionsPayload,\n model: Model,\n): Promise<{ input: number; output: number }> => {\n // Get tokenizer string\n const tokenizer = getTokenizerFromModel(model)\n\n // Get corresponding encoder module\n const encoder = await getEncodeChatFunction(tokenizer)\n\n const simplifiedMessages = payload.messages\n const inputMessages = simplifiedMessages.filter(\n (msg) => msg.role !== \"assistant\",\n )\n const outputMessages = simplifiedMessages.filter(\n (msg) => msg.role === \"assistant\",\n )\n\n const constants = getModelConstants(model)\n // gpt count token https://github.com/openai/openai-cookbook/blob/main/examples/How_to_count_tokens_with_tiktoken.ipynb\n let inputTokens = calculateTokens(inputMessages, encoder, constants)\n if (payload.tools && payload.tools.length > 0) {\n inputTokens += numTokensForTools(payload.tools, encoder, constants)\n }\n const outputTokens = calculateTokens(outputMessages, encoder, constants)\n\n return {\n input: inputTokens,\n output: outputTokens,\n }\n}\n","import type { Model } from \"~/services/copilot/get-models\"\n\nimport { state } from \"~/lib/state\"\n\nexport const findEndpointModel = (sdkModelId: string): Model | undefined => {\n const models = state.models?.data ?? []\n const exactMatch = models.find((m) => m.id === sdkModelId)\n if (exactMatch) {\n return exactMatch\n }\n\n const normalized = _normalizeSdkModelId(sdkModelId)\n if (!normalized) {\n return undefined\n }\n\n const modelName = `claude-${normalized.family}-${normalized.version}`\n const model = models.find((m) => m.id === modelName)\n if (model) {\n return model\n }\n\n return undefined\n}\n\n/**\n * Normalizes an SDK model ID to extract the model family and version.\n * this method from github copilot extension\n * Examples:\n * - \"claude-opus-4-5-20251101\" -> { family: \"opus\", version: \"4.5\" }\n * - \"claude-3-5-sonnet-20241022\" -> { family: \"sonnet\", version: \"3.5\" }\n * - \"claude-sonnet-4-20250514\" -> { family: \"sonnet\", version: \"4\" }\n * - \"claude-haiku-3-5-20250514\" -> { family: \"haiku\", version: \"3.5\" }\n * - \"claude-haiku-4.5\" -> { family: \"haiku\", version: \"4.5\" }\n */\nconst _normalizeSdkModelId = (\n sdkModelId: string,\n): { family: string; version: string } | undefined => {\n const lower = sdkModelId.toLowerCase()\n\n // Strip date suffix (8 digits at the end)\n const withoutDate = lower.replace(/-\\d{8}$/, \"\")\n\n // Pattern 1: claude-{family}-{major}-{minor} (e.g., claude-opus-4-5, claude-haiku-3-5)\n const pattern1 = withoutDate.match(/^claude-(\\w+)-(\\d+)-(\\d+)$/)\n if (pattern1) {\n return { family: pattern1[1], version: `${pattern1[2]}.${pattern1[3]}` }\n }\n\n // Pattern 2: claude-{major}-{minor}-{family} (e.g., claude-3-5-sonnet)\n const pattern2 = withoutDate.match(/^claude-(\\d+)-(\\d+)-(\\w+)$/)\n if (pattern2) {\n return { family: pattern2[3], version: `${pattern2[1]}.${pattern2[2]}` }\n }\n\n // Pattern 3: claude-{family}-{major}.{minor} (e.g., claude-haiku-4.5)\n const pattern3 = withoutDate.match(/^claude-(\\w+)-(\\d+)\\.(\\d+)$/)\n if (pattern3) {\n return { family: pattern3[1], version: `${pattern3[2]}.${pattern3[3]}` }\n }\n\n // Pattern 4: claude-{family}-{major} (e.g., claude-sonnet-4)\n const pattern4 = withoutDate.match(/^claude-(\\w+)-(\\d+)$/)\n if (pattern4) {\n return { family: pattern4[1], version: pattern4[2] }\n }\n\n // Pattern 5: claude-{major}-{family} (e.g., claude-3-opus)\n const pattern5 = withoutDate.match(/^claude-(\\d+)-(\\w+)$/)\n if (pattern5) {\n return { family: pattern5[2], version: pattern5[1] }\n }\n\n return undefined\n}\n","import { type AnthropicResponse } from \"./anthropic-types\"\n\nexport function mapOpenAIStopReasonToAnthropic(\n finishReason: \"stop\" | \"length\" | \"tool_calls\" | \"content_filter\" | null,\n): AnthropicResponse[\"stop_reason\"] {\n if (finishReason === null) {\n return null\n }\n const stopReasonMap = {\n stop: \"end_turn\",\n length: \"max_tokens\",\n tool_calls: \"tool_use\",\n content_filter: \"end_turn\",\n } as const\n return stopReasonMap[finishReason]\n}\n","import type { Model } from \"~/services/copilot/get-models\"\n\nimport { state } from \"~/lib/state\"\nimport {\n type ChatCompletionResponse,\n type ChatCompletionsPayload,\n type ContentPart,\n type Message,\n type TextPart,\n type Tool,\n type ToolCall,\n} from \"~/services/copilot/create-chat-completions\"\n\nimport {\n type AnthropicAssistantContentBlock,\n type AnthropicAssistantMessage,\n type AnthropicMessagesPayload,\n type AnthropicResponse,\n type AnthropicTextBlock,\n type AnthropicThinkingBlock,\n type AnthropicTool,\n type AnthropicToolResultContentBlock,\n type AnthropicToolResultBlock,\n type AnthropicToolUseBlock,\n type AnthropicUserContentBlock,\n type AnthropicUserMessage,\n} from \"./anthropic-types\"\nimport { mapOpenAIStopReasonToAnthropic } from \"./utils\"\n\n// Compatible with opencode, it will filter out blocks where the thinking text is empty, so we need add a default thinking text\nexport const THINKING_TEXT = \"Thinking...\"\n\ntype MappableContentBlock =\n | AnthropicUserContentBlock\n | AnthropicAssistantContentBlock\n | AnthropicToolResultContentBlock\n\n// Payload translation\nexport function translateToOpenAI(\n payload: AnthropicMessagesPayload,\n): ChatCompletionsPayload {\n const modelId = payload.model\n const model = state.models?.data.find((m) => m.id === modelId)\n const thinkingBudget = getThinkingBudget(payload, model)\n return {\n model: modelId,\n messages: translateAnthropicMessagesToOpenAI(\n payload,\n modelId,\n thinkingBudget,\n ),\n max_tokens: payload.max_tokens,\n stop: payload.stop_sequences,\n stream: payload.stream,\n temperature: payload.temperature,\n top_p: payload.top_p,\n user: payload.metadata?.user_id,\n tools: translateAnthropicToolsToOpenAI(payload.tools),\n tool_choice: translateAnthropicToolChoiceToOpenAI(payload.tool_choice),\n thinking_budget: thinkingBudget,\n }\n}\n\nfunction getThinkingBudget(\n payload: AnthropicMessagesPayload,\n model: Model | undefined,\n): number | undefined {\n const thinking = payload.thinking\n if (model && thinking) {\n const maxThinkingBudget = Math.min(\n model.capabilities.supports.max_thinking_budget ?? 0,\n (model.capabilities.limits.max_output_tokens ?? 0) - 1,\n )\n thinking.budget_tokens ??= maxThinkingBudget\n if (maxThinkingBudget > 0) {\n const budgetTokens = Math.min(thinking.budget_tokens, maxThinkingBudget)\n return Math.max(\n budgetTokens,\n model.capabilities.supports.min_thinking_budget ?? 1024,\n )\n }\n }\n return undefined\n}\n\nfunction translateAnthropicMessagesToOpenAI(\n payload: AnthropicMessagesPayload,\n modelId: string,\n _thinkingBudget: number | undefined,\n): Array<Message> {\n const systemMessages = handleSystemPrompt(payload.system)\n const otherMessages = payload.messages.flatMap((message) =>\n message.role === \"user\" ?\n handleUserMessage(message)\n : handleAssistantMessage(message, modelId),\n )\n return [...systemMessages, ...otherMessages]\n}\n\nfunction handleSystemPrompt(\n system: string | Array<AnthropicTextBlock> | undefined,\n): Array<Message> {\n if (!system) {\n return []\n }\n\n if (typeof system === \"string\") {\n return [{ role: \"system\", content: system }]\n } else {\n const systemText = system\n .map((block) => {\n return block.text\n })\n .join(\"\\n\\n\")\n return [{ role: \"system\", content: systemText }]\n }\n}\n\nfunction handleUserMessage(message: AnthropicUserMessage): Array<Message> {\n const newMessages: Array<Message> = []\n\n if (Array.isArray(message.content)) {\n const toolResultBlocks = message.content.filter(\n (block): block is AnthropicToolResultBlock =>\n block.type === \"tool_result\",\n )\n const otherBlocks = message.content.filter(\n (block) => block.type !== \"tool_result\",\n )\n\n // Tool results must come first to maintain protocol: tool_use -> tool_result -> user\n for (const block of toolResultBlocks) {\n newMessages.push({\n role: \"tool\",\n tool_call_id: block.tool_use_id,\n content: mapContent(block.content),\n })\n }\n\n if (otherBlocks.length > 0) {\n newMessages.push({\n role: \"user\",\n content: mapContent(otherBlocks),\n })\n }\n } else {\n newMessages.push({\n role: \"user\",\n content: mapContent(message.content),\n })\n }\n\n return newMessages\n}\n\nfunction handleAssistantMessage(\n message: AnthropicAssistantMessage,\n modelId: string,\n): Array<Message> {\n if (!Array.isArray(message.content)) {\n return [\n {\n role: \"assistant\",\n content: mapContent(message.content),\n },\n ]\n }\n\n const toolUseBlocks = message.content.filter(\n (block): block is AnthropicToolUseBlock => block.type === \"tool_use\",\n )\n\n let thinkingBlocks = message.content.filter(\n (block): block is AnthropicThinkingBlock => block.type === \"thinking\",\n )\n\n if (modelId.startsWith(\"claude\")) {\n thinkingBlocks = thinkingBlocks.filter(\n (b) =>\n b.thinking\n && b.thinking !== THINKING_TEXT\n && b.signature\n // gpt signature has @ in it, so filter those out for claude models\n && !b.signature.includes(\"@\"),\n )\n }\n\n const thinkingContents = thinkingBlocks\n .filter((b) => b.thinking && b.thinking !== THINKING_TEXT)\n .map((b) => b.thinking)\n\n const allThinkingContent =\n thinkingContents.length > 0 ? thinkingContents.join(\"\\n\\n\") : undefined\n\n const signature = thinkingBlocks.find((b) => b.signature)?.signature\n\n return toolUseBlocks.length > 0 ?\n [\n {\n role: \"assistant\",\n content: mapContent(message.content),\n reasoning_text: allThinkingContent,\n reasoning_opaque: signature,\n tool_calls: toolUseBlocks.map((toolUse) => ({\n id: toolUse.id,\n type: \"function\",\n function: {\n name: toolUse.name,\n arguments: JSON.stringify(toolUse.input),\n },\n })),\n },\n ]\n : [\n {\n role: \"assistant\",\n content: mapContent(message.content),\n reasoning_text: allThinkingContent,\n reasoning_opaque: signature,\n },\n ]\n}\n\nfunction mapContent(\n content: string | Array<MappableContentBlock>,\n): string | Array<ContentPart> | null {\n if (typeof content === \"string\") {\n return content\n }\n if (!Array.isArray(content)) {\n return null\n }\n\n const contentParts: Array<ContentPart> = []\n for (const block of content) {\n switch (block.type) {\n case \"text\": {\n contentParts.push({ type: \"text\", text: block.text })\n break\n }\n case \"image\": {\n contentParts.push({\n type: \"image_url\",\n image_url: {\n url: `data:${block.source.media_type};base64,${block.source.data}`,\n },\n })\n break\n }\n case \"document\": {\n contentParts.push(createDocumentTextPart())\n break\n }\n case \"tool_reference\": {\n contentParts.push({\n type: \"text\",\n text: `Tool ${block.tool_name} loaded`,\n })\n break\n }\n // No default\n }\n }\n return contentParts\n}\n\nfunction createDocumentTextPart(): TextPart {\n return {\n type: \"text\",\n text: \"A PDF document was attached, but this api cannot send PDF inputs directly. Analyze using other tools.\",\n }\n}\n\nfunction translateAnthropicToolsToOpenAI(\n anthropicTools: Array<AnthropicTool> | undefined,\n): Array<Tool> | undefined {\n if (!anthropicTools) {\n return undefined\n }\n return anthropicTools.map((tool) => ({\n type: \"function\",\n function: {\n name: tool.name,\n description: tool.description,\n parameters: normalizeToolSchema(tool.input_schema),\n },\n }))\n}\n\n/**\n * Ensures `type: \"object\"` schema has a `properties` field.\n * OpenAI's API rejects object schemas without it.\n */\nexport const normalizeToolSchema = (\n schema: Record<string, unknown>,\n): Record<string, unknown> => {\n if (schema.type === \"object\" && !schema.properties) {\n return { ...schema, properties: {} }\n }\n return schema\n}\n\nfunction translateAnthropicToolChoiceToOpenAI(\n anthropicToolChoice: AnthropicMessagesPayload[\"tool_choice\"],\n): ChatCompletionsPayload[\"tool_choice\"] {\n if (!anthropicToolChoice) {\n return undefined\n }\n\n switch (anthropicToolChoice.type) {\n case \"auto\": {\n return \"auto\"\n }\n case \"any\": {\n return \"required\"\n }\n case \"tool\": {\n if (anthropicToolChoice.name) {\n return {\n type: \"function\",\n function: { name: anthropicToolChoice.name },\n }\n }\n return undefined\n }\n case \"none\": {\n return \"none\"\n }\n default: {\n return undefined\n }\n }\n}\n\n// Response translation\n\nexport function translateToAnthropic(\n response: ChatCompletionResponse,\n): AnthropicResponse {\n // Merge content from all choices\n const assistantContentBlocks: Array<AnthropicAssistantContentBlock> = []\n let stopReason = response.choices[0]?.finish_reason ?? null\n\n // Process all choices to extract text and tool use blocks\n for (const choice of response.choices) {\n const textBlocks = getAnthropicTextBlocks(choice.message.content)\n const thinkBlocks = getAnthropicThinkBlocks(\n choice.message.reasoning_text,\n choice.message.reasoning_opaque,\n )\n const toolUseBlocks = getAnthropicToolUseBlocks(choice.message.tool_calls)\n\n assistantContentBlocks.push(...thinkBlocks, ...textBlocks, ...toolUseBlocks)\n\n // Use the finish_reason from the first choice, or prioritize tool_calls\n if (choice.finish_reason === \"tool_calls\" || stopReason === \"stop\") {\n stopReason = choice.finish_reason\n }\n }\n\n return {\n id: response.id,\n type: \"message\",\n role: \"assistant\",\n model: response.model,\n content: assistantContentBlocks,\n stop_reason: mapOpenAIStopReasonToAnthropic(stopReason),\n stop_sequence: null,\n usage: {\n input_tokens:\n (response.usage?.prompt_tokens ?? 0)\n - (response.usage?.prompt_tokens_details?.cached_tokens ?? 0),\n output_tokens: response.usage?.completion_tokens ?? 0,\n ...(response.usage?.prompt_tokens_details?.cached_tokens\n !== undefined && {\n cache_read_input_tokens:\n response.usage.prompt_tokens_details.cached_tokens,\n }),\n },\n }\n}\n\nfunction getAnthropicTextBlocks(\n messageContent: Message[\"content\"],\n): Array<AnthropicTextBlock> {\n if (typeof messageContent === \"string\" && messageContent.length > 0) {\n return [{ type: \"text\", text: messageContent }]\n }\n\n if (Array.isArray(messageContent)) {\n return messageContent\n .filter((part): part is TextPart => part.type === \"text\")\n .map((part) => ({ type: \"text\", text: part.text }))\n }\n\n return []\n}\n\nfunction getAnthropicThinkBlocks(\n reasoningText: string | null | undefined,\n reasoningOpaque: string | null | undefined,\n): Array<AnthropicThinkingBlock> {\n if (reasoningText && reasoningText.length > 0) {\n return [\n {\n type: \"thinking\",\n thinking: reasoningText,\n signature: reasoningOpaque || \"\",\n },\n ]\n }\n if (reasoningOpaque && reasoningOpaque.length > 0) {\n return [\n {\n type: \"thinking\",\n thinking: THINKING_TEXT, // Compatible with opencode, it will filter out blocks where the thinking text is empty, so we add a default thinking text here\n signature: reasoningOpaque,\n },\n ]\n }\n return []\n}\n\nfunction getAnthropicToolUseBlocks(\n toolCalls: Array<ToolCall> | undefined,\n): Array<AnthropicToolUseBlock> {\n if (!toolCalls) {\n return []\n }\n return toolCalls.map((toolCall) => ({\n type: \"tool_use\",\n id: toolCall.id,\n name: toolCall.function.name,\n input: JSON.parse(toolCall.function.arguments) as Record<string, unknown>,\n }))\n}\n","import type { Context } from \"hono\"\n\nimport consola from \"consola\"\n\nimport { getAnthropicApiKey, getClaudeTokenMultiplier } from \"~/lib/config\"\nimport { getTokenCount } from \"~/lib/tokenizer\"\n\nimport { findEndpointModel } from \"../../lib/models\"\nimport { type AnthropicMessagesPayload } from \"./anthropic-types\"\nimport { translateToOpenAI } from \"./non-stream-translation\"\n\n/**\n * Forwards token counting to Anthropic's real /v1/messages/count_tokens endpoint.\n * Returns the result on success, or null to fall through to estimation.\n */\nasync function countTokensViaAnthropic(\n c: Context,\n payload: AnthropicMessagesPayload,\n): Promise<Response | null> {\n if (!payload.model.startsWith(\"claude\")) return null\n\n const apiKey = getAnthropicApiKey()\n if (!apiKey) return null\n\n // Copilot uses dotted names (claude-opus-4.6) but Anthropic requires dashes (claude-opus-4-6)\n const model = payload.model.replaceAll(\".\", \"-\")\n\n const res = await fetch(\n \"https://api.anthropic.com/v1/messages/count_tokens\",\n {\n method: \"POST\",\n headers: {\n \"content-type\": \"application/json\",\n \"x-api-key\": apiKey,\n \"anthropic-version\": \"2023-06-01\",\n \"anthropic-beta\": \"token-counting-2024-11-01\",\n },\n body: JSON.stringify({ ...payload, model }),\n },\n )\n\n if (!res.ok) {\n consola.warn(\n \"Anthropic count_tokens failed:\",\n res.status,\n await res.text().catch(() => \"\"),\n \"- falling back to estimation\",\n )\n return null\n }\n\n const result = (await res.json()) as { input_tokens: number }\n consola.info(\"Token count (Anthropic API):\", result.input_tokens)\n return c.json(result)\n}\n\n/**\n * Handles token counting for Anthropic messages.\n *\n * When an Anthropic API key is available (via config or ANTHROPIC_API_KEY env var)\n * and the model is a Claude model, forwards to Anthropic's free /v1/messages/count_tokens\n * endpoint for accurate counts. Otherwise falls back to GPT tokenizer estimation.\n */\nexport async function handleCountTokens(c: Context) {\n try {\n const anthropicPayload = await c.req.json<AnthropicMessagesPayload>()\n\n // Try Anthropic's real endpoint first (Claude models only)\n const anthropicResult = await countTokensViaAnthropic(c, anthropicPayload)\n if (anthropicResult) return anthropicResult\n\n // Fallback: GPT tokenizer estimation (also used for non-Claude models)\n const anthropicBeta = c.req.header(\"anthropic-beta\")\n\n const openAIPayload = translateToOpenAI(anthropicPayload)\n\n const selectedModel = findEndpointModel(anthropicPayload.model)\n anthropicPayload.model = selectedModel?.id ?? anthropicPayload.model\n\n if (!selectedModel) {\n consola.warn(\"Model not found, returning default token count\")\n return c.json({\n input_tokens: 1,\n })\n }\n\n const tokenCount = await getTokenCount(openAIPayload, selectedModel)\n\n if (anthropicPayload.tools && anthropicPayload.tools.length > 0) {\n let addToolSystemPromptCount = false\n if (anthropicBeta) {\n const toolsLength = anthropicPayload.tools.length\n addToolSystemPromptCount = !anthropicPayload.tools.some(\n (tool) =>\n tool.name.startsWith(\"mcp__\")\n || (tool.name === \"Skill\" && toolsLength === 1),\n )\n }\n if (addToolSystemPromptCount) {\n if (anthropicPayload.model.startsWith(\"claude\")) {\n // https://docs.anthropic.com/en/docs/agents-and-tools/tool-use/overview#pricing\n tokenCount.input = tokenCount.input + 346\n } else if (anthropicPayload.model.startsWith(\"grok\")) {\n tokenCount.input = tokenCount.input + 120\n }\n }\n }\n\n let finalTokenCount = tokenCount.input + tokenCount.output\n if (anthropicPayload.model.startsWith(\"claude\")) {\n finalTokenCount = Math.round(finalTokenCount * getClaudeTokenMultiplier())\n }\n\n consola.info(\"Token count:\", finalTokenCount)\n\n return c.json({\n input_tokens: finalTokenCount,\n })\n } catch (error) {\n consola.error(\"Error counting tokens:\", error)\n return c.json({\n input_tokens: 1,\n })\n }\n}\n","import consola from \"consola\"\nimport { events } from \"fetch-event-stream\"\n\nimport type { CompactType } from \"~/lib/compact\"\nimport type { SubagentMarker } from \"~/lib/subagent\"\n\nimport {\n copilotBaseUrl,\n copilotHeaders,\n prepareForCompact,\n prepareInteractionHeaders,\n} from \"~/lib/api-config\"\nimport { logCopilotRateLimits } from \"~/lib/copilot-rate-limit\"\nimport { HTTPError } from \"~/lib/error\"\nimport { state } from \"~/lib/state\"\n\nexport interface ResponsesPayload {\n model: string\n instructions?: string | null\n input?: string | Array<ResponseInputItem>\n tools?: Array<Tool> | null\n tool_choice?: ToolChoiceOptions | ToolChoiceFunction\n temperature?: number | null\n top_p?: number | null\n max_output_tokens?: number | null\n metadata?: Metadata | null\n stream?: boolean | null\n safety_identifier?: string | null\n prompt_cache_key?: string | null\n parallel_tool_calls?: boolean | null\n store?: boolean | null\n reasoning?: Reasoning | null\n context_management?: Array<ResponseContextManagementItem> | null\n include?: Array<ResponseIncludable>\n service_tier?: string | null // NOTE: Unsupported by GitHub Copilot\n [key: string]: unknown\n}\n\nexport type ToolChoiceOptions = \"none\" | \"auto\" | \"required\"\n\nexport interface ToolChoiceFunction {\n name: string\n type: \"function\"\n}\n\nexport type Tool = FunctionTool | Record<string, unknown>\n\nexport interface FunctionTool {\n name: string\n parameters: { [key: string]: unknown } | null\n strict: boolean | null\n type: \"function\"\n description?: string | null\n}\n\nexport type ResponseIncludable =\n | \"file_search_call.results\"\n | \"message.input_image.image_url\"\n | \"computer_call_output.output.image_url\"\n | \"reasoning.encrypted_content\"\n | \"code_interpreter_call.outputs\"\n\nexport interface Reasoning {\n effort?: \"none\" | \"minimal\" | \"low\" | \"medium\" | \"high\" | \"xhigh\" | null\n summary?: \"auto\" | \"concise\" | \"detailed\" | null\n}\n\nexport interface ResponseContextManagementCompactionItem {\n type: \"compaction\"\n compact_threshold: number\n}\n\nexport type ResponseContextManagementItem =\n ResponseContextManagementCompactionItem\n\nexport interface ResponseInputMessage {\n type?: \"message\"\n role: \"user\" | \"assistant\" | \"system\" | \"developer\"\n content?: string | Array<ResponseInputContent>\n status?: string\n phase?: \"commentary\" | \"final_answer\"\n}\n\nexport interface ResponseFunctionToolCallItem {\n type: \"function_call\"\n call_id: string\n name: string\n arguments: string\n status?: \"in_progress\" | \"completed\" | \"incomplete\"\n}\n\nexport interface ResponseFunctionCallOutputItem {\n type: \"function_call_output\"\n call_id: string\n output: string | Array<ResponseInputContent>\n status?: \"in_progress\" | \"completed\" | \"incomplete\"\n}\n\nexport interface ResponseInputReasoning {\n id?: string\n type: \"reasoning\"\n summary: Array<{\n type: \"summary_text\"\n text: string\n }>\n encrypted_content: string\n}\n\nexport interface ResponseInputCompaction {\n id: string\n type: \"compaction\"\n encrypted_content: string\n}\n\nexport type ResponseInputItem =\n | ResponseInputMessage\n | ResponseFunctionToolCallItem\n | ResponseFunctionCallOutputItem\n | ResponseInputReasoning\n | ResponseInputCompaction\n | Record<string, unknown>\n\nexport type ResponseInputContent =\n | ResponseInputText\n | ResponseInputImage\n | ResponseInputFile\n | Record<string, unknown>\n\nexport interface ResponseInputText {\n type: \"input_text\" | \"output_text\"\n text: string\n}\n\nexport interface ResponseInputImage {\n type: \"input_image\"\n image_url?: string | null\n file_id?: string | null\n detail: \"low\" | \"high\" | \"auto\"\n}\n\nexport interface ResponseInputFile {\n type: \"input_file\"\n file_data?: string | null\n file_id?: string | null\n filename?: string | null\n}\n\nexport interface ResponsesResult {\n id: string\n object: \"response\"\n created_at: number\n model: string\n output: Array<ResponseOutputItem>\n output_text: string\n status: string\n usage?: ResponseUsage | null\n error: ResponseError | null\n incomplete_details: IncompleteDetails | null\n instructions: string | null\n metadata: Metadata | null\n parallel_tool_calls: boolean\n temperature: number | null\n tool_choice: unknown\n tools: Array<Tool>\n top_p: number | null\n}\n\nexport type Metadata = { [key: string]: string }\n\nexport interface IncompleteDetails {\n reason?: \"max_output_tokens\" | \"content_filter\"\n}\n\nexport interface ResponseError {\n message: string\n}\n\nexport type ResponseOutputItem =\n | ResponseOutputMessage\n | ResponseOutputReasoning\n | ResponseOutputFunctionCall\n | ResponseOutputCompaction\n\nexport interface ResponseOutputMessage {\n id: string\n type: \"message\"\n role: \"assistant\"\n status: \"completed\" | \"in_progress\" | \"incomplete\"\n content?: Array<ResponseOutputContentBlock>\n}\n\nexport interface ResponseOutputReasoning {\n id: string\n type: \"reasoning\"\n summary?: Array<ResponseReasoningBlock>\n encrypted_content?: string\n status?: \"completed\" | \"in_progress\" | \"incomplete\"\n}\n\nexport interface ResponseReasoningBlock {\n type: string\n text?: string\n}\n\nexport interface ResponseOutputFunctionCall {\n id?: string\n type: \"function_call\"\n call_id: string\n name: string\n arguments: string\n status?: \"in_progress\" | \"completed\" | \"incomplete\"\n}\n\nexport interface ResponseOutputCompaction {\n id: string\n type: \"compaction\"\n encrypted_content: string\n}\n\nexport type ResponseOutputContentBlock =\n | ResponseOutputText\n | ResponseOutputRefusal\n | Record<string, unknown>\n\nexport interface ResponseOutputText {\n type: \"output_text\"\n text: string\n annotations: Array<unknown>\n}\n\nexport interface ResponseOutputRefusal {\n type: \"refusal\"\n refusal: string\n}\n\nexport interface ResponseUsage {\n input_tokens: number\n output_tokens?: number\n total_tokens: number\n input_tokens_details?: {\n cached_tokens: number\n }\n output_tokens_details?: {\n reasoning_tokens: number\n }\n}\n\nexport type ResponseStreamEvent =\n | ResponseCompletedEvent\n | ResponseIncompleteEvent\n | ResponseCreatedEvent\n | ResponseErrorEvent\n | ResponseFunctionCallArgumentsDeltaEvent\n | ResponseFunctionCallArgumentsDoneEvent\n | ResponseFailedEvent\n | ResponseOutputItemAddedEvent\n | ResponseOutputItemDoneEvent\n | ResponseReasoningSummaryTextDeltaEvent\n | ResponseReasoningSummaryTextDoneEvent\n | ResponseTextDeltaEvent\n | ResponseTextDoneEvent\n\nexport interface ResponseCompletedEvent {\n response: ResponsesResult\n sequence_number: number\n type: \"response.completed\"\n}\n\nexport interface ResponseIncompleteEvent {\n response: ResponsesResult\n sequence_number: number\n type: \"response.incomplete\"\n}\n\nexport interface ResponseCreatedEvent {\n response: ResponsesResult\n sequence_number: number\n type: \"response.created\"\n}\n\nexport interface ResponseErrorEvent {\n code: string | null\n message: string\n param: string | null\n sequence_number: number\n type: \"error\"\n}\n\nexport interface ResponseFunctionCallArgumentsDeltaEvent {\n delta: string\n item_id: string\n output_index: number\n sequence_number: number\n type: \"response.function_call_arguments.delta\"\n}\n\nexport interface ResponseFunctionCallArgumentsDoneEvent {\n arguments: string\n item_id: string\n name: string\n output_index: number\n sequence_number: number\n type: \"response.function_call_arguments.done\"\n}\n\nexport interface ResponseFailedEvent {\n response: ResponsesResult\n sequence_number: number\n type: \"response.failed\"\n}\n\nexport interface ResponseOutputItemAddedEvent {\n item: ResponseOutputItem\n output_index: number\n sequence_number: number\n type: \"response.output_item.added\"\n}\n\nexport interface ResponseOutputItemDoneEvent {\n item: ResponseOutputItem\n output_index: number\n sequence_number: number\n type: \"response.output_item.done\"\n}\n\nexport interface ResponseReasoningSummaryTextDeltaEvent {\n delta: string\n item_id: string\n output_index: number\n sequence_number: number\n summary_index: number\n type: \"response.reasoning_summary_text.delta\"\n}\n\nexport interface ResponseReasoningSummaryTextDoneEvent {\n item_id: string\n output_index: number\n sequence_number: number\n summary_index: number\n text: string\n type: \"response.reasoning_summary_text.done\"\n}\n\nexport interface ResponseTextDeltaEvent {\n content_index: number\n delta: string\n item_id: string\n output_index: number\n sequence_number: number\n type: \"response.output_text.delta\"\n}\n\nexport interface ResponseTextDoneEvent {\n content_index: number\n item_id: string\n output_index: number\n sequence_number: number\n text: string\n type: \"response.output_text.done\"\n}\n\nexport type ResponsesStream = ReturnType<typeof events>\nexport type CreateResponsesReturn = ResponsesResult | ResponsesStream\n\ninterface ResponsesRequestOptions {\n vision: boolean\n initiator: \"agent\" | \"user\"\n subagentMarker?: SubagentMarker | null\n requestId: string\n sessionId?: string\n compactType?: CompactType\n}\n\nexport const createResponses = async (\n payload: ResponsesPayload,\n {\n vision,\n initiator,\n subagentMarker,\n requestId,\n sessionId,\n compactType,\n }: ResponsesRequestOptions,\n): Promise<CreateResponsesReturn> => {\n if (!state.copilotToken) throw new Error(\"Copilot token not found\")\n\n const headers: Record<string, string> = {\n ...copilotHeaders(state, requestId, vision),\n \"x-initiator\": initiator,\n }\n\n prepareInteractionHeaders(sessionId, Boolean(subagentMarker), headers)\n\n prepareForCompact(headers, compactType)\n\n // service_tier is not supported by github copilot\n payload.service_tier = undefined\n\n consola.log(`<-- model: ${payload.model}`)\n\n const response = await fetch(`${copilotBaseUrl(state)}/responses`, {\n method: \"POST\",\n headers,\n body: JSON.stringify(payload),\n })\n\n logCopilotRateLimits(response.headers)\n\n if (!response.ok) {\n consola.error(\"Failed to create responses\", response)\n throw new HTTPError(\"Failed to create responses\", response)\n }\n\n if (payload.stream) {\n return events(response)\n }\n\n return (await response.json()) as ResponsesResult\n}\n","import consola from \"consola\"\n\nimport {\n getExtraPromptForModel,\n getReasoningEffortForModel,\n} from \"~/lib/config\"\nimport { parseUserIdMetadata } from \"~/lib/utils\"\nimport {\n type ResponsesPayload,\n type ResponseInputCompaction,\n type ResponseInputContent,\n type ResponseInputFile,\n type ResponseInputImage,\n type ResponseInputItem,\n type ResponseInputMessage,\n type ResponseInputReasoning,\n type ResponseInputText,\n type ResponsesResult,\n type ResponseOutputContentBlock,\n type ResponseOutputCompaction,\n type ResponseOutputFunctionCall,\n type ResponseOutputItem,\n type ResponseOutputReasoning,\n type ResponseReasoningBlock,\n type ResponseOutputRefusal,\n type ResponseOutputText,\n type ResponseFunctionToolCallItem,\n type ResponseFunctionCallOutputItem,\n type Tool,\n type ToolChoiceFunction,\n type ToolChoiceOptions,\n} from \"~/services/copilot/create-responses\"\n\nimport {\n type AnthropicAssistantContentBlock,\n type AnthropicAssistantMessage,\n type AnthropicDocumentBlock,\n type AnthropicResponse,\n type AnthropicImageBlock,\n type AnthropicMessage,\n type AnthropicMessagesPayload,\n type AnthropicTextBlock,\n type AnthropicThinkingBlock,\n type AnthropicTool,\n type AnthropicToolResultContentBlock,\n type AnthropicToolResultBlock,\n type AnthropicToolUseBlock,\n type AnthropicUserContentBlock,\n type AnthropicUserMessage,\n} from \"./anthropic-types\"\nimport { normalizeToolSchema } from \"./non-stream-translation\"\n\nconst MESSAGE_TYPE = \"message\"\nconst COMPACTION_SIGNATURE_PREFIX = \"cm1#\"\nconst COMPACTION_SIGNATURE_SEPARATOR = \"@\"\n\nexport const THINKING_TEXT = \"Thinking...\"\n\nexport const translateAnthropicMessagesToResponsesPayload = (\n payload: AnthropicMessagesPayload,\n): ResponsesPayload => {\n const input: Array<ResponseInputItem> = []\n const applyPhase = shouldApplyPhase(payload.model)\n\n for (const message of payload.messages) {\n input.push(...translateMessage(message, payload.model, applyPhase))\n }\n\n const translatedTools = convertAnthropicTools(payload.tools)\n const toolChoice = convertAnthropicToolChoice(payload.tool_choice)\n\n // Remove safetyIdentifier to align with vscode copilot\n const { sessionId: promptCacheKey } = parseUserIdMetadata(\n payload.metadata?.user_id,\n )\n\n const responsesPayload: ResponsesPayload = {\n model: payload.model,\n input,\n instructions: translateSystemPrompt(payload.system, payload.model),\n temperature: 1, // reasoning high temperature fixed to 1\n top_p: payload.top_p ?? null,\n max_output_tokens: Math.max(payload.max_tokens, 12800),\n tools: translatedTools,\n tool_choice: toolChoice,\n metadata: payload.metadata ? { ...payload.metadata } : null,\n prompt_cache_key: promptCacheKey,\n stream: payload.stream ?? null,\n store: false,\n parallel_tool_calls: true,\n reasoning: {\n effort: getReasoningEffortForModel(payload.model),\n summary: \"detailed\",\n },\n include: [\"reasoning.encrypted_content\"],\n }\n\n return responsesPayload\n}\n\ntype CompactionCarrier = {\n id: string\n encrypted_content: string\n}\n\nexport const encodeCompactionCarrierSignature = (\n compaction: CompactionCarrier,\n): string => {\n return `${COMPACTION_SIGNATURE_PREFIX}${compaction.encrypted_content}${COMPACTION_SIGNATURE_SEPARATOR}${compaction.id}`\n}\n\nexport const decodeCompactionCarrierSignature = (\n signature: string,\n): CompactionCarrier | undefined => {\n if (signature.startsWith(COMPACTION_SIGNATURE_PREFIX)) {\n const raw = signature.slice(COMPACTION_SIGNATURE_PREFIX.length)\n const separatorIndex = raw.indexOf(COMPACTION_SIGNATURE_SEPARATOR)\n\n if (separatorIndex <= 0 || separatorIndex === raw.length - 1) {\n return undefined\n }\n\n const encrypted_content = raw.slice(0, separatorIndex)\n const id = raw.slice(separatorIndex + 1)\n\n if (!encrypted_content) {\n return undefined\n }\n\n return {\n id,\n encrypted_content,\n }\n }\n\n return undefined\n}\n\nconst translateMessage = (\n message: AnthropicMessage,\n model: string,\n applyPhase: boolean,\n): Array<ResponseInputItem> => {\n if (message.role === \"user\") {\n return translateUserMessage(message)\n }\n\n return translateAssistantMessage(message, model, applyPhase)\n}\n\nconst translateUserMessage = (\n message: AnthropicUserMessage,\n): Array<ResponseInputItem> => {\n if (typeof message.content === \"string\") {\n return [createMessage(\"user\", message.content)]\n }\n\n if (!Array.isArray(message.content)) {\n return []\n }\n\n const items: Array<ResponseInputItem> = []\n const pendingContent: Array<ResponseInputContent> = []\n\n for (const block of message.content) {\n if (block.type === \"tool_result\") {\n flushPendingContent(pendingContent, items, { role: \"user\" })\n items.push(createFunctionCallOutput(block))\n continue\n }\n\n const converted = translateUserContentBlock(block)\n if (converted.length > 0) {\n pendingContent.push(...converted)\n }\n }\n\n flushPendingContent(pendingContent, items, { role: \"user\" })\n\n return items\n}\n\nconst translateAssistantMessage = (\n message: AnthropicAssistantMessage,\n model: string,\n applyPhase: boolean,\n): Array<ResponseInputItem> => {\n const assistantPhase = resolveAssistantPhase(\n model,\n message.content,\n applyPhase,\n )\n\n if (typeof message.content === \"string\") {\n return [createMessage(\"assistant\", message.content, assistantPhase)]\n }\n\n if (!Array.isArray(message.content)) {\n return []\n }\n\n const items: Array<ResponseInputItem> = []\n const pendingContent: Array<ResponseInputContent> = []\n\n for (const block of message.content) {\n if (block.type === \"tool_use\") {\n flushPendingContent(pendingContent, items, {\n role: \"assistant\",\n phase: assistantPhase,\n })\n items.push(createFunctionToolCall(block))\n continue\n }\n\n if (block.type === \"thinking\" && block.signature) {\n const compactionContent = createCompactionContent(block)\n if (compactionContent) {\n flushPendingContent(pendingContent, items, {\n role: \"assistant\",\n phase: assistantPhase,\n })\n items.push(compactionContent)\n continue\n }\n\n if (block.signature.includes(\"@\")) {\n flushPendingContent(pendingContent, items, {\n role: \"assistant\",\n phase: assistantPhase,\n })\n items.push(createReasoningContent(block))\n continue\n }\n }\n\n const converted = translateAssistantContentBlock(block)\n if (converted) {\n pendingContent.push(converted)\n }\n }\n\n flushPendingContent(pendingContent, items, {\n role: \"assistant\",\n phase: assistantPhase,\n })\n\n return items\n}\n\nconst translateUserContentBlock = (\n block: AnthropicUserContentBlock,\n): Array<ResponseInputContent> => {\n switch (block.type) {\n case \"text\": {\n return [createTextContent(block.text)]\n }\n case \"image\": {\n return [createImageContent(block)]\n }\n case \"document\": {\n return [createFileContent(block)]\n }\n default: {\n return []\n }\n }\n}\n\nconst translateAssistantContentBlock = (\n block: AnthropicAssistantContentBlock,\n): ResponseInputContent | undefined => {\n switch (block.type) {\n case \"text\": {\n return createOutPutTextContent(block.text)\n }\n default: {\n return undefined\n }\n }\n}\n\nconst flushPendingContent = (\n pendingContent: Array<ResponseInputContent>,\n target: Array<ResponseInputItem>,\n message: Pick<ResponseInputMessage, \"role\" | \"phase\">,\n) => {\n if (pendingContent.length === 0) {\n return\n }\n\n const messageContent = [...pendingContent]\n\n target.push(createMessage(message.role, messageContent, message.phase))\n pendingContent.length = 0\n}\n\nconst createMessage = (\n role: ResponseInputMessage[\"role\"],\n content: string | Array<ResponseInputContent>,\n phase?: ResponseInputMessage[\"phase\"],\n): ResponseInputMessage => ({\n type: MESSAGE_TYPE,\n role,\n content,\n ...(role === \"assistant\" && phase ? { phase } : {}),\n})\n\nconst resolveAssistantPhase = (\n _model: string,\n content: AnthropicAssistantMessage[\"content\"],\n applyPhase: boolean,\n): ResponseInputMessage[\"phase\"] | undefined => {\n if (!applyPhase) {\n return undefined\n }\n\n if (typeof content === \"string\") {\n return \"final_answer\"\n }\n\n if (!Array.isArray(content)) {\n return undefined\n }\n\n const hasText = content.some((block) => block.type === \"text\")\n if (!hasText) {\n return undefined\n }\n\n const hasToolUse = content.some((block) => block.type === \"tool_use\")\n return hasToolUse ? \"commentary\" : \"final_answer\"\n}\n\nconst shouldApplyPhase = (model: string): boolean => {\n const extraPrompt = getExtraPromptForModel(model)\n return extraPrompt.includes(\"## Intermediary updates\")\n}\n\nconst createTextContent = (text: string): ResponseInputText => ({\n type: \"input_text\",\n text,\n})\n\nconst createOutPutTextContent = (text: string): ResponseInputText => ({\n type: \"output_text\",\n text,\n})\n\nconst createImageContent = (\n block: AnthropicImageBlock,\n): ResponseInputImage => ({\n type: \"input_image\",\n image_url: `data:${block.source.media_type};base64,${block.source.data}`,\n detail: \"auto\",\n})\n\nconst createFileContent = (\n block: AnthropicDocumentBlock,\n): ResponseInputFile => ({\n type: \"input_file\",\n file_data: `data:${block.source.media_type};base64,${block.source.data}`,\n filename: block.title ?? \"document.pdf\",\n})\n\nconst createReasoningContent = (\n block: AnthropicThinkingBlock,\n): ResponseInputReasoning => {\n // align with vscode-copilot-chat extractThinkingData, should add id, otherwise it will cause miss cache occasionally —— the usage input cached tokens to be 0\n // https://github.com/microsoft/vscode-copilot-chat/blob/main/src/platform/endpoint/node/responsesApi.ts#L162\n // when use in codex cli, reasoning id is empty, so it will cause miss cache occasionally\n const { encryptedContent, id } = parseReasoningSignature(block.signature)\n const thinking = block.thinking === THINKING_TEXT ? \"\" : block.thinking\n return {\n id,\n type: \"reasoning\",\n summary: thinking ? [{ type: \"summary_text\", text: thinking }] : [],\n encrypted_content: encryptedContent,\n }\n}\n\nconst createCompactionContent = (\n block: AnthropicThinkingBlock,\n): ResponseInputCompaction | undefined => {\n const compaction = decodeCompactionCarrierSignature(block.signature)\n if (!compaction) {\n return undefined\n }\n\n return {\n id: compaction.id,\n type: \"compaction\",\n encrypted_content: compaction.encrypted_content,\n }\n}\n\nconst parseReasoningSignature = (\n signature: string,\n): { encryptedContent: string; id: string } => {\n const splitIndex = signature.lastIndexOf(\"@\")\n\n if (splitIndex <= 0 || splitIndex === signature.length - 1) {\n return { encryptedContent: signature, id: \"\" }\n }\n\n return {\n encryptedContent: signature.slice(0, splitIndex),\n id: signature.slice(splitIndex + 1),\n }\n}\n\nconst createFunctionToolCall = (\n block: AnthropicToolUseBlock,\n): ResponseFunctionToolCallItem => ({\n type: \"function_call\",\n call_id: block.id,\n name: block.name,\n arguments: JSON.stringify(block.input),\n status: \"completed\",\n})\n\nconst createFunctionCallOutput = (\n block: AnthropicToolResultBlock,\n): ResponseFunctionCallOutputItem => ({\n type: \"function_call_output\",\n call_id: block.tool_use_id,\n output: convertToolResultContent(block.content),\n status: block.is_error ? \"incomplete\" : \"completed\",\n})\n\nconst translateSystemPrompt = (\n system: string | Array<AnthropicTextBlock> | undefined,\n model: string,\n): string | null => {\n if (!system) {\n return null\n }\n\n const extraPrompt = getExtraPromptForModel(model)\n\n if (typeof system === \"string\") {\n return system + extraPrompt\n }\n\n const text = system\n .map((block, index) => {\n if (index === 0) {\n return block.text + \"\\n\\n\" + extraPrompt + \"\\n\\n\"\n }\n return block.text\n })\n .join(\" \")\n return text.length > 0 ? text : null\n}\n\nconst convertAnthropicTools = (\n tools: Array<AnthropicTool> | undefined,\n): Array<Tool> | null => {\n if (!tools || tools.length === 0) {\n return null\n }\n\n return tools.map((tool) => ({\n type: \"function\",\n name: tool.name,\n parameters: normalizeToolSchema(tool.input_schema),\n strict: false,\n ...(tool.description ? { description: tool.description } : {}),\n }))\n}\n\nconst convertAnthropicToolChoice = (\n choice: AnthropicMessagesPayload[\"tool_choice\"],\n): ToolChoiceOptions | ToolChoiceFunction => {\n if (!choice) {\n return \"auto\"\n }\n\n switch (choice.type) {\n case \"auto\": {\n return \"auto\"\n }\n case \"any\": {\n return \"required\"\n }\n case \"tool\": {\n return choice.name ? { type: \"function\", name: choice.name } : \"auto\"\n }\n case \"none\": {\n return \"none\"\n }\n default: {\n return \"auto\"\n }\n }\n}\n\nexport const translateResponsesResultToAnthropic = (\n response: ResponsesResult,\n): AnthropicResponse => {\n const contentBlocks = mapOutputToAnthropicContent(response.output)\n const usage = mapResponsesUsage(response)\n let anthropicContent = fallbackContentBlocks(response.output_text)\n if (contentBlocks.length > 0) {\n anthropicContent = contentBlocks\n }\n\n const stopReason = mapResponsesStopReason(response)\n\n return {\n id: response.id,\n type: \"message\",\n role: \"assistant\",\n content: anthropicContent,\n model: response.model,\n stop_reason: stopReason,\n stop_sequence: null,\n usage,\n }\n}\n\nconst mapOutputToAnthropicContent = (\n output: Array<ResponseOutputItem>,\n): Array<AnthropicAssistantContentBlock> => {\n const contentBlocks: Array<AnthropicAssistantContentBlock> = []\n\n for (const item of output) {\n switch (item.type) {\n case \"reasoning\": {\n const thinkingText = extractReasoningText(item)\n if (thinkingText.length > 0) {\n contentBlocks.push({\n type: \"thinking\",\n thinking: thinkingText,\n signature: (item.encrypted_content ?? \"\") + \"@\" + item.id,\n })\n }\n break\n }\n case \"function_call\": {\n const toolUseBlock = createToolUseContentBlock(item)\n if (toolUseBlock) {\n contentBlocks.push(toolUseBlock)\n }\n break\n }\n case \"message\": {\n const combinedText = combineMessageTextContent(item.content)\n if (combinedText.length > 0) {\n contentBlocks.push({ type: \"text\", text: combinedText })\n }\n break\n }\n case \"compaction\": {\n const compactionBlock = createCompactionThinkingBlock(item)\n if (compactionBlock) {\n contentBlocks.push(compactionBlock)\n }\n break\n }\n default: {\n // Future compatibility for unrecognized output item types.\n const combinedText = combineMessageTextContent(\n (item as { content?: Array<ResponseOutputContentBlock> }).content,\n )\n if (combinedText.length > 0) {\n contentBlocks.push({ type: \"text\", text: combinedText })\n }\n }\n }\n }\n\n return contentBlocks\n}\n\nconst combineMessageTextContent = (\n content: Array<ResponseOutputContentBlock> | undefined,\n): string => {\n if (!Array.isArray(content)) {\n return \"\"\n }\n\n let aggregated = \"\"\n\n for (const block of content) {\n if (isResponseOutputText(block)) {\n aggregated += block.text\n continue\n }\n\n if (isResponseOutputRefusal(block)) {\n aggregated += block.refusal\n continue\n }\n\n if (typeof (block as { text?: unknown }).text === \"string\") {\n aggregated += (block as { text: string }).text\n continue\n }\n\n if (typeof (block as { reasoning?: unknown }).reasoning === \"string\") {\n aggregated += (block as { reasoning: string }).reasoning\n continue\n }\n }\n\n return aggregated\n}\n\nconst extractReasoningText = (item: ResponseOutputReasoning): string => {\n const segments: Array<string> = []\n\n const collectFromBlocks = (blocks?: Array<ResponseReasoningBlock>) => {\n if (!Array.isArray(blocks)) {\n return\n }\n\n for (const block of blocks) {\n if (typeof block.text === \"string\") {\n segments.push(block.text)\n continue\n }\n }\n }\n\n // Compatible with opencode, it will filter out blocks where the thinking text is empty, so we add a default thinking text here\n if (!item.summary || item.summary.length === 0) {\n return THINKING_TEXT\n }\n\n collectFromBlocks(item.summary)\n\n return segments.join(\"\").trim()\n}\n\nconst createToolUseContentBlock = (\n call: ResponseOutputFunctionCall,\n): AnthropicToolUseBlock | null => {\n const toolId = call.call_id\n if (!call.name || !toolId) {\n return null\n }\n\n const input = parseFunctionCallArguments(call.arguments)\n\n return {\n type: \"tool_use\",\n id: toolId,\n name: call.name,\n input,\n }\n}\n\nconst createCompactionThinkingBlock = (\n item: ResponseOutputCompaction,\n): AnthropicAssistantContentBlock | null => {\n if (!item.id || !item.encrypted_content) {\n return null\n }\n\n return {\n type: \"thinking\",\n thinking: THINKING_TEXT,\n signature: encodeCompactionCarrierSignature({\n id: item.id,\n encrypted_content: item.encrypted_content,\n }),\n }\n}\n\nconst parseFunctionCallArguments = (\n rawArguments: string,\n): Record<string, unknown> => {\n if (typeof rawArguments !== \"string\" || rawArguments.trim().length === 0) {\n return {}\n }\n\n try {\n const parsed: unknown = JSON.parse(rawArguments)\n\n if (Array.isArray(parsed)) {\n return { arguments: parsed }\n }\n\n if (parsed && typeof parsed === \"object\") {\n return parsed as Record<string, unknown>\n }\n } catch (error) {\n consola.warn(\"Failed to parse function call arguments\", {\n error,\n rawArguments,\n })\n }\n\n return { raw_arguments: rawArguments }\n}\n\nconst fallbackContentBlocks = (\n outputText: string,\n): Array<AnthropicAssistantContentBlock> => {\n if (!outputText) {\n return []\n }\n\n return [\n {\n type: \"text\",\n text: outputText,\n },\n ]\n}\n\nconst mapResponsesStopReason = (\n response: ResponsesResult,\n): AnthropicResponse[\"stop_reason\"] => {\n const { status, incomplete_details: incompleteDetails } = response\n\n if (status === \"completed\") {\n if (response.output.some((item) => item.type === \"function_call\")) {\n return \"tool_use\"\n }\n return \"end_turn\"\n }\n\n if (status === \"incomplete\") {\n if (incompleteDetails?.reason === \"max_output_tokens\") {\n return \"max_tokens\"\n }\n if (incompleteDetails?.reason === \"content_filter\") {\n return \"end_turn\"\n }\n }\n\n return null\n}\n\nconst mapResponsesUsage = (\n response: ResponsesResult,\n): AnthropicResponse[\"usage\"] => {\n const inputTokens = response.usage?.input_tokens ?? 0\n const outputTokens = response.usage?.output_tokens ?? 0\n const inputCachedTokens = response.usage?.input_tokens_details?.cached_tokens\n\n return {\n input_tokens: inputTokens - (inputCachedTokens ?? 0),\n output_tokens: outputTokens,\n ...(response.usage?.input_tokens_details?.cached_tokens !== undefined && {\n cache_read_input_tokens:\n response.usage.input_tokens_details.cached_tokens,\n }),\n }\n}\n\nconst isRecord = (value: unknown): value is Record<string, unknown> =>\n typeof value === \"object\" && value !== null\n\nconst isResponseOutputText = (\n block: ResponseOutputContentBlock,\n): block is ResponseOutputText =>\n isRecord(block)\n && \"type\" in block\n && (block as { type?: unknown }).type === \"output_text\"\n\nconst isResponseOutputRefusal = (\n block: ResponseOutputContentBlock,\n): block is ResponseOutputRefusal =>\n isRecord(block)\n && \"type\" in block\n && (block as { type?: unknown }).type === \"refusal\"\n\nconst convertToolResultContent = (\n content: string | Array<AnthropicToolResultContentBlock>,\n): string | Array<ResponseInputContent> => {\n if (typeof content === \"string\") {\n return content\n }\n\n if (Array.isArray(content)) {\n const result: Array<ResponseInputContent> = []\n for (const block of content) {\n switch (block.type) {\n case \"text\": {\n result.push(createTextContent(block.text))\n break\n }\n case \"image\": {\n result.push(createImageContent(block))\n break\n }\n case \"document\": {\n result.push(createFileContent(block))\n break\n }\n case \"tool_reference\": {\n result.push(createTextContent(`Tool ${block.tool_name} loaded`))\n break\n }\n default: {\n break\n }\n }\n }\n return result\n }\n\n return \"\"\n}\n","import {\n type ResponseCompletedEvent,\n type ResponseCreatedEvent,\n type ResponseErrorEvent,\n type ResponseFailedEvent,\n type ResponseFunctionCallArgumentsDeltaEvent,\n type ResponseFunctionCallArgumentsDoneEvent,\n type ResponseIncompleteEvent,\n type ResponseOutputItemAddedEvent,\n type ResponseOutputItemDoneEvent,\n type ResponseReasoningSummaryTextDeltaEvent,\n type ResponseReasoningSummaryTextDoneEvent,\n type ResponsesResult,\n type ResponseStreamEvent,\n type ResponseTextDeltaEvent,\n type ResponseTextDoneEvent,\n} from \"~/services/copilot/create-responses\"\n\nimport { type AnthropicStreamEventData } from \"./anthropic-types\"\nimport {\n THINKING_TEXT,\n encodeCompactionCarrierSignature,\n translateResponsesResultToAnthropic,\n} from \"./responses-translation\"\n\nconst MAX_CONSECUTIVE_FUNCTION_CALL_WHITESPACE = 20\n\nclass FunctionCallArgumentsValidationError extends Error {\n constructor(message: string) {\n super(message)\n this.name = \"FunctionCallArgumentsValidationError\"\n }\n}\n\nconst updateWhitespaceRunState = (\n previousCount: number,\n chunk: string,\n): {\n nextCount: number\n exceeded: boolean\n} => {\n let count = previousCount\n\n for (const char of chunk) {\n if (char === \"\\r\" || char === \"\\n\" || char === \"\\t\") {\n count += 1\n if (count > MAX_CONSECUTIVE_FUNCTION_CALL_WHITESPACE) {\n return { nextCount: count, exceeded: true }\n }\n continue\n }\n\n if (char !== \" \") {\n count = 0\n }\n }\n\n return { nextCount: count, exceeded: false }\n}\n\nexport interface ResponsesStreamState {\n messageStartSent: boolean\n messageCompleted: boolean\n nextContentBlockIndex: number\n blockIndexByKey: Map<string, number>\n openBlocks: Set<number>\n blockHasDelta: Set<number>\n functionCallStateByOutputIndex: Map<number, FunctionCallStreamState>\n}\n\ntype FunctionCallStreamState = {\n blockIndex: number\n toolCallId: string\n name: string\n consecutiveWhitespaceCount: number\n}\n\nexport const createResponsesStreamState = (): ResponsesStreamState => ({\n messageStartSent: false,\n messageCompleted: false,\n nextContentBlockIndex: 0,\n blockIndexByKey: new Map(),\n openBlocks: new Set(),\n blockHasDelta: new Set(),\n functionCallStateByOutputIndex: new Map(),\n})\n\nexport const translateResponsesStreamEvent = (\n rawEvent: ResponseStreamEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const eventType = rawEvent.type\n switch (eventType) {\n case \"response.created\": {\n return handleResponseCreated(rawEvent, state)\n }\n\n case \"response.output_item.added\": {\n return handleOutputItemAdded(rawEvent, state)\n }\n\n case \"response.reasoning_summary_text.delta\": {\n return handleReasoningSummaryTextDelta(rawEvent, state)\n }\n\n case \"response.output_text.delta\": {\n return handleOutputTextDelta(rawEvent, state)\n }\n\n case \"response.reasoning_summary_text.done\": {\n return handleReasoningSummaryTextDone(rawEvent, state)\n }\n\n case \"response.output_text.done\": {\n return handleOutputTextDone(rawEvent, state)\n }\n case \"response.output_item.done\": {\n return handleOutputItemDone(rawEvent, state)\n }\n\n case \"response.function_call_arguments.delta\": {\n return handleFunctionCallArgumentsDelta(rawEvent, state)\n }\n\n case \"response.function_call_arguments.done\": {\n return handleFunctionCallArgumentsDone(rawEvent, state)\n }\n\n case \"response.completed\":\n case \"response.incomplete\": {\n return handleResponseCompleted(rawEvent, state)\n }\n\n case \"response.failed\": {\n return handleResponseFailed(rawEvent, state)\n }\n\n case \"error\": {\n return handleErrorEvent(rawEvent, state)\n }\n\n default: {\n return []\n }\n }\n}\n\n// Helper handlers to keep translateResponsesStreamEvent concise\nconst handleResponseCreated = (\n rawEvent: ResponseCreatedEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n return messageStart(state, rawEvent.response)\n}\n\nconst handleOutputItemAdded = (\n rawEvent: ResponseOutputItemAddedEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const events = new Array<AnthropicStreamEventData>()\n const functionCallDetails = extractFunctionCallDetails(rawEvent)\n if (!functionCallDetails) {\n return events\n }\n\n const { outputIndex, toolCallId, name, initialArguments } =\n functionCallDetails\n const blockIndex = openFunctionCallBlock(state, {\n outputIndex,\n toolCallId,\n name,\n events,\n })\n\n if (initialArguments !== undefined && initialArguments.length > 0) {\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"input_json_delta\",\n partial_json: initialArguments,\n },\n })\n state.blockHasDelta.add(blockIndex)\n }\n\n return events\n}\n\nconst handleOutputItemDone = (\n rawEvent: ResponseOutputItemDoneEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const events = new Array<AnthropicStreamEventData>()\n const item = rawEvent.item\n const itemType = item.type\n const outputIndex = rawEvent.output_index\n\n if (itemType === \"compaction\") {\n if (!item.id || !item.encrypted_content) {\n return events\n }\n\n const blockIndex = openThinkingBlockIfNeeded(state, outputIndex, events)\n\n if (!state.blockHasDelta.has(blockIndex)) {\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"thinking_delta\",\n thinking: THINKING_TEXT,\n },\n })\n }\n\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"signature_delta\",\n signature: encodeCompactionCarrierSignature({\n id: item.id,\n encrypted_content: item.encrypted_content,\n }),\n },\n })\n state.blockHasDelta.add(blockIndex)\n return events\n }\n\n if (itemType !== \"reasoning\") {\n return events\n }\n\n const blockIndex = openThinkingBlockIfNeeded(state, outputIndex, events)\n const signature = (item.encrypted_content ?? \"\") + \"@\" + item.id\n if (signature) {\n // Compatible with opencode, it will filter out blocks where the thinking text is empty, so we add a default thinking text here\n if (!item.summary || item.summary.length === 0) {\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"thinking_delta\",\n thinking: THINKING_TEXT,\n },\n })\n }\n\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"signature_delta\",\n signature,\n },\n })\n state.blockHasDelta.add(blockIndex)\n }\n\n return events\n}\n\nconst handleFunctionCallArgumentsDelta = (\n rawEvent: ResponseFunctionCallArgumentsDeltaEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const events = new Array<AnthropicStreamEventData>()\n const outputIndex = rawEvent.output_index\n const deltaText = rawEvent.delta\n\n if (!deltaText) {\n return events\n }\n\n const blockIndex = openFunctionCallBlock(state, {\n outputIndex,\n events,\n })\n\n const functionCallState =\n state.functionCallStateByOutputIndex.get(outputIndex)\n if (!functionCallState) {\n return handleFunctionCallArgumentsValidationError(\n new FunctionCallArgumentsValidationError(\n \"Received function call arguments delta without an open tool call block.\",\n ),\n state,\n events,\n )\n }\n\n // fix: copolit function call returning infinite line breaks until max_tokens limit\n // \"arguments\": \"{\\\"path\\\":\\\"xxx\\\",\\\"pattern\\\":\\\"**/*.ts\\\",\\\"} }? Wait extra braces. Need correct. I should run? Wait overcame. Need proper JSON with pattern \\\"\\n\\n\\n\\n\\n\\n\\n\\n...\n const { nextCount, exceeded } = updateWhitespaceRunState(\n functionCallState.consecutiveWhitespaceCount,\n deltaText,\n )\n if (exceeded) {\n return handleFunctionCallArgumentsValidationError(\n new FunctionCallArgumentsValidationError(\n \"Received function call arguments delta containing more than 20 consecutive whitespace characters.\",\n ),\n state,\n events,\n )\n }\n functionCallState.consecutiveWhitespaceCount = nextCount\n\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"input_json_delta\",\n partial_json: deltaText,\n },\n })\n state.blockHasDelta.add(blockIndex)\n\n return events\n}\n\nconst handleFunctionCallArgumentsDone = (\n rawEvent: ResponseFunctionCallArgumentsDoneEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const events = new Array<AnthropicStreamEventData>()\n const outputIndex = rawEvent.output_index\n const blockIndex = openFunctionCallBlock(state, {\n outputIndex,\n events,\n })\n\n const finalArguments =\n typeof rawEvent.arguments === \"string\" ? rawEvent.arguments : undefined\n\n if (!state.blockHasDelta.has(blockIndex) && finalArguments) {\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"input_json_delta\",\n partial_json: finalArguments,\n },\n })\n state.blockHasDelta.add(blockIndex)\n }\n\n state.functionCallStateByOutputIndex.delete(outputIndex)\n return events\n}\n\nconst handleOutputTextDelta = (\n rawEvent: ResponseTextDeltaEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const events = new Array<AnthropicStreamEventData>()\n const outputIndex = rawEvent.output_index\n const contentIndex = rawEvent.content_index\n const deltaText = rawEvent.delta\n\n if (!deltaText) {\n return events\n }\n\n const blockIndex = openTextBlockIfNeeded(state, {\n outputIndex,\n contentIndex,\n events,\n })\n\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"text_delta\",\n text: deltaText,\n },\n })\n state.blockHasDelta.add(blockIndex)\n\n return events\n}\n\nconst handleReasoningSummaryTextDelta = (\n rawEvent: ResponseReasoningSummaryTextDeltaEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const outputIndex = rawEvent.output_index\n const deltaText = rawEvent.delta\n const events = new Array<AnthropicStreamEventData>()\n const blockIndex = openThinkingBlockIfNeeded(state, outputIndex, events)\n\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"thinking_delta\",\n thinking: deltaText,\n },\n })\n state.blockHasDelta.add(blockIndex)\n\n return events\n}\n\nconst handleReasoningSummaryTextDone = (\n rawEvent: ResponseReasoningSummaryTextDoneEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const outputIndex = rawEvent.output_index\n const text = rawEvent.text\n const events = new Array<AnthropicStreamEventData>()\n const blockIndex = openThinkingBlockIfNeeded(state, outputIndex, events)\n\n if (text && !state.blockHasDelta.has(blockIndex)) {\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"thinking_delta\",\n thinking: text,\n },\n })\n }\n\n return events\n}\n\nconst handleOutputTextDone = (\n rawEvent: ResponseTextDoneEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const events = new Array<AnthropicStreamEventData>()\n const outputIndex = rawEvent.output_index\n const contentIndex = rawEvent.content_index\n const text = rawEvent.text\n\n const blockIndex = openTextBlockIfNeeded(state, {\n outputIndex,\n contentIndex,\n events,\n })\n\n if (text && !state.blockHasDelta.has(blockIndex)) {\n events.push({\n type: \"content_block_delta\",\n index: blockIndex,\n delta: {\n type: \"text_delta\",\n text,\n },\n })\n }\n\n return events\n}\n\nconst handleResponseCompleted = (\n rawEvent: ResponseCompletedEvent | ResponseIncompleteEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const response = rawEvent.response\n const events = new Array<AnthropicStreamEventData>()\n\n closeAllOpenBlocks(state, events)\n const anthropic = translateResponsesResultToAnthropic(response)\n events.push(\n {\n type: \"message_delta\",\n delta: {\n stop_reason: anthropic.stop_reason,\n stop_sequence: anthropic.stop_sequence,\n },\n usage: anthropic.usage,\n },\n { type: \"message_stop\" },\n )\n state.messageCompleted = true\n return events\n}\n\nconst handleResponseFailed = (\n rawEvent: ResponseFailedEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const response = rawEvent.response\n const events = new Array<AnthropicStreamEventData>()\n closeAllOpenBlocks(state, events)\n\n const message =\n response.error?.message ?? \"The response failed due to an unknown error.\"\n\n events.push(buildErrorEvent(message))\n state.messageCompleted = true\n\n return events\n}\n\nconst handleErrorEvent = (\n rawEvent: ResponseErrorEvent,\n state: ResponsesStreamState,\n): Array<AnthropicStreamEventData> => {\n const message =\n typeof rawEvent.message === \"string\" ?\n rawEvent.message\n : \"An unexpected error occurred during streaming.\"\n\n state.messageCompleted = true\n return [buildErrorEvent(message)]\n}\n\nconst handleFunctionCallArgumentsValidationError = (\n error: FunctionCallArgumentsValidationError,\n state: ResponsesStreamState,\n events: Array<AnthropicStreamEventData> = [],\n): Array<AnthropicStreamEventData> => {\n const reason = error.message\n\n closeAllOpenBlocks(state, events)\n state.messageCompleted = true\n\n events.push(buildErrorEvent(reason))\n\n return events\n}\n\nconst messageStart = (\n state: ResponsesStreamState,\n response: ResponsesResult,\n): Array<AnthropicStreamEventData> => {\n state.messageStartSent = true\n const inputCachedTokens = response.usage?.input_tokens_details?.cached_tokens\n const inputTokens =\n (response.usage?.input_tokens ?? 0) - (inputCachedTokens ?? 0)\n return [\n {\n type: \"message_start\",\n message: {\n id: response.id,\n type: \"message\",\n role: \"assistant\",\n content: [],\n model: response.model,\n stop_reason: null,\n stop_sequence: null,\n usage: {\n input_tokens: inputTokens,\n output_tokens: 0,\n cache_read_input_tokens: inputCachedTokens ?? 0,\n },\n },\n },\n ]\n}\n\nconst openTextBlockIfNeeded = (\n state: ResponsesStreamState,\n params: {\n outputIndex: number\n contentIndex: number\n events: Array<AnthropicStreamEventData>\n },\n): number => {\n const { outputIndex, contentIndex, events } = params\n const key = getBlockKey(outputIndex, contentIndex)\n let blockIndex = state.blockIndexByKey.get(key)\n\n if (blockIndex === undefined) {\n blockIndex = state.nextContentBlockIndex\n state.nextContentBlockIndex += 1\n state.blockIndexByKey.set(key, blockIndex)\n }\n\n if (!state.openBlocks.has(blockIndex)) {\n closeOpenBlocks(state, events)\n events.push({\n type: \"content_block_start\",\n index: blockIndex,\n content_block: {\n type: \"text\",\n text: \"\",\n },\n })\n state.openBlocks.add(blockIndex)\n }\n\n return blockIndex\n}\n\nconst openThinkingBlockIfNeeded = (\n state: ResponsesStreamState,\n outputIndex: number,\n events: Array<AnthropicStreamEventData>,\n): number => {\n //thinking blocks has multiple summary_index, should combine into one block\n const summaryIndex = 0\n const key = getBlockKey(outputIndex, summaryIndex)\n let blockIndex = state.blockIndexByKey.get(key)\n\n if (blockIndex === undefined) {\n blockIndex = state.nextContentBlockIndex\n state.nextContentBlockIndex += 1\n state.blockIndexByKey.set(key, blockIndex)\n }\n\n if (!state.openBlocks.has(blockIndex)) {\n closeOpenBlocks(state, events)\n events.push({\n type: \"content_block_start\",\n index: blockIndex,\n content_block: {\n type: \"thinking\",\n thinking: \"\",\n },\n })\n state.openBlocks.add(blockIndex)\n }\n\n return blockIndex\n}\n\nconst closeBlockIfOpen = (\n state: ResponsesStreamState,\n blockIndex: number,\n events: Array<AnthropicStreamEventData>,\n) => {\n if (!state.openBlocks.has(blockIndex)) {\n return\n }\n\n events.push({ type: \"content_block_stop\", index: blockIndex })\n state.openBlocks.delete(blockIndex)\n state.blockHasDelta.delete(blockIndex)\n}\n\nconst closeOpenBlocks = (\n state: ResponsesStreamState,\n events: Array<AnthropicStreamEventData>,\n) => {\n for (const blockIndex of state.openBlocks) {\n closeBlockIfOpen(state, blockIndex, events)\n }\n}\n\nconst closeAllOpenBlocks = (\n state: ResponsesStreamState,\n events: Array<AnthropicStreamEventData>,\n) => {\n closeOpenBlocks(state, events)\n\n state.functionCallStateByOutputIndex.clear()\n}\n\nexport const buildErrorEvent = (message: string): AnthropicStreamEventData => ({\n type: \"error\",\n error: {\n type: \"api_error\",\n message,\n },\n})\n\nconst getBlockKey = (outputIndex: number, contentIndex: number): string =>\n `${outputIndex}:${contentIndex}`\n\nconst openFunctionCallBlock = (\n state: ResponsesStreamState,\n params: {\n outputIndex: number\n toolCallId?: string\n name?: string\n events: Array<AnthropicStreamEventData>\n },\n): number => {\n const { outputIndex, toolCallId, name, events } = params\n\n let functionCallState = state.functionCallStateByOutputIndex.get(outputIndex)\n\n if (!functionCallState) {\n const blockIndex = state.nextContentBlockIndex\n state.nextContentBlockIndex += 1\n\n const resolvedToolCallId = toolCallId ?? `tool_call_${blockIndex}`\n const resolvedName = name ?? \"function\"\n\n functionCallState = {\n blockIndex,\n toolCallId: resolvedToolCallId,\n name: resolvedName,\n consecutiveWhitespaceCount: 0,\n }\n\n state.functionCallStateByOutputIndex.set(outputIndex, functionCallState)\n }\n\n const { blockIndex } = functionCallState\n\n if (!state.openBlocks.has(blockIndex)) {\n closeOpenBlocks(state, events)\n events.push({\n type: \"content_block_start\",\n index: blockIndex,\n content_block: {\n type: \"tool_use\",\n id: functionCallState.toolCallId,\n name: functionCallState.name,\n input: {},\n },\n })\n state.openBlocks.add(blockIndex)\n }\n\n return blockIndex\n}\n\ntype FunctionCallDetails = {\n outputIndex: number\n toolCallId: string\n name: string\n initialArguments?: string\n}\n\nconst extractFunctionCallDetails = (\n rawEvent: ResponseOutputItemAddedEvent,\n): FunctionCallDetails | undefined => {\n const item = rawEvent.item\n const itemType = item.type\n if (itemType !== \"function_call\") {\n return undefined\n }\n\n const outputIndex = rawEvent.output_index\n const toolCallId = item.call_id\n const name = item.name\n const initialArguments = item.arguments\n return {\n outputIndex,\n toolCallId,\n name,\n initialArguments,\n }\n}\n","import type {\n ResponseContextManagementCompactionItem,\n ResponseInputItem,\n ResponsesPayload,\n} from \"~/services/copilot/create-responses\"\n\nimport { isResponsesApiContextManagementModel } from \"~/lib/config\"\n\nexport const getResponsesRequestOptions = (\n payload: ResponsesPayload,\n): { vision: boolean; initiator: \"agent\" | \"user\" } => {\n const vision = hasVisionInput(payload)\n const initiator = hasAgentInitiator(payload) ? \"agent\" : \"user\"\n\n return { vision, initiator }\n}\n\nexport const hasAgentInitiator = (payload: ResponsesPayload): boolean => {\n // Refactor `isAgentCall` logic to check only the last message in the history rather than any message. This prevents valid user messages from being incorrectly flagged as agent calls due to previous assistant history, ensuring proper credit consumption for multi-turn conversations.\n const lastItem = getPayloadItems(payload).at(-1)\n if (!lastItem) {\n return false\n }\n if (!(\"role\" in lastItem) || !lastItem.role) {\n return true\n }\n const role =\n typeof lastItem.role === \"string\" ? lastItem.role.toLowerCase() : \"\"\n return role === \"assistant\"\n}\n\nexport const hasVisionInput = (payload: ResponsesPayload): boolean => {\n const values = getPayloadItems(payload)\n return values.some((item) => containsVisionContent(item))\n}\n\nexport const resolveResponsesCompactThreshold = (\n maxPromptTokens?: number,\n): number => {\n if (typeof maxPromptTokens === \"number\" && maxPromptTokens > 0) {\n return Math.floor(maxPromptTokens * 0.9)\n }\n\n return 50000\n}\n\nconst createCompactionContextManagement = (\n compactThreshold: number,\n): Array<ResponseContextManagementCompactionItem> => [\n {\n type: \"compaction\",\n compact_threshold: compactThreshold,\n },\n]\n\nexport const applyResponsesApiContextManagement = (\n payload: ResponsesPayload,\n maxPromptTokens?: number,\n): void => {\n if (payload.context_management !== undefined) {\n return\n }\n\n if (!isResponsesApiContextManagementModel(payload.model)) {\n return\n }\n\n payload.context_management = createCompactionContextManagement(\n resolveResponsesCompactThreshold(maxPromptTokens),\n )\n}\n\nexport const compactInputByLatestCompaction = (\n payload: ResponsesPayload,\n): void => {\n if (!Array.isArray(payload.input) || payload.input.length === 0) {\n return\n }\n\n const latestCompactionMessageIndex = getLatestCompactionMessageIndex(\n payload.input,\n )\n\n if (latestCompactionMessageIndex === undefined) {\n return\n }\n\n payload.input = payload.input.slice(latestCompactionMessageIndex)\n}\n\nconst getLatestCompactionMessageIndex = (\n input: Array<ResponseInputItem>,\n): number | undefined => {\n for (let index = input.length - 1; index >= 0; index -= 1) {\n if (isCompactionInputItem(input[index])) {\n return index\n }\n }\n\n return undefined\n}\n\nconst isCompactionInputItem = (value: ResponseInputItem): boolean => {\n return (\n \"type\" in value\n && typeof value.type === \"string\"\n && value.type === \"compaction\"\n )\n}\n\nconst getPayloadItems = (\n payload: ResponsesPayload,\n): Array<ResponseInputItem> => {\n const result: Array<ResponseInputItem> = []\n\n const { input } = payload\n\n if (Array.isArray(input)) {\n result.push(...input)\n }\n\n return result\n}\n\nconst containsVisionContent = (value: unknown): boolean => {\n if (!value) return false\n\n if (Array.isArray(value)) {\n return value.some((entry) => containsVisionContent(entry))\n }\n\n if (typeof value !== \"object\") {\n return false\n }\n\n const record = value as Record<string, unknown>\n const type =\n typeof record.type === \"string\" ? record.type.toLowerCase() : undefined\n\n if (type === \"input_image\") {\n return true\n }\n\n if (Array.isArray(record.content)) {\n return record.content.some((entry) => containsVisionContent(entry))\n }\n\n return false\n}\n","import consola from \"consola\"\nimport { events } from \"fetch-event-stream\"\n\nimport type { CompactType } from \"~/lib/compact\"\nimport type { SubagentMarker } from \"~/lib/subagent\"\nimport type {\n AnthropicMessagesPayload,\n AnthropicResponse,\n} from \"~/routes/messages/anthropic-types\"\n\nimport {\n copilotBaseUrl,\n copilotHeaders,\n prepareForCompact,\n prepareInteractionHeaders,\n prepareMessageProxyHeaders,\n} from \"~/lib/api-config\"\nimport { logCopilotRateLimits } from \"~/lib/copilot-rate-limit\"\nimport { HTTPError } from \"~/lib/error\"\nimport { state } from \"~/lib/state\"\nimport { parseUserIdMetadata } from \"~/lib/utils\"\n\nexport type MessagesStream = ReturnType<typeof events>\nexport type CreateMessagesReturn = AnthropicResponse | MessagesStream\n\nconst INTERLEAVED_THINKING_BETA = \"interleaved-thinking-2025-05-14\"\nconst ADVANCED_TOOL_USE_BETA = \"advanced-tool-use-2025-11-20\"\nconst allowedAnthropicBetas = new Set([\n INTERLEAVED_THINKING_BETA,\n \"context-management-2025-06-27\",\n ADVANCED_TOOL_USE_BETA,\n])\n\nconst buildAnthropicBetaHeader = (\n anthropicBetaHeader: string | undefined,\n thinking: AnthropicMessagesPayload[\"thinking\"],\n _model: string,\n): string | undefined => {\n const isAdaptiveThinking = thinking?.type === \"adaptive\"\n\n if (anthropicBetaHeader) {\n const filteredBeta = anthropicBetaHeader\n .split(\",\")\n .map((item) => item.trim())\n .filter((item) => item.length > 0)\n .filter((item) => allowedAnthropicBetas.has(item))\n\n // in vscode copilot extension, advanced-tool-use is enabled by default\n // align header with vscode copilot extension\n const uniqueFilteredBetas = [...filteredBeta]\n if (uniqueFilteredBetas.length > 0) {\n return uniqueFilteredBetas.join(\",\")\n }\n\n return undefined\n }\n\n if (thinking?.budget_tokens && !isAdaptiveThinking) {\n return INTERLEAVED_THINKING_BETA\n }\n\n return undefined\n}\n\nexport const createMessages = async (\n payload: AnthropicMessagesPayload,\n anthropicBetaHeader: string | undefined,\n options: {\n subagentMarker?: SubagentMarker | null\n requestId: string\n sessionId?: string\n compactType?: CompactType\n },\n): Promise<CreateMessagesReturn> => {\n if (!state.copilotToken) throw new Error(\"Copilot token not found\")\n\n const enableVision = payload.messages.some((message) => {\n if (!Array.isArray(message.content)) return false\n return message.content.some(\n (block) =>\n block.type === \"image\"\n || (block.type === \"tool_result\"\n && Array.isArray(block.content)\n && block.content.some((inner) => inner.type === \"image\")),\n )\n })\n\n let isInitiateRequest = false\n const lastMessage = payload.messages.at(-1)\n if (lastMessage?.role === \"user\") {\n isInitiateRequest =\n Array.isArray(lastMessage.content) ?\n lastMessage.content.some((block) => block.type !== \"tool_result\")\n : true\n }\n\n const headers: Record<string, string> = {\n ...copilotHeaders(state, options.requestId, enableVision),\n \"x-initiator\": isInitiateRequest ? \"user\" : \"agent\",\n }\n\n prepareInteractionHeaders(\n options.sessionId,\n Boolean(options.subagentMarker),\n headers,\n )\n\n prepareForCompact(headers, options.compactType)\n\n const { safetyIdentifier, sessionId } = parseUserIdMetadata(\n payload.metadata?.user_id,\n )\n // from claude code\n if (safetyIdentifier && sessionId) {\n prepareMessageProxyHeaders(headers)\n }\n\n // align with vscode copilot extension anthropic-beta\n const anthropicBeta = buildAnthropicBetaHeader(\n anthropicBetaHeader,\n payload.thinking,\n payload.model,\n )\n if (anthropicBeta) {\n headers[\"anthropic-beta\"] = anthropicBeta\n }\n\n consola.log(`<-- model: ${payload.model}`)\n\n const response = await fetch(`${copilotBaseUrl(state)}/v1/messages`, {\n method: \"POST\",\n headers,\n body: JSON.stringify(payload),\n })\n\n logCopilotRateLimits(response.headers)\n\n if (!response.ok) {\n consola.error(\"Failed to create messages\", response)\n throw new HTTPError(\"Failed to create messages\", response)\n }\n\n if (payload.stream) {\n return events(response)\n }\n\n return (await response.json()) as AnthropicResponse\n}\n","import type { Model } from \"~/services/copilot/get-models\"\n\nimport {\n COMPACT_AUTO_CONTINUE,\n COMPACT_REQUEST,\n compactAutoContinuePromptStarts,\n compactMessageSections,\n compactSummaryPromptStart,\n compactSystemPromptStarts,\n compactTextOnlyGuard,\n type CompactType,\n} from \"~/lib/compact\"\nimport { getReasoningEffortForModel } from \"~/lib/config\"\n\nimport type {\n AnthropicDocumentBlock,\n AnthropicImageBlock,\n AnthropicMessage,\n AnthropicMessagesPayload,\n AnthropicTextBlock,\n AnthropicToolResultBlock,\n AnthropicUserContentBlock,\n} from \"./anthropic-types\"\n\nexport const TOOL_REFERENCE_TURN_BOUNDARY = \"Tool loaded.\"\n\nconst IDE_EXECUTE_CODE_TOOL = \"mcp__ide__executeCode\"\nconst IDE_GET_DIAGNOSTICS_TOOL = \"mcp__ide__getDiagnostics\"\nconst IDE_GET_DIAGNOSTICS_DESCRIPTION =\n \"Get language diagnostics from VS Code. Returns errors, warnings, information, and hints for files in the workspace.\"\nconst PDF_FILE_READ_PREFIX = \"PDF file read:\"\n\ntype AnthropicAttachmentBlock = AnthropicImageBlock | AnthropicDocumentBlock\ntype IndexedAttachment = {\n attachment: AnthropicAttachmentBlock\n order: number\n}\n\nconst getCompactCandidateText = (message: AnthropicMessage): string => {\n if (message.role !== \"user\") {\n return \"\"\n }\n\n if (typeof message.content === \"string\") {\n return message.content\n }\n\n return message.content\n .filter((block): block is AnthropicTextBlock => block.type === \"text\")\n .map((block) =>\n block.text.startsWith(\"<system-reminder>\") ? \"\" : block.text,\n )\n .filter((text) => text.length > 0)\n .join(\"\\n\\n\")\n}\n\nconst isCompactMessage = (lastMessage: AnthropicMessage): boolean => {\n const text = getCompactCandidateText(lastMessage)\n if (!text) {\n return false\n }\n\n return (\n text.includes(compactTextOnlyGuard)\n && text.includes(compactSummaryPromptStart)\n && compactMessageSections.some((section) => text.includes(section))\n )\n}\n\nconst isCompactAutoContinueMessage = (\n lastMessage: AnthropicMessage,\n): boolean => {\n const text = getCompactCandidateText(lastMessage)\n return (\n Boolean(text)\n && compactAutoContinuePromptStarts.some((promptStart) =>\n text.startsWith(promptStart),\n )\n )\n}\n\nexport const getCompactType = (\n anthropicPayload: AnthropicMessagesPayload,\n): CompactType => {\n const lastMessage = anthropicPayload.messages.at(-1)\n if (lastMessage && isCompactMessage(lastMessage)) {\n return COMPACT_REQUEST\n }\n\n if (lastMessage && isCompactAutoContinueMessage(lastMessage)) {\n return COMPACT_AUTO_CONTINUE\n }\n\n const system = anthropicPayload.system\n if (typeof system === \"string\") {\n const hasCompactSystemPrompt = compactSystemPromptStarts.some(\n (promptStart) => system.startsWith(promptStart),\n )\n return hasCompactSystemPrompt ? COMPACT_REQUEST : 0\n }\n if (!Array.isArray(system)) return 0\n\n const hasCompactSystemPrompt = system.some(\n (msg) =>\n typeof msg.text === \"string\"\n && compactSystemPromptStarts.some((promptStart) =>\n msg.text.startsWith(promptStart),\n ),\n )\n if (hasCompactSystemPrompt) {\n return COMPACT_REQUEST\n }\n\n return 0\n}\n\nconst mergeContentWithText = (\n tr: AnthropicToolResultBlock,\n textBlock: AnthropicTextBlock,\n): AnthropicToolResultBlock => {\n if (typeof tr.content === \"string\") {\n return { ...tr, content: `${tr.content}\\n\\n${textBlock.text}` }\n }\n // Unable to merge, discard other text blocks, wait for the next round of re-request\n if (hasToolRef(tr)) {\n return tr\n }\n return {\n ...tr,\n content: [...tr.content, textBlock],\n }\n}\n\nconst mergeContentWithTexts = (\n tr: AnthropicToolResultBlock,\n textBlocks: Array<AnthropicTextBlock>,\n): AnthropicToolResultBlock => {\n if (typeof tr.content === \"string\") {\n const appendedTexts = textBlocks.map((tb) => tb.text).join(\"\\n\\n\")\n return { ...tr, content: `${tr.content}\\n\\n${appendedTexts}` }\n }\n // Unable to merge, discard other text blocks, wait for the next round of re-request\n if (hasToolRef(tr)) {\n return tr\n }\n return { ...tr, content: [...tr.content, ...textBlocks] }\n}\n\nconst mergeContentWithAttachments = (\n tr: AnthropicToolResultBlock,\n attachments: Array<AnthropicAttachmentBlock>,\n): AnthropicToolResultBlock => {\n if (typeof tr.content === \"string\") {\n return {\n ...tr,\n content: [{ type: \"text\", text: tr.content }, ...attachments],\n }\n }\n\n return {\n ...tr,\n content: [...tr.content, ...attachments],\n }\n}\n\nconst isAttachmentBlock = (\n block: AnthropicUserContentBlock,\n): block is AnthropicAttachmentBlock => {\n return block.type === \"image\" || block.type === \"document\"\n}\n\nconst getMergeableToolResultIndices = (\n toolResults: Array<AnthropicToolResultBlock>,\n): Array<number> => {\n return toolResults.flatMap((block, index) =>\n block.is_error || hasToolRef(block) ? [] : [index],\n )\n}\n\nconst mergeAttachmentsIntoToolResults = (\n toolResults: Array<AnthropicToolResultBlock>,\n attachmentsByToolResultIndex: Map<number, Array<IndexedAttachment>>,\n): Array<AnthropicToolResultBlock> => {\n if (attachmentsByToolResultIndex.size === 0) {\n return toolResults\n }\n\n return toolResults.map((block, index) => {\n const matchedAttachments = attachmentsByToolResultIndex.get(index)\n if (!matchedAttachments) {\n return block\n }\n\n const orderedAttachments = [...matchedAttachments]\n .sort((left, right) => left.order - right.order)\n .map(({ attachment }) => attachment)\n\n return mergeContentWithAttachments(block, orderedAttachments)\n })\n}\n\nconst assignAttachmentsToToolResults = (\n target: Map<number, Array<IndexedAttachment>>,\n attachments: Array<IndexedAttachment>,\n options: {\n toolResultIndices: Array<number>\n fallbackToolResultIndices?: Array<number>\n },\n): void => {\n const { toolResultIndices } = options\n const fallbackToolResultIndices =\n options.fallbackToolResultIndices ?? toolResultIndices\n\n if (attachments.length === 0) {\n return\n }\n\n if (\n toolResultIndices.length > 0\n && toolResultIndices.length === attachments.length\n ) {\n for (const [index, toolResultIndex] of toolResultIndices.entries()) {\n const currentAttachments = target.get(toolResultIndex)\n if (currentAttachments) {\n currentAttachments.push(attachments[index])\n continue\n }\n\n target.set(toolResultIndex, [attachments[index]])\n }\n return\n }\n\n const lastToolResultIndex = fallbackToolResultIndices.at(-1)\n if (lastToolResultIndex === undefined) {\n return\n }\n\n const currentAttachments = target.get(lastToolResultIndex)\n if (currentAttachments) {\n currentAttachments.push(...attachments)\n return\n }\n\n target.set(lastToolResultIndex, [...attachments])\n}\n\nconst startsWithPdfFileRead = (\n toolResult: AnthropicToolResultBlock,\n): boolean => {\n if (typeof toolResult.content === \"string\") {\n return toolResult.content.startsWith(PDF_FILE_READ_PREFIX)\n }\n\n if (toolResult.content.some((block) => block.type === \"document\")) {\n return false\n }\n\n if (toolResult.content.length === 0) {\n return false\n }\n\n const firstBlock = toolResult.content[0]\n if (firstBlock.type !== \"text\") {\n return false\n }\n\n return firstBlock.text.startsWith(PDF_FILE_READ_PREFIX)\n}\n\nconst collectMergeableUserContent = (\n content: Array<AnthropicUserContentBlock>,\n): {\n toolResults: Array<AnthropicToolResultBlock>\n textBlocks: Array<AnthropicTextBlock>\n attachments: Array<IndexedAttachment>\n} | null => {\n const toolResults: Array<AnthropicToolResultBlock> = []\n const textBlocks: Array<AnthropicTextBlock> = []\n const attachments: Array<IndexedAttachment> = []\n\n for (const [order, block] of content.entries()) {\n if (block.type === \"tool_result\") {\n toolResults.push(block)\n continue\n }\n if (block.type === \"text\") {\n textBlocks.push(block)\n continue\n }\n if (isAttachmentBlock(block)) {\n attachments.push({ attachment: block, order })\n continue\n }\n\n return null\n }\n\n return {\n toolResults,\n textBlocks,\n attachments,\n }\n}\n\nconst mergeAttachmentsForToolResults = (\n toolResults: Array<AnthropicToolResultBlock>,\n attachments: Array<IndexedAttachment>,\n): Array<AnthropicToolResultBlock> => {\n if (attachments.length === 0) {\n return toolResults\n }\n\n const documentBlocks = attachments.filter(\n ({ attachment }) => attachment.type === \"document\",\n )\n const mergeableToolResultIndices = getMergeableToolResultIndices(toolResults)\n const pdfReadToolResultIndices = mergeableToolResultIndices.filter((index) =>\n startsWithPdfFileRead(toolResults[index]),\n )\n\n const attachmentsByToolResultIndex = new Map<\n number,\n Array<IndexedAttachment>\n >()\n let remainingAttachments = attachments\n let countMatchToolResultIndices = mergeableToolResultIndices\n\n // Match PDF read tool results and documents in order first, then leave any\n // unmatched documents to the generic fallback path below.\n if (documentBlocks.length > 0 && pdfReadToolResultIndices.length > 0) {\n const matchedDocumentCount = Math.min(\n pdfReadToolResultIndices.length,\n documentBlocks.length,\n )\n const matchedDocuments = documentBlocks.slice(0, matchedDocumentCount)\n const matchedDocumentOrders = new Set(\n matchedDocuments.map(({ order }) => order),\n )\n const matchedPdfToolResultIndices = pdfReadToolResultIndices.slice(\n 0,\n matchedDocumentCount,\n )\n const matchedPdfToolResultIndexSet = new Set(matchedPdfToolResultIndices)\n\n assignAttachmentsToToolResults(\n attachmentsByToolResultIndex,\n matchedDocuments,\n {\n toolResultIndices: matchedPdfToolResultIndices,\n },\n )\n countMatchToolResultIndices = mergeableToolResultIndices.filter(\n (index) => !matchedPdfToolResultIndexSet.has(index),\n )\n remainingAttachments = attachments.filter(\n ({ attachment, order }) =>\n attachment.type !== \"document\" || !matchedDocumentOrders.has(order),\n )\n }\n\n // Everything else keeps the existing count-match / last-tool-result fallback.\n assignAttachmentsToToolResults(\n attachmentsByToolResultIndex,\n remainingAttachments,\n {\n toolResultIndices: countMatchToolResultIndices,\n fallbackToolResultIndices: mergeableToolResultIndices,\n },\n )\n\n return mergeAttachmentsIntoToolResults(\n toolResults,\n attachmentsByToolResultIndex,\n )\n}\n\nconst mergeUserMessageContent = (\n content: Array<AnthropicUserContentBlock>,\n): Array<AnthropicUserContentBlock> | null => {\n const mergeableContent = collectMergeableUserContent(content)\n if (!mergeableContent) {\n return null\n }\n\n const { toolResults, textBlocks, attachments } = mergeableContent\n if (\n toolResults.length === 0\n || (textBlocks.length === 0 && attachments.length === 0)\n ) {\n return null\n }\n\n const mergedToolResults =\n textBlocks.length === 0 ?\n toolResults\n : mergeToolResult(toolResults, textBlocks)\n\n return mergeAttachmentsForToolResults(mergedToolResults, attachments)\n}\n\nconst mergeToolResult = (\n toolResults: Array<AnthropicToolResultBlock>,\n textBlocks: Array<AnthropicTextBlock>,\n): Array<AnthropicToolResultBlock> => {\n if (toolResults.length === textBlocks.length) {\n return toolResults.map((tr, i) => mergeContentWithText(tr, textBlocks[i]))\n }\n\n const lastIndex = toolResults.length - 1\n return toolResults.map((tr, i) =>\n i === lastIndex ? mergeContentWithTexts(tr, textBlocks) : tr,\n )\n}\n\nexport const stripToolReferenceTurnBoundary = (\n anthropicPayload: AnthropicMessagesPayload,\n): void => {\n for (const msg of anthropicPayload.messages) {\n if (msg.role !== \"user\" || !Array.isArray(msg.content)) continue\n\n const hasToolReference = msg.content.some(\n (block) => block.type === \"tool_result\" && hasToolRef(block),\n )\n if (!hasToolReference) continue\n\n msg.content = msg.content.filter(\n (block) =>\n block.type !== \"text\"\n || block.text.trim() !== TOOL_REFERENCE_TURN_BOUNDARY,\n )\n }\n}\n\nexport const mergeToolResultForClaude = (\n anthropicPayload: AnthropicMessagesPayload,\n options?: {\n skipLastMessage?: boolean\n },\n): void => {\n const lastMessageIndex = anthropicPayload.messages.length - 1\n\n for (const [index, msg] of anthropicPayload.messages.entries()) {\n if (options?.skipLastMessage && index === lastMessageIndex) continue\n\n if (msg.role !== \"user\" || !Array.isArray(msg.content)) continue\n\n const mergedContent = mergeUserMessageContent(msg.content)\n if (mergedContent) {\n msg.content = mergedContent\n }\n }\n}\n\n// align with vscode copilot claude agent tools\nexport const sanitizeIdeTools = (payload: AnthropicMessagesPayload): void => {\n if (!payload.tools || payload.tools.length === 0) {\n return\n }\n\n payload.tools = payload.tools.flatMap((tool) => {\n if (tool.name === IDE_EXECUTE_CODE_TOOL && !tool.defer_loading) {\n return []\n }\n\n if (tool.name === IDE_GET_DIAGNOSTICS_TOOL) {\n return [\n {\n ...tool,\n description: IDE_GET_DIAGNOSTICS_DESCRIPTION,\n },\n ]\n }\n\n return [tool]\n })\n}\n\nconst hasToolRef = (block: AnthropicToolResultBlock) => {\n return (\n Array.isArray(block.content)\n && block.content.some((c) => c.type === \"tool_reference\")\n )\n}\n\n// Strip cache_control from system content blocks as the\n// Copilot Messages API does not support them (rejects extra fields like scope).\n// commit by nicktogo\nconst stripCacheControl = (payload: AnthropicMessagesPayload): void => {\n if (Array.isArray(payload.system)) {\n for (const block of payload.system) {\n const systemBlock = block as AnthropicTextBlock & {\n cache_control?: Record<string, unknown>\n }\n const cacheControl = systemBlock.cache_control\n if (cacheControl && typeof cacheControl === \"object\") {\n const { scope, ...rest } = cacheControl\n systemBlock.cache_control = rest\n }\n }\n }\n}\n\n// Pre-request processing: filter thinking blocks for Claude models so only\n// valid thinking blocks are sent to the Copilot Messages API.\nconst filterAssistantThinkingBlocks = (\n payload: AnthropicMessagesPayload,\n): void => {\n for (const msg of payload.messages) {\n if (msg.role === \"assistant\" && Array.isArray(msg.content)) {\n msg.content = msg.content.filter((block) => {\n if (block.type !== \"thinking\") return true\n return (\n block.thinking\n && block.thinking !== \"Thinking...\"\n && block.signature\n && !block.signature.includes(\"@\")\n )\n })\n }\n }\n}\n\nexport const prepareMessagesApiPayload = (\n payload: AnthropicMessagesPayload,\n selectedModel?: Model,\n): void => {\n stripCacheControl(payload)\n filterAssistantThinkingBlocks(payload)\n\n const hasThinking = Boolean(payload.thinking)\n\n // https://platform.claude.com/docs/en/build-with-claude/extended-thinking#extended-thinking-with-tool-use\n // Using tool_choice: {\"type\": \"any\"} or tool_choice: {\"type\": \"tool\", \"name\": \"...\"} will result in an error because these options force tool use, which is incompatible with extended thinking.\n const toolChoice = payload.tool_choice\n const disableThink = toolChoice?.type === \"any\" || toolChoice?.type === \"tool\"\n\n if (selectedModel?.capabilities.supports.adaptive_thinking && !disableThink) {\n payload.thinking = {\n type: \"adaptive\",\n }\n // align with vscode copilot\n if (!hasThinking) {\n payload.thinking.display = \"summarized\"\n }\n if (payload.model === \"claude-opus-4.7\") {\n payload.thinking.display = \"summarized\"\n }\n let effort = getReasoningEffortForModel(payload.model)\n if (effort === \"none\" || effort === \"minimal\") {\n effort = \"low\"\n }\n const reasoningEffort = selectedModel.capabilities.supports.reasoning_effort\n if (reasoningEffort && !reasoningEffort.includes(effort)) {\n effort = reasoningEffort.at(-1) as \"low\" | \"medium\" | \"high\"\n }\n payload.output_config = {\n effort: effort,\n }\n }\n}\n","import {\n type ChatCompletionChunk,\n type Choice,\n type Delta,\n} from \"~/services/copilot/create-chat-completions\"\n\nimport {\n type AnthropicStreamEventData,\n type AnthropicStreamState,\n} from \"./anthropic-types\"\nimport { THINKING_TEXT } from \"./non-stream-translation\"\nimport { mapOpenAIStopReasonToAnthropic } from \"./utils\"\n\nfunction isToolBlockOpen(state: AnthropicStreamState): boolean {\n if (!state.contentBlockOpen) {\n return false\n }\n // Check if the current block index corresponds to any known tool call\n return Object.values(state.toolCalls).some(\n (tc) => tc.anthropicBlockIndex === state.contentBlockIndex,\n )\n}\n\nexport function translateChunkToAnthropicEvents(\n chunk: ChatCompletionChunk,\n state: AnthropicStreamState,\n): Array<AnthropicStreamEventData> {\n const events: Array<AnthropicStreamEventData> = []\n\n if (chunk.choices.length === 0) {\n return events\n }\n\n const choice = chunk.choices[0]\n const { delta } = choice\n\n handleMessageStart(state, events, chunk)\n\n handleThinkingText(delta, state, events)\n\n handleContent(delta, state, events)\n\n handleToolCalls(delta, state, events)\n\n handleFinish(choice, state, { events, chunk })\n\n return events\n}\n\nfunction handleFinish(\n choice: Choice,\n state: AnthropicStreamState,\n context: {\n events: Array<AnthropicStreamEventData>\n chunk: ChatCompletionChunk\n },\n) {\n const { events, chunk } = context\n if (choice.finish_reason && choice.finish_reason.length > 0) {\n if (state.contentBlockOpen) {\n const toolBlockOpen = isToolBlockOpen(state)\n context.events.push({\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n })\n state.contentBlockOpen = false\n state.contentBlockIndex++\n if (!toolBlockOpen) {\n handleReasoningOpaque(choice.delta, events, state)\n }\n }\n\n events.push(\n {\n type: \"message_delta\",\n delta: {\n stop_reason: mapOpenAIStopReasonToAnthropic(choice.finish_reason),\n stop_sequence: null,\n },\n usage: {\n input_tokens:\n (chunk.usage?.prompt_tokens ?? 0)\n - (chunk.usage?.prompt_tokens_details?.cached_tokens ?? 0),\n output_tokens: chunk.usage?.completion_tokens ?? 0,\n ...(chunk.usage?.prompt_tokens_details?.cached_tokens\n !== undefined && {\n cache_read_input_tokens:\n chunk.usage.prompt_tokens_details.cached_tokens,\n }),\n },\n },\n {\n type: \"message_stop\",\n },\n )\n }\n}\n\nfunction handleToolCalls(\n delta: Delta,\n state: AnthropicStreamState,\n events: Array<AnthropicStreamEventData>,\n) {\n if (delta.tool_calls && delta.tool_calls.length > 0) {\n closeThinkingBlockIfOpen(state, events)\n\n handleReasoningOpaqueInToolCalls(state, events, delta)\n\n for (const toolCall of delta.tool_calls) {\n if (toolCall.id && toolCall.function?.name) {\n // New tool call starting.\n if (state.contentBlockOpen) {\n // Close any previously open block.\n events.push({\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n })\n state.contentBlockIndex++\n state.contentBlockOpen = false\n }\n\n const anthropicBlockIndex = state.contentBlockIndex\n state.toolCalls[toolCall.index] = {\n id: toolCall.id,\n name: toolCall.function.name,\n anthropicBlockIndex,\n }\n\n events.push({\n type: \"content_block_start\",\n index: anthropicBlockIndex,\n content_block: {\n type: \"tool_use\",\n id: toolCall.id,\n name: toolCall.function.name,\n input: {},\n },\n })\n state.contentBlockOpen = true\n }\n\n if (toolCall.function?.arguments) {\n const toolCallInfo = state.toolCalls[toolCall.index]\n // Tool call can still be empty\n // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition\n if (toolCallInfo) {\n events.push({\n type: \"content_block_delta\",\n index: toolCallInfo.anthropicBlockIndex,\n delta: {\n type: \"input_json_delta\",\n partial_json: toolCall.function.arguments,\n },\n })\n }\n }\n }\n }\n}\n\nfunction handleReasoningOpaqueInToolCalls(\n state: AnthropicStreamState,\n events: Array<AnthropicStreamEventData>,\n delta: Delta,\n) {\n if (state.contentBlockOpen && !isToolBlockOpen(state)) {\n events.push({\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n })\n state.contentBlockIndex++\n state.contentBlockOpen = false\n }\n handleReasoningOpaque(delta, events, state)\n}\n\nfunction handleContent(\n delta: Delta,\n state: AnthropicStreamState,\n events: Array<AnthropicStreamEventData>,\n) {\n if (delta.content && delta.content.length > 0) {\n closeThinkingBlockIfOpen(state, events)\n\n if (isToolBlockOpen(state)) {\n // A tool block was open, so close it before starting a text block.\n events.push({\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n })\n state.contentBlockIndex++\n state.contentBlockOpen = false\n }\n\n if (!state.contentBlockOpen) {\n events.push({\n type: \"content_block_start\",\n index: state.contentBlockIndex,\n content_block: {\n type: \"text\",\n text: \"\",\n },\n })\n state.contentBlockOpen = true\n }\n\n events.push({\n type: \"content_block_delta\",\n index: state.contentBlockIndex,\n delta: {\n type: \"text_delta\",\n text: delta.content,\n },\n })\n }\n\n // handle for claude model\n if (\n delta.content === \"\"\n && delta.reasoning_opaque\n && delta.reasoning_opaque.length > 0\n && state.thinkingBlockOpen\n ) {\n events.push(\n {\n type: \"content_block_delta\",\n index: state.contentBlockIndex,\n delta: {\n type: \"signature_delta\",\n signature: delta.reasoning_opaque,\n },\n },\n {\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n },\n )\n state.contentBlockIndex++\n state.thinkingBlockOpen = false\n }\n}\n\nfunction handleMessageStart(\n state: AnthropicStreamState,\n events: Array<AnthropicStreamEventData>,\n chunk: ChatCompletionChunk,\n) {\n if (!state.messageStartSent) {\n events.push({\n type: \"message_start\",\n message: {\n id: chunk.id,\n type: \"message\",\n role: \"assistant\",\n content: [],\n model: chunk.model,\n stop_reason: null,\n stop_sequence: null,\n usage: {\n input_tokens:\n (chunk.usage?.prompt_tokens ?? 0)\n - (chunk.usage?.prompt_tokens_details?.cached_tokens ?? 0),\n output_tokens: 0, // Will be updated in message_delta when finished\n ...(chunk.usage?.prompt_tokens_details?.cached_tokens\n !== undefined && {\n cache_read_input_tokens:\n chunk.usage.prompt_tokens_details.cached_tokens,\n }),\n },\n },\n })\n state.messageStartSent = true\n }\n}\n\nfunction handleReasoningOpaque(\n delta: Delta,\n events: Array<AnthropicStreamEventData>,\n state: AnthropicStreamState,\n) {\n if (delta.reasoning_opaque && delta.reasoning_opaque.length > 0) {\n events.push(\n {\n type: \"content_block_start\",\n index: state.contentBlockIndex,\n content_block: {\n type: \"thinking\",\n thinking: \"\",\n },\n },\n {\n type: \"content_block_delta\",\n index: state.contentBlockIndex,\n delta: {\n type: \"thinking_delta\",\n thinking: THINKING_TEXT, // Compatible with opencode, it will filter out blocks where the thinking text is empty, so we add a default thinking text here\n },\n },\n {\n type: \"content_block_delta\",\n index: state.contentBlockIndex,\n delta: {\n type: \"signature_delta\",\n signature: delta.reasoning_opaque,\n },\n },\n {\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n },\n )\n state.contentBlockIndex++\n }\n}\n\nfunction handleThinkingText(\n delta: Delta,\n state: AnthropicStreamState,\n events: Array<AnthropicStreamEventData>,\n) {\n if (delta.reasoning_text && delta.reasoning_text.length > 0) {\n // compatible with copilot API returning content->reasoning_text->reasoning_opaque in different deltas\n // this is an extremely abnormal situation, probably a server-side bug\n // only occurs in the claude model, with a very low probability of occurrence\n if (state.contentBlockOpen) {\n delta.content = delta.reasoning_text\n delta.reasoning_text = undefined\n return\n }\n\n if (!state.thinkingBlockOpen) {\n events.push({\n type: \"content_block_start\",\n index: state.contentBlockIndex,\n content_block: {\n type: \"thinking\",\n thinking: \"\",\n },\n })\n state.thinkingBlockOpen = true\n }\n\n events.push({\n type: \"content_block_delta\",\n index: state.contentBlockIndex,\n delta: {\n type: \"thinking_delta\",\n thinking: delta.reasoning_text,\n },\n })\n }\n}\n\nfunction closeThinkingBlockIfOpen(\n state: AnthropicStreamState,\n events: Array<AnthropicStreamEventData>,\n): void {\n if (state.thinkingBlockOpen) {\n events.push(\n {\n type: \"content_block_delta\",\n index: state.contentBlockIndex,\n delta: {\n type: \"signature_delta\",\n signature: \"\",\n },\n },\n {\n type: \"content_block_stop\",\n index: state.contentBlockIndex,\n },\n )\n state.contentBlockIndex++\n state.thinkingBlockOpen = false\n }\n}\n\nexport function translateErrorToAnthropicErrorEvent(): AnthropicStreamEventData {\n return {\n type: \"error\",\n error: {\n type: \"api_error\",\n message: \"An unexpected error occurred during streaming.\",\n },\n }\n}\n","import type { ConsolaInstance } from \"consola\"\nimport type { Context } from \"hono\"\n\nimport { streamSSE } from \"hono/streaming\"\n\nimport type { CompactType } from \"~/lib/compact\"\nimport type { SubagentMarker } from \"~/lib/subagent\"\nimport type { Model } from \"~/services/copilot/get-models\"\n\nimport { debugJson, debugJsonTail, debugLazy } from \"~/lib/logger\"\nimport {\n buildErrorEvent,\n createResponsesStreamState,\n translateResponsesStreamEvent,\n} from \"~/routes/messages/responses-stream-translation\"\nimport {\n translateAnthropicMessagesToResponsesPayload,\n translateResponsesResultToAnthropic,\n} from \"~/routes/messages/responses-translation\"\nimport {\n applyResponsesApiContextManagement,\n compactInputByLatestCompaction,\n getResponsesRequestOptions,\n} from \"~/routes/responses/utils\"\nimport {\n createChatCompletions,\n type ChatCompletionChunk,\n type ChatCompletionResponse,\n} from \"~/services/copilot/create-chat-completions\"\nimport { createMessages } from \"~/services/copilot/create-messages\"\nimport {\n createResponses,\n type ResponsesResult,\n type ResponseStreamEvent,\n} from \"~/services/copilot/create-responses\"\n\nimport {\n type AnthropicMessagesPayload,\n type AnthropicStreamState,\n} from \"./anthropic-types\"\nimport {\n translateToAnthropic,\n translateToOpenAI,\n} from \"./non-stream-translation\"\nimport { prepareMessagesApiPayload } from \"./preprocess\"\nimport { translateChunkToAnthropicEvents } from \"./stream-translation\"\n\nexport interface FlowBaseOptions {\n logger: ConsolaInstance\n subagentMarker?: SubagentMarker | null\n requestId: string\n sessionId?: string\n compactType?: CompactType\n}\n\ninterface ResponsesFlowOptions extends FlowBaseOptions {\n selectedModel?: Model\n}\n\ninterface MessagesFlowOptions extends FlowBaseOptions {\n anthropicBetaHeader?: string\n selectedModel?: Model\n}\n\nexport const handleWithChatCompletions = async (\n c: Context,\n anthropicPayload: AnthropicMessagesPayload,\n options: FlowBaseOptions,\n) => {\n const { logger, subagentMarker, requestId, sessionId, compactType } = options\n const openAIPayload = translateToOpenAI(anthropicPayload)\n debugJson(logger, \"Translated OpenAI request payload:\", openAIPayload)\n\n const response = await createChatCompletions(openAIPayload, {\n subagentMarker,\n requestId,\n sessionId,\n compactType,\n })\n\n if (isNonStreaming(response)) {\n debugJson(logger, \"Non-streaming response from Copilot:\", response)\n const anthropicResponse = translateToAnthropic(response)\n debugJson(logger, \"Translated Anthropic response:\", anthropicResponse)\n return c.json(anthropicResponse)\n }\n\n logger.debug(\"Streaming response from Copilot\")\n return streamSSE(c, async (stream) => {\n const streamState: AnthropicStreamState = {\n messageStartSent: false,\n contentBlockIndex: 0,\n contentBlockOpen: false,\n toolCalls: {},\n thinkingBlockOpen: false,\n }\n\n for await (const rawEvent of response) {\n debugJson(logger, \"Copilot raw stream event:\", rawEvent)\n if (rawEvent.data === \"[DONE]\") {\n break\n }\n\n if (!rawEvent.data) {\n continue\n }\n\n const chunk = JSON.parse(rawEvent.data) as ChatCompletionChunk\n const events = translateChunkToAnthropicEvents(chunk, streamState)\n\n for (const event of events) {\n const eventData = JSON.stringify(event)\n debugLazy(logger, () => [\"Translated Anthropic event:\", eventData])\n await stream.writeSSE({\n event: event.type,\n data: eventData,\n })\n }\n }\n })\n}\n\nexport const handleWithResponsesApi = async (\n c: Context,\n anthropicPayload: AnthropicMessagesPayload,\n options: ResponsesFlowOptions,\n) => {\n const {\n logger,\n subagentMarker,\n selectedModel,\n requestId,\n sessionId,\n compactType,\n } = options\n\n const responsesPayload =\n translateAnthropicMessagesToResponsesPayload(anthropicPayload)\n\n applyResponsesApiContextManagement(\n responsesPayload,\n selectedModel?.capabilities.limits.max_prompt_tokens,\n )\n\n compactInputByLatestCompaction(responsesPayload)\n\n debugJson(logger, \"Translated Responses payload:\", responsesPayload)\n\n const { vision, initiator } = getResponsesRequestOptions(responsesPayload)\n const response = await createResponses(responsesPayload, {\n vision,\n initiator,\n subagentMarker,\n requestId,\n sessionId,\n compactType,\n })\n\n if (responsesPayload.stream && isAsyncIterable(response)) {\n logger.debug(\"Streaming response from Copilot (Responses API)\")\n return streamSSE(c, async (stream) => {\n const streamState = createResponsesStreamState()\n\n for await (const chunk of response) {\n const eventName = chunk.event\n if (eventName === \"ping\") {\n await stream.writeSSE({ event: \"ping\", data: '{\"type\":\"ping\"}' })\n continue\n }\n\n const data = chunk.data\n if (!data) {\n continue\n }\n\n debugLazy(logger, () => [\"Responses raw stream event:\", data])\n\n const events = translateResponsesStreamEvent(\n JSON.parse(data) as ResponseStreamEvent,\n streamState,\n )\n for (const event of events) {\n const eventData = JSON.stringify(event)\n debugLazy(logger, () => [\"Translated Anthropic event:\", eventData])\n await stream.writeSSE({\n event: event.type,\n data: eventData,\n })\n }\n\n if (streamState.messageCompleted) {\n logger.debug(\"Message completed, ending stream\")\n break\n }\n }\n\n if (!streamState.messageCompleted) {\n logger.warn(\n \"Responses stream ended without completion; sending error event\",\n )\n const errorEvent = buildErrorEvent(\n \"Responses stream ended without completion\",\n )\n await stream.writeSSE({\n event: errorEvent.type,\n data: JSON.stringify(errorEvent),\n })\n }\n })\n }\n\n debugJsonTail(logger, \"Non-streaming Responses result:\", {\n value: response,\n tailLength: 400,\n })\n const anthropicResponse = translateResponsesResultToAnthropic(\n response as ResponsesResult,\n )\n debugJson(logger, \"Translated Anthropic response:\", anthropicResponse)\n return c.json(anthropicResponse)\n}\n\nexport const handleWithMessagesApi = async (\n c: Context,\n anthropicPayload: AnthropicMessagesPayload,\n options: MessagesFlowOptions,\n) => {\n const {\n logger,\n anthropicBetaHeader,\n subagentMarker,\n selectedModel,\n requestId,\n sessionId,\n compactType,\n } = options\n\n prepareMessagesApiPayload(anthropicPayload, selectedModel)\n\n debugJson(logger, \"Translated Messages payload:\", anthropicPayload)\n\n const response = await createMessages(anthropicPayload, anthropicBetaHeader, {\n subagentMarker,\n requestId,\n sessionId,\n compactType,\n })\n\n if (isAsyncIterable(response)) {\n logger.debug(\"Streaming response from Copilot (Messages API)\")\n return streamSSE(c, async (stream) => {\n for await (const event of response) {\n const eventName = event.event\n const data = event.data ?? \"\"\n if (data === \"[DONE]\") {\n break\n }\n if (!data) {\n continue\n }\n debugLazy(logger, () => [\"Messages raw stream event:\", data])\n await stream.writeSSE({\n event: eventName,\n data,\n })\n }\n })\n }\n\n debugJsonTail(logger, \"Non-streaming Messages result:\", {\n value: response,\n tailLength: 400,\n })\n return c.json(response)\n}\n\nconst isNonStreaming = (\n response: Awaited<ReturnType<typeof createChatCompletions>>,\n): response is ChatCompletionResponse => Object.hasOwn(response, \"choices\")\n\nconst isAsyncIterable = <T>(value: unknown): value is AsyncIterable<T> =>\n Boolean(value)\n && typeof (value as AsyncIterable<T>)[Symbol.asyncIterator] === \"function\"\n","export const subagentMarkerPrefix = \"__SUBAGENT_MARKER__\"\n\nexport interface SubagentMarker {\n session_id: string\n agent_id: string\n agent_type: string\n}\n","import { subagentMarkerPrefix, type SubagentMarker } from \"~/lib/subagent\"\n\nimport type { AnthropicMessagesPayload } from \"./anthropic-types\"\n\nexport const parseSubagentMarkerFromFirstUser = (\n payload: AnthropicMessagesPayload,\n): SubagentMarker | null => {\n const firstUserMessage = payload.messages.find(\n (msg) => msg.role === \"user\" && Array.isArray(msg.content),\n )\n if (!firstUserMessage || !Array.isArray(firstUserMessage.content)) {\n return null\n }\n\n for (const block of firstUserMessage.content) {\n if (block.type !== \"text\") {\n continue\n }\n\n const marker = parseSubagentMarkerFromSystemReminder(block.text)\n if (marker) {\n return marker\n }\n }\n\n return null\n}\n\nconst parseSubagentMarkerFromSystemReminder = (\n text: string,\n): SubagentMarker | null => {\n const startTag = \"<system-reminder>\"\n const endTag = \"</system-reminder>\"\n let searchFrom = 0\n\n while (true) {\n const reminderStart = text.indexOf(startTag, searchFrom)\n if (reminderStart === -1) {\n break\n }\n\n const contentStart = reminderStart + startTag.length\n const reminderEnd = text.indexOf(endTag, contentStart)\n if (reminderEnd === -1) {\n break\n }\n\n const reminderContent = text.slice(contentStart, reminderEnd)\n const markerIndex = reminderContent.indexOf(subagentMarkerPrefix)\n if (markerIndex === -1) {\n searchFrom = reminderEnd + endTag.length\n continue\n }\n\n const markerJson = reminderContent\n .slice(markerIndex + subagentMarkerPrefix.length)\n .trim()\n\n try {\n const parsed = JSON.parse(markerJson) as SubagentMarker\n if (!parsed.session_id || !parsed.agent_id || !parsed.agent_type) {\n searchFrom = reminderEnd + endTag.length\n continue\n }\n\n return parsed\n } catch {\n searchFrom = reminderEnd + endTag.length\n continue\n }\n }\n\n return null\n}\n","import type { Context } from \"hono\"\n\nimport type { Model } from \"~/services/copilot/get-models\"\n\nimport { awaitApproval } from \"~/lib/approval\"\nimport { COMPACT_REQUEST } from \"~/lib/compact\"\nimport { getSmallModel, isMessagesApiEnabled } from \"~/lib/config\"\nimport { createHandlerLogger, debugJson } from \"~/lib/logger\"\nimport { findEndpointModel } from \"~/lib/models\"\nimport { checkRateLimit } from \"~/lib/rate-limit\"\nimport { state } from \"~/lib/state\"\nimport { generateRequestIdFromPayload, getRootSessionId } from \"~/lib/utils\"\n\nimport { type AnthropicMessagesPayload } from \"./anthropic-types\"\nimport {\n handleWithChatCompletions,\n handleWithMessagesApi,\n handleWithResponsesApi,\n} from \"./api-flows\"\nimport {\n getCompactType,\n mergeToolResultForClaude,\n sanitizeIdeTools,\n stripToolReferenceTurnBoundary,\n} from \"./preprocess\"\nimport { parseSubagentMarkerFromFirstUser } from \"./subagent-marker\"\n\nconst logger = createHandlerLogger(\"messages-handler\")\n\nexport async function handleCompletion(c: Context) {\n await checkRateLimit(state)\n\n const anthropicPayload = await c.req.json<AnthropicMessagesPayload>()\n debugJson(logger, \"Anthropic request payload:\", anthropicPayload)\n\n sanitizeIdeTools(anthropicPayload)\n\n const subagentMarker = parseSubagentMarkerFromFirstUser(anthropicPayload)\n if (subagentMarker) {\n debugJson(logger, \"Detected Subagent marker:\", subagentMarker)\n }\n\n const sessionId = getRootSessionId(anthropicPayload, c)\n logger.debug(\"Extracted session ID:\", sessionId)\n\n // claude code and opencode compact / auto-continue detection\n const compactType = getCompactType(anthropicPayload)\n\n // fix claude code 2.0.28+ warmup request consume premium request, forcing small model if no tools are used\n // set \"CLAUDE_CODE_SUBAGENT_MODEL\": \"you small model\" also can avoid this\n const anthropicBeta = c.req.header(\"anthropic-beta\")\n logger.debug(\"Anthropic Beta header:\", anthropicBeta)\n const noTools = !anthropicPayload.tools || anthropicPayload.tools.length === 0\n if (anthropicBeta && noTools && compactType === 0) {\n anthropicPayload.model = getSmallModel()\n }\n\n if (compactType) {\n logger.debug(\"Compact request type:\", compactType)\n }\n\n stripToolReferenceTurnBoundary(anthropicPayload)\n\n // Merge tool_result and text blocks into tool_result to avoid consuming premium requests\n // (caused by skill invocations, edit hooks, plan or to do reminders)\n // e.g. {\"role\":\"user\",\"content\":[{\"type\":\"tool_result\",\"content\":\"Launching skill: xxx\"},{\"type\":\"text\",\"text\":\"xxx\"}]}\n // not only for claude, but also for opencode\n // compact requests still run this processing, except for the final compact message itself\n mergeToolResultForClaude(anthropicPayload, {\n skipLastMessage: compactType === COMPACT_REQUEST,\n })\n\n const requestId = generateRequestIdFromPayload(anthropicPayload, sessionId)\n logger.debug(\"Generated request ID:\", requestId)\n\n if (state.manualApprove) {\n await awaitApproval()\n }\n\n const selectedModel = findEndpointModel(anthropicPayload.model)\n anthropicPayload.model = selectedModel?.id ?? anthropicPayload.model\n\n if (shouldUseMessagesApi(selectedModel)) {\n return await handleWithMessagesApi(c, anthropicPayload, {\n anthropicBetaHeader: anthropicBeta,\n subagentMarker,\n selectedModel,\n requestId,\n sessionId,\n compactType,\n logger,\n })\n }\n\n if (shouldUseResponsesApi(selectedModel)) {\n return await handleWithResponsesApi(c, anthropicPayload, {\n subagentMarker,\n selectedModel,\n requestId,\n sessionId,\n compactType,\n logger,\n })\n }\n\n return await handleWithChatCompletions(c, anthropicPayload, {\n subagentMarker,\n requestId,\n sessionId,\n compactType,\n logger,\n })\n}\n\nconst RESPONSES_ENDPOINT = \"/responses\"\nconst MESSAGES_ENDPOINT = \"/v1/messages\"\n\nconst shouldUseResponsesApi = (selectedModel: Model | undefined): boolean => {\n return (\n selectedModel?.supported_endpoints?.includes(RESPONSES_ENDPOINT) ?? false\n )\n}\n\nconst shouldUseMessagesApi = (selectedModel: Model | undefined): boolean => {\n const useMessagesApi = isMessagesApiEnabled()\n if (!useMessagesApi) {\n return false\n }\n return (\n selectedModel?.supported_endpoints?.includes(MESSAGES_ENDPOINT) ?? false\n )\n}\n","import { Hono } from \"hono\"\n\nimport { forwardError } from \"~/lib/error\"\n\nimport { handleCountTokens } from \"./count-tokens-handler\"\nimport { handleCompletion } from \"./handler\"\n\nexport const messageRoutes = new Hono()\n\nmessageRoutes.post(\"/\", async (c) => {\n try {\n return await handleCompletion(c)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n\nmessageRoutes.post(\"/count_tokens\", async (c) => {\n try {\n return await handleCountTokens(c)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n","import { Hono } from \"hono\"\n\nimport { forwardError } from \"~/lib/error\"\nimport { state } from \"~/lib/state\"\nimport { cacheModels } from \"~/lib/utils\"\n\nexport const modelRoutes = new Hono()\n\nmodelRoutes.get(\"/\", async (c) => {\n try {\n if (!state.models) {\n // This should be handled by startup logic, but as a fallback.\n await cacheModels()\n }\n\n const models = state.models?.data.map((model) => ({\n ...model,\n id: model.id,\n object: \"model\",\n type: \"model\",\n created: 0, // No date available from source\n created_at: new Date(0).toISOString(), // No date available from source\n owned_by: model.vendor,\n display_name: model.name,\n }))\n\n return c.json({\n object: \"list\",\n data: models,\n has_more: false,\n })\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n","import type { Context } from \"hono\"\n\nimport type { Model } from \"~/services/copilot/get-models\"\n\nimport { createHandlerLogger } from \"~/lib/logger\"\nimport { state } from \"~/lib/state\"\nimport { getTokenCount } from \"~/lib/tokenizer\"\nimport { type AnthropicMessagesPayload } from \"~/routes/messages/anthropic-types\"\nimport { translateToOpenAI } from \"~/routes/messages/non-stream-translation\"\n\nconst logger = createHandlerLogger(\"provider-count-tokens-handler\")\n\nconst createFallbackModel = (modelId: string): Model => ({\n capabilities: {\n family: \"provider\",\n limits: {},\n object: \"model_capabilities\",\n supports: {},\n tokenizer: \"o200k_base\",\n type: \"chat\",\n },\n id: modelId,\n model_picker_enabled: false,\n name: modelId,\n object: \"model\",\n preview: false,\n vendor: \"provider\",\n version: \"unknown\",\n})\n\nexport async function handleProviderCountTokens(c: Context): Promise<Response> {\n const provider = c.req.param(\"provider\")\n\n try {\n const anthropicPayload = await c.req.json<AnthropicMessagesPayload>()\n const openAIPayload = translateToOpenAI(anthropicPayload)\n const modelId = anthropicPayload.model.trim()\n\n let selectedModel = state.models?.data.find((model) => model.id === modelId)\n\n if (!selectedModel && modelId) {\n selectedModel = createFallbackModel(modelId)\n }\n\n if (!selectedModel) {\n logger.warn(\"provider.count_tokens.model_not_found\", {\n provider,\n model: anthropicPayload.model,\n })\n return c.json({\n input_tokens: 1,\n })\n }\n\n const tokenCount = await getTokenCount(openAIPayload, selectedModel)\n const finalTokenCount = tokenCount.input + tokenCount.output\n\n logger.debug(\"provider.count_tokens.success\", {\n provider,\n model: anthropicPayload.model,\n input_tokens: finalTokenCount,\n })\n\n return c.json({\n input_tokens: finalTokenCount,\n })\n } catch (error) {\n logger.error(\"provider.count_tokens.error\", {\n provider,\n error,\n })\n return c.json({\n input_tokens: 1,\n })\n }\n}\n","import type { ResolvedProviderConfig } from \"~/lib/config\"\nimport type { AnthropicMessagesPayload } from \"~/routes/messages/anthropic-types\"\n\nconst FORWARDABLE_HEADERS = [\n \"anthropic-version\",\n \"anthropic-beta\",\n \"accept\",\n \"user-agent\",\n] as const\n\nconst STRIPPED_RESPONSE_HEADERS = [\n \"connection\",\n \"content-encoding\",\n \"content-length\",\n \"keep-alive\",\n \"proxy-authenticate\",\n \"proxy-authorization\",\n \"te\",\n \"trailer\",\n \"transfer-encoding\",\n \"upgrade\",\n] as const\n\nexport function buildProviderUpstreamHeaders(\n providerConfig: ResolvedProviderConfig,\n requestHeaders: Headers,\n): Record<string, string> {\n const authHeaders: Record<string, string> = {}\n if (providerConfig.authType === \"authorization\") {\n authHeaders.authorization = `Bearer ${providerConfig.apiKey}`\n } else {\n authHeaders[\"x-api-key\"] = providerConfig.apiKey\n }\n\n const headers: Record<string, string> = {\n \"content-type\": \"application/json\",\n accept: \"application/json\",\n ...authHeaders,\n }\n\n for (const headerName of FORWARDABLE_HEADERS) {\n const headerValue = requestHeaders.get(headerName)\n if (headerValue) {\n headers[headerName] = headerValue\n }\n }\n\n return headers\n}\n\nexport function createProviderProxyResponse(\n upstreamResponse: Response,\n): Response {\n const headers = new Headers(upstreamResponse.headers)\n\n for (const headerName of STRIPPED_RESPONSE_HEADERS) {\n headers.delete(headerName)\n }\n\n return new Response(upstreamResponse.body, {\n headers,\n status: upstreamResponse.status,\n statusText: upstreamResponse.statusText,\n })\n}\n\nexport async function forwardProviderMessages(\n providerConfig: ResolvedProviderConfig,\n payload: AnthropicMessagesPayload,\n requestHeaders: Headers,\n): Promise<Response> {\n return await fetch(`${providerConfig.baseUrl}/v1/messages`, {\n method: \"POST\",\n headers: buildProviderUpstreamHeaders(providerConfig, requestHeaders),\n body: JSON.stringify(payload),\n })\n}\n\nexport async function forwardProviderModels(\n providerConfig: ResolvedProviderConfig,\n requestHeaders: Headers,\n): Promise<Response> {\n return await fetch(`${providerConfig.baseUrl}/v1/models`, {\n method: \"GET\",\n headers: buildProviderUpstreamHeaders(providerConfig, requestHeaders),\n })\n}\n","import type { Context } from \"hono\"\n\nimport { events } from \"fetch-event-stream\"\nimport { streamSSE } from \"hono/streaming\"\n\nimport type {\n AnthropicMessagesPayload,\n AnthropicResponse,\n AnthropicStreamEventData,\n} from \"~/routes/messages/anthropic-types\"\n\nimport { getProviderConfig, type ResolvedProviderConfig } from \"~/lib/config\"\nimport { HTTPError } from \"~/lib/error\"\nimport { createHandlerLogger, debugJson } from \"~/lib/logger\"\nimport { forwardProviderMessages } from \"~/services/providers/anthropic-proxy\"\n\nconst logger = createHandlerLogger(\"provider-messages-handler\")\n\nexport async function handleProviderMessages(c: Context): Promise<Response> {\n const provider = c.req.param(\"provider\")\n const providerConfig = getProviderConfig(provider)\n if (!providerConfig) {\n return c.json(\n {\n error: {\n message: `Provider '${provider}' not found or disabled`,\n type: \"invalid_request_error\",\n },\n },\n 404,\n )\n }\n\n try {\n const payload = await c.req.json<AnthropicMessagesPayload>()\n\n const modelConfig = providerConfig.models?.[payload.model]\n payload.temperature ??= modelConfig?.temperature\n payload.top_p ??= modelConfig?.topP\n payload.top_k ??= modelConfig?.topK\n\n debugJson(logger, \"provider.messages.request\", { payload, provider })\n\n const upstreamResponse = await forwardProviderMessages(\n providerConfig,\n payload,\n c.req.raw.headers,\n )\n\n if (!upstreamResponse.ok) {\n logger.error(\"Failed to create responses\", upstreamResponse)\n throw new HTTPError(\"Failed to create responses\", upstreamResponse)\n }\n\n const contentType = upstreamResponse.headers.get(\"content-type\") ?? \"\"\n const isStreamingResponse =\n Boolean(payload.stream) && contentType.includes(\"text/event-stream\")\n\n if (isStreamingResponse) {\n logger.debug(\"provider.messages.streaming\")\n return streamSSE(c, async (stream) => {\n for await (const chunk of events(upstreamResponse)) {\n logger.debug(\"provider.messages.raw_stream_event:\", chunk.data)\n const eventName = chunk.event\n if (eventName === \"ping\") {\n await stream.writeSSE({ event: \"ping\", data: '{\"type\":\"ping\"}' })\n continue\n }\n\n let data = chunk.data\n if (!data) {\n continue\n }\n\n if (chunk.data === \"[DONE]\") {\n break\n }\n\n try {\n const parsed = JSON.parse(data) as AnthropicStreamEventData\n if (parsed.type === \"message_start\") {\n adjustInputTokens(providerConfig, parsed.message.usage)\n } else if (parsed.type === \"message_delta\") {\n adjustInputTokens(providerConfig, parsed.usage)\n }\n data = JSON.stringify(parsed)\n } catch (error) {\n logger.error(\"provider.messages.streaming.adjust_tokens_error\", {\n error,\n originalData: data,\n })\n }\n await stream.writeSSE({\n event: eventName,\n data,\n })\n }\n })\n }\n\n const jsonBody = (await upstreamResponse.json()) as AnthropicResponse\n\n adjustInputTokens(providerConfig, jsonBody.usage)\n\n debugJson(logger, \"provider.messages.no_stream result:\", jsonBody)\n return c.json(jsonBody)\n } catch (error) {\n logger.error(\"provider.messages.error\", {\n provider,\n error,\n })\n throw error\n }\n}\n\nconst adjustInputTokens = (\n providerConfig: ResolvedProviderConfig,\n usage?: {\n input_tokens?: number\n cache_read_input_tokens?: number\n cache_creation_input_tokens?: number\n },\n): void => {\n if (!providerConfig.adjustInputTokens || !usage) {\n return\n }\n const adjustedInput = Math.max(\n 0,\n (usage.input_tokens ?? 0)\n - (usage.cache_read_input_tokens ?? 0)\n - (usage.cache_creation_input_tokens ?? 0),\n )\n usage.input_tokens = adjustedInput\n debugJson(logger, \"provider.messages.adjusted_usage:\", usage)\n}\n","import { Hono } from \"hono\"\n\nimport { forwardError } from \"~/lib/error\"\n\nimport { handleProviderCountTokens } from \"./count-tokens-handler\"\nimport { handleProviderMessages } from \"./handler\"\n\nexport const providerMessageRoutes = new Hono()\n\nproviderMessageRoutes.post(\"/\", async (c) => {\n try {\n return await handleProviderMessages(c)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n\nproviderMessageRoutes.post(\"/count_tokens\", async (c) => {\n try {\n return await handleProviderCountTokens(c)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n","import { Hono } from \"hono\"\n\nimport { getProviderConfig } from \"~/lib/config\"\nimport { forwardError } from \"~/lib/error\"\nimport { createHandlerLogger } from \"~/lib/logger\"\nimport {\n createProviderProxyResponse,\n forwardProviderModels,\n} from \"~/services/providers/anthropic-proxy\"\n\nconst logger = createHandlerLogger(\"provider-models-handler\")\n\nexport const providerModelRoutes = new Hono()\n\nproviderModelRoutes.get(\"/\", async (c) => {\n const provider = c.req.param(\"provider\") ?? \"\"\n\n try {\n const providerConfig = getProviderConfig(provider)\n if (!providerConfig) {\n return c.json(\n {\n error: {\n message: `Provider '${provider}' not found or disabled`,\n type: \"invalid_request_error\",\n },\n },\n 404,\n )\n }\n\n const upstreamResponse = await forwardProviderModels(\n providerConfig,\n c.req.raw.headers,\n )\n\n logger.debug(\"provider.models.response\", {\n provider,\n statusCode: upstreamResponse.status,\n })\n\n return createProviderProxyResponse(upstreamResponse)\n } catch (error) {\n logger.error(\"provider.models.error\", {\n provider,\n error,\n })\n return await forwardError(c, error)\n }\n})\n","/**\n * Stream ID Synchronization for @ai-sdk/openai compatibility\n *\n * Problem: GitHub Copilot's Responses API returns different IDs for the same\n * item in 'added' vs 'done' events. This breaks @ai-sdk/openai which expects\n * consistent IDs across the stream lifecycle.\n *\n * Errors without this fix:\n * - \"activeReasoningPart.summaryParts\" undefined\n * - \"text part not found\"\n *\n * Use case: OpenCode (AI coding assistant) using Codex models (gpt-5.2-codex)\n * via @ai-sdk/openai provider requires the Responses API endpoint.\n */\n\nimport type {\n ResponseOutputItemAddedEvent,\n ResponseOutputItemDoneEvent,\n ResponseStreamEvent,\n} from \"~/services/copilot/create-responses\"\n\ninterface StreamIdTracker {\n outputItems: Map<number, string>\n}\n\nexport const createStreamIdTracker = (): StreamIdTracker => ({\n outputItems: new Map(),\n})\n\nexport const fixStreamIds = (\n data: string,\n event: string | undefined,\n tracker: StreamIdTracker,\n): string => {\n if (!data) return data\n const parsed = JSON.parse(data) as ResponseStreamEvent\n switch (event) {\n case \"response.output_item.added\": {\n return handleOutputItemAdded(\n parsed as ResponseOutputItemAddedEvent,\n tracker,\n )\n }\n case \"response.output_item.done\": {\n return handleOutputItemDone(\n parsed as ResponseOutputItemDoneEvent,\n tracker,\n )\n }\n default: {\n return handleItemId(parsed, tracker)\n }\n }\n}\n\nconst handleOutputItemAdded = (\n parsed: ResponseOutputItemAddedEvent,\n tracker: StreamIdTracker,\n): string => {\n if (!parsed.item.id) {\n let randomSuffix = \"\"\n while (randomSuffix.length < 16) {\n randomSuffix += Math.random().toString(36).slice(2)\n }\n parsed.item.id = `oi_${parsed.output_index}_${randomSuffix.slice(0, 16)}`\n }\n\n const outputIndex = parsed.output_index\n tracker.outputItems.set(outputIndex, parsed.item.id)\n return JSON.stringify(parsed)\n}\n\nconst handleOutputItemDone = (\n parsed: ResponseOutputItemDoneEvent,\n tracker: StreamIdTracker,\n): string => {\n const outputIndex = parsed.output_index\n const originalId = tracker.outputItems.get(outputIndex)\n if (originalId) {\n parsed.item.id = originalId\n }\n return JSON.stringify(parsed)\n}\n\nconst handleItemId = (\n parsed: ResponseStreamEvent & { output_index?: number; item_id?: string },\n tracker: StreamIdTracker,\n): string => {\n const outputIndex = parsed.output_index\n if (outputIndex !== undefined) {\n const itemId = tracker.outputItems.get(outputIndex)\n if (itemId) {\n parsed.item_id = itemId\n }\n }\n return JSON.stringify(parsed)\n}\n","import type { Context } from \"hono\"\n\nimport { streamSSE } from \"hono/streaming\"\n\nimport { awaitApproval } from \"~/lib/approval\"\nimport { getConfig, isResponsesApiWebSearchEnabled } from \"~/lib/config\"\nimport { createHandlerLogger, debugJson, debugJsonTail } from \"~/lib/logger\"\nimport { checkRateLimit } from \"~/lib/rate-limit\"\nimport { state } from \"~/lib/state\"\nimport { generateRequestIdFromPayload, getUUID } from \"~/lib/utils\"\nimport {\n createResponses,\n type ResponsesPayload,\n type ResponsesResult,\n} from \"~/services/copilot/create-responses\"\n\nimport { createStreamIdTracker, fixStreamIds } from \"./stream-id-sync\"\nimport {\n applyResponsesApiContextManagement,\n compactInputByLatestCompaction,\n getResponsesRequestOptions,\n} from \"./utils\"\n\nconst logger = createHandlerLogger(\"responses-handler\")\n\nconst RESPONSES_ENDPOINT = \"/responses\"\n\nexport const handleResponses = async (c: Context) => {\n await checkRateLimit(state)\n\n const payload = await c.req.json<ResponsesPayload>()\n debugJson(logger, \"Responses request payload:\", payload)\n\n // not support subagent marker for now , set sessionId = getUUID(requestId)\n const requestId = generateRequestIdFromPayload({ messages: payload.input })\n logger.debug(\"Generated request ID:\", requestId)\n\n const sessionId = getUUID(requestId)\n logger.debug(\"Extracted session ID:\", sessionId)\n\n useFunctionApplyPatch(payload)\n\n removeUnsupportedTools(payload)\n\n if (!isResponsesApiWebSearchEnabled()) {\n removeWebSearchTool(payload)\n }\n\n compactInputByLatestCompaction(payload)\n\n const selectedModel = state.models?.data.find(\n (model) => model.id === payload.model,\n )\n const supportsResponses =\n selectedModel?.supported_endpoints?.includes(RESPONSES_ENDPOINT) ?? false\n\n if (!supportsResponses) {\n return c.json(\n {\n error: {\n message:\n \"This model does not support the responses endpoint. Please choose a different model.\",\n type: \"invalid_request_error\",\n },\n },\n 400,\n )\n }\n\n applyResponsesApiContextManagement(\n payload,\n selectedModel?.capabilities.limits.max_prompt_tokens,\n )\n\n debugJson(logger, \"Translated Responses payload:\", payload)\n\n const { vision, initiator } = getResponsesRequestOptions(payload)\n\n if (state.manualApprove) {\n await awaitApproval()\n }\n\n const response = await createResponses(payload, {\n vision,\n initiator,\n requestId,\n sessionId: sessionId,\n })\n\n if (isStreamingRequested(payload) && isAsyncIterable(response)) {\n logger.debug(\"Forwarding native Responses stream\")\n return streamSSE(c, async (stream) => {\n const idTracker = createStreamIdTracker()\n\n for await (const chunk of response) {\n debugJson(logger, \"Responses stream chunk:\", chunk)\n\n const processedData = fixStreamIds(\n (chunk as { data?: string }).data ?? \"\",\n (chunk as { event?: string }).event,\n idTracker,\n )\n\n await stream.writeSSE({\n id: (chunk as { id?: string }).id,\n event: (chunk as { event?: string }).event,\n data: processedData,\n })\n }\n })\n }\n\n debugJsonTail(logger, \"Forwarding native Responses result:\", {\n value: response,\n tailLength: 400,\n })\n return c.json(response as ResponsesResult)\n}\n\nconst isAsyncIterable = <T>(value: unknown): value is AsyncIterable<T> =>\n Boolean(value)\n && typeof (value as AsyncIterable<T>)[Symbol.asyncIterator] === \"function\"\n\nconst isStreamingRequested = (payload: ResponsesPayload): boolean =>\n Boolean(payload.stream)\n\nconst useFunctionApplyPatch = (payload: ResponsesPayload): void => {\n const config = getConfig()\n const useFunctionApplyPatch = config.useFunctionApplyPatch ?? true\n if (useFunctionApplyPatch) {\n logger.debug(\"Using function tool apply_patch for responses\")\n if (Array.isArray(payload.tools)) {\n const toolsArr = payload.tools\n for (let i = 0; i < toolsArr.length; i++) {\n const t = toolsArr[i]\n if (t.type === \"custom\" && t.name === \"apply_patch\") {\n toolsArr[i] = {\n type: \"function\",\n name: t.name,\n description: \"Use the `apply_patch` tool to edit files\",\n parameters: {\n type: \"object\",\n properties: {\n input: {\n type: \"string\",\n description: \"The entire contents of the apply_patch command\",\n },\n },\n required: [\"input\"],\n },\n strict: false,\n }\n }\n }\n }\n }\n}\n\nconst removeWebSearchTool = (payload: ResponsesPayload): void => {\n if (!Array.isArray(payload.tools) || payload.tools.length === 0) return\n\n payload.tools = payload.tools.filter((t) => {\n return t.type !== \"web_search\"\n })\n}\n\nconst COPILOT_UNSUPPORTED_TOOL_TYPES = new Set([\"image_generation\"])\n\nexport const removeUnsupportedTools = (payload: ResponsesPayload): void => {\n if (!Array.isArray(payload.tools) || payload.tools.length === 0) return\n\n const dropped: Array<string> = []\n payload.tools = payload.tools.filter((t) => {\n const type = t.type as string\n if (COPILOT_UNSUPPORTED_TOOL_TYPES.has(type)) {\n dropped.push(type)\n return false\n }\n return true\n })\n if (dropped.length > 0) {\n logger.debug(\"Removed unsupported tools:\", dropped)\n }\n}\n","import { Hono } from \"hono\"\n\nimport { forwardError } from \"~/lib/error\"\n\nimport { handleResponses } from \"./handler\"\n\nexport const responsesRoutes = new Hono()\n\nresponsesRoutes.post(\"/\", async (c) => {\n try {\n return await handleResponses(c)\n } catch (error) {\n return await forwardError(c, error)\n }\n})\n","import { Hono } from \"hono\"\n\nimport { state } from \"~/lib/state\"\n\nexport const tokenRoute = new Hono()\n\ntokenRoute.get(\"/\", (c) => {\n try {\n return c.json({\n token: state.copilotToken,\n })\n } catch (error) {\n console.error(\"Error fetching token:\", error)\n return c.json({ error: \"Failed to fetch token\", token: null }, 500)\n }\n})\n","import { Hono } from \"hono\"\n\nimport { getCopilotUsage } from \"~/services/github/get-copilot-usage\"\n\nexport const usageRoute = new Hono()\n\nusageRoute.get(\"/\", async (c) => {\n try {\n const usage = await getCopilotUsage()\n return c.json(usage)\n } catch (error) {\n console.error(\"Error fetching Copilot usage:\", error)\n return c.json({ error: \"Failed to fetch Copilot usage\" }, 500)\n }\n})\n","import { Hono } from \"hono\"\nimport { cors } from \"hono/cors\"\nimport { logger } from \"hono/logger\"\nimport { readFileSync } from \"node:fs\"\n\nimport { createAuthMiddleware } from \"./lib/request-auth\"\nimport { traceIdMiddleware } from \"./lib/trace\"\nimport { completionRoutes } from \"./routes/chat-completions/route\"\nimport { embeddingRoutes } from \"./routes/embeddings/route\"\nimport { messageRoutes } from \"./routes/messages/route\"\nimport { modelRoutes } from \"./routes/models/route\"\nimport { providerMessageRoutes } from \"./routes/provider/messages/route\"\nimport { providerModelRoutes } from \"./routes/provider/models/route\"\nimport { responsesRoutes } from \"./routes/responses/route\"\nimport { tokenRoute } from \"./routes/token/route\"\nimport { usageRoute } from \"./routes/usage/route\"\n\nexport const server = new Hono()\n\nserver.use(traceIdMiddleware)\nserver.use(logger())\nserver.use(cors())\nserver.use(\n \"*\",\n createAuthMiddleware({\n allowUnauthenticatedPaths: [\"/\", \"/usage-viewer\", \"/usage-viewer/\"],\n }),\n)\n\nserver.get(\"/\", (c) => c.text(\"Server running\"))\nserver.get(\"/usage-viewer\", (c) => {\n const usageViewerFileUrl = new URL(\"../pages/index.html\", import.meta.url)\n return c.html(readFileSync(usageViewerFileUrl, \"utf8\"))\n})\nserver.get(\"/usage-viewer/\", (c) => c.redirect(\"/usage-viewer\", 301))\n\nserver.route(\"/chat/completions\", completionRoutes)\nserver.route(\"/models\", modelRoutes)\nserver.route(\"/embeddings\", embeddingRoutes)\nserver.route(\"/usage\", usageRoute)\nserver.route(\"/token\", tokenRoute)\nserver.route(\"/responses\", responsesRoutes)\n\n// Compatibility with tools that expect v1/ prefix\nserver.route(\"/v1/chat/completions\", completionRoutes)\nserver.route(\"/v1/models\", modelRoutes)\nserver.route(\"/v1/embeddings\", embeddingRoutes)\nserver.route(\"/v1/responses\", responsesRoutes)\n\n// Anthropic compatible endpoints\nserver.route(\"/v1/messages\", messageRoutes)\n\n// Provider scoped Anthropic-compatible endpoints\nserver.route(\"/:provider/v1/messages\", providerMessageRoutes)\nserver.route(\"/:provider/v1/models\", providerModelRoutes)\n"],"x_google_ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,22,23,24,28,29,30],"mappings":";;;;;;;;;AACA,IAAI,WAAW,YAAY,SAAS,eAAe;AACjD,SAAQ,SAAS,SAAS;EACxB,IAAI,QAAQ;AACZ,SAAO,SAAS,EAAE;EAClB,eAAe,SAAS,GAAG;AACzB,OAAI,KAAK,MACP,OAAM,IAAI,MAAM,+BAA+B;AAEjD,WAAQ;GACR,IAAI;GACJ,IAAI,UAAU;GACd,IAAI;AACJ,OAAI,WAAW,IAAI;AACjB,cAAU,WAAW,GAAG,GAAG;AAC3B,YAAQ,IAAI,aAAa;SAEzB,WAAU,MAAM,WAAW,UAAU,QAAQ,KAAK;AAEpD,OAAI,QACF,KAAI;AACF,UAAM,MAAM,QAAQ,eAAe,SAAS,IAAI,EAAE,CAAC;YAC5C,KAAK;AACZ,QAAI,eAAe,SAAS,SAAS;AACnC,aAAQ,QAAQ;AAChB,WAAM,MAAM,QAAQ,KAAK,QAAQ;AACjC,eAAU;UAEV,OAAM;;YAIN,QAAQ,cAAc,SAAS,WACjC,OAAM,MAAM,WAAW,QAAQ;AAGnC,OAAI,QAAQ,QAAQ,cAAc,SAAS,SACzC,SAAQ,MAAM;AAEhB,UAAO;;;;;;;ACtCb,IAAI,mBAAmB,QAAQ;;;;ACC/B,IAAI,YAAY,OAAO,SAAS,UAA0B,uBAAO,OAAO,KAAK,KAAK;CAChF,MAAM,EAAE,MAAM,OAAO,MAAM,UAAU;CAErC,MAAM,eADU,mBAAmB,cAAc,QAAQ,IAAI,UAAU,QAAQ,SACnD,IAAI,eAAe;AAC/C,KAAI,aAAa,WAAW,sBAAsB,IAAI,aAAa,WAAW,oCAAoC,CAChH,QAAO,cAAc,SAAS;EAAE;EAAK;EAAK,CAAC;AAE7C,QAAO,EAAE;;AAEX,eAAe,cAAc,SAAS,SAAS;CAC7C,MAAM,WAAW,MAAM,QAAQ,UAAU;AACzC,KAAI,SACF,QAAO,0BAA0B,UAAU,QAAQ;AAErD,QAAO,EAAE;;AAEX,SAAS,0BAA0B,UAAU,SAAS;CACpD,MAAM,OAAuB,uBAAO,OAAO,KAAK;AAChD,UAAS,SAAS,OAAO,QAAQ;AAE/B,MAAI,EADyB,QAAQ,OAAO,IAAI,SAAS,KAAK,EAE5D,MAAK,OAAO;MAEZ,wBAAuB,MAAM,KAAK,MAAM;GAE1C;AACF,KAAI,QAAQ,IACV,QAAO,QAAQ,KAAK,CAAC,SAAS,CAAC,KAAK,WAAW;AAE7C,MAD6B,IAAI,SAAS,IAAI,EACpB;AACxB,6BAA0B,MAAM,KAAK,MAAM;AAC3C,UAAO,KAAK;;GAEd;AAEJ,QAAO;;AAET,IAAI,0BAA0B,MAAM,KAAK,UAAU;AACjD,KAAI,KAAK,SAAS,KAAK,EACrB,KAAI,MAAM,QAAQ,KAAK,KAAK,CAE1B,MAAK,KAAK,KAAK,MAAM;KAErB,MAAK,OAAO,CAAC,KAAK,MAAM,MAAM;UAG5B,CAAC,IAAI,SAAS,KAAK,CACrB,MAAK,OAAO;KAEZ,MAAK,OAAO,CAAC,MAAM;;AAIzB,IAAI,6BAA6B,MAAM,KAAK,UAAU;CACpD,IAAI,aAAa;CACjB,MAAM,OAAO,IAAI,MAAM,IAAI;AAC3B,MAAK,SAAS,MAAM,UAAU;AAC5B,MAAI,UAAU,KAAK,SAAS,EAC1B,YAAW,QAAQ;OACd;AACL,OAAI,CAAC,WAAW,SAAS,OAAO,WAAW,UAAU,YAAY,MAAM,QAAQ,WAAW,MAAM,IAAI,WAAW,iBAAiB,KAC9H,YAAW,QAAwB,uBAAO,OAAO,KAAK;AAExD,gBAAa,WAAW;;GAE1B;;;;;AClEJ,IAAI,aAAa,WAAS;CACxB,MAAM,QAAQA,OAAK,MAAM,IAAI;AAC7B,KAAI,MAAM,OAAO,GACf,OAAM,OAAO;AAEf,QAAO;;AAET,IAAI,oBAAoB,cAAc;CACpC,MAAM,EAAE,QAAQ,iBAAS,sBAAsB,UAAU;CACzD,MAAM,QAAQ,UAAUA,OAAK;AAC7B,QAAO,kBAAkB,OAAO,OAAO;;AAEzC,IAAI,yBAAyB,WAAS;CACpC,MAAM,SAAS,EAAE;AACjB,UAAOA,OAAK,QAAQ,eAAe,OAAO,UAAU;EAClD,MAAM,OAAO,IAAI;AACjB,SAAO,KAAK,CAAC,MAAM,MAAM,CAAC;AAC1B,SAAO;GACP;AACF,QAAO;EAAE;EAAQ;EAAM;;AAEzB,IAAI,qBAAqB,OAAO,WAAW;AACzC,MAAK,IAAI,IAAI,OAAO,SAAS,GAAG,KAAK,GAAG,KAAK;EAC3C,MAAM,CAAC,QAAQ,OAAO;AACtB,OAAK,IAAI,IAAI,MAAM,SAAS,GAAG,KAAK,GAAG,IACrC,KAAI,MAAM,GAAG,SAAS,KAAK,EAAE;AAC3B,SAAM,KAAK,MAAM,GAAG,QAAQ,MAAM,OAAO,GAAG,GAAG;AAC/C;;;AAIN,QAAO;;AAET,IAAI,eAAe,EAAE;AACrB,IAAI,cAAc,OAAO,SAAS;AAChC,KAAI,UAAU,IACZ,QAAO;CAET,MAAM,QAAQ,MAAM,MAAM,8BAA8B;AACxD,KAAI,OAAO;EACT,MAAM,WAAW,GAAG,MAAM,GAAG;AAC7B,MAAI,CAAC,aAAa,UAChB,KAAI,MAAM,GACR,cAAa,YAAY,QAAQ,KAAK,OAAO,OAAO,KAAK,OAAO,MAAM;GAAC;GAAU,MAAM;mBAAI,IAAI,OAAO,IAAI,MAAM,GAAG,MAAM,KAAK,GAAG;GAAC,GAAG;GAAC;GAAO,MAAM;mBAAI,IAAI,OAAO,IAAI,MAAM,GAAG,GAAG;GAAC;MAEnL,cAAa,YAAY;GAAC;GAAO,MAAM;GAAI;GAAK;AAGpD,SAAO,aAAa;;AAEtB,QAAO;;AAET,IAAI,aAAa,KAAK,YAAY;AAChC,KAAI;AACF,SAAO,QAAQ,IAAI;SACb;AACN,SAAO,IAAI,QAAQ,0BAA0B,UAAU;AACrD,OAAI;AACF,WAAO,QAAQ,MAAM;WACf;AACN,WAAO;;IAET;;;AAGN,IAAI,gBAAgB,QAAQ,UAAU,KAAK,UAAU;AACrD,IAAI,WAAW,YAAY;CACzB,MAAM,MAAM,QAAQ;CACpB,MAAM,QAAQ,IAAI,QAAQ,KAAK,IAAI,QAAQ,IAAI,GAAG,EAAE;CACpD,IAAI,IAAI;AACR,QAAO,IAAI,IAAI,QAAQ,KAAK;EAC1B,MAAM,WAAW,IAAI,WAAW,EAAE;AAClC,MAAI,aAAa,IAAI;GACnB,MAAM,aAAa,IAAI,QAAQ,KAAK,EAAE;GACtC,MAAMA,SAAO,IAAI,MAAM,OAAO,eAAe,KAAK,KAAK,IAAI,WAAW;AACtE,UAAO,aAAaA,OAAK,SAAS,MAAM,GAAGA,OAAK,QAAQ,QAAQ,QAAQ,GAAGA,OAAK;aACvE,aAAa,GACtB;;AAGJ,QAAO,IAAI,MAAM,OAAO,EAAE;;AAM5B,IAAI,mBAAmB,YAAY;CACjC,MAAM,SAAS,QAAQ,QAAQ;AAC/B,QAAO,OAAO,SAAS,KAAK,OAAO,GAAG,GAAG,KAAK,MAAM,OAAO,MAAM,GAAG,GAAG,GAAG;;AAE5E,IAAI,aAAa,MAAM,KAAK,GAAG,SAAS;AACtC,KAAI,KAAK,OACP,OAAM,UAAU,KAAK,GAAG,KAAK;AAE/B,QAAO,GAAG,OAAO,OAAO,MAAM,KAAK,MAAM,OAAO,QAAQ,MAAM,KAAK,GAAG,MAAM,GAAG,GAAG,KAAK,MAAM,KAAK,MAAM,MAAM,OAAO,MAAM,IAAI,MAAM,EAAE,GAAG;;AAE5I,IAAI,0BAA0B,WAAS;AACrC,KAAIA,OAAK,WAAWA,OAAK,SAAS,EAAE,KAAK,MAAM,CAACA,OAAK,SAAS,IAAI,CAChE,QAAO;CAET,MAAM,WAAWA,OAAK,MAAM,IAAI;CAChC,MAAM,UAAU,EAAE;CAClB,IAAI,WAAW;AACf,UAAS,SAAS,YAAY;AAC5B,MAAI,YAAY,MAAM,CAAC,KAAK,KAAK,QAAQ,CACvC,aAAY,MAAM;WACT,KAAK,KAAK,QAAQ,CAC3B,KAAI,KAAK,KAAK,QAAQ,EAAE;AACtB,OAAI,QAAQ,WAAW,KAAK,aAAa,GACvC,SAAQ,KAAK,IAAI;OAEjB,SAAQ,KAAK,SAAS;GAExB,MAAM,kBAAkB,QAAQ,QAAQ,KAAK,GAAG;AAChD,eAAY,MAAM;AAClB,WAAQ,KAAK,SAAS;QAEtB,aAAY,MAAM;GAGtB;AACF,QAAO,QAAQ,QAAQ,GAAG,GAAG,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE;;AAExD,IAAI,cAAc,UAAU;AAC1B,KAAI,CAAC,OAAO,KAAK,MAAM,CACrB,QAAO;AAET,KAAI,MAAM,QAAQ,IAAI,KAAK,GACzB,SAAQ,MAAM,QAAQ,OAAO,IAAI;AAEnC,QAAO,MAAM,QAAQ,IAAI,KAAK,KAAK,UAAU,OAAO,oBAAoB,GAAG;;AAE7E,IAAI,kBAAkB,KAAK,KAAK,aAAa;CAC3C,IAAI;AACJ,KAAI,CAAC,YAAY,OAAO,CAAC,OAAO,KAAK,IAAI,EAAE;EACzC,IAAI,YAAY,IAAI,QAAQ,IAAI,OAAO,EAAE;AACzC,MAAI,cAAc,GAChB,aAAY,IAAI,QAAQ,IAAI,OAAO,EAAE;AAEvC,SAAO,cAAc,IAAI;GACvB,MAAM,kBAAkB,IAAI,WAAW,YAAY,IAAI,SAAS,EAAE;AAClE,OAAI,oBAAoB,IAAI;IAC1B,MAAM,aAAa,YAAY,IAAI,SAAS;IAC5C,MAAM,WAAW,IAAI,QAAQ,KAAK,WAAW;AAC7C,WAAO,WAAW,IAAI,MAAM,YAAY,aAAa,KAAK,KAAK,IAAI,SAAS,CAAC;cACpE,mBAAmB,MAAM,MAAM,gBAAgB,CACxD,QAAO;AAET,eAAY,IAAI,QAAQ,IAAI,OAAO,YAAY,EAAE;;AAEnD,YAAU,OAAO,KAAK,IAAI;AAC1B,MAAI,CAAC,QACH;;CAGJ,MAAM,UAAU,EAAE;AAClB,aAAY,OAAO,KAAK,IAAI;CAC5B,IAAI,WAAW,IAAI,QAAQ,KAAK,EAAE;AAClC,QAAO,aAAa,IAAI;EACtB,MAAM,eAAe,IAAI,QAAQ,KAAK,WAAW,EAAE;EACnD,IAAI,aAAa,IAAI,QAAQ,KAAK,SAAS;AAC3C,MAAI,aAAa,gBAAgB,iBAAiB,GAChD,cAAa;EAEf,IAAI,OAAO,IAAI,MACb,WAAW,GACX,eAAe,KAAK,iBAAiB,KAAK,KAAK,IAAI,eAAe,WACnE;AACD,MAAI,QACF,QAAO,WAAW,KAAK;AAEzB,aAAW;AACX,MAAI,SAAS,GACX;EAEF,IAAI;AACJ,MAAI,eAAe,GACjB,SAAQ;OACH;AACL,WAAQ,IAAI,MAAM,aAAa,GAAG,iBAAiB,KAAK,KAAK,IAAI,aAAa;AAC9E,OAAI,QACF,SAAQ,WAAW,MAAM;;AAG7B,MAAI,UAAU;AACZ,OAAI,EAAE,QAAQ,SAAS,MAAM,QAAQ,QAAQ,MAAM,EACjD,SAAQ,QAAQ,EAAE;AAGpB,WAAQ,MAAM,KAAK,MAAM;QAEzB,SAAQ,UAAU;;AAGtB,QAAO,MAAM,QAAQ,OAAO;;AAE9B,IAAI,gBAAgB;AACpB,IAAI,kBAAkB,KAAK,QAAQ;AACjC,QAAO,eAAe,KAAK,KAAK,KAAK;;AAEvC,IAAI,sBAAsB;;;;ACrM1B,IAAI,yBAAyB,QAAQ,UAAU,KAAK,oBAAoB;AACxE,IAAI,cAAc,MAAM;CACtB;CACA;CACA;CACA,aAAa;CACb;CACA,YAAY,EAAE;CACd,YAAY,SAAS,SAAO,KAAK,cAAc,CAAC,EAAE,CAAC,EAAE;AACnD,OAAK,MAAM;AACX,OAAK,OAAOC;AACZ,QAAKC,cAAe;AACpB,QAAKC,gBAAiB,EAAE;;CAE1B,MAAM,KAAK;AACT,SAAO,MAAM,MAAKC,gBAAiB,IAAI,GAAG,MAAKC,qBAAsB;;CAEvE,iBAAiB,KAAK;EACpB,MAAM,WAAW,MAAKH,YAAa,GAAG,KAAK,YAAY,GAAG;EAC1D,MAAM,QAAQ,MAAKI,cAAe,SAAS;AAC3C,SAAO,SAAS,KAAK,KAAK,MAAM,GAAG,sBAAsB,MAAM,GAAG;;CAEpE,uBAAuB;EACrB,MAAM,UAAU,EAAE;EAClB,MAAM,OAAO,OAAO,KAAK,MAAKJ,YAAa,GAAG,KAAK,YAAY,GAAG;AAClE,OAAK,MAAM,OAAO,MAAM;GACtB,MAAM,QAAQ,MAAKI,cAAe,MAAKJ,YAAa,GAAG,KAAK,YAAY,GAAG,KAAK;AAChF,OAAI,UAAU,KAAK,EACjB,SAAQ,OAAO,KAAK,KAAK,MAAM,GAAG,sBAAsB,MAAM,GAAG;;AAGrE,SAAO;;CAET,eAAe,UAAU;AACvB,SAAO,MAAKA,YAAa,KAAK,MAAKA,YAAa,GAAG,YAAY;;CAEjE,MAAM,KAAK;AACT,SAAO,cAAc,KAAK,KAAK,IAAI;;CAErC,QAAQ,KAAK;AACX,SAAO,eAAe,KAAK,KAAK,IAAI;;CAEtC,OAAO,MAAM;AACX,MAAI,KACF,QAAO,KAAK,IAAI,QAAQ,IAAI,KAAK,IAAI,KAAK;EAE5C,MAAM,aAAa,EAAE;AACrB,OAAK,IAAI,QAAQ,SAAS,OAAO,QAAQ;AACvC,cAAW,OAAO;IAClB;AACF,SAAO;;CAET,MAAM,UAAU,SAAS;AACvB,SAAO,KAAK,UAAU,eAAe,MAAM,UAAU,MAAM,QAAQ;;CAErE,eAAe,QAAQ;EACrB,MAAM,EAAE,WAAW,eAAQ;EAC3B,MAAM,aAAa,UAAU;AAC7B,MAAI,WACF,QAAO;EAET,MAAM,eAAe,OAAO,KAAK,UAAU,CAAC;AAC5C,MAAI,aACF,QAAO,UAAU,cAAc,MAAM,SAAS;AAC5C,OAAI,iBAAiB,OACnB,QAAO,KAAK,UAAU,KAAK;AAE7B,UAAO,IAAI,SAAS,KAAK,CAAC,MAAM;IAChC;AAEJ,SAAO,UAAU,OAAOK,MAAI,MAAM;;CAEpC,OAAO;AACL,SAAO,MAAKC,WAAY,OAAO,CAAC,MAAM,SAAS,KAAK,MAAM,KAAK,CAAC;;CAElE,OAAO;AACL,SAAO,MAAKA,WAAY,OAAO;;CAEjC,cAAc;AACZ,SAAO,MAAKA,WAAY,cAAc;;CAExC,OAAO;AACL,SAAO,MAAKA,WAAY,OAAO;;CAEjC,WAAW;AACT,SAAO,MAAKA,WAAY,WAAW;;CAErC,iBAAiB,QAAQ,MAAM;AAC7B,QAAKL,cAAe,UAAU;;CAEhC,MAAM,QAAQ;AACZ,SAAO,MAAKA,cAAe;;CAE7B,IAAI,MAAM;AACR,SAAO,KAAK,IAAI;;CAElB,IAAI,SAAS;AACX,SAAO,KAAK,IAAI;;CAElB,KAAK,oBAAoB;AACvB,SAAO,MAAKD;;CAEd,IAAI,gBAAgB;AAClB,SAAO,MAAKA,YAAa,GAAG,KAAK,CAAC,GAAG,YAAY,MAAM;;CAEzD,IAAI,YAAY;AACd,SAAO,MAAKA,YAAa,GAAG,KAAK,CAAC,GAAG,YAAY,MAAM,CAAC,KAAK,YAAY;;;;;;AC7G7E,IAAI,2BAA2B;CAC7B,WAAW;CACX,cAAc;CACd,QAAQ;CACT;AACD,IAAI,OAAO,OAAO,cAAc;CAC9B,MAAM,gBAAgB,IAAI,OAAO,MAAM;AACvC,eAAc,YAAY;AAC1B,eAAc,YAAY;AAC1B,QAAO;;AA4ET,IAAI,kBAAkB,OAAO,KAAK,OAAO,mBAAmB,SAAS,WAAW;AAC9E,KAAI,OAAO,QAAQ,YAAY,EAAE,eAAe,SAAS;AACvD,MAAI,EAAE,eAAe,SACnB,OAAM,IAAI,UAAU;AAEtB,MAAI,eAAe,QACjB,OAAM,MAAM;;CAGhB,MAAM,YAAY,IAAI;AACtB,KAAI,CAAC,WAAW,OACd,QAAO,QAAQ,QAAQ,IAAI;AAE7B,KAAI,OACF,QAAO,MAAM;KAEb,UAAS,CAAC,IAAI;CAEhB,MAAM,SAAS,QAAQ,IAAI,UAAU,KAAK,MAAM,EAAE;EAAE;EAAO;EAAQ;EAAS,CAAC,CAAC,CAAC,CAAC,MAC7E,QAAQ,QAAQ,IACf,IAAI,OAAO,QAAQ,CAAC,KAAK,SAAS,gBAAgB,MAAM,OAAO,OAAO,SAAS,OAAO,CAAC,CACxF,CAAC,WAAW,OAAO,GAAG,CACxB;AACD,KAAI,kBACF,QAAO,IAAI,MAAM,QAAQ,UAAU;KAEnC,QAAO;;;;;AC7GX,IAAI,aAAa;AACjB,IAAI,yBAAyB,aAAa,YAAY;AACpD,QAAO;EACL,gBAAgB;EAChB,GAAG;EACJ;;AAEH,IAAI,UAAU,MAAM;CAClB;CACA;CACA,MAAM,EAAE;CACR;CACA,YAAY;CACZ;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA,YAAY,KAAK,SAAS;AACxB,QAAKO,aAAc;AACnB,MAAI,SAAS;AACX,SAAKC,eAAgB,QAAQ;AAC7B,QAAK,MAAM,QAAQ;AACnB,SAAKC,kBAAmB,QAAQ;AAChC,SAAKC,OAAQ,QAAQ;AACrB,SAAKC,cAAe,QAAQ;;;CAGhC,IAAI,MAAM;AACR,QAAKC,QAAS,IAAI,YAAY,MAAKL,YAAa,MAAKG,MAAO,MAAKC,YAAa;AAC9E,SAAO,MAAKC;;CAEd,IAAI,QAAQ;AACV,MAAI,MAAKJ,gBAAiB,iBAAiB,MAAKA,aAC9C,QAAO,MAAKA;MAEZ,OAAM,MAAM,iCAAiC;;CAGjD,IAAI,eAAe;AACjB,MAAI,MAAKA,aACP,QAAO,MAAKA;MAEZ,OAAM,MAAM,uCAAuC;;CAGvD,IAAI,MAAM;AACR,SAAO,MAAKK,QAAS,IAAI,SAAS,MAAM,EACtC,SAAS,MAAKC,oBAAqB,IAAI,SAAS,EACjD,CAAC;;CAEJ,IAAI,IAAI,MAAM;AACZ,MAAI,MAAKD,OAAQ,MAAM;AACrB,UAAO,IAAI,SAAS,KAAK,MAAM,KAAK;AACpC,QAAK,MAAM,CAAC,GAAG,MAAM,MAAKA,IAAK,QAAQ,SAAS,EAAE;AAChD,QAAI,MAAM,eACR;AAEF,QAAI,MAAM,cAAc;KACtB,MAAM,UAAU,MAAKA,IAAK,QAAQ,cAAc;AAChD,UAAK,QAAQ,OAAO,aAAa;AACjC,UAAK,MAAM,UAAU,QACnB,MAAK,QAAQ,OAAO,cAAc,OAAO;UAG3C,MAAK,QAAQ,IAAI,GAAG,EAAE;;;AAI5B,QAAKA,MAAO;AACZ,OAAK,YAAY;;CAEnB,UAAU,GAAG,SAAS;AACpB,QAAKE,cAAe,YAAY,KAAK,KAAK,QAAQ;AAClD,SAAO,MAAKA,SAAU,GAAG,KAAK;;CAEhC,aAAa,WAAW,MAAKC,SAAU;CACvC,kBAAkB,MAAKA;CACvB,eAAe,aAAa;AAC1B,QAAKD,WAAY;;CAEnB,UAAU,MAAM,OAAO,YAAY;AACjC,MAAI,KAAK,UACP,OAAKF,MAAO,IAAI,SAAS,MAAKA,IAAK,MAAM,MAAKA,IAAK;EAErD,MAAM,UAAU,MAAKA,MAAO,MAAKA,IAAK,UAAU,MAAKC,oBAAqB,IAAI,SAAS;AACvF,MAAI,UAAU,KAAK,EACjB,SAAQ,OAAO,KAAK;WACX,SAAS,OAClB,SAAQ,OAAO,MAAM,MAAM;MAE3B,SAAQ,IAAI,MAAM,MAAM;;CAG5B,UAAU,WAAW;AACnB,QAAKG,SAAU;;CAEjB,OAAO,KAAK,UAAU;AACpB,QAAKC,wBAAyB,IAAI,KAAK;AACvC,QAAKA,IAAK,IAAI,KAAK,MAAM;;CAE3B,OAAO,QAAQ;AACb,SAAO,MAAKA,MAAO,MAAKA,IAAK,IAAI,IAAI,GAAG,KAAK;;CAE/C,IAAI,MAAM;AACR,MAAI,CAAC,MAAKA,IACR,QAAO,EAAE;AAEX,SAAO,OAAO,YAAY,MAAKA,IAAK;;CAEtC,aAAa,MAAM,KAAK,SAAS;EAC/B,MAAM,kBAAkB,MAAKL,MAAO,IAAI,QAAQ,MAAKA,IAAK,QAAQ,GAAG,MAAKC,mBAAoB,IAAI,SAAS;AAC3G,MAAI,OAAO,QAAQ,YAAY,aAAa,KAAK;GAC/C,MAAM,aAAa,IAAI,mBAAmB,UAAU,IAAI,UAAU,IAAI,QAAQ,IAAI,QAAQ;AAC1F,QAAK,MAAM,CAAC,KAAK,UAAU,WACzB,KAAI,IAAI,aAAa,KAAK,aACxB,iBAAgB,OAAO,KAAK,MAAM;OAElC,iBAAgB,IAAI,KAAK,MAAM;;AAIrC,MAAI,QACF,MAAK,MAAM,CAAC,GAAG,MAAM,OAAO,QAAQ,QAAQ,CAC1C,KAAI,OAAO,MAAM,SACf,iBAAgB,IAAI,GAAG,EAAE;OACpB;AACL,mBAAgB,OAAO,EAAE;AACzB,QAAK,MAAM,MAAM,EACf,iBAAgB,OAAO,GAAG,GAAG;;EAKrC,MAAM,SAAS,OAAO,QAAQ,WAAW,MAAM,KAAK,UAAU,MAAKG;AACnE,SAAO,IAAI,SAAS,MAAM;GAAE;GAAQ,SAAS;GAAiB,CAAC;;CAEjE,eAAe,GAAG,SAAS,MAAKE,YAAa,GAAG,KAAK;CACrD,QAAQ,MAAM,KAAK,YAAY,MAAKA,YAAa,MAAM,KAAK,QAAQ;CACpE,QAAQ,MAAM,KAAK,YAAY;AAC7B,SAAO,CAAC,MAAKL,mBAAoB,CAAC,MAAKG,UAAW,CAAC,OAAO,CAAC,WAAW,CAAC,KAAK,YAAY,IAAI,SAAS,KAAK,GAAG,MAAKE,YAChH,MACA,KACA,sBAAsB,YAAY,QAAQ,CAC3C;;CAEH,QAAQ,QAAQ,KAAK,YAAY;AAC/B,SAAO,MAAKA,YACV,KAAK,UAAU,OAAO,EACtB,KACA,sBAAsB,oBAAoB,QAAQ,CACnD;;CAEH,QAAQ,MAAM,KAAK,YAAY;EAC7B,MAAM,OAAO,UAAU,MAAKA,YAAa,OAAO,KAAK,sBAAsB,4BAA4B,QAAQ,CAAC;AAChH,SAAO,OAAO,SAAS,WAAW,gBAAgB,MAAM,yBAAyB,WAAW,OAAO,EAAE,CAAC,CAAC,KAAK,IAAI,GAAG,IAAI,KAAK;;CAE9H,YAAY,UAAU,WAAW;EAC/B,MAAM,iBAAiB,OAAO,SAAS;AACvC,OAAK,OACH,YACA,CAAC,eAAe,KAAK,eAAe,GAAG,iBAAiB,UAAU,eAAe,CAClF;AACD,SAAO,KAAK,YAAY,MAAM,UAAU,IAAI;;CAE9C,iBAAiB;AACf,QAAKV,0BAA2B,IAAI,UAAU;AAC9C,SAAO,MAAKA,gBAAiB,KAAK;;;;;;AC9KtC,IAAI,kBAAkB;AACtB,IAAI,4BAA4B;AAChC,IAAI,UAAU;CAAC;CAAO;CAAQ;CAAO;CAAU;CAAW;CAAQ;AAClE,IAAI,mCAAmC;AACvC,IAAI,uBAAuB,cAAc,MAAM;;;;ACJ/C,IAAI,mBAAmB;;;;ACKvB,IAAI,mBAAmB,MAAM;AAC3B,QAAO,EAAE,KAAK,iBAAiB,IAAI;;AAErC,IAAI,gBAAgB,KAAK,MAAM;AAC7B,KAAI,iBAAiB,KAAK;EACxB,MAAM,MAAM,IAAI,aAAa;AAC7B,SAAO,EAAE,YAAY,IAAI,MAAM,IAAI;;AAErC,SAAQ,MAAM,IAAI;AAClB,QAAO,EAAE,KAAK,yBAAyB,IAAI;;AAE7C,IAAIW,SAAO,MAAM;CACf;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA,YAAY;CACZ,QAAQ;CACR,SAAS,EAAE;CACX,YAAY,UAAU,EAAE,EAAE;AAExB,EADmB,CAAC,GAAG,SAAS,0BAA0B,CAC/C,SAAS,WAAW;AAC7B,QAAK,WAAW,OAAO,GAAG,SAAS;AACjC,QAAI,OAAO,UAAU,SACnB,OAAKC,OAAQ;QAEb,OAAKC,SAAU,QAAQ,MAAKD,MAAO,MAAM;AAE3C,SAAK,SAAS,YAAY;AACxB,WAAKC,SAAU,QAAQ,MAAKD,MAAO,QAAQ;MAC3C;AACF,WAAO;;IAET;AACF,OAAK,MAAM,QAAQ,QAAM,GAAG,aAAa;AACvC,QAAK,MAAM,KAAK,CAACE,OAAK,CAAC,MAAM,EAAE;AAC7B,UAAKF,OAAQ;AACb,SAAK,MAAM,KAAK,CAAC,OAAO,CAAC,MAAM,CAC7B,UAAS,KAAK,YAAY;AACxB,WAAKC,SAAU,EAAE,aAAa,EAAE,MAAKD,MAAO,QAAQ;MACpD;;AAGN,UAAO;;AAET,OAAK,OAAO,MAAM,GAAG,aAAa;AAChC,OAAI,OAAO,SAAS,SAClB,OAAKA,OAAQ;QACR;AACL,UAAKA,OAAQ;AACb,aAAS,QAAQ,KAAK;;AAExB,YAAS,SAAS,YAAY;AAC5B,UAAKC,SAAU,iBAAiB,MAAKD,MAAO,QAAQ;KACpD;AACF,UAAO;;EAET,MAAM,EAAE,OAAQ,GAAG,yBAAyB;AAC5C,SAAO,OAAO,MAAM,qBAAqB;AACzC,OAAK,UAAU,UAAU,OAAO,QAAQ,WAAW,UAAU;;CAE/D,SAAS;EACP,MAAM,QAAQ,IAAID,OAAK;GACrB,QAAQ,KAAK;GACb,SAAS,KAAK;GACf,CAAC;AACF,QAAM,eAAe,KAAK;AAC1B,SAAMI,kBAAmB,MAAKA;AAC9B,QAAM,SAAS,KAAK;AACpB,SAAO;;CAET,mBAAmB;CACnB,eAAe;CACf,MAAM,QAAM,KAAK;EACf,MAAM,SAAS,KAAK,SAASD,OAAK;AAClC,MAAI,OAAO,KAAK,MAAM;GACpB,IAAI;AACJ,OAAI,IAAI,iBAAiB,aACvB,WAAU,EAAE;QACP;AACL,cAAU,OAAO,GAAG,UAAU,MAAM,QAAQ,EAAE,EAAE,IAAI,aAAa,CAAC,SAAS,EAAE,QAAQ,GAAG,KAAK,CAAC,EAAE;AAChG,YAAQ,oBAAoB,EAAE;;AAEhC,WAAOD,SAAU,EAAE,QAAQ,EAAE,MAAM,QAAQ;IAC3C;AACF,SAAO;;CAET,SAAS,QAAM;EACb,MAAM,SAAS,MAAKG,OAAQ;AAC5B,SAAO,YAAY,UAAU,KAAK,WAAWF,OAAK;AAClD,SAAO;;CAET,WAAW,YAAY;AACrB,OAAK,eAAe;AACpB,SAAO;;CAET,YAAY,YAAY;AACtB,QAAKC,kBAAmB;AACxB,SAAO;;CAET,MAAM,QAAM,oBAAoB,SAAS;EACvC,IAAI;EACJ,IAAI;AACJ,MAAI,QACF,KAAI,OAAO,YAAY,WACrB,iBAAgB;OACX;AACL,mBAAgB,QAAQ;AACxB,OAAI,QAAQ,mBAAmB,MAC7B,mBAAkB,YAAY;OAE9B,kBAAiB,QAAQ;;EAI/B,MAAM,aAAa,iBAAiB,MAAM;GACxC,MAAM,WAAW,cAAc,EAAE;AACjC,UAAO,MAAM,QAAQ,SAAS,GAAG,WAAW,CAAC,SAAS;OACnD,MAAM;GACT,IAAI,mBAAmB,KAAK;AAC5B,OAAI;AACF,uBAAmB,EAAE;WACf;AAER,UAAO,CAAC,EAAE,KAAK,iBAAiB;;AAElC,4BAA0B;GACxB,MAAM,aAAa,UAAU,KAAK,WAAWD,OAAK;GAClD,MAAM,mBAAmB,eAAe,MAAM,IAAI,WAAW;AAC7D,WAAQ,YAAY;IAClB,MAAM,MAAM,IAAI,IAAI,QAAQ,IAAI;AAChC,QAAI,WAAW,IAAI,SAAS,MAAM,iBAAiB,IAAI;AACvD,WAAO,IAAI,QAAQ,KAAK,QAAQ;;MAEhC;EACJ,MAAM,UAAU,OAAO,GAAG,SAAS;GACjC,MAAM,MAAM,MAAM,mBAAmB,eAAe,EAAE,IAAI,IAAI,EAAE,GAAG,WAAW,EAAE,CAAC;AACjF,OAAI,IACF,QAAO;AAET,SAAM,MAAM;;AAEd,QAAKD,SAAU,iBAAiB,UAAUC,QAAM,IAAI,EAAE,QAAQ;AAC9D,SAAO;;CAET,UAAU,QAAQ,QAAM,SAAS;AAC/B,WAAS,OAAO,aAAa;AAC7B,WAAO,UAAU,KAAK,WAAWA,OAAK;EACtC,MAAM,IAAI;GAAE,UAAU,KAAK;GAAW;GAAM;GAAQ;GAAS;AAC7D,OAAK,OAAO,IAAI,QAAQA,QAAM,CAAC,SAAS,EAAE,CAAC;AAC3C,OAAK,OAAO,KAAK,EAAE;;CAErB,aAAa,KAAK,GAAG;AACnB,MAAI,eAAe,MACjB,QAAO,KAAK,aAAa,KAAK,EAAE;AAElC,QAAM;;CAER,UAAU,SAAS,cAAc,KAAK,QAAQ;AAC5C,MAAI,WAAW,OACb,SAAQ,YAAY,IAAI,SAAS,MAAM,MAAM,MAAKG,SAAU,SAAS,cAAc,KAAK,MAAM,CAAC,GAAG;EAEpG,MAAMH,SAAO,KAAK,QAAQ,SAAS,EAAE,KAAK,CAAC;EAC3C,MAAM,cAAc,KAAK,OAAO,MAAM,QAAQA,OAAK;EACnD,MAAM,IAAI,IAAI,QAAQ,SAAS;GAC7B;GACA;GACA;GACA;GACA,iBAAiB,MAAKC;GACvB,CAAC;AACF,MAAI,YAAY,GAAG,WAAW,GAAG;GAC/B,IAAI;AACJ,OAAI;AACF,UAAM,YAAY,GAAG,GAAG,GAAG,GAAG,GAAG,YAAY;AAC3C,OAAE,MAAM,MAAM,MAAKA,gBAAiB,EAAE;MACtC;YACK,KAAK;AACZ,WAAO,MAAKG,YAAa,KAAK,EAAE;;AAElC,UAAO,eAAe,UAAU,IAAI,MACjC,aAAa,aAAa,EAAE,YAAY,EAAE,MAAM,MAAKH,gBAAiB,EAAE,EAC1E,CAAC,OAAO,QAAQ,MAAKG,YAAa,KAAK,EAAE,CAAC,GAAG,OAAO,MAAKH,gBAAiB,EAAE;;EAE/E,MAAM,WAAW,QAAQ,YAAY,IAAI,KAAK,cAAc,MAAKA,gBAAiB;AAClF,UAAQ,YAAY;AAClB,OAAI;IACF,MAAM,UAAU,MAAM,SAAS,EAAE;AACjC,QAAI,CAAC,QAAQ,UACX,OAAM,IAAI,MACR,0FACD;AAEH,WAAO,QAAQ;YACR,KAAK;AACZ,WAAO,MAAKG,YAAa,KAAK,EAAE;;MAEhC;;CAEN,SAAS,SAAS,GAAG,SAAS;AAC5B,SAAO,MAAKD,SAAU,SAAS,KAAK,IAAI,KAAK,IAAI,QAAQ,OAAO;;CAElE,WAAW,OAAO,aAAa,KAAK,iBAAiB;AACnD,MAAI,iBAAiB,QACnB,QAAO,KAAK,MAAM,cAAc,IAAI,QAAQ,OAAO,YAAY,GAAG,OAAO,KAAK,aAAa;AAE7F,UAAQ,MAAM,UAAU;AACxB,SAAO,KAAK,MACV,IAAI,QACF,eAAe,KAAK,MAAM,GAAG,QAAQ,mBAAmB,UAAU,KAAK,MAAM,IAC7E,YACD,EACD,KACA,aACD;;CAEH,aAAa;AACX,mBAAiB,UAAU,UAAU;AACnC,SAAM,YAAY,MAAKA,SAAU,MAAM,SAAS,OAAO,KAAK,GAAG,MAAM,QAAQ,OAAO,CAAC;IACrF;;;;;;ACvON,IAAI,oBAAoB;AACxB,IAAI,4BAA4B;AAChC,IAAI,4BAA4B;AAChC,IAAI,aAAa,QAAQ;AACzB,IAAI,kCAAkB,IAAI,IAAI,cAAc;AAC5C,SAAS,WAAW,GAAG,GAAG;AACxB,KAAI,EAAE,WAAW,EACf,QAAO,EAAE,WAAW,IAAI,IAAI,IAAI,KAAK,IAAI;AAE3C,KAAI,EAAE,WAAW,EACf,QAAO;AAET,KAAI,MAAM,6BAA6B,MAAM,0BAC3C,QAAO;UACE,MAAM,6BAA6B,MAAM,0BAClD,QAAO;AAET,KAAI,MAAM,kBACR,QAAO;UACE,MAAM,kBACf,QAAO;AAET,QAAO,EAAE,WAAW,EAAE,SAAS,IAAI,IAAI,KAAK,IAAI,EAAE,SAAS,EAAE;;AAE/D,IAAIE,SAAO,MAAM;CACf;CACA;CACA,YAA4B,uBAAO,OAAO,KAAK;CAC/C,OAAO,QAAQ,OAAO,UAAU,SAAS,oBAAoB;AAC3D,MAAI,OAAO,WAAW,GAAG;AACvB,OAAI,MAAKC,UAAW,KAAK,EACvB,OAAM;AAER,OAAI,mBACF;AAEF,SAAKA,QAAS;AACd;;EAEF,MAAM,CAAC,OAAO,GAAG,cAAc;EAC/B,MAAM,UAAU,UAAU,MAAM,WAAW,WAAW,IAAI;GAAC;GAAI;GAAI;GAA0B,GAAG;GAAC;GAAI;GAAI;GAAkB,GAAG,UAAU,OAAO;GAAC;GAAI;GAAI;GAA0B,GAAG,MAAM,MAAM,8BAA8B;EAC/N,IAAI;AACJ,MAAI,SAAS;GACX,MAAM,OAAO,QAAQ;GACrB,IAAI,YAAY,QAAQ,MAAM;AAC9B,OAAI,QAAQ,QAAQ,IAAI;AACtB,QAAI,cAAc,KAChB,OAAM;AAER,gBAAY,UAAU,QAAQ,0BAA0B,MAAM;AAC9D,QAAI,YAAY,KAAK,UAAU,CAC7B,OAAM;;AAGV,UAAO,MAAKC,SAAU;AACtB,OAAI,CAAC,MAAM;AACT,QAAI,OAAO,KAAK,MAAKA,SAAU,CAAC,MAC7B,MAAM,MAAM,6BAA6B,MAAM,0BACjD,CACC,OAAM;AAER,QAAI,mBACF;AAEF,WAAO,MAAKA,SAAU,aAAa,IAAIF,QAAM;AAC7C,QAAI,SAAS,GACX,OAAKG,WAAY,QAAQ;;AAG7B,OAAI,CAAC,sBAAsB,SAAS,GAClC,UAAS,KAAK,CAAC,MAAM,MAAKA,SAAU,CAAC;SAElC;AACL,UAAO,MAAKD,SAAU;AACtB,OAAI,CAAC,MAAM;AACT,QAAI,OAAO,KAAK,MAAKA,SAAU,CAAC,MAC7B,MAAM,EAAE,SAAS,KAAK,MAAM,6BAA6B,MAAM,0BACjE,CACC,OAAM;AAER,QAAI,mBACF;AAEF,WAAO,MAAKA,SAAU,SAAS,IAAIF,QAAM;;;AAG7C,OAAK,OAAO,YAAY,OAAO,UAAU,SAAS,mBAAmB;;CAEvE,iBAAiB;EAEf,MAAM,UADY,OAAO,KAAK,MAAKE,SAAU,CAAC,KAAK,WAAW,CACpC,KAAK,MAAM;GACnC,MAAM,IAAI,MAAKA,SAAU;AACzB,WAAQ,OAAO,GAAEC,aAAc,WAAW,IAAI,EAAE,IAAI,GAAEA,aAAc,gBAAgB,IAAI,EAAE,GAAG,KAAK,MAAM,KAAK,EAAE,gBAAgB;IAC/H;AACF,MAAI,OAAO,MAAKF,UAAW,SACzB,SAAQ,QAAQ,IAAI,MAAKA,QAAS;AAEpC,MAAI,QAAQ,WAAW,EACrB,QAAO;AAET,MAAI,QAAQ,WAAW,EACrB,QAAO,QAAQ;AAEjB,SAAO,QAAQ,QAAQ,KAAK,IAAI,GAAG;;;;;;ACtGvC,IAAI,OAAO,MAAM;CACf,WAAW,EAAE,UAAU,GAAG;CAC1B,QAAQ,IAAIG,QAAM;CAClB,OAAO,QAAM,OAAO,oBAAoB;EACtC,MAAM,aAAa,EAAE;EACrB,MAAM,SAAS,EAAE;AACjB,OAAK,IAAI,IAAI,KAAO;GAClB,IAAI,WAAW;AACf,YAAOC,OAAK,QAAQ,eAAe,MAAM;IACvC,MAAM,OAAO,MAAM;AACnB,WAAO,KAAK,CAAC,MAAM,EAAE;AACrB;AACA,eAAW;AACX,WAAO;KACP;AACF,OAAI,CAAC,SACH;;EAGJ,MAAM,SAASA,OAAK,MAAM,2BAA2B,IAAI,EAAE;AAC3D,OAAK,IAAI,IAAI,OAAO,SAAS,GAAG,KAAK,GAAG,KAAK;GAC3C,MAAM,CAAC,QAAQ,OAAO;AACtB,QAAK,IAAI,IAAI,OAAO,SAAS,GAAG,KAAK,GAAG,IACtC,KAAI,OAAO,GAAG,QAAQ,KAAK,KAAK,IAAI;AAClC,WAAO,KAAK,OAAO,GAAG,QAAQ,MAAM,OAAO,GAAG,GAAG;AACjD;;;AAIN,QAAKC,KAAM,OAAO,QAAQ,OAAO,YAAY,MAAKC,SAAU,mBAAmB;AAC/E,SAAO;;CAET,cAAc;EACZ,IAAI,SAAS,MAAKD,KAAM,gBAAgB;AACxC,MAAI,WAAW,GACb,QAAO;GAAC;GAAM,EAAE;GAAE,EAAE;GAAC;EAEvB,IAAI,eAAe;EACnB,MAAM,sBAAsB,EAAE;EAC9B,MAAM,sBAAsB,EAAE;AAC9B,WAAS,OAAO,QAAQ,0BAA0B,GAAG,cAAc,eAAe;AAChF,OAAI,iBAAiB,KAAK,GAAG;AAC3B,wBAAoB,EAAE,gBAAgB,OAAO,aAAa;AAC1D,WAAO;;AAET,OAAI,eAAe,KAAK,GAAG;AACzB,wBAAoB,OAAO,WAAW,IAAI,EAAE;AAC5C,WAAO;;AAET,UAAO;IACP;AACF,SAAO;mBAAC,IAAI,OAAO,IAAI,SAAS;GAAE;GAAqB;GAAoB;;;;;;AC5C/E,IAAI,aAAa,EAAE;AACnB,IAAI,cAAc;CAAC;CAAM,EAAE;CAAkB,uBAAO,OAAO,KAAK;CAAC;AACjE,IAAI,sBAAsC,uBAAO,OAAO,KAAK;AAC7D,SAAS,oBAAoB,QAAM;AACjC,QAAO,oBAAoBE,4BAAU,IAAI,OACvCA,WAAS,MAAM,KAAK,IAAIA,OAAK,QAC3B,4BACC,GAAG,aAAa,WAAW,KAAK,aAAa,WAC/C,CAAC,GACH;;AAEH,SAAS,2BAA2B;AAClC,uBAAsC,uBAAO,OAAO,KAAK;;AAE3D,SAAS,mCAAmC,QAAQ;CAClD,MAAM,OAAO,IAAI,MAAM;CACvB,MAAM,cAAc,EAAE;AACtB,KAAI,OAAO,WAAW,EACpB,QAAO;CAET,MAAM,2BAA2B,OAAO,KACrC,UAAU,CAAC,CAAC,SAAS,KAAK,MAAM,GAAG,EAAE,GAAG,MAAM,CAChD,CAAC,MACC,CAAC,WAAW,QAAQ,CAAC,WAAW,WAAW,YAAY,IAAI,YAAY,KAAK,MAAM,SAAS,MAAM,OACnG;CACD,MAAM,YAA4B,uBAAO,OAAO,KAAK;AACrD,MAAK,IAAI,IAAI,GAAG,IAAI,IAAI,MAAM,yBAAyB,QAAQ,IAAI,KAAK,KAAK;EAC3E,MAAM,CAAC,oBAAoBA,QAAM,YAAY,yBAAyB;AACtE,MAAI,mBACF,WAAUA,UAAQ,CAAC,SAAS,KAAK,CAAC,OAAO,CAAC,GAAmB,uBAAO,OAAO,KAAK,CAAC,CAAC,EAAE,WAAW;MAE/F;EAEF,IAAI;AACJ,MAAI;AACF,gBAAa,KAAK,OAAOA,QAAM,GAAG,mBAAmB;WAC9C,GAAG;AACV,SAAM,MAAM,aAAa,IAAI,qBAAqBA,OAAK,GAAG;;AAE5D,MAAI,mBACF;AAEF,cAAY,KAAK,SAAS,KAAK,CAAC,GAAG,gBAAgB;GACjD,MAAM,gBAAgC,uBAAO,OAAO,KAAK;AACzD,iBAAc;AACd,UAAO,cAAc,GAAG,cAAc;IACpC,MAAM,CAAC,KAAK,SAAS,WAAW;AAChC,kBAAc,OAAO;;AAEvB,UAAO,CAAC,GAAG,cAAc;IACzB;;CAEJ,MAAM,CAAC,QAAQ,qBAAqB,uBAAuB,KAAK,aAAa;AAC7E,MAAK,IAAI,IAAI,GAAG,MAAM,YAAY,QAAQ,IAAI,KAAK,IACjD,MAAK,IAAI,IAAI,GAAG,OAAO,YAAY,GAAG,QAAQ,IAAI,MAAM,KAAK;EAC3D,MAAM,MAAM,YAAY,GAAG,KAAK;AAChC,MAAI,CAAC,IACH;EAEF,MAAM,OAAO,OAAO,KAAK,IAAI;AAC7B,OAAK,IAAI,IAAI,GAAG,OAAO,KAAK,QAAQ,IAAI,MAAM,IAC5C,KAAI,KAAK,MAAM,oBAAoB,IAAI,KAAK;;CAIlD,MAAM,aAAa,EAAE;AACrB,MAAK,MAAM,KAAK,oBACd,YAAW,KAAK,YAAY,oBAAoB;AAElD,QAAO;EAAC;EAAQ;EAAY;EAAU;;AAExC,SAAS,eAAe,YAAY,QAAM;AACxC,KAAI,CAAC,WACH;AAEF,MAAK,MAAM,KAAK,OAAO,KAAK,WAAW,CAAC,MAAM,GAAG,MAAM,EAAE,SAAS,EAAE,OAAO,CACzE,KAAI,oBAAoB,EAAE,CAAC,KAAKA,OAAK,CACnC,QAAO,CAAC,GAAG,WAAW,GAAG;;AAK/B,IAAI,eAAe,MAAM;CACvB,OAAO;CACP;CACA;CACA,cAAc;AACZ,QAAKC,aAAc,GAAG,kBAAkC,uBAAO,OAAO,KAAK,EAAE;AAC7E,QAAKC,SAAU,GAAG,kBAAkC,uBAAO,OAAO,KAAK,EAAE;;CAE3E,IAAI,QAAQ,QAAM,SAAS;EACzB,MAAM,aAAa,MAAKD;EACxB,MAAM,SAAS,MAAKC;AACpB,MAAI,CAAC,cAAc,CAAC,OAClB,OAAM,IAAI,MAAM,iCAAiC;AAEnD,MAAI,CAAC,WAAW,QAEd,EAAC,YAAY,OAAO,CAAC,SAAS,eAAe;AAC3C,cAAW,UAA0B,uBAAO,OAAO,KAAK;AACxD,UAAO,KAAK,WAAW,iBAAiB,CAAC,SAAS,MAAM;AACtD,eAAW,QAAQ,KAAK,CAAC,GAAG,WAAW,iBAAiB,GAAG;KAC3D;IACF;AAEJ,MAAIF,WAAS,KACX,UAAO;EAET,MAAM,cAAcA,OAAK,MAAM,OAAO,IAAI,EAAE,EAAE;AAC9C,MAAI,MAAM,KAAKA,OAAK,EAAE;GACpB,MAAM,KAAK,oBAAoBA,OAAK;AACpC,OAAI,WAAW,gBACb,QAAO,KAAK,WAAW,CAAC,SAAS,MAAM;AACrC,eAAW,GAAGA,YAAU,eAAe,WAAW,IAAIA,OAAK,IAAI,eAAe,WAAW,kBAAkBA,OAAK,IAAI,EAAE;KACtH;OAEF,YAAW,QAAQA,YAAU,eAAe,WAAW,SAASA,OAAK,IAAI,eAAe,WAAW,kBAAkBA,OAAK,IAAI,EAAE;AAElI,UAAO,KAAK,WAAW,CAAC,SAAS,MAAM;AACrC,QAAI,WAAW,mBAAmB,WAAW,EAC3C,QAAO,KAAK,WAAW,GAAG,CAAC,SAAS,MAAM;AACxC,QAAG,KAAK,EAAE,IAAI,WAAW,GAAG,GAAG,KAAK,CAAC,SAAS,WAAW,CAAC;MAC1D;KAEJ;AACF,UAAO,KAAK,OAAO,CAAC,SAAS,MAAM;AACjC,QAAI,WAAW,mBAAmB,WAAW,EAC3C,QAAO,KAAK,OAAO,GAAG,CAAC,SACpB,MAAM,GAAG,KAAK,EAAE,IAAI,OAAO,GAAG,GAAG,KAAK,CAAC,SAAS,WAAW,CAAC,CAC9D;KAEH;AACF;;EAEF,MAAM,QAAQ,uBAAuBA,OAAK,IAAI,CAACA,OAAK;AACpD,OAAK,IAAI,IAAI,GAAG,MAAM,MAAM,QAAQ,IAAI,KAAK,KAAK;GAChD,MAAM,QAAQ,MAAM;AACpB,UAAO,KAAK,OAAO,CAAC,SAAS,MAAM;AACjC,QAAI,WAAW,mBAAmB,WAAW,GAAG;AAC9C,YAAO,GAAG,WAAW,CACnB,GAAG,eAAe,WAAW,IAAI,MAAM,IAAI,eAAe,WAAW,kBAAkB,MAAM,IAAI,EAAE,CACpG;AACD,YAAO,GAAG,OAAO,KAAK,CAAC,SAAS,aAAa,MAAM,IAAI,EAAE,CAAC;;KAE5D;;;CAGN,MAAM,QAAQ,QAAM;AAClB,4BAA0B;EAC1B,MAAM,WAAW,MAAKG,kBAAmB;AACzC,OAAK,SAAS,SAAS,UAAU;GAC/B,MAAM,UAAU,SAAS,YAAY,SAAS;GAC9C,MAAM,cAAc,QAAQ,GAAG;AAC/B,OAAI,YACF,QAAO;GAET,MAAM,QAAQ,MAAM,MAAM,QAAQ,GAAG;AACrC,OAAI,CAAC,MACH,QAAO,CAAC,EAAE,EAAE,WAAW;GAEzB,MAAM,QAAQ,MAAM,QAAQ,IAAI,EAAE;AAClC,UAAO,CAAC,QAAQ,GAAG,QAAQ,MAAM;;AAEnC,SAAO,KAAK,MAAM,QAAQH,OAAK;;CAEjC,oBAAoB;EAClB,MAAM,WAA2B,uBAAO,OAAO,KAAK;AACpD,SAAO,KAAK,MAAKE,OAAQ,CAAC,OAAO,OAAO,KAAK,MAAKD,WAAY,CAAC,CAAC,SAAS,WAAW;AAClF,YAAS,YAAY,MAAKG,aAAc,OAAO;IAC/C;AACF,QAAKH,aAAc,MAAKC,SAAU,KAAK;AACvC,SAAO;;CAET,cAAc,QAAQ;EACpB,MAAM,SAAS,EAAE;EACjB,IAAI,cAAc,WAAW;AAC7B,GAAC,MAAKD,YAAa,MAAKC,OAAQ,CAAC,SAAS,MAAM;GAC9C,MAAM,WAAW,EAAE,UAAU,OAAO,KAAK,EAAE,QAAQ,CAAC,KAAK,WAAS,CAACF,QAAM,EAAE,QAAQA,QAAM,CAAC,GAAG,EAAE;AAC/F,OAAI,SAAS,WAAW,GAAG;AACzB,oBAAgB;AAChB,WAAO,KAAK,GAAG,SAAS;cACf,WAAW,gBACpB,QAAO,KACL,GAAG,OAAO,KAAK,EAAE,iBAAiB,CAAC,KAAK,WAAS,CAACA,QAAM,EAAE,iBAAiBA,QAAM,CAAC,CACnF;IAEH;AACF,MAAI,CAAC,YACH,QAAO;MAEP,QAAO,mCAAmC,OAAO;;;;;;ACrMvD,IAAI,cAAc,MAAM;CACtB,OAAO;CACP,WAAW,EAAE;CACb,UAAU,EAAE;CACZ,YAAY,MAAM;AAChB,QAAKK,UAAW,KAAK;;CAEvB,IAAI,QAAQ,QAAM,SAAS;AACzB,MAAI,CAAC,MAAKC,OACR,OAAM,IAAI,MAAM,iCAAiC;AAEnD,QAAKA,OAAQ,KAAK;GAAC;GAAQC;GAAM;GAAQ,CAAC;;CAE5C,MAAM,QAAQ,QAAM;AAClB,MAAI,CAAC,MAAKD,OACR,OAAM,IAAI,MAAM,cAAc;EAEhC,MAAM,UAAU,MAAKD;EACrB,MAAM,SAAS,MAAKC;EACpB,MAAM,MAAM,QAAQ;EACpB,IAAI,IAAI;EACR,IAAI;AACJ,SAAO,IAAI,KAAK,KAAK;GACnB,MAAM,SAAS,QAAQ;AACvB,OAAI;AACF,SAAK,IAAI,KAAK,GAAG,OAAO,OAAO,QAAQ,KAAK,MAAM,KAChD,QAAO,IAAI,GAAG,OAAO,IAAI;AAE3B,UAAM,OAAO,MAAM,QAAQC,OAAK;YACzB,GAAG;AACV,QAAI,aAAa,qBACf;AAEF,UAAM;;AAER,QAAK,QAAQ,OAAO,MAAM,KAAK,OAAO;AACtC,SAAKF,UAAW,CAAC,OAAO;AACxB,SAAKC,SAAU,KAAK;AACpB;;AAEF,MAAI,MAAM,IACR,OAAM,IAAI,MAAM,cAAc;AAEhC,OAAK,OAAO,iBAAiB,KAAK,aAAa;AAC/C,SAAO;;CAET,IAAI,eAAe;AACjB,MAAI,MAAKA,UAAW,MAAKD,QAAS,WAAW,EAC3C,OAAM,IAAI,MAAM,4CAA4C;AAE9D,SAAO,MAAKA,QAAS;;;;;;ACjDzB,IAAI,cAA8B,uBAAO,OAAO,KAAK;AACrD,IAAI,OAAO,MAAM;CACf;CACA;CACA;CACA,SAAS;CACT,UAAU;CACV,YAAY,QAAQ,SAAS,UAAU;AACrC,QAAKG,WAAY,YAA4B,uBAAO,OAAO,KAAK;AAChE,QAAKC,UAAW,EAAE;AAClB,MAAI,UAAU,SAAS;GACrB,MAAM,IAAoB,uBAAO,OAAO,KAAK;AAC7C,KAAE,UAAU;IAAE;IAAS,cAAc,EAAE;IAAE,OAAO;IAAG;AACnD,SAAKA,UAAW,CAAC,EAAE;;AAErB,QAAKC,WAAY,EAAE;;CAErB,OAAO,QAAQ,QAAM,SAAS;AAC5B,QAAKC,QAAS,EAAE,MAAKA;EACrB,IAAI,UAAU;EACd,MAAM,QAAQ,iBAAiBC,OAAK;EACpC,MAAM,eAAe,EAAE;AACvB,OAAK,IAAI,IAAI,GAAG,MAAM,MAAM,QAAQ,IAAI,KAAK,KAAK;GAChD,MAAM,IAAI,MAAM;GAChB,MAAM,QAAQ,MAAM,IAAI;GACxB,MAAM,UAAU,WAAW,GAAG,MAAM;GACpC,MAAM,MAAM,MAAM,QAAQ,QAAQ,GAAG,QAAQ,KAAK;AAClD,OAAI,OAAO,SAAQJ,UAAW;AAC5B,cAAU,SAAQA,SAAU;AAC5B,QAAI,QACF,cAAa,KAAK,QAAQ,GAAG;AAE/B;;AAEF,YAAQA,SAAU,OAAO,IAAI,MAAM;AACnC,OAAI,SAAS;AACX,aAAQE,SAAU,KAAK,QAAQ;AAC/B,iBAAa,KAAK,QAAQ,GAAG;;AAE/B,aAAU,SAAQF,SAAU;;AAE9B,WAAQC,QAAS,KAAK,GACnB,SAAS;GACR;GACA,cAAc,aAAa,QAAQ,GAAG,GAAG,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE;GAClE,OAAO,MAAKE;GACb,EACF,CAAC;AACF,SAAO;;CAET,gBAAgB,MAAM,QAAQ,YAAY,QAAQ;EAChD,MAAM,cAAc,EAAE;AACtB,OAAK,IAAI,IAAI,GAAG,MAAM,MAAKF,QAAS,QAAQ,IAAI,KAAK,KAAK;GACxD,MAAM,IAAI,MAAKA,QAAS;GACxB,MAAM,aAAa,EAAE,WAAW,EAAE;GAClC,MAAM,eAAe,EAAE;AACvB,OAAI,eAAe,KAAK,GAAG;AACzB,eAAW,SAAyB,uBAAO,OAAO,KAAK;AACvD,gBAAY,KAAK,WAAW;AAC5B,QAAI,eAAe,eAAe,UAAU,WAAW,YACrD,MAAK,IAAI,KAAK,GAAG,OAAO,WAAW,aAAa,QAAQ,KAAK,MAAM,MAAM;KACvE,MAAM,MAAM,WAAW,aAAa;KACpC,MAAM,YAAY,aAAa,WAAW;AAC1C,gBAAW,OAAO,OAAO,SAAS,QAAQ,CAAC,YAAY,OAAO,OAAO,WAAW,QAAQ,SAAS;AACjG,kBAAa,WAAW,SAAS;;;;AAKzC,SAAO;;CAET,OAAO,QAAQ,QAAM;EACnB,MAAM,cAAc,EAAE;AACtB,QAAKI,SAAU;EAEf,IAAI,WAAW,CADC,KACQ;EACxB,MAAM,QAAQ,UAAUD,OAAK;EAC7B,MAAM,gBAAgB,EAAE;AACxB,OAAK,IAAI,IAAI,GAAG,MAAM,MAAM,QAAQ,IAAI,KAAK,KAAK;GAChD,MAAM,OAAO,MAAM;GACnB,MAAM,SAAS,MAAM,MAAM;GAC3B,MAAM,YAAY,EAAE;AACpB,QAAK,IAAI,IAAI,GAAG,OAAO,SAAS,QAAQ,IAAI,MAAM,KAAK;IACrD,MAAM,OAAO,SAAS;IACtB,MAAM,WAAW,MAAKJ,SAAU;AAChC,QAAI,UAAU;AACZ,eAASK,SAAU,MAAKA;AACxB,SAAI,QAAQ;AACV,UAAI,UAASL,SAAU,KACrB,aAAY,KACV,GAAG,MAAKM,eAAgB,UAASN,SAAU,MAAM,QAAQ,MAAKK,OAAQ,CACvE;AAEH,kBAAY,KAAK,GAAG,MAAKC,eAAgB,UAAU,QAAQ,MAAKD,OAAQ,CAAC;WAEzE,WAAU,KAAK,SAAS;;AAG5B,SAAK,IAAI,IAAI,GAAG,OAAO,MAAKH,SAAU,QAAQ,IAAI,MAAM,KAAK;KAC3D,MAAM,UAAU,MAAKA,SAAU;KAC/B,MAAM,SAAS,MAAKG,WAAY,cAAc,EAAE,GAAG,EAAE,GAAG,MAAKA,QAAS;AACtE,SAAI,YAAY,KAAK;MACnB,MAAM,UAAU,MAAKL,SAAU;AAC/B,UAAI,SAAS;AACX,mBAAY,KAAK,GAAG,MAAKM,eAAgB,SAAS,QAAQ,MAAKD,OAAQ,CAAC;AACxE,gBAAQA,SAAU;AAClB,iBAAU,KAAK,QAAQ;;AAEzB;;KAEF,MAAM,CAAC,KAAK,MAAM,WAAW;AAC7B,SAAI,CAAC,QAAQ,EAAE,mBAAmB,QAChC;KAEF,MAAM,QAAQ,MAAKL,SAAU;KAC7B,MAAM,iBAAiB,MAAM,MAAM,EAAE,CAAC,KAAK,IAAI;AAC/C,SAAI,mBAAmB,QAAQ;MAC7B,MAAM,IAAI,QAAQ,KAAK,eAAe;AACtC,UAAI,GAAG;AACL,cAAO,QAAQ,EAAE;AACjB,mBAAY,KAAK,GAAG,MAAKM,eAAgB,OAAO,QAAQ,MAAKD,QAAS,OAAO,CAAC;AAC9E,WAAI,OAAO,KAAK,OAAML,SAAU,CAAC,QAAQ;AACvC,eAAMK,SAAU;QAChB,MAAM,iBAAiB,EAAE,GAAG,MAAM,KAAK,EAAE,UAAU;AAEnD,SADuB,cAAc,oBAAoB,EAAE,EAC5C,KAAK,MAAM;;AAE5B;;;AAGJ,SAAI,YAAY,QAAQ,QAAQ,KAAK,KAAK,EAAE;AAC1C,aAAO,QAAQ;AACf,UAAI,QAAQ;AACV,mBAAY,KAAK,GAAG,MAAKC,eAAgB,OAAO,QAAQ,QAAQ,MAAKD,OAAQ,CAAC;AAC9E,WAAI,OAAML,SAAU,KAClB,aAAY,KACV,GAAG,MAAKM,eAAgB,OAAMN,SAAU,MAAM,QAAQ,QAAQ,MAAKK,OAAQ,CAC5E;aAEE;AACL,cAAMA,SAAU;AAChB,iBAAU,KAAK,MAAM;;;;;AAK7B,cAAW,UAAU,OAAO,cAAc,OAAO,IAAI,EAAE,CAAC;;AAE1D,MAAI,YAAY,SAAS,EACvB,aAAY,MAAM,GAAG,MAAM;AACzB,UAAO,EAAE,QAAQ,EAAE;IACnB;AAEJ,SAAO,CAAC,YAAY,KAAK,EAAE,SAAS,aAAa,CAAC,SAAS,OAAO,CAAC,CAAC;;;;;;ACzJxE,IAAI,aAAa,MAAM;CACrB,OAAO;CACP;CACA,cAAc;AACZ,QAAKE,OAAQ,IAAI,MAAM;;CAEzB,IAAI,QAAQ,QAAM,SAAS;EACzB,MAAM,UAAU,uBAAuBC,OAAK;AAC5C,MAAI,SAAS;AACX,QAAK,IAAI,IAAI,GAAG,MAAM,QAAQ,QAAQ,IAAI,KAAK,IAC7C,OAAKD,KAAM,OAAO,QAAQ,QAAQ,IAAI,QAAQ;AAEhD;;AAEF,QAAKA,KAAM,OAAO,QAAQC,QAAM,QAAQ;;CAE1C,MAAM,QAAQ,QAAM;AAClB,SAAO,MAAKD,KAAM,OAAO,QAAQC,OAAK;;;;;;ACf1C,IAAI,OAAO,cAAcC,OAAS;CAChC,YAAY,UAAU,EAAE,EAAE;AACxB,QAAM,QAAQ;AACd,OAAK,SAAS,QAAQ,UAAU,IAAI,YAAY,EAC9C,SAAS,CAAC,IAAI,cAAc,EAAE,IAAI,YAAY,CAAC,EAChD,CAAC;;;;;;ACTN,IAAI,QAAQ,YAAY;CAOtB,MAAM,OAAO;EALX,QAAQ;EACR,cAAc;GAAC;GAAO;GAAQ;GAAO;GAAQ;GAAU;GAAQ;EAC/D,cAAc,EAAE;EAChB,eAAe,EAAE;EAIjB,GAAG;EACJ;CACD,MAAM,oBAAoB,eAAe;AACvC,MAAI,OAAO,eAAe,SACxB,KAAI,eAAe,IACjB,cAAa;MAEb,SAAQ,WAAW,eAAe,SAAS,SAAS;WAE7C,OAAO,eAAe,WAC/B,QAAO;MAEP,SAAQ,WAAW,WAAW,SAAS,OAAO,GAAG,SAAS;IAE3D,KAAK,OAAO;CACf,MAAM,qBAAqB,qBAAqB;AAC9C,MAAI,OAAO,qBAAqB,WAC9B,QAAO;WACE,MAAM,QAAQ,iBAAiB,CACxC,cAAa;MAEb,cAAa,EAAE;IAEhB,KAAK,aAAa;AACrB,QAAO,eAAe,MAAM,GAAG,MAAM;EACnC,SAAS,IAAI,KAAK,OAAO;AACvB,KAAE,IAAI,QAAQ,IAAI,KAAK,MAAM;;EAE/B,MAAM,cAAc,MAAM,gBAAgB,EAAE,IAAI,OAAO,SAAS,IAAI,IAAI,EAAE;AAC1E,MAAI,YACF,KAAI,+BAA+B,YAAY;AAEjD,MAAI,KAAK,WAAW,KAAK;GACvB,MAAM,eAAe,EAAE,IAAI,OAAO,OAAO;AACzC,OAAI,aACF,KAAI,QAAQ,aAAa;OAEzB,KAAI,QAAQ,SAAS;;AAGzB,MAAI,KAAK,YACP,KAAI,oCAAoC,OAAO;AAEjD,MAAI,KAAK,eAAe,OACtB,KAAI,iCAAiC,KAAK,cAAc,KAAK,IAAI,CAAC;AAEpE,MAAI,EAAE,IAAI,WAAW,WAAW;AAC9B,OAAI,KAAK,UAAU,KACjB,KAAI,0BAA0B,KAAK,OAAO,UAAU,CAAC;GAEvD,MAAM,eAAe,MAAM,iBAAiB,EAAE,IAAI,OAAO,SAAS,IAAI,IAAI,EAAE;AAC5E,OAAI,aAAa,OACf,KAAI,gCAAgC,aAAa,KAAK,IAAI,CAAC;GAE7D,IAAI,UAAU,KAAK;AACnB,OAAI,CAAC,SAAS,QAAQ;IACpB,MAAM,iBAAiB,EAAE,IAAI,OAAO,iCAAiC;AACrE,QAAI,eACF,WAAU,eAAe,MAAM,UAAU;;AAG7C,OAAI,SAAS,QAAQ;AACnB,QAAI,gCAAgC,QAAQ,KAAK,IAAI,CAAC;AACtD,MAAE,IAAI,QAAQ,OAAO,QAAQ,iCAAiC;;AAEhE,KAAE,IAAI,QAAQ,OAAO,iBAAiB;AACtC,KAAE,IAAI,QAAQ,OAAO,eAAe;AACpC,UAAO,IAAI,SAAS,MAAM;IACxB,SAAS,EAAE,IAAI;IACf,QAAQ;IACR,YAAY;IACb,CAAC;;AAEJ,QAAM,MAAM;;;;;;AClFhB,SAAS,kBAAkB;CACzB,MAAM,EAAE,oBAAS,SAAS;AAE1B,QAAO,EADW,OAAO,MAAM,YAAY,YAAY,KAAK,UAAUC,cAAY,KAAK,IAAI,cAAcA,WAAS,MAAM;;AAG1H,eAAe,uBAAuB;CACpC,MAAM,EAAE,cAAc;CACtB,MAAM,YAAY;AAQlB,QAAO,EAPW,cAAc,KAAK,KAAK,UAAU,cAAc,uBAAuB,OAAO,YAAY;AAC1G,MAAI;AACF,UAAO,gBAAgB,MAAM,OAAO,YAAY,OAAO,EAAE;UACnD;AACN,UAAO;;KAEP,GAAG,CAAC,iBAAiB;;;;;ACb3B,IAAI,YAAY,UAAU;CACxB,MAAM,CAAC,WAAW,aAAa,CAAC,KAAK,IAAI;AAEzC,QADmB,MAAM,KAAK,MAAM,EAAE,QAAQ,4BAA4B,OAAO,UAAU,CAAC,CAC1E,KAAK,UAAU;;AAEnC,IAAI,QAAQ,UAAU;CACpB,MAAM,QAAQ,KAAK,KAAK,GAAG;AAC3B,QAAO,SAAS,CAAC,QAAQ,MAAM,QAAQ,OAAO,KAAK,MAAM,QAAQ,IAAI,GAAG,IAAI,CAAC;;AAE/E,IAAI,cAAc,OAAO,WAAW;AAElC,KADqB,MAAM,sBAAsB,CAE/C,SAAQ,SAAS,MAAM,GAAvB;EACE,KAAK,EACH,QAAO,WAAW,OAAO;EAC3B,KAAK,EACH,QAAO,WAAW,OAAO;EAC3B,KAAK,EACH,QAAO,WAAW,OAAO;EAC3B,KAAK,EACH,QAAO,WAAW,OAAO;;AAG/B,QAAO,GAAG;;AAEZ,eAAe,IAAI,IAAI,QAAQ,QAAQ,QAAM,SAAS,GAAG,SAAS;CAChE,MAAM,MAAM,WAAW,QAAuB,GAAG,OAAO,GAAG,OAAO,GAAGC,WAAS,GAAG,OAAO,GAAG,OAAO,GAAGA,OAAK,GAAG,MAAM,YAAY,OAAO,CAAC,GAAG;AAC1I,IAAG,IAAI;;AAET,IAAI,UAAU,KAAK,QAAQ,QAAQ;AACjC,QAAO,eAAe,QAAQ,GAAG,MAAM;EACrC,MAAM,EAAE,QAAQ,QAAQ,EAAE;EAC1B,MAAMA,SAAO,IAAI,MAAM,IAAI,QAAQ,KAAK,EAAE,CAAC;AAC3C,QAAM,IAAI,IAAI,OAAsB,QAAQA,OAAK;EACjD,MAAM,QAAQ,KAAK,KAAK;AACxB,QAAM,MAAM;AACZ,QAAM,IAAI,IAAI,OAAsB,QAAQA,QAAM,EAAE,IAAI,QAAQ,KAAK,MAAM,CAAC;;;;;;AC1BhF,SAAgB,iBAAiB,SAAiC;AAChE,KAAI,CAAC,MAAM,QAAQ,QAAQ,EAAE;AAC3B,MAAI,YAAY,OACd,SAAQ,KAAK,6DAA6D;AAE5E,SAAO,EAAE;;CAGX,MAAM,iBAAiB,QACpB,QAAQ,QAAuB,OAAO,QAAQ,SAAS,CACvD,KAAK,QAAQ,IAAI,MAAM,CAAC,CACxB,QAAQ,QAAQ,IAAI,SAAS,EAAE;AAElC,KAAI,eAAe,WAAW,QAAQ,OACpC,SAAQ,KACN,0EACD;AAGH,QAAO,CAAC,GAAG,IAAI,IAAI,eAAe,CAAC;;AAGrC,SAAgB,uBAAsC;CACpD,MAAM,SAAS,WAAW;AAC1B,QAAO,iBAAiB,OAAO,MAAM,QAAQ;;AAG/C,SAAgB,qBAAqB,GAA2B;CAC9D,MAAM,UAAU,EAAE,IAAI,OAAO,YAAY,EAAE,MAAM;AACjD,KAAI,QACF,QAAO;CAGT,MAAM,gBAAgB,EAAE,IAAI,OAAO,gBAAgB;AACnD,KAAI,CAAC,cACH,QAAO;CAGT,MAAM,CAAC,QAAQ,GAAG,QAAQ,cAAc,MAAM,CAAC,MAAM,MAAM;AAC3D,KAAI,OAAO,aAAa,KAAK,SAC3B,QAAO;AAIT,QADoB,KAAK,KAAK,IAAI,CAAC,MAAM,IACnB;;AAGxB,SAAS,2BAA2B,GAAsB;AACxD,GAAE,OAAO,oBAAoB,+BAA6B;AAC1D,QAAO,EAAE,KACP,EACE,OAAO;EACL,SAAS;EACT,MAAM;EACP,EACF,EACD,IACD;;AAGH,SAAgB,qBACd,UAAiC,EAAE,EAChB;CACnB,MAAM,aAAa,QAAQ,cAAc;CACzC,MAAM,4BAA4B,QAAQ,6BAA6B,CAAC,IAAI;CAC5E,MAAM,qBAAqB,QAAQ,sBAAsB;AAEzD,QAAO,OAAO,GAAG,SAAS;AACxB,MAAI,sBAAsB,EAAE,IAAI,WAAW,UACzC,QAAO,MAAM;AAGf,MAAI,0BAA0B,SAAS,EAAE,IAAI,KAAK,CAChD,QAAO,MAAM;EAGf,MAAM,UAAU,YAAY;AAC5B,MAAI,QAAQ,WAAW,EACrB,QAAO,MAAM;EAGf,MAAM,gBAAgB,qBAAqB,EAAE;AAC7C,MAAI,CAAC,iBAAiB,CAAC,QAAQ,SAAS,cAAc,CACpD,QAAO,2BAA2B,EAAE;AAGtC,SAAO,MAAM;;;;;;AC9FjB,MAAaC,oBAAuC,OAAO,GAAG,SAAS;CACrE,MAAM,UAAU,eAAe,EAAE,IAAI,OAAO,aAAa,CAAC;AAE1D,GAAE,OAAO,cAAc,QAAQ;CAE/B,MAAM,UAAU;EACd;EACA,WAAW,KAAK,KAAK;EACrB,WAAW,EAAE,IAAI,OAAO,aAAa,IAAI;EACzC,iBAAiB,EAAE,IAAI,OAAO,qBAAqB;EACnD,iBAAiB,EAAE,IAAI,OAAO,sBAAsB;EACrD;AAED,OAAM,eAAe,IAAI,SAAS,YAAY;AAC5C,QAAM,MAAM;GACZ;;;;;AClBJ,IAAI,eAAe,MAAM;CACvB;CACA;CACA;CACA,mBAAmB,EAAE;CACrB;CACA,UAAU;CACV,SAAS;CACT,YAAY,UAAU,WAAW;AAC/B,OAAK,WAAW;AAChB,OAAK,SAAS,SAAS,WAAW;AAClC,OAAK,UAAU,IAAI,aAAa;EAChC,MAAM,SAAS,UAAU,WAAW;AACpC,OAAK,iBAAiB,KAAK,YAAY;AACrC,SAAM,OAAO,QAAQ;IACrB;AACF,OAAK,mBAAmB,IAAI,eAAe;GACzC,MAAM,KAAK,YAAY;IACrB,MAAM,EAAE,MAAM,UAAU,MAAM,OAAO,MAAM;AAC3C,WAAO,WAAW,OAAO,GAAG,WAAW,QAAQ,MAAM;;GAEvD,cAAc;AACZ,SAAK,OAAO;;GAEf,CAAC;;CAEJ,MAAM,MAAM,OAAO;AACjB,MAAI;AACF,OAAI,OAAO,UAAU,SACnB,SAAQ,KAAK,QAAQ,OAAO,MAAM;AAEpC,SAAM,KAAK,OAAO,MAAM,MAAM;UACxB;AAER,SAAO;;CAET,MAAM,QAAQ,OAAO;AACnB,QAAM,KAAK,MAAM,QAAQ,KAAK;AAC9B,SAAO;;CAET,MAAM,IAAI;AACR,SAAO,IAAI,SAAS,QAAQ,WAAW,KAAK,GAAG,CAAC;;CAElD,MAAM,QAAQ;AACZ,MAAI;AACF,SAAM,KAAK,OAAO,OAAO;UACnB;AAER,OAAK,SAAS;;CAEhB,MAAM,KAAK,MAAM;AACf,OAAK,OAAO,aAAa;AACzB,QAAM,KAAK,OAAO,KAAK,UAAU,EAAE,cAAc,MAAM,CAAC;AACxD,OAAK,SAAS,KAAK,SAAS,WAAW;;CAEzC,QAAQ,UAAU;AAChB,OAAK,iBAAiB,KAAK,SAAS;;CAEtC,QAAQ;AACN,MAAI,CAAC,KAAK,SAAS;AACjB,QAAK,UAAU;AACf,QAAK,iBAAiB,SAAS,eAAe,YAAY,CAAC;;;;;;;AC7DjE,IAAI,wBAAwB;CAC1B,MAAM,UAAU,OAAO,QAAQ,cAAc,IAAI,UAAU,KAAK;AAChE,KAAI,YAAY,KAAK,EACnB,QAAO;CAET,MAAM,SAAS,QAAQ,WAAW,MAAM,IAAI,QAAQ,WAAW,MAAM,IAAI,QAAQ,WAAW,KAAK;AACjG,yBAAwB;AACxB,QAAO;;;;;ACJT,IAAI,kBAAkB,cAAc,aAAa;CAC/C,YAAY,UAAU,UAAU;AAC9B,QAAM,UAAU,SAAS;;CAE3B,MAAM,SAAS,SAAS;EAEtB,MAAM,aADO,MAAM,gBAAgB,QAAQ,MAAM,yBAAyB,WAAW,OAAO,EAAE,CAAC,EACxE,MAAM,KAAK,CAAC,KAAK,SAAS;AAC/C,UAAO,SAAS;IAChB,CAAC,KAAK,KAAK;EACb,MAAM,UAAU;GACd,QAAQ,SAAS,UAAU,QAAQ;GACnC;GACA,QAAQ,MAAM,OAAO,QAAQ;GAC7B,QAAQ,SAAS,UAAU,QAAQ;GACpC,CAAC,OAAO,QAAQ,CAAC,KAAK,KAAK,GAAG;AAC/B,QAAM,KAAK,MAAM,QAAQ;;;AAG7B,IAAI,MAAM,OAAO,UAAQ,IAAI,YAAY;AACvC,KAAI;AACF,QAAM,GAAGC,SAAO;UACT,GAAG;AACV,MAAI,aAAa,SAAS,SAAS;AACjC,SAAM,QAAQ,GAAGA,SAAO;AACxB,SAAMA,SAAO,SAAS;IACpB,OAAO;IACP,MAAM,EAAE;IACT,CAAC;QAEF,SAAQ,MAAM,EAAE;WAEV;AACR,WAAO,OAAO;;;AAGlB,IAAI,+BAA+B,IAAI,SAAS;AAChD,IAAI,aAAa,GAAG,IAAI,YAAY;CAClC,MAAM,EAAE,UAAU,aAAa,IAAI,iBAAiB;CACpD,MAAMA,WAAS,IAAI,gBAAgB,UAAU,SAAS;AACtD,KAAI,iBAAiB,CACnB,GAAE,IAAI,IAAI,OAAO,iBAAiB,eAAe;AAC/C,MAAI,CAACA,SAAO,OACV,UAAO,OAAO;GAEhB;AAEJ,cAAa,IAAIA,SAAO,kBAAkB,EAAE;AAC5C,GAAE,OAAO,qBAAqB,UAAU;AACxC,GAAE,OAAO,gBAAgB,oBAAoB;AAC7C,GAAE,OAAO,iBAAiB,WAAW;AACrC,GAAE,OAAO,cAAc,aAAa;AACpC,KAAIA,UAAQ,IAAI,QAAQ;AACxB,QAAO,EAAE,YAAYA,SAAO,iBAAiB;;;;;ACpD/C,MAAa,gBAAgB,YAAY;AAKvC,KAAI,CAJa,MAAM,QAAQ,OAAO,4BAA4B,EAChE,MAAM,WACP,CAAC,CAGA,OAAM,IAAI,UACR,oBACA,SAAS,KAAK,EAAE,SAAS,oBAAoB,EAAE,EAAE,QAAQ,KAAK,CAAC,CAChE;;;;;ACHL,MAAM,mBAAmB,QAA+B,KAAK;AAC7D,MAAM,sBAAsB,OAAU,KAAK;AAC3C,MAAM,UAAU,KAAK,KAAK,MAAM,SAAS,OAAO;AAChD,MAAM,oBAAoB;AAC1B,MAAM,kBAAkB;AAExB,MAAM,6BAAa,IAAI,KAA6B;AACpD,MAAM,6BAAa,IAAI,KAA4B;AAEnD,IAAI,qBAAqB;AACzB,IAAIC;AACJ,IAAIC;AAEJ,MAAM,2BAA2B;AAC/B,KAAI,CAAC,GAAG,WAAW,QAAQ,CACzB,IAAG,UAAU,SAAS,EAAE,WAAW,MAAM,CAAC;;AAI9C,MAAM,uBAAuB;AAC3B,KAAI,CAAC,GAAG,WAAW,QAAQ,CACzB;CAGF,MAAM,MAAM,KAAK,KAAK;AAEtB,MAAK,MAAM,SAAS,GAAG,YAAY,QAAQ,EAAE;EAC3C,MAAM,WAAW,KAAK,KAAK,SAAS,MAAM;EAE1C,IAAIC;AACJ,MAAI;AACF,WAAQ,GAAG,SAAS,SAAS;UACvB;AACN;;AAGF,MAAI,CAAC,MAAM,QAAQ,CACjB;AAGF,MAAI,MAAM,MAAM,UAAU,iBACxB,KAAI;AACF,MAAG,OAAO,SAAS;UACb;AACN;;;;AAMR,MAAM,cAAc,SAClB,KACG,KAAK,QACJ,OAAO,QAAQ,WAAW,MACxB,KAAK,QAAQ,KAAK;CAAE,OAAO;CAAM,QAAQ;CAAO,CAAC,CAEpD,CACA,KAAK,IAAI;AAEd,MAAM,gBAAgB,SAAiB;CACrC,MAAM,aAAa,KAChB,aAAa,CACb,WAAW,eAAe,IAAI,CAC9B,WAAW,YAAY,GAAG;AAE7B,QAAO,eAAe,KAAK,YAAY;;AAGzC,MAAM,cAAc,UAA0C;AAC5D,OAAM,OAAO;;AAGf,MAAM,eAAe,aAAqB;CACxC,MAAM,SAAS,WAAW,IAAI,SAAS;AACvC,KAAI,CAAC,UAAU,OAAO,WAAW,EAC/B;CAGF,MAAMC,WAAS,aAAa,SAAS;CACrC,MAAM,UAAU,OAAO,KAAK,KAAK,GAAG;AACpC,UAAO,MAAM,UAAU,UAAU;AAC/B,MAAI,MACF,SAAQ,KAAK,+BAA+B,MAAM;GAEpD;AAEF,YAAW,IAAI,UAAU,EAAE,CAAC;;AAG9B,MAAM,wBAAwB;AAC5B,MAAK,MAAM,YAAY,WAAW,MAAM,CACtC,aAAY,SAAS;;AAIzB,MAAM,gBAAgB;AACpB,KAAI,eAAe;AACjB,gBAAc,cAAc;AAC5B,kBAAgB;;AAElB,KAAI,iBAAiB;AACnB,gBAAc,gBAAgB;AAC9B,oBAAkB;;AAGpB,kBAAiB;AACjB,MAAK,MAAMA,YAAU,WAAW,QAAQ,CACtC,UAAO,KAAK;AAEd,YAAW,OAAO;AAClB,YAAW,OAAO;;AAGpB,MAAM,gCAAgC;AACpC,KAAI,mBACF;AAGF,sBAAqB;AAErB,qBAAoB;AACpB,iBAAgB;AAEhB,iBAAgB,YAAY,iBAAiB,kBAAkB;AAC/D,YAAW,cAAc;AAEzB,mBAAkB,YAAY,gBAAgB,oBAAoB;AAClE,YAAW,gBAAgB;AAE3B,SAAQ,KAAK,QAAQ,QAAQ;AAC7B,SAAQ,KAAK,gBAAgB;AAC3B,WAAS;AACT,UAAQ,KAAK,EAAE;GACf;AACF,SAAQ,KAAK,iBAAiB;AAC5B,WAAS;AACT,UAAQ,KAAK,EAAE;GACf;;AAGJ,MAAM,gBAAgB,aAAqC;AACzD,0BAAyB;CAEzB,IAAIA,WAAS,WAAW,IAAI,SAAS;AACrC,KAAI,CAACA,YAAUA,SAAO,WAAW;AAC/B,aAAS,GAAG,kBAAkB,UAAU,EAAE,OAAO,KAAK,CAAC;AACvD,aAAW,IAAI,UAAUA,SAAO;AAEhC,WAAO,GAAG,UAAU,UAAmB;AACrC,WAAQ,KAAK,oBAAoB,MAAM;AACvC,cAAW,OAAO,SAAS;IAC3B;;AAEJ,QAAOA;;AAGT,MAAM,cAAc,UAAkB,SAAiB;CACrD,IAAI,SAAS,WAAW,IAAI,SAAS;AACrC,KAAI,CAAC,QAAQ;AACX,WAAS,EAAE;AACX,aAAW,IAAI,UAAU,OAAO;;AAGlC,QAAO,KAAK,KAAK;AAEjB,KAAI,OAAO,UAAU,gBACnB,aAAY,SAAS;;AAMzB,MAAa,aACX,UACA,YACS;AACT,KAAI,CAAC,MAAM,QACT;AAGF,UAAO,MAAM,GAAG,SAAS,CAAC;;AAG5B,MAAa,aACX,UACA,OACA,UACS;AACT,WAAUC,gBAAc,CAAC,OAAO,KAAK,UAAU,MAAM,CAAC,CAAC;;AAGzD,MAAa,iBACX,UACA,OACA,EAAE,OAAO,aAAa,UACb;AACT,WAAUA,gBAAc,CAAC,OAAO,KAAK,UAAU,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;;AAG5E,MAAa,uBAAuB,SAAkC;CACpE,MAAM,gBAAgB,aAAa,KAAK;CACxC,MAAM,WAAW,QAAQ,QAAQ,KAAK;AAEtC,KAAI,MAAM,QACR,UAAS,QAAQ;AAEnB,UAAS,aAAa,EAAE,CAAC;AAEzB,UAAS,YAAY,EACnB,IAAI,QAAQ;AACV,2BAAyB;EAGzB,MAAM,UADU,eAAe,UAAU,EAChB;EACzB,MAAM,OAAO,OAAO;EACpB,MAAM,UAAU,KAAK,mBAAmB,QAAQ;EAChD,MAAM,YAAY,KAAK,eAAe,SAAS,EAAE,QAAQ,OAAO,CAAC;EACjE,MAAM,WAAW,KAAK,KAAK,SAAS,GAAG,cAAc,GAAG,QAAQ,MAAM;EACtE,MAAM,UAAU,WAAW,OAAO,KAAuB;EACzD,MAAM,aAAa,UAAU,KAAK,QAAQ,KAAK;EAC/C,MAAM,OAAO,IAAI,UAAU,KAAK,OAAO,KAAK,KAAK,OAAO,OAAO,KAAK,GAAG,aACrE,UAAU,IAAI,YAAY;AAG5B,aAAW,UAAU,KAAK;IAE7B,CAAC;AAEF,QAAO;;;;;ACvOT,eAAsB,eAAe,SAAc;AACjD,KAAIC,QAAM,qBAAqB,OAAW;CAE1C,MAAM,MAAM,KAAK,KAAK;AAEtB,KAAI,CAACA,QAAM,sBAAsB;AAC/B,UAAM,uBAAuB;AAC7B;;CAGF,MAAM,kBAAkB,MAAMA,QAAM,wBAAwB;AAE5D,KAAI,iBAAiBA,QAAM,kBAAkB;AAC3C,UAAM,uBAAuB;AAC7B;;CAGF,MAAM,kBAAkB,KAAK,KAAKA,QAAM,mBAAmB,eAAe;AAE1E,KAAI,CAACA,QAAM,eAAe;AACxB,UAAQ,KACN,qCAAqC,gBAAgB,gBACtD;AACD,QAAM,IAAI,UACR,uBACA,SAAS,KAAK,EAAE,SAAS,uBAAuB,EAAE,EAAE,QAAQ,KAAK,CAAC,CACnE;;CAGH,MAAM,aAAa,kBAAkB;AACrC,SAAQ,KACN,+BAA+B,gBAAgB,+BAChD;AACD,OAAM,MAAM,WAAW;AAEvB,SAAM,uBAAuB;AAC7B,SAAQ,KAAK,qDAAqD;;;;;;;;;;;;;;;;;;;AC3BpE,IAAa,iBAAb,cAAoC,gBAAgB;CAChD,eAAe;;CAEf,YAAY,UAAU,EAAE,SAAS,OAAO,EAAE;AACtC,QAAM;GACF,YAAY,OAAO,eAAe;AAC9B,YAAQ,MAAKC,cAAe;AAC5B,WAAO,MAAM;KACT,MAAM,UAAU,MAAM,QAAQ,KAAK;KACnC,MAAM,UAAU,QAAQ,UAAU,MAAM,QAAQ,KAAK,GAAG;AACxD,SAAI,YAAY,MAAM,YAAa,MAAM,SAAS,MAC7C,YAAY,MAAO,UAAU,IAAK,UAAU;AAC7C,iBAAW,QAAQ,MAAM,MAAM,GAAG,QAAQ,CAAC;AAC3C,cAAQ,MAAM,MAAM,UAAU,EAAE;AAChC;;AAEJ,SAAI,YAAY,GACZ;KACJ,MAAM,WAAW,MAAM,UAAU,OAAO,OAAO,UAAU,IAAI;AAC7D,gBAAW,QAAQ,MAAM,MAAM,GAAG,SAAS,CAAC;AAC5C,aAAQ,MAAM,MAAM,UAAU,EAAE;;AAEpC,UAAKA,cAAe;;GAExB,QAAQ,eAAe;AACnB,QAAI,MAAKA,gBAAiB,GACtB;IACJ,MAAM,cAAc,QAAQ,WAAW,MAAKA,YAAa,SAAS,KAAK,GACjE,MAAKA,YAAa,MAAM,GAAG,GAAG,GAC9B,MAAKA;AACX,eAAW,QAAQ,YAAY;;GAEtC,CAAC;;;;;;AC/CV,SAAgB,OAAO,OAAO;CAC1B,IAAI,UAAU,IAAI,mBAAmB;CACrC,IAAIC,UAAQ,IAAI,eAAe,EAAE,SAAS,MAAM,CAAC;AACjD,QAAO,MAAM,YAAY,QAAQ,CAAC,YAAYA,QAAM;;AAExD,SAAgB,MAAM,OAAO;CAEzB,IAAI,QADM,SACM,KAAK,MAAM;CAE3B,IAAI,MAAM,SAAS,MAAM;AACzB,KAAI,IACA,QAAO,CACH,MAAM,UAAU,GAAG,IAAI,EACvB,MAAM,UAAU,MAAM,MAAM,GAAG,OAAO,CACzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACkBT,gBAAuB,OAAO,KAAK,QAAQ;AAEvC,KAAI,CAAC,IAAI,KACL;CACJ,IAAI,OAAOC,OAAa,IAAI,KAAK;CACjC,IAAI,MAAM,SAAS,KAAK,WAAW;CACnC,IAAI;AACJ,UAAS;AACL,MAAI,UAAU,OAAO,QACjB,QAAO,OAAO,QAAQ;AAE1B,SAAO,MAAM,OAAO,MAAM;AAC1B,MAAI,KAAK,KACL;AACJ,MAAI,CAAC,KAAK,OAAO;AACb,OAAI,MACA,OAAM;AACV,WAAQ;AACR;;EAEJ,IAAI,CAAC,OAAO,SAASC,MAAY,KAAK,MAAM,IAAI,EAAE;AAClD,MAAI,CAAC,MACD;AACJ,MAAI,UAAU,QAAQ;AAClB,aAAU,EAAE;AACZ,SAAM,SAAS,MAAM,SAAU,MAAM,SAAS,OAAO,QAAS;aAEzD,UAAU,SAAS;AACxB,aAAU,EAAE;AACZ,SAAM,SAAS;aAEV,UAAU,MAAM;AACrB,aAAU,EAAE;AACZ,SAAM,SAAS,CAAC,SAAS;aAEpB,UAAU,SAAS;AACxB,aAAU,EAAE;AACZ,SAAM,SAAS,CAAC,SAAS;;;;;;;ACpErC,MAAM,wBAAwB,CAAC,WAAW,SAAS;AAYnD,MAAMC,0BAAgE;CACpE,SAAS;CACT,QAAQ;CACT;AAED,MAAM,gBAAgB,YAA6C;AACjE,QAAO,SAAS,WAAW,OAAO,QAAQ,QAAQ;;AAGpD,MAAM,kBACJ,SACA,eACkB;AAClB,KAAI,aAAa,QAAQ,CACvB,QAAO,QAAQ,IAAI,WAAW;CAGhC,MAAM,uBAAuB,WAAW,aAAa;AAKrD,QAJqB,OAAO,QAAQ,QAAQ,CAAC,MAC1C,CAAC,SAAS,IAAI,aAAa,KAAK,qBAClC,GAEqB,MAAM;;AAG9B,MAAa,+BACX,gBAC+C;CAC/C,MAAM,SAAS,IAAI,gBAAgB,YAAY;CAC/C,MAAM,YAAY,OAAO,IAAI,MAAM;CACnC,MAAM,UAAU,OAAO,IAAI,MAAM;AAEjC,KAAI,CAAC,aAAa,CAAC,QACjB,QAAO;AAGT,QAAO;EACL;EACA;EACD;;AAGH,MAAa,4BACX,SACA,SACiC;CACjC,MAAM,aAAa,wBAAwB;CAC3C,MAAM,cAAc,eAAe,SAAS,WAAW;AAEvD,KAAI,CAAC,YACH,QAAO;CAGT,MAAM,SAAS,4BAA4B,YAAY;AAEvD,KAAI,CAAC,OACH,QAAO;AAGT,QAAO;EACL;EACA,GAAG;EACJ;;AAGH,MAAa,wBAAwB,YAA+B;AAClE,MAAK,MAAM,QAAQ,uBAAuB;EACxC,MAAM,QAAQ,yBAAyB,SAAS,KAAK;AAErD,MAAI,CAAC,MACH;EAGF,MAAM,IAAI,IAAI,KAAK,MAAM,QAAQ;EACjC,MAAM,UACJ,OAAO,MAAM,EAAE,SAAS,CAAC,GAAG,MAAM,UAAU,EAAE,gBAAgB;AAChE,UAAQ,KACN,WAAW,MAAM,KAAK,oBAAoB,MAAM,UAAU,eAAe,UAC1E;;;;;;AC5EL,MAAa,wBAAwB,OACnC,SACA,YAMG;AACH,KAAI,CAAC,MAAM,aAAc,OAAM,IAAI,MAAM,0BAA0B;CAEnE,MAAM,eAAe,QAAQ,SAAS,MACnC,MACC,OAAO,EAAE,YAAY,YAClB,EAAE,SAAS,MAAM,QAAMC,IAAE,SAAS,YAAY,CACpD;CAKD,IAAI,cAAc;AAClB,KAAI,QAAQ,SAAS,SAAS,GAAG;EAC/B,MAAM,cAAc,QAAQ,SAAS,GAAG,GAAG;AAC3C,MAAI,YACF,eAAc,CAAC,aAAa,OAAO,CAAC,SAAS,YAAY,KAAK;;CAKlE,MAAMC,UAAkC;EACtC,GAAG,eAAe,OAAO,QAAQ,WAAW,aAAa;EACzD,eAAe,cAAc,UAAU;EACxC;AAED,2BACE,QAAQ,WACR,QAAQ,QAAQ,eAAe,EAC/B,QACD;AAED,mBAAkB,SAAS,QAAQ,YAAY;AAE/C,SAAQ,IAAI,cAAc,QAAQ,QAAQ;CAE1C,MAAM,WAAW,MAAM,MAAM,GAAG,eAAe,MAAM,CAAC,oBAAoB;EACxE,QAAQ;EACR;EACA,MAAM,KAAK,UAAU,QAAQ;EAC9B,CAAC;AAEF,sBAAqB,SAAS,QAAQ;AAEtC,KAAI,CAAC,SAAS,IAAI;AAChB,UAAQ,MAAM,qCAAqC,SAAS;AAC5D,QAAM,IAAI,UAAU,qCAAqC,SAAS;;AAGpE,KAAI,QAAQ,OACV,QAAO,OAAO,SAAS;AAGzB,QAAQ,MAAM,SAAS,MAAM;;;;;AC9D/B,MAAMC,WAAS,oBAAoB,2BAA2B;AAE9D,eAAsBC,mBAAiB,GAAY;AACjD,OAAM,eAAe,MAAM;CAE3B,IAAI,UAAU,MAAM,EAAE,IAAI,MAA8B;AACxD,eAAcD,UAAQ,oBAAoB;EAAE,OAAO;EAAS,YAAY;EAAK,CAAC;CAG9E,MAAM,gBAAgB,MAAM,QAAQ,KAAK,MACtC,UAAU,MAAM,OAAO,QAAQ,MACjC;AAED,KAAI,eAAe,OAAO,UACxB,QAAO,EAAE,KACP,EACE,OAAO;EACL,SAAS;EACT,MAAM;EACP,EACF,EACD,IACD;AAGH,KAAI,MAAM,cAAe,OAAM,eAAe;AAE9C,KAAI,UAAU,QAAQ,WAAW,EAAE;AACjC,YAAU;GACR,GAAG;GACH,YAAY,eAAe,aAAa,OAAO;GAChD;AACD,YAAUA,UAAQ,sBAAsB,QAAQ,WAAW;;CAI7D,MAAM,YAAY,6BAA6B,QAAQ;AACvD,UAAO,MAAM,yBAAyB,UAAU;CAEhD,MAAM,YAAY,QAAQ,UAAU;AACpC,UAAO,MAAM,yBAAyB,UAAU;CAEhD,MAAM,WAAW,MAAM,sBAAsB,SAAS;EACpD;EACA;EACD,CAAC;AAEF,KAAIE,iBAAe,SAAS,EAAE;AAC5B,YAAUF,UAAQ,2BAA2B,SAAS;AACtD,SAAO,EAAE,KAAK,SAAS;;AAGzB,UAAO,MAAM,qBAAqB;AAClC,QAAO,UAAU,GAAG,OAAO,aAAW;AACpC,aAAW,MAAM,SAAS,UAAU;AAClC,aAAUA,UAAQ,oBAAoB,MAAM;AAC5C,SAAMG,SAAO,SAAS,MAAoB;;GAE5C;;AAGJ,MAAMD,oBACJ,aACuC,OAAO,OAAO,UAAU,UAAU;;;;ACxE3E,MAAa,mBAAmB,IAAI,MAAM;AAE1C,iBAAiB,KAAK,KAAK,OAAO,MAAM;AACtC,KAAI;AACF,SAAO,MAAME,mBAAiB,EAAE;UACzB,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACVF,MAAa,mBAAmB,OAAO,YAA8B;AACnE,KAAI,CAAC,MAAM,aAAc,OAAM,IAAI,MAAM,0BAA0B;CAEnE,MAAM,WAAW,MAAM,MAAM,GAAG,eAAe,MAAM,CAAC,cAAc;EAClE,QAAQ;EACR,SAAS,eAAe,MAAM;EAC9B,MAAM,KAAK,UAAU,QAAQ;EAC9B,CAAC;AAEF,KAAI,CAAC,SAAS,GAAI,OAAM,IAAI,UAAU,+BAA+B,SAAS;AAE9E,QAAQ,MAAM,SAAS,MAAM;;;;;ACP/B,MAAa,kBAAkB,IAAI,MAAM;AAEzC,gBAAgB,KAAK,KAAK,OAAO,MAAM;AACrC,KAAI;EACF,MAAM,SAAS,MAAM,EAAE,IAAI,MAAwB;EACnD,MAAM,WAAW,MAAM,iBAAiB,OAAO;AAE/C,SAAO,EAAE,KAAK,SAAS;UAChB,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACTF,MAAM,eAAe;CACnB,kBAAkB,OAAO;CACzB,mBAAmB,OAAO;CAC1B,iBAAiB,OAAO;CACxB,iBAAiB,OAAO;CACxB,iBAAiB,OAAO;CACzB;AAUD,MAAM,gCAAgB,IAAI,KAAsB;;;;AAKhD,MAAM,4BACJ,WACA,SACA,cACW;CACX,IAAI,SAAS;AACb,MAAK,MAAM,YAAY,WAAW;AAChC,YAAU,UAAU;AACpB,YAAU,QAAQ,OAAO,SAAS,GAAG,CAAC;AACtC,YAAU,QAAQ,OAAO,SAAS,SAAS,KAAK,CAAC;AACjD,YAAU,QAAQ,OAAO,SAAS,SAAS,UAAU,CAAC;;AAExD,WAAU,UAAU;AACpB,QAAO;;;;;AAMT,MAAM,+BACJ,cACA,YACW;CACX,IAAI,SAAS;AACb,MAAK,MAAM,QAAQ,aACjB,KAAI,KAAK,SAAS,YAChB,WAAU,QAAQ,OAAO,KAAK,UAAU,IAAI,CAAC,SAAS;UAC7C,KAAK,KACd,WAAU,QAAQ,OAAO,KAAK,KAAK,CAAC;AAGxC,QAAO;;;;;AAMT,MAAM,0BACJ,SACA,SACA,cACW;CACX,MAAM,mBAAmB;CACzB,MAAM,gBAAgB;CACtB,IAAI,SAAS;AACb,MAAK,MAAM,CAAC,KAAK,UAAU,OAAO,QAAQ,QAAQ,EAAE;AAClD,MAAI,QAAQ,mBACV;AAEF,MAAI,OAAO,UAAU,SACnB,WAAU,QAAQ,OAAO,MAAM,CAAC;AAElC,MAAI,QAAQ,OACV,WAAU;AAEZ,MAAI,QAAQ,aACV,WAAU,yBACR,OACA,SACA,UACD;AAEH,MAAI,QAAQ,aAAa,MAAM,QAAQ,MAAM,CAC3C,WAAU,4BACR,OACA,QACD;;AAGL,QAAO;;;;;AAMT,MAAM,mBACJ,UACA,SACA,cACW;AACX,KAAI,SAAS,WAAW,EACtB,QAAO;CAET,IAAI,YAAY;AAChB,MAAK,MAAM,WAAW,SACpB,cAAa,uBAAuB,SAAS,SAAS,UAAU;AAGlE,cAAa;AACb,QAAO;;;;;AAMT,MAAM,wBAAwB,OAAO,aAAuC;AAC1E,KAAI,cAAc,IAAI,SAAS,EAAE;EAC/B,MAAM,SAAS,cAAc,IAAI,SAAS;AAC1C,MAAI,OACF,QAAO;;CAIX,MAAM,oBAAoB;AAC1B,KAAI,EAAE,qBAAqB,eAAe;EACxC,MAAM,iBAAkB,MAAM,aAAa,YAAY;AACvD,gBAAc,IAAI,UAAU,eAAe;AAC3C,SAAO;;CAGT,MAAM,iBAAkB,MAAM,aAAa,oBAAoB;AAC/D,eAAc,IAAI,UAAU,eAAe;AAC3C,QAAO;;;;;AAMT,MAAa,yBAAyB,UAAyB;AAC7D,QAAO,MAAM,aAAa,aAAa;;;;;AAMzC,MAAM,qBAAqB,UAAiB;AAC1C,QAAO,MAAM,OAAO,mBAAmB,MAAM,OAAO,UAChD;EACE,UAAU;EACV,UAAU;EACV,SAAS;EACT,UAAU;EACV,UAAU;EACV,SAAS;EACT,OAAO;EACR,GACD;EACE,UAAU;EACV,UAAU;EACV,SAAS;EACT,UAAU;EACV,UAAU;EACV,SAAS;EACT,OAAO,MAAM,GAAG,WAAW,OAAO;EACnC;;;;;AAMP,MAAM,4BACJ,KACA,MACA,YAIW;CACX,MAAM,EAAE,SAAS,cAAc;CAC/B,IAAI,SAAS,UAAU;AAGvB,KAAI,OAAO,SAAS,YAAY,SAAS,KACvC,QAAO;CAIT,MAAM,QAAQ;CAOd,MAAM,YAAY;CAClB,MAAM,YAAY,MAAM,QAAQ;CAChC,IAAI,YAAY,MAAM,eAAe;AAGrC,KAAI,MAAM,QAAQ,MAAM,QAAQ,MAAM,KAAK,EAAE;AAC3C,YAAU,UAAU;AACpB,OAAK,MAAM,QAAQ,MAAM,MAAM;AAC7B,aAAU,UAAU;AACpB,aAAU,QAAQ,OAAO,OAAO,KAAK,CAAC,CAAC;;;AAK3C,KAAI,UAAU,SAAS,IAAI,CACzB,aAAY,UAAU,MAAM,GAAG,GAAG;CAIpC,MAAM,OAAO,GAAG,UAAU,GAAG,UAAU,GAAG;AAC1C,WAAU,QAAQ,OAAO,KAAK,CAAC;AAE/B,KAAI,MAAM,SAAS,WAAW,MAAM,SAClC,WAAU,0BAA0B,MAAM,UAAU,SAAS,UAAU;CAIzE,MAAM,eAAe,IAAI,IAAI;EAAC;EAAQ;EAAe;EAAQ;EAAQ,CAAC;AACtE,MAAK,MAAM,gBAAgB,OAAO,KAAK,MAAM,CAC3C,KAAI,CAAC,aAAa,IAAI,aAAa,EAAE;EACnC,MAAM,gBAAgB,MAAM;EAC5B,MAAM,eACJ,OAAO,kBAAkB,WAAW,gBAClC,KAAK,UAAU,cAAc;AAEjC,YAAU,QAAQ,OAAO,GAAG,aAAa,GAAG,eAAe,CAAC;;AAIhE,QAAO;;;;;AAMT,MAAM,6BACJ,YACA,SACA,cACW;CACX,IAAI,SAAS;AACb,KAAI,OAAO,KAAK,WAAW,CAAC,SAAS,GAAG;AACtC,YAAU,UAAU;AACpB,OAAK,MAAM,WAAW,OAAO,KAAK,WAAW,CAC3C,WAAU,yBAAyB,SAAS,WAAW,UAAU;GAC/D;GACA;GACD,CAAC;;AAGN,QAAO;;;;;AAMT,MAAM,6BACJ,YACA,SACA,cACW;AACX,KAAI,CAAC,cAAc,OAAO,eAAe,SACvC,QAAO;CAGT,MAAM,SAAS;CACf,IAAI,SAAS;CAEb,MAAM,eAAe,IAAI,IAAI,CAAC,WAAW,uBAAuB,CAAC;AACjE,MAAK,MAAM,CAAC,KAAK,UAAU,OAAO,QAAQ,OAAO,EAAE;AACjD,MAAI,aAAa,IAAI,IAAI,CACvB;AAEF,MAAI,QAAQ,aACV,WAAU,0BACR,OACA,SACA,UACD;OACI;GACL,MAAM,YACJ,OAAO,UAAU,WAAW,QAAQ,KAAK,UAAU,MAAM;AAC3D,aAAU,QAAQ,OAAO,GAAG,IAAI,GAAG,YAAY,CAAC;;;AAIpD,QAAO;;;;;AAMT,MAAM,uBACJ,MACA,SACA,cACW;CACX,IAAI,SAAS,UAAU;CACvB,MAAM,OAAO,KAAK;CAClB,MAAM,QAAQ,KAAK;CACnB,IAAI,QAAQ,KAAK,eAAe;AAChC,KAAI,MAAM,SAAS,IAAI,CACrB,SAAQ,MAAM,MAAM,GAAG,GAAG;CAE5B,MAAM,OAAO,QAAQ,MAAM;AAC3B,WAAU,QAAQ,OAAO,KAAK,CAAC;AAC/B,KACE,OAAO,KAAK,eAAe,YACxB,KAAK,eAAe,KAEvB,WAAU,0BAA0B,KAAK,YAAY,SAAS,UAAU;AAE1E,QAAO;;;;;AAMT,MAAa,qBACX,OACA,SACA,cACW;CACX,IAAI,iBAAiB;AACrB,KAAI,UAAU,OAAO;AACnB,OAAK,MAAM,QAAQ,MACjB,mBAAkB,oBAAoB,MAAM,SAAS,UAAU;AAEjE,oBAAkB,UAAU;OAE5B,MAAK,MAAM,QAAQ,MACjB,mBAAkB,QAAQ,OAAO,KAAK,UAAU,KAAK,CAAC,CAAC;AAG3D,QAAO;;;;;AAMT,MAAa,gBAAgB,OAC3B,SACA,UAC+C;CAE/C,MAAM,YAAY,sBAAsB,MAAM;CAG9C,MAAM,UAAU,MAAM,sBAAsB,UAAU;CAEtD,MAAM,qBAAqB,QAAQ;CACnC,MAAM,gBAAgB,mBAAmB,QACtC,QAAQ,IAAI,SAAS,YACvB;CACD,MAAM,iBAAiB,mBAAmB,QACvC,QAAQ,IAAI,SAAS,YACvB;CAED,MAAM,YAAY,kBAAkB,MAAM;CAE1C,IAAI,cAAc,gBAAgB,eAAe,SAAS,UAAU;AACpE,KAAI,QAAQ,SAAS,QAAQ,MAAM,SAAS,EAC1C,gBAAe,kBAAkB,QAAQ,OAAO,SAAS,UAAU;CAErE,MAAM,eAAe,gBAAgB,gBAAgB,SAAS,UAAU;AAExE,QAAO;EACL,OAAO;EACP,QAAQ;EACT;;;;;AC5XH,MAAa,qBAAqB,eAA0C;CAC1E,MAAM,SAAS,MAAM,QAAQ,QAAQ,EAAE;CACvC,MAAM,aAAa,OAAO,MAAM,MAAM,EAAE,OAAO,WAAW;AAC1D,KAAI,WACF,QAAO;CAGT,MAAM,aAAa,qBAAqB,WAAW;AACnD,KAAI,CAAC,WACH;CAGF,MAAM,YAAY,UAAU,WAAW,OAAO,GAAG,WAAW;CAC5D,MAAM,QAAQ,OAAO,MAAM,MAAM,EAAE,OAAO,UAAU;AACpD,KAAI,MACF,QAAO;;;;;;;;;;;;AAgBX,MAAM,wBACJ,eACoD;CAIpD,MAAM,cAHQ,WAAW,aAAa,CAGZ,QAAQ,WAAW,GAAG;CAGhD,MAAM,WAAW,YAAY,MAAM,6BAA6B;AAChE,KAAI,SACF,QAAO;EAAE,QAAQ,SAAS;EAAI,SAAS,GAAG,SAAS,GAAG,GAAG,SAAS;EAAM;CAI1E,MAAM,WAAW,YAAY,MAAM,6BAA6B;AAChE,KAAI,SACF,QAAO;EAAE,QAAQ,SAAS;EAAI,SAAS,GAAG,SAAS,GAAG,GAAG,SAAS;EAAM;CAI1E,MAAM,WAAW,YAAY,MAAM,8BAA8B;AACjE,KAAI,SACF,QAAO;EAAE,QAAQ,SAAS;EAAI,SAAS,GAAG,SAAS,GAAG,GAAG,SAAS;EAAM;CAI1E,MAAM,WAAW,YAAY,MAAM,uBAAuB;AAC1D,KAAI,SACF,QAAO;EAAE,QAAQ,SAAS;EAAI,SAAS,SAAS;EAAI;CAItD,MAAM,WAAW,YAAY,MAAM,uBAAuB;AAC1D,KAAI,SACF,QAAO;EAAE,QAAQ,SAAS;EAAI,SAAS,SAAS;EAAI;;;;;ACpExD,SAAgB,+BACd,cACkC;AAClC,KAAI,iBAAiB,KACnB,QAAO;AAQT,QANsB;EACpB,MAAM;EACN,QAAQ;EACR,YAAY;EACZ,gBAAgB;EACjB,CACoB;;;;;ACgBvB,MAAa,gBAAgB;AAQ7B,SAAgB,kBACd,SACwB;CACxB,MAAM,UAAU,QAAQ;CACxB,MAAM,QAAQ,MAAM,QAAQ,KAAK,MAAM,MAAM,EAAE,OAAO,QAAQ;CAC9D,MAAM,iBAAiB,kBAAkB,SAAS,MAAM;AACxD,QAAO;EACL,OAAO;EACP,UAAU,mCACR,SACA,SACA,eACD;EACD,YAAY,QAAQ;EACpB,MAAM,QAAQ;EACd,QAAQ,QAAQ;EAChB,aAAa,QAAQ;EACrB,OAAO,QAAQ;EACf,MAAM,QAAQ,UAAU;EACxB,OAAO,gCAAgC,QAAQ,MAAM;EACrD,aAAa,qCAAqC,QAAQ,YAAY;EACtE,iBAAiB;EAClB;;AAGH,SAAS,kBACP,SACA,OACoB;CACpB,MAAM,WAAW,QAAQ;AACzB,KAAI,SAAS,UAAU;EACrB,MAAM,oBAAoB,KAAK,IAC7B,MAAM,aAAa,SAAS,uBAAuB,IAClD,MAAM,aAAa,OAAO,qBAAqB,KAAK,EACtD;AACD,WAAS,kBAAkB;AAC3B,MAAI,oBAAoB,GAAG;GACzB,MAAM,eAAe,KAAK,IAAI,SAAS,eAAe,kBAAkB;AACxE,UAAO,KAAK,IACV,cACA,MAAM,aAAa,SAAS,uBAAuB,KACpD;;;;AAMP,SAAS,mCACP,SACA,SACA,iBACgB;CAChB,MAAM,iBAAiB,mBAAmB,QAAQ,OAAO;CACzD,MAAM,gBAAgB,QAAQ,SAAS,SAAS,YAC9C,QAAQ,SAAS,SACf,kBAAkB,QAAQ,GAC1B,uBAAuB,SAAS,QAAQ,CAC3C;AACD,QAAO,CAAC,GAAG,gBAAgB,GAAG,cAAc;;AAG9C,SAAS,mBACP,QACgB;AAChB,KAAI,CAAC,OACH,QAAO,EAAE;AAGX,KAAI,OAAO,WAAW,SACpB,QAAO,CAAC;EAAE,MAAM;EAAU,SAAS;EAAQ,CAAC;KAO5C,QAAO,CAAC;EAAE,MAAM;EAAU,SALP,OAChB,KAAK,UAAU;AACd,UAAO,MAAM;IACb,CACD,KAAK,OAAO;EACgC,CAAC;;AAIpD,SAAS,kBAAkB,SAA+C;CACxE,MAAMC,cAA8B,EAAE;AAEtC,KAAI,MAAM,QAAQ,QAAQ,QAAQ,EAAE;EAClC,MAAM,mBAAmB,QAAQ,QAAQ,QACtC,UACC,MAAM,SAAS,cAClB;EACD,MAAM,cAAc,QAAQ,QAAQ,QACjC,UAAU,MAAM,SAAS,cAC3B;AAGD,OAAK,MAAM,SAAS,iBAClB,aAAY,KAAK;GACf,MAAM;GACN,cAAc,MAAM;GACpB,SAAS,WAAW,MAAM,QAAQ;GACnC,CAAC;AAGJ,MAAI,YAAY,SAAS,EACvB,aAAY,KAAK;GACf,MAAM;GACN,SAAS,WAAW,YAAY;GACjC,CAAC;OAGJ,aAAY,KAAK;EACf,MAAM;EACN,SAAS,WAAW,QAAQ,QAAQ;EACrC,CAAC;AAGJ,QAAO;;AAGT,SAAS,uBACP,SACA,SACgB;AAChB,KAAI,CAAC,MAAM,QAAQ,QAAQ,QAAQ,CACjC,QAAO,CACL;EACE,MAAM;EACN,SAAS,WAAW,QAAQ,QAAQ;EACrC,CACF;CAGH,MAAM,gBAAgB,QAAQ,QAAQ,QACnC,UAA0C,MAAM,SAAS,WAC3D;CAED,IAAI,iBAAiB,QAAQ,QAAQ,QAClC,UAA2C,MAAM,SAAS,WAC5D;AAED,KAAI,QAAQ,WAAW,SAAS,CAC9B,kBAAiB,eAAe,QAC7B,MACC,EAAE,YACC,EAAE,aAAa,iBACf,EAAE,aAEF,CAAC,EAAE,UAAU,SAAS,IAAI,CAChC;CAGH,MAAM,mBAAmB,eACtB,QAAQ,MAAM,EAAE,YAAY,EAAE,aAAa,cAAc,CACzD,KAAK,MAAM,EAAE,SAAS;CAEzB,MAAM,qBACJ,iBAAiB,SAAS,IAAI,iBAAiB,KAAK,OAAO,GAAG;CAEhE,MAAM,YAAY,eAAe,MAAM,MAAM,EAAE,UAAU,EAAE;AAE3D,QAAO,cAAc,SAAS,IAC1B,CACE;EACE,MAAM;EACN,SAAS,WAAW,QAAQ,QAAQ;EACpC,gBAAgB;EAChB,kBAAkB;EAClB,YAAY,cAAc,KAAK,aAAa;GAC1C,IAAI,QAAQ;GACZ,MAAM;GACN,UAAU;IACR,MAAM,QAAQ;IACd,WAAW,KAAK,UAAU,QAAQ,MAAM;IACzC;GACF,EAAE;EACJ,CACF,GACD,CACE;EACE,MAAM;EACN,SAAS,WAAW,QAAQ,QAAQ;EACpC,gBAAgB;EAChB,kBAAkB;EACnB,CACF;;AAGP,SAAS,WACP,SACoC;AACpC,KAAI,OAAO,YAAY,SACrB,QAAO;AAET,KAAI,CAAC,MAAM,QAAQ,QAAQ,CACzB,QAAO;CAGT,MAAMC,eAAmC,EAAE;AAC3C,MAAK,MAAM,SAAS,QAClB,SAAQ,MAAM,MAAd;EACE,KAAK;AACH,gBAAa,KAAK;IAAE,MAAM;IAAQ,MAAM,MAAM;IAAM,CAAC;AACrD;EAEF,KAAK;AACH,gBAAa,KAAK;IAChB,MAAM;IACN,WAAW,EACT,KAAK,QAAQ,MAAM,OAAO,WAAW,UAAU,MAAM,OAAO,QAC7D;IACF,CAAC;AACF;EAEF,KAAK;AACH,gBAAa,KAAK,wBAAwB,CAAC;AAC3C;EAEF,KAAK;AACH,gBAAa,KAAK;IAChB,MAAM;IACN,MAAM,QAAQ,MAAM,UAAU;IAC/B,CAAC;AACF;;AAKN,QAAO;;AAGT,SAAS,yBAAmC;AAC1C,QAAO;EACL,MAAM;EACN,MAAM;EACP;;AAGH,SAAS,gCACP,gBACyB;AACzB,KAAI,CAAC,eACH;AAEF,QAAO,eAAe,KAAK,UAAU;EACnC,MAAM;EACN,UAAU;GACR,MAAM,KAAK;GACX,aAAa,KAAK;GAClB,YAAY,oBAAoB,KAAK,aAAa;GACnD;EACF,EAAE;;;;;;AAOL,MAAa,uBACX,WAC4B;AAC5B,KAAI,OAAO,SAAS,YAAY,CAAC,OAAO,WACtC,QAAO;EAAE,GAAG;EAAQ,YAAY,EAAE;EAAE;AAEtC,QAAO;;AAGT,SAAS,qCACP,qBACuC;AACvC,KAAI,CAAC,oBACH;AAGF,SAAQ,oBAAoB,MAA5B;EACE,KAAK,OACH,QAAO;EAET,KAAK,MACH,QAAO;EAET,KAAK;AACH,OAAI,oBAAoB,KACtB,QAAO;IACL,MAAM;IACN,UAAU,EAAE,MAAM,oBAAoB,MAAM;IAC7C;AAEH;EAEF,KAAK,OACH,QAAO;EAET,QACE;;;AAON,SAAgB,qBACd,UACmB;CAEnB,MAAMC,yBAAgE,EAAE;CACxE,IAAI,aAAa,SAAS,QAAQ,IAAI,iBAAiB;AAGvD,MAAK,MAAM,UAAU,SAAS,SAAS;EACrC,MAAM,aAAa,uBAAuB,OAAO,QAAQ,QAAQ;EACjE,MAAM,cAAc,wBAClB,OAAO,QAAQ,gBACf,OAAO,QAAQ,iBAChB;EACD,MAAM,gBAAgB,0BAA0B,OAAO,QAAQ,WAAW;AAE1E,yBAAuB,KAAK,GAAG,aAAa,GAAG,YAAY,GAAG,cAAc;AAG5E,MAAI,OAAO,kBAAkB,gBAAgB,eAAe,OAC1D,cAAa,OAAO;;AAIxB,QAAO;EACL,IAAI,SAAS;EACb,MAAM;EACN,MAAM;EACN,OAAO,SAAS;EAChB,SAAS;EACT,aAAa,+BAA+B,WAAW;EACvD,eAAe;EACf,OAAO;GACL,eACG,SAAS,OAAO,iBAAiB,MAC/B,SAAS,OAAO,uBAAuB,iBAAiB;GAC7D,eAAe,SAAS,OAAO,qBAAqB;GACpD,GAAI,SAAS,OAAO,uBAAuB,kBACrC,UAAa,EACjB,yBACE,SAAS,MAAM,sBAAsB,eACxC;GACF;EACF;;AAGH,SAAS,uBACP,gBAC2B;AAC3B,KAAI,OAAO,mBAAmB,YAAY,eAAe,SAAS,EAChE,QAAO,CAAC;EAAE,MAAM;EAAQ,MAAM;EAAgB,CAAC;AAGjD,KAAI,MAAM,QAAQ,eAAe,CAC/B,QAAO,eACJ,QAAQ,SAA2B,KAAK,SAAS,OAAO,CACxD,KAAK,UAAU;EAAE,MAAM;EAAQ,MAAM,KAAK;EAAM,EAAE;AAGvD,QAAO,EAAE;;AAGX,SAAS,wBACP,eACA,iBAC+B;AAC/B,KAAI,iBAAiB,cAAc,SAAS,EAC1C,QAAO,CACL;EACE,MAAM;EACN,UAAU;EACV,WAAW,mBAAmB;EAC/B,CACF;AAEH,KAAI,mBAAmB,gBAAgB,SAAS,EAC9C,QAAO,CACL;EACE,MAAM;EACN,UAAU;EACV,WAAW;EACZ,CACF;AAEH,QAAO,EAAE;;AAGX,SAAS,0BACP,WAC8B;AAC9B,KAAI,CAAC,UACH,QAAO,EAAE;AAEX,QAAO,UAAU,KAAK,cAAc;EAClC,MAAM;EACN,IAAI,SAAS;EACb,MAAM,SAAS,SAAS;EACxB,OAAO,KAAK,MAAM,SAAS,SAAS,UAAU;EAC/C,EAAE;;;;;;;;;ACnaL,eAAe,wBACb,GACA,SAC0B;AAC1B,KAAI,CAAC,QAAQ,MAAM,WAAW,SAAS,CAAE,QAAO;CAEhD,MAAM,SAAS,oBAAoB;AACnC,KAAI,CAAC,OAAQ,QAAO;CAGpB,MAAM,QAAQ,QAAQ,MAAM,WAAW,KAAK,IAAI;CAEhD,MAAM,MAAM,MAAM,MAChB,sDACA;EACE,QAAQ;EACR,SAAS;GACP,gBAAgB;GAChB,aAAa;GACb,qBAAqB;GACrB,kBAAkB;GACnB;EACD,MAAM,KAAK,UAAU;GAAE,GAAG;GAAS;GAAO,CAAC;EAC5C,CACF;AAED,KAAI,CAAC,IAAI,IAAI;AACX,UAAQ,KACN,kCACA,IAAI,QACJ,MAAM,IAAI,MAAM,CAAC,YAAY,GAAG,EAChC,+BACD;AACD,SAAO;;CAGT,MAAM,SAAU,MAAM,IAAI,MAAM;AAChC,SAAQ,KAAK,gCAAgC,OAAO,aAAa;AACjE,QAAO,EAAE,KAAK,OAAO;;;;;;;;;AAUvB,eAAsB,kBAAkB,GAAY;AAClD,KAAI;EACF,MAAM,mBAAmB,MAAM,EAAE,IAAI,MAAgC;EAGrE,MAAM,kBAAkB,MAAM,wBAAwB,GAAG,iBAAiB;AAC1E,MAAI,gBAAiB,QAAO;EAG5B,MAAM,gBAAgB,EAAE,IAAI,OAAO,iBAAiB;EAEpD,MAAM,gBAAgB,kBAAkB,iBAAiB;EAEzD,MAAM,gBAAgB,kBAAkB,iBAAiB,MAAM;AAC/D,mBAAiB,QAAQ,eAAe,MAAM,iBAAiB;AAE/D,MAAI,CAAC,eAAe;AAClB,WAAQ,KAAK,iDAAiD;AAC9D,UAAO,EAAE,KAAK,EACZ,cAAc,GACf,CAAC;;EAGJ,MAAM,aAAa,MAAM,cAAc,eAAe,cAAc;AAEpE,MAAI,iBAAiB,SAAS,iBAAiB,MAAM,SAAS,GAAG;GAC/D,IAAI,2BAA2B;AAC/B,OAAI,eAAe;IACjB,MAAM,cAAc,iBAAiB,MAAM;AAC3C,+BAA2B,CAAC,iBAAiB,MAAM,MAChD,SACC,KAAK,KAAK,WAAW,QAAQ,IACzB,KAAK,SAAS,WAAW,gBAAgB,EAChD;;AAEH,OAAI,0BACF;QAAI,iBAAiB,MAAM,WAAW,SAAS,CAE7C,YAAW,QAAQ,WAAW,QAAQ;aAC7B,iBAAiB,MAAM,WAAW,OAAO,CAClD,YAAW,QAAQ,WAAW,QAAQ;;;EAK5C,IAAI,kBAAkB,WAAW,QAAQ,WAAW;AACpD,MAAI,iBAAiB,MAAM,WAAW,SAAS,CAC7C,mBAAkB,KAAK,MAAM,kBAAkB,0BAA0B,CAAC;AAG5E,UAAQ,KAAK,gBAAgB,gBAAgB;AAE7C,SAAO,EAAE,KAAK,EACZ,cAAc,iBACf,CAAC;UACK,OAAO;AACd,UAAQ,MAAM,0BAA0B,MAAM;AAC9C,SAAO,EAAE,KAAK,EACZ,cAAc,GACf,CAAC;;;;;;AC2PN,MAAa,kBAAkB,OAC7B,SACA,EACE,QACA,WACA,gBACA,WACA,WACA,kBAEiC;AACnC,KAAI,CAAC,MAAM,aAAc,OAAM,IAAI,MAAM,0BAA0B;CAEnE,MAAMC,UAAkC;EACtC,GAAG,eAAe,OAAO,WAAW,OAAO;EAC3C,eAAe;EAChB;AAED,2BAA0B,WAAW,QAAQ,eAAe,EAAE,QAAQ;AAEtE,mBAAkB,SAAS,YAAY;AAGvC,SAAQ,eAAe;AAEvB,SAAQ,IAAI,cAAc,QAAQ,QAAQ;CAE1C,MAAM,WAAW,MAAM,MAAM,GAAG,eAAe,MAAM,CAAC,aAAa;EACjE,QAAQ;EACR;EACA,MAAM,KAAK,UAAU,QAAQ;EAC9B,CAAC;AAEF,sBAAqB,SAAS,QAAQ;AAEtC,KAAI,CAAC,SAAS,IAAI;AAChB,UAAQ,MAAM,8BAA8B,SAAS;AACrD,QAAM,IAAI,UAAU,8BAA8B,SAAS;;AAG7D,KAAI,QAAQ,OACV,QAAO,OAAO,SAAS;AAGzB,QAAQ,MAAM,SAAS,MAAM;;;;;AC7W/B,MAAM,eAAe;AACrB,MAAM,8BAA8B;AACpC,MAAM,iCAAiC;AAEvC,MAAaC,kBAAgB;AAE7B,MAAa,gDACX,YACqB;CACrB,MAAMC,QAAkC,EAAE;CAC1C,MAAM,aAAa,iBAAiB,QAAQ,MAAM;AAElD,MAAK,MAAM,WAAW,QAAQ,SAC5B,OAAM,KAAK,GAAG,iBAAiB,SAAS,QAAQ,OAAO,WAAW,CAAC;CAGrE,MAAM,kBAAkB,sBAAsB,QAAQ,MAAM;CAC5D,MAAM,aAAa,2BAA2B,QAAQ,YAAY;CAGlE,MAAM,EAAE,WAAW,mBAAmB,oBACpC,QAAQ,UAAU,QACnB;AAuBD,QArB2C;EACzC,OAAO,QAAQ;EACf;EACA,cAAc,sBAAsB,QAAQ,QAAQ,QAAQ,MAAM;EAClE,aAAa;EACb,OAAO,QAAQ,SAAS;EACxB,mBAAmB,KAAK,IAAI,QAAQ,YAAY,MAAM;EACtD,OAAO;EACP,aAAa;EACb,UAAU,QAAQ,WAAW,EAAE,GAAG,QAAQ,UAAU,GAAG;EACvD,kBAAkB;EAClB,QAAQ,QAAQ,UAAU;EAC1B,OAAO;EACP,qBAAqB;EACrB,WAAW;GACT,QAAQ,2BAA2B,QAAQ,MAAM;GACjD,SAAS;GACV;EACD,SAAS,CAAC,8BAA8B;EACzC;;AAUH,MAAa,oCACX,eACW;AACX,QAAO,GAAG,8BAA8B,WAAW,oBAAoB,iCAAiC,WAAW;;AAGrH,MAAa,oCACX,cACkC;AAClC,KAAI,UAAU,WAAW,4BAA4B,EAAE;EACrD,MAAMC,QAAM,UAAU,MAAM,EAAmC;EAC/D,MAAM,iBAAiBA,MAAI,QAAQ,+BAA+B;AAElE,MAAI,kBAAkB,KAAK,mBAAmBA,MAAI,SAAS,EACzD;EAGF,MAAM,oBAAoBA,MAAI,MAAM,GAAG,eAAe;EACtD,MAAM,KAAKA,MAAI,MAAM,iBAAiB,EAAE;AAExC,MAAI,CAAC,kBACH;AAGF,SAAO;GACL;GACA;GACD;;;AAML,MAAM,oBACJ,SACA,OACA,eAC6B;AAC7B,KAAI,QAAQ,SAAS,OACnB,QAAO,qBAAqB,QAAQ;AAGtC,QAAO,0BAA0B,SAAS,OAAO,WAAW;;AAG9D,MAAM,wBACJ,YAC6B;AAC7B,KAAI,OAAO,QAAQ,YAAY,SAC7B,QAAO,CAAC,cAAc,QAAQ,QAAQ,QAAQ,CAAC;AAGjD,KAAI,CAAC,MAAM,QAAQ,QAAQ,QAAQ,CACjC,QAAO,EAAE;CAGX,MAAMC,QAAkC,EAAE;CAC1C,MAAMC,iBAA8C,EAAE;AAEtD,MAAK,MAAM,SAAS,QAAQ,SAAS;AACnC,MAAI,MAAM,SAAS,eAAe;AAChC,uBAAoB,gBAAgB,OAAO,EAAE,MAAM,QAAQ,CAAC;AAC5D,SAAM,KAAK,yBAAyB,MAAM,CAAC;AAC3C;;EAGF,MAAM,YAAY,0BAA0B,MAAM;AAClD,MAAI,UAAU,SAAS,EACrB,gBAAe,KAAK,GAAG,UAAU;;AAIrC,qBAAoB,gBAAgB,OAAO,EAAE,MAAM,QAAQ,CAAC;AAE5D,QAAO;;AAGT,MAAM,6BACJ,SACA,OACA,eAC6B;CAC7B,MAAM,iBAAiB,sBACrB,OACA,QAAQ,SACR,WACD;AAED,KAAI,OAAO,QAAQ,YAAY,SAC7B,QAAO,CAAC,cAAc,aAAa,QAAQ,SAAS,eAAe,CAAC;AAGtE,KAAI,CAAC,MAAM,QAAQ,QAAQ,QAAQ,CACjC,QAAO,EAAE;CAGX,MAAMD,QAAkC,EAAE;CAC1C,MAAMC,iBAA8C,EAAE;AAEtD,MAAK,MAAM,SAAS,QAAQ,SAAS;AACnC,MAAI,MAAM,SAAS,YAAY;AAC7B,uBAAoB,gBAAgB,OAAO;IACzC,MAAM;IACN,OAAO;IACR,CAAC;AACF,SAAM,KAAK,uBAAuB,MAAM,CAAC;AACzC;;AAGF,MAAI,MAAM,SAAS,cAAc,MAAM,WAAW;GAChD,MAAM,oBAAoB,wBAAwB,MAAM;AACxD,OAAI,mBAAmB;AACrB,wBAAoB,gBAAgB,OAAO;KACzC,MAAM;KACN,OAAO;KACR,CAAC;AACF,UAAM,KAAK,kBAAkB;AAC7B;;AAGF,OAAI,MAAM,UAAU,SAAS,IAAI,EAAE;AACjC,wBAAoB,gBAAgB,OAAO;KACzC,MAAM;KACN,OAAO;KACR,CAAC;AACF,UAAM,KAAK,uBAAuB,MAAM,CAAC;AACzC;;;EAIJ,MAAM,YAAY,+BAA+B,MAAM;AACvD,MAAI,UACF,gBAAe,KAAK,UAAU;;AAIlC,qBAAoB,gBAAgB,OAAO;EACzC,MAAM;EACN,OAAO;EACR,CAAC;AAEF,QAAO;;AAGT,MAAM,6BACJ,UACgC;AAChC,SAAQ,MAAM,MAAd;EACE,KAAK,OACH,QAAO,CAAC,kBAAkB,MAAM,KAAK,CAAC;EAExC,KAAK,QACH,QAAO,CAAC,mBAAmB,MAAM,CAAC;EAEpC,KAAK,WACH,QAAO,CAAC,kBAAkB,MAAM,CAAC;EAEnC,QACE,QAAO,EAAE;;;AAKf,MAAM,kCACJ,UACqC;AACrC,SAAQ,MAAM,MAAd;EACE,KAAK,OACH,QAAO,wBAAwB,MAAM,KAAK;EAE5C,QACE;;;AAKN,MAAM,uBACJ,gBACA,QACA,YACG;AACH,KAAI,eAAe,WAAW,EAC5B;CAGF,MAAM,iBAAiB,CAAC,GAAG,eAAe;AAE1C,QAAO,KAAK,cAAc,QAAQ,MAAM,gBAAgB,QAAQ,MAAM,CAAC;AACvE,gBAAe,SAAS;;AAG1B,MAAM,iBACJ,MACA,SACA,WAC0B;CAC1B,MAAM;CACN;CACA;CACA,GAAI,SAAS,eAAe,QAAQ,EAAE,OAAO,GAAG,EAAE;CACnD;AAED,MAAM,yBACJ,QACA,SACA,eAC8C;AAC9C,KAAI,CAAC,WACH;AAGF,KAAI,OAAO,YAAY,SACrB,QAAO;AAGT,KAAI,CAAC,MAAM,QAAQ,QAAQ,CACzB;AAIF,KAAI,CADY,QAAQ,MAAM,UAAU,MAAM,SAAS,OAAO,CAE5D;AAIF,QADmB,QAAQ,MAAM,UAAU,MAAM,SAAS,WAAW,GACjD,eAAe;;AAGrC,MAAM,oBAAoB,UAA2B;AAEnD,QADoB,uBAAuB,MAAM,CAC9B,SAAS,0BAA0B;;AAGxD,MAAM,qBAAqB,UAAqC;CAC9D,MAAM;CACN;CACD;AAED,MAAM,2BAA2B,UAAqC;CACpE,MAAM;CACN;CACD;AAED,MAAM,sBACJ,WACwB;CACxB,MAAM;CACN,WAAW,QAAQ,MAAM,OAAO,WAAW,UAAU,MAAM,OAAO;CAClE,QAAQ;CACT;AAED,MAAM,qBACJ,WACuB;CACvB,MAAM;CACN,WAAW,QAAQ,MAAM,OAAO,WAAW,UAAU,MAAM,OAAO;CAClE,UAAU,MAAM,SAAS;CAC1B;AAED,MAAM,0BACJ,UAC2B;CAI3B,MAAM,EAAE,kBAAkB,OAAO,wBAAwB,MAAM,UAAU;CACzE,MAAM,WAAW,MAAM,aAAaJ,kBAAgB,KAAK,MAAM;AAC/D,QAAO;EACL;EACA,MAAM;EACN,SAAS,WAAW,CAAC;GAAE,MAAM;GAAgB,MAAM;GAAU,CAAC,GAAG,EAAE;EACnE,mBAAmB;EACpB;;AAGH,MAAM,2BACJ,UACwC;CACxC,MAAM,aAAa,iCAAiC,MAAM,UAAU;AACpE,KAAI,CAAC,WACH;AAGF,QAAO;EACL,IAAI,WAAW;EACf,MAAM;EACN,mBAAmB,WAAW;EAC/B;;AAGH,MAAM,2BACJ,cAC6C;CAC7C,MAAM,aAAa,UAAU,YAAY,IAAI;AAE7C,KAAI,cAAc,KAAK,eAAe,UAAU,SAAS,EACvD,QAAO;EAAE,kBAAkB;EAAW,IAAI;EAAI;AAGhD,QAAO;EACL,kBAAkB,UAAU,MAAM,GAAG,WAAW;EAChD,IAAI,UAAU,MAAM,aAAa,EAAE;EACpC;;AAGH,MAAM,0BACJ,WACkC;CAClC,MAAM;CACN,SAAS,MAAM;CACf,MAAM,MAAM;CACZ,WAAW,KAAK,UAAU,MAAM,MAAM;CACtC,QAAQ;CACT;AAED,MAAM,4BACJ,WACoC;CACpC,MAAM;CACN,SAAS,MAAM;CACf,QAAQ,yBAAyB,MAAM,QAAQ;CAC/C,QAAQ,MAAM,WAAW,eAAe;CACzC;AAED,MAAM,yBACJ,QACA,UACkB;AAClB,KAAI,CAAC,OACH,QAAO;CAGT,MAAM,cAAc,uBAAuB,MAAM;AAEjD,KAAI,OAAO,WAAW,SACpB,QAAO,SAAS;CAGlB,MAAM,OAAO,OACV,KAAK,OAAO,UAAU;AACrB,MAAI,UAAU,EACZ,QAAO,MAAM,OAAO,SAAS,cAAc;AAE7C,SAAO,MAAM;GACb,CACD,KAAK,IAAI;AACZ,QAAO,KAAK,SAAS,IAAI,OAAO;;AAGlC,MAAM,yBACJ,UACuB;AACvB,KAAI,CAAC,SAAS,MAAM,WAAW,EAC7B,QAAO;AAGT,QAAO,MAAM,KAAK,UAAU;EAC1B,MAAM;EACN,MAAM,KAAK;EACX,YAAY,oBAAoB,KAAK,aAAa;EAClD,QAAQ;EACR,GAAI,KAAK,cAAc,EAAE,aAAa,KAAK,aAAa,GAAG,EAAE;EAC9D,EAAE;;AAGL,MAAM,8BACJ,WAC2C;AAC3C,KAAI,CAAC,OACH,QAAO;AAGT,SAAQ,OAAO,MAAf;EACE,KAAK,OACH,QAAO;EAET,KAAK,MACH,QAAO;EAET,KAAK,OACH,QAAO,OAAO,OAAO;GAAE,MAAM;GAAY,MAAM,OAAO;GAAM,GAAG;EAEjE,KAAK,OACH,QAAO;EAET,QACE,QAAO;;;AAKb,MAAa,uCACX,aACsB;CACtB,MAAM,gBAAgB,4BAA4B,SAAS,OAAO;CAClE,MAAM,QAAQ,kBAAkB,SAAS;CACzC,IAAI,mBAAmB,sBAAsB,SAAS,YAAY;AAClE,KAAI,cAAc,SAAS,EACzB,oBAAmB;CAGrB,MAAM,aAAa,uBAAuB,SAAS;AAEnD,QAAO;EACL,IAAI,SAAS;EACb,MAAM;EACN,MAAM;EACN,SAAS;EACT,OAAO,SAAS;EAChB,aAAa;EACb,eAAe;EACf;EACD;;AAGH,MAAM,+BACJ,WAC0C;CAC1C,MAAMK,gBAAuD,EAAE;AAE/D,MAAK,MAAM,QAAQ,OACjB,SAAQ,KAAK,MAAb;EACE,KAAK,aAAa;GAChB,MAAM,eAAe,qBAAqB,KAAK;AAC/C,OAAI,aAAa,SAAS,EACxB,eAAc,KAAK;IACjB,MAAM;IACN,UAAU;IACV,YAAY,KAAK,qBAAqB,MAAM,MAAM,KAAK;IACxD,CAAC;AAEJ;;EAEF,KAAK,iBAAiB;GACpB,MAAM,eAAe,0BAA0B,KAAK;AACpD,OAAI,aACF,eAAc,KAAK,aAAa;AAElC;;EAEF,KAAK,WAAW;GACd,MAAM,eAAe,0BAA0B,KAAK,QAAQ;AAC5D,OAAI,aAAa,SAAS,EACxB,eAAc,KAAK;IAAE,MAAM;IAAQ,MAAM;IAAc,CAAC;AAE1D;;EAEF,KAAK,cAAc;GACjB,MAAM,kBAAkB,8BAA8B,KAAK;AAC3D,OAAI,gBACF,eAAc,KAAK,gBAAgB;AAErC;;EAEF,SAAS;GAEP,MAAM,eAAe,0BAClB,KAAyD,QAC3D;AACD,OAAI,aAAa,SAAS,EACxB,eAAc,KAAK;IAAE,MAAM;IAAQ,MAAM;IAAc,CAAC;;;AAMhE,QAAO;;AAGT,MAAM,6BACJ,YACW;AACX,KAAI,CAAC,MAAM,QAAQ,QAAQ,CACzB,QAAO;CAGT,IAAI,aAAa;AAEjB,MAAK,MAAM,SAAS,SAAS;AAC3B,MAAI,qBAAqB,MAAM,EAAE;AAC/B,iBAAc,MAAM;AACpB;;AAGF,MAAI,wBAAwB,MAAM,EAAE;AAClC,iBAAc,MAAM;AACpB;;AAGF,MAAI,OAAQ,MAA6B,SAAS,UAAU;AAC1D,iBAAe,MAA2B;AAC1C;;AAGF,MAAI,OAAQ,MAAkC,cAAc,UAAU;AACpE,iBAAe,MAAgC;AAC/C;;;AAIJ,QAAO;;AAGT,MAAM,wBAAwB,SAA0C;CACtE,MAAMC,WAA0B,EAAE;CAElC,MAAM,qBAAqB,WAA2C;AACpE,MAAI,CAAC,MAAM,QAAQ,OAAO,CACxB;AAGF,OAAK,MAAM,SAAS,OAClB,KAAI,OAAO,MAAM,SAAS,UAAU;AAClC,YAAS,KAAK,MAAM,KAAK;AACzB;;;AAMN,KAAI,CAAC,KAAK,WAAW,KAAK,QAAQ,WAAW,EAC3C,QAAON;AAGT,mBAAkB,KAAK,QAAQ;AAE/B,QAAO,SAAS,KAAK,GAAG,CAAC,MAAM;;AAGjC,MAAM,6BACJ,SACiC;CACjC,MAAM,SAAS,KAAK;AACpB,KAAI,CAAC,KAAK,QAAQ,CAAC,OACjB,QAAO;CAGT,MAAM,QAAQ,2BAA2B,KAAK,UAAU;AAExD,QAAO;EACL,MAAM;EACN,IAAI;EACJ,MAAM,KAAK;EACX;EACD;;AAGH,MAAM,iCACJ,SAC0C;AAC1C,KAAI,CAAC,KAAK,MAAM,CAAC,KAAK,kBACpB,QAAO;AAGT,QAAO;EACL,MAAM;EACN,UAAUA;EACV,WAAW,iCAAiC;GAC1C,IAAI,KAAK;GACT,mBAAmB,KAAK;GACzB,CAAC;EACH;;AAGH,MAAM,8BACJ,iBAC4B;AAC5B,KAAI,OAAO,iBAAiB,YAAY,aAAa,MAAM,CAAC,WAAW,EACrE,QAAO,EAAE;AAGX,KAAI;EACF,MAAMO,SAAkB,KAAK,MAAM,aAAa;AAEhD,MAAI,MAAM,QAAQ,OAAO,CACvB,QAAO,EAAE,WAAW,QAAQ;AAG9B,MAAI,UAAU,OAAO,WAAW,SAC9B,QAAO;UAEF,OAAO;AACd,UAAQ,KAAK,2CAA2C;GACtD;GACA;GACD,CAAC;;AAGJ,QAAO,EAAE,eAAe,cAAc;;AAGxC,MAAM,yBACJ,eAC0C;AAC1C,KAAI,CAAC,WACH,QAAO,EAAE;AAGX,QAAO,CACL;EACE,MAAM;EACN,MAAM;EACP,CACF;;AAGH,MAAM,0BACJ,aACqC;CACrC,MAAM,EAAE,QAAQ,oBAAoB,sBAAsB;AAE1D,KAAI,WAAW,aAAa;AAC1B,MAAI,SAAS,OAAO,MAAM,SAAS,KAAK,SAAS,gBAAgB,CAC/D,QAAO;AAET,SAAO;;AAGT,KAAI,WAAW,cAAc;AAC3B,MAAI,mBAAmB,WAAW,oBAChC,QAAO;AAET,MAAI,mBAAmB,WAAW,iBAChC,QAAO;;AAIX,QAAO;;AAGT,MAAM,qBACJ,aAC+B;CAC/B,MAAM,cAAc,SAAS,OAAO,gBAAgB;CACpD,MAAM,eAAe,SAAS,OAAO,iBAAiB;CACtD,MAAM,oBAAoB,SAAS,OAAO,sBAAsB;AAEhE,QAAO;EACL,cAAc,eAAe,qBAAqB;EAClD,eAAe;EACf,GAAI,SAAS,OAAO,sBAAsB,kBAAkB,UAAa,EACvE,yBACE,SAAS,MAAM,qBAAqB,eACvC;EACF;;AAGH,MAAM,YAAY,UAChB,OAAO,UAAU,YAAY,UAAU;AAEzC,MAAM,wBACJ,UAEA,SAAS,MAAM,IACZ,UAAU,SACT,MAA6B,SAAS;AAE5C,MAAM,2BACJ,UAEA,SAAS,MAAM,IACZ,UAAU,SACT,MAA6B,SAAS;AAE5C,MAAM,4BACJ,YACyC;AACzC,KAAI,OAAO,YAAY,SACrB,QAAO;AAGT,KAAI,MAAM,QAAQ,QAAQ,EAAE;EAC1B,MAAMC,SAAsC,EAAE;AAC9C,OAAK,MAAM,SAAS,QAClB,SAAQ,MAAM,MAAd;GACE,KAAK;AACH,WAAO,KAAK,kBAAkB,MAAM,KAAK,CAAC;AAC1C;GAEF,KAAK;AACH,WAAO,KAAK,mBAAmB,MAAM,CAAC;AACtC;GAEF,KAAK;AACH,WAAO,KAAK,kBAAkB,MAAM,CAAC;AACrC;GAEF,KAAK;AACH,WAAO,KAAK,kBAAkB,QAAQ,MAAM,UAAU,SAAS,CAAC;AAChE;GAEF,QACE;;AAIN,SAAO;;AAGT,QAAO;;;;;AC3wBT,MAAM,2CAA2C;AAEjD,IAAM,uCAAN,cAAmD,MAAM;CACvD,YAAY,SAAiB;AAC3B,QAAM,QAAQ;AACd,OAAK,OAAO;;;AAIhB,MAAM,4BACJ,eACA,UAIG;CACH,IAAI,QAAQ;AAEZ,MAAK,MAAM,QAAQ,OAAO;AACxB,MAAI,SAAS,QAAQ,SAAS,QAAQ,SAAS,KAAM;AACnD,YAAS;AACT,OAAI,QAAQ,yCACV,QAAO;IAAE,WAAW;IAAO,UAAU;IAAM;AAE7C;;AAGF,MAAI,SAAS,IACX,SAAQ;;AAIZ,QAAO;EAAE,WAAW;EAAO,UAAU;EAAO;;AAoB9C,MAAa,oCAA0D;CACrE,kBAAkB;CAClB,kBAAkB;CAClB,uBAAuB;CACvB,iCAAiB,IAAI,KAAK;CAC1B,4BAAY,IAAI,KAAK;CACrB,+BAAe,IAAI,KAAK;CACxB,gDAAgC,IAAI,KAAK;CAC1C;AAED,MAAa,iCACX,UACA,YACoC;AAEpC,SADkB,SAAS,MAC3B;EACE,KAAK,mBACH,QAAO,sBAAsB,UAAUC,QAAM;EAG/C,KAAK,6BACH,QAAOC,wBAAsB,UAAUD,QAAM;EAG/C,KAAK,wCACH,QAAO,gCAAgC,UAAUA,QAAM;EAGzD,KAAK,6BACH,QAAO,sBAAsB,UAAUA,QAAM;EAG/C,KAAK,uCACH,QAAO,+BAA+B,UAAUA,QAAM;EAGxD,KAAK,4BACH,QAAO,qBAAqB,UAAUA,QAAM;EAE9C,KAAK,4BACH,QAAOE,uBAAqB,UAAUF,QAAM;EAG9C,KAAK,yCACH,QAAO,iCAAiC,UAAUA,QAAM;EAG1D,KAAK,wCACH,QAAO,gCAAgC,UAAUA,QAAM;EAGzD,KAAK;EACL,KAAK,sBACH,QAAO,wBAAwB,UAAUA,QAAM;EAGjD,KAAK,kBACH,QAAO,qBAAqB,UAAUA,QAAM;EAG9C,KAAK,QACH,QAAO,iBAAiB,UAAUA,QAAM;EAG1C,QACE,QAAO,EAAE;;;AAMf,MAAM,yBACJ,UACA,YACoC;AACpC,QAAO,aAAaA,SAAO,SAAS,SAAS;;AAG/C,MAAMC,2BACJ,UACA,YACoC;CACpC,MAAME,WAAS,IAAI,OAAiC;CACpD,MAAM,sBAAsB,2BAA2B,SAAS;AAChE,KAAI,CAAC,oBACH,QAAOA;CAGT,MAAM,EAAE,aAAa,YAAY,MAAM,qBACrC;CACF,MAAM,aAAa,sBAAsBH,SAAO;EAC9C;EACA;EACA;EACA;EACD,CAAC;AAEF,KAAI,qBAAqB,UAAa,iBAAiB,SAAS,GAAG;AACjE,WAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,OAAO;IACL,MAAM;IACN,cAAc;IACf;GACF,CAAC;AACF,UAAM,cAAc,IAAI,WAAW;;AAGrC,QAAOG;;AAGT,MAAMD,0BACJ,UACA,YACoC;CACpC,MAAMC,WAAS,IAAI,OAAiC;CACpD,MAAM,OAAO,SAAS;CACtB,MAAM,WAAW,KAAK;CACtB,MAAM,cAAc,SAAS;AAE7B,KAAI,aAAa,cAAc;AAC7B,MAAI,CAAC,KAAK,MAAM,CAAC,KAAK,kBACpB,QAAOA;EAGT,MAAMC,eAAa,0BAA0BJ,SAAO,aAAaG,SAAO;AAExE,MAAI,CAACH,QAAM,cAAc,IAAII,aAAW,CACtC,UAAO,KAAK;GACV,MAAM;GACN,OAAOA;GACP,OAAO;IACL,MAAM;IACN,UAAUC;IACX;GACF,CAAC;AAGJ,WAAO,KAAK;GACV,MAAM;GACN,OAAOD;GACP,OAAO;IACL,MAAM;IACN,WAAW,iCAAiC;KAC1C,IAAI,KAAK;KACT,mBAAmB,KAAK;KACzB,CAAC;IACH;GACF,CAAC;AACF,UAAM,cAAc,IAAIA,aAAW;AACnC,SAAOD;;AAGT,KAAI,aAAa,YACf,QAAOA;CAGT,MAAM,aAAa,0BAA0BH,SAAO,aAAaG,SAAO;CACxE,MAAM,aAAa,KAAK,qBAAqB,MAAM,MAAM,KAAK;AAC9D,KAAI,WAAW;AAEb,MAAI,CAAC,KAAK,WAAW,KAAK,QAAQ,WAAW,EAC3C,UAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,OAAO;IACL,MAAM;IACN,UAAUE;IACX;GACF,CAAC;AAGJ,WAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,OAAO;IACL,MAAM;IACN;IACD;GACF,CAAC;AACF,UAAM,cAAc,IAAI,WAAW;;AAGrC,QAAOF;;AAGT,MAAM,oCACJ,UACA,YACoC;CACpC,MAAMA,WAAS,IAAI,OAAiC;CACpD,MAAM,cAAc,SAAS;CAC7B,MAAM,YAAY,SAAS;AAE3B,KAAI,CAAC,UACH,QAAOA;CAGT,MAAM,aAAa,sBAAsBH,SAAO;EAC9C;EACA;EACD,CAAC;CAEF,MAAM,oBACJA,QAAM,+BAA+B,IAAI,YAAY;AACvD,KAAI,CAAC,kBACH,QAAO,2CACL,IAAI,qCACF,0EACD,EACDA,SACAG,SACD;CAKH,MAAM,EAAE,WAAW,aAAa,yBAC9B,kBAAkB,4BAClB,UACD;AACD,KAAI,SACF,QAAO,2CACL,IAAI,qCACF,oGACD,EACDH,SACAG,SACD;AAEH,mBAAkB,6BAA6B;AAE/C,UAAO,KAAK;EACV,MAAM;EACN,OAAO;EACP,OAAO;GACL,MAAM;GACN,cAAc;GACf;EACF,CAAC;AACF,SAAM,cAAc,IAAI,WAAW;AAEnC,QAAOA;;AAGT,MAAM,mCACJ,UACA,YACoC;CACpC,MAAMA,WAAS,IAAI,OAAiC;CACpD,MAAM,cAAc,SAAS;CAC7B,MAAM,aAAa,sBAAsBH,SAAO;EAC9C;EACA;EACD,CAAC;CAEF,MAAM,iBACJ,OAAO,SAAS,cAAc,WAAW,SAAS,YAAY;AAEhE,KAAI,CAACA,QAAM,cAAc,IAAI,WAAW,IAAI,gBAAgB;AAC1D,WAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,OAAO;IACL,MAAM;IACN,cAAc;IACf;GACF,CAAC;AACF,UAAM,cAAc,IAAI,WAAW;;AAGrC,SAAM,+BAA+B,OAAO,YAAY;AACxD,QAAOG;;AAGT,MAAM,yBACJ,UACA,YACoC;CACpC,MAAMA,WAAS,IAAI,OAAiC;CACpD,MAAM,cAAc,SAAS;CAC7B,MAAM,eAAe,SAAS;CAC9B,MAAM,YAAY,SAAS;AAE3B,KAAI,CAAC,UACH,QAAOA;CAGT,MAAM,aAAa,sBAAsBH,SAAO;EAC9C;EACA;EACA;EACD,CAAC;AAEF,UAAO,KAAK;EACV,MAAM;EACN,OAAO;EACP,OAAO;GACL,MAAM;GACN,MAAM;GACP;EACF,CAAC;AACF,SAAM,cAAc,IAAI,WAAW;AAEnC,QAAOG;;AAGT,MAAM,mCACJ,UACA,YACoC;CACpC,MAAM,cAAc,SAAS;CAC7B,MAAM,YAAY,SAAS;CAC3B,MAAMA,WAAS,IAAI,OAAiC;CACpD,MAAM,aAAa,0BAA0BH,SAAO,aAAaG,SAAO;AAExE,UAAO,KAAK;EACV,MAAM;EACN,OAAO;EACP,OAAO;GACL,MAAM;GACN,UAAU;GACX;EACF,CAAC;AACF,SAAM,cAAc,IAAI,WAAW;AAEnC,QAAOA;;AAGT,MAAM,kCACJ,UACA,YACoC;CACpC,MAAM,cAAc,SAAS;CAC7B,MAAM,OAAO,SAAS;CACtB,MAAMA,WAAS,IAAI,OAAiC;CACpD,MAAM,aAAa,0BAA0BH,SAAO,aAAaG,SAAO;AAExE,KAAI,QAAQ,CAACH,QAAM,cAAc,IAAI,WAAW,CAC9C,UAAO,KAAK;EACV,MAAM;EACN,OAAO;EACP,OAAO;GACL,MAAM;GACN,UAAU;GACX;EACF,CAAC;AAGJ,QAAOG;;AAGT,MAAM,wBACJ,UACA,YACoC;CACpC,MAAMA,WAAS,IAAI,OAAiC;CACpD,MAAM,cAAc,SAAS;CAC7B,MAAM,eAAe,SAAS;CAC9B,MAAM,OAAO,SAAS;CAEtB,MAAM,aAAa,sBAAsBH,SAAO;EAC9C;EACA;EACA;EACD,CAAC;AAEF,KAAI,QAAQ,CAACA,QAAM,cAAc,IAAI,WAAW,CAC9C,UAAO,KAAK;EACV,MAAM;EACN,OAAO;EACP,OAAO;GACL,MAAM;GACN;GACD;EACF,CAAC;AAGJ,QAAOG;;AAGT,MAAM,2BACJ,UACA,YACoC;CACpC,MAAM,WAAW,SAAS;CAC1B,MAAMA,WAAS,IAAI,OAAiC;AAEpD,oBAAmBH,SAAOG,SAAO;CACjC,MAAM,YAAY,oCAAoC,SAAS;AAC/D,UAAO,KACL;EACE,MAAM;EACN,OAAO;GACL,aAAa,UAAU;GACvB,eAAe,UAAU;GAC1B;EACD,OAAO,UAAU;EAClB,EACD,EAAE,MAAM,gBAAgB,CACzB;AACD,SAAM,mBAAmB;AACzB,QAAOA;;AAGT,MAAM,wBACJ,UACA,YACoC;CACpC,MAAM,WAAW,SAAS;CAC1B,MAAMA,WAAS,IAAI,OAAiC;AACpD,oBAAmBH,SAAOG,SAAO;CAEjC,MAAM,UACJ,SAAS,OAAO,WAAW;AAE7B,UAAO,KAAK,gBAAgB,QAAQ,CAAC;AACrC,SAAM,mBAAmB;AAEzB,QAAOA;;AAGT,MAAM,oBACJ,UACA,YACoC;CACpC,MAAM,UACJ,OAAO,SAAS,YAAY,WAC1B,SAAS,UACT;AAEJ,SAAM,mBAAmB;AACzB,QAAO,CAAC,gBAAgB,QAAQ,CAAC;;AAGnC,MAAM,8CACJ,OACA,SACA,WAA0C,EAAE,KACR;CACpC,MAAM,SAAS,MAAM;AAErB,oBAAmBH,SAAOG,SAAO;AACjC,SAAM,mBAAmB;AAEzB,UAAO,KAAK,gBAAgB,OAAO,CAAC;AAEpC,QAAOA;;AAGT,MAAM,gBACJ,SACA,aACoC;AACpC,SAAM,mBAAmB;CACzB,MAAM,oBAAoB,SAAS,OAAO,sBAAsB;CAChE,MAAM,eACH,SAAS,OAAO,gBAAgB,MAAM,qBAAqB;AAC9D,QAAO,CACL;EACE,MAAM;EACN,SAAS;GACP,IAAI,SAAS;GACb,MAAM;GACN,MAAM;GACN,SAAS,EAAE;GACX,OAAO,SAAS;GAChB,aAAa;GACb,eAAe;GACf,OAAO;IACL,cAAc;IACd,eAAe;IACf,yBAAyB,qBAAqB;IAC/C;GACF;EACF,CACF;;AAGH,MAAM,yBACJ,SACA,WAKW;CACX,MAAM,EAAE,aAAa,cAAc,qBAAW;CAC9C,MAAM,MAAM,YAAY,aAAa,aAAa;CAClD,IAAI,aAAaH,QAAM,gBAAgB,IAAI,IAAI;AAE/C,KAAI,eAAe,QAAW;AAC5B,eAAaA,QAAM;AACnB,UAAM,yBAAyB;AAC/B,UAAM,gBAAgB,IAAI,KAAK,WAAW;;AAG5C,KAAI,CAACA,QAAM,WAAW,IAAI,WAAW,EAAE;AACrC,kBAAgBA,SAAOG,SAAO;AAC9B,WAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,eAAe;IACb,MAAM;IACN,MAAM;IACP;GACF,CAAC;AACF,UAAM,WAAW,IAAI,WAAW;;AAGlC,QAAO;;AAGT,MAAM,6BACJ,SACA,aACA,aACW;CAGX,MAAM,MAAM,YAAY,aADH,EAC6B;CAClD,IAAI,aAAaH,QAAM,gBAAgB,IAAI,IAAI;AAE/C,KAAI,eAAe,QAAW;AAC5B,eAAaA,QAAM;AACnB,UAAM,yBAAyB;AAC/B,UAAM,gBAAgB,IAAI,KAAK,WAAW;;AAG5C,KAAI,CAACA,QAAM,WAAW,IAAI,WAAW,EAAE;AACrC,kBAAgBA,SAAOG,SAAO;AAC9B,WAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,eAAe;IACb,MAAM;IACN,UAAU;IACX;GACF,CAAC;AACF,UAAM,WAAW,IAAI,WAAW;;AAGlC,QAAO;;AAGT,MAAM,oBACJ,SACA,YACA,aACG;AACH,KAAI,CAACH,QAAM,WAAW,IAAI,WAAW,CACnC;AAGF,UAAO,KAAK;EAAE,MAAM;EAAsB,OAAO;EAAY,CAAC;AAC9D,SAAM,WAAW,OAAO,WAAW;AACnC,SAAM,cAAc,OAAO,WAAW;;AAGxC,MAAM,mBACJ,SACA,aACG;AACH,MAAK,MAAM,cAAcA,QAAM,WAC7B,kBAAiBA,SAAO,YAAYG,SAAO;;AAI/C,MAAM,sBACJ,SACA,aACG;AACH,iBAAgBH,SAAOG,SAAO;AAE9B,SAAM,+BAA+B,OAAO;;AAG9C,MAAa,mBAAmB,aAA+C;CAC7E,MAAM;CACN,OAAO;EACL,MAAM;EACN;EACD;CACF;AAED,MAAM,eAAe,aAAqB,iBACxC,GAAG,YAAY,GAAG;AAEpB,MAAM,yBACJ,SACA,WAMW;CACX,MAAM,EAAE,aAAa,YAAY,MAAM,qBAAW;CAElD,IAAI,oBAAoBH,QAAM,+BAA+B,IAAI,YAAY;AAE7E,KAAI,CAAC,mBAAmB;EACtB,MAAMI,eAAaJ,QAAM;AACzB,UAAM,yBAAyB;EAE/B,MAAM,qBAAqB,cAAc,aAAaI;AAGtD,sBAAoB;GAClB;GACA,YAAY;GACZ,MALmB,QAAQ;GAM3B,4BAA4B;GAC7B;AAED,UAAM,+BAA+B,IAAI,aAAa,kBAAkB;;CAG1E,MAAM,EAAE,eAAe;AAEvB,KAAI,CAACJ,QAAM,WAAW,IAAI,WAAW,EAAE;AACrC,kBAAgBA,SAAOG,SAAO;AAC9B,WAAO,KAAK;GACV,MAAM;GACN,OAAO;GACP,eAAe;IACb,MAAM;IACN,IAAI,kBAAkB;IACtB,MAAM,kBAAkB;IACxB,OAAO,EAAE;IACV;GACF,CAAC;AACF,UAAM,WAAW,IAAI,WAAW;;AAGlC,QAAO;;AAUT,MAAM,8BACJ,aACoC;CACpC,MAAM,OAAO,SAAS;AAEtB,KADiB,KAAK,SACL,gBACf;CAGF,MAAM,cAAc,SAAS;CAC7B,MAAM,aAAa,KAAK;CACxB,MAAM,OAAO,KAAK;CAClB,MAAM,mBAAmB,KAAK;AAC9B,QAAO;EACL;EACA;EACA;EACA;EACD;;;;;AC7tBH,MAAa,8BACX,YACqD;CACrD,MAAM,SAAS,eAAe,QAAQ;CACtC,MAAM,YAAY,kBAAkB,QAAQ,GAAG,UAAU;AAEzD,QAAO;EAAE;EAAQ;EAAW;;AAG9B,MAAa,qBAAqB,YAAuC;CAEvE,MAAM,WAAW,gBAAgB,QAAQ,CAAC,GAAG,GAAG;AAChD,KAAI,CAAC,SACH,QAAO;AAET,KAAI,EAAE,UAAU,aAAa,CAAC,SAAS,KACrC,QAAO;AAIT,SADE,OAAO,SAAS,SAAS,WAAW,SAAS,KAAK,aAAa,GAAG,QACpD;;AAGlB,MAAa,kBAAkB,YAAuC;AAEpE,QADe,gBAAgB,QAAQ,CACzB,MAAM,SAAS,sBAAsB,KAAK,CAAC;;AAG3D,MAAa,oCACX,oBACW;AACX,KAAI,OAAO,oBAAoB,YAAY,kBAAkB,EAC3D,QAAO,KAAK,MAAM,kBAAkB,GAAI;AAG1C,QAAO;;AAGT,MAAM,qCACJ,qBACmD,CACnD;CACE,MAAM;CACN,mBAAmB;CACpB,CACF;AAED,MAAa,sCACX,SACA,oBACS;AACT,KAAI,QAAQ,uBAAuB,OACjC;AAGF,KAAI,CAAC,qCAAqC,QAAQ,MAAM,CACtD;AAGF,SAAQ,qBAAqB,kCAC3B,iCAAiC,gBAAgB,CAClD;;AAGH,MAAa,kCACX,YACS;AACT,KAAI,CAAC,MAAM,QAAQ,QAAQ,MAAM,IAAI,QAAQ,MAAM,WAAW,EAC5D;CAGF,MAAM,+BAA+B,gCACnC,QAAQ,MACT;AAED,KAAI,iCAAiC,OACnC;AAGF,SAAQ,QAAQ,QAAQ,MAAM,MAAM,6BAA6B;;AAGnE,MAAM,mCACJ,UACuB;AACvB,MAAK,IAAI,QAAQ,MAAM,SAAS,GAAG,SAAS,GAAG,SAAS,EACtD,KAAI,sBAAsB,MAAM,OAAO,CACrC,QAAO;;AAOb,MAAM,yBAAyB,UAAsC;AACnE,QACE,UAAU,SACP,OAAO,MAAM,SAAS,YACtB,MAAM,SAAS;;AAItB,MAAM,mBACJ,YAC6B;CAC7B,MAAMG,SAAmC,EAAE;CAE3C,MAAM,EAAE,UAAU;AAElB,KAAI,MAAM,QAAQ,MAAM,CACtB,QAAO,KAAK,GAAG,MAAM;AAGvB,QAAO;;AAGT,MAAM,yBAAyB,UAA4B;AACzD,KAAI,CAAC,MAAO,QAAO;AAEnB,KAAI,MAAM,QAAQ,MAAM,CACtB,QAAO,MAAM,MAAM,UAAU,sBAAsB,MAAM,CAAC;AAG5D,KAAI,OAAO,UAAU,SACnB,QAAO;CAGT,MAAM,SAAS;AAIf,MAFE,OAAO,OAAO,SAAS,WAAW,OAAO,KAAK,aAAa,GAAG,YAEnD,cACX,QAAO;AAGT,KAAI,MAAM,QAAQ,OAAO,QAAQ,CAC/B,QAAO,OAAO,QAAQ,MAAM,UAAU,sBAAsB,MAAM,CAAC;AAGrE,QAAO;;;;;AC1HT,MAAM,4BAA4B;AAElC,MAAM,wBAAwB,IAAI,IAAI;CACpC;CACA;CAH6B;CAK9B,CAAC;AAEF,MAAM,4BACJ,qBACA,UACA,WACuB;CACvB,MAAM,qBAAqB,UAAU,SAAS;AAE9C,KAAI,qBAAqB;EASvB,MAAM,sBAAsB,CAAC,GARR,oBAClB,MAAM,IAAI,CACV,KAAK,SAAS,KAAK,MAAM,CAAC,CAC1B,QAAQ,SAAS,KAAK,SAAS,EAAE,CACjC,QAAQ,SAAS,sBAAsB,IAAI,KAAK,CAAC,CAIP;AAC7C,MAAI,oBAAoB,SAAS,EAC/B,QAAO,oBAAoB,KAAK,IAAI;AAGtC;;AAGF,KAAI,UAAU,iBAAiB,CAAC,mBAC9B,QAAO;;AAMX,MAAa,iBAAiB,OAC5B,SACA,qBACA,YAMkC;AAClC,KAAI,CAAC,MAAM,aAAc,OAAM,IAAI,MAAM,0BAA0B;CAEnE,MAAM,eAAe,QAAQ,SAAS,MAAM,YAAY;AACtD,MAAI,CAAC,MAAM,QAAQ,QAAQ,QAAQ,CAAE,QAAO;AAC5C,SAAO,QAAQ,QAAQ,MACpB,UACC,MAAM,SAAS,WACX,MAAM,SAAS,iBACd,MAAM,QAAQ,MAAM,QAAQ,IAC5B,MAAM,QAAQ,MAAM,UAAU,MAAM,SAAS,QAAQ,CAC7D;GACD;CAEF,IAAI,oBAAoB;CACxB,MAAM,cAAc,QAAQ,SAAS,GAAG,GAAG;AAC3C,KAAI,aAAa,SAAS,OACxB,qBACE,MAAM,QAAQ,YAAY,QAAQ,GAChC,YAAY,QAAQ,MAAM,UAAU,MAAM,SAAS,cAAc,GACjE;CAGN,MAAMC,UAAkC;EACtC,GAAG,eAAe,OAAO,QAAQ,WAAW,aAAa;EACzD,eAAe,oBAAoB,SAAS;EAC7C;AAED,2BACE,QAAQ,WACR,QAAQ,QAAQ,eAAe,EAC/B,QACD;AAED,mBAAkB,SAAS,QAAQ,YAAY;CAE/C,MAAM,EAAE,kBAAkB,cAAc,oBACtC,QAAQ,UAAU,QACnB;AAED,KAAI,oBAAoB,UACtB,4BAA2B,QAAQ;CAIrC,MAAM,gBAAgB,yBACpB,qBACA,QAAQ,UACR,QAAQ,MACT;AACD,KAAI,cACF,SAAQ,oBAAoB;AAG9B,SAAQ,IAAI,cAAc,QAAQ,QAAQ;CAE1C,MAAM,WAAW,MAAM,MAAM,GAAG,eAAe,MAAM,CAAC,eAAe;EACnE,QAAQ;EACR;EACA,MAAM,KAAK,UAAU,QAAQ;EAC9B,CAAC;AAEF,sBAAqB,SAAS,QAAQ;AAEtC,KAAI,CAAC,SAAS,IAAI;AAChB,UAAQ,MAAM,6BAA6B,SAAS;AACpD,QAAM,IAAI,UAAU,6BAA6B,SAAS;;AAG5D,KAAI,QAAQ,OACV,QAAO,OAAO,SAAS;AAGzB,QAAQ,MAAM,SAAS,MAAM;;;;;AC1H/B,MAAa,+BAA+B;AAE5C,MAAM,wBAAwB;AAC9B,MAAM,2BAA2B;AACjC,MAAM,kCACJ;AACF,MAAM,uBAAuB;AAQ7B,MAAM,2BAA2B,YAAsC;AACrE,KAAI,QAAQ,SAAS,OACnB,QAAO;AAGT,KAAI,OAAO,QAAQ,YAAY,SAC7B,QAAO,QAAQ;AAGjB,QAAO,QAAQ,QACZ,QAAQ,UAAuC,MAAM,SAAS,OAAO,CACrE,KAAK,UACJ,MAAM,KAAK,WAAW,oBAAoB,GAAG,KAAK,MAAM,KACzD,CACA,QAAQ,SAAS,KAAK,SAAS,EAAE,CACjC,KAAK,OAAO;;AAGjB,MAAM,oBAAoB,gBAA2C;CACnE,MAAM,OAAO,wBAAwB,YAAY;AACjD,KAAI,CAAC,KACH,QAAO;AAGT,QACE,KAAK,SAAS,qBAAqB,IAChC,KAAK,SAAS,0BAA0B,IACxC,uBAAuB,MAAM,YAAY,KAAK,SAAS,QAAQ,CAAC;;AAIvE,MAAM,gCACJ,gBACY;CACZ,MAAM,OAAO,wBAAwB,YAAY;AACjD,QACE,QAAQ,KAAK,IACV,gCAAgC,MAAM,gBACvC,KAAK,WAAW,YAAY,CAC7B;;AAIL,MAAa,kBACX,qBACgB;CAChB,MAAM,cAAc,iBAAiB,SAAS,GAAG,GAAG;AACpD,KAAI,eAAe,iBAAiB,YAAY,CAC9C,QAAO;AAGT,KAAI,eAAe,6BAA6B,YAAY,CAC1D,QAAO;CAGT,MAAM,SAAS,iBAAiB;AAChC,KAAI,OAAO,WAAW,SAIpB,QAH+B,0BAA0B,MACtD,gBAAgB,OAAO,WAAW,YAAY,CAChD,GAC+B,kBAAkB;AAEpD,KAAI,CAAC,MAAM,QAAQ,OAAO,CAAE,QAAO;AASnC,KAP+B,OAAO,MACnC,QACC,OAAO,IAAI,SAAS,YACjB,0BAA0B,MAAM,gBACjC,IAAI,KAAK,WAAW,YAAY,CACjC,CACJ,CAEC,QAAO;AAGT,QAAO;;AAGT,MAAM,wBACJ,IACA,cAC6B;AAC7B,KAAI,OAAO,GAAG,YAAY,SACxB,QAAO;EAAE,GAAG;EAAI,SAAS,GAAG,GAAG,QAAQ,MAAM,UAAU;EAAQ;AAGjE,KAAI,WAAW,GAAG,CAChB,QAAO;AAET,QAAO;EACL,GAAG;EACH,SAAS,CAAC,GAAG,GAAG,SAAS,UAAU;EACpC;;AAGH,MAAM,yBACJ,IACA,eAC6B;AAC7B,KAAI,OAAO,GAAG,YAAY,UAAU;EAClC,MAAM,gBAAgB,WAAW,KAAK,OAAO,GAAG,KAAK,CAAC,KAAK,OAAO;AAClE,SAAO;GAAE,GAAG;GAAI,SAAS,GAAG,GAAG,QAAQ,MAAM;GAAiB;;AAGhE,KAAI,WAAW,GAAG,CAChB,QAAO;AAET,QAAO;EAAE,GAAG;EAAI,SAAS,CAAC,GAAG,GAAG,SAAS,GAAG,WAAW;EAAE;;AAG3D,MAAM,+BACJ,IACA,gBAC6B;AAC7B,KAAI,OAAO,GAAG,YAAY,SACxB,QAAO;EACL,GAAG;EACH,SAAS,CAAC;GAAE,MAAM;GAAQ,MAAM,GAAG;GAAS,EAAE,GAAG,YAAY;EAC9D;AAGH,QAAO;EACL,GAAG;EACH,SAAS,CAAC,GAAG,GAAG,SAAS,GAAG,YAAY;EACzC;;AAGH,MAAM,qBACJ,UACsC;AACtC,QAAO,MAAM,SAAS,WAAW,MAAM,SAAS;;AAGlD,MAAM,iCACJ,gBACkB;AAClB,QAAO,YAAY,SAAS,OAAO,UACjC,MAAM,YAAY,WAAW,MAAM,GAAG,EAAE,GAAG,CAAC,MAAM,CACnD;;AAGH,MAAM,mCACJ,aACA,iCACoC;AACpC,KAAI,6BAA6B,SAAS,EACxC,QAAO;AAGT,QAAO,YAAY,KAAK,OAAO,UAAU;EACvC,MAAM,qBAAqB,6BAA6B,IAAI,MAAM;AAClE,MAAI,CAAC,mBACH,QAAO;EAGT,MAAM,qBAAqB,CAAC,GAAG,mBAAmB,CAC/C,MAAM,MAAM,UAAU,KAAK,QAAQ,MAAM,MAAM,CAC/C,KAAK,EAAE,iBAAiB,WAAW;AAEtC,SAAO,4BAA4B,OAAO,mBAAmB;GAC7D;;AAGJ,MAAM,kCACJ,QACA,aACA,YAIS;CACT,MAAM,EAAE,sBAAsB;CAC9B,MAAM,4BACJ,QAAQ,6BAA6B;AAEvC,KAAI,YAAY,WAAW,EACzB;AAGF,KACE,kBAAkB,SAAS,KACxB,kBAAkB,WAAW,YAAY,QAC5C;AACA,OAAK,MAAM,CAAC,OAAO,oBAAoB,kBAAkB,SAAS,EAAE;GAClE,MAAMC,uBAAqB,OAAO,IAAI,gBAAgB;AACtD,OAAIA,sBAAoB;AACtB,yBAAmB,KAAK,YAAY,OAAO;AAC3C;;AAGF,UAAO,IAAI,iBAAiB,CAAC,YAAY,OAAO,CAAC;;AAEnD;;CAGF,MAAM,sBAAsB,0BAA0B,GAAG,GAAG;AAC5D,KAAI,wBAAwB,OAC1B;CAGF,MAAM,qBAAqB,OAAO,IAAI,oBAAoB;AAC1D,KAAI,oBAAoB;AACtB,qBAAmB,KAAK,GAAG,YAAY;AACvC;;AAGF,QAAO,IAAI,qBAAqB,CAAC,GAAG,YAAY,CAAC;;AAGnD,MAAM,yBACJ,eACY;AACZ,KAAI,OAAO,WAAW,YAAY,SAChC,QAAO,WAAW,QAAQ,WAAW,qBAAqB;AAG5D,KAAI,WAAW,QAAQ,MAAM,UAAU,MAAM,SAAS,WAAW,CAC/D,QAAO;AAGT,KAAI,WAAW,QAAQ,WAAW,EAChC,QAAO;CAGT,MAAM,aAAa,WAAW,QAAQ;AACtC,KAAI,WAAW,SAAS,OACtB,QAAO;AAGT,QAAO,WAAW,KAAK,WAAW,qBAAqB;;AAGzD,MAAM,+BACJ,YAKU;CACV,MAAMC,cAA+C,EAAE;CACvD,MAAMC,aAAwC,EAAE;CAChD,MAAMC,cAAwC,EAAE;AAEhD,MAAK,MAAM,CAAC,OAAO,UAAU,QAAQ,SAAS,EAAE;AAC9C,MAAI,MAAM,SAAS,eAAe;AAChC,eAAY,KAAK,MAAM;AACvB;;AAEF,MAAI,MAAM,SAAS,QAAQ;AACzB,cAAW,KAAK,MAAM;AACtB;;AAEF,MAAI,kBAAkB,MAAM,EAAE;AAC5B,eAAY,KAAK;IAAE,YAAY;IAAO;IAAO,CAAC;AAC9C;;AAGF,SAAO;;AAGT,QAAO;EACL;EACA;EACA;EACD;;AAGH,MAAM,kCACJ,aACA,gBACoC;AACpC,KAAI,YAAY,WAAW,EACzB,QAAO;CAGT,MAAM,iBAAiB,YAAY,QAChC,EAAE,iBAAiB,WAAW,SAAS,WACzC;CACD,MAAM,6BAA6B,8BAA8B,YAAY;CAC7E,MAAM,2BAA2B,2BAA2B,QAAQ,UAClE,sBAAsB,YAAY,OAAO,CAC1C;CAED,MAAM,+CAA+B,IAAI,KAGtC;CACH,IAAI,uBAAuB;CAC3B,IAAI,8BAA8B;AAIlC,KAAI,eAAe,SAAS,KAAK,yBAAyB,SAAS,GAAG;EACpE,MAAM,uBAAuB,KAAK,IAChC,yBAAyB,QACzB,eAAe,OAChB;EACD,MAAM,mBAAmB,eAAe,MAAM,GAAG,qBAAqB;EACtE,MAAM,wBAAwB,IAAI,IAChC,iBAAiB,KAAK,EAAE,YAAY,MAAM,CAC3C;EACD,MAAM,8BAA8B,yBAAyB,MAC3D,GACA,qBACD;EACD,MAAM,+BAA+B,IAAI,IAAI,4BAA4B;AAEzE,iCACE,8BACA,kBACA,EACE,mBAAmB,6BACpB,CACF;AACD,gCAA8B,2BAA2B,QACtD,UAAU,CAAC,6BAA6B,IAAI,MAAM,CACpD;AACD,yBAAuB,YAAY,QAChC,EAAE,YAAY,YACb,WAAW,SAAS,cAAc,CAAC,sBAAsB,IAAI,MAAM,CACtE;;AAIH,gCACE,8BACA,sBACA;EACE,mBAAmB;EACnB,2BAA2B;EAC5B,CACF;AAED,QAAO,gCACL,aACA,6BACD;;AAGH,MAAM,2BACJ,YAC4C;CAC5C,MAAM,mBAAmB,4BAA4B,QAAQ;AAC7D,KAAI,CAAC,iBACH,QAAO;CAGT,MAAM,EAAE,aAAa,YAAY,gBAAgB;AACjD,KACE,YAAY,WAAW,KACnB,WAAW,WAAW,KAAK,YAAY,WAAW,EAEtD,QAAO;CAGT,MAAM,oBACJ,WAAW,WAAW,IACpB,cACA,gBAAgB,aAAa,WAAW;AAE5C,QAAO,+BAA+B,mBAAmB,YAAY;;AAGvE,MAAM,mBACJ,aACA,eACoC;AACpC,KAAI,YAAY,WAAW,WAAW,OACpC,QAAO,YAAY,KAAK,IAAI,MAAM,qBAAqB,IAAI,WAAW,GAAG,CAAC;CAG5E,MAAM,YAAY,YAAY,SAAS;AACvC,QAAO,YAAY,KAAK,IAAI,MAC1B,MAAM,YAAY,sBAAsB,IAAI,WAAW,GAAG,GAC3D;;AAGH,MAAa,kCACX,qBACS;AACT,MAAK,MAAM,OAAO,iBAAiB,UAAU;AAC3C,MAAI,IAAI,SAAS,UAAU,CAAC,MAAM,QAAQ,IAAI,QAAQ,CAAE;AAKxD,MAAI,CAHqB,IAAI,QAAQ,MAClC,UAAU,MAAM,SAAS,iBAAiB,WAAW,MAAM,CAC7D,CACsB;AAEvB,MAAI,UAAU,IAAI,QAAQ,QACvB,UACC,MAAM,SAAS,UACZ,MAAM,KAAK,MAAM,KAAK,6BAC5B;;;AAIL,MAAa,4BACX,kBACA,YAGS;CACT,MAAM,mBAAmB,iBAAiB,SAAS,SAAS;AAE5D,MAAK,MAAM,CAAC,OAAO,QAAQ,iBAAiB,SAAS,SAAS,EAAE;AAC9D,MAAI,SAAS,mBAAmB,UAAU,iBAAkB;AAE5D,MAAI,IAAI,SAAS,UAAU,CAAC,MAAM,QAAQ,IAAI,QAAQ,CAAE;EAExD,MAAM,gBAAgB,wBAAwB,IAAI,QAAQ;AAC1D,MAAI,cACF,KAAI,UAAU;;;AAMpB,MAAa,oBAAoB,YAA4C;AAC3E,KAAI,CAAC,QAAQ,SAAS,QAAQ,MAAM,WAAW,EAC7C;AAGF,SAAQ,QAAQ,QAAQ,MAAM,SAAS,SAAS;AAC9C,MAAI,KAAK,SAAS,yBAAyB,CAAC,KAAK,cAC/C,QAAO,EAAE;AAGX,MAAI,KAAK,SAAS,yBAChB,QAAO,CACL;GACE,GAAG;GACH,aAAa;GACd,CACF;AAGH,SAAO,CAAC,KAAK;GACb;;AAGJ,MAAM,cAAc,UAAoC;AACtD,QACE,MAAM,QAAQ,MAAM,QAAQ,IACzB,MAAM,QAAQ,MAAM,MAAM,EAAE,SAAS,iBAAiB;;AAO7D,MAAM,qBAAqB,YAA4C;AACrE,KAAI,MAAM,QAAQ,QAAQ,OAAO,CAC/B,MAAK,MAAM,SAAS,QAAQ,QAAQ;EAClC,MAAM,cAAc;EAGpB,MAAM,eAAe,YAAY;AACjC,MAAI,gBAAgB,OAAO,iBAAiB,UAAU;GACpD,MAAM,EAAE,MAAO,GAAG,SAAS;AAC3B,eAAY,gBAAgB;;;;AAQpC,MAAM,iCACJ,YACS;AACT,MAAK,MAAM,OAAO,QAAQ,SACxB,KAAI,IAAI,SAAS,eAAe,MAAM,QAAQ,IAAI,QAAQ,CACxD,KAAI,UAAU,IAAI,QAAQ,QAAQ,UAAU;AAC1C,MAAI,MAAM,SAAS,WAAY,QAAO;AACtC,SACE,MAAM,YACH,MAAM,aAAa,iBACnB,MAAM,aACN,CAAC,MAAM,UAAU,SAAS,IAAI;GAEnC;;AAKR,MAAa,6BACX,SACA,kBACS;AACT,mBAAkB,QAAQ;AAC1B,+BAA8B,QAAQ;CAEtC,MAAM,cAAc,QAAQ,QAAQ,SAAS;CAI7C,MAAM,aAAa,QAAQ;CAC3B,MAAM,eAAe,YAAY,SAAS,SAAS,YAAY,SAAS;AAExE,KAAI,eAAe,aAAa,SAAS,qBAAqB,CAAC,cAAc;AAC3E,UAAQ,WAAW,EACjB,MAAM,YACP;AAED,MAAI,CAAC,YACH,SAAQ,SAAS,UAAU;AAE7B,MAAI,QAAQ,UAAU,kBACpB,SAAQ,SAAS,UAAU;EAE7B,IAAI,SAAS,2BAA2B,QAAQ,MAAM;AACtD,MAAI,WAAW,UAAU,WAAW,UAClC,UAAS;EAEX,MAAM,kBAAkB,cAAc,aAAa,SAAS;AAC5D,MAAI,mBAAmB,CAAC,gBAAgB,SAAS,OAAO,CACtD,UAAS,gBAAgB,GAAG,GAAG;AAEjC,UAAQ,gBAAgB,EACd,QACT;;;;;;ACjiBL,SAAS,gBAAgB,SAAsC;AAC7D,KAAI,CAACC,QAAM,iBACT,QAAO;AAGT,QAAO,OAAO,OAAOA,QAAM,UAAU,CAAC,MACnC,OAAO,GAAG,wBAAwBA,QAAM,kBAC1C;;AAGH,SAAgB,gCACd,OACA,SACiC;CACjC,MAAMC,WAA0C,EAAE;AAElD,KAAI,MAAM,QAAQ,WAAW,EAC3B,QAAOC;CAGT,MAAM,SAAS,MAAM,QAAQ;CAC7B,MAAM,EAAE,UAAU;AAElB,oBAAmBF,SAAOE,UAAQ,MAAM;AAExC,oBAAmB,OAAOF,SAAOE,SAAO;AAExC,eAAc,OAAOF,SAAOE,SAAO;AAEnC,iBAAgB,OAAOF,SAAOE,SAAO;AAErC,cAAa,QAAQF,SAAO;EAAE;EAAQ;EAAO,CAAC;AAE9C,QAAOE;;AAGT,SAAS,aACP,QACA,SACA,SAIA;CACA,MAAM,EAAE,kBAAQ,UAAU;AAC1B,KAAI,OAAO,iBAAiB,OAAO,cAAc,SAAS,GAAG;AAC3D,MAAIF,QAAM,kBAAkB;GAC1B,MAAM,gBAAgB,gBAAgBA,QAAM;AAC5C,WAAQ,OAAO,KAAK;IAClB,MAAM;IACN,OAAOA,QAAM;IACd,CAAC;AACF,WAAM,mBAAmB;AACzB,WAAM;AACN,OAAI,CAAC,cACH,uBAAsB,OAAO,OAAOE,UAAQF,QAAM;;AAItD,WAAO,KACL;GACE,MAAM;GACN,OAAO;IACL,aAAa,+BAA+B,OAAO,cAAc;IACjE,eAAe;IAChB;GACD,OAAO;IACL,eACG,MAAM,OAAO,iBAAiB,MAC5B,MAAM,OAAO,uBAAuB,iBAAiB;IAC1D,eAAe,MAAM,OAAO,qBAAqB;IACjD,GAAI,MAAM,OAAO,uBAAuB,kBAClC,UAAa,EACjB,yBACE,MAAM,MAAM,sBAAsB,eACrC;IACF;GACF,EACD,EACE,MAAM,gBACP,CACF;;;AAIL,SAAS,gBACP,OACA,SACA,UACA;AACA,KAAI,MAAM,cAAc,MAAM,WAAW,SAAS,GAAG;AACnD,2BAAyBA,SAAOE,SAAO;AAEvC,mCAAiCF,SAAOE,UAAQ,MAAM;AAEtD,OAAK,MAAM,YAAY,MAAM,YAAY;AACvC,OAAI,SAAS,MAAM,SAAS,UAAU,MAAM;AAE1C,QAAIF,QAAM,kBAAkB;AAE1B,cAAO,KAAK;MACV,MAAM;MACN,OAAOA,QAAM;MACd,CAAC;AACF,aAAM;AACN,aAAM,mBAAmB;;IAG3B,MAAM,sBAAsBA,QAAM;AAClC,YAAM,UAAU,SAAS,SAAS;KAChC,IAAI,SAAS;KACb,MAAM,SAAS,SAAS;KACxB;KACD;AAED,aAAO,KAAK;KACV,MAAM;KACN,OAAO;KACP,eAAe;MACb,MAAM;MACN,IAAI,SAAS;MACb,MAAM,SAAS,SAAS;MACxB,OAAO,EAAE;MACV;KACF,CAAC;AACF,YAAM,mBAAmB;;AAG3B,OAAI,SAAS,UAAU,WAAW;IAChC,MAAM,eAAeA,QAAM,UAAU,SAAS;AAG9C,QAAI,aACF,UAAO,KAAK;KACV,MAAM;KACN,OAAO,aAAa;KACpB,OAAO;MACL,MAAM;MACN,cAAc,SAAS,SAAS;MACjC;KACF,CAAC;;;;;AAOZ,SAAS,iCACP,SACA,UACA,OACA;AACA,KAAIA,QAAM,oBAAoB,CAAC,gBAAgBA,QAAM,EAAE;AACrD,WAAO,KAAK;GACV,MAAM;GACN,OAAOA,QAAM;GACd,CAAC;AACF,UAAM;AACN,UAAM,mBAAmB;;AAE3B,uBAAsB,OAAOE,UAAQF,QAAM;;AAG7C,SAAS,cACP,OACA,SACA,UACA;AACA,KAAI,MAAM,WAAW,MAAM,QAAQ,SAAS,GAAG;AAC7C,2BAAyBA,SAAOE,SAAO;AAEvC,MAAI,gBAAgBF,QAAM,EAAE;AAE1B,YAAO,KAAK;IACV,MAAM;IACN,OAAOA,QAAM;IACd,CAAC;AACF,WAAM;AACN,WAAM,mBAAmB;;AAG3B,MAAI,CAACA,QAAM,kBAAkB;AAC3B,YAAO,KAAK;IACV,MAAM;IACN,OAAOA,QAAM;IACb,eAAe;KACb,MAAM;KACN,MAAM;KACP;IACF,CAAC;AACF,WAAM,mBAAmB;;AAG3B,WAAO,KAAK;GACV,MAAM;GACN,OAAOA,QAAM;GACb,OAAO;IACL,MAAM;IACN,MAAM,MAAM;IACb;GACF,CAAC;;AAIJ,KACE,MAAM,YAAY,MACf,MAAM,oBACN,MAAM,iBAAiB,SAAS,KAChCA,QAAM,mBACT;AACA,WAAO,KACL;GACE,MAAM;GACN,OAAOA,QAAM;GACb,OAAO;IACL,MAAM;IACN,WAAW,MAAM;IAClB;GACF,EACD;GACE,MAAM;GACN,OAAOA,QAAM;GACd,CACF;AACD,UAAM;AACN,UAAM,oBAAoB;;;AAI9B,SAAS,mBACP,SACA,UACA,OACA;AACA,KAAI,CAACA,QAAM,kBAAkB;AAC3B,WAAO,KAAK;GACV,MAAM;GACN,SAAS;IACP,IAAI,MAAM;IACV,MAAM;IACN,MAAM;IACN,SAAS,EAAE;IACX,OAAO,MAAM;IACb,aAAa;IACb,eAAe;IACf,OAAO;KACL,eACG,MAAM,OAAO,iBAAiB,MAC5B,MAAM,OAAO,uBAAuB,iBAAiB;KAC1D,eAAe;KACf,GAAI,MAAM,OAAO,uBAAuB,kBAClC,UAAa,EACjB,yBACE,MAAM,MAAM,sBAAsB,eACrC;KACF;IACF;GACF,CAAC;AACF,UAAM,mBAAmB;;;AAI7B,SAAS,sBACP,OACA,UACA,SACA;AACA,KAAI,MAAM,oBAAoB,MAAM,iBAAiB,SAAS,GAAG;AAC/D,WAAO,KACL;GACE,MAAM;GACN,OAAOA,QAAM;GACb,eAAe;IACb,MAAM;IACN,UAAU;IACX;GACF,EACD;GACE,MAAM;GACN,OAAOA,QAAM;GACb,OAAO;IACL,MAAM;IACN,UAAU;IACX;GACF,EACD;GACE,MAAM;GACN,OAAOA,QAAM;GACb,OAAO;IACL,MAAM;IACN,WAAW,MAAM;IAClB;GACF,EACD;GACE,MAAM;GACN,OAAOA,QAAM;GACd,CACF;AACD,UAAM;;;AAIV,SAAS,mBACP,OACA,SACA,UACA;AACA,KAAI,MAAM,kBAAkB,MAAM,eAAe,SAAS,GAAG;AAI3D,MAAIA,QAAM,kBAAkB;AAC1B,SAAM,UAAU,MAAM;AACtB,SAAM,iBAAiB;AACvB;;AAGF,MAAI,CAACA,QAAM,mBAAmB;AAC5B,YAAO,KAAK;IACV,MAAM;IACN,OAAOA,QAAM;IACb,eAAe;KACb,MAAM;KACN,UAAU;KACX;IACF,CAAC;AACF,WAAM,oBAAoB;;AAG5B,WAAO,KAAK;GACV,MAAM;GACN,OAAOA,QAAM;GACb,OAAO;IACL,MAAM;IACN,UAAU,MAAM;IACjB;GACF,CAAC;;;AAIN,SAAS,yBACP,SACA,UACM;AACN,KAAIA,QAAM,mBAAmB;AAC3B,WAAO,KACL;GACE,MAAM;GACN,OAAOA,QAAM;GACb,OAAO;IACL,MAAM;IACN,WAAW;IACZ;GACF,EACD;GACE,MAAM;GACN,OAAOA,QAAM;GACd,CACF;AACD,UAAM;AACN,UAAM,oBAAoB;;;;;;ACrT9B,MAAa,4BAA4B,OACvC,GACA,kBACA,YACG;CACH,MAAM,EAAE,kBAAQ,gBAAgB,WAAW,WAAW,gBAAgB;CACtE,MAAM,gBAAgB,kBAAkB,iBAAiB;AACzD,WAAUG,UAAQ,sCAAsC,cAAc;CAEtE,MAAM,WAAW,MAAM,sBAAsB,eAAe;EAC1D;EACA;EACA;EACA;EACD,CAAC;AAEF,KAAI,eAAe,SAAS,EAAE;AAC5B,YAAUA,UAAQ,wCAAwC,SAAS;EACnE,MAAM,oBAAoB,qBAAqB,SAAS;AACxD,YAAUA,UAAQ,kCAAkC,kBAAkB;AACtE,SAAO,EAAE,KAAK,kBAAkB;;AAGlC,UAAO,MAAM,kCAAkC;AAC/C,QAAO,UAAU,GAAG,OAAO,aAAW;EACpC,MAAMC,cAAoC;GACxC,kBAAkB;GAClB,mBAAmB;GACnB,kBAAkB;GAClB,WAAW,EAAE;GACb,mBAAmB;GACpB;AAED,aAAW,MAAM,YAAY,UAAU;AACrC,aAAUD,UAAQ,6BAA6B,SAAS;AACxD,OAAI,SAAS,SAAS,SACpB;AAGF,OAAI,CAAC,SAAS,KACZ;GAGF,MAAM,QAAQ,KAAK,MAAM,SAAS,KAAK;GACvC,MAAME,WAAS,gCAAgC,OAAO,YAAY;AAElE,QAAK,MAAM,SAASA,UAAQ;IAC1B,MAAM,YAAY,KAAK,UAAU,MAAM;AACvC,cAAUF,gBAAc,CAAC,+BAA+B,UAAU,CAAC;AACnE,UAAMG,SAAO,SAAS;KACpB,OAAO,MAAM;KACb,MAAM;KACP,CAAC;;;GAGN;;AAGJ,MAAa,yBAAyB,OACpC,GACA,kBACA,YACG;CACH,MAAM,EACJ,kBACA,gBACA,eACA,WACA,WACA,gBACE;CAEJ,MAAM,mBACJ,6CAA6C,iBAAiB;AAEhE,oCACE,kBACA,eAAe,aAAa,OAAO,kBACpC;AAED,gCAA+B,iBAAiB;AAEhD,WAAUH,UAAQ,iCAAiC,iBAAiB;CAEpE,MAAM,EAAE,QAAQ,cAAc,2BAA2B,iBAAiB;CAC1E,MAAM,WAAW,MAAM,gBAAgB,kBAAkB;EACvD;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;AAEF,KAAI,iBAAiB,UAAUI,kBAAgB,SAAS,EAAE;AACxD,WAAO,MAAM,kDAAkD;AAC/D,SAAO,UAAU,GAAG,OAAO,aAAW;GACpC,MAAM,cAAc,4BAA4B;AAEhD,cAAW,MAAM,SAAS,UAAU;AAElC,QADkB,MAAM,UACN,QAAQ;AACxB,WAAMD,SAAO,SAAS;MAAE,OAAO;MAAQ,MAAM;MAAmB,CAAC;AACjE;;IAGF,MAAM,OAAO,MAAM;AACnB,QAAI,CAAC,KACH;AAGF,cAAUH,gBAAc,CAAC,+BAA+B,KAAK,CAAC;IAE9D,MAAME,WAAS,8BACb,KAAK,MAAM,KAAK,EAChB,YACD;AACD,SAAK,MAAM,SAASA,UAAQ;KAC1B,MAAM,YAAY,KAAK,UAAU,MAAM;AACvC,eAAUF,gBAAc,CAAC,+BAA+B,UAAU,CAAC;AACnE,WAAMG,SAAO,SAAS;MACpB,OAAO,MAAM;MACb,MAAM;MACP,CAAC;;AAGJ,QAAI,YAAY,kBAAkB;AAChC,cAAO,MAAM,mCAAmC;AAChD;;;AAIJ,OAAI,CAAC,YAAY,kBAAkB;AACjC,aAAO,KACL,iEACD;IACD,MAAM,aAAa,gBACjB,4CACD;AACD,UAAMA,SAAO,SAAS;KACpB,OAAO,WAAW;KAClB,MAAM,KAAK,UAAU,WAAW;KACjC,CAAC;;IAEJ;;AAGJ,eAAcH,UAAQ,mCAAmC;EACvD,OAAO;EACP,YAAY;EACb,CAAC;CACF,MAAM,oBAAoB,oCACxB,SACD;AACD,WAAUA,UAAQ,kCAAkC,kBAAkB;AACtE,QAAO,EAAE,KAAK,kBAAkB;;AAGlC,MAAa,wBAAwB,OACnC,GACA,kBACA,YACG;CACH,MAAM,EACJ,kBACA,qBACA,gBACA,eACA,WACA,WACA,gBACE;AAEJ,2BAA0B,kBAAkB,cAAc;AAE1D,WAAUA,UAAQ,gCAAgC,iBAAiB;CAEnE,MAAM,WAAW,MAAM,eAAe,kBAAkB,qBAAqB;EAC3E;EACA;EACA;EACA;EACD,CAAC;AAEF,KAAII,kBAAgB,SAAS,EAAE;AAC7B,WAAO,MAAM,iDAAiD;AAC9D,SAAO,UAAU,GAAG,OAAO,aAAW;AACpC,cAAW,MAAM,SAAS,UAAU;IAClC,MAAM,YAAY,MAAM;IACxB,MAAM,OAAO,MAAM,QAAQ;AAC3B,QAAI,SAAS,SACX;AAEF,QAAI,CAAC,KACH;AAEF,cAAUJ,gBAAc,CAAC,8BAA8B,KAAK,CAAC;AAC7D,UAAMG,SAAO,SAAS;KACpB,OAAO;KACP;KACD,CAAC;;IAEJ;;AAGJ,eAAcH,UAAQ,kCAAkC;EACtD,OAAO;EACP,YAAY;EACb,CAAC;AACF,QAAO,EAAE,KAAK,SAAS;;AAGzB,MAAM,kBACJ,aACuC,OAAO,OAAO,UAAU,UAAU;AAE3E,MAAMI,qBAAsB,UAC1B,QAAQ,MAAM,IACX,OAAQ,MAA2B,OAAO,mBAAmB;;;;AC1RlE,MAAa,uBAAuB;;;;ACIpC,MAAa,oCACX,YAC0B;CAC1B,MAAM,mBAAmB,QAAQ,SAAS,MACvC,QAAQ,IAAI,SAAS,UAAU,MAAM,QAAQ,IAAI,QAAQ,CAC3D;AACD,KAAI,CAAC,oBAAoB,CAAC,MAAM,QAAQ,iBAAiB,QAAQ,CAC/D,QAAO;AAGT,MAAK,MAAM,SAAS,iBAAiB,SAAS;AAC5C,MAAI,MAAM,SAAS,OACjB;EAGF,MAAM,SAAS,sCAAsC,MAAM,KAAK;AAChE,MAAI,OACF,QAAO;;AAIX,QAAO;;AAGT,MAAM,yCACJ,SAC0B;CAC1B,MAAM,WAAW;CACjB,MAAM,SAAS;CACf,IAAI,aAAa;AAEjB,QAAO,MAAM;EACX,MAAM,gBAAgB,KAAK,QAAQ,UAAU,WAAW;AACxD,MAAI,kBAAkB,GACpB;EAGF,MAAM,eAAe,gBAAgB;EACrC,MAAM,cAAc,KAAK,QAAQ,QAAQ,aAAa;AACtD,MAAI,gBAAgB,GAClB;EAGF,MAAM,kBAAkB,KAAK,MAAM,cAAc,YAAY;EAC7D,MAAM,cAAc,gBAAgB,QAAQ,qBAAqB;AACjE,MAAI,gBAAgB,IAAI;AACtB,gBAAa,cAAc;AAC3B;;EAGF,MAAM,aAAa,gBAChB,MAAM,cAAc,qBAAqB,OAAO,CAChD,MAAM;AAET,MAAI;GACF,MAAM,SAAS,KAAK,MAAM,WAAW;AACrC,OAAI,CAAC,OAAO,cAAc,CAAC,OAAO,YAAY,CAAC,OAAO,YAAY;AAChE,iBAAa,cAAc;AAC3B;;AAGF,UAAO;UACD;AACN,gBAAa,cAAc;AAC3B;;;AAIJ,QAAO;;;;;AC7CT,MAAMC,WAAS,oBAAoB,mBAAmB;AAEtD,eAAsB,iBAAiB,GAAY;AACjD,OAAM,eAAe,MAAM;CAE3B,MAAM,mBAAmB,MAAM,EAAE,IAAI,MAAgC;AACrE,WAAUA,UAAQ,8BAA8B,iBAAiB;AAEjE,kBAAiB,iBAAiB;CAElC,MAAM,iBAAiB,iCAAiC,iBAAiB;AACzE,KAAI,eACF,WAAUA,UAAQ,6BAA6B,eAAe;CAGhE,MAAM,YAAY,iBAAiB,kBAAkB,EAAE;AACvD,UAAO,MAAM,yBAAyB,UAAU;CAGhD,MAAM,cAAc,eAAe,iBAAiB;CAIpD,MAAM,gBAAgB,EAAE,IAAI,OAAO,iBAAiB;AACpD,UAAO,MAAM,0BAA0B,cAAc;CACrD,MAAM,UAAU,CAAC,iBAAiB,SAAS,iBAAiB,MAAM,WAAW;AAC7E,KAAI,iBAAiB,WAAW,gBAAgB,EAC9C,kBAAiB,QAAQ,eAAe;AAG1C,KAAI,YACF,UAAO,MAAM,yBAAyB,YAAY;AAGpD,gCAA+B,iBAAiB;AAOhD,0BAAyB,kBAAkB,EACzC,iBAAiB,gBAAgB,iBAClC,CAAC;CAEF,MAAM,YAAY,6BAA6B,kBAAkB,UAAU;AAC3E,UAAO,MAAM,yBAAyB,UAAU;AAEhD,KAAI,MAAM,cACR,OAAM,eAAe;CAGvB,MAAM,gBAAgB,kBAAkB,iBAAiB,MAAM;AAC/D,kBAAiB,QAAQ,eAAe,MAAM,iBAAiB;AAE/D,KAAI,qBAAqB,cAAc,CACrC,QAAO,MAAM,sBAAsB,GAAG,kBAAkB;EACtD,qBAAqB;EACrB;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;AAGJ,KAAI,sBAAsB,cAAc,CACtC,QAAO,MAAM,uBAAuB,GAAG,kBAAkB;EACvD;EACA;EACA;EACA;EACA;EACA;EACD,CAAC;AAGJ,QAAO,MAAM,0BAA0B,GAAG,kBAAkB;EAC1D;EACA;EACA;EACA;EACA;EACD,CAAC;;AAGJ,MAAMC,uBAAqB;AAC3B,MAAM,oBAAoB;AAE1B,MAAM,yBAAyB,kBAA8C;AAC3E,QACE,eAAe,qBAAqB,SAASA,qBAAmB,IAAI;;AAIxE,MAAM,wBAAwB,kBAA8C;AAE1E,KAAI,CADmB,sBAAsB,CAE3C,QAAO;AAET,QACE,eAAe,qBAAqB,SAAS,kBAAkB,IAAI;;;;;AC1HvE,MAAa,gBAAgB,IAAI,MAAM;AAEvC,cAAc,KAAK,KAAK,OAAO,MAAM;AACnC,KAAI;AACF,SAAO,MAAM,iBAAiB,EAAE;UACzB,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;AAEF,cAAc,KAAK,iBAAiB,OAAO,MAAM;AAC/C,KAAI;AACF,SAAO,MAAM,kBAAkB,EAAE;UAC1B,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACjBF,MAAa,cAAc,IAAI,MAAM;AAErC,YAAY,IAAI,KAAK,OAAO,MAAM;AAChC,KAAI;AACF,MAAI,CAAC,MAAM,OAET,OAAM,aAAa;EAGrB,MAAM,SAAS,MAAM,QAAQ,KAAK,KAAK,WAAW;GAChD,GAAG;GACH,IAAI,MAAM;GACV,QAAQ;GACR,MAAM;GACN,SAAS;GACT,6BAAY,IAAI,KAAK,EAAE,EAAC,aAAa;GACrC,UAAU,MAAM;GAChB,cAAc,MAAM;GACrB,EAAE;AAEH,SAAO,EAAE,KAAK;GACZ,QAAQ;GACR,MAAM;GACN,UAAU;GACX,CAAC;UACK,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACxBF,MAAMC,WAAS,oBAAoB,gCAAgC;AAEnE,MAAM,uBAAuB,aAA4B;CACvD,cAAc;EACZ,QAAQ;EACR,QAAQ,EAAE;EACV,QAAQ;EACR,UAAU,EAAE;EACZ,WAAW;EACX,MAAM;EACP;CACD,IAAI;CACJ,sBAAsB;CACtB,MAAM;CACN,QAAQ;CACR,SAAS;CACT,QAAQ;CACR,SAAS;CACV;AAED,eAAsB,0BAA0B,GAA+B;CAC7E,MAAM,WAAW,EAAE,IAAI,MAAM,WAAW;AAExC,KAAI;EACF,MAAM,mBAAmB,MAAM,EAAE,IAAI,MAAgC;EACrE,MAAM,gBAAgB,kBAAkB,iBAAiB;EACzD,MAAM,UAAU,iBAAiB,MAAM,MAAM;EAE7C,IAAI,gBAAgB,MAAM,QAAQ,KAAK,MAAM,UAAU,MAAM,OAAO,QAAQ;AAE5E,MAAI,CAAC,iBAAiB,QACpB,iBAAgB,oBAAoB,QAAQ;AAG9C,MAAI,CAAC,eAAe;AAClB,YAAO,KAAK,yCAAyC;IACnD;IACA,OAAO,iBAAiB;IACzB,CAAC;AACF,UAAO,EAAE,KAAK,EACZ,cAAc,GACf,CAAC;;EAGJ,MAAM,aAAa,MAAM,cAAc,eAAe,cAAc;EACpE,MAAM,kBAAkB,WAAW,QAAQ,WAAW;AAEtD,WAAO,MAAM,iCAAiC;GAC5C;GACA,OAAO,iBAAiB;GACxB,cAAc;GACf,CAAC;AAEF,SAAO,EAAE,KAAK,EACZ,cAAc,iBACf,CAAC;UACK,OAAO;AACd,WAAO,MAAM,+BAA+B;GAC1C;GACA;GACD,CAAC;AACF,SAAO,EAAE,KAAK,EACZ,cAAc,GACf,CAAC;;;;;;ACtEN,MAAM,sBAAsB;CAC1B;CACA;CACA;CACA;CACD;AAED,MAAM,4BAA4B;CAChC;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CACD;AAED,SAAgB,6BACd,gBACA,gBACwB;CACxB,MAAMC,cAAsC,EAAE;AAC9C,KAAI,eAAe,aAAa,gBAC9B,aAAY,gBAAgB,UAAU,eAAe;KAErD,aAAY,eAAe,eAAe;CAG5C,MAAMC,UAAkC;EACtC,gBAAgB;EAChB,QAAQ;EACR,GAAG;EACJ;AAED,MAAK,MAAM,cAAc,qBAAqB;EAC5C,MAAM,cAAc,eAAe,IAAI,WAAW;AAClD,MAAI,YACF,SAAQ,cAAc;;AAI1B,QAAO;;AAGT,SAAgB,4BACd,kBACU;CACV,MAAM,UAAU,IAAI,QAAQ,iBAAiB,QAAQ;AAErD,MAAK,MAAM,cAAc,0BACvB,SAAQ,OAAO,WAAW;AAG5B,QAAO,IAAI,SAAS,iBAAiB,MAAM;EACzC;EACA,QAAQ,iBAAiB;EACzB,YAAY,iBAAiB;EAC9B,CAAC;;AAGJ,eAAsB,wBACpB,gBACA,SACA,gBACmB;AACnB,QAAO,MAAM,MAAM,GAAG,eAAe,QAAQ,eAAe;EAC1D,QAAQ;EACR,SAAS,6BAA6B,gBAAgB,eAAe;EACrE,MAAM,KAAK,UAAU,QAAQ;EAC9B,CAAC;;AAGJ,eAAsB,sBACpB,gBACA,gBACmB;AACnB,QAAO,MAAM,MAAM,GAAG,eAAe,QAAQ,aAAa;EACxD,QAAQ;EACR,SAAS,6BAA6B,gBAAgB,eAAe;EACtE,CAAC;;;;;ACrEJ,MAAMC,WAAS,oBAAoB,4BAA4B;AAE/D,eAAsB,uBAAuB,GAA+B;CAC1E,MAAM,WAAW,EAAE,IAAI,MAAM,WAAW;CACxC,MAAM,iBAAiB,kBAAkB,SAAS;AAClD,KAAI,CAAC,eACH,QAAO,EAAE,KACP,EACE,OAAO;EACL,SAAS,aAAa,SAAS;EAC/B,MAAM;EACP,EACF,EACD,IACD;AAGH,KAAI;EACF,MAAM,UAAU,MAAM,EAAE,IAAI,MAAgC;EAE5D,MAAM,cAAc,eAAe,SAAS,QAAQ;AACpD,UAAQ,gBAAgB,aAAa;AACrC,UAAQ,UAAU,aAAa;AAC/B,UAAQ,UAAU,aAAa;AAE/B,YAAUA,UAAQ,6BAA6B;GAAE;GAAS;GAAU,CAAC;EAErE,MAAM,mBAAmB,MAAM,wBAC7B,gBACA,SACA,EAAE,IAAI,IAAI,QACX;AAED,MAAI,CAAC,iBAAiB,IAAI;AACxB,YAAO,MAAM,8BAA8B,iBAAiB;AAC5D,SAAM,IAAI,UAAU,8BAA8B,iBAAiB;;EAGrE,MAAM,cAAc,iBAAiB,QAAQ,IAAI,eAAe,IAAI;AAIpE,MAFE,QAAQ,QAAQ,OAAO,IAAI,YAAY,SAAS,oBAAoB,EAE7C;AACvB,YAAO,MAAM,8BAA8B;AAC3C,UAAO,UAAU,GAAG,OAAO,aAAW;AACpC,eAAW,MAAM,SAAS,OAAO,iBAAiB,EAAE;AAClD,cAAO,MAAM,uCAAuC,MAAM,KAAK;KAC/D,MAAM,YAAY,MAAM;AACxB,SAAI,cAAc,QAAQ;AACxB,YAAMC,SAAO,SAAS;OAAE,OAAO;OAAQ,MAAM;OAAmB,CAAC;AACjE;;KAGF,IAAI,OAAO,MAAM;AACjB,SAAI,CAAC,KACH;AAGF,SAAI,MAAM,SAAS,SACjB;AAGF,SAAI;MACF,MAAM,SAAS,KAAK,MAAM,KAAK;AAC/B,UAAI,OAAO,SAAS,gBAClB,mBAAkB,gBAAgB,OAAO,QAAQ,MAAM;eAC9C,OAAO,SAAS,gBACzB,mBAAkB,gBAAgB,OAAO,MAAM;AAEjD,aAAO,KAAK,UAAU,OAAO;cACtB,OAAO;AACd,eAAO,MAAM,mDAAmD;OAC9D;OACA,cAAc;OACf,CAAC;;AAEJ,WAAMA,SAAO,SAAS;MACpB,OAAO;MACP;MACD,CAAC;;KAEJ;;EAGJ,MAAM,WAAY,MAAM,iBAAiB,MAAM;AAE/C,oBAAkB,gBAAgB,SAAS,MAAM;AAEjD,YAAUD,UAAQ,uCAAuC,SAAS;AAClE,SAAO,EAAE,KAAK,SAAS;UAChB,OAAO;AACd,WAAO,MAAM,2BAA2B;GACtC;GACA;GACD,CAAC;AACF,QAAM;;;AAIV,MAAM,qBACJ,gBACA,UAKS;AACT,KAAI,CAAC,eAAe,qBAAqB,CAAC,MACxC;AAQF,OAAM,eANgB,KAAK,IACzB,IACC,MAAM,gBAAgB,MAClB,MAAM,2BAA2B,MACjC,MAAM,+BAA+B,GAC3C;AAED,WAAUA,UAAQ,qCAAqC,MAAM;;;;;AC9H/D,MAAa,wBAAwB,IAAI,MAAM;AAE/C,sBAAsB,KAAK,KAAK,OAAO,MAAM;AAC3C,KAAI;AACF,SAAO,MAAM,uBAAuB,EAAE;UAC/B,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;AAEF,sBAAsB,KAAK,iBAAiB,OAAO,MAAM;AACvD,KAAI;AACF,SAAO,MAAM,0BAA0B,EAAE;UAClC,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACbF,MAAME,WAAS,oBAAoB,0BAA0B;AAE7D,MAAa,sBAAsB,IAAI,MAAM;AAE7C,oBAAoB,IAAI,KAAK,OAAO,MAAM;CACxC,MAAM,WAAW,EAAE,IAAI,MAAM,WAAW,IAAI;AAE5C,KAAI;EACF,MAAM,iBAAiB,kBAAkB,SAAS;AAClD,MAAI,CAAC,eACH,QAAO,EAAE,KACP,EACE,OAAO;GACL,SAAS,aAAa,SAAS;GAC/B,MAAM;GACP,EACF,EACD,IACD;EAGH,MAAM,mBAAmB,MAAM,sBAC7B,gBACA,EAAE,IAAI,IAAI,QACX;AAED,WAAO,MAAM,4BAA4B;GACvC;GACA,YAAY,iBAAiB;GAC9B,CAAC;AAEF,SAAO,4BAA4B,iBAAiB;UAC7C,OAAO;AACd,WAAO,MAAM,yBAAyB;GACpC;GACA;GACD,CAAC;AACF,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACxBF,MAAa,+BAAgD,EAC3D,6BAAa,IAAI,KAAK,EACvB;AAED,MAAa,gBACX,MACA,OACA,YACW;AACX,KAAI,CAAC,KAAM,QAAO;CAClB,MAAM,SAAS,KAAK,MAAM,KAAK;AAC/B,SAAQ,OAAR;EACE,KAAK,6BACH,QAAO,sBACL,QACA,QACD;EAEH,KAAK,4BACH,QAAO,qBACL,QACA,QACD;EAEH,QACE,QAAO,aAAa,QAAQ,QAAQ;;;AAK1C,MAAM,yBACJ,QACA,YACW;AACX,KAAI,CAAC,OAAO,KAAK,IAAI;EACnB,IAAI,eAAe;AACnB,SAAO,aAAa,SAAS,GAC3B,iBAAgB,KAAK,QAAQ,CAAC,SAAS,GAAG,CAAC,MAAM,EAAE;AAErD,SAAO,KAAK,KAAK,MAAM,OAAO,aAAa,GAAG,aAAa,MAAM,GAAG,GAAG;;CAGzE,MAAM,cAAc,OAAO;AAC3B,SAAQ,YAAY,IAAI,aAAa,OAAO,KAAK,GAAG;AACpD,QAAO,KAAK,UAAU,OAAO;;AAG/B,MAAM,wBACJ,QACA,YACW;CACX,MAAM,cAAc,OAAO;CAC3B,MAAM,aAAa,QAAQ,YAAY,IAAI,YAAY;AACvD,KAAI,WACF,QAAO,KAAK,KAAK;AAEnB,QAAO,KAAK,UAAU,OAAO;;AAG/B,MAAM,gBACJ,QACA,YACW;CACX,MAAM,cAAc,OAAO;AAC3B,KAAI,gBAAgB,QAAW;EAC7B,MAAM,SAAS,QAAQ,YAAY,IAAI,YAAY;AACnD,MAAI,OACF,QAAO,UAAU;;AAGrB,QAAO,KAAK,UAAU,OAAO;;;;;ACxE/B,MAAMC,WAAS,oBAAoB,oBAAoB;AAEvD,MAAM,qBAAqB;AAE3B,MAAa,kBAAkB,OAAO,MAAe;AACnD,OAAM,eAAe,MAAM;CAE3B,MAAM,UAAU,MAAM,EAAE,IAAI,MAAwB;AACpD,WAAUA,UAAQ,8BAA8B,QAAQ;CAGxD,MAAM,YAAY,6BAA6B,EAAE,UAAU,QAAQ,OAAO,CAAC;AAC3E,UAAO,MAAM,yBAAyB,UAAU;CAEhD,MAAM,YAAY,QAAQ,UAAU;AACpC,UAAO,MAAM,yBAAyB,UAAU;AAEhD,uBAAsB,QAAQ;AAE9B,wBAAuB,QAAQ;AAE/B,KAAI,CAAC,gCAAgC,CACnC,qBAAoB,QAAQ;AAG9B,gCAA+B,QAAQ;CAEvC,MAAM,gBAAgB,MAAM,QAAQ,KAAK,MACtC,UAAU,MAAM,OAAO,QAAQ,MACjC;AAID,KAAI,EAFF,eAAe,qBAAqB,SAAS,mBAAmB,IAAI,OAGpE,QAAO,EAAE,KACP,EACE,OAAO;EACL,SACE;EACF,MAAM;EACP,EACF,EACD,IACD;AAGH,oCACE,SACA,eAAe,aAAa,OAAO,kBACpC;AAED,WAAUA,UAAQ,iCAAiC,QAAQ;CAE3D,MAAM,EAAE,QAAQ,cAAc,2BAA2B,QAAQ;AAEjE,KAAI,MAAM,cACR,OAAM,eAAe;CAGvB,MAAM,WAAW,MAAM,gBAAgB,SAAS;EAC9C;EACA;EACA;EACW;EACZ,CAAC;AAEF,KAAI,qBAAqB,QAAQ,IAAI,gBAAgB,SAAS,EAAE;AAC9D,WAAO,MAAM,qCAAqC;AAClD,SAAO,UAAU,GAAG,OAAO,aAAW;GACpC,MAAM,YAAY,uBAAuB;AAEzC,cAAW,MAAM,SAAS,UAAU;AAClC,cAAUA,UAAQ,2BAA2B,MAAM;IAEnD,MAAM,gBAAgB,aACnB,MAA4B,QAAQ,IACpC,MAA6B,OAC9B,UACD;AAED,UAAMC,SAAO,SAAS;KACpB,IAAK,MAA0B;KAC/B,OAAQ,MAA6B;KACrC,MAAM;KACP,CAAC;;IAEJ;;AAGJ,eAAcD,UAAQ,uCAAuC;EAC3D,OAAO;EACP,YAAY;EACb,CAAC;AACF,QAAO,EAAE,KAAK,SAA4B;;AAG5C,MAAM,mBAAsB,UAC1B,QAAQ,MAAM,IACX,OAAQ,MAA2B,OAAO,mBAAmB;AAElE,MAAM,wBAAwB,YAC5B,QAAQ,QAAQ,OAAO;AAEzB,MAAM,yBAAyB,YAAoC;AAGjE,KAFe,WAAW,CACW,yBAAyB,MACnC;AACzB,WAAO,MAAM,gDAAgD;AAC7D,MAAI,MAAM,QAAQ,QAAQ,MAAM,EAAE;GAChC,MAAM,WAAW,QAAQ;AACzB,QAAK,IAAI,IAAI,GAAG,IAAI,SAAS,QAAQ,KAAK;IACxC,MAAM,IAAI,SAAS;AACnB,QAAI,EAAE,SAAS,YAAY,EAAE,SAAS,cACpC,UAAS,KAAK;KACZ,MAAM;KACN,MAAM,EAAE;KACR,aAAa;KACb,YAAY;MACV,MAAM;MACN,YAAY,EACV,OAAO;OACL,MAAM;OACN,aAAa;OACd,EACF;MACD,UAAU,CAAC,QAAQ;MACpB;KACD,QAAQ;KACT;;;;;AAOX,MAAM,uBAAuB,YAAoC;AAC/D,KAAI,CAAC,MAAM,QAAQ,QAAQ,MAAM,IAAI,QAAQ,MAAM,WAAW,EAAG;AAEjE,SAAQ,QAAQ,QAAQ,MAAM,QAAQ,MAAM;AAC1C,SAAO,EAAE,SAAS;GAClB;;AAGJ,MAAM,iCAAiC,IAAI,IAAI,CAAC,mBAAmB,CAAC;AAEpE,MAAa,0BAA0B,YAAoC;AACzE,KAAI,CAAC,MAAM,QAAQ,QAAQ,MAAM,IAAI,QAAQ,MAAM,WAAW,EAAG;CAEjE,MAAME,UAAyB,EAAE;AACjC,SAAQ,QAAQ,QAAQ,MAAM,QAAQ,MAAM;EAC1C,MAAM,OAAO,EAAE;AACf,MAAI,+BAA+B,IAAI,KAAK,EAAE;AAC5C,WAAQ,KAAK,KAAK;AAClB,UAAO;;AAET,SAAO;GACP;AACF,KAAI,QAAQ,SAAS,EACnB,UAAO,MAAM,8BAA8B,QAAQ;;;;;AC/KvD,MAAa,kBAAkB,IAAI,MAAM;AAEzC,gBAAgB,KAAK,KAAK,OAAO,MAAM;AACrC,KAAI;AACF,SAAO,MAAM,gBAAgB,EAAE;UACxB,OAAO;AACd,SAAO,MAAM,aAAa,GAAG,MAAM;;EAErC;;;;ACVF,MAAa,aAAa,IAAI,MAAM;AAEpC,WAAW,IAAI,MAAM,MAAM;AACzB,KAAI;AACF,SAAO,EAAE,KAAK,EACZ,OAAO,MAAM,cACd,CAAC;UACK,OAAO;AACd,UAAQ,MAAM,yBAAyB,MAAM;AAC7C,SAAO,EAAE,KAAK;GAAE,OAAO;GAAyB,OAAO;GAAM,EAAE,IAAI;;EAErE;;;;ACXF,MAAa,aAAa,IAAI,MAAM;AAEpC,WAAW,IAAI,KAAK,OAAO,MAAM;AAC/B,KAAI;EACF,MAAM,QAAQ,MAAM,iBAAiB;AACrC,SAAO,EAAE,KAAK,MAAM;UACb,OAAO;AACd,UAAQ,MAAM,iCAAiC,MAAM;AACrD,SAAO,EAAE,KAAK,EAAE,OAAO,iCAAiC,EAAE,IAAI;;EAEhE;;;;ACGF,MAAa,SAAS,IAAI,MAAM;AAEhC,OAAO,IAAI,kBAAkB;AAC7B,OAAO,IAAI,QAAQ,CAAC;AACpB,OAAO,IAAI,MAAM,CAAC;AAClB,OAAO,IACL,KACA,qBAAqB,EACnB,2BAA2B;CAAC;CAAK;CAAiB;CAAiB,EACpE,CAAC,CACH;AAED,OAAO,IAAI,MAAM,MAAM,EAAE,KAAK,iBAAiB,CAAC;AAChD,OAAO,IAAI,kBAAkB,MAAM;CACjC,MAAM,qBAAqB,IAAI,IAAI,uBAAuB,OAAO,KAAK,IAAI;AAC1E,QAAO,EAAE,KAAK,aAAa,oBAAoB,OAAO,CAAC;EACvD;AACF,OAAO,IAAI,mBAAmB,MAAM,EAAE,SAAS,iBAAiB,IAAI,CAAC;AAErE,OAAO,MAAM,qBAAqB,iBAAiB;AACnD,OAAO,MAAM,WAAW,YAAY;AACpC,OAAO,MAAM,eAAe,gBAAgB;AAC5C,OAAO,MAAM,UAAU,WAAW;AAClC,OAAO,MAAM,UAAU,WAAW;AAClC,OAAO,MAAM,cAAc,gBAAgB;AAG3C,OAAO,MAAM,wBAAwB,iBAAiB;AACtD,OAAO,MAAM,cAAc,YAAY;AACvC,OAAO,MAAM,kBAAkB,gBAAgB;AAC/C,OAAO,MAAM,iBAAiB,gBAAgB;AAG9C,OAAO,MAAM,gBAAgB,cAAc;AAG3C,OAAO,MAAM,0BAA0B,sBAAsB;AAC7D,OAAO,MAAM,wBAAwB,oBAAoB"}