Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Evaluate as command #2684

Draft
wants to merge 9 commits into
base: dev
Choose a base branch
from
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 3 additions & 1 deletion CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,9 +4,11 @@ Changes to Calva.

## [Unreleased]

- [Added resultAsCommand and commandThen options for custom snippets](https://github.com/BetterThanTomorrow/calva/issues/2683)

## [2.0.482] - 2024-12-03

- Fix: [Added 'replace-refer-all-with-alias' & 'replace-refer-all-with-refer' actions to calva.](https://github.com/BetterThanTomorrow/calva/issues/2667)
- Fix: [Added 'replace-refer-all-with-alias' & 'replace-refer-all-with-refer' actions to calva.](https://github.com/BetterThanTomorrow/calva/issues/2667)

## [2.0.481] - 2024-10-29

Expand Down
244 changes: 244 additions & 0 deletions docs/site/commands-reference.md
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

There is a commands reference built in to VS Code. Perhaps it is better to refer to that, than to maintain our own? I see that there's automation to this one, but still. This one is indexed by search engines, so it may be worth it from that standpoint. WDYT?

commands reference

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think adding the command reference documentation provides a small amount of value:

  • Groups commands into logical topics
  • Provides another path for discovering what commands are available
  • Indexable by search engines

For users like myself who are discovering functionality, I think it is slightly more inviting to have the grouped topics instead of having to read them all in a seemingly random order.

Because it is generated, the maintenance cost is low.

The motivation I had for adding it was that the existing documentation asked for someone to add it 😄
If we don't want it then I think we should update the documentation to remove the previous confusing message.

Original file line number Diff line number Diff line change
@@ -0,0 +1,244 @@
---
title: Calva Command Reference
description: All Calva commands.
---

# Calva Command Reference

Calva's commands are part of the [Calva API](api.md).
They often accept arguments of some type.

## JackIn

| Command | Title |
| :------ | :---- |
| `calva.startJoyrideReplAndConnect` | Start Joyride REPL and Connect |
| `calva.copyJackInCommandToClipboard` | Copy Jack-In Command Line to Clipboard |
| `calva.jackIn` | Start a Project REPL and Connect (aka Jack-In) |
| `calva.jackOut` | Stop/Kill the Project REPL started by Calva (aka Jack-Out) |
| `calva.connect` | Connect to a Running REPL Server in the Project |
| `calva.connectNonProjectREPL` | Connect to a Running REPL Server, not in Project |
| `calva.disconnect` | Disconnect from the REPL Server |
| `calva.startStandaloneHelloRepl` | Create a Getting Started REPL project |
| `calva.revealJackInTerminal` | Reveal Jack-In Terminal |

## Evaluate

| Command | Title |
| :------ | :---- |
| `calva.togglePrettyPrint` | Toggle Pretty Printing for All Evaluations |
| `calva.clearInlineResults` | Clear Inline Evaluation Results |
| `calva.interruptAllEvaluations` | Interrupt Running Evaluations |
| `calva.evaluateSelection` | Evaluate Current Form (or selection, if any) |
| `calva.evaluateEnclosingForm` | Evaluate Current Enclosing Form |
| `calva.evaluateToCursor` | Evaluate From Start of List to Cursor, Closing Brackets |
| `calva.evaluateSelectionToSelectionEnd` | Evaluate Selection, Closing Brackets |
| `calva.evaluateTopLevelFormToCursor` | Evaluate From Start of Top Level Form to Cursor, Closing Brackets |
| `calva.tapSelection` | Tap Current Form (or selection, if any) |
| `calva.evaluateCurrentTopLevelForm` | Evaluate Top Level Form (defun) |
| `calva.tapCurrentTopLevelForm` | Tap Current Top Level Form |
| `calva.evaluateSelectionAsComment` | Evaluate Current Form to Comment |
| `calva.evaluateTopLevelFormAsComment` | Evaluate Top Level Form (defun) to Comment |
| `calva.copyLastResults` | Copy Last Evaluation Result to Clipboard |
| `calva.loadFile` | Load/Evaluate Current File and its Requires/Dependencies |
| `calva.refresh` | Refresh Changed Namespaces |
| `calva.refreshAll` | Refresh All Namespaces |
| `calva.evaluateFiddleForSourceFile` | Evaluate Fiddle File for Current File |

## Test

| Command | Title |
| :------ | :---- |
| `calva.evaluateStartOfFileToCursor` | Evaluate From Start of File to Cursor, Closing Brackets |
| `calva.runNamespaceTests` | Run Tests for Current Namespace |
| `calva.loadTestFileForCurrentNamespace` | Load/Evaluate Test File (as saved on disk) for Current Namespace |
| `calva.runAllTests` | Run All Tests |
| `calva.rerunTests` | Run Failing Tests Again |
| `calva.runTestUnderCursor` | Run Current Test |
| `calva.toggleBetweenImplAndTest` | Toggle between implementation and test |

## Paredit

| Command | Title |
| :------ | :---- |
| `paredit.togglemode` | Toggle Paredit Mode |
| `paredit.forwardSexp` | Move Cursor Forward Sexp/Form |
| `paredit.backwardSexp` | Move Cursor Backward Sexp/Form |
| `paredit.forwardSexpOrUp` | Move Cursor Forward or Up Sexp/Form |
| `paredit.backwardSexpOrUp` | Move Cursor Backward or Up Sexp/Form |
| `paredit.forwardDownSexp` | Move Cursor Forward Down Sexp/Form |
| `paredit.backwardDownSexp` | Move Cursor Backward Down Sexp/Form |
| `paredit.backwardUpSexp` | Move Cursor Backward Up Sexp/Form |
| `paredit.forwardUpSexp` | Move Cursor Forward Up Sexp/Form |
| `paredit.closeList` | Move Cursor Forward to List End/Close |
| `paredit.selectForwardSexp` | Select Forward Sexp |
| `paredit.selectRight` | Select Right |
| `paredit.selectBackwardSexp` | Select Backward Sexp |
| `paredit.selectForwardDownSexp` | Select Forward Down Sexp |
| `paredit.selectBackwardDownSexp` | Select Backward Down Sexp |
| `paredit.selectBackwardUpSexp` | Select Backward Up Sexp |
| `paredit.selectForwardUpSexp` | Select Forward Up Sexp |
| `paredit.selectBackwardSexpOrUp` | Select Backward Or Up Sexp |
| `paredit.selectForwardSexpOrUp` | Select Forward Or Up Sexp |
| `paredit.selectCloseList` | Select Forward to List End/Close |
| `paredit.selectOpenList` | Select Backward to List Start/Open |
| `paredit.rangeForDefun` | Select Current Top Level (aka defun) Form |
| `paredit.sexpRangeExpansion` | Expand Selection |
| `paredit.sexpRangeContraction` | Shrink Selection |
| `paredit.slurpSexpForward` | Slurp Sexp Forward |
| `paredit.slurpSexpBackward` | Slurp Sexp Backward |
| `paredit.barfSexpForward` | Barf Sexp Forward |
| `paredit.barfSexpBackward` | Barf Sexp Backward |
| `paredit.spliceSexp` | Splice Sexp |
| `paredit.splitSexp` | Split Sexp |
| `paredit.joinSexp` | Join Sexp |
| `paredit.raiseSexp` | Raise Sexp |
| `paredit.transpose` | Transpose (Swap) the two Sexps Around the Cursor |
| `paredit.dragSexprBackward` | Drag Sexp Backward |
| `paredit.dragSexprForward` | Drag Sexp Forward |
| `paredit.dragSexprBackwardUp` | Drag Sexp Backward Up |
| `paredit.dragSexprForwardDown` | Drag Sexp Forward Down |
| `paredit.dragSexprForwardUp` | Drag Sexp Forward Up |
| `paredit.dragSexprBackwardDown` | Drag Sexp Backward Down |
| `paredit.convolute` | Convolute Sexp ¯\_(ツ)_/¯ |
| `paredit.killRight` | Kill/Delete Right |
| `paredit.killLeft` | Kill/Delete Left |
| `paredit.killSexpForward` | Kill/Delete Sexp Forward |
| `paredit.killSexpBackward` | Kill/Delete Sexp Backward |
| `paredit.killListForward` | Kill/Delete Forward to End of List |
| `paredit.killListBackward` | Kill/Delete Backward to Start of List |
| `paredit.spliceSexpKillForward` | Splice & Kill/Delete Forward |
| `paredit.spliceSexpKillBackward` | Splice & Kill/Delete Backward |
| `paredit.deleteForward` | Delete Forward |
| `paredit.deleteBackward` | Delete Backward |
| `paredit.forceDeleteForward` | Force Delete Forward |
| `paredit.forceDeleteBackward` | Force Delete Backward |
| `paredit.wrapAroundParens` | Wrap Around () |
| `paredit.wrapAroundSquare` | Wrap Around [] |
| `paredit.wrapAroundCurly` | Wrap Around {} |
| `paredit.wrapAroundQuote` | Wrap Around "" |
| `paredit.rewrapParens` | Rewrap () |
| `paredit.rewrapSquare` | Rewrap [] |
| `paredit.rewrapCurly` | Rewrap {} |
| `paredit.rewrapSet` | Rewrap #{} |
| `paredit.rewrapQuote` | Rewrap "" |
| `paredit.addRichComment` | Add Rich Comment |

## LSP

| Command | Title |
| :------ | :---- |
| `calva.clojureLsp.showClojureLspMenu` | Show clojure-lsp menu |
| `calva.clojureLsp.download` | Download the configured Clojure LSP Server version |
| `calva.clojureLsp.start` | Start the Clojure LSP Server |
| `calva.clojureLsp.stop` | Stop the Clojure LSP Server |
| `calva.clojureLsp.restart` | Restart the Clojure LSP Server |
| `calva.clojureLsp.manage` | Manage Clojure LSP Servers |
| `calva.diagnostics.openClojureLspLogFile` | Open Clojure LSP Log File |
| `calva.diagnostics.showLspTraceLevelSettings` | Show LSP Trace Level Settings |
| `clojureLsp.refactor.cleanNs` | Clean NS Form |
| `clojureLsp.refactor.addMissingLibspec` | Add Missing Require |
| `clojureLsp.dragBackward` | Drag Sexp Backward |
| `clojureLsp.dragForward` | Drag Sexp Forward |
| `clojureLsp.refactor.cyclePrivacy` | Cycle/Toggle Privacy |
| `clojureLsp.refactor.expandLet` | Expand Let |
| `clojureLsp.refactor.inlineSymbol` | Inline Symbol |
| `clojureLsp.refactor.threadFirst` | Thread First |
| `clojureLsp.refactor.threadFirstAll` | Thread First All |
| `clojureLsp.refactor.threadLast` | Thread Last |
| `clojureLsp.refactor.threadLastAll` | Thread Last All |
| `clojureLsp.refactor.unwindAll` | Unwind All |
| `clojureLsp.refactor.unwindThread` | Unwind Thread |
| `clojureLsp.refactor.introduceLet` | Introduce let |
| `clojureLsp.refactor.moveToLet` | Move to Previous let Box |
| `clojureLsp.refactor.extractFunction` | Extract to New Function |
| `calva.diagnostics.clojureLspServerInfo` | Clojure-lsp Server Info |

## Formatting

| Command | Title |
| :------ | :---- |
| `calva-fmt.formatCurrentForm` | Format Current Form |
| `calva-fmt.alignCurrentForm` | Format and Align Current Form (recursively, experimental) |
| `calva-fmt.trimCurrentFormWhiteSpace` | Format Current Form and trim space between forms |
| `calva-fmt.inferParens` | Infer Parens (from the indentation) |
| `calva-fmt.tabIndent` | Indent Line |
| `calva-fmt.tabDedent` | Dedent Line |

## Conversion

| Command | Title |
| :------ | :---- |
| `calva.convertJs2Cljs` | Convert JavaScript code to ClojureScript |
| `calva.convertDart2Clj` | Convert Dart code to Clojure/ClojureDart |
| `calva.convertHtml2Hiccup` | Convert HTML code to Hiccup |
| `calva.pasteHtmlAsHiccup` | Paste HTML code as Hiccup |
| `calva.copyHtmlAsHiccup` | Copy HTML code as Hiccup |

## Inspector

| Command | Title |
| :------ | :---- |
| `calva.clearInspector` | Clear All Inspector Items |
| `calva.clearInspectorItem` | Clear Inspector Item |
| `calva.copyInspectorItem` | Copy Inspector Item |
| `calva.inspectItem` | Inspect Item |
| `calva.pasteAsInspectorItem` | Paste as Inspector Item |
| `calva.addToInspector` | Add Selection or Current Form to Inspector |
| `calva.revealInspector` | Reveal Inspector |

## Show

| Command | Title |
| :------ | :---- |
| `calva.info` | Show Information Message |
| `calva.warn` | Show Warning Message |
| `calva.error` | Show Error Message |
| `calva.webview` | Show Webview |

## REPL

| Command | Title |
| :------ | :---- |
| `calva.prettyPrintReplaceCurrentForm` | Replace Current Form (or Selection) with Pretty Printed Form |
| `calva.openUserConfigEdn` | Open REPL snippets User config.edn |
| `calva.rereadUserConfigEdn` | Refresh REPL snippets from User config.edn |
| `calva.diagnostics.toggleNreplLoggingEnabled` | Toggle nREPL Logging Enabled |
| `calva.toggleEvaluationSendCodeToOutputWindow` | Toggle also sending evaluated code to the REPL Window |
| `calva.showReplMenu` | Open the REPL Menu (Start/Connect a REPL, etc.) |
| `calva.toggleCLJCSession` | Toggle the REPL Connection (clj or cljs) used for CLJC Files |
| `calva.evaluateSelectionReplace` | Evaluate Current Form and Replace it with the Result |
| `calva.printLastStacktrace` | Print Last Stacktrace to REPL Window |
| `calva.requireREPLUtilities` | Require (refer) REPL utilities, like (doc) etcetera, into Current Namespace |
| `calva.runCustomREPLCommand` | Run Custom REPL Command |
| `calva.showOutputChannel` | Show/Open the Calva says Output Channel |
| `calva.showOutputTerminal` | Show/Open the Calva Output Terminal |
| `calva.showResultOutputDestination` | Show/Open the result output destination |
| `calva.showReplWindow` | Show/Open REPL Window |
| `calva.showFileForOutputWindowNS` | Show File for the Current REPL Window Namespace |
| `calva.setOutputWindowNamespace` | Switch Namespace in REPL Window to Current Namespace |
| `calva.sendCurrentFormToOutputWindow` | Send Current Form to REPL Window |
| `calva.sendCurrentTopLevelFormToOutputWindow` | Send Current Top Level Form to REPL Window |
| `calva.showPreviousReplHistoryEntry` | Show Previous REPL History Entry |
| `calva.showNextReplHistoryEntry` | Show Next REPL History Entry |
| `calva.clearReplHistory` | Clear REPL History |

## Miscellaneous

| Command | Title |
| :------ | :---- |
| `calva.activateCalva` | Activate the Calva Extension |
| `calva.diagnostics.printTextNotationFromDocument` | Print TextNotation from the current document to Calva says |
| `calva.diagnostics.createDocumentFromTextNotation` | Create a new Clojure Document from TextNotation |
| `calva.linting.resolveMacroAs` | Resolve Macro As |
| `calva.openCalvaDocs` | Open Documentation (calva.io) |
| `calva.debug.instrument` | Instrument Top Level Form for Debugging |
| `calva.createMinimalProject` | Create a mini Clojure project |
| `calva.continueComment` | Continue Comment (add a commented line below). |
| `calva.switchCljsBuild` | Select CLJS Build Connection |
| `calva.toggleKeybindingsEnabled` | Toggle Keybindings Enabled |
| `calva.selectCurrentForm` | Select Current Form |
| `calva.openFiddleForSourceFile` | Open Fiddle File for Current File |
| `calva.openSourceFileForFiddle` | Open Source File for Current Fiddle File |
| `calva.printClojureDocsToOutputWindow` | Print clojuredocs.org examples to OutputWindow |
| `calva.printClojureDocsToRichComment` | Print clojuredocs.org examples to Rich Comment |
13 changes: 4 additions & 9 deletions docs/site/commands.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,6 @@ description: A list of all (well, not by far yet) Calva commands. A part of Calv

# Calva Commands

!!! Note "This list is totally incomplete"
If you want to help the Calva project, one way to do so is to help making this list of commands complete.

Calva's commands are part of the [Calva API](api.md). They often accept arguments of some type, which you can use from keybindings and from [Joyride](https://github.com/BetterThanTomorrow/joyride) (or another VS Code extension). Well behaved commands return a Promise, if it is async. You can utilize this with Joyride too, or with keybindings involving [`runCommands`](https://blog.agical.se/en/posts/vs-code-runcommands-for-multi-commands-keyboard-shortcuts/).

## Example shortcut bindings
Expand Down Expand Up @@ -44,16 +41,14 @@ Here's another way to achieve something similar.
}
```

## REPL commands

Commands that establishes or needs a REPL connection.
## Commands with arguments

| Command | Title | Arguments | Notes |
| :------ | :---- | :-------- | :---- |
| `calva.refresh` | Refreshes changed namespaces | A JSON object with stuff from [cider-nrepl ops/refresh](https://github.com/clojure-emacs/cider-nrepl/blob/master/doc/modules/ROOT/pages/nrepl-api/ops.adoc#refresh) | Mostly meant for sending `:dirs`, `:after`, and `:before`. The print options may or may not work.
| `calva.refreshAll` | Refreshes changed namespaces | A JSON object with stuff from [cider-nrepl ops/refresh-aa](https://github.com/clojure-emacs/cider-nrepl/blob/master/doc/modules/ROOT/pages/nrepl-api/ops.adoc#refresh-all) | Mostly meant for sending `:dirs`, `:after`, and `:before`. The print options may or may not work.

Unfortunatley the arguments are not well documented, so you may need to poke around in the code to discover them.
If you search for the command, you should find it in package.json, and be able to navigate to the function definition to see the arguments.

## Wait, where are all the commands?

Told you the list is incomplete... Please consider helping with making this a complete list! 🙏
See [Commands Reference](commands-reference.md) for the complete list of commands available.
22 changes: 21 additions & 1 deletion docs/site/custom-commands.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ The `calva.customREPLCommandSnippets` is an array of objects with the following
* `ns`: A namespace to evaluate the command in. If omitted the command will be executed in the namespace of the current editor.
* `repl`: Which repl session to use for the evaluation. Either `"clj"` or `"cljs"`. Omit if you want to use the session of the current editor.
* `evaluationSendCodeToOutputWindow`: (default `true`) Whether the evaluated code should be echoed to the Output/REPL window.
* `command`: (optional) A VS Code command to invoke after the snippet completes, providing the snippet's result as arguments. Supply and empty array `[]` if the result should include the command itself.

There are also substitutions available, which will take elements from the current state of Calva and splice them in to the text of your command before executing it. They are

Expand Down Expand Up @@ -86,7 +87,6 @@ And these **Workspace** settings:
"snippet": "(start)"
}
],

```

Issuing **Run Custom REPL Command** will then render a VS Code menu with all the commands, where the Workspace configured commands will be listed first.
Expand Down Expand Up @@ -170,3 +170,23 @@ A new experimental feature lets library authors ship snippets inside their jar f
{:name "edn hover show val"
:snippet (str "### EDN show val\n```clojure\n" (pr-str (eval (symbol (str "$ns" "/" "$hover-top-level-defined-symbol")))) "\n```")}]}
```

## Running a command as the result of evaluation

Supplying a `command` will cause the result of evaluation to be treated as a command.
`command` is an array signature of the command.
If empty then the result will be treated as the command.
If supplied then the result will be treated as additional arguments.

```json
{
"name": "Eval Current Form as Command",
"key": "a",
"repl": "clj",
"snippet": "$current-form",
"command": []
},
```

It's useful to know that there is a "runCommands" command,
so you can also chain multiple command/snippets together.
2 changes: 2 additions & 0 deletions docs/site/finding-commands.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,8 @@ Did you know? There is a complete list of Calva settings and commands in the *Co

![The Calva Contributions Tab](https://user-images.githubusercontent.com/30010/66733740-c754b800-ee60-11e9-877b-962f6b920cd7.png)

See also the [Commands Reference](commands-reference.md)

## Toggling Keyboard Shortcuts On/Off

The command `calva.toggleKeybindingsEnabled` can be used to quickly enable and disable (almost) all keyboard shortcuts. This allows you to quickly toggle between Calva keybindings and other keybindings which would otherwise not be available when Calva is enabled. This is particularly useful with the Paredit keyboard shortcuts, whose default shortcuts conflict with the default VS Code shortcuts for textual (non-structural) editing.
Expand Down
1 change: 1 addition & 0 deletions mkdocs.yml
Original file line number Diff line number Diff line change
Expand Up @@ -108,6 +108,7 @@ nav:
- API:
- api.md
- commands.md
- commands-reference.md
- Guides:
- get-started-with-clojure.md
- jack-in-guide.md
Expand Down
28 changes: 27 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2168,6 +2168,31 @@
"category": "Calva",
"command": "calva.revealInspector",
"title": "Reveal Inspector"
},
{
"category": "Calva",
"command": "calva.revealJackInTerminal",
"title": "Reveal Jack-In Terminal"
},
{
"category": "Calva",
"command": "calva.info",
"title": "Show Information Message"
},
{
"category": "Calva",
"command": "calva.warn",
"title": "Show Warning Message"
},
{
"category": "Calva",
"command": "calva.error",
"title": "Show Error Message"
},
Comment on lines +2178 to +2191
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Maybe people can use Joyride to reach functionality like this instead?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You are correct that notification commands could be left out.

My opinion is that we want to enable toolmakers (like Clay) to do useful things by providing snippets that have "resultAsCommand". The question then is what is useful? Creating a Webview is essential for Clay.
Showing notifications is not essential for Clay. It may be useful for showing info messages or errors, but it is not necessary because those can be done via the Webview.

I think notifications would be broadly useful for toolmakers working on things like standard formatters, test runners, schema validators, and debuggers.

I was surprised that there is no notification command available in VSCode.
VSCode has over 3k commands, Calva has about 100 commands, but none of them handle notification AFAIK. This makes sense because why would a user want to notify themselves? But the intention of this change is to enable toolmakers to request a command, and one obvious thing that toolmakers would benefit from is showing a notification.

This brings up the question of should the feature be "resultAsCommand" at all?
A more conservative approach would be to only provide an interface to the functionality that toolmakers need.
Possibly that doesn't include any commands at all.

I believe that embracing the "command" approach feels nicer, more open, and more powerful for creative customization. And that notifications would be a useful part of that approach.

If adding notifications seems problematic, then I'd like to better understand why, and whether we should be limiting the feature to only show a Webview instead of allowing any command.

Are you concerned about adding notification commands because they would become a breaking change to remove? Perhaps something more?

{
"category": "Calva",
"command": "calva.webview",
"title": "Show Webview"
}
],
"keybindings": [
Expand Down Expand Up @@ -3342,7 +3367,8 @@
"preprettier-format-watch": "npm run prettier-format",
"eslint": "npx eslint . --ext .js,.jsx,.ts,.tsx",
"eslint-watch": "npx esw . --ext .js,.jsx,.ts,.tsx --watch",
"install-ys": "curl -sS https://yamlscript.org/install | PREFIX=/tmp/yamlscript VERSION=0.1.56 bash"
"install-ys": "curl -sS https://yamlscript.org/install | PREFIX=/tmp/yamlscript VERSION=0.1.56 bash",
"generate-commands-md": "node ./scripts/generate-commands-md.js"
},
"dependencies": {
"@vscode/debugadapter": "^1.64.0",
Expand Down
Loading