Subversion Repositories Applications.papyrus

Compare Revisions

Ignore whitespace Rev 73 → Rev 74

/trunk/api/fichier/FIC_manipulation.fonct.php
19,7 → 19,7
// | License along with this library; if not, write to the Free Software |
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
// +------------------------------------------------------------------------------------------------------+
// CVS : $Id: FIC_manipulation.fonct.php,v 1.2 2004-10-18 10:12:22 jpm Exp $
// CVS : $Id: FIC_manipulation.fonct.php,v 1.3 2004-10-19 15:57:03 jpm Exp $
/**
* Bibliothèque de fonctions permettant de manipuler des fichier ou des dossiers.
*
31,7 → 31,7
//Autres auteurs :
*@author Aucun
*@copyright Tela-Botanica 2000-2004
*@version $Revision: 1.2 $ $Date: 2004-10-18 10:12:22 $
*@version $Revision: 1.3 $ $Date: 2004-10-19 15:57:03 $
// +------------------------------------------------------------------------------------------------------+
*/
 
51,9 → 51,9
* @version 1.0.0
* @param string le chemin du dossier à supprimer.
* @param string le caractère représentant le séparateur dans un chemin d'accès.
* @return bool retoure true en cas de succès, false dans le cas contraire.
* @return bool retoure TRUE en cas de succès, FALSE dans le cas contraire.
*/
function supprimerDossier($dossier_nom, $separateur)
function supprimerDossier($dossier_nom, $separateur = '/')
{
// Simple suppression d'un fichier
if (is_file($dossier_nom)) {
60,30 → 60,75
return unlink($dossier_nom);
}
// Analyse du dossier
$dossier = dir($dossier_nom);
while (false !== $entree = $dossier->read()) {
// Nous sautons les pointeurs
if ($entree == '.' || $entree == '..') {
continue;
if (is_dir($dossier_nom)) {
// Analyse du dossier
$dossier = dir($dossier_nom);
while (false !== $entree = $dossier->read()) {
// Nous sautons les pointeurs
if ($entree == '.' || $entree == '..') {
continue;
}
// Suppression du dossier ou appel récursif de la fonction
if (is_dir($dossier_nom.$separateur.$entree)) {
supprimerDossier($dossier_nom.$separateur.$entree, $separateur);
} else {
unlink($dossier_nom.$separateur.$entree);
}
}
// Suppression du dossier ou appel récursif de la fonction
if (is_dir($dossier_nom.$separateur.$entree)) {
supprimerDossier($dossier_nom.$separateur.$entree);
} else {
unlink($dossier_nom.$separateur.$entree);
// Nettoyage
$dossier->close();
return rmdir($dossier_nom);
} else {
return false;
}
}
 
/**
* Fonction creerDossier() - Créer une structure de dossier.
*
* Fonction récursive créant une structure de dossiers.
* Auteur d'origine : Aidan Lister (http://aidan.dotgeek.org/lib/?file=function.mkdirr.php)
* Traduction française et ajout gestion séparateur : Jean-Pascal Milcent
*
* @author Aidan Lister <aidan@php.net>
* @version 1.0.0
* @param string la structure de dossier à créer.
* @param string le mode de création du répertoire.
* @param string le caractère représentant le séparateur dans un chemin d'accès.
* @return bool retourne TRUE en cas de succès, FALSE dans le cas contraire.
*/
 
function creerDossier($chemin, $mode = null, $separateur = '/')
{
// Check if directory already exists
if (is_dir($chemin) || empty($chemin)) {
return true;
}
// Ensure a file does not already exist with the same name
if (is_file($chemin)) {
trigger_error('mkdirr() File exists', E_USER_WARNING);
return false;
}
// Crawl up the directory tree
$chemin_suite = substr($chemin, 0, strrpos($chemin, $separateur));
if (creerDossier($chemin_suite, $mode, $separateur)) {
if (!file_exists($chemin)) {
return @mkdir($chemin, $mode);
}
}
// Nettoyage
$dossier->close();
return rmdir($dossier_nom);
return false;
}
 
/* +--Fin du code ----------------------------------------------------------------------------------------+
*
* $Log: not supported by cvs2svn $
* Revision 1.2 2004/10/18 10:12:22 jpm
* Traduction commentaires...
*
* Revision 1.1 2004/10/18 10:09:12 jpm
* Ajout d'une fonction permettant de supprimer récursivement un répertoire.
*