sassc-embedded 1.0.6 → 1.2.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/sassc/embedded/version.rb +1 -1
- data/lib/sassc/embedded.rb +35 -23
- metadata +4 -4
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 165d1e520918392a01a808a20da523f4f573d762684c279f83dcf75202659c46
|
4
|
+
data.tar.gz: 80bf5a80e154a4be31c013489bd807a7c8ffdac4ffc1f143baf76c81e61326f0
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f5f88d175f876435912bbb8141180dd4c72f3874b3d76604188598499c53c9dcdc5f273e3abdaff8674c93de30553a4be9370ba1b6665bab38a578cc3540ef65
|
7
|
+
data.tar.gz: 6c26f72589706937100230aa6e7e5e2ddd687f7cead7ce6653354fd556f371e26a07a400012845210c947f2928532ffb0a13c01ecde27b8b4a4eb5c691ec6e32
|
data/lib/sassc/embedded.rb
CHANGED
@@ -38,14 +38,14 @@ module SassC
|
|
38
38
|
|
39
39
|
@dependencies = result.loaded_urls
|
40
40
|
.filter { |url| url.start_with?('file:') && url != file_url }
|
41
|
-
.map { |url|
|
41
|
+
.map { |url| URL.file_url_to_path(url) }
|
42
42
|
@source_map = post_process_source_map(result.source_map)
|
43
43
|
|
44
44
|
return post_process_css(result.css) unless quiet?
|
45
45
|
rescue ::Sass::CompileError => e
|
46
46
|
line = e.span&.start&.line
|
47
47
|
line += 1 unless line.nil?
|
48
|
-
path =
|
48
|
+
path = URL.file_url_to_path(e.span&.url)
|
49
49
|
path = relative_path(Dir.pwd, path) unless path.nil?
|
50
50
|
raise SyntaxError.new(e.message, filename: path, line: line)
|
51
51
|
end
|
@@ -60,7 +60,7 @@ module SassC
|
|
60
60
|
end
|
61
61
|
|
62
62
|
def file_url
|
63
|
-
@file_url ||=
|
63
|
+
@file_url ||= URL.path_to_file_url(filename || 'stdin')
|
64
64
|
end
|
65
65
|
|
66
66
|
def syntax
|
@@ -98,11 +98,11 @@ module SassC
|
|
98
98
|
|
99
99
|
source_map_dir = File.dirname(source_map_file || '')
|
100
100
|
|
101
|
-
data['file'] =
|
101
|
+
data['file'] = URL.escape(relative_path(source_map_dir, output_path)) if output_path
|
102
102
|
|
103
103
|
data['sources'].map! do |source|
|
104
104
|
if source.start_with?('file:')
|
105
|
-
relative_path(source_map_dir,
|
105
|
+
relative_path(source_map_dir, URL.file_url_to_path(source))
|
106
106
|
else
|
107
107
|
source
|
108
108
|
end
|
@@ -117,7 +117,7 @@ module SassC
|
|
117
117
|
url = if source_map_embed?
|
118
118
|
"data:application/json;base64,#{Base64.strict_encode64(@source_map)}"
|
119
119
|
else
|
120
|
-
|
120
|
+
URL.escape(relative_path(File.dirname(output_path || ''), source_map_file))
|
121
121
|
end
|
122
122
|
css += "\n/*# sourceMappingURL=#{url} */"
|
123
123
|
end
|
@@ -163,8 +163,8 @@ module SassC
|
|
163
163
|
private
|
164
164
|
|
165
165
|
def arguments_from_native_list(native_argument_list)
|
166
|
-
native_argument_list.map do |
|
167
|
-
Script::ValueConversion.from_native
|
166
|
+
native_argument_list.map do |native_value|
|
167
|
+
Script::ValueConversion.from_native(native_value, @options)
|
168
168
|
end.compact
|
169
169
|
end
|
170
170
|
|
@@ -175,7 +175,7 @@ module SassC
|
|
175
175
|
raise ::Sass::ScriptError
|
176
176
|
end
|
177
177
|
rescue StandardError => e
|
178
|
-
unless e.full_message.include?
|
178
|
+
unless e.full_message.include?(e.cause.full_message)
|
179
179
|
::Sass::ScriptError.class_eval do
|
180
180
|
def full_message(*args, **kwargs)
|
181
181
|
full_message = super(*args, **kwargs)
|
@@ -195,12 +195,12 @@ module SassC
|
|
195
195
|
if @importer
|
196
196
|
[FileImporter.new, Importer.new(@importer)]
|
197
197
|
else
|
198
|
-
[
|
198
|
+
[]
|
199
199
|
end
|
200
200
|
end
|
201
201
|
|
202
202
|
class FileImporter
|
203
|
-
def find_file_url(url, **
|
203
|
+
def find_file_url(url, **)
|
204
204
|
return url if url.start_with?('file:')
|
205
205
|
end
|
206
206
|
end
|
@@ -215,11 +215,11 @@ module SassC
|
|
215
215
|
|
216
216
|
def canonicalize(url, **)
|
217
217
|
path = if url.start_with?('file:')
|
218
|
-
|
218
|
+
URL.file_url_to_path(url)
|
219
219
|
else
|
220
|
-
|
220
|
+
URL.unescape(url)
|
221
221
|
end
|
222
|
-
canonical_url =
|
222
|
+
canonical_url = URL.path_to_file_url(File.absolute_path(path))
|
223
223
|
|
224
224
|
if @importer_results.key?(canonical_url)
|
225
225
|
return if @importer_results[canonical_url].nil?
|
@@ -229,8 +229,8 @@ module SassC
|
|
229
229
|
|
230
230
|
canonical_url = "sassc-embedded:#{canonical_url}"
|
231
231
|
|
232
|
-
imports = @importer.imports
|
233
|
-
unless imports.is_a?
|
232
|
+
imports = @importer.imports(path, @importer.options[:filename])
|
233
|
+
unless imports.is_a?(Array)
|
234
234
|
return if imports.path == path
|
235
235
|
|
236
236
|
imports = [imports]
|
@@ -238,7 +238,7 @@ module SassC
|
|
238
238
|
|
239
239
|
dirname = File.dirname(@importer.options.fetch(:filename, 'stdin'))
|
240
240
|
contents = imports.map do |import|
|
241
|
-
import_url =
|
241
|
+
import_url = URL.path_to_file_url(File.absolute_path(import.path, dirname))
|
242
242
|
@importer_results[import_url] = if import.source
|
243
243
|
{
|
244
244
|
contents: import.source,
|
@@ -251,7 +251,7 @@ module SassC
|
|
251
251
|
:scss
|
252
252
|
end,
|
253
253
|
source_map_url: if import.source_map_path
|
254
|
-
|
254
|
+
URL.path_to_file_url(
|
255
255
|
File.absolute_path(
|
256
256
|
import.source_map_path, dirname
|
257
257
|
)
|
@@ -395,15 +395,25 @@ module SassC
|
|
395
395
|
end
|
396
396
|
end
|
397
397
|
|
398
|
-
module
|
398
|
+
module URL
|
399
|
+
PARSER = URI::Parser.new({ RESERVED: ';/?:@&=+$,' })
|
400
|
+
|
401
|
+
private_constant :PARSER
|
402
|
+
|
399
403
|
module_function
|
400
404
|
|
401
|
-
|
405
|
+
def escape(str)
|
406
|
+
PARSER.escape(str)
|
407
|
+
end
|
408
|
+
|
409
|
+
def unescape(str)
|
410
|
+
PARSER.unescape(str)
|
411
|
+
end
|
402
412
|
|
403
413
|
def file_url_to_path(url)
|
404
414
|
return if url.nil?
|
405
415
|
|
406
|
-
path =
|
416
|
+
path = unescape(URI.parse(url).path)
|
407
417
|
path = path[1..] if Gem.win_platform? && path[0].chr == '/' && path[1].chr =~ /[a-z]/i && path[2].chr == ':'
|
408
418
|
path
|
409
419
|
end
|
@@ -412,8 +422,10 @@ module SassC
|
|
412
422
|
return if path.nil?
|
413
423
|
|
414
424
|
path = File.absolute_path(path)
|
415
|
-
path = "/#{path}" unless path.start_with?
|
416
|
-
URI::File.build([nil,
|
425
|
+
path = "/#{path}" unless path.start_with?('/')
|
426
|
+
URI::File.build([nil, escape(path)]).to_s
|
417
427
|
end
|
418
428
|
end
|
429
|
+
|
430
|
+
private_constant :URL
|
419
431
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: sassc-embedded
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 1.0
|
4
|
+
version: 1.2.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- なつき
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date: 2022-03-
|
11
|
+
date: 2022-03-27 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: sassc
|
@@ -138,8 +138,8 @@ homepage: https://github.com/ntkme/sassc-embedded-polyfill-ruby
|
|
138
138
|
licenses:
|
139
139
|
- MIT
|
140
140
|
metadata:
|
141
|
-
documentation_uri: https://rubydoc.info/gems/sassc-embedded/1.0
|
142
|
-
source_code_uri: https://github.com/ntkme/sassc-embedded-polyfill-ruby/tree/v1.0
|
141
|
+
documentation_uri: https://rubydoc.info/gems/sassc-embedded/1.2.0
|
142
|
+
source_code_uri: https://github.com/ntkme/sassc-embedded-polyfill-ruby/tree/v1.2.0
|
143
143
|
funding_uri: https://github.com/sponsors/ntkme
|
144
144
|
post_install_message:
|
145
145
|
rdoc_options: []
|