Files
yjs/structs/ItemString.js

62 lines
1.5 KiB
JavaScript
Raw Normal View History

/**
2018-11-25 03:17:00 +01:00
* @module structs
*/
2017-10-11 03:41:54 +02:00
2018-11-27 14:59:12 +01:00
import { Item, splitHelper } from './Item.js'
import { logItemHelper } from '../protocols/syncProtocol.js'
import * as encoding from '../lib/encoding.js'
import * as decoding from '../lib/decoding.js'
import { Y } from '../utils/Y.js' // eslint-disable-line
2018-11-25 03:17:00 +01:00
export class ItemString extends Item {
2017-10-11 03:41:54 +02:00
constructor () {
super()
this._content = null
}
2018-02-15 17:58:14 +01:00
_copy () {
let struct = super._copy()
2017-10-30 11:33:00 +01:00
struct._content = this._content
return struct
}
2017-10-11 03:41:54 +02:00
get _length () {
return this._content.length
}
/**
* @param {Y} y
* @param {decoding.Decoder} decoder
*/
2017-10-11 03:41:54 +02:00
_fromBinary (y, decoder) {
let missing = super._fromBinary(y, decoder)
this._content = decoding.readVarString(decoder)
2017-10-11 03:41:54 +02:00
return missing
}
/**
* @param {encoding.Encoder} encoder
*/
2017-10-16 04:53:12 +02:00
_toBinary (encoder) {
super._toBinary(encoder)
encoding.writeVarString(encoder, this._content)
2017-10-11 03:41:54 +02:00
}
2018-03-29 11:58:02 +02:00
/**
* Transform this YXml Type to a readable format.
* Useful for logging as all Items and Delete implement this method.
*
* @private
*/
2017-10-11 03:41:54 +02:00
_logString () {
2018-03-29 11:58:02 +02:00
return logItemHelper('ItemString', this, `content:"${this._content}"`)
2017-10-11 03:41:54 +02:00
}
2017-10-16 04:53:12 +02:00
_splitAt (y, diff) {
if (diff === 0) {
return this
} else if (diff >= this._length) {
return this._right
}
let item = new ItemString()
item._content = this._content.slice(diff)
this._content = this._content.slice(0, diff)
splitHelper(y, this, item, diff)
return item
}
2017-10-11 03:41:54 +02:00
}