(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)
Phar::decompress — Décompresse l'archive tar complète
Note:
Cette méthode nécessite que la variable de configuration INI
phar.readonly
soit définie à0
pour fonctionner avec les objets Phar. Sinon, une exception PharException sera lançée.
Pour les archives phar basées sur tar et sur phar, cette méthode décompresse l'archive complète.
Pour les archives phar bases sur Zip, cette méthode échoue et lève une exception. L'extension zlib doit être active pour décompresser une archive compressée grâce à gzip, et l'extension bzip2 doit être active pour décompresser une archive compressée grâce à bzip2. Comme avec toutes les fonctionnalités qui modifient le coutenu d'un phar, la variable INI phar.readonly doit être à off pour fonctionner.
De plus, cette méthode change automatiquement l'extension de l'archive,
.phar
Par défaut pour les archives phar, ou .phar.tar
pour les archives phar basées sur tar.
Sinon, une extension de fichier peut aussi être spécifiée en utilisant le second
paramètre.
extension
Pour décompresser, les extension de fichier par défaut
sont .phar
et .phar.tar
.
Utilisez ce paramètre pour spécifier une autre extension de fichier.
A noter que toutes les archives phar exécutables doivent contenir .phar
dans leur nom de fichier.
Un objet Phar est retourné en cas de succès,
ou null
en cas d'échec.
Lève une exception BadMethodCallException si la variable INI phar.readonly est à on, si l'extension zlib n'est pas disponible, ou si l'extension bzip2 n'est pas activée.
Version | Description |
---|---|
8.0.0 |
extension est désormais nullable.
|
Exemple #1 Un exemple avec Phar::decompress()
<?php
$p = new Phar('/chemin/vers/mon.phar', 0, 'mon.phar.gz');
$p['monfichier.txt'] = 'salut';
$p['monfichier.txt'] = 'salut';
$p3 = $p2->decompress(); // crée /chemin/vers/mon.phar
?>