(PHP >= 5.3.0, PECL phar >= 2.0.0)
PharData::copy — Copie un fichier un fichier interne à l'archive phar vers un autre fichier au sein de la même archive
$oldfile
, string $newfile
)Copie un fichier interne à l'archive tar/zip vers un autre fichier au sein de la même archive. C'est une alternative orientée objet à l'utilisation de copy() avec le gestionnaire de flux phar.
oldfile
newfile
retourne TRUE
en cas de succès, mais il est plus sûr d'encadrer l'appel à la méthode dans un bloc
try/catch est de considérer son succès si aucune exception n'est levée.
lève une exception UnexpectedValueException si le fichier source n'existe pas, si le fichier de destination existe déjà, si le support en écriture est désactivé, si l'ouverture d'un des deux fichiers échoue ou si la lecture du fichier source échoue; ou lève une exception PharException si l'écriture des changements de l'archive phar échoue.
Exemple #1 Un exemple avec PharData::copy()
Cet exemple montre l'utilisation de PharData::copy() et de son équivalent en terme de gestionnaire de flux. La différence principale entre les deux façons de faire concerne la gestion des erreurs. Toutes les méthodes PharData soulèvent des exceptions, alors que le gestionnaire de flux utilise trigger_error().
<?php
try {
$phar = new PharData('monphar.tar');
$phar['a'] = 'salut';
$phar->copy('a', 'b');
echo $phar['b']; // affiche "phar://myphar.tar/b"
} catch (Exception $e) {
// on traite les erreurs
}
// l'équivalent en terme de flux de l'exemple ci-dessus.
// des E_WARNINGS sont lancés en cas d'erreur à la place d'exceptions.
copy('phar://monphar.tar/a', 'phar//monphar.tar/c');
echo file_get_contents('phar://monphar.tar/c'); // affiche "salut"
?>