lib/pdf/reader/filter/run_length.rb
# coding: utf-8 # class PDF::Reader module Filter # :nodoc: class RunLength def initialize(options = {}) @options = options end ################################################################################ # Decode the specified data with the RunLengthDecode compression algorithm def filter(data) pos = 0 out = "" while pos < data.length if data.respond_to?(:getbyte) length = data.getbyte(pos) else length = data[pos] end pos += 1 case when length == 128 break when length < 128 # When the length is < 128, we copy the following length+1 bytes # literally. out << data[pos, length + 1] pos += length else # When the length is > 128, we copy the next byte (257 - length) # times; i.e., "\xFA\x00" ([250, 0]) will expand to # "\x00\x00\x00\x00\x00\x00\x00". out << data[pos, 1] * (257 - length) end pos += 1 end Depredict.new(@options).filter(out) end end end end