slim-embedded-minify 0.2.4 → 0.2.6
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +9 -1
- data/lib/slim/embedded/minify/javascript.rb +39 -4
- data/lib/slim/embedded/minify/tag.rb +83 -13
- data/lib/slim/embedded/minify/version.rb +1 -1
- data/slim-embedded-minify.gemspec +2 -1
- metadata +3 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a0acd763c9c3c2869fee898e2da36f1a26aa1aa2430d9cfe9c3008db35ecd442
|
4
|
+
data.tar.gz: b3d30f07bbf45aa062deac825d4e849958f495fc4cae6cb819362ebb32f8c53b
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: f7e085fd30ce3b514709e55e8999c919e2ab4f25fbdcc7c3b62617a8ee09e890d732af7d6c03064eda833b002fbc5b2cec9cccf3ef5afe7ab93a7c843b708ad5
|
7
|
+
data.tar.gz: 26466135a7c571e04eb572f49906f8f17d3ccc21ae1be8ca44e9a00c1da1ae591cb7583d16cbada24d34e0f324a7bf1dd32afc7b4248ac82afed387527fffd58
|
data/CHANGELOG.md
CHANGED
@@ -1,8 +1,16 @@
|
|
1
1
|
## Unreleased
|
2
2
|
|
3
|
+
## 0.2.6 - 2023-08-01
|
4
|
+
|
5
|
+
- Fix incorrect removing when using escaped quotation.
|
6
|
+
|
7
|
+
## 0.2.5 - 2023-07-27
|
8
|
+
|
9
|
+
- Fix to not delete anything other than comments.
|
10
|
+
|
3
11
|
## 0.2.4 - 2023-07-27
|
4
12
|
|
5
|
-
- Fix deletion of strings when `/*` is present in the string
|
13
|
+
- Fix deletion of strings when `/*` is present in the string.
|
6
14
|
|
7
15
|
## 0.2.3 - 2023-07-27
|
8
16
|
|
@@ -11,11 +11,46 @@ module Slim
|
|
11
11
|
super(engine, minified_body, attrs)
|
12
12
|
end
|
13
13
|
|
14
|
-
private
|
15
|
-
|
16
14
|
def remove_comments!(line)
|
17
|
-
|
18
|
-
|
15
|
+
need_deletion = false
|
16
|
+
need_deletion_all = false
|
17
|
+
escaped = false
|
18
|
+
escaped_backslash = false
|
19
|
+
inside_char = nil
|
20
|
+
line[-1] = line.last.chars.each_with_index.map do |char, index|
|
21
|
+
next if need_deletion_all
|
22
|
+
|
23
|
+
if char == "/" && next_char(line, index) == "*" && inside_char.nil?
|
24
|
+
if remaining_string_range(line, index).include?("*/")
|
25
|
+
need_deletion = true
|
26
|
+
next
|
27
|
+
end
|
28
|
+
elsif char == "/" && prev_char(line, index) == "*" && inside_char.nil? && need_deletion
|
29
|
+
need_deletion = false
|
30
|
+
next
|
31
|
+
elsif char == "/" && next_char(line, index) == "/" && inside_char.nil? && !need_deletion
|
32
|
+
need_deletion_all = true
|
33
|
+
next
|
34
|
+
elsif char == "\\" && next_char(line, index) == "\\" && inside_char
|
35
|
+
escaped_backslash = true
|
36
|
+
next char
|
37
|
+
elsif char == "\\"
|
38
|
+
if ["'", '"'].include?(next_char(line, index)) && inside_char == next_char(line, index) && !escaped_backslash
|
39
|
+
escaped = true
|
40
|
+
end
|
41
|
+
escaped_backslash = false
|
42
|
+
next char
|
43
|
+
elsif ["'", '"'].include?(char) && !need_deletion
|
44
|
+
if inside_char == char
|
45
|
+
inside_char = nil unless escaped
|
46
|
+
escaped = false
|
47
|
+
next char
|
48
|
+
end
|
49
|
+
|
50
|
+
inside_char = char if inside_char.nil?
|
51
|
+
end
|
52
|
+
char if !need_deletion || inside_char
|
53
|
+
end&.compact&.join
|
19
54
|
end
|
20
55
|
end
|
21
56
|
end
|
@@ -13,43 +13,113 @@ module Slim
|
|
13
13
|
|
14
14
|
def minify(body)
|
15
15
|
multiline_comment = false
|
16
|
-
body.
|
16
|
+
body.filter_map do |line|
|
17
17
|
if line.instance_of?(Array) && line.first == :slim
|
18
18
|
remove_comments!(line)
|
19
|
-
|
19
|
+
next if line.last.nil?
|
20
20
|
|
21
|
+
remove_whitespace!(line)
|
21
22
|
stripped_quotes = stripped_quotes(line)
|
22
|
-
if stripped_quotes.
|
23
|
+
if stripped_quotes.include?("/*") && !multiline_comment
|
23
24
|
multiline_comment = true
|
24
|
-
line.last.sub
|
25
|
+
line[-1] = line.last.reverse.sub(%r{.*?\*/}, "").reverse
|
25
26
|
elsif multiline_comment
|
26
|
-
next unless stripped_quotes.
|
27
|
+
next unless stripped_quotes.include?("*/")
|
27
28
|
|
28
29
|
multiline_comment = false
|
29
|
-
line.last.sub!(
|
30
|
+
line.last.sub!(%r{.*\*/(?<!['"])}, "")
|
31
|
+
end
|
32
|
+
if stripped_quotes.include?("/*") && !multiline_comment
|
33
|
+
multiline_comment = true
|
34
|
+
line[-1] = line.last.reverse.sub(%r{.*?\*/}, "").reverse
|
30
35
|
end
|
31
36
|
next if empty_line?(line)
|
32
37
|
end
|
33
38
|
line
|
34
|
-
end
|
39
|
+
end
|
35
40
|
end
|
36
41
|
|
37
42
|
def remove_comments!(line)
|
38
|
-
|
43
|
+
need_deletion = false
|
44
|
+
inside_char = nil
|
45
|
+
line[-1] = line.last.chars.each_with_index.map do |char, index|
|
46
|
+
if char == "/" && next_char(line, index) == "*" && inside_char.nil?
|
47
|
+
if remaining_string_range(line, index).include?("*/")
|
48
|
+
need_deletion = true
|
49
|
+
next
|
50
|
+
end
|
51
|
+
elsif char == "/" && prev_char(line, index) == "*" && inside_char.nil? && need_deletion
|
52
|
+
need_deletion = false
|
53
|
+
next
|
54
|
+
elsif char == '"' && !need_deletion
|
55
|
+
if inside_char == '"'
|
56
|
+
inside_char = nil
|
57
|
+
next char
|
58
|
+
end
|
59
|
+
|
60
|
+
inside_char = '"' if inside_char.nil?
|
61
|
+
elsif char == "'" && !need_deletion
|
62
|
+
if inside_char == "'"
|
63
|
+
inside_char = nil
|
64
|
+
next char
|
65
|
+
end
|
66
|
+
|
67
|
+
inside_char = "'" if inside_char.nil?
|
68
|
+
end
|
69
|
+
char unless need_deletion
|
70
|
+
end&.compact&.join
|
71
|
+
end
|
72
|
+
|
73
|
+
def remaining_string_range(line, index)
|
74
|
+
line.last[index..]
|
75
|
+
end
|
76
|
+
|
77
|
+
def prev_char(line, index)
|
78
|
+
line.last[index - 1] if index.positive?
|
79
|
+
end
|
80
|
+
|
81
|
+
def next_char(line, index)
|
82
|
+
line.last[index + 1]
|
39
83
|
end
|
40
84
|
|
41
85
|
def remove_whitespace!(line)
|
42
|
-
|
43
|
-
|
44
|
-
|
86
|
+
return unless line.last.delete("\n").match?(/^\s*$/)
|
87
|
+
|
88
|
+
line.last.gsub!(/^\s*$/, "")
|
45
89
|
end
|
46
90
|
|
47
91
|
def stripped_quotes(line)
|
48
|
-
|
92
|
+
inside_char = nil
|
93
|
+
escaped = false
|
94
|
+
escaped_backslash = false
|
95
|
+
line.last.chars.each_with_index.filter_map do |char, index|
|
96
|
+
if ["'", '"'].include?(char) && inside_char.nil?
|
97
|
+
inside_char = char
|
98
|
+
next
|
99
|
+
elsif char == "\\" && next_char(line, index) == "\\" && inside_char
|
100
|
+
escaped_backslash = true
|
101
|
+
next
|
102
|
+
elsif char == "\\"
|
103
|
+
if ["'",
|
104
|
+
'"'].include?(next_char(line, index)) && inside_char == next_char(line, index) && !escaped_backslash
|
105
|
+
escaped = true
|
106
|
+
end
|
107
|
+
escaped_backslash = false
|
108
|
+
next
|
109
|
+
elsif char == inside_char && !inside_char.nil?
|
110
|
+
inside_char = nil unless escaped
|
111
|
+
escaped = false
|
112
|
+
next
|
113
|
+
elsif inside_char
|
114
|
+
next
|
115
|
+
else
|
116
|
+
char
|
117
|
+
end
|
118
|
+
end.join
|
49
119
|
end
|
50
120
|
|
51
121
|
def empty_line?(line)
|
52
|
-
line.last.gsub(/[\n\s]/,
|
122
|
+
line.last.gsub(/[\n\s]/, "").empty?
|
53
123
|
end
|
54
124
|
end
|
55
125
|
end
|
@@ -27,5 +27,6 @@ Gem::Specification.new do |spec|
|
|
27
27
|
spec.bindir = "exe"
|
28
28
|
spec.executables = spec.files.grep(%r{\Aexe/}) { |f| File.basename(f) }
|
29
29
|
spec.require_paths = ["lib"]
|
30
|
-
spec.add_runtime_dependency
|
30
|
+
spec.add_runtime_dependency "slim", "~> 5.1"
|
31
|
+
spec.metadata["rubygems_mfa_required"] = "true"
|
31
32
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: slim-embedded-minify
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.6
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Yudai Takada
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2023-
|
11
|
+
date: 2023-08-01 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: slim
|
@@ -49,6 +49,7 @@ metadata:
|
|
49
49
|
homepage_uri: https://github.com/ydah/slim-embedded-minify
|
50
50
|
source_code_uri: https://github.com/ydah/slim-embedded-minify
|
51
51
|
changelog_uri: https://github.com/ydah/slim-embedded-minify/releases
|
52
|
+
rubygems_mfa_required: 'true'
|
52
53
|
post_install_message:
|
53
54
|
rdoc_options: []
|
54
55
|
require_paths:
|