Module: BinData::FloatingPoint

Defined in:
lib/bindata/float.rb

Overview

Defines a number of classes that contain a floating point number. The float is defined by precision and endian.

Constant Summary collapse

PRECISION =
{
  single: 4,
  double: 8,
}
PACK_CODE =
{
  [:single, :little] => 'e',
  [:single, :big]    => 'g',
  [:double, :little] => 'E',
  [:double, :big]    => 'G'
}

Class Method Summary collapse

Class Method Details

.create_num_bytes_code(precision) ⇒ Object



44
45
46
# File 'lib/bindata/float.rb', line 44

def create_num_bytes_code(precision)
  PRECISION[precision]
end

.create_read_code(precision, endian) ⇒ Object



48
49
50
51
52
53
# File 'lib/bindata/float.rb', line 48

def create_read_code(precision, endian)
  nbytes = PRECISION[precision]
  unpack = PACK_CODE[[precision, endian]]

  "io.readbytes(#{nbytes}).unpack1('#{unpack}')"
end

.create_to_binary_s_code(precision, endian) ⇒ Object



55
56
57
58
59
# File 'lib/bindata/float.rb', line 55

def create_to_binary_s_code(precision, endian)
  pack = PACK_CODE[[precision, endian]]

  "[val].pack('#{pack}')"
end

.define_methods(float_class, precision, endian) ⇒ Object



21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# File 'lib/bindata/float.rb', line 21

def define_methods(float_class, precision, endian)
  float_class.module_eval "    def do_num_bytes\n      \#{create_num_bytes_code(precision)}\n    end\n\n    #---------------\n    private\n\n    def sensible_default\n      0.0\n    end\n\n    def value_to_binary_string(val)\n      \#{create_to_binary_s_code(precision, endian)}\n    end\n\n    def read_and_return_value(io)\n      \#{create_read_code(precision, endian)}\n    end\n  END\nend\n"