superacli 1.1.6 → 1.1.7

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 (1262) hide show
  1. package/README.md +77 -53
  2. package/__tests__/azd-plugin.test.js +109 -0
  3. package/__tests__/config.test.js +4 -3
  4. package/__tests__/discover.test.js +59 -0
  5. package/__tests__/goose-plugin.test.js +149 -0
  6. package/__tests__/help-json.test.js +2 -0
  7. package/__tests__/openhands-plugin.test.js +106 -0
  8. package/__tests__/plugin-cocoindex-code-uninstall.test.js +19 -0
  9. package/__tests__/plugin-cocoindex-code.test.js +37 -0
  10. package/__tests__/plugin-install-guidance.test.js +81 -0
  11. package/__tests__/plugins-registry.test.js +44 -0
  12. package/__tests__/plugins-store.test.js +40 -5
  13. package/__tests__/process-adapter.test.js +50 -1
  14. package/__tests__/server-app.test.js +1 -0
  15. package/__tests__/server-routes-commands.test.js +20 -2
  16. package/__tests__/server-routes-plugins.test.js +130 -0
  17. package/__tests__/skills.test.js +26 -0
  18. package/__tests__/squirrelscan-plugin.test.js +129 -0
  19. package/__tests__/uipath-plugin.test.js +104 -0
  20. package/__tests__/uipathcli-plugin.test.js +95 -0
  21. package/cli/adapters/mcp.js +2 -0
  22. package/cli/adapters/process.js +49 -2
  23. package/cli/config.js +240 -3
  24. package/cli/discover.js +157 -0
  25. package/cli/help-json.js +16 -1
  26. package/cli/plugin-install-guidance.js +92 -37
  27. package/cli/plugins-manager.js +1 -0
  28. package/cli/plugins-registry.js +74 -8
  29. package/cli/plugins-store.js +78 -17
  30. package/cli/skills-mcp.js +1 -1
  31. package/cli/skills.js +39 -2
  32. package/cli/supercli.js +87 -11
  33. package/docs/feature-gaps.md +8 -8
  34. package/docs/features/azd-uipath-plugins.md +43 -0
  35. package/docs/features/server-plugins.md +62 -0
  36. package/docs/features/skills.md +9 -5
  37. package/docs/{supported-harnesses.md → plugins-available.md} +4 -3
  38. package/docs/{plugin-harness-guide.md → plugins-how-to.md} +1 -1
  39. package/docs/plugins.md +26 -20
  40. package/docs/server-plugins-usage-guide.md +182 -0
  41. package/docs/skills-catalog.md +12 -10
  42. package/package.json +1 -1
  43. package/plugins/agent-browser/README.md +69 -0
  44. package/plugins/agent-browser/plugin.json +111 -0
  45. package/plugins/agent-browser/skills/quickstart/SKILL.md +66 -0
  46. package/plugins/aider/README.md +53 -0
  47. package/plugins/aider/plugin.json +105 -0
  48. package/plugins/aider/scripts/aider-wrapper.js +243 -0
  49. package/plugins/aider/scripts/setup-aider.js +37 -0
  50. package/plugins/aider/skills/dry-run-review.md +24 -0
  51. package/plugins/aider/skills/model-and-provider.md +24 -0
  52. package/plugins/aider/skills/one-shot-edits.md +30 -0
  53. package/plugins/aider/skills/quickstart/SKILL.md +51 -0
  54. package/plugins/azd/README.md +28 -0
  55. package/plugins/azd/plugin.json +87 -0
  56. package/plugins/azd/skills/quickstart/SKILL.md +41 -0
  57. package/plugins/blogwatcher/README.md +3 -3
  58. package/plugins/boxlite/Dockerfile +9 -0
  59. package/plugins/boxlite/README.md +62 -0
  60. package/plugins/boxlite/plugin.json +201 -0
  61. package/plugins/boxlite/scripts/run-boxlite.js +106 -0
  62. package/plugins/boxlite/skills/quickstart/SKILL.md +40 -0
  63. package/plugins/cass/plugin.json +150 -0
  64. package/plugins/cass/scripts/setup-cass.js +47 -0
  65. package/plugins/cass/skills/quickstart/SKILL.md +46 -0
  66. package/plugins/clever/README.md +46 -0
  67. package/plugins/clever/plugin.json +119 -0
  68. package/plugins/clever/scripts/setup-clever.js +28 -0
  69. package/plugins/clever/skills/auth-and-profile.md +29 -0
  70. package/plugins/clever/skills/passthrough-safety.md +21 -0
  71. package/plugins/clever/skills/quickstart/SKILL.md +45 -0
  72. package/plugins/clever/skills/resource-inventory.md +24 -0
  73. package/plugins/clix/README.md +4 -4
  74. package/plugins/cocoindex-code/README.md +64 -0
  75. package/plugins/cocoindex-code/plugin.json +81 -0
  76. package/plugins/cocoindex-code/scripts/__pycache__/query.cpython-310.pyc +0 -0
  77. package/plugins/cocoindex-code/scripts/__pycache__/query.cpython-311.pyc +0 -0
  78. package/plugins/cocoindex-code/scripts/post-install.js +61 -0
  79. package/plugins/cocoindex-code/scripts/post-uninstall.js +25 -0
  80. package/plugins/cocoindex-code/scripts/query.py +88 -0
  81. package/plugins/cocoindex-code/scripts/run-query.js +50 -0
  82. package/plugins/cocoindex-code/skills/quickstart/SKILL.md +73 -0
  83. package/plugins/copilot/README.md +24 -0
  84. package/plugins/copilot/plugin.json +80 -0
  85. package/plugins/copilot/skills/quickstart/SKILL.md +44 -0
  86. package/plugins/gemini/README.md +24 -0
  87. package/plugins/gemini/plugin.json +98 -0
  88. package/plugins/gemini/skills/quickstart/SKILL.md +44 -0
  89. package/plugins/gifcap/plugin.json +119 -0
  90. package/plugins/gifcap/scripts/setup-gifcap.js +44 -0
  91. package/plugins/gifcap/skills/quickstart/SKILL.md +34 -0
  92. package/plugins/gifcap/test-record-quiet.gif +0 -0
  93. package/plugins/gifcap/test-record.gif +0 -0
  94. package/plugins/goose/README.md +36 -0
  95. package/plugins/goose/plugin.json +183 -0
  96. package/plugins/goose/skills/quickstart/SKILL.md +44 -0
  97. package/plugins/json-server/README.md +58 -0
  98. package/plugins/json-server/plugin.json +113 -0
  99. package/plugins/json-server/skills/quickstart/SKILL.md +57 -0
  100. package/plugins/lightpanda/README.md +145 -0
  101. package/plugins/lightpanda/package-lock.json +1375 -0
  102. package/plugins/lightpanda/package.json +12 -0
  103. package/plugins/lightpanda/plugin.json +116 -0
  104. package/plugins/lightpanda/scripts/lightpanda-contacts.js +494 -0
  105. package/plugins/lightpanda/scripts/lightpanda-generic-extract.js +403 -0
  106. package/plugins/lightpanda/scripts/lightpanda-wrapper.js +480 -0
  107. package/plugins/lightpanda/scripts/setup-lightpanda.js +39 -0
  108. package/plugins/lightpanda/skills/contact-discovery.md +51 -0
  109. package/plugins/lightpanda/skills/generic-extraction.md +66 -0
  110. package/plugins/lightpanda/skills/quickstart/SKILL.md +103 -0
  111. package/plugins/lightpanda/skills/resilient-navigation.md +42 -0
  112. package/plugins/monty/README.md +2 -2
  113. package/plugins/nullclaw/README.md +3 -3
  114. package/plugins/offline-ai/README.md +23 -0
  115. package/plugins/offline-ai/plugin.json +82 -0
  116. package/plugins/offline-ai/skills/quickstart/SKILL.md +43 -0
  117. package/plugins/openhands/README.md +25 -0
  118. package/plugins/openhands/plugin.json +116 -0
  119. package/plugins/openhands/skills/quickstart/SKILL.md +26 -0
  120. package/plugins/plandex/README.md +25 -0
  121. package/plugins/plandex/plugin.json +130 -0
  122. package/plugins/plandex/skills/quickstart/SKILL.md +50 -0
  123. package/plugins/plugins.json +188 -0
  124. package/plugins/squirrelscan/Dockerfile +5 -0
  125. package/plugins/squirrelscan/README.md +47 -0
  126. package/plugins/squirrelscan/plugin.json +493 -0
  127. package/plugins/squirrelscan/scripts/post-install.js +33 -0
  128. package/plugins/squirrelscan/scripts/post-uninstall.js +25 -0
  129. package/plugins/squirrelscan/scripts/run-squirrel.js +73 -0
  130. package/plugins/squirrelscan/skills/audit-workflow/SKILL.md +33 -0
  131. package/plugins/squirrelscan/skills/publish-report/SKILL.md +33 -0
  132. package/plugins/squirrelscan/skills/quickstart/SKILL.md +41 -0
  133. package/plugins/uipath/README.md +27 -0
  134. package/plugins/uipath/plugin.json +86 -0
  135. package/plugins/uipath/skills/quickstart/SKILL.md +47 -0
  136. package/plugins/uipathcli/README.md +28 -0
  137. package/plugins/uipathcli/plugin.json +120 -0
  138. package/plugins/uipathcli/scripts/run-uipath-cli.js +49 -0
  139. package/plugins/uipathcli/skills/quickstart/SKILL.md +22 -0
  140. package/plugins/xurl/README.md +4 -4
  141. package/server/app.js +5 -2
  142. package/server/public/app.js +3 -0
  143. package/server/routes/commands.js +95 -12
  144. package/server/routes/plugins.js +262 -0
  145. package/server/services/pluginsService.js +303 -0
  146. package/server/views/command-edit.ejs +196 -14
  147. package/server/views/partials/head.ejs +1 -0
  148. package/server/views/plugins.ejs +264 -0
  149. package/tests/test-plugins-registry.js +30 -0
  150. package/.beads/.br_history/issues.20260308_200823_636718328.jsonl +0 -20
  151. package/.beads/.br_history/issues.20260308_200823_636718328.jsonl.meta.json +0 -1
  152. package/.beads/.br_history/issues.20260308_200827_033159453.jsonl +0 -21
  153. package/.beads/.br_history/issues.20260308_200827_033159453.jsonl.meta.json +0 -1
  154. package/.beads/.br_history/issues.20260308_200829_595900053.jsonl +0 -22
  155. package/.beads/.br_history/issues.20260308_200829_595900053.jsonl.meta.json +0 -1
  156. package/.beads/.br_history/issues.20260308_200834_079930100.jsonl +0 -23
  157. package/.beads/.br_history/issues.20260308_200834_079930100.jsonl.meta.json +0 -1
  158. package/.beads/.br_history/issues.20260308_200858_370924996.jsonl +0 -24
  159. package/.beads/.br_history/issues.20260308_200858_370924996.jsonl.meta.json +0 -1
  160. package/.beads/.br_history/issues.20260308_201031_019730855.jsonl +0 -24
  161. package/.beads/.br_history/issues.20260308_201031_019730855.jsonl.meta.json +0 -1
  162. package/.beads/.br_history/issues.20260308_201031_578974884.jsonl +0 -24
  163. package/.beads/.br_history/issues.20260308_201031_578974884.jsonl.meta.json +0 -1
  164. package/.beads/.br_history/issues.20260308_201054_780345548.jsonl +0 -24
  165. package/.beads/.br_history/issues.20260308_201054_780345548.jsonl.meta.json +0 -1
  166. package/.beads/.br_history/issues.20260308_201054_896980019.jsonl +0 -24
  167. package/.beads/.br_history/issues.20260308_201054_896980019.jsonl.meta.json +0 -1
  168. package/.beads/.br_history/issues.20260308_201128_599819688.jsonl +0 -24
  169. package/.beads/.br_history/issues.20260308_201128_599819688.jsonl.meta.json +0 -1
  170. package/.beads/.br_history/issues.20260308_201128_710221699.jsonl +0 -24
  171. package/.beads/.br_history/issues.20260308_201128_710221699.jsonl.meta.json +0 -1
  172. package/.beads/.br_history/issues.20260308_201204_745649213.jsonl +0 -24
  173. package/.beads/.br_history/issues.20260308_201204_745649213.jsonl.meta.json +0 -1
  174. package/.beads/.br_history/issues.20260308_201338_908436144.jsonl +0 -24
  175. package/.beads/.br_history/issues.20260308_201338_908436144.jsonl.meta.json +0 -1
  176. package/.beads/.br_history/issues.20260308_201344_734860714.jsonl +0 -25
  177. package/.beads/.br_history/issues.20260308_201344_734860714.jsonl.meta.json +0 -1
  178. package/.beads/.br_history/issues.20260308_201630_819282295.jsonl +0 -25
  179. package/.beads/.br_history/issues.20260308_201630_819282295.jsonl.meta.json +0 -1
  180. package/.beads/.br_history/issues.20260308_203538_054279699.jsonl +0 -25
  181. package/.beads/.br_history/issues.20260308_203538_054279699.jsonl.meta.json +0 -1
  182. package/.beads/.br_history/issues.20260308_203547_597113070.jsonl +0 -26
  183. package/.beads/.br_history/issues.20260308_203547_597113070.jsonl.meta.json +0 -1
  184. package/.beads/.br_history/issues.20260308_203547_775139216.jsonl +0 -27
  185. package/.beads/.br_history/issues.20260308_203547_775139216.jsonl.meta.json +0 -1
  186. package/.beads/.br_history/issues.20260308_203547_950724773.jsonl +0 -28
  187. package/.beads/.br_history/issues.20260308_203547_950724773.jsonl.meta.json +0 -1
  188. package/.beads/.br_history/issues.20260308_203548_107684523.jsonl +0 -29
  189. package/.beads/.br_history/issues.20260308_203548_107684523.jsonl.meta.json +0 -1
  190. package/.beads/.br_history/issues.20260308_203548_310389993.jsonl +0 -30
  191. package/.beads/.br_history/issues.20260308_203548_310389993.jsonl.meta.json +0 -1
  192. package/.beads/.br_history/issues.20260308_203825_953337320.jsonl +0 -31
  193. package/.beads/.br_history/issues.20260308_203825_953337320.jsonl.meta.json +0 -1
  194. package/.beads/.br_history/issues.20260308_204056_071377736.jsonl +0 -32
  195. package/.beads/.br_history/issues.20260308_204056_071377736.jsonl.meta.json +0 -1
  196. package/.beads/.br_history/issues.20260308_205141_517616844.jsonl +0 -32
  197. package/.beads/.br_history/issues.20260308_205141_517616844.jsonl.meta.json +0 -1
  198. package/.beads/.br_history/issues.20260308_205141_648994024.jsonl +0 -32
  199. package/.beads/.br_history/issues.20260308_205141_648994024.jsonl.meta.json +0 -1
  200. package/.beads/.br_history/issues.20260308_205141_867598036.jsonl +0 -32
  201. package/.beads/.br_history/issues.20260308_205141_867598036.jsonl.meta.json +0 -1
  202. package/.beads/.br_history/issues.20260308_205142_094157355.jsonl +0 -32
  203. package/.beads/.br_history/issues.20260308_205142_094157355.jsonl.meta.json +0 -1
  204. package/.beads/.br_history/issues.20260308_205142_327315677.jsonl +0 -32
  205. package/.beads/.br_history/issues.20260308_205142_327315677.jsonl.meta.json +0 -1
  206. package/.beads/.br_history/issues.20260308_205142_545563822.jsonl +0 -32
  207. package/.beads/.br_history/issues.20260308_205142_545563822.jsonl.meta.json +0 -1
  208. package/.beads/.br_history/issues.20260308_205213_061989333.jsonl +0 -32
  209. package/.beads/.br_history/issues.20260308_205213_061989333.jsonl.meta.json +0 -1
  210. package/.beads/.br_history/issues.20260308_205213_181103364.jsonl +0 -32
  211. package/.beads/.br_history/issues.20260308_205213_181103364.jsonl.meta.json +0 -1
  212. package/.beads/.br_history/issues.20260308_205213_408872234.jsonl +0 -32
  213. package/.beads/.br_history/issues.20260308_205213_408872234.jsonl.meta.json +0 -1
  214. package/.beads/.br_history/issues.20260308_205213_616681652.jsonl +0 -32
  215. package/.beads/.br_history/issues.20260308_205213_616681652.jsonl.meta.json +0 -1
  216. package/.beads/.br_history/issues.20260308_205213_821507069.jsonl +0 -32
  217. package/.beads/.br_history/issues.20260308_205213_821507069.jsonl.meta.json +0 -1
  218. package/.beads/.br_history/issues.20260308_205214_026661112.jsonl +0 -32
  219. package/.beads/.br_history/issues.20260308_205214_026661112.jsonl.meta.json +0 -1
  220. package/.beads/.br_history/issues.20260308_205454_955250554.jsonl +0 -32
  221. package/.beads/.br_history/issues.20260308_205454_955250554.jsonl.meta.json +0 -1
  222. package/.beads/.br_history/issues.20260308_205556_337800392.jsonl +0 -33
  223. package/.beads/.br_history/issues.20260308_205556_337800392.jsonl.meta.json +0 -1
  224. package/.beads/.br_history/issues.20260308_205824_274686694.jsonl +0 -33
  225. package/.beads/.br_history/issues.20260308_205824_274686694.jsonl.meta.json +0 -1
  226. package/.beads/.br_history/issues.20260308_210240_583768328.jsonl +0 -34
  227. package/.beads/.br_history/issues.20260308_210240_583768328.jsonl.meta.json +0 -1
  228. package/.beads/.br_history/issues.20260308_212223_641541494.jsonl +0 -34
  229. package/.beads/.br_history/issues.20260308_212223_641541494.jsonl.meta.json +0 -1
  230. package/.beads/.br_history/issues.20260308_212227_735550996.jsonl +0 -35
  231. package/.beads/.br_history/issues.20260308_212227_735550996.jsonl.meta.json +0 -1
  232. package/.beads/.br_history/issues.20260308_212232_547298548.jsonl +0 -36
  233. package/.beads/.br_history/issues.20260308_212232_547298548.jsonl.meta.json +0 -1
  234. package/.beads/.br_history/issues.20260308_212528_843628125.jsonl +0 -37
  235. package/.beads/.br_history/issues.20260308_212528_843628125.jsonl.meta.json +0 -1
  236. package/.beads/.br_history/issues.20260308_212529_094530502.jsonl +0 -38
  237. package/.beads/.br_history/issues.20260308_212529_094530502.jsonl.meta.json +0 -1
  238. package/.beads/.br_history/issues.20260308_212529_331000853.jsonl +0 -39
  239. package/.beads/.br_history/issues.20260308_212529_331000853.jsonl.meta.json +0 -1
  240. package/.beads/.br_history/issues.20260308_212529_587925652.jsonl +0 -40
  241. package/.beads/.br_history/issues.20260308_212529_587925652.jsonl.meta.json +0 -1
  242. package/.beads/.br_history/issues.20260308_212804_927764103.jsonl +0 -41
  243. package/.beads/.br_history/issues.20260308_212804_927764103.jsonl.meta.json +0 -1
  244. package/.beads/.br_history/issues.20260308_212805_153673453.jsonl +0 -42
  245. package/.beads/.br_history/issues.20260308_212805_153673453.jsonl.meta.json +0 -1
  246. package/.beads/.br_history/issues.20260308_212805_415982363.jsonl +0 -43
  247. package/.beads/.br_history/issues.20260308_212805_415982363.jsonl.meta.json +0 -1
  248. package/.beads/.br_history/issues.20260308_212805_657497741.jsonl +0 -44
  249. package/.beads/.br_history/issues.20260308_212805_657497741.jsonl.meta.json +0 -1
  250. package/.beads/.br_history/issues.20260308_212805_952838724.jsonl +0 -45
  251. package/.beads/.br_history/issues.20260308_212805_952838724.jsonl.meta.json +0 -1
  252. package/.beads/.br_history/issues.20260308_212806_325433779.jsonl +0 -46
  253. package/.beads/.br_history/issues.20260308_212806_325433779.jsonl.meta.json +0 -1
  254. package/.beads/.br_history/issues.20260308_212806_584685598.jsonl +0 -47
  255. package/.beads/.br_history/issues.20260308_212806_584685598.jsonl.meta.json +0 -1
  256. package/.beads/.br_history/issues.20260308_212806_827817208.jsonl +0 -48
  257. package/.beads/.br_history/issues.20260308_212806_827817208.jsonl.meta.json +0 -1
  258. package/.beads/.br_history/issues.20260308_212807_111320451.jsonl +0 -49
  259. package/.beads/.br_history/issues.20260308_212807_111320451.jsonl.meta.json +0 -1
  260. package/.beads/.br_history/issues.20260308_212807_409545536.jsonl +0 -50
  261. package/.beads/.br_history/issues.20260308_212807_409545536.jsonl.meta.json +0 -1
  262. package/.beads/.br_history/issues.20260308_212807_625063294.jsonl +0 -51
  263. package/.beads/.br_history/issues.20260308_212807_625063294.jsonl.meta.json +0 -1
  264. package/.beads/.br_history/issues.20260308_212807_843906551.jsonl +0 -52
  265. package/.beads/.br_history/issues.20260308_212807_843906551.jsonl.meta.json +0 -1
  266. package/.beads/.br_history/issues.20260308_212808_100304073.jsonl +0 -53
  267. package/.beads/.br_history/issues.20260308_212808_100304073.jsonl.meta.json +0 -1
  268. package/.beads/.br_history/issues.20260308_212808_324723976.jsonl +0 -54
  269. package/.beads/.br_history/issues.20260308_212808_324723976.jsonl.meta.json +0 -1
  270. package/.beads/.br_history/issues.20260308_212808_557513104.jsonl +0 -55
  271. package/.beads/.br_history/issues.20260308_212808_557513104.jsonl.meta.json +0 -1
  272. package/.beads/.br_history/issues.20260308_212808_788048322.jsonl +0 -56
  273. package/.beads/.br_history/issues.20260308_212808_788048322.jsonl.meta.json +0 -1
  274. package/.beads/.br_history/issues.20260308_213702_613249728.jsonl +0 -57
  275. package/.beads/.br_history/issues.20260308_213702_613249728.jsonl.meta.json +0 -1
  276. package/.beads/.br_history/issues.20260308_213715_115792063.jsonl +0 -57
  277. package/.beads/.br_history/issues.20260308_213715_115792063.jsonl.meta.json +0 -1
  278. package/.beads/.br_history/issues.20260308_213715_462220666.jsonl +0 -57
  279. package/.beads/.br_history/issues.20260308_213715_462220666.jsonl.meta.json +0 -1
  280. package/.beads/.br_history/issues.20260308_213727_191258923.jsonl +0 -57
  281. package/.beads/.br_history/issues.20260308_213727_191258923.jsonl.meta.json +0 -1
  282. package/.beads/.br_history/issues.20260308_213727_684383652.jsonl +0 -57
  283. package/.beads/.br_history/issues.20260308_213727_684383652.jsonl.meta.json +0 -1
  284. package/.beads/.br_history/issues.20260308_213735_751882991.jsonl +0 -57
  285. package/.beads/.br_history/issues.20260308_213735_751882991.jsonl.meta.json +0 -1
  286. package/.beads/.br_history/issues.20260308_222052_279844960.jsonl +0 -57
  287. package/.beads/.br_history/issues.20260308_222052_279844960.jsonl.meta.json +0 -1
  288. package/.beads/.br_history/issues.20260308_222056_873282114.jsonl +0 -57
  289. package/.beads/.br_history/issues.20260308_222056_873282114.jsonl.meta.json +0 -1
  290. package/.beads/.br_history/issues.20260308_222103_402410761.jsonl +0 -57
  291. package/.beads/.br_history/issues.20260308_222103_402410761.jsonl.meta.json +0 -1
  292. package/.beads/.br_history/issues.20260308_235202_180577215.jsonl +0 -57
  293. package/.beads/.br_history/issues.20260308_235202_180577215.jsonl.meta.json +0 -1
  294. package/.beads/.br_history/issues.20260308_235202_387414163.jsonl +0 -57
  295. package/.beads/.br_history/issues.20260308_235202_387414163.jsonl.meta.json +0 -1
  296. package/.beads/.br_history/issues.20260308_235202_564422794.jsonl +0 -57
  297. package/.beads/.br_history/issues.20260308_235202_564422794.jsonl.meta.json +0 -1
  298. package/.beads/.br_history/issues.20260308_235202_742600597.jsonl +0 -57
  299. package/.beads/.br_history/issues.20260308_235202_742600597.jsonl.meta.json +0 -1
  300. package/.beads/.br_history/issues.20260308_235208_133360069.jsonl +0 -57
  301. package/.beads/.br_history/issues.20260308_235208_133360069.jsonl.meta.json +0 -1
  302. package/.beads/.br_history/issues.20260308_235505_473406307.jsonl +0 -57
  303. package/.beads/.br_history/issues.20260308_235505_473406307.jsonl.meta.json +0 -1
  304. package/.beads/.br_history/issues.20260308_235505_662360489.jsonl +0 -57
  305. package/.beads/.br_history/issues.20260308_235505_662360489.jsonl.meta.json +0 -1
  306. package/.beads/.br_history/issues.20260308_235505_843935624.jsonl +0 -57
  307. package/.beads/.br_history/issues.20260308_235505_843935624.jsonl.meta.json +0 -1
  308. package/.beads/.br_history/issues.20260308_235506_044530221.jsonl +0 -57
  309. package/.beads/.br_history/issues.20260308_235506_044530221.jsonl.meta.json +0 -1
  310. package/.beads/.br_history/issues.20260309_002618_115728731.jsonl +0 -57
  311. package/.beads/.br_history/issues.20260309_002618_115728731.jsonl.meta.json +0 -1
  312. package/.beads/.br_history/issues.20260309_003748_878174586.jsonl +0 -57
  313. package/.beads/.br_history/issues.20260309_003748_878174586.jsonl.meta.json +0 -1
  314. package/.beads/.br_history/issues.20260309_004057_868755623.jsonl +0 -57
  315. package/.beads/.br_history/issues.20260309_004057_868755623.jsonl.meta.json +0 -1
  316. package/.beads/.br_history/issues.20260309_004058_512842163.jsonl +0 -57
  317. package/.beads/.br_history/issues.20260309_004058_512842163.jsonl.meta.json +0 -1
  318. package/.beads/.br_history/issues.20260309_004058_994445226.jsonl +0 -57
  319. package/.beads/.br_history/issues.20260309_004058_994445226.jsonl.meta.json +0 -1
  320. package/.beads/.br_history/issues.20260309_004059_475988596.jsonl +0 -57
  321. package/.beads/.br_history/issues.20260309_004059_475988596.jsonl.meta.json +0 -1
  322. package/.beads/.br_history/issues.20260309_161902_566857851.jsonl +0 -57
  323. package/.beads/.br_history/issues.20260309_161902_566857851.jsonl.meta.json +0 -1
  324. package/.beads/.br_history/issues.20260309_170512_277017739.jsonl +0 -57
  325. package/.beads/.br_history/issues.20260309_170512_277017739.jsonl.meta.json +0 -1
  326. package/.beads/.br_history/issues.20260309_170512_477876921.jsonl +0 -57
  327. package/.beads/.br_history/issues.20260309_170512_477876921.jsonl.meta.json +0 -1
  328. package/.beads/.br_history/issues.20260309_170512_664382701.jsonl +0 -57
  329. package/.beads/.br_history/issues.20260309_170512_664382701.jsonl.meta.json +0 -1
  330. package/.beads/.br_history/issues.20260309_170512_859400333.jsonl +0 -57
  331. package/.beads/.br_history/issues.20260309_170512_859400333.jsonl.meta.json +0 -1
  332. package/.beads/.br_history/issues.20260309_212326_082771164.jsonl +0 -57
  333. package/.beads/.br_history/issues.20260309_212326_082771164.jsonl.meta.json +0 -1
  334. package/.beads/.br_history/issues.20260309_212326_245619716.jsonl +0 -58
  335. package/.beads/.br_history/issues.20260309_212326_245619716.jsonl.meta.json +0 -1
  336. package/.beads/.br_history/issues.20260309_212326_403198317.jsonl +0 -59
  337. package/.beads/.br_history/issues.20260309_212326_403198317.jsonl.meta.json +0 -1
  338. package/.beads/.br_history/issues.20260309_212332_539197678.jsonl +0 -60
  339. package/.beads/.br_history/issues.20260309_212332_539197678.jsonl.meta.json +0 -1
  340. package/.beads/.br_history/issues.20260309_212332_731373599.jsonl +0 -60
  341. package/.beads/.br_history/issues.20260309_212332_731373599.jsonl.meta.json +0 -1
  342. package/.beads/.br_history/issues.20260309_212332_928710953.jsonl +0 -60
  343. package/.beads/.br_history/issues.20260309_212332_928710953.jsonl.meta.json +0 -1
  344. package/.beads/.br_history/issues.20260309_213021_341505240.jsonl +0 -60
  345. package/.beads/.br_history/issues.20260309_213021_341505240.jsonl.meta.json +0 -1
  346. package/.beads/.br_history/issues.20260309_213022_023136934.jsonl +0 -60
  347. package/.beads/.br_history/issues.20260309_213022_023136934.jsonl.meta.json +0 -1
  348. package/.beads/.br_history/issues.20260309_213022_400050719.jsonl +0 -60
  349. package/.beads/.br_history/issues.20260309_213022_400050719.jsonl.meta.json +0 -1
  350. package/.beads/config.yaml +0 -4
  351. package/.beads/issues.jsonl +0 -60
  352. package/.beads/metadata.json +0 -4
  353. package/docs/mcp-cheatsheet.md +0 -324
  354. package/docs/visual-overview.md +0 -21
  355. package/ref-monty/.cargo/config.toml +0 -3
  356. package/ref-monty/.claude/settings.json +0 -60
  357. package/ref-monty/.claude/skills/fastmod/SKILL.md +0 -22
  358. package/ref-monty/.claude/skills/python-playground/SKILL.md +0 -47
  359. package/ref-monty/.codecov.yml +0 -12
  360. package/ref-monty/.github/actions/build-pgo-wheel/action.yml +0 -72
  361. package/ref-monty/.github/workflows/ci.yml +0 -776
  362. package/ref-monty/.github/workflows/codspeed.yml +0 -45
  363. package/ref-monty/.github/workflows/init-npm-packages.yml +0 -82
  364. package/ref-monty/.pre-commit-config.yaml +0 -47
  365. package/ref-monty/.python-version +0 -1
  366. package/ref-monty/.rustfmt.toml +0 -4
  367. package/ref-monty/.zed/settings.json +0 -11
  368. package/ref-monty/CLAUDE.md +0 -535
  369. package/ref-monty/Cargo.lock +0 -3798
  370. package/ref-monty/Cargo.toml +0 -87
  371. package/ref-monty/LICENSE +0 -21
  372. package/ref-monty/Makefile +0 -216
  373. package/ref-monty/README.md +0 -430
  374. package/ref-monty/RELEASING.md +0 -47
  375. package/ref-monty/crates/fuzz/Cargo.toml +0 -30
  376. package/ref-monty/crates/fuzz/fuzz_targets/string_input_panic.rs +0 -37
  377. package/ref-monty/crates/fuzz/fuzz_targets/tokens_input_panic.rs +0 -552
  378. package/ref-monty/crates/monty/Cargo.toml +0 -68
  379. package/ref-monty/crates/monty/benches/main.rs +0 -247
  380. package/ref-monty/crates/monty/build.rs +0 -10
  381. package/ref-monty/crates/monty/src/args.rs +0 -733
  382. package/ref-monty/crates/monty/src/asyncio.rs +0 -179
  383. package/ref-monty/crates/monty/src/builtins/abs.rs +0 -55
  384. package/ref-monty/crates/monty/src/builtins/all.rs +0 -30
  385. package/ref-monty/crates/monty/src/builtins/any.rs +0 -30
  386. package/ref-monty/crates/monty/src/builtins/bin.rs +0 -59
  387. package/ref-monty/crates/monty/src/builtins/chr.rs +0 -46
  388. package/ref-monty/crates/monty/src/builtins/divmod.rs +0 -164
  389. package/ref-monty/crates/monty/src/builtins/enumerate.rs +0 -52
  390. package/ref-monty/crates/monty/src/builtins/filter.rs +0 -67
  391. package/ref-monty/crates/monty/src/builtins/getattr.rs +0 -65
  392. package/ref-monty/crates/monty/src/builtins/hash.rs +0 -28
  393. package/ref-monty/crates/monty/src/builtins/hex.rs +0 -58
  394. package/ref-monty/crates/monty/src/builtins/id.rs +0 -24
  395. package/ref-monty/crates/monty/src/builtins/isinstance.rs +0 -68
  396. package/ref-monty/crates/monty/src/builtins/len.rs +0 -25
  397. package/ref-monty/crates/monty/src/builtins/map.rs +0 -98
  398. package/ref-monty/crates/monty/src/builtins/min_max.rs +0 -113
  399. package/ref-monty/crates/monty/src/builtins/mod.rs +0 -246
  400. package/ref-monty/crates/monty/src/builtins/next.rs +0 -21
  401. package/ref-monty/crates/monty/src/builtins/oct.rs +0 -59
  402. package/ref-monty/crates/monty/src/builtins/ord.rs +0 -67
  403. package/ref-monty/crates/monty/src/builtins/pow.rs +0 -365
  404. package/ref-monty/crates/monty/src/builtins/print.rs +0 -141
  405. package/ref-monty/crates/monty/src/builtins/repr.rs +0 -16
  406. package/ref-monty/crates/monty/src/builtins/reversed.rs +0 -28
  407. package/ref-monty/crates/monty/src/builtins/round.rs +0 -174
  408. package/ref-monty/crates/monty/src/builtins/sorted.rs +0 -151
  409. package/ref-monty/crates/monty/src/builtins/sum.rs +0 -66
  410. package/ref-monty/crates/monty/src/builtins/type_.rs +0 -16
  411. package/ref-monty/crates/monty/src/builtins/zip.rs +0 -77
  412. package/ref-monty/crates/monty/src/bytecode/builder.rs +0 -699
  413. package/ref-monty/crates/monty/src/bytecode/code.rs +0 -310
  414. package/ref-monty/crates/monty/src/bytecode/compiler.rs +0 -3206
  415. package/ref-monty/crates/monty/src/bytecode/mod.rs +0 -24
  416. package/ref-monty/crates/monty/src/bytecode/op.rs +0 -617
  417. package/ref-monty/crates/monty/src/bytecode/vm/async_exec.rs +0 -1058
  418. package/ref-monty/crates/monty/src/bytecode/vm/attr.rs +0 -63
  419. package/ref-monty/crates/monty/src/bytecode/vm/binary.rs +0 -487
  420. package/ref-monty/crates/monty/src/bytecode/vm/call.rs +0 -767
  421. package/ref-monty/crates/monty/src/bytecode/vm/collections.rs +0 -741
  422. package/ref-monty/crates/monty/src/bytecode/vm/compare.rs +0 -147
  423. package/ref-monty/crates/monty/src/bytecode/vm/exceptions.rs +0 -297
  424. package/ref-monty/crates/monty/src/bytecode/vm/format.rs +0 -132
  425. package/ref-monty/crates/monty/src/bytecode/vm/mod.rs +0 -1958
  426. package/ref-monty/crates/monty/src/bytecode/vm/scheduler.rs +0 -620
  427. package/ref-monty/crates/monty/src/exception_private.rs +0 -1513
  428. package/ref-monty/crates/monty/src/exception_public.rs +0 -346
  429. package/ref-monty/crates/monty/src/expressions.rs +0 -694
  430. package/ref-monty/crates/monty/src/fstring.rs +0 -854
  431. package/ref-monty/crates/monty/src/function.rs +0 -119
  432. package/ref-monty/crates/monty/src/heap.rs +0 -1073
  433. package/ref-monty/crates/monty/src/heap_data.rs +0 -985
  434. package/ref-monty/crates/monty/src/heap_traits.rs +0 -312
  435. package/ref-monty/crates/monty/src/intern.rs +0 -837
  436. package/ref-monty/crates/monty/src/io.rs +0 -106
  437. package/ref-monty/crates/monty/src/lib.rs +0 -52
  438. package/ref-monty/crates/monty/src/modules/asyncio.rs +0 -144
  439. package/ref-monty/crates/monty/src/modules/math.rs +0 -1453
  440. package/ref-monty/crates/monty/src/modules/mod.rs +0 -120
  441. package/ref-monty/crates/monty/src/modules/os.rs +0 -116
  442. package/ref-monty/crates/monty/src/modules/pathlib.rs +0 -33
  443. package/ref-monty/crates/monty/src/modules/re.rs +0 -606
  444. package/ref-monty/crates/monty/src/modules/sys.rs +0 -60
  445. package/ref-monty/crates/monty/src/modules/typing.rs +0 -70
  446. package/ref-monty/crates/monty/src/namespace.rs +0 -21
  447. package/ref-monty/crates/monty/src/object.rs +0 -1040
  448. package/ref-monty/crates/monty/src/os.rs +0 -215
  449. package/ref-monty/crates/monty/src/parse.rs +0 -1730
  450. package/ref-monty/crates/monty/src/prepare.rs +0 -3015
  451. package/ref-monty/crates/monty/src/repl.rs +0 -1109
  452. package/ref-monty/crates/monty/src/resource.rs +0 -559
  453. package/ref-monty/crates/monty/src/run.rs +0 -457
  454. package/ref-monty/crates/monty/src/run_progress.rs +0 -821
  455. package/ref-monty/crates/monty/src/signature.rs +0 -651
  456. package/ref-monty/crates/monty/src/sorting.rs +0 -100
  457. package/ref-monty/crates/monty/src/types/bytes.rs +0 -2356
  458. package/ref-monty/crates/monty/src/types/dataclass.rs +0 -345
  459. package/ref-monty/crates/monty/src/types/dict.rs +0 -879
  460. package/ref-monty/crates/monty/src/types/dict_view.rs +0 -619
  461. package/ref-monty/crates/monty/src/types/iter.rs +0 -799
  462. package/ref-monty/crates/monty/src/types/list.rs +0 -929
  463. package/ref-monty/crates/monty/src/types/long_int.rs +0 -211
  464. package/ref-monty/crates/monty/src/types/mod.rs +0 -48
  465. package/ref-monty/crates/monty/src/types/module.rs +0 -146
  466. package/ref-monty/crates/monty/src/types/namedtuple.rs +0 -261
  467. package/ref-monty/crates/monty/src/types/path.rs +0 -596
  468. package/ref-monty/crates/monty/src/types/property.rs +0 -35
  469. package/ref-monty/crates/monty/src/types/py_trait.rs +0 -322
  470. package/ref-monty/crates/monty/src/types/range.rs +0 -285
  471. package/ref-monty/crates/monty/src/types/re_match.rs +0 -522
  472. package/ref-monty/crates/monty/src/types/re_pattern.rs +0 -726
  473. package/ref-monty/crates/monty/src/types/set.rs +0 -1373
  474. package/ref-monty/crates/monty/src/types/slice.rs +0 -257
  475. package/ref-monty/crates/monty/src/types/str.rs +0 -2051
  476. package/ref-monty/crates/monty/src/types/tuple.rs +0 -376
  477. package/ref-monty/crates/monty/src/types/type.rs +0 -407
  478. package/ref-monty/crates/monty/src/value.rs +0 -2558
  479. package/ref-monty/crates/monty/test_cases/args__dict_get_no_args.py +0 -3
  480. package/ref-monty/crates/monty/test_cases/args__dict_get_too_many.py +0 -3
  481. package/ref-monty/crates/monty/test_cases/args__dict_items_with_args.py +0 -3
  482. package/ref-monty/crates/monty/test_cases/args__dict_keys_with_args.py +0 -3
  483. package/ref-monty/crates/monty/test_cases/args__dict_pop_no_args.py +0 -3
  484. package/ref-monty/crates/monty/test_cases/args__dict_pop_too_many.py +0 -3
  485. package/ref-monty/crates/monty/test_cases/args__dict_values_with_args.py +0 -3
  486. package/ref-monty/crates/monty/test_cases/args__id_too_many.py +0 -2
  487. package/ref-monty/crates/monty/test_cases/args__len_no_args.py +0 -2
  488. package/ref-monty/crates/monty/test_cases/args__len_too_many.py +0 -2
  489. package/ref-monty/crates/monty/test_cases/args__len_type_error_int.py +0 -9
  490. package/ref-monty/crates/monty/test_cases/args__len_type_error_none.py +0 -9
  491. package/ref-monty/crates/monty/test_cases/args__list_append_no_args.py +0 -3
  492. package/ref-monty/crates/monty/test_cases/args__list_append_too_many.py +0 -3
  493. package/ref-monty/crates/monty/test_cases/args__list_insert_too_few.py +0 -3
  494. package/ref-monty/crates/monty/test_cases/args__list_insert_too_many.py +0 -3
  495. package/ref-monty/crates/monty/test_cases/args__repr_no_args.py +0 -2
  496. package/ref-monty/crates/monty/test_cases/arith__div_zero_float.py +0 -2
  497. package/ref-monty/crates/monty/test_cases/arith__div_zero_int.py +0 -2
  498. package/ref-monty/crates/monty/test_cases/arith__floordiv_zero_float.py +0 -2
  499. package/ref-monty/crates/monty/test_cases/arith__floordiv_zero_int.py +0 -2
  500. package/ref-monty/crates/monty/test_cases/arith__pow_zero_neg.py +0 -2
  501. package/ref-monty/crates/monty/test_cases/arith__pow_zero_neg_builtin.py +0 -9
  502. package/ref-monty/crates/monty/test_cases/assert__expr_fail.py +0 -2
  503. package/ref-monty/crates/monty/test_cases/assert__fail.py +0 -2
  504. package/ref-monty/crates/monty/test_cases/assert__fail_msg.py +0 -2
  505. package/ref-monty/crates/monty/test_cases/assert__fn_fail.py +0 -3
  506. package/ref-monty/crates/monty/test_cases/assert__ops.py +0 -11
  507. package/ref-monty/crates/monty/test_cases/async__asyncio_run.py +0 -47
  508. package/ref-monty/crates/monty/test_cases/async__basic.py +0 -10
  509. package/ref-monty/crates/monty/test_cases/async__closure.py +0 -14
  510. package/ref-monty/crates/monty/test_cases/async__double_await_coroutine.py +0 -16
  511. package/ref-monty/crates/monty/test_cases/async__exception.py +0 -10
  512. package/ref-monty/crates/monty/test_cases/async__ext_call.py +0 -73
  513. package/ref-monty/crates/monty/test_cases/async__gather_all.py +0 -85
  514. package/ref-monty/crates/monty/test_cases/async__nested_await.py +0 -15
  515. package/ref-monty/crates/monty/test_cases/async__nested_gather_ext.py +0 -37
  516. package/ref-monty/crates/monty/test_cases/async__not_awaitable.py +0 -10
  517. package/ref-monty/crates/monty/test_cases/async__not_imported.py +0 -14
  518. package/ref-monty/crates/monty/test_cases/async__recursion_depth_isolation.py +0 -27
  519. package/ref-monty/crates/monty/test_cases/async__return_types.py +0 -31
  520. package/ref-monty/crates/monty/test_cases/async__sequential.py +0 -16
  521. package/ref-monty/crates/monty/test_cases/async__traceback.py +0 -19
  522. package/ref-monty/crates/monty/test_cases/async__with_args.py +0 -14
  523. package/ref-monty/crates/monty/test_cases/attr__get_int_error.py +0 -9
  524. package/ref-monty/crates/monty/test_cases/attr__get_list_error.py +0 -9
  525. package/ref-monty/crates/monty/test_cases/attr__set_frozen_nonfield.py +0 -12
  526. package/ref-monty/crates/monty/test_cases/attr__set_int_error.py +0 -10
  527. package/ref-monty/crates/monty/test_cases/attr__set_list_error.py +0 -10
  528. package/ref-monty/crates/monty/test_cases/bench__kitchen_sink.py +0 -68
  529. package/ref-monty/crates/monty/test_cases/bool__ops.py +0 -20
  530. package/ref-monty/crates/monty/test_cases/builtin__add_type_error.py +0 -2
  531. package/ref-monty/crates/monty/test_cases/builtin__filter.py +0 -62
  532. package/ref-monty/crates/monty/test_cases/builtin__filter_not_iterable.py +0 -11
  533. package/ref-monty/crates/monty/test_cases/builtin__getattr.py +0 -84
  534. package/ref-monty/crates/monty/test_cases/builtin__iter_funcs.py +0 -42
  535. package/ref-monty/crates/monty/test_cases/builtin__iter_next.py +0 -66
  536. package/ref-monty/crates/monty/test_cases/builtin__map.py +0 -74
  537. package/ref-monty/crates/monty/test_cases/builtin__map_not_iterable.py +0 -11
  538. package/ref-monty/crates/monty/test_cases/builtin__math_funcs.py +0 -154
  539. package/ref-monty/crates/monty/test_cases/builtin__more_iter_funcs.py +0 -148
  540. package/ref-monty/crates/monty/test_cases/builtin__next_stop_iteration.py +0 -10
  541. package/ref-monty/crates/monty/test_cases/builtin__print_invalid_kwarg.py +0 -9
  542. package/ref-monty/crates/monty/test_cases/builtin__print_kwargs.py +0 -12
  543. package/ref-monty/crates/monty/test_cases/builtin__repr.py +0 -3
  544. package/ref-monty/crates/monty/test_cases/builtin__string_funcs.py +0 -73
  545. package/ref-monty/crates/monty/test_cases/bytes__decode_invalid_utf8.py +0 -18
  546. package/ref-monty/crates/monty/test_cases/bytes__endswith_str_error.py +0 -10
  547. package/ref-monty/crates/monty/test_cases/bytes__getitem_index_error.py +0 -10
  548. package/ref-monty/crates/monty/test_cases/bytes__index_start_gt_end.py +0 -10
  549. package/ref-monty/crates/monty/test_cases/bytes__methods.py +0 -394
  550. package/ref-monty/crates/monty/test_cases/bytes__negative_count.py +0 -9
  551. package/ref-monty/crates/monty/test_cases/bytes__ops.py +0 -90
  552. package/ref-monty/crates/monty/test_cases/bytes__startswith_str_error.py +0 -10
  553. package/ref-monty/crates/monty/test_cases/call_object.py +0 -3
  554. package/ref-monty/crates/monty/test_cases/chain_comparison__all.py +0 -79
  555. package/ref-monty/crates/monty/test_cases/closure__param_shadows_outer.py +0 -81
  556. package/ref-monty/crates/monty/test_cases/closure__pep448.py +0 -203
  557. package/ref-monty/crates/monty/test_cases/closure__undefined_nonlocal.py +0 -13
  558. package/ref-monty/crates/monty/test_cases/compare__mixed_types.py +0 -120
  559. package/ref-monty/crates/monty/test_cases/comprehension__all.py +0 -208
  560. package/ref-monty/crates/monty/test_cases/comprehension__scope.py +0 -7
  561. package/ref-monty/crates/monty/test_cases/comprehension__unbound_local.py +0 -14
  562. package/ref-monty/crates/monty/test_cases/dataclass__basic.py +0 -238
  563. package/ref-monty/crates/monty/test_cases/dataclass__call_field_error.py +0 -12
  564. package/ref-monty/crates/monty/test_cases/dataclass__frozen_set_error.py +0 -12
  565. package/ref-monty/crates/monty/test_cases/dataclass__get_missing_attr_error.py +0 -11
  566. package/ref-monty/crates/monty/test_cases/dict__get_unhashable_key.py +0 -3
  567. package/ref-monty/crates/monty/test_cases/dict__literal_unhashable_key.py +0 -2
  568. package/ref-monty/crates/monty/test_cases/dict__method_pop_missing_error.py +0 -3
  569. package/ref-monty/crates/monty/test_cases/dict__methods.py +0 -151
  570. package/ref-monty/crates/monty/test_cases/dict__ops.py +0 -133
  571. package/ref-monty/crates/monty/test_cases/dict__pop_unhashable_key.py +0 -4
  572. package/ref-monty/crates/monty/test_cases/dict__popitem_empty.py +0 -9
  573. package/ref-monty/crates/monty/test_cases/dict__subscript_missing_key.py +0 -3
  574. package/ref-monty/crates/monty/test_cases/dict__unhashable_dict_key.py +0 -2
  575. package/ref-monty/crates/monty/test_cases/dict__unhashable_list_key.py +0 -2
  576. package/ref-monty/crates/monty/test_cases/dict__unpack_type_error.py +0 -2
  577. package/ref-monty/crates/monty/test_cases/dict__views.py +0 -165
  578. package/ref-monty/crates/monty/test_cases/edge__all.py +0 -26
  579. package/ref-monty/crates/monty/test_cases/edge__float_int_mod.py +0 -2
  580. package/ref-monty/crates/monty/test_cases/edge__int_float_mod.py +0 -2
  581. package/ref-monty/crates/monty/test_cases/exc__args.py +0 -16
  582. package/ref-monty/crates/monty/test_cases/exc__str.py +0 -15
  583. package/ref-monty/crates/monty/test_cases/execute_ok__all.py +0 -54
  584. package/ref-monty/crates/monty/test_cases/execute_raise__error_instance_str.py +0 -2
  585. package/ref-monty/crates/monty/test_cases/execute_raise__error_no_args.py +0 -2
  586. package/ref-monty/crates/monty/test_cases/execute_raise__error_string_arg.py +0 -2
  587. package/ref-monty/crates/monty/test_cases/execute_raise__error_string_arg_quotes.py +0 -2
  588. package/ref-monty/crates/monty/test_cases/execute_raise__error_type.py +0 -2
  589. package/ref-monty/crates/monty/test_cases/execute_raise__raise_instance_via_var.py +0 -4
  590. package/ref-monty/crates/monty/test_cases/execute_raise__raise_list.py +0 -2
  591. package/ref-monty/crates/monty/test_cases/execute_raise__raise_number.py +0 -2
  592. package/ref-monty/crates/monty/test_cases/execute_raise__raise_type_call_via_var.py +0 -4
  593. package/ref-monty/crates/monty/test_cases/execute_raise__raise_type_direct.py +0 -3
  594. package/ref-monty/crates/monty/test_cases/execute_raise__raise_type_via_var.py +0 -4
  595. package/ref-monty/crates/monty/test_cases/ext_call__arg_side_effect_bug.py +0 -22
  596. package/ref-monty/crates/monty/test_cases/ext_call__augmented.py +0 -17
  597. package/ref-monty/crates/monty/test_cases/ext_call__augmented_refcount_bug.py +0 -7
  598. package/ref-monty/crates/monty/test_cases/ext_call__bare_raise_after_resume.py +0 -34
  599. package/ref-monty/crates/monty/test_cases/ext_call__basic.py +0 -99
  600. package/ref-monty/crates/monty/test_cases/ext_call__boolean.py +0 -37
  601. package/ref-monty/crates/monty/test_cases/ext_call__boolean_side_effect_hang.py +0 -17
  602. package/ref-monty/crates/monty/test_cases/ext_call__closure_bug.py +0 -16
  603. package/ref-monty/crates/monty/test_cases/ext_call__comparison.py +0 -26
  604. package/ref-monty/crates/monty/test_cases/ext_call__deep_call_stack.py +0 -18
  605. package/ref-monty/crates/monty/test_cases/ext_call__elif.py +0 -171
  606. package/ref-monty/crates/monty/test_cases/ext_call__exc.py +0 -4
  607. package/ref-monty/crates/monty/test_cases/ext_call__exc_deep_stack.py +0 -39
  608. package/ref-monty/crates/monty/test_cases/ext_call__exc_in_function.py +0 -17
  609. package/ref-monty/crates/monty/test_cases/ext_call__exc_nested_functions.py +0 -31
  610. package/ref-monty/crates/monty/test_cases/ext_call__ext_exc.py +0 -171
  611. package/ref-monty/crates/monty/test_cases/ext_call__for.py +0 -114
  612. package/ref-monty/crates/monty/test_cases/ext_call__fstring.py +0 -12
  613. package/ref-monty/crates/monty/test_cases/ext_call__if.py +0 -135
  614. package/ref-monty/crates/monty/test_cases/ext_call__if_condition.py +0 -37
  615. package/ref-monty/crates/monty/test_cases/ext_call__in_closure.py +0 -14
  616. package/ref-monty/crates/monty/test_cases/ext_call__in_function.py +0 -40
  617. package/ref-monty/crates/monty/test_cases/ext_call__in_function_simple.py +0 -7
  618. package/ref-monty/crates/monty/test_cases/ext_call__literals.py +0 -17
  619. package/ref-monty/crates/monty/test_cases/ext_call__multi_in_func.py +0 -32
  620. package/ref-monty/crates/monty/test_cases/ext_call__name_lookup.py +0 -69
  621. package/ref-monty/crates/monty/test_cases/ext_call__name_lookup_undefined.py +0 -4
  622. package/ref-monty/crates/monty/test_cases/ext_call__nested_calls.py +0 -14
  623. package/ref-monty/crates/monty/test_cases/ext_call__recursion_bug.py +0 -19
  624. package/ref-monty/crates/monty/test_cases/ext_call__return.py +0 -28
  625. package/ref-monty/crates/monty/test_cases/ext_call__side_effects.py +0 -25
  626. package/ref-monty/crates/monty/test_cases/ext_call__subscript.py +0 -7
  627. package/ref-monty/crates/monty/test_cases/ext_call__ternary.py +0 -28
  628. package/ref-monty/crates/monty/test_cases/ext_call__try.py +0 -280
  629. package/ref-monty/crates/monty/test_cases/ext_call__try_simple.py +0 -10
  630. package/ref-monty/crates/monty/test_cases/ext_call__unary.py +0 -13
  631. package/ref-monty/crates/monty/test_cases/frozenset__ops.py +0 -178
  632. package/ref-monty/crates/monty/test_cases/fstring__all.py +0 -236
  633. package/ref-monty/crates/monty/test_cases/fstring__error_eq_align_on_str.py +0 -3
  634. package/ref-monty/crates/monty/test_cases/fstring__error_float_f_on_str.py +0 -3
  635. package/ref-monty/crates/monty/test_cases/fstring__error_int_d_on_float.py +0 -3
  636. package/ref-monty/crates/monty/test_cases/fstring__error_int_d_on_str.py +0 -3
  637. package/ref-monty/crates/monty/test_cases/fstring__error_invalid_spec.py +0 -4
  638. package/ref-monty/crates/monty/test_cases/fstring__error_invalid_spec_dynamic.py +0 -4
  639. package/ref-monty/crates/monty/test_cases/fstring__error_invalid_spec_str.py +0 -4
  640. package/ref-monty/crates/monty/test_cases/fstring__error_str_s_on_int.py +0 -3
  641. package/ref-monty/crates/monty/test_cases/function__call_duplicate_kwargs.py +0 -6
  642. package/ref-monty/crates/monty/test_cases/function__call_unpack.py +0 -42
  643. package/ref-monty/crates/monty/test_cases/function__defaults.py +0 -117
  644. package/ref-monty/crates/monty/test_cases/function__err_duplicate_arg.py +0 -7
  645. package/ref-monty/crates/monty/test_cases/function__err_duplicate_first_arg.py +0 -7
  646. package/ref-monty/crates/monty/test_cases/function__err_duplicate_kwarg_cleanup.py +0 -9
  647. package/ref-monty/crates/monty/test_cases/function__err_kwonly_as_positional.py +0 -7
  648. package/ref-monty/crates/monty/test_cases/function__err_missing_all_posonly.py +0 -7
  649. package/ref-monty/crates/monty/test_cases/function__err_missing_heap_cleanup.py +0 -9
  650. package/ref-monty/crates/monty/test_cases/function__err_missing_kwonly.py +0 -7
  651. package/ref-monty/crates/monty/test_cases/function__err_missing_posonly_with_kwarg.py +0 -7
  652. package/ref-monty/crates/monty/test_cases/function__err_missing_with_posonly.py +0 -7
  653. package/ref-monty/crates/monty/test_cases/function__err_posonly_as_kwarg.py +0 -7
  654. package/ref-monty/crates/monty/test_cases/function__err_posonly_first_as_kwarg.py +0 -7
  655. package/ref-monty/crates/monty/test_cases/function__err_too_many_posonly.py +0 -7
  656. package/ref-monty/crates/monty/test_cases/function__err_too_many_with_kwonly.py +0 -7
  657. package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg.py +0 -7
  658. package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg_cleanup.py +0 -9
  659. package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg_quote.py +0 -13
  660. package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg_simple.py +0 -7
  661. package/ref-monty/crates/monty/test_cases/function__err_unpack_duplicate_arg.py +0 -6
  662. package/ref-monty/crates/monty/test_cases/function__err_unpack_duplicate_heap.py +0 -8
  663. package/ref-monty/crates/monty/test_cases/function__err_unpack_int.py +0 -6
  664. package/ref-monty/crates/monty/test_cases/function__err_unpack_nonstring_key.py +0 -6
  665. package/ref-monty/crates/monty/test_cases/function__err_unpack_not_mapping.py +0 -6
  666. package/ref-monty/crates/monty/test_cases/function__kwargs_unpacking.py +0 -173
  667. package/ref-monty/crates/monty/test_cases/function__ops.py +0 -294
  668. package/ref-monty/crates/monty/test_cases/function__return_none.py +0 -42
  669. package/ref-monty/crates/monty/test_cases/function__signatures.py +0 -47
  670. package/ref-monty/crates/monty/test_cases/function__too_few_args_all.py +0 -6
  671. package/ref-monty/crates/monty/test_cases/function__too_few_args_one.py +0 -6
  672. package/ref-monty/crates/monty/test_cases/function__too_few_args_two.py +0 -6
  673. package/ref-monty/crates/monty/test_cases/function__too_many_args_one.py +0 -6
  674. package/ref-monty/crates/monty/test_cases/function__too_many_args_two.py +0 -6
  675. package/ref-monty/crates/monty/test_cases/function__too_many_args_zero.py +0 -6
  676. package/ref-monty/crates/monty/test_cases/global__error_assigned_before.py +0 -7
  677. package/ref-monty/crates/monty/test_cases/global__ops.py +0 -163
  678. package/ref-monty/crates/monty/test_cases/hash__dict_unhashable.py +0 -2
  679. package/ref-monty/crates/monty/test_cases/hash__list_unhashable.py +0 -2
  680. package/ref-monty/crates/monty/test_cases/hash__ops.py +0 -153
  681. package/ref-monty/crates/monty/test_cases/id__bytes_literals_distinct.py +0 -3
  682. package/ref-monty/crates/monty/test_cases/id__int_copy_distinct.py +0 -5
  683. package/ref-monty/crates/monty/test_cases/id__is_number_is_number.py +0 -3
  684. package/ref-monty/crates/monty/test_cases/id__non_overlapping_lifetimes_distinct_types.py +0 -10
  685. package/ref-monty/crates/monty/test_cases/id__non_overlapping_lifetimes_same_types.py +0 -6
  686. package/ref-monty/crates/monty/test_cases/id__ops.py +0 -97
  687. package/ref-monty/crates/monty/test_cases/id__str_literals_same.py +0 -3
  688. package/ref-monty/crates/monty/test_cases/if__elif_else.py +0 -207
  689. package/ref-monty/crates/monty/test_cases/if__raise_elif.py +0 -11
  690. package/ref-monty/crates/monty/test_cases/if__raise_else.py +0 -13
  691. package/ref-monty/crates/monty/test_cases/if__raise_if.py +0 -9
  692. package/ref-monty/crates/monty/test_cases/if__raise_in_elif_condition.py +0 -18
  693. package/ref-monty/crates/monty/test_cases/if__raise_in_if_condition.py +0 -16
  694. package/ref-monty/crates/monty/test_cases/if_else_expr__all.py +0 -55
  695. package/ref-monty/crates/monty/test_cases/import__error_cannot_import.py +0 -9
  696. package/ref-monty/crates/monty/test_cases/import__error_module_not_found.py +0 -9
  697. package/ref-monty/crates/monty/test_cases/import__local_scope.py +0 -68
  698. package/ref-monty/crates/monty/test_cases/import__os.py +0 -25
  699. package/ref-monty/crates/monty/test_cases/import__relative_error.py +0 -9
  700. package/ref-monty/crates/monty/test_cases/import__relative_no_module_error.py +0 -9
  701. package/ref-monty/crates/monty/test_cases/import__runtime_error_when_executed.py +0 -14
  702. package/ref-monty/crates/monty/test_cases/import__star_error.py +0 -11
  703. package/ref-monty/crates/monty/test_cases/import__sys.py +0 -47
  704. package/ref-monty/crates/monty/test_cases/import__sys_monty.py +0 -28
  705. package/ref-monty/crates/monty/test_cases/import__type_checking_guard.py +0 -37
  706. package/ref-monty/crates/monty/test_cases/import__typing.py +0 -25
  707. package/ref-monty/crates/monty/test_cases/import__typing_type_ignore.py +0 -4
  708. package/ref-monty/crates/monty/test_cases/int__bigint.py +0 -467
  709. package/ref-monty/crates/monty/test_cases/int__bigint_errors.py +0 -260
  710. package/ref-monty/crates/monty/test_cases/int__ops.py +0 -219
  711. package/ref-monty/crates/monty/test_cases/int__overflow_division.py +0 -84
  712. package/ref-monty/crates/monty/test_cases/is_variant__all.py +0 -36
  713. package/ref-monty/crates/monty/test_cases/isinstance__arg2_list_error.py +0 -2
  714. package/ref-monty/crates/monty/test_cases/isinstance__arg2_type_error.py +0 -2
  715. package/ref-monty/crates/monty/test_cases/iter__dict_mutation.py +0 -4
  716. package/ref-monty/crates/monty/test_cases/iter__for.py +0 -243
  717. package/ref-monty/crates/monty/test_cases/iter__for_loop_unpacking.py +0 -66
  718. package/ref-monty/crates/monty/test_cases/iter__generator_expr.py +0 -20
  719. package/ref-monty/crates/monty/test_cases/iter__generator_expr_type.py +0 -7
  720. package/ref-monty/crates/monty/test_cases/iter__not_iterable.py +0 -3
  721. package/ref-monty/crates/monty/test_cases/lambda__all.py +0 -145
  722. package/ref-monty/crates/monty/test_cases/list__extend_not_iterable.py +0 -7
  723. package/ref-monty/crates/monty/test_cases/list__getitem_out_of_bounds.py +0 -3
  724. package/ref-monty/crates/monty/test_cases/list__index_not_found.py +0 -9
  725. package/ref-monty/crates/monty/test_cases/list__index_start_gt_end.py +0 -10
  726. package/ref-monty/crates/monty/test_cases/list__ops.py +0 -473
  727. package/ref-monty/crates/monty/test_cases/list__pop_empty.py +0 -9
  728. package/ref-monty/crates/monty/test_cases/list__pop_out_of_range.py +0 -9
  729. package/ref-monty/crates/monty/test_cases/list__pop_type_error.py +0 -9
  730. package/ref-monty/crates/monty/test_cases/list__remove_not_found.py +0 -9
  731. package/ref-monty/crates/monty/test_cases/list__setitem_dict_index.py +0 -13
  732. package/ref-monty/crates/monty/test_cases/list__setitem_huge_int_index.py +0 -13
  733. package/ref-monty/crates/monty/test_cases/list__setitem_index_error.py +0 -10
  734. package/ref-monty/crates/monty/test_cases/list__setitem_type_error.py +0 -10
  735. package/ref-monty/crates/monty/test_cases/list__unpack_type_error.py +0 -2
  736. package/ref-monty/crates/monty/test_cases/longint__index_error.py +0 -3
  737. package/ref-monty/crates/monty/test_cases/longint__repeat_error.py +0 -3
  738. package/ref-monty/crates/monty/test_cases/loop__break_continue.py +0 -113
  739. package/ref-monty/crates/monty/test_cases/loop__break_finally.py +0 -69
  740. package/ref-monty/crates/monty/test_cases/loop__break_in_function_error.py +0 -13
  741. package/ref-monty/crates/monty/test_cases/loop__break_in_if_error.py +0 -11
  742. package/ref-monty/crates/monty/test_cases/loop__break_nested_except_clears.py +0 -55
  743. package/ref-monty/crates/monty/test_cases/loop__break_outside_error.py +0 -9
  744. package/ref-monty/crates/monty/test_cases/loop__continue_finally.py +0 -81
  745. package/ref-monty/crates/monty/test_cases/loop__continue_in_function_error.py +0 -13
  746. package/ref-monty/crates/monty/test_cases/loop__continue_in_if_error.py +0 -11
  747. package/ref-monty/crates/monty/test_cases/loop__continue_nested_except_clears.py +0 -60
  748. package/ref-monty/crates/monty/test_cases/loop__continue_outside_error.py +0 -9
  749. package/ref-monty/crates/monty/test_cases/math__acos_domain_error.py +0 -11
  750. package/ref-monty/crates/monty/test_cases/math__acosh_domain_error.py +0 -11
  751. package/ref-monty/crates/monty/test_cases/math__asin_domain_error.py +0 -11
  752. package/ref-monty/crates/monty/test_cases/math__atanh_domain_error.py +0 -11
  753. package/ref-monty/crates/monty/test_cases/math__cos_inf_error.py +0 -11
  754. package/ref-monty/crates/monty/test_cases/math__cosh_overflow_error.py +0 -11
  755. package/ref-monty/crates/monty/test_cases/math__exp_overflow_error.py +0 -11
  756. package/ref-monty/crates/monty/test_cases/math__factorial_float_error.py +0 -11
  757. package/ref-monty/crates/monty/test_cases/math__factorial_negative_error.py +0 -11
  758. package/ref-monty/crates/monty/test_cases/math__floor_inf_error.py +0 -11
  759. package/ref-monty/crates/monty/test_cases/math__floor_nan_error.py +0 -11
  760. package/ref-monty/crates/monty/test_cases/math__floor_str_error.py +0 -11
  761. package/ref-monty/crates/monty/test_cases/math__fmod_inf_error.py +0 -11
  762. package/ref-monty/crates/monty/test_cases/math__gamma_neg_int_error.py +0 -11
  763. package/ref-monty/crates/monty/test_cases/math__gcd_float_error.py +0 -11
  764. package/ref-monty/crates/monty/test_cases/math__isqrt_negative_error.py +0 -11
  765. package/ref-monty/crates/monty/test_cases/math__ldexp_overflow_error.py +0 -11
  766. package/ref-monty/crates/monty/test_cases/math__log1p_domain_error.py +0 -11
  767. package/ref-monty/crates/monty/test_cases/math__log_base1_error.py +0 -11
  768. package/ref-monty/crates/monty/test_cases/math__log_zero_error.py +0 -11
  769. package/ref-monty/crates/monty/test_cases/math__module.py +0 -1432
  770. package/ref-monty/crates/monty/test_cases/math__pow_domain_error.py +0 -11
  771. package/ref-monty/crates/monty/test_cases/math__sin_inf_error.py +0 -11
  772. package/ref-monty/crates/monty/test_cases/math__sqrt_negative_error.py +0 -11
  773. package/ref-monty/crates/monty/test_cases/math__tan_inf_error.py +0 -11
  774. package/ref-monty/crates/monty/test_cases/math__trunc_str_error.py +0 -11
  775. package/ref-monty/crates/monty/test_cases/method__args_kwargs_unpacking.py +0 -259
  776. package/ref-monty/crates/monty/test_cases/name_error__unbound_local_func.py +0 -19
  777. package/ref-monty/crates/monty/test_cases/name_error__unbound_local_module.py +0 -12
  778. package/ref-monty/crates/monty/test_cases/name_error__undefined_call_chained.py +0 -9
  779. package/ref-monty/crates/monty/test_cases/name_error__undefined_call_in_expr.py +0 -9
  780. package/ref-monty/crates/monty/test_cases/name_error__undefined_call_in_function.py +0 -16
  781. package/ref-monty/crates/monty/test_cases/name_error__undefined_call_with_args.py +0 -9
  782. package/ref-monty/crates/monty/test_cases/name_error__undefined_global.py +0 -10
  783. package/ref-monty/crates/monty/test_cases/namedtuple__missing_attr.py +0 -11
  784. package/ref-monty/crates/monty/test_cases/namedtuple__ops.py +0 -34
  785. package/ref-monty/crates/monty/test_cases/nonlocal__error_module_level.py +0 -3
  786. package/ref-monty/crates/monty/test_cases/nonlocal__ops.py +0 -353
  787. package/ref-monty/crates/monty/test_cases/os__environ.py +0 -40
  788. package/ref-monty/crates/monty/test_cases/os__getenv_key_list_error.py +0 -5
  789. package/ref-monty/crates/monty/test_cases/os__getenv_key_type_error.py +0 -5
  790. package/ref-monty/crates/monty/test_cases/parse_error__complex.py +0 -3
  791. package/ref-monty/crates/monty/test_cases/pathlib__import.py +0 -11
  792. package/ref-monty/crates/monty/test_cases/pathlib__os.py +0 -136
  793. package/ref-monty/crates/monty/test_cases/pathlib__os_read_error.py +0 -12
  794. package/ref-monty/crates/monty/test_cases/pathlib__pure.py +0 -81
  795. package/ref-monty/crates/monty/test_cases/pyobject__cycle_dict_self.py +0 -5
  796. package/ref-monty/crates/monty/test_cases/pyobject__cycle_list_dict.py +0 -6
  797. package/ref-monty/crates/monty/test_cases/pyobject__cycle_list_self.py +0 -5
  798. package/ref-monty/crates/monty/test_cases/pyobject__cycle_multiple_refs.py +0 -6
  799. package/ref-monty/crates/monty/test_cases/range__error_no_args.py +0 -2
  800. package/ref-monty/crates/monty/test_cases/range__error_step_zero.py +0 -2
  801. package/ref-monty/crates/monty/test_cases/range__error_too_many_args.py +0 -2
  802. package/ref-monty/crates/monty/test_cases/range__getitem_index_error.py +0 -10
  803. package/ref-monty/crates/monty/test_cases/range__ops.py +0 -236
  804. package/ref-monty/crates/monty/test_cases/re__basic.py +0 -756
  805. package/ref-monty/crates/monty/test_cases/re__grouping.py +0 -241
  806. package/ref-monty/crates/monty/test_cases/re__match.py +0 -148
  807. package/ref-monty/crates/monty/test_cases/recursion__deep_drop.py +0 -26
  808. package/ref-monty/crates/monty/test_cases/recursion__deep_eq.py +0 -23
  809. package/ref-monty/crates/monty/test_cases/recursion__deep_hash.py +0 -46
  810. package/ref-monty/crates/monty/test_cases/recursion__deep_repr.py +0 -12
  811. package/ref-monty/crates/monty/test_cases/recursion__function_depth.py +0 -13
  812. package/ref-monty/crates/monty/test_cases/refcount__cycle_mutual_reference.py +0 -18
  813. package/ref-monty/crates/monty/test_cases/refcount__cycle_self_reference.py +0 -12
  814. package/ref-monty/crates/monty/test_cases/refcount__dict_basic.py +0 -5
  815. package/ref-monty/crates/monty/test_cases/refcount__dict_get.py +0 -5
  816. package/ref-monty/crates/monty/test_cases/refcount__dict_keys_and.py +0 -14
  817. package/ref-monty/crates/monty/test_cases/refcount__dict_overwrite.py +0 -6
  818. package/ref-monty/crates/monty/test_cases/refcount__gather_cleanup.py +0 -16
  819. package/ref-monty/crates/monty/test_cases/refcount__gather_exception.py +0 -18
  820. package/ref-monty/crates/monty/test_cases/refcount__gather_nested_cancel.py +0 -25
  821. package/ref-monty/crates/monty/test_cases/refcount__immediate_skipped.py +0 -4
  822. package/ref-monty/crates/monty/test_cases/refcount__kwargs_unpacking.py +0 -27
  823. package/ref-monty/crates/monty/test_cases/refcount__list_append_multiple.py +0 -6
  824. package/ref-monty/crates/monty/test_cases/refcount__list_append_ref.py +0 -5
  825. package/ref-monty/crates/monty/test_cases/refcount__list_concat.py +0 -5
  826. package/ref-monty/crates/monty/test_cases/refcount__list_getitem.py +0 -5
  827. package/ref-monty/crates/monty/test_cases/refcount__list_iadd.py +0 -5
  828. package/ref-monty/crates/monty/test_cases/refcount__nested_list.py +0 -4
  829. package/ref-monty/crates/monty/test_cases/refcount__re_pattern_sub_error_paths.py +0 -37
  830. package/ref-monty/crates/monty/test_cases/refcount__re_search_match.py +0 -34
  831. package/ref-monty/crates/monty/test_cases/refcount__re_sub_error_paths.py +0 -31
  832. package/ref-monty/crates/monty/test_cases/refcount__shared_reference.py +0 -4
  833. package/ref-monty/crates/monty/test_cases/refcount__single_list.py +0 -3
  834. package/ref-monty/crates/monty/test_cases/repr__cycle_detection.py +0 -24
  835. package/ref-monty/crates/monty/test_cases/set__ops.py +0 -191
  836. package/ref-monty/crates/monty/test_cases/set__review_bugs.py +0 -35
  837. package/ref-monty/crates/monty/test_cases/set__unpack_type_error.py +0 -2
  838. package/ref-monty/crates/monty/test_cases/slice__invalid_indices.py +0 -2
  839. package/ref-monty/crates/monty/test_cases/slice__kwargs.py +0 -9
  840. package/ref-monty/crates/monty/test_cases/slice__no_args.py +0 -9
  841. package/ref-monty/crates/monty/test_cases/slice__ops.py +0 -149
  842. package/ref-monty/crates/monty/test_cases/slice__step_zero.py +0 -9
  843. package/ref-monty/crates/monty/test_cases/slice__step_zero_bytes.py +0 -9
  844. package/ref-monty/crates/monty/test_cases/slice__step_zero_range.py +0 -9
  845. package/ref-monty/crates/monty/test_cases/slice__step_zero_str.py +0 -9
  846. package/ref-monty/crates/monty/test_cases/slice__step_zero_tuple.py +0 -9
  847. package/ref-monty/crates/monty/test_cases/slice__too_many_args.py +0 -9
  848. package/ref-monty/crates/monty/test_cases/str__getitem_index_error.py +0 -10
  849. package/ref-monty/crates/monty/test_cases/str__index_not_found.py +0 -9
  850. package/ref-monty/crates/monty/test_cases/str__join_no_args.py +0 -9
  851. package/ref-monty/crates/monty/test_cases/str__join_non_string.py +0 -9
  852. package/ref-monty/crates/monty/test_cases/str__join_not_iterable.py +0 -9
  853. package/ref-monty/crates/monty/test_cases/str__join_too_many_args.py +0 -9
  854. package/ref-monty/crates/monty/test_cases/str__methods.py +0 -327
  855. package/ref-monty/crates/monty/test_cases/str__ops.py +0 -162
  856. package/ref-monty/crates/monty/test_cases/str__partition_empty.py +0 -9
  857. package/ref-monty/crates/monty/test_cases/str__rsplit_empty_sep.py +0 -9
  858. package/ref-monty/crates/monty/test_cases/str__split_empty_sep.py +0 -9
  859. package/ref-monty/crates/monty/test_cases/sys__types.py +0 -7
  860. package/ref-monty/crates/monty/test_cases/traceback__division_error.py +0 -30
  861. package/ref-monty/crates/monty/test_cases/traceback__index_error.py +0 -17
  862. package/ref-monty/crates/monty/test_cases/traceback__insert_as_int.py +0 -10
  863. package/ref-monty/crates/monty/test_cases/traceback__nested_call.py +0 -29
  864. package/ref-monty/crates/monty/test_cases/traceback__nonlocal_module_scope.py +0 -10
  865. package/ref-monty/crates/monty/test_cases/traceback__nonlocal_unbound.py +0 -24
  866. package/ref-monty/crates/monty/test_cases/traceback__range_as_int.py +0 -9
  867. package/ref-monty/crates/monty/test_cases/traceback__recursion_error.py +0 -23
  868. package/ref-monty/crates/monty/test_cases/traceback__set_mutation.py +0 -11
  869. package/ref-monty/crates/monty/test_cases/traceback__undefined_attr_call.py +0 -16
  870. package/ref-monty/crates/monty/test_cases/traceback__undefined_call.py +0 -16
  871. package/ref-monty/crates/monty/test_cases/traceback__undefined_raise.py +0 -16
  872. package/ref-monty/crates/monty/test_cases/try_except__all.py +0 -472
  873. package/ref-monty/crates/monty/test_cases/try_except__bare_raise_no_context.py +0 -2
  874. package/ref-monty/crates/monty/test_cases/try_except__invalid_type.py +0 -5
  875. package/ref-monty/crates/monty/test_cases/tuple__getitem_out_of_bounds.py +0 -3
  876. package/ref-monty/crates/monty/test_cases/tuple__index_not_found.py +0 -9
  877. package/ref-monty/crates/monty/test_cases/tuple__index_start_gt_end.py +0 -10
  878. package/ref-monty/crates/monty/test_cases/tuple__methods.py +0 -19
  879. package/ref-monty/crates/monty/test_cases/tuple__ops.py +0 -133
  880. package/ref-monty/crates/monty/test_cases/tuple__unpack_type_error.py +0 -2
  881. package/ref-monty/crates/monty/test_cases/type__builtin_attr_error.py +0 -9
  882. package/ref-monty/crates/monty/test_cases/type__bytes_negative.py +0 -2
  883. package/ref-monty/crates/monty/test_cases/type__cell_not_builtin.py +0 -9
  884. package/ref-monty/crates/monty/test_cases/type__exception_attr_error.py +0 -11
  885. package/ref-monty/crates/monty/test_cases/type__float_conversion_error.py +0 -2
  886. package/ref-monty/crates/monty/test_cases/type__float_repr_both_quotes.py +0 -9
  887. package/ref-monty/crates/monty/test_cases/type__float_repr_newline.py +0 -9
  888. package/ref-monty/crates/monty/test_cases/type__float_repr_single_quote.py +0 -9
  889. package/ref-monty/crates/monty/test_cases/type__int_conversion_error.py +0 -2
  890. package/ref-monty/crates/monty/test_cases/type__list_not_iterable.py +0 -2
  891. package/ref-monty/crates/monty/test_cases/type__non_builtin_name_error.py +0 -9
  892. package/ref-monty/crates/monty/test_cases/type__ops.py +0 -200
  893. package/ref-monty/crates/monty/test_cases/type__shadow_exc.py +0 -3
  894. package/ref-monty/crates/monty/test_cases/type__shadow_int.py +0 -9
  895. package/ref-monty/crates/monty/test_cases/type__shadow_len.py +0 -3
  896. package/ref-monty/crates/monty/test_cases/type__tuple_not_iterable.py +0 -2
  897. package/ref-monty/crates/monty/test_cases/type_error__int_add_list.py +0 -2
  898. package/ref-monty/crates/monty/test_cases/type_error__int_div_str.py +0 -2
  899. package/ref-monty/crates/monty/test_cases/type_error__int_floordiv_str.py +0 -2
  900. package/ref-monty/crates/monty/test_cases/type_error__int_iadd_str.py +0 -3
  901. package/ref-monty/crates/monty/test_cases/type_error__int_mod_str.py +0 -2
  902. package/ref-monty/crates/monty/test_cases/type_error__int_pow_str.py +0 -2
  903. package/ref-monty/crates/monty/test_cases/type_error__int_sub_str.py +0 -2
  904. package/ref-monty/crates/monty/test_cases/type_error__list_add_int.py +0 -2
  905. package/ref-monty/crates/monty/test_cases/type_error__list_add_str.py +0 -2
  906. package/ref-monty/crates/monty/test_cases/type_error__list_iadd_int.py +0 -6
  907. package/ref-monty/crates/monty/test_cases/type_error__str_add_int.py +0 -2
  908. package/ref-monty/crates/monty/test_cases/type_error__str_iadd_int.py +0 -3
  909. package/ref-monty/crates/monty/test_cases/type_error__unary_invert_str.py +0 -3
  910. package/ref-monty/crates/monty/test_cases/type_error__unary_minus_str.py +0 -4
  911. package/ref-monty/crates/monty/test_cases/type_error__unary_neg_str.py +0 -3
  912. package/ref-monty/crates/monty/test_cases/type_error__unary_plus_str.py +0 -4
  913. package/ref-monty/crates/monty/test_cases/typing__types.py +0 -24
  914. package/ref-monty/crates/monty/test_cases/unpack__nested.py +0 -48
  915. package/ref-monty/crates/monty/test_cases/unpack__non_sequence.py +0 -9
  916. package/ref-monty/crates/monty/test_cases/unpack__not_enough.py +0 -9
  917. package/ref-monty/crates/monty/test_cases/unpack__ops.py +0 -153
  918. package/ref-monty/crates/monty/test_cases/unpack__star_not_enough.py +0 -9
  919. package/ref-monty/crates/monty/test_cases/unpack__too_many.py +0 -9
  920. package/ref-monty/crates/monty/test_cases/version__cpython.py +0 -4
  921. package/ref-monty/crates/monty/test_cases/walrus__all.py +0 -178
  922. package/ref-monty/crates/monty/test_cases/while__all.py +0 -206
  923. package/ref-monty/crates/monty/tests/asyncio.rs +0 -764
  924. package/ref-monty/crates/monty/tests/binary_serde.rs +0 -185
  925. package/ref-monty/crates/monty/tests/bytecode_limits.rs +0 -248
  926. package/ref-monty/crates/monty/tests/datatest_runner.rs +0 -2029
  927. package/ref-monty/crates/monty/tests/inputs.rs +0 -420
  928. package/ref-monty/crates/monty/tests/json_serde.rs +0 -250
  929. package/ref-monty/crates/monty/tests/main.rs +0 -71
  930. package/ref-monty/crates/monty/tests/math_module.rs +0 -114
  931. package/ref-monty/crates/monty/tests/name_lookup.rs +0 -482
  932. package/ref-monty/crates/monty/tests/os_tests.rs +0 -459
  933. package/ref-monty/crates/monty/tests/parse_errors.rs +0 -441
  934. package/ref-monty/crates/monty/tests/print_writer.rs +0 -238
  935. package/ref-monty/crates/monty/tests/py_object.rs +0 -121
  936. package/ref-monty/crates/monty/tests/regex.rs +0 -90
  937. package/ref-monty/crates/monty/tests/repl.rs +0 -344
  938. package/ref-monty/crates/monty/tests/resource_limits.rs +0 -1826
  939. package/ref-monty/crates/monty/tests/try_from.rs +0 -167
  940. package/ref-monty/crates/monty-cli/Cargo.toml +0 -25
  941. package/ref-monty/crates/monty-cli/src/main.rs +0 -541
  942. package/ref-monty/crates/monty-js/.cargo/config.toml +0 -2
  943. package/ref-monty/crates/monty-js/.prettierignore +0 -8
  944. package/ref-monty/crates/monty-js/Cargo.toml +0 -32
  945. package/ref-monty/crates/monty-js/README.md +0 -207
  946. package/ref-monty/crates/monty-js/__test__/async.spec.ts +0 -350
  947. package/ref-monty/crates/monty-js/__test__/basic.spec.ts +0 -114
  948. package/ref-monty/crates/monty-js/__test__/exceptions.spec.ts +0 -427
  949. package/ref-monty/crates/monty-js/__test__/external.spec.ts +0 -354
  950. package/ref-monty/crates/monty-js/__test__/inputs.spec.ts +0 -143
  951. package/ref-monty/crates/monty-js/__test__/limits.spec.ts +0 -162
  952. package/ref-monty/crates/monty-js/__test__/package.json +0 -3
  953. package/ref-monty/crates/monty-js/__test__/print.spec.ts +0 -229
  954. package/ref-monty/crates/monty-js/__test__/repl.spec.ts +0 -34
  955. package/ref-monty/crates/monty-js/__test__/serialize.spec.ts +0 -205
  956. package/ref-monty/crates/monty-js/__test__/start.spec.ts +0 -443
  957. package/ref-monty/crates/monty-js/__test__/type_check.spec.ts +0 -147
  958. package/ref-monty/crates/monty-js/__test__/types.spec.ts +0 -319
  959. package/ref-monty/crates/monty-js/build.rs +0 -61
  960. package/ref-monty/crates/monty-js/index-header.d.ts +0 -3
  961. package/ref-monty/crates/monty-js/package-lock.json +0 -4694
  962. package/ref-monty/crates/monty-js/package.json +0 -100
  963. package/ref-monty/crates/monty-js/scripts/smoke-test.sh +0 -69
  964. package/ref-monty/crates/monty-js/smoke-test/package.json +0 -17
  965. package/ref-monty/crates/monty-js/smoke-test/test.ts +0 -171
  966. package/ref-monty/crates/monty-js/smoke-test/tsconfig.json +0 -11
  967. package/ref-monty/crates/monty-js/src/convert.rs +0 -648
  968. package/ref-monty/crates/monty-js/src/exceptions.rs +0 -293
  969. package/ref-monty/crates/monty-js/src/lib.rs +0 -41
  970. package/ref-monty/crates/monty-js/src/limits.rs +0 -53
  971. package/ref-monty/crates/monty-js/src/monty_cls.rs +0 -1407
  972. package/ref-monty/crates/monty-js/tsconfig.json +0 -17
  973. package/ref-monty/crates/monty-js/wrapper.ts +0 -701
  974. package/ref-monty/crates/monty-python/Cargo.toml +0 -38
  975. package/ref-monty/crates/monty-python/README.md +0 -134
  976. package/ref-monty/crates/monty-python/build.rs +0 -4
  977. package/ref-monty/crates/monty-python/example.py +0 -40
  978. package/ref-monty/crates/monty-python/exercise.py +0 -46
  979. package/ref-monty/crates/monty-python/pyproject.toml +0 -57
  980. package/ref-monty/crates/monty-python/python/pydantic_monty/__init__.py +0 -281
  981. package/ref-monty/crates/monty-python/python/pydantic_monty/_monty.pyi +0 -677
  982. package/ref-monty/crates/monty-python/python/pydantic_monty/os_access.py +0 -933
  983. package/ref-monty/crates/monty-python/python/pydantic_monty/py.typed +0 -0
  984. package/ref-monty/crates/monty-python/src/convert.rs +0 -273
  985. package/ref-monty/crates/monty-python/src/dataclass.rs +0 -461
  986. package/ref-monty/crates/monty-python/src/exceptions.rs +0 -557
  987. package/ref-monty/crates/monty-python/src/external.rs +0 -165
  988. package/ref-monty/crates/monty-python/src/lib.rs +0 -77
  989. package/ref-monty/crates/monty-python/src/limits.rs +0 -142
  990. package/ref-monty/crates/monty-python/src/monty_cls.rs +0 -1650
  991. package/ref-monty/crates/monty-python/src/repl.rs +0 -470
  992. package/ref-monty/crates/monty-python/src/serialization.rs +0 -761
  993. package/ref-monty/crates/monty-python/tests/test_async.py +0 -1201
  994. package/ref-monty/crates/monty-python/tests/test_basic.py +0 -66
  995. package/ref-monty/crates/monty-python/tests/test_dataclasses.py +0 -971
  996. package/ref-monty/crates/monty-python/tests/test_exceptions.py +0 -361
  997. package/ref-monty/crates/monty-python/tests/test_external.py +0 -367
  998. package/ref-monty/crates/monty-python/tests/test_inputs.py +0 -126
  999. package/ref-monty/crates/monty-python/tests/test_limits.py +0 -257
  1000. package/ref-monty/crates/monty-python/tests/test_os_access.py +0 -1286
  1001. package/ref-monty/crates/monty-python/tests/test_os_access_compat.py +0 -731
  1002. package/ref-monty/crates/monty-python/tests/test_os_access_raw.py +0 -483
  1003. package/ref-monty/crates/monty-python/tests/test_os_calls.py +0 -819
  1004. package/ref-monty/crates/monty-python/tests/test_print.py +0 -208
  1005. package/ref-monty/crates/monty-python/tests/test_re.py +0 -170
  1006. package/ref-monty/crates/monty-python/tests/test_readme_examples.py +0 -20
  1007. package/ref-monty/crates/monty-python/tests/test_repl.py +0 -749
  1008. package/ref-monty/crates/monty-python/tests/test_serialize.py +0 -284
  1009. package/ref-monty/crates/monty-python/tests/test_start.py +0 -346
  1010. package/ref-monty/crates/monty-python/tests/test_threading.py +0 -163
  1011. package/ref-monty/crates/monty-python/tests/test_type_check.py +0 -344
  1012. package/ref-monty/crates/monty-python/tests/test_types.py +0 -553
  1013. package/ref-monty/crates/monty-type-checking/Cargo.toml +0 -32
  1014. package/ref-monty/crates/monty-type-checking/src/db.rs +0 -116
  1015. package/ref-monty/crates/monty-type-checking/src/lib.rs +0 -4
  1016. package/ref-monty/crates/monty-type-checking/src/type_check.rs +0 -280
  1017. package/ref-monty/crates/monty-type-checking/tests/bad_types.py +0 -109
  1018. package/ref-monty/crates/monty-type-checking/tests/bad_types_output.txt +0 -21
  1019. package/ref-monty/crates/monty-type-checking/tests/good_types.py +0 -475
  1020. package/ref-monty/crates/monty-type-checking/tests/main.rs +0 -205
  1021. package/ref-monty/crates/monty-type-checking/tests/reveal_types.py +0 -56
  1022. package/ref-monty/crates/monty-type-checking/tests/reveal_types_output.txt +0 -41
  1023. package/ref-monty/crates/monty-typeshed/Cargo.toml +0 -29
  1024. package/ref-monty/crates/monty-typeshed/README.md +0 -11
  1025. package/ref-monty/crates/monty-typeshed/build.rs +0 -101
  1026. package/ref-monty/crates/monty-typeshed/custom/README.md +0 -1
  1027. package/ref-monty/crates/monty-typeshed/custom/asyncio.pyi +0 -138
  1028. package/ref-monty/crates/monty-typeshed/custom/os.pyi +0 -87
  1029. package/ref-monty/crates/monty-typeshed/custom/sys.pyi +0 -33
  1030. package/ref-monty/crates/monty-typeshed/src/lib.rs +0 -56
  1031. package/ref-monty/crates/monty-typeshed/update.py +0 -321
  1032. package/ref-monty/crates/monty-typeshed/vendor/typeshed/source_commit.txt +0 -1
  1033. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/VERSIONS +0 -20
  1034. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/_collections_abc.pyi +0 -105
  1035. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/_typeshed/__init__.pyi +0 -394
  1036. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/asyncio.pyi +0 -138
  1037. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/builtins.pyi +0 -1434
  1038. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/collections/__init__.pyi +0 -527
  1039. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/collections/abc.pyi +0 -2
  1040. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/dataclasses.pyi +0 -502
  1041. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/enum.pyi +0 -376
  1042. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/math.pyi +0 -149
  1043. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/os.pyi +0 -87
  1044. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/pathlib/__init__.pyi +0 -395
  1045. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/pathlib/types.pyi +0 -8
  1046. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/re.pyi +0 -337
  1047. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/sys.pyi +0 -33
  1048. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/types.pyi +0 -741
  1049. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/typing.pyi +0 -1217
  1050. package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/typing_extensions.pyi +0 -716
  1051. package/ref-monty/docs/usage-guide.md +0 -117
  1052. package/ref-monty/examples/README.md +0 -3
  1053. package/ref-monty/examples/expense_analysis/README.md +0 -3
  1054. package/ref-monty/examples/expense_analysis/data.py +0 -124
  1055. package/ref-monty/examples/expense_analysis/main.py +0 -115
  1056. package/ref-monty/examples/sql_playground/README.md +0 -20
  1057. package/ref-monty/examples/sql_playground/external_functions.py +0 -129
  1058. package/ref-monty/examples/sql_playground/main.py +0 -81
  1059. package/ref-monty/examples/sql_playground/sandbox_code.py +0 -82
  1060. package/ref-monty/examples/sql_playground/type_stubs.pyi +0 -14
  1061. package/ref-monty/examples/web_scraper/README.md +0 -15
  1062. package/ref-monty/examples/web_scraper/browser.py +0 -56
  1063. package/ref-monty/examples/web_scraper/example_code.py +0 -59
  1064. package/ref-monty/examples/web_scraper/external_functions.py +0 -324
  1065. package/ref-monty/examples/web_scraper/main.py +0 -193
  1066. package/ref-monty/examples/web_scraper/sub_agent.py +0 -79
  1067. package/ref-monty/monty-npm.md +0 -235
  1068. package/ref-monty/pyproject.toml +0 -162
  1069. package/ref-monty/scripts/check_imports.py +0 -91
  1070. package/ref-monty/scripts/codecov_diff.py +0 -412
  1071. package/ref-monty/scripts/complete_tests.py +0 -146
  1072. package/ref-monty/scripts/flamegraph_to_text.py +0 -208
  1073. package/ref-monty/scripts/iter_test_methods.py +0 -540
  1074. package/ref-monty/scripts/run_traceback.py +0 -180
  1075. package/ref-monty/scripts/startup_performance.py +0 -130
  1076. package/ref-monty/uv.lock +0 -1779
  1077. package/temp_resend_cli/repo/.github/scripts/pr-title-check.js +0 -34
  1078. package/temp_resend_cli/repo/.github/workflows/ci.yml +0 -67
  1079. package/temp_resend_cli/repo/.github/workflows/post-release.yml +0 -51
  1080. package/temp_resend_cli/repo/.github/workflows/pr-title-check.yml +0 -13
  1081. package/temp_resend_cli/repo/.github/workflows/release.yml +0 -175
  1082. package/temp_resend_cli/repo/.github/workflows/test-install-unix.yml +0 -34
  1083. package/temp_resend_cli/repo/.github/workflows/test-install-windows.yml +0 -48
  1084. package/temp_resend_cli/repo/CHANGELOG.md +0 -31
  1085. package/temp_resend_cli/repo/LICENSE +0 -21
  1086. package/temp_resend_cli/repo/README.md +0 -450
  1087. package/temp_resend_cli/repo/biome.json +0 -36
  1088. package/temp_resend_cli/repo/install.ps1 +0 -141
  1089. package/temp_resend_cli/repo/install.sh +0 -301
  1090. package/temp_resend_cli/repo/package.json +0 -61
  1091. package/temp_resend_cli/repo/pnpm-lock.yaml +0 -2439
  1092. package/temp_resend_cli/repo/renovate.json +0 -4
  1093. package/temp_resend_cli/repo/src/cli.ts +0 -98
  1094. package/temp_resend_cli/repo/src/commands/api-keys/create.ts +0 -114
  1095. package/temp_resend_cli/repo/src/commands/api-keys/delete.ts +0 -47
  1096. package/temp_resend_cli/repo/src/commands/api-keys/index.ts +0 -26
  1097. package/temp_resend_cli/repo/src/commands/api-keys/list.ts +0 -35
  1098. package/temp_resend_cli/repo/src/commands/api-keys/utils.ts +0 -8
  1099. package/temp_resend_cli/repo/src/commands/auth/index.ts +0 -20
  1100. package/temp_resend_cli/repo/src/commands/auth/login.ts +0 -234
  1101. package/temp_resend_cli/repo/src/commands/auth/logout.ts +0 -105
  1102. package/temp_resend_cli/repo/src/commands/broadcasts/create.ts +0 -196
  1103. package/temp_resend_cli/repo/src/commands/broadcasts/delete.ts +0 -46
  1104. package/temp_resend_cli/repo/src/commands/broadcasts/get.ts +0 -59
  1105. package/temp_resend_cli/repo/src/commands/broadcasts/index.ts +0 -43
  1106. package/temp_resend_cli/repo/src/commands/broadcasts/list.ts +0 -60
  1107. package/temp_resend_cli/repo/src/commands/broadcasts/send.ts +0 -56
  1108. package/temp_resend_cli/repo/src/commands/broadcasts/update.ts +0 -95
  1109. package/temp_resend_cli/repo/src/commands/broadcasts/utils.ts +0 -35
  1110. package/temp_resend_cli/repo/src/commands/contact-properties/create.ts +0 -118
  1111. package/temp_resend_cli/repo/src/commands/contact-properties/delete.ts +0 -48
  1112. package/temp_resend_cli/repo/src/commands/contact-properties/get.ts +0 -46
  1113. package/temp_resend_cli/repo/src/commands/contact-properties/index.ts +0 -48
  1114. package/temp_resend_cli/repo/src/commands/contact-properties/list.ts +0 -68
  1115. package/temp_resend_cli/repo/src/commands/contact-properties/update.ts +0 -88
  1116. package/temp_resend_cli/repo/src/commands/contact-properties/utils.ts +0 -17
  1117. package/temp_resend_cli/repo/src/commands/contacts/add-segment.ts +0 -78
  1118. package/temp_resend_cli/repo/src/commands/contacts/create.ts +0 -122
  1119. package/temp_resend_cli/repo/src/commands/contacts/delete.ts +0 -49
  1120. package/temp_resend_cli/repo/src/commands/contacts/get.ts +0 -53
  1121. package/temp_resend_cli/repo/src/commands/contacts/index.ts +0 -58
  1122. package/temp_resend_cli/repo/src/commands/contacts/list.ts +0 -57
  1123. package/temp_resend_cli/repo/src/commands/contacts/remove-segment.ts +0 -48
  1124. package/temp_resend_cli/repo/src/commands/contacts/segments.ts +0 -39
  1125. package/temp_resend_cli/repo/src/commands/contacts/topics.ts +0 -45
  1126. package/temp_resend_cli/repo/src/commands/contacts/update-topics.ts +0 -90
  1127. package/temp_resend_cli/repo/src/commands/contacts/update.ts +0 -77
  1128. package/temp_resend_cli/repo/src/commands/contacts/utils.ts +0 -119
  1129. package/temp_resend_cli/repo/src/commands/doctor.ts +0 -216
  1130. package/temp_resend_cli/repo/src/commands/domains/create.ts +0 -83
  1131. package/temp_resend_cli/repo/src/commands/domains/delete.ts +0 -42
  1132. package/temp_resend_cli/repo/src/commands/domains/get.ts +0 -47
  1133. package/temp_resend_cli/repo/src/commands/domains/index.ts +0 -35
  1134. package/temp_resend_cli/repo/src/commands/domains/list.ts +0 -53
  1135. package/temp_resend_cli/repo/src/commands/domains/update.ts +0 -75
  1136. package/temp_resend_cli/repo/src/commands/domains/utils.ts +0 -44
  1137. package/temp_resend_cli/repo/src/commands/domains/verify.ts +0 -38
  1138. package/temp_resend_cli/repo/src/commands/emails/batch.ts +0 -140
  1139. package/temp_resend_cli/repo/src/commands/emails/get.ts +0 -44
  1140. package/temp_resend_cli/repo/src/commands/emails/index.ts +0 -30
  1141. package/temp_resend_cli/repo/src/commands/emails/list.ts +0 -84
  1142. package/temp_resend_cli/repo/src/commands/emails/receiving/attachment.ts +0 -55
  1143. package/temp_resend_cli/repo/src/commands/emails/receiving/attachments.ts +0 -68
  1144. package/temp_resend_cli/repo/src/commands/emails/receiving/get.ts +0 -58
  1145. package/temp_resend_cli/repo/src/commands/emails/receiving/index.ts +0 -28
  1146. package/temp_resend_cli/repo/src/commands/emails/receiving/list.ts +0 -59
  1147. package/temp_resend_cli/repo/src/commands/emails/receiving/utils.ts +0 -38
  1148. package/temp_resend_cli/repo/src/commands/emails/send.ts +0 -189
  1149. package/temp_resend_cli/repo/src/commands/open.ts +0 -27
  1150. package/temp_resend_cli/repo/src/commands/segments/create.ts +0 -50
  1151. package/temp_resend_cli/repo/src/commands/segments/delete.ts +0 -47
  1152. package/temp_resend_cli/repo/src/commands/segments/get.ts +0 -38
  1153. package/temp_resend_cli/repo/src/commands/segments/index.ts +0 -36
  1154. package/temp_resend_cli/repo/src/commands/segments/list.ts +0 -58
  1155. package/temp_resend_cli/repo/src/commands/segments/utils.ts +0 -7
  1156. package/temp_resend_cli/repo/src/commands/teams/index.ts +0 -10
  1157. package/temp_resend_cli/repo/src/commands/teams/list.ts +0 -35
  1158. package/temp_resend_cli/repo/src/commands/teams/remove.ts +0 -86
  1159. package/temp_resend_cli/repo/src/commands/teams/switch.ts +0 -76
  1160. package/temp_resend_cli/repo/src/commands/topics/create.ts +0 -73
  1161. package/temp_resend_cli/repo/src/commands/topics/delete.ts +0 -47
  1162. package/temp_resend_cli/repo/src/commands/topics/get.ts +0 -42
  1163. package/temp_resend_cli/repo/src/commands/topics/index.ts +0 -42
  1164. package/temp_resend_cli/repo/src/commands/topics/list.ts +0 -34
  1165. package/temp_resend_cli/repo/src/commands/topics/update.ts +0 -59
  1166. package/temp_resend_cli/repo/src/commands/topics/utils.ts +0 -16
  1167. package/temp_resend_cli/repo/src/commands/webhooks/create.ts +0 -128
  1168. package/temp_resend_cli/repo/src/commands/webhooks/delete.ts +0 -49
  1169. package/temp_resend_cli/repo/src/commands/webhooks/get.ts +0 -42
  1170. package/temp_resend_cli/repo/src/commands/webhooks/index.ts +0 -42
  1171. package/temp_resend_cli/repo/src/commands/webhooks/list.ts +0 -55
  1172. package/temp_resend_cli/repo/src/commands/webhooks/listen.ts +0 -379
  1173. package/temp_resend_cli/repo/src/commands/webhooks/update.ts +0 -83
  1174. package/temp_resend_cli/repo/src/commands/webhooks/utils.ts +0 -36
  1175. package/temp_resend_cli/repo/src/commands/whoami.ts +0 -71
  1176. package/temp_resend_cli/repo/src/lib/actions.ts +0 -157
  1177. package/temp_resend_cli/repo/src/lib/client.ts +0 -37
  1178. package/temp_resend_cli/repo/src/lib/config.ts +0 -217
  1179. package/temp_resend_cli/repo/src/lib/files.ts +0 -15
  1180. package/temp_resend_cli/repo/src/lib/help-text.ts +0 -38
  1181. package/temp_resend_cli/repo/src/lib/output.ts +0 -56
  1182. package/temp_resend_cli/repo/src/lib/pagination.ts +0 -36
  1183. package/temp_resend_cli/repo/src/lib/prompts.ts +0 -149
  1184. package/temp_resend_cli/repo/src/lib/spinner.ts +0 -100
  1185. package/temp_resend_cli/repo/src/lib/table.ts +0 -57
  1186. package/temp_resend_cli/repo/src/lib/tty.ts +0 -28
  1187. package/temp_resend_cli/repo/src/lib/update-check.ts +0 -169
  1188. package/temp_resend_cli/repo/src/lib/version.ts +0 -4
  1189. package/temp_resend_cli/repo/tests/commands/api-keys/create.test.ts +0 -196
  1190. package/temp_resend_cli/repo/tests/commands/api-keys/delete.test.ts +0 -157
  1191. package/temp_resend_cli/repo/tests/commands/api-keys/list.test.ts +0 -134
  1192. package/temp_resend_cli/repo/tests/commands/auth/login.test.ts +0 -153
  1193. package/temp_resend_cli/repo/tests/commands/auth/logout.test.ts +0 -153
  1194. package/temp_resend_cli/repo/tests/commands/broadcasts/create.test.ts +0 -454
  1195. package/temp_resend_cli/repo/tests/commands/broadcasts/delete.test.ts +0 -183
  1196. package/temp_resend_cli/repo/tests/commands/broadcasts/get.test.ts +0 -147
  1197. package/temp_resend_cli/repo/tests/commands/broadcasts/list.test.ts +0 -199
  1198. package/temp_resend_cli/repo/tests/commands/broadcasts/send.test.ts +0 -162
  1199. package/temp_resend_cli/repo/tests/commands/broadcasts/update.test.ts +0 -288
  1200. package/temp_resend_cli/repo/tests/commands/contact-properties/create.test.ts +0 -251
  1201. package/temp_resend_cli/repo/tests/commands/contact-properties/delete.test.ts +0 -184
  1202. package/temp_resend_cli/repo/tests/commands/contact-properties/get.test.ts +0 -145
  1203. package/temp_resend_cli/repo/tests/commands/contact-properties/list.test.ts +0 -181
  1204. package/temp_resend_cli/repo/tests/commands/contact-properties/update.test.ts +0 -217
  1205. package/temp_resend_cli/repo/tests/commands/contacts/add-segment.test.ts +0 -189
  1206. package/temp_resend_cli/repo/tests/commands/contacts/create.test.ts +0 -271
  1207. package/temp_resend_cli/repo/tests/commands/contacts/delete.test.ts +0 -193
  1208. package/temp_resend_cli/repo/tests/commands/contacts/get.test.ts +0 -149
  1209. package/temp_resend_cli/repo/tests/commands/contacts/list.test.ts +0 -176
  1210. package/temp_resend_cli/repo/tests/commands/contacts/remove-segment.test.ts +0 -167
  1211. package/temp_resend_cli/repo/tests/commands/contacts/segments.test.ts +0 -168
  1212. package/temp_resend_cli/repo/tests/commands/contacts/topics.test.ts +0 -164
  1213. package/temp_resend_cli/repo/tests/commands/contacts/update-topics.test.ts +0 -248
  1214. package/temp_resend_cli/repo/tests/commands/contacts/update.test.ts +0 -206
  1215. package/temp_resend_cli/repo/tests/commands/doctor.test.ts +0 -164
  1216. package/temp_resend_cli/repo/tests/commands/domains/create.test.ts +0 -193
  1217. package/temp_resend_cli/repo/tests/commands/domains/delete.test.ts +0 -157
  1218. package/temp_resend_cli/repo/tests/commands/domains/get.test.ts +0 -138
  1219. package/temp_resend_cli/repo/tests/commands/domains/list.test.ts +0 -165
  1220. package/temp_resend_cli/repo/tests/commands/domains/update.test.ts +0 -224
  1221. package/temp_resend_cli/repo/tests/commands/domains/verify.test.ts +0 -118
  1222. package/temp_resend_cli/repo/tests/commands/emails/batch.test.ts +0 -324
  1223. package/temp_resend_cli/repo/tests/commands/emails/get.test.ts +0 -132
  1224. package/temp_resend_cli/repo/tests/commands/emails/receiving/attachment.test.ts +0 -141
  1225. package/temp_resend_cli/repo/tests/commands/emails/receiving/attachments.test.ts +0 -169
  1226. package/temp_resend_cli/repo/tests/commands/emails/receiving/get.test.ts +0 -141
  1227. package/temp_resend_cli/repo/tests/commands/emails/receiving/list.test.ts +0 -182
  1228. package/temp_resend_cli/repo/tests/commands/emails/send.test.ts +0 -312
  1229. package/temp_resend_cli/repo/tests/commands/segments/create.test.ts +0 -164
  1230. package/temp_resend_cli/repo/tests/commands/segments/delete.test.ts +0 -183
  1231. package/temp_resend_cli/repo/tests/commands/segments/get.test.ts +0 -138
  1232. package/temp_resend_cli/repo/tests/commands/segments/list.test.ts +0 -174
  1233. package/temp_resend_cli/repo/tests/commands/teams/list.test.ts +0 -62
  1234. package/temp_resend_cli/repo/tests/commands/teams/remove.test.ts +0 -110
  1235. package/temp_resend_cli/repo/tests/commands/teams/switch.test.ts +0 -103
  1236. package/temp_resend_cli/repo/tests/commands/topics/create.test.ts +0 -192
  1237. package/temp_resend_cli/repo/tests/commands/topics/delete.test.ts +0 -157
  1238. package/temp_resend_cli/repo/tests/commands/topics/get.test.ts +0 -126
  1239. package/temp_resend_cli/repo/tests/commands/topics/list.test.ts +0 -125
  1240. package/temp_resend_cli/repo/tests/commands/topics/update.test.ts +0 -178
  1241. package/temp_resend_cli/repo/tests/commands/webhooks/create.test.ts +0 -225
  1242. package/temp_resend_cli/repo/tests/commands/webhooks/delete.test.ts +0 -157
  1243. package/temp_resend_cli/repo/tests/commands/webhooks/get.test.ts +0 -126
  1244. package/temp_resend_cli/repo/tests/commands/webhooks/list.test.ts +0 -178
  1245. package/temp_resend_cli/repo/tests/commands/webhooks/update.test.ts +0 -207
  1246. package/temp_resend_cli/repo/tests/commands/whoami.test.ts +0 -98
  1247. package/temp_resend_cli/repo/tests/e2e/smoke.test.ts +0 -93
  1248. package/temp_resend_cli/repo/tests/helpers.ts +0 -86
  1249. package/temp_resend_cli/repo/tests/lib/client.test.ts +0 -71
  1250. package/temp_resend_cli/repo/tests/lib/config.test.ts +0 -451
  1251. package/temp_resend_cli/repo/tests/lib/files.test.ts +0 -73
  1252. package/temp_resend_cli/repo/tests/lib/help-text.test.ts +0 -97
  1253. package/temp_resend_cli/repo/tests/lib/output.test.ts +0 -136
  1254. package/temp_resend_cli/repo/tests/lib/prompts.test.ts +0 -185
  1255. package/temp_resend_cli/repo/tests/lib/spinner.test.ts +0 -166
  1256. package/temp_resend_cli/repo/tests/lib/table.test.ts +0 -63
  1257. package/temp_resend_cli/repo/tests/lib/tty.test.ts +0 -89
  1258. package/temp_resend_cli/repo/tests/lib/update-check.test.ts +0 -179
  1259. package/temp_resend_cli/repo/tsconfig.json +0 -14
  1260. package/temp_resend_cli/repo/vitest.config.e2e.ts +0 -8
  1261. package/temp_resend_cli/repo/vitest.config.ts +0 -10
  1262. /package/docs/{plugin-examples.md → plugins-examples.md} +0 -0
@@ -1,1373 +0,0 @@
1
- use std::fmt::Write;
2
-
3
- use ahash::AHashSet;
4
- use hashbrown::HashTable;
5
-
6
- use super::{MontyIter, PyTrait};
7
- use crate::{
8
- args::ArgValues,
9
- bytecode::{CallResult, VM},
10
- defer_drop, defer_drop_mut,
11
- exception_private::{ExcType, RunResult},
12
- heap::{ContainsHeap, DropWithHeap, Heap, HeapData, HeapGuard, HeapId},
13
- intern::{Interns, StaticStrings},
14
- resource::{ResourceError, ResourceTracker},
15
- types::Type,
16
- value::{EitherStr, Value},
17
- };
18
-
19
- /// Entry in the set storage, containing a value and its cached hash.
20
- #[derive(Debug, serde::Serialize, serde::Deserialize)]
21
- struct SetEntry {
22
- pub(crate) value: Value,
23
- /// Cached hash for efficient lookup and reinsertion.
24
- pub(crate) hash: u64,
25
- }
26
-
27
- /// Internal storage shared between Set and FrozenSet.
28
- ///
29
- /// Uses a `HashTable<usize>` for O(1) lookups combined with a dense `Vec<SetEntry>`
30
- /// to preserve insertion order (consistent with Python 3.7+ dict behavior).
31
- /// The hash table maps value hashes to indices in the entries vector.
32
- #[derive(Debug, Default)]
33
- pub(crate) struct SetStorage {
34
- /// Maps hash to index in entries vector.
35
- indices: HashTable<usize>,
36
- /// Dense vector of entries maintaining insertion order.
37
- entries: Vec<SetEntry>,
38
- }
39
-
40
- impl SetStorage {
41
- /// Creates a new empty set storage.
42
- fn new() -> Self {
43
- Self::default()
44
- }
45
-
46
- /// Creates a new set storage with pre-allocated capacity.
47
- fn with_capacity(capacity: usize) -> Self {
48
- Self {
49
- indices: HashTable::with_capacity(capacity),
50
- entries: Vec::with_capacity(capacity),
51
- }
52
- }
53
-
54
- /// Creates a SetStorage from a vector of (value, hash) pairs.
55
- ///
56
- /// This is used to avoid borrow conflicts when we need to copy another set's
57
- /// contents and then perform operations requiring mutable heap access.
58
- /// The caller is responsible for handling reference counting.
59
- fn from_entries(entries: Vec<(Value, u64)>) -> Self {
60
- let mut storage = Self::with_capacity(entries.len());
61
- for (idx, (value, hash)) in entries.into_iter().enumerate() {
62
- storage.entries.push(SetEntry { value, hash });
63
- storage.indices.insert_unique(hash, idx, |&i| storage.entries[i].hash);
64
- }
65
- storage
66
- }
67
-
68
- /// Clones entries with proper reference counting.
69
- fn clone_entries(&self, heap: &impl ContainsHeap) -> Vec<(Value, u64)> {
70
- self.entries
71
- .iter()
72
- .map(|e| (e.value.clone_with_heap(heap), e.hash))
73
- .collect()
74
- }
75
-
76
- /// Returns the number of elements in the set.
77
- fn len(&self) -> usize {
78
- self.entries.len()
79
- }
80
-
81
- /// Returns true if the set is empty.
82
- fn is_empty(&self) -> bool {
83
- self.entries.is_empty()
84
- }
85
-
86
- /// Returns whether this set contains any heap references (`Value::Ref`).
87
- ///
88
- /// Used during allocation to determine if this container could create cycles.
89
- #[inline]
90
- fn has_refs(&self) -> bool {
91
- self.entries.iter().any(|e| matches!(e.value, Value::Ref(_)))
92
- }
93
-
94
- /// Adds an element to the set, transferring ownership.
95
- ///
96
- /// Returns `Ok(true)` if the element was added (not already present),
97
- /// `Ok(false)` if the element was already in the set.
98
- /// Returns `Err` if the element is unhashable.
99
- ///
100
- /// The caller transfers ownership of `value`. If the value is already in
101
- /// the set, it will be dropped.
102
- fn add(&mut self, value: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
103
- let hash = match value.py_hash(vm.heap, vm.interns) {
104
- Ok(Some(h)) => h,
105
- Ok(None) => {
106
- let err = ExcType::type_error_unhashable_set_element(value.py_type(vm.heap));
107
- value.drop_with_heap(vm.heap);
108
- return Err(err);
109
- }
110
- Err(e) => {
111
- value.drop_with_heap(vm.heap);
112
- return Err(e.into());
113
- }
114
- };
115
-
116
- // Check if value already exists.
117
- let existing = self
118
- .indices
119
- .find(hash, |&idx| value.py_eq(&self.entries[idx].value, vm).unwrap_or(false));
120
-
121
- if existing.is_some() {
122
- // Value already in set, drop the new value
123
- value.drop_with_heap(vm.heap);
124
- Ok(false)
125
- } else {
126
- // Add new entry
127
- let index = self.entries.len();
128
- self.entries.push(SetEntry { value, hash });
129
- self.indices.insert_unique(hash, index, |&idx| self.entries[idx].hash);
130
- Ok(true)
131
- }
132
- }
133
-
134
- /// Removes an element from the set.
135
- ///
136
- /// Returns `Ok(true)` if the element was removed, `Ok(false)` if not found.
137
- /// Returns `Err` if the key is unhashable.
138
- fn remove(&mut self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
139
- let hash = value
140
- .py_hash(vm.heap, vm.interns)?
141
- .ok_or_else(|| ExcType::type_error_unhashable_set_element(value.py_type(vm.heap)))?;
142
-
143
- let entry = self.indices.entry(
144
- hash,
145
- |&idx| value.py_eq(&self.entries[idx].value, vm).unwrap_or(false),
146
- |&idx| self.entries[idx].hash,
147
- );
148
-
149
- if let hashbrown::hash_table::Entry::Occupied(occ) = entry {
150
- let index = *occ.get();
151
- let removed_entry = self.entries.remove(index);
152
- occ.remove();
153
-
154
- // Update indices for entries that shifted down
155
- for idx in &mut self.indices {
156
- if *idx > index {
157
- *idx -= 1;
158
- }
159
- }
160
-
161
- // Drop the removed value
162
- removed_entry.value.drop_with_heap(vm);
163
- Ok(true)
164
- } else {
165
- Ok(false)
166
- }
167
- }
168
-
169
- /// Removes an element from the set without raising an error if not found.
170
- ///
171
- /// Returns `Ok(())` always (unless the key is unhashable).
172
- fn discard(&mut self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<()> {
173
- self.remove(value, vm)?;
174
- Ok(())
175
- }
176
-
177
- /// Removes and returns an arbitrary element from the set.
178
- ///
179
- /// Returns `Err(KeyError)` if the set is empty.
180
- fn pop(&mut self) -> RunResult<Value> {
181
- if self.entries.is_empty() {
182
- return Err(ExcType::key_error_pop_empty_set());
183
- }
184
-
185
- // Remove the last entry (most efficient)
186
- let entry = self.entries.pop().expect("checked non-empty");
187
-
188
- // Remove from hash table
189
- self.indices
190
- .find_entry(entry.hash, |&idx| idx == self.entries.len())
191
- .expect("entry must exist")
192
- .remove();
193
-
194
- Ok(entry.value)
195
- }
196
-
197
- /// Removes all elements from the set.
198
- fn clear(&mut self, heap: &mut Heap<impl ResourceTracker>) {
199
- self.entries.drain(..).drop_with_heap(heap);
200
- self.indices.clear();
201
- }
202
-
203
- /// Creates a deep clone with proper reference counting.
204
- fn clone_with_heap(&self, heap: &impl ContainsHeap) -> Self {
205
- Self {
206
- indices: self.indices.clone(),
207
- entries: self
208
- .entries
209
- .iter()
210
- .map(|entry| SetEntry {
211
- value: entry.value.clone_with_heap(heap),
212
- hash: entry.hash,
213
- })
214
- .collect(),
215
- }
216
- }
217
-
218
- /// Checks if the set contains a value.
219
- pub fn contains(&self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
220
- let hash = value
221
- .py_hash(vm.heap, vm.interns)?
222
- .ok_or_else(|| ExcType::type_error_unhashable_set_element(value.py_type(vm.heap)))?;
223
-
224
- // Set values are typically shallow (strings, ints, tuples of primitives),
225
- // so recursion errors are unlikely. If one occurs, treat it as "not equal".
226
- Ok(self
227
- .indices
228
- .find(hash, |&idx| value.py_eq(&self.entries[idx].value, vm).unwrap_or(false))
229
- .is_some())
230
- }
231
-
232
- /// Returns an iterator over the values in the set.
233
- pub(crate) fn iter(&self) -> impl Iterator<Item = &Value> {
234
- self.entries.iter().map(|e| &e.value)
235
- }
236
-
237
- /// Returns the value at the given index, if valid.
238
- ///
239
- /// Used by MontyIter for index-based iteration.
240
- pub(crate) fn value_at(&self, index: usize) -> Option<&Value> {
241
- self.entries.get(index).map(|e| &e.value)
242
- }
243
-
244
- /// Collects heap IDs for reference counting cleanup.
245
- fn collect_dec_ref_ids(&mut self, stack: &mut Vec<HeapId>) {
246
- for entry in &mut self.entries {
247
- if let Value::Ref(id) = &entry.value {
248
- stack.push(*id);
249
- #[cfg(feature = "ref-count-panic")]
250
- entry.value.dec_ref_forget();
251
- }
252
- }
253
- }
254
-
255
- /// Compares two sets for equality.
256
- fn eq(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> Result<bool, ResourceError> {
257
- if self.len() != other.len() {
258
- return Ok(false);
259
- }
260
-
261
- let token = vm.heap.incr_recursion_depth()?;
262
- defer_drop!(token, vm);
263
- // Check that every element in self is in other
264
- for entry in &self.entries {
265
- if !matches!(other.contains(&entry.value, vm), Ok(true)) {
266
- return Ok(false);
267
- }
268
- }
269
- Ok(true)
270
- }
271
-
272
- /// Returns true if this set is a subset of other.
273
- fn is_subset(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
274
- for entry in &self.entries {
275
- if !other.contains(&entry.value, vm)? {
276
- return Ok(false);
277
- }
278
- }
279
- Ok(true)
280
- }
281
-
282
- /// Returns true if this set is a superset of other.
283
- fn is_superset(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
284
- other.is_subset(self, vm)
285
- }
286
-
287
- /// Returns true if this set has no elements in common with other.
288
- fn is_disjoint(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
289
- // Iterate over the smaller set for efficiency
290
- let (smaller, larger) = if self.len() <= other.len() {
291
- (self, other)
292
- } else {
293
- (other, self)
294
- };
295
-
296
- for entry in &smaller.entries {
297
- if larger.contains(&entry.value, vm)? {
298
- return Ok(false);
299
- }
300
- }
301
- Ok(true)
302
- }
303
-
304
- /// Returns a new set containing elements in either set (union).
305
- fn union(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
306
- let mut result_guard = HeapGuard::new(self.clone_with_heap(vm), vm);
307
- let (result, vm) = result_guard.as_parts_mut();
308
- for entry in &other.entries {
309
- let value = entry.value.clone_with_heap(vm);
310
- result.add(value, vm)?;
311
- }
312
- Ok(result_guard.into_inner())
313
- }
314
-
315
- /// Returns a new set containing elements in both sets (intersection).
316
- fn intersection(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
317
- let mut result_guard = HeapGuard::new(Self::new(), vm);
318
- let (result, vm) = result_guard.as_parts_mut();
319
- // Iterate over the smaller set for efficiency
320
- let (smaller, larger) = if self.len() <= other.len() {
321
- (self, other)
322
- } else {
323
- (other, self)
324
- };
325
-
326
- for entry in &smaller.entries {
327
- if larger.contains(&entry.value, vm)? {
328
- let value = entry.value.clone_with_heap(vm);
329
- result.add(value, vm)?;
330
- }
331
- }
332
- Ok(result_guard.into_inner())
333
- }
334
-
335
- /// Returns a new set containing elements in self but not in other (difference).
336
- fn difference(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
337
- let mut result_guard = HeapGuard::new(Self::new(), vm);
338
- let (result, vm) = result_guard.as_parts_mut();
339
- for entry in &self.entries {
340
- if !other.contains(&entry.value, vm)? {
341
- let value = entry.value.clone_with_heap(vm);
342
- result.add(value, vm)?;
343
- }
344
- }
345
- Ok(result_guard.into_inner())
346
- }
347
-
348
- /// Returns a new set containing elements in either set but not both (symmetric difference).
349
- fn symmetric_difference(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
350
- let mut result_guard = HeapGuard::new(Self::new(), vm);
351
- let (result, vm) = result_guard.as_parts_mut();
352
-
353
- // Add elements in self but not in other
354
- for entry in &self.entries {
355
- if !other.contains(&entry.value, vm)? {
356
- let value = entry.value.clone_with_heap(vm);
357
- result.add(value, vm)?;
358
- }
359
- }
360
-
361
- // Add elements in other but not in self
362
- for entry in &other.entries {
363
- if !self.contains(&entry.value, vm)? {
364
- let value = entry.value.clone_with_heap(vm);
365
- result.add(value, vm)?;
366
- }
367
- }
368
-
369
- Ok(result_guard.into_inner())
370
- }
371
-
372
- /// Adds all elements from other to this set (in-place union).
373
- fn update(&mut self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<()> {
374
- for entry in &other.entries {
375
- let value = entry.value.clone_with_heap(vm);
376
- self.add(value, vm)?;
377
- }
378
- Ok(())
379
- }
380
-
381
- /// Writes the repr format to a formatter.
382
- ///
383
- /// For sets, outputs `{elem1, elem2, ...}` (no type prefix).
384
- /// For frozensets, outputs `frozenset({elem1, elem2, ...})`.
385
- fn repr_fmt(
386
- &self,
387
- f: &mut impl Write,
388
- vm: &VM<'_, '_, impl ResourceTracker>,
389
- heap_ids: &mut AHashSet<HeapId>,
390
- type_name: &str,
391
- ) -> std::fmt::Result {
392
- if self.is_empty() {
393
- return write!(f, "{type_name}()");
394
- }
395
-
396
- // Check depth limit before recursing
397
- let Some(token) = vm.heap.incr_recursion_depth_for_repr() else {
398
- return f.write_str("{...}");
399
- };
400
- crate::defer_drop_immutable_heap!(token, vm);
401
-
402
- // frozenset needs type prefix: frozenset({...}), but set doesn't: {...}
403
- let needs_prefix = type_name != "set";
404
- if needs_prefix {
405
- write!(f, "{type_name}(")?;
406
- }
407
-
408
- f.write_char('{')?;
409
- let mut first = true;
410
- for entry in &self.entries {
411
- if !first {
412
- if vm.heap.check_time().is_err() {
413
- f.write_str(", ...[timeout]")?;
414
- break;
415
- }
416
- f.write_str(", ")?;
417
- }
418
- first = false;
419
- entry.value.py_repr_fmt(f, vm, heap_ids)?;
420
- }
421
- f.write_char('}')?;
422
-
423
- if needs_prefix {
424
- f.write_char(')')?;
425
- }
426
-
427
- Ok(())
428
- }
429
-
430
- /// Estimates the memory size of this storage.
431
- fn estimate_size(&self) -> usize {
432
- std::mem::size_of::<Self>() + self.len() * std::mem::size_of::<SetEntry>()
433
- }
434
- }
435
-
436
- /// Python set type - mutable, unordered collection of unique hashable elements.
437
- ///
438
- /// Sets support standard operations like add, remove, discard, pop, clear, as well
439
- /// as set algebra operations like union, intersection, difference, and symmetric
440
- /// difference.
441
- ///
442
- /// # Reference Counting
443
- /// When values are added, their reference counts are NOT incremented by the set -
444
- /// the caller transfers ownership. When values are removed or the set is cleared,
445
- /// their reference counts are decremented.
446
- #[derive(Debug, Default)]
447
- pub(crate) struct Set(SetStorage);
448
-
449
- impl Set {
450
- /// Creates a new empty set.
451
- #[must_use]
452
- pub fn new() -> Self {
453
- Self(SetStorage::new())
454
- }
455
-
456
- /// Creates a set with pre-allocated capacity.
457
- #[must_use]
458
- pub fn with_capacity(capacity: usize) -> Self {
459
- Self(SetStorage::with_capacity(capacity))
460
- }
461
-
462
- /// Returns the number of elements in the set.
463
- #[must_use]
464
- pub fn len(&self) -> usize {
465
- self.0.len()
466
- }
467
-
468
- /// Returns true if the set is empty.
469
- #[must_use]
470
- pub fn is_empty(&self) -> bool {
471
- self.0.is_empty()
472
- }
473
-
474
- /// Returns whether this set contains any heap references (`Value::Ref`).
475
- ///
476
- /// Used during allocation to determine if this container could create cycles.
477
- #[inline]
478
- #[must_use]
479
- pub fn has_refs(&self) -> bool {
480
- self.0.has_refs()
481
- }
482
-
483
- /// Adds an element to the set, transferring ownership.
484
- ///
485
- /// Returns `Ok(true)` if added, `Ok(false)` if already present.
486
- pub fn add(&mut self, value: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
487
- self.0.add(value, vm)
488
- }
489
-
490
- /// Removes an element from the set.
491
- ///
492
- /// Returns `Err(KeyError)` if the element is not present.
493
- pub fn remove(&mut self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<()> {
494
- if self.0.remove(value, vm)? {
495
- Ok(())
496
- } else {
497
- Err(ExcType::key_error(value, vm))
498
- }
499
- }
500
-
501
- /// Removes an element from the set if present.
502
- ///
503
- /// Does not raise an error if the element is not found.
504
- pub fn discard(&mut self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<()> {
505
- self.0.discard(value, vm)
506
- }
507
-
508
- /// Removes and returns an arbitrary element from the set.
509
- ///
510
- /// Returns `Err(KeyError)` if the set is empty.
511
- pub fn pop(&mut self) -> RunResult<Value> {
512
- self.0.pop()
513
- }
514
-
515
- /// Removes all elements from the set.
516
- pub fn clear(&mut self, heap: &mut Heap<impl ResourceTracker>) {
517
- self.0.clear(heap);
518
- }
519
-
520
- /// Returns a shallow copy of the set.
521
- #[must_use]
522
- pub fn copy(&self, heap: &mut Heap<impl ResourceTracker>) -> Self {
523
- Self(self.0.clone_with_heap(heap))
524
- }
525
-
526
- /// Checks if the set contains a value.
527
- pub fn contains(&self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
528
- self.0.contains(value, vm)
529
- }
530
-
531
- /// Returns the internal storage (for set operations between Set and FrozenSet).
532
- pub(crate) fn storage(&self) -> &SetStorage {
533
- &self.0
534
- }
535
-
536
- /// Returns an iterator over the set's elements in insertion order.
537
- ///
538
- /// This is primarily used by other runtime helpers that need to implement
539
- /// set-like protocols while still preserving Monty's single canonical set
540
- /// storage implementation.
541
- pub(crate) fn iter(&self) -> impl Iterator<Item = &Value> {
542
- self.0.iter()
543
- }
544
-
545
- /// Creates a set from the `set()` constructor call.
546
- ///
547
- /// - `set()` with no args returns an empty set
548
- /// - `set(iterable)` creates a set from any iterable (list, tuple, set, dict, range, str, bytes)
549
- pub fn init(vm: &mut VM<'_, '_, impl ResourceTracker>, args: ArgValues) -> RunResult<Value> {
550
- let value = args.get_zero_one_arg("set", vm.heap)?;
551
- let set = match value {
552
- None => Self::new(),
553
- Some(v) => Self::from_iterable(v, vm)?,
554
- };
555
- let heap_id = vm.heap.allocate(HeapData::Set(set))?;
556
- Ok(Value::Ref(heap_id))
557
- }
558
-
559
- /// Creates a set from a MontyIter, adding elements one by one.
560
- ///
561
- /// Unlike list/tuple which can just collect into a Vec, sets need to add
562
- /// each element individually to handle duplicates and compute hashes.
563
- fn from_iterator(iter: MontyIter, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
564
- defer_drop_mut!(iter, vm);
565
- let mut set = Self::with_capacity(iter.size_hint(vm.heap));
566
- while let Some(item) = iter.for_next(vm)? {
567
- set.add(item, vm)?;
568
- }
569
- Ok(set)
570
- }
571
-
572
- /// Creates a set from an iterable value.
573
- ///
574
- /// This is a convenience method used by helper methods that need to convert
575
- /// arbitrary iterables to sets. It uses `MontyIter` internally.
576
- fn from_iterable(iterable: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
577
- let iter = MontyIter::new(iterable, vm)?;
578
- let set = Self::from_iterator(iter, vm)?;
579
- Ok(set)
580
- }
581
- }
582
-
583
- impl DropWithHeap for Set {
584
- fn drop_with_heap<H: ContainsHeap>(self, heap: &mut H) {
585
- self.0.drop_with_heap(heap);
586
- }
587
- }
588
-
589
- impl DropWithHeap for SetStorage {
590
- fn drop_with_heap<H: ContainsHeap>(self, heap: &mut H) {
591
- self.entries.drop_with_heap(heap);
592
- }
593
- }
594
-
595
- impl DropWithHeap for FrozenSet {
596
- fn drop_with_heap<H: ContainsHeap>(self, heap: &mut H) {
597
- self.0.drop_with_heap(heap);
598
- }
599
- }
600
-
601
- impl DropWithHeap for SetEntry {
602
- fn drop_with_heap<H: ContainsHeap>(self, heap: &mut H) {
603
- self.value.drop_with_heap(heap);
604
- }
605
- }
606
-
607
- impl PyTrait for Set {
608
- fn py_type(&self, _heap: &Heap<impl ResourceTracker>) -> Type {
609
- Type::Set
610
- }
611
-
612
- fn py_estimate_size(&self) -> usize {
613
- self.0.estimate_size()
614
- }
615
-
616
- fn py_len(&self, _vm: &VM<'_, '_, impl ResourceTracker>) -> Option<usize> {
617
- Some(self.len())
618
- }
619
-
620
- fn py_eq(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> Result<bool, ResourceError> {
621
- if self.len() != other.len() {
622
- return Ok(false);
623
- }
624
- let token = vm.heap.incr_recursion_depth()?;
625
- defer_drop!(token, vm);
626
- self.0.eq(&other.0, vm)
627
- }
628
-
629
- fn py_dec_ref_ids(&mut self, stack: &mut Vec<HeapId>) {
630
- self.0.collect_dec_ref_ids(stack);
631
- }
632
-
633
- fn py_bool(&self, _vm: &VM<'_, '_, impl ResourceTracker>) -> bool {
634
- !self.is_empty()
635
- }
636
-
637
- fn py_repr_fmt(
638
- &self,
639
- f: &mut impl Write,
640
- vm: &VM<'_, '_, impl ResourceTracker>,
641
- heap_ids: &mut AHashSet<HeapId>,
642
- ) -> std::fmt::Result {
643
- self.0.repr_fmt(f, vm, heap_ids, "set")
644
- }
645
-
646
- fn py_call_attr(
647
- &mut self,
648
- _self_id: HeapId,
649
- vm: &mut VM<'_, '_, impl ResourceTracker>,
650
- attr: &EitherStr,
651
- args: ArgValues,
652
- ) -> RunResult<CallResult> {
653
- let value = match attr.static_string() {
654
- Some(StaticStrings::Add) => {
655
- let value = args.get_one_arg("set.add", vm.heap)?;
656
- self.add(value, vm)?;
657
- Ok(Value::None)
658
- }
659
- Some(StaticStrings::Remove) => {
660
- let value = args.get_one_arg("set.remove", vm.heap)?;
661
- defer_drop!(value, vm);
662
- self.remove(value, vm)?;
663
- Ok(Value::None)
664
- }
665
- Some(StaticStrings::Discard) => {
666
- let value = args.get_one_arg("set.discard", vm.heap)?;
667
- defer_drop!(value, vm);
668
- self.discard(value, vm)?;
669
- Ok(Value::None)
670
- }
671
- Some(StaticStrings::Pop) => {
672
- args.check_zero_args("set.pop", vm.heap)?;
673
- self.pop()
674
- }
675
- Some(StaticStrings::Clear) => {
676
- args.check_zero_args("set.clear", vm.heap)?;
677
- self.clear(vm.heap);
678
- Ok(Value::None)
679
- }
680
- Some(StaticStrings::Copy) => {
681
- args.check_zero_args("set.copy", vm.heap)?;
682
- let copy = self.copy(vm.heap);
683
- let heap_id = vm.heap.allocate(HeapData::Set(copy))?;
684
- Ok(Value::Ref(heap_id))
685
- }
686
- Some(StaticStrings::Update) => {
687
- let other = args.get_one_arg("set.update", vm.heap)?;
688
- self.update_from_value(other, vm)?;
689
- Ok(Value::None)
690
- }
691
- Some(StaticStrings::Union) => {
692
- let other = args.get_one_arg("set.union", vm.heap)?;
693
- let result = self.union_from_value(other, vm)?;
694
- let heap_id = vm.heap.allocate(HeapData::Set(result))?;
695
- Ok(Value::Ref(heap_id))
696
- }
697
- Some(StaticStrings::Intersection) => {
698
- let other = args.get_one_arg("set.intersection", vm.heap)?;
699
- let result = self.intersection_from_value(other, vm)?;
700
- let heap_id = vm.heap.allocate(HeapData::Set(result))?;
701
- Ok(Value::Ref(heap_id))
702
- }
703
- Some(StaticStrings::Difference) => {
704
- let other = args.get_one_arg("set.difference", vm.heap)?;
705
- let result = self.difference_from_value(other, vm)?;
706
- let heap_id = vm.heap.allocate(HeapData::Set(result))?;
707
- Ok(Value::Ref(heap_id))
708
- }
709
- Some(StaticStrings::SymmetricDifference) => {
710
- let other = args.get_one_arg("set.symmetric_difference", vm.heap)?;
711
- let result = self.symmetric_difference_from_value(other, vm)?;
712
- let heap_id = vm.heap.allocate(HeapData::Set(result))?;
713
- Ok(Value::Ref(heap_id))
714
- }
715
- Some(StaticStrings::Issubset) => {
716
- let other = args.get_one_arg("set.issubset", vm.heap)?;
717
- defer_drop!(other, vm);
718
- Ok(Value::Bool(self.issubset_from_value(other, vm)?))
719
- }
720
- Some(StaticStrings::Issuperset) => {
721
- let other = args.get_one_arg("set.issuperset", vm.heap)?;
722
- defer_drop!(other, vm);
723
- Ok(Value::Bool(self.issuperset_from_value(other, vm)?))
724
- }
725
- Some(StaticStrings::Isdisjoint) => {
726
- let other = args.get_one_arg("set.isdisjoint", vm.heap)?;
727
- defer_drop!(other, vm);
728
- Ok(Value::Bool(self.isdisjoint_from_value(other, vm)?))
729
- }
730
- _ => {
731
- args.drop_with_heap(vm);
732
- return Err(ExcType::attribute_error(Type::Set, attr.as_str(vm.interns)));
733
- }
734
- };
735
- value.map(CallResult::Value)
736
- }
737
-
738
- fn py_sub(
739
- &self,
740
- _other: &Self,
741
- _vm: &mut VM<'_, '_, impl ResourceTracker>,
742
- ) -> Result<Option<Value>, crate::resource::ResourceError> {
743
- // This is called from heap.rs with two Sets
744
- // We need interns for contains check, but py_sub doesn't have it
745
- // This is a limitation - we'll need to handle this differently
746
- // For now, return None to indicate not supported via this path
747
- Ok(None)
748
- }
749
- }
750
-
751
- /// Pure set/frozenset binary operators shared by both concrete container types.
752
- #[derive(Debug, Clone, Copy)]
753
- pub(crate) enum SetBinaryOp {
754
- And,
755
- Or,
756
- Xor,
757
- Sub,
758
- }
759
-
760
- /// Helper methods for set operations with arbitrary iterables.
761
- impl Set {
762
- /// Implements operator-form set algebra, which only accepts set/frozenset operands.
763
- ///
764
- /// Unlike method forms such as `set.union(iterable)`, the binary operators
765
- /// `& | ^ -` are intentionally strict and return `None` for operands outside
766
- /// the set-like values CPython accepts here (`set`, `frozenset`,
767
- /// `dict_keys`, and `dict_items`) so the VM can raise the standard
768
- /// unsupported-operands `TypeError`.
769
- pub(crate) fn binary_op_value(
770
- &self,
771
- other: &Value,
772
- op: SetBinaryOp,
773
- vm: &mut VM<'_, '_, impl ResourceTracker>,
774
- ) -> RunResult<Option<Self>> {
775
- let Some(other_storage) = get_storage_from_set_operand(other, vm)? else {
776
- return Ok(None);
777
- };
778
- defer_drop!(other_storage, vm);
779
-
780
- let result = match op {
781
- SetBinaryOp::And => Self(self.0.intersection(other_storage, vm)?),
782
- SetBinaryOp::Or => Self(self.0.union(other_storage, vm)?),
783
- SetBinaryOp::Xor => Self(self.0.symmetric_difference(other_storage, vm)?),
784
- SetBinaryOp::Sub => Self(self.0.difference(other_storage, vm)?),
785
- };
786
- Ok(Some(result))
787
- }
788
-
789
- /// Updates this set with elements from an iterable value.
790
- fn update_from_value(&mut self, other: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<()> {
791
- let heap = &mut *vm.heap;
792
- // Try to get entries from a Set/FrozenSet directly
793
- let entries_opt = match &other {
794
- Value::Ref(id) => match heap.get(*id) {
795
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(heap)),
796
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(heap)),
797
- _ => None,
798
- },
799
- _ => None,
800
- };
801
-
802
- if let Some(entries) = entries_opt {
803
- other.drop_with_heap(heap);
804
- for (value, _hash) in entries {
805
- self.add(value, vm)?;
806
- }
807
- return Ok(());
808
- }
809
-
810
- // Fall back to creating a temporary set from the iterable
811
- let temp_set = Self::from_iterable(other, vm)?;
812
- defer_drop!(temp_set, vm);
813
- self.0.update(&temp_set.0, vm)?;
814
- Ok(())
815
- }
816
-
817
- /// Returns a new set with elements from both this set and an iterable.
818
- fn union_from_value(&self, other: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
819
- let other_storage = Self::get_storage_from_value(other, vm)?;
820
- defer_drop!(other_storage, vm);
821
- let result_storage = self.0.union(other_storage, vm)?;
822
- Ok(Self(result_storage))
823
- }
824
-
825
- /// Returns a new set with elements common to both this set and an iterable.
826
- fn intersection_from_value(&self, other: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
827
- let other_storage = Self::get_storage_from_value(other, vm)?;
828
- defer_drop!(other_storage, vm);
829
- let result_storage = self.0.intersection(other_storage, vm)?;
830
- Ok(Self(result_storage))
831
- }
832
-
833
- /// Returns a new set with elements in this set but not in an iterable.
834
- fn difference_from_value(&self, other: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
835
- let other_storage = Self::get_storage_from_value(other, vm)?;
836
- defer_drop!(other_storage, vm);
837
- let result_storage = self.0.difference(other_storage, vm)?;
838
- Ok(Self(result_storage))
839
- }
840
-
841
- /// Returns a new set with elements in either set but not both.
842
- fn symmetric_difference_from_value(
843
- &self,
844
- other: Value,
845
- vm: &mut VM<'_, '_, impl ResourceTracker>,
846
- ) -> RunResult<Self> {
847
- let other_storage = Self::get_storage_from_value(other, vm)?;
848
- defer_drop!(other_storage, vm);
849
- let result_storage = self.0.symmetric_difference(other_storage, vm)?;
850
- Ok(Self(result_storage))
851
- }
852
-
853
- /// Checks if this set is a subset of an iterable.
854
- fn issubset_from_value(&self, other: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
855
- // Try to get entries from a Set/FrozenSet directly
856
- let entries_opt = match other {
857
- Value::Ref(id) => match vm.heap.get(*id) {
858
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(vm.heap)),
859
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(vm.heap)),
860
- _ => None,
861
- },
862
- _ => None,
863
- };
864
-
865
- if let Some(entries) = entries_opt {
866
- let other_storage = SetStorage::from_entries(entries);
867
- defer_drop!(other_storage, vm);
868
- return self.0.is_subset(other_storage, vm);
869
- }
870
-
871
- // Handle all other iterables (list, tuple, range, str, bytes, dict, etc.)
872
- let temp = Self::from_iterable(other.clone_with_heap(vm), vm)?;
873
- defer_drop!(temp, vm);
874
- self.0.is_subset(&temp.0, vm)
875
- }
876
-
877
- /// Checks if this set is a superset of an iterable.
878
- fn issuperset_from_value(&self, other: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
879
- // Try to get entries from a Set/FrozenSet directly
880
- let entries_opt = match other {
881
- Value::Ref(id) => match vm.heap.get(*id) {
882
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(vm.heap)),
883
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(vm.heap)),
884
- _ => None,
885
- },
886
- _ => None,
887
- };
888
-
889
- if let Some(entries) = entries_opt {
890
- let other_storage = SetStorage::from_entries(entries);
891
- defer_drop!(other_storage, vm);
892
- return self.0.is_superset(other_storage, vm);
893
- }
894
-
895
- // Handle all other iterables (list, tuple, range, str, bytes, dict, etc.)
896
- let temp = Self::from_iterable(other.clone_with_heap(vm), vm)?;
897
- defer_drop!(temp, vm);
898
- self.0.is_superset(&temp.0, vm)
899
- }
900
-
901
- /// Checks if this set has no elements in common with an iterable.
902
- fn isdisjoint_from_value(&self, other: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
903
- // Try to get entries from a Set/FrozenSet directly
904
- let entries_opt = match other {
905
- Value::Ref(id) => match vm.heap.get(*id) {
906
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(vm.heap)),
907
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(vm.heap)),
908
- _ => None,
909
- },
910
- _ => None,
911
- };
912
-
913
- if let Some(entries) = entries_opt {
914
- let other_storage = SetStorage::from_entries(entries);
915
- defer_drop!(other_storage, vm);
916
- return self.0.is_disjoint(other_storage, vm);
917
- }
918
-
919
- // Handle all other iterables (list, tuple, range, str, bytes, dict, etc.)
920
- let temp = Self::from_iterable(other.clone_with_heap(vm), vm)?;
921
- defer_drop!(temp, vm);
922
- self.0.is_disjoint(&temp.0, vm)
923
- }
924
-
925
- /// Helper to get SetStorage from a Value (either directly or by conversion).
926
- fn get_storage_from_value(value: Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<SetStorage> {
927
- // Try to get entries from a Set/FrozenSet directly
928
- let entries_opt = match &value {
929
- Value::Ref(id) => match vm.heap.get(*id) {
930
- HeapData::Set(set) => Some(set.0.clone_entries(vm.heap)),
931
- HeapData::FrozenSet(set) => Some(set.0.clone_entries(vm.heap)),
932
- _ => None,
933
- },
934
- _ => None,
935
- };
936
-
937
- if let Some(entries) = entries_opt {
938
- value.drop_with_heap(vm);
939
- return Ok(SetStorage::from_entries(entries));
940
- }
941
-
942
- // Convert iterable to set
943
- let temp_set = Self::from_iterable(value, vm)?;
944
- Ok(temp_set.0)
945
- }
946
- }
947
-
948
- /// Python frozenset type - immutable, unordered collection of unique hashable elements.
949
- ///
950
- /// FrozenSets support the same set algebra operations as sets (union, intersection,
951
- /// difference, symmetric difference) but are immutable and therefore hashable.
952
- ///
953
- /// # Hashability
954
- /// Unlike mutable sets, frozensets can be used as dict keys or set elements because
955
- /// they are immutable. The hash is computed as the XOR of element hashes (order-independent).
956
- #[derive(Debug, Default)]
957
- pub(crate) struct FrozenSet(SetStorage);
958
-
959
- impl FrozenSet {
960
- /// Creates a new empty frozenset.
961
- #[must_use]
962
- pub fn new() -> Self {
963
- Self(SetStorage::new())
964
- }
965
-
966
- /// Returns the number of elements in the frozenset.
967
- #[must_use]
968
- pub fn len(&self) -> usize {
969
- self.0.len()
970
- }
971
-
972
- /// Returns true if the frozenset is empty.
973
- #[must_use]
974
- pub fn is_empty(&self) -> bool {
975
- self.0.is_empty()
976
- }
977
-
978
- /// Returns whether this frozenset contains any heap references (`Value::Ref`).
979
- ///
980
- /// Used during allocation to determine if this container could create cycles.
981
- #[inline]
982
- #[must_use]
983
- pub fn has_refs(&self) -> bool {
984
- self.0.has_refs()
985
- }
986
-
987
- /// Returns a shallow copy of the frozenset.
988
- #[must_use]
989
- pub fn copy(&self, heap: &mut Heap<impl ResourceTracker>) -> Self {
990
- Self(self.0.clone_with_heap(heap))
991
- }
992
-
993
- /// Returns the internal storage.
994
- pub(crate) fn storage(&self) -> &SetStorage {
995
- &self.0
996
- }
997
-
998
- /// Checks if the frozenset contains a value.
999
- pub fn contains(&self, value: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
1000
- self.0.contains(value, vm)
1001
- }
1002
-
1003
- /// Computes the hash of this frozenset.
1004
- ///
1005
- /// The hash is the XOR of all element hashes, making it order-independent.
1006
- /// Checks recursion depth before recursing into element hashes.
1007
- pub fn compute_hash(
1008
- &self,
1009
- heap: &mut Heap<impl ResourceTracker>,
1010
- interns: &Interns,
1011
- ) -> Result<Option<u64>, ResourceError> {
1012
- let token = heap.incr_recursion_depth()?;
1013
- defer_drop!(token, heap);
1014
- let mut hash: u64 = 0;
1015
- for entry in &self.0.entries {
1016
- // All elements must be hashable (enforced at construction)
1017
- match entry.value.py_hash(heap, interns)? {
1018
- Some(h) => hash ^= h,
1019
- None => return Ok(None),
1020
- }
1021
- }
1022
- Ok(Some(hash))
1023
- }
1024
-
1025
- /// Creates a frozenset from a Set, consuming the Set's storage.
1026
- ///
1027
- /// This is used when we need to convert a mutable set to an immutable frozenset
1028
- /// without cloning.
1029
- pub fn from_set(set: Set) -> Self {
1030
- Self(set.0)
1031
- }
1032
-
1033
- /// Creates a frozenset from the `frozenset()` constructor call.
1034
- ///
1035
- /// - `frozenset()` with no args returns an empty frozenset
1036
- /// - `frozenset(iterable)` creates a frozenset from any iterable (list, tuple, set, dict, range, str, bytes)
1037
- pub fn init(vm: &mut VM<'_, '_, impl ResourceTracker>, args: ArgValues) -> RunResult<Value> {
1038
- let value = args.get_zero_one_arg("frozenset", vm.heap)?;
1039
- let frozenset = match value {
1040
- None => Self::new(),
1041
- Some(v) => Self::from_set(Set::from_iterable(v, vm)?),
1042
- };
1043
- let heap_id = vm.heap.allocate(HeapData::FrozenSet(frozenset))?;
1044
- Ok(Value::Ref(heap_id))
1045
- }
1046
-
1047
- /// Returns a new frozenset with elements from both this and another set.
1048
- pub(crate) fn union(&self, other: &SetStorage, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
1049
- Ok(Self(self.0.union(other, vm)?))
1050
- }
1051
-
1052
- /// Returns a new frozenset with elements common to both sets.
1053
- pub(crate) fn intersection(
1054
- &self,
1055
- other: &SetStorage,
1056
- vm: &mut VM<'_, '_, impl ResourceTracker>,
1057
- ) -> RunResult<Self> {
1058
- Ok(Self(self.0.intersection(other, vm)?))
1059
- }
1060
-
1061
- /// Returns a new frozenset with elements in this set but not in other.
1062
- pub(crate) fn difference(&self, other: &SetStorage, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<Self> {
1063
- Ok(Self(self.0.difference(other, vm)?))
1064
- }
1065
-
1066
- /// Returns a new frozenset with elements in either set but not both.
1067
- pub(crate) fn symmetric_difference(
1068
- &self,
1069
- other: &SetStorage,
1070
- vm: &mut VM<'_, '_, impl ResourceTracker>,
1071
- ) -> RunResult<Self> {
1072
- Ok(Self(self.0.symmetric_difference(other, vm)?))
1073
- }
1074
- }
1075
-
1076
- impl PyTrait for FrozenSet {
1077
- fn py_type(&self, _heap: &Heap<impl ResourceTracker>) -> Type {
1078
- Type::FrozenSet
1079
- }
1080
-
1081
- fn py_estimate_size(&self) -> usize {
1082
- self.0.estimate_size()
1083
- }
1084
-
1085
- fn py_len(&self, _vm: &VM<'_, '_, impl ResourceTracker>) -> Option<usize> {
1086
- Some(self.len())
1087
- }
1088
-
1089
- fn py_eq(&self, other: &Self, vm: &mut VM<'_, '_, impl ResourceTracker>) -> Result<bool, ResourceError> {
1090
- if self.len() != other.len() {
1091
- return Ok(false);
1092
- }
1093
- let token = vm.heap.incr_recursion_depth()?;
1094
- defer_drop!(token, vm);
1095
- self.0.eq(&other.0, vm)
1096
- }
1097
-
1098
- fn py_dec_ref_ids(&mut self, stack: &mut Vec<HeapId>) {
1099
- self.0.collect_dec_ref_ids(stack);
1100
- }
1101
-
1102
- fn py_bool(&self, _vm: &VM<'_, '_, impl ResourceTracker>) -> bool {
1103
- !self.is_empty()
1104
- }
1105
-
1106
- fn py_repr_fmt(
1107
- &self,
1108
- f: &mut impl Write,
1109
- vm: &VM<'_, '_, impl ResourceTracker>,
1110
- heap_ids: &mut AHashSet<HeapId>,
1111
- ) -> std::fmt::Result {
1112
- self.0.repr_fmt(f, vm, heap_ids, "frozenset")
1113
- }
1114
-
1115
- fn py_call_attr(
1116
- &mut self,
1117
- _self_id: HeapId,
1118
- vm: &mut VM<'_, '_, impl ResourceTracker>,
1119
- attr: &EitherStr,
1120
- args: ArgValues,
1121
- ) -> RunResult<CallResult> {
1122
- let heap = &mut *vm.heap;
1123
- let interns = vm.interns;
1124
- let value = match attr.static_string() {
1125
- Some(StaticStrings::Copy) => {
1126
- args.check_zero_args("frozenset.copy", heap)?;
1127
- let copy = self.copy(heap);
1128
- let heap_id = heap.allocate(HeapData::FrozenSet(copy))?;
1129
- Ok(Value::Ref(heap_id))
1130
- }
1131
- Some(StaticStrings::Union) => {
1132
- let other = args.get_one_arg("frozenset.union", heap)?;
1133
- let other_storage = Set::get_storage_from_value(other, vm)?;
1134
- defer_drop!(other_storage, vm);
1135
- let result = self.union(other_storage, vm)?;
1136
- let heap_id = vm.heap.allocate(HeapData::FrozenSet(result))?;
1137
- Ok(Value::Ref(heap_id))
1138
- }
1139
- Some(StaticStrings::Intersection) => {
1140
- let other = args.get_one_arg("frozenset.intersection", heap)?;
1141
- let other_storage = Set::get_storage_from_value(other, vm)?;
1142
- defer_drop!(other_storage, vm);
1143
- let result = self.intersection(other_storage, vm)?;
1144
- let heap_id = vm.heap.allocate(HeapData::FrozenSet(result))?;
1145
- Ok(Value::Ref(heap_id))
1146
- }
1147
- Some(StaticStrings::Difference) => {
1148
- let other = args.get_one_arg("frozenset.difference", heap)?;
1149
- let other_storage = Set::get_storage_from_value(other, vm)?;
1150
- defer_drop!(other_storage, vm);
1151
- let result = self.difference(other_storage, vm)?;
1152
- let heap_id = vm.heap.allocate(HeapData::FrozenSet(result))?;
1153
- Ok(Value::Ref(heap_id))
1154
- }
1155
- Some(StaticStrings::SymmetricDifference) => {
1156
- let other = args.get_one_arg("frozenset.symmetric_difference", heap)?;
1157
- let other_storage = Set::get_storage_from_value(other, vm)?;
1158
- defer_drop!(other_storage, vm);
1159
- let result = self.symmetric_difference(other_storage, vm)?;
1160
- let heap_id = vm.heap.allocate(HeapData::FrozenSet(result))?;
1161
- Ok(Value::Ref(heap_id))
1162
- }
1163
- Some(StaticStrings::Issubset) => {
1164
- let other = args.get_one_arg("frozenset.issubset", heap)?;
1165
- defer_drop!(other, vm);
1166
- Ok(Value::Bool(self.issubset_from_value(other, vm)?))
1167
- }
1168
- Some(StaticStrings::Issuperset) => {
1169
- let other = args.get_one_arg("frozenset.issuperset", heap)?;
1170
- defer_drop!(other, vm);
1171
- Ok(Value::Bool(self.issuperset_from_value(other, vm)?))
1172
- }
1173
- Some(StaticStrings::Isdisjoint) => {
1174
- let other = args.get_one_arg("frozenset.isdisjoint", heap)?;
1175
- defer_drop!(other, vm);
1176
- Ok(Value::Bool(self.isdisjoint_from_value(other, vm)?))
1177
- }
1178
- _ => {
1179
- args.drop_with_heap(heap);
1180
- return Err(ExcType::attribute_error(Type::FrozenSet, attr.as_str(interns)));
1181
- }
1182
- };
1183
- value.map(CallResult::Value)
1184
- }
1185
-
1186
- fn py_sub(
1187
- &self,
1188
- _other: &Self,
1189
- _vm: &mut VM<'_, '_, impl ResourceTracker>,
1190
- ) -> Result<Option<Value>, crate::resource::ResourceError> {
1191
- // Same limitation as Set - needs interns
1192
- Ok(None)
1193
- }
1194
- }
1195
-
1196
- /// Helper methods for frozenset operations with arbitrary iterables.
1197
- impl FrozenSet {
1198
- /// Implements operator-form set algebra, which only accepts set/frozenset operands.
1199
- ///
1200
- /// CPython returns the type of the left operand for pure set/frozenset binary
1201
- /// operators, so this helper keeps the result as `frozenset` even when the
1202
- /// right operand is a mutable `set`. Like `set`, the accepted right-hand
1203
- /// side includes CPython's set-like dict views.
1204
- pub(crate) fn binary_op_value(
1205
- &self,
1206
- other: &Value,
1207
- op: SetBinaryOp,
1208
- vm: &mut VM<'_, '_, impl ResourceTracker>,
1209
- ) -> RunResult<Option<Self>> {
1210
- let Some(other_storage) = get_storage_from_set_operand(other, vm)? else {
1211
- return Ok(None);
1212
- };
1213
- defer_drop!(other_storage, vm);
1214
-
1215
- let result = match op {
1216
- SetBinaryOp::And => Self(self.0.intersection(other_storage, vm)?),
1217
- SetBinaryOp::Or => Self(self.0.union(other_storage, vm)?),
1218
- SetBinaryOp::Xor => Self(self.0.symmetric_difference(other_storage, vm)?),
1219
- SetBinaryOp::Sub => Self(self.0.difference(other_storage, vm)?),
1220
- };
1221
- Ok(Some(result))
1222
- }
1223
-
1224
- /// Checks if this frozenset is a subset of an iterable.
1225
- fn issubset_from_value(&self, other: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
1226
- // Try to get entries from a Set/FrozenSet directly
1227
- let entries_opt = match other {
1228
- Value::Ref(id) => match vm.heap.get(*id) {
1229
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(vm.heap)),
1230
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(vm.heap)),
1231
- _ => None,
1232
- },
1233
- _ => None,
1234
- };
1235
-
1236
- if let Some(entries) = entries_opt {
1237
- // Build temporary storage and check
1238
- let other_storage = SetStorage::from_entries(entries);
1239
- defer_drop!(other_storage, vm);
1240
- return self.0.is_subset(other_storage, vm);
1241
- }
1242
-
1243
- // Handle all other iterables (list, tuple, range, str, bytes, dict, etc.)
1244
- let temp = Set::from_iterable(other.clone_with_heap(vm), vm)?;
1245
- defer_drop!(temp, vm);
1246
- self.0.is_subset(&temp.0, vm)
1247
- }
1248
-
1249
- /// Checks if this frozenset is a superset of an iterable.
1250
- fn issuperset_from_value(&self, other: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
1251
- // Try to get entries from a Set/FrozenSet directly
1252
- let entries_opt = match other {
1253
- Value::Ref(id) => match vm.heap.get(*id) {
1254
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(vm.heap)),
1255
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(vm.heap)),
1256
- _ => None,
1257
- },
1258
- _ => None,
1259
- };
1260
-
1261
- if let Some(entries) = entries_opt {
1262
- // Build temporary storage and check
1263
- let other_storage = SetStorage::from_entries(entries);
1264
- defer_drop!(other_storage, vm);
1265
- return self.0.is_superset(other_storage, vm);
1266
- }
1267
-
1268
- // Handle all other iterables (list, tuple, range, str, bytes, dict, etc.)
1269
- let temp = Set::from_iterable(other.clone_with_heap(vm), vm)?;
1270
- defer_drop!(temp, vm);
1271
- self.0.is_superset(&temp.0, vm)
1272
- }
1273
-
1274
- /// Checks if this frozenset has no elements in common with an iterable.
1275
- fn isdisjoint_from_value(&self, other: &Value, vm: &mut VM<'_, '_, impl ResourceTracker>) -> RunResult<bool> {
1276
- // Try to get entries from a Set/FrozenSet directly
1277
- let entries_opt = match other {
1278
- Value::Ref(id) => match vm.heap.get(*id) {
1279
- HeapData::Set(other_set) => Some(other_set.0.clone_entries(vm.heap)),
1280
- HeapData::FrozenSet(other_set) => Some(other_set.0.clone_entries(vm.heap)),
1281
- _ => None,
1282
- },
1283
- _ => None,
1284
- };
1285
-
1286
- if let Some(entries) = entries_opt {
1287
- // Build temporary storage and check
1288
- let other_storage = SetStorage::from_entries(entries);
1289
- defer_drop!(other_storage, vm);
1290
- return self.0.is_disjoint(other_storage, vm);
1291
- }
1292
-
1293
- // Handle all other iterables (list, tuple, range, str, bytes, dict, etc.)
1294
- let temp = Set::from_iterable(other.clone_with_heap(vm), vm)?;
1295
- defer_drop!(temp, vm);
1296
- self.0.is_disjoint(&temp.0, vm)
1297
- }
1298
- }
1299
-
1300
- /// Returns temporary set storage only for operator-valid set operands.
1301
- ///
1302
- /// This is stricter than `Set::get_storage_from_value(...)`: operator forms
1303
- /// only accept CPython's set-like operands (`set`, `frozenset`, `dict_keys`,
1304
- /// and `dict_items`), while method forms accept any iterable.
1305
- fn get_storage_from_set_operand(
1306
- value: &Value,
1307
- vm: &mut VM<'_, '_, impl ResourceTracker>,
1308
- ) -> RunResult<Option<SetStorage>> {
1309
- let Value::Ref(id) = value else {
1310
- return Ok(None);
1311
- };
1312
-
1313
- match vm.heap.get(*id) {
1314
- HeapData::Set(set) => Ok(Some(SetStorage::from_entries(set.0.clone_entries(vm.heap)))),
1315
- HeapData::FrozenSet(set) => Ok(Some(SetStorage::from_entries(set.0.clone_entries(vm.heap)))),
1316
- // Dict views are `Copy` — matched value is not borrowed from the heap,
1317
- // so `to_set` can take `&mut VM` below without conflict.
1318
- HeapData::DictKeysView(view) => {
1319
- let Set(storage) = view.to_set(vm)?;
1320
- Ok(Some(storage))
1321
- }
1322
- HeapData::DictItemsView(view) => {
1323
- let Set(storage) = view.to_set(vm)?;
1324
- Ok(Some(storage))
1325
- }
1326
- _ => Ok(None),
1327
- }
1328
- }
1329
-
1330
- // Custom serde implementations for SetStorage, Set, and FrozenSet.
1331
- // Only serialize entries; rebuild the indices hash table on deserialize.
1332
-
1333
- impl serde::Serialize for SetStorage {
1334
- fn serialize<S: serde::Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
1335
- self.entries.serialize(serializer)
1336
- }
1337
- }
1338
-
1339
- impl<'de> serde::Deserialize<'de> for SetStorage {
1340
- fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
1341
- let entries: Vec<SetEntry> = serde::Deserialize::deserialize(deserializer)?;
1342
- // Rebuild the indices hash table from the entries
1343
- let mut indices = HashTable::with_capacity(entries.len());
1344
- for (idx, entry) in entries.iter().enumerate() {
1345
- indices.insert_unique(entry.hash, idx, |&i| entries[i].hash);
1346
- }
1347
- Ok(Self { indices, entries })
1348
- }
1349
- }
1350
-
1351
- impl serde::Serialize for Set {
1352
- fn serialize<S: serde::Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
1353
- self.0.serialize(serializer)
1354
- }
1355
- }
1356
-
1357
- impl<'de> serde::Deserialize<'de> for Set {
1358
- fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
1359
- Ok(Self(SetStorage::deserialize(deserializer)?))
1360
- }
1361
- }
1362
-
1363
- impl serde::Serialize for FrozenSet {
1364
- fn serialize<S: serde::Serializer>(&self, serializer: S) -> Result<S::Ok, S::Error> {
1365
- self.0.serialize(serializer)
1366
- }
1367
- }
1368
-
1369
- impl<'de> serde::Deserialize<'de> for FrozenSet {
1370
- fn deserialize<D: serde::Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error> {
1371
- Ok(Self(SetStorage::deserialize(deserializer)?))
1372
- }
1373
- }