(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)
PharData::convertToExecutable â Convertit une archive tar/zip non-exĂ©cutable en une archive phar exĂ©cutable
$format = null, ?int $compression = null, ?string $extension = null): ?PharNote: Cette méthode nécessite que la variable de configuration INI
phar.readonlysoit dĂ©finie Ă0pour fonctionner avec les objets Phar. Sinon, une exception PharException sera lançée.
Cette mĂ©thode est utilisĂ©e pour convertir une archive tar ou zip non-exĂ©cutable en une archive phar exĂ©cutable. N'importe lequel des trois formats de fichier (phar, tar ou zip) peut ĂȘtre utilisĂ© et la compression de l'archive complĂšte est aussi possible.
Si aucun changement n'est demandé, cette méthode soulÚve une exception BadMethodCallException.
En cas de succĂšs, cette mĂ©thode crĂ©e une nouvelle archive sur le disque et retourne un objet Phar. L'ancienne archive n'est pas effacĂ©e du disque, ceci devant ĂȘtre fait manuellement une fois le traitement terminĂ©.
format
Le format doit ĂȘtre Phar::PHAR, Phar::TAR
ou Phar::ZIP. S'il vaut null, le format de fichier actuel sera conservé.
compression
La compression doit ĂȘtre Phar::NONE pour Ă©viter la compression de l'archive
complÚte, Phar::GZ pour la compression basée sur zlib, et
Phar::BZ2 pour la compression basée sur bzip.
extension
Ce paramÚtre est utilisé pour écraser l'extension de fichier par défaut de l'archive convertie. Notez
que toutes les archives basées sur tar et sur zip doivent contenir
.phar dans leur extension de fichier pour pouvoir ĂȘtre traitĂ©es comme des archives
phar.
En cas de conversion vers une archive basée sur phar, les extensions par défaut sont
.phar, .phar.gz ou .phar.bz2
selon la compression spécifiée. Pour les archives phar basées sur tar, les extensions par défaut
sont .phar.tar, .phar.tar.gz
et .phar.tar.bz2. Pour les archives phar basées sur zip, l'extension par
défaut est .phar.zip.
Cette méthode soulÚve une exception BadMethodCallException quand elle est incapable de compresser, quand une méthode de compression inconnue a été spécifiée, quand l'archive demandée est mise en tampon avec Phar::startBuffering() et qu'elle n'a pas été conclue avec Phar::stopBuffering(), soulÚve une exception UnexpectedValueException si le support en écriture est désactivé, et soulÚve une exception PharException si des problÚmes ont été rencontrés lors de la création du phar.
| Version | Description |
|---|---|
| 8.0.0 |
format, compression,
et localName sont désormais nullable.
|
Exemple #1 Un exemple avec PharData::convertToExecutable()
Utilisons PharData::convertToExecutable() :
<?php
try {
$tarphar = new PharData('monphar.tar');
// le convertit au format de fichier phar
// notez que monphar.tar n'est *pas* effacé
$phar = $tarphar->convertToExecutable(Phar::PHAR); // crée monphar.phar
$phar->setStub($phar->createDefaultStub('cli.php', 'web/index.php'));
// crée monphar.phar.tgz
$compressed = $tarphar->convertToExecutable(Phar::TAR, Phar::GZ, '.phar.tgz');
} catch (Exception $e) {
// les erreurs sont traitées ici
}
?>