Commit 6a506e97 authored by Amy Qualls's avatar Amy Qualls

Apply light CTRT polish to syntax highlight page

This page had tasks that weren't broken out into subheadings; this
commit cleans up the language and breaks those tasks apart into
scannable chunks.
parent dc860cb9
...@@ -7,61 +7,67 @@ type: reference ...@@ -7,61 +7,67 @@ type: reference
# Syntax Highlighting **(FREE)** # Syntax Highlighting **(FREE)**
GitLab provides syntax highlighting on all files through the [Rouge](https://rubygems.org/gems/rouge) Ruby gem. It attempts to guess what language to use based on the file extension, which most of the time is sufficient. GitLab provides syntax highlighting on all files through the
[Rouge](https://rubygems.org/gems/rouge) Ruby gem. It attempts to guess what language
to use based on the file extension, which most of the time is sufficient.
The paths here are Git's built-in [`.gitattributes` interface](https://git-scm.com/docs/gitattributes).
NOTE: NOTE:
The [Web IDE](web_ide/index.md) and [Snippets](../snippets.md) use [Monaco Editor](https://microsoft.github.io/monaco-editor/) The [Web IDE](web_ide/index.md) and [Snippets](../snippets.md) use [Monaco Editor](https://microsoft.github.io/monaco-editor/)
for text editing, which internally uses the [Monarch](https://microsoft.github.io/monaco-editor/monarch.html) for text editing, which internally uses the [Monarch](https://microsoft.github.io/monaco-editor/monarch.html)
library for syntax highlighting. library for syntax highlighting.
<!-- vale gitlab.Spelling = NO --> ## Override syntax highlighting for a file type
If GitLab is guessing wrong, you can override its choice of language using the
`gitlab-language` attribute in `.gitattributes`. For example, if you are working in a Prolog
project and using the `.pl` file extension (which would normally be highlighted as Perl),
you can add the following to your `.gitattributes` file:
<!-- vale gitlab.Spelling = YES --> NOTE:
The Web IDE [does not support `.gitattribute` files](https://gitlab.com/gitlab-org/gitlab/-/issues/22014).
``` conf
*.pl gitlab-language=prolog
```
<!-- vale gitlab.Spelling = NO --> To override syntax highlighting for a file type:
When you check in and push that change, all `*.pl` files in your project are highlighted as Prolog. 1. If a `.gitattributes` file does not exist in the root directory of your project,
create a blank file with this name.
1. For each file type you want to modify, add a line to the `.gitattributes` file
declaring the file extension and your desired highlighting language:
<!-- vale gitlab.Spelling = YES --> ```conf
# This extension would normally receive Perl syntax highlighting
# but if we also use Prolog, we may want to override highlighting for
# files with this extension:
*.pl gitlab-language=prolog
```
The paths here are Git's built-in [`.gitattributes` interface](https://git-scm.com/docs/gitattributes). So, if you were to invent a file format called a `Nicefile` at the root of your project that used Ruby syntax, all you need is: 1. Commit, push, and merge your changes into your default branch.
``` conf After the changes merge into your [default branch](repository/branches/default.md),
/Nicefile gitlab-language=ruby all `*.pl` files in your project are highlighted in your preferred language.
```
To disable highlighting entirely, use `gitlab-language=text`. Lots more fun shenanigans are available through common gateway interface (CGI) options, such as: You can also extend the highlighting with common gateway interface (CGI) options, such as:
``` conf ``` conf
# json with erb in it # JSON file with .erb in it
/my-cool-file gitlab-language=erb?parent=json /my-cool-file gitlab-language=erb?parent=json
# an entire file of highlighting errors! # An entire file of highlighting errors!
/other-file gitlab-language=text?token=Error /other-file gitlab-language=text?token=Error
``` ```
These configurations only take effect when the `.gitattributes` ## Disable syntax highlighting for a file type
file is in your [default branch](repository/branches/default.md).
NOTE: To disable highlighting entirely for a file type, follow the instructions for overriding
The Web IDE does not support `.gitattribute` files, but it's [planned for a future release](https://gitlab.com/gitlab-org/gitlab/-/issues/22014). the highlighting for a file type, and use `gitlab-language=text`:
## Configure maximum file size for highlighting ```conf
# Disable syntax highlighting for this file type
*.module gitlab-language=text
```
You can configure the maximum size of the file to be highlighted. ## Configure maximum file size for highlighting
The file size is measured in kilobytes, and is set to a default of `512 KB`. Any file _over_ the file size is rendered in plain text. By default, GitLab renders any file larger than 512 KB in plain text. To change this value:
1. Open the [`gitlab.yml`](https://gitlab.com/gitlab-org/gitlab-foss/blob/master/config/gitlab.yml.example) configuration file. 1. Open the [`gitlab.yml`](https://gitlab.com/gitlab-org/gitlab-foss/blob/master/config/gitlab.yml.example)
configuration file for your project.
1. Add this section, replacing `maximum_text_highlight_size_kilobytes` with the value you want. 1. Add this section, replacing `maximum_text_highlight_size_kilobytes` with the value you want.
...@@ -72,3 +78,5 @@ The file size is measured in kilobytes, and is set to a default of `512 KB`. Any ...@@ -72,3 +78,5 @@ The file size is measured in kilobytes, and is set to a default of `512 KB`. Any
## https://docs.gitlab.com/ee/user/project/highlighting.html ## https://docs.gitlab.com/ee/user/project/highlighting.html
maximum_text_highlight_size_kilobytes: 512 maximum_text_highlight_size_kilobytes: 512
``` ```
1. Commit, push, and merge your changes into your default branch.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment