97 lines
2.3 KiB
PHP
97 lines
2.3 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Safe;
|
||
|
|
||
|
use Safe\Exceptions\Bzip2Exception;
|
||
|
|
||
|
/**
|
||
|
* Closes the given bzip2 file pointer.
|
||
|
*
|
||
|
* @param resource $bz The file pointer. It must be valid and must point to a file
|
||
|
* successfully opened by bzopen.
|
||
|
* @throws Bzip2Exception
|
||
|
*
|
||
|
*/
|
||
|
function bzclose($bz): void
|
||
|
{
|
||
|
error_clear_last();
|
||
|
$result = \bzclose($bz);
|
||
|
if ($result === false) {
|
||
|
throw Bzip2Exception::createFromPhpError();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Forces a write of all buffered bzip2 data for the file pointer
|
||
|
* bz.
|
||
|
*
|
||
|
* @param resource $bz The file pointer. It must be valid and must point to a file
|
||
|
* successfully opened by bzopen.
|
||
|
* @throws Bzip2Exception
|
||
|
*
|
||
|
*/
|
||
|
function bzflush($bz): void
|
||
|
{
|
||
|
error_clear_last();
|
||
|
$result = \bzflush($bz);
|
||
|
if ($result === false) {
|
||
|
throw Bzip2Exception::createFromPhpError();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* bzread reads from the given bzip2 file pointer.
|
||
|
*
|
||
|
* Reading stops when length (uncompressed) bytes have
|
||
|
* been read or EOF is reached, whichever comes first.
|
||
|
*
|
||
|
* @param resource $bz The file pointer. It must be valid and must point to a file
|
||
|
* successfully opened by bzopen.
|
||
|
* @param int $length If not specified, bzread will read 1024
|
||
|
* (uncompressed) bytes at a time. A maximum of 8192
|
||
|
* uncompressed bytes will be read at a time.
|
||
|
* @return string Returns the uncompressed data.
|
||
|
* @throws Bzip2Exception
|
||
|
*
|
||
|
*/
|
||
|
function bzread($bz, int $length = 1024): string
|
||
|
{
|
||
|
error_clear_last();
|
||
|
$result = \bzread($bz, $length);
|
||
|
if ($result === false) {
|
||
|
throw Bzip2Exception::createFromPhpError();
|
||
|
}
|
||
|
return $result;
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* bzwrite writes a string into the given bzip2 file
|
||
|
* stream.
|
||
|
*
|
||
|
* @param resource $bz The file pointer. It must be valid and must point to a file
|
||
|
* successfully opened by bzopen.
|
||
|
* @param string $data The written data.
|
||
|
* @param int $length If supplied, writing will stop after length
|
||
|
* (uncompressed) bytes have been written or the end of
|
||
|
* data is reached, whichever comes first.
|
||
|
* @return int Returns the number of bytes written.
|
||
|
* @throws Bzip2Exception
|
||
|
*
|
||
|
*/
|
||
|
function bzwrite($bz, string $data, int $length = null): int
|
||
|
{
|
||
|
error_clear_last();
|
||
|
if ($length !== null) {
|
||
|
$result = \bzwrite($bz, $data, $length);
|
||
|
} else {
|
||
|
$result = \bzwrite($bz, $data);
|
||
|
}
|
||
|
if ($result === false) {
|
||
|
throw Bzip2Exception::createFromPhpError();
|
||
|
}
|
||
|
return $result;
|
||
|
}
|