1package s
2
3import (
4 . "github.com/alecthomas/chroma" // nolint
5 "github.com/alecthomas/chroma/lexers/internal"
6)
7
8// nolint
9
10// Scheme lexer.
11var SchemeLang = internal.Register(MustNewLexer(
12 &Config{
13 Name: "Scheme",
14 Aliases: []string{"scheme", "scm"},
15 Filenames: []string{"*.scm", "*.ss"},
16 MimeTypes: []string{"text/x-scheme", "application/x-scheme"},
17 },
18 Rules{
19 "root": {
20 {`;.*$`, CommentSingle, nil},
21 {`#\|`, CommentMultiline, Push("multiline-comment")},
22 {`#;\s*\(`, Comment, Push("commented-form")},
23 {`#!r6rs`, Comment, nil},
24 {`\s+`, Text, nil},
25 {`-?\d+\.\d+`, LiteralNumberFloat, nil},
26 {`-?\d+`, LiteralNumberInteger, nil},
27 {`"(\\\\|\\"|[^"])*"`, LiteralString, nil},
28 {`'[\w!$%&*+,/:<=>?@^~|-]+`, LiteralStringSymbol, nil},
29 {`#\\([()/'\"._!§$%& ?=+-]|[a-zA-Z0-9]+)`, LiteralStringChar, nil},
30 {`(#t|#f)`, NameConstant, nil},
31 {"('|#|`|,@|,|\\.)", Operator, nil},
32 {`(lambda |define |if |else |cond |and |or |case |let |let\* |letrec |begin |do |delay |set\! |\=\> |quote |quasiquote |unquote |unquote\-splicing |define\-syntax |let\-syntax |letrec\-syntax |syntax\-rules )`, Keyword, nil},
33 {`(?<='\()[\w!$%&*+,/:<=>?@^~|-]+`, NameVariable, nil},
34 {`(?<=#\()[\w!$%&*+,/:<=>?@^~|-]+`, NameVariable, nil},
35 {`(?<=\()(\* |\+ |\- |\/ |\< |\<\= |\= |\> |\>\= |abs |acos |angle |append |apply |asin |assoc |assq |assv |atan |boolean\? |caaaar |caaadr |caaar |caadar |caaddr |caadr |caar |cadaar |cadadr |cadar |caddar |cadddr |caddr |cadr |call\-with\-current\-continuation |call\-with\-input\-file |call\-with\-output\-file |call\-with\-values |call\/cc |car |cdaaar |cdaadr |cdaar |cdadar |cdaddr |cdadr |cdar |cddaar |cddadr |cddar |cdddar |cddddr |cdddr |cddr |cdr |ceiling |char\-\>integer |char\-alphabetic\? |char\-ci\<\=\? |char\-ci\<\? |char\-ci\=\? |char\-ci\>\=\? |char\-ci\>\? |char\-downcase |char\-lower\-case\? |char\-numeric\? |char\-ready\? |char\-upcase |char\-upper\-case\? |char\-whitespace\? |char\<\=\? |char\<\? |char\=\? |char\>\=\? |char\>\? |char\? |close\-input\-port |close\-output\-port |complex\? |cons |cos |current\-input\-port |current\-output\-port |denominator |display |dynamic\-wind |eof\-object\? |eq\? |equal\? |eqv\? |eval |even\? |exact\-\>inexact |exact\? |exp |expt |floor |for\-each |force |gcd |imag\-part |inexact\-\>exact |inexact\? |input\-port\? |integer\-\>char |integer\? |interaction\-environment |lcm |length |list |list\-\>string |list\-\>vector |list\-ref |list\-tail |list\? |load |log |magnitude |make\-polar |make\-rectangular |make\-string |make\-vector |map |max |member |memq |memv |min |modulo |negative\? |newline |not |null\-environment |null\? |number\-\>string |number\? |numerator |odd\? |open\-input\-file |open\-output\-file |output\-port\? |pair\? |peek\-char |port\? |positive\? |procedure\? |quotient |rational\? |rationalize |read |read\-char |real\-part |real\? |remainder |reverse |round |scheme\-report\-environment |set\-car\! |set\-cdr\! |sin |sqrt |string |string\-\>list |string\-\>number |string\-\>symbol |string\-append |string\-ci\<\=\? |string\-ci\<\? |string\-ci\=\? |string\-ci\>\=\? |string\-ci\>\? |string\-copy |string\-fill\! |string\-length |string\-ref |string\-set\! |string\<\=\? |string\<\? |string\=\? |string\>\=\? |string\>\? |string\? |substring |symbol\-\>string |symbol\? |tan |transcript\-off |transcript\-on |truncate |values |vector |vector\-\>list |vector\-fill\! |vector\-length |vector\-ref |vector\-set\! |vector\? |with\-input\-from\-file |with\-output\-to\-file |write |write\-char |zero\? )`, NameBuiltin, nil},
36 {`(?<=\()[\w!$%&*+,/:<=>?@^~|-]+`, NameFunction, nil},
37 {`[\w!$%&*+,/:<=>?@^~|-]+`, NameVariable, nil},
38 {`(\(|\))`, Punctuation, nil},
39 {`(\[|\])`, Punctuation, nil},
40 },
41 "multiline-comment": {
42 {`#\|`, CommentMultiline, Push()},
43 {`\|#`, CommentMultiline, Pop(1)},
44 {`[^|#]+`, CommentMultiline, nil},
45 {`[|#]`, CommentMultiline, nil},
46 },
47 "commented-form": {
48 {`\(`, Comment, Push()},
49 {`\)`, Comment, Pop(1)},
50 {`[^()]+`, Comment, nil},
51 },
52 },
53))