Swift.tmLanguage is a TextMate language grammar for the Swift programming language. It defines regex-based parsing rules so that code renderers can highlight Swift code using a semantic color scheme.
This grammar is used for syntax highlighting by:
- Visual Studio Code — as part of the built-in extension for basic language support, not in the full-featured
vscode-swift
extension - Shiki — via the
tm-grammars
package
(It was also used by GitHub Linguist until 2024.)
The language grammar is available in three formats:
- Swift.tmLanguage.yaml — the canonical copy intended for human editing
- Swift.tmLanguage.json — generated from the YAML
- Swift.tmLanguage — generated from the JSON
-
Run
yarn install
to install dependencies. -
After making changes to the YAML grammar, run
yarn build
to regenerate the.tmLanguage.json
and.tmLanguage
files. -
To test the grammar in VS Code, press F5 to load the current version of the
.tmLanguage
in a new window. After eachyarn build
, reload the window to load the updated.tmLanguage
. (If you have thevscode-swift
extension installed, you'll need to disable it so it doesn't override the scopes provided by the.tmLanguage
grammar.)
The Swift grammar was developed for years at textmate/swift.tmbundle, which is no longer actively maintained. Development of the grammar continues here.
This grammar is maintained by @jtbandes as a passion project. If you'd like to support past and future development, please consider making a donation. 💖
This project is licensed under the terms of the MIT license.