asciidoctor-diagram 1.2.0 → 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +5 -5
- data/CHANGELOG.adoc +262 -7
- data/README.adoc +463 -40
- data/README_zh-CN.adoc +336 -0
- data/Rakefile +3 -7
- data/examples/features.adoc +2 -2
- data/images/asciidoctor-diagram-classes.png +0 -0
- data/images/asciidoctor-diagram-process.png +0 -0
- data/lib/asciidoctor-diagram/a2s/converter.rb +55 -0
- data/lib/asciidoctor-diagram/a2s/extension.rb +14 -0
- data/lib/asciidoctor-diagram/a2s.rb +7 -0
- data/lib/asciidoctor-diagram/blockdiag/converter.rb +37 -0
- data/lib/asciidoctor-diagram/blockdiag/extension.rb +11 -11
- data/lib/asciidoctor-diagram/blockdiag.rb +5 -4
- data/lib/asciidoctor-diagram/bpmn/converter.rb +62 -0
- data/lib/asciidoctor-diagram/bpmn/extension.rb +14 -0
- data/lib/asciidoctor-diagram/bpmn.rb +7 -0
- data/lib/asciidoctor-diagram/diagram_converter.rb +19 -0
- data/lib/asciidoctor-diagram/diagram_processor.rb +320 -0
- data/lib/asciidoctor-diagram/diagram_source.rb +275 -0
- data/lib/asciidoctor-diagram/ditaa/converter.rb +86 -0
- data/lib/asciidoctor-diagram/ditaa/extension.rb +6 -28
- data/lib/asciidoctor-diagram/ditaa.rb +3 -4
- data/lib/asciidoctor-diagram/erd/converter.rb +31 -0
- data/lib/asciidoctor-diagram/erd/extension.rb +14 -0
- data/lib/asciidoctor-diagram/erd.rb +7 -0
- data/lib/asciidoctor-diagram/gnuplot/converter.rb +63 -0
- data/lib/asciidoctor-diagram/gnuplot/extension.rb +14 -0
- data/lib/asciidoctor-diagram/gnuplot.rb +7 -0
- data/lib/asciidoctor-diagram/graphviz/converter.rb +32 -0
- data/lib/asciidoctor-diagram/graphviz/extension.rb +8 -10
- data/lib/asciidoctor-diagram/graphviz.rb +3 -4
- data/lib/asciidoctor-diagram/http/server.rb +127 -0
- data/lib/asciidoctor-diagram/lilypond/converter.rb +54 -0
- data/lib/asciidoctor-diagram/lilypond/extension.rb +14 -0
- data/lib/asciidoctor-diagram/lilypond.rb +7 -0
- data/lib/asciidoctor-diagram/meme/converter.rb +122 -0
- data/lib/asciidoctor-diagram/meme/extension.rb +28 -0
- data/lib/asciidoctor-diagram/meme.rb +6 -0
- data/lib/asciidoctor-diagram/mermaid/converter.rb +178 -0
- data/lib/asciidoctor-diagram/mermaid/extension.rb +14 -0
- data/lib/asciidoctor-diagram/mermaid.rb +7 -0
- data/lib/asciidoctor-diagram/msc/converter.rb +35 -0
- data/lib/asciidoctor-diagram/msc/extension.rb +14 -0
- data/lib/asciidoctor-diagram/msc.rb +7 -0
- data/lib/asciidoctor-diagram/nomnoml/converter.rb +25 -0
- data/lib/asciidoctor-diagram/nomnoml/extension.rb +14 -0
- data/lib/asciidoctor-diagram/nomnoml.rb +7 -0
- data/lib/asciidoctor-diagram/plantuml/converter.rb +115 -0
- data/lib/asciidoctor-diagram/plantuml/extension.rb +14 -20
- data/lib/asciidoctor-diagram/plantuml.rb +3 -5
- data/lib/asciidoctor-diagram/salt.rb +7 -0
- data/lib/asciidoctor-diagram/shaape/converter.rb +25 -0
- data/lib/asciidoctor-diagram/shaape/extension.rb +9 -11
- data/lib/asciidoctor-diagram/shaape.rb +3 -5
- data/lib/asciidoctor-diagram/smcat/converter.rb +44 -0
- data/lib/asciidoctor-diagram/smcat/extension.rb +14 -0
- data/lib/asciidoctor-diagram/smcat.rb +7 -0
- data/lib/asciidoctor-diagram/svgbob/converter.rb +25 -0
- data/lib/asciidoctor-diagram/svgbob/extension.rb +14 -0
- data/lib/asciidoctor-diagram/svgbob.rb +7 -0
- data/lib/asciidoctor-diagram/syntrax/converter.rb +55 -0
- data/lib/asciidoctor-diagram/syntrax/extension.rb +14 -0
- data/lib/asciidoctor-diagram/syntrax.rb +7 -0
- data/lib/asciidoctor-diagram/tikz/converter.rb +56 -0
- data/lib/asciidoctor-diagram/tikz/extension.rb +14 -0
- data/lib/asciidoctor-diagram/tikz.rb +7 -0
- data/lib/asciidoctor-diagram/umlet/converter.rb +24 -0
- data/lib/asciidoctor-diagram/umlet/extension.rb +14 -0
- data/lib/asciidoctor-diagram/umlet.rb +7 -0
- data/lib/asciidoctor-diagram/util/binaryio.rb +20 -0
- data/lib/asciidoctor-diagram/util/cli.rb +81 -0
- data/lib/asciidoctor-diagram/util/cli_generator.rb +73 -22
- data/lib/asciidoctor-diagram/util/gif.rb +21 -0
- data/lib/asciidoctor-diagram/util/java.rb +95 -1
- data/lib/asciidoctor-diagram/util/java_jruby.rb +14 -20
- data/lib/asciidoctor-diagram/util/java_socket.rb +175 -0
- data/lib/asciidoctor-diagram/util/pdf.rb +10 -0
- data/lib/asciidoctor-diagram/util/platform.rb +97 -0
- data/lib/asciidoctor-diagram/util/png.rb +1 -0
- data/lib/asciidoctor-diagram/util/svg.rb +4 -3
- data/lib/asciidoctor-diagram/util/which.rb +15 -9
- data/lib/asciidoctor-diagram/vega/converter.rb +47 -0
- data/lib/asciidoctor-diagram/vega/extension.rb +14 -0
- data/lib/asciidoctor-diagram/vega.rb +10 -0
- data/lib/asciidoctor-diagram/version.rb +1 -1
- data/lib/asciidoctor-diagram/wavedrom/converter.rb +50 -0
- data/lib/asciidoctor-diagram/wavedrom/extension.rb +14 -0
- data/lib/asciidoctor-diagram/wavedrom.rb +7 -0
- data/lib/asciidoctor-diagram.rb +22 -5
- data/lib/batik-all-1.10.jar +0 -0
- data/lib/ditaa-1.3.14.jar +0 -0
- data/lib/ditaamini-0.12.jar +0 -0
- data/lib/jlatexmath-minimal-1.0.5.jar +0 -0
- data/lib/plantuml-1.3.14.jar +0 -0
- data/lib/plantuml.jar +0 -0
- data/lib/server-1.3.14.jar +0 -0
- data/spec/a2s_spec.rb +167 -0
- data/spec/blockdiag_spec.rb +55 -24
- data/spec/bpmn-example.xml +44 -0
- data/spec/bpmn_spec.rb +96 -0
- data/spec/ditaa_spec.rb +150 -15
- data/spec/erd_spec.rb +289 -0
- data/spec/gnuplot_spec.rb +478 -0
- data/spec/graphviz_spec.rb +20 -20
- data/spec/lilypond_spec.rb +151 -0
- data/spec/man.jpg +0 -0
- data/spec/meme_spec.rb +67 -0
- data/spec/mermaid_spec.rb +336 -0
- data/spec/msc_spec.rb +230 -0
- data/spec/nomnoml_spec.rb +170 -0
- data/spec/plantuml_spec.rb +895 -54
- data/spec/shaape_spec.rb +25 -24
- data/spec/smcat_spec.rb +164 -0
- data/spec/svgbob_spec.rb +167 -0
- data/spec/syntrax_spec.rb +228 -0
- data/spec/test_helper.rb +88 -9
- data/spec/tikz_spec.rb +127 -0
- data/spec/umlet_spec.rb +85 -0
- data/spec/vega_spec.rb +241 -0
- data/spec/wavedrom_spec.rb +214 -0
- metadata +130 -35
- data/lib/asciidoctor-diagram/plantuml/generator.rb +0 -46
- data/lib/asciidoctor-diagram/util/diagram.rb +0 -220
- data/lib/asciidoctor-diagram/util/java_rjb.rb +0 -90
- data/lib/ditaamini0_9.jar +0 -0
@@ -0,0 +1,175 @@
|
|
1
|
+
require 'socket'
|
2
|
+
|
3
|
+
require_relative 'cli'
|
4
|
+
require_relative 'platform'
|
5
|
+
require_relative 'which'
|
6
|
+
|
7
|
+
module Asciidoctor
|
8
|
+
module Diagram
|
9
|
+
# @private
|
10
|
+
module Java
|
11
|
+
class CommandServer
|
12
|
+
def initialize(java, classpath)
|
13
|
+
args = []
|
14
|
+
args << '-Djava.awt.headless=true'
|
15
|
+
args << '-Djava.net.useSystemProxies=true'
|
16
|
+
args << '-cp'
|
17
|
+
args << classpath.flatten.map { |jar| ::Asciidoctor::Diagram::Platform.host_os_path(jar).strip }.join(::Asciidoctor::Diagram::Platform.host_os_path_separator)
|
18
|
+
args << 'org.asciidoctor.diagram.StdInOutCommandServer'
|
19
|
+
|
20
|
+
@server = IO.popen([java, *args], 'r+')
|
21
|
+
end
|
22
|
+
|
23
|
+
def io
|
24
|
+
@server
|
25
|
+
end
|
26
|
+
|
27
|
+
def shutdown
|
28
|
+
# KILL is a bit heavy handed, but TERM does not seem to shut down the JVM on Windows.
|
29
|
+
Process.kill('KILL', @server.pid)
|
30
|
+
@server.close
|
31
|
+
end
|
32
|
+
end
|
33
|
+
|
34
|
+
def self.load
|
35
|
+
if defined?(@loaded) && @loaded
|
36
|
+
return
|
37
|
+
end
|
38
|
+
|
39
|
+
instance
|
40
|
+
@loaded = true
|
41
|
+
end
|
42
|
+
|
43
|
+
def self.instance
|
44
|
+
@java_exe ||= find_java
|
45
|
+
raise "Could not find Java executable" unless @java_exe
|
46
|
+
|
47
|
+
unless defined?(@command_server) && @command_server
|
48
|
+
server = CommandServer.new(@java_exe, classpath)
|
49
|
+
@command_server = server
|
50
|
+
at_exit do
|
51
|
+
server.shutdown
|
52
|
+
end
|
53
|
+
end
|
54
|
+
|
55
|
+
@command_server
|
56
|
+
end
|
57
|
+
|
58
|
+
def self.send_request(req)
|
59
|
+
svr = instance
|
60
|
+
req[:headers] ||= {}
|
61
|
+
# headers = req[:headers] ||= {}
|
62
|
+
# headers['Host'] = "localhost:#{svr.port}"
|
63
|
+
format_request(req, svr.io)
|
64
|
+
parse_response(svr.io)
|
65
|
+
end
|
66
|
+
|
67
|
+
private
|
68
|
+
def self.find_java
|
69
|
+
case ::Asciidoctor::Diagram::Platform.os
|
70
|
+
when :windows
|
71
|
+
path_to(ENV['JAVA_HOME'], 'bin/java.exe') || registry_lookup || ::Asciidoctor::Diagram::Which.which('java')
|
72
|
+
when :macosx
|
73
|
+
path_to(ENV['JAVA_HOME'], 'bin/java') || path_to(::Asciidoctor::Diagram::Cli.run('/usr/libexec/java_home')[:out].strip, 'bin/java') || ::Asciidoctor::Diagram::Which.which('java')
|
74
|
+
else
|
75
|
+
path_to(ENV['JAVA_HOME'], 'bin/java') || ::Asciidoctor::Diagram::Which.which('java')
|
76
|
+
end
|
77
|
+
end
|
78
|
+
|
79
|
+
def self.path_to(java_home, java_binary)
|
80
|
+
exe_path = File.expand_path(java_binary, java_home)
|
81
|
+
if File.executable?(exe_path)
|
82
|
+
exe_path
|
83
|
+
else
|
84
|
+
nil
|
85
|
+
end
|
86
|
+
end
|
87
|
+
|
88
|
+
JDK_KEY = 'HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Development Kit'
|
89
|
+
JRE_KEY = 'HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft\Java Runtime Environment'
|
90
|
+
|
91
|
+
def self.registry_lookup
|
92
|
+
registry_current(JRE_KEY) || registry_current(JDK_KEY) || registry_any()
|
93
|
+
end
|
94
|
+
|
95
|
+
def self.registry_current(key)
|
96
|
+
current_version = registry_query(key, 'CurrentVersion')
|
97
|
+
if current_version
|
98
|
+
java_home = registry_query("#{key}\\#{current_version}", 'JavaHome')
|
99
|
+
java_exe(java_home)
|
100
|
+
else
|
101
|
+
nil
|
102
|
+
end
|
103
|
+
end
|
104
|
+
|
105
|
+
def self.registry_any()
|
106
|
+
java_homes = registry_query('HKEY_LOCAL_MACHINE\SOFTWARE\JavaSoft', 'JavaHome', :recursive => true).values
|
107
|
+
java_homes.map { |path| java_exe(path) }.find { |exe| !exe.nil? }
|
108
|
+
end
|
109
|
+
|
110
|
+
def self.java_exe(java_home)
|
111
|
+
java = File.expand_path('bin/java.exe', java_home)
|
112
|
+
|
113
|
+
if File.executable?(java)
|
114
|
+
java
|
115
|
+
else
|
116
|
+
nil
|
117
|
+
end
|
118
|
+
end
|
119
|
+
|
120
|
+
def self.registry_query(key, value = nil, opts = {})
|
121
|
+
args = ['reg', 'query']
|
122
|
+
args << key
|
123
|
+
args << '/v' << value unless value.nil?
|
124
|
+
args << '/s' if opts[:recursive]
|
125
|
+
|
126
|
+
begin
|
127
|
+
lines = ::Asciidoctor::Diagram::Cli.run(*args)[:out].lines.reject { |l| l.strip.empty? }.each
|
128
|
+
rescue
|
129
|
+
lines = [].each
|
130
|
+
end
|
131
|
+
|
132
|
+
result = {}
|
133
|
+
|
134
|
+
while true
|
135
|
+
begin
|
136
|
+
begin
|
137
|
+
k = lines.next
|
138
|
+
rescue StopIteration
|
139
|
+
break
|
140
|
+
end
|
141
|
+
|
142
|
+
unless k.start_with? key
|
143
|
+
next
|
144
|
+
end
|
145
|
+
|
146
|
+
v = nil
|
147
|
+
begin
|
148
|
+
v = lines.next.strip if lines.peek.start_with?(' ')
|
149
|
+
rescue StopIteration
|
150
|
+
break
|
151
|
+
end
|
152
|
+
|
153
|
+
if !k.valid_encoding? || (v && !v.valid_encoding?)
|
154
|
+
next
|
155
|
+
end
|
156
|
+
|
157
|
+
if v && (md = /([^\s]+)\s+(REG_[^\s]+)\s+(.+)/.match(v))
|
158
|
+
v_name = md[1]
|
159
|
+
v_value = md[3]
|
160
|
+
result["#{k}\\#{v_name}"] = v_value
|
161
|
+
else
|
162
|
+
result[k] = v
|
163
|
+
end
|
164
|
+
end
|
165
|
+
end
|
166
|
+
|
167
|
+
if value && !opts[:recursive]
|
168
|
+
result.values[0]
|
169
|
+
else
|
170
|
+
result
|
171
|
+
end
|
172
|
+
end
|
173
|
+
end
|
174
|
+
end
|
175
|
+
end
|
@@ -0,0 +1,97 @@
|
|
1
|
+
require 'rbconfig'
|
2
|
+
require_relative 'cli'
|
3
|
+
require_relative 'which'
|
4
|
+
|
5
|
+
module Asciidoctor
|
6
|
+
module Diagram
|
7
|
+
module Platform
|
8
|
+
def self.os
|
9
|
+
os_info[:os]
|
10
|
+
end
|
11
|
+
|
12
|
+
def self.os_variant
|
13
|
+
os_info[:os_variant]
|
14
|
+
end
|
15
|
+
|
16
|
+
def self.file_separator
|
17
|
+
os_info[:file_sep]
|
18
|
+
end
|
19
|
+
|
20
|
+
def self.host_os_file_separator
|
21
|
+
os_info[:host_os_file_sep]
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.path_separator
|
25
|
+
os_info[:path_sep]
|
26
|
+
end
|
27
|
+
|
28
|
+
def self.host_os_path_separator
|
29
|
+
os_info[:host_os_path_sep]
|
30
|
+
end
|
31
|
+
|
32
|
+
def self.os_info
|
33
|
+
@os ||= (
|
34
|
+
host_os = RbConfig::CONFIG['host_os']
|
35
|
+
|
36
|
+
file_sep = '/'
|
37
|
+
host_os_file_sep = nil
|
38
|
+
variant = nil
|
39
|
+
path_sep = ::File::PATH_SEPARATOR
|
40
|
+
host_os_path_sep = nil
|
41
|
+
|
42
|
+
case host_os
|
43
|
+
when /(msys|mingw|mswin|bccwin|wince|emc)/i
|
44
|
+
os = :windows
|
45
|
+
variant = $1.downcase.to_sym
|
46
|
+
file_sep = '\\'
|
47
|
+
when /(cygwin)/i
|
48
|
+
os = :windows
|
49
|
+
variant = $1.downcase.to_sym
|
50
|
+
host_os_file_sep = '\\'
|
51
|
+
host_os_path_sep = ';'
|
52
|
+
when /darwin|mac os/i
|
53
|
+
os = :macosx
|
54
|
+
when /linux/i
|
55
|
+
os = :linux
|
56
|
+
else
|
57
|
+
os = :unix
|
58
|
+
end
|
59
|
+
{
|
60
|
+
:os => os,
|
61
|
+
:os_variant => variant || os,
|
62
|
+
:file_sep => file_sep,
|
63
|
+
:host_os_file_sep => host_os_file_sep || file_sep,
|
64
|
+
:path_sep => path_sep,
|
65
|
+
:host_os_path_sep => host_os_path_sep || path_sep
|
66
|
+
}
|
67
|
+
)
|
68
|
+
end
|
69
|
+
|
70
|
+
def self.native_path(path)
|
71
|
+
return path if path.nil?
|
72
|
+
|
73
|
+
sep = file_separator
|
74
|
+
if sep != '/'
|
75
|
+
path.to_s.gsub('/', sep)
|
76
|
+
else
|
77
|
+
path.to_s
|
78
|
+
end
|
79
|
+
end
|
80
|
+
|
81
|
+
def self.host_os_path(path)
|
82
|
+
# special case for cygwin, it requires path translation for java to work
|
83
|
+
if os_variant == :cygwin
|
84
|
+
cygpath = ::Asciidoctor::Diagram::Which.which('cygpath')
|
85
|
+
if cygpath != nil
|
86
|
+
::Asciidoctor::Diagram::Cli.run(cygpath, '-w', path)[:out]
|
87
|
+
else
|
88
|
+
puts 'cygwin warning: cygpath not found'
|
89
|
+
native_path(path)
|
90
|
+
end
|
91
|
+
else
|
92
|
+
native_path(path)
|
93
|
+
end
|
94
|
+
end
|
95
|
+
end
|
96
|
+
end
|
97
|
+
end
|
@@ -2,6 +2,7 @@ require_relative 'binaryio'
|
|
2
2
|
|
3
3
|
module Asciidoctor
|
4
4
|
module Diagram
|
5
|
+
# @private
|
5
6
|
module SVG
|
6
7
|
def self.get_image_size(data)
|
7
8
|
if m = START_TAG_REGEX.match(data)
|
@@ -25,9 +26,9 @@ module Asciidoctor
|
|
25
26
|
private
|
26
27
|
|
27
28
|
START_TAG_REGEX = /<svg[^>]*>/
|
28
|
-
WIDTH_REGEX = /width="(?<value>\d+)(?<unit>[a-zA-Z]+)"/
|
29
|
-
HEIGHT_REGEX = /height="(?<value>\d+)(?<unit>[a-zA-Z]+)"/
|
30
|
-
VIEWBOX_REGEX = /viewBox="\d+ \d+ (?<width>\d+) (?<height>\d+)"/
|
29
|
+
WIDTH_REGEX = /width="(?<value>\d+(?:\.\d+)?)(?<unit>[a-zA-Z]+)?"/
|
30
|
+
HEIGHT_REGEX = /height="(?<value>\d+(?:\.\d+)?)(?<unit>[a-zA-Z]+)?"/
|
31
|
+
VIEWBOX_REGEX = /viewBox="\d+(?:\.\d+)? \d+(?:\.\d+)? (?<width>\d+(?:\.\d+)?) (?<height>\d+(?:\.\d+)?)"/
|
31
32
|
|
32
33
|
def self.to_px_factor(unit)
|
33
34
|
case unit
|
@@ -1,14 +1,20 @@
|
|
1
1
|
module Asciidoctor
|
2
2
|
module Diagram
|
3
|
-
|
4
|
-
|
5
|
-
|
6
|
-
exts.
|
7
|
-
|
8
|
-
|
9
|
-
|
3
|
+
module Which
|
4
|
+
# @private
|
5
|
+
def self.which(cmd, options = {})
|
6
|
+
exts = ENV['PATHEXT'] ? ENV['PATHEXT'].split(';') : ['']
|
7
|
+
|
8
|
+
paths = (options[:path] || []) + (ENV['PATH'] ? ENV['PATH'].split(File::PATH_SEPARATOR) : [])
|
9
|
+
paths.each do |path|
|
10
|
+
exts.each { |ext|
|
11
|
+
exe = File.join(path, "#{cmd}#{ext}")
|
12
|
+
return exe if File.executable? exe
|
13
|
+
}
|
14
|
+
end
|
15
|
+
|
16
|
+
nil
|
10
17
|
end
|
11
|
-
nil
|
12
18
|
end
|
13
19
|
end
|
14
|
-
end
|
20
|
+
end
|
@@ -0,0 +1,47 @@
|
|
1
|
+
require_relative '../diagram_converter'
|
2
|
+
require_relative '../util/cli_generator'
|
3
|
+
require_relative '../util/platform'
|
4
|
+
|
5
|
+
module Asciidoctor
|
6
|
+
module Diagram
|
7
|
+
# @private
|
8
|
+
class VegaConverter
|
9
|
+
include DiagramConverter
|
10
|
+
include CliGenerator
|
11
|
+
|
12
|
+
|
13
|
+
def supported_formats
|
14
|
+
[:svg, :png]
|
15
|
+
end
|
16
|
+
|
17
|
+
|
18
|
+
def collect_options(source, name)
|
19
|
+
{
|
20
|
+
:vegalite => name.to_s.include?('lite') || source.attr('vegalite')
|
21
|
+
}
|
22
|
+
end
|
23
|
+
|
24
|
+
def convert(source, format, options)
|
25
|
+
base_dir = source.base_dir
|
26
|
+
|
27
|
+
code = source.to_s
|
28
|
+
|
29
|
+
if code.include?('/schema/vega-lite/') || options[:vegalite]
|
30
|
+
vega_code = generate_stdin_stdout(source.find_command("vl2vg"), code)
|
31
|
+
else
|
32
|
+
vega_code = code
|
33
|
+
end
|
34
|
+
|
35
|
+
generate_file(source.find_command("vg2#{format}"), "json", format.to_s, vega_code) do |tool_path, input_path, output_path|
|
36
|
+
args = [tool_path, '--base', Platform.native_path(base_dir)]
|
37
|
+
if format == :svg
|
38
|
+
args << '--header'
|
39
|
+
end
|
40
|
+
|
41
|
+
args << Platform.native_path(input_path)
|
42
|
+
args << Platform.native_path(output_path)
|
43
|
+
end
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require_relative '../diagram_processor'
|
2
|
+
require_relative 'converter'
|
3
|
+
|
4
|
+
module Asciidoctor
|
5
|
+
module Diagram
|
6
|
+
class VegaBlockProcessor < DiagramBlockProcessor
|
7
|
+
use_converter VegaConverter
|
8
|
+
end
|
9
|
+
|
10
|
+
class VegaBlockMacroProcessor < DiagramBlockMacroProcessor
|
11
|
+
use_converter VegaConverter
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
@@ -0,0 +1,10 @@
|
|
1
|
+
require 'asciidoctor/extensions'
|
2
|
+
require_relative 'vega/extension'
|
3
|
+
|
4
|
+
Asciidoctor::Extensions.register do
|
5
|
+
block Asciidoctor::Diagram::VegaBlockProcessor, :vega
|
6
|
+
block_macro Asciidoctor::Diagram::VegaBlockMacroProcessor, :vega
|
7
|
+
|
8
|
+
block Asciidoctor::Diagram::VegaBlockProcessor, :vegalite
|
9
|
+
block_macro Asciidoctor::Diagram::VegaBlockMacroProcessor, :vegalite
|
10
|
+
end
|
@@ -0,0 +1,50 @@
|
|
1
|
+
require_relative '../diagram_converter'
|
2
|
+
require_relative '../util/cli_generator'
|
3
|
+
require_relative '../util/platform'
|
4
|
+
|
5
|
+
module Asciidoctor
|
6
|
+
module Diagram
|
7
|
+
# @private
|
8
|
+
class WavedromConverter
|
9
|
+
include DiagramConverter
|
10
|
+
include CliGenerator
|
11
|
+
|
12
|
+
|
13
|
+
def supported_formats
|
14
|
+
[:png, :svg]
|
15
|
+
end
|
16
|
+
|
17
|
+
|
18
|
+
def convert(source, format, options)
|
19
|
+
wavedrom_cli = source.find_command('wavedrom-cli', :raise_on_error => false)
|
20
|
+
if wavedrom_cli
|
21
|
+
generate_file(wavedrom_cli, 'wvd', format.to_s, source.to_s) do |tool_path, input_path, output_path|
|
22
|
+
[Platform.native_path(tool_path), '--input', Platform.native_path(input_path), "--#{format.to_s}", Platform.native_path(output_path)]
|
23
|
+
end
|
24
|
+
else
|
25
|
+
wavedrom_cli = source.find_command('wavedrom', :raise_on_error => false)
|
26
|
+
phantomjs = source.find_command('phantomjs', :alt_attrs => ['phantomjs_2'], :raise_on_error => false)
|
27
|
+
|
28
|
+
if wavedrom_cli && !wavedrom_cli.include?('WaveDromEditor') && phantomjs
|
29
|
+
generate_file(wavedrom_cli, 'wvd', format.to_s, source.to_s) do |tool_path, input_path, output_path|
|
30
|
+
[phantomjs, Platform.native_path(tool_path), '-i', Platform.native_path(input_path), "-#{format.to_s[0]}", Platform.native_path(output_path)]
|
31
|
+
end
|
32
|
+
else
|
33
|
+
if ::Asciidoctor::Diagram::Platform.os == :macosx
|
34
|
+
wavedrom = source.find_command('WaveDromEditor.app', :alt_cmds => ['wavedrom-editor.app'], :attrs => ['WaveDromEditorApp'], :path => ['/Applications'])
|
35
|
+
if wavedrom
|
36
|
+
wavedrom = File.join(wavedrom, 'Contents/MacOS/nwjs')
|
37
|
+
end
|
38
|
+
else
|
39
|
+
wavedrom = source.find_command('WaveDromEditor')
|
40
|
+
end
|
41
|
+
|
42
|
+
generate_file(wavedrom, 'wvd', format.to_s, source.to_s) do |tool_path, input_path, output_path|
|
43
|
+
[tool_path, 'source', Platform.native_path(input_path), format.to_s, Platform.native_path(output_path)]
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
50
|
+
end
|
@@ -0,0 +1,14 @@
|
|
1
|
+
require_relative '../diagram_processor'
|
2
|
+
require_relative 'converter'
|
3
|
+
|
4
|
+
module Asciidoctor
|
5
|
+
module Diagram
|
6
|
+
class WavedromBlockProcessor < DiagramBlockProcessor
|
7
|
+
use_converter WavedromConverter
|
8
|
+
end
|
9
|
+
|
10
|
+
class WavedromBlockMacroProcessor < DiagramBlockMacroProcessor
|
11
|
+
use_converter WavedromConverter
|
12
|
+
end
|
13
|
+
end
|
14
|
+
end
|
data/lib/asciidoctor-diagram.rb
CHANGED
@@ -1,5 +1,22 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
|
4
|
-
|
5
|
-
|
1
|
+
require_relative 'asciidoctor-diagram/a2s'
|
2
|
+
require_relative 'asciidoctor-diagram/blockdiag'
|
3
|
+
require_relative 'asciidoctor-diagram/bpmn'
|
4
|
+
require_relative 'asciidoctor-diagram/ditaa'
|
5
|
+
require_relative 'asciidoctor-diagram/erd'
|
6
|
+
require_relative 'asciidoctor-diagram/gnuplot'
|
7
|
+
require_relative 'asciidoctor-diagram/graphviz'
|
8
|
+
require_relative 'asciidoctor-diagram/lilypond'
|
9
|
+
require_relative 'asciidoctor-diagram/meme'
|
10
|
+
require_relative 'asciidoctor-diagram/mermaid'
|
11
|
+
require_relative 'asciidoctor-diagram/msc'
|
12
|
+
require_relative 'asciidoctor-diagram/nomnoml'
|
13
|
+
require_relative 'asciidoctor-diagram/plantuml'
|
14
|
+
require_relative 'asciidoctor-diagram/salt'
|
15
|
+
require_relative 'asciidoctor-diagram/shaape'
|
16
|
+
require_relative 'asciidoctor-diagram/smcat'
|
17
|
+
require_relative 'asciidoctor-diagram/svgbob'
|
18
|
+
require_relative 'asciidoctor-diagram/syntrax'
|
19
|
+
require_relative 'asciidoctor-diagram/tikz'
|
20
|
+
require_relative 'asciidoctor-diagram/umlet'
|
21
|
+
require_relative 'asciidoctor-diagram/vega'
|
22
|
+
require_relative 'asciidoctor-diagram/wavedrom'
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
Binary file
|
data/lib/plantuml.jar
CHANGED
Binary file
|
Binary file
|