(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)
PharData::copy — Copie un fichier interne à l'archive phar vers un autre fichier au sein de la même archive
Description
public
PharData::copy(string
$from
, string
$to
): bool
Liste de paramètres
-
from
-
-
to
-
Valeurs de retour
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.
Erreurs / Exceptions
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.
Exemples
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"
?>