metanorma-utils 1.0.3 → 1.0.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/.github/workflows/rake.yml +53 -0
- data/.rubocop.yml +6 -0
- data/Rakefile +0 -2
- data/lib/utils/hash_transform_keys.rb +51 -0
- data/lib/utils/main.rb +100 -19
- data/lib/utils/version.rb +1 -1
- data/metanorma-utils.gemspec +3 -1
- data/spec/fixtures/rice_image1.png +0 -0
- data/spec/hash_transform_keys_spec.rb +52 -0
- data/spec/utils_spec.rb +156 -2
- metadata +37 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 366ab5765fb28315b8c4258b6d766b04733ffbc69c912fd718f2229a5d5a9303
|
4
|
+
data.tar.gz: abdcfed1228161a42c79d748b4a50b36ef29c08f9b028c1ee86ce14b053db482
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 620d77ee112d112ee72e2fc90257692ff39120f6fa0e2e8d219e0a2790435e750ec2b6742c7a75cfb2a195e1e41bc5afe33d8b5aa015f616eac559ad9e6c9944
|
7
|
+
data.tar.gz: 42591f0ed4cdc91895f154c7f3c50d5e572b9870c77604367207ab1567025a7fbb07c3d9ca90965f8e688188ed91d894ded759db07eabc5008c6c3da5642c118
|
@@ -0,0 +1,53 @@
|
|
1
|
+
# Auto-generated by Cimas: Do not edit it manually!
|
2
|
+
# See https://github.com/metanorma/cimas
|
3
|
+
name: rake
|
4
|
+
|
5
|
+
on:
|
6
|
+
push:
|
7
|
+
branches: [ master, main ]
|
8
|
+
tags: [ v* ]
|
9
|
+
pull_request:
|
10
|
+
|
11
|
+
jobs:
|
12
|
+
rake:
|
13
|
+
name: Test on Ruby ${{ matrix.ruby }} ${{ matrix.os }}
|
14
|
+
runs-on: ${{ matrix.os }}
|
15
|
+
continue-on-error: ${{ matrix.experimental }}
|
16
|
+
strategy:
|
17
|
+
fail-fast: false
|
18
|
+
matrix:
|
19
|
+
ruby: [ '2.7', '2.6', '2.5', '2.4' ]
|
20
|
+
os: [ ubuntu-latest, windows-latest, macos-latest ]
|
21
|
+
experimental: [ false ]
|
22
|
+
include:
|
23
|
+
- ruby: '3.0'
|
24
|
+
os: 'ubuntu-latest'
|
25
|
+
experimental: true
|
26
|
+
- ruby: '3.0'
|
27
|
+
os: 'windows-latest'
|
28
|
+
experimental: true
|
29
|
+
- ruby: '3.0'
|
30
|
+
os: 'macos-latest'
|
31
|
+
experimental: true
|
32
|
+
steps:
|
33
|
+
- uses: actions/checkout@v2
|
34
|
+
with:
|
35
|
+
submodules: true
|
36
|
+
|
37
|
+
- uses: ruby/setup-ruby@v1
|
38
|
+
with:
|
39
|
+
ruby-version: ${{ matrix.ruby }}
|
40
|
+
bundler-cache: true
|
41
|
+
|
42
|
+
- run: bundle exec rake
|
43
|
+
|
44
|
+
tests-passed:
|
45
|
+
needs: rake
|
46
|
+
runs-on: ubuntu-latest
|
47
|
+
steps:
|
48
|
+
- uses: peter-evans/repository-dispatch@v1
|
49
|
+
with:
|
50
|
+
token: ${{ secrets.METANORMA_CI_PAT_TOKEN || secrets.GITHUB_TOKEN }}
|
51
|
+
repository: ${{ github.repository }}
|
52
|
+
event-type: notify
|
53
|
+
client-payload: '{"ref": "${{ github.ref }}", "sha": "${{ github.sha }}"}'
|
data/.rubocop.yml
ADDED
@@ -0,0 +1,6 @@
|
|
1
|
+
# This project follows the Ribose OSS style guide.
|
2
|
+
# https://github.com/riboseinc/oss-guides
|
3
|
+
# All project-specific additions and overrides should be specified in this file.
|
4
|
+
|
5
|
+
inherit_from:
|
6
|
+
- https://raw.githubusercontent.com/riboseinc/oss-guides/master/ci/rubocop.yml
|
data/Rakefile
CHANGED
@@ -0,0 +1,51 @@
|
|
1
|
+
class Array
|
2
|
+
def stringify_all_keys
|
3
|
+
map do |v|
|
4
|
+
case v
|
5
|
+
when Hash, Array
|
6
|
+
v.stringify_all_keys
|
7
|
+
else
|
8
|
+
v
|
9
|
+
end
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
def symbolize_all_keys
|
14
|
+
map do |v|
|
15
|
+
case v
|
16
|
+
when Hash, Array
|
17
|
+
v.symbolize_all_keys
|
18
|
+
else
|
19
|
+
v
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
end
|
24
|
+
|
25
|
+
class Hash
|
26
|
+
def stringify_all_keys
|
27
|
+
result = {}
|
28
|
+
each do |k, v|
|
29
|
+
result[k.to_s] = case v
|
30
|
+
when Hash, Array
|
31
|
+
v.stringify_all_keys
|
32
|
+
else
|
33
|
+
v
|
34
|
+
end
|
35
|
+
end
|
36
|
+
result
|
37
|
+
end
|
38
|
+
|
39
|
+
def symbolize_all_keys
|
40
|
+
result = {}
|
41
|
+
each do |k, v|
|
42
|
+
result[k.to_sym] = case v
|
43
|
+
when Hash, Array
|
44
|
+
v.symbolize_all_keys
|
45
|
+
else
|
46
|
+
v
|
47
|
+
end
|
48
|
+
end
|
49
|
+
result
|
50
|
+
end
|
51
|
+
end
|
data/lib/utils/main.rb
CHANGED
@@ -1,6 +1,10 @@
|
|
1
1
|
require "asciidoctor"
|
2
|
+
require "tempfile"
|
2
3
|
require "sterile"
|
3
4
|
require "uuidtools"
|
5
|
+
require "mimemagic"
|
6
|
+
require "mime/types"
|
7
|
+
require "base64"
|
4
8
|
|
5
9
|
module Metanorma
|
6
10
|
module Utils
|
@@ -78,35 +82,73 @@ module Metanorma
|
|
78
82
|
hash
|
79
83
|
end
|
80
84
|
|
81
|
-
|
82
|
-
xmldoc
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
85
|
+
class Namespace
|
86
|
+
def initialize(xmldoc)
|
87
|
+
@namespace = xmldoc.root.namespace
|
88
|
+
end
|
89
|
+
|
90
|
+
def ns(path)
|
91
|
+
return path if @namespace.nil?
|
92
|
+
path.gsub(%r{/([a-zA-z])}, "/xmlns:\\1").
|
93
|
+
gsub(%r{::([a-zA-z])}, "::xmlns:\\1").
|
94
|
+
gsub(%r{\[([a-zA-z][a-z0-9A-Z@/]* ?=)}, "[xmlns:\\1").
|
95
|
+
gsub(%r{\[([a-zA-z][a-z0-9A-Z@/]*\])}, "[xmlns:\\1")
|
90
96
|
end
|
91
97
|
end
|
92
98
|
|
93
|
-
def
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
99
|
+
def save_dataimage(uri)
|
100
|
+
%r{^data:(image|application)/(?<imgtype>[^;]+);base64,(?<imgdata>.+)$} =~ uri
|
101
|
+
imgtype.sub!(/\+[a-z0-9]+$/, '') # svg+xml
|
102
|
+
imgtype = 'png' unless /^[a-z0-9]+$/.match imgtype
|
103
|
+
Tempfile.open(['image', ".#{imgtype}"]) do |f|
|
104
|
+
f.binmode
|
105
|
+
f.write(Base64.strict_decode64(imgdata))
|
106
|
+
f.path
|
98
107
|
end
|
99
|
-
|
100
|
-
|
108
|
+
end
|
109
|
+
|
110
|
+
SVG_NS = "http://www.w3.org/2000/svg".freeze
|
111
|
+
|
112
|
+
def svgmap_rewrite(xmldoc, localdirectory = "")
|
113
|
+
n = Namespace.new(xmldoc)
|
114
|
+
xmldoc.xpath(n.ns("//svgmap")).each do |s|
|
115
|
+
next unless svgmap_rewrite0(s, n, localdirectory)
|
116
|
+
next if s.at(n.ns("./target/eref"))
|
117
|
+
s.replace(s.at(n.ns("./figure")))
|
101
118
|
end
|
102
|
-
|
119
|
+
end
|
120
|
+
|
121
|
+
def svgmap_rewrite0(s, n, localdirectory)
|
122
|
+
if i = s.at(n.ns(".//image")) and src = i["src"]
|
123
|
+
path = /^data:/.match(src) ? save_dataimage(src) : File.file?(src) ? src : localdirectory + src
|
124
|
+
File.file?(path) or return false
|
125
|
+
svgmap_rewrite1(s, Nokogiri::XML(File.read(path, encoding: "utf-8")), path, n)
|
126
|
+
/^data:/.match(src) and i["src"] = datauri(path)
|
127
|
+
elsif i = s.at(".//m:svg", "m" => SVG_NS)
|
128
|
+
svgmap_rewrite1(s, i, nil, n)
|
129
|
+
else
|
130
|
+
return false
|
131
|
+
end
|
132
|
+
true
|
133
|
+
end
|
134
|
+
|
135
|
+
def svgmap_rewrite1(s, svg, path, n)
|
136
|
+
targets = s.xpath(n.ns("./target")).each_with_object({}) do |t, m|
|
137
|
+
x = t.at(n.ns("./xref")) and m[File.expand_path(t["href"])] = "##{x['target']}"
|
138
|
+
x = t.at(n.ns("./link")) and m[File.expand_path(t["href"])] = x['target']
|
139
|
+
t.remove if t.at(n.ns("./xref | ./link"))
|
140
|
+
end
|
141
|
+
svg.xpath(".//m:a", "m" => SVG_NS).each do |a|
|
142
|
+
a["xlink:href"] and x = targets[File.expand_path(a["xlink:href"])] and a["xlink:href"] = x
|
143
|
+
a["href"] and x = targets[File.expand_path(a["href"])] and a["href"] = x
|
144
|
+
end
|
145
|
+
path and File.open(path, "w", encoding: "utf-8") { |f| f.write(svg.to_xml) }
|
103
146
|
end
|
104
147
|
|
105
148
|
# not currently used
|
106
149
|
def flatten_rawtext_lines(node, result)
|
107
150
|
node.lines.each do |x|
|
108
|
-
if node.respond_to?(:context) && (node.context == :literal ||
|
109
|
-
node.context == :listing)
|
151
|
+
if node.respond_to?(:context) && (node.context == :literal || node.context == :listing)
|
110
152
|
result << x.gsub(/</, "<").gsub(/>/, ">")
|
111
153
|
else
|
112
154
|
# strip not only HTML <tag>, and Asciidoc xrefs <<xref>>
|
@@ -132,6 +174,45 @@ module Metanorma
|
|
132
174
|
end
|
133
175
|
result.reject(&:empty?)
|
134
176
|
end
|
177
|
+
|
178
|
+
# sources/plantuml/plantuml20200524-90467-1iqek5i.png already includes localdir
|
179
|
+
def datauri(uri, localdirectory = ".")
|
180
|
+
return uri if /^data:/.match(uri)
|
181
|
+
path = %r{^([A-Z]:)?/}.match?(uri) ? uri :
|
182
|
+
File.exist?(uri) ? uri : File.join(localdirectory, uri)
|
183
|
+
unless File.exist?(path)
|
184
|
+
warn "image at #{path} not found"
|
185
|
+
return uri
|
186
|
+
end
|
187
|
+
types = MIME::Types.type_for(path)
|
188
|
+
type = types ? types.first.to_s : 'text/plain; charset="utf-8"'
|
189
|
+
bin = File.open(path, 'rb', &:read)
|
190
|
+
data = Base64.strict_encode64(bin)
|
191
|
+
"data:#{type};base64,#{data}"
|
192
|
+
end
|
193
|
+
|
194
|
+
def datauri2mime(uri)
|
195
|
+
%r{^data:image/(?<imgtype>[^;]+);base64,(?<imgdata>.+)$} =~ uri
|
196
|
+
type = nil
|
197
|
+
imgtype = "png" unless /^[a-z0-9]+$/.match imgtype
|
198
|
+
::Tempfile.open(["imageuri", ".#{imgtype}"]) do |file|
|
199
|
+
type = datauri2mime1(file, imgdata)
|
200
|
+
end
|
201
|
+
[type]
|
202
|
+
end
|
203
|
+
|
204
|
+
def datauri2mime1(file, imgdata)
|
205
|
+
type = nil
|
206
|
+
begin
|
207
|
+
file.binmode
|
208
|
+
file.write(Base64.strict_decode64(imgdata))
|
209
|
+
file.rewind
|
210
|
+
type = MimeMagic.by_magic(file)
|
211
|
+
ensure
|
212
|
+
file.close!
|
213
|
+
end
|
214
|
+
type
|
215
|
+
end
|
135
216
|
end
|
136
217
|
end
|
137
218
|
end
|
data/lib/utils/version.rb
CHANGED
data/metanorma-utils.gemspec
CHANGED
@@ -29,12 +29,14 @@ Gem::Specification.new do |spec|
|
|
29
29
|
spec.add_dependency "nokogiri", "~> 1.10.4"
|
30
30
|
spec.add_dependency "asciidoctor", "~> 2.0.0"
|
31
31
|
spec.add_dependency "uuidtools"
|
32
|
+
spec.add_dependency "mimemagic"
|
33
|
+
spec.add_dependency "mime-types"
|
32
34
|
|
33
35
|
spec.add_development_dependency "byebug"
|
34
36
|
spec.add_development_dependency "equivalent-xml", "~> 0.6"
|
35
37
|
spec.add_development_dependency "guard", "~> 2.14"
|
36
38
|
spec.add_development_dependency "guard-rspec", "~> 4.7"
|
37
|
-
spec.add_development_dependency "rake", "~>
|
39
|
+
spec.add_development_dependency "rake", "~> 13.0"
|
38
40
|
spec.add_development_dependency "rspec", "~> 3.6"
|
39
41
|
spec.add_development_dependency "rubocop", "= 0.54.0"
|
40
42
|
spec.add_development_dependency "simplecov", "~> 0.15"
|
Binary file
|
@@ -0,0 +1,52 @@
|
|
1
|
+
require "spec_helper"
|
2
|
+
require "utils/hash_transform_keys"
|
3
|
+
|
4
|
+
RSpec.describe Metanorma::Utils do
|
5
|
+
it "deep stringify hash but skip values" do
|
6
|
+
result = {
|
7
|
+
test0: :test0,
|
8
|
+
test1: false,
|
9
|
+
test2: {
|
10
|
+
test20: :test20,
|
11
|
+
},
|
12
|
+
test3: %i(test31 test32 test33),
|
13
|
+
test4: [
|
14
|
+
{
|
15
|
+
test41: :test41,
|
16
|
+
},
|
17
|
+
],
|
18
|
+
}.stringify_all_keys
|
19
|
+
|
20
|
+
expect(result).to include("test0", "test1", "test2", "test3", "test4")
|
21
|
+
expect(result["test0"]).to eq(:test0)
|
22
|
+
expect(result["test2"]).to include("test20")
|
23
|
+
expect(result["test2"]["test20"]).to eq(:test20)
|
24
|
+
expect(result["test3"]).to include(:test31, :test32, :test33)
|
25
|
+
expect(result["test4"][0]).to include("test41")
|
26
|
+
expect(result["test4"][0]["test41"]).to eq(:test41)
|
27
|
+
end
|
28
|
+
|
29
|
+
it "deep symbolize hash but skip values" do
|
30
|
+
result = {
|
31
|
+
test0: "test0",
|
32
|
+
test1: false,
|
33
|
+
test2: {
|
34
|
+
test20: "test20",
|
35
|
+
},
|
36
|
+
test3: %w(test31 test32 test33),
|
37
|
+
test4: [
|
38
|
+
{
|
39
|
+
test41: "test41",
|
40
|
+
},
|
41
|
+
],
|
42
|
+
}.stringify_all_keys.symbolize_all_keys
|
43
|
+
|
44
|
+
expect(result).to include(:test0, :test1, :test2, :test3, :test4)
|
45
|
+
expect(result[:test0]).to eq("test0")
|
46
|
+
expect(result[:test2]).to include(:test20)
|
47
|
+
expect(result[:test2][:test20]).to eq("test20")
|
48
|
+
expect(result[:test3]).to include("test31", "test32", "test33")
|
49
|
+
expect(result[:test4][0]).to include(:test41)
|
50
|
+
expect(result[:test4][0][:test41]).to eq("test41")
|
51
|
+
end
|
52
|
+
end
|
data/spec/utils_spec.rb
CHANGED
@@ -102,10 +102,35 @@ RSpec.describe Metanorma::Utils do
|
|
102
102
|
</svgmap>
|
103
103
|
<svgmap id="_60dadf08-48d4-4164-845c-b4e293e00abd">
|
104
104
|
<figure><image src="action_schemaexpg2.svg" alt="Workmap"/></figure>
|
105
|
-
<target href="href1.htm"><xref target="ref1">Computer</xref></target><target href="mn://basic_attribute_schema"><link target="http://www.example.com">Phone</link></target><target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap
|
105
|
+
<target href="href1.htm"><xref target="ref1">Computer</xref></target><target href="mn://basic_attribute_schema"><link target="http://www.example.com">Phone</link></target><target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap>
|
106
|
+
<svgmap id="_60dadf08-48d4-4164-845c-b4e293e00abd">
|
107
|
+
<figure>
|
108
|
+
<svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' version='1.1' id='Layer_1' x='0px' y='0px' viewBox='0 0 595.28 841.89' style='enable-background:new 0 0 595.28 841.89;' xml:space='preserve'>
|
109
|
+
<a href="mn://action_schema" >
|
110
|
+
<rect x="123.28" y="273.93" class="st0" width="88.05" height="41.84"/>
|
111
|
+
</a>
|
112
|
+
<a href="mn://basic_attribute_schema" >
|
113
|
+
<rect x="324.69" y="450.52" class="st0" width="132.62" height="40.75"/>
|
114
|
+
</a>
|
115
|
+
<a xlink:href="mn://support_resource_schema" >
|
116
|
+
<rect x="324.69" y="528.36" class="st0" width="148.16" height="40.75"/>
|
117
|
+
</a>
|
118
|
+
</svg>
|
119
|
+
</figure>
|
120
|
+
<target href="mn://action_schema"><xref target="ref1">Computer</xref></target><target href="http://www.example.com"><link target="http://www.example.com">Phone</link></target>
|
121
|
+
</svgmap>
|
122
|
+
<svgmap id="_60dadf08-48d4-4164-845c-b4e293e00abd">
|
123
|
+
<figure>
|
124
|
+
|
125
|
+
<image src='' id='__ISO_17301-1_2016' mimetype='image/svg+xml' height='auto' width='auto' alt='Workmap1'/>
|
126
|
+
</figure>
|
127
|
+
<target href="href1.htm"><xref target="ref1">Computer</xref></target><target href="mn://basic_attribute_schema"><link target="http://www.example.com">Phone</link></target><target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap>
|
128
|
+
</sections>
|
106
129
|
</standard-document>
|
107
130
|
INPUT
|
108
131
|
Metanorma::Utils.svgmap_rewrite(xmldoc)
|
132
|
+
xmldoc1 = xmldoc.dup
|
133
|
+
xmldoc&.at("//image[@alt = 'Workmap1']")&.remove
|
109
134
|
expect(xmlpp(xmldoc.to_xml)).to be_equivalent_to xmlpp(<<~OUTPUT)
|
110
135
|
<standard-document type="semantic" version="1.8.2">
|
111
136
|
<bibdata type="standard">
|
@@ -133,7 +158,35 @@ RSpec.describe Metanorma::Utils do
|
|
133
158
|
<figure>
|
134
159
|
<image src='action_schemaexpg2.svg' alt='Workmap'/>
|
135
160
|
</figure>
|
136
|
-
<target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap
|
161
|
+
<target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap>
|
162
|
+
<figure>
|
163
|
+
<svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' version='1.1' id='Layer_1' x='0px' y='0px' viewBox='0 0 595.28 841.89' style='enable-background:new 0 0 595.28 841.89;' xml:space='preserve'>
|
164
|
+
<a href='#ref1'>
|
165
|
+
<rect x='123.28' y='273.93' class='st0' width='88.05' height='41.84'/>
|
166
|
+
</a>
|
167
|
+
<a href='mn://basic_attribute_schema'>
|
168
|
+
<rect x='324.69' y='450.52' class='st0' width='132.62' height='40.75'/>
|
169
|
+
</a>
|
170
|
+
<a xlink:href='mn://support_resource_schema'>
|
171
|
+
<rect x='324.69' y='528.36' class='st0' width='148.16' height='40.75'/>
|
172
|
+
</a>
|
173
|
+
</svg>
|
174
|
+
</figure>
|
175
|
+
<svgmap id='_60dadf08-48d4-4164-845c-b4e293e00abd'>
|
176
|
+
<figure>
|
177
|
+
</figure>
|
178
|
+
<target href='mn://support_resource_schema'>
|
179
|
+
<eref type='express' bibitemid='express_action_schema' citeas=''>
|
180
|
+
<localityStack>
|
181
|
+
<locality type='anchor'>
|
182
|
+
<referenceFrom>action_schema.basic</referenceFrom>
|
183
|
+
</locality>
|
184
|
+
</localityStack>
|
185
|
+
Coffee
|
186
|
+
</eref>
|
187
|
+
</target>
|
188
|
+
</svgmap>
|
189
|
+
</sections>
|
137
190
|
</standard-document>
|
138
191
|
OUTPUT
|
139
192
|
expect(xmlpp(File.read("action_schemaexpg1.svg", encoding: "utf-8").sub(%r{<image .*</image>}m, ""))).to be_equivalent_to <<~OUTPUT
|
@@ -167,9 +220,92 @@ expect(xmlpp(File.read("action_schemaexpg2.svg", encoding: "utf-8").sub(%r{<imag
|
|
167
220
|
<rect x='324.69' y='528.36' class='st0' width='148.16' height='40.75'/>
|
168
221
|
</a>
|
169
222
|
</svg>
|
223
|
+
OUTPUT
|
224
|
+
expect(xmlpp(File.read(Metanorma::Utils.save_dataimage(xmldoc1.at("//image[@alt = 'Workmap1']/@src"))))).to be_equivalent_to <<~OUTPUT
|
225
|
+
<?xml version='1.0' encoding='UTF-8'?>
|
226
|
+
<!-- Generator: Adobe Illustrator 25.0.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
227
|
+
<svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' version='1.1' id='Layer_1' x='0px' y='0px' viewBox='0 0 595.28 841.89' style='enable-background:new 0 0 595.28 841.89;' xml:space='preserve'>
|
228
|
+
<style type='text/css'> .st0{fill:none;stroke:#000000;stroke-miterlimit:10;} </style>
|
229
|
+
<image style='overflow:visible;' width='368' height='315' xlink:href=' ZgBmmQBmzABm/wCZAACZMwCZZgCZmQCZzACZ/wDMAADMMwDMZgDMmQDMzADM/wD/AAD/MwD/ZgD/ mQD/zAD//zMAADMAMzMAZjMAmTMAzDMA/zMzADMzMzMzZjMzmTMzzDMz/zNmADNmMzNmZjNmmTNm zDNm/zOZADOZMzOZZjOZmTOZzDOZ/zPMADPMMzPMZjPMmTPMzDPM/zP/ADP/MzP/ZjP/mTP/zDP/ /2YAAGYAM2YAZmYAmWYAzGYA/2YzAGYzM2YzZmYzmWYzzGYz/2ZmAGZmM2ZmZmZmmWZmzGZm/2aZ AGaZM2aZZmaZmWaZzGaZ/2bMAGbMM2bMZmbMmWbMzGbM/2b/AGb/M2b/Zmb/mWb/zGb//5kAAJkA M5kAZpkAmZkAzJkA/5kzAJkzM5kzZpkzmZkzzJkz/5lmAJlmM5lmZplmmZlmzJlm/5mZAJmZM5mZ ZpmZmZmZzJmZ/5nMAJnMM5nMZpnMmZnMzJnM/5n/AJn/M5n/Zpn/mZn/zJn//8wAAMwAM8wAZswA mcwAzMwA/8wzAMwzM8wzZswzmcwzzMwz/8xmAMxmM8xmZsxmmcxmzMxm/8yZAMyZM8yZZsyZmcyZ zMyZ/8zMAMzMM8zMZszMmczMzMzM/8z/AMz/M8z/Zsz/mcz/zMz///8AAP8AM/8AZv8Amf8AzP8A //8zAP8zM/8zZv8zmf8zzP8z//9mAP9mM/9mZv9mmf9mzP9m//+ZAP+ZM/+ZZv+Zmf+ZzP+Z///M AP/MM//MZv/Mmf/MzP/M////AP//M///Zv//mf//zP////j4+PLy8uvr6+Xl5d/f39jY2NLS0szM zMXFxb+/v7i4uLKysqysrKWlpZ+fn5mZmZKSkoyMjIWFhX9/f3l5eXJycmxsbGZmZl9fX1lZWVJS UkxMTEZGRj8/Pzk5OTMzMywsLCYmJh8fHxkZGRMTEwwMDAYGBgAAACwAAAAAcAE7AQAI/gCvCRxI sKDBgwgTKlzIsKHDhxAjSpxIsaLFixgzatzIsaPHjyBDihxJsqTJkyhTqlzJsqXLlzBjypxJs6bN mzhz6tzJs6fPn0CDCh1KtKjRo0iTKl3KtKnTp1CjSp1KterIe/+yat3KtavXr2DDih3r9Z7Vs2gp /qu6Nq3btwrbTpULt25dulHx2t17Vu9Tv3wD52UruDBVwAqtISkTUjHjjYgNSz4auaCzxyKtyfmH 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' transform='matrix(1 0 0 1 114 263.8898)'> </image>
|
230
|
+
<a xlink:href='mn://action_schema'>
|
231
|
+
<rect x='123.28' y='273.93' class='st0' width='88.05' height='41.84'/>
|
232
|
+
</a>
|
233
|
+
<a xlink:href='http://www.example.com'>
|
234
|
+
<rect x='324.69' y='450.52' class='st0' width='132.62' height='40.75'/>
|
235
|
+
</a>
|
236
|
+
<a xlink:href='mn://support_resource_schema'>
|
237
|
+
<rect x='324.69' y='528.36' class='st0' width='148.16' height='40.75'/>
|
238
|
+
</a>
|
239
|
+
</svg>
|
170
240
|
OUTPUT
|
171
241
|
end
|
172
242
|
|
243
|
+
it "rewrites SVGs with namespaces" do
|
244
|
+
FileUtils.cp "spec/fixtures/action_schemaexpg1.svg", "action_schemaexpg1.svg"
|
245
|
+
FileUtils.cp "spec/fixtures/action_schemaexpg1.svg", "action_schemaexpg2.svg"
|
246
|
+
xmldoc = Nokogiri::XML(<<~INPUT)
|
247
|
+
<standard-document type="semantic" version="1.8.2" xmlns="http://www.example.com">
|
248
|
+
<bibdata type="standard">
|
249
|
+
<title language="en" format="text/plain">Document title</title>
|
250
|
+
<docidentifier/>
|
251
|
+
<docnumber/>
|
252
|
+
<version/>
|
253
|
+
<language>en</language>
|
254
|
+
<script>Latn</script>
|
255
|
+
<status>
|
256
|
+
<stage>published</stage>
|
257
|
+
</status>
|
258
|
+
<copyright>
|
259
|
+
<from>2021</from>
|
260
|
+
</copyright>
|
261
|
+
<ext>
|
262
|
+
<doctype>article</doctype>
|
263
|
+
</ext>
|
264
|
+
</bibdata>
|
265
|
+
<sections>
|
266
|
+
<svgmap id="_d5b5049a-dd53-4ea0-bc6f-e8773bd59052"><target href="mn://action_schema"><xref target="ref1">Computer</xref></target></svgmap>
|
267
|
+
<svgmap id="_4072bdcb-5895-4821-b636-5795b96787cb">
|
268
|
+
<figure><image src="action_schemaexpg1.svg"/></figure>
|
269
|
+
<target href="mn://action_schema"><xref target="ref1">Computer</xref></target><target href="http://www.example.com"><link target="http://www.example.com">Phone</link></target>
|
270
|
+
</svgmap>
|
271
|
+
<svgmap id="_60dadf08-48d4-4164-845c-b4e293e00abd">
|
272
|
+
<figure><image src="action_schemaexpg2.svg" alt="Workmap"/></figure>
|
273
|
+
<target href="href1.htm"><xref target="ref1">Computer</xref></target><target href="mn://basic_attribute_schema"><link target="http://www.example.com">Phone</link></target><target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap></sections>
|
274
|
+
</standard-document>
|
275
|
+
INPUT
|
276
|
+
Metanorma::Utils.svgmap_rewrite(xmldoc)
|
277
|
+
expect(xmlpp(xmldoc.to_xml)).to be_equivalent_to xmlpp(<<~OUTPUT)
|
278
|
+
<standard-document type="semantic" version="1.8.2" xmlns="http://www.example.com">
|
279
|
+
<bibdata type="standard">
|
280
|
+
<title language="en" format="text/plain">Document title</title>
|
281
|
+
<docidentifier/>
|
282
|
+
<docnumber/>
|
283
|
+
<version/>
|
284
|
+
<language>en</language>
|
285
|
+
<script>Latn</script>
|
286
|
+
<status>
|
287
|
+
<stage>published</stage>
|
288
|
+
</status>
|
289
|
+
<copyright>
|
290
|
+
<from>2021</from>
|
291
|
+
</copyright>
|
292
|
+
<ext>
|
293
|
+
<doctype>article</doctype>
|
294
|
+
</ext>
|
295
|
+
</bibdata>
|
296
|
+
<sections><svgmap id="_d5b5049a-dd53-4ea0-bc6f-e8773bd59052"><target href="mn://action_schema"><xref target="ref1">Computer</xref></target></svgmap>
|
297
|
+
<figure>
|
298
|
+
<image src='action_schemaexpg1.svg'/>
|
299
|
+
</figure>
|
300
|
+
<svgmap id='_60dadf08-48d4-4164-845c-b4e293e00abd'>
|
301
|
+
<figure>
|
302
|
+
<image src='action_schemaexpg2.svg' alt='Workmap'/>
|
303
|
+
</figure>
|
304
|
+
<target href="mn://support_resource_schema"><eref type="express" bibitemid="express_action_schema" citeas=""><localityStack><locality type="anchor"><referenceFrom>action_schema.basic</referenceFrom></locality></localityStack>Coffee</eref></target></svgmap></sections>
|
305
|
+
</standard-document>
|
306
|
+
OUTPUT
|
307
|
+
end
|
308
|
+
|
173
309
|
# not testing Asciidoctor log extraction here
|
174
310
|
it "generates log" do
|
175
311
|
xml = Nokogiri::XML(<<~INPUT)
|
@@ -205,4 +341,22 @@ log.txt errors
|
|
205
341
|
</b>
|
206
342
|
OUTPUT
|
207
343
|
end
|
344
|
+
|
345
|
+
def datauri(uri, localdir = "")
|
346
|
+
return uri if /^data:/.match(uri)
|
347
|
+
path = File.join(localdir, uri)
|
348
|
+
types = MIME::Types.type_for(path)
|
349
|
+
type = types ? types.first.to_s : 'text/plain; charset="utf-8"'
|
350
|
+
bin = File.open(path, 'rb', &:read)
|
351
|
+
data = Base64.strict_encode64(bin)
|
352
|
+
"data:#{type};base64,#{data}"
|
353
|
+
end
|
354
|
+
|
355
|
+
|
356
|
+
it "generates data uris" do
|
357
|
+
expect(Metanorma::Utils.datauri("data:xyz")).to eq "data:xyz"
|
358
|
+
expect(Metanorma::Utils.datauri("spec/fixtures/rice_image1.png")).to be_equivalent_to ""
|
359
|
+
expect(Metanorma::Utils.datauri("rice_image1.png", "spec/fixtures")).to be_equivalent_to ""
|
360
|
+
expect(Metanorma::Utils.datauri2mime("")&.first&.to_s).to eq "image/png"
|
361
|
+
end
|
208
362
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: metanorma-utils
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0.
|
4
|
+
version: 1.0.8
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ribose Inc.
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2021-
|
11
|
+
date: 2021-03-15 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: sterile
|
@@ -80,6 +80,34 @@ dependencies:
|
|
80
80
|
- - ">="
|
81
81
|
- !ruby/object:Gem::Version
|
82
82
|
version: '0'
|
83
|
+
- !ruby/object:Gem::Dependency
|
84
|
+
name: mimemagic
|
85
|
+
requirement: !ruby/object:Gem::Requirement
|
86
|
+
requirements:
|
87
|
+
- - ">="
|
88
|
+
- !ruby/object:Gem::Version
|
89
|
+
version: '0'
|
90
|
+
type: :runtime
|
91
|
+
prerelease: false
|
92
|
+
version_requirements: !ruby/object:Gem::Requirement
|
93
|
+
requirements:
|
94
|
+
- - ">="
|
95
|
+
- !ruby/object:Gem::Version
|
96
|
+
version: '0'
|
97
|
+
- !ruby/object:Gem::Dependency
|
98
|
+
name: mime-types
|
99
|
+
requirement: !ruby/object:Gem::Requirement
|
100
|
+
requirements:
|
101
|
+
- - ">="
|
102
|
+
- !ruby/object:Gem::Version
|
103
|
+
version: '0'
|
104
|
+
type: :runtime
|
105
|
+
prerelease: false
|
106
|
+
version_requirements: !ruby/object:Gem::Requirement
|
107
|
+
requirements:
|
108
|
+
- - ">="
|
109
|
+
- !ruby/object:Gem::Version
|
110
|
+
version: '0'
|
83
111
|
- !ruby/object:Gem::Dependency
|
84
112
|
name: byebug
|
85
113
|
requirement: !ruby/object:Gem::Requirement
|
@@ -142,14 +170,14 @@ dependencies:
|
|
142
170
|
requirements:
|
143
171
|
- - "~>"
|
144
172
|
- !ruby/object:Gem::Version
|
145
|
-
version: '
|
173
|
+
version: '13.0'
|
146
174
|
type: :development
|
147
175
|
prerelease: false
|
148
176
|
version_requirements: !ruby/object:Gem::Requirement
|
149
177
|
requirements:
|
150
178
|
- - "~>"
|
151
179
|
- !ruby/object:Gem::Version
|
152
|
-
version: '
|
180
|
+
version: '13.0'
|
153
181
|
- !ruby/object:Gem::Dependency
|
154
182
|
name: rspec
|
155
183
|
requirement: !ruby/object:Gem::Requirement
|
@@ -243,17 +271,22 @@ executables: []
|
|
243
271
|
extensions: []
|
244
272
|
extra_rdoc_files: []
|
245
273
|
files:
|
274
|
+
- ".github/workflows/rake.yml"
|
275
|
+
- ".rubocop.yml"
|
246
276
|
- Gemfile
|
247
277
|
- LICENSE
|
248
278
|
- README.adoc
|
249
279
|
- Rakefile
|
250
280
|
- bin/rspec
|
251
281
|
- lib/metanorma-utils.rb
|
282
|
+
- lib/utils/hash_transform_keys.rb
|
252
283
|
- lib/utils/log.rb
|
253
284
|
- lib/utils/main.rb
|
254
285
|
- lib/utils/version.rb
|
255
286
|
- metanorma-utils.gemspec
|
256
287
|
- spec/fixtures/action_schemaexpg1.svg
|
288
|
+
- spec/fixtures/rice_image1.png
|
289
|
+
- spec/hash_transform_keys_spec.rb
|
257
290
|
- spec/spec_helper.rb
|
258
291
|
- spec/utils_spec.rb
|
259
292
|
homepage: https://github.com/metanorma/metanorma-utils
|