rouge 3.23.0 → 3.25.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/rouge.rb +1 -0
- data/lib/rouge/cli.rb +32 -2
- data/lib/rouge/demos/email +11 -0
- data/lib/rouge/demos/j +12 -0
- data/lib/rouge/formatters/html_line_highlighter.rb +24 -0
- data/lib/rouge/formatters/html_line_table.rb +1 -3
- data/lib/rouge/formatters/html_linewise.rb +2 -3
- data/lib/rouge/lexer.rb +38 -20
- data/lib/rouge/lexers/apex.rb +9 -7
- data/lib/rouge/lexers/batchfile.rb +2 -1
- data/lib/rouge/lexers/cpp.rb +1 -1
- data/lib/rouge/lexers/docker.rb +1 -1
- data/lib/rouge/lexers/elm.rb +5 -5
- data/lib/rouge/lexers/email.rb +39 -0
- data/lib/rouge/lexers/ghc_core.rb +2 -1
- data/lib/rouge/lexers/graphql.rb +1 -1
- data/lib/rouge/lexers/http.rb +8 -2
- data/lib/rouge/lexers/isbl.rb +2 -2
- data/lib/rouge/lexers/j.rb +244 -0
- data/lib/rouge/lexers/janet.rb +9 -8
- data/lib/rouge/lexers/javascript.rb +8 -2
- data/lib/rouge/lexers/jsl.rb +1 -1
- data/lib/rouge/lexers/jsonnet.rb +4 -3
- data/lib/rouge/lexers/jsp.rb +2 -3
- data/lib/rouge/lexers/kotlin.rb +5 -4
- data/lib/rouge/lexers/opentype_feature_file.rb +0 -1
- data/lib/rouge/lexers/perl.rb +6 -4
- data/lib/rouge/lexers/powershell.rb +39 -29
- data/lib/rouge/lexers/q.rb +1 -1
- data/lib/rouge/lexers/rust.rb +3 -2
- data/lib/rouge/lexers/smarty.rb +1 -1
- data/lib/rouge/lexers/velocity.rb +1 -1
- data/lib/rouge/lexers/wollok.rb +0 -1
- data/lib/rouge/regex_lexer.rb +56 -1
- data/lib/rouge/version.rb +1 -1
- metadata +7 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 35d2eb9627935d1f4e510d66263bddb55773667d8a441677019a377abaf3784e
|
4
|
+
data.tar.gz: 04370e4428e5f4c30a552d455bbf5655beeae8bf3ddc68db09ba0fbf76fee3e9
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: fc847dd05c6d47cdbcc4296b60594faf8477b1c143e8f303c84a09bfbd88345baa5dbe19e4238ef6a37c79e59809616f649679070faf17f556838ce874cb95b9
|
7
|
+
data.tar.gz: 272f4948d1935e9e9c1eaae8e5230e5db42933dcf1e2130dad009d6d3e4c57fee656b4aead64d6933cadf836bd7d82287fbc8193032c1af7ebf21e53fc7fb403
|
data/lib/rouge.rb
CHANGED
@@ -83,6 +83,7 @@ Rouge.load_file 'formatters/html_table'
|
|
83
83
|
Rouge.load_file 'formatters/html_pygments'
|
84
84
|
Rouge.load_file 'formatters/html_legacy'
|
85
85
|
Rouge.load_file 'formatters/html_linewise'
|
86
|
+
Rouge.load_file 'formatters/html_line_highlighter'
|
86
87
|
Rouge.load_file 'formatters/html_line_table'
|
87
88
|
Rouge.load_file 'formatters/html_inline'
|
88
89
|
Rouge.load_file 'formatters/terminal256'
|
data/lib/rouge/cli.rb
CHANGED
@@ -44,6 +44,7 @@ module Rouge
|
|
44
44
|
yield %||
|
45
45
|
yield %|where <command> is one of:|
|
46
46
|
yield %| highlight #{Highlight.desc}|
|
47
|
+
yield %| debug #{Debug.desc}|
|
47
48
|
yield %| help #{Help.desc}|
|
48
49
|
yield %| style #{Style.desc}|
|
49
50
|
yield %| list #{List.desc}|
|
@@ -104,6 +105,8 @@ module Rouge
|
|
104
105
|
Help
|
105
106
|
when 'highlight', 'hi'
|
106
107
|
Highlight
|
108
|
+
when 'debug'
|
109
|
+
Debug
|
107
110
|
when 'style'
|
108
111
|
Style
|
109
112
|
when 'list'
|
@@ -215,7 +218,7 @@ module Rouge
|
|
215
218
|
end
|
216
219
|
end
|
217
220
|
|
218
|
-
def self.
|
221
|
+
def self.parse_opts(argv)
|
219
222
|
opts = {
|
220
223
|
:formatter => supports_truecolor? ? 'terminal-truecolor' : 'terminal256',
|
221
224
|
:theme => 'thankful_eyes',
|
@@ -256,7 +259,11 @@ module Rouge
|
|
256
259
|
end
|
257
260
|
end
|
258
261
|
|
259
|
-
|
262
|
+
opts
|
263
|
+
end
|
264
|
+
|
265
|
+
def self.parse(argv)
|
266
|
+
new(parse_opts(argv))
|
260
267
|
end
|
261
268
|
|
262
269
|
def input_stream
|
@@ -344,6 +351,29 @@ module Rouge
|
|
344
351
|
end
|
345
352
|
end
|
346
353
|
|
354
|
+
class Debug < Highlight
|
355
|
+
def self.desc
|
356
|
+
end
|
357
|
+
|
358
|
+
def self.doc
|
359
|
+
return enum_for(:doc) unless block_given?
|
360
|
+
|
361
|
+
yield %|usage: rougify debug [<options>]|
|
362
|
+
yield %||
|
363
|
+
yield %|Debug a lexer. Similar options to `rougify highlight`, but|
|
364
|
+
yield %|defaults to the `null` formatter, and ensures the `debug`|
|
365
|
+
yield %|option is enabled, to print debugging information to stdout.|
|
366
|
+
end
|
367
|
+
|
368
|
+
def self.parse_opts(argv)
|
369
|
+
out = super(argv)
|
370
|
+
out[:lexer_opts]['debug'] = '1'
|
371
|
+
out[:formatter] = 'null'
|
372
|
+
|
373
|
+
out
|
374
|
+
end
|
375
|
+
end
|
376
|
+
|
347
377
|
class Style < CLI
|
348
378
|
def self.desc
|
349
379
|
"print CSS styles"
|
@@ -0,0 +1,11 @@
|
|
1
|
+
From: Me <me@example.com>
|
2
|
+
To: You <you@example.com>
|
3
|
+
Date: Tue, 21 Jul 2020 15:14:03 +0000
|
4
|
+
Subject: A very important message
|
5
|
+
|
6
|
+
> Please investigate. Thank you.
|
7
|
+
|
8
|
+
I have investigated.
|
9
|
+
|
10
|
+
--
|
11
|
+
This message is highly confidential and will self-destruct.
|
data/lib/rouge/demos/j
ADDED
@@ -0,0 +1,12 @@
|
|
1
|
+
NB. Procedural programming
|
2
|
+
fizzbuzz=: monad define
|
3
|
+
for_i. >:i.y do.
|
4
|
+
if. 0 = 15 | i do. echo'FizzBuzz'
|
5
|
+
elseif. 0 = 3 | i do. echo'Fizz'
|
6
|
+
elseif. 0 = 5 | i do. echo'Buzz'
|
7
|
+
else. echo i
|
8
|
+
end.
|
9
|
+
end.
|
10
|
+
)
|
11
|
+
NB. Loopless programming
|
12
|
+
fizzbuzz=: echo@(, ::] ('Fizz' ; 'Buzz') ;@#~ 0 = 3 5&|)@>:@i.
|
@@ -0,0 +1,24 @@
|
|
1
|
+
# -*- coding: utf-8 -*- #
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
module Rouge
|
5
|
+
module Formatters
|
6
|
+
class HTMLLineHighlighter < Formatter
|
7
|
+
tag 'html_line_highlighter'
|
8
|
+
|
9
|
+
def initialize(delegate, opts = {})
|
10
|
+
@delegate = delegate
|
11
|
+
@highlight_line_class = opts.fetch(:highlight_line_class, 'hll')
|
12
|
+
@highlight_lines = opts[:highlight_lines] || []
|
13
|
+
end
|
14
|
+
|
15
|
+
def stream(tokens)
|
16
|
+
token_lines(tokens).with_index(1) do |line_tokens, lineno|
|
17
|
+
line = %(#{@delegate.format(line_tokens)}\n)
|
18
|
+
line = %(<span class="#{@highlight_line_class}">#{line}</span>) if @highlight_lines.include? lineno
|
19
|
+
yield line
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
end
|
@@ -32,10 +32,8 @@ module Rouge
|
|
32
32
|
end
|
33
33
|
|
34
34
|
def stream(tokens, &b)
|
35
|
-
lineno = @start_line - 1
|
36
35
|
buffer = [%(<table class="#@table_class"><tbody>)]
|
37
|
-
token_lines(tokens) do |line_tokens|
|
38
|
-
lineno += 1
|
36
|
+
token_lines(tokens).with_index(@start_line) do |line_tokens, lineno|
|
39
37
|
buffer << %(<tr id="#{sprintf @line_id, lineno}" class="#@line_class">)
|
40
38
|
buffer << %(<td class="#@gutter_class gl" )
|
41
39
|
buffer << %(style="-moz-user-select: none;-ms-user-select: none;)
|
@@ -11,9 +11,8 @@ module Rouge
|
|
11
11
|
end
|
12
12
|
|
13
13
|
def stream(tokens, &b)
|
14
|
-
|
15
|
-
|
16
|
-
yield %(<#{@tag_name} class="#{sprintf @class_format, lineno += 1}">)
|
14
|
+
token_lines(tokens).with_index(1) do |line_tokens, lineno|
|
15
|
+
yield %(<#{@tag_name} class="#{sprintf @class_format, lineno}">)
|
17
16
|
@formatter.stream(line_tokens) {|formatted| yield formatted }
|
18
17
|
yield %(\n</#{@tag_name}>)
|
19
18
|
end
|
data/lib/rouge/lexer.rb
CHANGED
@@ -38,28 +38,15 @@ module Rouge
|
|
38
38
|
registry[name.to_s]
|
39
39
|
end
|
40
40
|
|
41
|
-
#
|
42
|
-
#
|
43
|
-
#
|
44
|
-
#
|
45
|
-
# Lexer.find_fancy('erb?parent=tex')
|
46
|
-
#
|
47
|
-
# * You can pass the special name 'guess' so we guess for you,
|
48
|
-
# and you can pass a second argument of the code to guess by
|
49
|
-
#
|
50
|
-
# Lexer.find_fancy('guess', "#!/bin/bash\necho Hello, world")
|
41
|
+
# Same as ::find_fancy, except instead of returning an instantiated
|
42
|
+
# lexer, returns a pair of [lexer_class, options], so that you can
|
43
|
+
# modify or provide additional options to the lexer.
|
51
44
|
#
|
52
|
-
#
|
53
|
-
|
54
|
-
#
|
55
|
-
# This is used in the Redcarpet plugin as well as Rouge's own
|
56
|
-
# markdown lexer for highlighting internal code blocks.
|
57
|
-
#
|
58
|
-
def find_fancy(str, code=nil, additional_options={})
|
59
|
-
|
45
|
+
# Please note: the lexer class might be nil!
|
46
|
+
def lookup_fancy(str, code=nil, default_options={})
|
60
47
|
if str && !str.include?('?') && str != 'guess'
|
61
48
|
lexer_class = find(str)
|
62
|
-
return lexer_class
|
49
|
+
return [lexer_class, default_options]
|
63
50
|
end
|
64
51
|
|
65
52
|
name, opts = str ? str.split('?', 2) : [nil, '']
|
@@ -75,7 +62,7 @@ module Rouge
|
|
75
62
|
[ k.to_s, val ]
|
76
63
|
end
|
77
64
|
|
78
|
-
opts =
|
65
|
+
opts = default_options.merge(Hash[opts])
|
79
66
|
|
80
67
|
lexer_class = case name
|
81
68
|
when 'guess', nil
|
@@ -84,6 +71,29 @@ module Rouge
|
|
84
71
|
self.find(name)
|
85
72
|
end
|
86
73
|
|
74
|
+
[lexer_class, opts]
|
75
|
+
end
|
76
|
+
|
77
|
+
# Find a lexer, with fancy shiny features.
|
78
|
+
#
|
79
|
+
# * The string you pass can include CGI-style options
|
80
|
+
#
|
81
|
+
# Lexer.find_fancy('erb?parent=tex')
|
82
|
+
#
|
83
|
+
# * You can pass the special name 'guess' so we guess for you,
|
84
|
+
# and you can pass a second argument of the code to guess by
|
85
|
+
#
|
86
|
+
# Lexer.find_fancy('guess', "#!/bin/bash\necho Hello, world")
|
87
|
+
#
|
88
|
+
# If the code matches more than one lexer then Guesser::Ambiguous
|
89
|
+
# is raised.
|
90
|
+
#
|
91
|
+
# This is used in the Redcarpet plugin as well as Rouge's own
|
92
|
+
# markdown lexer for highlighting internal code blocks.
|
93
|
+
#
|
94
|
+
def find_fancy(str, code=nil, default_options={})
|
95
|
+
lexer_class, opts = lookup_fancy(str, code, default_options)
|
96
|
+
|
87
97
|
lexer_class && lexer_class.new(opts)
|
88
98
|
end
|
89
99
|
|
@@ -317,6 +327,14 @@ module Rouge
|
|
317
327
|
@debug = Lexer.debug_enabled? && bool_option('debug')
|
318
328
|
end
|
319
329
|
|
330
|
+
# Returns a new lexer with the given options set. Useful for e.g. setting
|
331
|
+
# debug flags post hoc, or providing global overrides for certain options
|
332
|
+
def with(opts={})
|
333
|
+
new_options = @options.dup
|
334
|
+
opts.each { |k, v| new_options[k.to_s] = v }
|
335
|
+
self.class.new(new_options)
|
336
|
+
end
|
337
|
+
|
320
338
|
def as_bool(val)
|
321
339
|
case val
|
322
340
|
when nil, false, 0, '0', 'false', 'off'
|
data/lib/rouge/lexers/apex.rb
CHANGED
@@ -49,7 +49,7 @@ module Rouge
|
|
49
49
|
|
50
50
|
state :root do
|
51
51
|
rule %r/\s+/m, Text
|
52
|
-
|
52
|
+
|
53
53
|
rule %r(//.*?$), Comment::Single
|
54
54
|
rule %r(/\*.*?\*/)m, Comment::Multiline
|
55
55
|
|
@@ -57,17 +57,19 @@ module Rouge
|
|
57
57
|
rule %r/import\b/, Keyword::Namespace, :import
|
58
58
|
|
59
59
|
rule %r/([@$.]?)(#{id})([:(]?)/io do |m|
|
60
|
-
|
60
|
+
lowercased = m[0].downcase
|
61
|
+
uppercased = m[0].upcase
|
62
|
+
if self.class.keywords.include? lowercased
|
61
63
|
token Keyword
|
62
|
-
elsif self.class.soql.include?
|
64
|
+
elsif self.class.soql.include? uppercased
|
63
65
|
token Keyword
|
64
|
-
elsif self.class.declarations.include?
|
66
|
+
elsif self.class.declarations.include? lowercased
|
65
67
|
token Keyword::Declaration
|
66
|
-
elsif self.class.types.include?
|
68
|
+
elsif self.class.types.include? lowercased
|
67
69
|
token Keyword::Type
|
68
|
-
elsif self.class.constants.include?
|
70
|
+
elsif self.class.constants.include? lowercased
|
69
71
|
token Keyword::Constant
|
70
|
-
elsif 'package'
|
72
|
+
elsif lowercased == 'package'
|
71
73
|
token Keyword::Namespace
|
72
74
|
elsif m[1] == "@"
|
73
75
|
token Name::Decorator
|
@@ -79,6 +79,7 @@ module Rouge
|
|
79
79
|
state :basic do
|
80
80
|
# Comments
|
81
81
|
rule %r/@?\brem\b.*$/i, Comment
|
82
|
+
|
82
83
|
# Empty Labels
|
83
84
|
rule %r/^::.*$/, Comment
|
84
85
|
|
@@ -105,7 +106,7 @@ module Rouge
|
|
105
106
|
end
|
106
107
|
end
|
107
108
|
|
108
|
-
rule %r/([
|
109
|
+
rule %r/((?:[\/\+]|--?)[a-z]+)\s*/i, Name::Attribute
|
109
110
|
|
110
111
|
mixin :expansions
|
111
112
|
|
data/lib/rouge/lexers/cpp.rb
CHANGED
@@ -63,7 +63,7 @@ module Rouge
|
|
63
63
|
rule %r((#{dq}[.]#{dq}?|[.]#{dq})(e[+-]?#{dq}[lu]*)?)i, Num::Float
|
64
64
|
rule %r(#{dq}e[+-]?#{dq}[lu]*)i, Num::Float
|
65
65
|
rule %r/0x\h('?\h)*[lu]*/i, Num::Hex
|
66
|
-
rule %r/0b[01]+(
|
66
|
+
rule %r/0b[01]+('[01]+)*/, Num::Bin
|
67
67
|
rule %r/0[0-7]('?[0-7])*[lu]*/i, Num::Oct
|
68
68
|
rule %r/#{dq}[lu]*/i, Num::Integer
|
69
69
|
rule %r/\bnullptr\b/, Name::Builtin
|
data/lib/rouge/lexers/docker.rb
CHANGED
data/lib/rouge/lexers/elm.rb
CHANGED
@@ -78,13 +78,13 @@ module Rouge
|
|
78
78
|
rule %r/"/, Str::Double, :pop!
|
79
79
|
end
|
80
80
|
|
81
|
-
# Multiple line string with
|
81
|
+
# Multiple line string with triple double quotes, e.g. """ multi """
|
82
82
|
state :multiline_string do
|
83
|
-
rule %r
|
84
|
-
rule %r
|
85
|
-
rule %r
|
83
|
+
rule %r/\\"/, Str::Escape
|
84
|
+
rule %r/"""/, Str, :pop!
|
85
|
+
rule %r/[^"]+/, Str
|
86
|
+
rule %r/"/, Str
|
86
87
|
end
|
87
|
-
|
88
88
|
end
|
89
89
|
end
|
90
90
|
end
|
@@ -0,0 +1,39 @@
|
|
1
|
+
# -*- coding: utf-8 -*- #
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
module Rouge
|
5
|
+
module Lexers
|
6
|
+
class Email < RegexLexer
|
7
|
+
tag 'email'
|
8
|
+
aliases 'eml', 'e-mail'
|
9
|
+
filenames '*.eml'
|
10
|
+
mimetypes 'message/rfc822'
|
11
|
+
|
12
|
+
title "Email"
|
13
|
+
desc "An email message"
|
14
|
+
|
15
|
+
start do
|
16
|
+
push :fields
|
17
|
+
end
|
18
|
+
|
19
|
+
state :fields do
|
20
|
+
rule %r/[:]/, Operator, :field_body
|
21
|
+
rule %r/[^\n\r:]+/, Name::Tag
|
22
|
+
rule %r/[\n\r]/, Name::Tag
|
23
|
+
end
|
24
|
+
|
25
|
+
state :field_body do
|
26
|
+
rule(/(\r?\n){2}/) { token Text; pop!(2) }
|
27
|
+
rule %r/\r?\n(?![ \v\t\f])/, Text, :pop!
|
28
|
+
rule %r/[^\n\r]+/, Name::Attribute
|
29
|
+
rule %r/[\n\r]/, Name::Attribute
|
30
|
+
end
|
31
|
+
|
32
|
+
state :root do
|
33
|
+
rule %r/\n/, Text
|
34
|
+
rule %r/^>.*/, Comment
|
35
|
+
rule %r/.+/, Text
|
36
|
+
end
|
37
|
+
end
|
38
|
+
end
|
39
|
+
end
|
data/lib/rouge/lexers/graphql.rb
CHANGED
data/lib/rouge/lexers/http.rb
CHANGED
@@ -8,16 +8,22 @@ module Rouge
|
|
8
8
|
title "HTTP"
|
9
9
|
desc 'http requests and responses'
|
10
10
|
|
11
|
+
option :content, "the language for the content (default: auto-detect)"
|
12
|
+
|
11
13
|
def self.http_methods
|
12
14
|
@http_methods ||= %w(GET POST PUT DELETE HEAD OPTIONS TRACE PATCH)
|
13
15
|
end
|
14
16
|
|
15
17
|
def content_lexer
|
18
|
+
@content_lexer ||= (lexer_option(:content) || guess_content_lexer)
|
19
|
+
end
|
20
|
+
|
21
|
+
def guess_content_lexer
|
16
22
|
return Lexers::PlainText unless @content_type
|
17
23
|
|
18
|
-
|
24
|
+
Lexer.guess_by_mimetype(@content_type)
|
19
25
|
rescue Lexer::AmbiguousGuess
|
20
|
-
|
26
|
+
Lexers::PlainText
|
21
27
|
end
|
22
28
|
|
23
29
|
start { @content_type = 'text/plain' }
|
data/lib/rouge/lexers/isbl.rb
CHANGED
@@ -41,7 +41,7 @@ module Rouge
|
|
41
41
|
|
42
42
|
state :dotted do
|
43
43
|
mixin :whitespace
|
44
|
-
rule %r/[a-zа-яё_0-9]
|
44
|
+
rule %r/[a-zа-яё_0-9]+/i do |m|
|
45
45
|
name = m[0]
|
46
46
|
if self.class.constants.include? name.downcase
|
47
47
|
token Name::Builtin
|
@@ -56,7 +56,7 @@ module Rouge
|
|
56
56
|
|
57
57
|
state :type do
|
58
58
|
mixin :whitespace
|
59
|
-
rule %r/[a-zа-яё_0-9]
|
59
|
+
rule %r/[a-zа-яё_0-9]+/i do |m|
|
60
60
|
name = m[0]
|
61
61
|
if self.class.interfaces.include? name.downcase
|
62
62
|
token Keyword::Type
|
@@ -0,0 +1,244 @@
|
|
1
|
+
# -*- coding: utf-8 -*- #
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
module Rouge
|
5
|
+
module Lexers
|
6
|
+
class J < RegexLexer
|
7
|
+
title 'J'
|
8
|
+
desc "The J programming language (jsoftware.com)"
|
9
|
+
tag 'j'
|
10
|
+
filenames '*.ijs', '*.ijt'
|
11
|
+
|
12
|
+
# For J-specific terms we use, see:
|
13
|
+
# https://code.jsoftware.com/wiki/Vocabulary/AET
|
14
|
+
# https://code.jsoftware.com/wiki/Vocabulary/Glossary
|
15
|
+
|
16
|
+
# https://code.jsoftware.com/wiki/Vocabulary/PartsOfSpeech
|
17
|
+
def self.token_map
|
18
|
+
@token_map ||= {
|
19
|
+
noun: Keyword::Constant,
|
20
|
+
verb: Name::Function,
|
21
|
+
modifier: Operator,
|
22
|
+
name: Name,
|
23
|
+
param: Name::Builtin::Pseudo,
|
24
|
+
other: Punctuation,
|
25
|
+
nil => Error,
|
26
|
+
}
|
27
|
+
end
|
28
|
+
|
29
|
+
# https://code.jsoftware.com/wiki/NuVoc
|
30
|
+
def self.inflection_list
|
31
|
+
@inflection_list ||= ['', '.', ':', '..', '.:', ':.', '::']
|
32
|
+
end
|
33
|
+
|
34
|
+
def self.primitive_table
|
35
|
+
@primitive_table ||= Hash.new([:name]).tap do |h|
|
36
|
+
{
|
37
|
+
'()' => [:other],
|
38
|
+
'=' => [:verb, :other, :other],
|
39
|
+
'<>+-*%$|,#' => [:verb, :verb, :verb],
|
40
|
+
'^' => [:verb, :verb, :modifier],
|
41
|
+
'~"' => [:modifier, :verb, :verb],
|
42
|
+
'.:@' => [:modifier, :modifier, :modifier],
|
43
|
+
';' => [:verb, :modifier, :verb],
|
44
|
+
'!' => [:verb, :modifier, :modifier],
|
45
|
+
'/\\' => [:modifier, :modifier, :verb],
|
46
|
+
'[' => [:verb, nil, :verb],
|
47
|
+
']' => [:verb],
|
48
|
+
'{' => [:verb, :verb, :verb, nil, nil, nil, :verb],
|
49
|
+
'}' => [:modifier, :verb, :verb, nil, nil, nil, :modifier],
|
50
|
+
'`' => [:modifier, nil, :modifier],
|
51
|
+
'&' => [:modifier, :modifier, :modifier, nil, :modifier],
|
52
|
+
'?' => [:verb, :verb],
|
53
|
+
'a' => [:name, :noun, :noun],
|
54
|
+
'ACeEIjorv' => [:name, :verb],
|
55
|
+
'bdfHMT' => [:name, :modifier],
|
56
|
+
'Dt' => [:name, :modifier, :modifier],
|
57
|
+
'F' => [:name, :modifier, :modifier, :modifier, :modifier,
|
58
|
+
:modifier, :modifier],
|
59
|
+
'iu' => [:name, :verb, :verb],
|
60
|
+
'L' => [:name, :verb, :modifier],
|
61
|
+
'mny' => [:param],
|
62
|
+
'p' => [:name, :verb, :verb, :verb],
|
63
|
+
'qsZ' => [:name, nil, :verb],
|
64
|
+
'S' => [:name, nil, :modifier],
|
65
|
+
'u' => [:param, :verb, :verb],
|
66
|
+
'v' => [:param, :verb],
|
67
|
+
'x' => [:param, nil, :verb],
|
68
|
+
}.each {|k, v| k.each_char {|c| h[c] = v } }
|
69
|
+
end
|
70
|
+
end
|
71
|
+
|
72
|
+
def self.primitive(char, inflection)
|
73
|
+
i = inflection_list.index(inflection) or return Error
|
74
|
+
token_map[primitive_table[char][i]]
|
75
|
+
end
|
76
|
+
|
77
|
+
def self.control_words
|
78
|
+
@control_words ||= Set.new %w(
|
79
|
+
assert break case catch catchd catcht continue do else elseif end
|
80
|
+
fcase for if return select throw try while whilst
|
81
|
+
)
|
82
|
+
end
|
83
|
+
|
84
|
+
def self.control_words_id
|
85
|
+
@control_words_id ||= Set.new %w(for goto label)
|
86
|
+
end
|
87
|
+
|
88
|
+
state :expr do
|
89
|
+
rule %r/\s+/, Text
|
90
|
+
|
91
|
+
rule %r'([!-&(-/:-@\[-^`{-~]|[A-Za-z]\b)([.:]*)' do |m|
|
92
|
+
token J.primitive(m[1], m[2])
|
93
|
+
end
|
94
|
+
|
95
|
+
rule %r/(?:\d|_\d?):([.:]*)/ do |m|
|
96
|
+
token m[1].empty? ? J.token_map[:verb] : Error
|
97
|
+
end
|
98
|
+
|
99
|
+
rule %r/[\d_][\w.]*([.:]*)/ do |m|
|
100
|
+
token m[1].empty? ? Num : Error
|
101
|
+
end
|
102
|
+
|
103
|
+
rule %r/'/, Str::Single, :str
|
104
|
+
|
105
|
+
rule %r/NB\.(?![.:]).*/, Comment::Single
|
106
|
+
|
107
|
+
rule %r/([A-Za-z]\w*)([.:]*)/ do |m|
|
108
|
+
if m[2] == '.'
|
109
|
+
word, sep, id = m[1].partition '_'
|
110
|
+
list = if sep.empty?
|
111
|
+
J.control_words
|
112
|
+
elsif not id.empty?
|
113
|
+
J.control_words_id
|
114
|
+
end
|
115
|
+
if list and list.include? word
|
116
|
+
token Keyword, word + sep
|
117
|
+
token((word == 'for' ? Name : Name::Label), id)
|
118
|
+
token Keyword, m[2]
|
119
|
+
else
|
120
|
+
token Error
|
121
|
+
end
|
122
|
+
else
|
123
|
+
token m[2].empty? ? Name : Error
|
124
|
+
end
|
125
|
+
end
|
126
|
+
end
|
127
|
+
|
128
|
+
state :str do
|
129
|
+
rule %r/''/, Str::Escape
|
130
|
+
rule %r/[^'\n]+/, Str::Single
|
131
|
+
rule %r/'|$/, Str::Single, :pop!
|
132
|
+
end
|
133
|
+
|
134
|
+
start do
|
135
|
+
@note_next = false
|
136
|
+
end
|
137
|
+
|
138
|
+
state :root do
|
139
|
+
rule %r/\n/ do
|
140
|
+
token Text
|
141
|
+
if @note_next
|
142
|
+
push :note
|
143
|
+
@note_next = false
|
144
|
+
end
|
145
|
+
end
|
146
|
+
|
147
|
+
# https://code.jsoftware.com/wiki/Vocabulary/com
|
148
|
+
# https://code.jsoftware.com/wiki/Vocabulary/NounExplicitDefinition
|
149
|
+
rule %r/
|
150
|
+
([0-4]|13|adverb|conjunction|dyad|monad|noun|verb)([\ \t]+)
|
151
|
+
(def(?:ine)?\b|:)(?![.:])([\ \t]*)
|
152
|
+
/x do |m|
|
153
|
+
groups Keyword::Pseudo, Text, Keyword::Pseudo, Text
|
154
|
+
@def_body = (m[1] == '0' || m[1] == 'noun') ? :noun : :code
|
155
|
+
if m[3] == 'define'
|
156
|
+
# stack: [:root]
|
157
|
+
# or [:root, ..., :def_next]
|
158
|
+
pop! if stack.size > 1
|
159
|
+
push @def_body
|
160
|
+
push :def_next # [:root, ..., @def_body, :def_next]
|
161
|
+
else
|
162
|
+
push :expl_def
|
163
|
+
end
|
164
|
+
end
|
165
|
+
|
166
|
+
rule %r/^([ \t]*)(Note\b(?![.:]))([ \t\r]*)(?!=[.:]|$)/ do
|
167
|
+
groups Text, Name, Text
|
168
|
+
@note_next = true
|
169
|
+
end
|
170
|
+
|
171
|
+
rule %r/[mnuvxy]\b(?![.:])/, Name
|
172
|
+
mixin :expr
|
173
|
+
end
|
174
|
+
|
175
|
+
state :def_next do
|
176
|
+
rule %r/\n/, Text, :pop!
|
177
|
+
mixin :root
|
178
|
+
end
|
179
|
+
|
180
|
+
state :expl_def do
|
181
|
+
rule %r/0\b(?![.:])/ do
|
182
|
+
token Keyword::Pseudo
|
183
|
+
# stack: [:root, :expl_def]
|
184
|
+
# or [:root, ..., :def_next, :expl_def]
|
185
|
+
pop! if stack.size > 2
|
186
|
+
goto @def_body
|
187
|
+
push :def_next # [:root, ..., @def_body, :def_next]
|
188
|
+
end
|
189
|
+
rule %r/'/ do
|
190
|
+
if @def_body == :noun
|
191
|
+
token Str::Single
|
192
|
+
goto :str
|
193
|
+
else
|
194
|
+
token Punctuation
|
195
|
+
goto :q_expr
|
196
|
+
end
|
197
|
+
end
|
198
|
+
rule(//) { pop! }
|
199
|
+
end
|
200
|
+
|
201
|
+
# `q_expr` lexes the content of a string literal which is a part of an
|
202
|
+
# explicit definition.
|
203
|
+
# e.g. dyad def 'x + y'
|
204
|
+
state :q_expr do
|
205
|
+
rule %r/''/, Str::Single, :q_str
|
206
|
+
rule %r/'|$/, Punctuation, :pop!
|
207
|
+
rule %r/NB\.(?![.:])([^'\n]|'')*/, Comment::Single
|
208
|
+
mixin :expr
|
209
|
+
end
|
210
|
+
|
211
|
+
state :q_str do
|
212
|
+
rule %r/''''/, Str::Escape
|
213
|
+
rule %r/[^'\n]+/, Str::Single
|
214
|
+
rule %r/''/, Str::Single, :pop!
|
215
|
+
rule(/'|$/) { token Punctuation; pop! 2 }
|
216
|
+
end
|
217
|
+
|
218
|
+
state :note do
|
219
|
+
mixin :delimiter
|
220
|
+
rule %r/.+\n?/, Comment::Multiline
|
221
|
+
end
|
222
|
+
|
223
|
+
state :noun do
|
224
|
+
mixin :delimiter
|
225
|
+
rule %r/.+\n?/, Str::Heredoc
|
226
|
+
end
|
227
|
+
|
228
|
+
state :code do
|
229
|
+
mixin :delimiter
|
230
|
+
rule %r/^([ \t]*)(:)([ \t\r]*)$/ do
|
231
|
+
groups Text, Punctuation, Text
|
232
|
+
end
|
233
|
+
mixin :expr
|
234
|
+
end
|
235
|
+
|
236
|
+
state :delimiter do
|
237
|
+
rule %r/^([ \t]*)(\))([ \t\r]*$\n?)/ do
|
238
|
+
groups Text, Punctuation, Text
|
239
|
+
pop!
|
240
|
+
end
|
241
|
+
end
|
242
|
+
end
|
243
|
+
end
|
244
|
+
end
|
data/lib/rouge/lexers/janet.rb
CHANGED
@@ -114,7 +114,7 @@ module Rouge
|
|
114
114
|
end
|
115
115
|
end
|
116
116
|
|
117
|
-
punctuation = %r/[_
|
117
|
+
punctuation = %r/[_!$%^&*+=~<>.?\/-]/o
|
118
118
|
symbol = %r/([[:alpha:]]|#{punctuation})([[:word:]]|#{punctuation}|:)*/o
|
119
119
|
|
120
120
|
state :root do
|
@@ -143,20 +143,19 @@ module Rouge
|
|
143
143
|
|
144
144
|
rule %r/\(/, Punctuation, :function
|
145
145
|
|
146
|
-
rule %r/(')([
|
146
|
+
rule %r/(')(@?[(\[{])/ do
|
147
147
|
groups Operator, Punctuation
|
148
148
|
push :quote
|
149
149
|
end
|
150
150
|
|
151
|
-
rule %r/(~)([
|
151
|
+
rule %r/(~)(@?[(\[{])/ do
|
152
152
|
groups Operator, Punctuation
|
153
153
|
push :quasiquote
|
154
154
|
end
|
155
155
|
|
156
156
|
rule %r/[\#~,';\|]/, Operator
|
157
157
|
|
158
|
-
rule %r/@?[({\[]/, Punctuation
|
159
|
-
rule %r/[)}\]]/, Punctuation, :pop!
|
158
|
+
rule %r/@?[(){}\[\]]/, Punctuation
|
160
159
|
|
161
160
|
rule symbol, Name
|
162
161
|
end
|
@@ -169,6 +168,8 @@ module Rouge
|
|
169
168
|
end
|
170
169
|
|
171
170
|
state :function do
|
171
|
+
rule %r/[\)]/, Punctuation, :pop!
|
172
|
+
|
172
173
|
rule symbol do |m|
|
173
174
|
case m[0]
|
174
175
|
when "quote"
|
@@ -187,8 +188,9 @@ module Rouge
|
|
187
188
|
end
|
188
189
|
|
189
190
|
state :quote do
|
190
|
-
rule %r/[
|
191
|
-
rule
|
191
|
+
rule %r/[(\[{]/, Punctuation, :push
|
192
|
+
rule %r/[)\]}]/, Punctuation, :pop!
|
193
|
+
rule symbol, Str::Escape
|
192
194
|
mixin :root
|
193
195
|
end
|
194
196
|
|
@@ -199,7 +201,6 @@ module Rouge
|
|
199
201
|
end
|
200
202
|
rule %r/(\()(\s*)(unquote)(\s+)(\()/ do
|
201
203
|
groups Punctuation, Text, Keyword, Text, Punctuation
|
202
|
-
push :root
|
203
204
|
push :function
|
204
205
|
end
|
205
206
|
|
@@ -162,6 +162,10 @@ module Rouge
|
|
162
162
|
push :template_string
|
163
163
|
end
|
164
164
|
|
165
|
+
# special case for the safe navigation operator ?.
|
166
|
+
# so that we don't start detecting a ternary expr
|
167
|
+
rule %r/[?][.]/, Punctuation
|
168
|
+
|
165
169
|
rule %r/[?]/ do
|
166
170
|
token Punctuation
|
167
171
|
push :ternary
|
@@ -265,9 +269,11 @@ module Rouge
|
|
265
269
|
|
266
270
|
# template strings
|
267
271
|
state :template_string do
|
268
|
-
rule %r
|
272
|
+
rule %r/[$]{/, Punctuation, :template_string_expr
|
269
273
|
rule %r/`/, Str::Double, :pop!
|
270
|
-
rule %r
|
274
|
+
rule %r/\\[$`]/, Str::Escape
|
275
|
+
rule %r/[^$`\\]+/, Str::Double
|
276
|
+
rule %r/[\\$]/, Str::Double
|
271
277
|
end
|
272
278
|
|
273
279
|
state :template_string_expr do
|
data/lib/rouge/lexers/jsl.rb
CHANGED
data/lib/rouge/lexers/jsonnet.rb
CHANGED
@@ -126,6 +126,7 @@ module Rouge
|
|
126
126
|
|
127
127
|
state :string do
|
128
128
|
rule %r/\\([\\\/bfnrt]|(u[0-9a-fA-F]{4}))/, Str::Escape
|
129
|
+
rule %r/\\./, Str::Escape
|
129
130
|
end
|
130
131
|
|
131
132
|
state :string_double do
|
@@ -137,15 +138,15 @@ module Rouge
|
|
137
138
|
|
138
139
|
state :string_single do
|
139
140
|
mixin :string
|
140
|
-
rule %r/\\'/, Str::Escape
|
141
141
|
rule %r/'/, Str, :pop!
|
142
142
|
rule %r/[^\\']+/, Str
|
143
143
|
end
|
144
144
|
|
145
145
|
state :string_block do
|
146
146
|
mixin :string
|
147
|
-
rule %r
|
148
|
-
rule %r
|
147
|
+
rule %r/[|][|][|]/, Str, :pop!
|
148
|
+
rule %r/[^|\\]+/, Str
|
149
|
+
rule %r/[|]/, Str
|
149
150
|
end
|
150
151
|
end
|
151
152
|
end
|
data/lib/rouge/lexers/jsp.rb
CHANGED
data/lib/rouge/lexers/kotlin.rb
CHANGED
@@ -53,7 +53,7 @@ module Rouge
|
|
53
53
|
groups Keyword::Declaration, Text
|
54
54
|
push :property
|
55
55
|
end
|
56
|
-
rule %r'(return|continue|break|this|super)(@#{name})
|
56
|
+
rule %r'(return|continue|break|this|super)(@#{name})?\b' do
|
57
57
|
groups Keyword, Name::Decorator
|
58
58
|
end
|
59
59
|
rule %r'\bfun\b', Keyword
|
@@ -133,9 +133,10 @@ module Rouge
|
|
133
133
|
end
|
134
134
|
|
135
135
|
state :comment do
|
136
|
-
rule %r'
|
137
|
-
rule %r'
|
138
|
-
rule %r'
|
136
|
+
rule %r'/[*]', Comment::Multiline, :comment
|
137
|
+
rule %r'[*]/', Comment::Multiline, :pop!
|
138
|
+
rule %r'[^/*]+', Comment::Multiline
|
139
|
+
rule %r'[/*]', Comment::Multiline
|
139
140
|
end
|
140
141
|
end
|
141
142
|
end
|
data/lib/rouge/lexers/perl.rb
CHANGED
@@ -110,9 +110,10 @@ module Rouge
|
|
110
110
|
|
111
111
|
rule %r/(__(END|DATA)__)\b/, Comment::Preproc, :end_part
|
112
112
|
rule %r/\$\^[ADEFHILMOPSTWX]/, Name::Variable::Global
|
113
|
-
rule %r/\$[\\"'\[\]&`+*.,;=%~?@$!<>(
|
113
|
+
rule %r/\$[\\"'\[\]&`+*.,;=%~?@$!<>(^\|\/_-](?!\w)/, Name::Variable::Global
|
114
|
+
rule %r/[$@%&*][$@%&*#_]*(?=[a-z{\[;])/i, Name::Variable, :varname
|
115
|
+
|
114
116
|
rule %r/[-+\/*%=<>&^\|!\\~]=?/, Operator
|
115
|
-
rule %r/[$@%#]+/, Name::Variable, :varname
|
116
117
|
|
117
118
|
rule %r/0_?[0-7]+(_[0-7]+)*/, Num::Oct
|
118
119
|
rule %r/0x[0-9A-Fa-f]+(_[0-9A-Fa-f]+)*/, Num::Hex
|
@@ -159,8 +160,9 @@ module Rouge
|
|
159
160
|
|
160
161
|
state :varname do
|
161
162
|
rule %r/\s+/, Text
|
162
|
-
rule %r
|
163
|
-
rule %r
|
163
|
+
rule %r/[{\[]/, Punctuation, :pop! # hash syntax
|
164
|
+
rule %r/[),]/, Punctuation, :pop! # arg specifier
|
165
|
+
rule %r/[;]/, Punctuation, :pop! # postfix
|
164
166
|
mixin :name_common
|
165
167
|
end
|
166
168
|
|
@@ -131,34 +131,50 @@ module Rouge
|
|
131
131
|
rule %r/[:,]/, Punctuation
|
132
132
|
end
|
133
133
|
|
134
|
-
state :
|
135
|
-
|
136
|
-
rule %r/\}/, Punctuation, :pop!
|
134
|
+
state :expr do
|
135
|
+
mixin :comments
|
137
136
|
rule %r/"/, Str::Double, :dq
|
138
137
|
rule %r/'/, Str::Single, :sq
|
139
|
-
rule %r
|
138
|
+
rule %r/@"/, Str::Heredoc, :heredoc
|
139
|
+
rule %r/@'.*?'@/m, Str::Heredoc
|
140
|
+
rule %r/\d*\.\d+/, Num::Float
|
141
|
+
rule %r/\d+/, Num::Integer
|
142
|
+
rule %r/@\{/, Punctuation, :hasht
|
143
|
+
rule %r/@\(/, Punctuation, :array
|
144
|
+
rule %r/{/, Punctuation, :brace
|
145
|
+
rule %r/\[/, Punctuation, :bracket
|
146
|
+
end
|
147
|
+
|
148
|
+
state :hasht do
|
149
|
+
rule %r/\}/, Punctuation, :pop!
|
140
150
|
rule %r/=/, Operator
|
141
|
-
rule %r
|
151
|
+
rule %r/[,;]/, Punctuation
|
152
|
+
mixin :expr
|
153
|
+
rule %r/\w+/, Name::Other
|
142
154
|
mixin :variable
|
143
155
|
end
|
144
156
|
|
145
157
|
state :array do
|
146
158
|
rule %r/\s+/, Text::Whitespace
|
147
159
|
rule %r/\)/, Punctuation, :pop!
|
148
|
-
rule %r/
|
149
|
-
|
150
|
-
rule %r/,/, Punctuation
|
160
|
+
rule %r/[,;]/, Punctuation
|
161
|
+
mixin :expr
|
151
162
|
mixin :variable
|
152
163
|
end
|
153
164
|
|
165
|
+
state :brace do
|
166
|
+
rule %r/[}]/, Punctuation, :pop!
|
167
|
+
mixin :root
|
168
|
+
end
|
169
|
+
|
154
170
|
state :bracket do
|
155
171
|
rule %r/\]/, Punctuation, :pop!
|
156
|
-
rule %r/[A-Za-z]\w+\./, Name
|
172
|
+
rule %r/[A-Za-z]\w+\./, Name
|
157
173
|
rule %r/([A-Za-z]\w+)/ do |m|
|
158
174
|
if ATTRIBUTES.include? m[0]
|
159
175
|
token Name::Builtin::Pseudo
|
160
176
|
else
|
161
|
-
token
|
177
|
+
token Name
|
162
178
|
end
|
163
179
|
end
|
164
180
|
mixin :root
|
@@ -174,20 +190,15 @@ module Rouge
|
|
174
190
|
mixin :root
|
175
191
|
end
|
176
192
|
|
177
|
-
state :
|
193
|
+
state :comments do
|
178
194
|
rule %r/\s+/, Text::Whitespace
|
179
|
-
|
180
|
-
rule %r/#requires\s-version \d(?:\.\d+)?/, Comment::Preproc
|
181
195
|
rule %r/#.*/, Comment
|
182
196
|
rule %r/<#/, Comment::Multiline, :multiline
|
197
|
+
end
|
183
198
|
|
184
|
-
|
185
|
-
|
186
|
-
rule %r
|
187
|
-
rule %r/@'.*?'@/m, Str::Heredoc
|
188
|
-
|
189
|
-
rule %r/\d*\.\d+/, Num::Float
|
190
|
-
rule %r/\d+/, Num::Integer
|
199
|
+
state :root do
|
200
|
+
mixin :comments
|
201
|
+
rule %r/#requires\s-version \d(?:\.\d+)?/, Comment::Preproc
|
191
202
|
|
192
203
|
rule %r/\.\.(?=\.?\d)/, Operator
|
193
204
|
rule %r/(?:#{OPERATORS})\b/i, Operator
|
@@ -204,28 +215,27 @@ module Rouge
|
|
204
215
|
rule %r/-{1,2}\w+/, Name::Tag
|
205
216
|
|
206
217
|
rule %r/(\.)?([-\w]+)(\[)/ do |m|
|
207
|
-
groups Operator, Name
|
218
|
+
groups Operator, Name, Punctuation
|
208
219
|
push :bracket
|
209
220
|
end
|
210
221
|
|
211
|
-
rule %r/([
|
212
|
-
groups Name
|
222
|
+
rule %r/([\/\\~[a-z]][-.:\/\\~\w]*)(\n)?/i do |m|
|
223
|
+
groups Name, Text::Whitespace
|
213
224
|
push :parameters
|
214
225
|
end
|
215
226
|
|
216
|
-
rule %r/(\.)
|
227
|
+
rule %r/(\.)([-\w]+)(?:(\()|(\n))?/ do |m|
|
217
228
|
groups Operator, Name::Function, Punctuation, Text::Whitespace
|
218
229
|
push :parameters unless m[3].nil?
|
219
230
|
end
|
220
231
|
|
221
232
|
rule %r/\?/, Name::Function, :parameters
|
222
|
-
rule %r/[-+*\/%=!.&|]/, Operator
|
223
|
-
rule %r/@\{/, Punctuation, :hasht
|
224
|
-
rule %r/@\(/, Punctuation, :array
|
225
|
-
rule %r/\[/, Punctuation, :bracket
|
226
|
-
rule %r/[{}(),:;]/, Punctuation
|
227
233
|
|
234
|
+
mixin :expr
|
228
235
|
mixin :variable
|
236
|
+
|
237
|
+
rule %r/[-+*\/%=!.&|]/, Operator
|
238
|
+
rule %r/[{}(),:;]/, Punctuation
|
229
239
|
end
|
230
240
|
end
|
231
241
|
end
|
data/lib/rouge/lexers/q.rb
CHANGED
data/lib/rouge/lexers/rust.rb
CHANGED
@@ -22,8 +22,8 @@ module Rouge
|
|
22
22
|
|
23
23
|
def self.keywords
|
24
24
|
@keywords ||= %w(
|
25
|
-
as assert async await break const copy do drop else enum extern
|
26
|
-
fn for if impl let log loop match mod move mut priv pub pure
|
25
|
+
as assert async await break const continue copy do drop else enum extern
|
26
|
+
fail false fn for if impl let log loop match mod move mut priv pub pure
|
27
27
|
ref return self static struct true trait type unsafe use where
|
28
28
|
while box
|
29
29
|
)
|
@@ -99,6 +99,7 @@ module Rouge
|
|
99
99
|
rule %r/[*\/!@~&+%^<>=\?-]|\.{2,3}/, Operator
|
100
100
|
|
101
101
|
rule %r/([.]\s*)?#{id}(?=\s*[(])/m, Name::Function
|
102
|
+
rule %r/[.]\s*await\b/, Keyword
|
102
103
|
rule %r/[.]\s*#{id}/, Name::Property
|
103
104
|
rule %r/[.]\s*\d+/, Name::Attribute
|
104
105
|
rule %r/(#{id})(::)/m do
|
data/lib/rouge/lexers/smarty.rb
CHANGED
@@ -63,7 +63,7 @@ module Rouge
|
|
63
63
|
rule %r/0[xX][0-9a-fA-F]+[Ll]?/, Num::Hex
|
64
64
|
rule %r/\b[0-9]+\b/, Num::Integer
|
65
65
|
rule %r/(true|false|null)\b/, Keyword::Constant
|
66
|
-
rule %r/[(\[]/, Punctuation, :push
|
66
|
+
rule %r/[(\[]/, Punctuation, :push
|
67
67
|
rule %r/[)\]}]/, Punctuation, :pop!
|
68
68
|
end
|
69
69
|
end
|
data/lib/rouge/lexers/wollok.rb
CHANGED
data/lib/rouge/regex_lexer.rb
CHANGED
@@ -6,6 +6,37 @@ module Rouge
|
|
6
6
|
# A stateful lexer that uses sets of regular expressions to
|
7
7
|
# tokenize a string. Most lexers are instances of RegexLexer.
|
8
8
|
class RegexLexer < Lexer
|
9
|
+
class InvalidRegex < StandardError
|
10
|
+
def initialize(re)
|
11
|
+
@re = re
|
12
|
+
end
|
13
|
+
|
14
|
+
def to_s
|
15
|
+
"regex #{@re.inspect} matches empty string, but has no predicate!"
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
class ClosedState < StandardError
|
20
|
+
attr_reader :state
|
21
|
+
def initialize(state)
|
22
|
+
@state = state
|
23
|
+
end
|
24
|
+
|
25
|
+
def rule
|
26
|
+
@state.rules.last
|
27
|
+
end
|
28
|
+
|
29
|
+
def to_s
|
30
|
+
rule = @state.rules.last
|
31
|
+
msg = "State :#{state.name} cannot continue after #{rule.inspect}, which will always match."
|
32
|
+
if rule.re.source.include?('*')
|
33
|
+
msg += " Consider replacing * with +."
|
34
|
+
end
|
35
|
+
|
36
|
+
msg
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
9
40
|
# A rule is a tuple of a regular expression to test, and a callback
|
10
41
|
# to perform if the test succeeds.
|
11
42
|
#
|
@@ -42,12 +73,13 @@ module Rouge
|
|
42
73
|
end
|
43
74
|
|
44
75
|
class StateDSL
|
45
|
-
attr_reader :rules
|
76
|
+
attr_reader :rules, :name
|
46
77
|
def initialize(name, &defn)
|
47
78
|
@name = name
|
48
79
|
@defn = defn
|
49
80
|
@rules = []
|
50
81
|
@loaded = false
|
82
|
+
@closed = false
|
51
83
|
end
|
52
84
|
|
53
85
|
def to_state(lexer_class)
|
@@ -95,10 +127,14 @@ module Rouge
|
|
95
127
|
# {RegexLexer#token}, and {RegexLexer#delegate}. The first
|
96
128
|
# argument can be used to access the match groups.
|
97
129
|
def rule(re, tok=nil, next_state=nil, &callback)
|
130
|
+
raise ClosedState.new(self) if @closed
|
131
|
+
|
98
132
|
if tok.nil? && callback.nil?
|
99
133
|
raise "please pass `rule` a token to yield or a callback"
|
100
134
|
end
|
101
135
|
|
136
|
+
matches_empty = re =~ ''
|
137
|
+
|
102
138
|
callback ||= case next_state
|
103
139
|
when :pop!
|
104
140
|
proc do |stream|
|
@@ -123,6 +159,9 @@ module Rouge
|
|
123
159
|
@stack.push(state)
|
124
160
|
end
|
125
161
|
when nil
|
162
|
+
# cannot use an empty-matching regexp with no predicate
|
163
|
+
raise InvalidRegex.new(re) if matches_empty
|
164
|
+
|
126
165
|
proc do |stream|
|
127
166
|
puts " yielding: #{tok.qualname}, #{stream[0].inspect}" if @debug
|
128
167
|
@output_stream.call(tok, stream[0])
|
@@ -132,6 +171,22 @@ module Rouge
|
|
132
171
|
end
|
133
172
|
|
134
173
|
rules << Rule.new(re, callback)
|
174
|
+
|
175
|
+
close! if matches_empty && !context_sensitive?(re)
|
176
|
+
end
|
177
|
+
|
178
|
+
def context_sensitive?(re)
|
179
|
+
source = re.source
|
180
|
+
return true if source =~ /[(][?]<?[!=]/
|
181
|
+
|
182
|
+
# anchors count as lookahead/behind
|
183
|
+
return true if source =~ /[$^]/
|
184
|
+
|
185
|
+
false
|
186
|
+
end
|
187
|
+
|
188
|
+
def close!
|
189
|
+
@closed = true
|
135
190
|
end
|
136
191
|
|
137
192
|
# Mix in the rules from another state into this state. The rules
|
data/lib/rouge/version.rb
CHANGED
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: rouge
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.
|
4
|
+
version: 3.25.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Jeanine Adkisson
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2020-
|
11
|
+
date: 2020-11-10 00:00:00.000000000 Z
|
12
12
|
dependencies: []
|
13
13
|
description: Rouge aims to a be a simple, easy-to-extend drop-in replacement for pygments.
|
14
14
|
email:
|
@@ -73,6 +73,7 @@ files:
|
|
73
73
|
- lib/rouge/demos/eiffel
|
74
74
|
- lib/rouge/demos/elixir
|
75
75
|
- lib/rouge/demos/elm
|
76
|
+
- lib/rouge/demos/email
|
76
77
|
- lib/rouge/demos/epp
|
77
78
|
- lib/rouge/demos/erb
|
78
79
|
- lib/rouge/demos/erlang
|
@@ -109,6 +110,7 @@ files:
|
|
109
110
|
- lib/rouge/demos/irb
|
110
111
|
- lib/rouge/demos/irb_output
|
111
112
|
- lib/rouge/demos/isbl
|
113
|
+
- lib/rouge/demos/j
|
112
114
|
- lib/rouge/demos/janet
|
113
115
|
- lib/rouge/demos/java
|
114
116
|
- lib/rouge/demos/javascript
|
@@ -228,6 +230,7 @@ files:
|
|
228
230
|
- lib/rouge/formatters/html.rb
|
229
231
|
- lib/rouge/formatters/html_inline.rb
|
230
232
|
- lib/rouge/formatters/html_legacy.rb
|
233
|
+
- lib/rouge/formatters/html_line_highlighter.rb
|
231
234
|
- lib/rouge/formatters/html_line_table.rb
|
232
235
|
- lib/rouge/formatters/html_linewise.rb
|
233
236
|
- lib/rouge/formatters/html_pygments.rb
|
@@ -296,6 +299,7 @@ files:
|
|
296
299
|
- lib/rouge/lexers/eiffel.rb
|
297
300
|
- lib/rouge/lexers/elixir.rb
|
298
301
|
- lib/rouge/lexers/elm.rb
|
302
|
+
- lib/rouge/lexers/email.rb
|
299
303
|
- lib/rouge/lexers/epp.rb
|
300
304
|
- lib/rouge/lexers/erb.rb
|
301
305
|
- lib/rouge/lexers/erlang.rb
|
@@ -333,6 +337,7 @@ files:
|
|
333
337
|
- lib/rouge/lexers/irb.rb
|
334
338
|
- lib/rouge/lexers/isbl.rb
|
335
339
|
- lib/rouge/lexers/isbl/builtins.rb
|
340
|
+
- lib/rouge/lexers/j.rb
|
336
341
|
- lib/rouge/lexers/janet.rb
|
337
342
|
- lib/rouge/lexers/java.rb
|
338
343
|
- lib/rouge/lexers/javascript.rb
|