data:image/s3,"s3://crabby-images/2523c/2523ce4b8b64bade795ffc89574cfc29f35428d3" alt="Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility"
Security News
Deno 2.2 Improves Dependency Management and Expands Node.js Compatibility
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
@codingame/monaco-vscode-api
Advanced tools
NPM module that implements the VSCode api and redirects calls to Monaco editor.
The VSCode api is composed of:
To implement by hands the optional features (file system, workspace folders, file...), you can use the Services
namespace from vscode/services
:
import { Services } from 'vscode/services'
Services.install({
workspace: {
workspaceFolders: ...,
createFileSystemWatcher (documentSelector, provider) {
...
},
onDidSaveTextDocument
},
window: {
withProgress: ...
}
})
Also, monaco-editor use standalone
versions or the vscode services, which are much simpler.
You may want to provide your custom implementations of them, especially for: textModelService
, codeEditorService
and notificationService
. To do so, you can provide them as the third parameter while creating your first editor.
This library allows you to use a more convenient way using StandaloneService.initialize
.
Also, monaco-editor doesn't provide good type for them, so this library does it.
Example:
import { StandaloneService, INotificationService } from 'vscode/services'
class MyCustomNotificationService implements INotificationService { ... }
StandaloneService.initialize({
get [INotificationService.toString()] () {
return new MyCustomNotificationService(...)
}
})
Additionally, this library exposes 3 modules that include the vscode version of some services (with some glue to make it work with monaco):
vscode/service-override/messages
vscode/service-override/modelEditor
vscode/service-override/configuration
Usage:
import { StandaloneService } from 'vscode/services'
import getModelEditorServiceOverride from 'vscode/service-override/modelEditor'
import getMessageServiceOverride from 'vscode/service-override/messages'
import getConfigurationServiceOverride, { updateUserConfiguration, configurationRegistry } from 'vscode/service-override/configuration'
StandaloneServices.initialize({
...getModelEditorServiceOverride((model, input, sideBySide) => {
// Open a new editor here and return it
// It will be called when for instance the user ctrl+click on an import
}),
...getMessageServiceOverride(document.body),
...getConfigurationServiceOverride()
})
configurationRegistry.registerDefaultConfigurations([{
overrides: {
'editor.fontSize': 10
}
}])
updateUserConfiguration(`{
"editor.fontSize": 12,
"[java]": {
"editor.fontSize": 15,
}
}`)
Note: using vscode/service-override/modelEditor
, you'll be able to use the vscode.workspace.registerTextDocumentContentProvider
api
StandaloneServices.initialize
can only be called once (note that monaco.editor.create
calls StandaloneServices.initialize
).
Also, a service that is used cannot be overriden anymore. So StandaloneServices.initialize
should be called as soon as possible to prevent most of the issues.
The editors created using monaco.editor.create
don't use the configuration from the configurationService.
This library exposes functions to create editors binded on the configuration:
before:
import * as monaco from 'monaco-editor'
monaco.editor.create(...)
after:
import { createConfiguredEditor } from 'vscode/monaco'
createConfiguredEditor(...)
createConfiguredEditor
returns a subclass of what is returned by monaco.editor.create
, the updateOptions
method can still be used.
The only difference is that is will use the configurationService
as a default configuration
npm install vscode@npm:@codingame/monaco-vscode-api
npm install -D @types/vscode
Just import it as if you were in a vscode extension:
import * as vscode from 'vscode'
const range = new vscode.Range(...)
vscode.languages.registerCompletionItemProvider(...)
This project was mainly created to make the implementation of monaco-languageclient more robust and maintainable.
monaco-languageclient uses vscode-languageclient which was built to run inside a VSCode extension. VSCode extensions communicate with the editor via an API they can import into their code.
The VSCode api exports:
The first implementations of monaco-languageclient were using a fake VSCode api implementation. The vscode-languageclient was hacked so the VSCode<->protocol object converters were mainly bypassed, so the fake VSCode api was receiving Language Server Protocol objects. Then the objects were transformed using custom transformers into Monaco objects to communicate with the monaco api.
This approach has some disadvantages:
With this library, it would be possible to plug vscode-languageclient directly on top of monaco, monaco-languageclient still helps to do so by:
vscode/services
)FAQs
VSCode public API plugged on the monaco editor
The npm package @codingame/monaco-vscode-api receives a total of 41,324 weekly downloads. As such, @codingame/monaco-vscode-api popularity was classified as popular.
We found that @codingame/monaco-vscode-api demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 6 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Deno 2.2 enhances Node.js compatibility, improves dependency management, adds OpenTelemetry support, and expands linting and task automation for developers.
Security News
React's CRA deprecation announcement sparked community criticism over framework recommendations, leading to quick updates acknowledging build tools like Vite as valid alternatives.
Security News
Ransomware payment rates hit an all-time low in 2024 as law enforcement crackdowns, stronger defenses, and shifting policies make attacks riskier and less profitable.