PharData::compress
(PHP >= 5.3.0, PECL phar >= 2.0.0)
PharData::compress — Compresse l'archive tar/zip complète en utilisant la compression Gzip ou Bzip2
Description
$compression
[, string $extension
] )Pour les archives tar, cette méthode compresse l'archive entière en utilisant la compressions gzip ou bzip2. Le fichier qui en résulte peut être manipulé avec la commande gunzip/bunzip, ou être accédé directement et de façon transparente avec l'extension Phar.
Pour les archives zip, cette méthode échoue en levant une exception. L'extension zlib doit être activée pour compresser avec gzip, l'extension bzip2 doit être activée pour compresser avec bzip2.
De plus, cette méthode renomme automatiquement l'archive, en la suffixant par .gz, .bz2 ou en enlevant l'extension si Phar::NONE est spécifié pour enlever la compression. Sinon, une extension de fichier peut être spécifiée avec le second paramètre.
Liste de paramètres
-
compression
-
La compression doit être Phar::GZ ou Phar::BZ2 pour appliquer une compression, ou Phar::NONE pour l'enlever.
-
extension
-
Par défaut, l'extension est .tar.gz ou .tar.bz2 pour compresser un tar, et .tar pour décompresser.
Valeurs de retour
Un objet PharData est retourné.
Erreurs / Exceptions
Soulève une exception BadMethodCallException si l'extension zlib n'est pas disponible, ou si l'extension bzip2 n'est pas activée.
Exemples
Exemple #1 Un exemple avec PharData::compress()
<?php $p = new PharData('/chemin/vers/mon.tar'); $p['monfichier.txt'] = 'salut'; $p['monfichier2.txt'] = 'salut'; $p1 = $p->compress(Phar::GZ); // copie vers /chemin/vers/mon.phar.gz $p2 = $p->compress(Phar::BZ2); // copie vers /chemin/vers/mon.phar.bz2 $p3 = $p2->compress(Phar::NONE); // exception: /chemin/vers/mon.phar existe déjà ?>
Voir aussi
- Phar::compress() - Compresse l'archive Phar complète en utilisant la compression Gzip ou Bzip2