(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL phar >= 2.0.0)
Phar::buildFromDirectory — Construit une archive phar à partir des fichiers d'un répertoire
Description
public
Phar::buildFromDirectory(string
$directory
, string
$pattern
= ""): array
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.
Remplit une archive phar à partir du contenu d'un répertoire. Le second paramètre,
optionnel, est une expression rationnelle (pcre) utilisée pour exclure des fichiers.
Tout fichier dont le nom satisfait l'expression rationnelle sera inclus, les autres seront exclus.
Pour un contrôle plus fin, utilisez phar::buildFromIterator().
Liste de paramètres
-
directory
-
Le chemin absolu ou relatif vers le répertoire contenant tous les fichiers
à ajouter à l'archive.
-
pattern
-
Une expression rationnelle optionnelle utilisée pour filtrer la liste
des fichiers. Seuls les fichiers dont le nom satisfait l'expression rationnelle
seront inclus dans l'archive.
Valeurs de retour
phar::buildFromDirectory() retourne un tableau associatif
faisant correspondre le chemin interne du fichier avec le chemin complet sur le système
de fichiers.
Erreurs / Exceptions
Cette méthode lève une exception BadMethodCallException quand elle est
incapable d'instancier l'itérateur de répertoire interne,
ou une exception PharException s'il y a eu des erreurs lors
de la sauvegarde de l'archive.
Historique
Exemples
Exemple #1 Un exemple avecphar::buildFromDirectory()
<?php
// crée avec l'alias "projet.phar"
$phar = new Phar('projet.phar', 0, 'projet.phar');
// ajoute des fichiers dans le projet
$phar->buildFromDirectory(dirname(__FILE__) . '/projet');
$phar->setStub($phar->createDefaultWebStub('cli/index.php', 'www/index.php'));
$phar2 = new Phar('projet2.phar', 0, 'projet2.phar');
// ajoute tous les fichiers dans le projet, mais juste les fichiers .php
$phar->buildFromDirectory(dirname(__FILE__) . '/projet', '/\.php$/');
$phar->setStub($phar->createDefaultStub('cli/index.php', 'www/index.php'));
?>
Voir aussi