Syntax Highlighting
Regex-based Highlighting
Syntax highlighting in Builder is performed by the GtkSourceView project. By providing an XML description of the syntax, GtkSourceView can automatically highlight the language of your choice. Thankfully, GtkSourceView already supports a large number of languages so the chances you need to add a new language is low. However, if you do, we suggest that you work with GtkSourceView to ensure that all applications, such as Gedit, benefit from your work.
Chances are you can find existing language syntax files on your system in /usr/share/gtksourceview-4/language-specs/
.
These language-spec files serve as a great example of how to make your own.
If it is not there, chances are there is already a .lang
file created but it has not yet been merged upstream.
Bundling Language Specs
Should you need to bundle your own language-spec, consider using GResources
to embed the language-spec within your plugin.
Then append the directory path of your language-specs to the GtkSource.LanguageManager
so it knows where to locate them.
from gi.repository import GtkSource
manager = GtkSource.LanguageManager.get_default()
paths = manager.get_search_path()
paths.append('resources:///plugins/my-plugin/language-specs/')
manager.set_search_path(paths)
Symantic Highlighting
If the language you are using provides an AST you may want to highlight additional information not easily decernable by a regex-based highlighter.
To simplify this, Builder provides the Ide.HighlightEngine
and Ide.Highlighter
abstractions.
The Ide.HighlightEngine
provides background updating of the document so that your Ide.Highlighter
implementation can focus on highlighting without dealing with performance impacts.
Out of simplicity, most Ide.Highlighter
implementations in Builder today use a simple word index and highlight based on the word.
However, this is not required if you prefer to do something more technical such as matching ranges to the AST.