real_encoder.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980
  1. package sarama
  2. import "encoding/binary"
  3. type realEncoder struct {
  4. raw []byte
  5. off int
  6. stack []pushEncoder
  7. }
  8. // primitives
  9. func (re *realEncoder) putInt8(in int8) {
  10. re.raw[re.off] = byte(in)
  11. re.off += binary.Size(in)
  12. }
  13. func (re *realEncoder) putInt16(in int16) {
  14. binary.BigEndian.PutUint16(re.raw[re.off:], uint16(in))
  15. re.off += binary.Size(in)
  16. }
  17. func (re *realEncoder) putInt32(in int32) {
  18. binary.BigEndian.PutUint32(re.raw[re.off:], uint32(in))
  19. re.off += binary.Size(in)
  20. }
  21. func (re *realEncoder) putInt64(in int64) {
  22. binary.BigEndian.PutUint64(re.raw[re.off:], uint64(in))
  23. re.off += binary.Size(in)
  24. }
  25. func (re *realEncoder) putArrayLength(in int) error {
  26. re.putInt32(int32(in))
  27. return nil
  28. }
  29. // collection
  30. func (re *realEncoder) putBytes(in []byte) error {
  31. if in == nil {
  32. re.putInt32(-1)
  33. return nil
  34. }
  35. re.putInt32(int32(len(in)))
  36. copy(re.raw[re.off:], in)
  37. re.off += len(in)
  38. return nil
  39. }
  40. func (re *realEncoder) putString(in string) error {
  41. re.putInt16(int16(len(in)))
  42. copy(re.raw[re.off:], in)
  43. re.off += len(in)
  44. return nil
  45. }
  46. func (re *realEncoder) putInt32Array(in []int32) error {
  47. re.putArrayLength(len(in))
  48. for _, val := range in {
  49. re.putInt32(val)
  50. }
  51. return nil
  52. }
  53. // stacks
  54. func (re *realEncoder) push(in pushEncoder) {
  55. in.saveOffset(re.off)
  56. re.off += in.reserveLength()
  57. re.stack = append(re.stack, in)
  58. }
  59. func (re *realEncoder) pop() error {
  60. // this is go's ugly pop pattern (the inverse of append)
  61. in := re.stack[len(re.stack)-1]
  62. re.stack = re.stack[:len(re.stack)-1]
  63. return in.run(re.off, re.raw)
  64. }