rle.go 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. package missinggo
  2. // A RunLengthEncoder counts successive duplicate elements and emits the
  3. // element and the run length when the element changes or the encoder is
  4. // flushed.
  5. type RunLengthEncoder interface {
  6. // Add a series of identical elements to the stream.
  7. Append(element interface{}, count uint64)
  8. // Emit the current element and its count if non-zero without waiting for
  9. // the element to change.
  10. Flush()
  11. }
  12. type runLengthEncoder struct {
  13. eachRun func(element interface{}, count uint64)
  14. element interface{}
  15. count uint64
  16. }
  17. // Creates a new RunLengthEncoder. eachRun is called when an element and its
  18. // count is emitted, per the RunLengthEncoder interface.
  19. func NewRunLengthEncoder(eachRun func(element interface{}, count uint64)) RunLengthEncoder {
  20. return &runLengthEncoder{
  21. eachRun: eachRun,
  22. }
  23. }
  24. func (me *runLengthEncoder) Append(element interface{}, count uint64) {
  25. if element == me.element {
  26. me.count += count
  27. return
  28. }
  29. if me.count != 0 {
  30. me.eachRun(me.element, me.count)
  31. }
  32. me.count = count
  33. me.element = element
  34. }
  35. func (me *runLengthEncoder) Flush() {
  36. if me.count == 0 {
  37. return
  38. }
  39. me.eachRun(me.element, me.count)
  40. me.count = 0
  41. }