(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)
PharData::convertToData — Converte um arquivo phar em um arquivo tar ou zip não executável
$format
= null
, ?int $compression
= null
, ?string $extension
= null
): ?PharDataEste método é usado para converter um arquivo tar ou zip não executável para outro formato não executável.
Se nenhuma alteração for especificada, este método lança uma BadMethodCallException. Este método deve ser usado para converter um arquivo tar para o formato zip ou vice-versa. Embora seja possível simplesmente alterar a compactação de um arquivo tar usando este método, é melhor usar o método PharData::compress() para consistência lógica.
Se bem-sucedido, o método cria um novo arquivo no disco e retorna um objeto PharData. O arquivo antigo não é removido do disco e deve ser removido manualmente após a conclusão do processo.
format
Deve ser um dos seguintes: Phar::TAR
ou Phar::ZIP
. Se definido como null
, o formato de arquivo existente
será preservado.
compression
Deve ser um dos seguintes: Phar::NONE
para nenhuma compactação de arquivo inteiro,
Phar::GZ
para compactação baseada em zlib e
Phar::BZ2
para compactação baseada em bzip.
extension
Este parâmetro é usado para substituir a extensão de arquivo padrão para um
arquivo convertido. Observe que .phar
não pode ser usado
em nenhum lugar no nome do arquivo para um arquivo tar ou zip não executável.
Ao converter para um arquivo phar baseado em tar, as
extensões padrão são .tar
, .tar.gz
,
e .tar.bz2
, dependendo da compactação especificada.
Para arquivos baseados em zip, a
extensão padrão é .zip
.
Este método lança uma BadMethodCallException quando não é possível compactar, ou se um método de compactação desconhecido foi especificado, ou se o arquivo solicitado está armazenando em buffer com Phar::startBuffering() e não foi concluído com Phar::stopBuffering(), e uma PharException se algum problema for encontrado durante o processo de criação do phar.
Versão | Descrição |
---|---|
8.0.0 |
format , compression e extension agora são anuláveis.
|
Exemplo #1 Um exemplo de PharData::convertToData()
Usando PharData::convertToData():
<?php
try {
$tarphar = new PharData('meuphar.tar');
// Observe que meuphar.tar *não* é excluído.
// Converte para o formato tar não executável.
// Cria meuphar.zip
$zip = $tarphar->convertToData(Phar::ZIP);
// Cria meuphar.tbz
$tgz = $zip->convertToData(Phar::TAR, Phar::BZ2, '.tbz');
// Cria meuphar.phar.tgz
$phar = $tarphar->convertToData(Phar::PHAR); // lança exceção
} catch (Exception $e) {
// lida com erros
}
?>