@fulmenhq/tsfulmen 0.1.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (188) hide show
  1. package/CHANGELOG.md +616 -0
  2. package/LICENSE +57 -0
  3. package/README.md +674 -0
  4. package/config/crucible-ts/README.md +38 -0
  5. package/config/crucible-ts/library/foundry/country-codes.yaml +29 -0
  6. package/config/crucible-ts/library/foundry/exit-codes.snapshot.json +351 -0
  7. package/config/crucible-ts/library/foundry/exit-codes.yaml +483 -0
  8. package/config/crucible-ts/library/foundry/fixtures/signals/invalid/invalid-behavior.yaml +45 -0
  9. package/config/crucible-ts/library/foundry/fixtures/signals/invalid/invalid-exit-code.yaml +51 -0
  10. package/config/crucible-ts/library/foundry/fixtures/signals/invalid/malformed.yaml +44 -0
  11. package/config/crucible-ts/library/foundry/fixtures/signals/invalid/missing-required.yaml +36 -0
  12. package/config/crucible-ts/library/foundry/fixtures/signals/parity-snapshot.json +162 -0
  13. package/config/crucible-ts/library/foundry/fixtures/signals/valid/complete.yaml +314 -0
  14. package/config/crucible-ts/library/foundry/fixtures/signals/valid/custom-behavior.yaml +96 -0
  15. package/config/crucible-ts/library/foundry/fixtures/signals/valid/minimal.yaml +55 -0
  16. package/config/crucible-ts/library/foundry/http-statuses.yaml +148 -0
  17. package/config/crucible-ts/library/foundry/mime-types.yaml +39 -0
  18. package/config/crucible-ts/library/foundry/patterns.yaml +185 -0
  19. package/config/crucible-ts/library/foundry/signals.yaml +331 -0
  20. package/config/crucible-ts/library/foundry/similarity-fixtures.yaml +432 -0
  21. package/config/crucible-ts/library/foundry/simplified-modes.snapshot.json +117 -0
  22. package/config/crucible-ts/library/fulhash/fixtures.yaml +160 -0
  23. package/config/crucible-ts/library/v1.0.0/module-manifest.yaml +179 -0
  24. package/config/crucible-ts/repository/app-identity/app-identity.example.yaml +42 -0
  25. package/config/crucible-ts/repository/app-identity/fixtures/invalid/invalid-binary-name.yaml +7 -0
  26. package/config/crucible-ts/repository/app-identity/fixtures/invalid/invalid-env-prefix.yaml +7 -0
  27. package/config/crucible-ts/repository/app-identity/fixtures/invalid/invalid-vendor.yaml +7 -0
  28. package/config/crucible-ts/repository/app-identity/fixtures/invalid/malformed-yaml.yaml +8 -0
  29. package/config/crucible-ts/repository/app-identity/fixtures/invalid/missing-required.yaml +6 -0
  30. package/config/crucible-ts/repository/app-identity/fixtures/valid/complete.yaml +20 -0
  31. package/config/crucible-ts/repository/app-identity/fixtures/valid/minimal.yaml +7 -0
  32. package/config/crucible-ts/repository/app-identity/fixtures/valid/monorepo-api.yaml +10 -0
  33. package/config/crucible-ts/repository/app-identity/fixtures/valid/monorepo-worker.yaml +10 -0
  34. package/config/crucible-ts/repository/app-identity/parity-snapshot.json +125 -0
  35. package/config/crucible-ts/server/management/server-management.yaml +141 -0
  36. package/config/crucible-ts/sync/README.md +13 -0
  37. package/config/crucible-ts/sync/sync-keys.yaml +74 -0
  38. package/config/crucible-ts/taxonomy/languages.yaml +33 -0
  39. package/config/crucible-ts/taxonomy/metrics.yaml +115 -0
  40. package/config/crucible-ts/taxonomy/repository-categories.yaml +66 -0
  41. package/config/crucible-ts/terminal/v1.0.0/terminal-overrides-defaults.yaml +38 -0
  42. package/config/crucible-ts/web/branding/site-branding.yaml +21 -0
  43. package/config/crucible-ts/web/styling/site-styling.yaml +104 -0
  44. package/dist/appidentity/index.d.ts +304 -0
  45. package/dist/appidentity/index.js +5519 -0
  46. package/dist/appidentity/index.js.map +1 -0
  47. package/dist/config/index.d.ts +144 -0
  48. package/dist/config/index.js +5752 -0
  49. package/dist/config/index.js.map +1 -0
  50. package/dist/crucible/index.d.ts +78 -0
  51. package/dist/crucible/index.js +6038 -0
  52. package/dist/crucible/index.js.map +1 -0
  53. package/dist/docscribe/index.d.ts +110 -0
  54. package/dist/docscribe/index.js +682 -0
  55. package/dist/docscribe/index.js.map +1 -0
  56. package/dist/errors/index.d.ts +150 -0
  57. package/dist/errors/index.js +5583 -0
  58. package/dist/errors/index.js.map +1 -0
  59. package/dist/foundry/index.d.ts +1557 -0
  60. package/dist/foundry/index.js +5474 -0
  61. package/dist/foundry/index.js.map +1 -0
  62. package/dist/foundry/similarity/index.d.ts +17 -0
  63. package/dist/foundry/similarity/index.js +136 -0
  64. package/dist/foundry/similarity/index.js.map +1 -0
  65. package/dist/fulhash/index.d.ts +82 -0
  66. package/dist/fulhash/index.js +374 -0
  67. package/dist/fulhash/index.js.map +1 -0
  68. package/dist/fulmen-error-B_kX8jSC.d.ts +309 -0
  69. package/dist/index.d.ts +14 -0
  70. package/dist/index.js +6197 -0
  71. package/dist/index.js.map +1 -0
  72. package/dist/logger-JU2jYitA.d.ts +171 -0
  73. package/dist/logging/index.d.ts +198 -0
  74. package/dist/logging/index.js +578 -0
  75. package/dist/logging/index.js.map +1 -0
  76. package/dist/pathfinder/index.d.ts +532 -0
  77. package/dist/pathfinder/index.js +6750 -0
  78. package/dist/pathfinder/index.js.map +1 -0
  79. package/dist/registry-x1-Qi_Tz.d.ts +349 -0
  80. package/dist/schema/index.d.ts +388 -0
  81. package/dist/schema/index.js +5522 -0
  82. package/dist/schema/index.js.map +1 -0
  83. package/dist/suggest-CLqjLZ5L.d.ts +168 -0
  84. package/dist/telemetry/index.d.ts +161 -0
  85. package/dist/telemetry/index.js +5610 -0
  86. package/dist/telemetry/index.js.map +1 -0
  87. package/dist/types-B_WtvQbS.d.ts +214 -0
  88. package/package.json +130 -0
  89. package/schemas/crucible-ts/api/http/v1.0.0/README.md +22 -0
  90. package/schemas/crucible-ts/api/http/v1.0.0/error-response.schema.json +54 -0
  91. package/schemas/crucible-ts/api/http/v1.0.0/health-response.schema.json +70 -0
  92. package/schemas/crucible-ts/api/http/v1.0.0/success-response.schema.json +51 -0
  93. package/schemas/crucible-ts/api/http/v1.0.0/version-response.schema.json +61 -0
  94. package/schemas/crucible-ts/ascii/v1.0.0/README.md +69 -0
  95. package/schemas/crucible-ts/ascii/v1.0.0/box-chars.schema.json +60 -0
  96. package/schemas/crucible-ts/ascii/v1.0.0/string-analysis.schema.json +45 -0
  97. package/schemas/crucible-ts/assessment/README.md +25 -0
  98. package/schemas/crucible-ts/assessment/v1.0.0/severity-definitions.schema.json +60 -0
  99. package/schemas/crucible-ts/config/fulmen-ecosystem/v1.0.0/README.md +11 -0
  100. package/schemas/crucible-ts/config/fulmen-ecosystem/v1.0.0/fulmen-config-paths.schema.json +61 -0
  101. package/schemas/crucible-ts/config/goneat/README.md +60 -0
  102. package/schemas/crucible-ts/config/goneat/v1.0.0/dates.yaml +234 -0
  103. package/schemas/crucible-ts/config/goneat/v1.0.0/goneat-config.yaml +344 -0
  104. package/schemas/crucible-ts/config/goneat/v1.0.0/lifecycle-phase.json +20 -0
  105. package/schemas/crucible-ts/config/goneat/v1.0.0/release-phase.json +17 -0
  106. package/schemas/crucible-ts/config/goneat/v1.0.0/security-policy.yaml +178 -0
  107. package/schemas/crucible-ts/config/goneat/v1.0.0/version-policy.schema.yaml +205 -0
  108. package/schemas/crucible-ts/config/repository/app-identity/v1.0.0/app-identity.schema.json +143 -0
  109. package/schemas/crucible-ts/config/repository/v1.0.0/lifecycle-phase.json +20 -0
  110. package/schemas/crucible-ts/config/repository-category/codex/v1.0.0/codex-config.schema.json +288 -0
  111. package/schemas/crucible-ts/config/standards/v1.0.0/adr-adoption-status.json +60 -0
  112. package/schemas/crucible-ts/config/standards/v1.0.0/adr-frontmatter.schema.json +225 -0
  113. package/schemas/crucible-ts/config/standards/v1.0.0/adr-lifecycle-status.json +62 -0
  114. package/schemas/crucible-ts/config/sync-consumer-config.yaml +51 -0
  115. package/schemas/crucible-ts/config/sync-keys.schema.yaml +37 -0
  116. package/schemas/crucible-ts/content/README.md +19 -0
  117. package/schemas/crucible-ts/content/binary-embed-manifest/v1.0.0/README.md +13 -0
  118. package/schemas/crucible-ts/content/binary-embed-manifest/v1.0.0/binary-embed-manifest.schema.yaml +36 -0
  119. package/schemas/crucible-ts/content/embed-manifest/v1.1.0/README.md +13 -0
  120. package/schemas/crucible-ts/content/embed-manifest/v1.1.0/embed-manifest.schema.yaml +78 -0
  121. package/schemas/crucible-ts/content/ssot-provenance/v1.0.0/README.md +200 -0
  122. package/schemas/crucible-ts/content/ssot-provenance/v1.0.0/ssot-provenance.schema.json +128 -0
  123. package/schemas/crucible-ts/error-handling/v1.0.0/error-response.schema.json +75 -0
  124. package/schemas/crucible-ts/library/foundry/v1.0.0/country-codes.schema.json +58 -0
  125. package/schemas/crucible-ts/library/foundry/v1.0.0/exit-codes.schema.json +300 -0
  126. package/schemas/crucible-ts/library/foundry/v1.0.0/http-status-groups.schema.json +74 -0
  127. package/schemas/crucible-ts/library/foundry/v1.0.0/mime-types.schema.json +60 -0
  128. package/schemas/crucible-ts/library/foundry/v1.0.0/patterns.schema.json +97 -0
  129. package/schemas/crucible-ts/library/foundry/v1.0.0/signals.schema.json +457 -0
  130. package/schemas/crucible-ts/library/foundry/v1.0.0/similarity.schema.json +260 -0
  131. package/schemas/crucible-ts/library/foundry/v2.0.0/similarity.schema.json +558 -0
  132. package/schemas/crucible-ts/library/fulhash/v1.0.0/README.md +6 -0
  133. package/schemas/crucible-ts/library/fulhash/v1.0.0/checksum-string.schema.json +8 -0
  134. package/schemas/crucible-ts/library/fulhash/v1.0.0/digest.schema.json +100 -0
  135. package/schemas/crucible-ts/library/fulhash/v1.0.0/fixtures.schema.json +227 -0
  136. package/schemas/crucible-ts/library/module-manifest/v1.0.0/README.md +31 -0
  137. package/schemas/crucible-ts/library/module-manifest/v1.0.0/module-manifest.schema.json +132 -0
  138. package/schemas/crucible-ts/meta/README.md +23 -0
  139. package/schemas/crucible-ts/meta/draft-07/schema.json +245 -0
  140. package/schemas/crucible-ts/meta/draft-2020-12/meta/applicator.json +81 -0
  141. package/schemas/crucible-ts/meta/draft-2020-12/meta/content.json +21 -0
  142. package/schemas/crucible-ts/meta/draft-2020-12/meta/core.json +64 -0
  143. package/schemas/crucible-ts/meta/draft-2020-12/meta/format-annotation.json +15 -0
  144. package/schemas/crucible-ts/meta/draft-2020-12/meta/meta-data.json +35 -0
  145. package/schemas/crucible-ts/meta/draft-2020-12/meta/unevaluated.json +18 -0
  146. package/schemas/crucible-ts/meta/draft-2020-12/meta/validation.json +119 -0
  147. package/schemas/crucible-ts/meta/draft-2020-12/schema.json +80 -0
  148. package/schemas/crucible-ts/observability/logging/v1.0.0/README.md +82 -0
  149. package/schemas/crucible-ts/observability/logging/v1.0.0/definitions.schema.json +140 -0
  150. package/schemas/crucible-ts/observability/logging/v1.0.0/log-event.schema.json +179 -0
  151. package/schemas/crucible-ts/observability/logging/v1.0.0/logger-config.schema.json +518 -0
  152. package/schemas/crucible-ts/observability/logging/v1.0.0/logging-policy.schema.json +225 -0
  153. package/schemas/crucible-ts/observability/logging/v1.0.0/middleware-config.schema.json +181 -0
  154. package/schemas/crucible-ts/observability/logging/v1.0.0/severity-filter.schema.json +38 -0
  155. package/schemas/crucible-ts/observability/metrics/v1.0.0/metrics-event.schema.json +86 -0
  156. package/schemas/crucible-ts/pathfinder/v1.0.0/README.md +104 -0
  157. package/schemas/crucible-ts/pathfinder/v1.0.0/error-response.schema.json +35 -0
  158. package/schemas/crucible-ts/pathfinder/v1.0.0/find-query.schema.json +49 -0
  159. package/schemas/crucible-ts/pathfinder/v1.0.0/finder-config.schema.json +91 -0
  160. package/schemas/crucible-ts/pathfinder/v1.0.0/metadata.schema.json +61 -0
  161. package/schemas/crucible-ts/pathfinder/v1.0.0/path-constraint.schema.json +50 -0
  162. package/schemas/crucible-ts/pathfinder/v1.0.0/path-result.schema.json +40 -0
  163. package/schemas/crucible-ts/protocol/http/v1.0.0/README.md +22 -0
  164. package/schemas/crucible-ts/protocol/http/v1.0.0/error-response.schema.json +54 -0
  165. package/schemas/crucible-ts/protocol/http/v1.0.0/health-response.schema.json +70 -0
  166. package/schemas/crucible-ts/protocol/http/v1.0.0/success-response.schema.json +51 -0
  167. package/schemas/crucible-ts/protocol/http/v1.0.0/version-response.schema.json +61 -0
  168. package/schemas/crucible-ts/schema-validation/v1.0.0/README.md +65 -0
  169. package/schemas/crucible-ts/schema-validation/v1.0.0/schema-registry.schema.json +31 -0
  170. package/schemas/crucible-ts/schema-validation/v1.0.0/validator-config.schema.json +36 -0
  171. package/schemas/crucible-ts/server/management/v1.0.0/server-management.schema.json +199 -0
  172. package/schemas/crucible-ts/taxonomy/language/v1.0.0/README.md +30 -0
  173. package/schemas/crucible-ts/taxonomy/language/v1.0.0/language-key.schema.json +17 -0
  174. package/schemas/crucible-ts/taxonomy/language/v1.0.0/language-metadata.schema.json +44 -0
  175. package/schemas/crucible-ts/taxonomy/repository-category/v1.0.0/README.md +31 -0
  176. package/schemas/crucible-ts/taxonomy/repository-category/v1.0.0/category-key.schema.json +19 -0
  177. package/schemas/crucible-ts/taxonomy/repository-category/v1.0.0/category-metadata.schema.json +39 -0
  178. package/schemas/crucible-ts/terminal/v1.0.0/README.md +45 -0
  179. package/schemas/crucible-ts/terminal/v1.0.0/catalog/apple-terminal.yaml +2 -0
  180. package/schemas/crucible-ts/terminal/v1.0.0/catalog/ghostty.yaml +13 -0
  181. package/schemas/crucible-ts/terminal/v1.0.0/catalog/iterm2.yaml +13 -0
  182. package/schemas/crucible-ts/terminal/v1.0.0/schema.json +40 -0
  183. package/schemas/crucible-ts/tooling/external-tools/v1.0.0/README.md +164 -0
  184. package/schemas/crucible-ts/tooling/external-tools/v1.0.0/external-tools-manifest.schema.yaml +83 -0
  185. package/schemas/crucible-ts/tooling/goneat-tools/v1.0.0/README.md +177 -0
  186. package/schemas/crucible-ts/tooling/goneat-tools/v1.0.0/goneat-tools-config.schema.yaml +146 -0
  187. package/schemas/crucible-ts/web/branding/v1.0.0/site-branding.schema.json +79 -0
  188. package/schemas/crucible-ts/web/styling/v1.0.0/site-styling.schema.json +321 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/telemetry/counter.ts","../../src/telemetry/gauge.ts","../../src/telemetry/taxonomy.ts","../../src/telemetry/histogram.ts","../../src/telemetry/registry.ts","../../src/telemetry/types.ts","../../src/schema/errors.ts","../../src/schema/utils.ts","../../src/schema/goneat-bridge.ts","../../src/schema/normalizer.ts","../../src/schema/registry.ts","../../src/schema/validator.ts","../../src/schema/export.ts","../../src/foundry/errors.ts","../../src/foundry/loader.ts","../../src/foundry/country-codes.ts","../../src/crucible/foundry/exitCodes.ts","../../src/foundry/exit-codes/capabilities.ts","../../src/foundry/exit-codes/simplified.ts","../../src/foundry/exit-codes/index.ts","../../src/foundry/http-statuses.ts","../../src/foundry/magic-numbers.ts","../../src/foundry/detector.ts","../../src/foundry/mime-types.ts","../../src/foundry/patterns.ts","../../src/foundry/signals/catalog.ts","../../src/foundry/signals/capabilities.ts","../../src/foundry/signals/convenience.ts","../../src/foundry/signals/double-tap.ts","../../src/foundry/signals/windows.ts","../../src/foundry/signals/guards.ts","../../src/foundry/signals/http-helper.ts","../../src/foundry/signals/manager.ts","../../src/foundry/signals/reload.ts","../../src/foundry/signals/index.ts","../../src/foundry/similarity/distance.ts","../../src/foundry/similarity/errors.ts","../../src/foundry/similarity/normalization.ts","../../src/foundry/similarity/score.ts","../../src/foundry/similarity/suggest.ts","../../src/foundry/similarity/index.ts","../../src/foundry/index.ts","../../src/appidentity/cache.ts","../../src/appidentity/constants.ts","../../src/errors/correlation.ts","../../src/errors/severity.ts","../../src/errors/serialization.ts","../../src/errors/validators.ts","../../src/errors/fulmen-error.ts","../../src/errors/index.ts","../../src/appidentity/errors.ts","../../src/appidentity/discovery.ts","../../src/appidentity/loader.ts","../../src/schema/cli.ts","../../src/schema/index.ts","../../src/telemetry/validators.ts","../../src/telemetry/index.ts"],"names":["parseYaml","isValidMetricName","ExportErrorReason","parseYAML","init_registry","__filename","__dirname","join","readFile","access","fileURLToPath","dirname","stringifyYAML","extname","init_errors","SimplifiedMode","deepClone","deepFreeze","ensureCatalogLoaded","catalogCache","loadCatalog","SSOT_PATHS","getPlatform","isPOSIX","isWindows","supportsSignalExitCodes","getPlatformCapabilities","init_capabilities","wasmNormalize","substringSimilarity","wasmScore","wasmSuggest","errors_exports","init_loader","validateSchema","writeFile","exportSchema","exitCodes","SchemaExportError","SchemaValidationError","loadIdentity","AppIdentityError","getValidationErrors","formatValidationErrors","init_validators","VERSION"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA,IAca;AAdb,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,0BAAA,GAAA;AAcO,IAAM,UAAN,MAAc;AAAA,MAGnB,YAA4B,IAAA,EAAkB;AAAlB,QAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAAA,MAAmB;AAAA,MAFvC,KAAA,GAAQ,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAgBhB,GAAA,CAAI,QAAQ,CAAA,EAAS;AACnB,QAAA,IAAI,QAAQ,CAAA,EAAG;AACb,UAAA,MAAM,IAAI,KAAA,CAAM,CAAA,yCAAA,EAA4C,KAAK,CAAA,CAAE,CAAA;AAAA,QACrE;AACA,QAAA,IAAA,CAAK,KAAA,IAAS,KAAA;AAAA,MAChB;AAAA;AAAA;AAAA;AAAA,MAKA,QAAA,GAAmB;AACjB,QAAA,OAAO,IAAA,CAAK,KAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,KAAA,GAAc;AACZ,QAAA,IAAA,CAAK,KAAA,GAAQ,CAAA;AAAA,MACf;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACnDA,IAca;AAdb,IAAA,UAAA,GAAA,KAAA,CAAA;AAAA,EAAA,wBAAA,GAAA;AAcO,IAAM,QAAN,MAAY;AAAA,MAGjB,YAA4B,IAAA,EAAkB;AAAlB,QAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAAA,MAAmB;AAAA,MAFvC,KAAA,GAAQ,CAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAgBhB,IAAI,KAAA,EAAqB;AACvB,QAAA,IAAA,CAAK,KAAA,GAAQ,KAAA;AAAA,MACf;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,GAAA,CAAI,QAAQ,CAAA,EAAS;AACnB,QAAA,IAAA,CAAK,KAAA,IAAS,KAAA;AAAA,MAChB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,GAAA,CAAI,QAAQ,CAAA,EAAS;AACnB,QAAA,IAAA,CAAK,KAAA,IAAS,KAAA;AAAA,MAChB;AAAA;AAAA;AAAA;AAAA,MAKA,QAAA,GAAmB;AACjB,QAAA,OAAO,IAAA,CAAK,KAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,KAAA,GAAc;AACZ,QAAA,IAAA,CAAK,KAAA,GAAQ,CAAA;AAAA,MACf;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;ACsGA,eAAsB,WAAA,GAAwC;AAC5D,EAAA,OAAO,cAAA,CAAe,WAAA,EAAY,CAAE,WAAA,EAAY;AAClD;AAQA,eAAsB,UAAU,IAAA,EAAyD;AACvF,EAAA,OAAO,cAAA,CAAe,WAAA,EAAY,CAAE,SAAA,CAAU,IAAI,CAAA;AACpD;AAQA,eAAsB,eAAe,IAAA,EAAmD;AACtF,EAAA,OAAO,cAAA,CAAe,WAAA,EAAY,CAAE,cAAA,CAAe,IAAI,CAAA;AACzD;AAiBA,eAAsB,kBAAkB,IAAA,EAAiD;AACvF,EAAA,OAAO,cAAA,CAAe,WAAA,EAAY,CAAE,iBAAA,CAAkB,IAAI,CAAA;AAC5D;AAQA,eAAsB,kBAAkB,IAAA,EAAgC;AACtE,EAAA,OAAO,cAAA,CAAe,WAAA,EAAY,CAAE,iBAAA,CAAkB,IAAI,CAAA;AAC5D;AA3NA,IAsCa,kBAAA,CAAA,CAKP;AA3CN,IAAA,aAAA,GAAA,KAAA,CAAA;AAAA,EAAA,2BAAA,GAAA;AAsCO,IAAM,kBAAA,GAAqB,CAAC,CAAA,EAAG,CAAA,EAAG,EAAA,EAAI,IAAI,GAAA,EAAK,GAAA,EAAK,GAAA,EAAM,GAAA,EAAM,GAAK,CAAA;AAK5E,IAAM,cAAA,GAAN,MAAM,eAAA,CAAe;AAAA,MACnB,OAAe,QAAA;AAAA,MACP,QAAA,GAAmC,IAAA;AAAA,MACnC,WAAA,GAA+C,IAAA;AAAA,MAC/C,SAAA,GAA0B,IAAA;AAAA,MAE1B,WAAA,GAAc;AAAA,MAEtB;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAA,GAA8B;AACnC,QAAA,IAAI,CAAC,gBAAe,QAAA,EAAU;AAC5B,UAAA,eAAA,CAAe,QAAA,GAAW,IAAI,eAAA,EAAe;AAAA,QAC/C;AACA,QAAA,OAAO,eAAA,CAAe,QAAA;AAAA,MACxB;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,IAAA,GAAiC;AAC7C,QAAA,IAAI,IAAA,CAAK,aAAa,IAAA,EAAM;AAC1B,UAAA,OAAO,IAAA,CAAK,QAAA;AAAA,QACd;AAEA,QAAA,IAAI,IAAA,CAAK,cAAc,IAAA,EAAM;AAC3B,UAAA,MAAM,IAAA,CAAK,SAAA;AAAA,QACb;AAEA,QAAA,IAAI,KAAK,WAAA,EAAa;AACpB,UAAA,OAAO,IAAA,CAAK,WAAA;AAAA,QACd;AAEA,QAAA,IAAA,CAAK,eAAe,YAAY;AAC9B,UAAA,IAAI;AAGF,YAAA,MAAM,YAAA,GAAe,IAAA;AAAA,cACnB,SAAA;AAAA,cACA,IAAA;AAAA,cACA,IAAA;AAAA,cACA,QAAA;AAAA,cACA,aAAA;AAAA,cACA,UAAA;AAAA,cACA;AAAA,aACF;AAEA,YAAA,MAAM,OAAA,GAAU,MAAM,QAAA,CAAS,YAAA,EAAc,OAAO,CAAA;AACpD,YAAA,IAAA,CAAK,QAAA,GAAWA,MAAU,OAAO,CAAA;AAEjC,YAAA,OAAO,IAAA,CAAK,QAAA;AAAA,UACd,SAAS,GAAA,EAAK;AACZ,YAAA,IAAA,CAAK,SAAA,GAAY,eAAe,KAAA,GAAQ,GAAA,GAAM,IAAI,KAAA,CAAM,MAAA,CAAO,GAAG,CAAC,CAAA;AACnE,YAAA,MAAM,IAAI,KAAA,CAAM,CAAA,iCAAA,EAAoC,IAAA,CAAK,SAAA,CAAU,OAAO,CAAA,CAAE,CAAA;AAAA,UAC9E;AAAA,QACF,CAAA,GAAG;AAEH,QAAA,OAAO,IAAA,CAAK,WAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,WAAA,GAAwC;AAC5C,QAAA,OAAO,KAAK,IAAA,EAAK;AAAA,MACnB;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,UAAU,IAAA,EAAyD;AACvE,QAAA,MAAM,QAAA,GAAW,MAAM,IAAA,CAAK,IAAA,EAAK;AACjC,QAAA,OAAO,SAAS,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,SAAS,IAAI,CAAA;AAAA,MACrD;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,eAAe,IAAA,EAAmD;AACtE,QAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,SAAA,CAAU,IAAI,CAAA;AACxC,QAAA,OAAO,MAAA,EAAQ,IAAA;AAAA,MACjB;AAAA;AAAA;AAAA;AAAA;AAAA,MAMA,MAAM,kBAAkB,IAAA,EAAiD;AAEvE,QAAA,IAAI,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA,EAAG;AACxB,UAAA,MAAM,QAAA,GAAW,MAAM,IAAA,CAAK,IAAA,EAAK;AACjC,UAAA,OAAO,QAAA,CAAS,SAAS,iBAAA,CAAkB,UAAA;AAAA,QAC7C;AACA,QAAA,OAAO,MAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,kBAAkB,IAAA,EAAgC;AACtD,QAAA,IAAI;AACF,UAAA,MAAM,QAAA,GAAW,MAAM,IAAA,CAAK,IAAA,EAAK;AACjC,UAAA,OAAO,SAAS,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,SAAS,IAAI,CAAA;AAAA,QACrD,CAAA,CAAA,MAAQ;AACN,UAAA,OAAO,KAAA;AAAA,QACT;AAAA,MACF;AAAA;AAAA;AAAA;AAAA;AAAA,MAMA,OAAO,MAAA,GAAe;AACpB,QAAA,eAAA,CAAe,QAAA,GAAW,IAAI,eAAA,EAAe;AAAA,MAC/C;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACjKA,IAgBa;AAhBb,IAAA,cAAA,GAAA,KAAA,CAAA;AAAA,EAAA,4BAAA,GAAA;AAOA,IAAA,aAAA,EAAA;AASO,IAAM,YAAN,MAAgB;AAAA,MAMrB,WAAA,CACkB,MAChB,OAAA,EACA;AAFgB,QAAA,IAAA,CAAA,IAAA,GAAA,IAAA;AAIhB,QAAA,IAAI,SAAS,OAAA,EAAS;AACpB,UAAA,IAAA,CAAK,OAAA,GAAU,CAAC,GAAG,OAAA,CAAQ,OAAO,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,GAAI,CAAC,CAAA;AAAA,QAC1D,CAAA,MAAA,IAAW,IAAA,CAAK,QAAA,CAAS,KAAK,CAAA,EAAG;AAC/B,UAAA,IAAA,CAAK,OAAA,GAAU,CAAC,GAAG,kBAAkB,CAAA;AAAA,QACvC,CAAA,MAAO;AACL,UAAA,IAAA,CAAK,UAAU,EAAC;AAAA,QAClB;AAGA,QAAA,KAAA,MAAW,MAAA,IAAU,KAAK,OAAA,EAAS;AACjC,UAAA,IAAA,CAAK,YAAA,CAAa,GAAA,CAAI,MAAA,EAAQ,CAAC,CAAA;AAAA,QACjC;AAAA,MACF;AAAA,MAtBQ,KAAA,GAAQ,CAAA;AAAA,MACR,GAAA,GAAM,CAAA;AAAA,MACN,YAAA,uBAAwC,GAAA,EAAI;AAAA,MACnC,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAiCjB,QAAQ,KAAA,EAAqB;AAC3B,QAAA,IAAA,CAAK,KAAA,EAAA;AACL,QAAA,IAAA,CAAK,GAAA,IAAO,KAAA;AAGZ,QAAA,KAAA,MAAW,MAAA,IAAU,KAAK,OAAA,EAAS;AACjC,UAAA,IAAI,SAAS,MAAA,EAAQ;AACnB,YAAA,IAAA,CAAK,YAAA,CAAa,IAAI,MAAA,EAAA,CAAS,IAAA,CAAK,aAAa,GAAA,CAAI,MAAM,CAAA,IAAK,CAAA,IAAK,CAAC,CAAA;AAAA,UACxE;AAAA,QACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,UAAA,GAA+B;AAC7B,QAAA,MAAM,OAAA,GAA6B,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,CAAC,EAAA,MAAQ;AAAA,UAC3D,EAAA;AAAA,UACA,KAAA,EAAO,IAAA,CAAK,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA,IAAK;AAAA,SACtC,CAAE,CAAA;AAEF,QAAA,OAAO;AAAA,UACL,OAAO,IAAA,CAAK,KAAA;AAAA,UACZ,KAAK,IAAA,CAAK,GAAA;AAAA,UACV;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,QAAA,GAAmB;AACjB,QAAA,OAAO,IAAA,CAAK,KAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,MAAA,GAAiB;AACf,QAAA,OAAO,IAAA,CAAK,GAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,UAAA,GAAqB;AACnB,QAAA,OAAO,KAAK,KAAA,GAAQ,CAAA,GAAI,IAAA,CAAK,GAAA,GAAM,KAAK,KAAA,GAAQ,CAAA;AAAA,MAClD;AAAA;AAAA;AAAA;AAAA,MAKA,KAAA,GAAc;AACZ,QAAA,IAAA,CAAK,KAAA,GAAQ,CAAA;AACb,QAAA,IAAA,CAAK,GAAA,GAAM,CAAA;AACX,QAAA,KAAA,MAAW,MAAA,IAAU,KAAK,OAAA,EAAS;AACjC,UAAA,IAAA,CAAK,YAAA,CAAa,GAAA,CAAI,MAAA,EAAQ,CAAC,CAAA;AAAA,QACjC;AAAA,MACF;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;AClHA,IAmBa;AAnBb,IAAA,aAAA,GAAA,KAAA,CAAA;AAAA,EAAA,2BAAA,GAAA;AAOA,IAAA,YAAA,EAAA;AACA,IAAA,UAAA,EAAA;AACA,IAAA,cAAA,EAAA;AACA,IAAA,aAAA,EAAA;AASO,IAAM,kBAAN,MAAsB;AAAA,MACnB,QAAA,uBAAyC,GAAA,EAAI;AAAA,MAC7C,MAAA,uBAAqC,GAAA,EAAI;AAAA,MACzC,UAAA,uBAA6C,GAAA,EAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAczD,QAAQ,IAAA,EAA2B;AACjC,QAAA,IAAI,OAAA,GAAU,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,IAAI,CAAA;AACpC,QAAA,IAAI,CAAC,OAAA,EAAS;AACZ,UAAA,OAAA,GAAU,IAAI,QAAQ,IAAI,CAAA;AAC1B,UAAA,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,IAAA,EAAM,OAAO,CAAA;AAAA,QACjC;AACA,QAAA,OAAO,OAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAcA,MAAM,IAAA,EAAyB;AAC7B,QAAA,IAAI,KAAA,GAAQ,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,IAAI,CAAA;AAChC,QAAA,IAAI,CAAC,KAAA,EAAO;AACV,UAAA,KAAA,GAAQ,IAAI,MAAM,IAAI,CAAA;AACtB,UAAA,IAAA,CAAK,MAAA,CAAO,GAAA,CAAI,IAAA,EAAM,KAAK,CAAA;AAAA,QAC7B;AACA,QAAA,OAAO,KAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAqBA,SAAA,CAAU,MAAkB,OAAA,EAAuC;AACjE,QAAA,IAAI,SAAA,GAAY,IAAA,CAAK,UAAA,CAAW,GAAA,CAAI,IAAI,CAAA;AACxC,QAAA,IAAI,CAAC,SAAA,EAAW;AACd,UAAA,SAAA,GAAY,IAAI,SAAA,CAAU,IAAA,EAAM,OAAO,CAAA;AACvC,UAAA,IAAA,CAAK,UAAA,CAAW,GAAA,CAAI,IAAA,EAAM,SAAS,CAAA;AAAA,QACrC;AACA,QAAA,OAAO,SAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAgBA,MAAM,MAAA,GAAkC;AACtC,QAAA,MAAM,SAAyB,EAAC;AAChC,QAAA,MAAM,SAAA,GAAA,iBAAY,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAGzC,QAAA,KAAA,MAAW,CAAC,IAAA,EAAM,OAAO,CAAA,IAAK,KAAK,QAAA,EAAU;AAC3C,UAAA,MAAM,IAAA,GAAO,MAAM,cAAA,CAAe,IAAI,CAAA;AACtC,UAAA,MAAA,CAAO,IAAA,CAAK;AAAA,YACV,SAAA;AAAA,YACA,IAAA;AAAA,YACA,KAAA,EAAO,QAAQ,QAAA,EAAS;AAAA,YACxB;AAAA,WACD,CAAA;AAAA,QACH;AAGA,QAAA,KAAA,MAAW,CAAC,IAAA,EAAM,KAAK,CAAA,IAAK,KAAK,MAAA,EAAQ;AACvC,UAAA,MAAM,IAAA,GAAO,MAAM,cAAA,CAAe,IAAI,CAAA;AACtC,UAAA,MAAA,CAAO,IAAA,CAAK;AAAA,YACV,SAAA;AAAA,YACA,IAAA;AAAA,YACA,KAAA,EAAO,MAAM,QAAA,EAAS;AAAA,YACtB;AAAA,WACD,CAAA;AAAA,QACH;AAGA,QAAA,KAAA,MAAW,CAAC,IAAA,EAAM,SAAS,CAAA,IAAK,KAAK,UAAA,EAAY;AAC/C,UAAA,MAAM,IAAA,GAAO,MAAM,cAAA,CAAe,IAAI,CAAA;AACtC,UAAA,MAAA,CAAO,IAAA,CAAK;AAAA,YACV,SAAA;AAAA,YACA,IAAA;AAAA,YACA,KAAA,EAAO,UAAU,UAAA,EAAW;AAAA,YAC5B;AAAA,WACD,CAAA;AAAA,QACH;AAEA,QAAA,OAAO,MAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAsBA,MAAM,MAAM,OAAA,EAAiD;AAC3D,QAAA,MAAM,MAAA,GAAS,MAAM,IAAA,CAAK,MAAA,EAAO;AAEjC,QAAA,IAAI;AAEF,UAAA,IAAI,SAAS,IAAA,EAAM;AACjB,YAAA,OAAA,CAAQ,KAAK,MAAM,CAAA;AAAA,UACrB;AAAA,QACF,CAAA,SAAE;AAEA,UAAA,IAAA,CAAK,KAAA,EAAM;AAAA,QACb;AAEA,QAAA,OAAO,MAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,KAAA,GAAc;AACZ,QAAA,KAAA,MAAW,OAAA,IAAW,IAAA,CAAK,QAAA,CAAS,MAAA,EAAO,EAAG;AAC5C,UAAA,OAAA,CAAQ,KAAA,EAAM;AAAA,QAChB;AACA,QAAA,KAAA,MAAW,KAAA,IAAS,IAAA,CAAK,MAAA,CAAO,MAAA,EAAO,EAAG;AACxC,UAAA,KAAA,CAAM,KAAA,EAAM;AAAA,QACd;AACA,QAAA,KAAA,MAAW,SAAA,IAAa,IAAA,CAAK,UAAA,CAAW,MAAA,EAAO,EAAG;AAChD,UAAA,SAAA,CAAU,KAAA,EAAM;AAAA,QAClB;AAAA,MACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQA,cAAA,GAA+B;AAC7B,QAAA,MAAM,KAAA,uBAAY,GAAA,EAAgB;AAClC,QAAA,KAAA,MAAW,IAAA,IAAQ,IAAA,CAAK,QAAA,CAAS,IAAA,EAAK,EAAG;AACvC,UAAA,KAAA,CAAM,IAAI,IAAI,CAAA;AAAA,QAChB;AACA,QAAA,KAAA,MAAW,IAAA,IAAQ,IAAA,CAAK,MAAA,CAAO,IAAA,EAAK,EAAG;AACrC,UAAA,KAAA,CAAM,IAAI,IAAI,CAAA;AAAA,QAChB;AACA,QAAA,KAAA,MAAW,IAAA,IAAQ,IAAA,CAAK,UAAA,CAAW,IAAA,EAAK,EAAG;AACzC,UAAA,KAAA,CAAM,IAAI,IAAI,CAAA;AAAA,QAChB;AACA,QAAA,OAAO,KAAA,CAAM,KAAK,KAAK,CAAA;AAAA,MACzB;AAAA;AAAA;AAAA;AAAA,MAKA,cAAA,GAAyB;AACvB,QAAA,OAAO,KAAK,QAAA,CAAS,IAAA,GAAO,KAAK,MAAA,CAAO,IAAA,GAAO,KAAK,UAAA,CAAW,IAAA;AAAA,MACjE;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACtIO,SAAS,mBAAmB,KAAA,EAA2C;AAC5E,EAAA,OACE,OAAO,UAAU,QAAA,IACjB,KAAA,KAAU,QACV,OAAA,IAAW,KAAA,IACX,KAAA,IAAS,KAAA,IACT,SAAA,IAAa,KAAA;AAEjB;AAKO,SAASC,mBAAkB,IAAA,EAAkC;AAClE,EAAA,MAAM,UAAA,GAA2B;AAAA,IAC/B,oBAAA;AAAA,IACA,0BAAA;AAAA,IACA,gBAAA;AAAA,IACA,oBAAA;AAAA,IACA,oBAAA;AAAA,IACA,8BAAA;AAAA,IACA,8BAAA;AAAA,IACA,sBAAA;AAAA,IACA,oBAAA;AAAA,IACA,yBAAA;AAAA,IACA;AAAA,GACF;AACA,EAAA,OAAO,UAAA,CAAW,SAAS,IAAkB,CAAA;AAC/C;AAKO,SAAS,kBAAkB,IAAA,EAAkC;AAClE,EAAA,MAAM,UAAA,GAA2B,CAAC,OAAA,EAAS,IAAA,EAAM,SAAS,SAAS,CAAA;AACnE,EAAA,OAAO,UAAA,CAAW,SAAS,IAAkB,CAAA;AAC/C;AAjIA,IAAA,UAAA,GAAA,KAAA,CAAA;AAAA,EAAA,wBAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACAA,IAAA,cAAA,GAAA,EAAA;AAAA,QAAA,CAAA,cAAA,EAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,qBAAA,EAAA,MAAA;AAAA,CAAA,CAAA;AAAA,IASY,mBAWC,qBAAA,EA2KA,iBAAA;AA/Lb,IAAA,WAAA,GAAA,KAAA,CAAA;AAAA,EAAA,sBAAA,GAAA;AASO,IAAK,iBAAA,qBAAAC,kBAAAA,KAAL;AACL,MAAAA,mBAAA,aAAA,CAAA,GAAc,aAAA;AACd,MAAAA,mBAAA,cAAA,CAAA,GAAe,cAAA;AACf,MAAAA,mBAAA,gBAAA,CAAA,GAAiB,gBAAA;AACjB,MAAAA,mBAAA,mBAAA,CAAA,GAAoB,mBAAA;AACpB,MAAAA,mBAAA,SAAA,CAAA,GAAU,SAAA;AALA,MAAA,OAAAA,kBAAAA;AAAA,IAAA,CAAA,EAAA,iBAAA,IAAA,EAAA,CAAA;AAWL,IAAM,qBAAA,GAAN,MAAM,sBAAA,SAA8B,KAAA,CAAM;AAAA,MAC/C,YACE,OAAA,EACO,QAAA,EACA,cAA4C,EAAC,EAC7C,QACA,KAAA,EACP;AACA,QAAA,KAAA,CAAM,OAAO,CAAA;AALN,QAAA,IAAA,CAAA,QAAA,GAAA,QAAA;AACA,QAAA,IAAA,CAAA,WAAA,GAAA,WAAA;AACA,QAAA,IAAA,CAAA,MAAA,GAAA,MAAA;AACA,QAAA,IAAA,CAAA,KAAA,GAAA,KAAA;AAGP,QAAA,IAAA,CAAK,IAAA,GAAO,uBAAA;AAGZ,QAAA,IAAI,MAAM,iBAAA,EAAmB;AAC3B,UAAA,KAAA,CAAM,iBAAA,CAAkB,MAAM,sBAAqB,CAAA;AAAA,QACrD;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,eAAe,QAAA,EAAyC;AAC7D,QAAA,OAAO,IAAI,sBAAA,CAAsB,CAAA,kBAAA,EAAqB,QAAQ,IAAI,QAAQ,CAAA;AAAA,MAC5E;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,kBAAA,CAAmB,MAAA,EAAsB,OAAA,EAAwC;AACtF,QAAA,OAAO,IAAI,uBAAsB,CAAA,sBAAA,EAAyB,OAAO,IAAI,MAAA,EAAW,IAAI,MAAM,CAAA;AAAA,MAC5F;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,gBAAA,CACL,QAAA,EACA,WAAA,EACA,MAAA,EACuB;AACvB,QAAA,MAAM,UAAA,GAAa,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,OAAO,CAAA,CAAE,MAAA;AACrE,QAAA,MAAM,YAAA,GAAe,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,MAAM,CAAA,CAAE,MAAA;AAEtE,QAAA,MAAM,OAAA,GAAU,CAAA,0BAAA,EAA6B,UAAU,CAAA,WAAA,EAAc,YAAY,CAAA,WAAA,CAAA;AAEjF,QAAA,OAAO,IAAI,sBAAA,CAAsB,OAAA,EAAS,QAAA,EAAU,aAAa,MAAM,CAAA;AAAA,MACzE;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,eAAe,UAAA,EAA4C;AAChE,QAAA,MAAM,QAAA,GAAW,UAAA,GAAa,CAAA,IAAA,EAAO,UAAU,CAAA,CAAA,GAAK,EAAA;AACpD,QAAA,OAAO,IAAI,sBAAA;AAAA,UACT,0BAA0B,QAAQ,CAAA,iCAAA;AAAA,SACpC;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,sBAAsB,KAAA,EAAqC;AAChE,QAAA,OAAO,IAAI,sBAAA;AAAA,UACT,0DAAA;AAAA,UACA,MAAA;AAAA,UACA,EAAC;AAAA,UACD,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,iBAAiB,MAAA,EAA8C;AACpE,QAAA,OAAO,IAAI,sBAAA,CAAsB,yBAAA,EAA2B,MAAA,EAAW,IAAI,MAAM,CAAA;AAAA,MACnF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAA,CAAY,MAAA,EAAsB,KAAA,EAAqC;AAC5E,QAAA,OAAO,IAAI,sBAAA;AAAA,UACT,CAAA,wBAAA,EAA2B,MAAM,OAAO,CAAA,CAAA;AAAA,UACxC,MAAA;AAAA,UACA,EAAC;AAAA,UACD,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,cAAA,CAAe,MAAA,EAAsB,KAAA,EAAqC;AAC/E,QAAA,OAAO,IAAI,sBAAA;AAAA,UACT,CAAA,yBAAA,EAA4B,MAAM,OAAO,CAAA,CAAA;AAAA,UACzC,MAAA;AAAA,UACA,EAAC;AAAA,UACD,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,aAAA,CAAc,SAAA,EAAmB,OAAA,EAAwC;AAC9E,QAAA,OAAO,IAAI,sBAAA,CAAsB,CAAA,gBAAA,EAAmB,SAAS,CAAA,SAAA,EAAY,OAAO,CAAA,CAAE,CAAA;AAAA,MACpF;AAAA;AAAA;AAAA;AAAA,MAKA,MAAA,GAAiB;AACf,QAAA,IAAI,SAAS,IAAA,CAAK,OAAA;AAElB,QAAA,IAAI,KAAK,QAAA,EAAU;AACjB,UAAA,MAAA,IAAU;AAAA,WAAA,EAAgB,KAAK,QAAQ,CAAA,CAAA;AAAA,QACzC;AAEA,QAAA,IAAI,IAAA,CAAK,WAAA,CAAY,MAAA,GAAS,CAAA,EAAG;AAC/B,UAAA,MAAA,IAAU,wBAAA;AACV,UAAA,IAAA,CAAK,WAAA,CAAY,OAAA,CAAQ,CAAC,IAAA,EAAM,KAAA,KAAU;AACxC,YAAA,MAAA,IAAU;AAAA,EAAA,EAAO,QAAQ,CAAC,CAAA,GAAA,EAAM,KAAK,QAAQ,CAAA,EAAA,EAAK,KAAK,OAAO,CAAA,CAAA;AAC9D,YAAA,IAAI,KAAK,OAAA,EAAS;AAChB,cAAA,MAAA,IAAU,CAAA,IAAA,EAAO,KAAK,OAAO,CAAA,CAAA;AAAA,YAC/B;AACA,YAAA,IAAI,KAAK,OAAA,EAAS;AAChB,cAAA,MAAA,IAAU,CAAA,WAAA,EAAc,KAAK,OAAO,CAAA,CAAA,CAAA;AAAA,YACtC;AACA,YAAA,IAAI,KAAK,MAAA,EAAQ;AACf,cAAA,MAAA,IAAU,CAAA,EAAA,EAAK,KAAK,MAAM,CAAA,CAAA,CAAA;AAAA,YAC5B;AAAA,UACF,CAAC,CAAA;AAAA,QACH;AAEA,QAAA,IAAI,KAAK,MAAA,EAAQ;AACf,UAAA,MAAA,IAAU;;AAAA,QAAA,EAAe,IAAA,CAAK,OAAO,IAAI,CAAA,CAAA;AACzC,UAAA,IAAI,IAAA,CAAK,OAAO,EAAA,EAAI;AAClB,YAAA,MAAA,IAAU,CAAA,EAAA,EAAK,IAAA,CAAK,MAAA,CAAO,EAAE,CAAA,CAAA,CAAA;AAAA,UAC/B;AAAA,QACF;AAEA,QAAA,OAAO,MAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKA,MAAA,GAOE;AACA,QAAA,OAAO;AAAA,UACL,MAAM,IAAA,CAAK,IAAA;AAAA,UACX,SAAS,IAAA,CAAK,OAAA;AAAA,UACd,UAAU,IAAA,CAAK,QAAA;AAAA,UACf,aAAa,IAAA,CAAK,WAAA;AAAA,UAClB,QAAQ,IAAA,CAAK,MAAA;AAAA,UACb,KAAA,EAAO,KAAK,KAAA,EAAO;AAAA,SACrB;AAAA,MACF;AAAA,KACF;AAKO,IAAM,iBAAA,GAAN,MAAM,kBAAA,SAA0B,qBAAA,CAAsB;AAAA,MAC3D,WAAA,CACE,OAAA,EACO,MAAA,EACA,QAAA,EACA,SACA,KAAA,EACP;AACA,QAAA,KAAA,CAAM,OAAA,EAAS,QAAA,EAAU,EAAC,EAAG,QAAW,KAAK,CAAA;AALtC,QAAA,IAAA,CAAA,MAAA,GAAA,MAAA;AACA,QAAA,IAAA,CAAA,QAAA,GAAA,QAAA;AACA,QAAA,IAAA,CAAA,OAAA,GAAA,OAAA;AACA,QAAA,IAAA,CAAA,KAAA,GAAA,KAAA;AAGP,QAAA,IAAA,CAAK,IAAA,GAAO,mBAAA;AAEZ,QAAA,IAAI,MAAM,iBAAA,EAAmB;AAC3B,UAAA,KAAA,CAAM,iBAAA,CAAkB,MAAM,kBAAiB,CAAA;AAAA,QACjD;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAW,OAAA,EAAoC;AACpD,QAAA,OAAO,IAAI,kBAAA;AAAA,UACT,+BAA+B,OAAO,CAAA,kCAAA,CAAA;AAAA,UACtC,aAAA;AAAA,UACA,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,aAAA,CAAc,MAAA,EAAgB,OAAA,EAAoC;AACvE,QAAA,OAAO,IAAI,kBAAA;AAAA,UACT,0BAA0B,MAAM,CAAA,2BAAA,CAAA;AAAA,UAChC,gBAAA;AAAA,UACA,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAA,CAAY,OAAA,EAAiB,KAAA,EAAiC;AACnE,QAAA,OAAO,IAAI,kBAAA;AAAA,UACT,CAAA,0BAAA,EAA6B,OAAO,CAAA,EAAA,EAAK,KAAA,CAAM,OAAO,CAAA,CAAA;AAAA,UACtD,cAAA;AAAA,UACA,MAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,gBAAA,CAAiB,OAAA,EAAiB,KAAA,EAAkC;AACzE,QAAA,OAAO,IAAI,kBAAA;AAAA,UACT,0CAA0C,OAAO,CAAA,CAAA;AAAA,UACjD,mBAAA;AAAA,UACA,MAAA;AAAA,UACA,MAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACtPO,SAAS,kBAAkB,WAAA,EAAmD;AACnF,EAAA,IAAI,WAAA,CAAY,WAAW,CAAA,EAAG;AAC5B,IAAA,OAAO,6BAAA;AAAA,EACT;AAEA,EAAA,MAAM,QAAkB,EAAC;AACzB,EAAA,MAAM,SAAS,WAAA,CAAY,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,aAAa,OAAO,CAAA;AAC/D,EAAA,MAAM,WAAW,WAAA,CAAY,MAAA,CAAO,CAAC,CAAA,KAAM,CAAA,CAAE,aAAa,MAAM,CAAA;AAEhE,EAAA,IAAI,MAAA,CAAO,SAAS,CAAA,EAAG;AACrB,IAAA,KAAA,CAAM,IAAA,CAAK,CAAA,OAAA,EAAK,MAAA,CAAO,MAAM,CAAA,gBAAA,CAAkB,CAAA;AAC/C,IAAA,MAAA,CAAO,OAAA,CAAQ,CAAC,IAAA,EAAM,KAAA,KAAU;AAC9B,MAAA,KAAA,CAAM,KAAK,CAAA,EAAA,EAAK,KAAA,GAAQ,CAAC,CAAA,EAAA,EAAK,IAAA,CAAK,OAAO,CAAA,CAAE,CAAA;AAC5C,MAAA,IAAI,KAAK,OAAA,EAAS;AAChB,QAAA,KAAA,CAAM,IAAA,CAAK,CAAA,QAAA,EAAW,IAAA,CAAK,OAAO,CAAA,CAAE,CAAA;AAAA,MACtC;AACA,MAAA,IAAI,KAAK,OAAA,EAAS;AAChB,QAAA,KAAA,CAAM,IAAA,CAAK,CAAA,cAAA,EAAiB,IAAA,CAAK,OAAO,CAAA,CAAE,CAAA;AAAA,MAC5C;AAAA,IACF,CAAC,CAAA;AAAA,EACH;AAEA,EAAA,IAAI,QAAA,CAAS,SAAS,CAAA,EAAG;AACvB,IAAA,KAAA,CAAM,KAAK,EAAE,CAAA;AACb,IAAA,KAAA,CAAM,IAAA,CAAK,CAAA,cAAA,EAAO,QAAA,CAAS,MAAM,CAAA,kBAAA,CAAoB,CAAA;AACrD,IAAA,QAAA,CAAS,OAAA,CAAQ,CAAC,IAAA,EAAM,KAAA,KAAU;AAChC,MAAA,KAAA,CAAM,KAAK,CAAA,EAAA,EAAK,KAAA,GAAQ,CAAC,CAAA,EAAA,EAAK,IAAA,CAAK,OAAO,CAAA,CAAE,CAAA;AAC5C,MAAA,IAAI,KAAK,OAAA,EAAS;AAChB,QAAA,KAAA,CAAM,IAAA,CAAK,CAAA,QAAA,EAAW,IAAA,CAAK,OAAO,CAAA,CAAE,CAAA;AAAA,MACtC;AAAA,IACF,CAAC,CAAA;AAAA,EACH;AAEA,EAAA,OAAO,KAAA,CAAM,KAAK,IAAI,CAAA;AACxB;AA6DO,SAAS,gBAAA,CACd,SACA,OAAA,EACA,OAAA,EACA,WAA6B,OAAA,EAC7B,MAAA,GAA2B,OAC3B,IAAA,EAC4B;AAC5B,EAAA,OAAO;AAAA,IACL,OAAA;AAAA,IACA,OAAA;AAAA,IACA,OAAA;AAAA,IACA,QAAA;AAAA,IACA,MAAA;AAAA,IACA;AAAA,GACF;AACF;AAzHA,IAAA,UAAA,GAAA,KAAA,CAAA;AAAA,EAAA,qBAAA,GAAA;AAIA,IAAA,WAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACuBA,eAAsB,aAAa,UAAA,EAA6C;AAE9E,EAAA,IAAI,UAAA,EAAY;AACd,IAAA,IAAI;AACF,MAAA,MAAM,OAAO,UAAU,CAAA;AACvB,MAAA,OAAO,UAAA;AAAA,IACT,CAAA,CAAA,MAAQ;AACN,MAAA,OAAO,IAAA;AAAA,IACT;AAAA,EACF;AAGA,EAAA,IAAI,OAAA,CAAQ,IAAI,WAAA,EAAa;AAC3B,IAAA,IAAI;AACF,MAAA,MAAM,MAAA,CAAO,OAAA,CAAQ,GAAA,CAAI,WAAW,CAAA;AACpC,MAAA,OAAO,QAAQ,GAAA,CAAI,WAAA;AAAA,IACrB,CAAA,CAAA,MAAQ;AAAA,IAER;AAAA,EACF;AAGA,EAAA,IAAI;AACF,IAAA,MAAM,OAAO,cAAc,CAAA;AAC3B,IAAA,OAAO,cAAA;AAAA,EACT,CAAA,CAAA,MAAQ;AAAA,EAER;AAGA,EAAA,OAAO,QAAA;AACT;AAQA,eAAsB,kBAAkB,UAAA,EAAuC;AAC7E,EAAA,IAAI,UAAA;AAEJ,EAAA,IAAI,UAAA,EAAY;AAGd,IAAA,UAAA,GAAa,UAAA;AAAA,EACf,CAAA,MAAO;AAEL,IAAA,UAAA,GAAa,MAAM,YAAA,EAAa;AAChC,IAAA,IAAI,CAAC,YAAY,OAAO,KAAA;AAAA,EAC1B;AAEA,EAAA,OAAO,IAAI,OAAA,CAAQ,CAAC,OAAA,KAAY;AAC9B,IAAA,MAAM,IAAA,GAAO,MAAM,UAAA,EAAsB,CAAC,SAAS,CAAA,EAAG,EAAE,KAAA,EAAO,QAAA,EAAU,CAAA;AACzE,IAAA,IAAA,CAAK,GAAG,OAAA,EAAS,CAAC,SAAS,OAAA,CAAQ,IAAA,KAAS,CAAC,CAAC,CAAA;AAC9C,IAAA,IAAA,CAAK,EAAA,CAAG,OAAA,EAAS,MAAM,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,EACvC,CAAC,CAAA;AACH;AAQA,eAAsB,mBAAA,CACpB,UAAA,EACA,QAAA,EACA,UAAA,EACiC;AACjC,EAAA,MAAM,QAAA,GAAW,MAAM,YAAA,CAAa,UAAU,CAAA;AAE9C,EAAA,IAAI,CAAC,QAAA,EAAU;AACb,IAAA,OAAO;AAAA,MACL,KAAA,EAAO,KAAA;AAAA,MACP,WAAA,EAAa;AAAA,QACX,gBAAA;AAAA,UACE,EAAA;AAAA,UACA,4EAAA;AAAA,UACA,oBAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AAGA,EAAA,IAAI,CAAE,MAAM,iBAAA,CAAkB,QAAQ,CAAA,EAAI;AACxC,IAAA,OAAO;AAAA,MACL,KAAA,EAAO,KAAA;AAAA,MACP,WAAA,EAAa;AAAA,QACX,gBAAA;AAAA,UACE,EAAA;AAAA,UACA,2BAA2B,QAAQ,CAAA,4CAAA,CAAA;AAAA,UACnC,uBAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AAEA,EAAA,OAAO,IAAI,OAAA,CAAQ,CAAC,OAAA,KAAY;AAC9B,IAAA,MAAM,IAAA,GAAO;AAAA,MACX,QAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,UAAA;AAAA,MACA,QAAA;AAAA,MACA,QAAA;AAAA,MACA,UAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,MAAM,IAAA,GAAO,KAAA,CAAM,QAAA,EAAU,IAAI,CAAA;AAEjC,IAAA,IAAI,MAAA,GAAS,EAAA;AACb,IAAA,IAAI,MAAA,GAAS,EAAA;AAEb,IAAA,IAAA,CAAK,MAAA,CAAO,EAAA,CAAG,MAAA,EAAQ,CAAC,IAAA,KAAS;AAC/B,MAAA,MAAA,IAAU,KAAK,QAAA,EAAS;AAAA,IAC1B,CAAC,CAAA;AAED,IAAA,IAAA,CAAK,MAAA,CAAO,EAAA,CAAG,MAAA,EAAQ,CAAC,IAAA,KAAS;AAC/B,MAAA,MAAA,IAAU,KAAK,QAAA,EAAS;AAAA,IAC1B,CAAC,CAAA;AAED,IAAA,IAAA,CAAK,EAAA,CAAG,OAAA,EAAS,CAAC,IAAA,KAAwB;AAExC,MAAA,IAAI,MAAA;AAEJ,MAAA,IAAI;AACF,QAAA,MAAA,GAAS,IAAA,CAAK,MAAM,MAAM,CAAA;AAAA,MAC5B,CAAA,CAAA,MAAQ;AAEN,QAAA,OAAA,CAAQ;AAAA,UACN,KAAA,EAAO,KAAA;AAAA,UACP,WAAA,EAAa;AAAA,YACX,gBAAA;AAAA,cACE,EAAA;AAAA,cACA,CAAA,0BAAA,EAA6B,UAAU,eAAe,CAAA,CAAA;AAAA,cACtD,cAAA;AAAA,cACA,OAAA;AAAA,cACA;AAAA;AACF,WACF;AAAA,UACA,MAAA,EAAQ;AAAA,SACT,CAAA;AACD,QAAA;AAAA,MACF;AAGA,MAAA,MAAM,WAAA,GACJ,OAAO,MAAA,EAAQ,GAAA;AAAA,QAAI,CAAC,KAAA,KAClB,gBAAA;AAAA,UACE,MAAM,IAAA,IAAQ,EAAA;AAAA,UACd,KAAA,CAAM,OAAA;AAAA,UACN,MAAM,OAAA,IAAW,YAAA;AAAA,UACjB,OAAA;AAAA,UACA;AAAA;AACF,WACG,EAAC;AAER,MAAA,OAAA,CAAQ;AAAA,QACN,KAAA,EAAO,IAAA,KAAS,CAAA,IAAK,MAAA,CAAO,KAAA;AAAA,QAC5B,WAAA;AAAA,QACA,MAAA,EAAQ;AAAA,OACT,CAAA;AAAA,IACH,CAAC,CAAA;AAED,IAAA,IAAA,CAAK,EAAA,CAAG,OAAA,EAAS,CAAC,KAAA,KAAU;AAC1B,MAAA,OAAA,CAAQ;AAAA,QACN,KAAA,EAAO,KAAA;AAAA,QACP,WAAA,EAAa;AAAA,UACX,gBAAA;AAAA,YACE,EAAA;AAAA,YACA,CAAA,0BAAA,EAA6B,MAAM,OAAO,CAAA,CAAA;AAAA,YAC1C,oBAAA;AAAA,YACA,OAAA;AAAA,YACA;AAAA;AACF,SACF;AAAA,QACA,MAAA,EAAQ;AAAA,OACT,CAAA;AAAA,IACH,CAAC,CAAA;AAAA,EACH,CAAC,CAAA;AACH;AAvNA,IAAA,kBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,6BAAA,GAAA;AAUA,IAAA,UAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACIA,SAAS,iBAAiB,KAAA,EAA6C;AACrE,EAAA,IAAI,CAAC,KAAA,EAAO;AACV,IAAA,MAAM,qBAAA,CAAsB,WAAA;AAAA,MAC1B,EAAE,IAAA,EAAM,QAAA,EAAU,OAAA,EAAS,EAAA,EAAG;AAAA,MAC9B,IAAI,MAAM,yBAAyB;AAAA,KACrC;AAAA,EACF;AAEA,EAAA,IAAI;AACF,IAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAE7B,MAAA,IAAI;AACF,QAAA,OAAO,IAAA,CAAK,MAAM,KAAK,CAAA;AAAA,MACzB,CAAA,CAAA,MAAQ;AACN,QAAA,OAAOC,MAAU,KAAK,CAAA;AAAA,MACxB;AAAA,IACF;AAEA,IAAA,IAAI,MAAA,CAAO,QAAA,CAAS,KAAK,CAAA,EAAG;AAC1B,MAAA,MAAM,OAAA,GAAU,KAAA,CAAM,QAAA,CAAS,OAAO,CAAA;AACtC,MAAA,IAAI;AACF,QAAA,OAAO,IAAA,CAAK,MAAM,OAAO,CAAA;AAAA,MAC3B,CAAA,CAAA,MAAQ;AACN,QAAA,OAAOA,MAAU,OAAO,CAAA;AAAA,MAC1B;AAAA,IACF;AAGA,IAAA,OAAO,KAAA;AAAA,EACT,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,qBAAA,CAAsB,WAAA;AAAA,MAC1B;AAAA,QACE,IAAA,EAAM,OAAO,KAAA,KAAU,QAAA,GAAW,QAAA,GAAW,QAAA;AAAA,QAC7C,SAAS,OAAO,KAAA,KAAU,WAAW,KAAA,GAAQ,IAAA,CAAK,UAAU,KAAK;AAAA,OACnE;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF;AAKA,SAAS,eAAe,GAAA,EAAuB;AAC7C,EAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,IAAA,OAAO,GAAA;AAAA,EACT;AAEA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA,EAAG;AACtB,IAAA,OAAO,GAAA,CAAI,IAAI,cAAc,CAAA;AAAA,EAC/B;AAEA,EAAA,MAAM,SAAkC,EAAC;AACzC,EAAA,MAAM,IAAA,GAAO,MAAA,CAAO,IAAA,CAAK,GAAG,EAAE,IAAA,EAAK;AAEnC,EAAA,KAAA,MAAW,OAAO,IAAA,EAAM;AACtB,IAAA,MAAA,CAAO,GAAG,CAAA,GAAI,cAAA,CAAgB,GAAA,CAAgC,GAAG,CAAC,CAAA;AAAA,EACpE;AAEA,EAAA,OAAO,MAAA;AACT;AAWO,SAAS,eAAA,CACd,KAAA,EACA,OAAA,GAAsC,EAAC,EAC/B;AACR,EAAA,IAAI;AAEF,IAAA,MAAM,MAAA,GAAS,iBAAiB,KAAK,CAAA;AAGrC,IAAA,MAAM,MAAA,GAAS,eAAe,MAAM,CAAA;AAGpC,IAAA,IAAI,QAAQ,OAAA,EAAS;AACnB,MAAA,OAAO,IAAA,CAAK,UAAU,MAAM,CAAA;AAAA,IAC9B;AAGA,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAA;AAAA,EACvC,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,iBAAiB,qBAAA,EAAuB;AAC1C,MAAA,MAAM,KAAA;AAAA,IACR;AACA,IAAA,MAAM,qBAAA,CAAsB,WAAA;AAAA,MAC1B;AAAA,QACE,IAAA,EAAM,OAAO,KAAA,KAAU,QAAA,GAAW,QAAA,GAAW,QAAA;AAAA,QAC7C,SAAS,OAAO,KAAA,KAAU,WAAW,KAAA,GAAQ,IAAA,CAAK,UAAU,KAAK;AAAA,OACnE;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF;AAQO,SAAS,cAAA,CACd,OAAA,EACA,OAAA,EACA,OAAA,GAAsC,EAAC,EACuB;AAC9D,EAAA,MAAM,WAAA,GAAc,eAAA,CAAgB,OAAA,EAAS,OAAO,CAAA;AACpD,EAAA,MAAM,WAAA,GAAc,eAAA,CAAgB,OAAA,EAAS,OAAO,CAAA;AAEpD,EAAA,OAAO;AAAA,IACL,OAAO,WAAA,KAAgB,WAAA;AAAA,IACvB,WAAA;AAAA,IACA;AAAA,GACF;AACF;AAxIA,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,0BAAA,GAAA;AAQA,IAAA,WAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACwOA,SAAS,eAAe,UAAA,EAA6C;AACnE,EAAA,IAAI,CAAC,UAAA,IAAc,CAAC,qBAAA,EAAuB,OAAO,KAAA;AAClD,EAAA,IAAI,CAAC,UAAA,IAAc,CAAC,qBAAA,EAAuB,OAAO,IAAA;AAElD,EAAA,OACE,UAAA,CAAW,YAAY,qBAAA,CAAsB,OAAA,IAC7C,KAAK,SAAA,CAAU,UAAA,CAAW,QAAQ,CAAA,KAAM,IAAA,CAAK,UAAU,qBAAA,CAAsB,QAAQ,KACrF,UAAA,CAAW,cAAA,KAAmB,sBAAsB,cAAA,IACpD,UAAA,CAAW,aAAa,qBAAA,CAAsB,QAAA;AAElD;AAKO,SAAS,kBAAkB,OAAA,EAAiD;AACjF,EAAA,IAAI,CAAC,cAAA,IAAkB,cAAA,CAAe,OAAO,CAAA,EAAG;AAC9C,IAAA,cAAA,GAAiB,IAAI,eAAe,OAAO,CAAA;AAC3C,IAAA,qBAAA,GAAwB,OAAA;AAAA,EAC1B;AACA,EAAA,OAAO,cAAA;AACT;AAKA,eAAsB,WAAA,CACpB,QACA,OAAA,EAC2B;AAC3B,EAAA,MAAM,QAAA,GAAW,kBAAkB,OAAO,CAAA;AAC1C,EAAA,OAAO,QAAA,CAAS,YAAY,MAAM,CAAA;AACpC;AAhRA,IAeM,gBAAA,EAKO,gBAsNT,cAAA,EACA,qBAAA;AA3OJ,IAAAC,cAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,wBAAA,GAAA;AASA,IAAA,WAAA,EAAA;AAMA,IAAM,gBAAA,GAAmB,CAAC,kBAAA,EAAoB,kBAAA,EAAoB,iBAAiB,CAAA;AAK5E,IAAM,iBAAN,MAAqB;AAAA,MAClB,OAAA,uBAA2C,GAAA,EAAI;AAAA,MAC/C,OAAA;AAAA,MAER,WAAA,CAAY,OAAA,GAAiC,EAAC,EAAG;AAC/C,QAAA,IAAA,CAAK,OAAA,GAAU;AAAA,UACb,OAAA,EAAS,OAAA,CAAQ,OAAA,IAAW,IAAA,CAAK,mBAAA,EAAoB;AAAA,UACrD,QAAA,EAAU,QAAQ,QAAA,IAAY,gBAAA;AAAA,UAC9B,cAAA,EAAgB,QAAQ,cAAA,IAAkB,KAAA;AAAA,UAC1C,QAAA,EAAU,QAAQ,QAAA,IAAY;AAAA,SAChC;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKQ,mBAAA,GAA8B;AACpC,QAAA,MAAMC,WAAAA,GAAa,aAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,QAAA,MAAMC,UAAAA,GAAY,QAAQD,WAAU,CAAA;AAEpC,QAAA,OAAOE,IAAAA,CAAKD,UAAAA,EAAW,IAAA,EAAM,IAAA,EAAM,WAAW,aAAa,CAAA;AAAA,MAC7D;AAAA;AAAA;AAAA;AAAA,MAKQ,aAAA,CAAc,UAAkB,OAAA,EAAyB;AAC/D,QAAA,MAAM,YAAA,GAAe,QAAA,CAAS,OAAA,EAAS,QAAQ,CAAA;AAC/C,QAAA,MAAM,UAAA,GAAa,YAAA,CAAa,OAAA,CAAQ,8BAAA,EAAgC,EAAE,CAAA;AAC1E,QAAA,OAAO,UAAA,CAAW,OAAA,CAAQ,KAAA,EAAO,GAAG,CAAA;AAAA,MACtC;AAAA;AAAA;AAAA;AAAA,MAKQ,gBAAgB,QAAA,EAAgC;AACtD,QAAA,MAAM,GAAA,GAAM,OAAA,CAAQ,QAAQ,CAAA,CAAE,WAAA,EAAY;AAC1C,QAAA,QAAQ,GAAA;AAAK,UACX,KAAK,OAAA;AACH,YAAA,OAAO,MAAA;AAAA,UACT,KAAK,OAAA;AAAA,UACL,KAAK,MAAA;AACH,YAAA,OAAO,MAAA;AAAA,UACT;AACE,YAAA,OAAO,MAAA;AAAA;AACX,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,gBAAgB,QAAA,EAA2C;AACvE,QAAA,IAAI;AACF,UAAA,MAAM,OAAA,GAAU,MAAME,QAAAA,CAAS,QAAA,EAAU,OAAO,CAAA;AAChD,UAAA,MAAM,MAAA,GAAS,IAAA,CAAK,eAAA,CAAgB,QAAQ,CAAA;AAE5C,UAAA,IAAI,MAAA;AACJ,UAAA,IAAI,WAAW,MAAA,EAAQ;AACrB,YAAA,MAAA,GAASL,MAAU,OAAO,CAAA;AAAA,UAC5B,CAAA,MAAO;AACL,YAAA,MAAA,GAAS,IAAA,CAAK,MAAM,OAAO,CAAA;AAAA,UAC7B;AAEA,UAAA,MAAM,OAAA,GAAU,IAAA,CAAK,OAAA,CAAQ,OAAA,IAAW,EAAA;AACxC,UAAA,MAAM,YAAA,GAAe,QAAA,CAAS,OAAA,EAAS,QAAQ,CAAA;AAE/C,UAAA,OAAO;AAAA,YACL,EAAA,EAAI,IAAA,CAAK,aAAA,CAAc,QAAA,EAAU,OAAO,CAAA;AAAA,YACxC,IAAA,EAAM,QAAA;AAAA,YACN,YAAA;AAAA,YACA,MAAA;AAAA,YACA,OAAA,EAAU,MAAA,CAAO,OAAA,IAAuB,MAAA,CAAO,OAAA;AAAA,YAC/C,WAAA,EAAc,MAAA,CAAO,KAAA,IAAqB,MAAA,CAAO,WAAA;AAAA,YACjD,aAAa,MAAA,CAAO;AAAA,WACtB;AAAA,QACF,SAAS,KAAA,EAAO;AACd,UAAA,MAAM,qBAAA,CAAsB,aAAA;AAAA,YAC1B,qBAAA;AAAA,YACA,CAAA,kBAAA,EAAqB,QAAQ,CAAA,EAAA,EAAM,KAAA,CAAgB,OAAO,CAAA;AAAA,WAC5D;AAAA,QACF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,eAAA,GAAiC;AACrC,QAAA,IAAI;AACF,UAAA,MAAM,OAAA,GAAU,IAAA,CAAK,OAAA,CAAQ,OAAA,IAAW,EAAA;AACxC,UAAA,MAAM,QAAA,GAAW,IAAA,CAAK,OAAA,CAAQ,QAAA,IAAY,EAAC;AAE3C,UAAA,IAAI,QAAA,CAAS,WAAW,CAAA,EAAG;AACzB,YAAA,IAAA,CAAK,QAAQ,KAAA,EAAM;AACnB,YAAA;AAAA,UACF;AAEA,UAAA,MAAM,OAAA,GAAU,SAAS,GAAA,CAAI,CAAC,MAAMI,IAAAA,CAAK,OAAA,EAAS,CAAC,CAAC,CAAA;AAGpD,UAAA,IAAI;AACF,YAAA,MAAME,OAAO,OAAO,CAAA;AAAA,UACtB,CAAA,CAAA,MAAQ;AAEN,YAAA,IAAA,CAAK,QAAQ,KAAA,EAAM;AACnB,YAAA;AAAA,UACF;AAEA,UAAA,MAAM,KAAA,GAAQ,MAAM,IAAA,CAAK,OAAA,EAAS;AAAA,YAChC,QAAA,EAAU,IAAA;AAAA,YACV,mBAAA,EAAqB,KAAK,OAAA,CAAQ,cAAA;AAAA,YAClC,IAAA,EAAM,KAAK,OAAA,CAAQ,QAAA;AAAA,YACnB,SAAA,EAAW,IAAA;AAAA,YACX,cAAA,EAAgB;AAAA;AAAA,WACjB,CAAA;AAGD,UAAA,IAAA,CAAK,QAAQ,KAAA,EAAM;AAGnB,UAAA,KAAA,MAAW,YAAY,KAAA,EAAO;AAC5B,YAAA,IAAI;AACF,cAAA,MAAM,QAAA,GAAW,MAAM,IAAA,CAAK,eAAA,CAAgB,QAAQ,CAAA;AACpD,cAAA,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,QAAA,CAAS,EAAA,EAAI,QAAQ,CAAA;AAAA,YACxC,SAAS,KAAA,EAAO;AAEd,cAAA,OAAA,CAAQ,IAAA,CAAK,CAAA,kCAAA,EAAqC,QAAQ,CAAA,CAAA,CAAA,EAAK,KAAK,CAAA;AAAA,YACtE;AAAA,UACF;AAAA,QACF,SAAS,KAAA,EAAO;AACd,UAAA,MAAM,qBAAA,CAAsB,aAAA,CAAc,WAAA,EAAc,KAAA,CAAgB,OAAO,CAAA;AAAA,QACjF;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,YAAY,MAAA,EAA4C;AAC5D,QAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,IAAA,KAAS,CAAA,EAAG;AAC3B,UAAA,MAAM,KAAK,eAAA,EAAgB;AAAA,QAC7B;AAEA,QAAA,MAAM,UAAU,KAAA,CAAM,IAAA,CAAK,IAAA,CAAK,OAAA,CAAQ,QAAQ,CAAA;AAEhD,QAAA,IAAI,MAAA,EAAQ;AACV,UAAA,OAAO,OAAA,CAAQ,OAAO,CAAC,MAAA,KAAW,OAAO,EAAA,CAAG,UAAA,CAAW,MAAM,CAAC,CAAA;AAAA,QAChE;AAEA,QAAA,OAAO,OAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,UAAU,EAAA,EAAqC;AACnD,QAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,IAAA,KAAS,CAAA,EAAG;AAC3B,UAAA,MAAM,KAAK,eAAA,EAAgB;AAAA,QAC7B;AAEA,QAAA,MAAM,MAAA,GAAS,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,EAAE,CAAA;AAClC,QAAA,IAAI,CAAC,MAAA,EAAQ;AACX,UAAA,MAAM,qBAAA,CAAsB,eAAe,EAAE,CAAA;AAAA,QAC/C;AAEA,QAAA,OAAO,MAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,gBAAgB,QAAA,EAA2C;AAC/D,QAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,IAAA,KAAS,CAAA,EAAG;AAC3B,UAAA,MAAM,KAAK,eAAA,EAAgB;AAAA,QAC7B;AAEA,QAAA,MAAM,YAAA,GAAe,QAAA,CAAS,UAAA,CAAW,GAAG,CAAA,GAAI,WAAWF,IAAAA,CAAK,OAAA,CAAQ,GAAA,EAAI,EAAG,QAAQ,CAAA;AAEvF,QAAA,KAAA,MAAW,MAAA,IAAU,IAAA,CAAK,OAAA,CAAQ,MAAA,EAAO,EAAG;AAC1C,UAAA,IAAI,MAAA,CAAO,SAAS,YAAA,EAAc;AAChC,YAAA,OAAO,MAAA;AAAA,UACT;AAAA,QACF;AAEA,QAAA,MAAM,qBAAA,CAAsB,eAAe,QAAQ,CAAA;AAAA,MACrD;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,UAAU,EAAA,EAA8B;AAC5C,QAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,IAAA,KAAS,CAAA,EAAG;AAC3B,UAAA,MAAM,KAAK,eAAA,EAAgB;AAAA,QAC7B;AAEA,QAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,EAAE,CAAA;AAAA,MAC5B;AAAA;AAAA;AAAA;AAAA,MAKA,IAAI,IAAA,GAAe;AACjB,QAAA,OAAO,KAAK,OAAA,CAAQ,IAAA;AAAA,MACtB;AAAA;AAAA;AAAA;AAAA,MAKA,KAAA,GAAc;AACZ,QAAA,IAAA,CAAK,QAAQ,KAAA,EAAM;AAAA,MACrB;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACrOA,IAAA,iBAAA,GAAA,EAAA;AAAA,QAAA,CAAA,iBAAA,EAAA;AAAA,EAAA,UAAA,EAAA,MAAA,UAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,cAAA,EAAA,MAAA;AAAA,CAAA,CAAA;AAuCA,eAAe,eACb,KAAA,EACkC;AAClC,EAAA,MAAMF,WAAAA,GAAaK,aAAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,EAAA,MAAMJ,UAAAA,GAAYK,QAAQN,WAAU,CAAA;AACpC,EAAA,MAAM,cAAA,GAAiBE,IAAAA;AAAA,IACrBD,UAAAA;AAAA,IACA,IAAA;AAAA,IACA,IAAA;AAAA,IACA,SAAA;AAAA,IACA,aAAA;AAAA,IACA,MAAA;AAAA,IACA,KAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,MAAM,OAAA,GAAU,MAAME,QAAAA,CAAS,cAAA,EAAgB,OAAO,CAAA;AACtD,EAAA,OAAO,IAAA,CAAK,MAAM,OAAO,CAAA;AAC3B;AAKA,eAAe,qBAAA,GAA4D;AACzE,EAAA,MAAMH,WAAAA,GAAaK,aAAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,EAAA,MAAMJ,UAAAA,GAAYK,QAAQN,WAAU,CAAA;AACpC,EAAA,MAAM,QAAA,GAAWE,IAAAA;AAAA,IACfD,UAAAA;AAAA,IACA,IAAA;AAAA,IACA,IAAA;AAAA,IACA,SAAA;AAAA,IACA,aAAA;AAAA,IACA,MAAA;AAAA,IACA,eAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,MAAM,UAAA,GAAa;AAAA,IACjB,WAAA;AAAA,IACA,iBAAA;AAAA,IACA,kBAAA;AAAA,IACA,iBAAA;AAAA,IACA,gBAAA;AAAA,IACA,wBAAA;AAAA,IACA;AAAA,GACF;AAEA,EAAA,MAAM,UAAqC,EAAC;AAC5C,EAAA,KAAA,MAAW,QAAQ,UAAA,EAAY;AAC7B,IAAA,IAAI;AACF,MAAA,MAAM,UAAU,MAAME,QAAAA,CAASD,KAAK,QAAA,EAAU,IAAI,GAAG,OAAO,CAAA;AAC5D,MAAA,OAAA,CAAQ,IAAA,CAAK,IAAA,CAAK,KAAA,CAAM,OAAO,CAA4B,CAAA;AAAA,IAC7D,CAAA,CAAA,MAAQ;AAAA,IAER;AAAA,EACF;AAEA,EAAA,OAAO,OAAA;AACT;AAQA,eAAe,qBAAqB,GAAA,EAA+C;AACjF,EAAA,MAAMF,WAAAA,GAAaK,aAAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,EAAA,MAAMJ,UAAAA,GAAYK,QAAQN,WAAU,CAAA;AACpC,EAAA,MAAM,QAAA,GAAWE,IAAAA,CAAKD,UAAAA,EAAW,IAAA,EAAM,IAAI,CAAA;AAE3C,EAAA,IAAI,YAAA;AAGJ,EAAA,IAAI,GAAA,CAAI,UAAA,CAAW,+BAA+B,CAAA,EAAG;AACnD,IAAA,MAAM,YAAA,GAAe,GAAA,CAAI,OAAA,CAAQ,+BAAA,EAAiC,EAAE,CAAA;AAGpE,IAAA,IAAI,YAAA,CAAa,UAAA,CAAW,kBAAkB,CAAA,EAAG;AAC/C,MAAA,YAAA,GAAeC,IAAAA;AAAA,QACb,QAAA;AAAA,QACA,QAAA;AAAA,QACA,aAAA;AAAA,QACA,UAAA;AAAA,QACA,YAAA,CAAa,KAAA,CAAM,GAAG,CAAA,CAAE,KAAI,IAAK;AAAA,OACnC;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,YAAA,GAAeA,IAAAA,CAAK,QAAA,EAAU,SAAA,EAAW,aAAA,EAAe,YAAY,CAAA;AAAA,IACtE;AAAA,EACF,CAAA,MAAA,IAES,IAAI,UAAA,CAAW,QAAQ,KAAK,GAAA,CAAI,UAAA,CAAW,KAAK,CAAA,EAAG;AAG1D,IAAA,MAAM,UAAA,GAAaA,IAAAA;AAAA,MACjB,QAAA;AAAA,MACA,SAAA;AAAA,MACA,aAAA;AAAA,MACA,eAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA,KACF;AACA,IAAA,YAAA,GAAeA,IAAAA,CAAK,YAAY,GAAG,CAAA;AAAA,EACrC,CAAA,MAAA,IAES,GAAA,CAAI,UAAA,CAAW,SAAS,CAAA,EAAG;AAClC,IAAA,YAAA,GAAeG,cAAc,GAAG,CAAA;AAAA,EAClC,CAAA,MAEK;AACH,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,2BAAA,EAA8B,GAAG,CAAA,CAAE,CAAA;AAAA,EACrD;AAGA,EAAA,MAAM,OAAA,GAAU,MAAMF,QAAAA,CAAS,YAAA,EAAc,OAAO,CAAA;AACpD,EAAA,MAAM,MAAM,YAAA,CAAa,KAAA,CAAM,GAAG,CAAA,CAAE,GAAA,IAAO,WAAA,EAAY;AAEvD,EAAA,IAAI,GAAA,KAAQ,MAAA,IAAU,GAAA,KAAQ,KAAA,EAAO;AACnC,IAAA,OAAOL,MAAU,OAAO,CAAA;AAAA,EAC1B;AACA,EAAA,OAAO,IAAA,CAAK,MAAM,OAAO,CAAA;AAC3B;AAKA,SAAS,MAAA,GAAc;AACrB,EAAA,IAAI,CAAC,WAAA,EAAa;AAChB,IAAA,WAAA,GAAc,IAAI,GAAA,CAAI;AAAA,MACpB,MAAA,EAAQ,KAAA;AAAA,MACR,SAAA,EAAW,IAAA;AAAA,MACX,OAAA,EAAS,IAAA;AAAA;AAAA,MAET,aAAA,EAAe,KAAA;AAAA;AAAA,MAEf,UAAA,EAAY;AAAA,KACb,CAAA;AAGD,IAAA,UAAA,CAAW,WAAA,EAAa;AAAA,MACtB,IAAA,EAAM,MAAA;AAAA,MACN,OAAA,EAAS,CAAC,WAAA,EAAa,OAAA,EAAS,YAAY,MAAA,EAAQ,MAAA,EAAQ,OAAO,eAAe;AAAA,KACnF,CAAA;AAGD,IAAA,eAAA,GAAkB,OAAA,CAAQ,GAAA,CAAI,CAAC,qBAAA,IAAyB,cAAA,CAAe,eAAe,CAAC,CAAC,EACrF,IAAA,CAAK,CAAC,CAAC,YAAA,EAAc,UAAU,CAAA,KAAM;AACpC,MAAA,IAAI,WAAA,EAAa;AAEf,QAAA,KAAA,MAAW,eAAe,YAAA,EAAc;AACtC,UAAA,IAAI;AACF,YAAA,WAAA,CAAY,cAAc,WAAW,CAAA;AAAA,UACvC,CAAA,CAAA,MAAQ;AAAA,UAER;AAAA,QACF;AAGA,QAAA,WAAA,CAAY,cAAc,UAAU,CAAA;AAAA,MACtC;AAAA,IACF,CAAC,CAAA,CACA,KAAA,CAAM,CAAC,KAAA,KAAU;AAChB,MAAA,MAAM,IAAI,KAAA,CAAM,CAAA,4BAAA,EAA+B,KAAK,CAAA,CAAE,CAAA;AAAA,IACxD,CAAC,CAAA;AAAA,EACL;AAEA,EAAA,OAAO,WAAA;AACT;AAKA,eAAsB,aAAA,CACpB,MAAA,EACA,OAAA,GAAkC,EAAC,EACP;AAE5B,EAAA,MAAM,MAAM,MAAA,EAAO;AACnB,EAAA,IAAI,eAAA,EAAiB;AACnB,IAAA,MAAM,eAAA;AAAA,EACR;AAGA,EAAA,MAAM,WAAW,OAAO,MAAA,KAAW,WAAW,MAAA,GAAS,IAAA,CAAK,UAAU,MAAM,CAAA;AAG5E,EAAA,MAAM,MAAA,GAAS,WAAA,CAAY,GAAA,CAAI,QAAQ,CAAA;AACvC,EAAA,IAAI,WAAW,MAAA,EAAW;AACxB,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,IAAI,YAAA;AACJ,EAAA,IAAI,OAAO,WAAW,QAAA,EAAU;AAC9B,IAAA,IAAI;AACF,MAAA,YAAA,GAAe,IAAA,CAAK,MAAM,MAAM,CAAA;AAAA,IAClC,CAAA,CAAA,MAAQ;AAEN,MAAA,YAAA,GAAeA,MAAU,MAAM,CAAA;AAAA,IACjC;AAAA,EACF,CAAA,MAAA,IAAW,MAAA,CAAO,QAAA,CAAS,MAAM,CAAA,EAAG;AAClC,IAAA,MAAM,OAAA,GAAU,MAAA,CAAO,QAAA,CAAS,OAAO,CAAA;AACvC,IAAA,IAAI;AACF,MAAA,YAAA,GAAe,IAAA,CAAK,MAAM,OAAO,CAAA;AAAA,IACnC,CAAA,CAAA,MAAQ;AACN,MAAA,YAAA,GAAeA,MAAU,OAAO,CAAA;AAAA,IAClC;AAAA,EACF,CAAA,MAAO;AACL,IAAA,YAAA,GAAe,MAAA;AAAA,EACjB;AAEA,EAAA,IAAI;AAEF,IAAA,IAAI,OAAA,CAAQ,OAAA,IAAW,OAAA,CAAQ,OAAA,CAAQ,SAAS,CAAA,EAAG;AACjD,MAAA,KAAA,MAAW,KAAA,IAAS,QAAQ,OAAA,EAAS;AACnC,QAAA,IAAI,KAAA,IAAS,GAAA,CAAI,SAAA,CAAU,KAAK,MAAM,KAAA,CAAA,EAAW;AAC/C,UAAA,IAAI;AACF,YAAA,GAAA,CAAI,SAAA,CAAU,cAAyC,KAAK,CAAA;AAAA,UAC9D,CAAA,CAAA,MAAQ;AAAA,UAER;AAAA,QACF;AAAA,MACF;AAAA,IACF;AAGA,IAAA,MAAM,SAAA,GAAY,MAAM,GAAA,CAAI,YAAA,CAAa,YAAuC,CAAA;AAGhF,IAAA,WAAA,CAAY,GAAA,CAAI,UAAU,SAA8B,CAAA;AAExD,IAAA,OAAO,SAAA;AAAA,EACT,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,qBAAA,CAAsB,WAAA;AAAA,MAC1B;AAAA,QACE,IAAA,EAAM,QAAA;AAAA,QACN,SAAS,OAAO,MAAA,KAAW,WAAW,MAAA,GAAS,IAAA,CAAK,UAAU,MAAM;AAAA,OACtE;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF;AAKO,SAAS,YAAA,CAAa,MAAe,SAAA,EAAsD;AAChG,EAAA,MAAM,KAAA,GAAQ,UAAU,IAAI,CAAA;AAE5B,EAAA,MAAM,MAAA,GAAiC;AAAA,IACrC,KAAA;AAAA,IACA,aAAa,EAAC;AAAA,IACd,MAAA,EAAQ;AAAA,GACV;AAEA,EAAA,IAAI,CAAC,KAAA,IAAS,SAAA,CAAU,MAAA,EAAQ;AAC9B,IAAA,MAAM,SAAS,SAAA,CAAU,MAAA;AACzB,IAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,MAAM,CAAA,EAAG;AACzB,MAAA,MAAA,CAAO,cAAc,MAAA,CAAO,GAAA;AAAA,QAAI,CAAC,KAAA,KAC/B,gBAAA;AAAA,UACE,MAAM,YAAA,IAAgB,EAAA;AAAA,UACtB,MAAM,OAAA,IAAW,mBAAA;AAAA,UACjB,MAAM,OAAA,IAAW,SAAA;AAAA,UACjB,OAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,IACF;AACA,IAAA,OAAA,CAAQ,OAAA,CAAQ,0BAA0B,CAAA,CAAE,GAAA,EAAI;AAAA,EAClD,CAAA,MAAO;AACL,IAAA,OAAA,CAAQ,OAAA,CAAQ,oBAAoB,CAAA,CAAE,GAAA,EAAI;AAAA,EAC5C;AAEA,EAAA,OAAO,MAAA;AACT;AAKA,eAAsB,YAAA,CACpB,UACA,SAAA,EACiC;AACjC,EAAA,IAAI;AACF,IAAA,MAAM,OAAA,GAAU,MAAMK,QAAAA,CAAS,QAAA,EAAU,OAAO,CAAA;AAChD,IAAA,IAAI,IAAA;AAEJ,IAAA,IAAI;AACF,MAAA,IAAA,GAAO,IAAA,CAAK,MAAM,OAAO,CAAA;AAAA,IAC3B,CAAA,CAAA,MAAQ;AAEN,MAAA,IAAA,GAAOL,MAAU,OAAO,CAAA;AAAA,IAC1B;AAEA,IAAA,OAAO,YAAA,CAAa,MAAM,SAAS,CAAA;AAAA,EACrC,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,iBAAiB,qBAAA,EAAuB;AAC1C,MAAA,MAAM,KAAA;AAAA,IACR;AACA,IAAA,MAAM,qBAAA,CAAsB,gBAAA;AAAA,MAC1B,QAAA;AAAA,MACA;AAAA,QACE,gBAAA;AAAA,UACE,EAAA;AAAA,UACA,CAAA,8BAAA,EAAkC,MAAgB,OAAO,CAAA,CAAA;AAAA,UACzD,WAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA,EAAE,IAAA,EAAM,MAAA,EAAQ,EAAA,EAAI,QAAA;AAAS,KAC/B;AAAA,EACF;AACF;AAKA,eAAsB,eAAe,MAAA,EAAsD;AACzF,EAAA,IAAI;AACF,IAAA,MAAM,SAAA,GAAY,MAAM,aAAA,CAAc,MAAM,CAAA;AAG5C,IAAA,YAAA,CAAa,IAAI,SAAS,CAAA;AAE1B,IAAA,OAAO;AAAA,MACL,KAAA,EAAO,IAAA;AAAA,MACP,aAAa,EAAC;AAAA,MACd,MAAA,EAAQ;AAAA,KACV;AAAA,EACF,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,iBAAiB,qBAAA,EAAuB;AAC1C,MAAA,OAAO;AAAA,QACL,KAAA,EAAO,KAAA;AAAA,QACP,aAAa,KAAA,CAAM,WAAA;AAAA,QACnB,MAAA,EAAQ;AAAA,OACV;AAAA,IACF;AAEA,IAAA,OAAO;AAAA,MACL,KAAA,EAAO,KAAA;AAAA,MACP,WAAA,EAAa;AAAA,QACX,gBAAA;AAAA,UACE,EAAA;AAAA,UACA,CAAA,0BAAA,EAA8B,MAAgB,OAAO,CAAA,CAAA;AAAA,UACrD,mBAAA;AAAA,UACA,OAAA;AAAA,UACA;AAAA;AACF,OACF;AAAA,MACA,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AACF;AAKO,SAAS,UAAA,GAAmB;AACjC,EAAA,WAAA,CAAY,KAAA,EAAM;AACpB;AAKO,SAAS,YAAA,GAAuB;AACrC,EAAA,OAAO,WAAA,CAAY,IAAA;AACrB;AAKA,eAAsB,iBAAA,CACpB,UACA,eAAA,EAC4B;AAC5B,EAAA,IAAI;AACF,IAAA,MAAM,QAAA,GAAW,kBAAkB,eAAe,CAAA;AAClD,IAAA,MAAM,QAAA,GAAW,MAAM,QAAA,CAAS,SAAA,CAAU,QAAQ,CAAA;AAElD,IAAA,MAAM,OAAA,GAAU,MAAMK,QAAAA,CAAS,QAAA,CAAS,MAAM,OAAO,CAAA;AACrD,IAAA,MAAM,UAAoB,EAAC;AAE3B,IAAA,MAAM,sBAAA,GAAyB,QAAA,CAAS,YAAA,CAAa,OAAA,CAAQ,OAAO,GAAG,CAAA;AACvE,IAAA,IAAI,sBAAA,EAAwB;AAC1B,MAAA,OAAA,CAAQ,KAAK,IAAI,GAAA,CAAI,wBAAwB,+BAA+B,CAAA,CAAE,UAAU,CAAA;AAAA,IAC1F;AAEA,IAAA,OAAO,aAAA,CAAc,OAAA,EAAS,EAAE,OAAA,EAAS,CAAA;AAAA,EAC3C,SAAS,KAAA,EAAO;AACd,IAAA,OAAA,CAAQ,OAAA,CAAQ,0BAA0B,CAAA,CAAE,GAAA,EAAI;AAChD,IAAA,MAAM,KAAA;AAAA,EACR;AACF;AAKA,eAAsB,sBAAA,CACpB,IAAA,EACA,QAAA,EACA,eAAA,EACiC;AACjC,EAAA,IAAI;AACF,IAAA,MAAM,SAAA,GAAY,MAAM,iBAAA,CAAkB,QAAA,EAAU,eAAe,CAAA;AACnE,IAAA,OAAO,YAAA,CAAa,MAAM,SAAS,CAAA;AAAA,EACrC,SAAS,KAAA,EAAO;AACd,IAAA,OAAA,CAAQ,OAAA,CAAQ,0BAA0B,CAAA,CAAE,GAAA,EAAI;AAChD,IAAA,MAAM,KAAA;AAAA,EACR;AACF;AAKA,eAAsB,sBAAA,CACpB,QAAA,EACA,QAAA,EACA,eAAA,EACiC;AACjC,EAAA,IAAI;AACF,IAAA,MAAM,SAAA,GAAY,MAAM,iBAAA,CAAkB,QAAA,EAAU,eAAe,CAAA;AACnE,IAAA,OAAO,YAAA,CAAa,UAAU,SAAS,CAAA;AAAA,EACzC,SAAS,KAAA,EAAO;AACd,IAAA,OAAA,CAAQ,OAAA,CAAQ,0BAA0B,CAAA,CAAE,GAAA,EAAI;AAChD,IAAA,MAAM,KAAA;AAAA,EACR;AACF;AAldA,IAwBI,aAKA,eAAA,EAKE,WAAA;AAlCN,IAAA,cAAA,GAAA,KAAA,CAAA;AAAA,EAAA,yBAAA,GAAA;AAUA,IAAA,cAAA,EAAA;AACA,IAAA,WAAA,EAAA;AACA,IAAAJ,cAAAA,EAAAA;AAOA,IAAA,UAAA,EAAA;AAUA,IAAI,eAAA,GAAwC,IAAA;AAK5C,IAAM,WAAA,uBAAkB,GAAA,EAA+B;AAAA,EAAA;AAAA,CAAA,CAAA;;;AClCvD,IAAA,cAAA,GAAA,EAAA;AAAA,QAAA,CAAA,cAAA,EAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,eAAA,EAAA,MAAA;AAAA,CAAA,CAAA;AAqBA,eAAe,0BAA0B,QAAA,EAAqD;AAC5F,EAAA,IAAI;AAEF,IAAA,MAAMC,WAAAA,GAAaK,aAAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,IAAA,MAAMJ,UAAAA,GAAYK,QAAQN,WAAU,CAAA;AACpC,IAAA,MAAM,eAAeE,IAAAA,CAAKD,UAAAA,EAAW,MAAM,IAAA,EAAM,WAAA,EAAa,YAAY,eAAe,CAAA;AACzF,IAAA,MAAM,eAAA,GAAkB,MAAME,QAAAA,CAAS,YAAA,EAAc,OAAO,CAAA;AAG5D,IAAA,MAAM,QAAA,GAAWL,MAAU,eAAe,CAAA;AAS1C,IAAA,MAAM,cAAA,GAAiB,QAAA,CAAS,OAAA,GAAU,CAAC,CAAA;AAC3C,IAAA,MAAM,eAAA,GAAkB,gBAAgB,OAAA,IAAW,SAAA;AACnD,IAAA,MAAM,WAAW,cAAA,EAAgB,MAAA;AAGjC,IAAA,MAAM,OAAA,GAAUI,IAAAA,CAAKD,UAAAA,EAAW,IAAA,EAAM,MAAM,cAAc,CAAA;AAC1D,IAAA,MAAM,UAAA,GAAa,MAAME,QAAAA,CAAS,OAAA,EAAS,OAAO,CAAA;AAClD,IAAA,MAAM,GAAA,GAAM,IAAA,CAAK,KAAA,CAAM,UAAU,CAAA;AAEjC,IAAA,OAAO;AAAA,MACL,SAAA,EAAW,QAAA;AAAA,MACX,gBAAA,EAAkB,eAAA;AAAA,MAClB,iBAAiB,GAAA,CAAI,OAAA;AAAA,MACrB,QAAA;AAAA,MACA,WAAA,EAAA,iBAAa,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAAA,MACpC,aAAA,EAAe;AAAA,KACjB;AAAA,EACF,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,iBAAA,CAAkB,gBAAA,CAAkB,KAAA,CAAgB,OAAA,EAAS,KAAc,CAAA;AAAA,EACnF;AACF;AAKA,SAAS,eAAA,CACP,aAAA,EACA,UAAA,EACA,MAAA,EACQ;AACR,EAAA,IAAI,WAAW,MAAA,EAAQ;AAErB,IAAA,MAAM,cAAA,GAAiB;AAAA,MACrB,GAAG,aAAA;AAAA,MACH,QAAA,EAAU;AAAA,QACR,GAAI,OAAO,aAAA,CAAc,aAAa,QAAA,GAAW,aAAA,CAAc,WAAW,EAAC;AAAA,QAC3E,mBAAA,EAAqB;AAAA;AACvB,KACF;AACA,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,cAAA,EAAgB,IAAA,EAAM,CAAC,CAAA;AAAA,EAC/C;AAGA,EAAA,MAAM,WAAA,GAAcI,UAAc,aAAA,EAAe;AAAA,IAC/C,MAAA,EAAQ,CAAA;AAAA,IACR,SAAA,EAAW;AAAA,GACZ,CAAA;AAED,EAAA,MAAM,iBAAA,GAAoB;AAAA,IACxB,sBAAA;AAAA,IACA,CAAA,eAAA,EAAkB,WAAW,SAAS,CAAA,CAAA;AAAA,IACtC,CAAA,sBAAA,EAAyB,WAAW,gBAAgB,CAAA,CAAA;AAAA,IACpD,CAAA,qBAAA,EAAwB,WAAW,eAAe,CAAA,CAAA;AAAA,IAClD,GAAI,WAAW,QAAA,GAAW,CAAC,iBAAiB,UAAA,CAAW,QAAQ,CAAA,CAAE,CAAA,GAAI,EAAC;AAAA,IACtE,CAAA,iBAAA,EAAoB,WAAW,WAAW,CAAA,CAAA;AAAA,IAC1C,CAAA,mBAAA,EAAsB,WAAW,aAAa,CAAA,CAAA;AAAA,IAC9C;AAAA,GACF,CAAE,KAAK,IAAI,CAAA;AAEX,EAAA,OAAO,iBAAA,GAAoB,WAAA;AAC7B;AAKA,SAAS,YAAA,CAAa,SAAiB,YAAA,EAAuD;AAC5F,EAAA,IAAI,YAAA,IAAgB,iBAAiB,MAAA,EAAQ;AAC3C,IAAA,OAAO,YAAA;AAAA,EACT;AAEA,EAAA,MAAM,GAAA,GAAMC,OAAAA,CAAQ,OAAO,CAAA,CAAE,WAAA,EAAY;AACzC,EAAA,QAAQ,GAAA;AAAK,IACX,KAAK,OAAA;AACH,MAAA,OAAO,MAAA;AAAA,IACT,KAAK,OAAA;AAAA,IACL,KAAK,MAAA;AACH,MAAA,OAAO,MAAA;AAAA,IACT;AACE,MAAA,MAAM,iBAAA,CAAkB,aAAA,CAAc,GAAA,EAAK,OAAO,CAAA;AAAA;AAExD;AAuBA,eAAsB,aAAa,OAAA,EAA2D;AAC5F,EAAA,MAAM;AAAA,IACJ,QAAA;AAAA,IACA,OAAA;AAAA,IACA,iBAAA,GAAoB,IAAA;AAAA,IACpB,QAAA,GAAW,IAAA;AAAA,IACX,SAAA,GAAY,KAAA;AAAA,IACZ,MAAA,EAAQ,YAAA;AAAA,IACR;AAAA,GACF,GAAI,OAAA;AAGJ,EAAA,MAAM,MAAA,GAAS,YAAA,CAAa,OAAA,EAAS,YAAY,CAAA;AAGjD,EAAA,IAAI,CAAC,SAAA,EAAW;AACd,IAAA,IAAI;AACF,MAAA,MAAMJ,OAAO,OAAO,CAAA;AACpB,MAAA,MAAM,iBAAA,CAAkB,WAAW,OAAO,CAAA;AAAA,IAC5C,SAAS,KAAA,EAAO;AAEd,MAAA,IAAK,KAAA,CAAgC,SAAS,QAAA,EAAU;AACtD,QAAA,MAAM,KAAA;AAAA,MACR;AAAA,IACF;AAAA,EACF;AAGA,EAAA,MAAM,QAAA,GAAW,iBAAA,CAAkB,EAAE,OAAA,EAAS,CAAA;AAC9C,EAAA,MAAM,MAAA,GAAS,MAAM,QAAA,CAAS,SAAA,CAAU,QAAQ,CAAA;AAGhD,EAAA,MAAM,aAAA,GAAgB,MAAMD,QAAAA,CAAS,MAAA,CAAO,MAAM,OAAO,CAAA;AAGzD,EAAA,IAAI,QAAA,EAAU;AACZ,IAAA,MAAM,gBAAA,GAAmB,MAAM,cAAA,CAAe,aAAa,CAAA;AAC3D,IAAA,IAAI,CAAC,iBAAiB,KAAA,EAAO;AAC3B,MAAA,MAAM,qBAAA,CAAsB,gBAAA,CAAiB,QAAA,EAAU,gBAAA,CAAiB,WAAA,EAAa;AAAA,QACnF,IAAA,EAAM,MAAA;AAAA,QACN,IAAI,MAAA,CAAO;AAAA,OACZ,CAAA;AAAA,IACH;AAAA,EACF;AAGA,EAAA,IAAI,YAAA;AACJ,EAAA,IAAI;AACF,IAAA,YAAA,GAAe,IAAA,CAAK,MAAM,aAAa,CAAA;AAAA,EACzC,CAAA,CAAA,MAAQ;AACN,IAAA,YAAA,GAAeL,MAAU,aAAa,CAAA;AAAA,EACxC;AAGA,EAAA,MAAA,CAAO,OAAO,YAAY,CAAA;AAE1B,EAAA,IAAI,UAAA;AACJ,EAAA,IAAI,aAAA;AAEJ,EAAA,IAAI,iBAAA,EAAmB;AAErB,IAAA,UAAA,GAAa,MAAM,0BAA0B,QAAQ,CAAA;AAGrD,IAAA,aAAA,GAAgB,eAAA,CAAgB,YAAA,EAAc,UAAA,EAAY,MAAM,CAAA;AAAA,EAClE,CAAA,MAAO;AAEL,IAAA,IAAI,WAAW,MAAA,EAAQ;AACrB,MAAA,aAAA,GAAgB,IAAA,CAAK,SAAA,CAAU,YAAA,EAAc,IAAA,EAAM,CAAC,CAAA;AAAA,IACtD,CAAA,MAAO;AACL,MAAA,aAAA,GAAgBS,UAAc,YAAA,EAAc,EAAE,QAAQ,CAAA,EAAG,SAAA,EAAW,GAAG,CAAA;AAAA,IACzE;AAAA,EACF;AAGA,EAAA,MAAM,MAAMD,OAAAA,CAAQ,OAAO,GAAG,EAAE,SAAA,EAAW,MAAM,CAAA;AAGjD,EAAA,IAAI;AACF,IAAA,MAAM,SAAA,CAAU,OAAA,EAAS,aAAA,EAAe,OAAO,CAAA;AAAA,EACjD,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,iBAAA,CAAkB,WAAA,CAAY,OAAA,EAAS,KAAc,CAAA;AAAA,EAC7D;AAEA,EAAA,OAAO;AAAA,IACL,OAAA,EAAS,IAAA;AAAA,IACT,QAAA;AAAA,IACA,OAAA;AAAA,IACA,MAAA;AAAA,IACA,iBAAA;AAAA,IACA;AAAA,GACF;AACF;AAmBO,SAAS,gBAAgB,OAAA,EAAyB;AACvD,EAAA,IAAI;AAEF,IAAA,MAAM,MAAA,GAAS,IAAA,CAAK,KAAA,CAAM,OAAO,CAAA;AAGjC,IAAA,IAAI,MAAA,CAAO,QAAA,IAAY,OAAO,MAAA,CAAO,aAAa,QAAA,EAAU;AAC1D,MAAA,MAAM,OAAA,GAAU,EAAE,GAAG,MAAA,CAAO,QAAA,EAAS;AACrC,MAAA,OAAO,QAAQ,mBAAmB,CAAA;AAGlC,MAAA,IAAI,MAAA,CAAO,IAAA,CAAK,OAAO,CAAA,CAAE,WAAW,CAAA,EAAG;AACrC,QAAA,OAAO,MAAA,CAAO,QAAA;AAAA,MAChB,CAAA,MAAO;AACL,QAAA,MAAA,CAAO,QAAA,GAAW,OAAA;AAAA,MACpB;AAAA,IACF;AAEA,IAAA,OAAO,IAAA,CAAK,SAAA,CAAU,MAAA,EAAQ,IAAA,EAAM,CAAC,CAAA;AAAA,EACvC,CAAA,CAAA,MAAQ;AAEN,IAAA,MAAM,KAAA,GAAQ,OAAA,CAAQ,KAAA,CAAM,IAAI,CAAA;AAChC,IAAA,MAAM,QAAA,GAAW,KAAA,CAAM,MAAA,CAAO,CAAC,IAAA,KAAS;AACtC,MAAA,MAAM,OAAA,GAAU,KAAK,IAAA,EAAK;AAC1B,MAAA,OAAO,EACL,QAAQ,UAAA,CAAW,sBAAsB,KACxC,OAAA,CAAQ,UAAA,CAAW,MAAM,CAAA,IACxB,uFAAA,CAAwF,IAAA;AAAA,QACtF;AAAA,OACF,CAAA;AAAA,IAEN,CAAC,CAAA;AAGD,IAAA,OAAO,QAAA,CAAS,SAAS,CAAA,IAAK,QAAA,CAAS,CAAC,CAAA,EAAG,IAAA,OAAW,EAAA,EAAI;AACxD,MAAA,QAAA,CAAS,KAAA,EAAM;AAAA,IACjB;AAEA,IAAA,OAAO,QAAA,CAAS,KAAK,IAAI,CAAA;AAAA,EAC3B;AACF;AArSA,IAAA,WAAA,GAAA,KAAA,CAAA;AAAA,EAAA,sBAAA,GAAA;AAQA,IAAA,WAAA,EAAA;AACA,IAAAP,cAAAA,EAAAA;AAOA,IAAA,cAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AChBA,IAMa,mBAAA;AANb,IAAAU,YAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,uBAAA,GAAA;AAMO,IAAM,mBAAA,GAAN,MAAM,oBAAA,SAA4B,KAAA,CAAM;AAAA,MAC7C,WAAA,CACE,OAAA,EACgB,OAAA,EACA,KAAA,EAChB;AACA,QAAA,KAAA,CAAM,OAAO,CAAA;AAHG,QAAA,IAAA,CAAA,OAAA,GAAA,OAAA;AACA,QAAA,IAAA,CAAA,KAAA,GAAA,KAAA;AAGhB,QAAA,IAAA,CAAK,IAAA,GAAO,qBAAA;AAGZ,QAAA,IAAI,MAAM,iBAAA,EAAmB;AAC3B,UAAA,KAAA,CAAM,iBAAA,CAAkB,MAAM,oBAAmB,CAAA;AAAA,QACnD;AAAA,MACF;AAAA,MAEA,OAAO,aAAA,CAAc,OAAA,EAAiB,OAAA,EAAiB,KAAA,EAAoC;AACzF,QAAA,OAAO,IAAI,oBAAA;AAAA,UACT,CAAA,kBAAA,EAAqB,OAAO,CAAA,UAAA,EAAa,OAAO,CAAA,CAAA;AAAA,UAChD,OAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA,MAEA,OAAO,eAAe,OAAA,EAAsC;AAC1D,QAAA,OAAO,IAAI,oBAAA,CAAoB,CAAA,QAAA,EAAW,OAAO,qCAAqC,OAAO,CAAA;AAAA,MAC/F;AAAA,MAEA,OAAO,cAAA,CAAe,SAAA,EAAmB,OAAA,EAAsC;AAC7E,QAAA,OAAO,IAAI,oBAAA,CAAoB,CAAA,gBAAA,EAAmB,SAAS,CAAA,EAAA,EAAK,OAAO,IAAI,UAAU,CAAA;AAAA,MACvF;AAAA,MAEA,OAAO,gBAAA,CAAiB,SAAA,EAAmB,OAAA,EAAiB,KAAA,EAAoC;AAC9F,QAAA,OAAO,IAAI,oBAAA;AAAA,UACT,CAAA,0BAAA,EAA6B,SAAS,CAAA,EAAA,EAAK,OAAO,CAAA,CAAA;AAAA,UAClD,UAAA;AAAA,UACA;AAAA,SACF;AAAA,MACF;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;ACAA,eAAe,WAAA,CAAe,QAAA,EAAkB,WAAA,EAAqB,QAAA,EAA8B;AACjG,EAAA,IAAI;AACF,IAAA,IAAI,OAAA;AAGJ,IAAA,IAAI,OAAO,QAAQ,WAAA,EAAa;AAC9B,MAAA,IAAI;AACF,QAAA,MAAM,IAAA,GAAO,GAAA,CAAI,IAAA,CAAK,QAAQ,CAAA;AAC9B,QAAA,IAAI,CAAE,MAAM,IAAA,CAAK,MAAA,EAAO,EAAI;AAC1B,UAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,OAAA,GAAU,MAAM,KAAK,IAAA,EAAK;AAAA,MAC5B,SAAS,KAAA,EAAO;AAEd,QAAA,IAAI,iBAAiB,KAAA,IAAS,KAAA,CAAM,OAAA,CAAQ,QAAA,CAAS,cAAc,CAAA,EAAG;AACpE,UAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,MAAM,KAAA;AAAA,MACR;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,IAAI;AACF,QAAA,OAAA,GAAU,MAAMN,QAAAA,CAAS,QAAA,EAAU,OAAO,CAAA;AAAA,MAC5C,SAAS,KAAA,EAAO;AACd,QAAA,IAAK,KAAA,CAAgC,SAAS,QAAA,EAAU;AACtD,UAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,MAAM,KAAA;AAAA,MACR;AAAA,IACF;AAGA,IAAA,MAAM,IAAA,GAAOR,MAAU,OAAO,CAAA;AAG9B,IAAA,MAAM,MAAA,GAAS,MAAM,sBAAA,CAAuB,IAAA,EAAM,QAAQ,CAAA;AAC1D,IAAA,IAAI,CAAC,OAAO,KAAA,EAAO;AACjB,MAAA,MAAM,aAAA,GAAgB,MAAA,CAAO,WAAA,CAAY,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,EAAG,CAAA,CAAE,OAAO,KAAK,CAAA,CAAE,OAAO,CAAA,CAAE,CAAA,CAAE,KAAK,IAAI,CAAA;AAC3F,MAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,QACxB,WAAA;AAAA,QACA,6BAA6B,aAAa,CAAA;AAAA,OAC5C;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,iBAAiB,mBAAA,EAAqB;AACxC,MAAA,MAAM,KAAA;AAAA,IACR;AAGA,IAAA,MAAM,GAAA,GAAM,KAAA;AACZ,IAAA,IAAI,GAAA,CAAI,SAAS,QAAA,EAAU;AACzB,MAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,IACtD,CAAA,MAAA,IAAW,GAAA,CAAI,IAAA,KAAS,QAAA,EAAU;AAChC,MAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,QACxB,WAAA;AAAA,QACA,0CAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,CAAA,MAAA,IAAW,GAAA,CAAI,IAAA,KAAS,QAAA,EAAU;AAChC,MAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,QACxB,WAAA;AAAA,QACA,mCAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,WAAW,GAAA,CAAI,IAAA,KAAS,QAAA,IAAY,GAAA,CAAI,SAAS,QAAA,EAAU;AACzD,MAAA,MAAM,mBAAA,CAAoB,aAAA,CAAc,WAAA,EAAa,qBAAA,EAAuB,GAAG,CAAA;AAAA,IACjF;AAEA,IAAA,MAAM,mBAAA,CAAoB,aAAA,CAAc,WAAA,EAAa,wBAAA,EAA0B,GAAG,CAAA;AAAA,EACpF;AACF;AAKA,eAAsB,kBAAA,GAA8C;AAClE,EAAA,OAAO,WAAA,CAA4B,UAAA,CAAW,QAAA,EAAU,UAAA,EAAY,WAAW,QAAQ,CAAA;AACzF;AAKA,eAAsB,qBAAA,GAAoD;AACxE,EAAA,OAAO,WAAA;AAAA,IACL,UAAA,CAAW,YAAA;AAAA,IACX,cAAA;AAAA,IACA,UAAA,CAAW;AAAA,GACb;AACF;AAKA,eAAsB,mBAAA,GAAgD;AACpE,EAAA,OAAO,WAAA,CAA6B,UAAA,CAAW,SAAA,EAAW,WAAA,EAAa,WAAW,SAAS,CAAA;AAC7F;AAKA,eAAsB,sBAAA,GAAkD;AACtE,EAAA,OAAO,WAAA;AAAA,IACL,UAAA,CAAW,YAAA;AAAA,IACX,cAAA;AAAA,IACA,UAAA,CAAW;AAAA,GACb;AACF;AAKA,eAAsB,eAAA,GAKnB;AACD,EAAA,MAAM,CAAC,UAAU,YAAA,EAAc,SAAA,EAAW,YAAY,CAAA,GAAI,MAAM,QAAQ,GAAA,CAAI;AAAA,IAC1E,kBAAA,EAAmB;AAAA,IACnB,qBAAA,EAAsB;AAAA,IACtB,mBAAA,EAAoB;AAAA,IACpB,sBAAA;AAAuB,GACxB,CAAA;AAED,EAAA,OAAO,EAAE,QAAA,EAAU,YAAA,EAAc,SAAA,EAAW,YAAA,EAAa;AAC3D;AA3KA,IAqBM,UAAA,EACAM,YAGA,UAAA,EAQA,UAAA;AAjCN,IAAA,WAAA,GAAA,KAAA,CAAA;AAAA,EAAA,uBAAA,GAAA;AAWA,IAAA,cAAA,EAAA;AACA,IAAAQ,YAAAA,EAAAA;AASA,IAAM,UAAA,GAAaJ,aAAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,IAAMJ,UAAAA,GAAYK,QAAQ,UAAU,CAAA;AAGpC,IAAM,UAAA,GAAa;AAAA,MACjB,QAAA,EAAUJ,IAAAA,CAAKD,UAAAA,EAAW,wDAAwD,CAAA;AAAA,MAClF,YAAA,EAAcC,IAAAA,CAAKD,UAAAA,EAAW,6DAA6D,CAAA;AAAA,MAC3F,SAAA,EAAWC,IAAAA,CAAKD,UAAAA,EAAW,0DAA0D,CAAA;AAAA,MACrF,YAAA,EAAcC,IAAAA,CAAKD,UAAAA,EAAW,6DAA6D;AAAA,KAC7F;AAGA,IAAM,UAAA,GAAa;AAAA,MACjB,QAAA,EAAU,iCAAA;AAAA,MACV,YAAA,EAAc,2CAAA;AAAA,MACd,SAAA,EAAW,mCAAA;AAAA,MACX,YAAA,EAAc;AAAA,KAChB;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACvBA,SAAS,UAAa,GAAA,EAAW;AAC/B,EAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,IAAA,OAAO,GAAA;AAAA,EACT;AAEA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA,EAAG;AACtB,IAAA,OAAO,IAAI,GAAA,CAAI,CAAC,IAAA,KAAS,SAAA,CAAU,IAAI,CAAC,CAAA;AAAA,EAC1C;AAEA,EAAA,MAAM,SAAkC,EAAC;AACzC,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAA,CAAO,GAAG,CAAA,GAAI,SAAA,CAAW,GAAA,CAAgC,GAAG,CAAC,CAAA;AAAA,IAC/D;AAAA,EACF;AACA,EAAA,OAAO,MAAA;AACT;AAEA,SAAS,WAA6B,GAAA,EAAW;AAC/C,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAEjB,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAM,KAAA,GAAQ,IAAI,GAAG,CAAA;AACrB,MAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,KAAU,QAAA,EAAU;AAC/C,QAAA,UAAA,CAAW,KAAK,CAAA;AAAA,MAClB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,GAAA;AACT;AAEA,SAAS,iBAAiB,IAAA,EAA+B;AACvD,EAAA,MAAM,MAAM,OAAO,IAAA,KAAS,QAAA,GAAW,IAAA,CAAK,UAAS,GAAI,IAAA;AACzD,EAAA,OAAO,GAAA,CAAI,QAAA,CAAS,CAAA,EAAG,GAAG,CAAA;AAC5B;AAEA,eAAe,mBAAA,GAAqC;AAClD,EAAA,IAAI,iBAAiB,IAAA,EAAM;AACzB,IAAA;AAAA,EACF;AAEA,EAAA,YAAA,GAAe,MAAM,sBAAA,EAAuB;AAE5C,EAAA,KAAA,MAAW,OAAA,IAAW,aAAa,SAAA,EAAW;AAE5C,IAAA,WAAA,CAAY,GAAA,CAAI,OAAA,CAAQ,MAAA,CAAO,WAAA,IAAe,OAAO,CAAA;AAGrD,IAAA,WAAA,CAAY,GAAA,CAAI,OAAA,CAAQ,MAAA,CAAO,WAAA,IAAe,OAAO,CAAA;AAGrD,IAAA,MAAM,UAAA,GAAa,gBAAA,CAAiB,OAAA,CAAQ,OAAO,CAAA;AACnD,IAAA,YAAA,CAAa,GAAA,CAAI,YAAY,OAAO,CAAA;AAAA,EACtC;AACF;AAEA,eAAsB,mBAAmB,IAAA,EAAiD;AACxF,EAAA,MAAM,mBAAA,EAAoB;AAC1B,EAAA,MAAM,UAAA,GAAa,KAAK,WAAA,EAAY;AACpC,EAAA,MAAM,OAAA,GAAU,WAAA,CAAY,GAAA,CAAI,UAAU,CAAA;AAC1C,EAAA,OAAO,OAAA,GAAU,UAAA,CAAW,SAAA,CAAU,OAAO,CAAC,CAAA,GAAI,IAAA;AACpD;AAEA,eAAsB,mBAAmB,IAAA,EAAiD;AACxF,EAAA,MAAM,mBAAA,EAAoB;AAC1B,EAAA,MAAM,UAAA,GAAa,KAAK,WAAA,EAAY;AACpC,EAAA,MAAM,OAAA,GAAU,WAAA,CAAY,GAAA,CAAI,UAAU,CAAA;AAC1C,EAAA,OAAO,OAAA,GAAU,UAAA,CAAW,SAAA,CAAU,OAAO,CAAC,CAAA,GAAI,IAAA;AACpD;AAEA,eAAsB,oBACpB,IAAA,EACmC;AACnC,EAAA,MAAM,mBAAA,EAAoB;AAC1B,EAAA,MAAM,UAAA,GAAa,iBAAiB,IAAI,CAAA;AACxC,EAAA,MAAM,OAAA,GAAU,YAAA,CAAa,GAAA,CAAI,UAAU,CAAA;AAC3C,EAAA,OAAO,OAAA,GAAU,UAAA,CAAW,SAAA,CAAU,OAAO,CAAC,CAAA,GAAI,IAAA;AACpD;AAEA,eAAsB,aAAA,GAA2D;AAC/E,EAAA,MAAM,mBAAA,EAAoB;AAC1B,EAAA,OAAO,KAAA,CAAM,IAAA,CAAK,WAAA,CAAY,MAAA,EAAQ,CAAA,CAAE,GAAA,CAAI,CAAC,CAAA,KAAM,UAAA,CAAW,SAAA,CAAU,CAAC,CAAC,CAAC,CAAA;AAC7E;AAEO,SAAS,qBAAA,GAA8B;AAC5C,EAAA,YAAA,GAAe,IAAA;AACf,EAAA,WAAA,CAAY,KAAA,EAAM;AAClB,EAAA,WAAA,CAAY,KAAA,EAAM;AAClB,EAAA,YAAA,CAAa,KAAA,EAAM;AACrB;AA1GA,IAUI,YAAA,EACE,aACA,WAAA,EACA,YAAA;AAbN,IAAA,kBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,8BAAA,GAAA;AAOA,IAAA,WAAA,EAAA;AAGA,IAAI,YAAA,GAAsC,IAAA;AAC1C,IAAM,WAAA,uBAAkB,GAAA,EAAqB;AAC7C,IAAM,WAAA,uBAAkB,GAAA,EAAqB;AAC7C,IAAM,YAAA,uBAAmB,GAAA,EAAqB;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACohBvC,SAAS,gBAAgB,IAAA,EAAwC;AACtE,EAAA,OAAO,iBAAiB,IAAI,CAAA;AAC9B;AAniBA,IAgBa,WAoHA,gBAAA,EAoaA,kBAAA;AAxiBb,IAAA,cAAA,GAAA,KAAA,CAAA;AAAA,EAAA,mCAAA,GAAA;AAgBO,IAAM,SAAA,GAAY;AAAA;AAAA;AAAA,MAGvB,YAAA,EAAc,CAAA;AAAA,MACd,YAAA,EAAc,CAAA;AAAA;AAAA;AAAA,MAId,gBAAA,EAAkB,EAAA;AAAA,MAClB,yBAAA,EAA2B,EAAA;AAAA,MAC3B,6BAAA,EAA+B,EAAA;AAAA,MAC/B,wBAAA,EAA0B,EAAA;AAAA,MAC1B,uBAAA,EAAyB,EAAA;AAAA,MACzB,uBAAA,EAAyB,EAAA;AAAA;AAAA;AAAA,MAIzB,mBAAA,EAAqB,EAAA;AAAA,MACrB,uBAAA,EAAyB,EAAA;AAAA,MACzB,0BAAA,EAA4B,EAAA;AAAA,MAC5B,0BAAA,EAA4B,EAAA;AAAA,MAC5B,wBAAA,EAA0B,EAAA;AAAA;AAAA;AAAA,MAI1B,wBAAA,EAA0B,EAAA;AAAA,MAC1B,yBAAA,EAA2B,EAAA;AAAA,MAC3B,iCAAA,EAAmC,EAAA;AAAA,MACnC,uBAAA,EAAyB,EAAA;AAAA,MACzB,sBAAA,EAAwB,EAAA;AAAA;AAAA;AAAA,MAIxB,qBAAA,EAAuB,EAAA;AAAA,MACvB,8BAAA,EAAgC,EAAA;AAAA,MAChC,UAAA,EAAY,EAAA;AAAA;AAAA;AAAA,MAIZ,sBAAA,EAAwB,EAAA;AAAA,MACxB,mBAAA,EAAqB,EAAA;AAAA,MACrB,wBAAA,EAA0B,EAAA;AAAA,MAC1B,oBAAA,EAAsB,EAAA;AAAA,MACtB,qBAAA,EAAuB,EAAA;AAAA;AAAA;AAAA,MAIvB,iBAAA,EAAmB,EAAA;AAAA,MACnB,gBAAA,EAAkB,EAAA;AAAA,MAClB,0BAAA,EAA4B,EAAA;AAAA,MAC5B,iBAAA,EAAmB,EAAA;AAAA;AAAA;AAAA,MAInB,0BAAA,EAA4B,EAAA;AAAA,MAC5B,yBAAA,EAA2B,EAAA;AAAA,MAC3B,uBAAA,EAAyB,EAAA;AAAA,MACzB,wBAAA,EAA0B,EAAA;AAAA;AAAA;AAAA,MAI1B,wBAAA,EAA0B,EAAA;AAAA,MAC1B,mBAAA,EAAqB,EAAA;AAAA,MACrB,mBAAA,EAAqB,EAAA;AAAA,MACrB,wBAAA,EAA0B,EAAA;AAAA,MAC1B,8BAAA,EAAgC,EAAA;AAAA;AAAA;AAAA,MAIhC,iBAAA,EAAmB,EAAA;AAAA,MACnB,eAAA,EAAiB,EAAA;AAAA,MACjB,qBAAA,EAAuB,EAAA;AAAA,MACvB,qBAAA,EAAuB,EAAA;AAAA,MACvB,4BAAA,EAA8B,EAAA;AAAA,MAC9B,+BAAA,EAAiC,EAAA;AAAA;AAAA;AAAA,MAIjC,eAAA,EAAiB,GAAA;AAAA,MACjB,eAAA,EAAiB,GAAA;AAAA,MACjB,gBAAA,EAAkB,GAAA;AAAA,MAClB,gBAAA,EAAkB,GAAA;AAAA,MAClB,gBAAA,EAAkB,GAAA;AAAA,MAClB,gBAAA,EAAkB,GAAA;AAAA,MAClB,gBAAA,EAAkB,GAAA;AAAA,MAClB,gBAAA,EAAkB,GAAA;AAAA,MAClB,gBAAA,EAAkB;AAAA,KACpB;AA6BO,IAAM,gBAAA,GAAiD;AAAA,MAC5D,CAAA,EAAG;AAAA,QACD,IAAA,EAAM,CAAA;AAAA,QACN,IAAA,EAAM,cAAA;AAAA,QACN,WAAA,EAAa,sBAAA;AAAA,QACb,OAAA,EAAS,kCAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,CAAA,EAAG;AAAA,QACD,IAAA,EAAM,CAAA;AAAA,QACN,IAAA,EAAM,cAAA;AAAA,QACN,WAAA,EAAa,qCAAA;AAAA,QACb,OAAA,EAAS,6CAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,kCAAA;AAAA,QACb,OAAA,EAAS,uEAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,2BAAA;AAAA,QACN,WAAA,EAAa,wCAAA;AAAA,QACb,OAAA,EAAS,6DAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,+BAAA;AAAA,QACN,WAAA,EAAa,iDAAA;AAAA,QACb,OAAA,EAAS,+DAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,iCAAA;AAAA,QACb,OAAA,EAAS,gEAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,yBAAA;AAAA,QACN,WAAA,EAAa,mCAAA;AAAA,QACb,OAAA,EAAS,wDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,yBAAA;AAAA,QACN,WAAA,EAAa,8BAAA;AAAA,QACb,OAAA,EAAS,uDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,qBAAA;AAAA,QACN,WAAA,EAAa,sCAAA;AAAA,QACb,OAAA,EAAS,0DAAA;AAAA,QACT,QAAA,EAAU,eAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,yBAAA;AAAA,QACN,WAAA,EAAa,+BAAA;AAAA,QACb,OAAA,EAAS,sDAAA;AAAA,QACT,QAAA,EAAU,eAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,4BAAA;AAAA,QACN,WAAA,EAAa,sCAAA;AAAA,QACb,OAAA,EAAS,qDAAA;AAAA,QACT,QAAA,EAAU,eAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,4BAAA;AAAA,QACN,WAAA,EAAa,uCAAA;AAAA,QACb,OAAA,EAAS,gDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,kDAAA;AAAA,QACb,OAAA,EAAS,sDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,mDAAA;AAAA,QACb,OAAA,EAAS,6CAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,2BAAA;AAAA,QACN,WAAA,EAAa,2CAAA;AAAA,QACb,OAAA,EAAS,oDAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,mCAAA;AAAA,QACN,WAAA,EAAa,uCAAA;AAAA,QACb,OAAA,EAAS,iDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,yBAAA;AAAA,QACN,WAAA,EAAa,6DAAA;AAAA,QACb,OAAA,EAAS,+CAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,wBAAA;AAAA,QACN,WAAA,EAAa,sCAAA;AAAA,QACb,OAAA,EAAS,wDAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,SAAA,EAAW;AAAA,OACb;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,uBAAA;AAAA,QACN,WAAA,EAAa,6CAAA;AAAA,QACb,OAAA,EAAS,mDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,gCAAA;AAAA,QACN,WAAA,EAAa,6CAAA;AAAA,QACb,OAAA,EAAS,mDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,YAAA;AAAA,QACN,WAAA,EAAa,0BAAA;AAAA,QACb,OAAA,EAAS,iEAAA;AAAA,QACT,QAAA,EAAU,OAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,wBAAA;AAAA,QACN,WAAA,EAAa,wCAAA;AAAA,QACb,OAAA,EAAS,0DAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,qBAAA;AAAA,QACN,WAAA,EAAa,yBAAA;AAAA,QACb,OAAA,EAAS,qDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,8BAAA;AAAA,QACb,OAAA,EAAS,gDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,sBAAA;AAAA,QACN,WAAA,EAAa,oBAAA;AAAA,QACb,OAAA,EAAS,4CAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,uBAAA;AAAA,QACN,WAAA,EAAa,oBAAA;AAAA,QACb,OAAA,EAAS,oDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,mBAAA;AAAA,QACN,WAAA,EAAa,8BAAA;AAAA,QACb,OAAA,EAAS,6CAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,0BAAA;AAAA,QACb,OAAA,EAAS,wCAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,4BAAA;AAAA,QACN,WAAA,EAAa,0CAAA;AAAA,QACb,OAAA,EAAS,4DAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,mBAAA;AAAA,QACN,WAAA,EAAa,0BAAA;AAAA,QACb,OAAA,EAAS,yCAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,4BAAA;AAAA,QACN,WAAA,EAAa,uBAAA;AAAA,QACb,OAAA,EAAS,+DAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,2BAAA;AAAA,QACN,WAAA,EAAa,mEAAA;AAAA,QACb,OAAA,EAAS,yDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,yBAAA;AAAA,QACN,WAAA,EAAa,oCAAA;AAAA,QACb,OAAA,EAAS,wDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,uCAAA;AAAA,QACb,OAAA,EAAS,mDAAA;AAAA,QACT,QAAA,EAAU,UAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,mDAAA;AAAA,QACb,OAAA,EACE,0JAAA;AAAA,QACF,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,qBAAA;AAAA,QACN,WAAA,EAAa,wCAAA;AAAA,QACb,OAAA,EAAS,oDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,qBAAA;AAAA,QACN,WAAA,EAAa,6CAAA;AAAA,QACb,OAAA,EAAS,iDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,0BAAA;AAAA,QACN,WAAA,EAAa,6BAAA;AAAA,QACb,OAAA,EAAS,iDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,gCAAA;AAAA,QACN,WAAA,EAAa,uCAAA;AAAA,QACb,OAAA,EAAS,+DAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,mBAAA;AAAA,QACN,WAAA,EAAa,0BAAA;AAAA,QACb,OAAA,EACE,kHAAA;AAAA,QACF,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,iBAAA;AAAA,QACN,WAAA,EAAa,yCAAA;AAAA,QACb,OAAA,EACE,6GAAA;AAAA,QACF,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,uBAAA;AAAA,QACN,WAAA,EAAa,wCAAA;AAAA,QACb,OAAA,EACE,uFAAA;AAAA,QACF,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,uBAAA;AAAA,QACN,WAAA,EAAa,0BAAA;AAAA,QACb,OAAA,EAAS,2EAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,8BAAA;AAAA,QACN,WAAA,EAAa,qCAAA;AAAA,QACb,OAAA,EAAS,mFAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,EAAA,EAAI;AAAA,QACF,IAAA,EAAM,EAAA;AAAA,QACN,IAAA,EAAM,iCAAA;AAAA,QACN,WAAA,EAAa,wCAAA;AAAA,QACb,OAAA,EAAS,gDAAA;AAAA,QACT,QAAA,EAAU;AAAA,OACZ;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,iBAAA;AAAA,QACN,WAAA,EAAa,wBAAA;AAAA,QACb,OAAA,EAAS,gDAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,iBAAA;AAAA,QACN,WAAA,EAAa,2BAAA;AAAA,QACb,OAAA,EAAS,gCAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,uBAAA;AAAA,QACb,OAAA,EAAS,sCAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,uBAAA;AAAA,QACb,OAAA,EAAS,6DAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe,SAAA;AAAA,QACf,UAAA,EAAY;AAAA,OACd;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,uBAAA;AAAA,QACb,OAAA,EAAS,kDAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe,UAAA;AAAA,QACf,UAAA,EAAY;AAAA,OACd;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,wBAAA;AAAA,QACb,OAAA,EAAS,+BAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe,UAAA;AAAA,QACf,UAAA,EAAY;AAAA,OACd;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,8BAAA;AAAA,QACb,OAAA,EAAS,iDAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe,UAAA;AAAA,QACf,UAAA,EAAY;AAAA,OACd;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,iCAAA;AAAA,QACb,OAAA,EAAS,sEAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA,GAAA,EAAK;AAAA,QACH,IAAA,EAAM,GAAA;AAAA,QACN,IAAA,EAAM,kBAAA;AAAA,QACN,WAAA,EAAa,iCAAA;AAAA,QACb,OAAA,EAAS,gEAAA;AAAA,QACT,QAAA,EAAU,SAAA;AAAA,QACV,aAAA,EAAe;AAAA;AACjB,KACF;AAeO,IAAM,kBAAA,GAAqB,QAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC3f3B,SAAS,uBAAA,GAAmC;AAGjD,EAAA,OAAO,QAAQ,QAAA,KAAa,OAAA;AAC9B;AASO,SAAS,WAAA,GAA+B;AAC7C,EAAA,OAAO,OAAA,CAAQ,QAAA;AACjB;AAUO,SAAS,SAAA,GAAqB;AACnC,EAAA,OAAO,QAAQ,QAAA,KAAa,OAAA;AAC9B;AAOO,SAAS,OAAA,GAAmB;AACjC,EAAA,OAAO,CAAC,SAAA,EAAU;AACpB;AA0BO,SAAS,uBAAA,GAAgD;AAC9D,EAAA,OAAO;AAAA,IACL,UAAU,WAAA,EAAY;AAAA,IACtB,yBAAyB,uBAAA,EAAwB;AAAA,IACjD,SAAS,OAAA,EAAQ;AAAA,IACjB,WAAW,SAAA;AAAU,GACvB;AACF;AAlHA,IAAA,iBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,wCAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC2DO,SAAS,uBAAA,CACd,IAAA,EACA,IAAA,GAAuB,OAAA,cACf;AAER,EAAA,IAAI,SAAS,CAAA,EAAG;AACd,IAAA,OAAO,CAAA;AAAA,EACT;AAGA,EAAA,IAAI,SAAS,OAAA,cAAsB;AACjC,IAAA,OAAO,CAAA;AAAA,EACT;AAGA,EAAA,MAAM,IAAA,GAAO,iBAAiB,IAAI,CAAA;AAClC,EAAA,IAAI,CAAC,IAAA,EAAM;AAET,IAAA,OAAO,CAAA;AAAA,EACT;AAGA,EAAA,IAAI,IAAA,CAAK,cAAc,OAAA,EAAS;AAE9B,IAAA,OAAO,CAAA;AAAA,EACT;AAEA,EAAA,IAAI,IAAA,CAAK,cAAc,UAAA,EAAY;AAEjC,IAAA,OAAO,CAAA;AAAA,EACT;AAEA,EAAA,IAAI,IAAA,CAAK,cAAc,aAAA,EAAe;AAEpC,IAAA,OAAO,CAAA;AAAA,EACT;AAGA,EAAA,QAAQ,KAAK,QAAA;AAAU,IACrB,KAAK,eAAA;AAAA,IACL,KAAK,OAAA;AAEH,MAAA,OAAO,CAAA;AAAA,IAET,KAAK,YAAA;AAAA,IACL,KAAK,SAAA;AAEH,MAAA,OAAO,CAAA;AAAA,IAET,KAAK,aAAA;AAAA,IACL,KAAK,MAAA;AAEH,MAAA,OAAO,CAAA;AAAA,IAET,KAAK,UAAA;AAEH,MAAA,OAAO,CAAA;AAAA,IAET,KAAK,eAAA;AAEH,MAAA,OAAO,CAAA;AAAA,IAET,KAAK,SAAA;AAEH,MAAA,OAAO,CAAA;AAAA,IAET,KAAK,SAAA;AAGH,MAAA,OAAO,CAAA;AAAA,IAET;AAEE,MAAA,OAAO,CAAA;AAAA;AAEb;AAmBO,SAAS,mBAAmB,IAAA,EAAgC;AACjE,EAAA,QAAQ,IAAA;AAAM,IACZ,KAAK,OAAA;AACH,MAAA,OAAO,CAAC,GAAG,CAAC,CAAA;AAAA,IACd,KAAK,UAAA;AACH,MAAA,OAAO,CAAC,CAAA,EAAG,CAAA,EAAG,CAAA,EAAG,CAAC,CAAA;AAAA,IACpB;AACE,MAAA,OAAO,CAAC,GAAG,CAAC,CAAA;AAAA;AAElB;AASO,SAAS,4BAAA,CAA6B,MAAc,IAAA,EAA8B;AACvF,EAAA,IAAI,SAAS,OAAA,cAAsB;AACjC,IAAA,QAAQ,IAAA;AAAM,MACZ,KAAK,CAAA;AACH,QAAA,OAAO,SAAA;AAAA,MACT,KAAK,CAAA;AACH,QAAA,OAAO,SAAA;AAAA,MACT;AACE,QAAA,OAAO,SAAA;AAAA;AACX,EACF;AAEA,EAAA,IAAI,SAAS,UAAA,iBAAyB;AACpC,IAAA,QAAQ,IAAA;AAAM,MACZ,KAAK,CAAA;AACH,QAAA,OAAO,SAAA;AAAA,MACT,KAAK,CAAA;AACH,QAAA,OAAO,oCAAA;AAAA,MACT,KAAK,CAAA;AACH,QAAA,OAAO,+CAAA;AAAA,MACT,KAAK,CAAA;AACH,QAAA,OAAO,oCAAA;AAAA,MACT;AACE,QAAA,OAAO,SAAA;AAAA;AACX,EACF;AAEA,EAAA,OAAO,cAAA;AACT;AAvMA,IAkBY,cAAA;AAlBZ,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,sCAAA,GAAA;AAaA,IAAA,cAAA,EAAA;AAKO,IAAK,cAAA,qBAAAS,eAAAA,KAAL;AAML,MAAAA,gBAAA,OAAA,CAAA,GAAQ,OAAA;AASR,MAAAA,gBAAA,UAAA,CAAA,GAAW,UAAA;AAfD,MAAA,OAAAA,eAAAA;AAAA,IAAA,CAAA,EAAA,cAAA,IAAA,EAAA,CAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AClBZ,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,iCAAA,GAAA;AAUA,IAAA,cAAA,EAAA;AAUA,IAAA,iBAAA,EAAA;AASA,IAAA,eAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACnBA,SAASC,WAAa,GAAA,EAAW;AAC/B,EAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,IAAA,OAAO,GAAA;AAAA,EACT;AAEA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA,EAAG;AACtB,IAAA,OAAO,IAAI,GAAA,CAAI,CAAC,IAAA,KAASA,UAAAA,CAAU,IAAI,CAAC,CAAA;AAAA,EAC1C;AAEA,EAAA,MAAM,SAAkC,EAAC;AACzC,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAA,CAAO,GAAG,CAAA,GAAIA,UAAAA,CAAW,GAAA,CAAgC,GAAG,CAAC,CAAA;AAAA,IAC/D;AAAA,EACF;AACA,EAAA,OAAO,MAAA;AACT;AAEA,SAASC,YAA6B,GAAA,EAAW;AAC/C,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAEjB,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAM,KAAA,GAAQ,IAAI,GAAG,CAAA;AACrB,MAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,KAAU,QAAA,EAAU;AAC/C,QAAAA,YAAW,KAAK,CAAA;AAAA,MAClB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,GAAA;AACT;AAEA,eAAeC,oBAAAA,GAAqC;AAClD,EAAA,IAAIC,kBAAiB,IAAA,EAAM;AACzB,IAAA;AAAA,EACF;AAEA,EAAAA,aAAAA,GAAe,MAAM,qBAAA,EAAsB;AAE3C,EAAA,KAAA,MAAW,KAAA,IAASA,cAAa,MAAA,EAAQ;AACvC,IAAA,MAAM,UAAU,KAAA,CAAM,EAAA;AACtB,IAAA,KAAA,MAAW,IAAA,IAAQ,MAAM,KAAA,EAAO;AAC9B,MAAA,eAAA,CAAgB,GAAA,CAAI,KAAK,KAAA,EAAO;AAAA,QAC9B,OAAO,IAAA,CAAK,KAAA;AAAA,QACZ,QAAQ,IAAA,CAAK,MAAA;AAAA,QACb,KAAA,EAAO;AAAA,OACR,CAAA;AAAA,IACH;AAAA,EACF;AACF;AAEA,eAAsB,cAAc,IAAA,EAAwD;AAC1F,EAAA,MAAMD,oBAAAA,EAAoB;AAC1B,EAAA,MAAM,MAAA,GAAS,eAAA,CAAgB,GAAA,CAAI,IAAI,CAAA;AACvC,EAAA,OAAO,MAAA,GAASD,WAAAA,CAAWD,UAAAA,CAAU,MAAM,CAAC,CAAA,GAAI,IAAA;AAClD;AAEO,SAAS,gBAAgB,IAAA,EAAuB;AACrD,EAAA,OAAO,IAAA,IAAQ,OAAO,IAAA,GAAO,GAAA;AAC/B;AAEO,SAAS,UAAU,IAAA,EAAuB;AAC/C,EAAA,OAAO,IAAA,IAAQ,OAAO,IAAA,GAAO,GAAA;AAC/B;AAEO,SAAS,cAAc,IAAA,EAAuB;AACnD,EAAA,OAAO,IAAA,IAAQ,OAAO,IAAA,GAAO,GAAA;AAC/B;AAEO,SAAS,cAAc,IAAA,EAAuB;AACnD,EAAA,OAAO,IAAA,IAAQ,OAAO,IAAA,GAAO,GAAA;AAC/B;AAEO,SAAS,cAAc,IAAA,EAAuB;AACnD,EAAA,OAAO,IAAA,IAAQ,OAAO,IAAA,GAAO,GAAA;AAC/B;AAEA,eAAsB,gBAAA,GAAqE;AACzF,EAAA,MAAME,oBAAAA,EAAoB;AAC1B,EAAA,OAAO,KAAA,CAAM,IAAA,CAAK,eAAA,CAAgB,MAAA,EAAQ,CAAA,CAAE,GAAA,CAAI,CAAC,CAAA,KAAMD,WAAAA,CAAWD,UAAAA,CAAU,CAAC,CAAC,CAAC,CAAA;AACjF;AAEA,eAAsB,gBAAgB,IAAA,EAAsC;AAC1E,EAAA,MAAM,MAAA,GAAS,MAAM,aAAA,CAAc,IAAI,CAAA;AACvC,EAAA,OAAO,QAAQ,MAAA,IAAU,IAAA;AAC3B;AAEO,SAAS,oBAAA,GAA6B;AAC3C,EAAAG,aAAAA,GAAe,IAAA;AACf,EAAA,eAAA,CAAgB,KAAA,EAAM;AACxB;AArGA,IAOIA,aAAAA,EACE,eAAA;AARN,IAAA,kBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,8BAAA,GAAA;AAIA,IAAA,WAAA,EAAA;AAGA,IAAIA,aAAAA,GAAyC,IAAA;AAC7C,IAAM,eAAA,uBAAsB,GAAA,EAA4B;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC+IjD,SAAS,OAAO,MAAA,EAAyB;AAC9C,EAAA,IAAI,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG,OAAO,KAAA;AAC9B,EAAA,OAAO,OAAO,CAAC,CAAA,KAAM,QAAA,CAAS,CAAC,KAAK,MAAA,CAAO,CAAC,CAAA,KAAM,QAAA,CAAS,CAAC,CAAA,IAAK,MAAA,CAAO,CAAC,CAAA,KAAM,SAAS,CAAC,CAAA;AAC3F;AAKO,SAAS,aAAa,MAAA,EAAwB;AACnD,EAAA,OAAO,MAAA,CAAO,MAAM,CAAA,GAAI,CAAA,GAAI,CAAA;AAC9B;AAjKA,IAwBa,UAGP,YAAA,EAcA,aAAA,EAwBA,eAcA,eAAA,EAGA,YAAA,EAGA,mBAGA,aAAA,EASO,qBAAA;AAjGb,IAAA,kBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,8BAAA,GAAA;AAwBO,IAAM,QAAA,GAAqB,CAAC,GAAA,EAAM,GAAA,EAAM,GAAI,CAAA;AAGnD,IAAM,YAAA,GAAqC;AAAA,MACzC;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,OAAO,CAAC,EAAA,EAAM,EAAA,EAAM,GAAA,EAAM,KAAM,GAAI,CAAA;AAAA,QACpC,WAAA,EAAa;AAAA,OACf;AAAA,MACA;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,KAAA,EAAO,CAAC,GAAA,EAAM,GAAA,EAAM,KAAM,EAAA,EAAM,EAAA,EAAM,GAAA,EAAM,GAAA,EAAM,GAAI,CAAA;AAAA,QACtD,WAAA,EAAa;AAAA;AACf,KACF;AAGA,IAAM,aAAA,GAAsC;AAAA,MAC1C;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,KAAA,EAAO,CAAC,GAAI,CAAA;AAAA,QACZ,WAAA,EAAa;AAAA,OACf;AAAA,MACA;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,KAAA,EAAO,CAAC,EAAI,CAAA;AAAA,QACZ,WAAA,EAAa;AAAA,OACf;AAAA,MACA;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,KAAA,EAAO,CAAC,GAAA,EAAM,GAAA,EAAM,KAAM,GAAI,CAAA;AAAA,QAC9B,WAAA,EAAa;AAAA,OACf;AAAA,MACA;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,KAAA,EAAO,CAAC,GAAA,EAAM,GAAA,EAAM,KAAM,EAAI,CAAA;AAAA,QAC9B,WAAA,EAAa;AAAA;AACf,KACF;AAGA,IAAM,aAAA,GAAsC;AAAA,MAC1C;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,KAAA,EAAO,CAAC,EAAA,EAAM,EAAA,EAAM,EAAI,CAAA;AAAA,QACxB,WAAA,EAAa;AAAA,OACf;AAAA,MACA;AAAA,QACE,MAAA,EAAQ,CAAA;AAAA,QACR,OAAO,CAAC,EAAA,EAAM,EAAA,EAAM,EAAA,EAAM,IAAM,EAAI,CAAA;AAAA,QACpC,WAAA,EAAa;AAAA;AACf,KACF;AAGA,IAAM,kBAAwC,EAAC;AAG/C,IAAM,eAAqC,EAAC;AAG5C,IAAM,oBAA0C,EAAC;AAGjD,IAAM,gBAAsC,EAAC;AAStC,IAAM,qBAAA,GAAgD;AAAA,MAC3D;AAAA,QACE,QAAA,EAAU,iBAAA;AAAA,QACV,QAAA,EAAU,YAAA;AAAA,QACV,QAAA,EAAU,EAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,sBAAA;AAAA,QACV,QAAA,EAAU,eAAA;AAAA,QACV,QAAA,EAAU,CAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,kBAAA;AAAA,QACV,QAAA,EAAU,aAAA;AAAA,QACV,QAAA,EAAU,CAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,kBAAA;AAAA,QACV,QAAA,EAAU,aAAA;AAAA,QACV,QAAA,EAAU,CAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,kBAAA;AAAA,QACV,UAAU,EAAC;AAAA,QACX,QAAA,EAAU,GAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,UAAA;AAAA,QACV,QAAA,EAAU,YAAA;AAAA,QACV,QAAA,EAAU,CAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,wBAAA;AAAA,QACV,QAAA,EAAU,iBAAA;AAAA,QACV,QAAA,EAAU,CAAA;AAAA,QACV,aAAA,EAAe;AAAA,OACjB;AAAA,MACA;AAAA,QACE,QAAA,EAAU,YAAA;AAAA,QACV,QAAA,EAAU,aAAA;AAAA,QACV,QAAA,EAAU,CAAA;AAAA,QACV,aAAA,EAAe;AAAA;AACjB,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACwJO,SAAS,eAAe,OAAA,EAAkD;AAC/E,EAAA,OAAO,IAAI,gBAAA,CAAiB,qBAAA,EAAuB,OAAO,CAAA;AAC5D;AA5SA,IAmCa,gBAAA;AAnCb,IAAA,aAAA,GAAA,KAAA,CAAA;AAAA,EAAA,yBAAA,GAAA;AAOA,IAAA,kBAAA,EAAA;AA4BO,IAAM,mBAAN,MAAuB;AAAA,MACpB,QAAA;AAAA,MACA,OAAA;AAAA,MAER,WAAA,CAAY,UAAkC,OAAA,EAAgC;AAC5E,QAAA,IAAA,CAAK,QAAA,GAAW,CAAC,GAAG,QAAQ,CAAA,CAAE,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM,CAAA,CAAE,QAAA,GAAW,CAAA,CAAE,QAAQ,CAAA;AACpE,QAAA,IAAA,CAAK,OAAA,GAAU,OAAA;AAAA,MACjB;AAAA;AAAA;AAAA;AAAA,MAKA,MAAA,CAAO,MAAA,EAAgB,QAAA,GAA6B,EAAC,EAAoB;AAEvE,QAAA,MAAM,MAAA,GAAS,aAAa,MAAM,CAAA;AAClC,QAAA,MAAM,gBAAgB,MAAA,GAAS,CAAA,GAAI,MAAA,CAAO,QAAA,CAAS,MAAM,CAAA,GAAI,MAAA;AAI7D,QAAA,KAAA,MAAW,OAAA,IAAW,KAAK,QAAA,EAAU;AACnC,UAAA,IAAI,QAAQ,aAAA,KAAkB,OAAA,IAAW,KAAK,YAAA,CAAa,aAAA,EAAe,OAAO,CAAA,EAAG;AAClF,YAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,OAAA,CAAQ,QAAQ,CAAA,IAAK,IAAA;AAAA,UAC/C;AACA,UAAA,IAAI,QAAQ,aAAA,KAAkB,WAAA,IAAe,KAAK,cAAA,CAAe,aAAA,EAAe,OAAO,CAAA,EAAG;AACxF,YAAA,OAAO,IAAA,CAAK,OAAA,CAAQ,GAAA,CAAI,OAAA,CAAQ,QAAQ,CAAA,IAAK,IAAA;AAAA,UAC/C;AAAA,QACF;AAEA,QAAA,OAAO,IAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKQ,YAAA,CAAa,QAAgB,SAAA,EAA0C;AAC7E,QAAA,KAAA,MAAW,OAAA,IAAW,UAAU,QAAA,EAAU;AACxC,UAAA,IAAI,IAAA,CAAK,UAAA,CAAW,MAAA,EAAQ,OAAO,CAAA,EAAG;AACpC,YAAA,OAAO,IAAA;AAAA,UACT;AAAA,QACF;AACA,QAAA,OAAO,KAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKQ,UAAA,CAAW,QAAgB,OAAA,EAAsC;AACvE,QAAA,MAAM,EAAE,MAAA,EAAQ,KAAA,EAAO,IAAA,EAAK,GAAI,OAAA;AAEhC,QAAA,IAAI,MAAA,CAAO,MAAA,GAAS,MAAA,GAAS,KAAA,CAAM,MAAA,EAAQ;AACzC,UAAA,OAAO,KAAA;AAAA,QACT;AAEA,QAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,KAAA,CAAM,QAAQ,CAAA,EAAA,EAAK;AACrC,UAAA,MAAM,UAAA,GAAa,MAAA,CAAO,MAAA,GAAS,CAAC,CAAA;AACpC,UAAA,MAAM,WAAA,GAAc,MAAM,CAAC,CAAA;AAC3B,UAAA,MAAM,QAAA,GAAW,IAAA,GAAO,IAAA,CAAK,CAAC,CAAA,GAAI,GAAA;AAElC,UAAA,IAAA,CAAK,UAAA,GAAa,QAAA,OAAe,WAAA,GAAc,QAAA,CAAA,EAAW;AACxD,YAAA,OAAO,KAAA;AAAA,UACT;AAAA,QACF;AAEA,QAAA,OAAO,IAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKQ,cAAA,CAAe,QAAgB,SAAA,EAA0C;AAC/E,QAAA,QAAQ,UAAU,QAAA;AAAU,UAC1B,KAAK,sBAAA;AACH,YAAA,OAAO,IAAA,CAAK,aAAa,MAAM,CAAA;AAAA,UACjC,KAAK,kBAAA;AACH,YAAA,OAAO,IAAA,CAAK,WAAW,MAAM,CAAA;AAAA,UAC/B,KAAK,UAAA;AACH,YAAA,OAAO,IAAA,CAAK,UAAU,MAAM,CAAA;AAAA,UAC9B,KAAK,wBAAA;AACH,YAAA,OAAO,IAAA,CAAK,eAAe,MAAM,CAAA;AAAA,UACnC,KAAK,YAAA;AACH,YAAA,OAAO,IAAA,CAAK,gBAAgB,MAAM,CAAA;AAAA,UACpC;AACE,YAAA,OAAO,KAAA;AAAA;AACX,MACF;AAAA;AAAA;AAAA;AAAA,MAKQ,aAAa,MAAA,EAAyB;AAC5C,QAAA,IAAI;AACF,UAAA,MAAM,IAAA,GAAO,MAAA,CAAO,QAAA,CAAS,OAAA,EAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrE,UAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,IAAI,CAAA,CAAE,MAAA,CAAO,CAAC,IAAA,KAAS,IAAA,CAAK,IAAA,EAAK,CAAE,MAAA,GAAS,CAAC,CAAA;AAEtE,UAAA,IAAI,KAAA,CAAM,MAAA,GAAS,CAAA,EAAG,OAAO,KAAA;AAG7B,UAAA,MAAM,YAAA,GAAe,IAAA,CAAK,GAAA,CAAI,CAAA,EAAG,MAAM,MAAM,CAAA;AAC7C,UAAA,IAAI,cAAA,GAAiB,CAAA;AAErB,UAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,YAAA,EAAc,CAAA,EAAA,EAAK;AACrC,YAAA,IAAI;AACF,cAAA,IAAA,CAAK,KAAA,CAAM,KAAA,CAAM,CAAC,CAAC,CAAA;AACnB,cAAA,cAAA,EAAA;AAAA,YACF,CAAA,CAAA,MAAQ;AACN,cAAA,OAAO,KAAA;AAAA,YACT;AAAA,UACF;AAEA,UAAA,OAAO,cAAA,IAAkB,CAAA;AAAA,QAC3B,CAAA,CAAA,MAAQ;AACN,UAAA,OAAO,KAAA;AAAA,QACT;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKQ,WAAW,MAAA,EAAyB;AAC1C,QAAA,IAAI;AACF,UAAA,MAAM,IAAA,GAAO,MAAA,CAAO,QAAA,CAAS,OAAA,EAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrE,UAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,IAAI,CAAA,CAAE,MAAA,CAAO,CAAC,IAAA,KAAS,IAAA,CAAK,IAAA,EAAK,CAAE,MAAA,GAAS,CAAC,CAAA;AAEtE,UAAA,IAAI,KAAA,CAAM,MAAA,KAAW,CAAA,EAAG,OAAO,KAAA;AAG/B,UAAA,IAAI,cAAA,GAAiB,CAAA;AACrB,UAAA,IAAI,iBAAA,GAAoB,CAAA;AAExB,UAAA,KAAA,MAAW,IAAA,IAAQ,KAAA,CAAM,KAAA,CAAM,CAAA,EAAG,EAAE,CAAA,EAAG;AACrC,YAAA,MAAM,OAAA,GAAU,KAAK,IAAA,EAAK;AAG1B,YAAA,IAAI,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAA,EAAG;AAG7B,YAAA,IAAI,qBAAA,CAAsB,IAAA,CAAK,OAAO,CAAA,EAAG;AACvC,cAAA,cAAA,EAAA;AACA,cAAA;AAAA,YACF;AAGA,YAAA,IAAI,OAAA,CAAQ,IAAA,CAAK,OAAO,CAAA,EAAG;AACzB,cAAA,cAAA,EAAA;AACA,cAAA;AAAA,YACF;AAGA,YAAA,IAAI,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAA,IAAK,OAAA,CAAQ,UAAA,CAAW,GAAG,CAAA,IAAK,OAAA,CAAQ,QAAA,CAAS,GAAG,CAAA,EAAG;AAC/E,cAAA,iBAAA,EAAA;AAAA,YACF;AAAA,UACF;AAGA,UAAA,OAAO,cAAA,IAAkB,KAAK,iBAAA,KAAsB,CAAA;AAAA,QACtD,CAAA,CAAA,MAAQ;AACN,UAAA,OAAO,KAAA;AAAA,QACT;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKQ,UAAU,MAAA,EAAyB;AACzC,QAAA,IAAI;AACF,UAAA,MAAM,IAAA,GAAO,MAAA,CAAO,QAAA,CAAS,OAAA,EAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,GAAG,CAAC,CAAA;AACrE,UAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,IAAI,CAAA,CAAE,MAAA,CAAO,CAAC,IAAA,KAAS,IAAA,CAAK,IAAA,EAAK,CAAE,MAAA,GAAS,CAAC,CAAA;AAEtE,UAAA,IAAI,KAAA,CAAM,MAAA,GAAS,CAAA,EAAG,OAAO,KAAA;AAG7B,UAAA,MAAM,UAAA,GAAa,CAAC,GAAA,EAAK,GAAA,EAAK,GAAI,CAAA;AAElC,UAAA,KAAA,MAAW,aAAa,UAAA,EAAY;AAClC,YAAA,MAAM,MAAA,GAAS,KAAA,CAAM,GAAA,CAAI,CAAC,IAAA,KAAS;AACjC,cAAA,MAAM,OAAA,GAAU,SAAA,CAAU,OAAA,CAAQ,qBAAA,EAAuB,MAAM,CAAA;AAC/D,cAAA,MAAM,UAAU,IAAA,CAAK,KAAA,CAAM,IAAI,MAAA,CAAO,OAAA,EAAS,GAAG,CAAC,CAAA;AACnD,cAAA,OAAO,OAAA,GAAU,QAAQ,MAAA,GAAS,CAAA;AAAA,YACpC,CAAC,CAAA;AAGD,YAAA,MAAM,UAAA,GAAa,OAAO,CAAC,CAAA;AAC3B,YAAA,IAAI,UAAA,GAAa,KAAK,MAAA,CAAO,KAAA,CAAM,CAAC,KAAA,KAAU,KAAA,KAAU,UAAU,CAAA,EAAG;AACnE,cAAA,OAAO,IAAA;AAAA,YACT;AAAA,UACF;AAEA,UAAA,OAAO,KAAA;AAAA,QACT,CAAA,CAAA,MAAQ;AACN,UAAA,OAAO,KAAA;AAAA,QACT;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKQ,eAAe,MAAA,EAAyB;AAC9C,QAAA,IAAI,MAAA,CAAO,MAAA,GAAS,CAAA,EAAG,OAAO,KAAA;AAM9B,QAAA,MAAM,SAAA,GAAY,OAAO,CAAC,CAAA;AAC1B,QAAA,MAAM,WAAW,SAAA,GAAY,CAAA;AAC7B,QAAA,MAAM,cAAc,SAAA,IAAa,CAAA;AAGjC,QAAA,MAAM,mBAAmB,QAAA,KAAa,CAAA,IAAK,aAAa,CAAA,IAAK,QAAA,KAAa,KAAK,QAAA,KAAa,CAAA;AAG5F,QAAA,MAAM,mBAAA,GAAsB,WAAA,GAAc,CAAA,IAAK,WAAA,GAAc,GAAA;AAG7D,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,MAAM,CAAA;AAG5C,QAAA,OAAO,oBAAoB,mBAAA,IAAuB,QAAA;AAAA,MACpD;AAAA;AAAA;AAAA;AAAA,MAKQ,gBAAgB,MAAA,EAAyB;AAC/C,QAAA,MAAM,MAAA,GAAS,OAAO,QAAA,CAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,GAAG,CAAC,CAAA;AAG9D,QAAA,IAAI,MAAA,CAAO,MAAA,KAAW,CAAA,EAAG,OAAO,KAAA;AAEhC,QAAA,IAAI,WAAA,GAAc,CAAA;AAElB,QAAA,KAAA,MAAW,QAAQ,MAAA,EAAQ;AAEzB,UAAA,IAAI,IAAA,KAAS,KAAS,IAAA,GAAO,EAAA,IAAQ,SAAS,CAAA,IAAQ,IAAA,KAAS,EAAA,IAAQ,IAAA,KAAS,EAAA,EAAO;AACrF,YAAA,WAAA,EAAA;AAAA,UACF;AAAA,QACF;AAGA,QAAA,OAAO,WAAA,GAAc,OAAO,MAAA,GAAS,IAAA;AAAA,MACvC;AAAA;AAAA;AAAA;AAAA,MAKQ,gBAAgB,MAAA,EAAyB;AAC/C,QAAA,MAAM,MAAA,GAAS,OAAO,QAAA,CAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,GAAG,CAAC,CAAA;AAC9D,QAAA,IAAI,WAAA,GAAc,CAAA;AAElB,QAAA,KAAA,MAAW,QAAQ,MAAA,EAAQ;AACzB,UAAA,IAAI,IAAA,KAAS,KAAS,IAAA,GAAO,EAAA,IAAQ,SAAS,CAAA,IAAQ,IAAA,KAAS,EAAA,IAAQ,IAAA,KAAS,EAAA,EAAO;AACrF,YAAA,WAAA,EAAA;AAAA,UACF;AAAA,QACF;AAGA,QAAA,OAAO,WAAA,GAAc,OAAO,MAAA,GAAS,GAAA;AAAA,MACvC;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;ACnRA,SAASH,WAAa,GAAA,EAAW;AAC/B,EAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,IAAA,OAAO,GAAA;AAAA,EACT;AAEA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA,EAAG;AACtB,IAAA,OAAO,IAAI,GAAA,CAAI,CAAC,IAAA,KAASA,UAAAA,CAAU,IAAI,CAAC,CAAA;AAAA,EAC1C;AAEA,EAAA,MAAM,SAAkC,EAAC;AACzC,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAA,CAAO,GAAG,CAAA,GAAIA,UAAAA,CAAW,GAAA,CAAgC,GAAG,CAAC,CAAA;AAAA,IAC/D;AAAA,EACF;AACA,EAAA,OAAO,MAAA;AACT;AAEA,SAASC,YAA6B,GAAA,EAAW;AAC/C,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAEjB,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAM,KAAA,GAAQ,IAAI,GAAG,CAAA;AACrB,MAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,KAAU,QAAA,EAAU;AAC/C,QAAAA,YAAW,KAAK,CAAA;AAAA,MAClB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,GAAA;AACT;AAEA,eAAeC,oBAAAA,GAAqC;AAClD,EAAA,IAAIC,kBAAiB,IAAA,EAAM;AACzB,IAAA;AAAA,EACF;AAEA,EAAAA,aAAAA,GAAe,MAAM,mBAAA,EAAoB;AAEzC,EAAA,KAAA,MAAW,QAAA,IAAYA,cAAa,KAAA,EAAO;AAEzC,IAAA,eAAA,CAAgB,GAAA,CAAI,QAAA,CAAS,IAAA,CAAK,WAAA,IAAe,QAAQ,CAAA;AAGzD,IAAA,KAAA,MAAW,GAAA,IAAO,SAAS,UAAA,EAAY;AACrC,MAAA,MAAM,aAAa,GAAA,CAAI,WAAA,EAAY,CAAE,OAAA,CAAQ,OAAO,EAAE,CAAA;AACtD,MAAA,cAAA,CAAe,GAAA,CAAI,YAAY,QAAQ,CAAA;AAAA,IACzC;AAAA,EACF;AAGA,EAAA,gBAAA,GAAmB,eAAe,eAAe,CAAA;AACnD;AAEA,eAAsB,YAAY,UAAA,EAAwD;AACxF,EAAA,MAAMD,oBAAAA,EAAoB;AAC1B,EAAA,MAAM,UAAA,GAAa,WAAW,WAAA,EAAY;AAC1C,EAAA,MAAM,QAAA,GAAW,eAAA,CAAgB,GAAA,CAAI,UAAU,CAAA;AAC/C,EAAA,OAAO,QAAA,GAAWD,WAAAA,CAAWD,UAAAA,CAAU,QAAQ,CAAC,CAAA,GAAI,IAAA;AACtD;AAEA,eAAsB,uBACpB,SAAA,EACoC;AACpC,EAAA,MAAME,oBAAAA,EAAoB;AAC1B,EAAA,MAAM,aAAa,SAAA,CAAU,WAAA,EAAY,CAAE,OAAA,CAAQ,OAAO,EAAE,CAAA;AAC5D,EAAA,MAAM,QAAA,GAAW,cAAA,CAAe,GAAA,CAAI,UAAU,CAAA;AAC9C,EAAA,OAAO,QAAA,GAAWD,WAAAA,CAAWD,UAAAA,CAAU,QAAQ,CAAC,CAAA,GAAI,IAAA;AACtD;AASA,eAAsB,oBAAoB,IAAA,EAAgC;AACxE,EAAA,MAAME,oBAAAA,EAAoB;AAC1B,EAAA,OAAO,eAAA,CAAgB,GAAA,CAAI,IAAA,CAAK,WAAA,EAAa,CAAA;AAC/C;AAeA,eAAsB,cAAA,CACpB,OACA,OAAA,EACoC;AACpC,EAAA,MAAMA,oBAAAA,EAAoB;AAE1B,EAAA,IAAI,CAAC,gBAAA,EAAkB;AACrB,IAAA,MAAM,IAAI,MAAM,0BAA0B,CAAA;AAAA,EAC5C;AAGA,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAC7B,IAAA,OAAO,sBAAA,CAAuB,OAAO,OAAO,CAAA;AAAA,EAC9C;AAEA,EAAA,IAAI,MAAA,CAAO,QAAA,CAAS,KAAK,CAAA,EAAG;AAC1B,IAAA,OAAO,wBAAA,CAAyB,OAAO,OAAO,CAAA;AAAA,EAChD;AAEA,EAAA,OAAO,wBAAA,CAAyB,OAAO,OAAO,CAAA;AAChD;AAKA,eAAsB,sBAAA,CACpB,QAAA,EACA,OAAA,GAA4B,EAAC,EACO;AACpC,EAAA,MAAMA,oBAAAA,EAAoB;AAE1B,EAAA,IAAI,CAAC,gBAAA,EAAkB;AACrB,IAAA,MAAM,IAAI,MAAM,0BAA0B,CAAA;AAAA,EAC5C;AAEA,EAAA,MAAM,WAAA,GAAc,QAAQ,WAAA,IAAe,GAAA;AAG3C,EAAA,IAAI,OAAO,QAAQ,WAAA,EAAa;AAC9B,IAAA,MAAM,IAAA,GAAO,GAAA,CAAI,IAAA,CAAK,QAAQ,CAAA;AAC9B,IAAA,IAAI,CAAE,MAAM,IAAA,CAAK,MAAA,EAAO,EAAI;AAC1B,MAAA,OAAO,IAAA;AAAA,IACT;AACA,IAAA,MAAM,KAAA,GAAQ,IAAA,CAAK,KAAA,CAAM,CAAA,EAAG,WAAW,CAAA;AACvC,IAAA,MAAM,WAAA,GAAc,MAAM,KAAA,CAAM,WAAA,EAAY;AAC5C,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,IAAA,CAAK,WAAW,CAAA;AACtC,IAAA,OAAO,wBAAA,CAAyB,QAAQ,OAAO,CAAA;AAAA,EACjD;AAGA,EAAA,IAAI;AACF,IAAA,MAAM,SAAS,MAAMV,QAAAA,CAAS,UAAU,EAAE,QAAA,EAAU,MAAM,CAAA;AAC1D,IAAA,MAAM,MAAA,GAAS,OAAO,QAAA,CAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,WAAW,CAAC,CAAA;AACtE,IAAA,OAAO,wBAAA,CAAyB,QAAQ,OAAO,CAAA;AAAA,EACjD,SAAS,KAAA,EAAO;AACd,IAAA,IAAK,KAAA,CAAgC,SAAS,QAAA,EAAU;AACtD,MAAA,OAAO,IAAA;AAAA,IACT;AACA,IAAA,MAAM,KAAA;AAAA,EACR;AACF;AAKO,SAAS,wBAAA,CACd,MAAA,EACA,OAAA,GAA4B,EAAC,EACF;AAC3B,EAAA,IAAI,CAAC,gBAAA,EAAkB;AACrB,IAAA,MAAM,IAAI,MAAM,0BAA0B,CAAA;AAAA,EAC5C;AAEA,EAAA,MAAM,MAAA,GAAS,gBAAA,CAAiB,MAAA,CAAO,MAAA,EAAQ,OAAO,CAAA;AACtD,EAAA,OAAO,MAAA,GAASS,WAAAA,CAAWD,UAAAA,CAAU,MAAM,CAAC,CAAA,GAAI,IAAA;AAClD;AAKA,eAAsB,wBAAA,CACpB,MAAA,EACA,OAAA,GAA4B,EAAC,EACO;AACpC,EAAA,MAAME,oBAAAA,EAAoB;AAE1B,EAAA,MAAM,WAAA,GAAc,QAAQ,WAAA,IAAe,GAAA;AAC3C,EAAA,MAAM,SAAuB,EAAC;AAC9B,EAAA,IAAI,UAAA,GAAa,CAAA;AAGjB,EAAA,MAAM,SAAA,GACJ,OAAQ,MAAA,CAA0B,SAAA,KAAc,aAC3C,MAAA,GACD,QAAA,CAAS,MAAM,MAAkB,CAAA;AAEvC,EAAA,MAAM,MAAA,GAAS,UAAU,SAAA,EAAU;AAEnC,EAAA,IAAI;AACF,IAAA,OAAO,aAAa,WAAA,EAAa;AAC/B,MAAA,MAAM,EAAE,KAAA,EAAO,IAAA,EAAK,GAAI,MAAM,OAAO,IAAA,EAAK;AAC1C,MAAA,IAAI,IAAA,EAAM;AAEV,MAAA,MAAA,CAAO,KAAK,KAAK,CAAA;AACjB,MAAA,UAAA,IAAc,KAAA,CAAM,MAAA;AAAA,IACtB;AAEA,IAAA,MAAM,MAAA,GAAS,MAAA,CAAO,MAAA,CAAO,MAAA,CAAO,GAAA,CAAI,CAAC,CAAA,KAAM,MAAA,CAAO,IAAA,CAAK,CAAC,CAAC,CAAC,CAAA;AAC9D,IAAA,MAAM,MAAA,GAAS,OAAO,QAAA,CAAS,CAAA,EAAG,KAAK,GAAA,CAAI,MAAA,CAAO,MAAA,EAAQ,WAAW,CAAC,CAAA;AAEtE,IAAA,OAAO,wBAAA,CAAyB,QAAQ,OAAO,CAAA;AAAA,EACjD,CAAA,SAAE;AACA,IAAA,MAAA,CAAO,WAAA,EAAY;AAAA,EACrB;AACF;AAKO,SAAS,gBAAA,CAAiB,QAAgB,QAAA,EAA2B;AAC1E,EAAA,IAAI,CAAC,gBAAA,EAAkB;AACrB,IAAA,MAAM,IAAI,MAAM,0BAA0B,CAAA;AAAA,EAC5C;AAEA,EAAA,MAAM,MAAA,GAAS,gBAAA,CAAiB,MAAA,CAAO,MAAM,CAAA;AAC7C,EAAA,OAAO,QAAQ,IAAA,KAAS,QAAA;AAC1B;AAEA,eAAsB,aAAA,GAA4D;AAChF,EAAA,MAAMA,oBAAAA,EAAoB;AAC1B,EAAA,OAAO,KAAA,CAAM,IAAA,CAAK,eAAA,CAAgB,MAAA,EAAQ,CAAA,CAAE,GAAA,CAAI,CAAC,CAAA,KAAMD,WAAAA,CAAWD,UAAAA,CAAU,CAAC,CAAC,CAAC,CAAA;AACjF;AAEO,SAAS,kBAAA,GAA2B;AACzC,EAAAG,aAAAA,GAAe,IAAA;AACf,EAAA,eAAA,CAAgB,KAAA,EAAM;AACtB,EAAA,cAAA,CAAe,KAAA,EAAM;AACrB,EAAA,gBAAA,GAAmB,IAAA;AACrB;AA5PA,IAaIA,aAAAA,EACE,iBACA,cAAA,EACF,gBAAA;AAhBJ,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,2BAAA,GAAA;AASA,IAAA,aAAA,EAAA;AACA,IAAA,WAAA,EAAA;AAGA,IAAIA,aAAAA,GAAuC,IAAA;AAC3C,IAAM,eAAA,uBAAsB,GAAA,EAAsB;AAClD,IAAM,cAAA,uBAAqB,GAAA,EAAsB;AACjD,IAAI,gBAAA,GAA6D,IAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACFjE,SAASH,WAAa,GAAA,EAAW;AAC/B,EAAA,IAAI,GAAA,KAAQ,IAAA,IAAQ,OAAO,GAAA,KAAQ,QAAA,EAAU;AAC3C,IAAA,OAAO,GAAA;AAAA,EACT;AAEA,EAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,GAAG,CAAA,EAAG;AACtB,IAAA,OAAO,IAAI,GAAA,CAAI,CAAC,IAAA,KAASA,UAAAA,CAAU,IAAI,CAAC,CAAA;AAAA,EAC1C;AAEA,EAAA,MAAM,SAAkC,EAAC;AACzC,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAA,CAAO,GAAG,CAAA,GAAIA,UAAAA,CAAW,GAAA,CAAgC,GAAG,CAAC,CAAA;AAAA,IAC/D;AAAA,EACF;AACA,EAAA,OAAO,MAAA;AACT;AAEA,SAASC,YAA6B,GAAA,EAAW;AAC/C,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAEjB,EAAA,KAAA,MAAW,OAAO,GAAA,EAAK;AACrB,IAAA,IAAI,MAAA,CAAO,MAAA,CAAO,GAAA,EAAK,GAAG,CAAA,EAAG;AAC3B,MAAA,MAAM,KAAA,GAAQ,IAAI,GAAG,CAAA;AACrB,MAAA,IAAI,KAAA,KAAU,IAAA,IAAQ,OAAO,KAAA,KAAU,QAAA,EAAU;AAC/C,QAAAA,YAAW,KAAK,CAAA;AAAA,MAClB;AAAA,IACF;AAAA,EACF;AAEA,EAAA,OAAO,GAAA;AACT;AAEA,eAAeC,oBAAAA,GAAqC;AAClD,EAAA,IAAIC,kBAAiB,IAAA,EAAM;AACzB,IAAA;AAAA,EACF;AAEA,EAAAA,aAAAA,GAAe,MAAM,kBAAA,EAAmB;AAExC,EAAA,KAAA,MAAW,OAAA,IAAWA,cAAa,QAAA,EAAU;AAC3C,IAAA,YAAA,CAAa,GAAA,CAAI,OAAA,CAAQ,EAAA,EAAI,OAAO,CAAA;AAAA,EACtC;AACF;AAEA,eAAsB,WAAW,EAAA,EAA+C;AAC9E,EAAA,MAAMD,oBAAAA,EAAoB;AAC1B,EAAA,MAAM,OAAA,GAAU,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA;AACnC,EAAA,OAAO,OAAA,GAAUD,WAAAA,CAAWD,UAAAA,CAAU,OAAO,CAAC,CAAA,GAAI,IAAA;AACpD;AAEA,eAAsB,gBAAgB,EAAA,EAAoC;AACxE,EAAA,MAAME,oBAAAA,EAAoB;AAC1B,EAAA,MAAM,OAAA,GAAU,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA;AAEnC,EAAA,IAAI,CAAC,OAAA,EAAS;AACZ,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,IAAI,OAAA,CAAQ,SAAS,OAAA,EAAS;AAC5B,IAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,MACxB,UAAA;AAAA,MACA,CAAA,SAAA,EAAY,EAAE,CAAA,gCAAA,EAAmC,OAAA,CAAQ,IAAI,CAAA,CAAA;AAAA,KAC/D;AAAA,EACF;AAEA,EAAA,MAAM,MAAA,GAAS,kBAAA,CAAmB,GAAA,CAAI,EAAE,CAAA;AACxC,EAAA,IAAI,WAAW,MAAA,EAAW;AACxB,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,IAAI,KAAA,GAAQ,EAAA;AACZ,EAAA,IAAI,OAAA,CAAQ,KAAA,EAAO,UAAA,EAAY,UAAA,EAAY;AACzC,IAAA,KAAA,IAAS,GAAA;AAAA,EACX;AAEA,EAAA,MAAM,yBAAA,GAA4B,OAAA,CAAQ,IAAA,CAAK,OAAA,CAAQ,OAAO,CAAA;AAC9D,EAAA,IAAI,OAAA,CAAQ,KAAA,EAAO,UAAA,EAAY,OAAA,IAAW,yBAAA,EAA2B;AACnE,IAAA,KAAA,IAAS,GAAA;AAAA,EACX;AAEA,EAAA,MAAM,KAAA,GAAQ,IAAI,MAAA,CAAO,OAAA,CAAQ,SAAS,KAAK,CAAA;AAC/C,EAAA,kBAAA,CAAmB,GAAA,CAAI,IAAI,KAAK,CAAA;AAChC,EAAA,OAAO,KAAA;AACT;AAEA,SAAS,eAAA,CAAgB,IAAY,OAAA,EAA+C;AAClF,EAAA,MAAM,MAAA,GAAS,iBAAA,CAAkB,GAAA,CAAI,EAAE,CAAA;AACvC,EAAA,IAAI,WAAW,MAAA,EAAW;AACxB,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,MAAM,OAAA,GAAU,UAAU,OAAO,CAAA;AACjC,EAAA,iBAAA,CAAkB,GAAA,CAAI,IAAI,OAAO,CAAA;AACjC,EAAA,OAAO,OAAA;AACT;AAEA,eAAsB,YAAA,CAAa,IAAY,KAAA,EAAiC;AAC9E,EAAA,MAAMA,oBAAAA,EAAoB;AAC1B,EAAA,MAAM,OAAA,GAAU,YAAA,CAAa,GAAA,CAAI,EAAE,CAAA;AAEnC,EAAA,IAAI,CAAC,OAAA,EAAS;AACZ,IAAA,MAAM,mBAAA,CAAoB,cAAA,CAAe,CAAA,SAAA,EAAY,EAAE,CAAA,WAAA,CAAa,CAAA;AAAA,EACtE;AAEA,EAAA,IAAI,OAAA,CAAQ,SAAS,OAAA,EAAS;AAC5B,IAAA,MAAM,KAAA,GAAQ,MAAM,eAAA,CAAgB,EAAE,CAAA;AACtC,IAAA,OAAO,KAAA,GAAQ,KAAA,CAAM,IAAA,CAAK,KAAK,CAAA,GAAI,KAAA;AAAA,EACrC;AAEA,EAAA,IAAI,OAAA,CAAQ,SAAS,MAAA,EAAQ;AAC3B,IAAA,MAAM,OAAA,GAAU,eAAA,CAAgB,EAAA,EAAI,OAAA,CAAQ,OAAO,CAAA;AACnD,IAAA,OAAO,QAAQ,KAAK,CAAA;AAAA,EACtB;AAEA,EAAA,IAAI,OAAA,CAAQ,SAAS,SAAA,EAAW;AAC9B,IAAA,OAAO,QAAQ,OAAA,KAAY,KAAA;AAAA,EAC7B;AAEA,EAAA,MAAM,oBAAoB,aAAA,CAAc,UAAA,EAAY,CAAA,sBAAA,EAAyB,OAAA,CAAQ,IAAI,CAAA,CAAE,CAAA;AAC7F;AAEA,eAAsB,YAAA,GAA0D;AAC9E,EAAA,MAAMA,oBAAAA,EAAoB;AAC1B,EAAA,OAAO,KAAA,CAAM,IAAA,CAAK,YAAA,CAAa,MAAA,EAAQ,CAAA,CAAE,GAAA,CAAI,CAAC,CAAA,KAAMD,WAAAA,CAAWD,UAAAA,CAAU,CAAC,CAAC,CAAC,CAAA;AAC9E;AAEA,eAAsB,gBAAgB,EAAA,EAAoC;AACxE,EAAA,MAAM,OAAA,GAAU,MAAM,UAAA,CAAW,EAAE,CAAA;AACnC,EAAA,OAAO,SAAS,WAAA,IAAe,IAAA;AACjC;AAEO,SAAS,iBAAA,GAA0B;AACxC,EAAAG,aAAAA,GAAe,IAAA;AACf,EAAA,YAAA,CAAa,KAAA,EAAM;AACnB,EAAA,kBAAA,CAAmB,KAAA,EAAM;AACzB,EAAA,iBAAA,CAAkB,KAAA,EAAM;AAC1B;AAvJA,IASIA,aAAAA,EACE,cACA,kBAAA,EACA,iBAAA;AAZN,IAAA,aAAA,GAAA,KAAA,CAAA;AAAA,EAAA,yBAAA,GAAA;AAKA,IAAAL,YAAAA,EAAAA;AACA,IAAA,WAAA,EAAA;AAGA,IAAIK,aAAAA,GAAsC,IAAA;AAC1C,IAAM,YAAA,uBAAmB,GAAA,EAAqB;AAC9C,IAAM,kBAAA,uBAAyB,GAAA,EAAoB;AACnD,IAAM,iBAAA,uBAAwB,GAAA,EAA0C;AAAA,EAAA;AAAA,CAAA,CAAA;ACmBxE,eAAeC,YAAAA,GAAsC;AACnD,EAAA,MAAM,WAAWC,WAAAA,CAAW,OAAA;AAC5B,EAAA,MAAM,WAAA,GAAc,SAAA;AAEpB,EAAA,IAAI;AACF,IAAA,IAAI,OAAA;AAGJ,IAAA,IAAI,OAAO,QAAQ,WAAA,EAAa;AAC9B,MAAA,IAAI;AACF,QAAA,MAAM,IAAA,GAAO,GAAA,CAAI,IAAA,CAAK,QAAQ,CAAA;AAC9B,QAAA,IAAI,CAAE,MAAM,IAAA,CAAK,MAAA,EAAO,EAAI;AAC1B,UAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,OAAA,GAAU,MAAM,KAAK,IAAA,EAAK;AAAA,MAC5B,SAAS,KAAA,EAAO;AAEd,QAAA,IAAI,iBAAiB,KAAA,IAAS,KAAA,CAAM,OAAA,CAAQ,QAAA,CAAS,cAAc,CAAA,EAAG;AACpE,UAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,MAAM,KAAA;AAAA,MACR;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,IAAI;AACF,QAAA,OAAA,GAAU,MAAMb,QAAAA,CAAS,QAAA,EAAU,OAAO,CAAA;AAAA,MAC5C,SAAS,KAAA,EAAO;AACd,QAAA,IAAK,KAAA,CAAgC,SAAS,QAAA,EAAU;AACtD,UAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,QACtD;AACA,QAAA,MAAM,KAAA;AAAA,MACR;AAAA,IACF;AAGA,IAAA,MAAM,IAAA,GAAOR,MAAU,OAAO,CAAA;AAG9B,IAAA,MAAM,MAAA,GAAS,MAAM,sBAAA,CAAuB,IAAA,EAAM,SAAS,CAAA;AAC3D,IAAA,IAAI,CAAC,OAAO,KAAA,EAAO;AACjB,MAAA,MAAM,aAAA,GAAgB,MAAA,CAAO,WAAA,CAAY,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,EAAG,CAAA,CAAE,OAAO,KAAK,CAAA,CAAE,OAAO,CAAA,CAAE,CAAA,CAAE,KAAK,IAAI,CAAA;AAC3F,MAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,QACxB,WAAA;AAAA,QACA,6BAA6B,aAAa,CAAA;AAAA,OAC5C;AAAA,IACF;AAEA,IAAA,OAAO,IAAA;AAAA,EACT,SAAS,KAAA,EAAO;AACd,IAAA,IAAI,iBAAiB,mBAAA,EAAqB;AACxC,MAAA,MAAM,KAAA;AAAA,IACR;AAGA,IAAA,MAAM,GAAA,GAAM,KAAA;AACZ,IAAA,IAAI,GAAA,CAAI,SAAS,QAAA,EAAU;AACzB,MAAA,MAAM,mBAAA,CAAoB,eAAe,WAAW,CAAA;AAAA,IACtD,CAAA,MAAA,IAAW,GAAA,CAAI,IAAA,KAAS,QAAA,EAAU;AAChC,MAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,QACxB,WAAA;AAAA,QACA,0CAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,CAAA,MAAA,IAAW,GAAA,CAAI,IAAA,KAAS,QAAA,EAAU;AAChC,MAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,QACxB,WAAA;AAAA,QACA,mCAAA;AAAA,QACA;AAAA,OACF;AAAA,IACF,WAAW,GAAA,CAAI,IAAA,KAAS,QAAA,IAAY,GAAA,CAAI,SAAS,QAAA,EAAU;AACzD,MAAA,MAAM,mBAAA,CAAoB,aAAA,CAAc,WAAA,EAAa,qBAAA,EAAuB,GAAG,CAAA;AAAA,IACjF;AAEA,IAAA,MAAM,mBAAA,CAAoB,aAAA,CAAc,WAAA,EAAa,wBAAA,EAA0B,GAAG,CAAA;AAAA,EACpF;AACF;AAQA,eAAe,UAAA,GAAqC;AAClD,EAAA,IAAI,CAAC,aAAA,EAAe;AAClB,IAAA,aAAA,GAAgB,MAAMoB,YAAAA,EAAY;AAAA,EACpC;AACA,EAAA,OAAO,aAAA;AACT;AAKA,eAAsB,iBAAA,GAAqC;AACzD,EAAA,MAAM,OAAA,GAAU,MAAM,UAAA,EAAW;AACjC,EAAA,OAAO,OAAA,CAAQ,OAAA;AACjB;AAKA,eAAsB,WAAA,GAAqC;AACzD,EAAA,MAAM,OAAA,GAAU,MAAM,UAAA,EAAW;AACjC,EAAA,OAAO,OAAA,CAAQ,QAAQ,GAAA,CAAI,CAAC,YAAY,EAAE,GAAG,QAAO,CAAE,CAAA;AACxD;AAKA,eAAsB,UAAU,UAAA,EAAgD;AAC9E,EAAA,MAAM,OAAA,GAAU,MAAM,UAAA,EAAW;AACjC,EAAA,MAAM,MAAA,GAAS,OAAA,CAAQ,OAAA,CAAQ,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,EAAA,KAAO,UAAA,IAAc,CAAA,CAAE,IAAA,KAAS,UAAU,CAAA;AACvF,EAAA,OAAO,MAAA,GAAS,EAAE,GAAG,MAAA,EAAO,GAAI,IAAA;AAClC;AAKA,eAAsB,aAAA,GAAyC;AAC7D,EAAA,MAAM,OAAA,GAAU,MAAM,UAAA,EAAW;AACjC,EAAA,OAAO,OAAA,CAAQ,UAAU,GAAA,CAAI,CAAC,cAAc,EAAE,GAAG,UAAS,CAAE,CAAA;AAC9D;AAKA,eAAsB,YAAY,EAAA,EAA0C;AAC1E,EAAA,MAAM,OAAA,GAAU,MAAM,UAAA,EAAW;AACjC,EAAA,MAAM,QAAA,GAAW,QAAQ,SAAA,CAAU,IAAA,CAAK,CAAC,CAAA,KAAM,CAAA,CAAE,OAAO,EAAE,CAAA;AAC1D,EAAA,OAAO,QAAA,GAAW,EAAE,GAAG,QAAA,EAAS,GAAI,IAAA;AACtC;AAKA,eAAsB,gBAAA,GAA2C;AAC/D,EAAA,OAAO,MAAM,UAAA,EAAW;AAC1B;AAxKA,IAgBMf,WAAAA,EACAC,UAAAA,EAGAe,WAAAA,EAKA,SAAA,EAoFF,aAAA;AA7GJ,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,gCAAA,GAAA;AAWA,IAAA,cAAA,EAAA;AACA,IAAAP,YAAAA,EAAAA;AAIA,IAAMT,WAAAA,GAAaK,aAAAA,CAAc,MAAA,CAAA,IAAA,CAAY,GAAG,CAAA;AAChD,IAAMJ,UAAAA,GAAYK,QAAQN,WAAU,CAAA;AAGpC,IAAMgB,WAAAA,GAAa;AAAA,MACjB,OAAA,EAASd,IAAAA,CAAKD,UAAAA,EAAW,0DAA0D;AAAA,KACrF;AAGA,IAAM,SAAA,GAAY,gCAAA;AAoFlB,IAAI,aAAA,GAAsC,IAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC7EnC,SAASgB,YAAAA,GAAwB;AACtC,EAAA,MAAM,WAAW,OAAA,CAAQ,QAAA;AAEzB,EAAA,QAAQ,QAAA;AAAU,IAChB,KAAK,OAAA;AACH,MAAA,OAAO,OAAA;AAAA,IACT,KAAK,QAAA;AACH,MAAA,OAAO,QAAA;AAAA,IACT,KAAK,OAAA;AACH,MAAA,OAAO,OAAA;AAAA,IACT,KAAK,SAAA;AACH,MAAA,OAAO,SAAA;AAAA,IACT;AACE,MAAA,OAAO,SAAA;AAAA;AAEb;AAKO,SAASC,QAAAA,GAAmB;AACjC,EAAA,MAAM,WAAWD,YAAAA,EAAY;AAC7B,EAAA,OAAO,QAAA,KAAa,OAAA,IAAW,QAAA,KAAa,QAAA,IAAY,QAAA,KAAa,SAAA;AACvE;AAKO,SAASE,UAAAA,GAAqB;AACnC,EAAA,OAAOF,cAAY,KAAM,OAAA;AAC3B;AAYA,eAAsB,eAAe,UAAA,EAAsC;AACzE,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,IAAIC,UAAQ,EAAG;AACb,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,IAAIC,YAAU,EAAG;AAEf,IAAA,OAAO,OAAO,aAAA,KAAkB,IAAA;AAAA,EAClC;AAGA,EAAA,OAAO,KAAA;AACT;AASO,SAASC,wBAAAA,GAAmC;AAEjD,EAAA,OAAOF,QAAAA,EAAQ;AACjB;AAQA,eAAsBG,wBAAAA,GAAyD;AAC7E,EAAA,MAAM,WAAWJ,YAAAA,EAAY;AAC7B,EAAA,MAAM,UAAUC,QAAAA,EAAQ;AACxB,EAAA,MAAM,QAAQC,UAAAA,EAAU;AACxB,EAAA,MAAM,OAAA,GAAU,MAAM,gBAAA,EAAiB;AAEvC,EAAA,MAAM,YAAsB,EAAC;AAC7B,EAAA,MAAM,cAAwB,EAAC;AAC/B,EAAA,MAAM,SAAmB,EAAC;AAG1B,EAAA,KAAA,MAAW,MAAA,IAAU,QAAQ,OAAA,EAAS;AACpC,IAAA,IAAI,OAAA,EAAS;AAEX,MAAA,SAAA,CAAU,IAAA,CAAK,OAAO,IAAI,CAAA;AAAA,IAC5B,WAAW,KAAA,EAAO;AAChB,MAAA,IAAI,MAAA,CAAO,kBAAkB,IAAA,EAAM;AAEjC,QAAA,SAAA,CAAU,IAAA,CAAK,OAAO,IAAI,CAAA;AAC1B,QAAA,MAAA,CAAO,IAAA,CAAK,OAAO,IAAI,CAAA;AAAA,MACzB,CAAA,MAAO;AAEL,QAAA,WAAA,CAAY,IAAA,CAAK,OAAO,IAAI,CAAA;AAAA,MAC9B;AAAA,IACF,CAAA,MAAO;AAEL,MAAA,WAAA,CAAY,IAAA,CAAK,OAAO,IAAI,CAAA;AAAA,IAC9B;AAAA,EACF;AAEA,EAAA,OAAO;AAAA,IACL,QAAA;AAAA,IACA,OAAA,EAAS,OAAA;AAAA,IACT,SAAA,EAAW,KAAA;AAAA,IACX,qBAAA,EAAuB,OAAA;AAAA,IACvB,yBAAyBC,wBAAAA,EAAwB;AAAA,IACjD,gBAAA,EAAkB,SAAA;AAAA,IAClB,kBAAA,EAAoB,WAAA;AAAA,IACpB,aAAA,EAAe;AAAA,GACjB;AACF;AAWA,eAAsB,gBAAgB,UAAA,EAA4C;AAChF,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,MAAM,WAAWH,YAAAA,EAAY;AAG7B,EAAA,IAAI,OAAO,kBAAA,EAAoB;AAC7B,IAAA,IAAI,QAAA,KAAa,QAAA,IAAY,MAAA,CAAO,kBAAA,CAAmB,WAAW,MAAA,EAAW;AAC3E,MAAA,OAAO,OAAO,kBAAA,CAAmB,MAAA;AAAA,IACnC;AACA,IAAA,IAAI,QAAA,KAAa,SAAA,IAAa,MAAA,CAAO,kBAAA,CAAmB,YAAY,MAAA,EAAW;AAC7E,MAAA,OAAO,OAAO,kBAAA,CAAmB,OAAA;AAAA,IACnC;AAAA,EACF;AAGA,EAAA,OAAO,MAAA,CAAO,WAAA;AAChB;AAUA,eAAsB,gBAAgB,UAAA,EAA4C;AAChF,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,OAAO,IAAA;AAAA,EACT;AAEA,EAAA,OAAO,MAAA,CAAO,aAAA;AAChB;AAzMA,IAAAK,kBAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,qCAAA,GAAA;AAQA,IAAA,YAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACkBA,eAAsB,UAAA,CACpB,OAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,SAAA,EAAW,OAAA,EAAS,OAAO,CAAA;AAClD,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,QAAA,EAAU,OAAA,EAAS,OAAO,CAAA;AACnD;AAqBA,eAAsB,QAAA,CACpB,OAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,QAAA,EAAU,OAAA,EAAS,OAAO,CAAA;AACnD;AAmBA,eAAsB,MAAA,CACpB,OAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,SAAA,EAAW,OAAA,EAAS,OAAO,CAAA;AACpD;AAmBA,eAAsB,MAAA,CACpB,OAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,SAAA,EAAW,OAAA,EAAS,OAAO,CAAA;AACpD;AAmBA,eAAsB,eAAA,CACpB,OAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,SAAA,EAAW,OAAA,EAAS,OAAO,CAAA;AACpD;AAYA,eAAsB,aAAA,CACpB,OAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,SAAA,EAAW,OAAA,EAAS,OAAO,CAAA;AAClD,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,QAAA,EAAU,OAAA,EAAS,OAAO,CAAA;AACjD,EAAA,MAAM,OAAA,CAAQ,QAAA,CAAS,SAAA,EAAW,OAAA,EAAS,OAAO,CAAA;AACpD;AA3JA,IAAA,gBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,oCAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC0DA,eAAsB,sBAAA,CACpB,UAAA,EACA,MAAA,GAA0B,EAAC,EACF;AACzB,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AAGzC,EAAA,MAAM,eAAA,GAAkB,MAAA,EAAQ,yBAAA,GAC5B,MAAA,CAAO,4BAA4B,GAAA,GACnC,GAAA;AACJ,EAAA,MAAM,eAAA,GAAkB,QAAQ,oBAAA,IAAwB,GAAA;AACxD,EAAA,MAAM,kBAAA,GACJ,QAAQ,kBAAA,IAAsB,4CAAA;AAEhC,EAAA,OAAO;AAAA,IACL,YAAA,EAAc,IAAA;AAAA,IACd,QAAA,EAAU,OAAO,QAAA,IAAY,eAAA;AAAA,IAC7B,QAAA,EAAU,OAAO,QAAA,IAAY,eAAA;AAAA,IAC7B,WAAA,EAAa,OAAO,WAAA,IAAe,kBAAA;AAAA,IACnC,QAAQ,MAAA,CAAO,MAAA;AAAA,IACf,QAAA,EAAU,OAAO,QAAA,IAAY;AAAA,GAC/B;AACF;AAWO,SAAS,gBAAgB,KAAA,EAAgC;AAC9D,EAAA,MAAM,GAAA,GAAM,KAAK,GAAA,EAAI;AAGrB,EAAA,IAAI,KAAA,CAAM,iBAAiB,IAAA,EAAM;AAC/B,IAAA,KAAA,CAAM,YAAA,GAAe,GAAA;AACrB,IAAA,IAAI,MAAM,MAAA,EAAQ;AAChB,MAAA,KAAA,CAAM,MAAA,CAAO,IAAA,CAAK,KAAA,CAAM,WAAW,CAAA;AAAA,IACrC,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,GAAA,CAAI,MAAM,WAAW,CAAA;AAAA,IAC/B;AACA,IAAA,OAAO,KAAA;AAAA,EACT;AAGA,EAAA,MAAM,OAAA,GAAU,MAAM,KAAA,CAAM,YAAA;AAC5B,EAAA,IAAI,OAAA,GAAU,MAAM,QAAA,EAAU;AAE5B,IAAA,IAAI,MAAM,MAAA,EAAQ;AAChB,MAAA,KAAA,CAAM,MAAA,CAAO,KAAK,mBAAmB,CAAA;AAAA,IACvC,CAAA,MAAO;AACL,MAAA,OAAA,CAAQ,IAAI,mBAAmB,CAAA;AAAA,IACjC;AAEA,IAAA,IAAI,CAAC,MAAM,QAAA,EAAU;AACnB,MAAA,OAAA,CAAQ,IAAA,CAAK,MAAM,QAAQ,CAAA;AAAA,IAC7B;AAEA,IAAA,OAAO,IAAA;AAAA,EACT;AAGA,EAAA,KAAA,CAAM,YAAA,GAAe,GAAA;AACrB,EAAA,IAAI,MAAM,MAAA,EAAQ;AAChB,IAAA,KAAA,CAAM,MAAA,CAAO,IAAA,CAAK,KAAA,CAAM,WAAW,CAAA;AAAA,EACrC,CAAA,MAAO;AACL,IAAA,OAAA,CAAQ,GAAA,CAAI,MAAM,WAAW,CAAA;AAAA,EAC/B;AACA,EAAA,OAAO,KAAA;AACT;AAOO,SAAS,eAAe,KAAA,EAA6B;AAC1D,EAAA,KAAA,CAAM,YAAA,GAAe,IAAA;AACvB;AAOO,SAAS,eAAe,KAAA,EAAgC;AAC7D,EAAA,IAAI,KAAA,CAAM,iBAAiB,IAAA,EAAM;AAC/B,IAAA,OAAO,KAAA;AAAA,EACT;AACA,EAAA,MAAM,OAAA,GAAU,IAAA,CAAK,GAAA,EAAI,GAAI,KAAA,CAAM,YAAA;AACnC,EAAA,OAAO,UAAU,KAAA,CAAM,QAAA;AACzB;AAOO,SAAS,uBAAuB,KAAA,EAAsC;AAC3E,EAAA,IAAI,KAAA,CAAM,iBAAiB,IAAA,EAAM;AAC/B,IAAA,OAAO,IAAA;AAAA,EACT;AACA,EAAA,MAAM,OAAA,GAAU,IAAA,CAAK,GAAA,EAAI,GAAI,KAAA,CAAM,YAAA;AACnC,EAAA,MAAM,SAAA,GAAY,MAAM,QAAA,GAAW,OAAA;AACnC,EAAA,OAAO,SAAA,GAAY,IAAI,SAAA,GAAY,IAAA;AACrC;AAtKA,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,mCAAA,GAAA;AAOA,IAAA,YAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC4EA,eAAsB,qBAAA,CACpB,UAAA,EACA,OAAA,GAAkC,EAAC,EACH;AAChC,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AAGzC,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,OAAO;AAAA,MACL,SAAA,EAAW,KAAA;AAAA,MACX,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AAGA,EAAA,IAAI,MAAA,CAAO,kBAAkB,IAAA,EAAM;AACjC,IAAA,OAAO;AAAA,MACL,SAAA,EAAW,IAAA;AAAA,MACX,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AAGA,EAAA,MAAM,WAAW,MAAA,CAAO,gBAAA;AACxB,EAAA,IAAI,CAAC,QAAA,EAAU;AAEb,IAAA,OAAO;AAAA,MACL,SAAA,EAAW,KAAA;AAAA,MACX,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AAGA,EAAA,IAAI,QAAQ,MAAA,EAAQ;AAClB,IAAA,OAAO;AAAA,MACL,SAAA,EAAW,KAAA;AAAA,MACX,QAAA;AAAA,MACA,MAAA,EAAQ;AAAA,KACV;AAAA,EACF;AAEA,EAAA,MAAM,MAAA,GAAS,QAAQ,MAAA,IAAU,aAAA;AACjC,EAAA,MAAM,YAAY,OAAA,CAAQ,SAAA;AAI1B,EAAA,MAAM,OAAA,GAAU;AAAA,IACd,QAAQ,MAAA,CAAO,IAAA;AAAA,IACf,QAAA,EAAU,SAAA;AAAA,IACV,UAAU,QAAA,CAAS,iBAAA;AAAA,IACnB,gBAAgB,QAAA,CAAS;AAAA,GAC3B;AAGA,EAAA,MAAA,CAAO,IAAA,CAAK,QAAA,CAAS,WAAA,EAAa,OAAO,CAAA;AAGzC,EAAA,IAAI,SAAA,EAAW;AACb,IAAA,SAAA,CAAU,IAAA,CAAK,QAAA,CAAS,eAAA,EAAiB,QAAA,CAAS,cAAc,CAAA;AAAA,EAClE;AAEA,EAAA,OAAO;AAAA,IACL,SAAA,EAAW,KAAA;AAAA,IACX,QAAA;AAAA,IACA,MAAA,EAAQ;AAAA,GACV;AACF;AASA,eAAsB,oBAAoB,UAAA,EAAqD;AAC7F,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,EAAA,IAAI,CAAC,MAAA,IAAU,CAAC,MAAA,CAAO,gBAAA,EAAkB;AACvC,IAAA,OAAO,IAAA;AAAA,EACT;AACA,EAAA,OAAO,MAAA,CAAO,gBAAA;AAChB;AAUA,eAAsB,iBAAiB,UAAA,EAAsC;AAC3E,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,OAAO,KAAA;AAAA,EACT;AACA,EAAA,OAAO,MAAA,CAAO,aAAA,KAAkB,IAAA,IAAQ,MAAA,CAAO,gBAAA,KAAqB,MAAA;AACtE;AAUA,eAAsB,wBAAwB,UAAA,EAA4C;AACxF,EAAA,MAAM,QAAA,GAAW,MAAM,mBAAA,CAAoB,UAAU,CAAA;AACrD,EAAA,IAAI,CAAC,QAAA,IAAY,QAAA,CAAS,iBAAA,KAAsB,qBAAA,EAAuB;AACrE,IAAA,OAAO,IAAA;AAAA,EACT;AACA,EAAA,OAAO,QAAA,CAAS,cAAA;AAClB;AApMA,IAoDM,aAAA;AApDN,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,gCAAA,GAAA;AAOA,IAAA,YAAA,EAAA;AA6CA,IAAM,aAAA,GAAgC;AAAA,MACpC,IAAA,CAAK,SAAiB,IAAA,EAAgC;AACpD,QAAA,IAAI,IAAA,EAAM;AACR,UAAA,OAAA,CAAQ,IAAA,CAAK,SAAS,IAAI,CAAA;AAAA,QAC5B,CAAA,MAAO;AACL,UAAA,OAAA,CAAQ,KAAK,OAAO,CAAA;AAAA,QACtB;AAAA,MACF,CAAA;AAAA,MACA,IAAA,CAAK,SAAiB,IAAA,EAAgC;AACpD,QAAA,IAAI,IAAA,EAAM;AACR,UAAA,OAAA,CAAQ,IAAA,CAAK,SAAS,IAAI,CAAA;AAAA,QAC5B,CAAA,MAAO;AACL,UAAA,OAAA,CAAQ,KAAK,OAAO,CAAA;AAAA,QACtB;AAAA,MACF;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC5BA,eAAsB,eAAA,CACpB,UAAA,EACA,OAAA,GAAwB,EAAC,EACV;AACf,EAAA,MAAM,EAAE,eAAA,GAAkB,IAAA,EAAK,GAAI,OAAA;AAGnC,EAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,MACxB,SAAA;AAAA,MACA,WAAW,UAAU,CAAA,2GAAA;AAAA,KAEvB;AAAA,EACF;AAGA,EAAA,MAAM,SAAA,GAAY,MAAM,cAAA,CAAe,UAAU,CAAA;AACjD,EAAA,IAAI,SAAA,EAAW;AACb,IAAA;AAAA,EACF;AAGA,EAAA,IAAI,OAAA,GAAU,CAAA,OAAA,EAAU,MAAA,CAAO,IAAI,CAAA,kCAAA,CAAA;AAEnC,EAAA,IAAIH,UAAAA,MAAe,eAAA,EAAiB;AAClC,IAAA,MAAM,QAAA,GAAW,MAAM,mBAAA,CAAoB,UAAU,CAAA;AACrD,IAAA,IAAI,QAAA,EAAU;AACZ,MAAA,OAAA,IAAW,CAAA,EAAA,EAAK,SAAS,WAAW,CAAA,CAAA;AAGpC,MAAA,QAAQ,SAAS,iBAAA;AAAmB,QAClC,KAAK,qBAAA;AACH,UAAA,OAAA,IAAW,CAAA,qBAAA,EAAwB,SAAS,cAAc,CAAA,CAAA;AAC1D,UAAA;AAAA,QACF,KAAK,oBAAA;AACH,UAAA,OAAA,IAAW,CAAA,eAAA,EAAkB,SAAS,cAAc,CAAA,CAAA;AACpD,UAAA;AAAA,QACF,KAAK,WAAA;AACH,UAAA,OAAA,IAAW,CAAA,eAAA,EAAkB,SAAS,cAAc,CAAA,CAAA;AACpD,UAAA;AAAA;AACJ,IACF;AAAA,EACF;AAEA,EAAA,MAAM,mBAAA,CAAoB,aAAA,CAAc,SAAA,EAAW,OAAO,CAAA;AAC5D;AAiBO,SAAS,8BAAA,GAAuC;AACrD,EAAA,IAAI,CAACD,UAAQ,EAAG;AACd,IAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,MACxB,SAAA;AAAA,MACA;AAAA,KAGF;AAAA,EACF;AACF;AAUO,SAAS,WAAA,GAAoB;AAClC,EAAA,IAAI,CAACA,UAAQ,EAAG;AACd,IAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,MACxB,SAAA;AAAA,MACA;AAAA,KAEF;AAAA,EACF;AACF;AAUO,SAAS,aAAA,GAAsB;AACpC,EAAA,IAAI,CAACC,YAAU,EAAG;AAChB,IAAA,MAAM,mBAAA,CAAoB,aAAA;AAAA,MACxB,SAAA;AAAA,MACA;AAAA,KACF;AAAA,EACF;AACF;AAlJA,IAAA,WAAA,GAAA,KAAA,CAAA;AAAA,EAAA,+BAAA,GAAA;AAOA,IAAAV,YAAAA,EAAAA;AACA,IAAAa,kBAAAA,EAAAA;AACA,IAAA,YAAA,EAAA;AACA,IAAA,YAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACyIO,SAAS,qBACd,OAAA,EAI6E;AAC7E,EAAA,MAAM,EAAE,OAAA,EAAS,IAAA,EAAM,WAAW,MAAA,EAAQ,SAAA,EAAW,gBAAe,GAAI,OAAA;AAExE,EAAA,OAAO,OAAO,SAAwB,GAAA,KAAiB;AACrD,IAAA,MAAM,aAAA,GAAgB,OAAA,CAAQ,cAAA,IAAkB,qBAAA,EAAsB;AAGtE,IAAA,MAAM,UAAA,GAAa,MAAM,IAAA,CAAK,GAAG,CAAA;AACjC,IAAA,IAAI,CAAC,WAAW,aAAA,EAAe;AAC7B,MAAA,IAAI,MAAA,EAAQ;AACV,QAAA,MAAA,CAAO,KAAK,wCAAA,EAA0C;AAAA,UACpD,cAAA,EAAgB,aAAA;AAAA,UAChB,QAAQ,UAAA,CAAW;AAAA,SACpB,CAAA;AAAA,MACH;AAEA,MAAA,IAAI,SAAA,EAAW;AACb,QAAA,SAAA,CAAU,KAAK,yCAAA,EAA2C;AAAA,UACxD,cAAA,EAAgB;AAAA,SACjB,CAAA;AAAA,MACH;AAEA,MAAA,OAAO;AAAA,QACL,MAAA,EAAQ,OAAA;AAAA,QACR,KAAA,EAAO,uBAAA;AAAA,QACP,OAAA,EAAS,WAAW,MAAA,IAAU,yBAAA;AAAA,QAC9B,UAAA,EAAY;AAAA,OACd;AAAA,IACF;AAEA,IAAA,MAAM,QAAA,GAAW,WAAW,QAAA,IAAY,SAAA;AAGxC,IAAA,IAAI,CAAC,QAAQ,MAAA,EAAQ;AACnB,MAAA,OAAO;AAAA,QACL,MAAA,EAAQ,OAAA;AAAA,QACR,KAAA,EAAO,iBAAA;AAAA,QACP,OAAA,EAAS,yBAAA;AAAA,QACT,UAAA,EAAY;AAAA,OACd;AAAA,IACF;AAGA,IAAA,MAAM,UAAA,GAAa,mBAAA,CAAoB,OAAA,CAAQ,MAAM,CAAA;AAGrD,IAAA,MAAM,cAAA,GAAiB;AAAA,MACrB,QAAA;AAAA,MACA,SAAA;AAAA,MACA,QAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA,SAAA;AAAA,MACA;AAAA,KACF;AAGA,IAAA,MAAM,OAAA,GAAA,CAAW,kBAAkB,cAAA,EAAgB,GAAA,CAAI,CAAC,CAAA,KAAM,mBAAA,CAAoB,CAAC,CAAC,CAAA;AAEpF,IAAA,IAAI,CAAC,OAAA,CAAQ,QAAA,CAAS,UAAU,CAAA,EAAG;AACjC,MAAA,OAAO;AAAA,QACL,MAAA,EAAQ,OAAA;AAAA,QACR,KAAA,EAAO,gBAAA;AAAA,QACP,OAAA,EAAS,WAAW,OAAA,CAAQ,MAAM,uCAAuC,OAAA,CAAQ,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA;AAAA,QAC3F,aAAA,EAAe,OAAA;AAAA,QACf,UAAA,EAAY;AAAA,OACd;AAAA,IACF;AAGA,IAAA,MAAM,SAAA,GAAY,MAAM,cAAA,CAAe,UAAU,CAAA;AACjD,IAAA,IAAI,CAAC,SAAA,EAAW;AAGd,MAAA,OAAO;AAAA,QACL,MAAA,EAAQ,OAAA;AAAA,QACR,KAAA,EAAO,sBAAA;AAAA,QACP,OAAA,EAAS,UAAU,UAAU,CAAA,kCAAA,CAAA;AAAA,QAC7B,UAAA,EAAY;AAAA,OACd;AAAA,IACF;AAGA,IAAA,IAAI,SAAA,EAAW;AACb,MAAA,MAAM,eAAA,GAAkB,MAAM,SAAA,CAAU,QAAA,EAAU,UAAU,CAAA;AAC5D,MAAA,IAAI,CAAC,gBAAgB,OAAA,EAAS;AAC5B,QAAA,IAAI,MAAA,EAAQ;AACV,UAAA,MAAA,CAAO,KAAK,sCAAA,EAAwC;AAAA,YAClD,cAAA,EAAgB,aAAA;AAAA,YAChB,QAAA;AAAA,YACA,MAAA,EAAQ;AAAA,WACT,CAAA;AAAA,QACH;AAEA,QAAA,IAAI,SAAA,EAAW;AACb,UAAA,SAAA,CAAU,KAAK,0CAAA,EAA4C;AAAA,YACzD,cAAA,EAAgB,aAAA;AAAA,YAChB,MAAA,EAAQ;AAAA,WACT,CAAA;AAAA,QACH;AAEA,QAAA,OAAO;AAAA,UACL,MAAA,EAAQ,OAAA;AAAA,UACR,KAAA,EAAO,qBAAA;AAAA,UACP,OAAA,EAAS,8CAAA;AAAA,UACT,UAAA,EAAY;AAAA,SACd;AAAA,MACF;AAAA,IACF;AAGA,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,MAAA,CAAO,KAAK,kCAAA,EAAoC;AAAA,QAC9C,cAAA,EAAgB,aAAA;AAAA,QAChB,QAAA;AAAA,QACA,MAAA,EAAQ,UAAA;AAAA,QACR,QAAQ,OAAA,CAAQ;AAAA,OACjB,CAAA;AAAA,IACH;AAEA,IAAA,IAAI,SAAA,EAAW;AACb,MAAA,SAAA,CAAU,KAAK,6CAAA,EAA+C;AAAA,QAC5D,cAAA,EAAgB,aAAA;AAAA,QAChB,MAAA,EAAQ;AAAA,OACT,CAAA;AAAA,IACH;AAIA,IAAA,KAAK,QAAQ,OAAA,CAAQ,UAAU,CAAA,CAAE,KAAA,CAAM,CAAC,KAAA,KAAU;AAChD,MAAA,IAAI,MAAA,EAAQ;AACV,QAAA,MAAA,CAAO,KAAK,iCAAA,EAAmC;AAAA,UAC7C,cAAA,EAAgB,aAAA;AAAA,UAChB,MAAA,EAAQ,UAAA;AAAA,UACR,OAAO,KAAA,YAAiB,KAAA,GAAQ,KAAA,CAAM,OAAA,GAAU,OAAO,KAAK;AAAA,SAC7D,CAAA;AAAA,MACH;AAAA,IACF,CAAC,CAAA;AAGD,IAAA,OAAO;AAAA,MACL,MAAA,EAAQ,UAAA;AAAA,MACR,MAAA,EAAQ,UAAA;AAAA,MACR,cAAA,EAAgB,aAAA;AAAA,MAChB,OAAA,EAAS,yCAAA;AAAA,MACT,UAAA,EAAY;AAAA,KACd;AAAA,EACF,CAAA;AACF;AAOA,SAAS,oBAAoB,MAAA,EAAwB;AACnD,EAAA,MAAM,KAAA,GAAQ,OAAO,WAAA,EAAY;AACjC,EAAA,IAAI,KAAA,CAAM,UAAA,CAAW,KAAK,CAAA,EAAG;AAC3B,IAAA,OAAO,KAAA;AAAA,EACT;AACA,EAAA,OAAO,MAAM,KAAK,CAAA,CAAA;AACpB;AAKA,SAAS,qBAAA,GAAgC;AACvC,EAAA,OAAO,CAAA,IAAA,EAAO,IAAA,CAAK,GAAA,EAAK,IAAI,IAAA,CAAK,MAAA,EAAO,CAAE,QAAA,CAAS,EAAE,CAAA,CAAE,SAAA,CAAU,CAAA,EAAG,CAAC,CAAC,CAAA,CAAA;AACxE;AAgBO,SAAS,sBAAsB,aAAA,EAAiC;AACrE,EAAA,OAAO,CAAC,GAAA,KAAiB;AACvB,IAAA,MAAM,UAAW,GAAA,CAA6C,OAAA;AAC9D,IAAA,MAAM,UAAA,GAAa,OAAA,EAAS,aAAA,IAAiB,OAAA,EAAS,aAAA;AAEtD,IAAA,IAAI,CAAC,UAAA,EAAY;AACf,MAAA,OAAO;AAAA,QACL,aAAA,EAAe,KAAA;AAAA,QACf,MAAA,EAAQ;AAAA,OACV;AAAA,IACF;AAEA,IAAA,MAAM,CAAC,MAAA,EAAQ,KAAK,CAAA,GAAI,UAAA,CAAW,MAAM,GAAG,CAAA;AAC5C,IAAA,IAAI,MAAA,KAAW,QAAA,IAAY,KAAA,KAAU,aAAA,EAAe;AAClD,MAAA,OAAO;AAAA,QACL,aAAA,EAAe,KAAA;AAAA,QACf,MAAA,EAAQ;AAAA,OACV;AAAA,IACF;AAEA,IAAA,OAAO;AAAA,MACL,aAAA,EAAe,IAAA;AAAA,MACf,QAAA,EAAU;AAAA,KACZ;AAAA,EACF,CAAA;AACF;AAgBO,SAAS,wBAAwB,iBAAA,EAA0C;AAChF,EAAA,MAAM,QAAA,uBAAe,GAAA,EAAsB;AAC3C,EAAA,MAAM,QAAA,GAAW,GAAA;AAEjB,EAAA,OAAO,CAAC,QAAA,KAAqB;AAC3B,IAAA,MAAM,GAAA,GAAM,KAAK,GAAA,EAAI;AACrB,IAAA,MAAM,GAAA,GAAM,QAAA;AAGZ,IAAA,IAAI,UAAA,GAAa,QAAA,CAAS,GAAA,CAAI,GAAG,KAAK,EAAC;AAGvC,IAAA,UAAA,GAAa,WAAW,MAAA,CAAO,CAAC,EAAA,KAAO,GAAA,GAAM,KAAK,QAAQ,CAAA;AAG1D,IAAA,IAAI,UAAA,CAAW,UAAU,iBAAA,EAAmB;AAC1C,MAAA,MAAM,eAAA,GAAkB,IAAA,CAAK,GAAA,CAAI,GAAG,UAAU,CAAA;AAC9C,MAAA,MAAM,UAAU,eAAA,GAAkB,QAAA;AAElC,MAAA,OAAO;AAAA,QACL,OAAA,EAAS,KAAA;AAAA,QACT,SAAA,EAAW,CAAA;AAAA,QACX,QAAA,EAAU;AAAA,OACZ;AAAA,IACF;AAGA,IAAA,UAAA,CAAW,KAAK,GAAG,CAAA;AACnB,IAAA,QAAA,CAAS,GAAA,CAAI,KAAK,UAAU,CAAA;AAE5B,IAAA,OAAO;AAAA,MACL,OAAA,EAAS,IAAA;AAAA,MACT,SAAA,EAAW,oBAAoB,UAAA,CAAW,MAAA;AAAA,MAC1C,UAAU,GAAA,GAAM;AAAA,KAClB;AAAA,EACF,CAAA;AACF;AA9ZA,IAAA,gBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,oCAAA,GAAA;AAOA,IAAAA,kBAAAA,EAAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC0bO,SAAS,mBAAA,CAAoB,OAAA,GAAgC,EAAC,EAAkB;AACrF,EAAA,OAAO,IAAI,cAAc,OAAO,CAAA;AAClC;AAncA,IA4Ga,aAAA;AA5Gb,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,gCAAA,GAAA;AAOA,IAAAA,kBAAAA,EAAAA;AACA,IAAA,YAAA,EAAA;AACA,IAAA,eAAA,EAAA;AAMA,IAAA,YAAA,EAAA;AA6FO,IAAM,gBAAN,MAAoB;AAAA,MACjB,QAAA,uBAAiD,GAAA,EAAI;AAAA,MACrD,eAAA,uBAAqE,GAAA,EAAI;AAAA,MACzE,OAAA;AAAA,MAIA,gBAAA,GAAmB,CAAA;AAAA,MACnB,iBAAA,uBAAqD,GAAA,EAAI;AAAA,MACzD,YAAA,GAAe,KAAA;AAAA,MAEvB,WAAA,CAAY,OAAA,GAAgC,EAAC,EAAG;AAC9C,QAAA,IAAA,CAAK,OAAA,GAAU;AAAA,UACb,gBAAA,EAAkB,QAAQ,gBAAA,IAAoB,GAAA;AAAA,UAC9C,eAAA,EAAiB,QAAQ,eAAA,IAAmB,kBAAA;AAAA,UAC5C,QAAA,EAAU,QAAQ,QAAA,IAAY,KAAA;AAAA,UAC9B,iBAAA,EAAmB,QAAQ,iBAAA,IAAqB,GAAA;AAAA,UAChD,iBAAA,EAAmB,QAAQ,iBAAA,IAAqB,GAAA;AAAA,UAChD,QAAQ,OAAA,CAAQ,MAAA;AAAA,UAChB,WAAW,OAAA,CAAQ;AAAA,SACrB;AAAA,MACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MASA,MAAM,QAAA,CACJ,MAAA,EACA,OAAA,EACA,OAAA,GAA0B,EAAC,EACZ;AACf,QAAA,MAAM,UAAA,GAAa,OAAO,MAAA,KAAW,QAAA,GAAW,MAAA,GAAS,MAAA;AAGzD,QAAA,MAAM,SAAA,GAAY,MAAM,cAAA,CAAe,UAAU,CAAA;AACjD,QAAA,IAAI,CAAC,SAAA,EAAW;AAEd,UAAA,IAAIH,YAAU,EAAG;AACf,YAAA,MAAM,sBAAsB,UAAA,EAAY;AAAA,cACtC,MAAA,EAAQ,KAAK,OAAA,CAAQ,MAAA;AAAA,cACrB,SAAA,EAAW,KAAK,OAAA,CAAQ;AAAA,aACzB,CAAA;AAAA,UACH;AACA,UAAA;AAAA,QACF;AAGA,QAAA,IAAI,CAAC,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,UAAU,CAAA,EAAG;AAClC,UAAA,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,UAAA,EAAY,EAAE,CAAA;AAAA,QAClC;AAGA,QAAA,MAAM,YAAA,GAAkC;AAAA,UACtC,MAAA,EAAQ,UAAA;AAAA,UACR,OAAA;AAAA,UACA,QAAA,EAAU,QAAQ,QAAA,IAAY,CAAA;AAAA,UAC9B,SAAA,EAAW,OAAA,CAAQ,SAAA,IAAa,IAAA,CAAK,OAAA,CAAQ,gBAAA;AAAA,UAC7C,IAAI,OAAA,CAAQ,EAAA,IAAM,CAAA,QAAA,EAAW,EAAE,KAAK,gBAAgB,CAAA,CAAA;AAAA,UACpD,YAAA,EAAc,KAAK,GAAA;AAAI,SACzB;AAGA,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,UAAU,CAAA;AAC7C,QAAA,IAAI,CAAC,QAAA,EAAU;AACb,UAAA,MAAM,IAAI,KAAA,CAAM,CAAA,wCAAA,EAA2C,UAAU,CAAA,CAAE,CAAA;AAAA,QACzE;AACA,QAAA,QAAA,CAAS,KAAK,YAAY,CAAA;AAG1B,QAAA,QAAA,CAAS,IAAA,CAAK,CAAC,CAAA,EAAG,CAAA,KAAM;AACtB,UAAA,IAAI,CAAA,CAAE,QAAA,KAAa,CAAA,CAAE,QAAA,EAAU;AAC7B,YAAA,OAAO,CAAA,CAAE,WAAW,CAAA,CAAE,QAAA;AAAA,UACxB;AACA,UAAA,OAAO,CAAA,CAAE,eAAe,CAAA,CAAE,YAAA;AAAA,QAC5B,CAAC,CAAA;AAGD,QAAA,IAAI,CAAC,IAAA,CAAK,eAAA,CAAgB,GAAA,CAAI,UAAU,CAAA,EAAG;AACzC,UAAA,MAAM,IAAA,CAAK,uBAAuB,UAAU,CAAA;AAAA,QAC9C;AAGA,QAAA,IAAI,IAAA,CAAK,QAAQ,MAAA,EAAQ;AACvB,UAAA,IAAA,CAAK,OAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,2BAAA,EAA8B,UAAU,CAAA,CAAA,EAAI;AAAA,YACnE,YAAY,YAAA,CAAa,EAAA;AAAA,YACzB,UAAU,YAAA,CAAa,QAAA;AAAA,YACvB,YAAY,YAAA,CAAa;AAAA,WAC1B,CAAA;AAAA,QACH;AAGA,QAAA,IAAI,IAAA,CAAK,QAAQ,SAAA,EAAW;AAC1B,UAAA,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,IAAA,CAAK,kCAAA,EAAoC;AAAA,YAC9D,MAAA,EAAQ,UAAA;AAAA,YACR,YAAY,YAAA,CAAa,EAAA;AAAA,YACzB,QAAA,EAAU,MAAA,CAAO,YAAA,CAAa,QAAQ;AAAA,WACvC,CAAA;AAAA,QACH;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,uBAAuB,UAAA,EAAmC;AACtE,QAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,UAAU,CAAA;AACzC,QAAA,IAAI,CAAC,MAAA,EAAQ;AACX,UAAA;AAAA,QACF;AAGA,QAAA,MAAM,YAAA,GAAe,OAAO,gBAAA,KAAqB,mCAAA;AAEjD,QAAA,IAAI,YAAA,EAAc;AAEhB,UAAA,MAAM,OAAA,GAAU,MAAM,sBAAA,CAAuB,UAAA,EAAY;AAAA,YACvD,QAAA,EAAU,KAAK,OAAA,CAAQ,iBAAA;AAAA,YACvB,QAAA,EAAU,KAAK,OAAA,CAAQ,iBAAA;AAAA,YACvB,MAAA,EAAQ,KAAK,OAAA,CAAQ,MAAA;AAAA,YACrB,QAAA,EAAU,KAAK,OAAA,CAAQ;AAAA,WACxB,CAAA;AACD,UAAA,IAAA,CAAK,iBAAA,CAAkB,GAAA,CAAI,UAAA,EAAY,OAAO,CAAA;AAAA,QAChD;AAGA,QAAA,MAAM,QAAA,GAAW,OAAO,GAAA,KAAwB;AAE9C,UAAA,IAAI,YAAA,EAAc;AAChB,YAAA,MAAM,OAAA,GAAU,IAAA,CAAK,iBAAA,CAAkB,GAAA,CAAI,UAAU,CAAA;AACrD,YAAA,IAAI,OAAA,EAAS;AACX,cAAA,MAAM,SAAA,GAAY,gBAAgB,OAAO,CAAA;AACzC,cAAA,IAAI,SAAA,EAAW;AAEb,gBAAA;AAAA,cACF;AAAA,YAEF;AAAA,UACF;AAGA,UAAA,MAAM,IAAA,CAAK,eAAA,CAAgB,UAAA,EAAY,GAAG,CAAA;AAAA,QAC5C,CAAA;AAGA,QAAA,OAAA,CAAQ,EAAA,CAAG,YAA8B,QAAQ,CAAA;AACjD,QAAA,IAAA,CAAK,eAAA,CAAgB,GAAA,CAAI,UAAA,EAAY,QAAQ,CAAA;AAAA,MAC/C;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,eAAA,CAAgB,UAAA,EAAoB,MAAA,EAAuC;AACvF,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,UAAU,CAAA;AAC7C,QAAA,IAAI,CAAC,QAAA,IAAY,QAAA,CAAS,MAAA,KAAW,CAAA,EAAG;AACtC,UAAA;AAAA,QACF;AAGA,QAAA,IAAA,CAAK,YAAA,GAAe,IAAA;AAGpB,QAAA,IAAI,IAAA,CAAK,QAAQ,MAAA,EAAQ;AACvB,UAAA,IAAA,CAAK,OAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,iBAAA,EAAoB,UAAU,CAAA,CAAA,EAAI;AAAA,YACzD,eAAe,QAAA,CAAS;AAAA,WACzB,CAAA;AAAA,QACH;AAGA,QAAA,KAAA,MAAW,gBAAgB,QAAA,EAAU;AACnC,UAAA,IAAI;AAEF,YAAA,MAAM,IAAA,CAAK,kBAAA,CAAmB,YAAA,EAAc,MAAM,CAAA;AAAA,UACpD,SAAS,KAAA,EAAO;AAEd,YAAA,IAAI,IAAA,CAAK,QAAQ,MAAA,EAAQ;AACvB,cAAA,IAAA,CAAK,OAAA,CAAQ,MAAA,CAAO,IAAA,CAAK,CAAA,uBAAA,EAA0B,UAAU,CAAA,CAAA,EAAI;AAAA,gBAC/D,YAAY,YAAA,CAAa,EAAA;AAAA,gBACzB,OAAO,KAAA,YAAiB,KAAA,GAAQ,KAAA,CAAM,OAAA,GAAU,OAAO,KAAK;AAAA,eAC7D,CAAA;AAAA,YACH;AAEA,YAAA,IAAI,IAAA,CAAK,QAAQ,SAAA,EAAW;AAC1B,cAAA,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,IAAA,CAAK,6BAAA,EAA+B;AAAA,gBACzD,MAAA,EAAQ,UAAA;AAAA,gBACR,YAAY,YAAA,CAAa,EAAA;AAAA,gBACzB,UAAA,EAAY,KAAA,YAAiB,KAAA,GAAQ,KAAA,CAAM,YAAY,IAAA,GAAO;AAAA,eAC/D,CAAA;AAAA,YACH;AAEA,YAAA,IAAI,IAAA,CAAK,OAAA,CAAQ,eAAA,KAAoB,YAAA,EAAc;AACjD,cAAA,MAAM,QAAA,GAAA,CAAY,MAAM,SAAA,CAAU,UAAU,IAAI,SAAA,IAAa,CAAA;AAC7D,cAAA,IAAI,CAAC,IAAA,CAAK,OAAA,CAAQ,QAAA,EAAU;AAC1B,gBAAA,OAAA,CAAQ,KAAK,QAAQ,CAAA;AAAA,cACvB;AACA,cAAA;AAAA,YACF;AAAA,UAEF;AAAA,QACF;AAGA,QAAA,MAAM,OAAA,GAAU,IAAA,CAAK,iBAAA,CAAkB,GAAA,CAAI,UAAU,CAAA;AACrD,QAAA,IAAI,OAAA,EAAS;AACX,UAAA,cAAA,CAAe,OAAO,CAAA;AAAA,QACxB;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,kBAAA,CACZ,YAAA,EACA,MAAA,EACe;AACf,QAAA,MAAM,cAAA,GAAiB,IAAI,OAAA,CAAe,CAAC,GAAG,MAAA,KAAW;AACvD,UAAA,UAAA,CAAW,MAAM;AACf,YAAA,MAAA,CAAO,IAAI,KAAA,CAAM,CAAA,0BAAA,EAA6B,YAAA,CAAa,SAAS,IAAI,CAAC,CAAA;AAAA,UAC3E,CAAA,EAAG,aAAa,SAAS,CAAA;AAAA,QAC3B,CAAC,CAAA;AAED,QAAA,MAAM,iBAAiB,OAAA,CAAQ,OAAA,CAAQ,YAAA,CAAa,OAAA,CAAQ,MAAM,CAAC,CAAA;AAEnE,QAAA,IAAI;AACF,UAAA,MAAM,OAAA,CAAQ,IAAA,CAAK,CAAC,cAAA,EAAgB,cAAc,CAAC,CAAA;AAGnD,UAAA,IAAI,IAAA,CAAK,QAAQ,SAAA,EAAW;AAC1B,YAAA,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,IAAA,CAAK,iCAAA,EAAmC;AAAA,cAC7D,QAAQ,YAAA,CAAa,MAAA;AAAA,cACrB,YAAY,YAAA,CAAa;AAAA,aAC1B,CAAA;AAAA,UACH;AAAA,QACF,SAAS,KAAA,EAAO;AAEd,UAAA,IAAI,IAAA,CAAK,QAAQ,SAAA,EAAW;AAC1B,YAAA,IAAA,CAAK,OAAA,CAAQ,SAAA,CAAU,IAAA,CAAK,+BAAA,EAAiC;AAAA,cAC3D,QAAQ,YAAA,CAAa,MAAA;AAAA,cACrB,YAAY,YAAA,CAAa,EAAA;AAAA,cACzB,UAAA,EAAY,MAAA,CAAO,YAAA,CAAa,SAAS;AAAA,aAC1C,CAAA;AAAA,UACH;AACA,UAAA,MAAM,KAAA;AAAA,QACR;AAAA,MACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQA,UAAA,CAAW,QAAgB,OAAA,EAA+B;AACxD,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA;AACzC,QAAA,IAAI,CAAC,QAAA,EAAU;AACb,UAAA;AAAA,QACF;AAEA,QAAA,IAAI,OAAA,EAAS;AAEX,UAAA,MAAM,QAAQ,QAAA,CAAS,SAAA,CAAU,CAAC,CAAA,KAAM,CAAA,CAAE,YAAY,OAAO,CAAA;AAC7D,UAAA,IAAI,UAAU,EAAA,EAAI;AAChB,YAAA,QAAA,CAAS,MAAA,CAAO,OAAO,CAAC,CAAA;AAAA,UAC1B;AAAA,QACF,CAAA,MAAO;AAEL,UAAA,QAAA,CAAS,MAAA,GAAS,CAAA;AAAA,QACpB;AAGA,QAAA,IAAI,QAAA,CAAS,WAAW,CAAA,EAAG;AACzB,UAAA,MAAM,QAAA,GAAW,IAAA,CAAK,eAAA,CAAgB,GAAA,CAAI,MAAM,CAAA;AAChD,UAAA,IAAI,QAAA,EAAU;AACZ,YAAA,OAAA,CAAQ,GAAA,CAAI,QAA0B,QAAQ,CAAA;AAC9C,YAAA,IAAA,CAAK,eAAA,CAAgB,OAAO,MAAM,CAAA;AAAA,UACpC;AACA,UAAA,IAAA,CAAK,QAAA,CAAS,OAAO,MAAM,CAAA;AAAA,QAC7B;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,aAAa,MAAA,EAAyB;AACpC,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA;AACzC,QAAA,OAAO,QAAA,KAAa,MAAA,IAAa,QAAA,CAAS,MAAA,GAAS,CAAA;AAAA,MACrD;AAAA;AAAA;AAAA;AAAA,MAKA,gBAAgB,MAAA,EAAwB;AACtC,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA;AACzC,QAAA,OAAO,UAAU,MAAA,IAAU,CAAA;AAAA,MAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,MAAM,QAAQ,MAAA,EAA+B;AAC3C,QAAA,MAAM,QAAA,GAAW,IAAA,CAAK,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA;AACzC,QAAA,IAAI,CAAC,QAAA,IAAY,QAAA,CAAS,MAAA,KAAW,CAAA,EAAG;AACtC,UAAA;AAAA,QACF;AAEA,QAAA,MAAM,IAAA,CAAK,eAAA,CAAgB,MAAA,EAAQ,MAAwB,CAAA;AAAA,MAC7D;AAAA;AAAA;AAAA;AAAA,MAKA,MAAM,QAAA,GAA0B;AAE9B,QAAA,KAAA,MAAW,CAAC,MAAA,EAAQ,QAAQ,KAAK,IAAA,CAAK,eAAA,CAAgB,SAAQ,EAAG;AAC/D,UAAA,OAAA,CAAQ,GAAA,CAAI,QAA0B,QAAQ,CAAA;AAAA,QAChD;AAGA,QAAA,IAAA,CAAK,gBAAgB,KAAA,EAAM;AAC3B,QAAA,IAAA,CAAK,SAAS,KAAA,EAAM;AACpB,QAAA,IAAA,CAAK,kBAAkB,KAAA,EAAM;AAC7B,QAAA,IAAA,CAAK,YAAA,GAAe,KAAA;AAAA,MACtB;AAAA;AAAA;AAAA;AAAA,MAKA,cAAA,GAA0B;AACxB,QAAA,OAAO,IAAA,CAAK,YAAA;AAAA,MACd;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC1UO,SAAS,0BACd,OAAA,EACqB;AACrB,EAAA,MAAM;AAAA,IACJ,MAAA;AAAA,IACA,SAAA;AAAA,IACA,WAAA;AAAA,IACA,QAAA,GAAW,GAAA;AAAA,IACX,MAAA;AAAA,IACA,SAAA;AAAA,IACA,QAAA,GAAW;AAAA,GACb,GAAI,OAAA;AAEJ,EAAA,OAAO,YAAY;AAEjB,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,MAAA,CAAO,KAAK,kCAAkC,CAAA;AAAA,IAChD;AAEA,IAAA,IAAI,SAAA,EAAW;AACb,MAAA,SAAA,CAAU,KAAK,uCAAA,EAAyC;AAAA,QACtD,MAAA,EAAQ;AAAA,OACT,CAAA;AAAA,IACH;AAEA,IAAA,IAAI;AAEF,MAAA,MAAM,SAAA,GAAY,MAAM,MAAA,EAAO;AAG/B,MAAA,MAAM,MAAA,GAAS,MAAM,SAAA,CAAU,SAAS,CAAA;AAExC,MAAA,IAAI,CAAC,OAAO,KAAA,EAAO;AAEjB,QAAA,IAAI,MAAA,EAAQ;AACV,UAAA,MAAA,CAAO,KAAK,2DAAA,EAA6D;AAAA,YACvE,WAAA,EAAa,MAAA,CAAO,MAAA,EAAQ,MAAA,IAAU,CAAA;AAAA,YACtC,QAAQ,MAAA,CAAO;AAAA,WAChB,CAAA;AAAA,QACH;AAEA,QAAA,IAAI,SAAA,EAAW;AACb,UAAA,SAAA,CAAU,KAAK,sCAAA,EAAwC;AAAA,YACrD,MAAA,EAAQ,QAAA;AAAA,YACR,MAAA,EAAQ,mBAAA;AAAA,YACR,WAAA,EAAa,MAAA,CAAO,MAAA,CAAO,MAAA,EAAQ,UAAU,CAAC;AAAA,WAC/C,CAAA;AAAA,QACH;AAEA,QAAA;AAAA,MACF;AAGA,MAAA,IAAI,MAAA,EAAQ;AACV,QAAA,MAAA,CAAO,KAAK,mDAAmD,CAAA;AAAA,MACjE;AAEA,MAAA,IAAI,SAAA,EAAW;AACb,QAAA,SAAA,CAAU,KAAK,sCAAA,EAAwC;AAAA,UACrD,MAAA,EAAQ;AAAA,SACT,CAAA;AAAA,MACH;AAGA,MAAA,IAAI,WAAA,EAAa;AACf,QAAA,MAAM,YAAY,SAAS,CAAA;AAAA,MAC7B;AAGA,MAAA,IAAI,CAAC,QAAA,EAAU;AACb,QAAA,OAAA,CAAQ,KAAK,QAAQ,CAAA;AAAA,MACvB;AAAA,IACF,SAAS,KAAA,EAAO;AAEd,MAAA,IAAI,MAAA,EAAQ;AACV,QAAA,MAAA,CAAO,KAAK,kEAAA,EAAoE;AAAA,UAC9E,OAAO,KAAA,YAAiB,KAAA,GAAQ,KAAA,CAAM,OAAA,GAAU,OAAO,KAAK;AAAA,SAC7D,CAAA;AAAA,MACH;AAEA,MAAA,IAAI,SAAA,EAAW;AACb,QAAA,SAAA,CAAU,KAAK,mCAAA,EAAqC;AAAA,UAClD,MAAA,EAAQ,QAAA;AAAA,UACR,UAAA,EAAY,KAAA,YAAiB,KAAA,GAAQ,KAAA,CAAM,YAAY,IAAA,GAAO;AAAA,SAC/D,CAAA;AAAA,MACH;AAAA,IAGF;AAAA,EACF,CAAA;AACF;AA1MA,IAkNa,mBAAA;AAlNb,IAAA,WAAA,GAAA,KAAA,CAAA;AAAA,EAAA,+BAAA,GAAA;AAkNO,IAAM,sBAAN,MAA0B;AAAA,MACvB,QAAA,GAAW,CAAA;AAAA,MACX,eAAA,GAAiC,IAAA;AAAA,MACxB,WAAA;AAAA,MACA,MAAA;AAAA,MACA,SAAA;AAAA,MAEjB,YAAY,OAAA,EAIT;AACD,QAAA,IAAA,CAAK,WAAA,GAAc,QAAQ,WAAA,IAAe,CAAA;AAC1C,QAAA,IAAA,CAAK,SAAS,OAAA,CAAQ,MAAA;AACtB,QAAA,IAAA,CAAK,YAAY,OAAA,CAAQ,SAAA;AAAA,MAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,aAAA,GAAyB;AACvB,QAAA,IAAA,CAAK,QAAA,EAAA;AACL,QAAA,IAAA,CAAK,eAAA,GAAkB,KAAK,GAAA,EAAI;AAEhC,QAAA,IAAI,IAAA,CAAK,QAAA,IAAY,IAAA,CAAK,WAAA,EAAa;AACrC,UAAA,IAAI,KAAK,MAAA,EAAQ;AACf,YAAA,IAAA,CAAK,MAAA,CAAO,IAAA;AAAA,cACV,CAAA,EAAG,KAAK,QAAQ,CAAA,yDAAA,CAAA;AAAA,cAChB;AAAA,gBACE,eAAe,IAAA,CAAK,QAAA;AAAA,gBACpB,WAAW,IAAA,CAAK;AAAA;AAClB,aACF;AAAA,UACF;AAEA,UAAA,IAAI,KAAK,SAAA,EAAW;AAClB,YAAA,IAAA,CAAK,SAAA,CAAU,KAAK,gDAAA,EAAkD;AAAA,cACpE,aAAA,EAAe,MAAA,CAAO,IAAA,CAAK,QAAQ,CAAA;AAAA,cACnC,SAAA,EAAW,MAAA,CAAO,IAAA,CAAK,WAAW;AAAA,aACnC,CAAA;AAAA,UACH;AAEA,UAAA,OAAO,IAAA;AAAA,QACT;AAEA,QAAA,OAAO,KAAA;AAAA,MACT;AAAA;AAAA;AAAA;AAAA,MAKA,aAAA,GAAsB;AACpB,QAAA,IAAA,CAAK,QAAA,GAAW,CAAA;AAChB,QAAA,IAAA,CAAK,eAAA,GAAkB,IAAA;AAAA,MACzB;AAAA;AAAA;AAAA;AAAA,MAKA,eAAA,GAA0B;AACxB,QAAA,OAAO,IAAA,CAAK,QAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,kBAAA,GAAoC;AAClC,QAAA,OAAO,IAAA,CAAK,eAAA;AAAA,MACd;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACzRA,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,8BAAA,GAAA;AAQA,IAAAG,kBAAAA,EAAAA;AAaA,IAAA,YAAA,EAAA;AASA,IAAA,gBAAA,EAAA;AASA,IAAA,eAAA,EAAA;AAUA,IAAA,WAAA,EAAA;AAQA,IAAA,gBAAA,EAAA;AAcA,IAAA,YAAA,EAAA;AAUA,IAAA,WAAA,EAAA;AA4BA,IAAA,YAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;AC9EO,SAAS,QAAA,CAAS,CAAA,EAAW,CAAA,EAAW,MAAA,GAAqB,aAAA,EAAuB;AACzF,EAAA,QAAQ,MAAA;AAAQ,IACd,KAAK,aAAA;AACH,MAAA,OAAO,WAAA,CAAY,GAAG,CAAC,CAAA;AAAA,IACzB,KAAK,aAAA;AACH,MAAA,OAAO,YAAA,CAAa,GAAG,CAAC,CAAA;AAAA,IAC1B,KAAK,sBAAA;AACH,MAAA,OAAO,mBAAA,CAAoB,GAAG,CAAC,CAAA;AAAA,IACjC,KAAK,cAAA;AACH,MAAA,OAAO,YAAA,CAAa,GAAG,CAAC,CAAA;AAAA,IAC1B,KAAK,WAAA;AAEH,MAAA,OAAO,mBAAA,CAAoB,CAAA,EAAG,CAAC,CAAA,CAAE,KAAA;AAAA,IACnC;AACE,MAAA,MAAM,IAAI,KAAA;AAAA,QACR,mBAAmB,MAAM,CAAA,0FAAA;AAAA,OAC3B;AAAA;AAEN;AAjDA,IAAA,aAAA,GAAA,KAAA,CAAA;AAAA,EAAA,oCAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACAA,IAAAb,YAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,kCAAA,GAAA;AAAA,IAAAA,YAAAA,EAAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACeA,SAAS,sBAAsB,MAAA,EAAkD;AAC/E,EAAA,IAAI,CAAC,MAAA,EAAQ;AACX,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,IAAI,MAAA,KAAW,IAAA,IAAQ,MAAA,KAAW,IAAA,IAAQ,WAAW,IAAA,EAAM;AACzD,IAAA,OAAO,MAAA;AAAA,EACT;AAEA,EAAA,OAAO,MAAA;AACT;AAeO,SAAS,SAAA,CACd,KAAA,EACA,MAAA,GAAiD,SAAA,EACjD,MAAA,EACQ;AAER,EAAA,IAAI,OAAO,WAAW,QAAA,EAAU;AAE9B,IAAA,MAAM,YAAA,GAAe,MAAA,CAAO,YAAA,GAAe,YAAA,GAAe,SAAA;AAC1D,IAAA,MAAM,YAAA,GAAe,qBAAA,CAAsB,MAAA,CAAO,MAAA,IAAU,MAAM,CAAA;AAClE,IAAA,OAAOc,WAAA,CAAc,KAAA,EAAO,YAAA,EAAc,YAAY,CAAA;AAAA,EACxD;AAEA,EAAA,OAAOA,WAAA,CAAc,KAAA,EAAO,MAAA,EAAmC,qBAAA,CAAsB,MAAM,CAAC,CAAA;AAC9F;AASO,SAAS,QAAA,CAAS,OAAe,MAAA,EAAyB;AAC/D,EAAA,IAAI,WAAW,IAAA,EAAM;AACnB,IAAA,OAAO,KAAA,CAAM,kBAAkB,OAAO,CAAA;AAAA,EACxC;AACA,EAAA,OAAO,MAAM,WAAA,EAAY;AAC3B;AAQO,SAAS,aAAa,KAAA,EAAuB;AAClD,EAAA,OAAO,MAAM,SAAA,CAAU,KAAK,CAAA,CAAE,OAAA,CAAQ,oBAAoB,EAAE,CAAA;AAC9D;AAUO,SAAS,gBAAA,CAAiB,CAAA,EAAW,CAAA,EAAW,OAAA,EAAqC;AAC1F,EAAA,OAAO,UAAU,CAAA,EAAG,OAAO,CAAA,KAAM,SAAA,CAAU,GAAG,OAAO,CAAA;AACvD;AA1FA,IAAA,kBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,yCAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACgCO,SAAS,KAAA,CAAM,CAAA,EAAW,CAAA,EAAW,MAAA,GAAqB,aAAA,EAAuB;AAEtF,EAAA,IAAI,WAAW,WAAA,EAAa;AAC1B,IAAA,OAAOC,mBAAAA,CAAoB,CAAA,EAAG,CAAC,CAAA,CAAE,KAAA;AAAA,EACnC;AAGA,EAAA,OAAOC,OAAA,CAAU,CAAA,EAAG,CAAA,EAAG,MAA0B,CAAA;AACnD;AAxCA,IAAA,UAAA,GAAA,KAAA,CAAA;AAAA,EAAA,iCAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;AC4BO,SAAS,OAAA,CACd,KAAA,EACA,UAAA,EACA,OAAA,EACc;AACd,EAAA,MAAM,MAAA,GAAS,SAAS,MAAA,IAAU,cAAA;AAClC,EAAA,MAAM,QAAA,GAAW,SAAS,QAAA,IAAY,iBAAA;AACtC,EAAA,MAAM,cAAA,GAAiB,SAAS,cAAA,IAAkB,uBAAA;AAGlD,EAAA,IAAI,eAAA,GAAkB,SAAS,eAAA,IAAmB,wBAAA;AAClD,EAAA,IAAI,OAAA,EAAS,cAAc,KAAA,EAAO;AAChC,IAAA,eAAA,GAAkB,MAAA;AAAA,EACpB,WAAW,OAAA,EAAS,SAAA,KAAc,IAAA,IAAQ,CAAC,SAAS,eAAA,EAAiB;AACnE,IAAA,eAAA,GAAkB,SAAA;AAAA,EACpB;AAGA,EAAA,MAAM,WAAA,GAAc;AAAA,IAClB,MAAA;AAAA,IACA,eAAA;AAAA,IACA,QAAA;AAAA,IACA,cAAA;AAAA,IACA,cAAc,OAAA,EAAS,YAAA;AAAA,IACvB,iBAAiB,OAAA,EAAS,eAAA;AAAA,IAC1B,eAAe,OAAA,EAAS;AAAA,GAC1B;AAEA,EAAA,MAAM,OAAA,GAAUC,SAAA,CAAY,KAAA,EAAO,UAAA,EAAwB,WAAW,CAAA;AAGtE,EAAA,OAAO,OAAA,CAAQ,GAAA,CAAI,CAAC,CAAA,MAAO;AAAA,IACzB,OAAO,CAAA,CAAE,KAAA;AAAA,IACT,OAAO,CAAA,CAAE,KAAA;AAAA,IACT,cAAc,CAAA,CAAE,YAAA;AAAA,IAChB,QAAQ,CAAA,CAAE,MAAA;AAAA,IACV,iBAAiB,CAAA,CAAE;AAAA,GACrB,CAAE,CAAA;AACJ;AAlEA,IAWM,iBAAA,EACA,yBACA,cAAA,EACA,wBAAA;AAdN,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,mCAAA,GAAA;AAWA,IAAM,iBAAA,GAAoB,GAAA;AAC1B,IAAM,uBAAA,GAA0B,CAAA;AAChC,IAAM,cAAA,GAAiB,aAAA;AACvB,IAAM,wBAAA,GAA2B,SAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACdjC,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,iCAAA,GAAA;AAUA,IAAA,aAAA,EAAA;AACA,IAAAjB,YAAAA,EAAAA;AACA,IAAA,kBAAA,EAAA;AAMA,IAAA,UAAA,EAAA;AACA,IAAA,YAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACnBA,IAAA,eAAA,GAAA,EAAA;AAAA,QAAA,CAAA,eAAA,EAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,cAAA,EAAA,MAAA,cAAA;AAAA,EAAA,OAAA,EAAA,MAAA,OAAA;AAAA,EAAA,QAAA,EAAA,MAAA,QAAA;AAAA,EAAA,qBAAA,EAAA,MAAA,qBAAA;AAAA,EAAA,oBAAA,EAAA,MAAA,oBAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,qBAAA,EAAA,MAAA,qBAAA;AAAA,EAAA,yBAAA,EAAA,MAAA,yBAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,oBAAA,EAAA,MAAA,oBAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,uBAAA,EAAA,MAAA,uBAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,cAAA,EAAA,MAAA,cAAA;AAAA,EAAA,wBAAA,EAAA,MAAA,wBAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,wBAAA,EAAA,MAAA,wBAAA;AAAA,EAAA,QAAA,EAAA,MAAA,QAAA;AAAA,EAAA,WAAA,EAAA,MAAA,WAAA;AAAA,EAAA,8BAAA,EAAA,MAAA,8BAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,SAAA,EAAA,MAAA,SAAA;AAAA,EAAA,WAAA,EAAA,MAAA,WAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,uBAAA,EAAA,MAAA,uBAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,WAAA,EAAA,MAAA,WAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,UAAA,EAAA,MAAA,UAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,WAAA,EAAA,MAAA,WAAA;AAAA,EAAA,uBAAA,EAAA,MAAA,uBAAA;AAAA,EAAA,SAAA,EAAA,MAAA,SAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,6BAAA,EAAA,MAAAY,wBAAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,4BAAA,EAAA,MAAA,4BAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,qBAAA,EAAA,MAAA,qBAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,OAAA,EAAA,MAAA,OAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,aAAA,EAAA,MAAAH,QAAAA;AAAA,EAAA,eAAA,EAAA,MAAAC,UAAAA;AAAA,EAAA,SAAA,EAAA,MAAA,SAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,SAAA,EAAA,MAAA,SAAA;AAAA,EAAA,cAAA,EAAA,MAAA,cAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,WAAA,EAAA,MAAA,WAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,sBAAA,EAAA,MAAA,sBAAA;AAAA,EAAA,qBAAA,EAAA,MAAA,qBAAA;AAAA,EAAA,mBAAA,EAAA,MAAA,mBAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,uBAAA,EAAA,MAAA,uBAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,SAAA,EAAA,MAAA,SAAA;AAAA,EAAA,aAAA,EAAA,MAAA,aAAA;AAAA,EAAA,eAAA,EAAA,MAAA,eAAA;AAAA,EAAA,QAAA,EAAA,MAAA,QAAA;AAAA,EAAA,UAAA,EAAA,MAAA,UAAA;AAAA,EAAA,MAAA,EAAA,MAAA,MAAA;AAAA,EAAA,MAAA,EAAA,MAAA,MAAA;AAAA,EAAA,gBAAA,EAAA,MAAA,gBAAA;AAAA,EAAA,cAAA,EAAA,MAAA,cAAA;AAAA,EAAA,KAAA,EAAA,MAAA,KAAA;AAAA,EAAA,YAAA,EAAA,MAAA,YAAA;AAAA,EAAA,OAAA,EAAA,MAAA,OAAA;AAAA,EAAA,cAAA,EAAA,MAAA,cAAA;AAAA,EAAA,4BAAA,EAAA,MAAAC,wBAAAA;AAAA,EAAA,uBAAA,EAAA,MAAA;AAAA,CAAA,CAAA;AAAA,IAQa,OAAA;AARb,IAAA,YAAA,GAAA,KAAA,CAAA;AAAA,EAAA,sBAAA,GAAA;AAWA,IAAA,kBAAA,EAAA;AAUA,IAAAX,YAAAA,EAAAA;AAEA,IAAA,eAAA,EAAA;AAoBA,IAAA,kBAAA,EAAA;AAYA,IAAA,WAAA,EAAA;AAQA,IAAA,eAAA,EAAA;AAaA,IAAA,aAAA,EAAA;AASA,IAAA,YAAA,EAAA;AAkGA,IAAA,eAAA,EAAA;AA/KO,IAAM,OAAA,GAAU,OAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACWhB,SAAS,iBAAA,GAAqC;AACnD,EAAA,OAAO,cAAA;AACT;AASO,SAAS,kBAAkB,QAAA,EAA0B;AAC1D,EAAA,cAAA,GAAiB,QAAA;AACnB;AAOO,SAAS,kBAAA,GAA2B;AACzC,EAAA,cAAA,GAAiB,IAAA;AACnB;AAzCA,IAYI,cAAA;AAZJ,IAAA,UAAA,GAAA,KAAA,CAAA;AAAA,EAAA,0BAAA,GAAA;AAYA,IAAI,cAAA,GAAkC,IAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACZtC,IASa,qBAAA,EAKA,gBAAA,EAKA,oBAAA,EAKA,sBAAA,EAMA,yBAAA;AA9Bb,IAAA,cAAA,GAAA,KAAA,CAAA;AAAA,EAAA,8BAAA,GAAA;AASO,IAAM,qBAAA,GAAwB,UAAA;AAK9B,IAAM,gBAAA,GAAmB,SAAA;AAKzB,IAAM,oBAAA,GAAuB,0BAAA;AAK7B,IAAM,sBAAA,GAAyB,oDAAA;AAM/B,IAAM,yBAAA,GAA4B,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;AC9BzC,IAAA,gBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,2BAAA,GAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACqIO,SAAS,kBAAA,GAGd;AACA,EAAA,OAAO;AAAA,IACL,MAAM,QAAA,CAAS,MAAA;AAAA,IACf,KAAA,EAAO;AAAA,GACT;AACF;AA7IA,IAUa,QAAA,EAuBA,eAAA;AAjCb,IAAA,aAAA,GAAA,KAAA,CAAA;AAAA,EAAA,wBAAA,GAAA;AAUO,IAAM,QAAA,GAAW;AAAA,MACtB,IAAA,EAAM,MAAA;AAAA,MACN,GAAA,EAAK,KAAA;AAAA,MACL,MAAA,EAAQ,QAAA;AAAA,MACR,IAAA,EAAM,MAAA;AAAA,MACN,QAAA,EAAU;AAAA,KACZ;AAiBO,IAAM,eAAA,GAAuD;AAAA,MAClE,IAAA,EAAM,CAAA;AAAA,MACN,GAAA,EAAK,CAAA;AAAA,MACL,MAAA,EAAQ,CAAA;AAAA,MACR,IAAA,EAAM,CAAA;AAAA,MACN,QAAA,EAAU;AAAA,KACZ;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACmEO,SAAS,oBAAoB,KAAA,EAAwB;AAC1D,EAAA,IAAI,iBAAiB,KAAA,EAAO;AAC1B,IAAA,OAAO,KAAA,CAAM,OAAA;AAAA,EACf;AACA,EAAA,IAAI,WAAA,CAAY,KAAK,CAAA,EAAG;AACtB,IAAA,OAAO,KAAA,CAAM,OAAA;AAAA,EACf;AACA,EAAA,IAAI,OAAO,UAAU,QAAA,EAAU;AAC7B,IAAA,OAAO,KAAA;AAAA,EACT;AACA,EAAA,OAAO,OAAO,KAAK,CAAA;AACrB;AAQO,SAAS,kBAAkB,KAAA,EAAoC;AACpE,EAAA,IAAI,iBAAiB,KAAA,EAAO;AAC1B,IAAA,OAAO,KAAA,CAAM,KAAA;AAAA,EACf;AACA,EAAA,IAAI,YAAY,KAAK,CAAA,IAAK,OAAO,KAAA,CAAM,UAAU,QAAA,EAAU;AACzD,IAAA,OAAO,KAAA,CAAM,KAAA;AAAA,EACf;AACA,EAAA,OAAO,MAAA;AACT;AAKA,SAAS,YAAY,KAAA,EAKnB;AACA,EAAA,OACE,OAAO,UAAU,QAAA,IACjB,KAAA,KAAU,QACV,SAAA,IAAa,KAAA,IACb,OAAQ,KAAA,CAA+B,OAAA,KAAY,QAAA;AAEvD;AAtJA,IAAA,kBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,6BAAA,GAAA;AAMA,IAAA,aAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACgIA,eAAsB,kBAAkB,IAAA,EAAiC;AACvE,EAAA,OAAO,cAAA,CAAe,WAAA,EAAY,CAAE,QAAA,CAAS,IAAI,CAAA;AACnD;AAxIA,IAgBM,cAAA;AAhBN,IAAA,eAAA,GAAA,KAAA,CAAA;AAAA,EAAA,0BAAA,GAAA;AAOA,IAAA,WAAA,EAAA;AASA,IAAM,cAAA,GAAN,MAAM,eAAA,CAAe;AAAA,MACnB,OAAe,QAAA;AAAA,MACP,UAAA,GAAuC,IAAA;AAAA,MACvC,WAAA,GAAoC,IAAA;AAAA,MACpC,SAAA,GAA0B,IAAA;AAAA,MAE1B,WAAA,GAAc;AAAA,MAEtB;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAA,GAA8B;AACnC,QAAA,IAAI,CAAC,gBAAe,QAAA,EAAU;AAC5B,UAAA,eAAA,CAAe,QAAA,GAAW,IAAI,eAAA,EAAe;AAAA,QAC/C;AACA,QAAA,OAAO,eAAA,CAAe,QAAA;AAAA,MACxB;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,IAAA,GAAsB;AAClC,QAAA,IAAI,IAAA,CAAK,UAAA,KAAe,IAAA,IAAQ,IAAA,CAAK,cAAc,IAAA,EAAM;AACvD,UAAA;AAAA,QACF;AAEA,QAAA,IAAI,KAAK,WAAA,EAAa;AACpB,UAAA,OAAO,IAAA,CAAK,WAAA;AAAA,QACd;AAEA,QAAA,IAAA,CAAK,eAAe,YAAY;AAC9B,UAAA,IAAI;AAGF,YAAA,MAAM,kBAAkB,kCAAkC,CAAA;AAC1D,YAAA,MAAM,kBAAkB,wCAAwC,CAAA;AAIhE,YAAA,IAAA,CAAK,UAAA,GAAa,MAAM,iBAAA,CAAkB,sCAAsC,CAAA;AAAA,UAClF,SAAS,GAAA,EAAK;AACZ,YAAA,IAAA,CAAK,SAAA,GAAY,eAAe,KAAA,GAAQ,GAAA,GAAM,IAAI,KAAA,CAAM,MAAA,CAAO,GAAG,CAAC,CAAA;AACnE,YAAA,MAAM,IAAI,KAAA,CAAM,CAAA,sCAAA,EAAyC,IAAA,CAAK,SAAA,CAAU,OAAO,CAAA,CAAE,CAAA;AAAA,UACnF;AAAA,QACF,CAAA,GAAG;AAEH,QAAA,OAAO,IAAA,CAAK,WAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MASA,MAAM,SAAS,IAAA,EAAiC;AAC9C,QAAA,IAAI,IAAA,CAAK,eAAe,IAAA,EAAM;AAC5B,UAAA,MAAM,KAAK,IAAA,EAAK;AAAA,QAClB;AAEA,QAAA,IAAI,KAAK,SAAA,EAAW;AAClB,UAAA,MAAM,IAAA,CAAK,SAAA;AAAA,QACb;AAEA,QAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,UAAA,MAAM,IAAI,MAAM,2BAA2B,CAAA;AAAA,QAC7C;AAEA,QAAA,OAAO,IAAA,CAAK,WAAW,IAAI,CAAA;AAAA,MAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAOA,SAAA,GAAY;AACV,QAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,UAAA,OAAO,IAAA;AAAA,QACT;AACA,QAAA,OAAO,KAAK,UAAA,CAAW,MAAA;AAAA,MACzB;AAAA;AAAA;AAAA;AAAA;AAAA,MAMA,OAAO,MAAA,GAAe;AACpB,QAAA,eAAA,CAAe,QAAA,GAAW,IAAI,eAAA,EAAe;AAAA,MAC/C;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACwIO,SAAS,kBAAkB,KAAA,EAA0C;AAC1E,EAAA,OACE,OAAO,KAAA,KAAU,QAAA,IACjB,KAAA,KAAU,QACV,MAAA,IAAU,KAAA,IACV,OAAQ,KAAA,CAA0B,SAAS,QAAA,IAC3C,SAAA,IAAa,KAAA,IACb,OAAQ,MAA0B,OAAA,KAAY,QAAA;AAElD;AA9PA,IAqCa,WAAA;AArCb,IAAA,iBAAA,GAAA,KAAA,CAAA;AAAA,EAAA,4BAAA,GAAA;AAOA,IAAA,kBAAA,EAAA;AAEA,IAAA,aAAA,EAAA;AACA,IAAA,eAAA,EAAA;AA2BO,IAAM,WAAA,GAAN,MAAM,YAAA,SAAoB,KAAA,CAAM;AAAA,MAC5B,IAAA;AAAA,MAET,YAAY,IAAA,EAAuB;AACjC,QAAA,KAAA,CAAM,KAAK,OAAO,CAAA;AAClB,QAAA,IAAA,CAAK,IAAA,GAAO,aAAA;AAGZ,QAAA,IAAA,CAAK,OAAO,MAAA,CAAO,MAAA,CAAO,EAAE,GAAG,MAAM,CAAA;AAGrC,QAAA,KAAA,CAAM,iBAAA,CAAkB,MAAM,YAAW,CAAA;AAAA,MAC3C;AAAA;AAAA;AAAA;AAAA,MAKA,MAAA,GAA0B;AACxB,QAAA,OAAO,IAAA,CAAK,IAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,KAAA,EAA6B;AAClC,QAAA,OAAO,IAAA,CAAK,UAAU,IAAA,CAAK,IAAI,MAAM,IAAA,CAAK,SAAA,CAAU,MAAM,IAAI,CAAA;AAAA,MAChE;AAAA;AAAA;AAAA;AAAA,MAKA,gBAAA,GAAkC;AAChC,QAAA,OAAO,KAAK,IAAA,CAAK,cAAA,IAAkB,gBAAgB,IAAA,CAAK,IAAA,CAAK,YAAY,QAAQ,CAAA;AAAA,MACnF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAuBA,OAAO,IAAA,CAAK,KAAA,EAAgC,OAAA,GAA8B,EAAC,EAAgB;AAEzF,QAAA,IAAI,iBAAiB,YAAA,EAAa;AAEhC,UAAA,MAAM,oBAAoB,OAAA,CAAQ,QAAA,IAAY,KAAA,CAAM,IAAA,CAAK,YAAY,QAAA,CAAS,MAAA;AAE9E,UAAA,MAAM,sBAAA,GAAyB,gBAAgB,iBAAiB,CAAA;AAGhE,UAAA,MAAM,SAAA,GAAA,iBAAY,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAEzC,UAAA,OAAO,IAAI,YAAA,CAAY;AAAA,YACrB,GAAG,KAAA,CAAM,IAAA;AAAA,YACT,GAAG,OAAA;AAAA,YACH,IAAA,EAAM,OAAA,CAAQ,IAAA,IAAQ,KAAA,CAAM,IAAA,CAAK,IAAA;AAAA,YACjC,OAAA,EAAS,MAAM,IAAA,CAAK,OAAA;AAAA,YACpB,QAAA,EAAU,iBAAA;AAAA;AAAA,YACV,cAAA,EAAgB,sBAAA;AAAA;AAAA,YAChB;AAAA;AAAA,WACD,CAAA;AAAA,QACH;AAGA,QAAA,IAAI,iBAAA,CAAkB,KAAK,CAAA,EAAG;AAC5B,UAAA,MAAM,kBAAkB,kBAAA,EAAmB;AAE3C,UAAA,MAAM,iBAAA,GAAoB,OAAA,CAAQ,QAAA,IAAY,KAAA,CAAM,YAAY,eAAA,CAAgB,IAAA;AAEhF,UAAA,MAAM,sBAAA,GAAyB,gBAAgB,iBAAiB,CAAA;AAEhE,UAAA,OAAO,IAAI,YAAA,CAAY;AAAA,YACrB,GAAG,KAAA;AAAA,YACH,GAAG,OAAA;AAAA,YACH,QAAA,EAAU,iBAAA;AAAA,YACV,cAAA,EAAgB,sBAAA;AAAA;AAAA,YAChB,WAAW,KAAA,CAAM,SAAA,IAAA,iBAAa,IAAI,IAAA,IAAO,WAAA;AAAY,WACtD,CAAA;AAAA,QACH;AAGA,QAAA,OAAO,YAAA,CAAY,SAAA,CAAU,KAAA,EAAO,OAAO,CAAA;AAAA,MAC7C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAkBA,OAAO,SAAA,CAAU,GAAA,EAAsB,OAAA,GAA8B,EAAC,EAAgB;AACpF,QAAA,MAAM,IAAA,GAAO,QAAQ,IAAA,IAAQ,eAAA;AAC7B,QAAA,MAAM,QAAA,GAAW,OAAA,CAAQ,QAAA,IAAY,QAAA,CAAS,MAAA;AAC9C,QAAA,MAAM,aAAA,GAAgB,gBAAgB,QAAQ,CAAA;AAE9C,QAAA,MAAM,OAAA,GAAU,oBAAoB,GAAG,CAAA;AACvC,QAAA,MAAM,KAAA,GAAQ,kBAAkB,GAAG,CAAA;AAEnC,QAAA,MAAM,IAAA,GAAwB;AAAA,UAC5B,IAAA;AAAA,UACA,OAAA;AAAA,UACA,QAAA;AAAA,UACA,cAAA,EAAgB,aAAA;AAAA,UAChB,SAAA,EAAA,iBAAW,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAAA,UAClC,GAAG,OAAA;AAAA,UACH,OAAA,EAAS;AAAA,YACP,GAAG,OAAA,CAAQ,OAAA;AAAA,YACX,YAAA,EAAc,GAAA,YAAe,KAAA,GAAQ,GAAA,CAAI,OAAO,OAAO,GAAA;AAAA,YACvD;AAAA,WACF;AAAA,UACA,UAAU,KAAA,IAAS;AAAA,SACrB;AAEA,QAAA,OAAO,IAAI,aAAY,IAAI,CAAA;AAAA,MAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAgBA,aAAa,SAAS,IAAA,EAAiC;AACrD,QAAA,OAAO,kBAAkB,IAAI,CAAA;AAAA,MAC/B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAoBA,OAAO,aAAA,CACL,KAAA,EACA,OAAA,GAA8C,EAAC,EACxC;AACP,QAAA,MAAM,MAAA,GAAS,OAAA,CAAQ,MAAA,IAAU,OAAA,CAAQ,KAAA;AACzC,QAAA,MAAM,QAAA,GAAW,KAAA,CAAM,IAAA,CAAK,SAAA,IAAa,CAAA;AAGzC,QAAA,MAAA,CAAO,KAAK,SAAA,CAAU,KAAA,CAAM,QAAO,EAAG,IAAA,EAAM,CAAC,CAAC,CAAA;AAG9C,QAAA,OAAA,CAAQ,KAAK,QAAQ,CAAA;AAAA,MACvB;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACnOA,IAAAA,YAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,qBAAA,GAAA;AAUA,IAAA,gBAAA,EAAA;AAOA,IAAA,iBAAA,EAAA;AAQA,IAAA,kBAAA,EAAA;AAMA,IAAA,aAAA,EAAA;AAcA,IAAA,eAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC7CA,IAAAkB,eAAAA,GAAA,EAAA;AAAA,QAAA,CAAAA,eAAAA,EAAA;AAAA,EAAA,gBAAA,EAAA,MAAA;AAAA,CAAA,CAAA;AAAA,IAYa,gBAAA;AAZb,IAAAlB,YAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,2BAAA,GAAA;AAMA,IAAAA,YAAAA,EAAAA;AAMO,IAAM,gBAAA,GAAN,MAAM,iBAAA,SAAyB,WAAA,CAAY;AAAA,MAChC,YAAA;AAAA,MAEhB,WAAA,CAAY,OAAA,EAAiB,YAAA,EAAuB,KAAA,EAAe;AAEjE,QAAA,IAAI,SAAA;AAEJ,QAAA,IAAI,KAAA,EAAO;AACT,UAAA,SAAA,GAAY,WAAA,CAAY,UAAU,KAAA,EAAO;AAAA,YACvC,IAAA,EAAM,oBAAA;AAAA,YACN,QAAA,EAAU,MAAA;AAAA,YACV,OAAA,EAAS,EAAE,YAAA;AAAa,WACzB,CAAA,CAAE,IAAA;AAAA,QACL,CAAA,MAAO;AACL,UAAA,SAAA,GAAY;AAAA,YACV,IAAA,EAAM,oBAAA;AAAA,YACN,OAAA;AAAA,YACA,QAAA,EAAU,MAAA;AAAA,YACV,SAAA,EAAA,iBAAW,IAAI,IAAA,EAAK,EAAE,WAAA,EAAY;AAAA,YAClC,OAAA,EAAS,EAAE,YAAA;AAAa,WAC1B;AAAA,QACF;AAEA,QAAA,KAAA,CAAM,SAAS,CAAA;AACf,QAAA,IAAA,CAAK,IAAA,GAAO,kBAAA;AACZ,QAAA,IAAA,CAAK,YAAA,GAAe,YAAA;AAGpB,QAAA,IAAI,MAAM,iBAAA,EAAmB;AAC3B,UAAA,KAAA,CAAM,iBAAA,CAAkB,MAAM,iBAAgB,CAAA;AAAA,QAChD;AAAA,MACF;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,SAAS,aAAA,EAA2C;AACzD,QAAA,MAAM,OAAA,GAAU,CAAA;AAAA;AAAA,EAA4C,aAAA,CAAc,GAAA,CAAI,CAAC,CAAA,KAAM,CAAA,IAAA,EAAO,CAAC,CAAA,CAAE,CAAA,CAAE,IAAA,CAAK,IAAI,CAAC,CAAA,CAAA;AAC3G,QAAA,OAAO,IAAI,kBAAiB,OAAO,CAAA;AAAA,MACrC;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,gBAAA,CACL,IAAA,EACA,WAAA,EACkB;AAClB,QAAA,MAAM,UAAA,GAAa,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,OAAO,CAAA,CAAE,MAAA;AACrE,QAAA,MAAM,YAAA,GAAe,YAAY,MAAA,CAAO,CAAC,MAAM,CAAA,CAAE,QAAA,KAAa,MAAM,CAAA,CAAE,MAAA;AAEtE,QAAA,IAAI,OAAA,GAAU,yBAAyB,IAAI;AAAA,CAAA;AAC3C,QAAA,OAAA,IAAW,CAAA,mBAAA,EAAsB,UAAU,CAAA,WAAA,EAAc,YAAY,CAAA;AAAA,CAAA;AAGrE,QAAA,MAAM,kBAAA,GAAqB,WAAA,CAAY,KAAA,CAAM,CAAA,EAAG,CAAC,CAAA;AACjD,QAAA,KAAA,MAAW,QAAQ,kBAAA,EAAoB;AACrC,UAAA,OAAA,IAAW,CAAA,IAAA,EAAO,KAAK,OAAO,CAAA,CAAA;AAC9B,UAAA,IAAI,KAAK,OAAA,EAAS;AAChB,YAAA,OAAA,IAAW,CAAA,IAAA,EAAO,KAAK,OAAO,CAAA,CAAA;AAAA,UAChC;AACA,UAAA,OAAA,IAAW,IAAA;AAAA,QACb;AAEA,QAAA,IAAI,WAAA,CAAY,SAAS,CAAA,EAAG;AAC1B,UAAA,OAAA,IAAW,CAAA,UAAA,EAAa,WAAA,CAAY,MAAA,GAAS,CAAC,CAAA;AAAA,CAAA;AAAA,QAChD;AAEA,QAAA,OAAO,IAAI,iBAAA,CAAiB,OAAA,EAAS,IAAI,CAAA;AAAA,MAC3C;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,mBAAmB,OAAA,EAAmC;AAC3D,QAAA,MAAM,OAAA,GAAU,oDAAoD,OAAO;AAAA,CAAA;AAC3E,QAAA,OAAO,IAAI,iBAAA,CAAiB,OAAA,EAAS,OAAO,CAAA;AAAA,MAC9C;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAA,CAAY,IAAA,EAAc,KAAA,EAAgC;AAC/D,QAAA,MAAM,OAAA,GAAU,kCAAkC,IAAI;AAAA,EAAK,MAAM,OAAO,CAAA,CAAA;AACxE,QAAA,OAAO,IAAI,iBAAA,CAAiB,OAAA,EAAS,IAAA,EAAM,KAAK,CAAA;AAAA,MAClD;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,UAAA,CAAW,IAAA,EAAc,KAAA,EAAgC;AAC9D,QAAA,MAAM,OAAA,GAAU,iCAAiC,IAAI;AAAA,EAAK,MAAM,OAAO,CAAA,CAAA;AACvE,QAAA,OAAO,IAAI,iBAAA,CAAiB,OAAA,EAAS,IAAA,EAAM,KAAK,CAAA;AAAA,MAClD;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;ACnDA,eAAsB,qBACpB,OAAA,EACiC;AAEjC,EAAA,IAAI,SAAS,IAAA,EAAM;AACjB,IAAA,MAAM,MAAA,GAAS,MAAM,UAAA,CAAW,OAAA,CAAQ,IAAI,CAAA;AAC5C,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAM,gBAAA,CAAiB,QAAA,CAAS,CAAC,OAAA,CAAQ,IAAI,CAAC,CAAA;AAAA,IAChD;AACA,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,CAAQ,IAAA,EAAM,QAAQ,UAAA,EAAW;AAAA,EAClD;AAGA,EAAA,MAAM,OAAA,GAAU,OAAA,CAAQ,GAAA,CAAI,oBAAoB,CAAA;AAChD,EAAA,IAAI,OAAA,EAAS;AACX,IAAA,MAAM,MAAA,GAAS,MAAM,UAAA,CAAW,OAAO,CAAA;AACvC,IAAA,IAAI,CAAC,MAAA,EAAQ;AACX,MAAA,MAAM,gBAAA,CAAiB,mBAAmB,OAAO,CAAA;AAAA,IACnD;AACA,IAAA,OAAO,EAAE,IAAA,EAAM,OAAA,EAAS,MAAA,EAAQ,KAAA,EAAM;AAAA,EACxC;AAGA,EAAA,MAAM,QAAA,GAAW,OAAA,EAAS,QAAA,IAAY,OAAA,CAAQ,GAAA,EAAI;AAClD,EAAA,MAAM,MAAA,GAAS,MAAM,eAAA,CAAgB,QAAQ,CAAA;AAC7C,EAAA,IAAI,MAAA,EAAQ;AACV,IAAA,OAAO,EAAE,IAAA,EAAM,MAAA,EAAQ,MAAA,EAAQ,UAAA,EAAW;AAAA,EAC5C;AAEA,EAAA,OAAO,IAAA;AACT;AAYA,eAAe,gBAAgB,QAAA,EAA0C;AACvE,EAAA,IAAI,UAAA,GAAa,QAAA;AACjB,EAAA,MAAM,gBAA0B,EAAC;AAEjC,EAAA,KAAA,IAAS,CAAA,GAAI,CAAA,EAAG,CAAA,GAAI,yBAAA,EAA2B,CAAA,EAAA,EAAK;AAClD,IAAA,MAAM,aAAA,GAAgBP,IAAAA,CAAK,UAAA,EAAY,gBAAA,EAAkB,qBAAqB,CAAA;AAC9E,IAAA,aAAA,CAAc,KAAK,aAAa,CAAA;AAEhC,IAAA,IAAI,MAAM,UAAA,CAAW,aAAa,CAAA,EAAG;AACnC,MAAA,OAAO,aAAA;AAAA,IACT;AAEA,IAAA,MAAM,SAAA,GAAYI,QAAQ,UAAU,CAAA;AACpC,IAAA,IAAI,cAAc,UAAA,EAAY;AAE5B,MAAA,MAAM,gBAAA,CAAiB,SAAS,aAAa,CAAA;AAAA,IAC/C;AACA,IAAA,UAAA,GAAa,SAAA;AAAA,EACf;AAGA,EAAA,MAAM,gBAAA,CAAiB,SAAS,aAAa,CAAA;AAC/C;AAQA,eAAe,WAAW,IAAA,EAAgC;AACxD,EAAA,IAAI;AACF,IAAA,MAAMF,OAAO,IAAI,CAAA;AACjB,IAAA,OAAO,IAAA;AAAA,EACT,CAAA,CAAA,MAAQ;AACN,IAAA,OAAO,KAAA;AAAA,EACT;AACF;AAtIA,IAAA,cAAA,GAAA,KAAA,CAAA;AAAA,EAAA,8BAAA,GAAA;AAWA,IAAA,cAAA,EAAA;AAMA,IAAAK,YAAAA,EAAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACjBA,IAAA,cAAA,GAAA,EAAA;AAAA,QAAA,CAAA,cAAA,EAAA;AAAA,EAAA,kBAAA,EAAA,MAAA,kBAAA;AAAA,EAAA,iBAAA,EAAA,MAAA,iBAAA;AAAA,EAAA,YAAA,EAAA,MAAA;AAAA,CAAA,CAAA;AA8BA,SAASG,YAAc,GAAA,EAAW;AAEhC,EAAA,MAAA,CAAO,OAAO,GAAG,CAAA;AAGjB,EAAA,MAAA,CAAO,mBAAA,CAAoB,GAAG,CAAA,CAAE,OAAA,CAAQ,CAAC,IAAA,KAAS;AAEhD,IAAA,MAAM,KAAA,GAAS,IAAY,IAAI,CAAA;AAC/B,IAAA,IACE,KAAA,KAAU,IAAA,KACT,OAAO,KAAA,KAAU,QAAA,IAAY,OAAO,KAAA,KAAU,UAAA,CAAA,IAC/C,CAAC,MAAA,CAAO,QAAA,CAAS,KAAK,CAAA,EACtB;AACA,MAAAA,YAAW,KAAK,CAAA;AAAA,IAClB;AAAA,EACF,CAAC,CAAA;AAED,EAAA,OAAO,GAAA;AACT;AAkBA,eAAsB,aAAa,OAAA,EAAkD;AAEnF,EAAA,IAAI,SAAS,QAAA,EAAU;AACrB,IAAA,OAAOA,WAAAA,CAAW,eAAA,CAAgB,OAAA,CAAQ,QAAQ,CAAC,CAAA;AAAA,EACrD;AAGA,EAAA,IAAI,CAAC,SAAS,SAAA,EAAW;AACvB,IAAA,MAAM,SAAS,iBAAA,EAAkB;AACjC,IAAA,IAAI,MAAA,EAAQ;AACV,MAAA,OAAO,MAAA;AAAA,IACT;AAAA,EACF;AAGA,EAAA,MAAM,SAAA,GAAY,MAAM,oBAAA,CAAqB;AAAA,IAC3C,MAAM,OAAA,EAAS,IAAA;AAAA,IACf,UAAU,OAAA,EAAS;AAAA,GACpB,CAAA;AAED,EAAA,IAAI,CAAC,SAAA,EAAW;AACd,IAAA,MAAM,gBAAA,CAAiB,QAAA,CAAS,EAAE,CAAA;AAAA,EACpC;AAGA,EAAA,IAAI,OAAA;AACJ,EAAA,IAAI;AACF,IAAA,OAAA,GAAU,MAAMT,QAAAA,CAAS,SAAA,CAAU,IAAA,EAAM,OAAO,CAAA;AAAA,EAClD,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,gBAAA,CAAiB,UAAA;AAAA,MACrB,SAAA,CAAU,IAAA;AAAA,MACV,iBAAiB,KAAA,GAAQ,KAAA,GAAQ,IAAI,KAAA,CAAM,MAAA,CAAO,KAAK,CAAC;AAAA,KAC1D;AAAA,EACF;AAGA,EAAA,IAAI,MAAA;AACJ,EAAA,IAAI;AACF,IAAA,MAAA,GAASL,MAAU,OAAO,CAAA;AAAA,EAC5B,SAAS,KAAA,EAAO;AACd,IAAA,MAAM,gBAAA,CAAiB,WAAA;AAAA,MACrB,SAAA,CAAU,IAAA;AAAA,MACV,iBAAiB,KAAA,GAAQ,KAAA,GAAQ,IAAI,KAAA,CAAM,MAAA,CAAO,KAAK,CAAC;AAAA,KAC1D;AAAA,EACF;AAGA,EAAA,IAAI,CAAC,SAAS,cAAA,EAAgB;AAC5B,IAAA,MAAM,MAAA,GAAS,MAAM,sBAAA,CAAuB,MAAA,EAAQ,sBAAsB,CAAA;AAE1E,IAAA,IAAI,CAAC,OAAO,KAAA,EAAO;AACjB,MAAA,MAAM,gBAAA,CAAiB,gBAAA,CAAiB,SAAA,CAAU,IAAA,EAAM,OAAO,WAAW,CAAA;AAAA,IAC5E;AAAA,EACF;AAGA,EAAA,MAAM,QAAA,GAAWc,WAAAA,CAAW,eAAA,CAAgB,MAAM,CAAC,CAAA;AAGnD,EAAA,iBAAA,CAAkB,QAAQ,CAAA;AAE1B,EAAA,OAAO,QAAA;AACT;AAhIA,IAAAgB,YAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,2BAAA,GAAA;AAQA,IAAA,WAAA,EAAA;AACA,IAAA,UAAA,EAAA;AACA,IAAA,cAAA,EAAA;AACA,IAAA,cAAA,EAAA;AACA,IAAAnB,YAAAA,EAAAA;AAAA,EAAA;AAAA,CAAA,CAAA;ACQO,SAAS,SAAA,CAAU,OAAA,GAAsB,EAAC,EAAY;AAC3D,EAAA,MAAM,OAAA,GAAU,IAAI,OAAA,EAAQ;AAE5B,EAAA,OAAA,CACG,KAAK,iBAAiB,CAAA,CACtB,YAAY,iEAAiE,CAAA,CAC7E,QAAQ,OAAO,CAAA;AAGlB,EAAA,OAAA,CACG,QAAQ,MAAM,CAAA,CACd,WAAA,CAAY,sCAAsC,EAClD,QAAA,CAAS,UAAA,EAAY,0BAA0B,CAAA,CAC/C,OAAO,mBAAA,EAAqB,gCAAgC,EAC5D,MAAA,CAAO,OAAO,QAAiB,UAAA,KAAsC;AACpE,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,MAAM,WAAA,CAAY,MAAA,EAAQ;AAAA,QACxC,OAAA,EAAS,UAAA,EAAY,OAAA,IAAW,OAAA,CAAQ;AAAA,OACzC,CAAA;AAED,MAAA,IAAI,OAAA,CAAQ,WAAW,CAAA,EAAG;AACxB,QAAA,OAAA,CAAQ,IAAI,kBAAkB,CAAA;AAC9B,QAAA;AAAA,MACF;AAEA,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,MAAA,EAAS,OAAA,CAAQ,MAAM,CAAA;AAAA,CAAe,CAAA;AAClD,MAAA,KAAA,MAAW,UAAU,OAAA,EAAS;AAC5B,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,EAAA,EAAK,MAAA,CAAO,EAAE,CAAA,CAAE,CAAA;AAC5B,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,YAAA,EAAe,MAAA,CAAO,MAAM,CAAA,CAAE,CAAA;AAC1C,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,MAAA,CAAO,YAAY,CAAA,CAAE,CAAA;AAC9C,QAAA,IAAI,OAAO,WAAA,EAAa;AACtB,UAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,iBAAA,EAAoB,MAAA,CAAO,WAAW,CAAA,CAAE,CAAA;AAAA,QACtD;AACA,QAAA,OAAA,CAAQ,GAAA,EAAI;AAAA,MACd;AAAA,IACF,SAAS,KAAA,EAAO;AACd,MAAA,OAAA,CAAQ,KAAA,CAAM,wBAAA,EAA2B,KAAA,CAAgB,OAAO,CAAA;AAChE,MAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,IAChB;AAAA,EACF,CAAC,CAAA;AAGH,EAAA,OAAA,CACG,QAAQ,MAAM,CAAA,CACd,WAAA,CAAY,qBAAqB,EACjC,cAAA,CAAe,kBAAA,EAAoB,mBAAmB,CAAA,CACtD,OAAO,mBAAA,EAAqB,gCAAgC,CAAA,CAC5D,MAAA,CAAO,OAAO,UAAA,KAAuD;AACpE,IAAA,IAAI;AACF,MAAA,MAAM,WAAW,iBAAA,CAAkB;AAAA,QACjC,OAAA,EAAS,UAAA,CAAW,OAAA,IAAW,OAAA,CAAQ;AAAA,OACxC,CAAA;AACD,MAAA,MAAM,MAAA,GAAS,MAAM,QAAA,CAAS,SAAA,CAAU,WAAW,QAAQ,CAAA;AAE3D,MAAA,OAAA,CAAQ,IAAI,mBAAmB,CAAA;AAC/B,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,MAAA,EAAS,MAAA,CAAO,EAAE,CAAA,CAAE,CAAA;AAChC,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,MAAA,CAAO,MAAM,CAAA,CAAE,CAAA;AACxC,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,QAAA,EAAW,MAAA,CAAO,IAAI,CAAA,CAAE,CAAA;AACpC,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,iBAAA,EAAoB,MAAA,CAAO,YAAY,CAAA,CAAE,CAAA;AACrD,MAAA,IAAI,OAAO,OAAA,EAAS;AAClB,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,WAAA,EAAc,MAAA,CAAO,OAAO,CAAA,CAAE,CAAA;AAAA,MAC5C;AACA,MAAA,IAAI,OAAO,WAAA,EAAa;AACtB,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,eAAA,EAAkB,MAAA,CAAO,WAAW,CAAA,CAAE,CAAA;AAAA,MACpD;AACA,MAAA,IAAI,OAAO,WAAA,EAAa;AACtB,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,gBAAA,EAAmB,MAAA,CAAO,WAAW,CAAA,CAAE,CAAA;AAAA,MACrD;AAGA,MAAA,MAAM,OAAA,GAAU,MAAMN,QAAAA,CAAS,MAAA,CAAO,MAAM,OAAO,CAAA;AACnD,MAAA,OAAA,CAAQ,IAAI,mBAAmB,CAAA;AAC/B,MAAA,OAAA,CAAQ,IAAI,OAAO,CAAA;AAAA,IACrB,SAAS,KAAA,EAAO;AACd,MAAA,OAAA,CAAQ,KAAA,CAAM,uBAAA,EAA0B,KAAA,CAAgB,OAAO,CAAA;AAC/D,MAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,IAChB;AAAA,EACF,CAAC,CAAA;AAGH,EAAA,OAAA,CACG,OAAA,CAAQ,UAAU,CAAA,CAClB,WAAA,CAAY,mCAAmC,EAC/C,cAAA,CAAe,kBAAA,EAAoB,+BAA+B,CAAA,CAClE,QAAA,CAAS,QAAA,EAAU,uBAAuB,CAAA,CAC1C,MAAA,CAAO,cAAA,EAAgB,oDAAoD,CAAA,CAC3E,MAAA,CAAO,sBAAA,EAAwB,uBAAuB,CAAA,CACtD,MAAA,CAAO,mBAAA,EAAqB,gCAAgC,CAAA,CAC5D,MAAA;AAAA,IACC,OACE,MACA,UAAA,KAMG;AACH,MAAA,IAAI;AACF,QAAA,IAAI,MAAA;AAEJ,QAAA,IAAI,WAAW,SAAA,EAAW;AAExB,UAAA,MAAM,SAAA,GAAY,MAAM,iBAAA,CAAkB,UAAA,CAAW,UAAU,CAAA;AAC/D,UAAA,IAAI,CAAC,SAAA,EAAW;AACd,YAAA,OAAA,CAAQ,MAAM,0EAAqE,CAAA;AACnF,YAAA,OAAA,CAAQ,MAAM,kEAAkE,CAAA;AAChF,YAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,UAChB;AAGA,UAAA,MAAM,WAAW,iBAAA,CAAkB;AAAA,YACjC,OAAA,EAAS,UAAA,CAAW,OAAA,IAAW,OAAA,CAAQ;AAAA,WACxC,CAAA;AACD,UAAA,MAAM,MAAA,GAAS,MAAM,QAAA,CAAS,SAAA,CAAU,WAAW,QAAQ,CAAA;AAE3D,UAAA,OAAA,CAAQ,IAAI,4BAA4B,CAAA;AACxC,UAAA,MAAA,GAAS,MAAM,mBAAA,CAAoB,MAAA,CAAO,IAAA,EAAM,IAAA,EAAM,WAAW,UAAU,CAAA;AAAA,QAC7E,CAAA,MAAO;AAEL,UAAA,OAAA,CAAQ,IAAI,yBAAyB,CAAA;AACrC,UAAA,MAAA,GAAS,MAAM,sBAAA,CAAuB,IAAA,EAAM,UAAA,CAAW,QAAA,EAAU;AAAA,YAC/D,OAAA,EAAS,UAAA,CAAW,OAAA,IAAW,OAAA,CAAQ;AAAA,WACxC,CAAA;AAAA,QACH;AAEA,QAAA,IAAI,OAAO,KAAA,EAAO;AAChB,UAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,0BAAA,EAAwB,MAAA,CAAO,MAAM,CAAA,CAAA,CAAG,CAAA;AACpD,UAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,QAChB,CAAA,MAAO;AACL,UAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,0BAAA,EAAwB,MAAA,CAAO,MAAM,CAAA,CAAA,CAAG,CAAA;AACpD,UAAA,OAAA,CAAQ,IAAI,gBAAgB,CAAA;AAC5B,UAAA,OAAA,CAAQ,GAAA,CAAI,iBAAA,CAAkB,MAAA,CAAO,WAAW,CAAC,CAAA;AACjD,UAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,QAChB;AAAA,MACF,SAAS,KAAA,EAAO;AACd,QAAA,OAAA,CAAQ,KAAA,CAAM,wBAAA,EAA2B,KAAA,CAAgB,OAAO,CAAA;AAChE,QAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,MAChB;AAAA,IACF;AAAA,GACF;AAGF,EAAA,OAAA,CACG,OAAA,CAAQ,iBAAiB,CAAA,CACzB,WAAA,CAAY,+BAA+B,CAAA,CAC3C,QAAA,CAAS,QAAA,EAAU,yBAAyB,CAAA,CAC5C,MAAA,CAAO,OAAO,IAAA,KAAiB;AAC9B,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,MAAMA,QAAAA,CAAS,IAAA,EAAM,OAAO,CAAA;AAC5C,MAAA,MAAM,EAAE,cAAA,EAAA0B,eAAAA,EAAe,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,cAAA,EAAA,EAAA,iBAAA,CAAA,CAAA;AACjC,MAAA,MAAM,MAAA,GAAS,MAAMA,eAAAA,CAAe,OAAO,CAAA;AAE3C,MAAA,IAAI,OAAO,KAAA,EAAO;AAChB,QAAA,OAAA,CAAQ,IAAI,wBAAmB,CAAA;AAC/B,QAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,MAChB,CAAA,MAAO;AACL,QAAA,OAAA,CAAQ,IAAI,0BAAqB,CAAA;AACjC,QAAA,OAAA,CAAQ,IAAI,gBAAgB,CAAA;AAC5B,QAAA,OAAA,CAAQ,GAAA,CAAI,iBAAA,CAAkB,MAAA,CAAO,WAAW,CAAC,CAAA;AACjD,QAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,MAChB;AAAA,IACF,SAAS,KAAA,EAAO;AACd,MAAA,OAAA,CAAQ,KAAA,CAAM,0BAAA,EAA6B,KAAA,CAAgB,OAAO,CAAA;AAClE,MAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,IAChB;AAAA,EACF,CAAC,CAAA;AAGH,EAAA,OAAA,CACG,OAAA,CAAQ,WAAW,CAAA,CACnB,WAAA,CAAY,2CAA2C,CAAA,CACvD,QAAA,CAAS,UAAU,0BAA0B,CAAA,CAC7C,OAAO,WAAA,EAAa,qCAAqC,EACzD,MAAA,CAAO,qBAAA,EAAuB,wCAAwC,CAAA,CACtE,MAAA,CAAO,OAAO,IAAA,EAAc,UAAA,KAAuD;AAClF,IAAA,IAAI;AACF,MAAA,MAAM,OAAA,GAAU,MAAM1B,QAAAA,CAAS,IAAA,EAAM,OAAO,CAAA;AAC5C,MAAA,MAAM,UAAA,GAAa,gBAAgB,OAAA,EAAS;AAAA,QAC1C,SAAS,UAAA,CAAW;AAAA,OACrB,CAAA;AAED,MAAA,IAAI,WAAW,MAAA,EAAQ;AACrB,QAAA,MAAM2B,SAAAA,CAAU,UAAA,CAAW,MAAA,EAAQ,UAAA,EAAY,OAAO,CAAA;AACtD,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,oCAAA,EAAkC,UAAA,CAAW,MAAM,CAAA,CAAE,CAAA;AAAA,MACnE,CAAA,MAAO;AACL,QAAA,OAAA,CAAQ,IAAI,UAAU,CAAA;AAAA,MACxB;AAAA,IACF,SAAS,KAAA,EAAO;AACd,MAAA,OAAA,CAAQ,KAAA,CAAM,2BAAA,EAA8B,KAAA,CAAgB,OAAO,CAAA;AACnE,MAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,IAChB;AAAA,EACF,CAAC,CAAA;AAGH,EAAA,OAAA,CACG,OAAA,CAAQ,SAAS,CAAA,CACjB,WAAA,CAAY,2CAA2C,CAAA,CACvD,QAAA,CAAS,SAAA,EAAW,mBAAmB,CAAA,CACvC,QAAA,CAAS,WAAW,oBAAoB,CAAA,CACxC,OAAO,mBAAA,EAAqB,yBAAyB,EACrD,MAAA,CAAO,OAAO,KAAA,EAAe,KAAA,EAAe,UAAA,KAA6C;AACxF,IAAA,IAAI;AACF,MAAA,MAAM,QAAA,GAAW,MAAM3B,QAAAA,CAAS,KAAA,EAAO,OAAO,CAAA;AAC9C,MAAA,MAAM,QAAA,GAAW,MAAMA,QAAAA,CAAS,KAAA,EAAO,OAAO,CAAA;AAE9C,MAAA,MAAM,MAAA,GAAS,cAAA,CAAe,QAAA,EAAU,QAAQ,CAAA;AAEhD,MAAA,IAAI,OAAO,KAAA,EAAO;AAChB,QAAA,OAAA,CAAQ,IAAI,uCAAkC,CAAA;AAAA,MAChD,CAAA,MAAO;AACL,QAAA,OAAA,CAAQ,IAAI,uBAAkB,CAAA;AAAA,MAChC;AAEA,MAAA,IAAI,WAAW,cAAA,EAAgB;AAC7B,QAAA,OAAA,CAAQ,IAAI,wBAAwB,CAAA;AACpC,QAAA,OAAA,CAAQ,GAAA,CAAI,OAAO,WAAW,CAAA;AAC9B,QAAA,OAAA,CAAQ,IAAI,wBAAwB,CAAA;AACpC,QAAA,OAAA,CAAQ,GAAA,CAAI,OAAO,WAAW,CAAA;AAAA,MAChC;AAEA,MAAA,OAAA,CAAQ,IAAA,CAAK,MAAA,CAAO,KAAA,GAAQ,CAAA,GAAI,CAAC,CAAA;AAAA,IACnC,SAAS,KAAA,EAAO;AACd,MAAA,OAAA,CAAQ,KAAA,CAAM,0BAAA,EAA6B,KAAA,CAAgB,OAAO,CAAA;AAClE,MAAA,OAAA,CAAQ,KAAK,CAAC,CAAA;AAAA,IAChB;AAAA,EACF,CAAC,CAAA;AAGH,EAAA,OAAA,CACG,OAAA,CAAQ,QAAQ,CAAA,CAChB,WAAA,CAAY,qDAAqD,CAAA,CACjE,cAAA,CAAe,kBAAA,EAAoB,qBAAqB,EACxD,cAAA,CAAe,cAAA,EAAgB,kBAAkB,CAAA,CACjD,OAAO,SAAA,EAAW,yBAAA,EAA2B,KAAK,CAAA,CAClD,OAAO,iBAAA,EAAmB,6BAA6B,CAAA,CACvD,MAAA,CAAO,iBAAiB,sCAAsC,CAAA,CAC9D,MAAA,CAAO,mBAAA,EAAqB,kCAAkC,MAAM,CAAA,CACpE,MAAA,CAAO,mBAAA,EAAqB,gCAAgC,CAAA,CAC5D,MAAA;AAAA,IACC,OAAO,UAAA,KAQD;AACJ,MAAA,IAAI;AACF,QAAA,MAAM,EAAE,YAAA,EAAA4B,aAAAA,EAAa,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,WAAA,EAAA,EAAA,cAAA,CAAA,CAAA;AAC/B,QAAA,MAAM,EAAE,SAAA,EAAAC,UAAAA,EAAU,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAE5B,QAAA,MAAM,MAAA,GAAS,MAAMD,aAAAA,CAAa;AAAA,UAChC,UAAU,UAAA,CAAW,QAAA;AAAA,UACrB,SAAS,UAAA,CAAW,GAAA;AAAA,UACpB,iBAAA,EAAmB,WAAW,UAAA,IAAc,IAAA;AAAA,UAC5C,QAAA,EAAU,WAAW,QAAA,IAAY,IAAA;AAAA,UACjC,SAAA,EAAW,WAAW,KAAA,IAAS,KAAA;AAAA,UAC/B,MAAA,EAAS,WAAW,MAAA,IAAuC,MAAA;AAAA,UAC3D,OAAA,EAAS,UAAA,CAAW,OAAA,IAAW,OAAA,CAAQ;AAAA,SACxC,CAAA;AAED,QAAA,OAAA,CAAQ,IAAI,qCAAgC,CAAA;AAC5C,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,cAAA,EAAiB,MAAA,CAAO,QAAQ,CAAA,CAAE,CAAA;AAC9C,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,WAAA,EAAc,MAAA,CAAO,OAAO,CAAA,CAAE,CAAA;AAC1C,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,WAAA,EAAc,MAAA,CAAO,MAAM,CAAA,CAAE,CAAA;AAEzC,QAAA,IAAI,OAAO,UAAA,EAAY;AACrB,UAAA,OAAA,CAAQ,IAAI,eAAe,CAAA;AAC3B,UAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,aAAA,EAAgB,MAAA,CAAO,UAAA,CAAW,gBAAgB,CAAA,CAAE,CAAA;AAChE,UAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,YAAA,EAAe,MAAA,CAAO,UAAA,CAAW,eAAe,CAAA,CAAE,CAAA;AAC9D,UAAA,IAAI,MAAA,CAAO,WAAW,QAAA,EAAU;AAC9B,YAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,aAAA,EAAgB,MAAA,CAAO,UAAA,CAAW,QAAQ,CAAA,CAAE,CAAA;AAAA,UAC1D;AACA,UAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,aAAA,EAAgB,MAAA,CAAO,UAAA,CAAW,WAAW,CAAA,CAAE,CAAA;AAAA,QAC7D;AAEA,QAAA,OAAA,CAAQ,IAAA,CAAKC,WAAU,YAAY,CAAA;AAAA,MACrC,SAAS,KAAA,EAAO;AACd,QAAA,MAAM,EAAE,SAAA,EAAAA,UAAAA,EAAU,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAC5B,QAAA,MAAM,EAAE,mBAAAC,kBAAAA,EAAmB,qBAAA,EAAAC,wBAAuB,iBAAA,EAAArC,kBAAAA,KAAsB,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,WAAA,EAAA,EAAA,cAAA,CAAA,CAAA;AAI9E,QAAA,OAAA,CAAQ,KAAA,CAAM,8BAAA,EAA4B,KAAA,CAAgB,OAAO,CAAA;AAGjE,QAAA,IAAI,iBAAiBoC,kBAAAA,EAAmB;AACtC,UAAA,IAAI,MAAM,OAAA,EAAS;AACjB,YAAA,OAAA,CAAQ,KAAA,CAAM,CAAA,gBAAA,EAAmB,KAAA,CAAM,OAAO,CAAA,CAAE,CAAA;AAAA,UAClD;AAGA,UAAA,QAAQ,MAAM,MAAA;AAAQ,YACpB,KAAKpC,kBAAAA,CAAkB,WAAA;AAAA,YACvB,KAAKA,kBAAAA,CAAkB,YAAA;AACrB,cAAA,OAAA,CAAQ,IAAA,CAAKmC,WAAU,qBAAqB,CAAA;AAC5C,cAAA;AAAA,YAEF,KAAKnC,kBAAAA,CAAkB,cAAA;AACrB,cAAA,OAAA,CAAQ,IAAA,CAAKmC,WAAU,qBAAqB,CAAA;AAC5C,cAAA;AAAA,YAEF;AAEE,cAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,YAAY,CAAA;AAAA;AACvC,QACF;AAEA,QAAA,IAAI,iBAAiBE,sBAAAA,EAAuB;AAE1C,UAAA,MAAM,QAAA,GAAW,KAAA,CAAM,OAAA,CAAQ,WAAA,EAAY;AAE3C,UAAA,IAAI,QAAA,CAAS,QAAA,CAAS,WAAW,CAAA,EAAG;AAClC,YAAA,OAAA,CAAQ,IAAA,CAAKF,WAAU,mBAAmB,CAAA;AAAA,UAC5C;AAGA,UAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,iBAAiB,CAAA;AAAA,QAC1C;AAEA,QAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,YAAY,CAAA;AAAA,MACrC;AAAA,IACF;AAAA,GACF;AAGF,EAAA,OAAA,CACG,QAAQ,eAAe,CAAA,CACvB,WAAA,CAAY,iDAAiD,EAC7D,MAAA,CAAO,eAAA,EAAiB,2BAA2B,CAAA,CACnD,OAAO,QAAA,EAAU,gBAAgB,CAAA,CACjC,MAAA,CAAO,OAAO,UAAA,KAAkD;AAC/D,IAAA,IAAI;AACF,MAAA,MAAM,EAAE,YAAA,EAAAG,aAAAA,EAAa,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,cAAA,CAAA,CAAA;AAC/B,MAAA,MAAM,EAAE,SAAA,EAAAH,UAAAA,EAAU,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAE5B,MAAA,MAAM,WAAW,MAAMG,aAAAA,CAAa,EAAE,IAAA,EAAM,UAAA,CAAW,MAAM,CAAA;AAE7D,MAAA,IAAI,WAAW,IAAA,EAAM;AACnB,QAAA,OAAA,CAAQ,IAAI,IAAA,CAAK,SAAA,CAAU,QAAA,EAAU,IAAA,EAAM,CAAC,CAAC,CAAA;AAAA,MAC/C,CAAA,MAAO;AACL,QAAA,OAAA,CAAQ,IAAI,yBAAyB,CAAA;AACrC,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,eAAA,EAAkB,QAAA,CAAS,GAAA,CAAI,WAAW,CAAA,CAAE,CAAA;AACxD,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,UAAA,EAAa,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA,CAAE,CAAA;AAC9C,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,cAAA,EAAiB,QAAA,CAAS,GAAA,CAAI,UAAU,CAAA,CAAE,CAAA;AACtD,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,eAAA,EAAkB,QAAA,CAAS,GAAA,CAAI,WAAW,CAAA,CAAE,CAAA;AACxD,QAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,eAAA,EAAkB,QAAA,CAAS,GAAA,CAAI,WAAW,CAAA,CAAE,CAAA;AAExD,QAAA,IAAI,SAAS,QAAA,EAAU;AACrB,UAAA,OAAA,CAAQ,IAAI,aAAa,CAAA;AACzB,UAAA,IAAI,QAAA,CAAS,SAAS,OAAA,EAAS;AAC7B,YAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,WAAA,EAAc,QAAA,CAAS,QAAA,CAAS,OAAO,CAAA,CAAE,CAAA;AAAA,UACvD;AACA,UAAA,IAAI,QAAA,CAAS,SAAS,mBAAA,EAAqB;AACzC,YAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,YAAA,EAAe,QAAA,CAAS,QAAA,CAAS,mBAAmB,CAAA,CAAE,CAAA;AAAA,UACpE;AACA,UAAA,IAAI,QAAA,CAAS,SAAS,mBAAA,EAAqB;AACzC,YAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,aAAA,EAAgB,QAAA,CAAS,QAAA,CAAS,mBAAmB,CAAA,CAAE,CAAA;AAAA,UACrE;AACA,UAAA,IAAI,QAAA,CAAS,SAAS,WAAA,EAAa;AACjC,YAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,eAAA,EAAkB,QAAA,CAAS,QAAA,CAAS,WAAW,CAAA,CAAE,CAAA;AAAA,UAC/D;AAAA,QACF;AAAA,MACF;AAEA,MAAA,OAAA,CAAQ,IAAA,CAAKH,WAAU,YAAY,CAAA;AAAA,IACrC,SAAS,KAAA,EAAO;AACd,MAAA,MAAM,EAAE,SAAA,EAAAA,UAAAA,EAAU,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAC5B,MAAA,MAAM,EAAE,gBAAA,EAAAI,iBAAAA,EAAiB,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAEnC,MAAA,OAAA,CAAQ,KAAA,CAAM,iCAAA,EAA+B,KAAA,CAAgB,OAAO,CAAA;AAEpE,MAAA,IAAI,iBAAiBA,iBAAAA,EAAkB;AACrC,QAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,QAAA,CAAS,WAAW,CAAA,EAAG;AACvC,UAAA,OAAA,CAAQ,IAAA,CAAKJ,WAAU,mBAAmB,CAAA;AAAA,QAC5C;AACA,QAAA,IAAI,KAAA,CAAM,QAAQ,QAAA,CAAS,SAAS,KAAK,KAAA,CAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA,EAAG;AAC7E,UAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,iBAAiB,CAAA;AAAA,QAC1C;AAAA,MACF;AAEA,MAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,YAAY,CAAA;AAAA,IACrC;AAAA,EACF,CAAC,CAAA;AAGH,EAAA,OAAA,CACG,OAAA,CAAQ,mBAAmB,CAAA,CAC3B,WAAA,CAAY,8CAA8C,CAAA,CAC1D,QAAA,CAAS,QAAA,EAAU,0CAA0C,CAAA,CAC7D,MAAA,CAAO,OAAO,IAAA,KAAkB;AAC/B,IAAA,IAAI;AACF,MAAA,MAAM,EAAE,YAAA,EAAAG,aAAAA,EAAa,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,cAAA,CAAA,CAAA;AAC/B,MAAA,MAAM,EAAE,SAAA,EAAAH,UAAAA,EAAU,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAE5B,MAAA,OAAA,CAAQ,IAAI,oCAAoC,CAAA;AAEhD,MAAA,MAAM,WAAW,MAAMG,aAAAA,CAAa,EAAE,IAAA,EAAM,MAAM,CAAA;AAElD,MAAA,OAAA,CAAQ,IAAI,0BAAqB,CAAA;AACjC,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,WAAA,EAAc,QAAA,CAAS,GAAA,CAAI,WAAW,CAAA,CAAE,CAAA;AACpD,MAAA,OAAA,CAAQ,GAAA,CAAI,CAAA,WAAA,EAAc,QAAA,CAAS,GAAA,CAAI,MAAM,CAAA,CAAE,CAAA;AAE/C,MAAA,OAAA,CAAQ,IAAA,CAAKH,WAAU,YAAY,CAAA;AAAA,IACrC,SAAS,KAAA,EAAO;AACd,MAAA,MAAM,EAAE,SAAA,EAAAA,UAAAA,EAAU,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAC5B,MAAA,MAAM,EAAE,gBAAA,EAAAI,iBAAAA,EAAiB,GAAI,MAAM,OAAA,CAAA,OAAA,EAAA,CAAA,IAAA,CAAA,OAAA,YAAA,EAAA,EAAA,eAAA,CAAA,CAAA;AAEnC,MAAA,OAAA,CAAQ,KAAA,CAAM,oCAAA,EAAkC,KAAA,CAAgB,OAAO,CAAA;AAEvE,MAAA,IAAI,iBAAiBA,iBAAAA,EAAkB;AACrC,QAAA,IAAI,KAAA,CAAM,OAAA,CAAQ,QAAA,CAAS,WAAW,CAAA,EAAG;AACvC,UAAA,OAAA,CAAQ,IAAA,CAAKJ,WAAU,mBAAmB,CAAA;AAAA,QAC5C;AACA,QAAA,IAAI,KAAA,CAAM,QAAQ,QAAA,CAAS,SAAS,KAAK,KAAA,CAAM,OAAA,CAAQ,QAAA,CAAS,YAAY,CAAA,EAAG;AAC7E,UAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,iBAAiB,CAAA;AAAA,QAC1C;AAAA,MACF;AAEA,MAAA,OAAA,CAAQ,IAAA,CAAKA,WAAU,YAAY,CAAA;AAAA,IACrC;AAAA,EACF,CAAC,CAAA;AAEH,EAAA,OAAO,OAAA;AACT;AA9bA,IAAA,QAAA,GAAA,KAAA,CAAA;AAAA,EAAA,mBAAA,GAAA;AAUA,IAAA,kBAAA,EAAA;AACA,IAAA,eAAA,EAAA;AACA,IAAAjC,cAAAA,EAAAA;AAEA,IAAA,UAAA,EAAA;AACA,IAAA,cAAA,EAAA;AAkbA,IAAA,IAAI,YAAY,GAAA,KAAQ,CAAA,OAAA,EAAU,QAAQ,IAAA,CAAK,CAAC,CAAC,CAAA,CAAA,EAAI;AACnD,MAAA,MAAM,UAAU,SAAA,EAAU;AAC1B,MAAA,OAAA,CAAQ,KAAA,CAAM,QAAQ,IAAI,CAAA;AAAA,IAC5B;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACpcA,IAAA,WAAA,GAAA,KAAA,CAAA;AAAA,EAAA,qBAAA,GAAA;AAUA,IAAA,QAAA,EAAA;AAEA,IAAA,WAAA,EAAA;AAEA,IAAA,WAAA,EAAA;AAEA,IAAA,kBAAA,EAAA;AAMA,IAAA,eAAA,EAAA;AAEA,IAAAA,cAAAA,EAAAA;AA6BA,IAAA,UAAA,EAAA;AAUA,IAAA,cAAA,EAAA;AAAA,EAAA;AAAA,CAAA,CAAA;;;AC8DA,eAAsB,qBAAqB,KAAA,EAAkC;AAC3E,EAAA,OAAO,gBAAA,CAAiB,WAAA,EAAY,CAAE,QAAA,CAAS,KAAK,CAAA;AACtD;AAQA,eAAsB,sBAAsB,MAAA,EAAqC;AAC/E,EAAA,KAAA,MAAW,SAAS,MAAA,EAAQ;AAC1B,IAAA,IAAI,CAAE,MAAM,oBAAA,CAAqB,KAAK,CAAA,EAAI;AACxC,MAAA,OAAO,KAAA;AAAA,IACT;AAAA,EACF;AACA,EAAA,OAAO,IAAA;AACT;AAKO,SAASsC,oBAAAA,GAAsB;AACpC,EAAA,OAAO,gBAAA,CAAiB,WAAA,EAAY,CAAE,SAAA,EAAU;AAClD;AAKO,SAASC,wBACd,MAAA,EACQ;AACR,EAAA,OAAO,MAAA,CACJ,GAAA,CAAI,CAAC,GAAA,KAAQ;AACZ,IAAA,MAAM,IAAA,GAAO,IAAI,YAAA,IAAgB,QAAA;AACjC,IAAA,MAAM,OAAA,GAAU,IAAI,OAAA,IAAW,mBAAA;AAC/B,IAAA,OAAO,CAAA,EAAG,IAAI,CAAA,EAAA,EAAK,OAAO,CAAA,CAAA;AAAA,EAC5B,CAAC,CAAA,CACA,IAAA,CAAK,IAAI,CAAA;AACd;AAQA,eAAsB,wBAAwB,KAAA,EAA+B;AAC3E,EAAA,IAAI,CAAE,MAAM,oBAAA,CAAqB,KAAK,CAAA,EAAI;AACxC,IAAA,MAAM,SAASD,oBAAAA,EAAoB;AACnC,IAAA,MAAM,OAAA,GAAU,MAAA,GAASC,uBAAAA,CAAuB,MAAM,CAAA,GAAI,iCAAA;AAC1D,IAAA,MAAM,IAAI,KAAA,CAAM,CAAA,uBAAA,EAA0B,OAAO,CAAA,CAAE,CAAA;AAAA,EACrD;AACF;AAlLA,IAeM,gBAAA;AAfN,IAAAC,gBAAAA,GAAA,KAAA,CAAA;AAAA,EAAA,6BAAA,GAAA;AAMA,IAAA,WAAA,EAAA;AASA,IAAM,gBAAA,GAAN,MAAM,iBAAA,CAAiB;AAAA,MACrB,OAAe,QAAA;AAAA,MACP,UAAA,GAAuC,IAAA;AAAA,MACvC,WAAA,GAAoC,IAAA;AAAA,MACpC,SAAA,GAA0B,IAAA;AAAA,MAE1B,WAAA,GAAc;AAAA,MAEtB;AAAA;AAAA;AAAA;AAAA,MAKA,OAAO,WAAA,GAAgC;AACrC,QAAA,IAAI,CAAC,kBAAiB,QAAA,EAAU;AAC9B,UAAA,iBAAA,CAAiB,QAAA,GAAW,IAAI,iBAAA,EAAiB;AAAA,QACnD;AACA,QAAA,OAAO,iBAAA,CAAiB,QAAA;AAAA,MAC1B;AAAA;AAAA;AAAA;AAAA,MAKA,MAAc,IAAA,GAAsB;AAClC,QAAA,IAAI,IAAA,CAAK,UAAA,KAAe,IAAA,IAAQ,IAAA,CAAK,cAAc,IAAA,EAAM;AACvD,UAAA;AAAA,QACF;AAEA,QAAA,IAAI,KAAK,WAAA,EAAa;AACpB,UAAA,OAAO,IAAA,CAAK,WAAA;AAAA,QACd;AAEA,QAAA,IAAA,CAAK,eAAe,YAAY;AAC9B,UAAA,IAAI;AAEF,YAAA,IAAA,CAAK,UAAA,GAAa,MAAM,iBAAA,CAAkB,4CAA4C,CAAA;AAAA,UACxF,SAAS,GAAA,EAAK;AACZ,YAAA,IAAA,CAAK,SAAA,GAAY,eAAe,KAAA,GAAQ,GAAA,GAAM,IAAI,KAAA,CAAM,MAAA,CAAO,GAAG,CAAC,CAAA;AACnE,YAAA,MAAM,IAAI,KAAA,CAAM,CAAA,wCAAA,EAA2C,IAAA,CAAK,SAAA,CAAU,OAAO,CAAA,CAAE,CAAA;AAAA,UACrF;AAAA,QACF,CAAA,GAAG;AAEH,QAAA,OAAO,IAAA,CAAK,WAAA;AAAA,MACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,MAQA,MAAM,SAAS,KAAA,EAAkC;AAC/C,QAAA,IAAI,IAAA,CAAK,eAAe,IAAA,EAAM;AAC5B,UAAA,MAAM,KAAK,IAAA,EAAK;AAAA,QAClB;AAEA,QAAA,IAAI,KAAK,SAAA,EAAW;AAClB,UAAA,MAAM,IAAA,CAAK,SAAA;AAAA,QACb;AAEA,QAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,UAAA,MAAM,IAAI,MAAM,2BAA2B,CAAA;AAAA,QAC7C;AAEA,QAAA,OAAO,IAAA,CAAK,WAAW,KAAK,CAAA;AAAA,MAC9B;AAAA;AAAA;AAAA;AAAA,MAKA,SAAA,GAAY;AACV,QAAA,IAAI,CAAC,KAAK,UAAA,EAAY;AACpB,UAAA,OAAO,IAAA;AAAA,QACT;AACA,QAAA,OAAO,KAAK,UAAA,CAAW,MAAA;AAAA,MACzB;AAAA;AAAA;AAAA;AAAA;AAAA,MAMA,OAAO,MAAA,GAAe;AACpB,QAAA,iBAAA,CAAiB,QAAA,GAAW,IAAI,iBAAA,EAAiB;AAAA,MACnD;AAAA,KACF;AAAA,EAAA;AAAA,CAAA,CAAA;;;ACnGA,IAOaC,QAAAA,CAAAA,CA0BA;AAjCb,IAAA,cAAA,GAAA,KAAA,CAAA;AAAA,EAAA,wBAAA,GAAA;AAUA,IAAA,aAAA,EAAA;AAEA,IAAA,aAAA,EAAA;AAwBA,IAAA,YAAA,EAAA;AACA,IAAA,UAAA,EAAA;AACA,IAAA,cAAA,EAAA;AAGA,IAAA,aAAA,EAAA;AAmBA,IAAA,UAAA,EAAA;AAOA,IAAAD,gBAAAA,EAAAA;AA5DO,IAAMC,QAAAA,GAAU,OAAA;AA0BhB,IAAM,OAAA,GAAU,IAAI,eAAA,EAAgB;AAAA,EAAA;AAAA,CAAA,CAAA","file":"index.js","sourcesContent":["/**\n * Counter metric implementation\n *\n * Monotonically increasing counter for counting events\n */\n\nimport type { MetricName } from './types.js';\n\n/**\n * Counter metric\n *\n * Monotonically increasing value for counting events.\n * Use for metrics like request counts, error counts, etc.\n */\nexport class Counter {\n private value = 0;\n\n constructor(public readonly name: MetricName) {}\n\n /**\n * Increment counter by delta (default: 1)\n *\n * @param delta - Amount to increment (must be non-negative)\n * @throws {Error} If delta is negative\n *\n * @example\n * ```typescript\n * counter.inc(); // Increment by 1\n * counter.inc(5); // Increment by 5\n * ```\n */\n inc(delta = 1): void {\n if (delta < 0) {\n throw new Error(`Counter delta must be non-negative, got: ${delta}`);\n }\n this.value += delta;\n }\n\n /**\n * Get current counter value\n */\n getValue(): number {\n return this.value;\n }\n\n /**\n * Reset counter to zero\n */\n reset(): void {\n this.value = 0;\n }\n}\n","/**\n * Gauge metric implementation\n *\n * Gauge for arbitrary values that can go up and down\n */\n\nimport type { MetricName } from './types.js';\n\n/**\n * Gauge metric\n *\n * Arbitrary value that can increase or decrease.\n * Use for metrics like current connections, memory usage, temperature, etc.\n */\nexport class Gauge {\n private value = 0;\n\n constructor(public readonly name: MetricName) {}\n\n /**\n * Set gauge to specific value\n *\n * @param value - New gauge value (can be any number, including negative)\n *\n * @example\n * ```typescript\n * gauge.set(42); // Set to 42\n * gauge.set(-10); // Negative values allowed\n * gauge.set(0); // Reset to zero\n * ```\n */\n set(value: number): void {\n this.value = value;\n }\n\n /**\n * Increment gauge by delta (default: 1)\n *\n * @param delta - Amount to increment (can be negative)\n */\n inc(delta = 1): void {\n this.value += delta;\n }\n\n /**\n * Decrement gauge by delta (default: 1)\n *\n * @param delta - Amount to decrement (can be negative)\n */\n dec(delta = 1): void {\n this.value -= delta;\n }\n\n /**\n * Get current gauge value\n */\n getValue(): number {\n return this.value;\n }\n\n /**\n * Reset gauge to zero\n */\n reset(): void {\n this.value = 0;\n }\n}\n","/**\n * Taxonomy loader for metrics definitions\n *\n * Loads and caches metrics taxonomy from config/crucible-ts/taxonomy/metrics.yaml\n * Provides default histogram buckets per ADR-0007\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { join } from 'node:path';\nimport { parse as parseYaml } from 'yaml';\nimport type { MetricName, MetricUnit } from './types.js';\n\n/**\n * Metric definition from taxonomy\n */\nexport interface MetricDefinition {\n name: MetricName;\n unit: MetricUnit;\n description: string;\n}\n\n/**\n * Taxonomy structure\n */\nexport interface MetricsTaxonomy {\n version: string;\n defaults: {\n histogram_buckets: {\n ms_metrics: number[];\n };\n };\n metrics: MetricDefinition[];\n}\n\n/**\n * Default histogram buckets for _ms metrics (ADR-0007)\n * [1, 5, 10, 50, 100, 500, 1000, 5000, 10000] milliseconds\n */\nexport const DEFAULT_MS_BUCKETS = [1, 5, 10, 50, 100, 500, 1000, 5000, 10000];\n\n/**\n * Singleton taxonomy loader\n */\nclass TaxonomyLoader {\n private static instance: TaxonomyLoader;\n private taxonomy: MetricsTaxonomy | null = null;\n private loadPromise: Promise<MetricsTaxonomy> | null = null;\n private loadError: Error | null = null;\n\n private constructor() {\n // Private constructor for singleton\n }\n\n /**\n * Get singleton instance\n */\n static getInstance(): TaxonomyLoader {\n if (!TaxonomyLoader.instance) {\n TaxonomyLoader.instance = new TaxonomyLoader();\n }\n return TaxonomyLoader.instance;\n }\n\n /**\n * Load taxonomy from YAML file\n */\n private async load(): Promise<MetricsTaxonomy> {\n if (this.taxonomy !== null) {\n return this.taxonomy;\n }\n\n if (this.loadError !== null) {\n throw this.loadError;\n }\n\n if (this.loadPromise) {\n return this.loadPromise;\n }\n\n this.loadPromise = (async () => {\n try {\n // Resolve path to taxonomy file\n // From src/telemetry/ → ../../config/crucible-ts/taxonomy/metrics.yaml\n const taxonomyPath = join(\n __dirname,\n '..',\n '..',\n 'config',\n 'crucible-ts',\n 'taxonomy',\n 'metrics.yaml',\n );\n\n const content = await readFile(taxonomyPath, 'utf-8');\n this.taxonomy = parseYaml(content) as MetricsTaxonomy;\n\n return this.taxonomy;\n } catch (err) {\n this.loadError = err instanceof Error ? err : new Error(String(err));\n throw new Error(`Failed to load metrics taxonomy: ${this.loadError.message}`);\n }\n })();\n\n return this.loadPromise;\n }\n\n /**\n * Get taxonomy (async)\n */\n async getTaxonomy(): Promise<MetricsTaxonomy> {\n return this.load();\n }\n\n /**\n * Get metric definition by name\n */\n async getMetric(name: MetricName): Promise<MetricDefinition | undefined> {\n const taxonomy = await this.load();\n return taxonomy.metrics.find((m) => m.name === name);\n }\n\n /**\n * Get default unit for metric\n */\n async getDefaultUnit(name: MetricName): Promise<MetricUnit | undefined> {\n const metric = await this.getMetric(name);\n return metric?.unit;\n }\n\n /**\n * Get default histogram buckets for metric\n * Returns ADR-0007 buckets for _ms metrics, undefined for others\n */\n async getDefaultBuckets(name: MetricName): Promise<number[] | undefined> {\n // Check if metric name ends with _ms\n if (name.endsWith('_ms')) {\n const taxonomy = await this.load();\n return taxonomy.defaults.histogram_buckets.ms_metrics;\n }\n return undefined;\n }\n\n /**\n * Check if metric name is valid (exists in taxonomy)\n */\n async isValidMetricName(name: string): Promise<boolean> {\n try {\n const taxonomy = await this.load();\n return taxonomy.metrics.some((m) => m.name === name);\n } catch {\n return false;\n }\n }\n\n /**\n * Reset loader state (for testing)\n * @internal\n */\n static _reset(): void {\n TaxonomyLoader.instance = new TaxonomyLoader();\n }\n}\n\n/**\n * Get metrics taxonomy\n *\n * @returns Promise resolving to taxonomy\n */\nexport async function getTaxonomy(): Promise<MetricsTaxonomy> {\n return TaxonomyLoader.getInstance().getTaxonomy();\n}\n\n/**\n * Get metric definition by name\n *\n * @param name - Metric name\n * @returns Promise resolving to metric definition or undefined\n */\nexport async function getMetric(name: MetricName): Promise<MetricDefinition | undefined> {\n return TaxonomyLoader.getInstance().getMetric(name);\n}\n\n/**\n * Get default unit for metric from taxonomy\n *\n * @param name - Metric name\n * @returns Promise resolving to unit or undefined\n */\nexport async function getDefaultUnit(name: MetricName): Promise<MetricUnit | undefined> {\n return TaxonomyLoader.getInstance().getDefaultUnit(name);\n}\n\n/**\n * Get default histogram buckets for metric\n *\n * Returns ADR-0007 buckets ([1, 5, 10, 50, 100, 500, 1000, 5000, 10000]) for\n * metrics ending with _ms, undefined for others.\n *\n * @param name - Metric name\n * @returns Promise resolving to bucket array or undefined\n *\n * @example\n * ```typescript\n * const buckets = await getDefaultBuckets('config_load_ms');\n * // Returns [1, 5, 10, 50, 100, 500, 1000, 5000, 10000]\n * ```\n */\nexport async function getDefaultBuckets(name: MetricName): Promise<number[] | undefined> {\n return TaxonomyLoader.getInstance().getDefaultBuckets(name);\n}\n\n/**\n * Check if metric name is valid (exists in taxonomy)\n *\n * @param name - Metric name to check\n * @returns Promise resolving to true if valid\n */\nexport async function isValidMetricName(name: string): Promise<boolean> {\n return TaxonomyLoader.getInstance().isValidMetricName(name);\n}\n\n// Export for testing\nexport { TaxonomyLoader };\n","/**\n * Histogram metric implementation\n *\n * Histogram with OTLP-compatible cumulative buckets, auto-applying ADR-0007\n * default buckets for _ms metrics.\n */\n\nimport { DEFAULT_MS_BUCKETS } from './taxonomy.js';\nimport type { HistogramBucket, HistogramOptions, HistogramSummary, MetricName } from './types.js';\n\n/**\n * Histogram metric\n *\n * Tracks distribution of values using cumulative buckets (OTLP-compatible).\n * Automatically applies ADR-0007 default buckets for _ms metrics.\n */\nexport class Histogram {\n private count = 0;\n private sum = 0;\n private bucketCounts: Map<number, number> = new Map();\n private readonly buckets: number[];\n\n constructor(\n public readonly name: MetricName,\n options?: HistogramOptions,\n ) {\n // Determine buckets: custom > ADR-0007 defaults for _ms metrics > empty\n if (options?.buckets) {\n this.buckets = [...options.buckets].sort((a, b) => a - b);\n } else if (name.endsWith('_ms')) {\n this.buckets = [...DEFAULT_MS_BUCKETS];\n } else {\n this.buckets = [];\n }\n\n // Initialize bucket counts\n for (const bucket of this.buckets) {\n this.bucketCounts.set(bucket, 0);\n }\n }\n\n /**\n * Record an observation\n *\n * @param value - Value to observe (typically a duration in ms)\n *\n * @example\n * ```typescript\n * const start = performance.now();\n * // ... operation ...\n * histogram.observe(performance.now() - start);\n * ```\n */\n observe(value: number): void {\n this.count++;\n this.sum += value;\n\n // Update cumulative bucket counts\n for (const bucket of this.buckets) {\n if (value <= bucket) {\n this.bucketCounts.set(bucket, (this.bucketCounts.get(bucket) || 0) + 1);\n }\n }\n }\n\n /**\n * Get histogram summary\n *\n * Returns OTLP-compatible histogram summary with cumulative bucket counts.\n */\n getSummary(): HistogramSummary {\n const buckets: HistogramBucket[] = this.buckets.map((le) => ({\n le,\n count: this.bucketCounts.get(le) || 0,\n }));\n\n return {\n count: this.count,\n sum: this.sum,\n buckets,\n };\n }\n\n /**\n * Get current observation count\n */\n getCount(): number {\n return this.count;\n }\n\n /**\n * Get sum of all observed values\n */\n getSum(): number {\n return this.sum;\n }\n\n /**\n * Get average of observed values\n */\n getAverage(): number {\n return this.count > 0 ? this.sum / this.count : 0;\n }\n\n /**\n * Reset histogram to initial state\n */\n reset(): void {\n this.count = 0;\n this.sum = 0;\n for (const bucket of this.buckets) {\n this.bucketCounts.set(bucket, 0);\n }\n }\n}\n","/**\n * Metrics registry - central registry for all metrics\n *\n * Provides singleton registry for counters, gauges, and histograms.\n * Exports events in schema-compliant format.\n */\n\nimport { Counter } from './counter.js';\nimport { Gauge } from './gauge.js';\nimport { Histogram } from './histogram.js';\nimport { getDefaultUnit } from './taxonomy.js';\nimport type { FlushOptions, HistogramOptions, MetricName, MetricsEvent } from './types.js';\n\n/**\n * Metrics registry\n *\n * Central registry for all metrics. Provides factory methods for counters,\n * gauges, and histograms. Exports metrics as schema-compliant events.\n */\nexport class MetricsRegistry {\n private counters: Map<MetricName, Counter> = new Map();\n private gauges: Map<MetricName, Gauge> = new Map();\n private histograms: Map<MetricName, Histogram> = new Map();\n\n /**\n * Get or create a counter\n *\n * @param name - Metric name from taxonomy\n * @returns Counter instance\n *\n * @example\n * ```typescript\n * const counter = registry.counter('schema_validations');\n * counter.inc();\n * ```\n */\n counter(name: MetricName): Counter {\n let counter = this.counters.get(name);\n if (!counter) {\n counter = new Counter(name);\n this.counters.set(name, counter);\n }\n return counter;\n }\n\n /**\n * Get or create a gauge\n *\n * @param name - Metric name from taxonomy\n * @returns Gauge instance\n *\n * @example\n * ```typescript\n * const gauge = registry.gauge('foundry_lookup_count');\n * gauge.set(42);\n * ```\n */\n gauge(name: MetricName): Gauge {\n let gauge = this.gauges.get(name);\n if (!gauge) {\n gauge = new Gauge(name);\n this.gauges.set(name, gauge);\n }\n return gauge;\n }\n\n /**\n * Get or create a histogram\n *\n * @param name - Metric name from taxonomy\n * @param options - Optional histogram options\n * @returns Histogram instance\n *\n * @example\n * ```typescript\n * // Auto-applies ADR-0007 buckets for _ms metrics\n * const histogram = registry.histogram('config_load_ms');\n * histogram.observe(42.5);\n *\n * // Custom buckets\n * const custom = registry.histogram('custom_metric', {\n * buckets: [10, 50, 100, 500, 1000]\n * });\n * ```\n */\n histogram(name: MetricName, options?: HistogramOptions): Histogram {\n let histogram = this.histograms.get(name);\n if (!histogram) {\n histogram = new Histogram(name, options);\n this.histograms.set(name, histogram);\n }\n return histogram;\n }\n\n /**\n * Export all metrics as events\n *\n * Returns array of schema-compliant MetricsEvent objects.\n * Does not clear metrics (use flush() to clear after export).\n *\n * @returns Promise resolving to array of metrics events\n *\n * @example\n * ```typescript\n * const events = await registry.export();\n * console.log(JSON.stringify(events, null, 2));\n * ```\n */\n async export(): Promise<MetricsEvent[]> {\n const events: MetricsEvent[] = [];\n const timestamp = new Date().toISOString();\n\n // Export counters\n for (const [name, counter] of this.counters) {\n const unit = await getDefaultUnit(name);\n events.push({\n timestamp,\n name,\n value: counter.getValue(),\n unit,\n });\n }\n\n // Export gauges\n for (const [name, gauge] of this.gauges) {\n const unit = await getDefaultUnit(name);\n events.push({\n timestamp,\n name,\n value: gauge.getValue(),\n unit,\n });\n }\n\n // Export histograms\n for (const [name, histogram] of this.histograms) {\n const unit = await getDefaultUnit(name);\n events.push({\n timestamp,\n name,\n value: histogram.getSummary(),\n unit,\n });\n }\n\n return events;\n }\n\n /**\n * Export and clear all metrics\n *\n * Exports metrics as events, optionally emits them via logger,\n * then resets all metrics to zero.\n *\n * @param options - Flush options\n * @returns Promise resolving to array of exported events\n *\n * @example\n * ```typescript\n * // Export and clear\n * const events = await registry.flush();\n *\n * // Export, emit to logger, and clear\n * const events = await registry.flush({\n * emit: (events) => console.log(JSON.stringify(events))\n * });\n * ```\n */\n async flush(options?: FlushOptions): Promise<MetricsEvent[]> {\n const events = await this.export();\n\n try {\n // Emit if logger provided\n if (options?.emit) {\n options.emit(events);\n }\n } finally {\n // Always clear metrics, even if emit throws\n this.clear();\n }\n\n return events;\n }\n\n /**\n * Clear all metrics (reset to zero)\n *\n * Resets all counters, gauges, and histograms to their initial state.\n */\n clear(): void {\n for (const counter of this.counters.values()) {\n counter.reset();\n }\n for (const gauge of this.gauges.values()) {\n gauge.reset();\n }\n for (const histogram of this.histograms.values()) {\n histogram.reset();\n }\n }\n\n /**\n * Get all registered metric names\n *\n * Returns array of all metric names that have been accessed\n * (counters, gauges, or histograms).\n */\n getMetricNames(): MetricName[] {\n const names = new Set<MetricName>();\n for (const name of this.counters.keys()) {\n names.add(name);\n }\n for (const name of this.gauges.keys()) {\n names.add(name);\n }\n for (const name of this.histograms.keys()) {\n names.add(name);\n }\n return Array.from(names);\n }\n\n /**\n * Get total count of registered metrics\n */\n getMetricCount(): number {\n return this.counters.size + this.gauges.size + this.histograms.size;\n }\n}\n","/**\n * Telemetry types - TypeScript types for metrics events\n *\n * Based on schemas/crucible-ts/observability/metrics/v1.0.0/metrics-event.schema.json\n * and config/crucible-ts/taxonomy/metrics.yaml\n */\n\n/**\n * Metric name from taxonomy\n * Aligned with config/crucible-ts/taxonomy/metrics.yaml#/$defs/metricName\n */\nexport type MetricName =\n | 'schema_validations'\n | 'schema_validation_errors'\n | 'config_load_ms'\n | 'config_load_errors'\n | 'pathfinder_find_ms'\n | 'pathfinder_validation_errors'\n | 'pathfinder_security_warnings'\n | 'foundry_lookup_count'\n | 'logging_emit_count'\n | 'logging_emit_latency_ms'\n | 'goneat_command_duration_ms';\n\n/**\n * Metric unit from taxonomy\n * Aligned with config/crucible-ts/taxonomy/metrics.yaml#/$defs/metricUnit\n */\nexport type MetricUnit = 'count' | 'ms' | 'bytes' | 'percent';\n\n/**\n * Histogram bucket for OTLP-compatible histograms\n */\nexport interface HistogramBucket {\n /** Upper bound (less-than-or-equal) for the bucket */\n le: number;\n /** Cumulative count up to and including this bucket */\n count: number;\n}\n\n/**\n * Histogram summary payload\n */\nexport interface HistogramSummary {\n /** Total count of observations */\n count: number;\n /** Sum of all observed values */\n sum: number;\n /** Ordered buckets with cumulative counts (OTLP-compatible) */\n buckets: HistogramBucket[];\n}\n\n/**\n * Metric value (scalar or histogram)\n */\nexport type MetricValue = number | HistogramSummary;\n\n/**\n * Metrics event structure\n * Aligned with schemas/crucible-ts/observability/metrics/v1.0.0/metrics-event.schema.json\n */\nexport interface MetricsEvent {\n /** RFC3339 timestamp of metric emission */\n timestamp: string;\n /** Metric identifier from taxonomy */\n name: MetricName;\n /** Measurement payload (scalar or histogram summary) */\n value: MetricValue;\n /** Optional key/value dimensions */\n tags?: Record<string, string>;\n /** Optional metric unit (defaults to taxonomy default) */\n unit?: MetricUnit;\n}\n\n/**\n * Histogram options for customization\n */\nexport interface HistogramOptions {\n /** Custom bucket boundaries (overrides default ADR-0007 buckets) */\n buckets?: number[];\n}\n\n/**\n * Flush options for metrics registry\n */\nexport interface FlushOptions {\n /** Optional logger function to emit metrics */\n emit?: (events: MetricsEvent[]) => void;\n}\n\n/**\n * Type guard to check if value is a histogram summary\n */\nexport function isHistogramSummary(value: unknown): value is HistogramSummary {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'count' in value &&\n 'sum' in value &&\n 'buckets' in value\n );\n}\n\n/**\n * Type guard to check if metric name is valid\n */\nexport function isValidMetricName(name: string): name is MetricName {\n const validNames: MetricName[] = [\n 'schema_validations',\n 'schema_validation_errors',\n 'config_load_ms',\n 'config_load_errors',\n 'pathfinder_find_ms',\n 'pathfinder_validation_errors',\n 'pathfinder_security_warnings',\n 'foundry_lookup_count',\n 'logging_emit_count',\n 'logging_emit_latency_ms',\n 'goneat_command_duration_ms',\n ];\n return validNames.includes(name as MetricName);\n}\n\n/**\n * Type guard to check if unit is valid\n */\nexport function isValidMetricUnit(unit: string): unit is MetricUnit {\n const validUnits: MetricUnit[] = ['count', 'ms', 'bytes', 'percent'];\n return validUnits.includes(unit as MetricUnit);\n}\n","/**\n * Schema validation errors - implements Fulmen Schema Validation Standard\n */\n\nimport type { SchemaSource, SchemaValidationDiagnostic } from './types.js';\n\n/**\n * Export error reason enum for type-safe error categorization\n */\nexport enum ExportErrorReason {\n FILE_EXISTS = 'FILE_EXISTS',\n WRITE_FAILED = 'WRITE_FAILED',\n INVALID_FORMAT = 'INVALID_FORMAT',\n PROVENANCE_FAILED = 'PROVENANCE_FAILED',\n UNKNOWN = 'UNKNOWN',\n}\n\n/**\n * Base error class for schema validation operations\n */\nexport class SchemaValidationError extends Error {\n constructor(\n message: string,\n public schemaId?: string,\n public diagnostics: SchemaValidationDiagnostic[] = [],\n public source?: SchemaSource,\n public cause?: Error,\n ) {\n super(message);\n this.name = 'SchemaValidationError';\n\n // Maintains proper stack trace for where our error was thrown (only available on V8)\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, SchemaValidationError);\n }\n }\n\n /**\n * Create error for schema not found\n */\n static schemaNotFound(schemaId: string): SchemaValidationError {\n return new SchemaValidationError(`Schema not found: ${schemaId}`, schemaId);\n }\n\n /**\n * Create error for invalid schema input\n */\n static invalidSchemaInput(source: SchemaSource, details: string): SchemaValidationError {\n return new SchemaValidationError(`Invalid schema input: ${details}`, undefined, [], source);\n }\n\n /**\n * Create error for validation failure\n */\n static validationFailed(\n schemaId: string,\n diagnostics: SchemaValidationDiagnostic[],\n source?: SchemaSource,\n ): SchemaValidationError {\n const errorCount = diagnostics.filter((d) => d.severity === 'ERROR').length;\n const warningCount = diagnostics.filter((d) => d.severity === 'WARN').length;\n\n const message = `Schema validation failed: ${errorCount} error(s), ${warningCount} warning(s)`;\n\n return new SchemaValidationError(message, schemaId, diagnostics, source);\n }\n\n /**\n * Create error for goneat binary not found\n */\n static goneatNotFound(goneatPath?: string): SchemaValidationError {\n const pathInfo = goneatPath ? ` at ${goneatPath}` : '';\n return new SchemaValidationError(\n `Goneat binary not found${pathInfo}. Falling back to AJV validation.`,\n );\n }\n\n /**\n * Create error for goneat execution failure\n */\n static goneatExecutionFailed(error: Error): SchemaValidationError {\n return new SchemaValidationError(\n 'Goneat execution failed. Falling back to AJV validation.',\n undefined,\n [],\n undefined,\n error,\n );\n }\n\n /**\n * Create error for empty schema input\n */\n static emptySchemaInput(source?: SchemaSource): SchemaValidationError {\n return new SchemaValidationError('Schema content is empty', undefined, [], source);\n }\n\n /**\n * Create error for parse failure\n */\n static parseFailed(source: SchemaSource, error: Error): SchemaValidationError {\n return new SchemaValidationError(\n `Failed to parse schema: ${error.message}`,\n undefined,\n [],\n source,\n error,\n );\n }\n\n /**\n * Create error for encoding failure\n */\n static encodingFailed(source: SchemaSource, error: Error): SchemaValidationError {\n return new SchemaValidationError(\n `Failed to encode schema: ${error.message}`,\n undefined,\n [],\n source,\n error,\n );\n }\n\n /**\n * Create error for registry operation failure\n */\n static registryError(operation: string, details: string): SchemaValidationError {\n return new SchemaValidationError(`Schema registry ${operation} failed: ${details}`);\n }\n\n /**\n * Format error for display\n */\n format(): string {\n let output = this.message;\n\n if (this.schemaId) {\n output += `\\nSchema ID: ${this.schemaId}`;\n }\n\n if (this.diagnostics.length > 0) {\n output += '\\n\\nValidation Issues:';\n this.diagnostics.forEach((diag, index) => {\n output += `\\n ${index + 1}. [${diag.severity}] ${diag.message}`;\n if (diag.pointer) {\n output += ` at ${diag.pointer}`;\n }\n if (diag.keyword) {\n output += ` (keyword: ${diag.keyword})`;\n }\n if (diag.source) {\n output += ` [${diag.source}]`;\n }\n });\n }\n\n if (this.source) {\n output += `\\n\\nSource: ${this.source.type}`;\n if (this.source.id) {\n output += ` (${this.source.id})`;\n }\n }\n\n return output;\n }\n\n /**\n * Convert to JSON representation\n */\n toJSON(): {\n name: string;\n message: string;\n schemaId?: string;\n diagnostics: SchemaValidationDiagnostic[];\n source?: SchemaSource;\n cause?: string;\n } {\n return {\n name: this.name,\n message: this.message,\n schemaId: this.schemaId,\n diagnostics: this.diagnostics,\n source: this.source,\n cause: this.cause?.message,\n };\n }\n}\n\n/**\n * Error class for schema export operations\n */\nexport class SchemaExportError extends SchemaValidationError {\n constructor(\n message: string,\n public reason: ExportErrorReason,\n public schemaId?: string,\n public outPath?: string,\n public cause?: Error,\n ) {\n super(message, schemaId, [], undefined, cause);\n this.name = 'SchemaExportError';\n\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, SchemaExportError);\n }\n }\n\n /**\n * Create error for file already exists\n */\n static fileExists(outPath: string): SchemaExportError {\n return new SchemaExportError(\n `Output file already exists: ${outPath}. Use overwrite option to replace.`,\n ExportErrorReason.FILE_EXISTS,\n undefined,\n outPath,\n );\n }\n\n /**\n * Create error for invalid export format\n */\n static invalidFormat(format: string, outPath: string): SchemaExportError {\n return new SchemaExportError(\n `Invalid export format: ${format}. Must be 'json' or 'yaml'.`,\n ExportErrorReason.INVALID_FORMAT,\n undefined,\n outPath,\n );\n }\n\n /**\n * Create error for write failure\n */\n static writeFailed(outPath: string, error: Error): SchemaExportError {\n return new SchemaExportError(\n `Failed to write schema to ${outPath}: ${error.message}`,\n ExportErrorReason.WRITE_FAILED,\n undefined,\n outPath,\n error,\n );\n }\n\n /**\n * Create error for provenance extraction failure\n */\n static provenanceFailed(details: string, error?: Error): SchemaExportError {\n return new SchemaExportError(\n `Failed to extract provenance metadata: ${details}`,\n ExportErrorReason.PROVENANCE_FAILED,\n undefined,\n undefined,\n error,\n );\n }\n}\n","/**\n * Schema validation utilities - helper functions for formatting and validation\n */\n\nimport { SchemaValidationError } from './errors.js';\nimport type { SchemaValidationDiagnostic, SchemaValidationResult } from './types.js';\n\n/**\n * Format validation diagnostics for display\n */\nexport function formatDiagnostics(diagnostics: SchemaValidationDiagnostic[]): string {\n if (diagnostics.length === 0) {\n return 'No validation issues found.';\n }\n\n const lines: string[] = [];\n const errors = diagnostics.filter((d) => d.severity === 'ERROR');\n const warnings = diagnostics.filter((d) => d.severity === 'WARN');\n\n if (errors.length > 0) {\n lines.push(`❌ ${errors.length} error(s) found:`);\n errors.forEach((diag, index) => {\n lines.push(` ${index + 1}. ${diag.message}`);\n if (diag.pointer) {\n lines.push(` at ${diag.pointer}`);\n }\n if (diag.keyword) {\n lines.push(` keyword: ${diag.keyword}`);\n }\n });\n }\n\n if (warnings.length > 0) {\n lines.push('');\n lines.push(`⚠️ ${warnings.length} warning(s) found:`);\n warnings.forEach((diag, index) => {\n lines.push(` ${index + 1}. ${diag.message}`);\n if (diag.pointer) {\n lines.push(` at ${diag.pointer}`);\n }\n });\n }\n\n return lines.join('\\n');\n}\n\n/**\n * Format validation result for display\n */\nexport function formatValidationResult(result: SchemaValidationResult): string {\n if (result.valid) {\n return '✅ Validation passed';\n }\n\n const output: string[] = [];\n output.push('❌ Validation failed');\n output.push(formatDiagnostics(result.diagnostics));\n output.push(`\\nSource: ${result.source}`);\n\n return output.join('\\n');\n}\n\n/**\n * Check if value is a SchemaValidationError\n */\nexport function isValidationError(error: unknown): error is SchemaValidationError {\n return error instanceof SchemaValidationError;\n}\n\n/**\n * Extract validation result from error or return success\n */\nexport function extractValidationResult(error: unknown): {\n valid: boolean;\n diagnostics: SchemaValidationDiagnostic[];\n source: 'ajv' | 'goneat';\n} {\n if (isValidationError(error)) {\n return {\n valid: false,\n diagnostics: error.diagnostics,\n source: error.diagnostics[0]?.source || 'ajv',\n };\n }\n\n return {\n valid: true,\n diagnostics: [],\n source: 'ajv',\n };\n}\n\n/**\n * Normalize JSON pointer path for display\n */\nexport function normalizePointer(pointer: string): string {\n if (pointer === '') {\n return 'root';\n }\n return pointer.replace(/^\\//, '').replace(/\\//g, '.');\n}\n\n/**\n * Create a validation diagnostic\n */\nexport function createDiagnostic(\n pointer: string,\n message: string,\n keyword: string,\n severity: 'ERROR' | 'WARN' = 'ERROR',\n source: 'ajv' | 'goneat' = 'ajv',\n data?: unknown,\n): SchemaValidationDiagnostic {\n return {\n pointer,\n message,\n keyword,\n severity,\n source,\n data,\n };\n}\n\n/**\n * Group diagnostics by severity\n */\nexport function groupDiagnosticsBySeverity(diagnostics: SchemaValidationDiagnostic[]): {\n errors: SchemaValidationDiagnostic[];\n warnings: SchemaValidationDiagnostic[];\n} {\n return {\n errors: diagnostics.filter((d) => d.severity === 'ERROR'),\n warnings: diagnostics.filter((d) => d.severity === 'WARN'),\n };\n}\n\n/**\n * Count diagnostics by severity\n */\nexport function countDiagnostics(diagnostics: SchemaValidationDiagnostic[]): {\n total: number;\n errors: number;\n warnings: number;\n} {\n const grouped = groupDiagnosticsBySeverity(diagnostics);\n return {\n total: diagnostics.length,\n errors: grouped.errors.length,\n warnings: grouped.warnings.length,\n };\n}\n","/**\n * Goneat bridge - Optional integration for CLI-only goneat validation\n *\n * Provides goneat validation as an opt-in alternative for CLI exploration.\n * NOT used by library consumers - AJV validation is the primary implementation.\n */\n\nimport { spawn } from 'node:child_process';\nimport { access } from 'node:fs/promises';\nimport type { SchemaValidationDiagnostic, SchemaValidationResult } from './types.js';\nimport { createDiagnostic } from './utils.js';\n\n/**\n * Goneat validation output structure\n */\ninterface GoneatValidationOutput {\n valid: boolean;\n errors?: Array<{\n path: string;\n message: string;\n keyword?: string;\n }>;\n}\n\n/**\n * Detect goneat binary location\n */\nexport async function detectGoneat(customPath?: string): Promise<string | null> {\n // Try custom path first\n if (customPath) {\n try {\n await access(customPath);\n return customPath;\n } catch {\n return null;\n }\n }\n\n // Try GONEAT_PATH environment variable\n if (process.env.GONEAT_PATH) {\n try {\n await access(process.env.GONEAT_PATH);\n return process.env.GONEAT_PATH;\n } catch {\n // Continue to next option\n }\n }\n\n // Try local bin/goneat\n try {\n await access('./bin/goneat');\n return './bin/goneat';\n } catch {\n // Continue to next option\n }\n\n // Try system PATH (assume 'goneat' command available)\n return 'goneat';\n}\n\n/**\n * Check if goneat is available\n *\n * If goneatPath is provided, use it directly to test availability.\n * Otherwise, detect goneat location first.\n */\nexport async function isGoneatAvailable(goneatPath?: string): Promise<boolean> {\n let pathToTest: string | null;\n\n if (goneatPath) {\n // Use provided path directly - don't re-detect\n // This allows testing 'goneat' command from PATH\n pathToTest = goneatPath;\n } else {\n // Detect goneat location\n pathToTest = await detectGoneat();\n if (!pathToTest) return false;\n }\n\n return new Promise((resolve) => {\n const proc = spawn(pathToTest as string, ['version'], { stdio: 'ignore' });\n proc.on('close', (code) => resolve(code === 0));\n proc.on('error', () => resolve(false));\n });\n}\n\n/**\n * Run goneat schema validation (CLI-only, opt-in)\n *\n * This is NOT used by library validation - it's purely for CLI comparison.\n * Library users get full AJV validation without goneat dependency.\n */\nexport async function runGoneatValidation(\n schemaPath: string,\n dataPath: string,\n goneatPath?: string,\n): Promise<SchemaValidationResult> {\n const detected = await detectGoneat(goneatPath);\n\n if (!detected) {\n return {\n valid: false,\n diagnostics: [\n createDiagnostic(\n '',\n 'goneat binary not found. Install goneat or specify path with --goneat-path',\n 'goneat-unavailable',\n 'ERROR',\n 'goneat',\n ),\n ],\n source: 'goneat',\n };\n }\n\n // Check availability using the detected path directly\n if (!(await isGoneatAvailable(detected))) {\n return {\n valid: false,\n diagnostics: [\n createDiagnostic(\n '',\n `goneat binary found at '${detected}' but not executable or version check failed`,\n 'goneat-not-executable',\n 'ERROR',\n 'goneat',\n ),\n ],\n source: 'goneat',\n };\n }\n\n return new Promise((resolve) => {\n const args = [\n 'schema',\n 'validate',\n '--schema',\n schemaPath,\n '--data',\n dataPath,\n '--format',\n 'json',\n ];\n const proc = spawn(detected, args);\n\n let stdout = '';\n let stderr = '';\n\n proc.stdout.on('data', (data) => {\n stdout += data.toString();\n });\n\n proc.stderr.on('data', (data) => {\n stderr += data.toString();\n });\n\n proc.on('close', (code: number | null) => {\n // Parse goneat output\n let output: GoneatValidationOutput;\n\n try {\n output = JSON.parse(stdout) as GoneatValidationOutput;\n } catch {\n // Failed to parse output, treat as error\n resolve({\n valid: false,\n diagnostics: [\n createDiagnostic(\n '',\n `goneat validation failed: ${stderr || 'unknown error'}`,\n 'goneat-error',\n 'ERROR',\n 'goneat',\n ),\n ],\n source: 'goneat',\n });\n return;\n }\n\n // Convert goneat errors to our diagnostic format\n const diagnostics: SchemaValidationDiagnostic[] =\n output.errors?.map((error) =>\n createDiagnostic(\n error.path || '',\n error.message,\n error.keyword || 'validation',\n 'ERROR',\n 'goneat',\n ),\n ) || [];\n\n resolve({\n valid: code === 0 && output.valid,\n diagnostics,\n source: 'goneat',\n });\n });\n\n proc.on('error', (error) => {\n resolve({\n valid: false,\n diagnostics: [\n createDiagnostic(\n '',\n `Failed to execute goneat: ${error.message}`,\n 'goneat-spawn-error',\n 'ERROR',\n 'goneat',\n ),\n ],\n source: 'goneat',\n });\n });\n });\n}\n","/**\n * Schema normalizer - implements schema normalization per Fulmen standard\n *\n * Provides utilities for canonicalizing and comparing schemas across\n * JSON and YAML formats with comment preservation and deterministic output.\n */\n\nimport { parse as parseYAML } from 'yaml';\nimport { SchemaValidationError } from './errors.js';\nimport type { SchemaInput, SchemaNormalizationOptions } from './types.js';\n\n/**\n * Parse schema input to object\n */\nfunction parseSchemaInput(input: SchemaInput): Record<string, unknown> {\n if (!input) {\n throw SchemaValidationError.parseFailed(\n { type: 'string', content: '' },\n new Error('schema content is empty'),\n );\n }\n\n try {\n if (typeof input === 'string') {\n // Try JSON first, fall back to YAML\n try {\n return JSON.parse(input) as Record<string, unknown>;\n } catch {\n return parseYAML(input) as Record<string, unknown>;\n }\n }\n\n if (Buffer.isBuffer(input)) {\n const content = input.toString('utf-8');\n try {\n return JSON.parse(content) as Record<string, unknown>;\n } catch {\n return parseYAML(content) as Record<string, unknown>;\n }\n }\n\n // Already an object\n return input as Record<string, unknown>;\n } catch (error) {\n throw SchemaValidationError.parseFailed(\n {\n type: typeof input === 'string' ? 'string' : 'object',\n content: typeof input === 'string' ? input : JSON.stringify(input),\n },\n error as Error,\n );\n }\n}\n\n/**\n * Sort object keys recursively in lexicographical order\n */\nfunction sortObjectKeys(obj: unknown): unknown {\n if (obj === null || typeof obj !== 'object') {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map(sortObjectKeys);\n }\n\n const sorted: Record<string, unknown> = {};\n const keys = Object.keys(obj).sort();\n\n for (const key of keys) {\n sorted[key] = sortObjectKeys((obj as Record<string, unknown>)[key]);\n }\n\n return sorted;\n}\n\n/**\n * Normalize schema to canonical JSON format\n *\n * Per Fulmen Schema Normalization Standard:\n * - Accepts YAML or JSON input\n * - Strips comments while preserving semantic structure\n * - Sorts keys lexicographically\n * - Produces deterministic, pretty-printed JSON (or compact if requested)\n */\nexport function normalizeSchema(\n input: SchemaInput,\n options: SchemaNormalizationOptions = {},\n): string {\n try {\n // Parse input to object\n const parsed = parseSchemaInput(input);\n\n // Sort keys recursively\n const sorted = sortObjectKeys(parsed);\n\n // Serialize to JSON with optional compact mode\n if (options.compact) {\n return JSON.stringify(sorted);\n }\n\n // Default: pretty-printed with 2-space indentation\n return JSON.stringify(sorted, null, 2);\n } catch (error) {\n if (error instanceof SchemaValidationError) {\n throw error;\n }\n throw SchemaValidationError.parseFailed(\n {\n type: typeof input === 'string' ? 'string' : 'object',\n content: typeof input === 'string' ? input : JSON.stringify(input),\n },\n error as Error,\n );\n }\n}\n\n/**\n * Compare two schemas for semantic equality\n *\n * Normalizes both schemas and compares the canonical JSON output.\n * Returns equality result along with normalized versions for debugging.\n */\nexport function compareSchemas(\n schemaA: SchemaInput,\n schemaB: SchemaInput,\n options: SchemaNormalizationOptions = {},\n): { equal: boolean; normalizedA: string; normalizedB: string } {\n const normalizedA = normalizeSchema(schemaA, options);\n const normalizedB = normalizeSchema(schemaB, options);\n\n return {\n equal: normalizedA === normalizedB,\n normalizedA,\n normalizedB,\n };\n}\n","/**\n * Schema registry - implements schema discovery and metadata extraction\n */\n\nimport { access, readFile } from 'node:fs/promises';\nimport { dirname, extname, join, relative } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport glob from 'fast-glob';\nimport { parse as parseYAML } from 'yaml';\nimport { SchemaValidationError } from './errors.js';\nimport type { SchemaFormat, SchemaMetadata, SchemaRegistryOptions } from './types.js';\n\n/**\n * Default schema file patterns\n */\nconst DEFAULT_PATTERNS = ['**/*.schema.json', '**/*.schema.yaml', '**/*.schema.yml'];\n\n/**\n * Schema registry class for managing schema discovery and metadata\n */\nexport class SchemaRegistry {\n private schemas: Map<string, SchemaMetadata> = new Map();\n private options: SchemaRegistryOptions;\n\n constructor(options: SchemaRegistryOptions = {}) {\n this.options = {\n baseDir: options.baseDir || this.getDefaultSchemaDir(),\n patterns: options.patterns || DEFAULT_PATTERNS,\n followSymlinks: options.followSymlinks ?? false,\n maxDepth: options.maxDepth ?? 10,\n };\n }\n\n /**\n * Get default schema directory using import.meta.url\n */\n private getDefaultSchemaDir(): string {\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n // From src/schema/ we need to go up 2 levels to repo root, then into schemas/crucible-ts\n return join(__dirname, '..', '..', 'schemas', 'crucible-ts');\n }\n\n /**\n * Build logical schema ID from file path\n */\n private buildSchemaId(filePath: string, baseDir: string): string {\n const relativePath = relative(baseDir, filePath);\n const withoutExt = relativePath.replace(/\\.(schema\\.(json|yaml|yml))$/, '');\n return withoutExt.replace(/\\\\/g, '/'); // Normalize path separators\n }\n\n /**\n * Extract schema format from file extension\n */\n private getSchemaFormat(filePath: string): SchemaFormat {\n const ext = extname(filePath).toLowerCase();\n switch (ext) {\n case '.json':\n return 'json';\n case '.yaml':\n case '.yml':\n return 'yaml';\n default:\n return 'json'; // Default fallback\n }\n }\n\n /**\n * Extract metadata from schema file\n */\n private async extractMetadata(filePath: string): Promise<SchemaMetadata> {\n try {\n const content = await readFile(filePath, 'utf-8');\n const format = this.getSchemaFormat(filePath);\n\n let parsed: Record<string, unknown>;\n if (format === 'yaml') {\n parsed = parseYAML(content) as Record<string, unknown>;\n } else {\n parsed = JSON.parse(content) as Record<string, unknown>;\n }\n\n const baseDir = this.options.baseDir ?? '';\n const relativePath = relative(baseDir, filePath);\n\n return {\n id: this.buildSchemaId(filePath, baseDir),\n path: filePath,\n relativePath: relativePath,\n format,\n version: (parsed.$schema as string) || (parsed.version as string),\n description: (parsed.title as string) || (parsed.description as string),\n schemaDraft: parsed.$schema as string,\n };\n } catch (error) {\n throw SchemaValidationError.registryError(\n 'metadata extraction',\n `Failed to process ${filePath}: ${(error as Error).message}`,\n );\n }\n }\n\n /**\n * Discover and index all available schemas\n */\n async discoverSchemas(): Promise<void> {\n try {\n const baseDir = this.options.baseDir ?? '';\n const patterns = this.options.patterns ?? [];\n\n if (patterns.length === 0) {\n this.schemas.clear();\n return;\n }\n\n const pattern = patterns.map((p) => join(baseDir, p));\n\n // Check if base directory exists\n try {\n await access(baseDir);\n } catch {\n // Base directory doesn't exist, clear registry and return\n this.schemas.clear();\n return;\n }\n\n const files = await glob(pattern, {\n absolute: true,\n followSymbolicLinks: this.options.followSymlinks,\n deep: this.options.maxDepth,\n onlyFiles: true,\n suppressErrors: true, // Don't throw on permission errors\n });\n\n // Clear existing schemas\n this.schemas.clear();\n\n // Process each schema file\n for (const filePath of files) {\n try {\n const metadata = await this.extractMetadata(filePath);\n this.schemas.set(metadata.id, metadata);\n } catch (error) {\n // Log error but continue processing other schemas\n console.warn(`Warning: Failed to process schema ${filePath}:`, error);\n }\n }\n } catch (error) {\n throw SchemaValidationError.registryError('discovery', (error as Error).message);\n }\n }\n\n /**\n * List available schemas with optional prefix filtering\n */\n async listSchemas(prefix?: string): Promise<SchemaMetadata[]> {\n if (this.schemas.size === 0) {\n await this.discoverSchemas();\n }\n\n const schemas = Array.from(this.schemas.values());\n\n if (prefix) {\n return schemas.filter((schema) => schema.id.startsWith(prefix));\n }\n\n return schemas;\n }\n\n /**\n * Get schema by logical ID\n */\n async getSchema(id: string): Promise<SchemaMetadata> {\n if (this.schemas.size === 0) {\n await this.discoverSchemas();\n }\n\n const schema = this.schemas.get(id);\n if (!schema) {\n throw SchemaValidationError.schemaNotFound(id);\n }\n\n return schema;\n }\n\n /**\n * Get schema by file path\n */\n async getSchemaByPath(filePath: string): Promise<SchemaMetadata> {\n if (this.schemas.size === 0) {\n await this.discoverSchemas();\n }\n\n const absolutePath = filePath.startsWith('/') ? filePath : join(process.cwd(), filePath);\n\n for (const schema of this.schemas.values()) {\n if (schema.path === absolutePath) {\n return schema;\n }\n }\n\n throw SchemaValidationError.schemaNotFound(filePath);\n }\n\n /**\n * Check if schema exists\n */\n async hasSchema(id: string): Promise<boolean> {\n if (this.schemas.size === 0) {\n await this.discoverSchemas();\n }\n\n return this.schemas.has(id);\n }\n\n /**\n * Get registry size\n */\n get size(): number {\n return this.schemas.size;\n }\n\n /**\n * Clear registry cache\n */\n clear(): void {\n this.schemas.clear();\n }\n}\n\n/**\n * Global schema registry instance with cached options\n */\nlet globalRegistry: SchemaRegistry | undefined;\nlet globalRegistryOptions: SchemaRegistryOptions | undefined;\n\n/**\n * Check if registry options have changed\n */\nfunction optionsChanged(newOptions?: SchemaRegistryOptions): boolean {\n if (!newOptions && !globalRegistryOptions) return false;\n if (!newOptions || !globalRegistryOptions) return true;\n\n return (\n newOptions.baseDir !== globalRegistryOptions.baseDir ||\n JSON.stringify(newOptions.patterns) !== JSON.stringify(globalRegistryOptions.patterns) ||\n newOptions.followSymlinks !== globalRegistryOptions.followSymlinks ||\n newOptions.maxDepth !== globalRegistryOptions.maxDepth\n );\n}\n\n/**\n * Get or create global schema registry, rebuilding if options change\n */\nexport function getSchemaRegistry(options?: SchemaRegistryOptions): SchemaRegistry {\n if (!globalRegistry || optionsChanged(options)) {\n globalRegistry = new SchemaRegistry(options);\n globalRegistryOptions = options;\n }\n return globalRegistry;\n}\n\n/**\n * List available schemas with optional prefix filtering\n */\nexport async function listSchemas(\n prefix?: string,\n options?: SchemaRegistryOptions,\n): Promise<SchemaMetadata[]> {\n const registry = getSchemaRegistry(options);\n return registry.listSchemas(prefix);\n}\n\n/**\n * Get schema by logical ID\n */\nexport async function getSchema(\n id: string,\n options?: SchemaRegistryOptions,\n): Promise<SchemaMetadata> {\n const registry = getSchemaRegistry(options);\n return registry.getSchema(id);\n}\n\n/**\n * Get schema by file path\n */\nexport async function getSchemaByPath(\n filePath: string,\n options?: SchemaRegistryOptions,\n): Promise<SchemaMetadata> {\n const registry = getSchemaRegistry(options);\n return registry.getSchemaByPath(filePath);\n}\n\n/**\n * Check if schema exists\n */\nexport async function hasSchema(id: string, options?: SchemaRegistryOptions): Promise<boolean> {\n const registry = getSchemaRegistry(options);\n return registry.hasSchema(id);\n}\n","/**\n * Schema validator - implements AJV-based schema validation with goneat integration\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { dirname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport Ajv from 'ajv';\nimport addFormats from 'ajv-formats';\nimport { parse as parseYAML } from 'yaml';\nimport { metrics } from '../telemetry/index.js';\nimport { SchemaValidationError } from './errors.js';\nimport { getSchemaRegistry } from './registry.js';\nimport type {\n CompiledValidator,\n SchemaInput,\n SchemaRegistryOptions,\n SchemaValidationResult,\n} from './types.js';\nimport { createDiagnostic } from './utils.js';\n\n/**\n * AJV instance with draft 2020-12 support and custom formats\n */\nlet ajvInstance: Ajv | undefined;\n\n/**\n * Metaschema initialization promise\n */\nlet metaschemaReady: Promise<void> | null = null;\n\n/**\n * Schema cache for compiled validators\n */\nconst schemaCache = new Map<string, CompiledValidator>();\n\n/**\n * Load metaschema from Crucible SSOT\n */\nasync function loadMetaSchema(\n draft: 'draft-07' | 'draft-2020-12',\n): Promise<Record<string, unknown>> {\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n const metaSchemaPath = join(\n __dirname,\n '..',\n '..',\n 'schemas',\n 'crucible-ts',\n 'meta',\n draft,\n 'schema.json',\n );\n\n const content = await readFile(metaSchemaPath, 'utf-8');\n return JSON.parse(content) as Record<string, unknown>;\n}\n\n/**\n * Load draft 2020-12 vocabulary schemas\n */\nasync function loadVocabularySchemas(): Promise<Record<string, unknown>[]> {\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n const vocabDir = join(\n __dirname,\n '..',\n '..',\n 'schemas',\n 'crucible-ts',\n 'meta',\n 'draft-2020-12',\n 'meta',\n );\n\n const vocabFiles = [\n 'core.json',\n 'applicator.json',\n 'unevaluated.json',\n 'validation.json',\n 'meta-data.json',\n 'format-annotation.json',\n 'content.json',\n ];\n\n const schemas: Record<string, unknown>[] = [];\n for (const file of vocabFiles) {\n try {\n const content = await readFile(join(vocabDir, file), 'utf-8');\n schemas.push(JSON.parse(content) as Record<string, unknown>);\n } catch {\n // Vocabulary schema not found, skip\n }\n }\n\n return schemas;\n}\n\n/**\n * Load referenced schemas (including YAML files) for AJV\n *\n * Resolves relative paths from schemas/ and config/ directories.\n * Handles both relative paths and https://schemas.fulmenhq.dev URIs.\n */\nasync function loadReferencedSchema(uri: string): Promise<Record<string, unknown>> {\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n const repoRoot = join(__dirname, '..', '..');\n\n let resolvedPath: string;\n\n // Handle https://schemas.fulmenhq.dev/ URIs - map to local files\n if (uri.startsWith('https://schemas.fulmenhq.dev/')) {\n const relativePath = uri.replace('https://schemas.fulmenhq.dev/', '');\n\n // Check if it's a config taxonomy reference\n if (relativePath.startsWith('config/taxonomy/')) {\n resolvedPath = join(\n repoRoot,\n 'config',\n 'crucible-ts',\n 'taxonomy',\n relativePath.split('/').pop() || '',\n );\n } else {\n // Schema reference - map to schemas/crucible-ts/\n resolvedPath = join(repoRoot, 'schemas', 'crucible-ts', relativePath);\n }\n }\n // Handle relative paths (e.g., \"../../../../config/taxonomy/metrics.yaml\")\n else if (uri.startsWith('../../') || uri.startsWith('../')) {\n // Resolve relative to schemas/crucible-ts/observability/metrics/v1.0.0/\n // (where metrics-event.schema.json is located)\n const schemaBase = join(\n repoRoot,\n 'schemas',\n 'crucible-ts',\n 'observability',\n 'metrics',\n 'v1.0.0',\n );\n resolvedPath = join(schemaBase, uri);\n }\n // Handle file:// URIs\n else if (uri.startsWith('file://')) {\n resolvedPath = fileURLToPath(uri);\n }\n // Unhandled URI scheme\n else {\n throw new Error(`Cannot load remote schema: ${uri}`);\n }\n\n // Read and parse the file\n const content = await readFile(resolvedPath, 'utf-8');\n const ext = resolvedPath.split('.').pop()?.toLowerCase();\n\n if (ext === 'yaml' || ext === 'yml') {\n return parseYAML(content) as Record<string, unknown>;\n }\n return JSON.parse(content) as Record<string, unknown>;\n}\n\n/**\n * Get or create AJV instance with draft 2020-12 support\n */\nfunction getAjv(): Ajv {\n if (!ajvInstance) {\n ajvInstance = new Ajv({\n strict: false,\n allErrors: true,\n verbose: true,\n // Allow schemas with $id to be added without replacing existing ones\n addUsedSchema: false,\n // Enable async schema loading for YAML references\n loadSchema: loadReferencedSchema,\n });\n\n // Add custom formats\n addFormats(ajvInstance, {\n mode: 'fast',\n formats: ['date-time', 'email', 'hostname', 'ipv4', 'ipv6', 'uri', 'uri-reference'],\n });\n\n // Initialize metaschema loading\n metaschemaReady = Promise.all([loadVocabularySchemas(), loadMetaSchema('draft-2020-12')])\n .then(([vocabSchemas, metaSchema]) => {\n if (ajvInstance) {\n // Add vocabulary schemas first (they are referenced by metaschema)\n for (const vocabSchema of vocabSchemas) {\n try {\n ajvInstance.addMetaSchema(vocabSchema);\n } catch {\n // Vocabulary already added or has issues, continue\n }\n }\n\n // Then add draft 2020-12 metaschema\n ajvInstance.addMetaSchema(metaSchema);\n }\n })\n .catch((error) => {\n throw new Error(`Failed to load metaschemas: ${error}`);\n });\n }\n\n return ajvInstance;\n}\n\n/**\n * Compile a schema for validation\n */\nexport async function compileSchema(\n schema: SchemaInput,\n options: { aliases?: string[] } = {},\n): Promise<CompiledValidator> {\n // Ensure metaschemas are loaded before compiling\n const ajv = getAjv();\n if (metaschemaReady) {\n await metaschemaReady;\n }\n\n // Create cache key from schema content\n const cacheKey = typeof schema === 'string' ? schema : JSON.stringify(schema);\n\n // Check cache first\n const cached = schemaCache.get(cacheKey);\n if (cached !== undefined) {\n return cached;\n }\n\n let parsedSchema: unknown;\n if (typeof schema === 'string') {\n try {\n parsedSchema = JSON.parse(schema);\n } catch {\n // Try YAML if JSON parsing fails\n parsedSchema = parseYAML(schema);\n }\n } else if (Buffer.isBuffer(schema)) {\n const content = schema.toString('utf-8');\n try {\n parsedSchema = JSON.parse(content);\n } catch {\n parsedSchema = parseYAML(content);\n }\n } else {\n parsedSchema = schema;\n }\n\n try {\n // Register schema aliases (e.g., alternate $id values) before compile to support relative refs\n if (options.aliases && options.aliases.length > 0) {\n for (const alias of options.aliases) {\n if (alias && ajv.getSchema(alias) === undefined) {\n try {\n ajv.addSchema(parsedSchema as Record<string, unknown>, alias);\n } catch {\n // Ignore if alias already registered or invalid\n }\n }\n }\n }\n\n // Use compileAsync to support loading external references (e.g., YAML files)\n const validator = await ajv.compileAsync(parsedSchema as Record<string, unknown>);\n\n // Cache the compiled validator\n schemaCache.set(cacheKey, validator as CompiledValidator);\n\n return validator as CompiledValidator;\n } catch (error) {\n throw SchemaValidationError.parseFailed(\n {\n type: 'string',\n content: typeof schema === 'string' ? schema : JSON.stringify(schema),\n },\n error as Error,\n );\n }\n}\n\n/**\n * Validate data against a compiled schema\n */\nexport function validateData(data: unknown, validator: CompiledValidator): SchemaValidationResult {\n const valid = validator(data);\n\n const result: SchemaValidationResult = {\n valid,\n diagnostics: [],\n source: 'ajv',\n };\n\n if (!valid && validator.errors) {\n const errors = validator.errors;\n if (Array.isArray(errors)) {\n result.diagnostics = errors.map((error) =>\n createDiagnostic(\n error.instancePath || '',\n error.message || 'Validation failed',\n error.keyword || 'unknown',\n 'ERROR',\n 'ajv',\n ),\n );\n }\n metrics.counter('schema_validation_errors').inc();\n } else {\n metrics.counter('schema_validations').inc();\n }\n\n return result;\n}\n\n/**\n * Validate file against a schema\n */\nexport async function validateFile(\n filePath: string,\n validator: CompiledValidator,\n): Promise<SchemaValidationResult> {\n try {\n const content = await readFile(filePath, 'utf-8');\n let data: unknown;\n\n try {\n data = JSON.parse(content);\n } catch {\n // Try YAML if JSON parsing fails\n data = parseYAML(content);\n }\n\n return validateData(data, validator);\n } catch (error) {\n if (error instanceof SchemaValidationError) {\n throw error;\n }\n throw SchemaValidationError.validationFailed(\n filePath,\n [\n createDiagnostic(\n '',\n `Failed to read or parse file: ${(error as Error).message}`,\n 'file-read',\n 'ERROR',\n 'ajv',\n ),\n ],\n { type: 'file', id: filePath },\n );\n }\n}\n\n/**\n * Validate a schema document itself\n */\nexport async function validateSchema(schema: SchemaInput): Promise<SchemaValidationResult> {\n try {\n const validator = await compileSchema(schema);\n\n // Test the schema with an empty object to ensure it compiles\n validateData({}, validator);\n\n return {\n valid: true,\n diagnostics: [],\n source: 'ajv',\n };\n } catch (error) {\n if (error instanceof SchemaValidationError) {\n return {\n valid: false,\n diagnostics: error.diagnostics,\n source: 'ajv',\n };\n }\n\n return {\n valid: false,\n diagnostics: [\n createDiagnostic(\n '',\n `Schema validation failed: ${(error as Error).message}`,\n 'schema-validation',\n 'ERROR',\n 'ajv',\n ),\n ],\n source: 'ajv',\n };\n }\n}\n\n/**\n * Clear schema cache\n */\nexport function clearCache(): void {\n schemaCache.clear();\n}\n\n/**\n * Get schema cache size\n */\nexport function getCacheSize(): number {\n return schemaCache.size;\n}\n\n/**\n * Load schema by ID from registry and compile\n */\nexport async function compileSchemaById(\n schemaId: string,\n registryOptions?: SchemaRegistryOptions,\n): Promise<CompiledValidator> {\n try {\n const registry = getSchemaRegistry(registryOptions);\n const metadata = await registry.getSchema(schemaId);\n\n const content = await readFile(metadata.path, 'utf-8');\n const aliases: string[] = [];\n\n const normalizedRelativePath = metadata.relativePath.replace(/\\\\/g, '/');\n if (normalizedRelativePath) {\n aliases.push(new URL(normalizedRelativePath, 'https://schemas.fulmenhq.dev/').toString());\n }\n\n return compileSchema(content, { aliases });\n } catch (error) {\n metrics.counter('schema_validation_errors').inc();\n throw error;\n }\n}\n\n/**\n * Validate data against a schema ID from registry\n */\nexport async function validateDataBySchemaId(\n data: unknown,\n schemaId: string,\n registryOptions?: SchemaRegistryOptions,\n): Promise<SchemaValidationResult> {\n try {\n const validator = await compileSchemaById(schemaId, registryOptions);\n return validateData(data, validator);\n } catch (error) {\n metrics.counter('schema_validation_errors').inc();\n throw error;\n }\n}\n\n/**\n * Validate file against a schema ID from registry\n */\nexport async function validateFileBySchemaId(\n filePath: string,\n schemaId: string,\n registryOptions?: SchemaRegistryOptions,\n): Promise<SchemaValidationResult> {\n try {\n const validator = await compileSchemaById(schemaId, registryOptions);\n return validateFile(filePath, validator);\n } catch (error) {\n metrics.counter('schema_validation_errors').inc();\n throw error;\n }\n}\n","/**\n * Schema export utilities - implements schema export with provenance\n */\n\nimport { access, mkdir, readFile, writeFile } from 'node:fs/promises';\nimport { dirname, extname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { parse as parseYAML, stringify as stringifyYAML } from 'yaml';\nimport { SchemaExportError, SchemaValidationError } from './errors.js';\nimport { getSchemaRegistry } from './registry.js';\nimport type {\n ExportSchemaOptions,\n ExportSchemaResult,\n SchemaExportFormat,\n SchemaProvenanceMetadata,\n} from './types.js';\nimport { validateSchema } from './validator.js';\n\n/**\n * Extract provenance metadata from Crucible sync metadata\n */\nasync function extractProvenanceMetadata(schemaId: string): Promise<SchemaProvenanceMetadata> {\n try {\n // Read Crucible metadata using proper path resolution\n const __filename = fileURLToPath(import.meta.url);\n const __dirname = dirname(__filename);\n const metadataPath = join(__dirname, '..', '..', '.crucible', 'metadata', 'metadata.yaml');\n const metadataContent = await readFile(metadataPath, 'utf-8');\n\n // Parse YAML properly to avoid brittle regex matching\n const metadata = parseYAML(metadataContent) as {\n sources?: Array<{\n name?: string;\n version?: string;\n commit?: string;\n }>;\n };\n\n // Extract Crucible source metadata (first source is typically 'crucible')\n const crucibleSource = metadata.sources?.[0];\n const crucibleVersion = crucibleSource?.version || 'unknown';\n const revision = crucibleSource?.commit;\n\n // Read library version from package.json\n const pkgPath = join(__dirname, '..', '..', 'package.json');\n const pkgContent = await readFile(pkgPath, 'utf-8');\n const pkg = JSON.parse(pkgContent) as { version: string };\n\n return {\n schema_id: schemaId,\n crucible_version: crucibleVersion,\n library_version: pkg.version,\n revision: revision,\n exported_at: new Date().toISOString(),\n export_source: 'tsfulmen',\n };\n } catch (error) {\n throw SchemaExportError.provenanceFailed((error as Error).message, error as Error);\n }\n}\n\n/**\n * Embed provenance metadata in schema content\n */\nfunction embedProvenance(\n schemaContent: Record<string, unknown>,\n provenance: SchemaProvenanceMetadata,\n format: SchemaExportFormat,\n): string {\n if (format === 'json') {\n // For JSON: embed under $comment[\"x-crucible-source\"]\n const withProvenance = {\n ...schemaContent,\n $comment: {\n ...(typeof schemaContent.$comment === 'object' ? schemaContent.$comment : {}),\n 'x-crucible-source': provenance,\n },\n };\n return JSON.stringify(withProvenance, null, 2);\n }\n\n // For YAML: prepend comment block\n const yamlContent = stringifyYAML(schemaContent, {\n indent: 2,\n lineWidth: 0,\n });\n\n const provenanceComment = [\n '# x-crucible-source:',\n `# schema_id: ${provenance.schema_id}`,\n `# crucible_version: ${provenance.crucible_version}`,\n `# library_version: ${provenance.library_version}`,\n ...(provenance.revision ? [`# revision: ${provenance.revision}`] : []),\n `# exported_at: ${provenance.exported_at}`,\n `# export_source: ${provenance.export_source}`,\n '',\n ].join('\\n');\n\n return provenanceComment + yamlContent;\n}\n\n/**\n * Detect export format from file extension or explicit option\n */\nfunction detectFormat(outPath: string, formatOption?: SchemaExportFormat): SchemaExportFormat {\n if (formatOption && formatOption !== 'auto') {\n return formatOption;\n }\n\n const ext = extname(outPath).toLowerCase();\n switch (ext) {\n case '.json':\n return 'json';\n case '.yaml':\n case '.yml':\n return 'yaml';\n default:\n throw SchemaExportError.invalidFormat(ext, outPath);\n }\n}\n\n/**\n * Export schema from registry to file with provenance\n *\n * @param options - Export options\n * @returns Export result with metadata\n *\n * @throws {SchemaExportError} If export fails\n * @throws {SchemaValidationError} If schema not found or validation fails\n *\n * @example\n * ```typescript\n * import { exportSchema } from '@fulmenhq/tsfulmen/schema';\n *\n * await exportSchema({\n * schemaId: 'library/foundry/v1.0.0/exit-codes',\n * outPath: './schemas/exit-codes.schema.json',\n * includeProvenance: true,\n * validate: true,\n * });\n * ```\n */\nexport async function exportSchema(options: ExportSchemaOptions): Promise<ExportSchemaResult> {\n const {\n schemaId,\n outPath,\n includeProvenance = true,\n validate = true,\n overwrite = false,\n format: formatOption,\n baseDir,\n } = options;\n\n // Detect output format\n const format = detectFormat(outPath, formatOption);\n\n // Check if file exists\n if (!overwrite) {\n try {\n await access(outPath);\n throw SchemaExportError.fileExists(outPath);\n } catch (error) {\n // File doesn't exist - proceed\n if ((error as NodeJS.ErrnoException).code !== 'ENOENT') {\n throw error;\n }\n }\n }\n\n // Get schema from registry\n const registry = getSchemaRegistry({ baseDir });\n const schema = await registry.getSchema(schemaId);\n\n // Read schema content\n const schemaContent = await readFile(schema.path, 'utf-8');\n\n // Validate if requested\n if (validate) {\n const validationResult = await validateSchema(schemaContent);\n if (!validationResult.valid) {\n throw SchemaValidationError.validationFailed(schemaId, validationResult.diagnostics, {\n type: 'file',\n id: schema.path,\n });\n }\n }\n\n // Parse schema content\n let schemaObject: Record<string, unknown>;\n try {\n schemaObject = JSON.parse(schemaContent) as Record<string, unknown>;\n } catch {\n schemaObject = parseYAML(schemaContent) as Record<string, unknown>;\n }\n\n // Freeze schema object to prevent mutation\n Object.freeze(schemaObject);\n\n let provenance: SchemaProvenanceMetadata | undefined;\n let outputContent: string;\n\n if (includeProvenance) {\n // Extract provenance metadata\n provenance = await extractProvenanceMetadata(schemaId);\n\n // Embed provenance in output\n outputContent = embedProvenance(schemaObject, provenance, format);\n } else {\n // Export without provenance\n if (format === 'json') {\n outputContent = JSON.stringify(schemaObject, null, 2);\n } else {\n outputContent = stringifyYAML(schemaObject, { indent: 2, lineWidth: 0 });\n }\n }\n\n // Ensure output directory exists\n await mkdir(dirname(outPath), { recursive: true });\n\n // Write to file\n try {\n await writeFile(outPath, outputContent, 'utf-8');\n } catch (error) {\n throw SchemaExportError.writeFailed(outPath, error as Error);\n }\n\n return {\n success: true,\n schemaId,\n outPath,\n format,\n includeProvenance,\n provenance,\n };\n}\n\n/**\n * Strip provenance metadata from schema content\n *\n * This helper is useful for comparing exported schemas with runtime\n * schemas or validating that provenance doesn't affect schema semantics.\n *\n * @param content - Schema content (JSON or YAML string)\n * @returns Schema content without provenance metadata\n *\n * @example\n * ```typescript\n * import { stripProvenance } from '@fulmenhq/tsfulmen/schema';\n *\n * const exported = await readFile('./schema.json', 'utf-8');\n * const withoutProvenance = stripProvenance(exported);\n * ```\n */\nexport function stripProvenance(content: string): string {\n try {\n // Try parsing as JSON\n const parsed = JSON.parse(content) as Record<string, unknown>;\n\n // Remove provenance from $comment\n if (parsed.$comment && typeof parsed.$comment === 'object') {\n const comment = { ...parsed.$comment } as Record<string, unknown>;\n delete comment['x-crucible-source'];\n\n // Remove $comment entirely if it's now empty\n if (Object.keys(comment).length === 0) {\n delete parsed.$comment;\n } else {\n parsed.$comment = comment;\n }\n }\n\n return JSON.stringify(parsed, null, 2);\n } catch {\n // YAML format - strip comment lines\n const lines = content.split('\\n');\n const filtered = lines.filter((line) => {\n const trimmed = line.trim();\n return !(\n trimmed.startsWith('# x-crucible-source:') ||\n (trimmed.startsWith('# ') &&\n /^#\\s+(schema_id|crucible_version|library_version|revision|exported_at|export_source):/.test(\n trimmed,\n ))\n );\n });\n\n // Remove leading blank lines\n while (filtered.length > 0 && filtered[0]?.trim() === '') {\n filtered.shift();\n }\n\n return filtered.join('\\n');\n }\n}\n","/**\n * Foundry module - Error handling\n *\n * Custom error classes for Foundry catalog operations with fail-fast validation.\n */\n\nexport class FoundryCatalogError extends Error {\n constructor(\n message: string,\n public readonly catalog?: string,\n public readonly cause?: Error,\n ) {\n super(message);\n this.name = 'FoundryCatalogError';\n\n // Maintain proper stack trace for V8\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, FoundryCatalogError);\n }\n }\n\n static invalidSchema(catalog: string, details: string, cause?: Error): FoundryCatalogError {\n return new FoundryCatalogError(\n `Invalid schema in ${catalog} catalog: ${details}`,\n catalog,\n cause,\n );\n }\n\n static missingCatalog(catalog: string): FoundryCatalogError {\n return new FoundryCatalogError(`Catalog ${catalog} not found or could not be loaded`, catalog);\n }\n\n static invalidPattern(patternId: string, details: string): FoundryCatalogError {\n return new FoundryCatalogError(`Invalid pattern ${patternId}: ${details}`, 'patterns');\n }\n\n static compilationError(patternId: string, details: string, cause?: Error): FoundryCatalogError {\n return new FoundryCatalogError(\n `Failed to compile pattern ${patternId}: ${details}`,\n 'patterns',\n cause,\n );\n }\n}\n","/**\n * Foundry module - SSOT data loader\n *\n * Loads and validates Foundry catalog data from Crucible SSOT assets\n * with Bun-first approach and comprehensive schema validation.\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { dirname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { parse as parseYaml } from 'yaml';\nimport { validateDataBySchemaId } from '../schema/validator.js';\nimport { FoundryCatalogError } from './errors.js';\nimport type {\n CountryCatalog,\n HttpStatusCatalog,\n MimeTypeCatalog,\n PatternCatalog,\n} from './types.js';\n\n// Get the directory of the current module file for proper path resolution\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = dirname(__filename);\n\n// SSOT Asset Paths (relative to module file, resolved to absolute paths)\nconst SSOT_PATHS = {\n patterns: join(__dirname, '../../config/crucible-ts/library/foundry/patterns.yaml'),\n httpStatuses: join(__dirname, '../../config/crucible-ts/library/foundry/http-statuses.yaml'),\n mimeTypes: join(__dirname, '../../config/crucible-ts/library/foundry/mime-types.yaml'),\n countryCodes: join(__dirname, '../../config/crucible-ts/library/foundry/country-codes.yaml'),\n} as const;\n\n// Schema IDs for Foundry catalogs (from Crucible SSOT)\nconst SCHEMA_IDS = {\n patterns: 'library/foundry/v1.0.0/patterns',\n httpStatuses: 'library/foundry/v1.0.0/http-status-groups',\n mimeTypes: 'library/foundry/v1.0.0/mime-types',\n countryCodes: 'library/foundry/v1.0.0/country-codes',\n} as const;\n\n/**\n * Load and validate a Foundry catalog from YAML file\n * Bun-first approach with Node.js fallback\n */\nasync function loadCatalog<T>(filePath: string, catalogName: string, schemaId: string): Promise<T> {\n try {\n let content: string;\n\n // Bun-first approach\n if (typeof Bun !== 'undefined') {\n try {\n const file = Bun.file(filePath);\n if (!(await file.exists())) {\n throw FoundryCatalogError.missingCatalog(catalogName);\n }\n content = await file.text();\n } catch (error) {\n // Handle Bun-specific errors\n if (error instanceof Error && error.message.includes('No such file')) {\n throw FoundryCatalogError.missingCatalog(catalogName);\n }\n throw error;\n }\n } else {\n // Node.js fallback\n try {\n content = await readFile(filePath, 'utf-8');\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code === 'ENOENT') {\n throw FoundryCatalogError.missingCatalog(catalogName);\n }\n throw error;\n }\n }\n\n // Parse YAML content\n const data = parseYaml(content) as T;\n\n // Validate against JSON Schema from Crucible SSOT\n const result = await validateDataBySchemaId(data, schemaId);\n if (!result.valid) {\n const errorMessages = result.diagnostics.map((d) => `${d.pointer}: ${d.message}`).join('; ');\n throw FoundryCatalogError.invalidSchema(\n catalogName,\n `Schema validation failed: ${errorMessages}`,\n );\n }\n\n return data;\n } catch (error) {\n if (error instanceof FoundryCatalogError) {\n throw error;\n }\n\n // Distinguish between different types of file access errors\n const err = error as NodeJS.ErrnoException;\n if (err.code === 'ENOENT') {\n throw FoundryCatalogError.missingCatalog(catalogName);\n } else if (err.code === 'EACCES') {\n throw FoundryCatalogError.invalidSchema(\n catalogName,\n 'Permission denied accessing catalog file',\n err,\n );\n } else if (err.code === 'EISDIR') {\n throw FoundryCatalogError.invalidSchema(\n catalogName,\n 'Expected file but found directory',\n err,\n );\n } else if (err.code === 'EMFILE' || err.code === 'ENFILE') {\n throw FoundryCatalogError.invalidSchema(catalogName, 'Too many open files', err);\n }\n\n throw FoundryCatalogError.invalidSchema(catalogName, 'Failed to load catalog', err);\n }\n}\n\n/**\n * Load Pattern Catalog from SSOT\n */\nexport async function loadPatternCatalog(): Promise<PatternCatalog> {\n return loadCatalog<PatternCatalog>(SSOT_PATHS.patterns, 'patterns', SCHEMA_IDS.patterns);\n}\n\n/**\n * Load HTTP Status Catalog from SSOT\n */\nexport async function loadHttpStatusCatalog(): Promise<HttpStatusCatalog> {\n return loadCatalog<HttpStatusCatalog>(\n SSOT_PATHS.httpStatuses,\n 'httpStatuses',\n SCHEMA_IDS.httpStatuses,\n );\n}\n\n/**\n * Load MIME Type Catalog from SSOT\n */\nexport async function loadMimeTypeCatalog(): Promise<MimeTypeCatalog> {\n return loadCatalog<MimeTypeCatalog>(SSOT_PATHS.mimeTypes, 'mimeTypes', SCHEMA_IDS.mimeTypes);\n}\n\n/**\n * Load Country Code Catalog from SSOT\n */\nexport async function loadCountryCodeCatalog(): Promise<CountryCatalog> {\n return loadCatalog<CountryCatalog>(\n SSOT_PATHS.countryCodes,\n 'countryCodes',\n SCHEMA_IDS.countryCodes,\n );\n}\n\n/**\n * Load all Foundry catalogs\n */\nexport async function loadAllCatalogs(): Promise<{\n patterns: PatternCatalog;\n httpStatuses: HttpStatusCatalog;\n mimeTypes: MimeTypeCatalog;\n countryCodes: CountryCatalog;\n}> {\n const [patterns, httpStatuses, mimeTypes, countryCodes] = await Promise.all([\n loadPatternCatalog(),\n loadHttpStatusCatalog(),\n loadMimeTypeCatalog(),\n loadCountryCodeCatalog(),\n ]);\n\n return { patterns, httpStatuses, mimeTypes, countryCodes };\n}\n","/**\n * Foundry Country Code Catalog - implements ISO 3166 country code lookups\n *\n * Provides case-insensitive alpha-2/alpha-3 lookups and normalized numeric lookups\n * with proper padding (76 → \"076\", \"76\" → \"076\", \"076\" → \"076\")\n */\n\nimport { loadCountryCodeCatalog } from './loader.js';\nimport type { Country, CountryCatalog } from './types.js';\n\nlet catalogCache: CountryCatalog | null = null;\nconst alpha2Index = new Map<string, Country>();\nconst alpha3Index = new Map<string, Country>();\nconst numericIndex = new Map<string, Country>();\n\nfunction deepClone<T>(obj: T): T {\n if (obj === null || typeof obj !== 'object') {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => deepClone(item)) as T;\n }\n\n const cloned: Record<string, unknown> = {};\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n cloned[key] = deepClone((obj as Record<string, unknown>)[key]);\n }\n }\n return cloned as T;\n}\n\nfunction deepFreeze<T extends object>(obj: T): T {\n Object.freeze(obj);\n\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n const value = obj[key];\n if (value !== null && typeof value === 'object') {\n deepFreeze(value);\n }\n }\n }\n\n return obj;\n}\n\nfunction normalizeNumeric(code: string | number): string {\n const str = typeof code === 'number' ? code.toString() : code;\n return str.padStart(3, '0');\n}\n\nasync function ensureCatalogLoaded(): Promise<void> {\n if (catalogCache !== null) {\n return;\n }\n\n catalogCache = await loadCountryCodeCatalog();\n\n for (const country of catalogCache.countries) {\n // Alpha-2 index (case-insensitive, uppercase keys)\n alpha2Index.set(country.alpha2.toUpperCase(), country);\n\n // Alpha-3 index (case-insensitive, uppercase keys)\n alpha3Index.set(country.alpha3.toUpperCase(), country);\n\n // Numeric index (normalized to 3 digits with leading zeros)\n const normalized = normalizeNumeric(country.numeric);\n numericIndex.set(normalized, country);\n }\n}\n\nexport async function getCountryByAlpha2(code: string): Promise<Readonly<Country> | null> {\n await ensureCatalogLoaded();\n const normalized = code.toUpperCase();\n const country = alpha2Index.get(normalized);\n return country ? deepFreeze(deepClone(country)) : null;\n}\n\nexport async function getCountryByAlpha3(code: string): Promise<Readonly<Country> | null> {\n await ensureCatalogLoaded();\n const normalized = code.toUpperCase();\n const country = alpha3Index.get(normalized);\n return country ? deepFreeze(deepClone(country)) : null;\n}\n\nexport async function getCountryByNumeric(\n code: string | number,\n): Promise<Readonly<Country> | null> {\n await ensureCatalogLoaded();\n const normalized = normalizeNumeric(code);\n const country = numericIndex.get(normalized);\n return country ? deepFreeze(deepClone(country)) : null;\n}\n\nexport async function listCountries(): Promise<ReadonlyArray<Readonly<Country>>> {\n await ensureCatalogLoaded();\n return Array.from(alpha2Index.values()).map((c) => deepFreeze(deepClone(c)));\n}\n\nexport function clearCountryCodeCache(): void {\n catalogCache = null;\n alpha2Index.clear();\n alpha3Index.clear();\n numericIndex.clear();\n}\n","/**\n * Exit Codes - Generated from Crucible catalog\n *\n * This file is AUTO-GENERATED from the Foundry exit codes catalog.\n * DO NOT EDIT MANUALLY - changes will be overwritten.\n *\n * Catalog Version: v1.0.0\n * Last Reviewed: 2025-10-31\n * Source: config/library/foundry/exit-codes.yaml\n */\n\n/**\n * Standardized process exit codes for Fulmen ecosystem\n *\n * @see https://github.com/fulmenhq/crucible/blob/main/docs/standards/library/foundry/README.md#exit-codes\n */\nexport const exitCodes = {\n // Standard Exit Codes (0-1)\n // POSIX standard success and generic failure codes\n EXIT_SUCCESS: 0,\n EXIT_FAILURE: 1,\n\n // Networking & Port Management (10-19)\n // Network-related failures (ports, connectivity, etc.)\n EXIT_PORT_IN_USE: 10,\n EXIT_PORT_RANGE_EXHAUSTED: 11,\n EXIT_INSTANCE_ALREADY_RUNNING: 12,\n EXIT_NETWORK_UNREACHABLE: 13,\n EXIT_CONNECTION_REFUSED: 14,\n EXIT_CONNECTION_TIMEOUT: 15,\n\n // Configuration & Validation (20-29)\n // Configuration errors, validation failures, version mismatches\n EXIT_CONFIG_INVALID: 20,\n EXIT_MISSING_DEPENDENCY: 21,\n EXIT_SSOT_VERSION_MISMATCH: 22,\n EXIT_CONFIG_FILE_NOT_FOUND: 23,\n EXIT_ENVIRONMENT_INVALID: 24,\n\n // Runtime Errors (30-39)\n // Errors during normal operation (health checks, database, etc.)\n EXIT_HEALTH_CHECK_FAILED: 30,\n EXIT_DATABASE_UNAVAILABLE: 31,\n EXIT_EXTERNAL_SERVICE_UNAVAILABLE: 32,\n EXIT_RESOURCE_EXHAUSTED: 33,\n EXIT_OPERATION_TIMEOUT: 34,\n\n // Command-Line Usage Errors (40-49)\n // Invalid arguments, missing required flags, usage errors\n EXIT_INVALID_ARGUMENT: 40,\n EXIT_MISSING_REQUIRED_ARGUMENT: 41,\n EXIT_USAGE: 64,\n\n // Permissions & File Access (50-59)\n // Permission denied, file not found, access errors\n EXIT_PERMISSION_DENIED: 50,\n EXIT_FILE_NOT_FOUND: 51,\n EXIT_DIRECTORY_NOT_FOUND: 52,\n EXIT_FILE_READ_ERROR: 53,\n EXIT_FILE_WRITE_ERROR: 54,\n\n // Data & Processing Errors (60-69)\n // Data validation, parsing, transformation failures\n EXIT_DATA_INVALID: 60,\n EXIT_PARSE_ERROR: 61,\n EXIT_TRANSFORMATION_FAILED: 62,\n EXIT_DATA_CORRUPT: 63,\n\n // Security & Authentication (70-79)\n // Authentication failures, authorization errors, security violations\n EXIT_AUTHENTICATION_FAILED: 70,\n EXIT_AUTHORIZATION_FAILED: 71,\n EXIT_SECURITY_VIOLATION: 72,\n EXIT_CERTIFICATE_INVALID: 73,\n\n // Observability & Monitoring (80-89)\n // Observability infrastructure failures. Use when observability is CRITICAL to operation (e.g., monitoring agents, telemetry exporters). For workhorses where observability is auxiliary: - Log warning and continue (don't exit) - Emit degraded health status - Only exit if explicitly configured (fail_on_observability_error: true)\n EXIT_METRICS_UNAVAILABLE: 80,\n EXIT_TRACING_FAILED: 81,\n EXIT_LOGGING_FAILED: 82,\n EXIT_ALERT_SYSTEM_FAILED: 83,\n EXIT_STRUCTURED_LOGGING_FAILED: 84,\n\n // Testing & Validation (91-99)\n // Test execution outcomes and validation failures. NOTE: Test harnesses MUST use EXIT_SUCCESS (0) for successful test runs per ecosystem conventions (pytest, Go testing, Jest all use 0 for success). Codes in this category are for FAILURES and exceptional conditions only.\n EXIT_TEST_FAILURE: 91,\n EXIT_TEST_ERROR: 92,\n EXIT_TEST_INTERRUPTED: 93,\n EXIT_TEST_USAGE_ERROR: 94,\n EXIT_TEST_NO_TESTS_COLLECTED: 95,\n EXIT_COVERAGE_THRESHOLD_NOT_MET: 96,\n\n // Signal-Induced Exits (128-165)\n // Process terminated by Unix signals (128+N pattern per POSIX). Signal codes follow Linux numbering; macOS/FreeBSD differ for SIGUSR1/SIGUSR2. For full signal semantics, see config/library/foundry/signals.yaml. For signal handling patterns, see docs/standards/library/modules/signal-handling.md.\n EXIT_SIGNAL_HUP: 129,\n EXIT_SIGNAL_INT: 130,\n EXIT_SIGNAL_QUIT: 131,\n EXIT_SIGNAL_KILL: 137,\n EXIT_SIGNAL_PIPE: 141,\n EXIT_SIGNAL_ALRM: 142,\n EXIT_SIGNAL_TERM: 143,\n EXIT_SIGNAL_USR1: 159,\n EXIT_SIGNAL_USR2: 160,\n} as const;\n\n/**\n * Exit code value type - union of all valid exit code numbers\n */\nexport type ExitCode = (typeof exitCodes)[keyof typeof exitCodes];\n\n/**\n * Exit code name type - union of all valid exit code constant names\n */\nexport type ExitCodeName = keyof typeof exitCodes;\n\n/**\n * Exit code metadata information\n */\nexport interface ExitCodeInfo {\n code: number;\n name: string;\n description: string;\n context: string;\n category: string;\n retryHint?: 'retry' | 'no_retry' | 'investigate';\n bsdEquivalent?: string;\n pythonNote?: string;\n}\n\n/**\n * Metadata for all exit codes\n */\nexport const exitCodeMetadata: Record<number, ExitCodeInfo> = {\n 0: {\n code: 0,\n name: 'EXIT_SUCCESS',\n description: 'Successful execution',\n context: 'Command completed without errors',\n category: 'standard',\n },\n 1: {\n code: 1,\n name: 'EXIT_FAILURE',\n description: 'Generic failure (unspecified error)',\n context: 'Use when no more specific exit code applies',\n category: 'standard',\n },\n 10: {\n code: 10,\n name: 'EXIT_PORT_IN_USE',\n description: 'Specified port is already in use',\n context: 'Server startup when port unavailable and fail_if_unavailable strategy',\n category: 'networking',\n },\n 11: {\n code: 11,\n name: 'EXIT_PORT_RANGE_EXHAUSTED',\n description: 'No available ports in configured range',\n context: 'Server startup when all ports in environment range occupied',\n category: 'networking',\n },\n 12: {\n code: 12,\n name: 'EXIT_INSTANCE_ALREADY_RUNNING',\n description: 'Another instance already running on target port',\n context: 'Server startup when PID registry shows active process on port',\n category: 'networking',\n },\n 13: {\n code: 13,\n name: 'EXIT_NETWORK_UNREACHABLE',\n description: 'Network destination unreachable',\n context: 'Client connections, health checks, external service validation',\n category: 'networking',\n },\n 14: {\n code: 14,\n name: 'EXIT_CONNECTION_REFUSED',\n description: 'Connection refused by remote host',\n context: 'Database connections, API endpoints, upstream services',\n category: 'networking',\n },\n 15: {\n code: 15,\n name: 'EXIT_CONNECTION_TIMEOUT',\n description: 'Connection attempt timed out',\n context: 'Slow networks, unresponsive services, firewall blocks',\n category: 'networking',\n },\n 20: {\n code: 20,\n name: 'EXIT_CONFIG_INVALID',\n description: 'Configuration file failed validation',\n context: 'Startup validation, schema mismatches, invalid YAML/JSON',\n category: 'configuration',\n retryHint: 'no_retry',\n },\n 21: {\n code: 21,\n name: 'EXIT_MISSING_DEPENDENCY',\n description: 'Required dependency not found',\n context: 'Missing binaries, libraries, or runtime requirements',\n category: 'configuration',\n retryHint: 'investigate',\n },\n 22: {\n code: 22,\n name: 'EXIT_SSOT_VERSION_MISMATCH',\n description: 'SSOT (Crucible) version incompatible',\n context: 'Helper library detects unsupported Crucible version',\n category: 'configuration',\n retryHint: 'no_retry',\n },\n 23: {\n code: 23,\n name: 'EXIT_CONFIG_FILE_NOT_FOUND',\n description: 'Required configuration file not found',\n context: \"Explicitly specified config path doesn't exist\",\n category: 'configuration',\n },\n 24: {\n code: 24,\n name: 'EXIT_ENVIRONMENT_INVALID',\n description: 'Invalid or unsupported environment specification',\n context: 'Unknown environment name, missing environment config',\n category: 'configuration',\n },\n 30: {\n code: 30,\n name: 'EXIT_HEALTH_CHECK_FAILED',\n description: 'Health check endpoint returned non-healthy status',\n context: 'Startup health validation, readiness probes',\n category: 'runtime',\n retryHint: 'retry',\n },\n 31: {\n code: 31,\n name: 'EXIT_DATABASE_UNAVAILABLE',\n description: 'Database connection failed or unavailable',\n context: 'Startup connection checks, critical query failures',\n category: 'runtime',\n retryHint: 'retry',\n },\n 32: {\n code: 32,\n name: 'EXIT_EXTERNAL_SERVICE_UNAVAILABLE',\n description: 'Required external service unavailable',\n context: 'API dependencies, message queues, cache servers',\n category: 'runtime',\n },\n 33: {\n code: 33,\n name: 'EXIT_RESOURCE_EXHAUSTED',\n description: 'System resources exhausted (memory, disk, file descriptors)',\n context: 'Out-of-memory, disk full, too many open files',\n category: 'runtime',\n retryHint: 'investigate',\n },\n 34: {\n code: 34,\n name: 'EXIT_OPERATION_TIMEOUT',\n description: 'Operation exceeded timeout threshold',\n context: 'Long-running tasks, async operations, batch processing',\n category: 'runtime',\n retryHint: 'retry',\n },\n 40: {\n code: 40,\n name: 'EXIT_INVALID_ARGUMENT',\n description: 'Invalid command-line argument or flag value',\n context: 'Type errors, out-of-range values, malformed input',\n category: 'usage',\n },\n 41: {\n code: 41,\n name: 'EXIT_MISSING_REQUIRED_ARGUMENT',\n description: 'Required command-line argument not provided',\n context: 'Missing --config, --port, or other required flags',\n category: 'usage',\n },\n 64: {\n code: 64,\n name: 'EXIT_USAGE',\n description: 'Command-line usage error',\n context: 'BSD sysexits.h EX_USAGE - wrong number of arguments, bad syntax',\n category: 'usage',\n bsdEquivalent: 'EX_USAGE',\n },\n 50: {\n code: 50,\n name: 'EXIT_PERMISSION_DENIED',\n description: 'Insufficient permissions for operation',\n context: 'File access, port binding (<1024), privileged operations',\n category: 'permissions',\n },\n 51: {\n code: 51,\n name: 'EXIT_FILE_NOT_FOUND',\n description: 'Required file not found',\n context: 'Assets, templates, data files (not config - use 23)',\n category: 'permissions',\n },\n 52: {\n code: 52,\n name: 'EXIT_DIRECTORY_NOT_FOUND',\n description: 'Required directory not found',\n context: 'State directories, log paths, data directories',\n category: 'permissions',\n },\n 53: {\n code: 53,\n name: 'EXIT_FILE_READ_ERROR',\n description: 'Error reading file',\n context: 'Corrupt files, I/O errors, encoding issues',\n category: 'permissions',\n },\n 54: {\n code: 54,\n name: 'EXIT_FILE_WRITE_ERROR',\n description: 'Error writing file',\n context: 'Disk full, read-only filesystem, permission errors',\n category: 'permissions',\n },\n 60: {\n code: 60,\n name: 'EXIT_DATA_INVALID',\n description: 'Input data failed validation',\n context: 'Schema validation, business rule violations',\n category: 'data',\n },\n 61: {\n code: 61,\n name: 'EXIT_PARSE_ERROR',\n description: 'Error parsing input data',\n context: 'Malformed JSON/YAML/XML, syntax errors',\n category: 'data',\n },\n 62: {\n code: 62,\n name: 'EXIT_TRANSFORMATION_FAILED',\n description: 'Data transformation or conversion failed',\n context: 'Type conversions, format transformations, encoding changes',\n category: 'data',\n },\n 63: {\n code: 63,\n name: 'EXIT_DATA_CORRUPT',\n description: 'Data corruption detected',\n context: 'Checksum failures, integrity violations',\n category: 'data',\n },\n 70: {\n code: 70,\n name: 'EXIT_AUTHENTICATION_FAILED',\n description: 'Authentication failed',\n context: 'Invalid credentials, expired tokens, auth service unavailable',\n category: 'security',\n },\n 71: {\n code: 71,\n name: 'EXIT_AUTHORIZATION_FAILED',\n description: 'Authorization failed (authenticated but insufficient permissions)',\n context: 'RBAC failures, scope violations, resource access denied',\n category: 'security',\n },\n 72: {\n code: 72,\n name: 'EXIT_SECURITY_VIOLATION',\n description: 'Security policy violation detected',\n context: 'Suspicious activity, rate limit exceeded, IP blocklist',\n category: 'security',\n },\n 73: {\n code: 73,\n name: 'EXIT_CERTIFICATE_INVALID',\n description: 'TLS/SSL certificate validation failed',\n context: 'Expired certs, untrusted CAs, hostname mismatches',\n category: 'security',\n bsdEquivalent: 'EX_PROTOCOL',\n },\n 80: {\n code: 80,\n name: 'EXIT_METRICS_UNAVAILABLE',\n description: 'Metrics endpoint or collection system unavailable',\n context:\n 'Use for observability-focused tools (Prometheus exporters, StatsD agents).\\nWorkhorses SHOULD log warning and continue unless configured to fail-fast.\\n',\n category: 'observability',\n },\n 81: {\n code: 81,\n name: 'EXIT_TRACING_FAILED',\n description: 'Distributed tracing system unavailable',\n context: 'OTLP exporter failed, Jaeger collector unreachable',\n category: 'observability',\n },\n 82: {\n code: 82,\n name: 'EXIT_LOGGING_FAILED',\n description: 'Logging system unavailable or misconfigured',\n context: 'Log aggregator unreachable, log file unwritable',\n category: 'observability',\n },\n 83: {\n code: 83,\n name: 'EXIT_ALERT_SYSTEM_FAILED',\n description: 'Alerting system unavailable',\n context: 'PagerDuty API failed, Slack webhook unreachable',\n category: 'observability',\n },\n 84: {\n code: 84,\n name: 'EXIT_STRUCTURED_LOGGING_FAILED',\n description: 'Structured logging system unavailable',\n context: 'JSON log aggregator unreachable, log schema validation failed',\n category: 'observability',\n },\n 91: {\n code: 91,\n name: 'EXIT_TEST_FAILURE',\n description: 'One or more tests failed',\n context:\n 'Test assertions failed, expected behavior not met.\\nMaps to pytest exit code 1, Go test failure, Jest failure.\\n',\n category: 'testing',\n },\n 92: {\n code: 92,\n name: 'EXIT_TEST_ERROR',\n description: 'Test execution error (not test failure)',\n context:\n 'Test setup failed, fixture unavailable, test harness error.\\nMaps to pytest exit code 3 (internal error).\\n',\n category: 'testing',\n },\n 93: {\n code: 93,\n name: 'EXIT_TEST_INTERRUPTED',\n description: 'Test run interrupted by user or system',\n context:\n 'Ctrl+C during tests, system signal, user cancellation.\\nMaps to pytest exit code 2.\\n',\n category: 'testing',\n },\n 94: {\n code: 94,\n name: 'EXIT_TEST_USAGE_ERROR',\n description: 'Test command usage error',\n context: 'Invalid test arguments, bad configuration.\\nMaps to pytest exit code 4.\\n',\n category: 'testing',\n },\n 95: {\n code: 95,\n name: 'EXIT_TEST_NO_TESTS_COLLECTED',\n description: 'No tests found or all tests skipped',\n context: 'Empty test suite, all tests deselected or skipped.\\nMaps to pytest exit code 5.\\n',\n category: 'testing',\n },\n 96: {\n code: 96,\n name: 'EXIT_COVERAGE_THRESHOLD_NOT_MET',\n description: 'Test coverage below required threshold',\n context: 'Code coverage validation, quality gate failure',\n category: 'testing',\n },\n 129: {\n code: 129,\n name: 'EXIT_SIGNAL_HUP',\n description: 'Hangup signal (SIGHUP)',\n context: 'Terminal disconnected, config reload requested',\n category: 'signals',\n bsdEquivalent: '128 + 1',\n },\n 130: {\n code: 130,\n name: 'EXIT_SIGNAL_INT',\n description: 'Interrupt signal (SIGINT)',\n context: 'Ctrl+C pressed, user interrupt',\n category: 'signals',\n bsdEquivalent: '128 + 2',\n },\n 131: {\n code: 131,\n name: 'EXIT_SIGNAL_QUIT',\n description: 'Quit signal (SIGQUIT)',\n context: 'Ctrl+\\\\ pressed, core dump requested',\n category: 'signals',\n bsdEquivalent: '128 + 3',\n },\n 137: {\n code: 137,\n name: 'EXIT_SIGNAL_KILL',\n description: 'Kill signal (SIGKILL)',\n context: 'Forceful termination, non-graceful shutdown (not catchable)',\n category: 'signals',\n bsdEquivalent: '128 + 9',\n pythonNote: 'Cannot be caught in Python (OS-level)',\n },\n 141: {\n code: 141,\n name: 'EXIT_SIGNAL_PIPE',\n description: 'Broken pipe (SIGPIPE)',\n context: 'Writing to closed pipe/socket, reader terminated',\n category: 'signals',\n bsdEquivalent: '128 + 13',\n pythonNote: 'Raised as BrokenPipeError exception',\n },\n 142: {\n code: 142,\n name: 'EXIT_SIGNAL_ALRM',\n description: 'Alarm signal (SIGALRM)',\n context: 'Timer expiration, alarm clock',\n category: 'signals',\n bsdEquivalent: '128 + 14',\n pythonNote: 'Supported by signal module, rarely used in practice',\n },\n 143: {\n code: 143,\n name: 'EXIT_SIGNAL_TERM',\n description: 'Termination signal (SIGTERM)',\n context: 'Graceful shutdown requested, normal termination',\n category: 'signals',\n bsdEquivalent: '128 + 15',\n pythonNote: 'Default signal for graceful shutdown',\n },\n 159: {\n code: 159,\n name: 'EXIT_SIGNAL_USR1',\n description: 'User-defined signal 1 (SIGUSR1)',\n context: 'Application-specific signal handling (e.g., reopen logs, dump stats)',\n category: 'signals',\n bsdEquivalent: '128 + 31',\n },\n 160: {\n code: 160,\n name: 'EXIT_SIGNAL_USR2',\n description: 'User-defined signal 2 (SIGUSR2)',\n context: 'Application-specific signal handling (e.g., toggle debug mode)',\n category: 'signals',\n bsdEquivalent: '128 + 32',\n },\n};\n\n/**\n * Get metadata for a specific exit code\n *\n * @param code - Exit code number\n * @returns Exit code metadata or undefined if not found\n */\nexport function getExitCodeInfo(code: number): ExitCodeInfo | undefined {\n return exitCodeMetadata[code];\n}\n\n/**\n * Catalog version for telemetry and compatibility checks\n */\nexport const EXIT_CODES_VERSION = 'v1.0.0';\n","/**\n * Exit Code Capabilities Detection\n *\n * Detects platform capabilities for exit code support, particularly\n * for signal-based exit codes which are POSIX-specific.\n *\n * @module foundry/exit-codes/capabilities\n */\n\n/**\n * Check if the current platform supports signal-based exit codes\n *\n * Signal exit codes (128+N pattern) are POSIX-specific and not\n * meaningful on Windows. Applications should use this to decide\n * whether to use simplified mode.\n *\n * @returns true if platform supports signal exit codes (POSIX), false otherwise (Windows)\n *\n * @example\n * ```ts\n * import { supportsSignalExitCodes, SimplifiedMode } from '@fulmenhq/tsfulmen/foundry/exit-codes';\n *\n * const exitCodeMode = supportsSignalExitCodes()\n * ? 'full' // Use all 54 exit codes\n * : SimplifiedMode.SEVERITY; // Use simplified mode on Windows\n *\n * console.log(`Exit code mode: ${exitCodeMode}`);\n * ```\n *\n * @example\n * ```ts\n * // Guard signal exit code usage\n * import { exitCodes, supportsSignalExitCodes } from '@fulmenhq/tsfulmen/foundry/exit-codes';\n *\n * function handleTermination() {\n * if (supportsSignalExitCodes()) {\n * // POSIX: Use specific signal exit code\n * process.exit(exitCodes.EXIT_SIGNAL_TERM);\n * } else {\n * // Windows: Use generic failure\n * process.exit(exitCodes.EXIT_FAILURE);\n * }\n * }\n * ```\n */\nexport function supportsSignalExitCodes(): boolean {\n // Windows does not support POSIX signals in the same way\n // WSL reports as 'linux' so it will correctly return true\n return process.platform !== 'win32';\n}\n\n/**\n * Get the current platform identifier\n *\n * Useful for logging and diagnostics.\n *\n * @returns Platform string (linux, darwin, win32, etc.)\n */\nexport function getPlatform(): NodeJS.Platform {\n return process.platform;\n}\n\n/**\n * Check if running on Windows (including WSL detection)\n *\n * Note: WSL reports as 'linux' not 'win32', so this only returns\n * true for native Windows processes.\n *\n * @returns true if running on native Windows\n */\nexport function isWindows(): boolean {\n return process.platform === 'win32';\n}\n\n/**\n * Check if running on a POSIX-compliant platform\n *\n * @returns true if running on Linux, macOS, or other POSIX systems\n */\nexport function isPOSIX(): boolean {\n return !isWindows();\n}\n\n/**\n * Platform capabilities summary\n */\nexport interface PlatformCapabilities {\n platform: NodeJS.Platform;\n supportsSignalExitCodes: boolean;\n isPOSIX: boolean;\n isWindows: boolean;\n}\n\n/**\n * Get a summary of platform capabilities\n *\n * @returns Platform capabilities object\n *\n * @example\n * ```ts\n * import { getPlatformCapabilities } from '@fulmenhq/tsfulmen/foundry/exit-codes';\n *\n * const caps = getPlatformCapabilities();\n * console.log(`Platform: ${caps.platform}`);\n * console.log(`Supports signal exit codes: ${caps.supportsSignalExitCodes}`);\n * ```\n */\nexport function getPlatformCapabilities(): PlatformCapabilities {\n return {\n platform: getPlatform(),\n supportsSignalExitCodes: supportsSignalExitCodes(),\n isPOSIX: isPOSIX(),\n isWindows: isWindows(),\n };\n}\n","/**\n * Simplified Exit Code Mapping\n *\n * Provides simplified exit code modes for applications that don't need\n * the full granularity of 54 exit codes. Useful for:\n * - Windows environments where signal codes may not be relevant\n * - Simple scripts that only need basic success/failure indication\n * - Wrapper scripts that aggregate multiple failure types\n *\n * @module foundry/exit-codes/simplified\n */\n\nimport type { ExitCode } from '../../crucible/foundry/exitCodes.js';\nimport { exitCodeMetadata } from '../../crucible/foundry/exitCodes.js';\n\n/**\n * Simplified exit code modes\n */\nexport enum SimplifiedMode {\n /**\n * BASIC mode: Only success (0) and failure (1)\n * - 0 = EXIT_SUCCESS\n * - 1 = All failures\n */\n BASIC = 'basic',\n\n /**\n * SEVERITY mode: Success, recoverable, config, fatal\n * - 0 = EXIT_SUCCESS\n * - 1 = Recoverable errors (retry possible)\n * - 2 = Configuration/usage errors (fix config, don't retry)\n * - 3 = Fatal errors (investigate required)\n */\n SEVERITY = 'severity',\n}\n\n/**\n * Map a full exit code to a simplified code based on mode\n *\n * @param code - Full exit code from exitCodes\n * @param mode - Simplified mode to use\n * @returns Simplified exit code (0-3 depending on mode)\n *\n * @example\n * ```ts\n * import { exitCodes, mapExitCodeToSimplified, SimplifiedMode } from '@fulmenhq/tsfulmen/foundry/exit-codes';\n *\n * // Basic mode - only 0 or 1\n * const basicCode = mapExitCodeToSimplified(exitCodes.EXIT_CONFIG_INVALID, SimplifiedMode.BASIC);\n * console.log(basicCode); // 1 (any failure)\n *\n * // Severity mode - categorizes failures\n * const sevCode = mapExitCodeToSimplified(exitCodes.EXIT_CONFIG_INVALID, SimplifiedMode.SEVERITY);\n * console.log(sevCode); // 2 (config error - don't retry)\n *\n * const retryCode = mapExitCodeToSimplified(exitCodes.EXIT_DATABASE_UNAVAILABLE, SimplifiedMode.SEVERITY);\n * console.log(retryCode); // 1 (recoverable - retry possible)\n * ```\n */\nexport function mapExitCodeToSimplified(\n code: ExitCode,\n mode: SimplifiedMode = SimplifiedMode.BASIC,\n): number {\n // Success is always 0\n if (code === 0) {\n return 0;\n }\n\n // BASIC mode: everything else is 1\n if (mode === SimplifiedMode.BASIC) {\n return 1;\n }\n\n // SEVERITY mode: categorize based on metadata\n const info = exitCodeMetadata[code];\n if (!info) {\n // Unknown code - treat as fatal\n return 3;\n }\n\n // Check retry hint first\n if (info.retryHint === 'retry') {\n // Recoverable - likely transient failure\n return 1;\n }\n\n if (info.retryHint === 'no_retry') {\n // Configuration/permanent error - don't retry\n return 2;\n }\n\n if (info.retryHint === 'investigate') {\n // Serious issue requiring investigation\n return 3;\n }\n\n // Category-based fallback\n switch (info.category) {\n case 'configuration':\n case 'usage':\n // Config and usage errors - fix config, don't retry\n return 2;\n\n case 'networking':\n case 'runtime':\n // Network and runtime issues - often recoverable\n return 1;\n\n case 'permissions':\n case 'data':\n // Permission and data errors - likely permanent\n return 2;\n\n case 'security':\n // Security issues - investigate\n return 3;\n\n case 'observability':\n // Observability failures - recoverable if non-critical\n return 1;\n\n case 'testing':\n // Test failures - depends on context, default to failure\n return 1;\n\n case 'signals':\n // Signal termination - not applicable on Windows\n // Treat as fatal since process was forcibly terminated\n return 3;\n\n default:\n // Unknown category - treat as generic failure\n return 1;\n }\n}\n\n/**\n * Get all simplified exit codes for a given mode\n *\n * @param mode - Simplified mode\n * @returns Array of simplified codes for this mode\n *\n * @example\n * ```ts\n * import { getSimplifiedCodes, SimplifiedMode } from '@fulmenhq/tsfulmen/foundry/exit-codes';\n *\n * console.log(getSimplifiedCodes(SimplifiedMode.BASIC));\n * // [0, 1]\n *\n * console.log(getSimplifiedCodes(SimplifiedMode.SEVERITY));\n * // [0, 1, 2, 3]\n * ```\n */\nexport function getSimplifiedCodes(mode: SimplifiedMode): number[] {\n switch (mode) {\n case SimplifiedMode.BASIC:\n return [0, 1];\n case SimplifiedMode.SEVERITY:\n return [0, 1, 2, 3];\n default:\n return [0, 1];\n }\n}\n\n/**\n * Get description for a simplified exit code\n *\n * @param code - Simplified exit code\n * @param mode - Simplified mode\n * @returns Human-readable description\n */\nexport function getSimplifiedCodeDescription(code: number, mode: SimplifiedMode): string {\n if (mode === SimplifiedMode.BASIC) {\n switch (code) {\n case 0:\n return 'Success';\n case 1:\n return 'Failure';\n default:\n return 'Unknown';\n }\n }\n\n if (mode === SimplifiedMode.SEVERITY) {\n switch (code) {\n case 0:\n return 'Success';\n case 1:\n return 'Recoverable error (retry possible)';\n case 2:\n return \"Configuration error (fix config, don't retry)\";\n case 3:\n return 'Fatal error (investigate required)';\n default:\n return 'Unknown';\n }\n }\n\n return 'Unknown mode';\n}\n","/**\n * Exit Codes Module\n *\n * Standardized process exit codes for the Fulmen ecosystem.\n * Generated from Crucible catalog and synced via make sync-ssot.\n *\n * @module foundry/exit-codes\n */\n\n// Re-export generated exit codes from crucible foundry\nexport {\n EXIT_CODES_VERSION,\n type ExitCode,\n type ExitCodeInfo,\n type ExitCodeName,\n exitCodeMetadata,\n exitCodes,\n getExitCodeInfo,\n} from '../../crucible/foundry/exitCodes.js';\n// Export capability detection helpers\nexport {\n getPlatform,\n getPlatformCapabilities,\n isPOSIX,\n isWindows,\n type PlatformCapabilities,\n supportsSignalExitCodes,\n} from './capabilities.js';\n// Export simplified mode helpers\nexport {\n getSimplifiedCodeDescription,\n getSimplifiedCodes,\n mapExitCodeToSimplified,\n SimplifiedMode,\n} from './simplified.js';\n","/**\n * Foundry HTTP Status Catalog - implements HTTP status code access and helpers\n */\n\nimport { loadHttpStatusCatalog } from './loader.js';\nimport type { HttpStatusCatalog, HttpStatusCode, HttpStatusGroupId } from './types.js';\n\nlet catalogCache: HttpStatusCatalog | null = null;\nconst statusCodeIndex = new Map<number, HttpStatusCode>();\n\nfunction deepClone<T>(obj: T): T {\n if (obj === null || typeof obj !== 'object') {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => deepClone(item)) as T;\n }\n\n const cloned: Record<string, unknown> = {};\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n cloned[key] = deepClone((obj as Record<string, unknown>)[key]);\n }\n }\n return cloned as T;\n}\n\nfunction deepFreeze<T extends object>(obj: T): T {\n Object.freeze(obj);\n\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n const value = obj[key];\n if (value !== null && typeof value === 'object') {\n deepFreeze(value);\n }\n }\n }\n\n return obj;\n}\n\nasync function ensureCatalogLoaded(): Promise<void> {\n if (catalogCache !== null) {\n return;\n }\n\n catalogCache = await loadHttpStatusCatalog();\n\n for (const group of catalogCache.groups) {\n const groupId = group.id as HttpStatusGroupId;\n for (const code of group.codes) {\n statusCodeIndex.set(code.value, {\n value: code.value,\n reason: code.reason,\n group: groupId,\n });\n }\n }\n}\n\nexport async function getHttpStatus(code: number): Promise<Readonly<HttpStatusCode> | null> {\n await ensureCatalogLoaded();\n const status = statusCodeIndex.get(code);\n return status ? deepFreeze(deepClone(status)) : null;\n}\n\nexport function isInformational(code: number): boolean {\n return code >= 100 && code < 200;\n}\n\nexport function isSuccess(code: number): boolean {\n return code >= 200 && code < 300;\n}\n\nexport function isRedirection(code: number): boolean {\n return code >= 300 && code < 400;\n}\n\nexport function isClientError(code: number): boolean {\n return code >= 400 && code < 500;\n}\n\nexport function isServerError(code: number): boolean {\n return code >= 500 && code < 600;\n}\n\nexport async function listHttpStatuses(): Promise<ReadonlyArray<Readonly<HttpStatusCode>>> {\n await ensureCatalogLoaded();\n return Array.from(statusCodeIndex.values()).map((s) => deepFreeze(deepClone(s)));\n}\n\nexport async function getStatusReason(code: number): Promise<string | null> {\n const status = await getHttpStatus(code);\n return status?.reason ?? null;\n}\n\nexport function clearHttpStatusCache(): void {\n catalogCache = null;\n statusCodeIndex.clear();\n}\n","/**\n * Foundry MIME Type Magic Number Database\n *\n * Defines byte patterns (magic numbers) for content-based MIME type detection.\n * Patterns are ordered by priority for accurate multi-format detection.\n */\n\nexport interface MagicNumberPattern {\n offset: number;\n bytes: number[];\n mask?: number[];\n description: string;\n}\n\nexport type MatchStrategy = 'exact' | 'heuristic';\n\nexport interface MagicNumberSignature {\n mimeType: string;\n patterns: MagicNumberPattern[];\n priority: number;\n matchStrategy: MatchStrategy;\n}\n\n// UTF-8 BOM (Byte Order Mark)\nexport const UTF8_BOM: number[] = [0xef, 0xbb, 0xbf];\n\n// XML Patterns (Priority 10 - Most specific)\nconst XML_PATTERNS: MagicNumberPattern[] = [\n {\n offset: 0,\n bytes: [0x3c, 0x3f, 0x78, 0x6d, 0x6c],\n description: 'XML declaration: <?xml',\n },\n {\n offset: 0,\n bytes: [0xef, 0xbb, 0xbf, 0x3c, 0x3f, 0x78, 0x6d, 0x6c],\n description: 'XML with UTF-8 BOM: BOM + <?xml',\n },\n];\n\n// JSON Patterns (Priority 9)\nconst JSON_PATTERNS: MagicNumberPattern[] = [\n {\n offset: 0,\n bytes: [0x7b],\n description: 'JSON object start: {',\n },\n {\n offset: 0,\n bytes: [0x5b],\n description: 'JSON array start: [',\n },\n {\n offset: 0,\n bytes: [0xef, 0xbb, 0xbf, 0x7b],\n description: 'JSON object with BOM: BOM + {',\n },\n {\n offset: 0,\n bytes: [0xef, 0xbb, 0xbf, 0x5b],\n description: 'JSON array with BOM: BOM + [',\n },\n];\n\n// YAML Patterns (Priority 8)\nconst YAML_PATTERNS: MagicNumberPattern[] = [\n {\n offset: 0,\n bytes: [0x2d, 0x2d, 0x2d],\n description: 'YAML document marker: ---',\n },\n {\n offset: 0,\n bytes: [0x25, 0x59, 0x41, 0x4d, 0x4c],\n description: 'YAML directive: %YAML',\n },\n];\n\n// NDJSON Patterns (Priority 7 - Heuristic only)\nconst NDJSON_PATTERNS: MagicNumberPattern[] = [];\n\n// CSV Patterns (Priority 6 - Heuristic only)\nconst CSV_PATTERNS: MagicNumberPattern[] = [];\n\n// Protobuf Patterns (Priority 5 - Heuristic only)\nconst PROTOBUF_PATTERNS: MagicNumberPattern[] = [];\n\n// Plain Text Patterns (Priority 1 - Fallback, heuristic)\nconst TEXT_PATTERNS: MagicNumberPattern[] = [];\n\n/**\n * Magic Number Database\n *\n * Ordered by detection priority (highest first).\n * Note: Heuristic detection runs BEFORE exact pattern matching\n * for formats that can be ambiguous (NDJSON vs JSON).\n */\nexport const MAGIC_NUMBER_DATABASE: MagicNumberSignature[] = [\n {\n mimeType: 'application/xml',\n patterns: XML_PATTERNS,\n priority: 10,\n matchStrategy: 'exact',\n },\n {\n mimeType: 'application/x-ndjson',\n patterns: NDJSON_PATTERNS,\n priority: 9,\n matchStrategy: 'heuristic',\n },\n {\n mimeType: 'application/json',\n patterns: JSON_PATTERNS,\n priority: 8,\n matchStrategy: 'exact',\n },\n {\n mimeType: 'application/yaml',\n patterns: YAML_PATTERNS,\n priority: 7,\n matchStrategy: 'exact',\n },\n {\n mimeType: 'application/yaml',\n patterns: [],\n priority: 6.5,\n matchStrategy: 'heuristic',\n },\n {\n mimeType: 'text/csv',\n patterns: CSV_PATTERNS,\n priority: 6,\n matchStrategy: 'heuristic',\n },\n {\n mimeType: 'application/x-protobuf',\n patterns: PROTOBUF_PATTERNS,\n priority: 5,\n matchStrategy: 'heuristic',\n },\n {\n mimeType: 'text/plain',\n patterns: TEXT_PATTERNS,\n priority: 1,\n matchStrategy: 'heuristic',\n },\n];\n\n/**\n * Check if buffer starts with UTF-8 BOM\n */\nexport function hasBOM(buffer: Buffer): boolean {\n if (buffer.length < 3) return false;\n return buffer[0] === UTF8_BOM[0] && buffer[1] === UTF8_BOM[1] && buffer[2] === UTF8_BOM[2];\n}\n\n/**\n * Get offset to skip BOM if present\n */\nexport function getBOMOffset(buffer: Buffer): number {\n return hasBOM(buffer) ? 3 : 0;\n}\n","/**\n * Foundry MIME Type Detector\n *\n * Pattern matching engine for content-based MIME type detection using\n * magic numbers and heuristic analysis.\n */\n\nimport {\n getBOMOffset,\n MAGIC_NUMBER_DATABASE,\n type MagicNumberPattern,\n type MagicNumberSignature,\n} from './magic-numbers.js';\nimport type { MimeType } from './types.js';\n\nexport interface DetectionOptions {\n /**\n * Fall back to extension-based detection if magic number detection fails.\n * Default: true\n */\n fallbackToExtension?: boolean;\n\n /**\n * Number of bytes to read for magic number detection.\n * Default: 512\n */\n bytesToRead?: number;\n\n /**\n * File extension hint for fallback detection.\n * Useful when input is a Buffer without path context.\n */\n extensionHint?: string;\n}\n\nexport class MimeTypeDetector {\n private patterns: MagicNumberSignature[];\n private catalog: Map<string, MimeType>;\n\n constructor(patterns: MagicNumberSignature[], catalog: Map<string, MimeType>) {\n this.patterns = [...patterns].sort((a, b) => b.priority - a.priority);\n this.catalog = catalog;\n }\n\n /**\n * Detect MIME type from buffer content\n */\n detect(buffer: Buffer, _options: DetectionOptions = {}): MimeType | null {\n // Skip BOM if present\n const offset = getBOMOffset(buffer);\n const workingBuffer = offset > 0 ? buffer.subarray(offset) : buffer;\n\n // Try patterns in priority order, regardless of strategy\n // This allows NDJSON heuristic to run before JSON exact match\n for (const pattern of this.patterns) {\n if (pattern.matchStrategy === 'exact' && this.matchPattern(workingBuffer, pattern)) {\n return this.catalog.get(pattern.mimeType) || null;\n }\n if (pattern.matchStrategy === 'heuristic' && this.matchHeuristic(workingBuffer, pattern)) {\n return this.catalog.get(pattern.mimeType) || null;\n }\n }\n\n return null;\n }\n\n /**\n * Match buffer against a pattern signature\n */\n private matchPattern(buffer: Buffer, signature: MagicNumberSignature): boolean {\n for (const pattern of signature.patterns) {\n if (this.matchBytes(buffer, pattern)) {\n return true;\n }\n }\n return false;\n }\n\n /**\n * Match bytes at specified offset with optional masking\n */\n private matchBytes(buffer: Buffer, pattern: MagicNumberPattern): boolean {\n const { offset, bytes, mask } = pattern;\n\n if (buffer.length < offset + bytes.length) {\n return false;\n }\n\n for (let i = 0; i < bytes.length; i++) {\n const bufferByte = buffer[offset + i];\n const patternByte = bytes[i];\n const maskByte = mask ? mask[i] : 0xff;\n\n if ((bufferByte & maskByte) !== (patternByte & maskByte)) {\n return false;\n }\n }\n\n return true;\n }\n\n /**\n * Heuristic detection for formats without magic numbers\n */\n private matchHeuristic(buffer: Buffer, signature: MagicNumberSignature): boolean {\n switch (signature.mimeType) {\n case 'application/x-ndjson':\n return this.detectNDJSON(buffer);\n case 'application/yaml':\n return this.detectYAML(buffer);\n case 'text/csv':\n return this.detectCSV(buffer);\n case 'application/x-protobuf':\n return this.detectProtobuf(buffer);\n case 'text/plain':\n return this.detectPlainText(buffer);\n default:\n return false;\n }\n }\n\n /**\n * Detect NDJSON (newline-delimited JSON)\n */\n private detectNDJSON(buffer: Buffer): boolean {\n try {\n const text = buffer.toString('utf-8', 0, Math.min(buffer.length, 512));\n const lines = text.split('\\n').filter((line) => line.trim().length > 0);\n\n if (lines.length < 2) return false;\n\n // Check if at least first 2-3 lines are valid JSON\n const linesToCheck = Math.min(3, lines.length);\n let validJsonLines = 0;\n\n for (let i = 0; i < linesToCheck; i++) {\n try {\n JSON.parse(lines[i]);\n validJsonLines++;\n } catch {\n return false;\n }\n }\n\n return validJsonLines >= 2;\n } catch {\n return false;\n }\n }\n\n /**\n * Detect YAML format (heuristic for files without --- header)\n */\n private detectYAML(buffer: Buffer): boolean {\n try {\n const text = buffer.toString('utf-8', 0, Math.min(buffer.length, 512));\n const lines = text.split('\\n').filter((line) => line.trim().length > 0);\n\n if (lines.length === 0) return false;\n\n // Count YAML-like patterns\n let yamlIndicators = 0;\n let nonYamlIndicators = 0;\n\n for (const line of lines.slice(0, 10)) {\n const trimmed = line.trim();\n\n // Skip comments\n if (trimmed.startsWith('#')) continue;\n\n // YAML key-value pattern: \"key: value\"\n if (/^[\\w\"'-]+\\s*:\\s*.+$/.test(trimmed)) {\n yamlIndicators++;\n continue;\n }\n\n // YAML list item: \"- item\"\n if (/^-\\s+/.test(trimmed)) {\n yamlIndicators++;\n continue;\n }\n\n // JSON-like patterns suggest not YAML\n if (trimmed.startsWith('{') || trimmed.startsWith('[') || trimmed.endsWith(',')) {\n nonYamlIndicators++;\n }\n }\n\n // Require at least 2 YAML indicators and no JSON indicators\n return yamlIndicators >= 2 && nonYamlIndicators === 0;\n } catch {\n return false;\n }\n }\n\n /**\n * Detect CSV format\n */\n private detectCSV(buffer: Buffer): boolean {\n try {\n const text = buffer.toString('utf-8', 0, Math.min(buffer.length, 512));\n const lines = text.split('\\n').filter((line) => line.trim().length > 0);\n\n if (lines.length < 2) return false;\n\n // Try common delimiters\n const delimiters = [',', ';', '\\t'];\n\n for (const delimiter of delimiters) {\n const counts = lines.map((line) => {\n const escaped = delimiter.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&');\n const matches = line.match(new RegExp(escaped, 'g'));\n return matches ? matches.length : 0;\n });\n\n // Check for consistent delimiter count across lines (and at least 1 delimiter)\n const firstCount = counts[0];\n if (firstCount > 0 && counts.every((count) => count === firstCount)) {\n return true;\n }\n }\n\n return false;\n } catch {\n return false;\n }\n }\n\n /**\n * Detect protobuf binary format\n */\n private detectProtobuf(buffer: Buffer): boolean {\n if (buffer.length < 4) return false;\n\n // Protobuf messages typically start with field tags\n // Field tag = (field_number << 3) | wire_type\n // Wire types: 0 (varint), 1 (64-bit), 2 (length-delimited), 5 (32-bit)\n\n const firstByte = buffer[0];\n const wireType = firstByte & 0x07;\n const fieldNumber = firstByte >> 3;\n\n // Valid wire type (0-5, excluding 3 and 4 which are deprecated)\n const hasValidWireType = wireType === 0 || wireType === 1 || wireType === 2 || wireType === 5;\n\n // Reasonable field number (1-99)\n const hasValidFieldNumber = fieldNumber > 0 && fieldNumber < 100;\n\n // Check if content is binary (not text)\n const isBinary = this.isBinaryContent(buffer);\n\n // All three conditions must be met\n return hasValidWireType && hasValidFieldNumber && isBinary;\n }\n\n /**\n * Detect plain text format\n */\n private detectPlainText(buffer: Buffer): boolean {\n const sample = buffer.subarray(0, Math.min(buffer.length, 512));\n\n // Reject empty buffers\n if (sample.length === 0) return false;\n\n let binaryBytes = 0;\n\n for (const byte of sample) {\n // Count null bytes and non-printable characters (excluding common whitespace)\n if (byte === 0x00 || (byte < 0x20 && byte !== 0x09 && byte !== 0x0a && byte !== 0x0d)) {\n binaryBytes++;\n }\n }\n\n // If less than 5% binary bytes, likely text (stricter threshold)\n return binaryBytes / sample.length < 0.05;\n }\n\n /**\n * Check if buffer contains binary content\n */\n private isBinaryContent(buffer: Buffer): boolean {\n const sample = buffer.subarray(0, Math.min(buffer.length, 512));\n let binaryBytes = 0;\n\n for (const byte of sample) {\n if (byte === 0x00 || (byte < 0x20 && byte !== 0x09 && byte !== 0x0a && byte !== 0x0d)) {\n binaryBytes++;\n }\n }\n\n // More than 10% binary bytes indicates binary content\n return binaryBytes / sample.length > 0.1;\n }\n}\n\n/**\n * Create a detector instance with the global magic number database\n */\nexport function createDetector(catalog: Map<string, MimeType>): MimeTypeDetector {\n return new MimeTypeDetector(MAGIC_NUMBER_DATABASE, catalog);\n}\n","/**\n * Foundry MIME Type Catalog - implements MIME type detection and lookup\n *\n * v0.1.1: Extension-based detection\n * v0.1.2: Magic number detection with streaming support\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { Readable } from 'node:stream';\nimport { createDetector, type DetectionOptions } from './detector.js';\nimport { loadMimeTypeCatalog } from './loader.js';\nimport type { MimeType, MimeTypeCatalog } from './types.js';\n\nlet catalogCache: MimeTypeCatalog | null = null;\nconst mimeStringIndex = new Map<string, MimeType>();\nconst extensionIndex = new Map<string, MimeType>();\nlet detectorInstance: ReturnType<typeof createDetector> | null = null;\n\nfunction deepClone<T>(obj: T): T {\n if (obj === null || typeof obj !== 'object') {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => deepClone(item)) as T;\n }\n\n const cloned: Record<string, unknown> = {};\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n cloned[key] = deepClone((obj as Record<string, unknown>)[key]);\n }\n }\n return cloned as T;\n}\n\nfunction deepFreeze<T extends object>(obj: T): T {\n Object.freeze(obj);\n\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n const value = obj[key];\n if (value !== null && typeof value === 'object') {\n deepFreeze(value);\n }\n }\n }\n\n return obj;\n}\n\nasync function ensureCatalogLoaded(): Promise<void> {\n if (catalogCache !== null) {\n return;\n }\n\n catalogCache = await loadMimeTypeCatalog();\n\n for (const mimeType of catalogCache.types) {\n // Index by MIME string (case-insensitive)\n mimeStringIndex.set(mimeType.mime.toLowerCase(), mimeType);\n\n // Index by extensions (case-insensitive, with and without leading dot)\n for (const ext of mimeType.extensions) {\n const normalized = ext.toLowerCase().replace(/^\\./, '');\n extensionIndex.set(normalized, mimeType);\n }\n }\n\n // Initialize detector\n detectorInstance = createDetector(mimeStringIndex);\n}\n\nexport async function getMimeType(mimeString: string): Promise<Readonly<MimeType> | null> {\n await ensureCatalogLoaded();\n const normalized = mimeString.toLowerCase();\n const mimeType = mimeStringIndex.get(normalized);\n return mimeType ? deepFreeze(deepClone(mimeType)) : null;\n}\n\nexport async function getMimeTypeByExtension(\n extension: string,\n): Promise<Readonly<MimeType> | null> {\n await ensureCatalogLoaded();\n const normalized = extension.toLowerCase().replace(/^\\./, '');\n const mimeType = extensionIndex.get(normalized);\n return mimeType ? deepFreeze(deepClone(mimeType)) : null;\n}\n\n/**\n * Check if a MIME type is supported in the catalog\n *\n * Note: Must be async to ensure catalog is loaded on cold calls.\n * Without ensureCatalogLoaded(), mimeStringIndex would be empty\n * and return false even for valid types.\n */\nexport async function isSupportedMimeType(mime: string): Promise<boolean> {\n await ensureCatalogLoaded();\n return mimeStringIndex.has(mime.toLowerCase());\n}\n\n/**\n * Detect MIME type from content using magic number analysis.\n *\n * Supports multiple input types:\n * - Buffer: Direct content analysis\n * - string (file path): Read and analyze file\n * - ReadableStream: Stream first N bytes for analysis\n * - Readable: Node.js stream first N bytes for analysis\n *\n * @param input - Content to analyze\n * @param options - Detection options\n * @returns Detected MIME type or null if unknown\n */\nexport async function detectMimeType(\n input: Buffer | ReadableStream | Readable | string,\n options?: DetectionOptions,\n): Promise<Readonly<MimeType> | null> {\n await ensureCatalogLoaded();\n\n if (!detectorInstance) {\n throw new Error('Detector not initialized');\n }\n\n // Handle different input types\n if (typeof input === 'string') {\n return detectMimeTypeFromFile(input, options);\n }\n\n if (Buffer.isBuffer(input)) {\n return detectMimeTypeFromBuffer(input, options);\n }\n\n return detectMimeTypeFromStream(input, options);\n}\n\n/**\n * Detect MIME type from file path\n */\nexport async function detectMimeTypeFromFile(\n filePath: string,\n options: DetectionOptions = {},\n): Promise<Readonly<MimeType> | null> {\n await ensureCatalogLoaded();\n\n if (!detectorInstance) {\n throw new Error('Detector not initialized');\n }\n\n const bytesToRead = options.bytesToRead || 512;\n\n // Use Bun.file() when available for better performance\n if (typeof Bun !== 'undefined') {\n const file = Bun.file(filePath);\n if (!(await file.exists())) {\n return null;\n }\n const slice = file.slice(0, bytesToRead);\n const arrayBuffer = await slice.arrayBuffer();\n const buffer = Buffer.from(arrayBuffer);\n return detectMimeTypeFromBuffer(buffer, options);\n }\n\n // Node.js fallback\n try {\n const buffer = await readFile(filePath, { encoding: null });\n const sample = buffer.subarray(0, Math.min(buffer.length, bytesToRead));\n return detectMimeTypeFromBuffer(sample, options);\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code === 'ENOENT') {\n return null;\n }\n throw error;\n }\n}\n\n/**\n * Detect MIME type from Buffer\n */\nexport function detectMimeTypeFromBuffer(\n buffer: Buffer,\n options: DetectionOptions = {},\n): Readonly<MimeType> | null {\n if (!detectorInstance) {\n throw new Error('Detector not initialized');\n }\n\n const result = detectorInstance.detect(buffer, options);\n return result ? deepFreeze(deepClone(result)) : null;\n}\n\n/**\n * Detect MIME type from stream (ReadableStream or Node.js Readable)\n */\nexport async function detectMimeTypeFromStream(\n stream: ReadableStream | Readable,\n options: DetectionOptions = {},\n): Promise<Readonly<MimeType> | null> {\n await ensureCatalogLoaded();\n\n const bytesToRead = options.bytesToRead || 512;\n const chunks: Uint8Array[] = [];\n let totalBytes = 0;\n\n // Convert Node.js Readable to Web ReadableStream if needed\n const webStream: ReadableStream =\n typeof (stream as ReadableStream).getReader === 'function'\n ? (stream as ReadableStream)\n : Readable.toWeb(stream as Readable);\n\n const reader = webStream.getReader();\n\n try {\n while (totalBytes < bytesToRead) {\n const { value, done } = await reader.read();\n if (done) break;\n\n chunks.push(value);\n totalBytes += value.length;\n }\n\n const buffer = Buffer.concat(chunks.map((c) => Buffer.from(c)));\n const sample = buffer.subarray(0, Math.min(buffer.length, bytesToRead));\n\n return detectMimeTypeFromBuffer(sample, options);\n } finally {\n reader.releaseLock();\n }\n}\n\n/**\n * Check if buffer matches a known magic number pattern\n */\nexport function matchMagicNumber(buffer: Buffer, mimeType: string): boolean {\n if (!detectorInstance) {\n throw new Error('Detector not initialized');\n }\n\n const result = detectorInstance.detect(buffer);\n return result?.mime === mimeType;\n}\n\nexport async function listMimeTypes(): Promise<ReadonlyArray<Readonly<MimeType>>> {\n await ensureCatalogLoaded();\n return Array.from(mimeStringIndex.values()).map((m) => deepFreeze(deepClone(m)));\n}\n\nexport function clearMimeTypeCache(): void {\n catalogCache = null;\n mimeStringIndex.clear();\n extensionIndex.clear();\n detectorInstance = null;\n}\n","/**\n * Foundry Pattern Catalog - implements pattern access and matching\n */\n\nimport picomatch from 'picomatch';\nimport { FoundryCatalogError } from './errors.js';\nimport { loadPatternCatalog } from './loader.js';\nimport type { Pattern, PatternCatalog } from './types.js';\n\nlet catalogCache: PatternCatalog | null = null;\nconst patternIndex = new Map<string, Pattern>();\nconst compiledRegexCache = new Map<string, RegExp>();\nconst compiledGlobCache = new Map<string, ReturnType<typeof picomatch>>();\n\nfunction deepClone<T>(obj: T): T {\n if (obj === null || typeof obj !== 'object') {\n return obj;\n }\n\n if (Array.isArray(obj)) {\n return obj.map((item) => deepClone(item)) as T;\n }\n\n const cloned: Record<string, unknown> = {};\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n cloned[key] = deepClone((obj as Record<string, unknown>)[key]);\n }\n }\n return cloned as T;\n}\n\nfunction deepFreeze<T extends object>(obj: T): T {\n Object.freeze(obj);\n\n for (const key in obj) {\n if (Object.hasOwn(obj, key)) {\n const value = obj[key];\n if (value !== null && typeof value === 'object') {\n deepFreeze(value);\n }\n }\n }\n\n return obj;\n}\n\nasync function ensureCatalogLoaded(): Promise<void> {\n if (catalogCache !== null) {\n return;\n }\n\n catalogCache = await loadPatternCatalog();\n\n for (const pattern of catalogCache.patterns) {\n patternIndex.set(pattern.id, pattern);\n }\n}\n\nexport async function getPattern(id: string): Promise<Readonly<Pattern> | null> {\n await ensureCatalogLoaded();\n const pattern = patternIndex.get(id);\n return pattern ? deepFreeze(deepClone(pattern)) : null;\n}\n\nexport async function getPatternRegex(id: string): Promise<RegExp | null> {\n await ensureCatalogLoaded();\n const pattern = patternIndex.get(id);\n\n if (!pattern) {\n return null;\n }\n\n if (pattern.kind !== 'regex') {\n throw FoundryCatalogError.invalidSchema(\n 'patterns',\n `Pattern '${id}' is not a regex pattern (kind: ${pattern.kind})`,\n );\n }\n\n const cached = compiledRegexCache.get(id);\n if (cached !== undefined) {\n return cached;\n }\n\n let flags = '';\n if (pattern.flags?.typescript?.ignoreCase) {\n flags += 'i';\n }\n\n const hasUnicodePropertyEscapes = /\\\\p\\{/.test(pattern.pattern);\n if (pattern.flags?.typescript?.unicode || hasUnicodePropertyEscapes) {\n flags += 'u';\n }\n\n const regex = new RegExp(pattern.pattern, flags);\n compiledRegexCache.set(id, regex);\n return regex;\n}\n\nfunction getCompiledGlob(id: string, pattern: string): ReturnType<typeof picomatch> {\n const cached = compiledGlobCache.get(id);\n if (cached !== undefined) {\n return cached;\n }\n\n const matcher = picomatch(pattern);\n compiledGlobCache.set(id, matcher);\n return matcher;\n}\n\nexport async function matchPattern(id: string, value: string): Promise<boolean> {\n await ensureCatalogLoaded();\n const pattern = patternIndex.get(id);\n\n if (!pattern) {\n throw FoundryCatalogError.missingCatalog(`Pattern '${id}' not found`);\n }\n\n if (pattern.kind === 'regex') {\n const regex = await getPatternRegex(id);\n return regex ? regex.test(value) : false;\n }\n\n if (pattern.kind === 'glob') {\n const matcher = getCompiledGlob(id, pattern.pattern);\n return matcher(value);\n }\n\n if (pattern.kind === 'literal') {\n return pattern.pattern === value;\n }\n\n throw FoundryCatalogError.invalidSchema('patterns', `Unknown pattern kind: ${pattern.kind}`);\n}\n\nexport async function listPatterns(): Promise<ReadonlyArray<Readonly<Pattern>>> {\n await ensureCatalogLoaded();\n return Array.from(patternIndex.values()).map((p) => deepFreeze(deepClone(p)));\n}\n\nexport async function describePattern(id: string): Promise<string | null> {\n const pattern = await getPattern(id);\n return pattern?.description ?? null;\n}\n\nexport function clearPatternCache(): void {\n catalogCache = null;\n patternIndex.clear();\n compiledRegexCache.clear();\n compiledGlobCache.clear();\n}\n","/**\n * Signal Catalog Loader\n *\n * Loads and validates the signal handling catalog from Crucible SSOT assets\n * following the same pattern as other Foundry catalogs.\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { dirname, join } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { parse as parseYaml } from 'yaml';\nimport { validateDataBySchemaId } from '../../schema/validator.js';\nimport { FoundryCatalogError } from '../errors.js';\nimport type { BehaviorInfo, SignalCatalog, SignalInfo } from './types.js';\n\n// Get the directory of the current module file for proper path resolution\nconst __filename = fileURLToPath(import.meta.url);\nconst __dirname = dirname(__filename);\n\n// SSOT Asset Paths (relative to module file, resolved to absolute paths)\nconst SSOT_PATHS = {\n signals: join(__dirname, '../../../config/crucible-ts/library/foundry/signals.yaml'),\n} as const;\n\n// Schema ID for signals catalog (from Crucible SSOT)\nconst SCHEMA_ID = 'library/foundry/v1.0.0/signals';\n\n/**\n * Load and validate the Signal Catalog from SSOT\n * Bun-first approach with Node.js fallback\n */\nasync function loadCatalog(): Promise<SignalCatalog> {\n const filePath = SSOT_PATHS.signals;\n const catalogName = 'signals';\n\n try {\n let content: string;\n\n // Bun-first approach\n if (typeof Bun !== 'undefined') {\n try {\n const file = Bun.file(filePath);\n if (!(await file.exists())) {\n throw FoundryCatalogError.missingCatalog(catalogName);\n }\n content = await file.text();\n } catch (error) {\n // Handle Bun-specific errors\n if (error instanceof Error && error.message.includes('No such file')) {\n throw FoundryCatalogError.missingCatalog(catalogName);\n }\n throw error;\n }\n } else {\n // Node.js fallback\n try {\n content = await readFile(filePath, 'utf-8');\n } catch (error) {\n if ((error as NodeJS.ErrnoException).code === 'ENOENT') {\n throw FoundryCatalogError.missingCatalog(catalogName);\n }\n throw error;\n }\n }\n\n // Parse YAML content\n const data = parseYaml(content) as SignalCatalog;\n\n // Validate against JSON Schema from Crucible SSOT\n const result = await validateDataBySchemaId(data, SCHEMA_ID);\n if (!result.valid) {\n const errorMessages = result.diagnostics.map((d) => `${d.pointer}: ${d.message}`).join('; ');\n throw FoundryCatalogError.invalidSchema(\n catalogName,\n `Schema validation failed: ${errorMessages}`,\n );\n }\n\n return data;\n } catch (error) {\n if (error instanceof FoundryCatalogError) {\n throw error;\n }\n\n // Distinguish between different types of file access errors\n const err = error as NodeJS.ErrnoException;\n if (err.code === 'ENOENT') {\n throw FoundryCatalogError.missingCatalog(catalogName);\n } else if (err.code === 'EACCES') {\n throw FoundryCatalogError.invalidSchema(\n catalogName,\n 'Permission denied accessing catalog file',\n err,\n );\n } else if (err.code === 'EISDIR') {\n throw FoundryCatalogError.invalidSchema(\n catalogName,\n 'Expected file but found directory',\n err,\n );\n } else if (err.code === 'EMFILE' || err.code === 'ENFILE') {\n throw FoundryCatalogError.invalidSchema(catalogName, 'Too many open files', err);\n }\n\n throw FoundryCatalogError.invalidSchema(catalogName, 'Failed to load catalog', err);\n }\n}\n\n// Cached catalog instance\nlet cachedCatalog: SignalCatalog | null = null;\n\n/**\n * Get the signal catalog, loading it if necessary\n */\nasync function getCatalog(): Promise<SignalCatalog> {\n if (!cachedCatalog) {\n cachedCatalog = await loadCatalog();\n }\n return cachedCatalog;\n}\n\n/**\n * Get the signals catalog version\n */\nexport async function getSignalsVersion(): Promise<string> {\n const catalog = await getCatalog();\n return catalog.version;\n}\n\n/**\n * Get all signals\n */\nexport async function listSignals(): Promise<SignalInfo[]> {\n const catalog = await getCatalog();\n return catalog.signals.map((signal) => ({ ...signal }));\n}\n\n/**\n * Get a specific signal by ID or name\n */\nexport async function getSignal(identifier: string): Promise<SignalInfo | null> {\n const catalog = await getCatalog();\n const signal = catalog.signals.find((s) => s.id === identifier || s.name === identifier);\n return signal ? { ...signal } : null;\n}\n\n/**\n * Get all behaviors\n */\nexport async function listBehaviors(): Promise<BehaviorInfo[]> {\n const catalog = await getCatalog();\n return catalog.behaviors.map((behavior) => ({ ...behavior }));\n}\n\n/**\n * Get a specific behavior by ID\n */\nexport async function getBehavior(id: string): Promise<BehaviorInfo | null> {\n const catalog = await getCatalog();\n const behavior = catalog.behaviors.find((b) => b.id === id);\n return behavior ? { ...behavior } : null;\n}\n\n/**\n * Get the complete catalog (for advanced use cases)\n */\nexport async function getSignalCatalog(): Promise<SignalCatalog> {\n return await getCatalog();\n}\n","/**\n * Signal Capability Detection\n *\n * Platform-aware signal support detection driven by catalog metadata.\n * Ensures cross-language parity by querying windows_event/fallback fields\n * rather than hardcoding signal names.\n */\n\nimport { getSignal, getSignalCatalog } from './catalog.js';\n\n/**\n * Platform types\n */\nexport type Platform = 'linux' | 'darwin' | 'win32' | 'freebsd' | 'unknown';\n\n/**\n * Platform capabilities summary\n */\nexport interface PlatformCapabilities {\n platform: Platform;\n isPOSIX: boolean;\n isWindows: boolean;\n supportsNativeSignals: boolean;\n supportsSignalExitCodes: boolean;\n supportedSignals: string[];\n unsupportedSignals: string[];\n mappedSignals: string[]; // Windows console events\n}\n\n/**\n * Detect current platform\n */\nexport function getPlatform(): Platform {\n const platform = process.platform;\n\n switch (platform) {\n case 'linux':\n return 'linux';\n case 'darwin':\n return 'darwin';\n case 'win32':\n return 'win32';\n case 'freebsd':\n return 'freebsd';\n default:\n return 'unknown';\n }\n}\n\n/**\n * Check if current platform is POSIX-compliant\n */\nexport function isPOSIX(): boolean {\n const platform = getPlatform();\n return platform === 'linux' || platform === 'darwin' || platform === 'freebsd';\n}\n\n/**\n * Check if current platform is Windows\n */\nexport function isWindows(): boolean {\n return getPlatform() === 'win32';\n}\n\n/**\n * Check if a signal is supported on the current platform\n *\n * Uses catalog metadata (windows_event field) to determine support.\n * Returns true if:\n * - Platform is POSIX (all signals natively supported)\n * - Platform is Windows AND signal has non-null windows_event\n *\n * @param signalName - Signal name (e.g., \"SIGTERM\") or id (e.g., \"term\")\n */\nexport async function supportsSignal(signalName: string): Promise<boolean> {\n const signal = await getSignal(signalName);\n if (!signal) {\n return false;\n }\n\n // POSIX platforms support all signals natively\n if (isPOSIX()) {\n return true;\n }\n\n // Windows: check if signal has a console event mapping\n if (isWindows()) {\n // Signal is supported if windows_event is non-null\n return signal.windows_event !== null;\n }\n\n // Unknown platform: conservative approach (assume unsupported)\n return false;\n}\n\n/**\n * Check if platform supports signal-based exit codes (128+N pattern)\n *\n * Windows doesn't propagate signal numbers via exit codes in the same way\n * as POSIX systems. This function helps applications decide whether to\n * rely on signal exit codes for process monitoring.\n */\nexport function supportsSignalExitCodes(): boolean {\n // Only POSIX systems reliably support 128+N exit code pattern\n return isPOSIX();\n}\n\n/**\n * Get comprehensive platform capabilities\n *\n * Queries catalog to build a complete picture of signal support.\n * Useful for capability reporting, documentation generation, and testing.\n */\nexport async function getPlatformCapabilities(): Promise<PlatformCapabilities> {\n const platform = getPlatform();\n const isPosix = isPOSIX();\n const isWin = isWindows();\n const catalog = await getSignalCatalog();\n\n const supported: string[] = [];\n const unsupported: string[] = [];\n const mapped: string[] = [];\n\n // Categorize signals based on platform\n for (const signal of catalog.signals) {\n if (isPosix) {\n // All signals supported on POSIX\n supported.push(signal.name);\n } else if (isWin) {\n if (signal.windows_event !== null) {\n // Signal has Windows console event mapping\n supported.push(signal.name);\n mapped.push(signal.name);\n } else {\n // No Windows support - requires fallback\n unsupported.push(signal.name);\n }\n } else {\n // Unknown platform - mark as unsupported\n unsupported.push(signal.name);\n }\n }\n\n return {\n platform,\n isPOSIX: isPosix,\n isWindows: isWin,\n supportsNativeSignals: isPosix,\n supportsSignalExitCodes: supportsSignalExitCodes(),\n supportedSignals: supported,\n unsupportedSignals: unsupported,\n mappedSignals: mapped,\n };\n}\n\n/**\n * Get the signal number for the current platform\n *\n * Handles platform-specific overrides (e.g., SIGUSR1/SIGUSR2 on macOS/FreeBSD).\n * Returns the appropriate signal number based on platform_overrides.\n *\n * @param signalName - Signal name (e.g., \"SIGTERM\") or id (e.g., \"term\")\n * @returns Signal number for current platform, or null if signal not found\n */\nexport async function getSignalNumber(signalName: string): Promise<number | null> {\n const signal = await getSignal(signalName);\n if (!signal) {\n return null;\n }\n\n const platform = getPlatform();\n\n // Check for platform-specific override\n if (signal.platform_overrides) {\n if (platform === 'darwin' && signal.platform_overrides.darwin !== undefined) {\n return signal.platform_overrides.darwin;\n }\n if (platform === 'freebsd' && signal.platform_overrides.freebsd !== undefined) {\n return signal.platform_overrides.freebsd;\n }\n }\n\n // Return standard Unix number\n return signal.unix_number;\n}\n\n/**\n * Get the Windows console event name for a signal\n *\n * Returns the Windows console event that corresponds to a Unix signal,\n * or null if the signal is not supported on Windows.\n *\n * @param signalName - Signal name (e.g., \"SIGTERM\") or id (e.g., \"term\")\n */\nexport async function getWindowsEvent(signalName: string): Promise<string | null> {\n const signal = await getSignal(signalName);\n if (!signal) {\n return null;\n }\n\n return signal.windows_event;\n}\n","/**\n * Signal Handler Convenience Wrappers\n *\n * Common signal handling patterns for shutdown, reload, and custom behaviors.\n */\n\nimport type { HandlerOptions, SignalHandler, SignalManager } from './manager.js';\n\n/**\n * Register a graceful shutdown handler\n *\n * Convenience wrapper for SIGTERM and SIGINT handlers.\n * Automatically registers both signals to the same handler.\n *\n * @param manager - Signal manager instance\n * @param handler - Shutdown handler function\n * @param options - Handler options\n *\n * @example\n * ```typescript\n * await onShutdown(manager, async () => {\n * await closeDatabase();\n * await flushLogs();\n * });\n * ```\n */\nexport async function onShutdown(\n manager: SignalManager,\n handler: SignalHandler,\n options: HandlerOptions = {},\n): Promise<void> {\n await manager.register('SIGTERM', handler, options);\n await manager.register('SIGINT', handler, options);\n}\n\n/**\n * Register a config reload handler\n *\n * Convenience wrapper for SIGHUP handler.\n * Only registers on POSIX platforms (SIGHUP not supported on Windows).\n *\n * @param manager - Signal manager instance\n * @param handler - Reload handler function\n * @param options - Handler options\n *\n * @example\n * ```typescript\n * await onReload(manager, async () => {\n * const newConfig = await loadConfig();\n * await validateConfig(newConfig);\n * process.exit(129); // Exit for restart\n * });\n * ```\n */\nexport async function onReload(\n manager: SignalManager,\n handler: SignalHandler,\n options: HandlerOptions = {},\n): Promise<void> {\n await manager.register('SIGHUP', handler, options);\n}\n\n/**\n * Register a custom handler for SIGUSR1\n *\n * Common use cases: toggle debug logging, reopen log files, dump statistics.\n *\n * @param manager - Signal manager instance\n * @param handler - Custom handler function\n * @param options - Handler options\n *\n * @example\n * ```typescript\n * await onUSR1(manager, async () => {\n * logger.info('SIGUSR1 received - reopening log files');\n * await reopenLogFiles();\n * });\n * ```\n */\nexport async function onUSR1(\n manager: SignalManager,\n handler: SignalHandler,\n options: HandlerOptions = {},\n): Promise<void> {\n await manager.register('SIGUSR1', handler, options);\n}\n\n/**\n * Register a custom handler for SIGUSR2\n *\n * Common use cases: trigger profiling, rotate credentials, toggle verbose mode.\n *\n * @param manager - Signal manager instance\n * @param handler - Custom handler function\n * @param options - Handler options\n *\n * @example\n * ```typescript\n * await onUSR2(manager, async () => {\n * logger.info('SIGUSR2 received - toggling debug mode');\n * toggleDebugMode();\n * });\n * ```\n */\nexport async function onUSR2(\n manager: SignalManager,\n handler: SignalHandler,\n options: HandlerOptions = {},\n): Promise<void> {\n await manager.register('SIGUSR2', handler, options);\n}\n\n/**\n * Register an emergency quit handler\n *\n * Convenience wrapper for SIGQUIT (immediate exit, no cleanup).\n *\n * @param manager - Signal manager instance\n * @param handler - Emergency quit handler\n * @param options - Handler options\n *\n * @example\n * ```typescript\n * await onEmergencyQuit(manager, async () => {\n * logger.error('SIGQUIT received - emergency exit');\n * process.exit(131);\n * });\n * ```\n */\nexport async function onEmergencyQuit(\n manager: SignalManager,\n handler: SignalHandler,\n options: HandlerOptions = {},\n): Promise<void> {\n await manager.register('SIGQUIT', handler, options);\n}\n\n/**\n * Register handlers for all common shutdown signals\n *\n * Registers the same handler for SIGTERM, SIGINT, and SIGQUIT.\n * Useful for applications that want consistent shutdown behavior.\n *\n * @param manager - Signal manager instance\n * @param handler - Shutdown handler function\n * @param options - Handler options\n */\nexport async function onAnyShutdown(\n manager: SignalManager,\n handler: SignalHandler,\n options: HandlerOptions = {},\n): Promise<void> {\n await manager.register('SIGTERM', handler, options);\n await manager.register('SIGINT', handler, options);\n await manager.register('SIGQUIT', handler, options);\n}\n","/**\n * Double-Tap Signal Handling\n *\n * Implements Ctrl+C double-tap pattern for graceful shutdown with force-quit option.\n * Per Crucible standard: 2-second window, immediate exit on second signal.\n */\n\nimport { getSignal } from './catalog.js';\nimport type { FallbackLogger } from './windows.js';\n\n/**\n * Double-tap configuration\n */\nexport interface DoubleTapConfig {\n /**\n * Debounce window in milliseconds (default: 2000ms per Crucible standard)\n */\n windowMs?: number;\n\n /**\n * Exit code for forced double-tap exit (default: 130 for SIGINT)\n */\n exitCode?: number;\n\n /**\n * Message to display on first signal (default: from catalog)\n */\n hintMessage?: string;\n\n /**\n * Logger for double-tap events\n */\n logger?: FallbackLogger;\n\n /**\n * Enable test mode (prevents process.exit calls)\n */\n testMode?: boolean;\n}\n\n/**\n * Double-tap state tracker\n */\nexport interface DoubleTapState {\n firstTapTime: number | null;\n windowMs: number;\n exitCode: number;\n hintMessage: string;\n logger?: FallbackLogger;\n testMode: boolean;\n}\n\n/**\n * Create double-tap state tracker for a signal\n *\n * @param signalName - Signal name (typically \"SIGINT\")\n * @param config - Double-tap configuration\n */\nexport async function createDoubleTapTracker(\n signalName: string,\n config: DoubleTapConfig = {},\n): Promise<DoubleTapState> {\n const signal = await getSignal(signalName);\n\n // Get defaults from catalog if available\n const defaultWindowMs = signal?.double_tap_window_seconds\n ? signal.double_tap_window_seconds * 1000\n : 2000;\n const defaultExitCode = signal?.double_tap_exit_code || 130;\n const defaultHintMessage =\n signal?.double_tap_message || 'Press Ctrl+C again within 2s to force quit';\n\n return {\n firstTapTime: null,\n windowMs: config.windowMs ?? defaultWindowMs,\n exitCode: config.exitCode ?? defaultExitCode,\n hintMessage: config.hintMessage ?? defaultHintMessage,\n logger: config.logger,\n testMode: config.testMode ?? false,\n };\n}\n\n/**\n * Handle double-tap signal logic\n *\n * Returns true if this is the second tap (force-quit), false if first tap.\n * Updates state to track timing between taps.\n *\n * @param state - Double-tap state tracker\n * @returns true if force-quit should proceed, false if graceful shutdown\n */\nexport function handleDoubleTap(state: DoubleTapState): boolean {\n const now = Date.now();\n\n // First tap\n if (state.firstTapTime === null) {\n state.firstTapTime = now;\n if (state.logger) {\n state.logger.info(state.hintMessage);\n } else {\n console.log(state.hintMessage);\n }\n return false; // Start graceful shutdown\n }\n\n // Check if within window\n const elapsed = now - state.firstTapTime;\n if (elapsed < state.windowMs) {\n // Second tap within window - force quit\n if (state.logger) {\n state.logger.info('Force quitting...');\n } else {\n console.log('Force quitting...');\n }\n\n if (!state.testMode) {\n process.exit(state.exitCode);\n }\n\n return true; // Force quit\n }\n\n // Outside window - treat as new first tap\n state.firstTapTime = now;\n if (state.logger) {\n state.logger.info(state.hintMessage);\n } else {\n console.log(state.hintMessage);\n }\n return false; // Start new graceful shutdown\n}\n\n/**\n * Reset double-tap state\n *\n * Called when graceful shutdown completes before second tap.\n */\nexport function resetDoubleTap(state: DoubleTapState): void {\n state.firstTapTime = null;\n}\n\n/**\n * Check if currently within double-tap window\n *\n * Useful for testing and debugging.\n */\nexport function isWithinWindow(state: DoubleTapState): boolean {\n if (state.firstTapTime === null) {\n return false;\n }\n const elapsed = Date.now() - state.firstTapTime;\n return elapsed < state.windowMs;\n}\n\n/**\n * Get time remaining in double-tap window (milliseconds)\n *\n * Returns null if not in a window, otherwise milliseconds remaining.\n */\nexport function getWindowTimeRemaining(state: DoubleTapState): number | null {\n if (state.firstTapTime === null) {\n return null;\n }\n const elapsed = Date.now() - state.firstTapTime;\n const remaining = state.windowMs - elapsed;\n return remaining > 0 ? remaining : null;\n}\n","/**\n * Windows Signal Fallback\n *\n * Implements standardized Windows fallback behavior for unsupported signals.\n * Follows Crucible specification for logging, telemetry, and operational hints.\n */\n\nimport { getSignal } from './catalog.js';\nimport type { WindowsFallback } from './types.js';\n\n/**\n * Windows fallback result\n */\nexport interface WindowsFallbackResult {\n supported: boolean;\n fallback?: WindowsFallback;\n logged: boolean;\n}\n\n/**\n * Logger interface for Windows fallback\n *\n * Applications should provide a logger instance that implements this interface.\n * If no logger is provided, messages are written to console.\n */\nexport interface FallbackLogger {\n info(message: string, meta?: Record<string, unknown>): void;\n warn(message: string, meta?: Record<string, unknown>): void;\n}\n\n/**\n * Telemetry emitter interface\n *\n * Applications should provide a telemetry emitter for observability.\n * If no emitter is provided, telemetry events are skipped.\n */\nexport interface TelemetryEmitter {\n emit(event: string, tags: Record<string, string>): void;\n}\n\n/**\n * Windows fallback options\n */\nexport interface WindowsFallbackOptions {\n logger?: FallbackLogger;\n telemetry?: TelemetryEmitter;\n silent?: boolean; // Skip logging/telemetry (for testing)\n}\n\n/**\n * Default console logger implementation\n */\nconst defaultLogger: FallbackLogger = {\n info(message: string, meta?: Record<string, unknown>) {\n if (meta) {\n console.info(message, meta);\n } else {\n console.info(message);\n }\n },\n warn(message: string, meta?: Record<string, unknown>) {\n if (meta) {\n console.warn(message, meta);\n } else {\n console.warn(message);\n }\n },\n};\n\n/**\n * Handle Windows signal registration fallback\n *\n * This function is called when attempting to register a signal handler\n * on Windows for a signal that lacks native support.\n *\n * Behavior per Crucible standard:\n * 1. Log structured message at INFO level (not WARN - this is expected on Windows)\n * 2. Emit standardized telemetry event (fulmen.signal.unsupported)\n * 3. Return fallback metadata for operational guidance\n *\n * @param signalName - Signal name (e.g., \"SIGHUP\")\n * @param options - Logging and telemetry configuration\n */\nexport async function handleWindowsFallback(\n signalName: string,\n options: WindowsFallbackOptions = {},\n): Promise<WindowsFallbackResult> {\n const signal = await getSignal(signalName);\n\n // Signal not found in catalog\n if (!signal) {\n return {\n supported: false,\n logged: false,\n };\n }\n\n // Signal is supported (has windows_event)\n if (signal.windows_event !== null) {\n return {\n supported: true,\n logged: false,\n };\n }\n\n // Signal is unsupported on Windows - apply fallback\n const fallback = signal.windows_fallback;\n if (!fallback) {\n // No fallback metadata defined (shouldn't happen with valid catalog)\n return {\n supported: false,\n logged: false,\n };\n }\n\n // Skip logging/telemetry if silent mode\n if (options.silent) {\n return {\n supported: false,\n fallback,\n logged: false,\n };\n }\n\n const logger = options.logger || defaultLogger;\n const telemetry = options.telemetry;\n\n // Structured logging per Crucible standard\n // Template: signal=${signal} platform=${platform} fallback=${fallback_behavior} message='${operation_hint}'\n const logMeta = {\n signal: signal.name,\n platform: 'windows',\n fallback: fallback.fallback_behavior,\n operation_hint: fallback.operation_hint,\n };\n\n // Log at INFO level (not WARN - this is expected Windows behavior)\n logger.info(fallback.log_message, logMeta);\n\n // Emit standardized telemetry\n if (telemetry) {\n telemetry.emit(fallback.telemetry_event, fallback.telemetry_tags);\n }\n\n return {\n supported: false,\n fallback,\n logged: true,\n };\n}\n\n/**\n * Get fallback metadata for a signal without logging\n *\n * Useful for capability checking and testing without side effects.\n *\n * @param signalName - Signal name (e.g., \"SIGHUP\")\n */\nexport async function getFallbackMetadata(signalName: string): Promise<WindowsFallback | null> {\n const signal = await getSignal(signalName);\n if (!signal || !signal.windows_fallback) {\n return null;\n }\n return signal.windows_fallback;\n}\n\n/**\n * Check if a signal requires Windows fallback\n *\n * Returns true if signal is defined in catalog but lacks Windows support\n * (windows_event is null and windows_fallback is defined).\n *\n * @param signalName - Signal name (e.g., \"SIGHUP\")\n */\nexport async function requiresFallback(signalName: string): Promise<boolean> {\n const signal = await getSignal(signalName);\n if (!signal) {\n return false;\n }\n return signal.windows_event === null && signal.windows_fallback !== undefined;\n}\n\n/**\n * Get HTTP endpoint recommendation for Windows fallback\n *\n * Returns formatted operational guidance for signals that require\n * HTTP admin endpoint fallback on Windows.\n *\n * @param signalName - Signal name (e.g., \"SIGHUP\")\n */\nexport async function getHttpFallbackGuidance(signalName: string): Promise<string | null> {\n const fallback = await getFallbackMetadata(signalName);\n if (!fallback || fallback.fallback_behavior !== 'http_admin_endpoint') {\n return null;\n }\n return fallback.operation_hint;\n}\n","/**\n * Signal Support Guards\n *\n * Validation functions that throw actionable errors when signals are unsupported.\n * Used to fail-fast with clear operational guidance.\n */\n\nimport { FoundryCatalogError } from '../errors.js';\nimport { isPOSIX, isWindows, supportsSignal } from './capabilities.js';\nimport { getSignal } from './catalog.js';\nimport { getFallbackMetadata } from './windows.js';\n\n/**\n * Guard options\n */\nexport interface GuardOptions {\n /**\n * Include platform-specific operational guidance in error message\n */\n includeGuidance?: boolean;\n}\n\n/**\n * Ensure a signal is supported on the current platform\n *\n * Throws an error with actionable guidance if the signal is not supported.\n * Use this as a guard at the start of signal registration functions.\n *\n * @param signalName - Signal name (e.g., \"SIGTERM\") or id (e.g., \"term\")\n * @param options - Guard configuration\n * @throws {FoundryCatalogError} If signal is not found or not supported\n *\n * @example\n * ```typescript\n * await ensureSupported(\"SIGHUP\");\n * // On Windows: throws with HTTP fallback guidance\n * // On POSIX: passes through\n * ```\n */\nexport async function ensureSupported(\n signalName: string,\n options: GuardOptions = {},\n): Promise<void> {\n const { includeGuidance = true } = options;\n\n // Check if signal exists in catalog\n const signal = await getSignal(signalName);\n if (!signal) {\n throw FoundryCatalogError.invalidSchema(\n 'signals',\n `Signal \"${signalName}\" not found in catalog. ` +\n `Valid signals: SIGTERM, SIGINT, SIGHUP, SIGQUIT, SIGPIPE, SIGALRM, SIGUSR1, SIGUSR2`,\n );\n }\n\n // Check platform support\n const supported = await supportsSignal(signalName);\n if (supported) {\n return; // Signal is supported\n }\n\n // Signal is not supported - build actionable error message\n let message = `Signal ${signal.name} is not supported on this platform`;\n\n if (isWindows() && includeGuidance) {\n const fallback = await getFallbackMetadata(signalName);\n if (fallback) {\n message += `. ${fallback.log_message}`;\n\n // Add specific guidance based on fallback type\n switch (fallback.fallback_behavior) {\n case 'http_admin_endpoint':\n message += `. Use HTTP endpoint: ${fallback.operation_hint}`;\n break;\n case 'exception_handling':\n message += `. Alternative: ${fallback.operation_hint}`;\n break;\n case 'timer_api':\n message += `. Alternative: ${fallback.operation_hint}`;\n break;\n }\n }\n }\n\n throw FoundryCatalogError.invalidSchema('signals', message);\n}\n\n/**\n * Ensure platform supports signal-based exit codes\n *\n * Throws an error if the platform doesn't support the POSIX 128+N exit code pattern.\n * Use this when exit code semantics are critical to application logic.\n *\n * @throws {FoundryCatalogError} If platform doesn't support signal exit codes\n *\n * @example\n * ```typescript\n * ensureSignalExitCodesSupported();\n * // On Windows: throws with guidance\n * // On POSIX: passes through\n * ```\n */\nexport function ensureSignalExitCodesSupported(): void {\n if (!isPOSIX()) {\n throw FoundryCatalogError.invalidSchema(\n 'signals',\n 'Signal-based exit codes (128+N pattern) are not supported on this platform. ' +\n 'Windows does not propagate signal numbers via exit codes. ' +\n 'Use explicit exit codes or monitor via HTTP admin endpoint.',\n );\n }\n}\n\n/**\n * Ensure platform is POSIX\n *\n * Throws an error if the platform is not POSIX-compliant.\n * Use this for functionality that strictly requires POSIX signal semantics.\n *\n * @throws {FoundryCatalogError} If platform is not POSIX\n */\nexport function ensurePOSIX(): void {\n if (!isPOSIX()) {\n throw FoundryCatalogError.invalidSchema(\n 'signals',\n 'This operation requires a POSIX-compliant platform (Linux, macOS, FreeBSD). ' +\n 'Current platform does not support native signal handling.',\n );\n }\n}\n\n/**\n * Ensure platform is Windows\n *\n * Throws an error if the platform is not Windows.\n * Use this for Windows-specific fallback testing or functionality.\n *\n * @throws {FoundryCatalogError} If platform is not Windows\n */\nexport function ensureWindows(): void {\n if (!isWindows()) {\n throw FoundryCatalogError.invalidSchema(\n 'signals',\n 'This operation requires Windows platform. Current platform uses native signals.',\n );\n }\n}\n","/**\n * HTTP Signal Endpoint Helper\n *\n * Framework-agnostic scaffold for POST /admin/signal endpoint.\n * Applications provide auth/rate-limiting; helper handles validation and execution.\n */\n\nimport { supportsSignal } from './capabilities.js';\nimport type { SignalManager } from './manager.js';\nimport type { FallbackLogger, TelemetryEmitter } from './windows.js';\n\n/**\n * Signal request payload\n */\nexport interface SignalRequest {\n signal: string;\n reason?: string;\n correlation_id?: string;\n}\n\n/**\n * Signal response (success)\n */\nexport interface SignalResponse {\n status: 'accepted';\n signal: string;\n correlation_id: string;\n message: string;\n}\n\n/**\n * Signal error response\n */\nexport interface SignalErrorResponse {\n status: 'error';\n error: string;\n message: string;\n valid_signals?: string[];\n}\n\n/**\n * Authentication result\n */\nexport interface AuthResult {\n authenticated: boolean;\n identity?: string; // Client identifier (IP, cert fingerprint, etc.)\n reason?: string;\n}\n\n/**\n * Rate limit result\n */\nexport interface RateLimitResult {\n allowed: boolean;\n remaining?: number;\n reset_at?: number;\n}\n\n/**\n * Authentication hook function\n *\n * Applications must provide this to validate requests.\n * Returns authentication result with optional identity.\n */\nexport type AuthHook = (req: unknown) => Promise<AuthResult> | AuthResult;\n\n/**\n * Rate limiting hook function\n *\n * Applications may provide this to enforce rate limits.\n * Returns whether request is allowed and quota info.\n */\nexport type RateLimitHook = (\n identity: string,\n signal: string,\n) => Promise<RateLimitResult> | RateLimitResult;\n\n/**\n * Signal endpoint options\n */\nexport interface SignalEndpointOptions {\n /**\n * Signal manager instance\n */\n manager: SignalManager;\n\n /**\n * Authentication hook (required)\n */\n auth: AuthHook;\n\n /**\n * Rate limiting hook (optional)\n */\n rateLimit?: RateLimitHook;\n\n /**\n * Logger for endpoint events\n */\n logger?: FallbackLogger;\n\n /**\n * Telemetry emitter\n */\n telemetry?: TelemetryEmitter;\n\n /**\n * Allowed signals (default: all catalog signals)\n */\n allowedSignals?: string[];\n}\n\n/**\n * Create a framework-agnostic signal endpoint handler\n *\n * Returns an async function that processes signal requests.\n * Applications wire this to their HTTP framework (Express, Fastify, etc.)\n *\n * @param options - Endpoint configuration\n *\n * @example Express\n * ```typescript\n * const handler = createSignalEndpoint({\n * manager,\n * auth: async (req) => {\n * const token = req.headers.authorization?.split(' ')[1];\n * return { authenticated: token === process.env.ADMIN_TOKEN };\n * },\n * });\n *\n * app.post('/admin/signal', async (req, res) => {\n * const result = await handler(req.body, req);\n * res.status(result.status === 'accepted' ? 202 : result.statusCode || 400)\n * .json(result);\n * });\n * ```\n *\n * @example Fastify\n * ```typescript\n * const handler = createSignalEndpoint({ manager, auth });\n *\n * fastify.post('/admin/signal', async (request, reply) => {\n * const result = await handler(request.body, request);\n * reply.status(result.status === 'accepted' ? 202 : 400).send(result);\n * });\n * ```\n */\nexport function createSignalEndpoint(\n options: SignalEndpointOptions,\n): (\n payload: SignalRequest,\n req: unknown,\n) => Promise<(SignalResponse | SignalErrorResponse) & { statusCode?: number }> {\n const { manager, auth, rateLimit, logger, telemetry, allowedSignals } = options;\n\n return async (payload: SignalRequest, req: unknown) => {\n const correlationId = payload.correlation_id ?? generateCorrelationId();\n\n // Authenticate request\n const authResult = await auth(req);\n if (!authResult.authenticated) {\n if (logger) {\n logger.warn('Signal endpoint: authentication failed', {\n correlation_id: correlationId,\n reason: authResult.reason,\n });\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.http_endpoint.auth_failed', {\n correlation_id: correlationId,\n });\n }\n\n return {\n status: 'error',\n error: 'authentication_failed',\n message: authResult.reason || 'Authentication required',\n statusCode: 401,\n };\n }\n\n const identity = authResult.identity || 'unknown';\n\n // Validate signal name\n if (!payload.signal) {\n return {\n status: 'error',\n error: 'invalid_request',\n message: 'Signal name is required',\n statusCode: 400,\n };\n }\n\n // Normalize signal name first\n const signalName = normalizeSignalName(payload.signal);\n\n // Check if signal is in allowed list\n const defaultAllowed = [\n 'SIGHUP',\n 'SIGTERM',\n 'SIGINT',\n 'SIGQUIT',\n 'SIGUSR1',\n 'SIGUSR2',\n 'SIGPIPE',\n 'SIGALRM',\n ];\n\n // Normalize allowed signals list (handle both 'HUP' and 'SIGHUP' formats)\n const allowed = (allowedSignals || defaultAllowed).map((s) => normalizeSignalName(s));\n\n if (!allowed.includes(signalName)) {\n return {\n status: 'error',\n error: 'invalid_signal',\n message: `Signal '${payload.signal}' is not recognized. Valid signals: ${allowed.join(', ')}`,\n valid_signals: allowed,\n statusCode: 400,\n };\n }\n\n // Check platform support\n const supported = await supportsSignal(signalName);\n if (!supported) {\n // This shouldn't happen on Windows (the only reason for HTTP endpoint)\n // but handle gracefully\n return {\n status: 'error',\n error: 'signal_not_supported',\n message: `Signal ${signalName} is not supported on this platform`,\n statusCode: 400,\n };\n }\n\n // Check rate limit\n if (rateLimit) {\n const rateLimitResult = await rateLimit(identity, signalName);\n if (!rateLimitResult.allowed) {\n if (logger) {\n logger.warn('Signal endpoint: rate limit exceeded', {\n correlation_id: correlationId,\n identity,\n signal: signalName,\n });\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.http_endpoint.rate_limited', {\n correlation_id: correlationId,\n signal: signalName,\n });\n }\n\n return {\n status: 'error',\n error: 'rate_limit_exceeded',\n message: 'Rate limit exceeded. Please try again later.',\n statusCode: 429,\n };\n }\n }\n\n // Log signal request\n if (logger) {\n logger.info('Signal endpoint: signal received', {\n correlation_id: correlationId,\n identity,\n signal: signalName,\n reason: payload.reason,\n });\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.http_endpoint.signal_received', {\n correlation_id: correlationId,\n signal: signalName,\n });\n }\n\n // Trigger signal asynchronously\n // Don't await - signal handlers may exit the process\n void manager.trigger(signalName).catch((error) => {\n if (logger) {\n logger.warn('Signal handler execution failed', {\n correlation_id: correlationId,\n signal: signalName,\n error: error instanceof Error ? error.message : String(error),\n });\n }\n });\n\n // Return success response immediately\n return {\n status: 'accepted',\n signal: signalName,\n correlation_id: correlationId,\n message: 'Signal will be processed asynchronously',\n statusCode: 202,\n };\n };\n}\n\n/**\n * Normalize signal name from HTTP request\n *\n * Converts \"HUP\" or \"hup\" to \"SIGHUP\"\n */\nfunction normalizeSignalName(signal: string): string {\n const upper = signal.toUpperCase();\n if (upper.startsWith('SIG')) {\n return upper;\n }\n return `SIG${upper}`;\n}\n\n/**\n * Generate a correlation ID\n */\nfunction generateCorrelationId(): string {\n return `sig-${Date.now()}-${Math.random().toString(36).substring(2, 9)}`;\n}\n\n/**\n * Create a simple bearer token auth hook\n *\n * Validates requests against a static token.\n * For production, use mTLS or more robust auth.\n *\n * @param expectedToken - Expected bearer token\n *\n * @example\n * ```typescript\n * const auth = createBearerTokenAuth(process.env.ADMIN_TOKEN);\n * const handler = createSignalEndpoint({ manager, auth });\n * ```\n */\nexport function createBearerTokenAuth(expectedToken: string): AuthHook {\n return (req: unknown) => {\n const headers = (req as { headers?: Record<string, string> }).headers;\n const authHeader = headers?.authorization || headers?.Authorization;\n\n if (!authHeader) {\n return {\n authenticated: false,\n reason: 'Missing Authorization header',\n };\n }\n\n const [scheme, token] = authHeader.split(' ');\n if (scheme !== 'Bearer' || token !== expectedToken) {\n return {\n authenticated: false,\n reason: 'Invalid bearer token',\n };\n }\n\n return {\n authenticated: true,\n identity: 'bearer-token-user',\n };\n };\n}\n\n/**\n * Create a simple in-memory rate limiter\n *\n * Tracks requests per identity with sliding window.\n * For production, use Redis or distributed rate limiting.\n *\n * @param requestsPerMinute - Max requests per minute per identity\n *\n * @example\n * ```typescript\n * const rateLimit = createSimpleRateLimiter(10); // 10 req/min\n * const handler = createSignalEndpoint({ manager, auth, rateLimit });\n * ```\n */\nexport function createSimpleRateLimiter(requestsPerMinute: number): RateLimitHook {\n const requests = new Map<string, number[]>();\n const windowMs = 60000; // 1 minute\n\n return (identity: string) => {\n const now = Date.now();\n const key = identity;\n\n // Get existing requests\n let timestamps = requests.get(key) || [];\n\n // Remove timestamps outside window\n timestamps = timestamps.filter((ts) => now - ts < windowMs);\n\n // Check if limit exceeded\n if (timestamps.length >= requestsPerMinute) {\n const oldestTimestamp = Math.min(...timestamps);\n const resetAt = oldestTimestamp + windowMs;\n\n return {\n allowed: false,\n remaining: 0,\n reset_at: resetAt,\n };\n }\n\n // Add current request\n timestamps.push(now);\n requests.set(key, timestamps);\n\n return {\n allowed: true,\n remaining: requestsPerMinute - timestamps.length,\n reset_at: now + windowMs,\n };\n };\n}\n","/**\n * Signal Manager\n *\n * Cross-platform signal handler registration and lifecycle management.\n * Implements FIFO execution, priority overrides, timeout enforcement, and double-tap support.\n */\n\nimport { isWindows, supportsSignal } from './capabilities.js';\nimport { getSignal } from './catalog.js';\nimport {\n createDoubleTapTracker,\n type DoubleTapState,\n handleDoubleTap,\n resetDoubleTap,\n} from './double-tap.js';\nimport { type FallbackLogger, handleWindowsFallback, type TelemetryEmitter } from './windows.js';\n\n/**\n * Signal handler function type\n */\nexport type SignalHandler = (signal: NodeJS.Signals) => void | Promise<void>;\n\n/**\n * Handler registration options\n */\nexport interface HandlerOptions {\n /**\n * Priority for execution order (higher priority runs first)\n * Default: 0 (FIFO order)\n */\n priority?: number;\n\n /**\n * Timeout for this handler in milliseconds\n * Default: manager's default timeout (30s)\n */\n timeoutMs?: number;\n\n /**\n * Handler identifier for debugging\n */\n id?: string;\n}\n\n/**\n * Timeout behavior options\n */\nexport type TimeoutBehavior = 'force_exit' | 'log_and_continue';\n\n/**\n * Signal manager configuration\n */\nexport interface SignalManagerOptions {\n /**\n * Default handler timeout in milliseconds\n * Default: 30000 (30 seconds)\n */\n defaultTimeoutMs?: number;\n\n /**\n * Behavior when handler timeout is exceeded\n * Default: 'log_and_continue'\n */\n timeoutBehavior?: TimeoutBehavior;\n\n /**\n * Logger for handler events\n */\n logger?: FallbackLogger;\n\n /**\n * Telemetry emitter for observability\n */\n telemetry?: TelemetryEmitter;\n\n /**\n * Enable test mode (prevents process.exit, allows signal injection)\n */\n testMode?: boolean;\n\n /**\n * Double-tap debounce window in milliseconds (for SIGINT)\n * Default: 2000 (2 seconds per Crucible standard)\n */\n doubleTapWindowMs?: number;\n\n /**\n * Exit code for double-tap force quit\n * Default: 130 (SIGINT)\n */\n doubleTapExitCode?: number;\n}\n\n/**\n * Internal handler registration\n */\ninterface RegisteredHandler {\n signal: string;\n handler: SignalHandler;\n priority: number;\n timeoutMs: number;\n id: string;\n registeredAt: number;\n}\n\n/**\n * Signal Manager\n */\nexport class SignalManager {\n private handlers: Map<string, RegisteredHandler[]> = new Map();\n private nativeListeners: Map<string, (signal: NodeJS.Signals) => void> = new Map();\n private options: Required<Omit<SignalManagerOptions, 'logger' | 'telemetry'>> & {\n logger?: FallbackLogger;\n telemetry?: TelemetryEmitter;\n };\n private handlerIdCounter = 0;\n private doubleTapTrackers: Map<string, DoubleTapState> = new Map();\n private shuttingDown = false;\n\n constructor(options: SignalManagerOptions = {}) {\n this.options = {\n defaultTimeoutMs: options.defaultTimeoutMs ?? 30000,\n timeoutBehavior: options.timeoutBehavior ?? 'log_and_continue',\n testMode: options.testMode ?? false,\n doubleTapWindowMs: options.doubleTapWindowMs ?? 2000,\n doubleTapExitCode: options.doubleTapExitCode ?? 130,\n logger: options.logger,\n telemetry: options.telemetry,\n };\n }\n\n /**\n * Register a signal handler\n *\n * @param signal - Signal name (e.g., \"SIGTERM\") or NodeJS.Signals\n * @param handler - Handler function\n * @param options - Handler options\n */\n async register(\n signal: string | NodeJS.Signals,\n handler: SignalHandler,\n options: HandlerOptions = {},\n ): Promise<void> {\n const signalName = typeof signal === 'string' ? signal : signal;\n\n // Check if signal is supported on this platform\n const supported = await supportsSignal(signalName);\n if (!supported) {\n // Log Windows fallback if applicable\n if (isWindows()) {\n await handleWindowsFallback(signalName, {\n logger: this.options.logger,\n telemetry: this.options.telemetry,\n });\n }\n return; // Don't register unsupported signals\n }\n\n // Get or create handler list for this signal\n if (!this.handlers.has(signalName)) {\n this.handlers.set(signalName, []);\n }\n\n // Create handler registration\n const registration: RegisteredHandler = {\n signal: signalName,\n handler,\n priority: options.priority ?? 0,\n timeoutMs: options.timeoutMs ?? this.options.defaultTimeoutMs,\n id: options.id ?? `handler-${++this.handlerIdCounter}`,\n registeredAt: Date.now(),\n };\n\n // Add to handler list (guaranteed to exist from lines 160-162)\n const handlers = this.handlers.get(signalName);\n if (!handlers) {\n throw new Error(`Handler list not initialized for signal ${signalName}`);\n }\n handlers.push(registration);\n\n // Sort by priority (higher first), then by registration order (FIFO)\n handlers.sort((a, b) => {\n if (a.priority !== b.priority) {\n return b.priority - a.priority; // Higher priority first\n }\n return a.registeredAt - b.registeredAt; // FIFO for same priority\n });\n\n // Register native listener if not already registered\n if (!this.nativeListeners.has(signalName)) {\n await this.registerNativeListener(signalName);\n }\n\n // Log registration\n if (this.options.logger) {\n this.options.logger.info(`Signal handler registered: ${signalName}`, {\n handler_id: registration.id,\n priority: registration.priority,\n timeout_ms: registration.timeoutMs,\n });\n }\n\n // Emit telemetry\n if (this.options.telemetry) {\n this.options.telemetry.emit('fulmen.signal.handler_registered', {\n signal: signalName,\n handler_id: registration.id,\n priority: String(registration.priority),\n });\n }\n }\n\n /**\n * Register native Node.js signal listener\n */\n private async registerNativeListener(signalName: string): Promise<void> {\n const signal = await getSignal(signalName);\n if (!signal) {\n return;\n }\n\n // Check if this signal uses double-tap behavior\n const useDoubleTap = signal.default_behavior === 'graceful_shutdown_with_double_tap';\n\n if (useDoubleTap) {\n // Create double-tap tracker\n const tracker = await createDoubleTapTracker(signalName, {\n windowMs: this.options.doubleTapWindowMs,\n exitCode: this.options.doubleTapExitCode,\n logger: this.options.logger,\n testMode: this.options.testMode,\n });\n this.doubleTapTrackers.set(signalName, tracker);\n }\n\n // Create native listener\n const listener = async (sig: NodeJS.Signals) => {\n // Handle double-tap if enabled\n if (useDoubleTap) {\n const tracker = this.doubleTapTrackers.get(signalName);\n if (tracker) {\n const forceQuit = handleDoubleTap(tracker);\n if (forceQuit) {\n // Second tap - force quit already handled by handleDoubleTap\n return;\n }\n // First tap - continue to graceful shutdown\n }\n }\n\n // Execute registered handlers\n await this.executeHandlers(signalName, sig);\n };\n\n // Register with Node.js\n process.on(signalName as NodeJS.Signals, listener);\n this.nativeListeners.set(signalName, listener);\n }\n\n /**\n * Execute all registered handlers for a signal\n */\n private async executeHandlers(signalName: string, signal: NodeJS.Signals): Promise<void> {\n const handlers = this.handlers.get(signalName);\n if (!handlers || handlers.length === 0) {\n return;\n }\n\n // Mark as shutting down\n this.shuttingDown = true;\n\n // Log signal receipt\n if (this.options.logger) {\n this.options.logger.info(`Signal received: ${signalName}`, {\n handler_count: handlers.length,\n });\n }\n\n // Execute handlers in priority order\n for (const registration of handlers) {\n try {\n // Execute with timeout\n await this.executeWithTimeout(registration, signal);\n } catch (error) {\n // Handler failed - log and continue or exit\n if (this.options.logger) {\n this.options.logger.warn(`Signal handler failed: ${signalName}`, {\n handler_id: registration.id,\n error: error instanceof Error ? error.message : String(error),\n });\n }\n\n if (this.options.telemetry) {\n this.options.telemetry.emit('fulmen.signal.handler_error', {\n signal: signalName,\n handler_id: registration.id,\n error_type: error instanceof Error ? error.constructor.name : 'unknown',\n });\n }\n\n if (this.options.timeoutBehavior === 'force_exit') {\n const exitCode = (await getSignal(signalName))?.exit_code ?? 1;\n if (!this.options.testMode) {\n process.exit(exitCode);\n }\n return;\n }\n // Otherwise continue to next handler\n }\n }\n\n // Reset double-tap state if graceful shutdown completed\n const tracker = this.doubleTapTrackers.get(signalName);\n if (tracker) {\n resetDoubleTap(tracker);\n }\n }\n\n /**\n * Execute a handler with timeout enforcement\n */\n private async executeWithTimeout(\n registration: RegisteredHandler,\n signal: NodeJS.Signals,\n ): Promise<void> {\n const timeoutPromise = new Promise<never>((_, reject) => {\n setTimeout(() => {\n reject(new Error(`Handler timeout exceeded: ${registration.timeoutMs}ms`));\n }, registration.timeoutMs);\n });\n\n const handlerPromise = Promise.resolve(registration.handler(signal));\n\n try {\n await Promise.race([handlerPromise, timeoutPromise]);\n\n // Handler completed successfully\n if (this.options.telemetry) {\n this.options.telemetry.emit('fulmen.signal.handler_completed', {\n signal: registration.signal,\n handler_id: registration.id,\n });\n }\n } catch (error) {\n // Timeout or handler error\n if (this.options.telemetry) {\n this.options.telemetry.emit('fulmen.signal.handler_timeout', {\n signal: registration.signal,\n handler_id: registration.id,\n timeout_ms: String(registration.timeoutMs),\n });\n }\n throw error;\n }\n }\n\n /**\n * Unregister a signal handler\n *\n * @param signal - Signal name\n * @param handler - Handler to remove (if not provided, removes all handlers)\n */\n unregister(signal: string, handler?: SignalHandler): void {\n const handlers = this.handlers.get(signal);\n if (!handlers) {\n return;\n }\n\n if (handler) {\n // Remove specific handler\n const index = handlers.findIndex((h) => h.handler === handler);\n if (index !== -1) {\n handlers.splice(index, 1);\n }\n } else {\n // Remove all handlers for this signal\n handlers.length = 0;\n }\n\n // If no handlers left, remove native listener\n if (handlers.length === 0) {\n const listener = this.nativeListeners.get(signal);\n if (listener) {\n process.off(signal as NodeJS.Signals, listener);\n this.nativeListeners.delete(signal);\n }\n this.handlers.delete(signal);\n }\n }\n\n /**\n * Check if a signal has registered handlers\n */\n isRegistered(signal: string): boolean {\n const handlers = this.handlers.get(signal);\n return handlers !== undefined && handlers.length > 0;\n }\n\n /**\n * Get handler count for a signal\n */\n getHandlerCount(signal: string): number {\n const handlers = this.handlers.get(signal);\n return handlers?.length ?? 0;\n }\n\n /**\n * Trigger signal handlers manually (for testing)\n *\n * @param signal - Signal name\n */\n async trigger(signal: string): Promise<void> {\n const handlers = this.handlers.get(signal);\n if (!handlers || handlers.length === 0) {\n return;\n }\n\n await this.executeHandlers(signal, signal as NodeJS.Signals);\n }\n\n /**\n * Shutdown the signal manager and cleanup all handlers\n */\n async shutdown(): Promise<void> {\n // Remove all native listeners\n for (const [signal, listener] of this.nativeListeners.entries()) {\n process.off(signal as NodeJS.Signals, listener);\n }\n\n // Clear state\n this.nativeListeners.clear();\n this.handlers.clear();\n this.doubleTapTrackers.clear();\n this.shuttingDown = false;\n }\n\n /**\n * Check if manager is currently shutting down\n */\n isShuttingDown(): boolean {\n return this.shuttingDown;\n }\n}\n\n/**\n * Create a new signal manager instance\n *\n * @param options - Manager configuration\n */\nexport function createSignalManager(options: SignalManagerOptions = {}): SignalManager {\n return new SignalManager(options);\n}\n","/**\n * Configuration Reload Helpers\n *\n * Implements restart-based config reload pattern with mandatory schema validation.\n * Per Crucible standard: validate before restart, reject invalid configs without disruption.\n */\n\nimport type { FallbackLogger, TelemetryEmitter } from './windows.js';\n\n/**\n * Configuration validator function type\n *\n * Applications provide this function to validate new config against schema.\n * Should return validation result with errors if invalid.\n */\nexport type ConfigValidator<T = unknown> = (\n config: T,\n) => Promise<ConfigValidationResult> | ConfigValidationResult;\n\n/**\n * Configuration validation result\n */\nexport interface ConfigValidationResult {\n valid: boolean;\n errors?: Array<{\n path: string;\n message: string;\n }>;\n}\n\n/**\n * Configuration loader function type\n *\n * Applications provide this function to load new config from disk/environment.\n */\nexport type ConfigLoader<T = unknown> = () => Promise<T> | T;\n\n/**\n * Config reload options\n */\nexport interface ConfigReloadOptions<T = unknown> {\n /**\n * Config loader function\n */\n loader: ConfigLoader<T>;\n\n /**\n * Schema validator function\n */\n validator: ConfigValidator<T>;\n\n /**\n * Callback invoked after successful validation, before exit\n * Use for cleanup, logging, etc.\n */\n onValidated?: (config: T) => void | Promise<void>;\n\n /**\n * Exit code for successful reload (default: 129 for SIGHUP)\n */\n exitCode?: number;\n\n /**\n * Logger for reload events\n */\n logger?: FallbackLogger;\n\n /**\n * Telemetry emitter\n */\n telemetry?: TelemetryEmitter;\n\n /**\n * Test mode (prevents process.exit)\n */\n testMode?: boolean;\n}\n\n/**\n * Config reload result (for testing)\n */\nexport interface ConfigReloadResult {\n reloaded: boolean;\n validationErrors?: Array<{ path: string; message: string }>;\n error?: Error;\n}\n\n/**\n * Create a config reload handler with schema validation\n *\n * Returns a signal handler function that implements restart-based reload:\n * 1. Load new config\n * 2. Validate against schema (mandatory)\n * 3. If invalid: log errors, continue with current config\n * 4. If valid: invoke callback, exit for restart\n *\n * @param options - Reload configuration\n *\n * @example\n * ```typescript\n * const reloadHandler = createConfigReloadHandler({\n * loader: () => loadConfig('./config.yaml'),\n * validator: (config) => validateConfigSchema(config),\n * onValidated: async (config) => {\n * logger.info('Config validated, restarting...');\n * },\n * logger: myLogger,\n * });\n *\n * await manager.register('SIGHUP', reloadHandler);\n * ```\n */\nexport function createConfigReloadHandler<T = unknown>(\n options: ConfigReloadOptions<T>,\n): () => Promise<void> {\n const {\n loader,\n validator,\n onValidated,\n exitCode = 129,\n logger,\n telemetry,\n testMode = false,\n } = options;\n\n return async () => {\n // Log reload request\n if (logger) {\n logger.info('Config reload requested (SIGHUP)');\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.config_reload_requested', {\n signal: 'SIGHUP',\n });\n }\n\n try {\n // Load new config\n const newConfig = await loader();\n\n // Validate against schema (mandatory)\n const result = await validator(newConfig);\n\n if (!result.valid) {\n // Invalid config - log and reject without restart\n if (logger) {\n logger.warn('Config validation failed - continuing with current config', {\n error_count: result.errors?.length ?? 0,\n errors: result.errors,\n });\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.config_reload_rejected', {\n signal: 'SIGHUP',\n reason: 'validation_failed',\n error_count: String(result.errors?.length ?? 0),\n });\n }\n\n return; // Don't exit - continue with current config\n }\n\n // Valid config - proceed with restart\n if (logger) {\n logger.info('Config validation succeeded - exiting for restart');\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.config_reload_accepted', {\n signal: 'SIGHUP',\n });\n }\n\n // Invoke pre-restart callback\n if (onValidated) {\n await onValidated(newConfig);\n }\n\n // Exit for restart (process supervisor will restart with new config)\n if (!testMode) {\n process.exit(exitCode);\n }\n } catch (error) {\n // Config load or validation threw error\n if (logger) {\n logger.warn('Config reload failed with error - continuing with current config', {\n error: error instanceof Error ? error.message : String(error),\n });\n }\n\n if (telemetry) {\n telemetry.emit('fulmen.signal.config_reload_error', {\n signal: 'SIGHUP',\n error_type: error instanceof Error ? error.constructor.name : 'unknown',\n });\n }\n\n // Don't exit - continue with current config\n }\n };\n}\n\n/**\n * Three-strikes failure tracker\n *\n * Tracks consecutive config reload failures and triggers alerts.\n * Useful for detecting persistent config source issues.\n */\nexport class ConfigReloadTracker {\n private failures = 0;\n private lastFailureTime: number | null = null;\n private readonly maxFailures: number;\n private readonly logger?: FallbackLogger;\n private readonly telemetry?: TelemetryEmitter;\n\n constructor(options: {\n maxFailures?: number;\n logger?: FallbackLogger;\n telemetry?: TelemetryEmitter;\n }) {\n this.maxFailures = options.maxFailures ?? 3;\n this.logger = options.logger;\n this.telemetry = options.telemetry;\n }\n\n /**\n * Record a reload failure\n *\n * @returns true if threshold exceeded, false otherwise\n */\n recordFailure(): boolean {\n this.failures++;\n this.lastFailureTime = Date.now();\n\n if (this.failures >= this.maxFailures) {\n if (this.logger) {\n this.logger.warn(\n `${this.failures} consecutive config reload failures - check config source`,\n {\n failure_count: this.failures,\n threshold: this.maxFailures,\n },\n );\n }\n\n if (this.telemetry) {\n this.telemetry.emit('fulmen.signal.config_reload_threshold_exceeded', {\n failure_count: String(this.failures),\n threshold: String(this.maxFailures),\n });\n }\n\n return true; // Threshold exceeded\n }\n\n return false;\n }\n\n /**\n * Record a successful reload (resets counter)\n */\n recordSuccess(): void {\n this.failures = 0;\n this.lastFailureTime = null;\n }\n\n /**\n * Get current failure count\n */\n getFailureCount(): number {\n return this.failures;\n }\n\n /**\n * Get last failure timestamp\n */\n getLastFailureTime(): number | null {\n return this.lastFailureTime;\n }\n}\n","/**\n * TSFulmen Signals Module\n *\n * Cross-platform signal handling with Fulmen ecosystem standards.\n * Provides catalog access, handler registration, and platform-aware fallbacks.\n */\n\n// Capability exports\nexport {\n getPlatform,\n getPlatformCapabilities,\n getSignalNumber,\n getWindowsEvent,\n isPOSIX,\n isWindows,\n type Platform,\n type PlatformCapabilities,\n supportsSignal,\n supportsSignalExitCodes,\n} from './capabilities.js';\n// Catalog exports\nexport {\n getBehavior,\n getSignal,\n getSignalCatalog,\n getSignalsVersion,\n listBehaviors,\n listSignals,\n} from './catalog.js';\n// Convenience wrapper exports\nexport {\n onAnyShutdown,\n onEmergencyQuit,\n onReload,\n onShutdown,\n onUSR1,\n onUSR2,\n} from './convenience.js';\n// Double-tap exports\nexport {\n createDoubleTapTracker,\n type DoubleTapConfig,\n type DoubleTapState,\n getWindowTimeRemaining,\n handleDoubleTap,\n isWithinWindow,\n resetDoubleTap,\n} from './double-tap.js';\n// Guard exports\nexport {\n ensurePOSIX,\n ensureSignalExitCodesSupported,\n ensureSupported,\n ensureWindows,\n type GuardOptions,\n} from './guards.js';\n// HTTP helper exports\nexport {\n type AuthHook,\n type AuthResult,\n createBearerTokenAuth,\n createSignalEndpoint,\n createSimpleRateLimiter,\n type RateLimitHook,\n type RateLimitResult,\n type SignalEndpointOptions,\n type SignalErrorResponse,\n type SignalRequest,\n type SignalResponse,\n} from './http-helper.js';\n// Manager exports\nexport {\n createSignalManager,\n type HandlerOptions,\n type SignalHandler,\n SignalManager,\n type SignalManagerOptions,\n type TimeoutBehavior,\n} from './manager.js';\n\n// Config reload exports\nexport {\n type ConfigLoader,\n type ConfigReloadOptions,\n type ConfigReloadResult,\n ConfigReloadTracker,\n type ConfigValidationResult,\n type ConfigValidator,\n createConfigReloadHandler,\n} from './reload.js';\n// Type exports\nexport type {\n Behavior,\n BehaviorInfo,\n BehaviorPhase,\n ExitCodes,\n LogLevel,\n OsMappings,\n PlatformOverrides,\n PlatformSupport,\n PlatformSupportLevel,\n Signal,\n SignalBehavior,\n SignalCatalog,\n SignalInfo,\n WindowsFallback,\n WindowsFallbackBehavior,\n} from './types.js';\n// Windows fallback exports\nexport {\n type FallbackLogger,\n getFallbackMetadata,\n getHttpFallbackGuidance,\n handleWindowsFallback,\n requiresFallback,\n type TelemetryEmitter,\n type WindowsFallbackOptions,\n type WindowsFallbackResult,\n} from './windows.js';\n","/**\n * Distance calculation with multiple metric support.\n *\n * Implements Crucible Foundry Similarity Standard v2.0.0 with WASM-backed metrics.\n *\n * @module foundry/similarity/distance\n */\n\nimport {\n damerau_levenshtein,\n jaro_winkler,\n levenshtein,\n osa_distance,\n substringSimilarity,\n} from '@3leaps/string-metrics-wasm';\nimport type { MetricType } from './types.js';\n\n/**\n * Calculate edit distance between two strings using specified metric.\n *\n * @param a - First string\n * @param b - Second string\n * @param metric - Distance metric (default: \"levenshtein\")\n * @returns Edit distance as non-negative integer (or similarity score for jaro_winkler/substring)\n *\n * @example\n * distance(\"kitten\", \"sitting\") // 3\n * distance(\"abcd\", \"abdc\", \"damerau_osa\") // 1\n * distance(\"CA\", \"ABC\", \"damerau_unrestricted\") // 2\n * distance(\"hello world\", \"world\", \"substring\") // 0.625 (as score, not distance)\n */\nexport function distance(a: string, b: string, metric: MetricType = 'levenshtein'): number {\n switch (metric) {\n case 'levenshtein':\n return levenshtein(a, b);\n case 'damerau_osa':\n return osa_distance(a, b);\n case 'damerau_unrestricted':\n return damerau_levenshtein(a, b);\n case 'jaro_winkler':\n return jaro_winkler(a, b);\n case 'substring':\n // Returns similarity score (not distance) with longest common substring\n return substringSimilarity(a, b).score;\n default:\n throw new Error(\n `Invalid metric '${metric}': must be one of: levenshtein, damerau_osa, damerau_unrestricted, jaro_winkler, substring`,\n );\n }\n}\n","import { FoundryCatalogError } from '../errors.js';\n\nexport class SimilarityError extends FoundryCatalogError {\n constructor(message: string, cause?: Error) {\n super(message, 'similarity', cause);\n this.name = 'SimilarityError';\n }\n}\n","/**\n * Unicode-aware text normalization utilities.\n *\n * Implements Crucible Foundry Similarity Standard v2.0.0 with normalization presets.\n *\n * @module foundry/similarity/normalization\n */\n\nimport {\n type NormalizationLocale,\n type NormalizationPreset as WasmNormalizationPreset,\n normalize as wasmNormalize,\n} from '@3leaps/string-metrics-wasm';\nimport type { NormalizationPreset, NormalizeOptions } from './types.js';\n\nfunction toNormalizationLocale(locale?: string): NormalizationLocale | undefined {\n if (!locale) {\n return undefined;\n }\n\n if (locale === 'tr' || locale === 'az' || locale === 'lt') {\n return locale;\n }\n\n return undefined;\n}\n\n/**\n * Apply normalization preset to text.\n *\n * @param value - Text to normalize\n * @param preset - Normalization preset (\"none\" | \"minimal\" | \"default\" | \"aggressive\")\n * @param locale - Optional locale for locale-aware casefolding (e.g., \"tr\" for Turkish)\n * @returns Normalized text\n *\n * @example\n * normalize(\" Café-Zürich! \", \"aggressive\") // \"cafezurich\"\n * normalize(\" Hello \", \"minimal\") // \"Hello\"\n * normalize(\"İstanbul\", \"default\", \"tr\") // \"istanbul\"\n */\nexport function normalize(\n value: string,\n preset: NormalizationPreset | NormalizeOptions = 'default',\n locale?: string,\n): string {\n // Handle legacy NormalizeOptions interface for backward compatibility\n if (typeof preset === 'object') {\n // Map old options to preset and extract locale\n const targetPreset = preset.stripAccents ? 'aggressive' : 'default';\n const targetLocale = toNormalizationLocale(preset.locale ?? locale);\n return wasmNormalize(value, targetPreset, targetLocale);\n }\n\n return wasmNormalize(value, preset as WasmNormalizationPreset, toNormalizationLocale(locale));\n}\n\n/**\n * Unicode-aware case folding.\n *\n * @param value - Text to casefold\n * @param locale - Optional locale (e.g., \"tr\" for Turkish)\n * @returns Lowercase text\n */\nexport function casefold(value: string, locale?: string): string {\n if (locale === 'tr') {\n return value.toLocaleLowerCase('tr-TR');\n }\n return value.toLowerCase();\n}\n\n/**\n * Strip diacritical marks from text.\n *\n * @param value - Text to process\n * @returns Text with accents removed\n */\nexport function stripAccents(value: string): string {\n return value.normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n}\n\n/**\n * Compare strings ignoring case and optionally accents.\n *\n * @param a - First string\n * @param b - Second string\n * @param options - Normalization options\n * @returns True if strings are equal after normalization\n */\nexport function equalsIgnoreCase(a: string, b: string, options?: NormalizeOptions): boolean {\n return normalize(a, options) === normalize(b, options);\n}\n","/**\n * Normalized similarity score with metric selection.\n *\n * Implements Crucible Foundry Similarity Standard v2.0.0.\n *\n * @module foundry/similarity/score\n */\n\nimport {\n type SimilarityMetric,\n substringSimilarity,\n score as wasmScore,\n} from '@3leaps/string-metrics-wasm';\nimport type { MetricType } from './types.js';\n\n/**\n * Calculate normalized similarity score between two strings.\n *\n * Returns a value between 0.0 (completely different) and 1.0 (identical).\n * For distance-based metrics: 1 - distance / max(len(a), len(b))\n * For jaro_winkler and substring: direct similarity score\n *\n * @param a - First string\n * @param b - Second string\n * @param metric - Similarity metric (default: \"levenshtein\")\n * @returns Similarity score in range [0.0, 1.0]\n *\n * @example\n * score(\"kitten\", \"sitting\") // 0.5714...\n * score(\"hello\", \"hallo\", \"jaro_winkler\") // 0.88\n * score(\"hello world\", \"world\", \"substring\") // 0.625\n */\nexport function score(a: string, b: string, metric: MetricType = 'levenshtein'): number {\n // Special case: substring uses different API to get proper longest common substring\n if (metric === 'substring') {\n return substringSimilarity(a, b).score;\n }\n\n // All other metrics supported directly by WASM score function\n return wasmScore(a, b, metric as SimilarityMetric);\n}\n","/**\n * Suggestion API with fuzzy matching and configurable metrics.\n *\n * Implements Crucible Foundry Similarity Standard v2.0.0.\n *\n * @module foundry/similarity/suggest\n */\n\nimport { type SuggestMetric, suggest as wasmSuggest } from '@3leaps/string-metrics-wasm';\nimport type { Suggestion, SuggestOptions } from './types.js';\n\nconst DEFAULT_MIN_SCORE = 0.6;\nconst DEFAULT_MAX_SUGGESTIONS = 3;\nconst DEFAULT_METRIC = 'levenshtein';\nconst DEFAULT_NORMALIZE_PRESET = 'default';\n\n/**\n * Generate ranked suggestions from candidate list based on similarity.\n *\n * @param input - Input string to match against\n * @param candidates - List of candidate strings\n * @param options - Suggestion options (metric, thresholds, normalization)\n * @returns Array of suggestions sorted by score (descending)\n *\n * @example\n * suggest(\"docscrib\", [\"docscribe\", \"crucible\"], { metric: \"levenshtein\" })\n * // [{ value: \"docscribe\", score: 0.889, ... }]\n */\nexport function suggest(\n input: string,\n candidates: readonly string[],\n options?: SuggestOptions,\n): Suggestion[] {\n const metric = options?.metric ?? DEFAULT_METRIC;\n const minScore = options?.minScore ?? DEFAULT_MIN_SCORE;\n const maxSuggestions = options?.maxSuggestions ?? DEFAULT_MAX_SUGGESTIONS;\n\n // Handle legacy 'normalize' boolean option\n let normalizePreset = options?.normalizePreset ?? DEFAULT_NORMALIZE_PRESET;\n if (options?.normalize === false) {\n normalizePreset = 'none';\n } else if (options?.normalize === true && !options?.normalizePreset) {\n normalizePreset = 'default';\n }\n\n // Pass metric name directly to WASM library (it handles \"substring\" correctly)\n const wasmOptions = {\n metric: metric as SuggestMetric,\n normalizePreset,\n minScore,\n maxSuggestions,\n preferPrefix: options?.preferPrefix,\n jaroPrefixScale: options?.jaroPrefixScale,\n jaroMaxPrefix: options?.jaroMaxPrefix,\n };\n\n const results = wasmSuggest(input, candidates as string[], wasmOptions);\n\n // Map WASM results to our Suggestion interface\n return results.map((r) => ({\n value: r.value,\n score: r.score,\n matchedRange: r.matchedRange as [number, number] | undefined,\n reason: r.reason,\n normalizedValue: r.normalizedValue,\n }));\n}\n","/**\n * Foundry similarity module - Text similarity and normalization utilities\n *\n * Implements the Crucible Foundry Text Similarity & Normalization Standard v2.0.0 (2025.10.3).\n *\n * @module foundry/similarity\n */\n\nexport const VERSION = '2.0.0';\n\nexport { distance } from './distance.js';\nexport { SimilarityError } from './errors.js';\nexport {\n casefold,\n equalsIgnoreCase,\n normalize,\n stripAccents,\n} from './normalization.js';\nexport { score } from './score.js';\nexport { suggest } from './suggest.js';\n\nexport type {\n MetricType,\n NormalizationPreset,\n NormalizeOptions,\n Suggestion,\n SuggestOptions,\n} from './types.js';\n","/**\n * Foundry module - Main exports\n *\n * Provides ergonomic access to Crucible Foundry Pattern Catalog data including\n * patterns, HTTP status codes, MIME types, and country codes with Bun-first\n * implementation and comprehensive TypeScript support.\n */\n\nexport const VERSION = '0.1.1';\n\n// Country Code catalog exports\nexport {\n clearCountryCodeCache,\n getCountryByAlpha2,\n getCountryByAlpha3,\n getCountryByNumeric,\n listCountries,\n} from './country-codes.js';\n// Detection options type export\nexport type { DetectionOptions } from './detector.js';\n// Export error classes\nexport { FoundryCatalogError } from './errors.js';\n// Exit Codes catalog and helpers\nexport {\n EXIT_CODES_VERSION,\n type ExitCode,\n type ExitCodeInfo,\n type ExitCodeName,\n exitCodeMetadata,\n exitCodes,\n getExitCodeInfo,\n getPlatform,\n getPlatformCapabilities,\n getSimplifiedCodeDescription,\n getSimplifiedCodes,\n isPOSIX,\n isWindows,\n mapExitCodeToSimplified,\n type PlatformCapabilities,\n SimplifiedMode,\n supportsSignalExitCodes,\n} from './exit-codes/index.js';\n// HTTP Status catalog exports\nexport {\n clearHttpStatusCache,\n getHttpStatus,\n getStatusReason,\n isClientError,\n isInformational,\n isRedirection,\n isServerError,\n isSuccess,\n listHttpStatuses,\n} from './http-statuses.js';\n// Export loader functions\nexport {\n loadAllCatalogs,\n loadCountryCodeCatalog,\n loadHttpStatusCatalog,\n loadMimeTypeCatalog,\n loadPatternCatalog,\n} from './loader.js';\n// MIME Type catalog exports\nexport {\n clearMimeTypeCache,\n detectMimeType,\n detectMimeTypeFromBuffer,\n detectMimeTypeFromFile,\n detectMimeTypeFromStream,\n getMimeType,\n getMimeTypeByExtension,\n isSupportedMimeType,\n listMimeTypes,\n matchMagicNumber,\n} from './mime-types.js';\n// Pattern catalog exports\nexport {\n clearPatternCache,\n describePattern,\n getPattern,\n getPatternRegex,\n listPatterns,\n matchPattern,\n} from './patterns.js';\n// Signal catalog and module exports\nexport {\n // Types\n type AuthHook,\n type AuthResult,\n type Behavior,\n type BehaviorInfo,\n type BehaviorPhase,\n type ConfigLoader,\n type ConfigReloadOptions,\n type ConfigReloadResult,\n // Config reload\n ConfigReloadTracker,\n type ConfigValidationResult,\n type ConfigValidator,\n // HTTP helper\n createBearerTokenAuth,\n createConfigReloadHandler,\n // Double-tap\n createDoubleTapTracker,\n createSignalEndpoint,\n // Manager\n createSignalManager,\n createSimpleRateLimiter,\n type DoubleTapConfig,\n type DoubleTapState,\n type ExitCodes,\n // Guards\n ensurePOSIX,\n ensureSignalExitCodesSupported,\n ensureSupported,\n ensureWindows,\n type FallbackLogger,\n type GuardOptions,\n // Catalog\n getBehavior,\n // Windows fallback\n getFallbackMetadata,\n getHttpFallbackGuidance,\n // Capabilities\n getPlatformCapabilities as getSignalPlatformCapabilities,\n getSignal,\n getSignalCatalog,\n getSignalNumber,\n getSignalsVersion,\n getWindowsEvent,\n getWindowTimeRemaining,\n type HandlerOptions,\n handleDoubleTap,\n handleWindowsFallback,\n isPOSIX as isSignalPOSIX,\n isWindows as isSignalWindows,\n isWithinWindow,\n type LogLevel,\n listBehaviors,\n listSignals,\n type OsMappings,\n // Convenience wrappers\n onAnyShutdown,\n onEmergencyQuit,\n onReload,\n onShutdown,\n onUSR1,\n onUSR2,\n type Platform,\n type PlatformCapabilities as SignalPlatformCapabilities,\n type PlatformOverrides,\n type PlatformSupport,\n type PlatformSupportLevel,\n type RateLimitHook,\n type RateLimitResult,\n requiresFallback,\n resetDoubleTap,\n type Signal,\n type SignalBehavior,\n type SignalCatalog,\n type SignalEndpointOptions,\n type SignalErrorResponse,\n type SignalHandler,\n type SignalInfo,\n SignalManager,\n type SignalManagerOptions,\n type SignalRequest,\n type SignalResponse,\n supportsSignal,\n supportsSignalExitCodes as supportsSignalBasedExitCodes,\n type TelemetryEmitter,\n type TimeoutBehavior,\n type WindowsFallback,\n type WindowsFallbackBehavior,\n type WindowsFallbackOptions,\n type WindowsFallbackResult,\n} from './signals/index.js';\nexport type {\n NormalizeOptions,\n Suggestion,\n SuggestOptions,\n} from './similarity/index.js';\n// Similarity utilities exports\nexport {\n casefold,\n distance,\n equalsIgnoreCase,\n normalize,\n score,\n stripAccents,\n suggest,\n} from './similarity/index.js';\n","/**\n * Application Identity Cache\n *\n * Process-level caching for identity objects with immutability guarantees\n */\n\nimport type { Identity } from './types.js';\n\n/**\n * Process-level cache storage\n * null = not cached, Identity = cached value\n */\nlet cachedIdentity: Identity | null = null;\n\n/**\n * Get cached identity if available\n *\n * @returns Cached identity or null if not cached\n */\nexport function getCachedIdentity(): Identity | null {\n return cachedIdentity;\n}\n\n/**\n * Set cached identity\n *\n * Identity object should already be frozen before caching\n *\n * @param identity - Identity to cache (must be frozen)\n */\nexport function setCachedIdentity(identity: Identity): void {\n cachedIdentity = identity;\n}\n\n/**\n * Clear the identity cache\n *\n * Useful for testing or when identity needs to be reloaded\n */\nexport function clearIdentityCache(): void {\n cachedIdentity = null;\n}\n","/**\n * Application Identity Constants\n *\n * Centralized configuration for identity discovery and validation\n */\n\n/**\n * Filename for identity document\n */\nexport const APP_IDENTITY_FILENAME = 'app.yaml';\n\n/**\n * Directory containing identity file\n */\nexport const APP_IDENTITY_DIR = '.fulmen';\n\n/**\n * Environment variable for explicit path override\n */\nexport const APP_IDENTITY_ENV_VAR = 'FULMEN_APP_IDENTITY_PATH';\n\n/**\n * Schema ID for validation\n */\nexport const APP_IDENTITY_SCHEMA_ID = 'config/repository/app-identity/v1.0.0/app-identity';\n\n/**\n * Maximum depth for ancestor directory search\n * Prevents infinite loops and excessive filesystem traversal\n */\nexport const MAX_ANCESTOR_SEARCH_DEPTH = 20;\n","/**\n * Correlation ID generation and validation for error tracking\n *\n * Provides UUID v4 generation for correlation IDs used in observability\n * and distributed tracing scenarios.\n */\n\nimport { randomUUID } from 'node:crypto';\n\n/**\n * UUID v4 regex pattern for validation\n */\nconst UUID_V4_PATTERN = /^[0-9a-f]{8}-[0-9a-f]{4}-4[0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;\n\n/**\n * Generate a new correlation ID (UUID v4)\n *\n * Uses Node.js crypto.randomUUID() for cryptographically strong random values.\n *\n * @returns UUID v4 string (e.g., \"550e8400-e29b-41d4-a716-446655440000\")\n *\n * @example\n * ```typescript\n * const correlationId = generateCorrelationId();\n * // \"550e8400-e29b-41d4-a716-446655440000\"\n * ```\n */\nexport function generateCorrelationId(): string {\n return randomUUID();\n}\n\n/**\n * Validate if a string is a valid UUID v4 correlation ID\n *\n * Checks format: xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx\n * where y is one of [8, 9, a, b]\n *\n * @param id - String to validate\n * @returns True if valid UUID v4 format\n *\n * @example\n * ```typescript\n * isValidCorrelationId('550e8400-e29b-41d4-a716-446655440000') // true\n * isValidCorrelationId('not-a-uuid') // false\n * isValidCorrelationId('550e8400-e29b-31d4-a716-446655440000') // false (version 3, not 4)\n * ```\n */\nexport function isValidCorrelationId(id: string): boolean {\n return UUID_V4_PATTERN.test(id);\n}\n\n/**\n * Normalize a correlation ID (lowercase, trim whitespace)\n *\n * @param id - Correlation ID to normalize\n * @returns Normalized correlation ID\n *\n * @example\n * ```typescript\n * normalizeCorrelationId(' 550E8400-E29B-41D4-A716-446655440000 ')\n * // \"550e8400-e29b-41d4-a716-446655440000\"\n * ```\n */\nexport function normalizeCorrelationId(id: string): string {\n return id.trim().toLowerCase();\n}\n\n/**\n * Type guard to check if a value is a valid correlation ID\n *\n * @param value - Value to check\n * @returns True if value is a string and valid UUID v4\n *\n * @example\n * ```typescript\n * if (isCorrelationId(value)) {\n * // TypeScript knows value is string here\n * const normalized = normalizeCorrelationId(value);\n * }\n * ```\n */\nexport function isCorrelationId(value: unknown): value is string {\n return typeof value === 'string' && isValidCorrelationId(value);\n}\n","/**\n * Severity mappings for error handling\n *\n * Implements severity levels from assessment/v1.0.0/severity-definitions schema\n * Provides bidirectional mapping between severity names and numeric levels\n */\n\n/**\n * Severity names aligned with assessment taxonomy\n */\nexport const Severity = {\n INFO: 'info',\n LOW: 'low',\n MEDIUM: 'medium',\n HIGH: 'high',\n CRITICAL: 'critical',\n} as const;\n\n/**\n * Severity name type (string literal union)\n */\nexport type SeverityName = (typeof Severity)[keyof typeof Severity];\n\n/**\n * Numeric severity level for sorting and comparison\n * info=0, low=1, medium=2, high=3, critical=4\n */\nexport type SeverityLevel = 0 | 1 | 2 | 3 | 4;\n\n/**\n * Canonical severity level mapping (name → level)\n * Aligned with schemas/crucible-ts/assessment/v1.0.0/severity-definitions.schema.json\n */\nexport const SEVERITY_LEVELS: Record<SeverityName, SeverityLevel> = {\n info: 0,\n low: 1,\n medium: 2,\n high: 3,\n critical: 4,\n};\n\n/**\n * Reverse mapping (level → name)\n */\nexport const LEVEL_TO_SEVERITY: Record<SeverityLevel, SeverityName> = {\n 0: 'info',\n 1: 'low',\n 2: 'medium',\n 3: 'high',\n 4: 'critical',\n};\n\n/**\n * Convert severity name to numeric level\n *\n * @param name - Severity name (info, low, medium, high, critical)\n * @returns Numeric severity level (0-4)\n * @throws {Error} If severity name is invalid\n *\n * @example\n * ```typescript\n * severityToLevel('high') // returns 3\n * severityToLevel('info') // returns 0\n * ```\n */\nexport function severityToLevel(name: string): SeverityLevel {\n if (!isSeverityName(name)) {\n throw new Error(\n `Invalid severity name: \"${name}\". Must be one of: ${Object.values(Severity).join(', ')}`,\n );\n }\n return SEVERITY_LEVELS[name];\n}\n\n/**\n * Convert numeric level to severity name\n *\n * @param level - Numeric severity level (0-4)\n * @returns Severity name\n * @throws {Error} If level is invalid\n *\n * @example\n * ```typescript\n * levelToSeverity(3) // returns 'high'\n * levelToSeverity(0) // returns 'info'\n * ```\n */\nexport function levelToSeverity(level: number): SeverityName {\n if (!isSeverityLevel(level)) {\n throw new Error(`Invalid severity level: ${level}. Must be 0-4`);\n }\n return LEVEL_TO_SEVERITY[level];\n}\n\n/**\n * Type guard to check if a value is a valid severity name\n *\n * @param value - Value to check\n * @returns True if value is a valid SeverityName\n *\n * @example\n * ```typescript\n * if (isSeverityName(value)) {\n * const level = severityToLevel(value); // Type-safe\n * }\n * ```\n */\nexport function isSeverityName(value: unknown): value is SeverityName {\n return typeof value === 'string' && Object.values(Severity).includes(value as SeverityName);\n}\n\n/**\n * Type guard to check if a value is a valid severity level\n *\n * @param value - Value to check\n * @returns True if value is a valid SeverityLevel\n *\n * @example\n * ```typescript\n * if (isSeverityLevel(value)) {\n * const name = levelToSeverity(value); // Type-safe\n * }\n * ```\n */\nexport function isSeverityLevel(value: unknown): value is SeverityLevel {\n return typeof value === 'number' && value >= 0 && value <= 4 && Number.isInteger(value);\n}\n\n/**\n * Get default severity (medium/2) when not specified\n *\n * @returns Default severity name and level\n */\nexport function getDefaultSeverity(): {\n name: SeverityName;\n level: SeverityLevel;\n} {\n return {\n name: Severity.MEDIUM,\n level: 2,\n };\n}\n\n/**\n * Compare two severity levels\n *\n * @param a - First severity (name or level)\n * @param b - Second severity (name or level)\n * @returns Negative if a < b, positive if a > b, zero if equal\n *\n * @example\n * ```typescript\n * compareSeverity('high', 'low') // returns positive (high > low)\n * compareSeverity(2, 'critical') // returns negative (medium < critical)\n * ```\n */\nexport function compareSeverity(\n a: SeverityName | SeverityLevel,\n b: SeverityName | SeverityLevel,\n): number {\n const levelA = typeof a === 'string' ? severityToLevel(a) : a;\n const levelB = typeof b === 'string' ? severityToLevel(b) : b;\n return levelA - levelB;\n}\n","/**\n * Error serialization utilities\n *\n * Provides safe serialization of Error objects and unknown errors to structured data\n */\n\nimport { Severity, type SeverityLevel, type SeverityName } from './severity.js';\n\n/**\n * FulmenError data structure (for serialization)\n * Defined here to avoid circular dependency\n */\nexport interface FulmenErrorData {\n readonly code: string;\n readonly message: string;\n readonly details?: Record<string, unknown>;\n readonly path?: string;\n readonly timestamp?: string;\n readonly severity?: SeverityName;\n readonly severity_level?: SeverityLevel;\n readonly correlation_id?: string;\n readonly trace_id?: string;\n readonly exit_code?: number;\n readonly context?: Record<string, unknown>;\n readonly original?: string | object;\n}\n\n/**\n * Safely serialize any error-like value to FulmenErrorData structure\n *\n * Handles native Error objects, plain objects, strings, and unknown types.\n *\n * @param error - Error value to serialize\n * @param code - Optional error code (defaults to 'UNKNOWN_ERROR')\n * @param severity - Optional severity (defaults to 'medium')\n * @returns Structured error data\n *\n * @example\n * ```typescript\n * try {\n * throw new Error('Something failed');\n * } catch (err) {\n * const data = serializeError(err, 'OPERATION_FAILED', 'high');\n * console.log(JSON.stringify(data));\n * }\n * ```\n */\nexport function serializeError(\n error: unknown,\n code = 'UNKNOWN_ERROR',\n severity: SeverityName = Severity.MEDIUM,\n): FulmenErrorData {\n // Handle Error instances\n if (error instanceof Error) {\n return {\n code,\n message: error.message,\n severity,\n timestamp: new Date().toISOString(),\n context: {\n name: error.name,\n stack: error.stack,\n },\n original: error.stack || error.message,\n };\n }\n\n // Handle plain objects with message\n if (isErrorLike(error)) {\n return {\n code,\n message: error.message,\n severity,\n timestamp: new Date().toISOString(),\n details: error.details,\n context: error.context,\n original: JSON.stringify(error),\n };\n }\n\n // Handle strings\n if (typeof error === 'string') {\n return {\n code,\n message: error,\n severity,\n timestamp: new Date().toISOString(),\n };\n }\n\n // Handle everything else\n return {\n code,\n message: String(error),\n severity,\n timestamp: new Date().toISOString(),\n original: typeof error === 'object' ? JSON.stringify(error) : String(error),\n };\n}\n\n/**\n * Extract error message from unknown error value\n *\n * @param error - Error value\n * @returns Error message string\n */\nexport function extractErrorMessage(error: unknown): string {\n if (error instanceof Error) {\n return error.message;\n }\n if (isErrorLike(error)) {\n return error.message;\n }\n if (typeof error === 'string') {\n return error;\n }\n return String(error);\n}\n\n/**\n * Extract stack trace from error if available\n *\n * @param error - Error value\n * @returns Stack trace string or undefined\n */\nexport function extractStackTrace(error: unknown): string | undefined {\n if (error instanceof Error) {\n return error.stack;\n }\n if (isErrorLike(error) && typeof error.stack === 'string') {\n return error.stack;\n }\n return undefined;\n}\n\n/**\n * Type guard for error-like objects\n */\nfunction isErrorLike(value: unknown): value is {\n message: string;\n stack?: string;\n details?: Record<string, unknown>;\n context?: Record<string, unknown>;\n} {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'message' in value &&\n typeof (value as { message: unknown }).message === 'string'\n );\n}\n","/**\n * Schema validation for FulmenError data\n *\n * Provides singleton validator that pre-compiles error-response schema\n * using existing src/schema infrastructure. Performance target: <1ms per validation.\n */\n\nimport { compileSchemaById } from '../schema/index.js';\nimport type { CompiledValidator } from '../schema/types.js';\n\n/**\n * Singleton validator for FulmenError data\n *\n * Pre-compiles the error-response schema at first access for optimal performance.\n * Reuses existing AJV setup from src/schema module.\n */\nclass ErrorValidator {\n private static instance: ErrorValidator;\n private validateFn: CompiledValidator | null = null;\n private initPromise: Promise<void> | null = null;\n private initError: Error | null = null;\n\n private constructor() {\n // Private constructor for singleton\n }\n\n /**\n * Get singleton instance\n */\n static getInstance(): ErrorValidator {\n if (!ErrorValidator.instance) {\n ErrorValidator.instance = new ErrorValidator();\n }\n return ErrorValidator.instance;\n }\n\n /**\n * Initialize validator (lazy load, async)\n */\n private async init(): Promise<void> {\n if (this.validateFn !== null || this.initError !== null) {\n return; // Already initialized\n }\n\n if (this.initPromise) {\n return this.initPromise; // Already initializing\n }\n\n this.initPromise = (async () => {\n try {\n // Ensure dependency schemas are registered before compiling error-response\n // Error handling schema references pathfinder error-response relatively.\n await compileSchemaById('pathfinder/v1.0.0/error-response');\n await compileSchemaById('assessment/v1.0.0/severity-definitions');\n\n // Compile schema using existing schema infrastructure\n // Schema ID for error-response extends pathfinder error-response\n this.validateFn = await compileSchemaById('error-handling/v1.0.0/error-response');\n } catch (err) {\n this.initError = err instanceof Error ? err : new Error(String(err));\n throw new Error(`Failed to initialize error validator: ${this.initError.message}`);\n }\n })();\n\n return this.initPromise;\n }\n\n /**\n * Validate error data against schema\n *\n * @param data - Data to validate\n * @returns Promise resolving to true if valid, false otherwise\n * @throws {Error} If validator failed to initialize\n */\n async validate(data: unknown): Promise<boolean> {\n if (this.validateFn === null) {\n await this.init();\n }\n\n if (this.initError) {\n throw this.initError;\n }\n\n if (!this.validateFn) {\n throw new Error('Validator not initialized');\n }\n\n return this.validateFn(data);\n }\n\n /**\n * Get validation errors from last validation\n *\n * @returns Validation errors or null\n */\n getErrors() {\n if (!this.validateFn) {\n return null;\n }\n return this.validateFn.errors;\n }\n\n /**\n * Reset validator state (for testing)\n * @internal\n */\n static _reset(): void {\n ErrorValidator.instance = new ErrorValidator();\n }\n}\n\n/**\n * Validate FulmenError data against error-response schema\n *\n * Uses pre-compiled validator singleton for optimal performance (<1ms target).\n *\n * @param data - Error data to validate\n * @returns Promise resolving to true if valid, false otherwise\n *\n * @example\n * ```typescript\n * const data = {\n * code: 'CONFIG_INVALID',\n * message: 'Configuration validation failed'\n * };\n *\n * if (await validateErrorData(data)) {\n * // Data is schema-compliant\n * } else {\n * const errors = await getValidationErrors();\n * console.error('Validation failed:', errors);\n * }\n * ```\n */\nexport async function validateErrorData(data: unknown): Promise<boolean> {\n return ErrorValidator.getInstance().validate(data);\n}\n\n/**\n * Get validation errors from last validation\n *\n * @returns Validation errors or null\n *\n * @example\n * ```typescript\n * if (!(await validateErrorData(data))) {\n * const errors = getValidationErrors();\n * errors?.forEach(err => {\n * console.error(`${err.instancePath}: ${err.message}`);\n * });\n * }\n * ```\n */\nexport function getValidationErrors() {\n return ErrorValidator.getInstance().getErrors();\n}\n\n/**\n * Format validation errors as human-readable string\n *\n * @param errors - Validation error objects\n * @returns Formatted error message\n *\n * @example\n * ```typescript\n * const errors = getValidationErrors();\n * if (errors) {\n * throw new Error(formatValidationErrors(errors));\n * }\n * ```\n */\nexport function formatValidationErrors(\n errors: Array<{ instancePath?: string; message?: string }>,\n): string {\n return errors\n .map((err) => {\n const path = err.instancePath || '(root)';\n const message = err.message || 'validation failed';\n return `${path}: ${message}`;\n })\n .join('; ');\n}\n\n/**\n * Validate and throw if invalid\n *\n * @param data - Error data to validate\n * @throws {Error} If validation fails\n *\n * @example\n * ```typescript\n * await assertValidErrorData(data); // Throws if invalid\n * // Safe to use data here\n * ```\n */\nexport async function assertValidErrorData(data: unknown): Promise<void> {\n if (!(await validateErrorData(data))) {\n const errors = getValidationErrors();\n const message = errors ? formatValidationErrors(errors) : 'Error data validation failed';\n throw new Error(`Invalid error data: ${message}`);\n }\n}\n\n// Export for testing\nexport { ErrorValidator };\n","/**\n * FulmenError - Structured error data model for observability\n *\n * Implements ADR-0006 error data model extending Pathfinder error-response\n * with optional telemetry metadata (severity, correlation_id, trace_id, etc.)\n */\n\nimport { extractErrorMessage, extractStackTrace, type FulmenErrorData } from './serialization.js';\nimport type { SeverityLevel, SeverityName } from './severity.js';\nimport { getDefaultSeverity, SEVERITY_LEVELS, Severity } from './severity.js';\nimport { validateErrorData } from './validators.js';\n\n// Re-export FulmenErrorData from serialization\nexport type { FulmenErrorData } from './serialization.js';\n\n/**\n * Options for creating/wrapping FulmenError\n */\nexport interface FulmenErrorOptions {\n code?: string;\n severity?: SeverityName;\n correlation_id?: string;\n trace_id?: string;\n exit_code?: number;\n context?: Record<string, unknown>;\n details?: Record<string, unknown>;\n path?: string;\n}\n\n/**\n * FulmenError class - wraps structured error data with helper methods\n *\n * Implements ADR-0006 canonical data model pattern:\n * - Data stored in immutable FulmenErrorData interface\n * - Class provides ergonomic API and methods\n * - Extends native Error for stack traces and instanceof checks\n */\nexport class FulmenError extends Error {\n readonly data: FulmenErrorData;\n\n constructor(data: FulmenErrorData) {\n super(data.message);\n this.name = 'FulmenError';\n\n // Freeze data for immutability\n this.data = Object.freeze({ ...data });\n\n // Capture stack trace\n Error.captureStackTrace(this, FulmenError);\n }\n\n /**\n * Serialize to JSON (schema-compliant)\n */\n toJSON(): FulmenErrorData {\n return this.data;\n }\n\n /**\n * Check equality with another FulmenError\n */\n equals(other: FulmenError): boolean {\n return JSON.stringify(this.data) === JSON.stringify(other.data);\n }\n\n /**\n * Get severity level for comparison\n */\n getSeverityLevel(): SeverityLevel {\n return this.data.severity_level ?? SEVERITY_LEVELS[this.data.severity ?? 'medium'];\n }\n\n /**\n * Wrap an existing error with FulmenError structure\n *\n * @param error - Error to wrap (Error instance or FulmenErrorData)\n * @param options - Additional error options\n * @returns New FulmenError instance\n *\n * @example\n * ```typescript\n * try {\n * throw new Error('Config invalid');\n * } catch (err) {\n * const fulmenErr = FulmenError.wrap(err, {\n * code: 'CONFIG_INVALID',\n * severity: 'high',\n * exit_code: 2\n * });\n * throw fulmenErr;\n * }\n * ```\n */\n static wrap(error: Error | FulmenErrorData, options: FulmenErrorOptions = {}): FulmenError {\n // If already FulmenError, merge options with recomputed derived fields\n if (error instanceof FulmenError) {\n // Determine effective severity (prefer options, fallback to existing, default to medium)\n const effectiveSeverity = options.severity ?? error.data.severity ?? Severity.MEDIUM;\n // CRITICAL: Recompute severity_level from severity to maintain consistency (ADR-0006)\n const effectiveSeverityLevel = SEVERITY_LEVELS[effectiveSeverity];\n\n // Update timestamp when re-wrapping (indicates new error context)\n const timestamp = new Date().toISOString();\n\n return new FulmenError({\n ...error.data,\n ...options,\n code: options.code ?? error.data.code,\n message: error.data.message,\n severity: effectiveSeverity, // Consistent severity\n severity_level: effectiveSeverityLevel, // Recomputed level\n timestamp, // Updated timestamp\n });\n }\n\n // If FulmenErrorData, recompute derived fields\n if (isFulmenErrorData(error)) {\n const defaultSeverity = getDefaultSeverity();\n // Prefer options.severity, fall back to error.severity, default to medium\n const effectiveSeverity = options.severity ?? error.severity ?? defaultSeverity.name;\n // CRITICAL: Always recompute severity_level from severity (never trust provided level)\n const effectiveSeverityLevel = SEVERITY_LEVELS[effectiveSeverity];\n\n return new FulmenError({\n ...error,\n ...options,\n severity: effectiveSeverity,\n severity_level: effectiveSeverityLevel, // Recomputed, not from error.severity_level\n timestamp: error.timestamp ?? new Date().toISOString(),\n });\n }\n\n // Wrap native Error\n return FulmenError.fromError(error, options);\n }\n\n /**\n * Create FulmenError from native Error object\n *\n * @param err - Native Error instance\n * @param options - Error options\n * @returns New FulmenError instance\n *\n * @example\n * ```typescript\n * const err = new TypeError('Invalid type');\n * const fulmenErr = FulmenError.fromError(err, {\n * code: 'TYPE_ERROR',\n * severity: 'medium'\n * });\n * ```\n */\n static fromError(err: Error | unknown, options: FulmenErrorOptions = {}): FulmenError {\n const code = options.code ?? 'UNKNOWN_ERROR';\n const severity = options.severity ?? Severity.MEDIUM;\n const severityLevel = SEVERITY_LEVELS[severity];\n\n const message = extractErrorMessage(err);\n const stack = extractStackTrace(err);\n\n const data: FulmenErrorData = {\n code,\n message,\n severity,\n severity_level: severityLevel,\n timestamp: new Date().toISOString(),\n ...options,\n context: {\n ...options.context,\n originalName: err instanceof Error ? err.name : typeof err,\n stack,\n },\n original: stack || message,\n };\n\n return new FulmenError(data);\n }\n\n /**\n * Validate error data against schema\n *\n * @param data - Error data to validate\n * @returns Promise resolving to true if valid\n *\n * @example\n * ```typescript\n * const data = { code: 'TEST', message: 'Test error' };\n * if (await FulmenError.validate(data)) {\n * const err = new FulmenError(data);\n * }\n * ```\n */\n static async validate(data: unknown): Promise<boolean> {\n return validateErrorData(data);\n }\n\n /**\n * Exit process with structured error\n *\n * Logs error as JSON and exits with specified exit code.\n * Mockable for testing (override process.exit).\n *\n * @param error - FulmenError instance\n * @param options - Exit options\n *\n * @example\n * ```typescript\n * const err = FulmenError.fromError(new Error('Fatal'), {\n * code: 'FATAL_ERROR',\n * exit_code: 1\n * });\n * FulmenError.exitWithError(err); // Exits with code 1\n * ```\n */\n static exitWithError(\n error: FulmenError,\n options: { logger?: (msg: string) => void } = {},\n ): never {\n const logger = options.logger ?? console.error;\n const exitCode = error.data.exit_code ?? 1;\n\n // Log structured error\n logger(JSON.stringify(error.toJSON(), null, 2));\n\n // Exit with code\n process.exit(exitCode);\n }\n}\n\n/**\n * Type guard to check if value is FulmenError instance\n *\n * @param value - Value to check\n * @returns True if value is FulmenError\n */\nexport function isFulmenError(value: unknown): value is FulmenError {\n return value instanceof FulmenError;\n}\n\n/**\n * Type guard to check if value is FulmenErrorData\n *\n * @param value - Value to check\n * @returns True if value is FulmenErrorData\n */\nexport function isFulmenErrorData(value: unknown): value is FulmenErrorData {\n return (\n typeof value === 'object' &&\n value !== null &&\n 'code' in value &&\n typeof (value as FulmenErrorData).code === 'string' &&\n 'message' in value &&\n typeof (value as FulmenErrorData).message === 'string'\n );\n}\n","/**\n * Errors module - structured error handling with telemetry\n *\n * Provides FulmenError data model and utilities for schema-backed error responses\n * with optional telemetry metadata (severity, correlation IDs, exit codes).\n */\n\nexport const VERSION = '0.2.0';\n\n// Correlation ID utilities\nexport {\n generateCorrelationId,\n isCorrelationId,\n isValidCorrelationId,\n normalizeCorrelationId,\n} from './correlation.js';\n// Core error class and types\nexport {\n FulmenError,\n type FulmenErrorData,\n type FulmenErrorOptions,\n isFulmenError,\n isFulmenErrorData,\n} from './fulmen-error.js';\n// Serialization utilities\nexport {\n extractErrorMessage,\n extractStackTrace,\n serializeError,\n} from './serialization.js';\n// Severity utilities\nexport {\n compareSeverity,\n getDefaultSeverity,\n isSeverityLevel,\n isSeverityName,\n LEVEL_TO_SEVERITY,\n levelToSeverity,\n SEVERITY_LEVELS,\n Severity,\n type SeverityLevel,\n type SeverityName,\n severityToLevel,\n} from './severity.js';\n// Validation utilities\nexport {\n assertValidErrorData,\n formatValidationErrors,\n getValidationErrors,\n validateErrorData,\n} from './validators.js';\n","/**\n * Application Identity Errors\n *\n * Module-specific error classes for identity operations\n */\n\nimport { FulmenError, type FulmenErrorData } from '../errors/index.js';\nimport type { SchemaValidationDiagnostic } from '../schema/types.js';\n\n/**\n * Base error class for app identity operations\n */\nexport class AppIdentityError extends FulmenError {\n public readonly identityPath?: string;\n\n constructor(message: string, identityPath?: string, cause?: Error) {\n // Build FulmenErrorData\n let errorData: FulmenErrorData;\n\n if (cause) {\n errorData = FulmenError.fromError(cause, {\n code: 'APP_IDENTITY_ERROR',\n severity: 'high',\n context: { identityPath },\n }).data;\n } else {\n errorData = {\n code: 'APP_IDENTITY_ERROR',\n message,\n severity: 'high',\n timestamp: new Date().toISOString(),\n context: { identityPath },\n };\n }\n\n super(errorData);\n this.name = 'AppIdentityError';\n this.identityPath = identityPath;\n\n // Maintains proper stack trace for where our error was thrown (only available on V8)\n if (Error.captureStackTrace) {\n Error.captureStackTrace(this, AppIdentityError);\n }\n }\n\n /**\n * Create error for identity not found\n */\n static notFound(searchedPaths: string[]): AppIdentityError {\n const message = `App identity not found\\nSearched paths:\\n${searchedPaths.map((p) => ` - ${p}`).join('\\n')}`;\n return new AppIdentityError(message);\n }\n\n /**\n * Create error for schema validation failure\n */\n static validationFailed(\n path: string,\n diagnostics: SchemaValidationDiagnostic[],\n ): AppIdentityError {\n const errorCount = diagnostics.filter((d) => d.severity === 'ERROR').length;\n const warningCount = diagnostics.filter((d) => d.severity === 'WARN').length;\n\n let message = `Invalid app identity: ${path}\\n`;\n message += `Validation errors: ${errorCount} error(s), ${warningCount} warning(s)\\n`;\n\n // Include first few diagnostics\n const displayDiagnostics = diagnostics.slice(0, 3);\n for (const diag of displayDiagnostics) {\n message += ` - ${diag.message}`;\n if (diag.pointer) {\n message += ` at ${diag.pointer}`;\n }\n message += '\\n';\n }\n\n if (diagnostics.length > 3) {\n message += ` ... and ${diagnostics.length - 3} more\\n`;\n }\n\n return new AppIdentityError(message, path);\n }\n\n /**\n * Create error for environment variable override pointing to missing file\n */\n static envOverrideMissing(envPath: string): AppIdentityError {\n const message = `FULMEN_APP_IDENTITY_PATH points to missing file: ${envPath}\\n`;\n return new AppIdentityError(message, envPath);\n }\n\n /**\n * Create error for YAML parsing failure\n */\n static parseFailed(path: string, cause: Error): AppIdentityError {\n const message = `Failed to parse identity file: ${path}\\n${cause.message}`;\n return new AppIdentityError(message, path, cause);\n }\n\n /**\n * Create error for file read failure\n */\n static readFailed(path: string, cause: Error): AppIdentityError {\n const message = `Failed to read identity file: ${path}\\n${cause.message}`;\n return new AppIdentityError(message, path, cause);\n }\n}\n","/**\n * Application Identity Discovery\n *\n * Implements the Crucible discovery precedence algorithm:\n * 1. Explicit path parameter (highest priority)\n * 2. Environment variable override (FULMEN_APP_IDENTITY_PATH)\n * 3. Ancestor search from CWD upward\n */\n\nimport { access } from 'node:fs/promises';\nimport { dirname, join } from 'node:path';\nimport {\n APP_IDENTITY_DIR,\n APP_IDENTITY_ENV_VAR,\n APP_IDENTITY_FILENAME,\n MAX_ANCESTOR_SEARCH_DEPTH,\n} from './constants.js';\nimport { AppIdentityError } from './errors.js';\n\n/**\n * Discovery result with path and source\n */\nexport interface DiscoveryResult {\n readonly path: string;\n readonly source: 'explicit' | 'env' | 'ancestor' | 'test';\n}\n\n/**\n * Options for identity discovery\n */\nexport interface DiscoveryOptions {\n /**\n * Explicit path override (highest priority)\n */\n readonly path?: string;\n\n /**\n * Starting directory for ancestor search\n * Defaults to process.cwd()\n */\n readonly startDir?: string;\n}\n\n/**\n * Discover application identity file using Crucible precedence algorithm\n *\n * Discovery order:\n * 1. Explicit path parameter (throws if not found)\n * 2. FULMEN_APP_IDENTITY_PATH env var (throws if set but not found)\n * 3. Ancestor search from startDir (throws if not found after max depth)\n *\n * @param options - Discovery options\n * @returns Discovery result with path and source\n * @throws {AppIdentityError} If identity file not found or inaccessible\n */\nexport async function discoverIdentityPath(\n options?: DiscoveryOptions,\n): Promise<DiscoveryResult | null> {\n // 1. Explicit path parameter (highest priority)\n if (options?.path) {\n const exists = await fileExists(options.path);\n if (!exists) {\n throw AppIdentityError.notFound([options.path]);\n }\n return { path: options.path, source: 'explicit' };\n }\n\n // 2. Environment variable override\n const envPath = process.env[APP_IDENTITY_ENV_VAR];\n if (envPath) {\n const exists = await fileExists(envPath);\n if (!exists) {\n throw AppIdentityError.envOverrideMissing(envPath);\n }\n return { path: envPath, source: 'env' };\n }\n\n // 3. Ancestor search from startDir\n const startDir = options?.startDir || process.cwd();\n const result = await searchAncestors(startDir);\n if (result) {\n return { path: result, source: 'ancestor' };\n }\n\n return null;\n}\n\n/**\n * Search ancestor directories for identity file\n *\n * Walks upward from startDir to filesystem root, looking for .fulmen/app.yaml\n * Stops at MAX_ANCESTOR_SEARCH_DEPTH or filesystem root\n *\n * @param startDir - Directory to start search from\n * @returns Path to identity file if found, null otherwise\n * @throws {AppIdentityError} If max depth reached or filesystem root reached without finding file\n */\nasync function searchAncestors(startDir: string): Promise<string | null> {\n let currentDir = startDir;\n const searchedPaths: string[] = [];\n\n for (let i = 0; i < MAX_ANCESTOR_SEARCH_DEPTH; i++) {\n const candidatePath = join(currentDir, APP_IDENTITY_DIR, APP_IDENTITY_FILENAME);\n searchedPaths.push(candidatePath);\n\n if (await fileExists(candidatePath)) {\n return candidatePath;\n }\n\n const parentDir = dirname(currentDir);\n if (parentDir === currentDir) {\n // Reached filesystem root\n throw AppIdentityError.notFound(searchedPaths);\n }\n currentDir = parentDir;\n }\n\n // Max depth reached\n throw AppIdentityError.notFound(searchedPaths);\n}\n\n/**\n * Check if a file exists and is accessible\n *\n * @param path - Path to check\n * @returns true if file exists and is readable, false otherwise\n */\nasync function fileExists(path: string): Promise<boolean> {\n try {\n await access(path);\n return true;\n } catch {\n return false;\n }\n}\n","/**\n * Application Identity Loader\n *\n * Main loading logic with YAML parsing, schema validation, and caching\n */\n\nimport { readFile } from 'node:fs/promises';\nimport { parse as parseYAML } from 'yaml';\nimport { validateDataBySchemaId } from '../schema/index.js';\nimport { clearIdentityCache, getCachedIdentity, setCachedIdentity } from './cache.js';\nimport { APP_IDENTITY_SCHEMA_ID } from './constants.js';\nimport { discoverIdentityPath } from './discovery.js';\nimport { AppIdentityError } from './errors.js';\nimport type { Identity, LoadIdentityOptions } from './types.js';\n\n/**\n * Deep freeze an object and all its nested properties\n *\n * Recursively freezes an object and all nested objects/functions to ensure\n * complete immutability. This prevents accidental mutations of identity data.\n *\n * Note: Uses `any` type assertion (line 28) to access arbitrary properties\n * during recursive traversal. This is necessary because TypeScript's generic\n * constraint system cannot express \"any object with indexable properties\"\n * without losing the return type safety. The `any` is scoped to a single\n * line and protected by runtime guards.\n *\n * @param obj - Object to freeze\n * @returns Frozen object (same type as input)\n */\nfunction deepFreeze<T>(obj: T): T {\n // Freeze the object itself\n Object.freeze(obj);\n\n // Recursively freeze all properties\n Object.getOwnPropertyNames(obj).forEach((prop) => {\n // biome-ignore lint/suspicious/noExplicitAny: Required for recursive property access - see function docs\n const value = (obj as any)[prop];\n if (\n value !== null &&\n (typeof value === 'object' || typeof value === 'function') &&\n !Object.isFrozen(value)\n ) {\n deepFreeze(value);\n }\n });\n\n return obj;\n}\n\n/**\n * Load application identity from .fulmen/app.yaml\n *\n * Discovery order:\n * 1. Test injection (options.identity) - bypasses all discovery and caching\n * 2. Explicit path (options.path)\n * 3. Environment variable (FULMEN_APP_IDENTITY_PATH)\n * 4. Ancestor search from startDir or CWD\n *\n * Results are cached after first successful load unless skipCache is true.\n * Test injections are never cached.\n *\n * @param options - Load options\n * @returns Frozen, immutable identity object\n * @throws {AppIdentityError} If identity not found, invalid, or unreadable\n */\nexport async function loadIdentity(options?: LoadIdentityOptions): Promise<Identity> {\n // Test injection (never caches)\n if (options?.identity) {\n return deepFreeze(structuredClone(options.identity)) as Identity;\n }\n\n // Check cache unless skipCache\n if (!options?.skipCache) {\n const cached = getCachedIdentity();\n if (cached) {\n return cached;\n }\n }\n\n // Discover file\n const discovery = await discoverIdentityPath({\n path: options?.path,\n startDir: options?.startDir,\n });\n\n if (!discovery) {\n throw AppIdentityError.notFound([]);\n }\n\n // Read file\n let content: string;\n try {\n content = await readFile(discovery.path, 'utf-8');\n } catch (error) {\n throw AppIdentityError.readFailed(\n discovery.path,\n error instanceof Error ? error : new Error(String(error)),\n );\n }\n\n // Parse YAML\n let parsed: unknown;\n try {\n parsed = parseYAML(content);\n } catch (error) {\n throw AppIdentityError.parseFailed(\n discovery.path,\n error instanceof Error ? error : new Error(String(error)),\n );\n }\n\n // Validate against schema (unless skipValidation)\n if (!options?.skipValidation) {\n const result = await validateDataBySchemaId(parsed, APP_IDENTITY_SCHEMA_ID);\n\n if (!result.valid) {\n throw AppIdentityError.validationFailed(discovery.path, result.diagnostics);\n }\n }\n\n // Deep freeze for immutability\n const identity = deepFreeze(structuredClone(parsed)) as Identity;\n\n // Cache result\n setCachedIdentity(identity);\n\n return identity;\n}\n\n/**\n * Get cached identity without triggering load\n *\n * @returns Cached identity or null if not cached\n */\nexport { getCachedIdentity };\n\n/**\n * Clear the identity cache\n *\n * Useful for testing or when identity needs to be reloaded\n */\nexport { clearIdentityCache };\n","/**\n * Schema CLI - Commander-based CLI for schema operations\n *\n * Provides command-line interface for schema discovery, validation,\n * and normalization operations. This is a developer tool for exploration\n * and testing, not for production use.\n */\n\nimport { readFile, writeFile } from 'node:fs/promises';\nimport { Command } from 'commander';\nimport { isGoneatAvailable, runGoneatValidation } from './goneat-bridge.js';\nimport { compareSchemas, normalizeSchema } from './normalizer.js';\nimport { getSchemaRegistry, listSchemas } from './registry.js';\nimport type { CLIOptions, SchemaValidationResult } from './types.js';\nimport { formatDiagnostics } from './utils.js';\nimport { validateFileBySchemaId } from './validator.js';\n\n/**\n * Create CLI command structure\n */\nexport function createCLI(options: CLIOptions = {}): Command {\n const program = new Command();\n\n program\n .name('tsfulmen-schema')\n .description('Schema validation and discovery CLI for Fulmen (developer tool)')\n .version('0.1.0');\n\n // List schemas command\n program\n .command('list')\n .description('List available schemas from registry')\n .argument('[prefix]', 'Filter schemas by prefix')\n .option('--base-dir <path>', 'Override schema base directory')\n .action(async (prefix?: string, cmdOptions?: { baseDir?: string }) => {\n try {\n const schemas = await listSchemas(prefix, {\n baseDir: cmdOptions?.baseDir || options.baseDir,\n });\n\n if (schemas.length === 0) {\n console.log('No schemas found');\n return;\n }\n\n console.log(`Found ${schemas.length} schema(s):\\n`);\n for (const schema of schemas) {\n console.log(` ${schema.id}`);\n console.log(` Format: ${schema.format}`);\n console.log(` Path: ${schema.relativePath}`);\n if (schema.description) {\n console.log(` Description: ${schema.description}`);\n }\n console.log();\n }\n } catch (error) {\n console.error('Error listing schemas:', (error as Error).message);\n process.exit(1);\n }\n });\n\n // Show schema command\n program\n .command('show')\n .description('Show schema details')\n .requiredOption('--schema-id <id>', 'Schema ID to show')\n .option('--base-dir <path>', 'Override schema base directory')\n .action(async (cmdOptions: { schemaId: string; baseDir?: string }) => {\n try {\n const registry = getSchemaRegistry({\n baseDir: cmdOptions.baseDir || options.baseDir,\n });\n const schema = await registry.getSchema(cmdOptions.schemaId);\n\n console.log('Schema Details:\\n');\n console.log(` ID: ${schema.id}`);\n console.log(` Format: ${schema.format}`);\n console.log(` Path: ${schema.path}`);\n console.log(` Relative Path: ${schema.relativePath}`);\n if (schema.version) {\n console.log(` Version: ${schema.version}`);\n }\n if (schema.description) {\n console.log(` Description: ${schema.description}`);\n }\n if (schema.schemaDraft) {\n console.log(` Schema Draft: ${schema.schemaDraft}`);\n }\n\n // Read and display schema content\n const content = await readFile(schema.path, 'utf-8');\n console.log('\\nSchema Content:');\n console.log(content);\n } catch (error) {\n console.error('Error showing schema:', (error as Error).message);\n process.exit(1);\n }\n });\n\n // Validate data command\n program\n .command('validate')\n .description('Validate data file against schema')\n .requiredOption('--schema-id <id>', 'Schema ID to validate against')\n .argument('<file>', 'Data file to validate')\n .option('--use-goneat', 'Use goneat for validation (requires goneat binary)')\n .option('--goneat-path <path>', 'Path to goneat binary')\n .option('--base-dir <path>', 'Override schema base directory')\n .action(\n async (\n file: string,\n cmdOptions: {\n schemaId: string;\n useGoneat?: boolean;\n goneatPath?: string;\n baseDir?: string;\n },\n ) => {\n try {\n let result: SchemaValidationResult;\n\n if (cmdOptions.useGoneat) {\n // Check goneat availability\n const available = await isGoneatAvailable(cmdOptions.goneatPath);\n if (!available) {\n console.error('❌ goneat not available. Install goneat or remove --use-goneat flag.');\n console.error(' AJV validation (default) works without external dependencies.');\n process.exit(1);\n }\n\n // Get schema path\n const registry = getSchemaRegistry({\n baseDir: cmdOptions.baseDir || options.baseDir,\n });\n const schema = await registry.getSchema(cmdOptions.schemaId);\n\n console.log('Using goneat validation...');\n result = await runGoneatValidation(schema.path, file, cmdOptions.goneatPath);\n } else {\n // Use AJV validation (default, library implementation)\n console.log('Using AJV validation...');\n result = await validateFileBySchemaId(file, cmdOptions.schemaId, {\n baseDir: cmdOptions.baseDir || options.baseDir,\n });\n }\n\n if (result.valid) {\n console.log(`✅ Validation passed (${result.source})`);\n process.exit(0);\n } else {\n console.log(`❌ Validation failed (${result.source})`);\n console.log('\\nDiagnostics:');\n console.log(formatDiagnostics(result.diagnostics));\n process.exit(1);\n }\n } catch (error) {\n console.error('Error validating file:', (error as Error).message);\n process.exit(1);\n }\n },\n );\n\n // Validate schema command\n program\n .command('validate-schema')\n .description('Validate a schema file itself')\n .argument('<file>', 'Schema file to validate')\n .action(async (file: string) => {\n try {\n const content = await readFile(file, 'utf-8');\n const { validateSchema } = await import('./validator.js');\n const result = await validateSchema(content);\n\n if (result.valid) {\n console.log('✅ Schema is valid');\n process.exit(0);\n } else {\n console.log('❌ Schema is invalid');\n console.log('\\nDiagnostics:');\n console.log(formatDiagnostics(result.diagnostics));\n process.exit(1);\n }\n } catch (error) {\n console.error('Error validating schema:', (error as Error).message);\n process.exit(1);\n }\n });\n\n // Normalize schema command\n program\n .command('normalize')\n .description('Normalize schema to canonical JSON format')\n .argument('<file>', 'Schema file to normalize')\n .option('--compact', 'Output compact JSON (no formatting)')\n .option('-o, --output <file>', 'Write to output file instead of stdout')\n .action(async (file: string, cmdOptions: { compact?: boolean; output?: string }) => {\n try {\n const content = await readFile(file, 'utf-8');\n const normalized = normalizeSchema(content, {\n compact: cmdOptions.compact,\n });\n\n if (cmdOptions.output) {\n await writeFile(cmdOptions.output, normalized, 'utf-8');\n console.log(`✅ Normalized schema written to ${cmdOptions.output}`);\n } else {\n console.log(normalized);\n }\n } catch (error) {\n console.error('Error normalizing schema:', (error as Error).message);\n process.exit(1);\n }\n });\n\n // Compare schemas command\n program\n .command('compare')\n .description('Compare two schemas for semantic equality')\n .argument('<file1>', 'First schema file')\n .argument('<file2>', 'Second schema file')\n .option('--show-normalized', 'Show normalized outputs')\n .action(async (file1: string, file2: string, cmdOptions: { showNormalized?: boolean }) => {\n try {\n const content1 = await readFile(file1, 'utf-8');\n const content2 = await readFile(file2, 'utf-8');\n\n const result = compareSchemas(content1, content2);\n\n if (result.equal) {\n console.log('✅ Schemas are semantically equal');\n } else {\n console.log('❌ Schemas differ');\n }\n\n if (cmdOptions.showNormalized) {\n console.log('\\nNormalized Schema 1:');\n console.log(result.normalizedA);\n console.log('\\nNormalized Schema 2:');\n console.log(result.normalizedB);\n }\n\n process.exit(result.equal ? 0 : 1);\n } catch (error) {\n console.error('Error comparing schemas:', (error as Error).message);\n process.exit(1);\n }\n });\n\n // Export schema command\n program\n .command('export')\n .description('Export schema from registry to file with provenance')\n .requiredOption('--schema-id <id>', 'Schema ID to export')\n .requiredOption('--out <path>', 'Output file path')\n .option('--force', 'Overwrite existing file', false)\n .option('--no-provenance', 'Exclude provenance metadata')\n .option('--no-validate', 'Skip schema validation before export')\n .option('--format <format>', 'Export format (json|yaml|auto)', 'auto')\n .option('--base-dir <path>', 'Override schema base directory')\n .action(\n async (cmdOptions: {\n schemaId: string;\n out: string;\n force?: boolean;\n provenance?: boolean;\n validate?: boolean;\n format?: string;\n baseDir?: string;\n }) => {\n try {\n const { exportSchema } = await import('./export.js');\n const { exitCodes } = await import('../foundry/index.js');\n\n const result = await exportSchema({\n schemaId: cmdOptions.schemaId,\n outPath: cmdOptions.out,\n includeProvenance: cmdOptions.provenance ?? true,\n validate: cmdOptions.validate ?? true,\n overwrite: cmdOptions.force ?? false,\n format: (cmdOptions.format as 'json' | 'yaml' | 'auto') ?? 'auto',\n baseDir: cmdOptions.baseDir || options.baseDir,\n });\n\n console.log('✅ Schema exported successfully');\n console.log(` Schema ID: ${result.schemaId}`);\n console.log(` Output: ${result.outPath}`);\n console.log(` Format: ${result.format}`);\n\n if (result.provenance) {\n console.log('\\nProvenance:');\n console.log(` Crucible: ${result.provenance.crucible_version}`);\n console.log(` Library: ${result.provenance.library_version}`);\n if (result.provenance.revision) {\n console.log(` Revision: ${result.provenance.revision}`);\n }\n console.log(` Exported: ${result.provenance.exported_at}`);\n }\n\n process.exit(exitCodes.EXIT_SUCCESS);\n } catch (error) {\n const { exitCodes } = await import('../foundry/index.js');\n const { SchemaExportError, SchemaValidationError, ExportErrorReason } = await import(\n './errors.js'\n );\n\n console.error('❌ Schema export failed:', (error as Error).message);\n\n // Map specific error types to appropriate exit codes\n if (error instanceof SchemaExportError) {\n if (error.outPath) {\n console.error(` Output path: ${error.outPath}`);\n }\n\n // Use error reason for type-safe exit code mapping\n switch (error.reason) {\n case ExportErrorReason.FILE_EXISTS:\n case ExportErrorReason.WRITE_FAILED:\n process.exit(exitCodes.EXIT_FILE_WRITE_ERROR);\n break;\n\n case ExportErrorReason.INVALID_FORMAT:\n process.exit(exitCodes.EXIT_INVALID_ARGUMENT);\n break;\n\n default:\n // PROVENANCE_FAILED, UNKNOWN, and any future reasons\n process.exit(exitCodes.EXIT_FAILURE);\n }\n }\n\n if (error instanceof SchemaValidationError) {\n // Schema not found or validation failed\n const errorMsg = error.message.toLowerCase();\n\n if (errorMsg.includes('not found')) {\n process.exit(exitCodes.EXIT_FILE_NOT_FOUND);\n }\n\n // Validation failures\n process.exit(exitCodes.EXIT_DATA_INVALID);\n }\n\n process.exit(exitCodes.EXIT_FAILURE);\n }\n },\n );\n\n // Identity show command\n program\n .command('identity-show')\n .description('Show application identity from .fulmen/app.yaml')\n .option('--path <path>', 'Explicit path to app.yaml')\n .option('--json', 'Output as JSON')\n .action(async (cmdOptions: { path?: string; json?: boolean }) => {\n try {\n const { loadIdentity } = await import('../appidentity/loader.js');\n const { exitCodes } = await import('../foundry/index.js');\n\n const identity = await loadIdentity({ path: cmdOptions.path });\n\n if (cmdOptions.json) {\n console.log(JSON.stringify(identity, null, 2));\n } else {\n console.log('Application Identity:\\n');\n console.log(` Binary Name: ${identity.app.binary_name}`);\n console.log(` Vendor: ${identity.app.vendor}`);\n console.log(` Env Prefix: ${identity.app.env_prefix}`);\n console.log(` Config Name: ${identity.app.config_name}`);\n console.log(` Description: ${identity.app.description}`);\n\n if (identity.metadata) {\n console.log('\\nMetadata:');\n if (identity.metadata.license) {\n console.log(` License: ${identity.metadata.license}`);\n }\n if (identity.metadata.repository_category) {\n console.log(` Category: ${identity.metadata.repository_category}`);\n }\n if (identity.metadata.telemetry_namespace) {\n console.log(` Telemetry: ${identity.metadata.telemetry_namespace}`);\n }\n if (identity.metadata.project_url) {\n console.log(` Project URL: ${identity.metadata.project_url}`);\n }\n }\n }\n\n process.exit(exitCodes.EXIT_SUCCESS);\n } catch (error) {\n const { exitCodes } = await import('../foundry/index.js');\n const { AppIdentityError } = await import('../appidentity/errors.js');\n\n console.error('❌ Failed to load identity:', (error as Error).message);\n\n if (error instanceof AppIdentityError) {\n if (error.message.includes('not found')) {\n process.exit(exitCodes.EXIT_FILE_NOT_FOUND);\n }\n if (error.message.includes('Invalid') || error.message.includes('validation')) {\n process.exit(exitCodes.EXIT_DATA_INVALID);\n }\n }\n\n process.exit(exitCodes.EXIT_FAILURE);\n }\n });\n\n // Identity validate command\n program\n .command('identity-validate')\n .description('Validate application identity against schema')\n .argument('[file]', 'Path to app.yaml (defaults to discovery)')\n .action(async (file?: string) => {\n try {\n const { loadIdentity } = await import('../appidentity/loader.js');\n const { exitCodes } = await import('../foundry/index.js');\n\n console.log('Validating application identity...');\n\n const identity = await loadIdentity({ path: file });\n\n console.log('✅ Identity is valid');\n console.log(` Binary: ${identity.app.binary_name}`);\n console.log(` Vendor: ${identity.app.vendor}`);\n\n process.exit(exitCodes.EXIT_SUCCESS);\n } catch (error) {\n const { exitCodes } = await import('../foundry/index.js');\n const { AppIdentityError } = await import('../appidentity/errors.js');\n\n console.error('❌ Identity validation failed:', (error as Error).message);\n\n if (error instanceof AppIdentityError) {\n if (error.message.includes('not found')) {\n process.exit(exitCodes.EXIT_FILE_NOT_FOUND);\n }\n if (error.message.includes('Invalid') || error.message.includes('validation')) {\n process.exit(exitCodes.EXIT_DATA_INVALID);\n }\n }\n\n process.exit(exitCodes.EXIT_FAILURE);\n }\n });\n\n return program;\n}\n\n// Main entry point when run directly\nif (import.meta.url === `file://${process.argv[1]}`) {\n const program = createCLI();\n program.parse(process.argv);\n}\n","/**\n * Schema validation module - implements Fulmen Schema Validation Standard\n *\n * Provides schema discovery, validation, and normalization utilities for Crucible schemas\n * with JSON Schema 2020-12 support and optional goneat integration.\n */\n\nexport const VERSION = '0.1.0';\n\n// CLI exports\nexport { createCLI } from './cli.js';\n// Error exports\nexport * from './errors.js';\n// Export exports\nexport { exportSchema, stripProvenance } from './export.js';\n// Goneat bridge exports (CLI-only, optional)\nexport {\n detectGoneat,\n isGoneatAvailable,\n runGoneatValidation,\n} from './goneat-bridge.js';\n// Normalizer exports\nexport { compareSchemas, normalizeSchema } from './normalizer.js';\n// Registry exports\nexport {\n getSchema,\n getSchemaByPath,\n getSchemaRegistry,\n hasSchema,\n listSchemas,\n SchemaRegistry,\n} from './registry.js';\n// Core exports\nexport type {\n AjvError,\n CLIOptions,\n CompiledValidator,\n ExportSchemaOptions,\n ExportSchemaResult,\n SchemaComparisonResult,\n SchemaExportFormat,\n SchemaFormat,\n SchemaInput,\n SchemaMetadata,\n SchemaNormalizationOptions,\n SchemaProvenanceMetadata,\n SchemaRegistryOptions,\n SchemaSource,\n SchemaValidationDiagnostic,\n SchemaValidationOptions,\n SchemaValidationResult,\n} from './types.js';\n// Utility exports\nexport {\n countDiagnostics,\n createDiagnostic,\n formatDiagnostics,\n formatValidationResult,\n groupDiagnosticsBySeverity,\n isValidationError,\n normalizePointer,\n} from './utils.js';\n// Validator exports\nexport {\n clearCache,\n compileSchema,\n compileSchemaById,\n getCacheSize,\n validateData,\n validateDataBySchemaId,\n validateFile,\n validateFileBySchemaId,\n validateSchema,\n} from './validator.js';\n","/**\n * Metrics event validators\n *\n * Schema validation for metrics events using existing src/schema infrastructure\n */\n\nimport { compileSchemaById } from '../schema/index.js';\nimport type { CompiledValidator } from '../schema/types.js';\n\n/**\n * Singleton validator for metrics events\n *\n * Pre-compiles the metrics-event schema at first access for optimal performance.\n * Reuses existing AJV setup from src/schema module.\n */\nclass MetricsValidator {\n private static instance: MetricsValidator;\n private validateFn: CompiledValidator | null = null;\n private initPromise: Promise<void> | null = null;\n private initError: Error | null = null;\n\n private constructor() {\n // Private constructor for singleton\n }\n\n /**\n * Get singleton instance\n */\n static getInstance(): MetricsValidator {\n if (!MetricsValidator.instance) {\n MetricsValidator.instance = new MetricsValidator();\n }\n return MetricsValidator.instance;\n }\n\n /**\n * Initialize validator (lazy load, async)\n */\n private async init(): Promise<void> {\n if (this.validateFn !== null || this.initError !== null) {\n return; // Already initialized\n }\n\n if (this.initPromise) {\n return this.initPromise; // Already initializing\n }\n\n this.initPromise = (async () => {\n try {\n // Compile schema using existing schema infrastructure\n this.validateFn = await compileSchemaById('observability/metrics/v1.0.0/metrics-event');\n } catch (err) {\n this.initError = err instanceof Error ? err : new Error(String(err));\n throw new Error(`Failed to initialize metrics validator: ${this.initError.message}`);\n }\n })();\n\n return this.initPromise;\n }\n\n /**\n * Validate metrics event against schema\n *\n * @param event - Metrics event to validate\n * @returns Promise resolving to true if valid, false otherwise\n */\n async validate(event: unknown): Promise<boolean> {\n if (this.validateFn === null) {\n await this.init();\n }\n\n if (this.initError) {\n throw this.initError;\n }\n\n if (!this.validateFn) {\n throw new Error('Validator not initialized');\n }\n\n return this.validateFn(event);\n }\n\n /**\n * Get validation errors from last validation\n */\n getErrors() {\n if (!this.validateFn) {\n return null;\n }\n return this.validateFn.errors;\n }\n\n /**\n * Reset validator state (for testing)\n * @internal\n */\n static _reset(): void {\n MetricsValidator.instance = new MetricsValidator();\n }\n}\n\n/**\n * Validate metrics event against schema\n *\n * Uses pre-compiled validator singleton for optimal performance.\n *\n * @param event - Metrics event to validate\n * @returns Promise resolving to true if valid\n *\n * @example\n * ```typescript\n * const event: MetricsEvent = {\n * timestamp: new Date().toISOString(),\n * name: 'schema_validations',\n * value: 42\n * };\n *\n * if (await validateMetricsEvent(event)) {\n * // Event is schema-compliant\n * } else {\n * const errors = getValidationErrors();\n * console.error('Validation failed:', errors);\n * }\n * ```\n */\nexport async function validateMetricsEvent(event: unknown): Promise<boolean> {\n return MetricsValidator.getInstance().validate(event);\n}\n\n/**\n * Validate array of metrics events\n *\n * @param events - Array of metrics events\n * @returns Promise resolving to true if all valid\n */\nexport async function validateMetricsEvents(events: unknown[]): Promise<boolean> {\n for (const event of events) {\n if (!(await validateMetricsEvent(event))) {\n return false;\n }\n }\n return true;\n}\n\n/**\n * Get validation errors from last validation\n */\nexport function getValidationErrors() {\n return MetricsValidator.getInstance().getErrors();\n}\n\n/**\n * Format validation errors as human-readable string\n */\nexport function formatValidationErrors(\n errors: Array<{ instancePath?: string; message?: string }>,\n): string {\n return errors\n .map((err) => {\n const path = err.instancePath || '(root)';\n const message = err.message || 'validation failed';\n return `${path}: ${message}`;\n })\n .join('; ');\n}\n\n/**\n * Assert that metrics event is valid (throws if not)\n *\n * @param event - Metrics event to validate\n * @throws {Error} If validation fails\n */\nexport async function assertValidMetricsEvent(event: unknown): Promise<void> {\n if (!(await validateMetricsEvent(event))) {\n const errors = getValidationErrors();\n const message = errors ? formatValidationErrors(errors) : 'Metrics event validation failed';\n throw new Error(`Invalid metrics event: ${message}`);\n }\n}\n\n// Export for testing\nexport { MetricsValidator };\n","/**\n * Telemetry module - metrics collection and export\n *\n * Provides counter, gauge, and histogram metrics with schema validation\n * and taxonomy-based defaults (ADR-0007).\n */\n\nexport const VERSION = '1.0.0';\n\n// Core registry and singleton\nexport { MetricsRegistry } from './registry.js';\n\nimport { MetricsRegistry } from './registry.js';\n\n/**\n * Default singleton metrics registry\n *\n * Use this for application-wide metrics collection.\n *\n * @example\n * ```typescript\n * import { metrics } from '@fulmenhq/tsfulmen/telemetry';\n *\n * // Increment counter\n * metrics.counter('schema_validations').inc();\n *\n * // Record histogram observation\n * metrics.histogram('config_load_ms').observe(42.5);\n *\n * // Export all metrics\n * const events = await metrics.export();\n * ```\n */\nexport const metrics = new MetricsRegistry();\n\n// Metric types\nexport { Counter } from './counter.js';\nexport { Gauge } from './gauge.js';\nexport { Histogram } from './histogram.js';\n// Taxonomy\nexport type { MetricDefinition, MetricsTaxonomy } from './taxonomy.js';\nexport {\n DEFAULT_MS_BUCKETS,\n getDefaultBuckets,\n getDefaultUnit,\n getMetric,\n getTaxonomy,\n isValidMetricName as isValidMetricNameTaxonomy,\n} from './taxonomy.js';\n// Types\nexport type {\n FlushOptions,\n HistogramBucket,\n HistogramOptions,\n HistogramSummary,\n MetricName,\n MetricsEvent,\n MetricUnit,\n MetricValue,\n} from './types.js';\nexport {\n isHistogramSummary,\n isValidMetricName,\n isValidMetricUnit,\n} from './types.js';\n\n// Validators\nexport {\n assertValidMetricsEvent,\n formatValidationErrors,\n getValidationErrors,\n validateMetricsEvent,\n validateMetricsEvents,\n} from './validators.js';\n"]}