prep_encoder.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. package sarama
  2. import (
  3. "encoding/binary"
  4. "fmt"
  5. "math"
  6. "github.com/rcrowley/go-metrics"
  7. )
  8. type prepEncoder struct {
  9. length int
  10. }
  11. // primitives
  12. func (pe *prepEncoder) putInt8(in int8) {
  13. pe.length++
  14. }
  15. func (pe *prepEncoder) putInt16(in int16) {
  16. pe.length += 2
  17. }
  18. func (pe *prepEncoder) putInt32(in int32) {
  19. pe.length += 4
  20. }
  21. func (pe *prepEncoder) putInt64(in int64) {
  22. pe.length += 8
  23. }
  24. func (pe *prepEncoder) putVarint(in int64) {
  25. var buf [binary.MaxVarintLen64]byte
  26. pe.length += binary.PutVarint(buf[:], in)
  27. }
  28. func (pe *prepEncoder) putArrayLength(in int) error {
  29. if in > math.MaxInt32 {
  30. return PacketEncodingError{fmt.Sprintf("array too long (%d)", in)}
  31. }
  32. pe.length += 4
  33. return nil
  34. }
  35. // arrays
  36. func (pe *prepEncoder) putBytes(in []byte) error {
  37. pe.length += 4
  38. if in == nil {
  39. return nil
  40. }
  41. return pe.putRawBytes(in)
  42. }
  43. func (pe *prepEncoder) putVarintBytes(in []byte) error {
  44. if in == nil {
  45. pe.putVarint(-1)
  46. return nil
  47. }
  48. pe.putVarint(int64(len(in)))
  49. return pe.putRawBytes(in)
  50. }
  51. func (pe *prepEncoder) putRawBytes(in []byte) error {
  52. if len(in) > math.MaxInt32 {
  53. return PacketEncodingError{fmt.Sprintf("byteslice too long (%d)", len(in))}
  54. }
  55. pe.length += len(in)
  56. return nil
  57. }
  58. func (pe *prepEncoder) putString(in string) error {
  59. pe.length += 2
  60. if len(in) > math.MaxInt16 {
  61. return PacketEncodingError{fmt.Sprintf("string too long (%d)", len(in))}
  62. }
  63. pe.length += len(in)
  64. return nil
  65. }
  66. func (pe *prepEncoder) putStringArray(in []string) error {
  67. err := pe.putArrayLength(len(in))
  68. if err != nil {
  69. return err
  70. }
  71. for _, str := range in {
  72. if err := pe.putString(str); err != nil {
  73. return err
  74. }
  75. }
  76. return nil
  77. }
  78. func (pe *prepEncoder) putInt32Array(in []int32) error {
  79. err := pe.putArrayLength(len(in))
  80. if err != nil {
  81. return err
  82. }
  83. pe.length += 4 * len(in)
  84. return nil
  85. }
  86. func (pe *prepEncoder) putInt64Array(in []int64) error {
  87. err := pe.putArrayLength(len(in))
  88. if err != nil {
  89. return err
  90. }
  91. pe.length += 8 * len(in)
  92. return nil
  93. }
  94. func (pe *prepEncoder) offset() int {
  95. return pe.length
  96. }
  97. // stackable
  98. func (pe *prepEncoder) push(in pushEncoder) {
  99. pe.length += in.reserveLength()
  100. }
  101. func (pe *prepEncoder) pop() error {
  102. return nil
  103. }
  104. // we do not record metrics during the prep encoder pass
  105. func (pe *prepEncoder) metricRegistry() metrics.Registry {
  106. return nil
  107. }