Sha256: bef05da6aeb96c7ef419c2846907e938885f529d0956af5d1e37042185b16621

Contents?: true

Size: 1.15 KB

Versions: 6

Compression:

Stored size: 1.15 KB

Contents

require_relative 'exif_parser'

class FormatParser::CR2Parser
  include FormatParser::IOUtils
  include FormatParser::EXIFParser

  TIFF_HEADER = [0x49, 0x49, 0x2a, 0x00]
  CR2_HEADER  = [0x43, 0x52, 0x02, 0x00]

  def call(io)
    io = FormatParser::IOConstraint.new(io)

    tiff_header = safe_read(io, 8)

    # Check whether it's a CR2 file
    tiff_bytes = tiff_header[0..3].bytes
    magic_bytes = safe_read(io, 4).unpack('C4')

    return if !magic_bytes.eql?(CR2_HEADER) || !tiff_bytes.eql?(TIFF_HEADER)

    # The TIFF scanner in EXIFR is plenty good enough,
    # so why don't we use it? It does all the right skips
    # in all the right places.
    exif_data = exif_from_tiff_io(io)
    return unless exif_data

    w = exif_data.image_width
    h = exif_data.image_length

    FormatParser::Image.new(
      format: :cr2,
      width_px: w,
      height_px: h,
      display_width_px: exif_data.rotated? ? h : w,
      display_height_px: exif_data.rotated? ? w : h,
      orientation: exif_data.orientation,
      intrinsics: {exif: exif_data},
    )
  rescue EXIFR::MalformedTIFF
    nil
  end

  FormatParser.register_parser self, natures: :image, formats: :cr2
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
format_parser-0.15.1 lib/parsers/cr2_parser.rb
format_parser-0.15.0 lib/parsers/cr2_parser.rb
format_parser-0.14.1 lib/parsers/cr2_parser.rb
format_parser-0.14.0 lib/parsers/cr2_parser.rb
format_parser-0.13.6 lib/parsers/cr2_parser.rb
format_parser-0.13.5 lib/parsers/cr2_parser.rb