metanorma-utils 1.0.5 → 1.1.0
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 +5 -3
- data/.gitignore +1 -0
- data/.rubocop.yml +10 -2
- data/lib/utils/main.rb +44 -29
- data/lib/utils/version.rb +1 -1
- data/metanorma-utils.gemspec +4 -3
- data/spec/utils_spec.rb +31 -0
- metadata +28 -13
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 8d7146df13587bfd1597f42bdbd573dd3800ac166bebddc6348025fa1d69cac0
|
4
|
+
data.tar.gz: e4f4da08e4ecdb617055fa24f39ece4c0565d32ce96f24c363185b30ec9597d0
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 933433fa3ae2c0d9bdca247a12c98de3a274ec2085248db3253d8b54ebdb2e84123ac7b2bd851c9cbcb29b629450d36204dc4710ba67c340cc722982450dd4c2
|
7
|
+
data.tar.gz: 59c93891f1d349a2b6338c27a38a48a1f84cf81aa9609d649715461ae9b3c6e30a643e77a92eb0a7efc8551a8c1588ba7e9edda15a0e65d13f99e4b7582fe096
|
data/.github/workflows/rake.yml
CHANGED
@@ -30,7 +30,9 @@ jobs:
|
|
30
30
|
os: 'macos-latest'
|
31
31
|
experimental: true
|
32
32
|
steps:
|
33
|
-
- uses: actions/checkout@
|
33
|
+
- uses: actions/checkout@v2
|
34
|
+
with:
|
35
|
+
submodules: true
|
34
36
|
|
35
37
|
- uses: ruby/setup-ruby@v1
|
36
38
|
with:
|
@@ -45,7 +47,7 @@ jobs:
|
|
45
47
|
steps:
|
46
48
|
- uses: peter-evans/repository-dispatch@v1
|
47
49
|
with:
|
48
|
-
token: ${{ secrets.GITHUB_TOKEN }}
|
50
|
+
token: ${{ secrets.METANORMA_CI_PAT_TOKEN || secrets.GITHUB_TOKEN }}
|
49
51
|
repository: ${{ github.repository }}
|
50
52
|
event-type: notify
|
51
|
-
client-payload: '{"ref": "${{ github.ref }}"}'
|
53
|
+
client-payload: '{"ref": "${{ github.ref }}", "sha": "${{ github.sha }}"}'
|
data/.gitignore
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
.rubocop-https--*
|
data/.rubocop.yml
CHANGED
@@ -1,6 +1,14 @@
|
|
1
1
|
# This project follows the Ribose OSS style guide.
|
2
2
|
# https://github.com/riboseinc/oss-guides
|
3
3
|
# All project-specific additions and overrides should be specified in this file.
|
4
|
-
|
5
4
|
inherit_from:
|
6
|
-
- https://raw.githubusercontent.com/riboseinc/oss-guides/master/ci/rubocop.yml
|
5
|
+
- https://raw.githubusercontent.com/riboseinc/oss-guides/master/ci/rubocop.yml
|
6
|
+
|
7
|
+
# local repo-specific modifications
|
8
|
+
|
9
|
+
AllCops:
|
10
|
+
DisplayCopNames: false
|
11
|
+
StyleGuideCopsOnly: false
|
12
|
+
TargetRubyVersion: 2.4
|
13
|
+
Rails:
|
14
|
+
Enabled: true
|
data/lib/utils/main.rb
CHANGED
@@ -2,7 +2,7 @@ require "asciidoctor"
|
|
2
2
|
require "tempfile"
|
3
3
|
require "sterile"
|
4
4
|
require "uuidtools"
|
5
|
-
require "
|
5
|
+
require "marcel"
|
6
6
|
require "mime/types"
|
7
7
|
require "base64"
|
8
8
|
|
@@ -30,10 +30,10 @@ module Metanorma
|
|
30
30
|
node.nil? || node.id.nil? || node.id.empty? ? "_" + uuid : node.id
|
31
31
|
end
|
32
32
|
|
33
|
-
def asciidoc_sub(x)
|
33
|
+
def asciidoc_sub(x, flavour = :standoc)
|
34
34
|
return nil if x.nil?
|
35
35
|
return "" if x.empty?
|
36
|
-
d = Asciidoctor::Document.new(x.lines.entries, { header_footer: false, backend:
|
36
|
+
d = Asciidoctor::Document.new(x.lines.entries, { header_footer: false, backend: flavour })
|
37
37
|
b = d.parse.blocks.first
|
38
38
|
b.apply_subs(b.source)
|
39
39
|
end
|
@@ -97,40 +97,52 @@ module Metanorma
|
|
97
97
|
end
|
98
98
|
|
99
99
|
def save_dataimage(uri)
|
100
|
-
|
101
|
-
|
102
|
-
|
103
|
-
|
104
|
-
|
105
|
-
|
106
|
-
|
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
|
107
|
+
end
|
107
108
|
end
|
108
|
-
end
|
109
109
|
|
110
|
-
|
110
|
+
SVG_NS = "http://www.w3.org/2000/svg".freeze
|
111
|
+
|
112
|
+
def svgmap_rewrite(xmldoc, localdirectory = "")
|
111
113
|
n = Namespace.new(xmldoc)
|
112
114
|
xmldoc.xpath(n.ns("//svgmap")).each do |s|
|
113
|
-
next unless
|
114
|
-
path = /^data:/.match(src) ? save_dataimage(src) : File.file?(src) ? src : localdir + src
|
115
|
-
File.file?(path) or next
|
116
|
-
svg = Nokogiri::XML(File.read(path, encoding: "utf-8"))
|
117
|
-
svgmap_rewrite1(s, svg, path, n)
|
118
|
-
/^data:/.match(src) and i["src"] = datauri(path)
|
115
|
+
next unless svgmap_rewrite0(s, n, localdirectory)
|
119
116
|
next if s.at(n.ns("./target/eref"))
|
120
117
|
s.replace(s.at(n.ns("./figure")))
|
121
118
|
end
|
122
119
|
end
|
123
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
|
+
|
124
135
|
def svgmap_rewrite1(s, svg, path, n)
|
125
136
|
targets = s.xpath(n.ns("./target")).each_with_object({}) do |t, m|
|
126
|
-
x = t.at(n.ns("./xref")) and m[t["href"]] = "##{x['target']}"
|
127
|
-
x = t.at(n.ns("./link")) and m[t["href"]] = x['target']
|
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']
|
128
139
|
t.remove if t.at(n.ns("./xref | ./link"))
|
129
140
|
end
|
130
|
-
svg.xpath(".//
|
131
|
-
x = targets[a["xlink:href"]] and a["xlink:href"] = x
|
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
|
132
144
|
end
|
133
|
-
File.open(path, "w", encoding: "utf-8") { |f| f.write(svg.to_xml) }
|
145
|
+
path and File.open(path, "w", encoding: "utf-8") { |f| f.write(svg.to_xml) }
|
134
146
|
end
|
135
147
|
|
136
148
|
# not currently used
|
@@ -163,12 +175,15 @@ module Metanorma
|
|
163
175
|
result.reject(&:empty?)
|
164
176
|
end
|
165
177
|
|
166
|
-
#
|
167
|
-
|
168
|
-
# sources/sources/plantuml/plantuml20200524-90467-1iqek5i.png)
|
169
|
-
def datauri(uri, localdir = ".")
|
178
|
+
# sources/plantuml/plantuml20200524-90467-1iqek5i.png already includes localdir
|
179
|
+
def datauri(uri, localdirectory = ".")
|
170
180
|
return uri if /^data:/.match(uri)
|
171
|
-
path = %r{^([A-Z]:)?/}.match?(uri) ? 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
|
172
187
|
types = MIME::Types.type_for(path)
|
173
188
|
type = types ? types.first.to_s : 'text/plain; charset="utf-8"'
|
174
189
|
bin = File.open(path, 'rb', &:read)
|
@@ -192,7 +207,7 @@ module Metanorma
|
|
192
207
|
file.binmode
|
193
208
|
file.write(Base64.strict_decode64(imgdata))
|
194
209
|
file.rewind
|
195
|
-
type =
|
210
|
+
type = Marcel::MimeType.for file
|
196
211
|
ensure
|
197
212
|
file.close!
|
198
213
|
end
|
data/lib/utils/version.rb
CHANGED
data/metanorma-utils.gemspec
CHANGED
@@ -29,18 +29,19 @@ 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 "
|
32
|
+
spec.add_dependency "marcel", "~> 1.0.0"
|
33
33
|
spec.add_dependency "mime-types"
|
34
34
|
|
35
35
|
spec.add_development_dependency "byebug"
|
36
36
|
spec.add_development_dependency "equivalent-xml", "~> 0.6"
|
37
37
|
spec.add_development_dependency "guard", "~> 2.14"
|
38
38
|
spec.add_development_dependency "guard-rspec", "~> 4.7"
|
39
|
-
spec.add_development_dependency "rake", "~>
|
39
|
+
spec.add_development_dependency "rake", "~> 13.0"
|
40
40
|
spec.add_development_dependency "rspec", "~> 3.6"
|
41
|
-
spec.add_development_dependency "rubocop", "
|
41
|
+
spec.add_development_dependency "rubocop", "~> 1.5.2"
|
42
42
|
spec.add_development_dependency "simplecov", "~> 0.15"
|
43
43
|
spec.add_development_dependency "timecop", "~> 0.9"
|
44
44
|
spec.add_development_dependency "vcr", "~> 5.0.0"
|
45
45
|
spec.add_development_dependency "webmock"
|
46
|
+
spec.add_development_dependency "metanorma-standoc", "~> 1.8"
|
46
47
|
end
|
data/spec/utils_spec.rb
CHANGED
@@ -18,7 +18,9 @@ RSpec.describe Metanorma::Utils do
|
|
18
18
|
end
|
19
19
|
|
20
20
|
it "applies Asciidoctor substitutions" do
|
21
|
+
require "metanorma-standoc"
|
21
22
|
expect(Metanorma::Utils.asciidoc_sub("A -- B")).to eq "A — B"
|
23
|
+
expect(Metanorma::Utils.asciidoc_sub("*A* stem:[x]")).to eq "<strong>A</strong> <stem type=\"AsciiMath\">x</stem>"
|
22
24
|
end
|
23
25
|
|
24
26
|
it "finds file path of docfile" do
|
@@ -104,6 +106,22 @@ RSpec.describe Metanorma::Utils do
|
|
104
106
|
<figure><image src="action_schemaexpg2.svg" alt="Workmap"/></figure>
|
105
107
|
<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
108
|
<svgmap id="_60dadf08-48d4-4164-845c-b4e293e00abd">
|
109
|
+
<figure>
|
110
|
+
<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'>
|
111
|
+
<a href="mn://action_schema" >
|
112
|
+
<rect x="123.28" y="273.93" class="st0" width="88.05" height="41.84"/>
|
113
|
+
</a>
|
114
|
+
<a href="mn://basic_attribute_schema" >
|
115
|
+
<rect x="324.69" y="450.52" class="st0" width="132.62" height="40.75"/>
|
116
|
+
</a>
|
117
|
+
<a xlink:href="mn://support_resource_schema" >
|
118
|
+
<rect x="324.69" y="528.36" class="st0" width="148.16" height="40.75"/>
|
119
|
+
</a>
|
120
|
+
</svg>
|
121
|
+
</figure>
|
122
|
+
<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>
|
123
|
+
</svgmap>
|
124
|
+
<svgmap id="_60dadf08-48d4-4164-845c-b4e293e00abd">
|
107
125
|
<figure>
|
108
126
|
|
109
127
|
<image src='' id='__ISO_17301-1_2016' mimetype='image/svg+xml' height='auto' width='auto' alt='Workmap1'/>
|
@@ -143,6 +161,19 @@ RSpec.describe Metanorma::Utils do
|
|
143
161
|
<image src='action_schemaexpg2.svg' alt='Workmap'/>
|
144
162
|
</figure>
|
145
163
|
<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>
|
164
|
+
<figure>
|
165
|
+
<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'>
|
166
|
+
<a href='#ref1'>
|
167
|
+
<rect x='123.28' y='273.93' class='st0' width='88.05' height='41.84'/>
|
168
|
+
</a>
|
169
|
+
<a href='mn://basic_attribute_schema'>
|
170
|
+
<rect x='324.69' y='450.52' class='st0' width='132.62' height='40.75'/>
|
171
|
+
</a>
|
172
|
+
<a xlink:href='mn://support_resource_schema'>
|
173
|
+
<rect x='324.69' y='528.36' class='st0' width='148.16' height='40.75'/>
|
174
|
+
</a>
|
175
|
+
</svg>
|
176
|
+
</figure>
|
146
177
|
<svgmap id='_60dadf08-48d4-4164-845c-b4e293e00abd'>
|
147
178
|
<figure>
|
148
179
|
</figure>
|
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.1.0
|
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-29 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: sterile
|
@@ -81,19 +81,19 @@ dependencies:
|
|
81
81
|
- !ruby/object:Gem::Version
|
82
82
|
version: '0'
|
83
83
|
- !ruby/object:Gem::Dependency
|
84
|
-
name:
|
84
|
+
name: marcel
|
85
85
|
requirement: !ruby/object:Gem::Requirement
|
86
86
|
requirements:
|
87
|
-
- - "
|
87
|
+
- - "~>"
|
88
88
|
- !ruby/object:Gem::Version
|
89
|
-
version:
|
89
|
+
version: 1.0.0
|
90
90
|
type: :runtime
|
91
91
|
prerelease: false
|
92
92
|
version_requirements: !ruby/object:Gem::Requirement
|
93
93
|
requirements:
|
94
|
-
- - "
|
94
|
+
- - "~>"
|
95
95
|
- !ruby/object:Gem::Version
|
96
|
-
version:
|
96
|
+
version: 1.0.0
|
97
97
|
- !ruby/object:Gem::Dependency
|
98
98
|
name: mime-types
|
99
99
|
requirement: !ruby/object:Gem::Requirement
|
@@ -170,14 +170,14 @@ dependencies:
|
|
170
170
|
requirements:
|
171
171
|
- - "~>"
|
172
172
|
- !ruby/object:Gem::Version
|
173
|
-
version: '
|
173
|
+
version: '13.0'
|
174
174
|
type: :development
|
175
175
|
prerelease: false
|
176
176
|
version_requirements: !ruby/object:Gem::Requirement
|
177
177
|
requirements:
|
178
178
|
- - "~>"
|
179
179
|
- !ruby/object:Gem::Version
|
180
|
-
version: '
|
180
|
+
version: '13.0'
|
181
181
|
- !ruby/object:Gem::Dependency
|
182
182
|
name: rspec
|
183
183
|
requirement: !ruby/object:Gem::Requirement
|
@@ -196,16 +196,16 @@ dependencies:
|
|
196
196
|
name: rubocop
|
197
197
|
requirement: !ruby/object:Gem::Requirement
|
198
198
|
requirements:
|
199
|
-
- -
|
199
|
+
- - "~>"
|
200
200
|
- !ruby/object:Gem::Version
|
201
|
-
version:
|
201
|
+
version: 1.5.2
|
202
202
|
type: :development
|
203
203
|
prerelease: false
|
204
204
|
version_requirements: !ruby/object:Gem::Requirement
|
205
205
|
requirements:
|
206
|
-
- -
|
206
|
+
- - "~>"
|
207
207
|
- !ruby/object:Gem::Version
|
208
|
-
version:
|
208
|
+
version: 1.5.2
|
209
209
|
- !ruby/object:Gem::Dependency
|
210
210
|
name: simplecov
|
211
211
|
requirement: !ruby/object:Gem::Requirement
|
@@ -262,6 +262,20 @@ dependencies:
|
|
262
262
|
- - ">="
|
263
263
|
- !ruby/object:Gem::Version
|
264
264
|
version: '0'
|
265
|
+
- !ruby/object:Gem::Dependency
|
266
|
+
name: metanorma-standoc
|
267
|
+
requirement: !ruby/object:Gem::Requirement
|
268
|
+
requirements:
|
269
|
+
- - "~>"
|
270
|
+
- !ruby/object:Gem::Version
|
271
|
+
version: '1.8'
|
272
|
+
type: :development
|
273
|
+
prerelease: false
|
274
|
+
version_requirements: !ruby/object:Gem::Requirement
|
275
|
+
requirements:
|
276
|
+
- - "~>"
|
277
|
+
- !ruby/object:Gem::Version
|
278
|
+
version: '1.8'
|
265
279
|
description: 'metanorma-utils provides utilities for the Metanorma stack
|
266
280
|
|
267
281
|
'
|
@@ -272,6 +286,7 @@ extensions: []
|
|
272
286
|
extra_rdoc_files: []
|
273
287
|
files:
|
274
288
|
- ".github/workflows/rake.yml"
|
289
|
+
- ".gitignore"
|
275
290
|
- ".rubocop.yml"
|
276
291
|
- Gemfile
|
277
292
|
- LICENSE
|