rouge 3.4.1 → 3.6.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 +4 -0
- data/lib/rouge/cli.rb +38 -13
- data/lib/rouge/demos/bpf +7 -0
- data/lib/rouge/demos/brainfuck +5 -0
- data/lib/rouge/demos/magik +6 -0
- data/lib/rouge/demos/openedge +4 -0
- data/lib/rouge/demos/powershell +12 -48
- data/lib/rouge/demos/xojo +2 -1
- data/lib/rouge/demos/xpath +2 -0
- data/lib/rouge/demos/xquery +22 -0
- data/lib/rouge/formatter.rb +2 -2
- data/lib/rouge/formatters/html.rb +18 -2
- data/lib/rouge/formatters/html_line_table.rb +51 -0
- data/lib/rouge/formatters/tex.rb +90 -0
- data/lib/rouge/guessers/glob_mapping.rb +1 -1
- data/lib/rouge/guessers/modeline.rb +1 -1
- data/lib/rouge/lexer.rb +22 -10
- data/lib/rouge/lexers/abap.rb +11 -11
- data/lib/rouge/lexers/actionscript.rb +34 -34
- data/lib/rouge/lexers/apache.rb +8 -8
- data/lib/rouge/lexers/apple_script.rb +15 -14
- data/lib/rouge/lexers/awk.rb +25 -25
- data/lib/rouge/lexers/biml.rb +4 -4
- data/lib/rouge/lexers/bpf.rb +104 -0
- data/lib/rouge/lexers/brainfuck.rb +53 -0
- data/lib/rouge/lexers/bsl.rb +12 -12
- data/lib/rouge/lexers/c.rb +30 -30
- data/lib/rouge/lexers/ceylon.rb +6 -34
- data/lib/rouge/lexers/cfscript.rb +26 -26
- data/lib/rouge/lexers/clojure.rb +14 -14
- data/lib/rouge/lexers/cmake.rb +14 -14
- data/lib/rouge/lexers/coffeescript.rb +30 -30
- data/lib/rouge/lexers/common_lisp.rb +36 -36
- data/lib/rouge/lexers/conf.rb +6 -6
- data/lib/rouge/lexers/coq.rb +18 -18
- data/lib/rouge/lexers/cpp.rb +8 -8
- data/lib/rouge/lexers/crystal.rb +70 -70
- data/lib/rouge/lexers/csharp.rb +28 -28
- data/lib/rouge/lexers/css.rb +23 -23
- data/lib/rouge/lexers/d.rb +59 -59
- data/lib/rouge/lexers/dart.rb +33 -33
- data/lib/rouge/lexers/digdag.rb +1 -1
- data/lib/rouge/lexers/docker.rb +10 -10
- data/lib/rouge/lexers/dot.rb +16 -16
- data/lib/rouge/lexers/eiffel.rb +20 -20
- data/lib/rouge/lexers/elixir.rb +34 -30
- data/lib/rouge/lexers/elm.rb +29 -29
- data/lib/rouge/lexers/erb.rb +4 -4
- data/lib/rouge/lexers/factor.rb +40 -40
- data/lib/rouge/lexers/fortran.rb +32 -32
- data/lib/rouge/lexers/fsharp.rb +30 -30
- data/lib/rouge/lexers/gherkin.rb +13 -13
- data/lib/rouge/lexers/glsl.rb +1 -5
- data/lib/rouge/lexers/go.rb +1 -1
- data/lib/rouge/lexers/graphql.rb +62 -62
- data/lib/rouge/lexers/groovy.rb +23 -25
- data/lib/rouge/lexers/hack.rb +1 -1
- data/lib/rouge/lexers/haml.rb +25 -29
- data/lib/rouge/lexers/handlebars.rb +18 -18
- data/lib/rouge/lexers/haskell.rb +66 -65
- data/lib/rouge/lexers/hcl.rb +25 -25
- data/lib/rouge/lexers/html.rb +31 -31
- data/lib/rouge/lexers/http.rb +4 -4
- data/lib/rouge/lexers/hylang.rb +14 -14
- data/lib/rouge/lexers/idlang.rb +32 -32
- data/lib/rouge/lexers/igorpro.rb +30 -30
- data/lib/rouge/lexers/ini.rb +12 -12
- data/lib/rouge/lexers/io.rb +7 -7
- data/lib/rouge/lexers/irb.rb +5 -5
- data/lib/rouge/lexers/java.rb +24 -24
- data/lib/rouge/lexers/javascript.rb +51 -51
- data/lib/rouge/lexers/jinja.rb +22 -22
- data/lib/rouge/lexers/json.rb +12 -11
- data/lib/rouge/lexers/json_doc.rb +2 -2
- data/lib/rouge/lexers/jsonnet.rb +18 -18
- data/lib/rouge/lexers/jsp.rb +30 -30
- data/lib/rouge/lexers/jsx.rb +16 -16
- data/lib/rouge/lexers/julia.rb +44 -44
- data/lib/rouge/lexers/kotlin.rb +3 -3
- data/lib/rouge/lexers/lasso.rb +50 -50
- data/lib/rouge/lexers/liquid.rb +76 -53
- data/lib/rouge/lexers/literate_coffeescript.rb +2 -2
- data/lib/rouge/lexers/literate_haskell.rb +5 -5
- data/lib/rouge/lexers/llvm.rb +23 -16
- data/lib/rouge/lexers/lua.rb +3 -3
- data/lib/rouge/lexers/m68k.rb +18 -19
- data/lib/rouge/lexers/magik.rb +127 -0
- data/lib/rouge/lexers/make.rb +26 -31
- data/lib/rouge/lexers/markdown.rb +37 -37
- data/lib/rouge/lexers/mathematica.rb +11 -11
- data/lib/rouge/lexers/matlab.rb +20 -20
- data/lib/rouge/lexers/moonscript.rb +3 -3
- data/lib/rouge/lexers/mosel.rb +63 -63
- data/lib/rouge/lexers/mxml.rb +18 -18
- data/lib/rouge/lexers/nasm.rb +24 -25
- data/lib/rouge/lexers/nginx.rb +14 -14
- data/lib/rouge/lexers/nim.rb +3 -2
- data/lib/rouge/lexers/nix.rb +43 -43
- data/lib/rouge/lexers/objective_c.rb +38 -38
- data/lib/rouge/lexers/ocaml.rb +29 -29
- data/lib/rouge/lexers/openedge.rb +429 -0
- data/lib/rouge/lexers/pascal.rb +4 -4
- data/lib/rouge/lexers/perl.rb +77 -79
- data/lib/rouge/lexers/php.rb +38 -38
- data/lib/rouge/lexers/plist.rb +14 -14
- data/lib/rouge/lexers/pony.rb +19 -19
- data/lib/rouge/lexers/powershell.rb +183 -637
- data/lib/rouge/lexers/praat.rb +75 -75
- data/lib/rouge/lexers/prolog.rb +26 -20
- data/lib/rouge/lexers/prometheus.rb +30 -30
- data/lib/rouge/lexers/properties.rb +12 -12
- data/lib/rouge/lexers/protobuf.rb +22 -22
- data/lib/rouge/lexers/puppet.rb +31 -31
- data/lib/rouge/lexers/python.rb +52 -52
- data/lib/rouge/lexers/q.rb +12 -12
- data/lib/rouge/lexers/qml.rb +12 -12
- data/lib/rouge/lexers/r.rb +12 -12
- data/lib/rouge/lexers/racket.rb +22 -22
- data/lib/rouge/lexers/ruby.rb +72 -70
- data/lib/rouge/lexers/rust.rb +30 -30
- data/lib/rouge/lexers/sass.rb +8 -8
- data/lib/rouge/lexers/sass/common.rb +40 -40
- data/lib/rouge/lexers/scala.rb +43 -43
- data/lib/rouge/lexers/scheme.rb +18 -18
- data/lib/rouge/lexers/scss.rb +3 -3
- data/lib/rouge/lexers/sed.rb +29 -29
- data/lib/rouge/lexers/shell.rb +61 -52
- data/lib/rouge/lexers/sieve.rb +8 -8
- data/lib/rouge/lexers/slim.rb +24 -24
- data/lib/rouge/lexers/smalltalk.rb +33 -33
- data/lib/rouge/lexers/smarty.rb +12 -12
- data/lib/rouge/lexers/sml.rb +67 -67
- data/lib/rouge/lexers/sqf.rb +1 -1
- data/lib/rouge/lexers/sql.rb +21 -21
- data/lib/rouge/lexers/supercollider.rb +19 -19
- data/lib/rouge/lexers/swift.rb +46 -43
- data/lib/rouge/lexers/tap.rb +20 -20
- data/lib/rouge/lexers/tcl.rb +27 -27
- data/lib/rouge/lexers/terraform.rb +13 -13
- data/lib/rouge/lexers/tex.rb +19 -19
- data/lib/rouge/lexers/toml.rb +19 -19
- data/lib/rouge/lexers/tulip.rb +36 -36
- data/lib/rouge/lexers/turtle.rb +35 -38
- data/lib/rouge/lexers/vala.rb +18 -18
- data/lib/rouge/lexers/vb.rb +27 -27
- data/lib/rouge/lexers/verilog.rb +25 -27
- data/lib/rouge/lexers/vhdl.rb +11 -11
- data/lib/rouge/lexers/viml.rb +14 -14
- data/lib/rouge/lexers/vue.rb +9 -9
- data/lib/rouge/lexers/wollok.rb +26 -26
- data/lib/rouge/lexers/xml.rb +17 -21
- data/lib/rouge/lexers/xojo.rb +17 -17
- data/lib/rouge/lexers/xpath.rb +332 -0
- data/lib/rouge/lexers/xquery.rb +145 -0
- data/lib/rouge/lexers/yaml.rb +63 -61
- data/lib/rouge/plugins/redcarpet.rb +1 -1
- data/lib/rouge/regex_lexer.rb +14 -13
- data/lib/rouge/tex_theme_renderer.rb +128 -0
- data/lib/rouge/theme.rb +4 -0
- data/lib/rouge/themes/magritte.rb +78 -0
- data/lib/rouge/themes/monokai_sublime.rb +2 -1
- data/lib/rouge/themes/pastie.rb +1 -1
- data/lib/rouge/util.rb +2 -2
- data/lib/rouge/version.rb +1 -1
- metadata +19 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: '0978a751e99189848662ab1f4d6b3763ff4ffc6bafa51d53f74a5f7d085492f5'
|
4
|
+
data.tar.gz: 06b154a4db8264d688c8a279c04ca6d82f8f188ae184b75a4b75df8726af3b28
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 1296057ef9206c038ba0da5a2c06e7e9658c95ece00bc98e8b5e22d53865930fd132ea5c3bbb9eaf6d1590c38b4680e9a83e5a7101e6a4ad5aab1be4910f01d2
|
7
|
+
data.tar.gz: 34acb9f469772310659845294d8fd3adfe989102cc6533a9632e64f41f1f20ad42f2e3951a0377ce8380b83b3a886178829c70868df987eb7f16f02b5f131272
|
data/lib/rouge.rb
CHANGED
@@ -69,11 +69,14 @@ load_relative 'rouge/formatters/html_table'
|
|
69
69
|
load_relative 'rouge/formatters/html_pygments'
|
70
70
|
load_relative 'rouge/formatters/html_legacy'
|
71
71
|
load_relative 'rouge/formatters/html_linewise'
|
72
|
+
load_relative 'rouge/formatters/html_line_table'
|
72
73
|
load_relative 'rouge/formatters/html_inline'
|
73
74
|
load_relative 'rouge/formatters/terminal256'
|
75
|
+
load_relative 'rouge/formatters/tex'
|
74
76
|
load_relative 'rouge/formatters/null'
|
75
77
|
|
76
78
|
load_relative 'rouge/theme'
|
79
|
+
load_relative 'rouge/tex_theme_renderer'
|
77
80
|
load_relative 'rouge/themes/thankful_eyes'
|
78
81
|
load_relative 'rouge/themes/colorful'
|
79
82
|
load_relative 'rouge/themes/base16'
|
@@ -86,3 +89,4 @@ load_relative 'rouge/themes/gruvbox'
|
|
86
89
|
load_relative 'rouge/themes/tulip'
|
87
90
|
load_relative 'rouge/themes/pastie'
|
88
91
|
load_relative 'rouge/themes/bw'
|
92
|
+
load_relative 'rouge/themes/magritte'
|
data/lib/rouge/cli.rb
CHANGED
@@ -38,7 +38,7 @@ module Rouge
|
|
38
38
|
def self.doc
|
39
39
|
return enum_for(:doc) unless block_given?
|
40
40
|
|
41
|
-
yield %|usage: rougify [command] [args...]|
|
41
|
+
yield %|usage: rougify {global options} [command] [args...]|
|
42
42
|
yield %||
|
43
43
|
yield %|where <command> is one of:|
|
44
44
|
yield %| highlight #{Highlight.desc}|
|
@@ -48,6 +48,9 @@ module Rouge
|
|
48
48
|
yield %| guess #{Guess.desc}|
|
49
49
|
yield %| version #{Version.desc}|
|
50
50
|
yield %||
|
51
|
+
yield %|global options:|
|
52
|
+
yield %[ --require|-r <fname> require <fname> after loading rouge]
|
53
|
+
yield %||
|
51
54
|
yield %|See `rougify help <command>` for more info.|
|
52
55
|
end
|
53
56
|
|
@@ -62,18 +65,22 @@ module Rouge
|
|
62
65
|
def self.parse(argv=ARGV)
|
63
66
|
argv = normalize_syntax(argv)
|
64
67
|
|
65
|
-
|
68
|
+
while (head = argv.shift)
|
69
|
+
case head
|
70
|
+
when '-h', '--help', 'help', '-help'
|
71
|
+
return Help.parse(argv)
|
72
|
+
when '--require', '-r'
|
73
|
+
require argv.shift
|
74
|
+
else
|
75
|
+
break
|
76
|
+
end
|
77
|
+
end
|
66
78
|
|
67
|
-
klass = class_from_arg(
|
79
|
+
klass = class_from_arg(head)
|
68
80
|
return klass.parse(argv) if klass
|
69
81
|
|
70
|
-
|
71
|
-
|
72
|
-
Help.parse(argv)
|
73
|
-
else
|
74
|
-
argv.unshift(mode) if mode
|
75
|
-
Highlight.parse(argv)
|
76
|
-
end
|
82
|
+
argv.unshift(head) if head
|
83
|
+
Highlight.parse(argv)
|
77
84
|
end
|
78
85
|
|
79
86
|
def initialize(options={})
|
@@ -91,7 +98,7 @@ module Rouge
|
|
91
98
|
case arg
|
92
99
|
when 'version', '--version', '-v'
|
93
100
|
Version
|
94
|
-
when 'help'
|
101
|
+
when 'help', nil
|
95
102
|
Help
|
96
103
|
when 'highlight', 'hi'
|
97
104
|
Highlight
|
@@ -297,8 +304,10 @@ module Rouge
|
|
297
304
|
when 'html' then Formatters::HTML.new
|
298
305
|
when 'html-pygments' then Formatters::HTMLPygments.new(Formatters::HTML.new, opts[:css_class])
|
299
306
|
when 'html-inline' then Formatters::HTMLInline.new(theme)
|
307
|
+
when 'html-line-table' then Formatters::HTMLLineTable.new(Formatters::HTML.new)
|
300
308
|
when 'html-table' then Formatters::HTMLTable.new(Formatters::HTML.new)
|
301
309
|
when 'null', 'raw', 'tokens' then Formatters::Null.new
|
310
|
+
when 'tex' then Formatters::Tex.new
|
302
311
|
else
|
303
312
|
error! "unknown formatter preset #{opts[:formatter]}"
|
304
313
|
end
|
@@ -334,18 +343,30 @@ module Rouge
|
|
334
343
|
yield %|respectively. Theme defaults to thankful_eyes.|
|
335
344
|
yield %||
|
336
345
|
yield %|options:|
|
337
|
-
yield %| --scope
|
346
|
+
yield %| --scope (default: .highlight) a css selector to scope by|
|
347
|
+
yield %| --tex (default: false) render as TeX|
|
348
|
+
yield %| --tex-prefix (default: RG) a command prefix for TeX|
|
349
|
+
yield %| implies --tex if specified|
|
338
350
|
yield %||
|
339
351
|
yield %|available themes:|
|
340
352
|
yield %| #{Theme.registry.keys.sort.join(', ')}|
|
341
353
|
end
|
342
354
|
|
343
355
|
def self.parse(argv)
|
344
|
-
opts = {
|
356
|
+
opts = {
|
357
|
+
:theme_name => 'thankful_eyes',
|
358
|
+
:tex => false,
|
359
|
+
:tex_prefix => 'RG'
|
360
|
+
}
|
345
361
|
|
346
362
|
until argv.empty?
|
347
363
|
arg = argv.shift
|
348
364
|
case arg
|
365
|
+
when '--tex'
|
366
|
+
opts[:tex] = true
|
367
|
+
when '--tex-prefix'
|
368
|
+
opts[:tex] = true
|
369
|
+
opts[:tex_prefix] = argv.shift
|
349
370
|
when /--(\w+)/
|
350
371
|
opts[$1.tr('-', '_').to_sym] = argv.shift
|
351
372
|
else
|
@@ -362,6 +383,10 @@ module Rouge
|
|
362
383
|
or error! "unknown theme: #{theme_name}"
|
363
384
|
|
364
385
|
@theme = theme_class.new(opts)
|
386
|
+
if opts[:tex]
|
387
|
+
tex_prefix = opts[:tex_prefix]
|
388
|
+
@theme = TexThemeRenderer.new(@theme, prefix: tex_prefix)
|
389
|
+
end
|
365
390
|
end
|
366
391
|
|
367
392
|
def run
|
data/lib/rouge/demos/bpf
ADDED
data/lib/rouge/demos/powershell
CHANGED
@@ -1,49 +1,13 @@
|
|
1
|
-
|
2
|
-
<#
|
3
|
-
.SYNOPSIS
|
4
|
-
Read IPv4Scopes from an array of servers
|
5
|
-
.PARAMETER Servers
|
6
|
-
Specifies an array of servers
|
7
|
-
.EXAMPLE
|
8
|
-
Get-IPv4Scopes
|
9
|
-
|
10
|
-
Will prompt for all inputs
|
11
|
-
#>
|
1
|
+
function Verb-Noun
|
12
2
|
{
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
[parameter(Mandatory=$false,ValueFromPipeline=$false)]
|
25
|
-
[bool]$Unique=$false
|
26
|
-
) #EndParam
|
27
|
-
|
28
|
-
Begin {}
|
29
|
-
|
30
|
-
Process {
|
31
|
-
$arrayJobs=@()
|
32
|
-
foreach ($server in $Servers) {
|
33
|
-
$arrayJobs+=Invoke-Command -ComputerName $server -scriptblock {Get-DhcpServerv4Scope} -AsJob
|
34
|
-
}
|
35
|
-
$complete=$false
|
36
|
-
while (-not $complete) {
|
37
|
-
$arrayJobsInProgress= $arrayJobs | Where-Object { $_.State -match 'running' }
|
38
|
-
if (-not $arrayJobsInProgress) { $complete=$true }
|
39
|
-
}
|
40
|
-
$Scopes=$arrayJobs|Receive-Job
|
41
|
-
$UniqueScopes=$Scopes|Sort-Object -Property ScopeId -Unique
|
42
|
-
}
|
43
|
-
|
44
|
-
End {
|
45
|
-
if ($Unique) { return $UniqueScopes }
|
46
|
-
else { return $Scopes }
|
47
|
-
}
|
48
|
-
|
49
|
-
} #end function
|
3
|
+
<#
|
4
|
+
.SYNOPSIS
|
5
|
+
Tells you what it does
|
6
|
+
|
7
|
+
.DESCRIPTION
|
8
|
+
Tells you what it does with more detail.
|
9
|
+
#>
|
10
|
+
param ([string]$Name, [string]$Extension = "txt", [string]$foo="bar")
|
11
|
+
$name = $name + "." + $extension
|
12
|
+
$name
|
13
|
+
}
|
data/lib/rouge/demos/xojo
CHANGED
@@ -1,7 +1,8 @@
|
|
1
1
|
Dim f As FolderItem
|
2
2
|
f = GetOpenFolderItem(FileTypes1.jpeg) // defined in the File Type Set editor
|
3
|
+
rem - we should check for nil!
|
3
4
|
If not f.Exists Then
|
4
|
-
Beep
|
5
|
+
Beep 'Just for fun
|
5
6
|
MsgBox("The file " + f.NativePath + "doesn't ""exist.""")
|
6
7
|
Else // document exists
|
7
8
|
ImageWell1.image=Picture.Open(f)
|
@@ -0,0 +1,22 @@
|
|
1
|
+
declare namespace html = "http://www.w3.org/1999/xhtml";
|
2
|
+
|
3
|
+
declare function local:test-function($catalog as document-node()) {
|
4
|
+
<html>
|
5
|
+
<head>
|
6
|
+
<title>XQuery example for the Rouge highlighter</title>
|
7
|
+
<link href="style.css"/>
|
8
|
+
</head>
|
9
|
+
<body>
|
10
|
+
<h1>List</h1>
|
11
|
+
<ul>
|
12
|
+
{for $product in $catalog/items/product[@sell-by > current-date()] return
|
13
|
+
<li>
|
14
|
+
<ul>
|
15
|
+
<li>{data($product/name)}</li>
|
16
|
+
<li>{$product/price * (1 + $product/tax)}$</li>
|
17
|
+
</ul>
|
18
|
+
</li>}
|
19
|
+
</ul>
|
20
|
+
</body>
|
21
|
+
</html>
|
22
|
+
};
|
data/lib/rouge/formatter.rb
CHANGED
@@ -29,7 +29,7 @@ module Rouge
|
|
29
29
|
end
|
30
30
|
|
31
31
|
def self.escape_enabled?
|
32
|
-
!!(@escape_enabled || Thread.current[:'rouge/with-escape'])
|
32
|
+
!!(((defined? @escape_enabled) && @escape_enabled) || Thread.current[:'rouge/with-escape'])
|
33
33
|
end
|
34
34
|
|
35
35
|
def self.enable_escape!
|
@@ -94,7 +94,7 @@ module Rouge
|
|
94
94
|
|
95
95
|
out = []
|
96
96
|
tokens.each do |tok, val|
|
97
|
-
val.scan /\n|[^\n]+/ do |s|
|
97
|
+
val.scan %r/\n|[^\n]+/ do |s|
|
98
98
|
if s == "\n"
|
99
99
|
yield out
|
100
100
|
out = []
|
@@ -15,7 +15,7 @@ module Rouge
|
|
15
15
|
def span(tok, val)
|
16
16
|
return val if escape?(tok)
|
17
17
|
|
18
|
-
safe_span(tok, val
|
18
|
+
safe_span(tok, escape_special_html_chars(val))
|
19
19
|
end
|
20
20
|
|
21
21
|
def safe_span(tok, safe_val)
|
@@ -29,12 +29,28 @@ module Rouge
|
|
29
29
|
end
|
30
30
|
end
|
31
31
|
|
32
|
-
|
33
32
|
TABLE_FOR_ESCAPE_HTML = {
|
34
33
|
'&' => '&',
|
35
34
|
'<' => '<',
|
36
35
|
'>' => '>',
|
37
36
|
}
|
37
|
+
|
38
|
+
private
|
39
|
+
# A performance-oriented helper method to escape `&`, `<` and `>` for the rendered
|
40
|
+
# HTML from this formatter.
|
41
|
+
#
|
42
|
+
# `String#gsub` will always return a new string instance irrespective of whether
|
43
|
+
# a substitution occurs. This method however invokes `String#gsub` only if
|
44
|
+
# a substitution is imminent.
|
45
|
+
#
|
46
|
+
# Returns either the given `value` argument string as is or a new string with the
|
47
|
+
# special characters replaced with their escaped counterparts.
|
48
|
+
def escape_special_html_chars(value)
|
49
|
+
escape_regex = /[&<>]/
|
50
|
+
return value unless value =~ escape_regex
|
51
|
+
|
52
|
+
value.gsub(escape_regex, TABLE_FOR_ESCAPE_HTML)
|
53
|
+
end
|
38
54
|
end
|
39
55
|
end
|
40
56
|
end
|
@@ -0,0 +1,51 @@
|
|
1
|
+
# -*- coding: utf-8 -*- #
|
2
|
+
# frozen_string_literal: true
|
3
|
+
|
4
|
+
module Rouge
|
5
|
+
module Formatters
|
6
|
+
class HTMLLineTable < Formatter
|
7
|
+
tag 'html_line_table'
|
8
|
+
|
9
|
+
# @param [Rouge::Formatters::Formatter] formatter An instance of a
|
10
|
+
# `Rouge::Formatters::HTML` or `Rouge::Formatters::HTMLInline`
|
11
|
+
# @param [Hash] opts options for HTMLLineTable instance.
|
12
|
+
# @option opts [Integer] :start_line line number to start from. Defaults to `1`.
|
13
|
+
# @option opts [String] :table_class Class name for the table.
|
14
|
+
# Defaults to `"rouge-line-table"`.
|
15
|
+
# @option opts [String] :line_id a `sprintf` template for generating an `id`
|
16
|
+
# attribute for each table row corresponding to current line number.
|
17
|
+
# Defaults to `"line-%i"`.
|
18
|
+
# @option opts [String] :line_class Class name for each table row.
|
19
|
+
# Defaults to `"lineno"`.
|
20
|
+
# @option opts [String] :gutter_class Class name for rendered line-number cell.
|
21
|
+
# Defaults to `"rouge-gutter"`.
|
22
|
+
# @option opts [String] :code_class Class name for rendered code cell.
|
23
|
+
# Defaults to `"rouge-code"`.
|
24
|
+
def initialize(formatter, opts={})
|
25
|
+
@formatter = formatter
|
26
|
+
@start_line = opts.fetch :start_line, 1
|
27
|
+
@table_class = opts.fetch :table_class, 'rouge-line-table'
|
28
|
+
@gutter_class = opts.fetch :gutter_class, 'rouge-gutter'
|
29
|
+
@code_class = opts.fetch :code_class, 'rouge-code'
|
30
|
+
@line_class = opts.fetch :line_class, 'lineno'
|
31
|
+
@line_id = opts.fetch :line_id, 'line-%i'
|
32
|
+
end
|
33
|
+
|
34
|
+
def stream(tokens, &b)
|
35
|
+
lineno = @start_line - 1
|
36
|
+
buffer = [%(<table class="#@table_class"><tbody>)]
|
37
|
+
token_lines(tokens) do |line_tokens|
|
38
|
+
lineno += 1
|
39
|
+
buffer << %(<tr id="#{sprintf @line_id, lineno}" class="#@line_class">)
|
40
|
+
buffer << %(<td class="#@gutter_class gl">)
|
41
|
+
buffer << %(<pre>#{lineno}</pre></td>)
|
42
|
+
buffer << %(<td class="#@code_class"><pre>)
|
43
|
+
@formatter.stream(line_tokens) { |formatted| buffer << formatted }
|
44
|
+
buffer << "\n</pre></td></tr>"
|
45
|
+
end
|
46
|
+
buffer << %(</tbody></table>)
|
47
|
+
yield buffer.join
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
51
|
+
end
|
@@ -0,0 +1,90 @@
|
|
1
|
+
module Rouge
|
2
|
+
module Formatters
|
3
|
+
class Tex < Formatter
|
4
|
+
tag 'tex'
|
5
|
+
|
6
|
+
# A map of TeX escape characters.
|
7
|
+
# Newlines are handled specially by using #token_lines
|
8
|
+
# spaces are preserved as long as they aren't at the beginning
|
9
|
+
# of a line. see #tag_first for our initial-space strategy
|
10
|
+
ESCAPE = {
|
11
|
+
'&' => '\&',
|
12
|
+
'%' => '\%',
|
13
|
+
'$' => '\$',
|
14
|
+
'#' => '\#',
|
15
|
+
'_' => '\_',
|
16
|
+
'{' => '\{',
|
17
|
+
'}' => '\}',
|
18
|
+
'~' => '{\textasciitilde}',
|
19
|
+
'^' => '{\textasciicircum}',
|
20
|
+
'|' => '{\textbar}',
|
21
|
+
'\\' => '{\textbackslash}',
|
22
|
+
"\t" => '{\tab}',
|
23
|
+
}
|
24
|
+
|
25
|
+
ESCAPE_REGEX = /[#{ESCAPE.keys.map(&Regexp.method(:escape)).join}]/om
|
26
|
+
|
27
|
+
def initialize(opts={})
|
28
|
+
@prefix = opts.fetch(:prefix) { 'RG' }
|
29
|
+
end
|
30
|
+
|
31
|
+
def escape_tex(str)
|
32
|
+
str.gsub(ESCAPE_REGEX, ESCAPE)
|
33
|
+
end
|
34
|
+
|
35
|
+
def stream(tokens, &b)
|
36
|
+
# surround the output with \begin{RG*}...\end{RG*}
|
37
|
+
yield "\\begin{#{@prefix}*}%\n"
|
38
|
+
|
39
|
+
# we strip the newline off the last line to avoid
|
40
|
+
# an extra line being rendered. we do this by yielding
|
41
|
+
# the \newline tag *before* every line group except
|
42
|
+
# the first.
|
43
|
+
first = true
|
44
|
+
|
45
|
+
token_lines tokens do |line|
|
46
|
+
if first
|
47
|
+
first = false
|
48
|
+
else
|
49
|
+
yield "\\newline%\n"
|
50
|
+
end
|
51
|
+
|
52
|
+
render_line(line, &b)
|
53
|
+
end
|
54
|
+
|
55
|
+
yield "%\n\\end{#{@prefix}*}%\n"
|
56
|
+
end
|
57
|
+
|
58
|
+
def render_line(line, &b)
|
59
|
+
head, *rest = line
|
60
|
+
return unless head
|
61
|
+
|
62
|
+
tag_first(*head, &b)
|
63
|
+
rest.each do |(tok, val)|
|
64
|
+
yield tag(tok, val)
|
65
|
+
end
|
66
|
+
end
|
67
|
+
|
68
|
+
# special handling for the first token
|
69
|
+
# of a line. we replace all initial spaces
|
70
|
+
# with \hphantom{xxxx}, which renders an
|
71
|
+
# empty space equal to the size of the x's.
|
72
|
+
def tag_first(tok, val)
|
73
|
+
leading = nil
|
74
|
+
val.sub!(/^[ ]+/) { leading = $&.size; '' }
|
75
|
+
yield "\\hphantom{#{'x' * leading}}" if leading
|
76
|
+
yield tag(tok, val)
|
77
|
+
end
|
78
|
+
|
79
|
+
def tag(tok, val)
|
80
|
+
if escape?(tok)
|
81
|
+
val
|
82
|
+
elsif tok == Token::Tokens::Text
|
83
|
+
escape_tex(val)
|
84
|
+
else
|
85
|
+
"\\#@prefix{#{tok.shortname}}{#{escape_tex(val)}}"
|
86
|
+
end
|
87
|
+
end
|
88
|
+
end
|
89
|
+
end
|
90
|
+
end
|