forked from forgejo/forgejo
Server-side syntax highlighting for all code (#12047)
* Server-side syntax hilighting for all code This PR does a few things: * Remove all traces of highlight.js * Use chroma library to provide fast syntax hilighting directly on the server * Provide syntax hilighting for diffs * Re-style both unified and split diffs views * Add custom syntax hilighting styling for both regular and arc-green Fixes #7729 Fixes #10157 Fixes #11825 Fixes #7728 Fixes #3872 Fixes #3682 And perhaps gets closer to #9553 * fix line marker * fix repo search * Fix single line select * properly load settings * npm uninstall highlight.js * review suggestion * code review * forgot to call function * fix test * Apply suggestions from code review suggestions from @silverwind thanks Co-authored-by: silverwind <me@silverwind.io> * code review * copy/paste error * Use const for highlight size limit * Update web_src/less/_repository.less Co-authored-by: Lauris BH <lauris@nix.lv> * update size limit to 1MB and other styling tweaks * fix highlighting for certain diff sections * fix test * add worker back as suggested Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
parent
ce5f2b9845
commit
af7ffaa279
336 changed files with 37293 additions and 769 deletions
66
vendor/github.com/alecthomas/chroma/lexers/r/r.go
generated
vendored
Normal file
66
vendor/github.com/alecthomas/chroma/lexers/r/r.go
generated
vendored
Normal file
|
@ -0,0 +1,66 @@
|
|||
package r
|
||||
|
||||
import (
|
||||
. "github.com/alecthomas/chroma" // nolint
|
||||
"github.com/alecthomas/chroma/lexers/internal"
|
||||
)
|
||||
|
||||
// R/S lexer.
|
||||
var R = internal.Register(MustNewLexer(
|
||||
&Config{
|
||||
Name: "R",
|
||||
Aliases: []string{"splus", "s", "r"},
|
||||
Filenames: []string{"*.S", "*.R", "*.r", ".Rhistory", ".Rprofile", ".Renviron"},
|
||||
MimeTypes: []string{"text/S-plus", "text/S", "text/x-r-source", "text/x-r", "text/x-R", "text/x-r-history", "text/x-r-profile"},
|
||||
},
|
||||
Rules{
|
||||
"comments": {
|
||||
{`#.*$`, CommentSingle, nil},
|
||||
},
|
||||
"valid_name": {
|
||||
{"(?:`[^`\\\\]*(?:\\\\.[^`\\\\]*)*`)|(?:(?:[a-zA-z]|[_.][^0-9])[\\w_.]*)", Name, nil},
|
||||
},
|
||||
"punctuation": {
|
||||
{`\[{1,2}|\]{1,2}|\(|\)|;|,`, Punctuation, nil},
|
||||
},
|
||||
"keywords": {
|
||||
{`(if|else|for|while|repeat|in|next|break|return|switch|function)(?![\w.])`, KeywordReserved, nil},
|
||||
},
|
||||
"operators": {
|
||||
{`<<?-|->>?|-|==|<=|>=|<|>|&&?|!=|\|\|?|\?`, Operator, nil},
|
||||
{`\*|\+|\^|/|!|%[^%]*%|=|~|\$|@|:{1,3}`, Operator, nil},
|
||||
},
|
||||
"builtin_symbols": {
|
||||
{`(NULL|NA(_(integer|real|complex|character)_)?|letters|LETTERS|Inf|TRUE|FALSE|NaN|pi|\.\.(\.|[0-9]+))(?![\w.])`, KeywordConstant, nil},
|
||||
{`(T|F)\b`, NameBuiltinPseudo, nil},
|
||||
},
|
||||
"numbers": {
|
||||
{`0[xX][a-fA-F0-9]+([pP][0-9]+)?[Li]?`, LiteralNumberHex, nil},
|
||||
{`[+-]?([0-9]+(\.[0-9]+)?|\.[0-9]+|\.)([eE][+-]?[0-9]+)?[Li]?`, LiteralNumber, nil},
|
||||
},
|
||||
"statements": {
|
||||
Include("comments"),
|
||||
{`\s+`, Text, nil},
|
||||
{`\'`, LiteralString, Push("string_squote")},
|
||||
{`\"`, LiteralString, Push("string_dquote")},
|
||||
Include("builtin_symbols"),
|
||||
Include("valid_name"),
|
||||
Include("numbers"),
|
||||
Include("keywords"),
|
||||
Include("punctuation"),
|
||||
Include("operators"),
|
||||
},
|
||||
"root": {
|
||||
{"((?:`[^`\\\\]*(?:\\\\.[^`\\\\]*)*`)|(?:(?:[a-zA-z]|[_.][^0-9])[\\w_.]*))\\s*(?=\\()", NameFunction, nil},
|
||||
Include("statements"),
|
||||
{`\{|\}`, Punctuation, nil},
|
||||
{`.`, Text, nil},
|
||||
},
|
||||
"string_squote": {
|
||||
{`([^\'\\]|\\.)*\'`, LiteralString, Pop(1)},
|
||||
},
|
||||
"string_dquote": {
|
||||
{`([^"\\]|\\.)*"`, LiteralString, Pop(1)},
|
||||
},
|
||||
},
|
||||
))
|
Loading…
Add table
Add a link
Reference in a new issue