markdiff 0.7.0 → 0.8.1
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/test.yml +2 -1
- data/CHANGELOG.md +54 -0
- data/Gemfile.lock +19 -19
- data/lib/markdiff/differ.rb +7 -4
- data/lib/markdiff/operations/text_diff_operation.rb +24 -17
- data/lib/markdiff/version.rb +1 -1
- data/markdiff.gemspec +3 -3
- metadata +15 -15
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: bcbedaaac5248f5ca65457efc285d8b931083379d9459fefd1633d6ba0074e6f
|
4
|
+
data.tar.gz: b32ed85a69e42c9ccd57dc2f5c2fd8c3835274b5a07e7629a5766a5fecd0bd97
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 3fab67dd051cbebacdfd8cefd270b1ef4375c9cdec915f5ab06351a4504d2cbbed9970835f794c7c509394d36ceb86410719bed969f3d69ac7001e2a529570cd
|
7
|
+
data.tar.gz: febf67a5e7eb49412789f3cfb519f3e2de5daa8e42ac311c99373066cf96041a7d650d24e72337a9ffdca0fdbe1bbd403d204d18a82e143049d78fdcf8ba02e9
|
data/.github/workflows/test.yml
CHANGED
data/CHANGELOG.md
CHANGED
@@ -2,65 +2,119 @@
|
|
2
2
|
|
3
3
|
## Unreleased
|
4
4
|
|
5
|
+
## 0.8.1
|
6
|
+
|
7
|
+
### Fixed
|
8
|
+
|
9
|
+
- Fix issue with diffs between blocks of matches.
|
10
|
+
|
11
|
+
## 0.8.0
|
12
|
+
|
13
|
+
### Changed
|
14
|
+
|
15
|
+
- Add class attributes to ins element: `.ins.ins-before` or `.ins.ins-after`.
|
16
|
+
|
17
|
+
### Fixed
|
18
|
+
|
19
|
+
- Fix issue on insertion and deletion on same position.
|
20
|
+
- Fix issue with long sentences.
|
21
|
+
|
22
|
+
## 0.7.0
|
23
|
+
|
24
|
+
### Fixed
|
25
|
+
|
5
26
|
- Fixed replaces shown wrongly.
|
6
27
|
|
7
28
|
## 0.6.3
|
8
29
|
|
30
|
+
### Fixed
|
31
|
+
|
9
32
|
- Support diff-lcs v1.4+.
|
10
33
|
|
11
34
|
## 0.6.2
|
12
35
|
|
36
|
+
### Changed
|
37
|
+
|
13
38
|
- Support tr.added and tr.deleted.
|
14
39
|
|
15
40
|
## 0.6.1
|
16
41
|
|
42
|
+
### Changed
|
43
|
+
|
17
44
|
- Fix patch order bug by making sort stable.
|
18
45
|
|
19
46
|
## 0.6.0
|
20
47
|
|
48
|
+
### Changed
|
49
|
+
|
21
50
|
- Add .del class to all del elements.
|
22
51
|
|
23
52
|
## 0.5.5
|
24
53
|
|
54
|
+
### Fixed
|
55
|
+
|
25
56
|
- Preserve classes on adding new class (e.g. .added).
|
26
57
|
|
27
58
|
## 0.5.4
|
28
59
|
|
60
|
+
### Fixed
|
61
|
+
|
29
62
|
- Fix bug on patch operations order.
|
30
63
|
|
31
64
|
## 0.5.3
|
32
65
|
|
66
|
+
### Fixed
|
67
|
+
|
33
68
|
- Fix bug on comparing nodes.
|
34
69
|
|
35
70
|
## 0.5.2
|
36
71
|
|
72
|
+
### Fixed
|
73
|
+
|
37
74
|
- Fix bug on comparing attributes and text nodes.
|
38
75
|
|
39
76
|
## 0.5.1
|
40
77
|
|
78
|
+
### Fixed
|
79
|
+
|
41
80
|
- Fix bug on text-diff operation.
|
42
81
|
|
43
82
|
## 0.5.0
|
44
83
|
|
84
|
+
### Changed
|
85
|
+
|
45
86
|
- Wrap changed nodes by div.changed.
|
46
87
|
|
47
88
|
## 0.4.0
|
48
89
|
|
90
|
+
### Changed
|
91
|
+
|
49
92
|
- Chanage .changed specs.
|
93
|
+
|
94
|
+
### Fixed
|
95
|
+
|
50
96
|
- Fix bugs on text diff.
|
51
97
|
|
52
98
|
## 0.3.0
|
53
99
|
|
100
|
+
### Changed
|
101
|
+
|
54
102
|
- Support partial text diff.
|
55
103
|
|
56
104
|
## 0.2.1
|
57
105
|
|
106
|
+
### Changed
|
107
|
+
|
58
108
|
- Support li.added and li.removed.
|
59
109
|
|
60
110
|
## 0.2.0
|
61
111
|
|
112
|
+
### Changed
|
113
|
+
|
62
114
|
- Support div.changed and li.changed.
|
63
115
|
|
64
116
|
## 0.1.0
|
65
117
|
|
118
|
+
### Added
|
119
|
+
|
66
120
|
- 1st Release.
|
data/Gemfile.lock
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
PATH
|
2
2
|
remote: .
|
3
3
|
specs:
|
4
|
-
markdiff (0.
|
4
|
+
markdiff (0.8.1)
|
5
5
|
diff-lcs
|
6
6
|
nokogiri
|
7
7
|
|
@@ -9,24 +9,24 @@ GEM
|
|
9
9
|
remote: https://rubygems.org/
|
10
10
|
specs:
|
11
11
|
diff-lcs (1.5.0)
|
12
|
-
nokogiri (1.
|
12
|
+
nokogiri (1.15.4-x86_64-linux)
|
13
13
|
racc (~> 1.4)
|
14
|
-
racc (1.
|
15
|
-
rake (
|
16
|
-
redcarpet (3.
|
17
|
-
rspec (3.
|
18
|
-
rspec-core (~> 3.
|
19
|
-
rspec-expectations (~> 3.
|
20
|
-
rspec-mocks (~> 3.
|
21
|
-
rspec-core (3.
|
22
|
-
rspec-support (~> 3.
|
23
|
-
rspec-expectations (3.
|
14
|
+
racc (1.7.1)
|
15
|
+
rake (13.0.6)
|
16
|
+
redcarpet (3.6.0)
|
17
|
+
rspec (3.12.0)
|
18
|
+
rspec-core (~> 3.12.0)
|
19
|
+
rspec-expectations (~> 3.12.0)
|
20
|
+
rspec-mocks (~> 3.12.0)
|
21
|
+
rspec-core (3.12.1)
|
22
|
+
rspec-support (~> 3.12.0)
|
23
|
+
rspec-expectations (3.12.2)
|
24
24
|
diff-lcs (>= 1.2.0, < 2.0)
|
25
|
-
rspec-support (~> 3.
|
26
|
-
rspec-mocks (3.
|
25
|
+
rspec-support (~> 3.12.0)
|
26
|
+
rspec-mocks (3.12.3)
|
27
27
|
diff-lcs (>= 1.2.0, < 2.0)
|
28
|
-
rspec-support (~> 3.
|
29
|
-
rspec-support (3.
|
28
|
+
rspec-support (~> 3.12.0)
|
29
|
+
rspec-support (3.12.0)
|
30
30
|
|
31
31
|
PLATFORMS
|
32
32
|
x86_64-linux
|
@@ -34,9 +34,9 @@ PLATFORMS
|
|
34
34
|
DEPENDENCIES
|
35
35
|
bundler
|
36
36
|
markdiff!
|
37
|
-
rake
|
38
|
-
redcarpet
|
39
|
-
rspec
|
37
|
+
rake
|
38
|
+
redcarpet
|
39
|
+
rspec
|
40
40
|
|
41
41
|
BUNDLED WITH
|
42
42
|
2.3.6
|
data/lib/markdiff/differ.rb
CHANGED
@@ -100,14 +100,17 @@ module Markdiff
|
|
100
100
|
end
|
101
101
|
|
102
102
|
# Partial matching
|
103
|
-
before_node.children.
|
104
|
-
if identity_map[before_child]
|
105
|
-
|
106
|
-
|
103
|
+
before_node.children.each_with_index do |before_child, index|
|
104
|
+
next if identity_map[before_child]
|
105
|
+
|
106
|
+
next_match = before_node.children[index..].find { |child| identity_map[child] }
|
107
|
+
|
107
108
|
after_node.children.each do |after_child|
|
108
109
|
case
|
109
110
|
when identity_map[before_child]
|
110
111
|
break
|
112
|
+
when next_match && inverted_identity_map[after_child] == next_match
|
113
|
+
break
|
111
114
|
when inverted_identity_map[after_child]
|
112
115
|
when before_child.text?
|
113
116
|
if after_child.text?
|
@@ -13,30 +13,37 @@ module Markdiff
|
|
13
13
|
|
14
14
|
# @return [Nokogiri::XML::Node]
|
15
15
|
def inserted_node
|
16
|
-
before_elements = target_node.to_s.split(
|
17
|
-
after_elements = @after_node.to_s.split(
|
18
|
-
|
16
|
+
before_elements = target_node.to_s.split(' ')
|
17
|
+
after_elements = @after_node.to_s.split(' ')
|
18
|
+
last_operation = nil
|
19
19
|
|
20
|
-
::Diff::LCS.
|
21
|
-
|
20
|
+
groupings = ::Diff::LCS.sdiff(before_elements, after_elements)
|
21
|
+
.slice_when { |prev, cur| prev.action != cur.action }
|
22
22
|
|
23
|
-
|
24
|
-
|
25
|
-
last_deleted_pos = position
|
26
|
-
elsif type == "+"
|
27
|
-
insert = "<ins>#{element}</ins>"
|
23
|
+
output = groupings.map do |grouping|
|
24
|
+
action = grouping.first.action
|
28
25
|
|
29
|
-
|
30
|
-
|
26
|
+
response = case action
|
27
|
+
when "="
|
28
|
+
grouping.map(&:new_element).join(" ")
|
29
|
+
when "-"
|
30
|
+
%(<del class="del">#{grouping.map(&:old_element).join(" ")}</del>)
|
31
|
+
when "+"
|
32
|
+
%(<ins class="ins ins-before">#{grouping.map(&:new_element).join(" ")}</ins>)
|
33
|
+
when "!"
|
34
|
+
%(<del class="del">#{grouping.map(&:old_element).join(" ")}</del><ins class="ins ins-after">#{grouping.map(&:new_element).join(" ")}</ins>)
|
31
35
|
else
|
32
|
-
|
33
|
-
end
|
34
|
-
else
|
35
|
-
raise "Unhandled type: #{type}"
|
36
|
+
raise "Unknown action #{action}"
|
36
37
|
end
|
38
|
+
|
39
|
+
response = " #{response}" if last_operation && last_operation != '+'
|
40
|
+
|
41
|
+
last_operation = action
|
42
|
+
|
43
|
+
response
|
37
44
|
end
|
38
45
|
|
39
|
-
::Nokogiri::HTML.fragment(
|
46
|
+
::Nokogiri::HTML.fragment(output.join(''))
|
40
47
|
end
|
41
48
|
|
42
49
|
def priority
|
data/lib/markdiff/version.rb
CHANGED
data/markdiff.gemspec
CHANGED
@@ -14,9 +14,9 @@ Gem::Specification.new do |spec|
|
|
14
14
|
spec.require_paths = ["lib"]
|
15
15
|
|
16
16
|
spec.add_development_dependency "bundler"
|
17
|
-
spec.add_development_dependency "rake"
|
18
|
-
spec.add_development_dependency "redcarpet"
|
19
|
-
spec.add_development_dependency "rspec"
|
17
|
+
spec.add_development_dependency "rake"
|
18
|
+
spec.add_development_dependency "redcarpet"
|
19
|
+
spec.add_development_dependency "rspec"
|
20
20
|
spec.add_runtime_dependency "diff-lcs"
|
21
21
|
spec.add_runtime_dependency "nokogiri"
|
22
22
|
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: markdiff
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.8.1
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Ryo Nakamura
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-09-20 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -28,44 +28,44 @@ dependencies:
|
|
28
28
|
name: rake
|
29
29
|
requirement: !ruby/object:Gem::Requirement
|
30
30
|
requirements:
|
31
|
-
- - "
|
31
|
+
- - ">="
|
32
32
|
- !ruby/object:Gem::Version
|
33
|
-
version: '
|
33
|
+
version: '0'
|
34
34
|
type: :development
|
35
35
|
prerelease: false
|
36
36
|
version_requirements: !ruby/object:Gem::Requirement
|
37
37
|
requirements:
|
38
|
-
- - "
|
38
|
+
- - ">="
|
39
39
|
- !ruby/object:Gem::Version
|
40
|
-
version: '
|
40
|
+
version: '0'
|
41
41
|
- !ruby/object:Gem::Dependency
|
42
42
|
name: redcarpet
|
43
43
|
requirement: !ruby/object:Gem::Requirement
|
44
44
|
requirements:
|
45
|
-
- -
|
45
|
+
- - ">="
|
46
46
|
- !ruby/object:Gem::Version
|
47
|
-
version:
|
47
|
+
version: '0'
|
48
48
|
type: :development
|
49
49
|
prerelease: false
|
50
50
|
version_requirements: !ruby/object:Gem::Requirement
|
51
51
|
requirements:
|
52
|
-
- -
|
52
|
+
- - ">="
|
53
53
|
- !ruby/object:Gem::Version
|
54
|
-
version:
|
54
|
+
version: '0'
|
55
55
|
- !ruby/object:Gem::Dependency
|
56
56
|
name: rspec
|
57
57
|
requirement: !ruby/object:Gem::Requirement
|
58
58
|
requirements:
|
59
|
-
- -
|
59
|
+
- - ">="
|
60
60
|
- !ruby/object:Gem::Version
|
61
|
-
version:
|
61
|
+
version: '0'
|
62
62
|
type: :development
|
63
63
|
prerelease: false
|
64
64
|
version_requirements: !ruby/object:Gem::Requirement
|
65
65
|
requirements:
|
66
|
-
- -
|
66
|
+
- - ">="
|
67
67
|
- !ruby/object:Gem::Version
|
68
|
-
version:
|
68
|
+
version: '0'
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: diff-lcs
|
71
71
|
requirement: !ruby/object:Gem::Requirement
|
@@ -142,7 +142,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
142
142
|
- !ruby/object:Gem::Version
|
143
143
|
version: '0'
|
144
144
|
requirements: []
|
145
|
-
rubygems_version: 3.
|
145
|
+
rubygems_version: 3.3.26
|
146
146
|
signing_key:
|
147
147
|
specification_version: 4
|
148
148
|
summary: Rendered Markdown differ.
|