Language Servers

For several programming languages, a language server offers information about the code to IDEs as long as they support communication via the language server protocol (LSP). The IDE can then offer the following services:

By providing a client for the language server protocol, Qt Creator can support the above features for several other programming languages besides C++. However, the client does not support language servers that require special handling.

Adding MIME Types for Language Servers

Qt Creator uses the MIME type of the file to determine which language server to request information from when you open a file for editing. Add new MIME types or file patterns to match language servers. If you do not set at least one MIME type or file pattern, no files will be sent to the language server. This is done to avoid unnecessary traffic and inaccurate information, as files are only sent to the language server if they are known to be handled by it. For more information about how Qt Creator uses MIME types, see Edit MIME types.

Adding Language Servers

Qt Creator adds a Python language server by default.

Also, it offers to install language servers for JSON and YAML files when you open them in the editor if it can find the NPM package manager on the computer.

{Prompt to install JSON language server}

Add a Java language server for Android development. For other languages, add generic stdIO language servers.

To add language servers, go to Preferences > Language Client and select Add.

{Language Client General preferences}

To enable a language server, select the checkbox next to the language server name and set server preferences.

To remove language servers from the list, select Delete.

Updating Python Language Server

Qt Creator offers to update the Python language server when you open a Python file in the editor.

{Message about updating Python Language Server}

To update the language server, select Update. To save your choice, select Always Update.

To skip updating and hide the message for future updates, select Never.

Supported Locator Filters

The locator enables you to browse not only files, but any items defined by locator filters. The language client plugin supports the following locator filters:

  • Locating symbols in the current project (:)
  • Locating symbols in the current document (.)
  • Locating class (c), enum, and function (m) definitions in your project

Reporting Issues

The language server client has been mostly tested with Python and C++. If problems arise when you try them or some other language, please select Help > Report Bug to report them in the Qt Project Bug Tracker. The reports should include Qt Creator console output with the environment variable QT_LOGGING_RULES=qtc.languageclient.*=true set.

See also How To: Manage Language Servers and Behavior.

Copyright © The Qt Company Ltd. and other contributors. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.