Class: Kafka::SnappyCodec

Inherits:
Object
  • Object
show all
Defined in:
lib/kafka/snappy_codec.rb

Instance Method Summary collapse

Constructor Details

#initializeSnappyCodec

Returns a new instance of SnappyCodec.



3
4
5
6
7
8
# File 'lib/kafka/snappy_codec.rb', line 3

def initialize
  require "snappy"
rescue LoadError
  raise LoadError,
    "Using snappy compression requires adding a dependency on the `snappy` gem to your Gemfile."
end

Instance Method Details

#codec_idObject



10
11
12
# File 'lib/kafka/snappy_codec.rb', line 10

def codec_id
  2
end

#compress(data) ⇒ Object



14
15
16
# File 'lib/kafka/snappy_codec.rb', line 14

def compress(data)
  Snappy.deflate(data)
end

#decompress(data) ⇒ Object



18
19
20
21
# File 'lib/kafka/snappy_codec.rb', line 18

def decompress(data)
  buffer = StringIO.new(data)
  Snappy::Reader.new(buffer).read
end