mirror of
https://github.com/cheat/cheat.git
synced 2024-11-27 00:11:36 +01:00
117 lines
5.1 KiB
Go
117 lines
5.1 KiB
Go
package s
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
. "github.com/alecthomas/chroma" // nolint
|
|
"github.com/alecthomas/chroma/lexers/internal"
|
|
)
|
|
|
|
// Scala lexer.
|
|
var Scala = internal.Register(MustNewLazyLexer(
|
|
&Config{
|
|
Name: "Scala",
|
|
Aliases: []string{"scala"},
|
|
Filenames: []string{"*.scala"},
|
|
MimeTypes: []string{"text/x-scala"},
|
|
DotAll: true,
|
|
},
|
|
scalaRules,
|
|
))
|
|
|
|
func scalaRules() Rules {
|
|
var (
|
|
scalaOp = "[-~\\^\\*!%&\\\\<>\\|+=:/?@\xa6-\xa7\xa9\xac\xae\xb0-\xb1\xb6\xd7\xf7\u03f6\u0482\u0606-\u0608\u060e-\u060f\u06e9\u06fd-\u06fe\u07f6\u09fa\u0b70\u0bf3-\u0bf8\u0bfa\u0c7f\u0cf1-\u0cf2\u0d79\u0f01-\u0f03\u0f13-\u0f17\u0f1a-\u0f1f\u0f34\u0f36\u0f38\u0fbe-\u0fc5\u0fc7-\u0fcf\u109e-\u109f\u1360\u1390-\u1399\u1940\u19e0-\u19ff\u1b61-\u1b6a\u1b74-\u1b7c\u2044\u2052\u207a-\u207c\u208a-\u208c\u2100-\u2101\u2103-\u2106\u2108-\u2109\u2114\u2116-\u2118\u211e-\u2123\u2125\u2127\u2129\u212e\u213a-\u213b\u2140-\u2144\u214a-\u214d\u214f\u2190-\u2328\u232b-\u244a\u249c-\u24e9\u2500-\u2767\u2794-\u27c4\u27c7-\u27e5\u27f0-\u2982\u2999-\u29d7\u29dc-\u29fb\u29fe-\u2b54\u2ce5-\u2cea\u2e80-\u2ffb\u3004\u3012-\u3013\u3020\u3036-\u3037\u303e-\u303f\u3190-\u3191\u3196-\u319f\u31c0-\u31e3\u3200-\u321e\u322a-\u3250\u3260-\u327f\u328a-\u32b0\u32c0-\u33ff\u4dc0-\u4dff\ua490-\ua4c6\ua828-\ua82b\ufb29\ufdfd\ufe62\ufe64-\ufe66\uff0b\uff1c-\uff1e\uff5c\uff5e\uffe2\uffe4\uffe8-\uffee\ufffc-\ufffd]+"
|
|
scalaUpper = `[\\$_\p{Lu}]`
|
|
scalaLetter = `[\\$_\p{L}]`
|
|
scalaIDRest = fmt.Sprintf(`%s(?:%s|[0-9])*(?:(?<=_)%s)?`, scalaLetter, scalaLetter, scalaOp)
|
|
)
|
|
|
|
return Rules{
|
|
"root": {
|
|
{`(class|trait|object)(\s+)`, ByGroups(Keyword, Text), Push("class")},
|
|
{`[^\S\n]+`, Text, nil},
|
|
{`//.*?\n`, CommentSingle, nil},
|
|
{`/\*`, CommentMultiline, Push("comment")},
|
|
{`@` + scalaIDRest, NameDecorator, nil},
|
|
{`(abstract|ca(?:se|tch)|d(?:ef|o)|e(?:lse|xtends)|f(?:inal(?:ly)?|or(?:Some)?)|i(?:f|mplicit)|lazy|match|new|override|pr(?:ivate|otected)|re(?:quires|turn)|s(?:ealed|uper)|t(?:h(?:is|row)|ry)|va[lr]|w(?:hile|ith)|yield)\b|(<[%:-]|=>|>:|[#=@_⇒←])(\b|(?=\s)|$)`, Keyword, nil},
|
|
{`:(?!` + scalaOp + `%s)`, Keyword, Push("type")},
|
|
{fmt.Sprintf("%s%s\\b", scalaUpper, scalaIDRest), NameClass, nil},
|
|
{`(true|false|null)\b`, KeywordConstant, nil},
|
|
{`(import|package)(\s+)`, ByGroups(Keyword, Text), Push("import")},
|
|
{`(type)(\s+)`, ByGroups(Keyword, Text), Push("type")},
|
|
{`""".*?"""(?!")`, LiteralString, nil},
|
|
{`"(\\\\|\\"|[^"])*"`, LiteralString, nil},
|
|
{`'\\.'|'[^\\]'|'\\u[0-9a-fA-F]{4}'`, LiteralStringChar, nil},
|
|
{"'" + scalaIDRest, TextSymbol, nil},
|
|
{`[fs]"""`, LiteralString, Push("interptriplestring")},
|
|
{`[fs]"`, LiteralString, Push("interpstring")},
|
|
{`raw"(\\\\|\\"|[^"])*"`, LiteralString, nil},
|
|
{scalaIDRest, Name, nil},
|
|
{"`[^`]+`", Name, nil},
|
|
{`\[`, Operator, Push("typeparam")},
|
|
{`[(){};,.#]`, Operator, nil},
|
|
{scalaOp, Operator, nil},
|
|
{`([0-9][0-9]*\.[0-9]*|\.[0-9]+)([eE][+-]?[0-9]+)?[fFdD]?`, LiteralNumberFloat, nil},
|
|
{`0x[0-9a-fA-F]+`, LiteralNumberHex, nil},
|
|
{`[0-9]+L?`, LiteralNumberInteger, nil},
|
|
{`\n`, Text, nil},
|
|
},
|
|
"class": {
|
|
{fmt.Sprintf("(%s|%s|`[^`]+`)(\\s*)(\\[)", scalaIDRest, scalaOp), ByGroups(NameClass, Text, Operator), Push("typeparam")},
|
|
{`\s+`, Text, nil},
|
|
{`\{`, Operator, Pop(1)},
|
|
{`\(`, Operator, Pop(1)},
|
|
{`//.*?\n`, CommentSingle, Pop(1)},
|
|
{fmt.Sprintf("%s|%s|`[^`]+`", scalaIDRest, scalaOp), NameClass, Pop(1)},
|
|
},
|
|
"type": {
|
|
{`\s+`, Text, nil},
|
|
{`<[%:]|>:|[#_]|forSome|type`, Keyword, nil},
|
|
{`([,);}]|=>|=|⇒)(\s*)`, ByGroups(Operator, Text), Pop(1)},
|
|
{`[({]`, Operator, Push()},
|
|
{fmt.Sprintf("((?:%s|%s|`[^`]+`)(?:\\.(?:%s|%s|`[^`]+`))*)(\\s*)(\\[)", scalaIDRest, scalaOp, scalaIDRest, scalaOp), ByGroups(KeywordType, Text, Operator), Push("#pop", "typeparam")},
|
|
{fmt.Sprintf("((?:%s|%s|`[^`]+`)(?:\\.(?:%s|%s|`[^`]+`))*)(\\s*)$", scalaIDRest, scalaOp, scalaIDRest, scalaOp), ByGroups(KeywordType, Text), Pop(1)},
|
|
{`//.*?\n`, CommentSingle, Pop(1)},
|
|
{fmt.Sprintf("\\.|%s|%s|`[^`]+`", scalaIDRest, scalaOp), KeywordType, nil},
|
|
},
|
|
"typeparam": {
|
|
{`[\s,]+`, Text, nil},
|
|
{`<[%:]|=>|>:|[#_⇒]|forSome|type`, Keyword, nil},
|
|
{`([\])}])`, Operator, Pop(1)},
|
|
{`[(\[{]`, Operator, Push()},
|
|
{fmt.Sprintf("\\.|%s|%s|`[^`]+`", scalaIDRest, scalaOp), KeywordType, nil},
|
|
},
|
|
"comment": {
|
|
{`[^/*]+`, CommentMultiline, nil},
|
|
{`/\*`, CommentMultiline, Push()},
|
|
{`\*/`, CommentMultiline, Pop(1)},
|
|
{`[*/]`, CommentMultiline, nil},
|
|
},
|
|
"import": {
|
|
{fmt.Sprintf("(%s|\\.)+", scalaIDRest), NameNamespace, Pop(1)},
|
|
},
|
|
"interpstringcommon": {
|
|
{`[^"$\\]+`, LiteralString, nil},
|
|
{`\$\$`, LiteralString, nil},
|
|
{`\$` + scalaLetter + `(?:` + scalaLetter + `|\d)*`, LiteralStringInterpol, nil},
|
|
{`\$\{`, LiteralStringInterpol, Push("interpbrace")},
|
|
{`\\.`, LiteralString, nil},
|
|
},
|
|
"interptriplestring": {
|
|
{`"""(?!")`, LiteralString, Pop(1)},
|
|
{`"`, LiteralString, nil},
|
|
Include("interpstringcommon"),
|
|
},
|
|
"interpstring": {
|
|
{`"`, LiteralString, Pop(1)},
|
|
Include("interpstringcommon"),
|
|
},
|
|
"interpbrace": {
|
|
{`\}`, LiteralStringInterpol, Pop(1)},
|
|
{`\{`, LiteralStringInterpol, Push()},
|
|
Include("root"),
|
|
},
|
|
}
|
|
}
|