Class: BinData::IO::Write

Inherits:
Object
  • Object
show all
Includes:
Common
Defined in:
lib/bindata/io.rb

Overview

Create a new IO Write wrapper around io. io must provide #write. If io is a string it will be automatically wrapped in an StringIO object.

The IO can handle bitstreams in either big or little endian format.

See IO::Read for more information.

Instance Method Summary collapse

Constructor Details

#initialize(io) ⇒ Write

Returns a new instance of Write.



370
371
372
373
374
375
376
# File 'lib/bindata/io.rb', line 370

def initialize(io)
  super(io)

  @wnbits  = 0
  @wval    = 0
  @wendian = nil
end

Instance Method Details

#flushbitsObject Also known as: flush

To be called after all writebits have been applied.



426
427
428
429
430
431
432
# File 'lib/bindata/io.rb', line 426

def flushbits
  raise "Internal state error nbits = #{@wnbits}" if @wnbits >= 8

  if @wnbits > 0
    writebits(0, 8 - @wnbits, @wendian)
  end
end

#offsetObject

Returns the current offset of the io stream. Offset will be rounded up when writing bitfields.



391
392
393
# File 'lib/bindata/io.rb', line 391

def offset
  offset_raw + (@wnbits > 0 ? 1 : 0)
end

#seekbytes(n) ⇒ Object

Seek n bytes from the current position in the io stream.



396
397
398
399
# File 'lib/bindata/io.rb', line 396

def seekbytes(n)
  flushbits
  seek(n)
end

#with_buffer(n) ⇒ Object

Sets a buffer of n bytes on the io stream. Any writes inside the block will be contained within this buffer. If less than n bytes are written inside the block, the remainder will be padded with ‘0’ bytes.



382
383
384
385
386
387
# File 'lib/bindata/io.rb', line 382

def with_buffer(n)
  with_buffer_common(n) do |_buf_start, buf_end|
    yield
    write("\0" * (buf_end - offset))
  end
end

#writebits(val, nbits, endian) ⇒ Object

Writes nbits bits from val to the stream. endian specifies whether the bits are to be stored in :big or :little endian format.



409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
# File 'lib/bindata/io.rb', line 409

def writebits(val, nbits, endian)
  if @wendian != endian
    # don't mix bits of differing endian
    flushbits
    @wendian = endian
  end

  clamped_val = val & mask(nbits)

  if endian == :big
    write_big_endian_bits(clamped_val, nbits)
  else
    write_little_endian_bits(clamped_val, nbits)
  end
end

#writebytes(str) ⇒ Object

Writes the given string of bytes to the io stream.



402
403
404
405
# File 'lib/bindata/io.rb', line 402

def writebytes(str)
  flushbits
  write(str)
end