PharData::copy
Copie un fichier un fichier interne à l'archive phar vers un autre fichier au sein de la même archive
&reftitle.description;
public boolPharData::copy
stringfrom
stringto
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.
&reftitle.parameters;
from
to
&reftitle.returnvalues;
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.
&reftitle.errors;
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.
&reftitle.examples;
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.
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"
?>
]]>