import { AbstractItem, AbstractItemRef, computeItemParams, changeItemRefOffset, GC, splitItem, addToDeleteSet, mergeItemWith, Y, StructStore, Transaction, ID, AbstractType // eslint-disable-line } from '../internals.js' import * as encoding from 'lib0/encoding.js' import * as decoding from 'lib0/decoding.js' /** * @private */ export const structDeletedRefNumber = 2 /** * @private */ export class ItemDeleted extends AbstractItem { /** * @param {ID} id * @param {AbstractItem | null} left * @param {ID | null} origin * @param {AbstractItem | null} right * @param {ID | null} rightOrigin * @param {AbstractType} parent * @param {string | null} parentSub * @param {number} length */ constructor (id, left, origin, right, rightOrigin, parent, parentSub, length) { super(id, left, origin, right, rightOrigin, parent, parentSub) this._len = length this.deleted = true } get length () { return this._len } /** * @param {ID} id * @param {AbstractItem | null} left * @param {ID | null} origin * @param {AbstractItem | null} right * @param {ID | null} rightOrigin * @param {AbstractType} parent * @param {string | null} parentSub */ copy (id, left, origin, right, rightOrigin, parent, parentSub) { return new ItemDeleted(id, left, origin, right, rightOrigin, parent, parentSub, this.length) } /** * @param {Transaction} transaction */ integrate (transaction) { super.integrate(transaction) addToDeleteSet(transaction.deleteSet, this.id, this.length) } /** * @param {Transaction} transaction * @param {number} diff */ splitAt (transaction, diff) { /** * @type {ItemDeleted} */ // @ts-ignore const right = splitItem(transaction, this, diff) right._len -= diff this._len = diff return right } /** * @param {ItemDeleted} right * @return {boolean} */ mergeWith (right) { if (mergeItemWith(this, right)) { this._len += right._len return true } return false } /** * @param {Transaction} transaction * @param {StructStore} store * @param {boolean} parentGCd * * @private */ gc (transaction, store, parentGCd) { if (parentGCd) { super.gc(transaction, store, parentGCd) } } /** * @param {encoding.Encoder} encoder * @param {number} offset */ write (encoder, offset) { super.write(encoder, offset, structDeletedRefNumber) encoding.writeVarUint(encoder, this.length - offset) } } /** * @private */ export class ItemDeletedRef extends AbstractItemRef { /** * @param {decoding.Decoder} decoder * @param {ID} id * @param {number} info */ constructor (decoder, id, info) { super(decoder, id, info) /** * @type {number} */ this.len = decoding.readVarUint(decoder) } get length () { return this.len } /** * @param {Transaction} transaction * @param {StructStore} store * @param {number} offset * @return {ItemDeleted|GC} */ toStruct (transaction, store, offset) { if (offset > 0) { changeItemRefOffset(this, offset) this.len = this.len - offset } const { left, right, parent, parentSub } = computeItemParams(transaction, store, this.left, this.right, this.parent, this.parentSub, this.parentYKey) return parent === null ? new GC(this.id, this.length) : new ItemDeleted( this.id, left, this.left, right, this.right, parent, parentSub, this.len ) } }