@marimo-team/frontend 0.23.7-dev5 → 0.23.7-dev51
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/dist/assets/CellStatus-DXNmZJpi.js +1 -0
- package/dist/assets/ConnectedDataExplorerComponent-D-boDGAP.js +1 -0
- package/dist/assets/DeferredRequestRegistry-CzVJLtsG.js +1 -0
- package/dist/assets/ErrorBoundary-DyYDV0HI.js +1 -0
- package/dist/assets/ImperativeModal-DEC1mXgV.js +1 -0
- package/dist/assets/JsonOutput-Dxol3ZtH.js +49 -0
- package/dist/assets/LazyAnyLanguageCodeMirror-B2pl_WA3.js +2 -0
- package/dist/assets/MarimoErrorOutput-YGhIA85d.js +7 -0
- package/dist/assets/RSPContexts-Bk1r00gJ.js +1 -0
- package/dist/assets/RenderHTML-Dz1OIbOh.js +1 -0
- package/dist/assets/RunButton-D1IZ1Yr0.js +1 -0
- package/dist/assets/__vite-browser-external-DuZehUbK.js +1 -0
- package/dist/assets/__vite-browser-external-Jpm67kL1.js +1 -0
- package/dist/assets/add-cell-with-ai-hIPYl46r.js +97 -0
- package/dist/assets/add-connection-dialog-CMR-c9XE.js +167 -0
- package/dist/assets/agent-panel-DnBAoLsM.js +287 -0
- package/dist/assets/ai-model-dropdown-zvokTxf_.js +5 -0
- package/dist/assets/alert-dialog-BqFLkbUc.js +11 -0
- package/dist/assets/any-language-editor-BgxVFHQ8.js +1 -0
- package/dist/assets/apl-Bl4yyYus.js +1 -0
- package/dist/assets/app-config-button-BjFAqaTN.js +1 -0
- package/dist/assets/arc-npelKso9.js +1 -0
- package/dist/assets/architecture-7HQA4BMR-CaNOiKrI.js +1 -0
- package/dist/assets/architectureDiagram-VXUJARFQ-BsWISGgz.js +36 -0
- package/dist/assets/asciiarmor-BlzLkEza.js +1 -0
- package/dist/assets/asn1-Khb778U5.js +1 -0
- package/dist/assets/ban-0fKnt00i.js +1 -0
- package/dist/assets/blockDiagram-VD42YOAC-CzfQ0Exj.js +122 -0
- package/dist/assets/brainfuck-BzHxpB_u.js +1 -0
- package/dist/assets/button-BbCh-29a.js +1 -0
- package/dist/assets/c4Diagram-YG6GDRKO-D0FgqleO.js +10 -0
- package/dist/assets/cache-panel-VL13fWgF.js +1 -0
- package/dist/assets/capabilities-A_KhFcGV.js +1 -0
- package/dist/assets/cell-editor-Dak_jwhB.js +20 -0
- package/dist/assets/cell-link-pRI-YfIp.js +1 -0
- package/dist/assets/cells-DbE28H1u.js +229 -0
- package/dist/assets/channel-DjPEzqq3.js +1 -0
- package/dist/assets/chat-display-D_nDPZek.js +1 -0
- package/dist/assets/chat-panel-BktSpl2P.js +3 -0
- package/dist/assets/chat-ui-C0_KcXrv.js +4 -0
- package/dist/assets/chunk-4BX2VUAB-Br07KPs3.js +1 -0
- package/dist/assets/chunk-55IACEB6-BHM3yXYz.js +1 -0
- package/dist/assets/chunk-5FQGJX7Z-DILIU9Rm.js +113 -0
- package/dist/assets/chunk-ABZYJK2D-pjI0V9vG.js +80 -0
- package/dist/assets/chunk-ATLVNIR6-DMcOYQJi.js +1 -0
- package/dist/assets/chunk-B4BG7PRW-jxe9_Hde.js +165 -0
- package/dist/assets/chunk-CVBHYZKI-DwNHftX6.js +1 -0
- package/dist/assets/chunk-DI55MBZ5-CNxnbO1g.js +220 -0
- package/dist/assets/chunk-EXTU4WIE-C7TYTuus.js +1 -0
- package/dist/assets/chunk-FMBD7UC4-jBIrJcS0.js +15 -0
- package/dist/assets/chunk-HN2XXSSU-COpG_X4X.js +1 -0
- package/dist/assets/chunk-JA3XYJ7Z-2W_JmZ4z.js +70 -0
- package/dist/assets/chunk-JZLCHNYA-DdjotIam.js +54 -0
- package/dist/assets/chunk-MI3HLSF2-D_z13ybc.js +32 -0
- package/dist/assets/chunk-N4CR4FBY-Y37VEUfx.js +2 -0
- package/dist/assets/chunk-QN33PNHL-BcKQMXSf.js +1 -0
- package/dist/assets/chunk-QXUST7PY-CU78e3vp.js +7 -0
- package/dist/assets/chunk-QZHKN3VN-g-7LWEK-.js +1 -0
- package/dist/assets/chunk-S3R3BYOJ-EEhIeeuI.js +2 -0
- package/dist/assets/chunk-TZMSLE5B-D1A_Dyzt.js +1 -0
- package/dist/assets/classDiagram-2ON5EDUG-CDgVuBLy.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-B2UHhBVi.js +1 -0
- package/dist/assets/clike-TW9KXOmZ.js +1 -0
- package/dist/assets/clojure-C_sT-_CQ.js +1 -0
- package/dist/assets/cmake-BjrhHx8m.js +1 -0
- package/dist/assets/cobol-Cs8YSzaw.js +1 -0
- package/dist/assets/code-block-37QAKDTI-Bgm-HPiB.js +2 -0
- package/dist/assets/coffeescript-juXyFkA0.js +1 -0
- package/dist/assets/column-preview-CNeXQtKn.js +1 -0
- package/dist/assets/command-2NPJCYDa.js +1 -0
- package/dist/assets/command-palette-CcjZs_TG.js +1 -0
- package/dist/assets/common-CWRr25jC.js +1 -0
- package/dist/assets/commonlisp-Cmn_5nuv.js +1 -0
- package/dist/assets/components-Cj3Al1Y6.js +1 -0
- package/dist/assets/components-DUd0ki0p.js +1 -0
- package/dist/assets/config-DGudsRYK.js +1 -0
- package/dist/assets/context-C1Tm_47t.js +1 -0
- package/dist/assets/copy-Ch48HVPK.js +1 -0
- package/dist/assets/copy-icon-BdZPgXgo.js +1 -0
- package/dist/assets/cose-bilkent-S5V4N54A-B7DsItpC.js +1 -0
- package/dist/assets/createReducer-CI9qeK_X.js +1 -0
- package/dist/assets/crystal-DJrWmXfk.js +1 -0
- package/dist/assets/css-BJpII9DZ.js +1 -0
- package/dist/assets/cypher-D549BT6Q.js +1 -0
- package/dist/assets/d-CQplIm4C.js +1 -0
- package/dist/assets/dagre-6UL2VRFP-F7ectrvx.js +4 -0
- package/dist/assets/data-grid-overlay-editor-Cvj8Susd.js +1 -0
- package/dist/assets/datasource-Prn_GWOB.js +3 -0
- package/dist/assets/dates-DI1TvEEK.js +1 -0
- package/dist/assets/dependency-graph-panel-DUUCij85.js +5 -0
- package/dist/assets/diagram-PSM6KHXK-DLOGvjhP.js +24 -0
- package/dist/assets/diagram-QEK2KX5R-BEJdNpvg.js +43 -0
- package/dist/assets/diagram-S2PKOQOG-CqMnWWB8.js +24 -0
- package/dist/assets/dialog-DqOQT_n4.js +1 -0
- package/dist/assets/diff-Dz2enOOE.js +1 -0
- package/dist/assets/dist-7TsTgeOV.js +1 -0
- package/dist/assets/dist-B0N0-Vx5.js +1 -0
- package/dist/assets/dist-BE3jO1WU.js +1 -0
- package/dist/assets/dist-BNfAUjeR.js +1 -0
- package/dist/assets/dist-BQxSimS-.js +1 -0
- package/dist/assets/dist-BSp3naSP.js +1 -0
- package/dist/assets/dist-BYShiqDa.js +1 -0
- package/dist/assets/dist-BZe5KYlj.js +1 -0
- package/dist/assets/dist-BZr6MMV-.js +1 -0
- package/dist/assets/dist-BbkYHvT2.js +1 -0
- package/dist/assets/dist-BdyjRhEt.js +1 -0
- package/dist/assets/dist-CAWvCIk5.js +1 -0
- package/dist/assets/dist-CK56b5MF.js +1 -0
- package/dist/assets/dist-COz0Y8UW.js +1 -0
- package/dist/assets/dist-CodYQwM5.js +1 -0
- package/dist/assets/dist-D4Od5Ds4.js +1 -0
- package/dist/assets/dist-DCqxOggh.js +6 -0
- package/dist/assets/dist-DLjDyeX7.js +1 -0
- package/dist/assets/dist-DOY95WD5.js +1 -0
- package/dist/assets/dist-Da-HT0I8.js +1 -0
- package/dist/assets/dist-Dc1gTRL9.js +1 -0
- package/dist/assets/dist-Dn1-guC7.js +1 -0
- package/dist/assets/dist-Dwy8b-Zd.js +1 -0
- package/dist/assets/dist-DxEuZTVa.js +1 -0
- package/dist/assets/dist-DxnNQmQo.js +7 -0
- package/dist/assets/dist-LFeDu06u.js +1 -0
- package/dist/assets/dist-ThkhuYAm.js +1 -0
- package/dist/assets/dist-jwcsaiRe.js +1 -0
- package/dist/assets/dist-oedZSmHi.js +1 -0
- package/dist/assets/dist-r-YlHvr1.js +1 -0
- package/dist/assets/dist-v1cdVFWt.js +1 -0
- package/dist/assets/dockerfile-AiWrCVkd.js +1 -0
- package/dist/assets/documentation-panel-CB8xalFX.js +1 -0
- package/dist/assets/download-DEJbA1IY.js +9 -0
- package/dist/assets/dropdown-menu-CR7cnzLX.js +1 -0
- package/dist/assets/dtd-DxzWHAng.js +1 -0
- package/dist/assets/dylan-Bj1NVjKa.js +1 -0
- package/dist/assets/ecl-Ch-B_r8E.js +1 -0
- package/dist/assets/edit-page-C7oPi1s6.js +9 -0
- package/dist/assets/eiffel-CICk6vIb.js +1 -0
- package/dist/assets/elm-C1O6zP9K.js +1 -0
- package/dist/assets/erDiagram-Q2GNP2WA-DlCxoG4y.js +60 -0
- package/dist/assets/erlang-BwL41NIP.js +1 -0
- package/dist/assets/error-banner-CLO6LFll.js +1 -0
- package/dist/assets/error-panel-DG6AtqLR.js +1 -0
- package/dist/assets/es-au8YY-8E.js +5 -0
- package/dist/assets/esm-BGRsx_Fp.js +1 -0
- package/dist/assets/esm-DLYpPRvw.js +1 -0
- package/dist/assets/external-link-BTNxSavU.js +1 -0
- package/dist/assets/factor-DgyyQiBQ.js +1 -0
- package/dist/assets/factor-DjzhghfA.js +1 -0
- package/dist/assets/field-CQGpbXj3.js +1 -0
- package/dist/assets/file-explorer-panel-BaQVOljq.js +26 -0
- package/dist/assets/file-icons-BjTIuMQg.js +1 -0
- package/dist/assets/file-name-input-CQVbWhL8.js +3 -0
- package/dist/assets/fileToBase64-BeYUTUzO.js +1 -0
- package/dist/assets/floating-outline-uy6dAsIe.js +1 -0
- package/dist/assets/flowDiagram-NV44I4VS-CXUevMnh.js +162 -0
- package/dist/assets/focus-0RBjdtZw.js +1 -0
- package/dist/assets/form-DNa2VnwU.js +2 -0
- package/dist/assets/formats-CJQ67TPE.js +1 -0
- package/dist/assets/formatting-XTtGIhGk.js +1 -0
- package/dist/assets/forth-D9Pm6H-4.js +1 -0
- package/dist/assets/fortran-Bkmw-ITl.js +1 -0
- package/dist/assets/fullscreen-eipL3i3Y.js +41 -0
- package/dist/assets/gallery-page-MrZHjySE.js +1 -0
- package/dist/assets/ganttDiagram-JELNMOA3-D8_HISpS.js +267 -0
- package/dist/assets/gas-hS11Npqh.js +1 -0
- package/dist/assets/gherkin-HvvvGZ2_.js +1 -0
- package/dist/assets/gitGraph-G5XIXVHT-DiktmQLx.js +1 -0
- package/dist/assets/gitGraphDiagram-V2S2FVAM-CN_m3FDa.js +65 -0
- package/dist/assets/glide-data-editor-4Wql6uq7.js +132 -0
- package/dist/assets/globals-DI5QlXvl.js +1 -0
- package/dist/assets/groovy-BymCZpo_.js +1 -0
- package/dist/assets/haskell-D1PB_nO2.js +1 -0
- package/dist/assets/haxe-BbvC3Y-d.js +1 -0
- package/dist/assets/home-page-BSuXANlw.js +4 -0
- package/dist/assets/hooks-B7pYZHjF.js +1 -0
- package/dist/assets/html-to-image-CIu-0LbU.js +2 -0
- package/dist/assets/idl-Do8pA7p2.js +1 -0
- package/dist/assets/index-8ta9aYoc.css +2 -0
- package/dist/assets/index-uDKD04Qe.js +42 -0
- package/dist/assets/info-VBDWY6EO-BH3NOLYF.js +1 -0
- package/dist/assets/infoDiagram-HS3SLOUP-C20LNJkf.js +2 -0
- package/dist/assets/input-CVE-gIjt.js +1 -0
- package/dist/assets/javascript-C0HGxgJT.js +1 -0
- package/dist/assets/journeyDiagram-XKPGCS4Q-CQWCJPyH.js +139 -0
- package/dist/assets/julia-B-Inh9cI.js +1 -0
- package/dist/assets/kanban-definition-3W4ZIXB7-CeH-UkBO.js +89 -0
- package/dist/assets/katex-Bci6q_jh.js +1 -0
- package/dist/assets/kiosk-mode-Ch75k65P.js +1 -0
- package/dist/assets/label-xHqFtfdz.js +1 -0
- package/dist/assets/layout-DFhJt7oJ.js +9 -0
- package/dist/assets/line-BkpbatV-.js +1 -0
- package/dist/assets/linear-BHpZPQfO.js +1 -0
- package/dist/assets/links-Av1BIe0O.js +1 -0
- package/dist/assets/livescript-C6P4ddCY.js +1 -0
- package/dist/assets/logs-panel-DR-1BC0S.js +1 -0
- package/dist/assets/loro_wasm_bg-Bg3nlaci.js +1 -0
- package/dist/assets/lua-DTvhQBWH.js +1 -0
- package/dist/assets/maps-n3GaPJwv.js +1 -0
- package/dist/assets/markdown-renderer-DGqYztXR.js +5 -0
- package/dist/assets/mathematica-wRwDN36m.js +1 -0
- package/dist/assets/mbox-BeQS3Xo8.js +1 -0
- package/dist/assets/menu-items-DcP01QzW.js +1 -0
- package/dist/assets/mermaid-4DMBBIKO-B-uFGNnk.js +1 -0
- package/dist/assets/mermaid-CZhfODkT.js +11 -0
- package/dist/assets/mermaid-parser.core-867JpRcd.js +4 -0
- package/dist/assets/mhchem-BKhnkPip.js +1 -0
- package/dist/assets/mindmap-definition-VGOIOE7T-BNg30ltj.js +68 -0
- package/dist/assets/mirc-D0yC5rBL.js +1 -0
- package/dist/assets/mllike-sRDGjaMs.js +1 -0
- package/dist/assets/modelica-CTTCwBwt.js +1 -0
- package/dist/assets/mscgen-D9NVglDL.js +1 -0
- package/dist/assets/multi-map-CUuNtzHt.js +1 -0
- package/dist/assets/mumps-eJkJqAKw.js +1 -0
- package/dist/assets/name-cell-input-DwfyLq31.js +1 -0
- package/dist/assets/nsis-B3ap5r7i.js +1 -0
- package/dist/assets/nsis-bDE8IZXy.js +1 -0
- package/dist/assets/ntriples-B2LCbtl9.js +1 -0
- package/dist/assets/number-overlay-editor-BOtWFe1E.js +9 -0
- package/dist/assets/numbers-mY4EY0yG.js +1 -0
- package/dist/assets/octave-DhLlnMzQ.js +1 -0
- package/dist/assets/ordinal-BKex0QZH.js +1 -0
- package/dist/assets/outline-panel-CWunrooQ.js +1 -0
- package/dist/assets/oz-CLovtD0B.js +1 -0
- package/dist/assets/package-B8oXOUM-.js +1 -0
- package/dist/assets/packages-panel-BdcXUFQJ.js +1 -0
- package/dist/assets/packet-DYOGHKS2-BZAo-1WV.js +1 -0
- package/dist/assets/panels-CJ1t18_z.js +1 -0
- package/dist/assets/pascal-BJwozZXL.js +1 -0
- package/dist/assets/pathUtils-vgBYIo5B.js +1 -0
- package/dist/assets/perl-B3rIP59U.js +1 -0
- package/dist/assets/pie-VRWISCQL-DSqXSW1A.js +1 -0
- package/dist/assets/pieDiagram-ADFJNKIX-CkDeU73E.js +30 -0
- package/dist/assets/pig-BQrpamWX.js +1 -0
- package/dist/assets/popover-Bz_0Vkyf.js +1 -0
- package/dist/assets/powershell-Crqgmja1.js +1 -0
- package/dist/assets/precisionRound-NX56vp6K.js +1 -0
- package/dist/assets/process-output-CS4QGJvL.js +1 -0
- package/dist/assets/properties-BMPI0iSd.js +1 -0
- package/dist/assets/protobuf-BMPWl2Em.js +1 -0
- package/dist/assets/pug-BvTKD58f.js +1 -0
- package/dist/assets/pug-CcL3ml0F.js +1 -0
- package/dist/assets/puppet-B1rTmaHH.js +1 -0
- package/dist/assets/python-DGMqnM8m.js +1 -0
- package/dist/assets/q-BNL1PH4D.js +1 -0
- package/dist/assets/quadrantDiagram-AYHSOK5B-DAx3aobn.js +7 -0
- package/dist/assets/r-DOvfvYEk.js +1 -0
- package/dist/assets/radar-ZZBFDIW7-BPcQHRAq.js +1 -0
- package/dist/assets/radio-group-BS2PIEzV.js +1 -0
- package/dist/assets/react-vega-4VQqM03t.js +188 -0
- package/dist/assets/react-vega-5tTMnjwa.js +1 -0
- package/dist/assets/readonly-python-code-C5JNX2fu.js +1 -0
- package/dist/assets/renderShortcut-D7FYCtYQ.js +1 -0
- package/dist/assets/request-registry-DKAymYdP.js +1 -0
- package/dist/assets/requirementDiagram-UZGBJVZJ-u-qLWr1t.js +64 -0
- package/dist/assets/reveal-component-PiSHIrbA.js +91 -0
- package/dist/assets/rpm-B7R9RTHE.js +1 -0
- package/dist/assets/ruby-BGJp-XLA.js +1 -0
- package/dist/assets/run-page-BovrPK0f.js +1 -0
- package/dist/assets/runs-Cn-NiTzH.js +1 -0
- package/dist/assets/sankeyDiagram-TZEHDZUN-VL3oPzoy.js +10 -0
- package/dist/assets/sas-CZmYq1Si.js +1 -0
- package/dist/assets/save-worker-D2iQi-UK.js +77 -0
- package/dist/assets/scheme-CdW_eMia.js +1 -0
- package/dist/assets/scratchpad-panel-CAWFveBD.js +1 -0
- package/dist/assets/secrets-panel-CEh4Wjfn.js +1 -0
- package/dist/assets/select-DZcFyKFQ.js +1 -0
- package/dist/assets/semaphore-X3ApuO41.js +1 -0
- package/dist/assets/sequenceDiagram-WL72ISMW-CyhmzEul.js +145 -0
- package/dist/assets/session-DGdfs0bJ.js +1 -0
- package/dist/assets/session-panel-BR9h5w96.js +1 -0
- package/dist/assets/share-oorMPghT.js +1 -0
- package/dist/assets/shell-oPdLMo8m.js +1 -0
- package/dist/assets/sieve-DEd8Bmn8.js +1 -0
- package/dist/assets/smalltalk-CnqQIV2W.js +1 -0
- package/dist/assets/snippets-panel-Y2etH9Qg.js +1 -0
- package/dist/assets/sparql-DKyVXlni.js +1 -0
- package/dist/assets/spec-D1ptWKg6.js +1 -0
- package/dist/assets/src-CvyFXpBy.js +1 -0
- package/dist/assets/state-1SbOXCLX.js +1 -0
- package/dist/assets/state-D-vYm99C.js +1 -0
- package/dist/assets/state-Fa6RzVTL.js +3 -0
- package/dist/assets/state-dx303w7J.js +1 -0
- package/dist/assets/stateDiagram-FKZM4ZOC-eVhhAfzW.js +1 -0
- package/dist/assets/stateDiagram-v2-4FDKWEC3-cGl1lSTF.js +1 -0
- package/dist/assets/step-vqKxn7TP.js +1 -0
- package/dist/assets/stex-C8c2RsN8.js +1 -0
- package/dist/assets/strings-wdPMRf6Z.js +2 -0
- package/dist/assets/stylus-Dk_-yu_w.js +1 -0
- package/dist/assets/swift-CjrgUbUd.js +1 -0
- package/dist/assets/swiper-component-DXTq6N70.js +1 -0
- package/dist/assets/switch-CTn-kJzM.js +1 -0
- package/dist/assets/tcl-DCmY87p6.js +1 -0
- package/dist/assets/terminal-DI2XRUUH.js +62 -0
- package/dist/assets/textarea-wgoQLrBS.js +1 -0
- package/dist/assets/textile-C_0nHQXl.js +1 -0
- package/dist/assets/time-Di7MbY-a.js +1 -0
- package/dist/assets/timeline-definition-IT6M3QCI-C01GhhW1.js +61 -0
- package/dist/assets/toml-DRTXXEvh.js +1 -0
- package/dist/assets/tooltip-DTV9tlSr.js +1 -0
- package/dist/assets/tracing-C9PZ0Pr1.js +1 -0
- package/dist/assets/tracing-panel-C20Rk6hU.js +2 -0
- package/dist/assets/tree-actions-D9i3o3Zk.js +1 -0
- package/dist/assets/treemap-GDKQZRPO-Bqwz-MRa.js +1 -0
- package/dist/assets/troff-Cc6RCKwc.js +1 -0
- package/dist/assets/ttcn-B_hjyyZd.js +1 -0
- package/dist/assets/ttcn-cfg-C9kHEAnH.js +1 -0
- package/dist/assets/turtle-BpKw2L0C.js +1 -0
- package/dist/assets/useBoolean-DP3412N2.js +1 -0
- package/dist/assets/useCellActionButton-D_-iAhme.js +1 -0
- package/dist/assets/useDateFormatter-d3yglQmW.js +1 -0
- package/dist/assets/useDeleteCell-41mvwiyA.js +1 -0
- package/dist/assets/useDependencyPanelTab-ELdrL73c.js +1 -0
- package/dist/assets/useEventListener-DvoEXWke.js +1 -0
- package/dist/assets/useHotkey-C04CW11R.js +1 -0
- package/dist/assets/useIframeCapabilities-DPVTppnD.js +1 -0
- package/dist/assets/useInstallPackage-hKfTes-m.js +1 -0
- package/dist/assets/useInterval-CSOniNAx.js +1 -0
- package/dist/assets/useNotebookActions-CgN-58GN.js +4 -0
- package/dist/assets/useNumberFormatter-CW4V-fpE.js +1 -0
- package/dist/assets/usePress-jH2RfcUG.js +7 -0
- package/dist/assets/useRunCells-CfHlqXY6.js +1 -0
- package/dist/assets/useSplitCell-gHtyz873.js +1 -0
- package/dist/assets/useTheme-Kwyx4PvL.js +1 -0
- package/dist/assets/utils-DQRuLEof.js +61 -0
- package/dist/assets/utils-Wvjk_Y4h.js +1 -0
- package/dist/assets/vb-DrexAmUA.js +1 -0
- package/dist/assets/vbscript-BxgSn4mU.js +1 -0
- package/dist/assets/vega-component-BPU1T-x7.js +1 -0
- package/dist/assets/vega-loader.browser-xq8miGHn.js +6 -0
- package/dist/assets/velocity-FfkCaLcE.js +1 -0
- package/dist/assets/verilog-CqmLdpPq.js +1 -0
- package/dist/assets/vhdl-Brd1jg5j.js +1 -0
- package/dist/assets/webidl-I7JvNTQ0.js +1 -0
- package/dist/assets/worker-B38WhSlZ.js +120 -0
- package/dist/assets/write-secret-modal-DjVzKit_.js +1 -0
- package/dist/assets/ws-Cb8IUKlU.js +22 -0
- package/dist/assets/xquery-DryU6qzU.js +1 -0
- package/dist/assets/xychartDiagram-PRI3JC2R-CohoDL7X.js +7 -0
- package/dist/assets/yacas-CxNmk6Uw.js +1 -0
- package/dist/assets/z80-CIIYHJij.js +1 -0
- package/dist/index.html +135 -132
- package/package.json +3 -3
- package/src/components/chat/chat-components.tsx +47 -0
- package/src/components/chat/chat-display.tsx +41 -7
- package/src/components/chat/chat-panel.tsx +37 -10
- package/src/components/chat/chat-utils.ts +42 -20
- package/src/components/chat/reasoning-accordion.tsx +14 -3
- package/src/components/chat/tool-call/shared.ts +13 -0
- package/src/components/chat/tool-call/tool-approval-card.tsx +62 -0
- package/src/components/chat/tool-call/tool-args.tsx +26 -0
- package/src/components/chat/tool-call/tool-call-view.tsx +99 -0
- package/src/components/chat/tool-call/tool-error-card.tsx +81 -0
- package/src/components/chat/tool-call/tool-history-row.tsx +153 -0
- package/src/components/chat/tool-call/tool-result.tsx +101 -0
- package/src/components/data-table/TableTopBar.tsx +5 -1
- package/src/components/data-table/__tests__/column-header.test.ts +3 -1
- package/src/components/data-table/__tests__/column-header.test.tsx +203 -0
- package/src/components/data-table/__tests__/filter-by-values-picker.test.tsx +112 -0
- package/src/components/data-table/__tests__/filter-pill-editor.test.tsx +175 -0
- package/src/components/data-table/__tests__/filters.test.ts +112 -36
- package/src/components/data-table/charts/components/form-fields.tsx +1 -0
- package/src/components/data-table/column-header.tsx +210 -157
- package/src/components/data-table/data-table.tsx +5 -0
- package/src/components/data-table/download-policy/atoms.ts +10 -0
- package/src/components/data-table/export-actions.tsx +31 -4
- package/src/components/data-table/filter-by-values-picker.tsx +70 -9
- package/src/components/data-table/filter-pill-editor.tsx +289 -144
- package/src/components/data-table/filter-pills.tsx +49 -8
- package/src/components/data-table/filters.ts +131 -36
- package/src/components/data-table/header-items.tsx +8 -1
- package/src/components/data-table/operator-labels.ts +25 -0
- package/src/components/data-table/regex-input.tsx +61 -0
- package/src/components/editor/actions/pair-with-agent-modal.tsx +140 -49
- package/src/components/editor/actions/useNotebookActions.tsx +3 -1
- package/src/components/editor/app-container.tsx +7 -1
- package/src/components/editor/chrome/panels/context-aware-panel/context-aware-panel.tsx +10 -2
- package/src/components/editor/chrome/wrapper/app-chrome.tsx +1 -0
- package/src/components/editor/chrome/wrapper/footer.tsx +4 -1
- package/src/components/editor/chrome/wrapper/panels.tsx +4 -1
- package/src/components/editor/chrome/wrapper/sidebar.tsx +4 -1
- package/src/components/editor/controls/Controls.tsx +11 -3
- package/src/components/editor/file-tree/requesting-tree.tsx +27 -25
- package/src/components/editor/file-tree/upload.tsx +23 -24
- package/src/components/editor/header/__tests__/status.test.tsx +108 -0
- package/src/components/editor/header/status.tsx +44 -10
- package/src/components/editor/navigation/__tests__/clipboard.test.ts +106 -0
- package/src/components/editor/navigation/__tests__/navigation.test.ts +70 -0
- package/src/components/editor/navigation/clipboard.ts +99 -25
- package/src/components/editor/navigation/navigation.ts +15 -1
- package/src/components/editor/notebook-cell.tsx +3 -0
- package/src/components/home/components.tsx +6 -0
- package/src/components/pages/run-page.tsx +4 -1
- package/src/components/ui/combobox.tsx +24 -5
- package/src/components/ui/number-field.tsx +2 -0
- package/src/core/ai/tools/__tests__/registry.test.ts +10 -12
- package/src/core/ai/tools/registry.ts +9 -5
- package/src/core/cells/__tests__/cells.test.ts +187 -0
- package/src/core/cells/__tests__/pending-cut-service.test.tsx +123 -0
- package/src/core/cells/cells.ts +102 -17
- package/src/core/cells/document-changes.ts +6 -1
- package/src/core/cells/pending-cut-service.ts +55 -0
- package/src/core/cells/utils.ts +11 -0
- package/src/core/codemirror/cells/extensions.ts +10 -0
- package/src/core/codemirror/go-to-definition/__tests__/commands.test.ts +152 -0
- package/src/core/codemirror/go-to-definition/__tests__/utils.test.ts +99 -0
- package/src/core/codemirror/go-to-definition/commands.ts +382 -22
- package/src/core/codemirror/go-to-definition/utils.ts +23 -5
- package/src/core/codemirror/markdown/__tests__/commands.test.ts +3 -3
- package/src/core/codemirror/markdown/commands.ts +1 -2
- package/src/core/edit-app.tsx +2 -1
- package/src/core/hotkeys/hotkeys.ts +5 -0
- package/src/core/islands/worker/worker.tsx +3 -2
- package/src/core/network/requests-network.ts +21 -3
- package/src/core/network/types.ts +12 -1
- package/src/core/run-app.tsx +2 -1
- package/src/core/wasm/__tests__/utils.test.ts +34 -0
- package/src/core/wasm/bridge.ts +14 -1
- package/src/core/wasm/utils.ts +14 -0
- package/src/core/wasm/worker/bootstrap.ts +3 -2
- package/src/core/wasm/worker/worker.ts +3 -2
- package/src/core/websocket/__tests__/useMarimoKernelConnection.hook.test.tsx +155 -0
- package/src/core/websocket/__tests__/useMarimoKernelConnection.test.ts +137 -0
- package/src/core/websocket/transports/basic.ts +2 -0
- package/src/core/websocket/transports/transport.ts +1 -0
- package/src/core/websocket/useMarimoKernelConnection.tsx +130 -55
- package/src/core/websocket/useWebSocket.tsx +5 -2
- package/src/css/app/Cell.css +10 -0
- package/src/plugins/core/__test__/sanitize.test.ts +30 -0
- package/src/plugins/impl/DataTablePlugin.tsx +12 -0
- package/src/plugins/impl/DropdownPlugin.tsx +12 -1
- package/src/plugins/impl/MultiselectPlugin.tsx +4 -0
- package/src/plugins/impl/SearchableSelect.tsx +11 -1
- package/src/plugins/impl/TabsPlugin.tsx +35 -7
- package/src/plugins/impl/__tests__/DropdownPlugin.test.tsx +56 -0
- package/src/plugins/impl/__tests__/TabsPlugin.test.tsx +154 -0
- package/src/plugins/impl/data-frames/DataFramePlugin.tsx +6 -0
- package/src/plugins/impl/data-frames/forms/__tests__/__snapshots__/form.test.tsx.snap +48 -36
- package/src/plugins/impl/data-frames/schema.ts +4 -1
- package/src/plugins/impl/vega/resolve-data.ts +8 -1
- package/src/utils/__tests__/id-tree.test.ts +71 -0
- package/src/utils/__tests__/semaphore.test.ts +218 -0
- package/src/utils/fileToBase64.ts +8 -7
- package/src/utils/id-tree.tsx +89 -0
- package/src/utils/semaphore.ts +88 -0
- package/dist/assets/CellStatus-CO_unhk0.js +0 -1
- package/dist/assets/ConnectedDataExplorerComponent-k8s9vETJ.js +0 -1
- package/dist/assets/DeferredRequestRegistry-CUzZ0y7K.js +0 -1
- package/dist/assets/ErrorBoundary-DzYV_VeY.js +0 -1
- package/dist/assets/ImperativeModal-D7lQ0Q7_.js +0 -1
- package/dist/assets/JsonOutput-BalWi8Qq.js +0 -49
- package/dist/assets/LazyAnyLanguageCodeMirror-BF3xpDgO.js +0 -2
- package/dist/assets/MarimoErrorOutput-1q6qtvxi.js +0 -7
- package/dist/assets/RSPContexts-CINae4Gg.js +0 -1
- package/dist/assets/RenderHTML-DkEHxB1r.js +0 -1
- package/dist/assets/RunButton-CJsJsGj-.js +0 -1
- package/dist/assets/__vite-browser-external-D0cSGXjR.js +0 -1
- package/dist/assets/__vite-browser-external-DQc2JVNq.js +0 -1
- package/dist/assets/add-cell-with-ai-D5JeNTNV.js +0 -92
- package/dist/assets/add-connection-dialog-Dh2rjP3o.js +0 -167
- package/dist/assets/agent-panel-CiOQnIC9.js +0 -287
- package/dist/assets/ai-model-dropdown-B-9yxYM4.js +0 -5
- package/dist/assets/alert-dialog-BGBdrcqJ.js +0 -11
- package/dist/assets/any-language-editor-C9DM60EN.js +0 -1
- package/dist/assets/apl-m-AMVo9Q.js +0 -1
- package/dist/assets/app-config-button-BOc_z0uX.js +0 -1
- package/dist/assets/arc-ONRhTAm2.js +0 -1
- package/dist/assets/architecture-7HQA4BMR-B8Ryu75w.js +0 -1
- package/dist/assets/architectureDiagram-VXUJARFQ-JNogHSZh.js +0 -36
- package/dist/assets/asciiarmor-BCgPMx-s.js +0 -1
- package/dist/assets/asn1-f2_lxsgc.js +0 -1
- package/dist/assets/blockDiagram-VD42YOAC-Dy-_c6-H.js +0 -122
- package/dist/assets/brainfuck-ZYebo2B9.js +0 -1
- package/dist/assets/button-D9nb17Rw.js +0 -1
- package/dist/assets/c4Diagram-YG6GDRKO-DHRUX7S-.js +0 -10
- package/dist/assets/cache-panel-B_zs00Q_.js +0 -1
- package/dist/assets/capabilities-C_FLIcjP.js +0 -1
- package/dist/assets/cell-editor-CtnFLzYa.js +0 -22
- package/dist/assets/cell-link-CC2MiW7a.js +0 -1
- package/dist/assets/cells-DAxz8J5R.js +0 -229
- package/dist/assets/channel-CWEEnT6g.js +0 -1
- package/dist/assets/chat-display-BiUNr6dU.js +0 -1
- package/dist/assets/chat-panel-BHsaaTzR.js +0 -3
- package/dist/assets/chat-ui-CTYG4pnL.js +0 -4
- package/dist/assets/chunk-4BX2VUAB-mPGRpph5.js +0 -1
- package/dist/assets/chunk-55IACEB6-DD051KDZ.js +0 -1
- package/dist/assets/chunk-5FQGJX7Z-e_arGD4o.js +0 -113
- package/dist/assets/chunk-ABZYJK2D-BInZW7OW.js +0 -80
- package/dist/assets/chunk-ATLVNIR6-_9Zaw7IP.js +0 -1
- package/dist/assets/chunk-B4BG7PRW-Bg43tpY1.js +0 -165
- package/dist/assets/chunk-CVBHYZKI-Brsoob-W.js +0 -1
- package/dist/assets/chunk-DI55MBZ5-DX01Gov5.js +0 -220
- package/dist/assets/chunk-EXTU4WIE-Cwo9-IiR.js +0 -1
- package/dist/assets/chunk-FMBD7UC4-Bt9icXTy.js +0 -15
- package/dist/assets/chunk-HN2XXSSU-BBxJMYrA.js +0 -1
- package/dist/assets/chunk-JA3XYJ7Z-C6cvGHie.js +0 -70
- package/dist/assets/chunk-JZLCHNYA-BM-e2D_8.js +0 -54
- package/dist/assets/chunk-MI3HLSF2-D6we5Ftb.js +0 -32
- package/dist/assets/chunk-N4CR4FBY-BREYOeLP.js +0 -2
- package/dist/assets/chunk-QN33PNHL-DwGffwWu.js +0 -1
- package/dist/assets/chunk-QXUST7PY-Q2jlSUop.js +0 -7
- package/dist/assets/chunk-QZHKN3VN-CeNfSWg4.js +0 -1
- package/dist/assets/chunk-S3R3BYOJ-DGKPoF4U.js +0 -2
- package/dist/assets/chunk-TZMSLE5B-Bfbjtd_W.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-CBbpzZPu.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-B0cWCuuo.js +0 -1
- package/dist/assets/clike-O99jWPIc.js +0 -1
- package/dist/assets/clojure-NE6UT6b9.js +0 -1
- package/dist/assets/cmake-7TIUAxVu.js +0 -1
- package/dist/assets/cobol-BdI6-uBH.js +0 -1
- package/dist/assets/code-block-37QAKDTI-CtU_48GW.js +0 -2
- package/dist/assets/coffeescript-CLx5m4GS.js +0 -1
- package/dist/assets/column-preview-C1-l9fq3.js +0 -1
- package/dist/assets/command-CBCkexpx.js +0 -1
- package/dist/assets/command-palette-0Bx056Jf.js +0 -1
- package/dist/assets/common-Qy2P7rii.js +0 -1
- package/dist/assets/commonlisp-8d9AwdCm.js +0 -1
- package/dist/assets/components-CZy03693.js +0 -1
- package/dist/assets/components-D9aJNSr-.js +0 -1
- package/dist/assets/config-CPqw1wUv.js +0 -1
- package/dist/assets/context-B3MsQb-b.js +0 -1
- package/dist/assets/copy-BCF-tANo.js +0 -1
- package/dist/assets/copy-icon-BYNydU7b.js +0 -1
- package/dist/assets/cose-bilkent-S5V4N54A-DWjOkKYE.js +0 -1
- package/dist/assets/createReducer-1ePoj7v6.js +0 -1
- package/dist/assets/crystal-Bn-cOTHZ.js +0 -1
- package/dist/assets/css-Ctj1grpW.js +0 -1
- package/dist/assets/cypher-DnT9gfY3.js +0 -1
- package/dist/assets/d-DCjbmG72.js +0 -1
- package/dist/assets/dagre-6UL2VRFP-DWD6iJku.js +0 -4
- package/dist/assets/data-grid-overlay-editor-DvZ8PZ2g.js +0 -1
- package/dist/assets/datasource-C1JWjcmE.js +0 -3
- package/dist/assets/dates-CAlnO9QB.js +0 -1
- package/dist/assets/dependency-graph-panel-DOHj-hNc.js +0 -5
- package/dist/assets/diagram-PSM6KHXK-B_Cc0ttH.js +0 -24
- package/dist/assets/diagram-QEK2KX5R-DhI0d2dH.js +0 -43
- package/dist/assets/diagram-S2PKOQOG-cc2LNQee.js +0 -24
- package/dist/assets/dialog-Dj0qTFnG.js +0 -1
- package/dist/assets/diff-DtVdhdPz.js +0 -1
- package/dist/assets/dist-A6v5-U3i.js +0 -1
- package/dist/assets/dist-B96NwXcp.js +0 -1
- package/dist/assets/dist-BVBYIAbx.js +0 -1
- package/dist/assets/dist-BkhaSQrg.js +0 -1
- package/dist/assets/dist-BoOh2kN5.js +0 -1
- package/dist/assets/dist-BvZKHNvJ.js +0 -1
- package/dist/assets/dist-C204e66A.js +0 -7
- package/dist/assets/dist-CEUFTp7U.js +0 -1
- package/dist/assets/dist-CGDn0y-i.js +0 -1
- package/dist/assets/dist-CbOE2rpr.js +0 -1
- package/dist/assets/dist-CmTrDl8w.js +0 -1
- package/dist/assets/dist-Cmcbyg5X.js +0 -1
- package/dist/assets/dist-Cn0rcGlX.js +0 -1
- package/dist/assets/dist-CwZoXpmG.js +0 -1
- package/dist/assets/dist-Cwcldbhl.js +0 -1
- package/dist/assets/dist-D4HwuQrf.js +0 -1
- package/dist/assets/dist-DBiqbYe-.js +0 -1
- package/dist/assets/dist-DMSWEOfO.js +0 -1
- package/dist/assets/dist-DQOq2Tf-.js +0 -6
- package/dist/assets/dist-Dn_fCOGr.js +0 -1
- package/dist/assets/dist-Dq4wQg6C.js +0 -1
- package/dist/assets/dist-Dw9UX7x1.js +0 -1
- package/dist/assets/dist-R7_s36kw.js +0 -1
- package/dist/assets/dist-RsQv8CvG.js +0 -1
- package/dist/assets/dist-_KQbcsP1.js +0 -1
- package/dist/assets/dist-_XomGjg6.js +0 -1
- package/dist/assets/dist-_qPWf6sD.js +0 -1
- package/dist/assets/dist-bvHsEZ9m.js +0 -1
- package/dist/assets/dist-e6kaTCKJ.js +0 -1
- package/dist/assets/dist-jLyLmWUE.js +0 -1
- package/dist/assets/dist-rzeRelEY.js +0 -1
- package/dist/assets/dockerfile-DERk1oNL.js +0 -1
- package/dist/assets/documentation-panel-BM7hNnyp.js +0 -1
- package/dist/assets/download-CXTuIv7r.js +0 -9
- package/dist/assets/dropdown-menu-D1A3cFC8.js +0 -1
- package/dist/assets/dtd-CHKGQo-k.js +0 -1
- package/dist/assets/dylan-DKXsKw9e.js +0 -1
- package/dist/assets/ecl-BJuToLkm.js +0 -1
- package/dist/assets/edit-page-Q7KKSAbL.js +0 -9
- package/dist/assets/eiffel-Bs0gRCeB.js +0 -1
- package/dist/assets/elm-BXUbhN4m.js +0 -1
- package/dist/assets/erDiagram-Q2GNP2WA-CPtVWZYn.js +0 -60
- package/dist/assets/erlang-B9b7RAaI.js +0 -1
- package/dist/assets/error-banner-C6aBa98y.js +0 -1
- package/dist/assets/error-panel-BN-anQD3.js +0 -1
- package/dist/assets/es-DaYh1PsD.js +0 -5
- package/dist/assets/esm-BRNC35J6.js +0 -1
- package/dist/assets/esm-BmrwxxCo.js +0 -1
- package/dist/assets/factor-BbYo7zsD.js +0 -1
- package/dist/assets/factor-C2NWkG3V.js +0 -1
- package/dist/assets/field-BrLPDxsA.js +0 -1
- package/dist/assets/file-explorer-panel-Y0zOwZxs.js +0 -26
- package/dist/assets/file-icons-5G4ZC70N.js +0 -1
- package/dist/assets/file-name-input-C70pv8AE.js +0 -3
- package/dist/assets/fileToBase64-Bzn96tYq.js +0 -1
- package/dist/assets/floating-outline-DHE0ukvC.js +0 -1
- package/dist/assets/flowDiagram-NV44I4VS-LeaIbfPS.js +0 -162
- package/dist/assets/focus-Crs_4nnQ.js +0 -1
- package/dist/assets/form-FbNsGFA8.js +0 -2
- package/dist/assets/formats-Dsc8AdCp.js +0 -1
- package/dist/assets/formatting-TmuwpwTs.js +0 -1
- package/dist/assets/forth-DAh7UX6C.js +0 -1
- package/dist/assets/fortran-Dy64-0b5.js +0 -1
- package/dist/assets/fullscreen-BDxedMYP.js +0 -41
- package/dist/assets/gallery-page-C4kMatxN.js +0 -1
- package/dist/assets/ganttDiagram-JELNMOA3-Bj-STLOZ.js +0 -267
- package/dist/assets/gas-DC-7PUFB.js +0 -1
- package/dist/assets/gherkin-ByiMyVl5.js +0 -1
- package/dist/assets/gitGraph-G5XIXVHT-CiMGDHpk.js +0 -1
- package/dist/assets/gitGraphDiagram-V2S2FVAM-B9HDL4DZ.js +0 -65
- package/dist/assets/glide-data-editor-DqqLCmqF.js +0 -132
- package/dist/assets/globals-DUw71mRV.js +0 -1
- package/dist/assets/groovy-DaM0RAwa.js +0 -1
- package/dist/assets/haskell-BwRtIbXW.js +0 -1
- package/dist/assets/haxe-DFGSCjmC.js +0 -1
- package/dist/assets/home-page-BM_BZnw7.js +0 -4
- package/dist/assets/hooks-BgTKQ8y5.js +0 -1
- package/dist/assets/html-to-image-v-_444d3.js +0 -2
- package/dist/assets/idl-Ip8qszMi.js +0 -1
- package/dist/assets/index-BdJiG5M1.js +0 -42
- package/dist/assets/index-DH5UUBE4.css +0 -2
- package/dist/assets/info-VBDWY6EO-yA01qfll.js +0 -1
- package/dist/assets/infoDiagram-HS3SLOUP-BDcw9LMK.js +0 -2
- package/dist/assets/input-BX98vgAu.js +0 -1
- package/dist/assets/javascript-DmUu6wxV.js +0 -1
- package/dist/assets/journeyDiagram-XKPGCS4Q-D29tj64e.js +0 -139
- package/dist/assets/julia-C8K-9kxt.js +0 -1
- package/dist/assets/kanban-definition-3W4ZIXB7-DStZ4tGj.js +0 -89
- package/dist/assets/katex-S9z-JFdU.js +0 -1
- package/dist/assets/kiosk-mode-DKb6W1WN.js +0 -1
- package/dist/assets/label-DTR8T0AE.js +0 -1
- package/dist/assets/layout-x1k2voam.js +0 -9
- package/dist/assets/line-j0cbFv7-.js +0 -1
- package/dist/assets/linear-Cof2JLCQ.js +0 -1
- package/dist/assets/links-iy4RlM-h.js +0 -1
- package/dist/assets/livescript-B3MfBDE2.js +0 -1
- package/dist/assets/logs-panel-BWCDk8Zy.js +0 -1
- package/dist/assets/loro_wasm_bg-DWJCS9pK.js +0 -1
- package/dist/assets/lua-B2YpVx0h.js +0 -1
- package/dist/assets/maps-C48Oksn0.js +0 -1
- package/dist/assets/markdown-renderer-CbuqHMPu.js +0 -5
- package/dist/assets/mathematica-D9tSC-hw.js +0 -1
- package/dist/assets/mbox-CjoMCyMH.js +0 -1
- package/dist/assets/menu-items-CwUpDHG7.js +0 -1
- package/dist/assets/mermaid-4DMBBIKO-gHC2PS1m.js +0 -1
- package/dist/assets/mermaid-D8YDyOib.js +0 -11
- package/dist/assets/mermaid-parser.core-BQULBKwL.js +0 -4
- package/dist/assets/mhchem-BNLsaqjJ.js +0 -1
- package/dist/assets/mindmap-definition-VGOIOE7T-Cy9nt356.js +0 -68
- package/dist/assets/mirc-DvJdMBLZ.js +0 -1
- package/dist/assets/mllike-5ykSeapn.js +0 -1
- package/dist/assets/modelica-laYOX8Zo.js +0 -1
- package/dist/assets/mscgen-z_sYErek.js +0 -1
- package/dist/assets/multi-map-rafH3cg3.js +0 -1
- package/dist/assets/mumps-BwcCoPkA.js +0 -1
- package/dist/assets/name-cell-input-DoYtA-nF.js +0 -1
- package/dist/assets/nsis-CpSPdWjV.js +0 -1
- package/dist/assets/nsis-Cr8jf68z.js +0 -1
- package/dist/assets/ntriples-D2ki9JZ6.js +0 -1
- package/dist/assets/number-overlay-editor-8-GuvfJX.js +0 -9
- package/dist/assets/numbers-CAW8yjzj.js +0 -1
- package/dist/assets/octave-D817mWs9.js +0 -1
- package/dist/assets/ordinal-K0JYqmCT.js +0 -1
- package/dist/assets/outline-panel-C5bTOsj4.js +0 -1
- package/dist/assets/oz-3GS03IG4.js +0 -1
- package/dist/assets/packages-panel-CHVjLKJK.js +0 -1
- package/dist/assets/packet-DYOGHKS2-D9yUvksZ.js +0 -1
- package/dist/assets/panels-D0bfHEhi.js +0 -1
- package/dist/assets/pascal-C08wXab2.js +0 -1
- package/dist/assets/pathUtils-DOhgNpTR.js +0 -1
- package/dist/assets/perl-Ija-iETI.js +0 -1
- package/dist/assets/pie-VRWISCQL-Cz1iTD2y.js +0 -1
- package/dist/assets/pieDiagram-ADFJNKIX-CqhovvcK.js +0 -30
- package/dist/assets/pig-BlBD3yVJ.js +0 -1
- package/dist/assets/popover-UExmgBsf.js +0 -1
- package/dist/assets/powershell-CjOQ_PjD.js +0 -1
- package/dist/assets/precisionRound-C3fmBb6j.js +0 -1
- package/dist/assets/process-output-CKd9tbdL.js +0 -1
- package/dist/assets/properties-5yVGVBrw.js +0 -1
- package/dist/assets/protobuf-hlm5v2rk.js +0 -1
- package/dist/assets/pug-CKg66ZCy.js +0 -1
- package/dist/assets/pug-DifRb20b.js +0 -1
- package/dist/assets/puppet-BpFPuj45.js +0 -1
- package/dist/assets/python-B_AEFhuO.js +0 -1
- package/dist/assets/q-BzDxfEQq.js +0 -1
- package/dist/assets/quadrantDiagram-AYHSOK5B-BNyiC3hL.js +0 -7
- package/dist/assets/r-BJ9VYyYa.js +0 -1
- package/dist/assets/radar-ZZBFDIW7-y2-V58qq.js +0 -1
- package/dist/assets/radio-group-BI3wOhfc.js +0 -1
- package/dist/assets/react-vega-C1LnPwEN.js +0 -1
- package/dist/assets/react-vega-SibldZnp.js +0 -188
- package/dist/assets/readonly-python-code-CaKJ84fy.js +0 -1
- package/dist/assets/renderShortcut-Bfk4NjRL.js +0 -1
- package/dist/assets/request-registry-BwzANGxx.js +0 -1
- package/dist/assets/requirementDiagram-UZGBJVZJ-U4CoEx7e.js +0 -64
- package/dist/assets/reveal-component-CZjszfUY.js +0 -91
- package/dist/assets/rpm-Ez4HwV9T.js +0 -1
- package/dist/assets/ruby-BcHOM0EI.js +0 -1
- package/dist/assets/run-page-tVelC3Sm.js +0 -1
- package/dist/assets/runs-5odJFrfi.js +0 -1
- package/dist/assets/sankeyDiagram-TZEHDZUN-BXgCc5j4.js +0 -10
- package/dist/assets/sas-Qmf5gHIU.js +0 -1
- package/dist/assets/save-worker-CvbUHJh7.js +0 -77
- package/dist/assets/scheme-Ctib9V77.js +0 -1
- package/dist/assets/scratchpad-panel-DB8GmXPG.js +0 -1
- package/dist/assets/secrets-panel-DaR50P_m.js +0 -1
- package/dist/assets/select-5i7URBEn.js +0 -1
- package/dist/assets/sequenceDiagram-WL72ISMW-CB8apKmu.js +0 -145
- package/dist/assets/session-VtovaFBS.js +0 -1
- package/dist/assets/session-panel-DBKRhLd_.js +0 -1
- package/dist/assets/share-DIVpiHPe.js +0 -1
- package/dist/assets/shell-BtgVCAhn.js +0 -1
- package/dist/assets/sieve-CMsTkuH0.js +0 -1
- package/dist/assets/smalltalk-BKSCdMTS.js +0 -1
- package/dist/assets/snippets-panel-BvuRa1mc.js +0 -1
- package/dist/assets/sparql-TK6HapG4.js +0 -1
- package/dist/assets/spec-Cq8FVoTf.js +0 -1
- package/dist/assets/src-nKy6a3tt.js +0 -1
- package/dist/assets/state-B34hXjp9.js +0 -1
- package/dist/assets/state-CjlRDG08.js +0 -3
- package/dist/assets/state-DgRSUIT8.js +0 -1
- package/dist/assets/state-Z-H4o98V.js +0 -1
- package/dist/assets/stateDiagram-FKZM4ZOC-3YqeHe0_.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-Dfvjjqh4.js +0 -1
- package/dist/assets/step-BE8c2ivx.js +0 -1
- package/dist/assets/stex-D6sqtveI.js +0 -1
- package/dist/assets/strings-md4mFbOQ.js +0 -2
- package/dist/assets/stylus-C8FKVvgQ.js +0 -1
- package/dist/assets/swift-D7BZKS_y.js +0 -1
- package/dist/assets/swiper-component-B-P7FNP9.js +0 -1
- package/dist/assets/switch-BvybnC9P.js +0 -1
- package/dist/assets/tcl-DFrjfFmM.js +0 -1
- package/dist/assets/terminal-zehb39z5.js +0 -62
- package/dist/assets/textarea-GPxmW3rS.js +0 -1
- package/dist/assets/textile-Bj913nF7.js +0 -1
- package/dist/assets/time-C12vLLcl.js +0 -1
- package/dist/assets/timeline-definition-IT6M3QCI-DZQqxPSn.js +0 -61
- package/dist/assets/toml-B6qgmS36.js +0 -1
- package/dist/assets/tooltip-Gcwqb_SK.js +0 -1
- package/dist/assets/tracing-CVQn241p.js +0 -1
- package/dist/assets/tracing-panel-TnogJs00.js +0 -2
- package/dist/assets/tree-actions-Ci3CV3hN.js +0 -1
- package/dist/assets/treemap-GDKQZRPO-C139r55s.js +0 -1
- package/dist/assets/troff-CysSpyUG.js +0 -1
- package/dist/assets/ttcn-DG1k5i1B.js +0 -1
- package/dist/assets/ttcn-cfg-p1jV7x_I.js +0 -1
- package/dist/assets/turtle-DSkxUncB.js +0 -1
- package/dist/assets/useBoolean-xXcxYCaI.js +0 -1
- package/dist/assets/useCellActionButton-C8PCItmw.js +0 -1
- package/dist/assets/useDateFormatter-CgFoBhVq.js +0 -1
- package/dist/assets/useDeleteCell-DMZGFMOB.js +0 -1
- package/dist/assets/useDependencyPanelTab-Jnl7B-vS.js +0 -1
- package/dist/assets/useEventListener-BR0C1MaI.js +0 -1
- package/dist/assets/useHotkey-DccKPSPx.js +0 -1
- package/dist/assets/useIframeCapabilities-BvE4n6hj.js +0 -1
- package/dist/assets/useInstallPackage-D0NLybAx.js +0 -1
- package/dist/assets/useInterval-CG264TRB.js +0 -1
- package/dist/assets/useNotebookActions-Bfp8EPmq.js +0 -1
- package/dist/assets/useNumberFormatter-DtiQW2H_.js +0 -1
- package/dist/assets/usePress-CfcdTqJM.js +0 -7
- package/dist/assets/useRunCells-BMgfN_OV.js +0 -1
- package/dist/assets/useSplitCell-B5YK7yVe.js +0 -1
- package/dist/assets/useTheme-DFXuDFj9.js +0 -1
- package/dist/assets/utils-BrXijSdZ.js +0 -1
- package/dist/assets/utils-CGtUbqcR.js +0 -61
- package/dist/assets/vb-BIvYC4My.js +0 -1
- package/dist/assets/vbscript-Coxg2EVQ.js +0 -1
- package/dist/assets/vega-component-DOyQwlmD.js +0 -1
- package/dist/assets/vega-loader.browser-BegSZk0G.js +0 -6
- package/dist/assets/velocity-Cy90c7hC.js +0 -1
- package/dist/assets/verilog-CTtn3HA0.js +0 -1
- package/dist/assets/vhdl-D3r3mwOF.js +0 -1
- package/dist/assets/webidl-CHPMhkWI.js +0 -1
- package/dist/assets/worker-CF8V9c2V.js +0 -120
- package/dist/assets/write-secret-modal-BFLUPDlo.js +0 -1
- package/dist/assets/ws-CtTwmdal.js +0 -22
- package/dist/assets/xquery-d-YlNlXH.js +0 -1
- package/dist/assets/xychartDiagram-PRI3JC2R-CmNNcgCM.js +0 -7
- package/dist/assets/yacas-BfZ0gs5_.js +0 -1
- package/dist/assets/z80-cYJ4lyZA.js +0 -1
- package/src/components/chat/tool-call-accordion.tsx +0 -247
- /package/dist/assets/{Deferred-DMWKlZOV.js → Deferred-DWBqOhWa.js} +0 -0
- /package/dist/assets/{ImageComparisonComponent-2VO41-VE.js → ImageComparisonComponent-nhywlX8O.js} +0 -0
- /package/dist/assets/{Inputs-BdyX096j.js → Inputs-COvM_tLq.js} +0 -0
- /package/dist/assets/{Plot-IawheWsD.js → Plot-BDBiXfv_.js} +0 -0
- /package/dist/assets/{SSRProvider-kyGHZp36.js → SSRProvider-BIDQNg9Q.js} +0 -0
- /package/dist/assets/{alert-DvqcBMUv.js → alert-DrHguQlr.js} +0 -0
- /package/dist/assets/{apl-T0uH_RjM.js → apl-iXnrDoYq.js} +0 -0
- /package/dist/assets/{array-BCwZq3ts.js → array-DdrmtJsl.js} +0 -0
- /package/dist/assets/{asciiarmor-D3ol7c2G.js → asciiarmor-CK-aFa78.js} +0 -0
- /package/dist/assets/{asn1-DA-fXXsk.js → asn1-DWJdxrMP.js} +0 -0
- /package/dist/assets/{asterisk-Cy-53Fu-.js → asterisk-DmqsRS7E.js} +0 -0
- /package/dist/assets/{azure-ZuB1zQ8Q.js → azure-DBVzcmvx.js} +0 -0
- /package/dist/assets/{badge-C7-HR1IO.js → badge-DOX1Xxa9.js} +0 -0
- /package/dist/assets/{blob-D-eV0cU3.js → blob-3_FN0u9S.js} +0 -0
- /package/dist/assets/{brainfuck-exn1QR7H.js → brainfuck-0bMZHpH_.js} +0 -0
- /package/dist/assets/{bundle.esm-BIoPrMH_.js → bundle.esm-DjhGJy4I.js} +0 -0
- /package/dist/assets/{card-BsOjr9wU.js → card-BFWJLptH.js} +0 -0
- /package/dist/assets/{chunk-4F5CHEZ2-BBsStyPF.js → chunk-4F5CHEZ2-BqEXxh1Z.js} +0 -0
- /package/dist/assets/{chunk-B2363JML-CPCjJ6tH.js → chunk-B2363JML-BMBEdPpn.js} +0 -0
- /package/dist/assets/{chunk-DR5Q36YT-DpSMafKt.js → chunk-DR5Q36YT-DKTVLAfY.js} +0 -0
- /package/dist/assets/{chunk-FRFDVMJY-D6StbPqE.js → chunk-FRFDVMJY-CfFB3K1V.js} +0 -0
- /package/dist/assets/{chunk-PL6DKKU2-x3Qoia3Y.js → chunk-PL6DKKU2-B33xUOa0.js} +0 -0
- /package/dist/assets/{chunk-SJTYNZTY-BNaCydHS.js → chunk-SJTYNZTY-8WPtvsjT.js} +0 -0
- /package/dist/assets/{chunk-TQ3KTPDO-DfYTN8Ct.js → chunk-TQ3KTPDO-D2AjvUV_.js} +0 -0
- /package/dist/assets/{chunk-UMXZTB3W-DsE6dCbX.js → chunk-UMXZTB3W-BCNtLoey.js} +0 -0
- /package/dist/assets/{clear-button-DBrTU3uL.js → clear-button-pxtY_gQU.js} +0 -0
- /package/dist/assets/{click-outside-container-BXzp0MYr.js → click-outside-container-C9uindjY.js} +0 -0
- /package/dist/assets/{clike-BK27e5qn.js → clike-5SQqmvx2.js} +0 -0
- /package/dist/assets/{clojure-Df1U5nhC.js → clojure-B0kIwyv8.js} +0 -0
- /package/dist/assets/{cmake-DrCf0yvp.js → cmake-CLXeINvH.js} +0 -0
- /package/dist/assets/{cobol-BWxHqof4.js → cobol-C9SsG--s.js} +0 -0
- /package/dist/assets/{coffeescript-nKvg8y_U.js → coffeescript-UIQG6RnU.js} +0 -0
- /package/dist/assets/{colors-CI3VyX7X.js → colors-CDxbWdyG.js} +0 -0
- /package/dist/assets/{common-keywords-CU-S2Vqm.js → common-keywords-Bf68gXm2.js} +0 -0
- /package/dist/assets/{commonlisp-Dm562cBV.js → commonlisp-BBPumpJY.js} +0 -0
- /package/dist/assets/{crystal-CrCmK2Cb.js → crystal-CGN1wsuY.js} +0 -0
- /package/dist/assets/{css-jpfGFPDE.js → css-aQ-Krb7T.js} +0 -0
- /package/dist/assets/{cypher-RQ5M28al.js → cypher-DEE4_Yec.js} +0 -0
- /package/dist/assets/{cytoscape.esm-BbAjzIsa.js → cytoscape.esm-DuXIsNbY.js} +0 -0
- /package/dist/assets/{d-CNQ_nPqU.js → d-CgJ8N-gL.js} +0 -0
- /package/dist/assets/{defaultLocale-YteS-k_t.js → defaultLocale-DPBdGRrH.js} +0 -0
- /package/dist/assets/{defaultLocale-B6z1Qyqt.js → defaultLocale-Lfi0pexn.js} +0 -0
- /package/dist/assets/{diff-DOODcY7A.js → diff-B8e18dKs.js} +0 -0
- /package/dist/assets/{dist-VjDnmGCZ.js → dist-BU26XwgJ.js} +0 -0
- /package/dist/assets/{dist-9g-_Ln9y.js → dist-Bm0v4xuz.js} +0 -0
- /package/dist/assets/{dist-E6ttb8td.js → dist-COs9gIu5.js} +0 -0
- /package/dist/assets/{dist-DBBYmRY4.js → dist-CTvZbFwy.js} +0 -0
- /package/dist/assets/{dist-DggusHaA.js → dist-CyKkoCYJ.js} +0 -0
- /package/dist/assets/{dist-DS5RCKZO.js → dist-DGhKKgfN.js} +0 -0
- /package/dist/assets/{dist-DCqWIRLq.js → dist-DP9Si-4r.js} +0 -0
- /package/dist/assets/{dist-DxxvVPQH.js → dist-DQ3_8QJg.js} +0 -0
- /package/dist/assets/{dist-D6wwIjcW.js → dist-DjGavUj4.js} +0 -0
- /package/dist/assets/{dist-B324sPca.js → dist-DkA__6UI.js} +0 -0
- /package/dist/assets/{dist-CsEqrZxx.js → dist-EbJ2Bafg.js} +0 -0
- /package/dist/assets/{dist-HW7R98td.js → dist-FS1xQUNb.js} +0 -0
- /package/dist/assets/{dist-ooLAQ9IK.js → dist-Scx61XLd.js} +0 -0
- /package/dist/assets/{dtd-CRYKjxdR.js → dtd-DtwMcoo9.js} +0 -0
- /package/dist/assets/{duckdb-keywords-CR9f4wu5.js → duckdb-keywords-BWKLsQSd.js} +0 -0
- /package/dist/assets/{dylan-Bg0sO2y3.js → dylan-Be6i1K-V.js} +0 -0
- /package/dist/assets/{ebnf-BdwTqLUx.js → ebnf-dezZofVm.js} +0 -0
- /package/dist/assets/{ecl-DaBeV7OZ.js → ecl-D5tlhe8s.js} +0 -0
- /package/dist/assets/{eiffel-BtJc6fqQ.js → eiffel-8SQWO4xP.js} +0 -0
- /package/dist/assets/{elm-D9Rly7Qq.js → elm-CtGe_7Jw.js} +0 -0
- /package/dist/assets/{emotion-is-prop-valid.esm-DD4AwVTU.js → emotion-is-prop-valid.esm-Dangy3Bv.js} +0 -0
- /package/dist/assets/{empty-state-CsVQSqKA.js → empty-state-CcobJSnG.js} +0 -0
- /package/dist/assets/{en-US-D_il4jD7.js → en-US-C7vnqfgk.js} +0 -0
- /package/dist/assets/{erlang-FZMRuv-7.js → erlang-CNwX3Z_M.js} +0 -0
- /package/dist/assets/{errors-TZBmrJmc.js → errors-iwK4b4VF.js} +0 -0
- /package/dist/assets/{esm-D_nSG7uo.js → esm-CX-gNDKf.js} +0 -0
- /package/dist/assets/{events-BRAWQiYK.js → events-CBm-hwqS.js} +0 -0
- /package/dist/assets/{extends-B2LJnKU3.js → extends-Dqvpuc10.js} +0 -0
- /package/dist/assets/{eye-off-n1Li95bE.js → eye-off-BT-KOYV5.js} +0 -0
- /package/dist/assets/{fcl-BFWIADMy.js → fcl-D566gDVV.js} +0 -0
- /package/dist/assets/{file-BrdxGLRX.js → file-HTLbeC2b.js} +0 -0
- /package/dist/assets/{file-headphone-BrQspHac.js → file-headphone-B3fuktN0.js} +0 -0
- /package/dist/assets/{forth-C6jh4lHA.js → forth-CaVwPSxM.js} +0 -0
- /package/dist/assets/{fortran-DuxTe5qi.js → fortran-B28t9xoj.js} +0 -0
- /package/dist/assets/{gas-D7RWbiQ0.js → gas-BSiJHAcz.js} +0 -0
- /package/dist/assets/{gherkin-DV4l4nlf.js → gherkin-1QurHPOF.js} +0 -0
- /package/dist/assets/{github-BKS_2Qwn.js → github-raQvpeuZ.js} +0 -0
- /package/dist/assets/{groovy-Ij7mXzwd.js → groovy-DFOLwJLv.js} +0 -0
- /package/dist/assets/{haskell-BT_ZNgUJ.js → haskell-CUN2jxPH.js} +0 -0
- /package/dist/assets/{haxe-DYYwGmM8.js → haxe-BYzKptPQ.js} +0 -0
- /package/dist/assets/{house-mGK3v0Mm.js → house-D2ldnAB9.js} +0 -0
- /package/dist/assets/{http-CgzOAOXj.js → http-Ms617AZI.js} +0 -0
- /package/dist/assets/{icons-D9TuFTJG.js → icons-Ol38nIbL.js} +0 -0
- /package/dist/assets/{idl-CjBvIccU.js → idl-cdmrQY5J.js} +0 -0
- /package/dist/assets/{image-DQHXdEQn.js → image-BIibSXT6.js} +0 -0
- /package/dist/assets/{init-DE_uL9Ns.js → init-DiAYA_Co.js} +0 -0
- /package/dist/assets/{isValid-C8T5uJYI.js → isValid-DdlR4-BY.js} +0 -0
- /package/dist/assets/{javascript-DQz7szA1.js → javascript-l5LYdpfx.js} +0 -0
- /package/dist/assets/{julia-U0NSUEwm.js → julia-DxiTohY8.js} +0 -0
- /package/dist/assets/{katex-M9SX-Gs-.js → katex-CgXtp7UB.js} +0 -0
- /package/dist/assets/{kbd-B3Breaz2.js → kbd-BJB2rf7K.js} +0 -0
- /package/dist/assets/{link-CfEtM3Rl.js → link-CoJxTwWE.js} +0 -0
- /package/dist/assets/{links-Dpap8NI2.js → links-B8WzCnbo.js} +0 -0
- /package/dist/assets/{livescript-D7jeebX7.js → livescript-BZkzGFkJ.js} +0 -0
- /package/dist/assets/{loro_wasm_bg-Bu4Ofw1K.js → loro_wasm_bg-C5TJxMR5.js} +0 -0
- /package/dist/assets/{lua-CT4vrRvN.js → lua-rVV1vLen.js} +0 -0
- /package/dist/assets/{marimo-icons-BSB-Z_W3.js → marimo-icons-CUuBQ0ae.js} +0 -0
- /package/dist/assets/{math-Bf0RgaKx.js → math-CS811RUM.js} +0 -0
- /package/dist/assets/{mathematica-DmzlinOc.js → mathematica-DktJ0aJB.js} +0 -0
- /package/dist/assets/{mbox-DYDL20A1.js → mbox-Ch6IVA7h.js} +0 -0
- /package/dist/assets/{message-circle-CWm2KnSx.js → message-circle-1YLdnr8A.js} +0 -0
- /package/dist/assets/{micromark-factory-space-DzSMahmM.js → micromark-factory-space-P--XWZhg.js} +0 -0
- /package/dist/assets/{mirc-6LiBC6Dw.js → mirc-CdWws4At.js} +0 -0
- /package/dist/assets/{mllike-orSu1SHG.js → mllike-CB0tp4Bz.js} +0 -0
- /package/dist/assets/{modelica-BsibU-7c.js → modelica-DQGg_xsi.js} +0 -0
- /package/dist/assets/{mscgen-vX4NsSXf.js → mscgen-vDSxnAXy.js} +0 -0
- /package/dist/assets/{multi-icon-DQxqgfM2.js → multi-icon-NVkxesVZ.js} +0 -0
- /package/dist/assets/{mumps-DIZYQE11.js → mumps-BzlVzIzl.js} +0 -0
- /package/dist/assets/{nginx-CFpObAqg.js → nginx-CNtYBWy9.js} +0 -0
- /package/dist/assets/{node-sql-parser-B8vXamqL.js → node-sql-parser-BvUFblwL.js} +0 -0
- /package/dist/assets/{ntriples-CwlUIE0o.js → ntriples-BndMB6TK.js} +0 -0
- /package/dist/assets/{objectWithoutPropertiesLoose-DaPAPabU.js → objectWithoutPropertiesLoose-DoKw85w0.js} +0 -0
- /package/dist/assets/{octave-BWtN_wao.js → octave-DhnkL0CH.js} +0 -0
- /package/dist/assets/{oz-CJMVKlqL.js → oz-DbZmNL9y.js} +0 -0
- /package/dist/assets/{panel-context-B3J07LRC.js → panel-context-DQWeG2KK.js} +0 -0
- /package/dist/assets/{pascal-C9rPtth-.js → pascal-DhE1sEjD.js} +0 -0
- /package/dist/assets/{path-LDcaQ64B.js → path-D1tAOolS.js} +0 -0
- /package/dist/assets/{paths-BXWH6vv4.js → paths-SFhaqGlE.js} +0 -0
- /package/dist/assets/{perl-CF7pKLbl.js → perl-BOZHK4Y3.js} +0 -0
- /package/dist/assets/{pig-Bu0nn8JT.js → pig-eswHTOE9.js} +0 -0
- /package/dist/assets/{play-C7DcCsoO.js → play-5vQl-hy9.js} +0 -0
- /package/dist/assets/{plus-BgB18UzY.js → plus-CxkHs8QM.js} +0 -0
- /package/dist/assets/{powershell-Bzwpi8yQ.js → powershell-pm9G_Qg5.js} +0 -0
- /package/dist/assets/{preload-helper-DItdS47A.js → preload-helper-DdZsAcJe.js} +0 -0
- /package/dist/assets/{prop-types-BiQYf0aU.js → prop-types-DVDiRdwc.js} +0 -0
- /package/dist/assets/{properties-Cfh_Lj0j.js → properties-7VoeFdHR.js} +0 -0
- /package/dist/assets/{protobuf-Vz3fs9Hb.js → protobuf-BAsuCsmK.js} +0 -0
- /package/dist/assets/{puppet-JwSHf4DX.js → puppet-DUYPK8CV.js} +0 -0
- /package/dist/assets/{purify.es-DBmVz-Wl.js → purify.es-DvRMX74T.js} +0 -0
- /package/dist/assets/{python-BRHQZrcc.js → python-UQl3_T6H.js} +0 -0
- /package/dist/assets/{q-DWFQ7YI_.js → q-CnvA_jxT.js} +0 -0
- /package/dist/assets/{r-DHkTNFL2.js → r-fM1OLzJB.js} +0 -0
- /package/dist/assets/{range-7fnH_zLA.js → range-Dk7lXDev.js} +0 -0
- /package/dist/assets/{react-icons.esm-D9xfKaPZ.js → react-icons.esm--O4lBTlZ.js} +0 -0
- /package/dist/assets/{react-resizable-panels.browser.esm-BUNcfKXO.js → react-resizable-panels.browser.esm-CgWOEYeG.js} +0 -0
- /package/dist/assets/{refresh-ccw-C-n2VFP5.js → refresh-ccw-DLc784Sj.js} +0 -0
- /package/dist/assets/{refresh-cw-DHwG4Mac.js → refresh-cw-a_9k9BK7.js} +0 -0
- /package/dist/assets/{requests-BqcqF00P.js → requests-DqJEWJ-Q.js} +0 -0
- /package/dist/assets/{rotate-ccw-CNsAb2VZ.js → rotate-ccw-DoQtGgvU.js} +0 -0
- /package/dist/assets/{rpm-zbaZz_dk.js → rpm-D62D_dq6.js} +0 -0
- /package/dist/assets/{ruby-COvM5Bj_.js → ruby-DemvBD0m.js} +0 -0
- /package/dist/assets/{sas-Be8P6y_s.js → sas-CZjYQi4h.js} +0 -0
- /package/dist/assets/{save-Clg5dMoP.js → save-DZ5aail6.js} +0 -0
- /package/dist/assets/{scheme-B9Zors0b.js → scheme-nPNaP0Qp.js} +0 -0
- /package/dist/assets/{settings-DfFe0dWD.js → settings-SnYErNWQ.js} +0 -0
- /package/dist/assets/{shell-CaaQwZ-W.js → shell-BE2ANxN1.js} +0 -0
- /package/dist/assets/{sieve-CdflT_3W.js → sieve-DXFUN4C7.js} +0 -0
- /package/dist/assets/{simple-mode-BJAT_N3M.js → simple-mode-CZ1ts7NY.js} +0 -0
- /package/dist/assets/{smalltalk-CRO88y3z.js → smalltalk-DwXXlSAY.js} +0 -0
- /package/dist/assets/{solr-BkyoAXqg.js → solr-DndbfGC6.js} +0 -0
- /package/dist/assets/{sparkles-CZ5WmLPA.js → sparkles-CC9Bko6a.js} +0 -0
- /package/dist/assets/{sparql-DEker8ZS.js → sparql-CgejAdiJ.js} +0 -0
- /package/dist/assets/{spinner-Bhir8k53.js → spinner-UuZAUjoP.js} +0 -0
- /package/dist/assets/{spreadsheet-7FZkhkVo.js → spreadsheet-DHoeoJHd.js} +0 -0
- /package/dist/assets/{sql-BNnXxKXA.js → sql-DzyjqiRG.js} +0 -0
- /package/dist/assets/{square-function-D1dlJvD8.js → square-function-blYaQso8.js} +0 -0
- /package/dist/assets/{square-DMaNzePN.js → square-rACnnz-q.js} +0 -0
- /package/dist/assets/{src-CmKhyEBC.js → src-D57-7XBB.js} +0 -0
- /package/dist/assets/{stex-CtmkcLz7.js → stex-lcoTi-7o.js} +0 -0
- /package/dist/assets/{stylus-DAJwnVOa.js → stylus-CslB9TS3.js} +0 -0
- /package/dist/assets/{swift-D5F-FU3-.js → swift-5t7SQPo8.js} +0 -0
- /package/dist/assets/{table-DPyRV1LT.js → table-DUSsaCYD.js} +0 -0
- /package/dist/assets/{tcl-DirNbhYm.js → tcl-Ddpe8YBc.js} +0 -0
- /package/dist/assets/{textile-DhHo4rKl.js → textile-D_Db33mq.js} +0 -0
- /package/dist/assets/{tiddlywiki-DE5lnTl3.js → tiddlywiki-Laz7iVQn.js} +0 -0
- /package/dist/assets/{tiki-Dt9oCY2i.js → tiki-Dd2_LAYu.js} +0 -0
- /package/dist/assets/{timer-CIInKAPS.js → timer-B6DpdVnC.js} +0 -0
- /package/dist/assets/{toml-CrP9HWVu.js → toml-CgkLq_pv.js} +0 -0
- /package/dist/assets/{trash-2-CKlZA04n.js → trash-2-BJLYnZpG.js} +0 -0
- /package/dist/assets/{trash-CdBDfa8x.js → trash-wVOgGgQw.js} +0 -0
- /package/dist/assets/{treemap-BKxvGXqJ.js → treemap-Cli48Hv9.js} +0 -0
- /package/dist/assets/{triangle-alert-B8l157gP.js → triangle-alert-CJ0ZIqcz.js} +0 -0
- /package/dist/assets/{troff-BWD1WiE0.js → troff-6nX9d05T.js} +0 -0
- /package/dist/assets/{ttcn-CQzcRj0D.js → ttcn-Dd4SMoHT.js} +0 -0
- /package/dist/assets/{ttcn-cfg-jzTcqwRW.js → ttcn-cfg-ByNDYolW.js} +0 -0
- /package/dist/assets/{turtle-BAqH2D2z.js → turtle-LDF8uFGv.js} +0 -0
- /package/dist/assets/{types-W8WWuumF.js → types-BYwxXaSY.js} +0 -0
- /package/dist/assets/{types-z6Sk3JCV.js → types-DZmRsGZN.js} +0 -0
- /package/dist/assets/{use-toast-T0_cQDma.js → use-toast-ERM44-k9.js} +0 -0
- /package/dist/assets/{useAsyncData-BFC6lWG9.js → useAsyncData-C5i0IRVM.js} +0 -0
- /package/dist/assets/{useDebounce-CLMpJfhX.js → useDebounce-_BZcy6gx.js} +0 -0
- /package/dist/assets/{useDeepCompareMemoize-D0WTlCXt.js → useDeepCompareMemoize-zUHU--0D.js} +0 -0
- /package/dist/assets/{uuid-DercMavo.js → uuid-D_zLHhNi.js} +0 -0
- /package/dist/assets/{vb-CrUpzy4g.js → vb-DaLxM60T.js} +0 -0
- /package/dist/assets/{vbscript-DEuHZ0Y0.js → vbscript-CwitZ57u.js} +0 -0
- /package/dist/assets/{velocity-D99sTvXl.js → velocity-D6bc4mrP.js} +0 -0
- /package/dist/assets/{verilog-XWBMMjwd.js → verilog-CIyPdzYJ.js} +0 -0
- /package/dist/assets/{vhdl-BAGmVXDV.js → vhdl-DfyhlM4K.js} +0 -0
- /package/dist/assets/{web-vitals-BaJPM15X.js → web-vitals-BaMazlva.js} +0 -0
- /package/dist/assets/{webidl-xagG_7hd.js → webidl-C23hA3Le.js} +0 -0
- /package/dist/assets/{workflow-ClChd5xI.js → workflow-CgnDnnoN.js} +0 -0
- /package/dist/assets/{xquery-B8Mguhly.js → xquery-BAVQXrAf.js} +0 -0
- /package/dist/assets/{yacas-XW2NxGKw.js → yacas-DrybVty2.js} +0 -0
- /package/dist/assets/{youtube-CbdpN8oL.js → youtube-3lRHw8NU.js} +0 -0
- /package/dist/assets/{z80-DhICfTcL.js → z80-8KI6AMtY.js} +0 -0
|
@@ -101,6 +101,158 @@ print(x)`);
|
|
|
101
101
|
`);
|
|
102
102
|
});
|
|
103
103
|
|
|
104
|
+
test("selects the nearest in-scope local definition", async () => {
|
|
105
|
+
const code = `\
|
|
106
|
+
a = 10
|
|
107
|
+
|
|
108
|
+
def my_func():
|
|
109
|
+
a = 20
|
|
110
|
+
print(a)`;
|
|
111
|
+
view = createEditor(code);
|
|
112
|
+
const result = goToVariableDefinition(view, "a", code.lastIndexOf("a"));
|
|
113
|
+
|
|
114
|
+
expect(result).toBe(true);
|
|
115
|
+
await tick();
|
|
116
|
+
expect(renderEditorView(view)).toMatchInlineSnapshot(`
|
|
117
|
+
"
|
|
118
|
+
a = 10
|
|
119
|
+
|
|
120
|
+
def my_func():
|
|
121
|
+
a = 20
|
|
122
|
+
^
|
|
123
|
+
print(a)
|
|
124
|
+
"
|
|
125
|
+
`);
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
test("selects the nearest in-scope parameter definition", async () => {
|
|
129
|
+
const code = `\
|
|
130
|
+
a = 10
|
|
131
|
+
|
|
132
|
+
def my_func(a):
|
|
133
|
+
print(a)`;
|
|
134
|
+
view = createEditor(code);
|
|
135
|
+
const result = goToVariableDefinition(view, "a", code.lastIndexOf("a"));
|
|
136
|
+
|
|
137
|
+
expect(result).toBe(true);
|
|
138
|
+
await tick();
|
|
139
|
+
expect(renderEditorView(view)).toMatchInlineSnapshot(`
|
|
140
|
+
"
|
|
141
|
+
a = 10
|
|
142
|
+
|
|
143
|
+
def my_func(a):
|
|
144
|
+
^
|
|
145
|
+
print(a)
|
|
146
|
+
"
|
|
147
|
+
`);
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
test("selects the comprehension target inside a set comprehension", async () => {
|
|
151
|
+
const code = `\
|
|
152
|
+
x = 100
|
|
153
|
+
s = {x for x in range(10)}`;
|
|
154
|
+
view = createEditor(code);
|
|
155
|
+
// Go-to-definition on the `x` before `for` (the expression part of the
|
|
156
|
+
// comprehension).
|
|
157
|
+
const usagePosition = code.indexOf("{x") + 1;
|
|
158
|
+
const result = goToVariableDefinition(view, "x", usagePosition);
|
|
159
|
+
|
|
160
|
+
expect(result).toBe(true);
|
|
161
|
+
await tick();
|
|
162
|
+
// Should jump to the comprehension target `x` (after `for`), not the
|
|
163
|
+
// outer `x = 100`. The Lezer Python grammar emits
|
|
164
|
+
// `SetComprehensionExpression`, and we now correctly match it in
|
|
165
|
+
// SCOPE_CREATING_NODES, so the comprehension creates a scope and the
|
|
166
|
+
// for-target is collected correctly.
|
|
167
|
+
expect(renderEditorView(view)).toMatchInlineSnapshot(`
|
|
168
|
+
"
|
|
169
|
+
x = 100
|
|
170
|
+
s = {x for x in range(10)}
|
|
171
|
+
^
|
|
172
|
+
"
|
|
173
|
+
`);
|
|
174
|
+
});
|
|
175
|
+
|
|
176
|
+
test("selects the comprehension target inside a dict comprehension", async () => {
|
|
177
|
+
const code = `\
|
|
178
|
+
x = 100
|
|
179
|
+
d = {x: x for x in range(10)}`;
|
|
180
|
+
view = createEditor(code);
|
|
181
|
+
const usagePosition = code.indexOf("{x") + 1;
|
|
182
|
+
const result = goToVariableDefinition(view, "x", usagePosition);
|
|
183
|
+
|
|
184
|
+
expect(result).toBe(true);
|
|
185
|
+
await tick();
|
|
186
|
+
// Positive control: `DictionaryComprehensionExpression` matches the grammar
|
|
187
|
+
// and is in SCOPE_CREATING_NODES, so this should jump to the comprehension
|
|
188
|
+
// target `x` (after `for`).
|
|
189
|
+
expect(renderEditorView(view)).toMatchInlineSnapshot(`
|
|
190
|
+
"
|
|
191
|
+
x = 100
|
|
192
|
+
d = {x: x for x in range(10)}
|
|
193
|
+
^
|
|
194
|
+
"
|
|
195
|
+
`);
|
|
196
|
+
});
|
|
197
|
+
|
|
198
|
+
test("skips enclosing class scope when resolving from inside a method", async () => {
|
|
199
|
+
const code = `\
|
|
200
|
+
x = 100
|
|
201
|
+
class Foo:
|
|
202
|
+
x = 10
|
|
203
|
+
def method(self):
|
|
204
|
+
return x`;
|
|
205
|
+
view = createEditor(code);
|
|
206
|
+
// Go-to-definition on the `x` inside `return x`.
|
|
207
|
+
const usagePosition = code.lastIndexOf("x");
|
|
208
|
+
const result = goToVariableDefinition(view, "x", usagePosition);
|
|
209
|
+
|
|
210
|
+
expect(result).toBe(true);
|
|
211
|
+
await tick();
|
|
212
|
+
// Should jump to `x = 100` at module scope. In Python, methods do NOT see
|
|
213
|
+
// their enclosing class body's names — class scopes are skipped in LEGB
|
|
214
|
+
// lookup once a function boundary has been crossed. We now correctly skip
|
|
215
|
+
// ClassDefinition in getScopeChain once a function boundary is crossed.
|
|
216
|
+
expect(renderEditorView(view)).toMatchInlineSnapshot(`
|
|
217
|
+
"
|
|
218
|
+
x = 100
|
|
219
|
+
^
|
|
220
|
+
class Foo:
|
|
221
|
+
x = 10
|
|
222
|
+
def method(self):
|
|
223
|
+
return x
|
|
224
|
+
"
|
|
225
|
+
`);
|
|
226
|
+
});
|
|
227
|
+
|
|
228
|
+
test("resolves a global forward-reference from inside a function", async () => {
|
|
229
|
+
const code = `\
|
|
230
|
+
def foo():
|
|
231
|
+
return a
|
|
232
|
+
|
|
233
|
+
a = 10`;
|
|
234
|
+
view = createEditor(code);
|
|
235
|
+
// Go-to-definition on the `a` inside `return a`.
|
|
236
|
+
const usagePosition = code.indexOf("return a") + "return ".length;
|
|
237
|
+
const result = goToVariableDefinition(view, "a", usagePosition);
|
|
238
|
+
|
|
239
|
+
expect(result).toBe(true);
|
|
240
|
+
await tick();
|
|
241
|
+
// Should jump to `a = 10` at the bottom. Python allows forward references
|
|
242
|
+
// from within nested functions to module-level names. We now correctly omit
|
|
243
|
+
// "global" from POSITION_SENSITIVE_SCOPES, allowing forward references to
|
|
244
|
+
// global-level definitions declared after the usage position.
|
|
245
|
+
expect(renderEditorView(view)).toMatchInlineSnapshot(`
|
|
246
|
+
"
|
|
247
|
+
def foo():
|
|
248
|
+
return a
|
|
249
|
+
|
|
250
|
+
a = 10
|
|
251
|
+
^
|
|
252
|
+
"
|
|
253
|
+
`);
|
|
254
|
+
});
|
|
255
|
+
|
|
104
256
|
test("selects outer-scope function declaration", async () => {
|
|
105
257
|
view = createEditor(`\
|
|
106
258
|
def x():
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
|
+
|
|
3
|
+
import { python } from "@codemirror/lang-python";
|
|
4
|
+
import { EditorState } from "@codemirror/state";
|
|
5
|
+
import { EditorView } from "@codemirror/view";
|
|
6
|
+
import { afterEach, describe, expect, test } from "vitest";
|
|
7
|
+
import { cellId, variableName } from "@/__tests__/branded";
|
|
8
|
+
import { initialNotebookState, notebookAtom } from "@/core/cells/cells";
|
|
9
|
+
import { store } from "@/core/state/jotai";
|
|
10
|
+
import { variablesAtom } from "@/core/variables/state";
|
|
11
|
+
import { goToDefinitionAtCursorPosition } from "../utils";
|
|
12
|
+
|
|
13
|
+
async function tick(): Promise<void> {
|
|
14
|
+
await new Promise((resolve) => requestAnimationFrame(resolve));
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
function createEditor(content: string, selection: number) {
|
|
18
|
+
const state = EditorState.create({
|
|
19
|
+
doc: content,
|
|
20
|
+
selection: { anchor: selection },
|
|
21
|
+
extensions: [python()],
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
return new EditorView({
|
|
25
|
+
state,
|
|
26
|
+
parent: document.body,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const views: EditorView[] = [];
|
|
31
|
+
|
|
32
|
+
afterEach(() => {
|
|
33
|
+
for (const view of views.splice(0)) {
|
|
34
|
+
view.destroy();
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
store.set(notebookAtom, initialNotebookState());
|
|
38
|
+
store.set(variablesAtom, {});
|
|
39
|
+
});
|
|
40
|
+
|
|
41
|
+
describe("goToDefinitionAtCursorPosition", () => {
|
|
42
|
+
test("prefers the current-cell local definition over a reactive global", async () => {
|
|
43
|
+
const globalCell = cellId("global-cell");
|
|
44
|
+
const localCell = cellId("local-cell");
|
|
45
|
+
const globalCode = `\
|
|
46
|
+
a = 10
|
|
47
|
+
print(a)`;
|
|
48
|
+
const localCode = `\
|
|
49
|
+
def test():
|
|
50
|
+
a = 20
|
|
51
|
+
print(a)`;
|
|
52
|
+
|
|
53
|
+
const globalView = createEditor(globalCode, globalCode.length);
|
|
54
|
+
const localView = createEditor(localCode, localCode.lastIndexOf("a"));
|
|
55
|
+
views.push(globalView, localView);
|
|
56
|
+
|
|
57
|
+
const notebook = initialNotebookState();
|
|
58
|
+
notebook.cellHandles[globalCell] = {
|
|
59
|
+
current: { editorView: globalView, editorViewOrNull: globalView },
|
|
60
|
+
};
|
|
61
|
+
notebook.cellHandles[localCell] = {
|
|
62
|
+
current: { editorView: localView, editorViewOrNull: localView },
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
store.set(notebookAtom, notebook);
|
|
66
|
+
store.set(variablesAtom, {
|
|
67
|
+
[variableName("a")]: {
|
|
68
|
+
dataType: "int",
|
|
69
|
+
declaredBy: [globalCell],
|
|
70
|
+
name: variableName("a"),
|
|
71
|
+
usedBy: [localCell],
|
|
72
|
+
value: "10",
|
|
73
|
+
},
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
const result = goToDefinitionAtCursorPosition(localView);
|
|
77
|
+
|
|
78
|
+
expect(result).toBe(true);
|
|
79
|
+
await tick();
|
|
80
|
+
expect(localView.state.selection.main.head).toBe(
|
|
81
|
+
localCode.indexOf("a = 20"),
|
|
82
|
+
);
|
|
83
|
+
expect(globalView.state.selection.main.head).toBe(globalCode.length);
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
test("keeps private variables within the current cell", async () => {
|
|
87
|
+
const code = `\
|
|
88
|
+
_x = 10
|
|
89
|
+
output = _x + 10`;
|
|
90
|
+
const view = createEditor(code, code.lastIndexOf("_x"));
|
|
91
|
+
views.push(view);
|
|
92
|
+
|
|
93
|
+
const result = goToDefinitionAtCursorPosition(view);
|
|
94
|
+
|
|
95
|
+
expect(result).toBe(true);
|
|
96
|
+
await tick();
|
|
97
|
+
expect(view.state.selection.main.head).toBe(code.indexOf("_x = 10"));
|
|
98
|
+
});
|
|
99
|
+
});
|
|
@@ -1,7 +1,31 @@
|
|
|
1
1
|
/* Copyright 2026 Marimo. All rights reserved. */
|
|
2
2
|
|
|
3
3
|
import { syntaxTree } from "@codemirror/language";
|
|
4
|
+
import type { EditorState } from "@codemirror/state";
|
|
4
5
|
import { EditorView } from "@codemirror/view";
|
|
6
|
+
import type { SyntaxNode, Tree, TreeCursor } from "@lezer/common";
|
|
7
|
+
|
|
8
|
+
const SCOPE_CREATING_NODES = new Set([
|
|
9
|
+
"FunctionDefinition",
|
|
10
|
+
"LambdaExpression",
|
|
11
|
+
"ArrayComprehensionExpression",
|
|
12
|
+
"SetComprehensionExpression",
|
|
13
|
+
"DictionaryComprehensionExpression",
|
|
14
|
+
"ComprehensionExpression",
|
|
15
|
+
"ClassDefinition",
|
|
16
|
+
]);
|
|
17
|
+
|
|
18
|
+
const POSITION_SENSITIVE_SCOPES = new Set(["ClassDefinition"]);
|
|
19
|
+
|
|
20
|
+
interface ScopeContext {
|
|
21
|
+
id: number;
|
|
22
|
+
type: string;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
interface VariableDeclaration {
|
|
26
|
+
from: number;
|
|
27
|
+
scopeId: number;
|
|
28
|
+
}
|
|
5
29
|
|
|
6
30
|
function goToPosition(view: EditorView, from: number): void {
|
|
7
31
|
view.focus();
|
|
@@ -22,50 +46,386 @@ function goToPosition(view: EditorView, from: number): void {
|
|
|
22
46
|
});
|
|
23
47
|
}
|
|
24
48
|
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
* for a given editor view.
|
|
28
|
-
* @param view The editor view which contains the variable name.
|
|
29
|
-
* @param variableName The name of the variable to select, if found in the editor.
|
|
30
|
-
*/
|
|
31
|
-
export function goToVariableDefinition(
|
|
32
|
-
view: EditorView,
|
|
49
|
+
function findFirstMatchingVariable(
|
|
50
|
+
state: EditorState,
|
|
33
51
|
variableName: string,
|
|
34
|
-
):
|
|
35
|
-
const { state } = view;
|
|
52
|
+
): number | null {
|
|
36
53
|
const tree = syntaxTree(state);
|
|
37
54
|
|
|
38
|
-
let
|
|
39
|
-
let from = 0;
|
|
55
|
+
let from: number | null = null;
|
|
40
56
|
|
|
41
57
|
tree.iterate({
|
|
42
58
|
enter: (node) => {
|
|
43
|
-
if (
|
|
59
|
+
if (from !== null) {
|
|
44
60
|
return false;
|
|
45
|
-
}
|
|
61
|
+
}
|
|
46
62
|
|
|
47
|
-
// Check if the node is an identifier and matches the variable name
|
|
48
63
|
if (
|
|
49
64
|
node.name === "VariableName" &&
|
|
50
65
|
state.doc.sliceString(node.from, node.to) === variableName
|
|
51
66
|
) {
|
|
52
67
|
from = node.from;
|
|
53
|
-
|
|
54
|
-
return false; // Stop traversal
|
|
68
|
+
return false;
|
|
55
69
|
}
|
|
56
70
|
|
|
57
|
-
// Skip comments and strings
|
|
58
71
|
if (node.name === "Comment" || node.name === "String") {
|
|
59
72
|
return false;
|
|
60
73
|
}
|
|
74
|
+
|
|
75
|
+
return undefined;
|
|
61
76
|
},
|
|
62
77
|
});
|
|
63
78
|
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
79
|
+
return from;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
function getScopeChain(tree: Tree, usagePosition: number): ScopeContext[] {
|
|
83
|
+
const scopeChain: ScopeContext[] = [];
|
|
84
|
+
let currentNode: SyntaxNode | null = tree.resolveInner(usagePosition, 0);
|
|
85
|
+
|
|
86
|
+
while (currentNode) {
|
|
87
|
+
if (SCOPE_CREATING_NODES.has(currentNode.name)) {
|
|
88
|
+
// Skip ClassDefinition if we've already seen a function/lambda.
|
|
89
|
+
const inFunctionLikeScope = scopeChain.some(
|
|
90
|
+
(scope) =>
|
|
91
|
+
scope.type === "FunctionDefinition" ||
|
|
92
|
+
scope.type === "LambdaExpression",
|
|
93
|
+
);
|
|
94
|
+
if (!(inFunctionLikeScope && currentNode.name === "ClassDefinition")) {
|
|
95
|
+
scopeChain.push({
|
|
96
|
+
id: currentNode.from,
|
|
97
|
+
type: currentNode.name,
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
currentNode = currentNode.parent;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
scopeChain.push({ id: -1, type: "global" });
|
|
105
|
+
return scopeChain;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
function addDeclaration(
|
|
109
|
+
declarations: VariableDeclaration[],
|
|
110
|
+
scopeId: number,
|
|
111
|
+
from: number,
|
|
112
|
+
) {
|
|
113
|
+
declarations.push({ scopeId, from });
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
function traverseChildren(
|
|
117
|
+
cursor: TreeCursor,
|
|
118
|
+
callback: (node: SyntaxNode) => void,
|
|
119
|
+
) {
|
|
120
|
+
if (cursor.firstChild()) {
|
|
121
|
+
do {
|
|
122
|
+
callback(cursor.node);
|
|
123
|
+
} while (cursor.nextSibling());
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
function collectMatchingTargets(
|
|
128
|
+
cursor: TreeCursor,
|
|
129
|
+
state: EditorState,
|
|
130
|
+
variableName: string,
|
|
131
|
+
scopeId: number,
|
|
132
|
+
declarations: VariableDeclaration[],
|
|
133
|
+
) {
|
|
134
|
+
switch (cursor.name) {
|
|
135
|
+
case "VariableName":
|
|
136
|
+
if (state.doc.sliceString(cursor.from, cursor.to) === variableName) {
|
|
137
|
+
addDeclaration(declarations, scopeId, cursor.from);
|
|
138
|
+
}
|
|
139
|
+
break;
|
|
140
|
+
|
|
141
|
+
case "TupleExpression":
|
|
142
|
+
case "ArrayExpression": {
|
|
143
|
+
const childCursor = cursor.node.cursor();
|
|
144
|
+
childCursor.firstChild();
|
|
145
|
+
do {
|
|
146
|
+
collectMatchingTargets(
|
|
147
|
+
childCursor,
|
|
148
|
+
state,
|
|
149
|
+
variableName,
|
|
150
|
+
scopeId,
|
|
151
|
+
declarations,
|
|
152
|
+
);
|
|
153
|
+
} while (childCursor.nextSibling());
|
|
154
|
+
break;
|
|
155
|
+
}
|
|
156
|
+
default:
|
|
157
|
+
break;
|
|
67
158
|
}
|
|
68
|
-
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
function collectFunctionParameters(
|
|
162
|
+
node: SyntaxNode | Tree,
|
|
163
|
+
state: EditorState,
|
|
164
|
+
variableName: string,
|
|
165
|
+
scopeId: number,
|
|
166
|
+
declarations: VariableDeclaration[],
|
|
167
|
+
) {
|
|
168
|
+
const cursor = node.cursor();
|
|
169
|
+
cursor.firstChild();
|
|
170
|
+
do {
|
|
171
|
+
if (cursor.name !== "ParamList") {
|
|
172
|
+
continue;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
const paramCursor = cursor.node.cursor();
|
|
176
|
+
paramCursor.firstChild();
|
|
177
|
+
do {
|
|
178
|
+
if (
|
|
179
|
+
paramCursor.name === "VariableName" &&
|
|
180
|
+
state.doc.sliceString(paramCursor.from, paramCursor.to) === variableName
|
|
181
|
+
) {
|
|
182
|
+
addDeclaration(declarations, scopeId, paramCursor.from);
|
|
183
|
+
}
|
|
184
|
+
} while (paramCursor.nextSibling());
|
|
185
|
+
} while (cursor.nextSibling());
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
function collectForTargets(
|
|
189
|
+
node: SyntaxNode | Tree,
|
|
190
|
+
state: EditorState,
|
|
191
|
+
variableName: string,
|
|
192
|
+
scopeId: number,
|
|
193
|
+
declarations: VariableDeclaration[],
|
|
194
|
+
) {
|
|
195
|
+
const cursor = node.cursor();
|
|
196
|
+
cursor.firstChild();
|
|
197
|
+
let foundFor = false;
|
|
198
|
+
do {
|
|
199
|
+
if (cursor.name === "for") {
|
|
200
|
+
foundFor = true;
|
|
201
|
+
} else if (foundFor && cursor.name === "in") {
|
|
202
|
+
break;
|
|
203
|
+
} else if (foundFor) {
|
|
204
|
+
collectMatchingTargets(
|
|
205
|
+
cursor,
|
|
206
|
+
state,
|
|
207
|
+
variableName,
|
|
208
|
+
scopeId,
|
|
209
|
+
declarations,
|
|
210
|
+
);
|
|
211
|
+
}
|
|
212
|
+
} while (cursor.nextSibling());
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
function collectMatchingDeclarations(
|
|
216
|
+
node: SyntaxNode | Tree,
|
|
217
|
+
state: EditorState,
|
|
218
|
+
variableName: string,
|
|
219
|
+
scopeStack: number[],
|
|
220
|
+
declarations: VariableDeclaration[],
|
|
221
|
+
) {
|
|
222
|
+
const cursor = node.cursor();
|
|
223
|
+
const nodeName = cursor.name;
|
|
224
|
+
const nodeStart = cursor.from;
|
|
225
|
+
|
|
226
|
+
const isNewScope = SCOPE_CREATING_NODES.has(nodeName);
|
|
227
|
+
const currentScopeStack = isNewScope
|
|
228
|
+
? [...scopeStack, nodeStart]
|
|
229
|
+
: scopeStack;
|
|
230
|
+
const currentScope = currentScopeStack[currentScopeStack.length - 1] ?? -1;
|
|
231
|
+
|
|
232
|
+
switch (nodeName) {
|
|
233
|
+
case "FunctionDefinition":
|
|
234
|
+
case "ClassDefinition": {
|
|
235
|
+
const subCursor = node.cursor();
|
|
236
|
+
subCursor.firstChild();
|
|
237
|
+
do {
|
|
238
|
+
if (
|
|
239
|
+
subCursor.name === "VariableName" &&
|
|
240
|
+
state.doc.sliceString(subCursor.from, subCursor.to) === variableName
|
|
241
|
+
) {
|
|
242
|
+
const parentScope = scopeStack[scopeStack.length - 1] ?? -1;
|
|
243
|
+
addDeclaration(declarations, parentScope, subCursor.from);
|
|
244
|
+
break;
|
|
245
|
+
}
|
|
246
|
+
} while (subCursor.nextSibling());
|
|
247
|
+
|
|
248
|
+
if (nodeName === "FunctionDefinition") {
|
|
249
|
+
collectFunctionParameters(
|
|
250
|
+
node,
|
|
251
|
+
state,
|
|
252
|
+
variableName,
|
|
253
|
+
nodeStart,
|
|
254
|
+
declarations,
|
|
255
|
+
);
|
|
256
|
+
}
|
|
257
|
+
break;
|
|
258
|
+
}
|
|
259
|
+
case "LambdaExpression":
|
|
260
|
+
collectFunctionParameters(
|
|
261
|
+
node,
|
|
262
|
+
state,
|
|
263
|
+
variableName,
|
|
264
|
+
nodeStart,
|
|
265
|
+
declarations,
|
|
266
|
+
);
|
|
267
|
+
break;
|
|
268
|
+
|
|
269
|
+
case "ArrayComprehensionExpression":
|
|
270
|
+
case "DictionaryComprehensionExpression":
|
|
271
|
+
case "SetComprehensionExpression":
|
|
272
|
+
case "ComprehensionExpression":
|
|
273
|
+
case "ForStatement":
|
|
274
|
+
collectForTargets(node, state, variableName, currentScope, declarations);
|
|
275
|
+
break;
|
|
276
|
+
|
|
277
|
+
case "AssignStatement": {
|
|
278
|
+
const assignOpPositions: number[] = [];
|
|
279
|
+
const subCursor = node.cursor();
|
|
280
|
+
subCursor.firstChild();
|
|
281
|
+
do {
|
|
282
|
+
if (subCursor.name === "AssignOp") {
|
|
283
|
+
assignOpPositions.push(subCursor.from);
|
|
284
|
+
}
|
|
285
|
+
} while (subCursor.nextSibling());
|
|
286
|
+
|
|
287
|
+
const lastAssignOpPosition =
|
|
288
|
+
assignOpPositions[assignOpPositions.length - 1];
|
|
289
|
+
if (lastAssignOpPosition === undefined) {
|
|
290
|
+
break;
|
|
291
|
+
}
|
|
292
|
+
|
|
293
|
+
const targetCursor = node.cursor();
|
|
294
|
+
targetCursor.firstChild();
|
|
295
|
+
do {
|
|
296
|
+
if (targetCursor.from < lastAssignOpPosition) {
|
|
297
|
+
collectMatchingTargets(
|
|
298
|
+
targetCursor,
|
|
299
|
+
state,
|
|
300
|
+
variableName,
|
|
301
|
+
currentScope,
|
|
302
|
+
declarations,
|
|
303
|
+
);
|
|
304
|
+
}
|
|
305
|
+
} while (targetCursor.nextSibling());
|
|
306
|
+
break;
|
|
307
|
+
}
|
|
308
|
+
case "ImportStatement": {
|
|
309
|
+
const subCursor = node.cursor();
|
|
310
|
+
subCursor.firstChild();
|
|
311
|
+
do {
|
|
312
|
+
if (
|
|
313
|
+
subCursor.name === "VariableName" &&
|
|
314
|
+
state.doc.sliceString(subCursor.from, subCursor.to) === variableName
|
|
315
|
+
) {
|
|
316
|
+
addDeclaration(declarations, currentScope, subCursor.from);
|
|
317
|
+
}
|
|
318
|
+
} while (subCursor.nextSibling());
|
|
319
|
+
break;
|
|
320
|
+
}
|
|
321
|
+
case "ImportFromStatement": {
|
|
322
|
+
const subCursor = node.cursor();
|
|
323
|
+
subCursor.firstChild();
|
|
324
|
+
let foundImport = false;
|
|
325
|
+
do {
|
|
326
|
+
if (subCursor.name === "import") {
|
|
327
|
+
foundImport = true;
|
|
328
|
+
} else if (
|
|
329
|
+
foundImport &&
|
|
330
|
+
subCursor.name === "VariableName" &&
|
|
331
|
+
state.doc.sliceString(subCursor.from, subCursor.to) === variableName
|
|
332
|
+
) {
|
|
333
|
+
addDeclaration(declarations, currentScope, subCursor.from);
|
|
334
|
+
}
|
|
335
|
+
} while (subCursor.nextSibling());
|
|
336
|
+
break;
|
|
337
|
+
}
|
|
338
|
+
case "TryStatement":
|
|
339
|
+
case "WithStatement": {
|
|
340
|
+
const subCursor = node.cursor();
|
|
341
|
+
subCursor.firstChild();
|
|
342
|
+
let foundAs = false;
|
|
343
|
+
do {
|
|
344
|
+
if (subCursor.name === "as") {
|
|
345
|
+
foundAs = true;
|
|
346
|
+
} else if (
|
|
347
|
+
foundAs &&
|
|
348
|
+
subCursor.name === "VariableName" &&
|
|
349
|
+
state.doc.sliceString(subCursor.from, subCursor.to) === variableName
|
|
350
|
+
) {
|
|
351
|
+
addDeclaration(declarations, currentScope, subCursor.from);
|
|
352
|
+
foundAs = false;
|
|
353
|
+
}
|
|
354
|
+
} while (subCursor.nextSibling());
|
|
355
|
+
break;
|
|
356
|
+
}
|
|
357
|
+
default:
|
|
358
|
+
break;
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
traverseChildren(cursor, (childNode) => {
|
|
362
|
+
collectMatchingDeclarations(
|
|
363
|
+
childNode,
|
|
364
|
+
state,
|
|
365
|
+
variableName,
|
|
366
|
+
currentScopeStack,
|
|
367
|
+
declarations,
|
|
368
|
+
);
|
|
369
|
+
});
|
|
370
|
+
}
|
|
371
|
+
|
|
372
|
+
function findScopedDefinitionPosition(
|
|
373
|
+
state: EditorState,
|
|
374
|
+
variableName: string,
|
|
375
|
+
usagePosition: number,
|
|
376
|
+
): number | null {
|
|
377
|
+
const tree = syntaxTree(state);
|
|
378
|
+
const declarations: VariableDeclaration[] = [];
|
|
379
|
+
|
|
380
|
+
collectMatchingDeclarations(tree, state, variableName, [], declarations);
|
|
381
|
+
|
|
382
|
+
const clampedUsagePosition = Math.max(
|
|
383
|
+
0,
|
|
384
|
+
Math.min(usagePosition, state.doc.length),
|
|
385
|
+
);
|
|
386
|
+
|
|
387
|
+
for (const scope of getScopeChain(tree, clampedUsagePosition)) {
|
|
388
|
+
const match = declarations
|
|
389
|
+
.filter((declaration) => declaration.scopeId === scope.id)
|
|
390
|
+
.filter((declaration) => {
|
|
391
|
+
return POSITION_SENSITIVE_SCOPES.has(scope.type)
|
|
392
|
+
? declaration.from <= clampedUsagePosition
|
|
393
|
+
: true;
|
|
394
|
+
})
|
|
395
|
+
.toSorted((left, right) => left.from - right.from)[0];
|
|
396
|
+
|
|
397
|
+
if (match) {
|
|
398
|
+
return match.from;
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
|
|
402
|
+
return null;
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
/**
|
|
406
|
+
* This function will select the first occurrence of the given variable name,
|
|
407
|
+
* for a given editor view.
|
|
408
|
+
* @param view The editor view which contains the variable name.
|
|
409
|
+
* @param variableName The name of the variable to select, if found in the editor.
|
|
410
|
+
* @param usagePosition The position of the variable usage, if available.
|
|
411
|
+
*/
|
|
412
|
+
export function goToVariableDefinition(
|
|
413
|
+
view: EditorView,
|
|
414
|
+
variableName: string,
|
|
415
|
+
usagePosition?: number,
|
|
416
|
+
): boolean {
|
|
417
|
+
const { state } = view;
|
|
418
|
+
const from =
|
|
419
|
+
(usagePosition !== undefined
|
|
420
|
+
? findScopedDefinitionPosition(state, variableName, usagePosition)
|
|
421
|
+
: null) ?? findFirstMatchingVariable(state, variableName);
|
|
422
|
+
|
|
423
|
+
if (from === null) {
|
|
424
|
+
return false;
|
|
425
|
+
}
|
|
426
|
+
|
|
427
|
+
goToPosition(view, from);
|
|
428
|
+
return true;
|
|
69
429
|
}
|
|
70
430
|
|
|
71
431
|
/**
|