overleaf/services/document-updater/app/js/DiffCodec.js

41 lines
925 B
JavaScript
Raw Normal View History

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
// 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 = {
ADDED: 1,
REMOVED: -1,
UNCHANGED: 0,
2014-02-12 10:40:42 +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
const ops = []
let position = 0
2020-12-07 20:25:20 +00:00
for (const diff of diffs) {
const type = diff[0]
const content = diff[1]
if (type === this.ADDED) {
ops.push({
i: content,
2021-07-13 11:04:42 +00:00
p: position,
})
position += content.length
} else if (type === this.REMOVED) {
ops.push({
d: content,
2021-07-13 11:04:42 +00:00
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-12-07 20:25:52 +00:00
callback(null, ops)
2021-07-13 11:04:42 +00:00
},
}