2020-12-07 21:13:36 +00:00
|
|
|
const DMP = require('diff-match-patch')
|
2020-12-07 20:29:24 +00:00
|
|
|
const dmp = new DMP()
|
2014-02-12 10:40:42 +00:00
|
|
|
|
2021-01-14 20:11:15 +00:00
|
|
|
// Do not attempt to produce a diff for more than 100ms
|
|
|
|
dmp.Diff_Timeout = 0.1
|
|
|
|
|
2020-12-07 20:27:41 +00:00
|
|
|
module.exports = {
|
2020-05-06 10:09:33 +00:00
|
|
|
ADDED: 1,
|
|
|
|
REMOVED: -1,
|
|
|
|
UNCHANGED: 0,
|
2014-02-12 10:40:42 +00:00
|
|
|
|
2020-05-06 10:09:33 +00:00
|
|
|
diffAsShareJsOp(before, after, callback) {
|
|
|
|
const diffs = dmp.diff_main(before.join('\n'), after.join('\n'))
|
|
|
|
dmp.diff_cleanupSemantic(diffs)
|
2014-02-12 10:40:42 +00:00
|
|
|
|
2020-05-06 10:09:33 +00:00
|
|
|
const ops = []
|
|
|
|
let position = 0
|
2020-12-07 20:25:20 +00:00
|
|
|
for (const diff of diffs) {
|
2020-05-06 10:09:33 +00:00
|
|
|
const type = diff[0]
|
|
|
|
const content = diff[1]
|
|
|
|
if (type === this.ADDED) {
|
|
|
|
ops.push({
|
|
|
|
i: content,
|
|
|
|
p: position
|
|
|
|
})
|
|
|
|
position += content.length
|
|
|
|
} else if (type === this.REMOVED) {
|
|
|
|
ops.push({
|
|
|
|
d: content,
|
|
|
|
p: position
|
|
|
|
})
|
|
|
|
} else if (type === this.UNCHANGED) {
|
|
|
|
position += content.length
|
|
|
|
} else {
|
2020-12-07 20:28:25 +00:00
|
|
|
throw new Error('Unknown type')
|
2020-05-06 10:09:33 +00:00
|
|
|
}
|
|
|
|
}
|
2020-12-07 20:25:52 +00:00
|
|
|
callback(null, ops)
|
2020-05-06 10:09:33 +00:00
|
|
|
}
|
|
|
|
}
|