@stevenvo780/st-lang 4.7.0 → 4.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (285) hide show
  1. package/dist/logic/profiles/quantum/index.d.ts +153 -0
  2. package/dist/logic/profiles/quantum/index.d.ts.map +1 -0
  3. package/dist/logic/profiles/quantum/index.js +788 -0
  4. package/dist/logic/profiles/quantum/index.js.map +1 -0
  5. package/dist/namespaces/reasoning.d.ts +3 -1
  6. package/dist/namespaces/reasoning.d.ts.map +1 -1
  7. package/dist/namespaces/reasoning.js +5 -1
  8. package/dist/namespaces/reasoning.js.map +1 -1
  9. package/dist/proof-systems/certificate/canonical.d.ts +18 -0
  10. package/dist/proof-systems/certificate/canonical.d.ts.map +1 -0
  11. package/dist/proof-systems/certificate/canonical.js +79 -0
  12. package/dist/proof-systems/certificate/canonical.js.map +1 -0
  13. package/dist/proof-systems/certificate/generate.d.ts +39 -0
  14. package/dist/proof-systems/certificate/generate.d.ts.map +1 -0
  15. package/dist/proof-systems/certificate/generate.js +259 -0
  16. package/dist/proof-systems/certificate/generate.js.map +1 -0
  17. package/dist/proof-systems/certificate/index.d.ts +7 -0
  18. package/dist/proof-systems/certificate/index.d.ts.map +1 -0
  19. package/dist/proof-systems/certificate/index.js +23 -0
  20. package/dist/proof-systems/certificate/index.js.map +1 -0
  21. package/dist/proof-systems/certificate/lfsc.d.ts +15 -0
  22. package/dist/proof-systems/certificate/lfsc.d.ts.map +1 -0
  23. package/dist/proof-systems/certificate/lfsc.js +395 -0
  24. package/dist/proof-systems/certificate/lfsc.js.map +1 -0
  25. package/dist/proof-systems/certificate/rules.d.ts +8 -0
  26. package/dist/proof-systems/certificate/rules.d.ts.map +1 -0
  27. package/dist/proof-systems/certificate/rules.js +369 -0
  28. package/dist/proof-systems/certificate/rules.js.map +1 -0
  29. package/dist/proof-systems/certificate/types.d.ts +114 -0
  30. package/dist/proof-systems/certificate/types.d.ts.map +1 -0
  31. package/dist/proof-systems/certificate/types.js +18 -0
  32. package/dist/proof-systems/certificate/types.js.map +1 -0
  33. package/dist/proof-systems/certificate/verify.d.ts +20 -0
  34. package/dist/proof-systems/certificate/verify.d.ts.map +1 -0
  35. package/dist/proof-systems/certificate/verify.js +171 -0
  36. package/dist/proof-systems/certificate/verify.js.map +1 -0
  37. package/dist/reasoning/ban-logic/analyze.d.ts +31 -0
  38. package/dist/reasoning/ban-logic/analyze.d.ts.map +1 -0
  39. package/dist/reasoning/ban-logic/analyze.js +113 -0
  40. package/dist/reasoning/ban-logic/analyze.js.map +1 -0
  41. package/dist/reasoning/ban-logic/index.d.ts +7 -0
  42. package/dist/reasoning/ban-logic/index.d.ts.map +1 -0
  43. package/dist/reasoning/ban-logic/index.js +66 -0
  44. package/dist/reasoning/ban-logic/index.js.map +1 -0
  45. package/dist/reasoning/ban-logic/protocols.d.ts +54 -0
  46. package/dist/reasoning/ban-logic/protocols.d.ts.map +1 -0
  47. package/dist/reasoning/ban-logic/protocols.js +219 -0
  48. package/dist/reasoning/ban-logic/protocols.js.map +1 -0
  49. package/dist/reasoning/ban-logic/rules.d.ts +83 -0
  50. package/dist/reasoning/ban-logic/rules.d.ts.map +1 -0
  51. package/dist/reasoning/ban-logic/rules.js +409 -0
  52. package/dist/reasoning/ban-logic/rules.js.map +1 -0
  53. package/dist/reasoning/ban-logic/terms.d.ts +26 -0
  54. package/dist/reasoning/ban-logic/terms.d.ts.map +1 -0
  55. package/dist/reasoning/ban-logic/terms.js +262 -0
  56. package/dist/reasoning/ban-logic/terms.js.map +1 -0
  57. package/dist/reasoning/ban-logic/types.d.ts +107 -0
  58. package/dist/reasoning/ban-logic/types.d.ts.map +1 -0
  59. package/dist/reasoning/ban-logic/types.js +27 -0
  60. package/dist/reasoning/ban-logic/types.js.map +1 -0
  61. package/dist/reasoning/combinatorial-games/index.d.ts +105 -0
  62. package/dist/reasoning/combinatorial-games/index.d.ts.map +1 -0
  63. package/dist/reasoning/combinatorial-games/index.js +377 -0
  64. package/dist/reasoning/combinatorial-games/index.js.map +1 -0
  65. package/dist/reasoning/differential-privacy/index.d.ts +121 -0
  66. package/dist/reasoning/differential-privacy/index.d.ts.map +1 -0
  67. package/dist/reasoning/differential-privacy/index.js +417 -0
  68. package/dist/reasoning/differential-privacy/index.js.map +1 -0
  69. package/dist/reasoning/mechanism-design/auctions.d.ts +49 -0
  70. package/dist/reasoning/mechanism-design/auctions.d.ts.map +1 -0
  71. package/dist/reasoning/mechanism-design/auctions.js +179 -0
  72. package/dist/reasoning/mechanism-design/auctions.js.map +1 -0
  73. package/dist/reasoning/mechanism-design/index.d.ts +5 -0
  74. package/dist/reasoning/mechanism-design/index.d.ts.map +1 -0
  75. package/dist/reasoning/mechanism-design/index.js +39 -0
  76. package/dist/reasoning/mechanism-design/index.js.map +1 -0
  77. package/dist/reasoning/mechanism-design/myerson.d.ts +64 -0
  78. package/dist/reasoning/mechanism-design/myerson.d.ts.map +1 -0
  79. package/dist/reasoning/mechanism-design/myerson.js +253 -0
  80. package/dist/reasoning/mechanism-design/myerson.js.map +1 -0
  81. package/dist/reasoning/mechanism-design/types.d.ts +44 -0
  82. package/dist/reasoning/mechanism-design/types.d.ts.map +1 -0
  83. package/dist/reasoning/mechanism-design/types.js +22 -0
  84. package/dist/reasoning/mechanism-design/types.js.map +1 -0
  85. package/dist/reasoning/mechanism-design/vcg.d.ts +29 -0
  86. package/dist/reasoning/mechanism-design/vcg.d.ts.map +1 -0
  87. package/dist/reasoning/mechanism-design/vcg.js +305 -0
  88. package/dist/reasoning/mechanism-design/vcg.js.map +1 -0
  89. package/dist/reasoning/probabilistic/distributions.d.ts +44 -0
  90. package/dist/reasoning/probabilistic/distributions.d.ts.map +1 -0
  91. package/dist/reasoning/probabilistic/distributions.js +207 -0
  92. package/dist/reasoning/probabilistic/distributions.js.map +1 -0
  93. package/dist/reasoning/probabilistic/examples.d.ts +31 -0
  94. package/dist/reasoning/probabilistic/examples.d.ts.map +1 -0
  95. package/dist/reasoning/probabilistic/examples.js +85 -0
  96. package/dist/reasoning/probabilistic/examples.js.map +1 -0
  97. package/dist/reasoning/probabilistic/index.d.ts +6 -0
  98. package/dist/reasoning/probabilistic/index.d.ts.map +1 -0
  99. package/dist/reasoning/probabilistic/index.js +42 -0
  100. package/dist/reasoning/probabilistic/index.js.map +1 -0
  101. package/dist/reasoning/probabilistic/inference.d.ts +45 -0
  102. package/dist/reasoning/probabilistic/inference.d.ts.map +1 -0
  103. package/dist/reasoning/probabilistic/inference.js +579 -0
  104. package/dist/reasoning/probabilistic/inference.js.map +1 -0
  105. package/dist/reasoning/probabilistic/types.d.ts +153 -0
  106. package/dist/reasoning/probabilistic/types.d.ts.map +1 -0
  107. package/dist/reasoning/probabilistic/types.js +37 -0
  108. package/dist/reasoning/probabilistic/types.js.map +1 -0
  109. package/dist/solver/smt-z3/index.d.ts +3 -0
  110. package/dist/solver/smt-z3/index.d.ts.map +1 -0
  111. package/dist/solver/smt-z3/index.js +11 -0
  112. package/dist/solver/smt-z3/index.js.map +1 -0
  113. package/dist/solver/smt-z3/types.d.ts +52 -0
  114. package/dist/solver/smt-z3/types.d.ts.map +1 -0
  115. package/dist/solver/smt-z3/types.js +6 -0
  116. package/dist/solver/smt-z3/types.js.map +1 -0
  117. package/dist/solver/smt-z3/z3-wasm-backend.d.ts +88 -0
  118. package/dist/solver/smt-z3/z3-wasm-backend.d.ts.map +1 -0
  119. package/dist/solver/smt-z3/z3-wasm-backend.js +437 -0
  120. package/dist/solver/smt-z3/z3-wasm-backend.js.map +1 -0
  121. package/dist/tests/logic/profiles/quantum/quantum.test.d.ts +2 -0
  122. package/dist/tests/logic/profiles/quantum/quantum.test.d.ts.map +1 -0
  123. package/dist/tests/logic/profiles/quantum/quantum.test.js +209 -0
  124. package/dist/tests/logic/profiles/quantum/quantum.test.js.map +1 -0
  125. package/dist/tests/proof-systems/certificate/certificate.test.d.ts +2 -0
  126. package/dist/tests/proof-systems/certificate/certificate.test.d.ts.map +1 -0
  127. package/dist/tests/proof-systems/certificate/certificate.test.js +449 -0
  128. package/dist/tests/proof-systems/certificate/certificate.test.js.map +1 -0
  129. package/dist/tests/reasoning/ban-logic/ban-logic.test.d.ts +2 -0
  130. package/dist/tests/reasoning/ban-logic/ban-logic.test.d.ts.map +1 -0
  131. package/dist/tests/reasoning/ban-logic/ban-logic.test.js +270 -0
  132. package/dist/tests/reasoning/ban-logic/ban-logic.test.js.map +1 -0
  133. package/dist/tests/reasoning/combinatorial-games/combinatorial-games.test.d.ts +2 -0
  134. package/dist/tests/reasoning/combinatorial-games/combinatorial-games.test.d.ts.map +1 -0
  135. package/dist/tests/reasoning/combinatorial-games/combinatorial-games.test.js +203 -0
  136. package/dist/tests/reasoning/combinatorial-games/combinatorial-games.test.js.map +1 -0
  137. package/dist/tests/reasoning/differential-privacy/differential-privacy.test.d.ts +2 -0
  138. package/dist/tests/reasoning/differential-privacy/differential-privacy.test.d.ts.map +1 -0
  139. package/dist/tests/reasoning/differential-privacy/differential-privacy.test.js +388 -0
  140. package/dist/tests/reasoning/differential-privacy/differential-privacy.test.js.map +1 -0
  141. package/dist/tests/reasoning/mechanism-design/mechanism-design.test.d.ts +2 -0
  142. package/dist/tests/reasoning/mechanism-design/mechanism-design.test.d.ts.map +1 -0
  143. package/dist/tests/reasoning/mechanism-design/mechanism-design.test.js +290 -0
  144. package/dist/tests/reasoning/mechanism-design/mechanism-design.test.js.map +1 -0
  145. package/dist/tests/reasoning/probabilistic/probabilistic.test.d.ts +2 -0
  146. package/dist/tests/reasoning/probabilistic/probabilistic.test.d.ts.map +1 -0
  147. package/dist/tests/reasoning/probabilistic/probabilistic.test.js +370 -0
  148. package/dist/tests/reasoning/probabilistic/probabilistic.test.js.map +1 -0
  149. package/dist/tests/solver/smt-z3/z3-wasm-backend.test.d.ts +2 -0
  150. package/dist/tests/solver/smt-z3/z3-wasm-backend.test.d.ts.map +1 -0
  151. package/dist/tests/solver/smt-z3/z3-wasm-backend.test.js +394 -0
  152. package/dist/tests/solver/smt-z3/z3-wasm-backend.test.js.map +1 -0
  153. package/dist/tests/tooling/mathlib/mathlib.test.d.ts +2 -0
  154. package/dist/tests/tooling/mathlib/mathlib.test.d.ts.map +1 -0
  155. package/dist/tests/tooling/mathlib/mathlib.test.js +214 -0
  156. package/dist/tests/tooling/mathlib/mathlib.test.js.map +1 -0
  157. package/dist/tests/tooling/proof-guidance/features.test.d.ts +2 -0
  158. package/dist/tests/tooling/proof-guidance/features.test.d.ts.map +1 -0
  159. package/dist/tests/tooling/proof-guidance/features.test.js +72 -0
  160. package/dist/tests/tooling/proof-guidance/features.test.js.map +1 -0
  161. package/dist/tests/tooling/proof-guidance/model.test.d.ts +2 -0
  162. package/dist/tests/tooling/proof-guidance/model.test.d.ts.map +1 -0
  163. package/dist/tests/tooling/proof-guidance/model.test.js +165 -0
  164. package/dist/tests/tooling/proof-guidance/model.test.js.map +1 -0
  165. package/dist/tests/tooling/proof-guidance/search.test.d.ts +2 -0
  166. package/dist/tests/tooling/proof-guidance/search.test.d.ts.map +1 -0
  167. package/dist/tests/tooling/proof-guidance/search.test.js +238 -0
  168. package/dist/tests/tooling/proof-guidance/search.test.js.map +1 -0
  169. package/dist/tests/type-theory/cubical/cubical.test.d.ts +2 -0
  170. package/dist/tests/type-theory/cubical/cubical.test.d.ts.map +1 -0
  171. package/dist/tests/type-theory/cubical/cubical.test.js +207 -0
  172. package/dist/tests/type-theory/cubical/cubical.test.js.map +1 -0
  173. package/dist/tests/type-theory/effects/effects.test.d.ts +2 -0
  174. package/dist/tests/type-theory/effects/effects.test.d.ts.map +1 -0
  175. package/dist/tests/type-theory/effects/effects.test.js +242 -0
  176. package/dist/tests/type-theory/effects/effects.test.js.map +1 -0
  177. package/dist/tooling/mathlib/group.d.ts +27 -0
  178. package/dist/tooling/mathlib/group.d.ts.map +1 -0
  179. package/dist/tooling/mathlib/group.js +89 -0
  180. package/dist/tooling/mathlib/group.js.map +1 -0
  181. package/dist/tooling/mathlib/index.d.ts +8 -0
  182. package/dist/tooling/mathlib/index.d.ts.map +1 -0
  183. package/dist/tooling/mathlib/index.js +40 -0
  184. package/dist/tooling/mathlib/index.js.map +1 -0
  185. package/dist/tooling/mathlib/instances.d.ts +29 -0
  186. package/dist/tooling/mathlib/instances.d.ts.map +1 -0
  187. package/dist/tooling/mathlib/instances.js +139 -0
  188. package/dist/tooling/mathlib/instances.js.map +1 -0
  189. package/dist/tooling/mathlib/lemmas.d.ts +3 -0
  190. package/dist/tooling/mathlib/lemmas.d.ts.map +1 -0
  191. package/dist/tooling/mathlib/lemmas.js +72 -0
  192. package/dist/tooling/mathlib/lemmas.js.map +1 -0
  193. package/dist/tooling/mathlib/order.d.ts +29 -0
  194. package/dist/tooling/mathlib/order.d.ts.map +1 -0
  195. package/dist/tooling/mathlib/order.js +91 -0
  196. package/dist/tooling/mathlib/order.js.map +1 -0
  197. package/dist/tooling/mathlib/ring.d.ts +15 -0
  198. package/dist/tooling/mathlib/ring.d.ts.map +1 -0
  199. package/dist/tooling/mathlib/ring.js +91 -0
  200. package/dist/tooling/mathlib/ring.js.map +1 -0
  201. package/dist/tooling/mathlib/types.d.ts +62 -0
  202. package/dist/tooling/mathlib/types.d.ts.map +1 -0
  203. package/dist/tooling/mathlib/types.js +7 -0
  204. package/dist/tooling/mathlib/types.js.map +1 -0
  205. package/dist/tooling/proof-guidance/features.d.ts +10 -0
  206. package/dist/tooling/proof-guidance/features.d.ts.map +1 -0
  207. package/dist/tooling/proof-guidance/features.js +97 -0
  208. package/dist/tooling/proof-guidance/features.js.map +1 -0
  209. package/dist/tooling/proof-guidance/index.d.ts +5 -0
  210. package/dist/tooling/proof-guidance/index.d.ts.map +1 -0
  211. package/dist/tooling/proof-guidance/index.js +25 -0
  212. package/dist/tooling/proof-guidance/index.js.map +1 -0
  213. package/dist/tooling/proof-guidance/model.d.ts +42 -0
  214. package/dist/tooling/proof-guidance/model.d.ts.map +1 -0
  215. package/dist/tooling/proof-guidance/model.js +149 -0
  216. package/dist/tooling/proof-guidance/model.js.map +1 -0
  217. package/dist/tooling/proof-guidance/search.d.ts +7 -0
  218. package/dist/tooling/proof-guidance/search.d.ts.map +1 -0
  219. package/dist/tooling/proof-guidance/search.js +102 -0
  220. package/dist/tooling/proof-guidance/search.js.map +1 -0
  221. package/dist/tooling/proof-guidance/types.d.ts +77 -0
  222. package/dist/tooling/proof-guidance/types.d.ts.map +1 -0
  223. package/dist/tooling/proof-guidance/types.js +8 -0
  224. package/dist/tooling/proof-guidance/types.js.map +1 -0
  225. package/dist/type-theory/cubical/equality.d.ts +4 -0
  226. package/dist/type-theory/cubical/equality.d.ts.map +1 -0
  227. package/dist/type-theory/cubical/equality.js +78 -0
  228. package/dist/type-theory/cubical/equality.js.map +1 -0
  229. package/dist/type-theory/cubical/index.d.ts +14 -0
  230. package/dist/type-theory/cubical/index.d.ts.map +1 -0
  231. package/dist/type-theory/cubical/index.js +71 -0
  232. package/dist/type-theory/cubical/index.js.map +1 -0
  233. package/dist/type-theory/cubical/infer.d.ts +18 -0
  234. package/dist/type-theory/cubical/infer.d.ts.map +1 -0
  235. package/dist/type-theory/cubical/infer.js +241 -0
  236. package/dist/type-theory/cubical/infer.js.map +1 -0
  237. package/dist/type-theory/cubical/interval.d.ts +12 -0
  238. package/dist/type-theory/cubical/interval.d.ts.map +1 -0
  239. package/dist/type-theory/cubical/interval.js +118 -0
  240. package/dist/type-theory/cubical/interval.js.map +1 -0
  241. package/dist/type-theory/cubical/normalize.d.ts +5 -0
  242. package/dist/type-theory/cubical/normalize.d.ts.map +1 -0
  243. package/dist/type-theory/cubical/normalize.js +191 -0
  244. package/dist/type-theory/cubical/normalize.js.map +1 -0
  245. package/dist/type-theory/cubical/path-algebra.d.ts +12 -0
  246. package/dist/type-theory/cubical/path-algebra.d.ts.map +1 -0
  247. package/dist/type-theory/cubical/path-algebra.js +109 -0
  248. package/dist/type-theory/cubical/path-algebra.js.map +1 -0
  249. package/dist/type-theory/cubical/substitute.d.ts +3 -0
  250. package/dist/type-theory/cubical/substitute.d.ts.map +1 -0
  251. package/dist/type-theory/cubical/substitute.js +109 -0
  252. package/dist/type-theory/cubical/substitute.js.map +1 -0
  253. package/dist/type-theory/cubical/types.d.ts +77 -0
  254. package/dist/type-theory/cubical/types.d.ts.map +1 -0
  255. package/dist/type-theory/cubical/types.js +258 -0
  256. package/dist/type-theory/cubical/types.js.map +1 -0
  257. package/dist/type-theory/effects/core.d.ts +27 -0
  258. package/dist/type-theory/effects/core.d.ts.map +1 -0
  259. package/dist/type-theory/effects/core.js +79 -0
  260. package/dist/type-theory/effects/core.js.map +1 -0
  261. package/dist/type-theory/effects/exception.d.ts +18 -0
  262. package/dist/type-theory/effects/exception.d.ts.map +1 -0
  263. package/dist/type-theory/effects/exception.js +59 -0
  264. package/dist/type-theory/effects/exception.js.map +1 -0
  265. package/dist/type-theory/effects/index.d.ts +11 -0
  266. package/dist/type-theory/effects/index.d.ts.map +1 -0
  267. package/dist/type-theory/effects/index.js +50 -0
  268. package/dist/type-theory/effects/index.js.map +1 -0
  269. package/dist/type-theory/effects/reader.d.ts +20 -0
  270. package/dist/type-theory/effects/reader.d.ts.map +1 -0
  271. package/dist/type-theory/effects/reader.js +62 -0
  272. package/dist/type-theory/effects/reader.js.map +1 -0
  273. package/dist/type-theory/effects/state.d.ts +31 -0
  274. package/dist/type-theory/effects/state.d.ts.map +1 -0
  275. package/dist/type-theory/effects/state.js +91 -0
  276. package/dist/type-theory/effects/state.js.map +1 -0
  277. package/dist/type-theory/effects/types.d.ts +45 -0
  278. package/dist/type-theory/effects/types.d.ts.map +1 -0
  279. package/dist/type-theory/effects/types.js +21 -0
  280. package/dist/type-theory/effects/types.js.map +1 -0
  281. package/dist/type-theory/effects/writer.d.ts +30 -0
  282. package/dist/type-theory/effects/writer.d.ts.map +1 -0
  283. package/dist/type-theory/effects/writer.js +79 -0
  284. package/dist/type-theory/effects/writer.js.map +1 -0
  285. package/package.json +1 -1
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // Cubical — Álgebra de caminos sobre el intervalo
4
+ // ============================================================
5
+ //
6
+ // Operaciones de alto nivel para construir caminos cúbicos sin tocar
7
+ // el AST manualmente. Las identidades estándar:
8
+ //
9
+ // reflPath x ≡ λi. x
10
+ // pathInverse p ≡ λi. p @ (~ i)
11
+ // pathCompose p q : composición vía hcomp (aquí: encadenamiento
12
+ // sintáctico — primer paso pedagógico).
13
+ //
14
+ // `glue` se importa de types pero lo re-exportamos como función de
15
+ // alto nivel firmada igual que en la misión.
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.reflPath = reflPath;
18
+ exports.pathInverse = pathInverse;
19
+ exports.pathCompose = pathCompose;
20
+ exports.glue = glue;
21
+ const types_1 = require("./types");
22
+ function reflPath(x) {
23
+ // λi. x (i no ocurre en x, así colapsa a una refl interválica)
24
+ return (0, types_1.cPLam)('i', x);
25
+ }
26
+ function pathInverse(p) {
27
+ // Optimización: inverso de refl es refl
28
+ if (p.kind === 'pLam' && !occurs('i', p.body)) {
29
+ return p;
30
+ }
31
+ // λi. p @ (~ i)
32
+ return (0, types_1.cPLam)('i', (0, types_1.cPApp)(p, (0, types_1.cINeg)((0, types_1.cIVar)('i'))));
33
+ }
34
+ function pathCompose(p, q) {
35
+ // Identidad izquierda/derecha sintáctica con reflPath: si p ≡ refl x,
36
+ // devolvemos q; si q ≡ refl, devolvemos p. Esto NO es la composición
37
+ // homotópica completa (que requiere hcomp), pero respeta las
38
+ // ecuaciones esperadas en los casos canónicos pedagógicos.
39
+ if (isReflLike(p))
40
+ return q;
41
+ if (isReflLike(q))
42
+ return p;
43
+ // Forma genérica: λi. encadenado (p @ i a la izquierda; q @ i a la derecha
44
+ // del intervalo dividido). Para mantener la igualdad sintáctica con la
45
+ // composición real cuando los extremos coinciden, devolvemos:
46
+ // λi. p @ i cuando q ≡ refl (ya cubierto)
47
+ // λi. q @ i cuando p ≡ refl (ya cubierto)
48
+ // El caso default es una marca composicional.
49
+ return (0, types_1.cPLam)('i', {
50
+ kind: 'pApp',
51
+ path: { kind: 'pLam', bind: 'j', body: (0, types_1.cPApp)(p, (0, types_1.cIVar)('j')) },
52
+ arg: (0, types_1.cIVar)('i'),
53
+ });
54
+ }
55
+ /**
56
+ * Glue: convierte una equivalencia A ≃ B (codificada como par Σ con
57
+ * dominio y codominio) en un Path en el universo. Es el precursor
58
+ * sintáctico de la computación de ua en CTT — aquí no implementamos
59
+ * la regla de cómputo full, sólo la introducción del término.
60
+ */
61
+ function glue(equiv, partial) {
62
+ return (0, types_1.cGlue)(equiv, partial);
63
+ }
64
+ // ── Helpers internos ─────────────────────────────────────────
65
+ function occurs(name, t) {
66
+ switch (t.kind) {
67
+ case 'i0':
68
+ case 'i1':
69
+ case 'universe':
70
+ return false;
71
+ case 'var':
72
+ case 'iVar':
73
+ return t.name === name;
74
+ case 'iNeg':
75
+ return occurs(name, t.arg);
76
+ case 'iMin':
77
+ case 'iMax':
78
+ return occurs(name, t.left) || occurs(name, t.right);
79
+ case 'pathP':
80
+ return occurs(name, t.family) || occurs(name, t.left) || occurs(name, t.right);
81
+ case 'pLam':
82
+ if (t.bind === name)
83
+ return false;
84
+ return occurs(name, t.body);
85
+ case 'pApp':
86
+ return occurs(name, t.path) || occurs(name, t.arg);
87
+ case 'glue':
88
+ return occurs(name, t.equiv) || occurs(name, t.partial);
89
+ case 'pi':
90
+ if (occurs(name, t.domain))
91
+ return true;
92
+ if (t.bind === name)
93
+ return false;
94
+ return occurs(name, t.codomain);
95
+ case 'lam':
96
+ if (occurs(name, t.domain))
97
+ return true;
98
+ if (t.bind === name)
99
+ return false;
100
+ return occurs(name, t.body);
101
+ case 'app':
102
+ return occurs(name, t.fn) || occurs(name, t.arg);
103
+ }
104
+ }
105
+ function isReflLike(p) {
106
+ // refl = pLam i. x con i no libre en x.
107
+ return p.kind === 'pLam' && !occurs(p.bind, p.body);
108
+ }
109
+ //# sourceMappingURL=path-algebra.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"path-algebra.js","sourceRoot":"","sources":["../../../src/type-theory/cubical/path-algebra.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { CubicalTerm } from './types';
2
+ export declare function substituteCubical(term: CubicalTerm, name: string, value: CubicalTerm): CubicalTerm;
3
+ //# sourceMappingURL=substitute.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"substitute.d.ts","sourceRoot":"","sources":["../../../src/type-theory/cubical/substitute.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAW3C,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,WAAW,EACjB,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,WAAW,GACjB,WAAW,CA0Eb"}
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // Cubical — Sustitución capture-avoiding
4
+ // ============================================================
5
+ //
6
+ // Las variables de término y las variables de intervalo viven en
7
+ // el mismo espacio sintáctico (ambas son nombres). Sustituimos
8
+ // uniformemente; el sustituidor decide por la posición sintáctica
9
+ // (var vs iVar) si reemplaza o no.
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ exports.substituteCubical = substituteCubical;
12
+ const types_1 = require("./types");
13
+ let freshCounter = 0;
14
+ function fresh(base, avoid) {
15
+ let candidate = `${base}#c${freshCounter++}`;
16
+ while (avoid.has(candidate))
17
+ candidate = `${base}#c${freshCounter++}`;
18
+ return candidate;
19
+ }
20
+ function substituteCubical(term, name, value) {
21
+ switch (term.kind) {
22
+ case 'i0':
23
+ case 'i1':
24
+ case 'universe':
25
+ return term;
26
+ case 'var':
27
+ return term.name === name ? value : term;
28
+ case 'iVar':
29
+ return term.name === name ? value : term;
30
+ case 'iMin':
31
+ return {
32
+ kind: 'iMin',
33
+ left: substituteCubical(term.left, name, value),
34
+ right: substituteCubical(term.right, name, value),
35
+ };
36
+ case 'iMax':
37
+ return {
38
+ kind: 'iMax',
39
+ left: substituteCubical(term.left, name, value),
40
+ right: substituteCubical(term.right, name, value),
41
+ };
42
+ case 'iNeg':
43
+ return { kind: 'iNeg', arg: substituteCubical(term.arg, name, value) };
44
+ case 'pathP':
45
+ return {
46
+ kind: 'pathP',
47
+ family: substituteCubical(term.family, name, value),
48
+ left: substituteCubical(term.left, name, value),
49
+ right: substituteCubical(term.right, name, value),
50
+ };
51
+ case 'pLam': {
52
+ if (term.bind === name)
53
+ return term;
54
+ const fv = (0, types_1.freeVarsCubical)(value);
55
+ if (fv.has(term.bind)) {
56
+ const newBind = fresh(term.bind, new Set([...fv, ...(0, types_1.freeVarsCubical)(term.body), name]));
57
+ const renamed = substituteCubical(term.body, term.bind, { kind: 'iVar', name: newBind });
58
+ return { kind: 'pLam', bind: newBind, body: substituteCubical(renamed, name, value) };
59
+ }
60
+ return { kind: 'pLam', bind: term.bind, body: substituteCubical(term.body, name, value) };
61
+ }
62
+ case 'pApp':
63
+ return {
64
+ kind: 'pApp',
65
+ path: substituteCubical(term.path, name, value),
66
+ arg: substituteCubical(term.arg, name, value),
67
+ };
68
+ case 'glue':
69
+ return {
70
+ kind: 'glue',
71
+ equiv: substituteCubical(term.equiv, name, value),
72
+ partial: substituteCubical(term.partial, name, value),
73
+ };
74
+ case 'pi':
75
+ return substBinder(term, name, value, term.domain, term.codomain, (bind, dom, cod) => ({
76
+ kind: 'pi',
77
+ bind,
78
+ domain: dom,
79
+ codomain: cod,
80
+ }));
81
+ case 'lam':
82
+ return substBinder(term, name, value, term.domain, term.body, (bind, dom, body) => ({
83
+ kind: 'lam',
84
+ bind,
85
+ domain: dom,
86
+ body,
87
+ }));
88
+ case 'app':
89
+ return {
90
+ kind: 'app',
91
+ fn: substituteCubical(term.fn, name, value),
92
+ arg: substituteCubical(term.arg, name, value),
93
+ };
94
+ }
95
+ }
96
+ function substBinder(source, name, value, dom, cod, build) {
97
+ const newDom = substituteCubical(dom, name, value);
98
+ if (source.bind === name) {
99
+ return build(source.bind, newDom, cod);
100
+ }
101
+ const fv = (0, types_1.freeVarsCubical)(value);
102
+ if (fv.has(source.bind)) {
103
+ const newBind = fresh(source.bind, new Set([...fv, ...(0, types_1.freeVarsCubical)(cod), name]));
104
+ const renamedCod = substituteCubical(cod, source.bind, { kind: 'var', name: newBind });
105
+ return build(newBind, newDom, substituteCubical(renamedCod, name, value));
106
+ }
107
+ return build(source.bind, newDom, substituteCubical(cod, name, value));
108
+ }
109
+ //# sourceMappingURL=substitute.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"substitute.js","sourceRoot":"","sources":["../../../src/type-theory/cubical/substitute.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,77 @@
1
+ export type CubicalTerm = {
2
+ kind: 'i0';
3
+ } | {
4
+ kind: 'i1';
5
+ } | {
6
+ kind: 'iVar';
7
+ name: string;
8
+ } | {
9
+ kind: 'iMin';
10
+ left: CubicalTerm;
11
+ right: CubicalTerm;
12
+ } | {
13
+ kind: 'iMax';
14
+ left: CubicalTerm;
15
+ right: CubicalTerm;
16
+ } | {
17
+ kind: 'iNeg';
18
+ arg: CubicalTerm;
19
+ } | {
20
+ kind: 'pathP';
21
+ family: CubicalTerm;
22
+ left: CubicalTerm;
23
+ right: CubicalTerm;
24
+ } | {
25
+ kind: 'pLam';
26
+ bind: string;
27
+ body: CubicalTerm;
28
+ } | {
29
+ kind: 'pApp';
30
+ path: CubicalTerm;
31
+ arg: CubicalTerm;
32
+ } | {
33
+ kind: 'glue';
34
+ equiv: CubicalTerm;
35
+ partial: CubicalTerm;
36
+ } | {
37
+ kind: 'var';
38
+ name: string;
39
+ } | {
40
+ kind: 'universe';
41
+ level: number;
42
+ } | {
43
+ kind: 'pi';
44
+ bind: string;
45
+ domain: CubicalTerm;
46
+ codomain: CubicalTerm;
47
+ } | {
48
+ kind: 'lam';
49
+ bind: string;
50
+ domain: CubicalTerm;
51
+ body: CubicalTerm;
52
+ } | {
53
+ kind: 'app';
54
+ fn: CubicalTerm;
55
+ arg: CubicalTerm;
56
+ };
57
+ export declare const cI0: () => CubicalTerm;
58
+ export declare const cI1: () => CubicalTerm;
59
+ export declare const cIVar: (name: string) => CubicalTerm;
60
+ export declare const cIMin: (left: CubicalTerm, right: CubicalTerm) => CubicalTerm;
61
+ export declare const cIMax: (left: CubicalTerm, right: CubicalTerm) => CubicalTerm;
62
+ export declare const cINeg: (arg: CubicalTerm) => CubicalTerm;
63
+ export declare const cPathP: (family: CubicalTerm, left: CubicalTerm, right: CubicalTerm) => CubicalTerm;
64
+ export declare const cPLam: (bind: string, body: CubicalTerm) => CubicalTerm;
65
+ export declare const cPApp: (path: CubicalTerm, arg: CubicalTerm) => CubicalTerm;
66
+ export declare const cGlue: (equiv: CubicalTerm, partial: CubicalTerm) => CubicalTerm;
67
+ export declare const cVar: (name: string) => CubicalTerm;
68
+ export declare const cUniverse: (level?: number) => CubicalTerm;
69
+ export declare const cPi: (bind: string, domain: CubicalTerm, codomain: CubicalTerm) => CubicalTerm;
70
+ export declare const cLam: (bind: string, domain: CubicalTerm, body: CubicalTerm) => CubicalTerm;
71
+ export declare const cApp: (fn: CubicalTerm, arg: CubicalTerm) => CubicalTerm;
72
+ export declare const cArrow: (from: CubicalTerm, to: CubicalTerm) => CubicalTerm;
73
+ export declare function isIntervalExpr(t: CubicalTerm): boolean;
74
+ export declare function occursFreeCubical(name: string, term: CubicalTerm): boolean;
75
+ export declare function freeVarsCubical(term: CubicalTerm, acc?: Set<string>): Set<string>;
76
+ export declare function termToStringCubical(t: CubicalTerm): string;
77
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/type-theory/cubical/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,258 @@
1
+ "use strict";
2
+ // ============================================================
3
+ // Cubical Type Theory (CTT-Lite) — términos y constructores
4
+ // ============================================================
5
+ //
6
+ // Subset pedagógico de Cubical Type Theory. La diferencia esencial
7
+ // con HoTT (homotopy type theory) es que aquí univalence pasa a ser
8
+ // COMPUTACIONAL via:
9
+ //
10
+ // - Un intervalo formal I con dos extremos i0, i1 y conexiones
11
+ // (∧ min, ∨ max) más involutiva (1 - i).
12
+ // - PathP A x y = caminos con familia dependiente sobre I.
13
+ // - Path-abstracción y aplicación (λi. t) @ i con reducción por
14
+ // sustitución de la variable de intervalo.
15
+ // - Glue como precursor sintáctico de transport sobre ua.
16
+ //
17
+ // Re-empaquetamos las construcciones MLTT mínimas que el subset
18
+ // necesita (Π, λ, app, var, universo). Para evitar conflictos de
19
+ // tipos con HoTT, este módulo es autocontenido: CubicalTerm vive en
20
+ // su propio universo de tipos.
21
+ //
22
+ // API mínima compatible con MLTT/HoTT:
23
+ // inferType / normalize / isIntervalExpr / evalInterval
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.cArrow = exports.cApp = exports.cLam = exports.cPi = exports.cUniverse = exports.cVar = exports.cGlue = exports.cPApp = exports.cPLam = exports.cPathP = exports.cINeg = exports.cIMax = exports.cIMin = exports.cIVar = exports.cI1 = exports.cI0 = void 0;
26
+ exports.isIntervalExpr = isIntervalExpr;
27
+ exports.occursFreeCubical = occursFreeCubical;
28
+ exports.freeVarsCubical = freeVarsCubical;
29
+ exports.termToStringCubical = termToStringCubical;
30
+ // ── Constructores convenientes ──────────────────────────────
31
+ const cI0 = () => ({ kind: 'i0' });
32
+ exports.cI0 = cI0;
33
+ const cI1 = () => ({ kind: 'i1' });
34
+ exports.cI1 = cI1;
35
+ const cIVar = (name) => ({ kind: 'iVar', name });
36
+ exports.cIVar = cIVar;
37
+ const cIMin = (left, right) => ({
38
+ kind: 'iMin',
39
+ left,
40
+ right,
41
+ });
42
+ exports.cIMin = cIMin;
43
+ const cIMax = (left, right) => ({
44
+ kind: 'iMax',
45
+ left,
46
+ right,
47
+ });
48
+ exports.cIMax = cIMax;
49
+ const cINeg = (arg) => ({ kind: 'iNeg', arg });
50
+ exports.cINeg = cINeg;
51
+ const cPathP = (family, left, right) => ({
52
+ kind: 'pathP',
53
+ family,
54
+ left,
55
+ right,
56
+ });
57
+ exports.cPathP = cPathP;
58
+ const cPLam = (bind, body) => ({
59
+ kind: 'pLam',
60
+ bind,
61
+ body,
62
+ });
63
+ exports.cPLam = cPLam;
64
+ const cPApp = (path, arg) => ({
65
+ kind: 'pApp',
66
+ path,
67
+ arg,
68
+ });
69
+ exports.cPApp = cPApp;
70
+ const cGlue = (equiv, partial) => ({
71
+ kind: 'glue',
72
+ equiv,
73
+ partial,
74
+ });
75
+ exports.cGlue = cGlue;
76
+ const cVar = (name) => ({ kind: 'var', name });
77
+ exports.cVar = cVar;
78
+ const cUniverse = (level = 0) => ({ kind: 'universe', level });
79
+ exports.cUniverse = cUniverse;
80
+ const cPi = (bind, domain, codomain) => ({
81
+ kind: 'pi',
82
+ bind,
83
+ domain,
84
+ codomain,
85
+ });
86
+ exports.cPi = cPi;
87
+ const cLam = (bind, domain, body) => ({
88
+ kind: 'lam',
89
+ bind,
90
+ domain,
91
+ body,
92
+ });
93
+ exports.cLam = cLam;
94
+ const cApp = (fn, arg) => ({ kind: 'app', fn, arg });
95
+ exports.cApp = cApp;
96
+ const cArrow = (from, to) => (0, exports.cPi)('_', from, to);
97
+ exports.cArrow = cArrow;
98
+ // ── Discriminador de fragmentos del intervalo ───────────────
99
+ function isIntervalExpr(t) {
100
+ switch (t.kind) {
101
+ case 'i0':
102
+ case 'i1':
103
+ case 'iVar':
104
+ return true;
105
+ case 'iMin':
106
+ case 'iMax':
107
+ return isIntervalExpr(t.left) && isIntervalExpr(t.right);
108
+ case 'iNeg':
109
+ return isIntervalExpr(t.arg);
110
+ default:
111
+ return false;
112
+ }
113
+ }
114
+ // ── Inspección estructural ───────────────────────────────────
115
+ function occursFreeCubical(name, term) {
116
+ switch (term.kind) {
117
+ case 'i0':
118
+ case 'i1':
119
+ case 'universe':
120
+ return false;
121
+ case 'var':
122
+ case 'iVar':
123
+ return term.name === name;
124
+ case 'iMin':
125
+ case 'iMax':
126
+ return occursFreeCubical(name, term.left) || occursFreeCubical(name, term.right);
127
+ case 'iNeg':
128
+ return occursFreeCubical(name, term.arg);
129
+ case 'pathP':
130
+ return (occursFreeCubical(name, term.family) ||
131
+ occursFreeCubical(name, term.left) ||
132
+ occursFreeCubical(name, term.right));
133
+ case 'pLam':
134
+ if (term.bind === name)
135
+ return false;
136
+ return occursFreeCubical(name, term.body);
137
+ case 'pApp':
138
+ return occursFreeCubical(name, term.path) || occursFreeCubical(name, term.arg);
139
+ case 'glue':
140
+ return occursFreeCubical(name, term.equiv) || occursFreeCubical(name, term.partial);
141
+ case 'pi': {
142
+ if (occursFreeCubical(name, term.domain))
143
+ return true;
144
+ if (term.bind === name)
145
+ return false;
146
+ return occursFreeCubical(name, term.codomain);
147
+ }
148
+ case 'lam': {
149
+ if (occursFreeCubical(name, term.domain))
150
+ return true;
151
+ if (term.bind === name)
152
+ return false;
153
+ return occursFreeCubical(name, term.body);
154
+ }
155
+ case 'app':
156
+ return occursFreeCubical(name, term.fn) || occursFreeCubical(name, term.arg);
157
+ }
158
+ }
159
+ function freeVarsCubical(term, acc = new Set()) {
160
+ switch (term.kind) {
161
+ case 'i0':
162
+ case 'i1':
163
+ case 'universe':
164
+ break;
165
+ case 'var':
166
+ case 'iVar':
167
+ acc.add(term.name);
168
+ break;
169
+ case 'iMin':
170
+ case 'iMax':
171
+ freeVarsCubical(term.left, acc);
172
+ freeVarsCubical(term.right, acc);
173
+ break;
174
+ case 'iNeg':
175
+ freeVarsCubical(term.arg, acc);
176
+ break;
177
+ case 'pathP':
178
+ freeVarsCubical(term.family, acc);
179
+ freeVarsCubical(term.left, acc);
180
+ freeVarsCubical(term.right, acc);
181
+ break;
182
+ case 'pLam': {
183
+ const inner = freeVarsCubical(term.body);
184
+ inner.delete(term.bind);
185
+ for (const v of inner)
186
+ acc.add(v);
187
+ break;
188
+ }
189
+ case 'pApp':
190
+ freeVarsCubical(term.path, acc);
191
+ freeVarsCubical(term.arg, acc);
192
+ break;
193
+ case 'glue':
194
+ freeVarsCubical(term.equiv, acc);
195
+ freeVarsCubical(term.partial, acc);
196
+ break;
197
+ case 'pi': {
198
+ freeVarsCubical(term.domain, acc);
199
+ const inner = freeVarsCubical(term.codomain);
200
+ inner.delete(term.bind);
201
+ for (const v of inner)
202
+ acc.add(v);
203
+ break;
204
+ }
205
+ case 'lam': {
206
+ freeVarsCubical(term.domain, acc);
207
+ const inner = freeVarsCubical(term.body);
208
+ inner.delete(term.bind);
209
+ for (const v of inner)
210
+ acc.add(v);
211
+ break;
212
+ }
213
+ case 'app':
214
+ freeVarsCubical(term.fn, acc);
215
+ freeVarsCubical(term.arg, acc);
216
+ break;
217
+ }
218
+ return acc;
219
+ }
220
+ // ── Serialización ────────────────────────────────────────────
221
+ function termToStringCubical(t) {
222
+ switch (t.kind) {
223
+ case 'i0':
224
+ return 'i0';
225
+ case 'i1':
226
+ return 'i1';
227
+ case 'iVar':
228
+ return t.name;
229
+ case 'iMin':
230
+ return `(${termToStringCubical(t.left)} ∧ ${termToStringCubical(t.right)})`;
231
+ case 'iMax':
232
+ return `(${termToStringCubical(t.left)} ∨ ${termToStringCubical(t.right)})`;
233
+ case 'iNeg':
234
+ return `~${termToStringCubical(t.arg)}`;
235
+ case 'pathP':
236
+ return `PathP(${termToStringCubical(t.family)}, ${termToStringCubical(t.left)}, ${termToStringCubical(t.right)})`;
237
+ case 'pLam':
238
+ return `(λi:I. ${t.bind} → ${termToStringCubical(t.body)})`;
239
+ case 'pApp':
240
+ return `(${termToStringCubical(t.path)} @ ${termToStringCubical(t.arg)})`;
241
+ case 'glue':
242
+ return `glue(${termToStringCubical(t.equiv)}, ${termToStringCubical(t.partial)})`;
243
+ case 'var':
244
+ return t.name;
245
+ case 'universe':
246
+ return t.level === 0 ? 'Type' : `Type ${t.level}`;
247
+ case 'pi':
248
+ if (t.bind === '_' || !occursFreeCubical(t.bind, t.codomain)) {
249
+ return `(${termToStringCubical(t.domain)} → ${termToStringCubical(t.codomain)})`;
250
+ }
251
+ return `(Π (${t.bind} : ${termToStringCubical(t.domain)}). ${termToStringCubical(t.codomain)})`;
252
+ case 'lam':
253
+ return `(λ (${t.bind} : ${termToStringCubical(t.domain)}). ${termToStringCubical(t.body)})`;
254
+ case 'app':
255
+ return `(${termToStringCubical(t.fn)} ${termToStringCubical(t.arg)})`;
256
+ }
257
+ }
258
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/type-theory/cubical/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,27 @@
1
+ import type { Eff, Effect, Handler } from './types';
2
+ /** Inyecta un valor puro en la mónada. */
3
+ export declare function pure<A>(value: A): Eff<never, A>;
4
+ /**
5
+ * Construye una computación que ejecuta una operación `tag` con `input`
6
+ * y entrega su resultado al consumidor. La continuación es la identidad:
7
+ * "haz la operación y devuelve su salida".
8
+ */
9
+ export declare function perform<EName extends string, I, O>(tag: EName, input: I): Eff<Effect<EName, I, O>, O>;
10
+ /** Bind monádico (>>= en notación de Haskell). */
11
+ export declare function bind<E, A, B>(eff: Eff<E, A>, fn: (a: A) => Eff<E, B>): Eff<E, B>;
12
+ /** Alias funtorial: aplica una función pura al resultado. */
13
+ export declare function map<E, A, B>(eff: Eff<E, A>, fn: (a: A) => B): Eff<E, B>;
14
+ /** Secuencia una lista de computaciones y colecta sus resultados. */
15
+ export declare function sequence<E, A>(effs: ReadonlyArray<Eff<E, A>>): Eff<E, A[]>;
16
+ /**
17
+ * Interpreta un efecto concreto. Recorre el árbol: las hojas `pure`
18
+ * pasan tal cual; los nodos `impure` cuyo `tag` coincida con el
19
+ * handler son delegados a `handle`; el resto se propaga.
20
+ */
21
+ export declare function handle<E1, E2, A>(eff: Eff<E1, A>, handler: Handler<string, unknown, unknown, E2, A>): Eff<E2, A>;
22
+ /**
23
+ * Extrae el valor de una computación 100% pura. Lanza si quedan efectos
24
+ * sin interpretar — útil tras componer todos los handlers.
25
+ */
26
+ export declare function run<A>(eff: Eff<never, A>): A;
27
+ //# sourceMappingURL=core.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../../../src/type-theory/effects/core.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAEpD,0CAA0C;AAC1C,wBAAgB,IAAI,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,CAE/C;AAED;;;;GAIG;AACH,wBAAgB,OAAO,CAAC,KAAK,SAAS,MAAM,EAAE,CAAC,EAAE,CAAC,EAChD,GAAG,EAAE,KAAK,EACV,KAAK,EAAE,CAAC,GACP,GAAG,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAO7B;AAED,kDAAkD;AAClD,wBAAgB,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAShF;AAED,6DAA6D;AAC7D,wBAAgB,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAEvE;AAED,qEAAqE;AACrE,wBAAgB,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,aAAa,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAK1E;AAED;;;;GAIG;AACH,wBAAgB,MAAM,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,EAC9B,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,EACf,OAAO,EAAE,OAAO,CAAC,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,CAAC,GAChD,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,CAeZ;AAED;;;GAGG;AACH,wBAAgB,GAAG,CAAC,CAAC,EAAE,GAAG,EAAE,GAAG,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAG5C"}