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.
Files changed (126) hide show
  1. checksums.yaml +5 -5
  2. data/CHANGELOG.adoc +262 -7
  3. data/README.adoc +463 -40
  4. data/README_zh-CN.adoc +336 -0
  5. data/Rakefile +3 -7
  6. data/examples/features.adoc +2 -2
  7. data/images/asciidoctor-diagram-classes.png +0 -0
  8. data/images/asciidoctor-diagram-process.png +0 -0
  9. data/lib/asciidoctor-diagram/a2s/converter.rb +55 -0
  10. data/lib/asciidoctor-diagram/a2s/extension.rb +14 -0
  11. data/lib/asciidoctor-diagram/a2s.rb +7 -0
  12. data/lib/asciidoctor-diagram/blockdiag/converter.rb +37 -0
  13. data/lib/asciidoctor-diagram/blockdiag/extension.rb +11 -11
  14. data/lib/asciidoctor-diagram/blockdiag.rb +5 -4
  15. data/lib/asciidoctor-diagram/bpmn/converter.rb +62 -0
  16. data/lib/asciidoctor-diagram/bpmn/extension.rb +14 -0
  17. data/lib/asciidoctor-diagram/bpmn.rb +7 -0
  18. data/lib/asciidoctor-diagram/diagram_converter.rb +19 -0
  19. data/lib/asciidoctor-diagram/diagram_processor.rb +320 -0
  20. data/lib/asciidoctor-diagram/diagram_source.rb +275 -0
  21. data/lib/asciidoctor-diagram/ditaa/converter.rb +86 -0
  22. data/lib/asciidoctor-diagram/ditaa/extension.rb +6 -28
  23. data/lib/asciidoctor-diagram/ditaa.rb +3 -4
  24. data/lib/asciidoctor-diagram/erd/converter.rb +31 -0
  25. data/lib/asciidoctor-diagram/erd/extension.rb +14 -0
  26. data/lib/asciidoctor-diagram/erd.rb +7 -0
  27. data/lib/asciidoctor-diagram/gnuplot/converter.rb +63 -0
  28. data/lib/asciidoctor-diagram/gnuplot/extension.rb +14 -0
  29. data/lib/asciidoctor-diagram/gnuplot.rb +7 -0
  30. data/lib/asciidoctor-diagram/graphviz/converter.rb +32 -0
  31. data/lib/asciidoctor-diagram/graphviz/extension.rb +8 -10
  32. data/lib/asciidoctor-diagram/graphviz.rb +3 -4
  33. data/lib/asciidoctor-diagram/http/server.rb +127 -0
  34. data/lib/asciidoctor-diagram/lilypond/converter.rb +54 -0
  35. data/lib/asciidoctor-diagram/lilypond/extension.rb +14 -0
  36. data/lib/asciidoctor-diagram/lilypond.rb +7 -0
  37. data/lib/asciidoctor-diagram/meme/converter.rb +122 -0
  38. data/lib/asciidoctor-diagram/meme/extension.rb +28 -0
  39. data/lib/asciidoctor-diagram/meme.rb +6 -0
  40. data/lib/asciidoctor-diagram/mermaid/converter.rb +178 -0
  41. data/lib/asciidoctor-diagram/mermaid/extension.rb +14 -0
  42. data/lib/asciidoctor-diagram/mermaid.rb +7 -0
  43. data/lib/asciidoctor-diagram/msc/converter.rb +35 -0
  44. data/lib/asciidoctor-diagram/msc/extension.rb +14 -0
  45. data/lib/asciidoctor-diagram/msc.rb +7 -0
  46. data/lib/asciidoctor-diagram/nomnoml/converter.rb +25 -0
  47. data/lib/asciidoctor-diagram/nomnoml/extension.rb +14 -0
  48. data/lib/asciidoctor-diagram/nomnoml.rb +7 -0
  49. data/lib/asciidoctor-diagram/plantuml/converter.rb +115 -0
  50. data/lib/asciidoctor-diagram/plantuml/extension.rb +14 -20
  51. data/lib/asciidoctor-diagram/plantuml.rb +3 -5
  52. data/lib/asciidoctor-diagram/salt.rb +7 -0
  53. data/lib/asciidoctor-diagram/shaape/converter.rb +25 -0
  54. data/lib/asciidoctor-diagram/shaape/extension.rb +9 -11
  55. data/lib/asciidoctor-diagram/shaape.rb +3 -5
  56. data/lib/asciidoctor-diagram/smcat/converter.rb +44 -0
  57. data/lib/asciidoctor-diagram/smcat/extension.rb +14 -0
  58. data/lib/asciidoctor-diagram/smcat.rb +7 -0
  59. data/lib/asciidoctor-diagram/svgbob/converter.rb +25 -0
  60. data/lib/asciidoctor-diagram/svgbob/extension.rb +14 -0
  61. data/lib/asciidoctor-diagram/svgbob.rb +7 -0
  62. data/lib/asciidoctor-diagram/syntrax/converter.rb +55 -0
  63. data/lib/asciidoctor-diagram/syntrax/extension.rb +14 -0
  64. data/lib/asciidoctor-diagram/syntrax.rb +7 -0
  65. data/lib/asciidoctor-diagram/tikz/converter.rb +56 -0
  66. data/lib/asciidoctor-diagram/tikz/extension.rb +14 -0
  67. data/lib/asciidoctor-diagram/tikz.rb +7 -0
  68. data/lib/asciidoctor-diagram/umlet/converter.rb +24 -0
  69. data/lib/asciidoctor-diagram/umlet/extension.rb +14 -0
  70. data/lib/asciidoctor-diagram/umlet.rb +7 -0
  71. data/lib/asciidoctor-diagram/util/binaryio.rb +20 -0
  72. data/lib/asciidoctor-diagram/util/cli.rb +81 -0
  73. data/lib/asciidoctor-diagram/util/cli_generator.rb +73 -22
  74. data/lib/asciidoctor-diagram/util/gif.rb +21 -0
  75. data/lib/asciidoctor-diagram/util/java.rb +95 -1
  76. data/lib/asciidoctor-diagram/util/java_jruby.rb +14 -20
  77. data/lib/asciidoctor-diagram/util/java_socket.rb +175 -0
  78. data/lib/asciidoctor-diagram/util/pdf.rb +10 -0
  79. data/lib/asciidoctor-diagram/util/platform.rb +97 -0
  80. data/lib/asciidoctor-diagram/util/png.rb +1 -0
  81. data/lib/asciidoctor-diagram/util/svg.rb +4 -3
  82. data/lib/asciidoctor-diagram/util/which.rb +15 -9
  83. data/lib/asciidoctor-diagram/vega/converter.rb +47 -0
  84. data/lib/asciidoctor-diagram/vega/extension.rb +14 -0
  85. data/lib/asciidoctor-diagram/vega.rb +10 -0
  86. data/lib/asciidoctor-diagram/version.rb +1 -1
  87. data/lib/asciidoctor-diagram/wavedrom/converter.rb +50 -0
  88. data/lib/asciidoctor-diagram/wavedrom/extension.rb +14 -0
  89. data/lib/asciidoctor-diagram/wavedrom.rb +7 -0
  90. data/lib/asciidoctor-diagram.rb +22 -5
  91. data/lib/batik-all-1.10.jar +0 -0
  92. data/lib/ditaa-1.3.14.jar +0 -0
  93. data/lib/ditaamini-0.12.jar +0 -0
  94. data/lib/jlatexmath-minimal-1.0.5.jar +0 -0
  95. data/lib/plantuml-1.3.14.jar +0 -0
  96. data/lib/plantuml.jar +0 -0
  97. data/lib/server-1.3.14.jar +0 -0
  98. data/spec/a2s_spec.rb +167 -0
  99. data/spec/blockdiag_spec.rb +55 -24
  100. data/spec/bpmn-example.xml +44 -0
  101. data/spec/bpmn_spec.rb +96 -0
  102. data/spec/ditaa_spec.rb +150 -15
  103. data/spec/erd_spec.rb +289 -0
  104. data/spec/gnuplot_spec.rb +478 -0
  105. data/spec/graphviz_spec.rb +20 -20
  106. data/spec/lilypond_spec.rb +151 -0
  107. data/spec/man.jpg +0 -0
  108. data/spec/meme_spec.rb +67 -0
  109. data/spec/mermaid_spec.rb +336 -0
  110. data/spec/msc_spec.rb +230 -0
  111. data/spec/nomnoml_spec.rb +170 -0
  112. data/spec/plantuml_spec.rb +895 -54
  113. data/spec/shaape_spec.rb +25 -24
  114. data/spec/smcat_spec.rb +164 -0
  115. data/spec/svgbob_spec.rb +167 -0
  116. data/spec/syntrax_spec.rb +228 -0
  117. data/spec/test_helper.rb +88 -9
  118. data/spec/tikz_spec.rb +127 -0
  119. data/spec/umlet_spec.rb +85 -0
  120. data/spec/vega_spec.rb +241 -0
  121. data/spec/wavedrom_spec.rb +214 -0
  122. metadata +130 -35
  123. data/lib/asciidoctor-diagram/plantuml/generator.rb +0 -46
  124. data/lib/asciidoctor-diagram/util/diagram.rb +0 -220
  125. data/lib/asciidoctor-diagram/util/java_rjb.rb +0 -90
  126. 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,10 @@
1
+ module Asciidoctor
2
+ module Diagram
3
+ # @private
4
+ module PDF
5
+ def self.get_image_size(_)
6
+ nil
7
+ end
8
+ end
9
+ end
10
+ 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 PNG
6
7
  PNG_SIGNATURE = [137, 80, 78, 71, 13, 10, 26, 10].pack('CCCCCCCC')
7
8
 
@@ -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
- def self.which(cmd)
4
- exts = ENV['PATHEXT'] ? ENV['PATHEXT'].split(';') : ['']
5
- ENV['PATH'].split(File::PATH_SEPARATOR).each do |path|
6
- exts.each { |ext|
7
- exe = File.join(path, "#{cmd}#{ext}")
8
- return exe if File.executable? exe
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
@@ -1,5 +1,5 @@
1
1
  module Asciidoctor
2
2
  module Diagram
3
- VERSION = "1.2.0"
3
+ VERSION = "2.0.0"
4
4
  end
5
5
  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
@@ -0,0 +1,7 @@
1
+ require 'asciidoctor/extensions'
2
+ require_relative 'wavedrom/extension'
3
+
4
+ Asciidoctor::Extensions.register do
5
+ block Asciidoctor::Diagram::WavedromBlockProcessor, :wavedrom
6
+ block_macro Asciidoctor::Diagram::WavedromBlockMacroProcessor, :wavedrom
7
+ end
@@ -1,5 +1,22 @@
1
- require 'asciidoctor-diagram/blockdiag'
2
- require 'asciidoctor-diagram/ditaa'
3
- require 'asciidoctor-diagram/graphviz'
4
- require 'asciidoctor-diagram/plantuml'
5
- require 'asciidoctor-diagram/shaape'
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