Class: Cassandra::Compression::Compressors::Snappy

Inherits:
Cassandra::Compression::Compressor show all
Defined in:
lib/cassandra/compression/compressors/snappy.rb

Overview

Note:

This compressor requires the snappy gem (v0.0.10 or later for JRuby support).

Note:

No need to instantiate this class manually, use compression: :snappy option when calling Cassandra.cluster and one will be created automatically for you.

A compressor that uses the Snappy compression library.

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(min_size = 64) ⇒ Snappy

Returns a new instance of Snappy.

Parameters:

  • min_size (Integer) (defaults to: 64)

    (64) Don't compress frames smaller than this size (see #compress?).



36
37
38
39
40
41
42
43
44
45
46
47
48
# File 'lib/cassandra/compression/compressors/snappy.rb', line 36

def initialize(min_size = 64)
  unless defined?(::Snappy)
    begin
      require 'snappy'
    rescue LoadError => e
      raise LoadError, %(Snappy support requires the "snappy" gem: #{e.message}),
            e.backtrace
    end
  end

  @algorithm = 'snappy'.freeze
  @min_size = min_size
end

Instance Attribute Details

#algorithmString (readonly)

Returns 'snappy'.

Returns:

  • (String)

    'snappy'



32
33
34
# File 'lib/cassandra/compression/compressors/snappy.rb', line 32

def algorithm
  @algorithm
end

Instance Method Details

#compress(str) ⇒ Object

See Also:

  • Cassandra::Compression::Compressor#compress


58
59
60
# File 'lib/cassandra/compression/compressors/snappy.rb', line 58

def compress(str)
  ::Snappy.deflate(str)
end

#compress?(str) ⇒ true, false

Returns will return false for frames smaller than the min_size given to the constructor.

Returns:

  • (true, false)

    will return false for frames smaller than the min_size given to the constructor.

See Also:

  • Cassandra::Compression::Compressor#compress?


53
54
55
# File 'lib/cassandra/compression/compressors/snappy.rb', line 53

def compress?(str)
  str.bytesize > @min_size
end

#decompress(str) ⇒ Object

See Also:

  • Cassandra::Compression::Compressor#decompress


63
64
65
# File 'lib/cassandra/compression/compressors/snappy.rb', line 63

def decompress(str)
  ::Snappy.inflate(str)
end