nelexa / buffer
Reading And Writing Binary Data (incl. primitive types, ex. byte, ubyte, short, ushort, int, uint, long, float, double). The classes also help with porting the I/O operations of the JAVA code.
Installs: 498 371
Dependents: 3
Suggesters: 0
Security: 0
Stars: 34
Watchers: 3
Forks: 5
Open Issues: 3
Requires
- php: >=5.4
Requires (Dev)
- phpunit/phpunit: ^4.8
This package is auto-updated.
Last update: 2024-10-26 06:11:40 UTC
README
This is classes defines methods for reading and writing values of all primitive types. Primitive values are translated to (or from) sequences of bytes according to the buffer's current byte order, which may be retrieved and modified via the order methods. The initial order of a byte buffer is always Buffer::BIG_ENDIAN.
Requirements
- PHP >= 5.4 (64 bit)
Installation
composer require nelexa/buffer
Documentation
Class \Nelexa\Buffer
is abstract and base methods for all other buffers.
Initialize buffer as string.
$buffer = new \Nelexa\StringBuffer(); // or $buffer = new \Nelexa\StringBuffer($text);
Initialize buffer as file.
$buffer = new \Nelexa\FileBuffer($filename);
Initialize buffer as memory resource (php://memory).
$buffer = new \Nelexa\MemoryReourceBuffer(); // or $buffer = new \Nelexa\MemoryReourceBuffer($text);
Initialize buffer as stream resource.
$fp = fopen('php://temp', 'w+b'); // or $buffer = new \Nelexa\ResourceBuffer($fp);
Set read only buffer
$buffer->setReadOnly(true);
Checking the possibility of recording in the buffer
$boolValue = $buffer->isReadOnly();
Modifies this buffer's byte order, either Buffer::BIG_ENDIAN
or Buffer::LITTLE_ENDIAN
$buffer->setOrder(\Nelexa\Buffer::LITTLE_ENDIAN);
Get buffer's byte order
$byteOrder = $buffer->order();
Get buffer size.
$size = $buffer->size();
Set buffer position.
$buffer->setPosition($position);
Get buffer position.
$position = $buffer->position();
Skip bytes.
$buffer->skip($count); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); $buffer->skip(-7); assert($buffer->position() === 3); $buffer->skip(2); assert($buffer->position() === 5);
Skip primitive type size.
$buffer->skipByte(); // skip 1 byte $buffer->skipShort(); // skip 2 bytes $buffer->skipInt(); // skip 4 bytes $buffer->skipLong(); // skip 8 bytes $buffer->skipFloat(); // skip 4 bytes $buffer->skipDouble(); // skip 8 bytes
Rewinds this buffer. The position is set to zero.
$buffer->rewind(); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); $buffer->rewind(); assert($buffer->position() === 0); assert($buffer->size() === 10);
Flips this buffer. The limit is set to the current position and then the position is set to zero.
$buffer->flip(); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); $buffer->setPosition(5); $buffer->flip(); assert($buffer->position() === 0); assert($buffer->size() === 5);
Returns the number of elements between the current position and the limit.
$remaining = $buffer->remaining(); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); $buffer->setPosition(7); assert($buffer->remaining() === 10 - 7);
Tells whether there are any elements between the current position and the limit. True if, and only if, there is at least one element remaining in this buffer
$boolValue = $buffer->hasRemaining(); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); assert($buffer->hasRemaining() === false); $buffer->setPosition(9); assert($buffer->hasRemaining() === true);
Close buffer and release resources
$buffer->close();
Read buffer
Read the entire contents of the buffer into a string without changing the position of the buffer.
$allBufferContent = $buffer->toString(); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); $buffer->setPosition(4); $allBufferContent = $buffer->toString(); assert($buffer->position() === 4); assert($allBufferContent === 'Test value');
Reads the string at this buffer's current position, and then increments the position.
$content = $buffer->get($length); // example $buffer->insertString('Test value'); assert($buffer->position() === 10); $buffer->setPosition(3); $content = $buffer->get(5); assert($buffer->position() === 8); assert($content === 't val');
Read literal types
Write to buffer
Insert bytes to buffer
Insert string (byte[]) or Buffer to buffer.
$buffer->insert('content'); // or $buffer->insert(new StringBuffer('Other buffer')); // example assert($buffer->position() === 0); assert($buffer->size() === 0); $buffer->insert('Test value'); assert($buffer->position() === 10); assert($buffer->size() === 10); $buffer->setPosition(4); $buffer->insert('ed'); assert($buffer->position() === 6); assert($buffer->size() === 12); assert($buffer->toString() === 'Tested value');
Insert primitive types
Insert boolean value false
or true
. Change size and position by +1.
$buffer->insertBoolean($boolValue);
Insert byte (-128 >= byte <= 127). Change size and position by +1.
$buffer->insertByte($byteValue);
Insert short value (-32768 >= short <= 32767). Change size and position by +2.
$buffer->insertShort($shortValue);
Insert integer value (-2147483648 >= int <= 2147483647). Change size and position by +4.
$buffer->insertInt($intValue);
Insert long value (-9223372036854775808 >= long <= 9223372036854775807). Change position +8.
$buffer->insertLong($longValue);
Insert float value (single-precision 32-bit IEEE 754 floating point number). Change position +4.
$buffer->insertFloat($floatValue);
Insert double value (double-precision 64-bit IEEE 754 floating point number). Change position +8.
$buffer->insertDouble($doubleValue);
Insert array bytes. Change size and position by +(size array).
$buffer->insertArrayBytes($bytes);
Insert string value. Change size and position by +(length string).
$buffer->insertString($string);
Insert UTF-8 string with encoding first two bytes as length string. Change size and position by +(2 + length string).
Analog java java.io.DataOutputStream#writeUTF(String str)
$buffer->insertUTF($string);
Insert string with UTF-16 encoding. Change size and position by +(2 * length string).
$buffer->insertUTF16($string);
Put bytes to buffer
Put string (byte[]) or Buffer to buffer and overwrite old value.
$buffer->put('content'); // or $buffer->put(new StringBuffer('Other buffer')); // example assert($buffer->position() === 0); assert($buffer->size() === 0); $buffer->insert('Test value'); assert($buffer->position() === 10); assert($buffer->size() === 10); $buffer->setPosition(4); $buffer->put('ed'); assert($buffer->position() === 6); assert($buffer->size() === 10); assert($buffer->toString() === 'Testedalue');
Put primitive types
Put boolean value false
or true
. Change position by +1.
$buffer->putBoolean($boolValue);
Put byte (-128 >= byte <= 127). Change position by +1.
$buffer->putByte($byteValue);
Put short value (-32768 >= short <= 32767). Change position by +2.
$buffer->putShort($shortValue);
Put integer value (-2147483648 >= int <= 2147483647). Change position by +4.
$buffer->putInt($intValue);
Put long value (-9223372036854775808 >= long <= 9223372036854775807). Change position by +8.
$buffer->putLong($longValue);
Put float value (single-precision 32-bit IEEE 754 floating point number). Change position +4.
$buffer->putFloat($floatValue);
Put double value (double-precision 64-bit IEEE 754 floating point number). Change position +8.
$buffer->putDouble($doubleValue);
Put array bytes. Change position by +(size array).
$buffer->putArrayBytes($bytes);
Insert string value. Change position by +(length string).
$buffer->putString($string);
Put UTF-8 string with encoding first two bytes as length string. Change position by +(2 + length string).
Analog java java.io.DataOutputStream#writeUTF(String str)
$buffer->puttUTF($string);
Put string with UTF-16 encoding. Change position by +(2 * length string).
$buffer->putUTF16($string);
Replace bytes by buffer
Replace following a certain number of bytes by string or another Buffer.
$buffer->replace('content', $length); // or $buffer->insert(new StringBuffer('Other buffer'), $length); // example assert($buffer->position() === 0); assert($buffer->size() === 0); $buffer->insert('Test value'); assert($buffer->position() === 10); assert($buffer->size() === 10); $buffer->setPosition(4); $buffer->replace('ed', 4); // remove 4 next bytes and insert 2 bytes assert($buffer->position() === 6); assert($buffer->size() === 8); assert($buffer->toString() === 'Testedlue');
Replace by primitive types
Replace by boolean value false
or true
. Change size by (-$length + 1) and position +1.
$buffer->replaceBoolean($boolValue, $length);
Replace by byte (-128 >= byte <= 127). Change size by (-$length + 1) and position +1.
$buffer->replaceByte($byteValue, $length);
Replace by short value (-32768 >= short <= 32767). Change size by (-$length + 2) and position +2.
$buffer->replaceShort($shortValue, $length);
Replace by integer value (-2147483648 >= int <= 2147483647). Change size by (-$length + 4) and position +4.
$buffer->replaceInt($intValue, $length);
Replace by long value (-9223372036854775808 >= long <= 9223372036854775807). Change size by (-$length + 8) and position +8.
$buffer->replaceLong($longValue, $length);
Replace by float value (single-precision 32-bit IEEE 754 floating point number). Change size by (-$length + 4) and position +4.
$buffer->replaceFloat($floatValue, $length);
Replace by double value (double-precision 64-bit IEEE 754 floating point number). Change size by (-$length + 8) and position +8.
$buffer->replaceDouble($doubleValue, $length);
Replace by array bytes. Change size by (-$length + size array) and position +(size array).
$buffer->replaceArrayBytes($bytes, $length);
Replace by string value. Change size by (-$length + length string) and position +(length string).
$buffer->replaceString($string, $length);
Replace by UTF-8 string with encoding first two bytes as length string. Change size by (-$length + 2 + length string) and position +(2 + length string).
Analog java java.io.DataOutputStream#writeUTF(String str)
$buffer->replaceUTF($string, $length);
Replace by string with UTF-16 encoding. Change size by (-$length + 2 * length string) and position +(2 * length string).
$buffer->replaceUTF16($string, $length);
Remove bytes by buffer
Remove a certain number of bytes. Change size by -$length.
$buffer->remove($length); // example assert($buffer->position() === 0); assert($buffer->size() === 0); $buffer->insert('Test value'); assert($buffer->position() === 10); assert($buffer->size() === 10); $buffer->setPosition(4); $buffer->remove(3); // remove 3 next bytes assert($buffer->position() === 4); assert($buffer->size() === 7); assert($buffer->toString() === 'Testlue');
Remove all bytes. Truncate buffer.
$buffer->truncate($size = 0); // example assert($buffer->position() === 0); assert($buffer->size() === 0); $buffer->insert('Test value'); assert($buffer->position() === 10); assert($buffer->size() === 10); $buffer->truncate(0); assert($buffer->position() === 0); assert($buffer->size() === 0);
Fluent interface
// example ($buffer = new StringBuffer()) ->insertByte(1) ->insertBoolean(true) ->insertShort(5551) ->skip(-2) ->insertUTF("Hello, World") ->truncate() ->insertString(str_rot13('Hello World')) ->setPosition(7) ->flip(); assert($this->buffer->size() === 7); assert($this->buffer->position() === 0); assert($this->buffer->toString() === str_rot13('Hello W'));