Variables

activeColorTheme:ColorTheme

The currently active color theme as configured in the settings. The active theme can be changed via the workbench.colorTheme setting.

read onlyactiveNotebookEditor:Null<NotebookEditor>

The currently active {@link NotebookEditor notebook editor} or undefined. The active editor is the one that currently has focus or, when none has focus, the one that has changed input most recently.

read onlyactiveTerminal:Null<Terminal>

The currently active terminal or undefined. The active terminal is the one that currently has focus or most recently had focus.

activeTextEditor:Null<TextEditor>

The currently active editor or undefined. The active editor is the one that currently has focus or, when none has focus, the one that has changed input most recently.

read onlyonDidChangeActiveColorTheme:Event<ColorTheme>

An {@link Event} which fires when the active color theme is changed or has changes.

read onlyonDidChangeActiveNotebookEditor:Event<Null<NotebookEditor>>

An {@link Event} which fires when the {@link window.activeNotebookEditor active notebook editor} has changed. Note that the event also fires when the active editor changes to undefined.

read onlyonDidChangeActiveTerminal:Null<Event<Terminal>>

An {@link Event} which fires when the {@link window.activeTerminal active terminal} has changed. Note that the event also fires when the active terminal changes to undefined.

read onlyonDidChangeActiveTextEditor:Event<Null<TextEditor>>

An {@link Event} which fires when the {@link window.activeTextEditor active editor} has changed. Note that the event also fires when the active editor changes to undefined.

read onlyonDidChangeNotebookEditorSelection:Event<NotebookEditorSelectionChangeEvent>

An {@link Event} which fires when the {@link NotebookEditor.selections notebook editor selections} have changed.

read onlyonDidChangeNotebookEditorVisibleRanges:Event<NotebookEditorVisibleRangesChangeEvent>

An {@link Event} which fires when the {@link NotebookEditor.visibleRanges notebook editor visible ranges} have changed.

read onlyonDidChangeTerminalShellIntegration:Event<TerminalShellIntegrationChangeEvent>

Fires when shell integration activates or one of its properties changes in a terminal.

read onlyonDidChangeTerminalState:Event<Terminal>

An {@link Event} which fires when a {@link Terminal.state terminal's state} has changed.

read onlyonDidChangeTextEditorOptions:Event<TextEditorOptionsChangeEvent>

An {@link Event} which fires when the options of an editor have changed.

read onlyonDidChangeTextEditorSelection:Event<TextEditorSelectionChangeEvent>

An {@link Event} which fires when the selection in an editor has changed.

read onlyonDidChangeTextEditorViewColumn:Event<TextEditorViewColumnChangeEvent>

An {@link Event} which fires when the view column of an editor has changed.

read onlyonDidChangeTextEditorVisibleRanges:Event<TextEditorVisibleRangesChangeEvent>

An {@link Event} which fires when the visible ranges of an editor has changed.

read onlyonDidChangeVisibleNotebookEditors:Event<ReadOnlyArray<NotebookEditor>>

An {@link Event} which fires when the {@link window.visibleNotebookEditors visible notebook editors} has changed.

read onlyonDidChangeVisibleTextEditors:Event<ReadOnlyArray<TextEditor>>

An {@link Event} which fires when the array of {@link window.visibleTextEditors visible editors} has changed.

read onlyonDidChangeWindowState:Event<WindowState>

An {@link Event} which fires when the focus or activity state of the current window changes. The value of the event represents whether the window is focused.

read onlyonDidCloseTerminal:Event<Terminal>

An {@link Event} which fires when a terminal is disposed.

read onlyonDidEndTerminalShellExecution:Event<TerminalShellExecutionEndEvent>

This will be fired when a terminal command is ended. This event will fire only when shell integration is activated for the terminal.

read onlyonDidOpenTerminal:Event<Terminal>

An {@link Event} which fires when a terminal has been created, either through the {@link window.createTerminal createTerminal} API or commands.

read onlyonDidStartTerminalShellExecution:Event<TerminalShellExecutionStartEvent>

This will be fired when a terminal command is started. This event will fire only when shell integration is activated for the terminal.

read onlystate:WindowState

Represents the current window's state.

read onlytabGroups:TabGroups

Represents the grid widget within the main editor area

read onlyterminals:ReadOnlyArray<Terminal>

The currently opened terminals or an empty array.

read onlyvisibleNotebookEditors:ReadOnlyArray<NotebookEditor>

The currently visible {@link NotebookEditor notebook editors} or an empty array.

visibleTextEditors:ReadOnlyArray<TextEditor>

The currently visible editors or an empty array.

Methods

createInputBox():InputBox

Creates a {@link InputBox} to let the user enter some text input.

Note that in many cases the more convenient {@link window.showInputBox} is easier to use. {@link window.createInputBox} should be used when {@link window.showInputBox} does not offer the required flexibility.

@link InputBox}.

Returns:

A new {

createOutputChannel(name:String, ?languageId:String):OutputChannel

createOutputChannel(name:String, options:{log:Bool}):LogOutputChannel

Creates a new {@link OutputChannel output channel} with the given name and language id If language id is not provided, then Log is used as default language id.

You can access the visible or active output channel as a {@link TextDocument text document} from {@link window.visibleTextEditors visible editors} or {@link window.activeTextEditor active editor} and use the language id to contribute language features like syntax coloring, code lens etc.,

Parameters:

name

Human-readable string which will be used to represent the channel in the UI.

languageId

The identifier of the language associated with the channel.

Returns:

A new output channel.

createQuickPick<T>():QuickPick<T>

Creates a {@link QuickPick} to let the user pick an item from a list of items of type T.

Note that in many cases the more convenient {@link window.showQuickPick} is easier to use. {@link window.createQuickPick} should be used when {@link window.showQuickPick} does not offer the required flexibility.

@link QuickPick}.

Returns:

A new {

createStatusBarItem(id:String, ?alignment:StatusBarAlignment, ?priority:Float):StatusBarItem

createStatusBarItem(?alignment:StatusBarAlignment, ?priority:Float):StatusBarItem

Creates a status bar {@link StatusBarItem item}.

Parameters:

id

The identifier of the item. Must be unique within the extension.

alignment

The alignment of the item.

priority

The priority of the item. Higher values mean the item should be shown more to the left.

Returns:

A new status bar item.

createTerminal(?name:String, ?shellPath:String, ?shellArgs:EitherType<ReadOnlyArray<String>, String>):Terminal

createTerminal(options:ExtensionTerminalOptions):Terminal

createTerminal(options:TerminalOptions):Terminal

Creates a {@link Terminal} with a backing shell process. The cwd of the terminal will be the workspace directory if it exists.

Parameters:

name

Optional human-readable string which will be used to represent the terminal in the UI.

shellPath

Optional path to a custom shell executable to be used in the terminal.

shellArgs

Optional args for the custom shell executable. A string can be used on Windows only which allows specifying shell args in command-line format.

Returns:

A new Terminal.

Throws:

When

running in an environment where a new process cannot be started.

createTextEditorDecorationType(options:DecorationRenderOptions):TextEditorDecorationType

Create a TextEditorDecorationType that can be used to add decorations to text editors.

Parameters:

options

Rendering options for the decoration type.

Returns:

A new decoration type instance.

createTreeView<T>(viewId:String, options:TreeViewOptions<T>):TreeView<T>

Create a {@link TreeView} for the view contributed using the extension point views. @link TreeView} @link TreeView}.

Parameters:

viewId

Id of the view contributed using the extension point views.

options

Options for creating the {

Returns:

a {

createWebviewPanel(viewType:String, title:String, showOptions:EitherType<ViewColumn, {viewColumn:ViewColumn, preserveFocus:Null<Bool>}>, ?options:Null<{retainContextWhenHidden:Null<Bool>, portMapping:Null<ReadOnlyArray<WebviewPortMapping>>, localResourceRoots:Null<ReadOnlyArray<Uri>>, enableScripts:Null<Bool>, enableForms:Null<Bool>, enableFindWidget:Null<Bool>, enableCommandUris:Null<EitherType<Bool, ReadOnlyArray<String>>>}>):WebviewPanel

Create and show a new webview panel.

Parameters:

viewType

Identifies the type of the webview panel.

title

Title of the panel.

showOptions

Where to show the webview in the editor. If preserveFocus is set, the new webview will not take focus.

options

Settings for the new panel.

Returns:

New webview panel.

registerCustomEditorProvider<T>(viewType:String, provider:EitherType<CustomTextEditorProvider, EitherType<CustomReadonlyEditorProvider<T>, CustomEditorProvider<T>>>, ?options:{webviewOptions:Null<WebviewPanelOptions>, supportsMultipleEditorsPerDocument:Null<Bool>}):Disposable

Register a provider for custom editors for the viewType contributed by the customEditors extension point.

When a custom editor is opened, an onCustomEditor:viewType activation event is fired. Your extension must register a {@linkcode CustomTextEditorProvider}, {@linkcode CustomReadonlyEditorProvider}, {@linkcode CustomEditorProvider}for viewType as part of activation.

Parameters:

viewType

Unique identifier for the custom editor provider. This should match the viewType from the customEditors contribution point.

provider

Provider that resolves custom editors.

options

Options for the provider.

Returns:

Disposable that unregisters the provider.

registerFileDecorationProvider(provider:FileDecorationProvider):Disposable

Register a file decoration provider.

@link FileDecorationProvider}. @link Disposable} that unregisters the provider.

Parameters:

provider

A {

Returns:

A {

registerTerminalLinkProvider<T>(provider:TerminalLinkProvider<T>):Disposable

Register provider that enables the detection and handling of links within the terminal.

Parameters:

provider

The provider that provides the terminal links.

Returns:

Disposable that unregisters the provider.

registerTerminalProfileProvider(id:String, provider:TerminalProfileProvider):Disposable

Registers a provider for a contributed terminal profile.

@link Disposable disposable} that unregisters the provider.

Parameters:

id

The ID of the contributed terminal profile.

provider

The terminal profile provider.

Returns:

A {

registerTreeDataProvider<T>(viewId:String, treeDataProvider:TreeDataProvider<T>):Disposable

Register a {@link TreeDataProvider} for the view contributed using the extension point views. This will allow you to contribute data to the {@link TreeView} and update if the data changes.

Note: To get access to the {@link TreeView} and perform operations on it, use {@link window.createTreeView createTreeView}.

@link TreeDataProvider} that provides tree data for the view @link Disposable disposable} that unregisters the {@link TreeDataProvider}.

Parameters:

viewId

Id of the view contributed using the extension point views.

treeDataProvider

A {

Returns:

A {

registerUriHandler(handler:UriHandler):Disposable

Registers a {@link UriHandler uri handler} capable of handling system-wide {@link Uri uris}. In case there are multiple windows open, the topmost window will handle the uri. A uri handler is scoped to the extension it is contributed from; it will only be able to handle uris which are directed to the extension itself. A uri must respect the following rules:

  • The uri-scheme must be vscode.env.uriScheme;
  • The uri-authority must be the extension id (e.g. my.extension);
  • The uri-path, -query and -fragment parts are arbitrary.

For example, if the my.extension extension registers a uri handler, it will only be allowed to handle uris with the prefix product-name://my.extension.

An extension can only register a single uri handler in its entire activation lifetime.

  • Note: There is an activation event onUri that fires when a uri directed for the current extension is about to be handled.

@link Disposable disposable} that unregisters the handler.

Parameters:

handler

The uri handler to register for this extension.

Returns:

A {

registerWebviewPanelSerializer<T>(viewType:String, serializer:WebviewPanelSerializer<T>):Disposable

Registers a webview panel serializer.

Extensions that support reviving should have an "onWebviewPanel:viewType" activation event and make sure that registerWebviewPanelSerializer is called during activation.

Only a single serializer may be registered at a time for a given viewType.

@link Disposable disposable} that unregisters the serializer.

Parameters:

viewType

Type of the webview panel that can be serialized.

serializer

Webview serializer.

Returns:

A {

registerWebviewViewProvider(viewId:String, provider:WebviewViewProvider, ?options:{webviewOptions:Null<{retainContextWhenHidden:Null<Bool>}>}):Disposable

Register a new provider for webview views.

Parameters:

viewId

Unique id of the view. This should match the id from the views contribution in the package.json.

provider

Provider for the webview views.

Returns:

Disposable that unregisters the provider.

setStatusBarMessage(text:String, hideAfterTimeout:Float):Disposable

setStatusBarMessage(text:String):Disposable

setStatusBarMessage(text:String, hideWhenDone:Thenable<Dynamic>):Disposable

Set a message to the status bar. This is a short hand for the more powerful status bar {@link window.createStatusBarItem items}.

@link StatusBarItem.text items}.

Parameters:

text

The message to show, supports icon substitution as in status bar {

hideAfterTimeout

Timeout in milliseconds after which the message will be disposed.

Returns:

A disposable which hides the status bar message.

showErrorMessage(message:String, items:Rest<String>):Thenable<Null<String>>

showErrorMessage<T>(message:String, options:MessageOptions, items:Rest<T>):Thenable<Null<T>>

showErrorMessage<T>(message:String, items:Rest<T>):Thenable<Null<T>>

showErrorMessage(message:String, options:MessageOptions, items:Rest<String>):Thenable<Null<String>>

Show an error message.

@link window.showInformationMessage showInformationMessage}

Parameters:

message

The message to show.

items

A set of items that will be rendered as actions in the message.

Returns:

A thenable that resolves to the selected item or undefined when being dismissed.

See also:

  • {

showInformationMessage<T>(message:String, items:Rest<T>):Thenable<Null<T>>

showInformationMessage<T>(message:String, options:MessageOptions, items:Rest<T>):Thenable<Null<T>>

Show an information message to users. Optionally provide an array of items which will be presented as clickable buttons.

Parameters:

message

The message to show.

items

A set of items that will be rendered as actions in the message.

Returns:

A thenable that resolves to the selected item or undefined when being dismissed.

showInputBox(?options:Null<InputBoxOptions>, ?token:Null<CancellationToken>):Thenable<Null<String>>

Opens an input box to ask the user for input.

The returned value will be undefined if the input box was canceled (e.g. pressing ESC). Otherwise the returned value will be the string typed by the user or an empty string if the user did not type anything but dismissed the input box with OK.

Parameters:

options

Configures the behavior of the input box.

token

A token that can be used to signal cancellation.

Returns:

A promise that resolves to a string the user provided or to undefined in case of dismissal.

showNotebookDocument(document:NotebookDocument, ?options:Null<NotebookDocumentShowOptions>):Thenable<NotebookEditor>

Show the given {@link NotebookDocument} in a {@link NotebookEditor notebook editor}.

@link NotebookDocumentShowOptions Editor options} to configure the behavior of showing the {@link NotebookEditor notebook editor}.

@link NotebookEditor notebook editor}.

Parameters:

document

A text document to be shown.

options

{

Returns:

A promise that resolves to an {

showOpenDialog(?options:Null<OpenDialogOptions>):Thenable<Null<Array<Uri>>>

Shows a file open dialog to the user which allows to select a file for opening-purposes.

Parameters:

options

Options that control the dialog.

Returns:

A promise that resolves to the selected resources or undefined.

showQuickPick(items:EitherType<ReadOnlyArray<String>, Thenable<ReadOnlyArray<String>>>, ?options:Null<QuickPickOptions>, ?token:Null<CancellationToken>):Thenable<Null<String>>

showQuickPick<T>(items:EitherType<ReadOnlyArray<T>, Thenable<ReadOnlyArray<T>>>, ?options:Null<QuickPickOptions>, ?token:Null<CancellationToken>):Thenable<Null<T>>

Shows a selection list allowing multiple selections.

Parameters:

items

An array of strings, or a promise that resolves to an array of strings.

options

Configures the behavior of the selection list.

token

A token that can be used to signal cancellation.

Returns:

A promise that resolves to the selected items or undefined.

inlineshowQuickPickMany<T>(items:EitherType<ReadOnlyArray<T>, Thenable<ReadOnlyArray<T>>>, ?options:Null<QuickPickOptions>, ?token:Null<CancellationToken>):Thenable<Null<Array<T>>>

Shows a selection list allowing multiple selections.

Parameters:

items

An array of items, or a promise that resolves to an array of items.

options

Configures the behavior of the selection list.

token

A token that can be used to signal cancellation.

Returns:

A promise that resolves to the selected items or undefined.

showSaveDialog(?options:Null<SaveDialogOptions>):Thenable<Null<Uri>>

Shows a file save dialog to the user which allows to select a file for saving-purposes.

Parameters:

options

Options that control the dialog.

Returns:

A promise that resolves to the selected resource or undefined.

showTextDocument(document:TextDocument, ?column:ViewColumn, ?preserveFocus:Bool):Thenable<TextEditor>

showTextDocument(document:TextDocument, ?options:Null<TextDocumentShowOptions>):Thenable<TextEditor>

showTextDocument(uri:Uri, ?options:Null<TextDocumentShowOptions>):Thenable<TextEditor>

Show the given document in a text editor. A {@link ViewColumn column} can be provided to control where the editor is being shown. Might change the {@link window.activeTextEditor active editor}.

@link TextEditor editor} should be shown. The default is the {@link ViewColumn.Active active}. Columns that do not exist will be created as needed up to the maximum of {@linkcode ViewColumn.Nine}. Use {@linkcode ViewColumn.Beside} to open the editor to the side of the currently active one. @link TextEditor editor}.

Parameters:

document

A text document to be shown.

column

A view column in which the {

preserveFocus

When true the editor will not take focus.

Returns:

A promise that resolves to an {

showWarningMessage(message:String, items:Rest<String>):Thenable<Null<String>>

showWarningMessage<T>(message:String, options:MessageOptions, items:Rest<T>):Thenable<Null<T>>

showWarningMessage<T>(message:String, items:Rest<T>):Thenable<Null<T>>

showWarningMessage(message:String, options:MessageOptions, items:Rest<String>):Thenable<Null<String>>

Show a warning message.

@link window.showInformationMessage showInformationMessage}

Parameters:

message

The message to show.

items

A set of items that will be rendered as actions in the message.

Returns:

A thenable that resolves to the selected item or undefined when being dismissed.

See also:

  • {

showWorkspaceFolderPick(?options:Null<WorkspaceFolderPickOptions>):Thenable<Null<WorkspaceFolder>>

Shows a selection list of {@link workspace.workspaceFolders workspace folders} to pick from. Returns undefined if no folder is open.

Parameters:

options

Configures the behavior of the workspace folder list.

Returns:

A promise that resolves to the workspace folder or undefined.

withProgress<R>(options:ProgressOptions, task:(Progress<{message:Null<String>, increment:Null<Float>}>, CancellationToken) ‑> Thenable<R>):Thenable<R>

Show progress in the editor. Progress is shown while running the given callback and while the promise it returned isn't resolved nor rejected. The location at which progress should show (and other details) is defined via the passed {@linkcode ProgressOptions}.

@linkcode ProgressOptions}-object describing the options to use for showing progress, like its location @link Progress}-object.

To report discrete progress, use increment to indicate how much work has been completed. Each call with a increment value will be summed up and reflected as overall progress until 100% is reached (a value of e.g. 10 accounts for 10% of work done). Note that currently only ProgressLocation.Notification is capable of showing discrete progress.

To monitor if the operation has been cancelled by the user, use the provided {@linkcode CancellationToken}. Note that currently only ProgressLocation.Notification is supporting to show a cancel button to cancel the long running operation.

Parameters:

options

A {

task

A callback returning a promise. Progress state can be reported with the provided {

Returns:

The thenable the task-callback returned.

withScmProgress<R>(task:Progress<Float> ‑> Thenable<R>):Thenable<R>

Deprecated: "Use `withProgress` instead."
Deprecated:

Use withProgress instead.

Show progress in the Source Control viewlet while running the given callback and while its returned promise isn't resolve or rejected.

@link Progress}-object.

Parameters:

task

A callback returning a promise. Progress increments can be reported with the provided {

Returns:

The thenable the task did return.