Module refinery.units.blockwise.terminate
Expand source code Browse git
from __future__ import annotations
from refinery.lib.types import Param, buf
from refinery.units.blockwise import Arg, BlockTransformationBase
class terminate(BlockTransformationBase):
"""
Split the input data at a termination sequence (null byte by default) and return only the first
half.
The unit reads data from the incoming chunk in blocks of any given size until the sentinel value
is encountered. The output of the unit is all data that was read, excluding the sentinel. The
default block size is one and the default sentinel value is zero, which corresponds to reading a
null-terminated string from the input. If the sentinel value is not found anywhere in the
incoming data, the complete input is returned as output.
"""
def __init__(
self,
sentinel: Param[buf, Arg(help='sentinel value to look for; default is {default}')] = B'\0',
blocksize=1, bigendian=False
):
super().__init__(blocksize=blocksize, bigendian=bigendian, sentinel=sentinel)
def process(self, data: bytearray):
sentinel = self.args.sentinel
position = 0
blocksize = self.blocksize
self.log_info('blocksize:', blocksize)
self.log_debug('separator:', sentinel)
while position >= 0:
position = data.find(sentinel, position)
if position < 0:
self.log_info(F'The sentinel value {sentinel} was not found.')
break
q, r = divmod(position, blocksize)
if r:
position = (q + 1) * blocksize
continue
else:
data[position:] = []
break
return data
def reverse(self, data: bytearray):
sentinel = self.args.sentinel
position = 0
while True:
position = data.find(sentinel, position)
if position < 0:
data.extend(sentinel)
break
if position % self.blocksize == 0:
self.log_warn('input string already contains the termination character; returning unmodified input')
break
position += 1
return data
Classes
class terminate (sentinel=b'\x00', blocksize=1, bigendian=False)-
Split the input data at a termination sequence (null byte by default) and return only the first half.
The unit reads data from the incoming chunk in blocks of any given size until the sentinel value is encountered. The output of the unit is all data that was read, excluding the sentinel. The default block size is one and the default sentinel value is zero, which corresponds to reading a null-terminated string from the input. If the sentinel value is not found anywhere in the incoming data, the complete input is returned as output.
Expand source code Browse git
class terminate(BlockTransformationBase): """ Split the input data at a termination sequence (null byte by default) and return only the first half. The unit reads data from the incoming chunk in blocks of any given size until the sentinel value is encountered. The output of the unit is all data that was read, excluding the sentinel. The default block size is one and the default sentinel value is zero, which corresponds to reading a null-terminated string from the input. If the sentinel value is not found anywhere in the incoming data, the complete input is returned as output. """ def __init__( self, sentinel: Param[buf, Arg(help='sentinel value to look for; default is {default}')] = B'\0', blocksize=1, bigendian=False ): super().__init__(blocksize=blocksize, bigendian=bigendian, sentinel=sentinel) def process(self, data: bytearray): sentinel = self.args.sentinel position = 0 blocksize = self.blocksize self.log_info('blocksize:', blocksize) self.log_debug('separator:', sentinel) while position >= 0: position = data.find(sentinel, position) if position < 0: self.log_info(F'The sentinel value {sentinel} was not found.') break q, r = divmod(position, blocksize) if r: position = (q + 1) * blocksize continue else: data[position:] = [] break return data def reverse(self, data: bytearray): sentinel = self.args.sentinel position = 0 while True: position = data.find(sentinel, position) if position < 0: data.extend(sentinel) break if position % self.blocksize == 0: self.log_warn('input string already contains the termination character; returning unmodified input') break position += 1 return dataAncestors
Subclasses
Inherited members
BlockTransformationBase:FilterEverythingRequiresactassemblebytestreamchunkchunk_into_bytescodecconsolefilterfinishhandlesis_quietis_reversibleisattylabelledleniencylog_alwayslog_debuglog_detachlog_faillog_infolog_levellog_warnloggernamenozzleoptional_dependenciesprocessreadread1required_dependenciesresetrestreverserunsourcesuperinitunchunk