/godot-vscode-plugin

Godot development tools for VSCode

Primary LanguageTypeScriptMIT LicenseMIT

Godot Tools

A complete set of tools to code games with Godot Engine in Visual Studio Code.

IMPORTANT NOTE: Versions 1.0.0 and later of this extension only support Godot 3.2 or later.

Features

The extension comes with a wealth of features to make your Godot programming experience as comfortable as possible:

  • Syntax highlighting for the GDScript (.gd) language
  • Syntax highlighting for the .tscn and .tres scene formats
  • Syntax highlighting for the .gdshader shader format
  • Full typed GDScript support
  • Optional "Smart Mode" to improve productivity with dynamically typed scripts
  • Function definitions and documentation display on hover (see image below)
  • Rich autocompletion
  • Switch from a .gd file to the related .tscn file (default keybind is alt+o)
  • In-editor Scene Preview
  • Display script warnings and errors
  • Ctrl + click on a variable or method call to jump to its definition
  • Full documentation of the Godot Engine's API supported (select Godot Tools: List native classes of Godot in the Command Palette)
  • Run a Godot project from VS Code
  • Debug your GDScript-based Godot project from VS Code with breakpoints, step-in/out/over, variable watch, call stack, and active scene tree

Showing the documentation on hover feature

Download

To install from GitHub Releases or a development build, see Install from a VSIX in the Visual Studio Code documentation.

Available commands

The extension adds a few entries to the VS Code Command Palette under "Godot Tools":

  • Open workspace with Godot editor
  • Run the workspace as a Godot project
  • List Godot's native classes

Configuration

Godot

If you like this extension, you can set VS Code as your default script editor for Godot by following these steps:

  1. Open the Editor Settings
  2. Select Text Editor > External
  3. Make sure the Use External Editor box is checked
  4. Fill Exec Path with the path to your VS Code executable
    • On macOS, this executable is typically located at: /Applications/Visual Studio Code.app/Contents/MacOS/Electron
  5. Fill Exec Flags with {project} --goto {file}:{line}:{col}

VS Code

Settings

You can use the following settings to configure Godot Tools:

  • godotTools.editorPath.godot3
  • godotTools.editorPath.godot4

The path to the Godot editor executable. Under Mac OS, this is the executable inside of Godot.app.

  • godotTools.lsp.headless

When using Godot >3.6 or >4.2, Headless LSP mode is available. In Headless mode, the extension will attempt to launch a windowless instance of the Godot editor to use as its Language Server.

GDScript Debugger

The debugger is for GDScript projects. To debug C# projects, use C# Tools for Godot.

To configure the GDScript debugger:

  1. Open the command palette (by pressing F1):
  2. >View: Show Run and Debug
  3. Click on "create a launch.json file"

Run and Debug View

  1. Select the Debug Godot configuration.
  2. Change any relevant settings.
  3. Press F5 to launch.

Configurations

Required

None: seriously. This is valid debugging configuration:

{ "name": "Launch", "type": "godot" }

Optional

project: Absolute path to a directory with a project.godot file. Defaults to the currently open VSCode workspace with ${workspaceFolder}. port: The port number for the Godot remote debugger to use. address: The IP address for the Godot remote debugger to use. scene_file: Path to a scene file to run instead of the projects 'main scene'. editor_path: Absolute path to the Godot executable to be used for this debug profile. additional_options: Additional command line arguments.

Usage

  • Stacktrace and variable dumps are the same as any regular debugger
  • The active scene tree can be refreshed with the Refresh icon in the top right.
  • Nodes can be brought to the fore in the Inspector by clicking the Eye icon next to nodes in the active scene tree, or Objects in the inspector.
  • You can edit integers, floats, strings, and booleans within the inspector by clicking the pencil icon next to each.

Showing the debugger in action

Issues and contributions

The Godot Tools extension is an open source project from the Godot organization. Feel free to open issues and create pull requests anytime.

See the full changelog for the latest changes.

Building from source

Requirements

Process

  1. Open a command prompt/terminal and browse to the location of this repository on your local filesystem.
  2. Download dependencies by using the command npm install
  3. When done, package a VSIX file by using the command npm run package.
  4. Install it by opening Visual Studio Code, opening the Extensions tab, clicking on the More actions (...) button in the top right, and choose Install from VSIX... and find the compiled VSIX file.

When developing for the extension, you can open this project in Visual Studio Code and debug the extension by using the Run Extension launch configuration instead of going through steps 3 and 4. It will launch a new instance of Visual Studio Code that has the extension running. You can then open a Godot project folder and debug the extension or GDScript debugger.

FAQ

Why does it fail to connect to the language server?

  • Godot 3.2 or later is required.
  • For Godot 4, the gdscript_lsp_server_port setting must be changed to 6005 to match the Godot editor's new default language server port number.
  • Make sure to open the project in the Godot editor first. If you opened the editor after opening VS Code, you can click the Retry button in the bottom-right corner in VS Code.

Why isn't IntelliSense displaying script members?

  • GDScript is a dynamically typed script language. The language server can't infer all variable types.
  • To increase the number of results displayed, open the Editor Settings, go to the Language Server section then check Enable Smart Resolve.