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.
- package/README.md +77 -53
- package/__tests__/azd-plugin.test.js +109 -0
- package/__tests__/config.test.js +4 -3
- package/__tests__/discover.test.js +59 -0
- package/__tests__/goose-plugin.test.js +149 -0
- package/__tests__/help-json.test.js +2 -0
- package/__tests__/openhands-plugin.test.js +106 -0
- package/__tests__/plugin-cocoindex-code-uninstall.test.js +19 -0
- package/__tests__/plugin-cocoindex-code.test.js +37 -0
- package/__tests__/plugin-install-guidance.test.js +81 -0
- package/__tests__/plugins-registry.test.js +44 -0
- package/__tests__/plugins-store.test.js +40 -5
- package/__tests__/process-adapter.test.js +50 -1
- package/__tests__/server-app.test.js +1 -0
- package/__tests__/server-routes-commands.test.js +20 -2
- package/__tests__/server-routes-plugins.test.js +130 -0
- package/__tests__/skills.test.js +26 -0
- package/__tests__/squirrelscan-plugin.test.js +129 -0
- package/__tests__/uipath-plugin.test.js +104 -0
- package/__tests__/uipathcli-plugin.test.js +95 -0
- package/cli/adapters/mcp.js +2 -0
- package/cli/adapters/process.js +49 -2
- package/cli/config.js +240 -3
- package/cli/discover.js +157 -0
- package/cli/help-json.js +16 -1
- package/cli/plugin-install-guidance.js +92 -37
- package/cli/plugins-manager.js +1 -0
- package/cli/plugins-registry.js +74 -8
- package/cli/plugins-store.js +78 -17
- package/cli/skills-mcp.js +1 -1
- package/cli/skills.js +39 -2
- package/cli/supercli.js +87 -11
- package/docs/feature-gaps.md +8 -8
- package/docs/features/azd-uipath-plugins.md +43 -0
- package/docs/features/server-plugins.md +62 -0
- package/docs/features/skills.md +9 -5
- package/docs/{supported-harnesses.md → plugins-available.md} +4 -3
- package/docs/{plugin-harness-guide.md → plugins-how-to.md} +1 -1
- package/docs/plugins.md +26 -20
- package/docs/server-plugins-usage-guide.md +182 -0
- package/docs/skills-catalog.md +12 -10
- package/package.json +1 -1
- package/plugins/agent-browser/README.md +69 -0
- package/plugins/agent-browser/plugin.json +111 -0
- package/plugins/agent-browser/skills/quickstart/SKILL.md +66 -0
- package/plugins/aider/README.md +53 -0
- package/plugins/aider/plugin.json +105 -0
- package/plugins/aider/scripts/aider-wrapper.js +243 -0
- package/plugins/aider/scripts/setup-aider.js +37 -0
- package/plugins/aider/skills/dry-run-review.md +24 -0
- package/plugins/aider/skills/model-and-provider.md +24 -0
- package/plugins/aider/skills/one-shot-edits.md +30 -0
- package/plugins/aider/skills/quickstart/SKILL.md +51 -0
- package/plugins/azd/README.md +28 -0
- package/plugins/azd/plugin.json +87 -0
- package/plugins/azd/skills/quickstart/SKILL.md +41 -0
- package/plugins/blogwatcher/README.md +3 -3
- package/plugins/boxlite/Dockerfile +9 -0
- package/plugins/boxlite/README.md +62 -0
- package/plugins/boxlite/plugin.json +201 -0
- package/plugins/boxlite/scripts/run-boxlite.js +106 -0
- package/plugins/boxlite/skills/quickstart/SKILL.md +40 -0
- package/plugins/cass/plugin.json +150 -0
- package/plugins/cass/scripts/setup-cass.js +47 -0
- package/plugins/cass/skills/quickstart/SKILL.md +46 -0
- package/plugins/clever/README.md +46 -0
- package/plugins/clever/plugin.json +119 -0
- package/plugins/clever/scripts/setup-clever.js +28 -0
- package/plugins/clever/skills/auth-and-profile.md +29 -0
- package/plugins/clever/skills/passthrough-safety.md +21 -0
- package/plugins/clever/skills/quickstart/SKILL.md +45 -0
- package/plugins/clever/skills/resource-inventory.md +24 -0
- package/plugins/clix/README.md +4 -4
- package/plugins/cocoindex-code/README.md +64 -0
- package/plugins/cocoindex-code/plugin.json +81 -0
- package/plugins/cocoindex-code/scripts/__pycache__/query.cpython-310.pyc +0 -0
- package/plugins/cocoindex-code/scripts/__pycache__/query.cpython-311.pyc +0 -0
- package/plugins/cocoindex-code/scripts/post-install.js +61 -0
- package/plugins/cocoindex-code/scripts/post-uninstall.js +25 -0
- package/plugins/cocoindex-code/scripts/query.py +88 -0
- package/plugins/cocoindex-code/scripts/run-query.js +50 -0
- package/plugins/cocoindex-code/skills/quickstart/SKILL.md +73 -0
- package/plugins/copilot/README.md +24 -0
- package/plugins/copilot/plugin.json +80 -0
- package/plugins/copilot/skills/quickstart/SKILL.md +44 -0
- package/plugins/gemini/README.md +24 -0
- package/plugins/gemini/plugin.json +98 -0
- package/plugins/gemini/skills/quickstart/SKILL.md +44 -0
- package/plugins/gifcap/plugin.json +119 -0
- package/plugins/gifcap/scripts/setup-gifcap.js +44 -0
- package/plugins/gifcap/skills/quickstart/SKILL.md +34 -0
- package/plugins/gifcap/test-record-quiet.gif +0 -0
- package/plugins/gifcap/test-record.gif +0 -0
- package/plugins/goose/README.md +36 -0
- package/plugins/goose/plugin.json +183 -0
- package/plugins/goose/skills/quickstart/SKILL.md +44 -0
- package/plugins/json-server/README.md +58 -0
- package/plugins/json-server/plugin.json +113 -0
- package/plugins/json-server/skills/quickstart/SKILL.md +57 -0
- package/plugins/lightpanda/README.md +145 -0
- package/plugins/lightpanda/package-lock.json +1375 -0
- package/plugins/lightpanda/package.json +12 -0
- package/plugins/lightpanda/plugin.json +116 -0
- package/plugins/lightpanda/scripts/lightpanda-contacts.js +494 -0
- package/plugins/lightpanda/scripts/lightpanda-generic-extract.js +403 -0
- package/plugins/lightpanda/scripts/lightpanda-wrapper.js +480 -0
- package/plugins/lightpanda/scripts/setup-lightpanda.js +39 -0
- package/plugins/lightpanda/skills/contact-discovery.md +51 -0
- package/plugins/lightpanda/skills/generic-extraction.md +66 -0
- package/plugins/lightpanda/skills/quickstart/SKILL.md +103 -0
- package/plugins/lightpanda/skills/resilient-navigation.md +42 -0
- package/plugins/monty/README.md +2 -2
- package/plugins/nullclaw/README.md +3 -3
- package/plugins/offline-ai/README.md +23 -0
- package/plugins/offline-ai/plugin.json +82 -0
- package/plugins/offline-ai/skills/quickstart/SKILL.md +43 -0
- package/plugins/openhands/README.md +25 -0
- package/plugins/openhands/plugin.json +116 -0
- package/plugins/openhands/skills/quickstart/SKILL.md +26 -0
- package/plugins/plandex/README.md +25 -0
- package/plugins/plandex/plugin.json +130 -0
- package/plugins/plandex/skills/quickstart/SKILL.md +50 -0
- package/plugins/plugins.json +188 -0
- package/plugins/squirrelscan/Dockerfile +5 -0
- package/plugins/squirrelscan/README.md +47 -0
- package/plugins/squirrelscan/plugin.json +493 -0
- package/plugins/squirrelscan/scripts/post-install.js +33 -0
- package/plugins/squirrelscan/scripts/post-uninstall.js +25 -0
- package/plugins/squirrelscan/scripts/run-squirrel.js +73 -0
- package/plugins/squirrelscan/skills/audit-workflow/SKILL.md +33 -0
- package/plugins/squirrelscan/skills/publish-report/SKILL.md +33 -0
- package/plugins/squirrelscan/skills/quickstart/SKILL.md +41 -0
- package/plugins/uipath/README.md +27 -0
- package/plugins/uipath/plugin.json +86 -0
- package/plugins/uipath/skills/quickstart/SKILL.md +47 -0
- package/plugins/uipathcli/README.md +28 -0
- package/plugins/uipathcli/plugin.json +120 -0
- package/plugins/uipathcli/scripts/run-uipath-cli.js +49 -0
- package/plugins/uipathcli/skills/quickstart/SKILL.md +22 -0
- package/plugins/xurl/README.md +4 -4
- package/server/app.js +5 -2
- package/server/public/app.js +3 -0
- package/server/routes/commands.js +95 -12
- package/server/routes/plugins.js +262 -0
- package/server/services/pluginsService.js +303 -0
- package/server/views/command-edit.ejs +196 -14
- package/server/views/partials/head.ejs +1 -0
- package/server/views/plugins.ejs +264 -0
- package/tests/test-plugins-registry.js +30 -0
- package/.beads/.br_history/issues.20260308_200823_636718328.jsonl +0 -20
- package/.beads/.br_history/issues.20260308_200823_636718328.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_200827_033159453.jsonl +0 -21
- package/.beads/.br_history/issues.20260308_200827_033159453.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_200829_595900053.jsonl +0 -22
- package/.beads/.br_history/issues.20260308_200829_595900053.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_200834_079930100.jsonl +0 -23
- package/.beads/.br_history/issues.20260308_200834_079930100.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_200858_370924996.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_200858_370924996.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201031_019730855.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201031_019730855.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201031_578974884.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201031_578974884.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201054_780345548.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201054_780345548.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201054_896980019.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201054_896980019.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201128_599819688.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201128_599819688.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201128_710221699.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201128_710221699.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201204_745649213.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201204_745649213.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201338_908436144.jsonl +0 -24
- package/.beads/.br_history/issues.20260308_201338_908436144.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201344_734860714.jsonl +0 -25
- package/.beads/.br_history/issues.20260308_201344_734860714.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_201630_819282295.jsonl +0 -25
- package/.beads/.br_history/issues.20260308_201630_819282295.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203538_054279699.jsonl +0 -25
- package/.beads/.br_history/issues.20260308_203538_054279699.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203547_597113070.jsonl +0 -26
- package/.beads/.br_history/issues.20260308_203547_597113070.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203547_775139216.jsonl +0 -27
- package/.beads/.br_history/issues.20260308_203547_775139216.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203547_950724773.jsonl +0 -28
- package/.beads/.br_history/issues.20260308_203547_950724773.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203548_107684523.jsonl +0 -29
- package/.beads/.br_history/issues.20260308_203548_107684523.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203548_310389993.jsonl +0 -30
- package/.beads/.br_history/issues.20260308_203548_310389993.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_203825_953337320.jsonl +0 -31
- package/.beads/.br_history/issues.20260308_203825_953337320.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_204056_071377736.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_204056_071377736.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205141_517616844.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205141_517616844.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205141_648994024.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205141_648994024.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205141_867598036.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205141_867598036.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205142_094157355.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205142_094157355.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205142_327315677.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205142_327315677.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205142_545563822.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205142_545563822.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205213_061989333.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205213_061989333.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205213_181103364.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205213_181103364.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205213_408872234.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205213_408872234.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205213_616681652.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205213_616681652.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205213_821507069.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205213_821507069.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205214_026661112.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205214_026661112.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205454_955250554.jsonl +0 -32
- package/.beads/.br_history/issues.20260308_205454_955250554.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205556_337800392.jsonl +0 -33
- package/.beads/.br_history/issues.20260308_205556_337800392.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_205824_274686694.jsonl +0 -33
- package/.beads/.br_history/issues.20260308_205824_274686694.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_210240_583768328.jsonl +0 -34
- package/.beads/.br_history/issues.20260308_210240_583768328.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212223_641541494.jsonl +0 -34
- package/.beads/.br_history/issues.20260308_212223_641541494.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212227_735550996.jsonl +0 -35
- package/.beads/.br_history/issues.20260308_212227_735550996.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212232_547298548.jsonl +0 -36
- package/.beads/.br_history/issues.20260308_212232_547298548.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212528_843628125.jsonl +0 -37
- package/.beads/.br_history/issues.20260308_212528_843628125.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212529_094530502.jsonl +0 -38
- package/.beads/.br_history/issues.20260308_212529_094530502.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212529_331000853.jsonl +0 -39
- package/.beads/.br_history/issues.20260308_212529_331000853.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212529_587925652.jsonl +0 -40
- package/.beads/.br_history/issues.20260308_212529_587925652.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212804_927764103.jsonl +0 -41
- package/.beads/.br_history/issues.20260308_212804_927764103.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212805_153673453.jsonl +0 -42
- package/.beads/.br_history/issues.20260308_212805_153673453.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212805_415982363.jsonl +0 -43
- package/.beads/.br_history/issues.20260308_212805_415982363.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212805_657497741.jsonl +0 -44
- package/.beads/.br_history/issues.20260308_212805_657497741.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212805_952838724.jsonl +0 -45
- package/.beads/.br_history/issues.20260308_212805_952838724.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212806_325433779.jsonl +0 -46
- package/.beads/.br_history/issues.20260308_212806_325433779.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212806_584685598.jsonl +0 -47
- package/.beads/.br_history/issues.20260308_212806_584685598.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212806_827817208.jsonl +0 -48
- package/.beads/.br_history/issues.20260308_212806_827817208.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212807_111320451.jsonl +0 -49
- package/.beads/.br_history/issues.20260308_212807_111320451.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212807_409545536.jsonl +0 -50
- package/.beads/.br_history/issues.20260308_212807_409545536.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212807_625063294.jsonl +0 -51
- package/.beads/.br_history/issues.20260308_212807_625063294.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212807_843906551.jsonl +0 -52
- package/.beads/.br_history/issues.20260308_212807_843906551.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212808_100304073.jsonl +0 -53
- package/.beads/.br_history/issues.20260308_212808_100304073.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212808_324723976.jsonl +0 -54
- package/.beads/.br_history/issues.20260308_212808_324723976.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212808_557513104.jsonl +0 -55
- package/.beads/.br_history/issues.20260308_212808_557513104.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_212808_788048322.jsonl +0 -56
- package/.beads/.br_history/issues.20260308_212808_788048322.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_213702_613249728.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_213702_613249728.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_213715_115792063.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_213715_115792063.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_213715_462220666.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_213715_462220666.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_213727_191258923.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_213727_191258923.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_213727_684383652.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_213727_684383652.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_213735_751882991.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_213735_751882991.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_222052_279844960.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_222052_279844960.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_222056_873282114.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_222056_873282114.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_222103_402410761.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_222103_402410761.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235202_180577215.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235202_180577215.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235202_387414163.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235202_387414163.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235202_564422794.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235202_564422794.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235202_742600597.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235202_742600597.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235208_133360069.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235208_133360069.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235505_473406307.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235505_473406307.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235505_662360489.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235505_662360489.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235505_843935624.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235505_843935624.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260308_235506_044530221.jsonl +0 -57
- package/.beads/.br_history/issues.20260308_235506_044530221.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_002618_115728731.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_002618_115728731.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_003748_878174586.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_003748_878174586.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_004057_868755623.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_004057_868755623.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_004058_512842163.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_004058_512842163.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_004058_994445226.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_004058_994445226.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_004059_475988596.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_004059_475988596.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_161902_566857851.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_161902_566857851.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_170512_277017739.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_170512_277017739.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_170512_477876921.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_170512_477876921.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_170512_664382701.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_170512_664382701.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_170512_859400333.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_170512_859400333.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_212326_082771164.jsonl +0 -57
- package/.beads/.br_history/issues.20260309_212326_082771164.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_212326_245619716.jsonl +0 -58
- package/.beads/.br_history/issues.20260309_212326_245619716.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_212326_403198317.jsonl +0 -59
- package/.beads/.br_history/issues.20260309_212326_403198317.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_212332_539197678.jsonl +0 -60
- package/.beads/.br_history/issues.20260309_212332_539197678.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_212332_731373599.jsonl +0 -60
- package/.beads/.br_history/issues.20260309_212332_731373599.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_212332_928710953.jsonl +0 -60
- package/.beads/.br_history/issues.20260309_212332_928710953.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_213021_341505240.jsonl +0 -60
- package/.beads/.br_history/issues.20260309_213021_341505240.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_213022_023136934.jsonl +0 -60
- package/.beads/.br_history/issues.20260309_213022_023136934.jsonl.meta.json +0 -1
- package/.beads/.br_history/issues.20260309_213022_400050719.jsonl +0 -60
- package/.beads/.br_history/issues.20260309_213022_400050719.jsonl.meta.json +0 -1
- package/.beads/config.yaml +0 -4
- package/.beads/issues.jsonl +0 -60
- package/.beads/metadata.json +0 -4
- package/docs/mcp-cheatsheet.md +0 -324
- package/docs/visual-overview.md +0 -21
- package/ref-monty/.cargo/config.toml +0 -3
- package/ref-monty/.claude/settings.json +0 -60
- package/ref-monty/.claude/skills/fastmod/SKILL.md +0 -22
- package/ref-monty/.claude/skills/python-playground/SKILL.md +0 -47
- package/ref-monty/.codecov.yml +0 -12
- package/ref-monty/.github/actions/build-pgo-wheel/action.yml +0 -72
- package/ref-monty/.github/workflows/ci.yml +0 -776
- package/ref-monty/.github/workflows/codspeed.yml +0 -45
- package/ref-monty/.github/workflows/init-npm-packages.yml +0 -82
- package/ref-monty/.pre-commit-config.yaml +0 -47
- package/ref-monty/.python-version +0 -1
- package/ref-monty/.rustfmt.toml +0 -4
- package/ref-monty/.zed/settings.json +0 -11
- package/ref-monty/CLAUDE.md +0 -535
- package/ref-monty/Cargo.lock +0 -3798
- package/ref-monty/Cargo.toml +0 -87
- package/ref-monty/LICENSE +0 -21
- package/ref-monty/Makefile +0 -216
- package/ref-monty/README.md +0 -430
- package/ref-monty/RELEASING.md +0 -47
- package/ref-monty/crates/fuzz/Cargo.toml +0 -30
- package/ref-monty/crates/fuzz/fuzz_targets/string_input_panic.rs +0 -37
- package/ref-monty/crates/fuzz/fuzz_targets/tokens_input_panic.rs +0 -552
- package/ref-monty/crates/monty/Cargo.toml +0 -68
- package/ref-monty/crates/monty/benches/main.rs +0 -247
- package/ref-monty/crates/monty/build.rs +0 -10
- package/ref-monty/crates/monty/src/args.rs +0 -733
- package/ref-monty/crates/monty/src/asyncio.rs +0 -179
- package/ref-monty/crates/monty/src/builtins/abs.rs +0 -55
- package/ref-monty/crates/monty/src/builtins/all.rs +0 -30
- package/ref-monty/crates/monty/src/builtins/any.rs +0 -30
- package/ref-monty/crates/monty/src/builtins/bin.rs +0 -59
- package/ref-monty/crates/monty/src/builtins/chr.rs +0 -46
- package/ref-monty/crates/monty/src/builtins/divmod.rs +0 -164
- package/ref-monty/crates/monty/src/builtins/enumerate.rs +0 -52
- package/ref-monty/crates/monty/src/builtins/filter.rs +0 -67
- package/ref-monty/crates/monty/src/builtins/getattr.rs +0 -65
- package/ref-monty/crates/monty/src/builtins/hash.rs +0 -28
- package/ref-monty/crates/monty/src/builtins/hex.rs +0 -58
- package/ref-monty/crates/monty/src/builtins/id.rs +0 -24
- package/ref-monty/crates/monty/src/builtins/isinstance.rs +0 -68
- package/ref-monty/crates/monty/src/builtins/len.rs +0 -25
- package/ref-monty/crates/monty/src/builtins/map.rs +0 -98
- package/ref-monty/crates/monty/src/builtins/min_max.rs +0 -113
- package/ref-monty/crates/monty/src/builtins/mod.rs +0 -246
- package/ref-monty/crates/monty/src/builtins/next.rs +0 -21
- package/ref-monty/crates/monty/src/builtins/oct.rs +0 -59
- package/ref-monty/crates/monty/src/builtins/ord.rs +0 -67
- package/ref-monty/crates/monty/src/builtins/pow.rs +0 -365
- package/ref-monty/crates/monty/src/builtins/print.rs +0 -141
- package/ref-monty/crates/monty/src/builtins/repr.rs +0 -16
- package/ref-monty/crates/monty/src/builtins/reversed.rs +0 -28
- package/ref-monty/crates/monty/src/builtins/round.rs +0 -174
- package/ref-monty/crates/monty/src/builtins/sorted.rs +0 -151
- package/ref-monty/crates/monty/src/builtins/sum.rs +0 -66
- package/ref-monty/crates/monty/src/builtins/type_.rs +0 -16
- package/ref-monty/crates/monty/src/builtins/zip.rs +0 -77
- package/ref-monty/crates/monty/src/bytecode/builder.rs +0 -699
- package/ref-monty/crates/monty/src/bytecode/code.rs +0 -310
- package/ref-monty/crates/monty/src/bytecode/compiler.rs +0 -3206
- package/ref-monty/crates/monty/src/bytecode/mod.rs +0 -24
- package/ref-monty/crates/monty/src/bytecode/op.rs +0 -617
- package/ref-monty/crates/monty/src/bytecode/vm/async_exec.rs +0 -1058
- package/ref-monty/crates/monty/src/bytecode/vm/attr.rs +0 -63
- package/ref-monty/crates/monty/src/bytecode/vm/binary.rs +0 -487
- package/ref-monty/crates/monty/src/bytecode/vm/call.rs +0 -767
- package/ref-monty/crates/monty/src/bytecode/vm/collections.rs +0 -741
- package/ref-monty/crates/monty/src/bytecode/vm/compare.rs +0 -147
- package/ref-monty/crates/monty/src/bytecode/vm/exceptions.rs +0 -297
- package/ref-monty/crates/monty/src/bytecode/vm/format.rs +0 -132
- package/ref-monty/crates/monty/src/bytecode/vm/mod.rs +0 -1958
- package/ref-monty/crates/monty/src/bytecode/vm/scheduler.rs +0 -620
- package/ref-monty/crates/monty/src/exception_private.rs +0 -1513
- package/ref-monty/crates/monty/src/exception_public.rs +0 -346
- package/ref-monty/crates/monty/src/expressions.rs +0 -694
- package/ref-monty/crates/monty/src/fstring.rs +0 -854
- package/ref-monty/crates/monty/src/function.rs +0 -119
- package/ref-monty/crates/monty/src/heap.rs +0 -1073
- package/ref-monty/crates/monty/src/heap_data.rs +0 -985
- package/ref-monty/crates/monty/src/heap_traits.rs +0 -312
- package/ref-monty/crates/monty/src/intern.rs +0 -837
- package/ref-monty/crates/monty/src/io.rs +0 -106
- package/ref-monty/crates/monty/src/lib.rs +0 -52
- package/ref-monty/crates/monty/src/modules/asyncio.rs +0 -144
- package/ref-monty/crates/monty/src/modules/math.rs +0 -1453
- package/ref-monty/crates/monty/src/modules/mod.rs +0 -120
- package/ref-monty/crates/monty/src/modules/os.rs +0 -116
- package/ref-monty/crates/monty/src/modules/pathlib.rs +0 -33
- package/ref-monty/crates/monty/src/modules/re.rs +0 -606
- package/ref-monty/crates/monty/src/modules/sys.rs +0 -60
- package/ref-monty/crates/monty/src/modules/typing.rs +0 -70
- package/ref-monty/crates/monty/src/namespace.rs +0 -21
- package/ref-monty/crates/monty/src/object.rs +0 -1040
- package/ref-monty/crates/monty/src/os.rs +0 -215
- package/ref-monty/crates/monty/src/parse.rs +0 -1730
- package/ref-monty/crates/monty/src/prepare.rs +0 -3015
- package/ref-monty/crates/monty/src/repl.rs +0 -1109
- package/ref-monty/crates/monty/src/resource.rs +0 -559
- package/ref-monty/crates/monty/src/run.rs +0 -457
- package/ref-monty/crates/monty/src/run_progress.rs +0 -821
- package/ref-monty/crates/monty/src/signature.rs +0 -651
- package/ref-monty/crates/monty/src/sorting.rs +0 -100
- package/ref-monty/crates/monty/src/types/bytes.rs +0 -2356
- package/ref-monty/crates/monty/src/types/dataclass.rs +0 -345
- package/ref-monty/crates/monty/src/types/dict.rs +0 -879
- package/ref-monty/crates/monty/src/types/dict_view.rs +0 -619
- package/ref-monty/crates/monty/src/types/iter.rs +0 -799
- package/ref-monty/crates/monty/src/types/list.rs +0 -929
- package/ref-monty/crates/monty/src/types/long_int.rs +0 -211
- package/ref-monty/crates/monty/src/types/mod.rs +0 -48
- package/ref-monty/crates/monty/src/types/module.rs +0 -146
- package/ref-monty/crates/monty/src/types/namedtuple.rs +0 -261
- package/ref-monty/crates/monty/src/types/path.rs +0 -596
- package/ref-monty/crates/monty/src/types/property.rs +0 -35
- package/ref-monty/crates/monty/src/types/py_trait.rs +0 -322
- package/ref-monty/crates/monty/src/types/range.rs +0 -285
- package/ref-monty/crates/monty/src/types/re_match.rs +0 -522
- package/ref-monty/crates/monty/src/types/re_pattern.rs +0 -726
- package/ref-monty/crates/monty/src/types/set.rs +0 -1373
- package/ref-monty/crates/monty/src/types/slice.rs +0 -257
- package/ref-monty/crates/monty/src/types/str.rs +0 -2051
- package/ref-monty/crates/monty/src/types/tuple.rs +0 -376
- package/ref-monty/crates/monty/src/types/type.rs +0 -407
- package/ref-monty/crates/monty/src/value.rs +0 -2558
- package/ref-monty/crates/monty/test_cases/args__dict_get_no_args.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__dict_get_too_many.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__dict_items_with_args.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__dict_keys_with_args.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__dict_pop_no_args.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__dict_pop_too_many.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__dict_values_with_args.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__id_too_many.py +0 -2
- package/ref-monty/crates/monty/test_cases/args__len_no_args.py +0 -2
- package/ref-monty/crates/monty/test_cases/args__len_too_many.py +0 -2
- package/ref-monty/crates/monty/test_cases/args__len_type_error_int.py +0 -9
- package/ref-monty/crates/monty/test_cases/args__len_type_error_none.py +0 -9
- package/ref-monty/crates/monty/test_cases/args__list_append_no_args.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__list_append_too_many.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__list_insert_too_few.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__list_insert_too_many.py +0 -3
- package/ref-monty/crates/monty/test_cases/args__repr_no_args.py +0 -2
- package/ref-monty/crates/monty/test_cases/arith__div_zero_float.py +0 -2
- package/ref-monty/crates/monty/test_cases/arith__div_zero_int.py +0 -2
- package/ref-monty/crates/monty/test_cases/arith__floordiv_zero_float.py +0 -2
- package/ref-monty/crates/monty/test_cases/arith__floordiv_zero_int.py +0 -2
- package/ref-monty/crates/monty/test_cases/arith__pow_zero_neg.py +0 -2
- package/ref-monty/crates/monty/test_cases/arith__pow_zero_neg_builtin.py +0 -9
- package/ref-monty/crates/monty/test_cases/assert__expr_fail.py +0 -2
- package/ref-monty/crates/monty/test_cases/assert__fail.py +0 -2
- package/ref-monty/crates/monty/test_cases/assert__fail_msg.py +0 -2
- package/ref-monty/crates/monty/test_cases/assert__fn_fail.py +0 -3
- package/ref-monty/crates/monty/test_cases/assert__ops.py +0 -11
- package/ref-monty/crates/monty/test_cases/async__asyncio_run.py +0 -47
- package/ref-monty/crates/monty/test_cases/async__basic.py +0 -10
- package/ref-monty/crates/monty/test_cases/async__closure.py +0 -14
- package/ref-monty/crates/monty/test_cases/async__double_await_coroutine.py +0 -16
- package/ref-monty/crates/monty/test_cases/async__exception.py +0 -10
- package/ref-monty/crates/monty/test_cases/async__ext_call.py +0 -73
- package/ref-monty/crates/monty/test_cases/async__gather_all.py +0 -85
- package/ref-monty/crates/monty/test_cases/async__nested_await.py +0 -15
- package/ref-monty/crates/monty/test_cases/async__nested_gather_ext.py +0 -37
- package/ref-monty/crates/monty/test_cases/async__not_awaitable.py +0 -10
- package/ref-monty/crates/monty/test_cases/async__not_imported.py +0 -14
- package/ref-monty/crates/monty/test_cases/async__recursion_depth_isolation.py +0 -27
- package/ref-monty/crates/monty/test_cases/async__return_types.py +0 -31
- package/ref-monty/crates/monty/test_cases/async__sequential.py +0 -16
- package/ref-monty/crates/monty/test_cases/async__traceback.py +0 -19
- package/ref-monty/crates/monty/test_cases/async__with_args.py +0 -14
- package/ref-monty/crates/monty/test_cases/attr__get_int_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/attr__get_list_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/attr__set_frozen_nonfield.py +0 -12
- package/ref-monty/crates/monty/test_cases/attr__set_int_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/attr__set_list_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/bench__kitchen_sink.py +0 -68
- package/ref-monty/crates/monty/test_cases/bool__ops.py +0 -20
- package/ref-monty/crates/monty/test_cases/builtin__add_type_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/builtin__filter.py +0 -62
- package/ref-monty/crates/monty/test_cases/builtin__filter_not_iterable.py +0 -11
- package/ref-monty/crates/monty/test_cases/builtin__getattr.py +0 -84
- package/ref-monty/crates/monty/test_cases/builtin__iter_funcs.py +0 -42
- package/ref-monty/crates/monty/test_cases/builtin__iter_next.py +0 -66
- package/ref-monty/crates/monty/test_cases/builtin__map.py +0 -74
- package/ref-monty/crates/monty/test_cases/builtin__map_not_iterable.py +0 -11
- package/ref-monty/crates/monty/test_cases/builtin__math_funcs.py +0 -154
- package/ref-monty/crates/monty/test_cases/builtin__more_iter_funcs.py +0 -148
- package/ref-monty/crates/monty/test_cases/builtin__next_stop_iteration.py +0 -10
- package/ref-monty/crates/monty/test_cases/builtin__print_invalid_kwarg.py +0 -9
- package/ref-monty/crates/monty/test_cases/builtin__print_kwargs.py +0 -12
- package/ref-monty/crates/monty/test_cases/builtin__repr.py +0 -3
- package/ref-monty/crates/monty/test_cases/builtin__string_funcs.py +0 -73
- package/ref-monty/crates/monty/test_cases/bytes__decode_invalid_utf8.py +0 -18
- package/ref-monty/crates/monty/test_cases/bytes__endswith_str_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/bytes__getitem_index_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/bytes__index_start_gt_end.py +0 -10
- package/ref-monty/crates/monty/test_cases/bytes__methods.py +0 -394
- package/ref-monty/crates/monty/test_cases/bytes__negative_count.py +0 -9
- package/ref-monty/crates/monty/test_cases/bytes__ops.py +0 -90
- package/ref-monty/crates/monty/test_cases/bytes__startswith_str_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/call_object.py +0 -3
- package/ref-monty/crates/monty/test_cases/chain_comparison__all.py +0 -79
- package/ref-monty/crates/monty/test_cases/closure__param_shadows_outer.py +0 -81
- package/ref-monty/crates/monty/test_cases/closure__pep448.py +0 -203
- package/ref-monty/crates/monty/test_cases/closure__undefined_nonlocal.py +0 -13
- package/ref-monty/crates/monty/test_cases/compare__mixed_types.py +0 -120
- package/ref-monty/crates/monty/test_cases/comprehension__all.py +0 -208
- package/ref-monty/crates/monty/test_cases/comprehension__scope.py +0 -7
- package/ref-monty/crates/monty/test_cases/comprehension__unbound_local.py +0 -14
- package/ref-monty/crates/monty/test_cases/dataclass__basic.py +0 -238
- package/ref-monty/crates/monty/test_cases/dataclass__call_field_error.py +0 -12
- package/ref-monty/crates/monty/test_cases/dataclass__frozen_set_error.py +0 -12
- package/ref-monty/crates/monty/test_cases/dataclass__get_missing_attr_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/dict__get_unhashable_key.py +0 -3
- package/ref-monty/crates/monty/test_cases/dict__literal_unhashable_key.py +0 -2
- package/ref-monty/crates/monty/test_cases/dict__method_pop_missing_error.py +0 -3
- package/ref-monty/crates/monty/test_cases/dict__methods.py +0 -151
- package/ref-monty/crates/monty/test_cases/dict__ops.py +0 -133
- package/ref-monty/crates/monty/test_cases/dict__pop_unhashable_key.py +0 -4
- package/ref-monty/crates/monty/test_cases/dict__popitem_empty.py +0 -9
- package/ref-monty/crates/monty/test_cases/dict__subscript_missing_key.py +0 -3
- package/ref-monty/crates/monty/test_cases/dict__unhashable_dict_key.py +0 -2
- package/ref-monty/crates/monty/test_cases/dict__unhashable_list_key.py +0 -2
- package/ref-monty/crates/monty/test_cases/dict__unpack_type_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/dict__views.py +0 -165
- package/ref-monty/crates/monty/test_cases/edge__all.py +0 -26
- package/ref-monty/crates/monty/test_cases/edge__float_int_mod.py +0 -2
- package/ref-monty/crates/monty/test_cases/edge__int_float_mod.py +0 -2
- package/ref-monty/crates/monty/test_cases/exc__args.py +0 -16
- package/ref-monty/crates/monty/test_cases/exc__str.py +0 -15
- package/ref-monty/crates/monty/test_cases/execute_ok__all.py +0 -54
- package/ref-monty/crates/monty/test_cases/execute_raise__error_instance_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__error_no_args.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__error_string_arg.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__error_string_arg_quotes.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__error_type.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__raise_instance_via_var.py +0 -4
- package/ref-monty/crates/monty/test_cases/execute_raise__raise_list.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__raise_number.py +0 -2
- package/ref-monty/crates/monty/test_cases/execute_raise__raise_type_call_via_var.py +0 -4
- package/ref-monty/crates/monty/test_cases/execute_raise__raise_type_direct.py +0 -3
- package/ref-monty/crates/monty/test_cases/execute_raise__raise_type_via_var.py +0 -4
- package/ref-monty/crates/monty/test_cases/ext_call__arg_side_effect_bug.py +0 -22
- package/ref-monty/crates/monty/test_cases/ext_call__augmented.py +0 -17
- package/ref-monty/crates/monty/test_cases/ext_call__augmented_refcount_bug.py +0 -7
- package/ref-monty/crates/monty/test_cases/ext_call__bare_raise_after_resume.py +0 -34
- package/ref-monty/crates/monty/test_cases/ext_call__basic.py +0 -99
- package/ref-monty/crates/monty/test_cases/ext_call__boolean.py +0 -37
- package/ref-monty/crates/monty/test_cases/ext_call__boolean_side_effect_hang.py +0 -17
- package/ref-monty/crates/monty/test_cases/ext_call__closure_bug.py +0 -16
- package/ref-monty/crates/monty/test_cases/ext_call__comparison.py +0 -26
- package/ref-monty/crates/monty/test_cases/ext_call__deep_call_stack.py +0 -18
- package/ref-monty/crates/monty/test_cases/ext_call__elif.py +0 -171
- package/ref-monty/crates/monty/test_cases/ext_call__exc.py +0 -4
- package/ref-monty/crates/monty/test_cases/ext_call__exc_deep_stack.py +0 -39
- package/ref-monty/crates/monty/test_cases/ext_call__exc_in_function.py +0 -17
- package/ref-monty/crates/monty/test_cases/ext_call__exc_nested_functions.py +0 -31
- package/ref-monty/crates/monty/test_cases/ext_call__ext_exc.py +0 -171
- package/ref-monty/crates/monty/test_cases/ext_call__for.py +0 -114
- package/ref-monty/crates/monty/test_cases/ext_call__fstring.py +0 -12
- package/ref-monty/crates/monty/test_cases/ext_call__if.py +0 -135
- package/ref-monty/crates/monty/test_cases/ext_call__if_condition.py +0 -37
- package/ref-monty/crates/monty/test_cases/ext_call__in_closure.py +0 -14
- package/ref-monty/crates/monty/test_cases/ext_call__in_function.py +0 -40
- package/ref-monty/crates/monty/test_cases/ext_call__in_function_simple.py +0 -7
- package/ref-monty/crates/monty/test_cases/ext_call__literals.py +0 -17
- package/ref-monty/crates/monty/test_cases/ext_call__multi_in_func.py +0 -32
- package/ref-monty/crates/monty/test_cases/ext_call__name_lookup.py +0 -69
- package/ref-monty/crates/monty/test_cases/ext_call__name_lookup_undefined.py +0 -4
- package/ref-monty/crates/monty/test_cases/ext_call__nested_calls.py +0 -14
- package/ref-monty/crates/monty/test_cases/ext_call__recursion_bug.py +0 -19
- package/ref-monty/crates/monty/test_cases/ext_call__return.py +0 -28
- package/ref-monty/crates/monty/test_cases/ext_call__side_effects.py +0 -25
- package/ref-monty/crates/monty/test_cases/ext_call__subscript.py +0 -7
- package/ref-monty/crates/monty/test_cases/ext_call__ternary.py +0 -28
- package/ref-monty/crates/monty/test_cases/ext_call__try.py +0 -280
- package/ref-monty/crates/monty/test_cases/ext_call__try_simple.py +0 -10
- package/ref-monty/crates/monty/test_cases/ext_call__unary.py +0 -13
- package/ref-monty/crates/monty/test_cases/frozenset__ops.py +0 -178
- package/ref-monty/crates/monty/test_cases/fstring__all.py +0 -236
- package/ref-monty/crates/monty/test_cases/fstring__error_eq_align_on_str.py +0 -3
- package/ref-monty/crates/monty/test_cases/fstring__error_float_f_on_str.py +0 -3
- package/ref-monty/crates/monty/test_cases/fstring__error_int_d_on_float.py +0 -3
- package/ref-monty/crates/monty/test_cases/fstring__error_int_d_on_str.py +0 -3
- package/ref-monty/crates/monty/test_cases/fstring__error_invalid_spec.py +0 -4
- package/ref-monty/crates/monty/test_cases/fstring__error_invalid_spec_dynamic.py +0 -4
- package/ref-monty/crates/monty/test_cases/fstring__error_invalid_spec_str.py +0 -4
- package/ref-monty/crates/monty/test_cases/fstring__error_str_s_on_int.py +0 -3
- package/ref-monty/crates/monty/test_cases/function__call_duplicate_kwargs.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__call_unpack.py +0 -42
- package/ref-monty/crates/monty/test_cases/function__defaults.py +0 -117
- package/ref-monty/crates/monty/test_cases/function__err_duplicate_arg.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_duplicate_first_arg.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_duplicate_kwarg_cleanup.py +0 -9
- package/ref-monty/crates/monty/test_cases/function__err_kwonly_as_positional.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_missing_all_posonly.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_missing_heap_cleanup.py +0 -9
- package/ref-monty/crates/monty/test_cases/function__err_missing_kwonly.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_missing_posonly_with_kwarg.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_missing_with_posonly.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_posonly_as_kwarg.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_posonly_first_as_kwarg.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_too_many_posonly.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_too_many_with_kwonly.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg_cleanup.py +0 -9
- package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg_quote.py +0 -13
- package/ref-monty/crates/monty/test_cases/function__err_unexpected_kwarg_simple.py +0 -7
- package/ref-monty/crates/monty/test_cases/function__err_unpack_duplicate_arg.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__err_unpack_duplicate_heap.py +0 -8
- package/ref-monty/crates/monty/test_cases/function__err_unpack_int.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__err_unpack_nonstring_key.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__err_unpack_not_mapping.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__kwargs_unpacking.py +0 -173
- package/ref-monty/crates/monty/test_cases/function__ops.py +0 -294
- package/ref-monty/crates/monty/test_cases/function__return_none.py +0 -42
- package/ref-monty/crates/monty/test_cases/function__signatures.py +0 -47
- package/ref-monty/crates/monty/test_cases/function__too_few_args_all.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__too_few_args_one.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__too_few_args_two.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__too_many_args_one.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__too_many_args_two.py +0 -6
- package/ref-monty/crates/monty/test_cases/function__too_many_args_zero.py +0 -6
- package/ref-monty/crates/monty/test_cases/global__error_assigned_before.py +0 -7
- package/ref-monty/crates/monty/test_cases/global__ops.py +0 -163
- package/ref-monty/crates/monty/test_cases/hash__dict_unhashable.py +0 -2
- package/ref-monty/crates/monty/test_cases/hash__list_unhashable.py +0 -2
- package/ref-monty/crates/monty/test_cases/hash__ops.py +0 -153
- package/ref-monty/crates/monty/test_cases/id__bytes_literals_distinct.py +0 -3
- package/ref-monty/crates/monty/test_cases/id__int_copy_distinct.py +0 -5
- package/ref-monty/crates/monty/test_cases/id__is_number_is_number.py +0 -3
- package/ref-monty/crates/monty/test_cases/id__non_overlapping_lifetimes_distinct_types.py +0 -10
- package/ref-monty/crates/monty/test_cases/id__non_overlapping_lifetimes_same_types.py +0 -6
- package/ref-monty/crates/monty/test_cases/id__ops.py +0 -97
- package/ref-monty/crates/monty/test_cases/id__str_literals_same.py +0 -3
- package/ref-monty/crates/monty/test_cases/if__elif_else.py +0 -207
- package/ref-monty/crates/monty/test_cases/if__raise_elif.py +0 -11
- package/ref-monty/crates/monty/test_cases/if__raise_else.py +0 -13
- package/ref-monty/crates/monty/test_cases/if__raise_if.py +0 -9
- package/ref-monty/crates/monty/test_cases/if__raise_in_elif_condition.py +0 -18
- package/ref-monty/crates/monty/test_cases/if__raise_in_if_condition.py +0 -16
- package/ref-monty/crates/monty/test_cases/if_else_expr__all.py +0 -55
- package/ref-monty/crates/monty/test_cases/import__error_cannot_import.py +0 -9
- package/ref-monty/crates/monty/test_cases/import__error_module_not_found.py +0 -9
- package/ref-monty/crates/monty/test_cases/import__local_scope.py +0 -68
- package/ref-monty/crates/monty/test_cases/import__os.py +0 -25
- package/ref-monty/crates/monty/test_cases/import__relative_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/import__relative_no_module_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/import__runtime_error_when_executed.py +0 -14
- package/ref-monty/crates/monty/test_cases/import__star_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/import__sys.py +0 -47
- package/ref-monty/crates/monty/test_cases/import__sys_monty.py +0 -28
- package/ref-monty/crates/monty/test_cases/import__type_checking_guard.py +0 -37
- package/ref-monty/crates/monty/test_cases/import__typing.py +0 -25
- package/ref-monty/crates/monty/test_cases/import__typing_type_ignore.py +0 -4
- package/ref-monty/crates/monty/test_cases/int__bigint.py +0 -467
- package/ref-monty/crates/monty/test_cases/int__bigint_errors.py +0 -260
- package/ref-monty/crates/monty/test_cases/int__ops.py +0 -219
- package/ref-monty/crates/monty/test_cases/int__overflow_division.py +0 -84
- package/ref-monty/crates/monty/test_cases/is_variant__all.py +0 -36
- package/ref-monty/crates/monty/test_cases/isinstance__arg2_list_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/isinstance__arg2_type_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/iter__dict_mutation.py +0 -4
- package/ref-monty/crates/monty/test_cases/iter__for.py +0 -243
- package/ref-monty/crates/monty/test_cases/iter__for_loop_unpacking.py +0 -66
- package/ref-monty/crates/monty/test_cases/iter__generator_expr.py +0 -20
- package/ref-monty/crates/monty/test_cases/iter__generator_expr_type.py +0 -7
- package/ref-monty/crates/monty/test_cases/iter__not_iterable.py +0 -3
- package/ref-monty/crates/monty/test_cases/lambda__all.py +0 -145
- package/ref-monty/crates/monty/test_cases/list__extend_not_iterable.py +0 -7
- package/ref-monty/crates/monty/test_cases/list__getitem_out_of_bounds.py +0 -3
- package/ref-monty/crates/monty/test_cases/list__index_not_found.py +0 -9
- package/ref-monty/crates/monty/test_cases/list__index_start_gt_end.py +0 -10
- package/ref-monty/crates/monty/test_cases/list__ops.py +0 -473
- package/ref-monty/crates/monty/test_cases/list__pop_empty.py +0 -9
- package/ref-monty/crates/monty/test_cases/list__pop_out_of_range.py +0 -9
- package/ref-monty/crates/monty/test_cases/list__pop_type_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/list__remove_not_found.py +0 -9
- package/ref-monty/crates/monty/test_cases/list__setitem_dict_index.py +0 -13
- package/ref-monty/crates/monty/test_cases/list__setitem_huge_int_index.py +0 -13
- package/ref-monty/crates/monty/test_cases/list__setitem_index_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/list__setitem_type_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/list__unpack_type_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/longint__index_error.py +0 -3
- package/ref-monty/crates/monty/test_cases/longint__repeat_error.py +0 -3
- package/ref-monty/crates/monty/test_cases/loop__break_continue.py +0 -113
- package/ref-monty/crates/monty/test_cases/loop__break_finally.py +0 -69
- package/ref-monty/crates/monty/test_cases/loop__break_in_function_error.py +0 -13
- package/ref-monty/crates/monty/test_cases/loop__break_in_if_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/loop__break_nested_except_clears.py +0 -55
- package/ref-monty/crates/monty/test_cases/loop__break_outside_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/loop__continue_finally.py +0 -81
- package/ref-monty/crates/monty/test_cases/loop__continue_in_function_error.py +0 -13
- package/ref-monty/crates/monty/test_cases/loop__continue_in_if_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/loop__continue_nested_except_clears.py +0 -60
- package/ref-monty/crates/monty/test_cases/loop__continue_outside_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/math__acos_domain_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__acosh_domain_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__asin_domain_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__atanh_domain_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__cos_inf_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__cosh_overflow_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__exp_overflow_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__factorial_float_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__factorial_negative_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__floor_inf_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__floor_nan_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__floor_str_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__fmod_inf_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__gamma_neg_int_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__gcd_float_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__isqrt_negative_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__ldexp_overflow_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__log1p_domain_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__log_base1_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__log_zero_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__module.py +0 -1432
- package/ref-monty/crates/monty/test_cases/math__pow_domain_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__sin_inf_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__sqrt_negative_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__tan_inf_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/math__trunc_str_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/method__args_kwargs_unpacking.py +0 -259
- package/ref-monty/crates/monty/test_cases/name_error__unbound_local_func.py +0 -19
- package/ref-monty/crates/monty/test_cases/name_error__unbound_local_module.py +0 -12
- package/ref-monty/crates/monty/test_cases/name_error__undefined_call_chained.py +0 -9
- package/ref-monty/crates/monty/test_cases/name_error__undefined_call_in_expr.py +0 -9
- package/ref-monty/crates/monty/test_cases/name_error__undefined_call_in_function.py +0 -16
- package/ref-monty/crates/monty/test_cases/name_error__undefined_call_with_args.py +0 -9
- package/ref-monty/crates/monty/test_cases/name_error__undefined_global.py +0 -10
- package/ref-monty/crates/monty/test_cases/namedtuple__missing_attr.py +0 -11
- package/ref-monty/crates/monty/test_cases/namedtuple__ops.py +0 -34
- package/ref-monty/crates/monty/test_cases/nonlocal__error_module_level.py +0 -3
- package/ref-monty/crates/monty/test_cases/nonlocal__ops.py +0 -353
- package/ref-monty/crates/monty/test_cases/os__environ.py +0 -40
- package/ref-monty/crates/monty/test_cases/os__getenv_key_list_error.py +0 -5
- package/ref-monty/crates/monty/test_cases/os__getenv_key_type_error.py +0 -5
- package/ref-monty/crates/monty/test_cases/parse_error__complex.py +0 -3
- package/ref-monty/crates/monty/test_cases/pathlib__import.py +0 -11
- package/ref-monty/crates/monty/test_cases/pathlib__os.py +0 -136
- package/ref-monty/crates/monty/test_cases/pathlib__os_read_error.py +0 -12
- package/ref-monty/crates/monty/test_cases/pathlib__pure.py +0 -81
- package/ref-monty/crates/monty/test_cases/pyobject__cycle_dict_self.py +0 -5
- package/ref-monty/crates/monty/test_cases/pyobject__cycle_list_dict.py +0 -6
- package/ref-monty/crates/monty/test_cases/pyobject__cycle_list_self.py +0 -5
- package/ref-monty/crates/monty/test_cases/pyobject__cycle_multiple_refs.py +0 -6
- package/ref-monty/crates/monty/test_cases/range__error_no_args.py +0 -2
- package/ref-monty/crates/monty/test_cases/range__error_step_zero.py +0 -2
- package/ref-monty/crates/monty/test_cases/range__error_too_many_args.py +0 -2
- package/ref-monty/crates/monty/test_cases/range__getitem_index_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/range__ops.py +0 -236
- package/ref-monty/crates/monty/test_cases/re__basic.py +0 -756
- package/ref-monty/crates/monty/test_cases/re__grouping.py +0 -241
- package/ref-monty/crates/monty/test_cases/re__match.py +0 -148
- package/ref-monty/crates/monty/test_cases/recursion__deep_drop.py +0 -26
- package/ref-monty/crates/monty/test_cases/recursion__deep_eq.py +0 -23
- package/ref-monty/crates/monty/test_cases/recursion__deep_hash.py +0 -46
- package/ref-monty/crates/monty/test_cases/recursion__deep_repr.py +0 -12
- package/ref-monty/crates/monty/test_cases/recursion__function_depth.py +0 -13
- package/ref-monty/crates/monty/test_cases/refcount__cycle_mutual_reference.py +0 -18
- package/ref-monty/crates/monty/test_cases/refcount__cycle_self_reference.py +0 -12
- package/ref-monty/crates/monty/test_cases/refcount__dict_basic.py +0 -5
- package/ref-monty/crates/monty/test_cases/refcount__dict_get.py +0 -5
- package/ref-monty/crates/monty/test_cases/refcount__dict_keys_and.py +0 -14
- package/ref-monty/crates/monty/test_cases/refcount__dict_overwrite.py +0 -6
- package/ref-monty/crates/monty/test_cases/refcount__gather_cleanup.py +0 -16
- package/ref-monty/crates/monty/test_cases/refcount__gather_exception.py +0 -18
- package/ref-monty/crates/monty/test_cases/refcount__gather_nested_cancel.py +0 -25
- package/ref-monty/crates/monty/test_cases/refcount__immediate_skipped.py +0 -4
- package/ref-monty/crates/monty/test_cases/refcount__kwargs_unpacking.py +0 -27
- package/ref-monty/crates/monty/test_cases/refcount__list_append_multiple.py +0 -6
- package/ref-monty/crates/monty/test_cases/refcount__list_append_ref.py +0 -5
- package/ref-monty/crates/monty/test_cases/refcount__list_concat.py +0 -5
- package/ref-monty/crates/monty/test_cases/refcount__list_getitem.py +0 -5
- package/ref-monty/crates/monty/test_cases/refcount__list_iadd.py +0 -5
- package/ref-monty/crates/monty/test_cases/refcount__nested_list.py +0 -4
- package/ref-monty/crates/monty/test_cases/refcount__re_pattern_sub_error_paths.py +0 -37
- package/ref-monty/crates/monty/test_cases/refcount__re_search_match.py +0 -34
- package/ref-monty/crates/monty/test_cases/refcount__re_sub_error_paths.py +0 -31
- package/ref-monty/crates/monty/test_cases/refcount__shared_reference.py +0 -4
- package/ref-monty/crates/monty/test_cases/refcount__single_list.py +0 -3
- package/ref-monty/crates/monty/test_cases/repr__cycle_detection.py +0 -24
- package/ref-monty/crates/monty/test_cases/set__ops.py +0 -191
- package/ref-monty/crates/monty/test_cases/set__review_bugs.py +0 -35
- package/ref-monty/crates/monty/test_cases/set__unpack_type_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/slice__invalid_indices.py +0 -2
- package/ref-monty/crates/monty/test_cases/slice__kwargs.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__no_args.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__ops.py +0 -149
- package/ref-monty/crates/monty/test_cases/slice__step_zero.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__step_zero_bytes.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__step_zero_range.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__step_zero_str.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__step_zero_tuple.py +0 -9
- package/ref-monty/crates/monty/test_cases/slice__too_many_args.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__getitem_index_error.py +0 -10
- package/ref-monty/crates/monty/test_cases/str__index_not_found.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__join_no_args.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__join_non_string.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__join_not_iterable.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__join_too_many_args.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__methods.py +0 -327
- package/ref-monty/crates/monty/test_cases/str__ops.py +0 -162
- package/ref-monty/crates/monty/test_cases/str__partition_empty.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__rsplit_empty_sep.py +0 -9
- package/ref-monty/crates/monty/test_cases/str__split_empty_sep.py +0 -9
- package/ref-monty/crates/monty/test_cases/sys__types.py +0 -7
- package/ref-monty/crates/monty/test_cases/traceback__division_error.py +0 -30
- package/ref-monty/crates/monty/test_cases/traceback__index_error.py +0 -17
- package/ref-monty/crates/monty/test_cases/traceback__insert_as_int.py +0 -10
- package/ref-monty/crates/monty/test_cases/traceback__nested_call.py +0 -29
- package/ref-monty/crates/monty/test_cases/traceback__nonlocal_module_scope.py +0 -10
- package/ref-monty/crates/monty/test_cases/traceback__nonlocal_unbound.py +0 -24
- package/ref-monty/crates/monty/test_cases/traceback__range_as_int.py +0 -9
- package/ref-monty/crates/monty/test_cases/traceback__recursion_error.py +0 -23
- package/ref-monty/crates/monty/test_cases/traceback__set_mutation.py +0 -11
- package/ref-monty/crates/monty/test_cases/traceback__undefined_attr_call.py +0 -16
- package/ref-monty/crates/monty/test_cases/traceback__undefined_call.py +0 -16
- package/ref-monty/crates/monty/test_cases/traceback__undefined_raise.py +0 -16
- package/ref-monty/crates/monty/test_cases/try_except__all.py +0 -472
- package/ref-monty/crates/monty/test_cases/try_except__bare_raise_no_context.py +0 -2
- package/ref-monty/crates/monty/test_cases/try_except__invalid_type.py +0 -5
- package/ref-monty/crates/monty/test_cases/tuple__getitem_out_of_bounds.py +0 -3
- package/ref-monty/crates/monty/test_cases/tuple__index_not_found.py +0 -9
- package/ref-monty/crates/monty/test_cases/tuple__index_start_gt_end.py +0 -10
- package/ref-monty/crates/monty/test_cases/tuple__methods.py +0 -19
- package/ref-monty/crates/monty/test_cases/tuple__ops.py +0 -133
- package/ref-monty/crates/monty/test_cases/tuple__unpack_type_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/type__builtin_attr_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__bytes_negative.py +0 -2
- package/ref-monty/crates/monty/test_cases/type__cell_not_builtin.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__exception_attr_error.py +0 -11
- package/ref-monty/crates/monty/test_cases/type__float_conversion_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/type__float_repr_both_quotes.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__float_repr_newline.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__float_repr_single_quote.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__int_conversion_error.py +0 -2
- package/ref-monty/crates/monty/test_cases/type__list_not_iterable.py +0 -2
- package/ref-monty/crates/monty/test_cases/type__non_builtin_name_error.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__ops.py +0 -200
- package/ref-monty/crates/monty/test_cases/type__shadow_exc.py +0 -3
- package/ref-monty/crates/monty/test_cases/type__shadow_int.py +0 -9
- package/ref-monty/crates/monty/test_cases/type__shadow_len.py +0 -3
- package/ref-monty/crates/monty/test_cases/type__tuple_not_iterable.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__int_add_list.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__int_div_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__int_floordiv_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__int_iadd_str.py +0 -3
- package/ref-monty/crates/monty/test_cases/type_error__int_mod_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__int_pow_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__int_sub_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__list_add_int.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__list_add_str.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__list_iadd_int.py +0 -6
- package/ref-monty/crates/monty/test_cases/type_error__str_add_int.py +0 -2
- package/ref-monty/crates/monty/test_cases/type_error__str_iadd_int.py +0 -3
- package/ref-monty/crates/monty/test_cases/type_error__unary_invert_str.py +0 -3
- package/ref-monty/crates/monty/test_cases/type_error__unary_minus_str.py +0 -4
- package/ref-monty/crates/monty/test_cases/type_error__unary_neg_str.py +0 -3
- package/ref-monty/crates/monty/test_cases/type_error__unary_plus_str.py +0 -4
- package/ref-monty/crates/monty/test_cases/typing__types.py +0 -24
- package/ref-monty/crates/monty/test_cases/unpack__nested.py +0 -48
- package/ref-monty/crates/monty/test_cases/unpack__non_sequence.py +0 -9
- package/ref-monty/crates/monty/test_cases/unpack__not_enough.py +0 -9
- package/ref-monty/crates/monty/test_cases/unpack__ops.py +0 -153
- package/ref-monty/crates/monty/test_cases/unpack__star_not_enough.py +0 -9
- package/ref-monty/crates/monty/test_cases/unpack__too_many.py +0 -9
- package/ref-monty/crates/monty/test_cases/version__cpython.py +0 -4
- package/ref-monty/crates/monty/test_cases/walrus__all.py +0 -178
- package/ref-monty/crates/monty/test_cases/while__all.py +0 -206
- package/ref-monty/crates/monty/tests/asyncio.rs +0 -764
- package/ref-monty/crates/monty/tests/binary_serde.rs +0 -185
- package/ref-monty/crates/monty/tests/bytecode_limits.rs +0 -248
- package/ref-monty/crates/monty/tests/datatest_runner.rs +0 -2029
- package/ref-monty/crates/monty/tests/inputs.rs +0 -420
- package/ref-monty/crates/monty/tests/json_serde.rs +0 -250
- package/ref-monty/crates/monty/tests/main.rs +0 -71
- package/ref-monty/crates/monty/tests/math_module.rs +0 -114
- package/ref-monty/crates/monty/tests/name_lookup.rs +0 -482
- package/ref-monty/crates/monty/tests/os_tests.rs +0 -459
- package/ref-monty/crates/monty/tests/parse_errors.rs +0 -441
- package/ref-monty/crates/monty/tests/print_writer.rs +0 -238
- package/ref-monty/crates/monty/tests/py_object.rs +0 -121
- package/ref-monty/crates/monty/tests/regex.rs +0 -90
- package/ref-monty/crates/monty/tests/repl.rs +0 -344
- package/ref-monty/crates/monty/tests/resource_limits.rs +0 -1826
- package/ref-monty/crates/monty/tests/try_from.rs +0 -167
- package/ref-monty/crates/monty-cli/Cargo.toml +0 -25
- package/ref-monty/crates/monty-cli/src/main.rs +0 -541
- package/ref-monty/crates/monty-js/.cargo/config.toml +0 -2
- package/ref-monty/crates/monty-js/.prettierignore +0 -8
- package/ref-monty/crates/monty-js/Cargo.toml +0 -32
- package/ref-monty/crates/monty-js/README.md +0 -207
- package/ref-monty/crates/monty-js/__test__/async.spec.ts +0 -350
- package/ref-monty/crates/monty-js/__test__/basic.spec.ts +0 -114
- package/ref-monty/crates/monty-js/__test__/exceptions.spec.ts +0 -427
- package/ref-monty/crates/monty-js/__test__/external.spec.ts +0 -354
- package/ref-monty/crates/monty-js/__test__/inputs.spec.ts +0 -143
- package/ref-monty/crates/monty-js/__test__/limits.spec.ts +0 -162
- package/ref-monty/crates/monty-js/__test__/package.json +0 -3
- package/ref-monty/crates/monty-js/__test__/print.spec.ts +0 -229
- package/ref-monty/crates/monty-js/__test__/repl.spec.ts +0 -34
- package/ref-monty/crates/monty-js/__test__/serialize.spec.ts +0 -205
- package/ref-monty/crates/monty-js/__test__/start.spec.ts +0 -443
- package/ref-monty/crates/monty-js/__test__/type_check.spec.ts +0 -147
- package/ref-monty/crates/monty-js/__test__/types.spec.ts +0 -319
- package/ref-monty/crates/monty-js/build.rs +0 -61
- package/ref-monty/crates/monty-js/index-header.d.ts +0 -3
- package/ref-monty/crates/monty-js/package-lock.json +0 -4694
- package/ref-monty/crates/monty-js/package.json +0 -100
- package/ref-monty/crates/monty-js/scripts/smoke-test.sh +0 -69
- package/ref-monty/crates/monty-js/smoke-test/package.json +0 -17
- package/ref-monty/crates/monty-js/smoke-test/test.ts +0 -171
- package/ref-monty/crates/monty-js/smoke-test/tsconfig.json +0 -11
- package/ref-monty/crates/monty-js/src/convert.rs +0 -648
- package/ref-monty/crates/monty-js/src/exceptions.rs +0 -293
- package/ref-monty/crates/monty-js/src/lib.rs +0 -41
- package/ref-monty/crates/monty-js/src/limits.rs +0 -53
- package/ref-monty/crates/monty-js/src/monty_cls.rs +0 -1407
- package/ref-monty/crates/monty-js/tsconfig.json +0 -17
- package/ref-monty/crates/monty-js/wrapper.ts +0 -701
- package/ref-monty/crates/monty-python/Cargo.toml +0 -38
- package/ref-monty/crates/monty-python/README.md +0 -134
- package/ref-monty/crates/monty-python/build.rs +0 -4
- package/ref-monty/crates/monty-python/example.py +0 -40
- package/ref-monty/crates/monty-python/exercise.py +0 -46
- package/ref-monty/crates/monty-python/pyproject.toml +0 -57
- package/ref-monty/crates/monty-python/python/pydantic_monty/__init__.py +0 -281
- package/ref-monty/crates/monty-python/python/pydantic_monty/_monty.pyi +0 -677
- package/ref-monty/crates/monty-python/python/pydantic_monty/os_access.py +0 -933
- package/ref-monty/crates/monty-python/python/pydantic_monty/py.typed +0 -0
- package/ref-monty/crates/monty-python/src/convert.rs +0 -273
- package/ref-monty/crates/monty-python/src/dataclass.rs +0 -461
- package/ref-monty/crates/monty-python/src/exceptions.rs +0 -557
- package/ref-monty/crates/monty-python/src/external.rs +0 -165
- package/ref-monty/crates/monty-python/src/lib.rs +0 -77
- package/ref-monty/crates/monty-python/src/limits.rs +0 -142
- package/ref-monty/crates/monty-python/src/monty_cls.rs +0 -1650
- package/ref-monty/crates/monty-python/src/repl.rs +0 -470
- package/ref-monty/crates/monty-python/src/serialization.rs +0 -761
- package/ref-monty/crates/monty-python/tests/test_async.py +0 -1201
- package/ref-monty/crates/monty-python/tests/test_basic.py +0 -66
- package/ref-monty/crates/monty-python/tests/test_dataclasses.py +0 -971
- package/ref-monty/crates/monty-python/tests/test_exceptions.py +0 -361
- package/ref-monty/crates/monty-python/tests/test_external.py +0 -367
- package/ref-monty/crates/monty-python/tests/test_inputs.py +0 -126
- package/ref-monty/crates/monty-python/tests/test_limits.py +0 -257
- package/ref-monty/crates/monty-python/tests/test_os_access.py +0 -1286
- package/ref-monty/crates/monty-python/tests/test_os_access_compat.py +0 -731
- package/ref-monty/crates/monty-python/tests/test_os_access_raw.py +0 -483
- package/ref-monty/crates/monty-python/tests/test_os_calls.py +0 -819
- package/ref-monty/crates/monty-python/tests/test_print.py +0 -208
- package/ref-monty/crates/monty-python/tests/test_re.py +0 -170
- package/ref-monty/crates/monty-python/tests/test_readme_examples.py +0 -20
- package/ref-monty/crates/monty-python/tests/test_repl.py +0 -749
- package/ref-monty/crates/monty-python/tests/test_serialize.py +0 -284
- package/ref-monty/crates/monty-python/tests/test_start.py +0 -346
- package/ref-monty/crates/monty-python/tests/test_threading.py +0 -163
- package/ref-monty/crates/monty-python/tests/test_type_check.py +0 -344
- package/ref-monty/crates/monty-python/tests/test_types.py +0 -553
- package/ref-monty/crates/monty-type-checking/Cargo.toml +0 -32
- package/ref-monty/crates/monty-type-checking/src/db.rs +0 -116
- package/ref-monty/crates/monty-type-checking/src/lib.rs +0 -4
- package/ref-monty/crates/monty-type-checking/src/type_check.rs +0 -280
- package/ref-monty/crates/monty-type-checking/tests/bad_types.py +0 -109
- package/ref-monty/crates/monty-type-checking/tests/bad_types_output.txt +0 -21
- package/ref-monty/crates/monty-type-checking/tests/good_types.py +0 -475
- package/ref-monty/crates/monty-type-checking/tests/main.rs +0 -205
- package/ref-monty/crates/monty-type-checking/tests/reveal_types.py +0 -56
- package/ref-monty/crates/monty-type-checking/tests/reveal_types_output.txt +0 -41
- package/ref-monty/crates/monty-typeshed/Cargo.toml +0 -29
- package/ref-monty/crates/monty-typeshed/README.md +0 -11
- package/ref-monty/crates/monty-typeshed/build.rs +0 -101
- package/ref-monty/crates/monty-typeshed/custom/README.md +0 -1
- package/ref-monty/crates/monty-typeshed/custom/asyncio.pyi +0 -138
- package/ref-monty/crates/monty-typeshed/custom/os.pyi +0 -87
- package/ref-monty/crates/monty-typeshed/custom/sys.pyi +0 -33
- package/ref-monty/crates/monty-typeshed/src/lib.rs +0 -56
- package/ref-monty/crates/monty-typeshed/update.py +0 -321
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/source_commit.txt +0 -1
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/VERSIONS +0 -20
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/_collections_abc.pyi +0 -105
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/_typeshed/__init__.pyi +0 -394
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/asyncio.pyi +0 -138
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/builtins.pyi +0 -1434
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/collections/__init__.pyi +0 -527
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/collections/abc.pyi +0 -2
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/dataclasses.pyi +0 -502
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/enum.pyi +0 -376
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/math.pyi +0 -149
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/os.pyi +0 -87
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/pathlib/__init__.pyi +0 -395
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/pathlib/types.pyi +0 -8
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/re.pyi +0 -337
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/sys.pyi +0 -33
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/types.pyi +0 -741
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/typing.pyi +0 -1217
- package/ref-monty/crates/monty-typeshed/vendor/typeshed/stdlib/typing_extensions.pyi +0 -716
- package/ref-monty/docs/usage-guide.md +0 -117
- package/ref-monty/examples/README.md +0 -3
- package/ref-monty/examples/expense_analysis/README.md +0 -3
- package/ref-monty/examples/expense_analysis/data.py +0 -124
- package/ref-monty/examples/expense_analysis/main.py +0 -115
- package/ref-monty/examples/sql_playground/README.md +0 -20
- package/ref-monty/examples/sql_playground/external_functions.py +0 -129
- package/ref-monty/examples/sql_playground/main.py +0 -81
- package/ref-monty/examples/sql_playground/sandbox_code.py +0 -82
- package/ref-monty/examples/sql_playground/type_stubs.pyi +0 -14
- package/ref-monty/examples/web_scraper/README.md +0 -15
- package/ref-monty/examples/web_scraper/browser.py +0 -56
- package/ref-monty/examples/web_scraper/example_code.py +0 -59
- package/ref-monty/examples/web_scraper/external_functions.py +0 -324
- package/ref-monty/examples/web_scraper/main.py +0 -193
- package/ref-monty/examples/web_scraper/sub_agent.py +0 -79
- package/ref-monty/monty-npm.md +0 -235
- package/ref-monty/pyproject.toml +0 -162
- package/ref-monty/scripts/check_imports.py +0 -91
- package/ref-monty/scripts/codecov_diff.py +0 -412
- package/ref-monty/scripts/complete_tests.py +0 -146
- package/ref-monty/scripts/flamegraph_to_text.py +0 -208
- package/ref-monty/scripts/iter_test_methods.py +0 -540
- package/ref-monty/scripts/run_traceback.py +0 -180
- package/ref-monty/scripts/startup_performance.py +0 -130
- package/ref-monty/uv.lock +0 -1779
- package/temp_resend_cli/repo/.github/scripts/pr-title-check.js +0 -34
- package/temp_resend_cli/repo/.github/workflows/ci.yml +0 -67
- package/temp_resend_cli/repo/.github/workflows/post-release.yml +0 -51
- package/temp_resend_cli/repo/.github/workflows/pr-title-check.yml +0 -13
- package/temp_resend_cli/repo/.github/workflows/release.yml +0 -175
- package/temp_resend_cli/repo/.github/workflows/test-install-unix.yml +0 -34
- package/temp_resend_cli/repo/.github/workflows/test-install-windows.yml +0 -48
- package/temp_resend_cli/repo/CHANGELOG.md +0 -31
- package/temp_resend_cli/repo/LICENSE +0 -21
- package/temp_resend_cli/repo/README.md +0 -450
- package/temp_resend_cli/repo/biome.json +0 -36
- package/temp_resend_cli/repo/install.ps1 +0 -141
- package/temp_resend_cli/repo/install.sh +0 -301
- package/temp_resend_cli/repo/package.json +0 -61
- package/temp_resend_cli/repo/pnpm-lock.yaml +0 -2439
- package/temp_resend_cli/repo/renovate.json +0 -4
- package/temp_resend_cli/repo/src/cli.ts +0 -98
- package/temp_resend_cli/repo/src/commands/api-keys/create.ts +0 -114
- package/temp_resend_cli/repo/src/commands/api-keys/delete.ts +0 -47
- package/temp_resend_cli/repo/src/commands/api-keys/index.ts +0 -26
- package/temp_resend_cli/repo/src/commands/api-keys/list.ts +0 -35
- package/temp_resend_cli/repo/src/commands/api-keys/utils.ts +0 -8
- package/temp_resend_cli/repo/src/commands/auth/index.ts +0 -20
- package/temp_resend_cli/repo/src/commands/auth/login.ts +0 -234
- package/temp_resend_cli/repo/src/commands/auth/logout.ts +0 -105
- package/temp_resend_cli/repo/src/commands/broadcasts/create.ts +0 -196
- package/temp_resend_cli/repo/src/commands/broadcasts/delete.ts +0 -46
- package/temp_resend_cli/repo/src/commands/broadcasts/get.ts +0 -59
- package/temp_resend_cli/repo/src/commands/broadcasts/index.ts +0 -43
- package/temp_resend_cli/repo/src/commands/broadcasts/list.ts +0 -60
- package/temp_resend_cli/repo/src/commands/broadcasts/send.ts +0 -56
- package/temp_resend_cli/repo/src/commands/broadcasts/update.ts +0 -95
- package/temp_resend_cli/repo/src/commands/broadcasts/utils.ts +0 -35
- package/temp_resend_cli/repo/src/commands/contact-properties/create.ts +0 -118
- package/temp_resend_cli/repo/src/commands/contact-properties/delete.ts +0 -48
- package/temp_resend_cli/repo/src/commands/contact-properties/get.ts +0 -46
- package/temp_resend_cli/repo/src/commands/contact-properties/index.ts +0 -48
- package/temp_resend_cli/repo/src/commands/contact-properties/list.ts +0 -68
- package/temp_resend_cli/repo/src/commands/contact-properties/update.ts +0 -88
- package/temp_resend_cli/repo/src/commands/contact-properties/utils.ts +0 -17
- package/temp_resend_cli/repo/src/commands/contacts/add-segment.ts +0 -78
- package/temp_resend_cli/repo/src/commands/contacts/create.ts +0 -122
- package/temp_resend_cli/repo/src/commands/contacts/delete.ts +0 -49
- package/temp_resend_cli/repo/src/commands/contacts/get.ts +0 -53
- package/temp_resend_cli/repo/src/commands/contacts/index.ts +0 -58
- package/temp_resend_cli/repo/src/commands/contacts/list.ts +0 -57
- package/temp_resend_cli/repo/src/commands/contacts/remove-segment.ts +0 -48
- package/temp_resend_cli/repo/src/commands/contacts/segments.ts +0 -39
- package/temp_resend_cli/repo/src/commands/contacts/topics.ts +0 -45
- package/temp_resend_cli/repo/src/commands/contacts/update-topics.ts +0 -90
- package/temp_resend_cli/repo/src/commands/contacts/update.ts +0 -77
- package/temp_resend_cli/repo/src/commands/contacts/utils.ts +0 -119
- package/temp_resend_cli/repo/src/commands/doctor.ts +0 -216
- package/temp_resend_cli/repo/src/commands/domains/create.ts +0 -83
- package/temp_resend_cli/repo/src/commands/domains/delete.ts +0 -42
- package/temp_resend_cli/repo/src/commands/domains/get.ts +0 -47
- package/temp_resend_cli/repo/src/commands/domains/index.ts +0 -35
- package/temp_resend_cli/repo/src/commands/domains/list.ts +0 -53
- package/temp_resend_cli/repo/src/commands/domains/update.ts +0 -75
- package/temp_resend_cli/repo/src/commands/domains/utils.ts +0 -44
- package/temp_resend_cli/repo/src/commands/domains/verify.ts +0 -38
- package/temp_resend_cli/repo/src/commands/emails/batch.ts +0 -140
- package/temp_resend_cli/repo/src/commands/emails/get.ts +0 -44
- package/temp_resend_cli/repo/src/commands/emails/index.ts +0 -30
- package/temp_resend_cli/repo/src/commands/emails/list.ts +0 -84
- package/temp_resend_cli/repo/src/commands/emails/receiving/attachment.ts +0 -55
- package/temp_resend_cli/repo/src/commands/emails/receiving/attachments.ts +0 -68
- package/temp_resend_cli/repo/src/commands/emails/receiving/get.ts +0 -58
- package/temp_resend_cli/repo/src/commands/emails/receiving/index.ts +0 -28
- package/temp_resend_cli/repo/src/commands/emails/receiving/list.ts +0 -59
- package/temp_resend_cli/repo/src/commands/emails/receiving/utils.ts +0 -38
- package/temp_resend_cli/repo/src/commands/emails/send.ts +0 -189
- package/temp_resend_cli/repo/src/commands/open.ts +0 -27
- package/temp_resend_cli/repo/src/commands/segments/create.ts +0 -50
- package/temp_resend_cli/repo/src/commands/segments/delete.ts +0 -47
- package/temp_resend_cli/repo/src/commands/segments/get.ts +0 -38
- package/temp_resend_cli/repo/src/commands/segments/index.ts +0 -36
- package/temp_resend_cli/repo/src/commands/segments/list.ts +0 -58
- package/temp_resend_cli/repo/src/commands/segments/utils.ts +0 -7
- package/temp_resend_cli/repo/src/commands/teams/index.ts +0 -10
- package/temp_resend_cli/repo/src/commands/teams/list.ts +0 -35
- package/temp_resend_cli/repo/src/commands/teams/remove.ts +0 -86
- package/temp_resend_cli/repo/src/commands/teams/switch.ts +0 -76
- package/temp_resend_cli/repo/src/commands/topics/create.ts +0 -73
- package/temp_resend_cli/repo/src/commands/topics/delete.ts +0 -47
- package/temp_resend_cli/repo/src/commands/topics/get.ts +0 -42
- package/temp_resend_cli/repo/src/commands/topics/index.ts +0 -42
- package/temp_resend_cli/repo/src/commands/topics/list.ts +0 -34
- package/temp_resend_cli/repo/src/commands/topics/update.ts +0 -59
- package/temp_resend_cli/repo/src/commands/topics/utils.ts +0 -16
- package/temp_resend_cli/repo/src/commands/webhooks/create.ts +0 -128
- package/temp_resend_cli/repo/src/commands/webhooks/delete.ts +0 -49
- package/temp_resend_cli/repo/src/commands/webhooks/get.ts +0 -42
- package/temp_resend_cli/repo/src/commands/webhooks/index.ts +0 -42
- package/temp_resend_cli/repo/src/commands/webhooks/list.ts +0 -55
- package/temp_resend_cli/repo/src/commands/webhooks/listen.ts +0 -379
- package/temp_resend_cli/repo/src/commands/webhooks/update.ts +0 -83
- package/temp_resend_cli/repo/src/commands/webhooks/utils.ts +0 -36
- package/temp_resend_cli/repo/src/commands/whoami.ts +0 -71
- package/temp_resend_cli/repo/src/lib/actions.ts +0 -157
- package/temp_resend_cli/repo/src/lib/client.ts +0 -37
- package/temp_resend_cli/repo/src/lib/config.ts +0 -217
- package/temp_resend_cli/repo/src/lib/files.ts +0 -15
- package/temp_resend_cli/repo/src/lib/help-text.ts +0 -38
- package/temp_resend_cli/repo/src/lib/output.ts +0 -56
- package/temp_resend_cli/repo/src/lib/pagination.ts +0 -36
- package/temp_resend_cli/repo/src/lib/prompts.ts +0 -149
- package/temp_resend_cli/repo/src/lib/spinner.ts +0 -100
- package/temp_resend_cli/repo/src/lib/table.ts +0 -57
- package/temp_resend_cli/repo/src/lib/tty.ts +0 -28
- package/temp_resend_cli/repo/src/lib/update-check.ts +0 -169
- package/temp_resend_cli/repo/src/lib/version.ts +0 -4
- package/temp_resend_cli/repo/tests/commands/api-keys/create.test.ts +0 -196
- package/temp_resend_cli/repo/tests/commands/api-keys/delete.test.ts +0 -157
- package/temp_resend_cli/repo/tests/commands/api-keys/list.test.ts +0 -134
- package/temp_resend_cli/repo/tests/commands/auth/login.test.ts +0 -153
- package/temp_resend_cli/repo/tests/commands/auth/logout.test.ts +0 -153
- package/temp_resend_cli/repo/tests/commands/broadcasts/create.test.ts +0 -454
- package/temp_resend_cli/repo/tests/commands/broadcasts/delete.test.ts +0 -183
- package/temp_resend_cli/repo/tests/commands/broadcasts/get.test.ts +0 -147
- package/temp_resend_cli/repo/tests/commands/broadcasts/list.test.ts +0 -199
- package/temp_resend_cli/repo/tests/commands/broadcasts/send.test.ts +0 -162
- package/temp_resend_cli/repo/tests/commands/broadcasts/update.test.ts +0 -288
- package/temp_resend_cli/repo/tests/commands/contact-properties/create.test.ts +0 -251
- package/temp_resend_cli/repo/tests/commands/contact-properties/delete.test.ts +0 -184
- package/temp_resend_cli/repo/tests/commands/contact-properties/get.test.ts +0 -145
- package/temp_resend_cli/repo/tests/commands/contact-properties/list.test.ts +0 -181
- package/temp_resend_cli/repo/tests/commands/contact-properties/update.test.ts +0 -217
- package/temp_resend_cli/repo/tests/commands/contacts/add-segment.test.ts +0 -189
- package/temp_resend_cli/repo/tests/commands/contacts/create.test.ts +0 -271
- package/temp_resend_cli/repo/tests/commands/contacts/delete.test.ts +0 -193
- package/temp_resend_cli/repo/tests/commands/contacts/get.test.ts +0 -149
- package/temp_resend_cli/repo/tests/commands/contacts/list.test.ts +0 -176
- package/temp_resend_cli/repo/tests/commands/contacts/remove-segment.test.ts +0 -167
- package/temp_resend_cli/repo/tests/commands/contacts/segments.test.ts +0 -168
- package/temp_resend_cli/repo/tests/commands/contacts/topics.test.ts +0 -164
- package/temp_resend_cli/repo/tests/commands/contacts/update-topics.test.ts +0 -248
- package/temp_resend_cli/repo/tests/commands/contacts/update.test.ts +0 -206
- package/temp_resend_cli/repo/tests/commands/doctor.test.ts +0 -164
- package/temp_resend_cli/repo/tests/commands/domains/create.test.ts +0 -193
- package/temp_resend_cli/repo/tests/commands/domains/delete.test.ts +0 -157
- package/temp_resend_cli/repo/tests/commands/domains/get.test.ts +0 -138
- package/temp_resend_cli/repo/tests/commands/domains/list.test.ts +0 -165
- package/temp_resend_cli/repo/tests/commands/domains/update.test.ts +0 -224
- package/temp_resend_cli/repo/tests/commands/domains/verify.test.ts +0 -118
- package/temp_resend_cli/repo/tests/commands/emails/batch.test.ts +0 -324
- package/temp_resend_cli/repo/tests/commands/emails/get.test.ts +0 -132
- package/temp_resend_cli/repo/tests/commands/emails/receiving/attachment.test.ts +0 -141
- package/temp_resend_cli/repo/tests/commands/emails/receiving/attachments.test.ts +0 -169
- package/temp_resend_cli/repo/tests/commands/emails/receiving/get.test.ts +0 -141
- package/temp_resend_cli/repo/tests/commands/emails/receiving/list.test.ts +0 -182
- package/temp_resend_cli/repo/tests/commands/emails/send.test.ts +0 -312
- package/temp_resend_cli/repo/tests/commands/segments/create.test.ts +0 -164
- package/temp_resend_cli/repo/tests/commands/segments/delete.test.ts +0 -183
- package/temp_resend_cli/repo/tests/commands/segments/get.test.ts +0 -138
- package/temp_resend_cli/repo/tests/commands/segments/list.test.ts +0 -174
- package/temp_resend_cli/repo/tests/commands/teams/list.test.ts +0 -62
- package/temp_resend_cli/repo/tests/commands/teams/remove.test.ts +0 -110
- package/temp_resend_cli/repo/tests/commands/teams/switch.test.ts +0 -103
- package/temp_resend_cli/repo/tests/commands/topics/create.test.ts +0 -192
- package/temp_resend_cli/repo/tests/commands/topics/delete.test.ts +0 -157
- package/temp_resend_cli/repo/tests/commands/topics/get.test.ts +0 -126
- package/temp_resend_cli/repo/tests/commands/topics/list.test.ts +0 -125
- package/temp_resend_cli/repo/tests/commands/topics/update.test.ts +0 -178
- package/temp_resend_cli/repo/tests/commands/webhooks/create.test.ts +0 -225
- package/temp_resend_cli/repo/tests/commands/webhooks/delete.test.ts +0 -157
- package/temp_resend_cli/repo/tests/commands/webhooks/get.test.ts +0 -126
- package/temp_resend_cli/repo/tests/commands/webhooks/list.test.ts +0 -178
- package/temp_resend_cli/repo/tests/commands/webhooks/update.test.ts +0 -207
- package/temp_resend_cli/repo/tests/commands/whoami.test.ts +0 -98
- package/temp_resend_cli/repo/tests/e2e/smoke.test.ts +0 -93
- package/temp_resend_cli/repo/tests/helpers.ts +0 -86
- package/temp_resend_cli/repo/tests/lib/client.test.ts +0 -71
- package/temp_resend_cli/repo/tests/lib/config.test.ts +0 -451
- package/temp_resend_cli/repo/tests/lib/files.test.ts +0 -73
- package/temp_resend_cli/repo/tests/lib/help-text.test.ts +0 -97
- package/temp_resend_cli/repo/tests/lib/output.test.ts +0 -136
- package/temp_resend_cli/repo/tests/lib/prompts.test.ts +0 -185
- package/temp_resend_cli/repo/tests/lib/spinner.test.ts +0 -166
- package/temp_resend_cli/repo/tests/lib/table.test.ts +0 -63
- package/temp_resend_cli/repo/tests/lib/tty.test.ts +0 -89
- package/temp_resend_cli/repo/tests/lib/update-check.test.ts +0 -179
- package/temp_resend_cli/repo/tsconfig.json +0 -14
- package/temp_resend_cli/repo/vitest.config.e2e.ts +0 -8
- package/temp_resend_cli/repo/vitest.config.ts +0 -10
- /package/docs/{plugin-examples.md → plugins-examples.md} +0 -0
package/.beads/issues.jsonl
DELETED
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
{"id":"dcli-12t","title":"Add streaming support for process-based plugin commands","description":"Implement incremental stdout handling for process adapter commands so CLI harnesses like Cline can expose live JSONL/NDJSON event streams without buffering until process exit. Include envelope behavior in supercli for streamed process output.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-09T21:23:26.049014225Z","created_by":"jarancibia","updated_at":"2026-03-09T21:30:20.991659650Z","closed_at":"2026-03-09T21:30:20.990860890Z","close_reason":"Implemented process-adapter JSONL streaming support for plugin commands.","source_repo":".","compaction_level":0,"original_size":0}
|
|
2
|
-
{"id":"dcli-15e","title":"Add Cline non-interactive skill and validation coverage","description":"Teach humans and agents how to use the Cline harness safely in unattended mode. Add a dedicated SKILL.md, unit tests, and smoke coverage for JSON streaming and wrapped command behavior.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-09T21:23:26.367938057Z","created_by":"jarancibia","updated_at":"2026-03-09T21:30:22.350869357Z","closed_at":"2026-03-09T21:30:22.350133706Z","close_reason":"Added dedicated Cline non-interactive skill plus test and smoke coverage.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-15e","depends_on_id":"dcli-12t","type":"blocks","created_at":"2026-03-09T21:23:32.662901558Z","created_by":"jarancibia"},{"issue_id":"dcli-15e","depends_on_id":"dcli-tsj","type":"blocks","created_at":"2026-03-09T21:23:32.863518820Z","created_by":"jarancibia"}]}
|
|
3
|
-
{"id":"dcli-15q","title":"Reposition dcli as universal cross-harness CLI router","description":"Update README.md to position dcli as a universal CLI router supporting dozens of harnesses (beads, gwc, commiat, and future community CLIs like gh, aws, docker, kubectl, etc.). Include new 'Cross-Harness Router Overview' section, enhance Architecture diagram with router-centric flow, expand Quick Start with multi-harness examples, rewrite CLI Usage for harness routing patterns, add 'Creating a Plugin Harness' section, and include 'Planned Harnesses' section showing future direction. Maintain backward compatibility messaging.","status":"closed","priority":1,"issue_type":"feature","created_at":"2026-03-08T20:08:23.610030300Z","created_by":"jarancibia","updated_at":"2026-03-08T20:10:30.975518848Z","closed_at":"2026-03-08T20:10:30.974698772Z","source_repo":".","compaction_level":0,"original_size":0}
|
|
4
|
-
{"id":"dcli-15q.1","title":"Document currently supported harnesses","description":"Create docs/supported-harnesses.md documenting all currently supported harnesses: bundled (beads, gwc, commiat, OpenAPI, HTTP, MCP), popular community harnesses (gh, aws, gcloud, az, docker, kubectl, terraform, npm, pip, cargo, git, etc.). Include installation guidance, examples for key harnesses, and reference link from README.","status":"closed","priority":2,"issue_type":"feature","created_at":"2026-03-08T20:08:27.000272090Z","created_by":"jarancibia","updated_at":"2026-03-08T20:10:54.738213960Z","closed_at":"2026-03-08T20:10:54.737045536Z","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-15q.1","depends_on_id":"dcli-15q","type":"parent-child","created_at":"2026-03-08T20:08:27.000272090Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
5
|
-
{"id":"dcli-15q.2","title":"Create plugin harness development guide","description":"Create docs/plugin-harness-guide.md explaining how to create plugin harnesses: manifest structure (plugin.json), command wrapping vs. passthrough patterns, argument mapping, dependency checks and validation, testing locally with 'plugins install', publishing to registry, and detailed examples from bundled plugins (beads, gwc, commiat).","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T20:08:29.562056202Z","created_by":"jarancibia","updated_at":"2026-03-08T20:11:28.559550783Z","closed_at":"2026-03-08T20:11:28.558796804Z","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-15q.2","depends_on_id":"dcli-15q","type":"parent-child","created_at":"2026-03-08T20:08:29.562056202Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
6
|
-
{"id":"dcli-170","title":"Define core Railway CLI commands wrapping","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:07.372166956Z","created_by":"jarancibia","updated_at":"2026-03-09T00:40:58.353933374Z","closed_at":"2026-03-09T00:40:58.352382395Z","close_reason":"Implemented railway wrapped core command (account whoami)","source_repo":".","compaction_level":0,"original_size":0}
|
|
7
|
-
{"id":"dcli-182","title":"Initialize Supabase CLI plugin directory and manifest","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:04.892874172Z","created_by":"jarancibia","updated_at":"2026-03-09T17:05:12.226637925Z","closed_at":"2026-03-09T17:05:12.225842586Z","close_reason":"Initialized supabase plugin directory and manifest","source_repo":".","compaction_level":0,"original_size":0}
|
|
8
|
-
{"id":"dcli-18l","title":"Define core Linear CLI commands wrapping","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:08.281813589Z","created_by":"jarancibia","updated_at":"2026-03-08T23:55:05.614587090Z","closed_at":"2026-03-08T23:55:05.613198881Z","close_reason":"Implemented linear wrapped core command (account whoami)","source_repo":".","compaction_level":0,"original_size":0}
|
|
9
|
-
{"id":"dcli-1c8","title":"Analyze uncovered code areas","description":"Identify modules with low coverage that are good candidates for adding tests","status":"closed","priority":3,"issue_type":"task","created_at":"2026-03-08T17:51:49.234895050Z","created_by":"jarancibia","updated_at":"2026-03-08T18:06:44.173927789Z","closed_at":"2026-03-08T18:06:44.173489704Z","close_reason":"Analyzed: skills.js has lowest coverage (48% -> 98% now covered)","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-1c8","depends_on_id":"dcli-2oo","type":"blocks","created_at":"2026-03-08T17:52:29.085976789Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
10
|
-
{"id":"dcli-1ft","title":"Add plugin registry, remote git installs, and plugins explore","description":"Add plugins/plugins.json registry, plugins explore filters, remote git manifest installs, skills auto-discovery for plugins usage, and commiat registry entry","status":"closed","priority":1,"issue_type":"feat","created_at":"2026-03-08T19:53:18.909662386Z","created_by":"jarancibia","updated_at":"2026-03-08T20:00:18.346569165Z","closed_at":"2026-03-08T20:00:18.346197072Z","close_reason":"Implemented plugin registry file, plugins explore filters, remote git plugin install support, commiat plugin manifest, and plugins usage auto-skill","source_repo":".","compaction_level":0,"original_size":0}
|
|
11
|
-
{"id":"dcli-1jc","title":"Add unit tests to reach +10% coverage","description":"Add unit tests for uncovered modules to increase coverage by 10%","status":"closed","priority":4,"issue_type":"task","created_at":"2026-03-08T17:51:52.761119803Z","created_by":"jarancibia","updated_at":"2026-03-08T18:06:48.819643678Z","closed_at":"2026-03-08T18:06:48.819350528Z","close_reason":"Added 13 new tests for skills.js - lines coverage: 48% -> 98%","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-1jc","depends_on_id":"dcli-1c8","type":"blocks","created_at":"2026-03-08T17:52:29.252402853Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
12
|
-
{"id":"dcli-1mc","title":"Implement ask.js unit tests","description":"Write comprehensive unit tests for cli/ask.js with 100% coverage goal, mocking LLM responses, executor, and console.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T20:54:54.928766024Z","created_by":"jarancibia","updated_at":"2026-03-08T20:55:56.296279039Z","closed_at":"2026-03-08T20:55:56.295812611Z","close_reason":"Implemented 117 unit tests for ask.js with 100% statement coverage. Mocked LLM fetch, executor, and console output. Handled markdown stripping and error cases.","source_repo":".","compaction_level":0,"original_size":0}
|
|
13
|
-
{"id":"dcli-1of","title":"Document Stripe CLI plugin","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:25:29.537678829Z","created_by":"jarancibia","updated_at":"2026-03-08T21:37:35.704082460Z","closed_at":"2026-03-08T21:37:35.702759554Z","source_repo":".","compaction_level":0,"original_size":0}
|
|
14
|
-
{"id":"dcli-1wg","title":"Harden process adapter argument and dependency checks","description":"Improve positional argument handling and missing binary diagnostics.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T18:08:21.391339882Z","created_by":"jarancibia","updated_at":"2026-03-08T18:15:03.761962659Z","closed_at":"2026-03-08T18:15:03.761653188Z","close_reason":"Hardened process adapter with preflight dependency checks, richer flag coercion, and cwd/env support.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-1wg","depends_on_id":"dcli-2s3","type":"blocks","created_at":"2026-03-08T18:08:30.630667298Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
15
|
-
{"id":"dcli-1x0","title":"Implement shell adapter with unsafe true gate","description":"Add shell adapter requiring unsafe true and deterministic timeout behavior.","status":"closed","priority":1,"issue_type":"feature","created_at":"2026-03-08T18:08:21.069755715Z","created_by":"jarancibia","updated_at":"2026-03-08T18:10:32.129812845Z","closed_at":"2026-03-08T18:10:32.129376399Z","close_reason":"Added shell adapter with unsafe true gate, timeout handling, and structured output behavior.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-1x0","depends_on_id":"dcli-2s3","type":"blocks","created_at":"2026-03-08T18:08:30.273366521Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
16
|
-
{"id":"dcli-1z3","title":"Expand plugin doctor for runtime readiness checks","description":"Report dependency readiness and actionable guidance per plugin.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T18:08:21.538062683Z","created_by":"jarancibia","updated_at":"2026-03-08T18:15:03.920467044Z","closed_at":"2026-03-08T18:15:03.920079895Z","close_reason":"Expanded plugins doctor with aggregate status, adapter summaries, and policy checks.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-1z3","depends_on_id":"dcli-2s3","type":"blocks","created_at":"2026-03-08T18:08:30.812806436Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
17
|
-
{"id":"dcli-20o","title":"Add commiat supercli plugin manifest to commiat repo","description":"Add plugins/supercli/plugin.json in commiat repository and validate local git install flow from dcli","status":"closed","priority":1,"issue_type":"feat","created_at":"2026-03-08T20:13:38.873650607Z","created_by":"jarancibia","updated_at":"2026-03-08T20:16:30.786915224Z","closed_at":"2026-03-08T20:16:30.785869803Z","close_reason":"Added commiat plugin manifest upstream and validated registry remote install, doctor, and passthrough","source_repo":".","compaction_level":0,"original_size":0}
|
|
18
|
-
{"id":"dcli-24w","title":"Add passthrough command for Railway CLI","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:07.591331888Z","created_by":"jarancibia","updated_at":"2026-03-09T00:40:58.860876036Z","closed_at":"2026-03-09T00:40:58.859739847Z","close_reason":"Implemented railway namespace passthrough command","source_repo":".","compaction_level":0,"original_size":0}
|
|
19
|
-
{"id":"dcli-2a6","title":"Add passthrough command for Stripe CLI","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:25:29.289038243Z","created_by":"jarancibia","updated_at":"2026-03-09T00:26:18.082926905Z","closed_at":"2026-03-09T00:26:18.082359820Z","close_reason":"Stripe passthrough validated with smoke test and command corrections","source_repo":".","compaction_level":0,"original_size":0}
|
|
20
|
-
{"id":"dcli-2gy","title":"Initialize Linear CLI plugin directory and manifest","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:08.060221135Z","created_by":"jarancibia","updated_at":"2026-03-08T23:55:05.415456755Z","closed_at":"2026-03-08T23:55:05.414617431Z","close_reason":"Initialized linear plugin directory and manifest","source_repo":".","compaction_level":0,"original_size":0}
|
|
21
|
-
{"id":"dcli-2i3","title":"Define core Supabase CLI commands wrapping","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:05.118469911Z","created_by":"jarancibia","updated_at":"2026-03-09T17:05:12.424724358Z","closed_at":"2026-03-09T17:05:12.423900874Z","close_reason":"Implemented supabase wrapped core command (projects list)","source_repo":".","compaction_level":0,"original_size":0}
|
|
22
|
-
{"id":"dcli-2oo","title":"Run baseline coverage test","description":"Run jest --coverage to establish current baseline coverage percentage","status":"closed","priority":2,"issue_type":"chore","created_at":"2026-03-08T17:51:45.159220774Z","created_by":"jarancibia","updated_at":"2026-03-08T18:03:34.179222044Z","closed_at":"2026-03-08T18:03:34.178923847Z","close_reason":"Baseline coverage: 63.82% lines, 61.96% statements","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-2oo","depends_on_id":"dcli-3pk","type":"blocks","created_at":"2026-03-08T17:52:18.741871912Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
23
|
-
{"id":"dcli-2pw","title":"Document Supabase CLI plugin","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:05.611100024Z","created_by":"jarancibia","updated_at":"2026-03-09T17:05:12.809098446Z","closed_at":"2026-03-09T17:05:12.808235464Z","close_reason":"Added supabase plugin documentation, tests, and smoke script","source_repo":".","compaction_level":0,"original_size":0}
|
|
24
|
-
{"id":"dcli-2q1","title":"Extend skills command for providers sync and search","description":"Add skills providers list/add/remove/show, skills sync, and skills search while preserving existing list/get/teach behavior.","status":"closed","priority":1,"issue_type":"feature","created_at":"2026-03-08T19:54:37.026431614Z","created_by":"jarancibia","updated_at":"2026-03-08T19:57:45.687222705Z","closed_at":"2026-03-08T19:57:45.686641965Z","close_reason":"Extended skills command with providers list/add/remove/show, sync, search, and catalog listing mode.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-2q1","depends_on_id":"dcli-uol","type":"blocks","created_at":"2026-03-08T19:54:44.939384039Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
25
|
-
{"id":"dcli-2s3","title":"Define adapter schema v1 and centralized validation","description":"Add shared adapter contract validation and deterministic preflight errors.","status":"closed","priority":1,"issue_type":"feature","created_at":"2026-03-08T18:08:20.896087476Z","created_by":"jarancibia","updated_at":"2026-03-08T18:10:31.987849029Z","closed_at":"2026-03-08T18:10:31.987315031Z","close_reason":"Implemented adapter schema validator with shared common checks and per-adapter required fields.","source_repo":".","compaction_level":0,"original_size":0}
|
|
26
|
-
{"id":"dcli-2sf","title":"Document Railway CLI plugin","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:07.805873356Z","created_by":"jarancibia","updated_at":"2026-03-09T00:40:59.333204662Z","closed_at":"2026-03-09T00:40:59.331370176Z","close_reason":"Added railway plugin documentation, tests, and smoke script","source_repo":".","compaction_level":0,"original_size":0}
|
|
27
|
-
{"id":"dcli-2tf","title":"Complete plugin subsystem unit tests","description":"Achieve 100% coverage for plugins-command.js, plugins-store.js, and plugins-registry.js.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T20:58:24.240011818Z","created_by":"jarancibia","updated_at":"2026-03-08T21:02:40.543353776Z","closed_at":"2026-03-08T21:02:40.542502146Z","close_reason":"Achieved 100% statement coverage for the entire plugin subsystem: plugins-command.js, plugins-manager.js, plugins-store.js, and plugins-registry.js. Implemented extensive mocks for fs, git, and child_process.","source_repo":".","compaction_level":0,"original_size":0}
|
|
28
|
-
{"id":"dcli-2vy","title":"Initialize Stripe CLI plugin directory and manifest","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:25:28.802380692Z","created_by":"jarancibia","updated_at":"2026-03-08T21:37:15.062449799Z","closed_at":"2026-03-08T21:37:15.061158668Z","source_repo":".","compaction_level":0,"original_size":0}
|
|
29
|
-
{"id":"dcli-2w4","title":"Achieve 100% coverage for skills.js","description":"Implement comprehensive unit tests for all subcommands in skills.js, including providers, sync, search, and YAML rendering logic.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T21:22:23.616011605Z","created_by":"jarancibia","updated_at":"2026-03-08T22:20:52.235261675Z","closed_at":"2026-03-08T22:20:52.234485980Z","close_reason":"Achieved 100% statement coverage for skills.js, including all subcommands and YAML rendering logic.","source_repo":".","compaction_level":0,"original_size":0}
|
|
30
|
-
{"id":"dcli-2y1","title":"Add documentation examples and cross-references","description":"Create docs/plugin-examples.md with real manifest examples, update README links to documentation, add CLI examples for router usage, ensure consistent terminology across docs, verify all code examples are executable. Polish and finalize documentation structure.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T20:08:34.045161763Z","created_by":"jarancibia","updated_at":"2026-03-08T20:12:04.706268306Z","closed_at":"2026-03-08T20:12:04.705477172Z","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-2y1","depends_on_id":"dcli-15q.1","type":"waits-for","created_at":"2026-03-08T20:08:34.045161763Z","created_by":"jarancibia","metadata":"{}","thread_id":""},{"issue_id":"dcli-2y1","depends_on_id":"dcli-15q.2","type":"waits-for","created_at":"2026-03-08T20:08:34.045161763Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
31
|
-
{"id":"dcli-2yj","title":"Initialize Vercel CLI plugin directory and manifest","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:05.885846057Z","created_by":"jarancibia","updated_at":"2026-03-08T23:52:02.132899213Z","closed_at":"2026-03-08T23:52:02.132012002Z","close_reason":"Implemented vercel plugin manifest and directory","source_repo":".","compaction_level":0,"original_size":0}
|
|
32
|
-
{"id":"dcli-2yv","title":"Initialize Railway CLI plugin directory and manifest","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:07.038707045Z","created_by":"jarancibia","updated_at":"2026-03-09T00:40:57.712487739Z","closed_at":"2026-03-09T00:40:57.711027583Z","close_reason":"Initialized railway plugin directory and manifest","source_repo":".","compaction_level":0,"original_size":0}
|
|
33
|
-
{"id":"dcli-35z","title":"Implement executor.js unit tests","description":"Write comprehensive unit tests for cli/executor.js to increase total project coverage by ~8%","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T19:20:31.823510086Z","created_by":"jarancibia","updated_at":"2026-03-08T19:35:52.819633671Z","closed_at":"2026-03-08T19:35:52.819299524Z","close_reason":"Implemented 43 unit tests for executor.js covering single commands, workflows, template replacement, and remote fetching. Total project coverage increased from 30.48% to 38.55% (+8.07%).","source_repo":".","compaction_level":0,"original_size":0}
|
|
34
|
-
{"id":"dcli-3e6","title":"Support provider:id retrieval for skills get","description":"Allow skills get <provider:id> to return skill markdown from indexed local providers.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T19:54:37.248310781Z","created_by":"jarancibia","updated_at":"2026-03-08T19:57:45.911625440Z","closed_at":"2026-03-08T19:57:45.910759800Z","close_reason":"Implemented provider:id retrieval path for skills get returning markdown from local index.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-3e6","depends_on_id":"dcli-uol","type":"blocks","created_at":"2026-03-08T19:54:45.084325141Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
35
|
-
{"id":"dcli-3he","title":"Enforce non-interactive execution across adapters","description":"Ensure adapters are non-interactive by default and reject interactive configs.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T18:08:21.229942971Z","created_by":"jarancibia","updated_at":"2026-03-08T18:10:32.331742349Z","closed_at":"2026-03-08T18:10:32.331023678Z","close_reason":"Enforced non-interactive policy through adapter schema validation and executor preflight.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-3he","depends_on_id":"dcli-2s3","type":"blocks","created_at":"2026-03-08T18:08:30.453629482Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
36
|
-
{"id":"dcli-3ms","title":"Implement plugins-manager.js unit tests","description":"Write comprehensive unit tests for cli/plugins-manager.js, mocking filesystem and child_process.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T19:40:54.363074535Z","created_by":"jarancibia","updated_at":"2026-03-08T19:42:09.412485323Z","closed_at":"2026-03-08T19:42:09.412169198Z","close_reason":"Implemented 71 unit tests for plugins-manager.js with 100% statement coverage. Mocked fs, child_process, and plugins-store to test install, remove, and doctor functionality.","source_repo":".","compaction_level":0,"original_size":0}
|
|
37
|
-
{"id":"dcli-3nz","title":"Implement Docker Harness MVP","description":"Main umbrella task for transforming dcli into a universal cross-harness CLI router by implementing the Docker harness. Includes reusable safety framework, plugin manifest, docs, and tests.","status":"closed","priority":1,"issue_type":"feature","created_at":"2026-03-08T20:35:38.017021224Z","created_by":"jarancibia","updated_at":"2026-03-08T20:52:13.981050163Z","closed_at":"2026-03-08T20:52:13.980053979Z","close_reason":"Completed Docker Harness MVP with safety framework, manifest, docs, examples, and tests","source_repo":".","compaction_level":0,"original_size":0,"labels":["docker","harness","router"]}
|
|
38
|
-
{"id":"dcli-3nz.1","title":"Implement Non-TTY Safety Framework in Adapter Layer","description":"Implement a reusable validation layer in the core adapter to prevent non-TTY interactive hangs.\n\nDetailed Instructions:\n1. Modify `cli/adapters/process.js`: Detect non-TTY (`process.stdout.isTTY`). Implement a validation function that rejects commands with flags listed in `interactiveFlags` or if `requiresInteractive: true`.\n2. Error Handling: Return exit code 91 (safety_violation) with a clear message: 'Operation rejected: Cannot run interactive command in a non-TTY environment. Use non-interactive flags instead.'\n3. Schema Update: Update `cli/adapter-schema.js` to include `safetyLevel`, `interactiveFlags`, and `requiresInteractive`.\n4. Integration: Update `executor.js` to call the validation check before spawning processes.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T20:35:47.492172728Z","created_by":"jarancibia","updated_at":"2026-03-08T20:52:13.030891482Z","closed_at":"2026-03-08T20:52:13.030435512Z","close_reason":"Added non-TTY interactive safety validation in process adapter and schema support for safety metadata","source_repo":".","compaction_level":0,"original_size":0,"labels":["core","safety"],"dependencies":[{"issue_id":"dcli-3nz.1","depends_on_id":"dcli-3nz","type":"parent-child","created_at":"2026-03-08T20:35:47.492172728Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
39
|
-
{"id":"dcli-3nz.2","title":"Create Docker Plugin Manifest with 20 Core Commands","description":"Create the comprehensive Docker plugin manifest with safety metadata.\n\nDetailed Instructions:\n1. Create `plugins/docker/plugin.json`.\n2. Resources/Actions (20 total):\n - container: run, ps, ls, start, stop, restart, rm, exec, logs, inspect\n - image: build, images, ls, pull, push, rmi, tag\n - system: info, version, df\n3. Safety Metadata:\n - `run`, `exec`: Add `interactiveFlags: [\"-i\", \"-t\", \"--interactive\", \"--tty\"]`.\n - `attach`, `login`: Add `requiresInteractive: true`.\n4. Argument Coverage: Ensure all major flags (e.g., `-d`, `-p`, `-v`, `-e`) are mapped.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T20:35:47.696246165Z","created_by":"jarancibia","updated_at":"2026-03-08T20:52:13.149910609Z","closed_at":"2026-03-08T20:52:13.149458660Z","close_reason":"Created plugins/docker/plugin.json with 20 core commands and safety metadata for run/exec","source_repo":".","compaction_level":0,"original_size":0,"labels":["docker","manifest"],"dependencies":[{"issue_id":"dcli-3nz.2","depends_on_id":"dcli-3nz","type":"parent-child","created_at":"2026-03-08T20:35:47.696246165Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
40
|
-
{"id":"dcli-3nz.3","title":"Implement Automated Integration Tests for Docker Harness","description":"Verify the Docker harness and safety framework via automated tests.\n\nDetailed Instructions:\n1. Create `__tests__/docker-plugin.test.js`.\n2. Test Cases:\n - Command Routing: `supercli docker container ls` -> `docker ps`.\n - Argument Mapping: Verify flags and positionals are correctly passed to the shell.\n - Safety Violation: Mock a non-TTY environment and verify that `-it` flags are rejected with code 91.\n - Integration: Real `docker version` call if Docker is installed.\n3. Test Safety: Ensure tests don't leave dangling containers/images.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T20:35:47.882064564Z","created_by":"jarancibia","updated_at":"2026-03-08T20:52:13.353186701Z","closed_at":"2026-03-08T20:52:13.351963127Z","close_reason":"Added automated docker harness tests in __tests__/docker-plugin.test.js plus safety tests","source_repo":".","compaction_level":0,"original_size":0,"labels":["docker","test"],"dependencies":[{"issue_id":"dcli-3nz.3","depends_on_id":"dcli-3nz","type":"parent-child","created_at":"2026-03-08T20:35:47.882064564Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
41
|
-
{"id":"dcli-3nz.4","title":"Create Comprehensive Documentation for Docker Harness","description":"Document the Docker harness usage and capabilities.\n\nDetailed Instructions:\n1. `plugins/docker/README.md`: Quick start, installation, common commands.\n2. `plugins/docker/MANIFEST.md`: Complete command-by-command reference with all supported arguments and safety warnings.\n3. No Root Docs: Ensure no files are created in the project root's `docs/` directory; all plugin docs must be local to the plugin folder.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T20:35:48.044182326Z","created_by":"jarancibia","updated_at":"2026-03-08T20:52:13.557081720Z","closed_at":"2026-03-08T20:52:13.555982511Z","close_reason":"Added plugin-local documentation at plugins/docker/README.md and plugins/docker/MANIFEST.md","source_repo":".","compaction_level":0,"original_size":0,"labels":["docker","docs"],"dependencies":[{"issue_id":"dcli-3nz.4","depends_on_id":"dcli-3nz","type":"parent-child","created_at":"2026-03-08T20:35:48.044182326Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
42
|
-
{"id":"dcli-3nz.5","title":"Create Docker Workflow Examples","description":"Create 5 real-world example scripts demonstrating the Docker harness.\n\nDetailed Instructions:\n1. Create `plugins/docker/examples/`.\n2. Example Scripts:\n - `list-containers.sh`: Basic listing and filtering.\n - `run-container.sh`: Detached mode deployment.\n - `build-image.sh`: Automated build process.\n - `inspect-container.sh`: Using JSON output and dcli query logic.\n - `multi-step-workflow.sh`: Orchestrating pull -> run -> rm.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T20:35:48.236283673Z","created_by":"jarancibia","updated_at":"2026-03-08T20:52:13.776385054Z","closed_at":"2026-03-08T20:52:13.775362245Z","close_reason":"Added five docker workflow example scripts under plugins/docker/examples","source_repo":".","compaction_level":0,"original_size":0,"labels":["docker","examples"],"dependencies":[{"issue_id":"dcli-3nz.5","depends_on_id":"dcli-3nz","type":"parent-child","created_at":"2026-03-08T20:35:48.236283673Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
43
|
-
{"id":"dcli-3pk","title":"Wait 10 min for initial test bootstrap","description":"Wait 10 minutes for other agent to finish bootstrapping jest and adding initial 10% coverage","status":"closed","priority":1,"issue_type":"chore","created_at":"2026-03-08T17:51:40.231952222Z","created_by":"jarancibia","updated_at":"2026-03-08T18:03:17.595327435Z","closed_at":"2026-03-08T18:03:17.595010820Z","close_reason":"Completed 10 minute wait","source_repo":".","compaction_level":0,"original_size":0}
|
|
44
|
-
{"id":"dcli-3pt","title":"Define core Stripe CLI commands wrapping","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:25:29.038703413Z","created_by":"jarancibia","updated_at":"2026-03-08T21:37:27.143137180Z","closed_at":"2026-03-08T21:37:27.141876900Z","source_repo":".","compaction_level":0,"original_size":0}
|
|
45
|
-
{"id":"dcli-3s2","title":"Define core Vercel CLI commands wrapping","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:06.249360433Z","created_by":"jarancibia","updated_at":"2026-03-08T23:52:02.327633914Z","closed_at":"2026-03-08T23:52:02.326696721Z","close_reason":"Implemented vercel wrapped core command","source_repo":".","compaction_level":0,"original_size":0}
|
|
46
|
-
{"id":"dcli-3vw","title":"Verify coverage increase","description":"Run jest --coverage to verify the 10% increase was achieved","status":"closed","priority":4,"issue_type":"chore","created_at":"2026-03-08T17:51:58.368870813Z","created_by":"jarancibia","updated_at":"2026-03-08T18:06:52.921522667Z","closed_at":"2026-03-08T18:06:52.921150881Z","close_reason":"Coverage: Lines 63.82% -> 98.58% (+34.76%), Stmts 61.96% -> 93.25% (+31.29%), Branches 55.97% -> 81.13% (+25.16%), Funcs 83.33% -> 100% (+16.67%)","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-3vw","depends_on_id":"dcli-1jc","type":"blocks","created_at":"2026-03-08T17:52:29.427057528Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
47
|
-
{"id":"dcli-4m2","title":"Add gwc plugin passthrough support","description":"Implement gwc plugin, passthrough execution, doctor/install guidance, docs and tests","status":"closed","priority":1,"issue_type":"feat","created_at":"2026-03-08T18:08:46.828812178Z","created_by":"jarancibia","updated_at":"2026-03-08T18:09:27.430656982Z","closed_at":"2026-03-08T18:09:27.430330695Z","close_reason":"Implemented gwc plugin passthrough, doctor/install guidance, docs, and tests","source_repo":".","compaction_level":0,"original_size":0}
|
|
48
|
-
{"id":"dcli-5ix","title":"Document Vercel CLI plugin","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:06.786816126Z","created_by":"jarancibia","updated_at":"2026-03-08T23:52:02.699454899Z","closed_at":"2026-03-08T23:52:02.698638014Z","close_reason":"Added vercel plugin documentation and smoke test","source_repo":".","compaction_level":0,"original_size":0}
|
|
49
|
-
{"id":"dcli-5nb","title":"Add Jest unit coverage for adapter validation and shell adapter","description":"Add tests covering validation matrix and shell adapter guardrails.","status":"closed","priority":2,"issue_type":"test","created_at":"2026-03-08T18:08:21.701319950Z","created_by":"jarancibia","updated_at":"2026-03-08T18:10:32.513527552Z","closed_at":"2026-03-08T18:10:32.513061779Z","close_reason":"Added Jest unit tests for adapter schema and shell adapter behaviors.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-5nb","depends_on_id":"dcli-1x0","type":"blocks","created_at":"2026-03-08T18:08:31.650601322Z","created_by":"jarancibia","metadata":"{}","thread_id":""},{"issue_id":"dcli-5nb","depends_on_id":"dcli-3he","type":"blocks","created_at":"2026-03-08T18:08:32.103318644Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
50
|
-
{"id":"dcli-6yj","title":"Achieve 100% coverage for mcp-local.js and namespace-passthrough.js","description":"Write unit tests for mcp-local registry commands and namespace passthrough logic.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:22:27.707188780Z","created_by":"jarancibia","updated_at":"2026-03-08T22:20:56.832067123Z","closed_at":"2026-03-08T22:20:56.831358454Z","close_reason":"Achieved 100% coverage for mcp-local.js and namespace-passthrough.js.","source_repo":".","compaction_level":0,"original_size":0}
|
|
51
|
-
{"id":"dcli-crv","title":"Add passthrough command for Linear CLI","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:08.507373270Z","created_by":"jarancibia","updated_at":"2026-03-08T23:55:05.799063207Z","closed_at":"2026-03-08T23:55:05.798293886Z","close_reason":"Implemented linear namespace passthrough command","source_repo":".","compaction_level":0,"original_size":0}
|
|
52
|
-
{"id":"dcli-ecg","title":"Add unit tests for local skills knowledge base flow","description":"Cover provider registry, indexing, search, and provider:id retrieval semantics.","status":"closed","priority":2,"issue_type":"test","created_at":"2026-03-08T19:54:37.463195652Z","created_by":"jarancibia","updated_at":"2026-03-08T19:57:46.160034662Z","closed_at":"2026-03-08T19:57:46.159135419Z","close_reason":"Added unit tests for skills catalog provider lifecycle, sync, search, and provider:id retrieval.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-ecg","depends_on_id":"dcli-2q1","type":"blocks","created_at":"2026-03-08T19:54:45.314171599Z","created_by":"jarancibia","metadata":"{}","thread_id":""},{"issue_id":"dcli-ecg","depends_on_id":"dcli-3e6","type":"blocks","created_at":"2026-03-08T19:54:45.588901979Z","created_by":"jarancibia","metadata":"{}","thread_id":""}]}
|
|
53
|
-
{"id":"dcli-id4","title":"Document Linear CLI plugin","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:08.746813105Z","created_by":"jarancibia","updated_at":"2026-03-08T23:55:05.981998145Z","closed_at":"2026-03-08T23:55:05.980489092Z","close_reason":"Added linear plugin documentation, tests, and smoke script","source_repo":".","compaction_level":0,"original_size":0}
|
|
54
|
-
{"id":"dcli-ltr","title":"Add passthrough command for Vercel CLI","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:06.543378685Z","created_by":"jarancibia","updated_at":"2026-03-08T23:52:02.513539971Z","closed_at":"2026-03-08T23:52:02.512901907Z","close_reason":"Implemented vercel passthrough command","source_repo":".","compaction_level":0,"original_size":0}
|
|
55
|
-
{"id":"dcli-pxq","title":"Add passthrough command for Supabase CLI","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:28:05.366008217Z","created_by":"jarancibia","updated_at":"2026-03-09T17:05:12.614912152Z","closed_at":"2026-03-09T17:05:12.614099327Z","close_reason":"Implemented supabase namespace passthrough command","source_repo":".","compaction_level":0,"original_size":0}
|
|
56
|
-
{"id":"dcli-rz0","title":"Complete coverage for adapter-schema.js","description":"Add tests for all supported adapters and validation logic in adapter-schema.js.","status":"closed","priority":2,"issue_type":"task","created_at":"2026-03-08T21:22:32.520742713Z","created_by":"jarancibia","updated_at":"2026-03-08T22:21:03.355990367Z","closed_at":"2026-03-08T22:21:03.355271357Z","close_reason":"Achieved 100% statement coverage for adapter-schema.js.","source_repo":".","compaction_level":0,"original_size":0}
|
|
57
|
-
{"id":"dcli-tsj","title":"Add hybrid Cline plugin for non-interactive task execution","description":"Create a rich Cline harness that combines wrapped non-interactive commands with full namespace passthrough. Focus on agent-safe task run/plan flows using act/plan, yolo, timeout, cwd, model, and JSON output defaults.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-09T21:23:26.210170266Z","created_by":"jarancibia","updated_at":"2026-03-09T21:30:21.764615758Z","closed_at":"2026-03-09T21:30:21.763840946Z","close_reason":"Added hybrid Cline plugin with rich non-interactive task wrappers and passthrough.","source_repo":".","compaction_level":0,"original_size":0,"dependencies":[{"issue_id":"dcli-tsj","depends_on_id":"dcli-12t","type":"blocks","created_at":"2026-03-09T21:23:32.474464976Z","created_by":"jarancibia"}]}
|
|
58
|
-
{"id":"dcli-u99","title":"Fix 0% coverage report in watch mode","description":"Investigate and fix why Jest watch mode shows 0% coverage even when tests pass","status":"closed","priority":1,"issue_type":"bug","created_at":"2026-03-08T18:13:11.302451858Z","created_by":"jarancibia","updated_at":"2026-03-08T18:14:44.003122825Z","closed_at":"2026-03-08T18:14:44.002681908Z","close_reason":"Fixed 0% coverage by setting rootDir, using v8 coverageProvider, and improving collectCoverageFrom patterns in jest.config.js","source_repo":".","compaction_level":0,"original_size":0}
|
|
59
|
-
{"id":"dcli-uol","title":"Add local skills provider registry and index","description":"Implement local_fs and repo_fs provider registry with persistent index cache for skills discovery.","status":"closed","priority":1,"issue_type":"feature","created_at":"2026-03-08T19:54:36.900938772Z","created_by":"jarancibia","updated_at":"2026-03-08T19:57:45.548791188Z","closed_at":"2026-03-08T19:57:45.548206406Z","close_reason":"Implemented local skills provider registry and persistent skills index cache with local_fs/repo_fs defaults.","source_repo":".","compaction_level":0,"original_size":0}
|
|
60
|
-
{"id":"dcli-yyr","title":"Implement config.js unit tests","description":"Write comprehensive unit tests for cli/config.js with 100% coverage goal, mocking fs, os, and fetch.","status":"closed","priority":1,"issue_type":"task","created_at":"2026-03-08T20:38:25.925745082Z","created_by":"jarancibia","updated_at":"2026-03-08T20:40:56.041144293Z","closed_at":"2026-03-08T20:40:56.040705425Z","close_reason":"Implemented 100% statement coverage for config.js. Mocked fs, os, and fetch. Fixed a bug in setMcpServer where null items in mcp_servers array would cause a crash during sorting. Removed dead code (ttlValid).","source_repo":".","compaction_level":0,"original_size":0}
|
package/.beads/metadata.json
DELETED
package/docs/mcp-cheatsheet.md
DELETED
|
@@ -1,324 +0,0 @@
|
|
|
1
|
-
# MCP Server Cheatsheet: SSE/HTTP Implementation in Node.js (Pure, No SDKs - Spec v2025-06-18)
|
|
2
|
-
|
|
3
|
-
<div style="border: 1px solid #ccc; padding: 20px; margin: 10px 0; background-color: #f9f9f9; border-radius: 8px;">
|
|
4
|
-
<strong>Artifact Note:</strong> This is a pure Node.js implementation cheatsheet for an SSE/HTTP-capable MCP server. It uses only built-in modules (e.g., `http`, `https`, `url`, `querystring`) for bidirectional streaming via JSON-RPC 2.0. No external SDKs or npm packages—ideal for lightweight setups. Expand sections for details.
|
|
5
|
-
</div>
|
|
6
|
-
|
|
7
|
-
## Overview
|
|
8
|
-
- **MCP Purpose**: Open protocol for AI apps (e.g., LLMs) to access external tools/resources via JSON-RPC 2.0.
|
|
9
|
-
- **Focus**: Pure Node.js server for bidirectional streaming (client-to-server via POST, server-to-client via SSE GET).
|
|
10
|
-
- **Transports**: SSE + HTTP (streamable; single endpoint preferred) or stdio (local-only). SSE enables real-time server pushes like tool calls/notifications.
|
|
11
|
-
- **Key Benefits**: Resumable streams, session management, secure (Origin validation, auth).
|
|
12
|
-
- **Node.js Notes**: Uses `http.Server` for endpoints; manual JSON-RPC parsing; EventEmitter for internal messaging.
|
|
13
|
-
|
|
14
|
-
<details>
|
|
15
|
-
<summary><strong>Prerequisites (Click to Expand)</strong></summary>
|
|
16
|
-
|
|
17
|
-
- **Runtime**: Node.js 20+ (LTS recommended for stability).
|
|
18
|
-
- **Modules**: Built-ins only: `http`, `https`, `url`, `querystring`, `crypto` (for sessions), `events` (for pub/sub).
|
|
19
|
-
- **Tools**: Familiarity with JSON-RPC, HTTP/SSE; editor like VS Code.
|
|
20
|
-
- **Security**: Use `https` in prod; validate origins to prevent rebinding. Run with `node server.js`.
|
|
21
|
-
|
|
22
|
-
</details>
|
|
23
|
-
|
|
24
|
-
## Transport Types: SSE/HTTP
|
|
25
|
-
| Type | Description | Pros | Cons |
|
|
26
|
-
|------|-------------|------|------|
|
|
27
|
-
| **Streamable HTTP + SSE** | Single endpoint (`/mcp`) for POST (client → server) & GET (SSE stream server → client). | Bidirectional, resumable, efficient for remote. | Manual SSE flushing; manage sessions. |
|
|
28
|
-
| **HTTP Only** | POST for all; no streaming. | Simple. | No real-time pushes. |
|
|
29
|
-
| **Stdio** | Local stdin/stdout (not HTTP). | Fast for desktop. | Non-remote. |
|
|
30
|
-
|
|
31
|
-
- **Protocol Version**: Client sends `MCP-Protocol-Version: 2025-06-18` header; server rejects invalid (400 Bad Request).
|
|
32
|
-
|
|
33
|
-
<details>
|
|
34
|
-
<summary><strong>Server Setup Steps (Click to Expand)</strong></summary>
|
|
35
|
-
|
|
36
|
-
1. **Init Project**:
|
|
37
|
-
Create `server.js` and `package.json` (for scripts, no deps):
|
|
38
|
-
```json
|
|
39
|
-
// package.json
|
|
40
|
-
{"name": "mcp-server", "scripts": {"start": "node server.js"}}
|
|
41
|
-
```
|
|
42
|
-
|
|
43
|
-
2. **Create HTTP Server Instance**:
|
|
44
|
-
```javascript
|
|
45
|
-
const http = require('http');
|
|
46
|
-
const url = require('url');
|
|
47
|
-
const { EventEmitter } = require('events');
|
|
48
|
-
const crypto = require('crypto');
|
|
49
|
-
|
|
50
|
-
const server = http.createServer(handleRequest);
|
|
51
|
-
const emitter = new EventEmitter(); // For internal pub/sub (e.g., server pushes)
|
|
52
|
-
|
|
53
|
-
function handleRequest(req, res) {
|
|
54
|
-
const parsedUrl = url.parse(req.url, true);
|
|
55
|
-
const method = req.method;
|
|
56
|
-
const pathname = parsedUrl.pathname;
|
|
57
|
-
|
|
58
|
-
// Validate protocol version
|
|
59
|
-
if (!req.headers['mcp-protocol-version'] || req.headers['mcp-protocol-version'] !== '2025-06-18') {
|
|
60
|
-
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
61
|
-
res.end(JSON.stringify({ jsonrpc: '2.0', error: { code: -32600, message: 'Invalid Protocol Version' } }));
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
if (pathname === '/mcp' || pathname === '/messages/') {
|
|
66
|
-
if (method === 'POST') {
|
|
67
|
-
handlePost(req, res, emitter);
|
|
68
|
-
} else if (method === 'GET') {
|
|
69
|
-
handleSSE(req, res, emitter);
|
|
70
|
-
} else if (method === 'DELETE') {
|
|
71
|
-
handleDelete(req, res);
|
|
72
|
-
} else {
|
|
73
|
-
res.writeHead(405);
|
|
74
|
-
res.end();
|
|
75
|
-
}
|
|
76
|
-
} else {
|
|
77
|
-
res.writeHead(404);
|
|
78
|
-
res.end();
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
3. **Define Tools/Resources** (Manual Dispatch):
|
|
84
|
-
Use a map for methods (tools/resources).
|
|
85
|
-
```javascript
|
|
86
|
-
const tools = {
|
|
87
|
-
example_tool: async (params) => `Processed: ${params.param}`,
|
|
88
|
-
// Add async funcs for I/O
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
const resources = {
|
|
92
|
-
'example://{id}': (id) => `Resource data for ${id}`,
|
|
93
|
-
};
|
|
94
|
-
|
|
95
|
-
// In handlePost: Parse method, dispatch
|
|
96
|
-
async function dispatchMethod(method, params, id, sessionId) {
|
|
97
|
-
if (tools[method]) {
|
|
98
|
-
try {
|
|
99
|
-
const result = await tools[method](params);
|
|
100
|
-
return { jsonrpc: '2.0', result, id };
|
|
101
|
-
} catch (e) {
|
|
102
|
-
return { jsonrpc: '2.0', error: { code: -32000, message: e.message }, id };
|
|
103
|
-
}
|
|
104
|
-
} else if (method.startsWith('resources/')) {
|
|
105
|
-
// Handle resources similarly
|
|
106
|
-
}
|
|
107
|
-
return { jsonrpc: '2.0', error: { code: -32601, message: 'Method Not Found' }, id };
|
|
108
|
-
}
|
|
109
|
-
```
|
|
110
|
-
|
|
111
|
-
4. **Setup SSE Transport**:
|
|
112
|
-
Manual SSE handling with keep-alives.
|
|
113
|
-
```javascript
|
|
114
|
-
function handleSSE(req, res, emitter) {
|
|
115
|
-
const sessionId = req.headers['mcp-session-id'];
|
|
116
|
-
if (!sessionId) {
|
|
117
|
-
res.writeHead(401);
|
|
118
|
-
res.end('Missing Session ID');
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
res.writeHead(200, {
|
|
123
|
-
'Content-Type': 'text/event-stream',
|
|
124
|
-
'Cache-Control': 'no-cache',
|
|
125
|
-
'Connection': 'keep-alive',
|
|
126
|
-
'Access-Control-Allow-Origin': req.headers.origin || '*', // Validate in prod
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
let lastEventId = req.headers['last-event-id'] || '0';
|
|
130
|
-
// Resume logic: Replay events > lastEventId (store in session map)
|
|
131
|
-
|
|
132
|
-
const heartbeat = setInterval(() => {
|
|
133
|
-
res.write(`: heartbeat\n\n`); // Keep-alive
|
|
134
|
-
}, 15000);
|
|
135
|
-
|
|
136
|
-
// Listen for server pushes
|
|
137
|
-
const listener = (msg) => {
|
|
138
|
-
if (msg.sessionId === sessionId && msg.eventId > parseInt(lastEventId)) {
|
|
139
|
-
res.write(`id: ${msg.eventId}\ndata: ${JSON.stringify(msg.data)}\n\n`);
|
|
140
|
-
lastEventId = msg.eventId.toString();
|
|
141
|
-
}
|
|
142
|
-
};
|
|
143
|
-
emitter.on('push', listener);
|
|
144
|
-
|
|
145
|
-
req.on('close', () => {
|
|
146
|
-
clearInterval(heartbeat);
|
|
147
|
-
emitter.off('push', listener);
|
|
148
|
-
res.end();
|
|
149
|
-
});
|
|
150
|
-
}
|
|
151
|
-
```
|
|
152
|
-
|
|
153
|
-
5. **Handle POST (Client Messages)**:
|
|
154
|
-
Parse JSON-RPC, dispatch, respond or push via SSE.
|
|
155
|
-
```javascript
|
|
156
|
-
function handlePost(req, res, emitter) {
|
|
157
|
-
let body = '';
|
|
158
|
-
req.on('data', chunk => body += chunk);
|
|
159
|
-
req.on('end', async () => {
|
|
160
|
-
try {
|
|
161
|
-
const msg = JSON.parse(body);
|
|
162
|
-
if (!msg.jsonrpc || msg.jsonrpc !== '2.0') throw new Error('Invalid JSON-RPC');
|
|
163
|
-
|
|
164
|
-
const sessionId = req.headers['mcp-session-id'] || generateSessionId();
|
|
165
|
-
res.setHeader('Mcp-Session-Id', sessionId);
|
|
166
|
-
|
|
167
|
-
if (msg.id !== undefined) { // Request
|
|
168
|
-
const response = await dispatchMethod(msg.method, msg.params || {}, msg.id, sessionId);
|
|
169
|
-
res.writeHead(202, { 'Content-Type': 'application/json' });
|
|
170
|
-
res.end(JSON.stringify(response));
|
|
171
|
-
} else { // Notification
|
|
172
|
-
await dispatchMethod(msg.method, msg.params || {}, null, sessionId); // Fire-and-forget
|
|
173
|
-
res.writeHead(202);
|
|
174
|
-
res.end();
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
// For server-initiated pushes (e.g., notifications)
|
|
178
|
-
emitter.emit('push', { sessionId, eventId: Date.now(), data: { /* response */ } });
|
|
179
|
-
} catch (e) {
|
|
180
|
-
res.writeHead(400, { 'Content-Type': 'application/json' });
|
|
181
|
-
res.end(JSON.stringify({ jsonrpc: '2.0', error: { code: -32700, message: 'Parse Error' } }));
|
|
182
|
-
}
|
|
183
|
-
});
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
function generateSessionId() {
|
|
187
|
-
return crypto.randomUUID();
|
|
188
|
-
}
|
|
189
|
-
```
|
|
190
|
-
|
|
191
|
-
6. **Run Server**:
|
|
192
|
-
```javascript
|
|
193
|
-
server.listen(8000, '127.0.0.1', () => {
|
|
194
|
-
console.log('MCP Server running on http://127.0.0.1:8000');
|
|
195
|
-
});
|
|
196
|
-
```
|
|
197
|
-
- For HTTPS: Replace `http` with `https`, provide key/cert.
|
|
198
|
-
|
|
199
|
-
</details>
|
|
200
|
-
|
|
201
|
-
## Endpoints
|
|
202
|
-
| Method | Path | Purpose | Headers/Body |
|
|
203
|
-
|--------|------|---------|--------------|
|
|
204
|
-
| **POST** | `/mcp` (or `/messages/`) | Client sends JSON-RPC (requests/notifications). | `Accept: application/json, text/event-stream`<br>Body: JSON-RPC msg |
|
|
205
|
-
| **GET** | `/mcp` (or `/sse/`) | Open SSE stream for server pushes (requests/notifications). | `Accept: text/event-stream`<br>`Last-Event-ID` (for resume) |
|
|
206
|
-
| **DELETE** | `/mcp` | Terminate session. | `Mcp-Session-Id` header |
|
|
207
|
-
|
|
208
|
-
- **Responses**:
|
|
209
|
-
- POST: 202 Accepted (no body) or JSON.
|
|
210
|
-
- Errors: 400/404/500 with JSON-RPC error body (no `id` for non-requests).
|
|
211
|
-
- **Keep-Alives**: SSE heartbeats every 15s; close after response.
|
|
212
|
-
|
|
213
|
-
<details>
|
|
214
|
-
<summary><strong>Message Formats (JSON-RPC 2.0) (Click to Expand)</strong></summary>
|
|
215
|
-
|
|
216
|
-
- **Request** (Client → Server):
|
|
217
|
-
```json
|
|
218
|
-
{"jsonrpc": "2.0", "method": "tool_name", "params": {"key": "value"}, "id": 1}
|
|
219
|
-
```
|
|
220
|
-
- **Notification** (No response expected): Omit `id`.
|
|
221
|
-
- **Response** (Server → Client):
|
|
222
|
-
```json
|
|
223
|
-
{"jsonrpc": "2.0", "result": "value", "id": 1}
|
|
224
|
-
```
|
|
225
|
-
- **Error**:
|
|
226
|
-
```json
|
|
227
|
-
{"jsonrpc": "2.0", "error": {"code": -32600, "message": "Invalid Request"}, "id": 1}
|
|
228
|
-
```
|
|
229
|
-
- **SSE Events**: `data: <JSON>\n\n` (UTF-8); unique `id` for resumability.
|
|
230
|
-
- **Session**: Server assigns `Mcp-Session-Id` in response header; client echoes in headers.
|
|
231
|
-
|
|
232
|
-
</details>
|
|
233
|
-
|
|
234
|
-
## Security & Authentication
|
|
235
|
-
- **Basics**: Use `https.createServer` in prod; validate `Origin` header (reject mismatches).
|
|
236
|
-
```javascript
|
|
237
|
-
// In handleRequest
|
|
238
|
-
if (req.headers.origin !== 'https://trusted-client.com') {
|
|
239
|
-
res.writeHead(403);
|
|
240
|
-
res.end();
|
|
241
|
-
return;
|
|
242
|
-
}
|
|
243
|
-
```
|
|
244
|
-
- **Auth**:
|
|
245
|
-
- API keys in headers (e.g., `Authorization: Bearer <token>`—verify manually).
|
|
246
|
-
- Sessions: Store in Map (e.g., `sessions.set(sessionId, { expires: Date.now() + 3600000 })`); expire after 1h inactivity (404).
|
|
247
|
-
- **Best Practices**: User approval for tools; no embedded newlines in msgs; log to console.error.
|
|
248
|
-
|
|
249
|
-
<details>
|
|
250
|
-
<summary><strong>Error Handling (Click to Expand)</strong></summary>
|
|
251
|
-
|
|
252
|
-
- **Common Codes**: -32600 (Invalid Req), -32601 (Method Not Found), -32700 (Parse Error).
|
|
253
|
-
- **Implementation**:
|
|
254
|
-
```javascript
|
|
255
|
-
try {
|
|
256
|
-
// Tool logic (e.g., fetch)
|
|
257
|
-
const response = await fetch(url, { timeout: 30000 });
|
|
258
|
-
if (!response.ok) throw new Error('HTTP Error');
|
|
259
|
-
return await response.json();
|
|
260
|
-
} catch (e) {
|
|
261
|
-
return { jsonrpc: '2.0', error: { code: -32000, message: e.message }, id };
|
|
262
|
-
}
|
|
263
|
-
```
|
|
264
|
-
- **Disconnections**: Don't cancel on close; require explicit `CancelledNotification`. Resume via `Last-Event-ID` (store events per session in a Map).
|
|
265
|
-
|
|
266
|
-
</details>
|
|
267
|
-
|
|
268
|
-
<details>
|
|
269
|
-
<summary><strong>Example: Full Pure Node.js SSE MCP Server (Click to Expand)</strong></summary>
|
|
270
|
-
|
|
271
|
-
```javascript
|
|
272
|
-
// server.js
|
|
273
|
-
const http = require('http');
|
|
274
|
-
const url = require('url');
|
|
275
|
-
const { EventEmitter } = require('events');
|
|
276
|
-
const crypto = require('crypto');
|
|
277
|
-
|
|
278
|
-
const emitter = new EventEmitter();
|
|
279
|
-
const sessions = new Map(); // Simple session store
|
|
280
|
-
|
|
281
|
-
const server = http.createServer(handleRequest);
|
|
282
|
-
server.listen(8000, '127.0.0.1', () => console.log('MCP Server on http://127.0.0.1:8000'));
|
|
283
|
-
|
|
284
|
-
const tools = {
|
|
285
|
-
echo: async (params) => `Echo: ${params.message}`,
|
|
286
|
-
};
|
|
287
|
-
|
|
288
|
-
async function dispatchMethod(method, params, id, sessionId) {
|
|
289
|
-
if (tools[method]) {
|
|
290
|
-
try {
|
|
291
|
-
const result = await tools[method](params);
|
|
292
|
-
emitter.emit('push', { sessionId, eventId: Date.now(), data: { jsonrpc: '2.0', result, id } });
|
|
293
|
-
return { jsonrpc: '2.0', result, id };
|
|
294
|
-
} catch (e) {
|
|
295
|
-
return { jsonrpc: '2.0', error: { code: -32000, message: e.message }, id };
|
|
296
|
-
}
|
|
297
|
-
}
|
|
298
|
-
return { jsonrpc: '2.0', error: { code: -32601, message: 'Method Not Found' }, id };
|
|
299
|
-
}
|
|
300
|
-
|
|
301
|
-
function handleRequest(req, res) {
|
|
302
|
-
// ... (as in steps above)
|
|
303
|
-
// Integrate dispatchMethod, handlePost, handleSSE
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
function handlePost(req, res, emitter) {
|
|
307
|
-
// ... (as in steps above)
|
|
308
|
-
}
|
|
309
|
-
|
|
310
|
-
function handleSSE(req, res, emitter) {
|
|
311
|
-
// ... (as in steps above)
|
|
312
|
-
}
|
|
313
|
-
|
|
314
|
-
function generateSessionId() {
|
|
315
|
-
return crypto.randomUUID();
|
|
316
|
-
}
|
|
317
|
-
```
|
|
318
|
-
- **Test**: POST to `/mcp` with JSON-RPC (e.g., via curl: `curl -X POST -H "Content-Type: application/json" -d '{"jsonrpc":"2.0","method":"echo","params":{"message":"hi"},"id":1}' http://localhost:8000/mcp`); GET `/mcp` for SSE. Config client: `{"url": "http://localhost:8000/mcp"}`.
|
|
319
|
-
|
|
320
|
-
For HTTPS or advanced deployment (e.g., PM2), extend with `https` module.
|
|
321
|
-
|
|
322
|
-
</details>
|
|
323
|
-
|
|
324
|
-
---
|
package/docs/visual-overview.md
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
# dcli visual overview
|
|
2
|
-
|
|
3
|
-
The architecture blueprint for dcli lives in the self-contained HTML artifact generated via the `visual-explainer` plugin.
|
|
4
|
-
|
|
5
|
-
- **File**: `~/.agent/diagrams/dcli-visual-architecture.html`
|
|
6
|
-
- **Open**: `xdg-open ~/.agent/diagrams/dcli-visual-architecture.html`
|
|
7
|
-
- **Source**: Created with `supercli skills get visual-explainer:visual-explainer.skill` guidance.
|
|
8
|
-
|
|
9
|
-
## What the HTML covers
|
|
10
|
-
|
|
11
|
-
1. **Skill routing pipeline** – Mermaid snapshot of `cli/supercli.js`, the skills catalog, plugin harness manager, server APIs, and adapters. Includes zoom, pan, and expand controls per the visual-explainer requirements.
|
|
12
|
-
2. **Runtime pillars** – Card grid summarizing the CLI runtime, catalog, plugin manager, and Express backend with file references such as `cli/plugins-manager.js` and `server/app.js`.
|
|
13
|
-
3. **Plugin & skill lifecycle** – Timeline of registry discovery → install → catalog sync → execution, tying back to commands like `supercli skills list --catalog`.
|
|
14
|
-
4. **Capability matrix** – HTML table comparing bundled harnesses, built-in adapters, remote providers, and the server API, highlighting when to use commands such as `supercli sync`.
|
|
15
|
-
5. **Operational cues** – Details blocks that document behaviors like plan building and storage fallbacks.
|
|
16
|
-
|
|
17
|
-
## Regenerating or extending
|
|
18
|
-
|
|
19
|
-
1. Ensure the `visual-explainer` provider is installed (`supercli plugins install visual-explainer`).
|
|
20
|
-
2. Re-open the reference templates (`visual-explainer:visual-explainer.templates.architecture`, `...templates.data-table`, etc.) to stay within the mandated aesthetics.
|
|
21
|
-
3. Update the HTML under `~/.agent/diagrams/` and refresh this markdown with any new sections you add. Keep this file as the only place in the repo that references the artifact’s path.
|
|
@@ -1,60 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"permissions": {
|
|
3
|
-
"allow": [
|
|
4
|
-
"Bash(cargo:*)",
|
|
5
|
-
"Bash(timeout 30s cargo:*)",
|
|
6
|
-
"Bash(timeout 10s cargo:*)",
|
|
7
|
-
"Bash(timeout 15s cargo:*)",
|
|
8
|
-
"Bash(RUST_BACKTRACE=1 cargo:*)",
|
|
9
|
-
"Bash(make:*)",
|
|
10
|
-
"Bash(INLINE_SNAPSHOT_DEFAULT_FLAGS=disable make:*)",
|
|
11
|
-
"Bash(mkdir:*)",
|
|
12
|
-
"Bash(uv:*)",
|
|
13
|
-
"Bash(echo:*)",
|
|
14
|
-
"Bash(rg:*)",
|
|
15
|
-
"Bash(sed:*)",
|
|
16
|
-
"Bash(grep:*)",
|
|
17
|
-
"Bash(fastmod:*)",
|
|
18
|
-
"Bash(find:*)",
|
|
19
|
-
"Bash(ls:*)",
|
|
20
|
-
"Bash(cat:*)",
|
|
21
|
-
"Bash(python3:*)",
|
|
22
|
-
"Bash(git show:*)",
|
|
23
|
-
"Bash(git diff:*)",
|
|
24
|
-
"Bash(git add:*)",
|
|
25
|
-
"Bash(git stash:*)",
|
|
26
|
-
"Bash(git checkout:*)",
|
|
27
|
-
"Bash(git mv:*)",
|
|
28
|
-
"Bash(git log:*)",
|
|
29
|
-
"Bash(git grep:*)",
|
|
30
|
-
"Bash(git status:*)",
|
|
31
|
-
"Bash(gh pr view:*)",
|
|
32
|
-
"Bash(gh api:*)",
|
|
33
|
-
"Bash(gh run view:*)",
|
|
34
|
-
"Bash(gh issue view:*)",
|
|
35
|
-
"Skill(python-playground)",
|
|
36
|
-
"Skill(fastmod)",
|
|
37
|
-
"Skill(coverage)",
|
|
38
|
-
"Bash(wc:*)",
|
|
39
|
-
"Bash(xxd:*)",
|
|
40
|
-
"Bash(head:*)",
|
|
41
|
-
"Bash(rustup show:*)",
|
|
42
|
-
"Bash(xargs:*)",
|
|
43
|
-
"Bash(perl:*)",
|
|
44
|
-
"Bash(du:*)",
|
|
45
|
-
"Bash(npm run:*)",
|
|
46
|
-
"Bash(mkdir:*)",
|
|
47
|
-
"WebSearch",
|
|
48
|
-
"WebFetch(domain:pypi.org)",
|
|
49
|
-
"WebFetch(domain:docs.anthropic.com)",
|
|
50
|
-
"WebFetch(domain:github.com)",
|
|
51
|
-
"WebFetch(domain:15r10nk.github.io)",
|
|
52
|
-
"WebFetch(domain:docs.rs)",
|
|
53
|
-
"WebFetch(domain:pyo3.rs)",
|
|
54
|
-
"WebFetch(domain:napi.rs)",
|
|
55
|
-
"WebFetch(domain:app.codecov.io)"
|
|
56
|
-
],
|
|
57
|
-
"deny": [],
|
|
58
|
-
"ask": []
|
|
59
|
-
}
|
|
60
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: fastmod
|
|
3
|
-
description: Use fastmod to make mass code updates to avoid many repetitive changes.
|
|
4
|
-
---
|
|
5
|
-
|
|
6
|
-
# fastmod
|
|
7
|
-
|
|
8
|
-
## Instructions
|
|
9
|
-
|
|
10
|
-
You can occasionally use `fastmod` or `sed` to make mass updates to the codebase and avoid wasting tokens changing each case one at a time.
|
|
11
|
-
|
|
12
|
-
Before making many repetitive changes to the codebase, consider using `fastmod --accept-all`.
|
|
13
|
-
|
|
14
|
-
THINK HARD about how best to use `fastmod` as it can dramatically improve your productivity.
|
|
15
|
-
|
|
16
|
-
## Examples
|
|
17
|
-
|
|
18
|
-
Example of switching the `py_type` function to use `impl ResourceTracker` instead of `T: ResourceTracker`:
|
|
19
|
-
|
|
20
|
-
```bash
|
|
21
|
-
fastmod --accept-all 'fn py_type<T: ResourceTracker>(\(.+?)<T>' 'fn py_type$1<impl ResourceTracker>'
|
|
22
|
-
```
|