diff --git a/htdocs/lib/functions.inc.php b/htdocs/lib/functions.inc.php index 29d943c5801..a1c3a90492d 100644 --- a/htdocs/lib/functions.inc.php +++ b/htdocs/lib/functions.inc.php @@ -38,7 +38,7 @@ Ensemble de fonctions de base de dolibarr sous forme d'include */ -// Pour compatibilité lors de l'upgrade +// Pour compatibilit� lors de l'upgrade if (! defined('DOL_DOCUMENT_ROOT')) { define('DOL_DOCUMENT_ROOT', '..'); @@ -114,7 +114,7 @@ function ValidEmail($address) } /** - \brief Renvoi vrai si l'email a un nom de domaine qui résoud via dns + \brief Renvoi vrai si l'email a un nom de domaine qui r�soud via dns \param mail adresse email (Ex: "toto@titi.com", "John Do ") \return boolean true si email valide, false sinon */ @@ -132,22 +132,22 @@ function check_mail ($mail) } /** - \brief Nettoie chaine de caractère des accents + \brief Nettoie chaine de caract�re des accents \param str Chaine a nettoyer - \return string Chaine nettoyé + \return string Chaine nettoy� */ function unaccent($str) { - $acc = array("à","ä","é","è","ë","ï","î","ö","ô","ù","ü","'"); + $acc = array("�","�","�","�","�","�","�","�","�","�","�","'"); $uac = array("a","a","e","e","e","i","i","o","o","u","u",""); return str_replace($acc, $uac, $str); } /** - \brief Nettoie chaine de caractère de caractères spéciaux + \brief Nettoie chaine de caract�re de caract�res sp�ciaux \param str Chaine a nettoyer - \return string Chaine nettoyé + \return string Chaine nettoy� */ function sanitize_string($str) { @@ -160,15 +160,15 @@ function sanitize_string($str) /** \brief Envoi des messages dolibarr dans un fichier ou dans syslog - Pour fichier: fichier défini par SYSLOG_FILE - Pour syslog: facility défini par SYSLOG_FACILITY + Pour fichier: fichier d�fini par SYSLOG_FILE + Pour syslog: facility d�fini par SYSLOG_FACILITY \param message Message a tracer. Ne doit pas etre traduit si level = LOG_ERR \param level Niveau de l'erreur - \remarks Cette fonction n'a un effet que si le module syslog est activé. - Warning, les fonctions syslog sont buggués sous Windows et générent des - fautes de protection mémoire. Pour résoudre, utiliser le loggage fichier, + \remarks Cette fonction n'a un effet que si le module syslog est activ�. + Warning, les fonctions syslog sont buggu�s sous Windows et g�n�rent des + fautes de protection m�moire. Pour r�soudre, utiliser le loggage fichier, au lieu du loggage syslog (configuration du module). - Si SYSLOG_FILE_NO_ERROR défini, on ne gére pas erreur ecriture log + Si SYSLOG_FILE_NO_ERROR d�fini, on ne g�re pas erreur ecriture log \remarks On Windows LOG_ERR=4, LOG_WARNING=5, LOG_NOTICE=LOG_INFO=LOG_DEBUG=6 On Linux LOG_ERR=3, LOG_WARNING=4, LOG_INFO=6, LOG_DEBUG=7 */ @@ -222,7 +222,7 @@ function dolibarr_syslog($message, $level=LOG_INFO) } else { - //define_syslog_variables(); déjà définit dans master.inc.php + //define_syslog_variables(); d�j� d�finit dans master.inc.php if (defined("MAIN_SYSLOG_FACILITY") && MAIN_SYSLOG_FACILITY) { $facility = MAIN_SYSLOG_FACILITY; @@ -304,9 +304,9 @@ function dolibarr_fiche_head($links, $active='0', $title='', $notab=0) } /** - \brief Récupère une constante depuis la base de données. + \brief R�cup�re une constante depuis la base de donn�es. \see dolibarr_del_const, dolibarr_set_const - \param db Handler d'accès base + \param db Handler d'acc�s base \param name Nom de la constante \return string Valeur de la constante */ @@ -328,13 +328,13 @@ function dolibarr_get_const($db, $name) /** - \brief Insertion d'une constante dans la base de données. + \brief Insertion d'une constante dans la base de donn�es. \see dolibarr_del_const, dolibarr_get_const - \param db Handler d'accès base + \param db Handler d'acc�s base \param name Nom de la constante \param value Valeur de la constante - \param type Type de constante (chaine par défaut) - \param visible La constante est elle visible (0 par défaut) + \param type Type de constante (chaine par d�faut) + \param visible La constante est elle visible (0 par d�faut) \param note Explication de la constante \return int <0 si ko, >0 si ok */ @@ -372,9 +372,9 @@ function dolibarr_set_const($db, $name, $value, $type='chaine', $visible=0, $not } /** - \brief Effacement d'une constante dans la base de données + \brief Effacement d'une constante dans la base de donn�es \see dolibarr_get_const, dolibarr_sel_const - \param db Handler d'accès base + \param db Handler d'acc�s base \param name Nom ou rowid de la constante \return int <0 si ko, >0 si ok */ @@ -399,11 +399,11 @@ function dolibarr_del_const($db, $name) /** \brief Sauvegarde parametrage personnel - \param db Handler d'accès base + \param db Handler d'acc�s base \param user Objet utilisateur - \param url Si defini, on sauve parametre du tableau tab dont clé = (url avec sortfield, sortorder, begin et page) + \param url Si defini, on sauve parametre du tableau tab dont cl� = (url avec sortfield, sortorder, begin et page) Si non defini on sauve tous parametres du tableau tab - \param tab Tableau (clé=>valeur) des paramètres à sauvegarder + \param tab Tableau (cl�=>valeur) des param�tres � sauvegarder \return int <0 si ko, >0 si ok */ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) @@ -413,7 +413,7 @@ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) $db->begin(); - // On efface anciens paramètres pour toutes les clé dans $tab + // On efface anciens param�tres pour toutes les cl� dans $tab $sql = "DELETE FROM ".MAIN_DB_PREFIX."user_param"; $sql.= " WHERE fk_user = ".$user->id; if ($url) $sql.=" AND page='".$url."'"; @@ -439,7 +439,7 @@ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) foreach ($tab as $key => $value) { - // On positionne nouveaux paramètres + // On positionne nouveaux param�tres if ($value && (! $url || in_array($key,array('sortfield','sortorder','begin','page')))) { $sql = "INSERT INTO ".MAIN_DB_PREFIX."user_param(fk_user,page,param,value)"; @@ -469,7 +469,7 @@ function dolibarr_set_user_page_param($db, &$user, $url='', $tab) /** \brief Formattage des nombres \param ca valeur a formater - \return int valeur formatée + \return int valeur format�e */ function dolibarr_print_ca($ca) { @@ -497,10 +497,10 @@ function dolibarr_print_ca($ca) /** - \brief Effectue un décalage de date par rapport à une durée + \brief Effectue un d�calage de date par rapport � une dur�e \param time Date timestamp ou au format YYYY-MM-DD - \param duration_value Valeur de la durée à ajouter - \param duration_unit Unité de la durée à ajouter (d, m, y) + \param duration_value Valeur de la dur�e � ajouter + \param duration_unit Unit� de la dur�e � ajouter (d, m, y) \return int Nouveau timestamp */ function dolibarr_time_plus_duree($time,$duration_value,$duration_unit) @@ -523,13 +523,13 @@ function dolibarr_time_plus_duree($time,$duration_value,$duration_unit) "%d/%m/%Y %H:%M", "%d/%m/%Y %H:%M:%S", "day", "daytext", "dayhour", "dayhourldap", "dayhourtext" - \return string Date formatée ou '' si time null + \return string Date format�e ou '' si time null */ function dolibarr_print_date($time,$format='') { global $conf; - // Si format non défini, on prend $conf->format_date_text_short sinon %Y-%m-%d %H:%M:%S + // Si format non d�fini, on prend $conf->format_date_text_short sinon %Y-%m-%d %H:%M:%S if (! $format) $format=(isset($conf->format_date_text_short) ? $conf->format_date_text_short : '%Y-%m-%d %H:%M:%S'); if ($format == 'day') $format=$conf->format_date_short; @@ -564,8 +564,8 @@ function dolibarr_print_date($time,$format='') /** - \brief Retourne une date fabriquée depuis une chaine - \param string Date formatée en chaine + \brief Retourne une date fabriqu�e depuis une chaine + \param string Date format�e en chaine YYYYMMDD YYYYMMDDHHMMSS DD/MM/YY ou DD/MM/YYYY @@ -644,14 +644,14 @@ function dolibarr_getdate($timestamp,$fast=false) } /** - \brief Retourne une date fabriquée depuis infos. - Remplace la fonction mktime non implémentée sous Windows si année < 1970 + \brief Retourne une date fabriqu�e depuis infos. + Remplace la fonction mktime non impl�ment�e sous Windows si ann�e < 1970 \param hour Heure \param minute Minute \param second Seconde \param month Mois \param day Jour - \param year Année + \param year Ann�e \return timestamp Date en timestamp, '' if error \remarks PHP mktime is restricted to the years 1901-2038 on Unix and 1970-2038 on Windows */ @@ -674,7 +674,7 @@ function dolibarr_mktime($hour,$minute,$second,$month,$day,$year,$gm=0) { /* // On peut utiliser strtotime pour obtenir la traduction. - // strtotime is ok for range: Vendredi 13 Décembre 1901 20:45:54 GMT au Mardi 19 Janvier 2038 03:14:07 GMT. + // strtotime is ok for range: Vendredi 13 D�cembre 1901 20:45:54 GMT au Mardi 19 Janvier 2038 03:14:07 GMT. $montharray=array(1=>'january',2=>'february',3=>'march',4=>'april',5=>'may',6=>'june', 7=>'july',8=>'august',9=>'september',10=>'october',11=>'november',12=>'december'); $string=$day." ".$montharray[0+$month]." ".$year." ".$hour.":".$minute.":".$second." GMT"; @@ -758,10 +758,10 @@ function dolibarr_print_object_info($object) } /** - \brief Formatage des numéros de telephone en fonction du format d'un pays - \param phone Numéro de telephone à formater + \brief Formatage des num�ros de telephone en fonction du format d'un pays + \param phone Num�ro de telephone � formater \param country Pays selon lequel formatter - \return string Numéro de téléphone formaté + \return string Num�ro de t�l�phone format� */ function dolibarr_print_phone($phone,$country="FR") { @@ -794,7 +794,7 @@ function dolibarr_print_phone($phone,$country="FR") } /** - \brief Tronque une chaine à une taille donnée en ajoutant les points de suspension si cela dépasse + \brief Tronque une chaine � une taille donn�e en ajoutant les points de suspension si cela d�passe \param string String to truncate \param size Max string size. 0 for no limit. \param trunc Where to trunc: right, left, middle @@ -835,12 +835,12 @@ function dolibarr_trunc($string,$size=40,$trunc='right') } /** - \brief Complète une chaine à une taille donnée par des espaces - \param string Chaine à compléter + \brief Compl�te une chaine � une taille donn�e par des espaces + \param string Chaine � compl�ter \param size Longueur de la chaine. - \param side 0=Complétion à droite, 1=Complétion à gauche - \param char Chaine de complétion - \return string Chaine complétée + \param side 0=Compl�tion � droite, 1=Compl�tion � gauche + \param char Chaine de compl�tion + \return string Chaine compl�t�e */ function dolibarr_pad($string,$size,$side,$char=' ') { @@ -856,7 +856,7 @@ function dolibarr_pad($string,$size,$side,$char=' ') } /** - \brief Affiche picto propre à une notion/module (fonction générique) + \brief Affiche picto propre � une notion/module (fonction g�n�rique) \param alt Texte sur le alt de l'image \param object Objet pour lequel il faut afficher le logo (exemple: user, group, action, bill, contract, propal, product, ...) \return string Retourne tag img @@ -868,10 +868,10 @@ function img_object($alt, $object) } /** - \brief Affiche picto (fonction générique) + \brief Affiche picto (fonction g�n�rique) \param alt Texte sur le alt de l'image \param picto Nom de l'image a afficher (Si pas d'extension, on met '.png') - \param options Attribut supplémentaire a la balise img + \param options Attribut suppl�mentaire a la balise img \return string Retourne tag img */ function img_picto($alt, $picto, $options='') @@ -1026,7 +1026,7 @@ function img_delete($alt = "default") } /** - \brief Affiche logo désactiver + \brief Affiche logo d�sactiver \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1129,7 +1129,7 @@ function img_alerte($alt = "default") } /** - \brief Affiche logo téléphone in + \brief Affiche logo t�l�phone in \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1141,7 +1141,7 @@ function img_phone_in($alt = "default") } /** - \brief Affiche logo téléphone out + \brief Affiche logo t�l�phone out \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1167,7 +1167,7 @@ function img_next($alt = "default") } /** - \brief Affiche logo précédent + \brief Affiche logo pr�c�dent \param alt Texte sur le alt de l'image \return string Retourne tag img */ @@ -1386,7 +1386,7 @@ function dol_loginfunction($notused,$pearstatus) print ''; if (file_exists(DOL_DOCUMENT_ROOT.'/logo.png')) { - // Cas qui ne devrait pas arriver (pour compatibilité) + // Cas qui ne devrait pas arriver (pour compatibilit�) print ''; } @@ -1435,7 +1435,7 @@ function dol_loginfunction($notused,$pearstatus) print ''."\n"; - // Code de sécurité + // Code de s�curit� if ($conf->global->MAIN_SECURITY_ENABLECAPTCHA) { //print "Info session: ".session_name().session_id();print_r($_SESSION); @@ -1489,12 +1489,12 @@ function dol_loginfunction($notused,$pearstatus) } /* - * \brief Vérifie les droits de l'utilisateur + * \brief V�rifie les droits de l'utilisateur * \param user Utilisateur courant - * \param module Module à vérifier + * \param module Module � v�rifier * \param objectid ID du document * \param dbtable Table de la base correspondant au module (optionnel) - * \param list Défini si la page sert de liste et donc ne fonctionne pas avec un id + * \param list D�fini si la page sert de liste et donc ne fonctionne pas avec un id */ function restrictedArea($user, $modulename, $objectid='', $dbtablename='', $list=0) { @@ -1512,7 +1512,7 @@ function dol_loginfunction($notused,$pearstatus) $socid = 0; $nocreate = 0; - //si dbtable non défini, même nom que le module + //si dbtable non d�fini, m�me nom que le module if (!$dbtablename) $dbtablename = $modulename; if (!$user->rights->$modulename->lire) @@ -1610,12 +1610,12 @@ function accessforbidden($message='',$printheader=1) /** - \brief Affiche message erreur system avec toutes les informations pour faciliter le diagnostic et la remontée des bugs. - On doit appeler cette fonction quand une erreur technique bloquante est rencontrée. + \brief Affiche message erreur system avec toutes les informations pour faciliter le diagnostic et la remont�e des bugs. + On doit appeler cette fonction quand une erreur technique bloquante est rencontr�e. Toutefois, il faut essayer de ne l'appeler qu'au sein de pages php, les classes devant - renvoyer leur erreur par l'intermédiaire de leur propriété "error". - \param db Handler de base utilisé - \param error Chaine erreur ou tableau de chaines erreur complémentaires à afficher + renvoyer leur erreur par l'interm�diaire de leur propri�t� "error". + \param db Handler de base utilis� + \param error Chaine erreur ou tableau de chaines erreur compl�mentaires � afficher */ function dolibarr_print_error($db='',$error='') { @@ -1696,7 +1696,7 @@ function dolibarr_print_error($db='',$error='') /** - \brief Deplacer les fichiers telechargés, apres quelques controles divers + \brief Deplacer les fichiers telecharg�s, apres quelques controles divers \param src_file fichier source \param dest_file fichier de destination \return int true=Deplacement OK, false=Pas de deplacement ou KO @@ -1723,7 +1723,7 @@ function doliMoveFileUpload($src_file, $dest_file) } // Security: - // On interdit les remontées de repertoire ainsi que les pipe dans + // On interdit les remont�es de repertoire ainsi que les pipe dans // les noms de fichiers. if (eregi('\.\.',$src_file) || eregi('[<>|]',$src_file)) { @@ -1732,7 +1732,7 @@ function doliMoveFileUpload($src_file, $dest_file) } // Security: - // On interdit les remontées de repertoire ainsi que les pipe dans + // On interdit les remont�es de repertoire ainsi que les pipe dans // les noms de fichiers. if (eregi('\.\.',$dest_file) || eregi('[<>|]',$dest_file)) { @@ -1750,22 +1750,22 @@ function doliMoveFileUpload($src_file, $dest_file) \brief Transcodage de francs en euros \param zonein zone de depart \param devise type de devise - \return r resultat transcodé + \return r resultat transcod� */ function transcoS2L($zonein,$devise) { // Open source offert par alainfloch@free.fr 28/10/2001, sans garantie. - // début de la fonction de transcodification de somme en toutes lettres + // d�but de la fonction de transcodification de somme en toutes lettres /* $zonein = "123,56"; - * $devise = "E"; // préciser F si francs , sinon ce sera de l'euro + * $devise = "E"; // pr�ciser F si francs , sinon ce sera de l'euro * $r = transcoS2L($zonein,$devise); // appeler la fonction - * echo "résultat vaut $r
"; - * $zonelettresM = strtoupper($r); // si vous voulez la même zone mais tout en majuscules - * echo "résultat en Majuscules vaut $zonelettresM
"; + * echo "r�sultat vaut $r
"; + * $zonelettresM = strtoupper($r); // si vous voulez la m�me zone mais tout en majuscules + * echo "r�sultat en Majuscules vaut $zonelettresM
"; * $zonein = "1,01"; * $r = transcoS2L($zonein,$devise); - * echo "résultat vaut $r
"; + * echo "r�sultat vaut $r
"; */ @@ -1782,7 +1782,7 @@ function transcoS2L($zonein,$devise) $cent_singulier = " centime"; } - $arr1_99 = array("zéro","un","deux","trois", + $arr1_99 = array("z�ro","un","deux","trois", "quatre","cinq","six","sept", "huit","neuf","dix","onze","douze", "treize","quatorze","quinze","seize", @@ -1820,24 +1820,24 @@ function transcoS2L($zonein,$devise) $arr1_99[$j] = "quatre-vingt-".$arr1_99[$i]; $i++; } // fin initialise la table (fin) - // echo "Pour une valeur en entrée = $zonein
"; //pour ceux qui ne croient que ce qu'ils voient ! + // echo "Pour une valeur en entr�e = $zonein
"; //pour ceux qui ne croient que ce qu'ils voient ! // quelques petits controles s'imposent !! - $valid = "[a-zA-Z\&\é\"\'\(\-\è\_\ç\à\)\=\;\:\!\*\$\^\<\>]"; + $valid = "[a-zA-Z\&\�\"\'\(\-\�\_\�\�\)\=\;\:\!\*\$\^\<\>]"; if (ereg($valid,$zonein)) { - $r = "la chaîne ".$zonein." n'est pas valide"; + $r = "la cha�ne ".$zonein." n'est pas valide"; return($r); } - $zone = explode(" ",$zonein); // supprimer les blancs séparateurs - $zonein = implode("",$zone); // reconcatène la zone input - $zone = explode(".",$zonein); // supprimer les points séparateurs - $zonein = implode("",$zone); // reconcatène la zone input, ça c'est fort ! merci PHP - $virg = strpos($zonein,",",1); // à la poursuite de la virgule + $zone = explode(" ",$zonein); // supprimer les blancs s�parateurs + $zonein = implode("",$zone); // reconcat�ne la zone input + $zone = explode(".",$zonein); // supprimer les points s�parateurs + $zonein = implode("",$zone); // reconcat�ne la zone input, �a c'est fort ! merci PHP + $virg = strpos($zonein,",",1); // � la poursuite de la virgule $i = strlen($zonein); // et de la longueur de la zone input if ($virg == 0) { // ya pas de virgule if ($i > 7) { - $r = "la chaîne ".$zonein." est trop longue (maxi = 9 millions)"; + $r = "la cha�ne ".$zonein." est trop longue (maxi = 9 millions)"; return($r); } $deb = 7 - $i; @@ -1845,12 +1845,12 @@ function transcoS2L($zonein,$devise) } else { //ya une virgule - $ti = explode(",",$zonein); // mettre de côté ce qu'il y a devant la virgule + $ti = explode(",",$zonein); // mettre de c�t� ce qu'il y a devant la virgule $i = strlen($ti[0]); // en controler la longueur $zonechiffres = "0000000,00"; if ($i > 7) { - $r = "la chaîne ".$zonein." est trop longue (maxi = 9 millions,00)"; + $r = "la cha�ne ".$zonein." est trop longue (maxi = 9 millions,00)"; return($r); } $deb = 7 - $i; @@ -1881,7 +1881,7 @@ function transcoS2L($zonein,$devise) } } // fin du else ya des centaines de mille $MM= substr($zoneanaly,2,2); - if (substr($zoneanaly,2,1)==0){ $MM = substr($zoneanaly,3,1);} // enlever le zéro des milliers cause indexation + if (substr($zoneanaly,2,1)==0){ $MM = substr($zoneanaly,3,1);} // enlever le z�ro des milliers cause indexation if ($MM ==0 && $CM > 0) { $r = $r."mille "; @@ -1909,7 +1909,7 @@ function transcoS2L($zonein,$devise) } } $C2= substr($zoneanaly,5,2); - if (substr($zoneanaly,5,1)==0){ $C2 = substr($zoneanaly,6,1);} // enlever le zéro des centaines cause indexation + if (substr($zoneanaly,5,1)==0){ $C2 = substr($zoneanaly,6,1);} // enlever le z�ro des centaines cause indexation $C1= substr($zoneanaly,4,1); if ($C2 ==0 && $C1 > 1) { @@ -1939,13 +1939,13 @@ function transcoS2L($zonein,$devise) if ($UN != "00") { $cts = $UN; - if (substr($UN,0,1)==0){ $cts = substr($UN,1,1);} // enlever le zéro des centimes cause indexation + if (substr($UN,0,1)==0){ $cts = substr($UN,1,1);} // enlever le z�ro des centimes cause indexation $r = $r." et ". $arr1_99[$cts].$cent_singulier; if ($UN > 1) $r =$r."s"; // accorde au pluriel } - $r1 = ltrim($r); // enleve quelques blancs possibles en début de zone - $r = ucfirst($r1); // met le 1er caractère en Majuscule, c'est + zoli - return($r); // retourne le résultat + $r1 = ltrim($r); // enleve quelques blancs possibles en d�but de zone + $r = ucfirst($r1); // met le 1er caract�re en Majuscule, c'est + zoli + return($r); // retourne le r�sultat } // fin fonction transcoS2L @@ -1957,7 +1957,7 @@ function transcoS2L($zonein,$devise) \param begin ("" par defaut) \param options ("" par defaut) \param td options de l'attribut td ("" par defaut) - \param sortfield nom du champ sur lequel est effectué le tri du tableau + \param sortfield nom du champ sur lequel est effectu� le tri du tableau \param sortorder ordre du tri */ function print_liste_field_titre($name, $file, $field, $begin="", $options="", $td="", $sortfield="", $sortorder="") @@ -1965,7 +1965,7 @@ function print_liste_field_titre($name, $file, $field, $begin="", $options="", $ global $conf; //print "$name, $file, $field, $begin, $options, $td, $sortfield, $sortorder
\n"; - // Le champ de tri est mis en évidence. + // Le champ de tri est mis en �vidence. // Exemple si (sortfield,field)=("nom","xxx.nom") ou (sortfield,field)=("nom","nom") if ($sortfield == $field || $sortfield == ereg_replace("^[^\.]+\.","",$field)) { @@ -2013,9 +2013,9 @@ function print_titre($titre) } /** - \brief Affichage d'un titre d'une fiche, aligné a gauche + \brief Affichage d'un titre d'une fiche, align� a gauche \param titre Le titre a afficher - \param mesg Message suplémentaire à afficher à droite + \param mesg Message supl�mentaire � afficher � droite \param picto Picto pour ligne de titre */ function print_fiche_titre($titre, $mesg='', $picto='') @@ -2051,8 +2051,8 @@ function dol_delete_file($file) } /** - \brief Effacement d'un répertoire - \param file Répertoire a effacer + \brief Effacement d'un r�pertoire + \param file R�pertoire a effacer */ function dol_delete_dir($dir) { @@ -2060,10 +2060,10 @@ function dol_delete_dir($dir) } /** - \brief Effacement d'un répertoire $dir et de son arborescence - \param file Répertoire a effacer - \param count Compteur pour comptage nb elements supprimés - \return int Nombre de fichier+repértoires supprimés + \brief Effacement d'un r�pertoire $dir et de son arborescence + \param file R�pertoire a effacer + \param count Compteur pour comptage nb elements supprim�s + \return int Nombre de fichier+rep�rtoires supprim�s */ function dol_delete_dir_recursive($dir,$count=0) { @@ -2098,7 +2098,7 @@ function dol_delete_dir_recursive($dir,$count=0) /** \brief Scan les fichiers avec un anti-virus \param file Fichier a scanner - \return malware Nom du virus si infecté sinon retourne "null" + \return malware Nom du virus si infect� sinon retourne "null" */ function dol_avscan_file($file) { @@ -2123,13 +2123,13 @@ function dol_avscan_file($file) /** \brief Fonction print_barre_liste \param titre titre de la page - \param page numéro de la page + \param page num�ro de la page \param file lien \param options parametres complementaires lien ('' par defaut) \param sortfield champ de tri ('' par defaut) \param sortorder ordre de tri ('' par defaut) \param center chaine du centre ('' par defaut) - \param num nombre d'élément total + \param num nombre d'�l�ment total */ function print_barre_liste($titre, $page, $file, $options='', $sortfield='', $sortorder='', $center='', $num=-1) { @@ -2174,7 +2174,7 @@ function print_barre_liste($titre, $page, $file, $options='', $sortfield='', $so /** \brief Fonction servant a afficher les fleches de navigation dans les pages de listes - \param page numéro de la page + \param page num�ro de la page \param file lien \param options autres parametres d'url a propager dans les liens ("" par defaut) \param nextpage faut-il une page suivante @@ -2195,10 +2195,10 @@ function print_fleche_navigation($page,$file,$options='',$nextpage) /** -* \brief Fonction qui retourne un taux de tva formaté pour visualisation -* \remarks Fonction utilisée dans les pdf et les pages html +* \brief Fonction qui retourne un taux de tva format� pour visualisation +* \remarks Fonction utilis�e dans les pdf et les pages html * \param rate Taux a formater (19.6 19,6 19.6% 19,6%...) -* \return string Chaine avec montant formaté (19,6 ou 19,6%) +* \return string Chaine avec montant format� (19,6 ou 19,6%) */ function vatrate($rate) { @@ -2213,14 +2213,14 @@ function vatrate($rate) /** -* \brief Fonction qui retourne un montant monétaire formaté pour visualisation -* \remarks Fonction utilisée dans les pdf et les pages html +* \brief Fonction qui retourne un montant mon�taire format� pour visualisation +* \remarks Fonction utilis�e dans les pdf et les pages html * \param amount Montant a formater * \param html Formatage html ou pas (0 par defaut) * \param outlangs Objet langs pour formatage text -* \param trunc 1=Tronque affichage si trop de décimales,0=Force le non troncage +* \param trunc 1=Tronque affichage si trop de d�cimales,0=Force le non troncage * \param nbdecimal Nbre decimals minimum. -* \return string Chaine avec montant formaté +* \return string Chaine avec montant format� * \seealso price2num Fonction inverse de price */ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) @@ -2242,11 +2242,11 @@ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) //print $amount."-"; $datas = split('\.',$amount); $decpart = $datas[1]; - $decpart = eregi_replace('0+$','',$decpart); // Supprime les 0 de fin de partie décimale + $decpart = eregi_replace('0+$','',$decpart); // Supprime les 0 de fin de partie d�cimale //print "decpart=".$decpart."
"; $end=''; - // On augmente au besoin si il y a plus de 2 décimales + // On augmente au besoin si il y a plus de 2 d�cimales if (strlen($decpart) > $nbdecimal) $nbdecimal=strlen($decpart); // Si on depasse max if ($trunc && $nbdecimal > $conf->global->MAIN_MAX_DECIMALS_SHOWN) @@ -2254,7 +2254,7 @@ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) $nbdecimal=$conf->global->MAIN_MAX_DECIMALS_SHOWN; if (eregi('\.\.\.',$conf->global->MAIN_MAX_DECIMALS_SHOWN)) { - // Si un affichage est tronqué, on montre des ... + // Si un affichage est tronqu�, on montre des ... $end='...'; } } @@ -2274,15 +2274,15 @@ function price($amount, $html=0, $outlangs='', $trunc=1, $nbdecimal=2) } /** - \brief Fonction qui retourne un numérique conforme PHP et SQL, depuis un montant au + \brief Fonction qui retourne un num�rique conforme PHP et SQL, depuis un montant au format utilisateur. - \remarks Fonction à appeler sur montants saisis avant un insert en base + \remarks Fonction � appeler sur montants saisis avant un insert en base \param amount Montant a formater \param rounding 'MU'=Round to Max unit price (MAIN_MAX_DECIMALS_UNIT) 'MT'=Round to Max with Tax (MAIN_MAX_DECIMALS_TOT) 'MS'=Round to Max Shown (MAIN_MAX_DECIMALS_SHOWN) ''=No rounding - \return string Montant au format numérique PHP et SQL (Exemple: '99.99999') + \return string Montant au format num�rique PHP et SQL (Exemple: '99.99999') \seealso price Fonction inverse de price2num */ function price2num($amount,$rounding='') @@ -2308,16 +2308,16 @@ function price2num($amount,$rounding='') /** \brief Fonction qui renvoie la tva d'une ligne (en fonction du vendeur, acheteur et taux du produit) - \remarks Si vendeur non assujeti à TVA, TVA par défaut=0. Fin de règle. - Si le (pays vendeur = pays acheteur) alors TVA par défaut=TVA du produit vendu. Fin de règle. - Si (vendeur et acheteur dans Communauté européenne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par défaut=0 (La TVA doit être payé par acheteur au centre d'impots de son pays et non au vendeur). Fin de règle. - Si (vendeur et acheteur dans Communauté européenne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par défaut=TVA du produit vendu. Fin de règle. - Si (vendeur et acheteur dans Communauté européenne) et (acheteur = entreprise avec num TVA) intra alors TVA par défaut=0. Fin de règle. - Sinon TVA proposée par défaut=0. Fin de règle. - \param societe_vendeuse Objet société vendeuse - \param societe_acheteuse Objet société acheteuse + \remarks Si vendeur non assujeti � TVA, TVA par d�faut=0. Fin de r�gle. + Si le (pays vendeur = pays acheteur) alors TVA par d�faut=TVA du produit vendu. Fin de r�gle. + Si (vendeur et acheteur dans Communaut� europ�enne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par d�faut=0 (La TVA doit �tre pay� par acheteur au centre d'impots de son pays et non au vendeur). Fin de r�gle. + Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par d�faut=TVA du produit vendu. Fin de r�gle. + Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = entreprise avec num TVA) intra alors TVA par d�faut=0. Fin de r�gle. + Sinon TVA propos�e par d�faut=0. Fin de r�gle. + \param societe_vendeuse Objet soci�t� vendeuse + \param societe_acheteuse Objet soci�t� acheteuse \param taux_produit Taux par defaut du produit vendu - \return float Taux de tva à appliquer, -1 si ne peut etre déterminé + \return float Taux de tva � appliquer, -1 si ne peut etre d�termin� */ function get_default_tva($societe_vendeuse, $societe_acheteuse, $taux_produit) { @@ -2326,37 +2326,37 @@ function get_default_tva($societe_vendeuse, $societe_acheteuse, $taux_produit) if (!is_object($societe_vendeuse)) return -1; if (!is_object($societe_acheteuse)) return -1; - // Si vendeur non assujeti à TVA (tva_assuj vaut 0/1 ou franchise/reel) + // Si vendeur non assujeti � TVA (tva_assuj vaut 0/1 ou franchise/reel) if (is_numeric($societe_vendeuse->tva_assuj) && ! $societe_vendeuse->tva_assuj) return 0; if (! is_numeric($societe_vendeuse->tva_assuj) && $societe_vendeuse->tva_assuj=='franchise') return 0; - // Si le (pays vendeur = pays acheteur) alors la TVA par défaut=TVA du produit vendu. Fin de règle. + // Si le (pays vendeur = pays acheteur) alors la TVA par d�faut=TVA du produit vendu. Fin de r�gle. //if (is_object($societe_acheteuse) && ($societe_vendeuse->pays_id == $societe_acheteuse->pays_id) && ($societe_acheteuse->tva_assuj == 1 || $societe_acheteuse->tva_assuj == 'reel')) - // Le test ci-dessus ne devrait pas etre necessaire. Me signaler l'exemple du cas juridique concercné si le test suivant n'est pas suffisant. + // Le test ci-dessus ne devrait pas etre necessaire. Me signaler l'exemple du cas juridique concercn� si le test suivant n'est pas suffisant. if ($societe_vendeuse->pays_id == $societe_acheteuse->pays_id) { - if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut déterminer taux tva + if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut d�terminer taux tva return $taux_produit; } - // Si (vendeur et acheteur dans Communauté européenne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par défaut=0 (La TVA doit être payé par l'acheteur au centre d'impots de son pays et non au vendeur). Fin de règle. - // Non géré + // Si (vendeur et acheteur dans Communaut� europ�enne) et (bien vendu = moyen de transports neuf comme auto, bateau, avion) alors TVA par d�faut=0 (La TVA doit �tre pay� par l'acheteur au centre d'impots de son pays et non au vendeur). Fin de r�gle. + // Non g�r� - // Si (vendeur et acheteur dans Communauté européenne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par défaut=TVA du produit vendu. Fin de règle. + // Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = particulier ou entreprise sans num TVA intra) alors TVA par d�faut=TVA du produit vendu. Fin de r�gle. if (($societe_vendeuse->isInEEC() && $societe_acheteuse->isInEEC()) && ! $societe_acheteuse->tva_intra) { - if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut déterminer taux tva + if (strlen($taux_produit) == 0) return -1; // Si taux produit = '', on ne peut d�terminer taux tva return $taux_produit; } - // Si (vendeur et acheteur dans Communauté européenne) et (acheteur = entreprise avec num TVA intra) alors TVA par défaut=0. Fin de règle. + // Si (vendeur et acheteur dans Communaut� europ�enne) et (acheteur = entreprise avec num TVA intra) alors TVA par d�faut=0. Fin de r�gle. if (($societe_vendeuse->isInEEC() && $societe_acheteuse->isInEEC()) && $societe_acheteuse->tva_intra) { return 0; } - // Sinon la TVA proposée par défaut=0. Fin de règle. - // Rem: Cela signifie qu'au moins un des 2 est hors Communauté européenne et que le pays diffère + // Sinon la TVA propos�e par d�faut=0. Fin de r�gle. + // Rem: Cela signifie qu'au moins un des 2 est hors Communaut� europ�enne et que le pays diff�re return 0; } @@ -2390,7 +2390,7 @@ function makesalt($type=CRYPT_SALT_LENGTH) { case 12: // 8 + 4 $saltlen=8; $saltprefix='$1$'; $saltsuffix='$'; break; - case 8: // 8 + 4 (Pour compatibilite, ne devrait pas etre utilisé) + case 8: // 8 + 4 (Pour compatibilite, ne devrait pas etre utilis�) $saltlen=8; $saltprefix='$1$'; $saltsuffix='$'; break; case 2: // 2 default: // by default, fall back on Standard DES (should work everywhere) @@ -2405,8 +2405,8 @@ function makesalt($type=CRYPT_SALT_LENGTH) } /** \brief Fonction pour qui retourne le rowid d'un departement par son code - \param db handler d'accès base - \param code Code région + \param db handler d'acc�s base + \param code Code r�gion \param pays_id Id du pays */ function departement_rowid($db,$code, $pays_id) @@ -2437,9 +2437,9 @@ function departement_rowid($db,$code, $pays_id) } /** - \brief Renvoi un chemin de classement répertoire en fonction d'un id + \brief Renvoi un chemin de classement r�pertoire en fonction d'un id \remarks Examples: 1->"0/0/1/", 15->"0/1/5/" - \param $num Id à décomposer + \param $num Id � d�composer \param $level Niveau de decoupage (1, 2 ou 3 niveaux) */ function get_exdir($num,$level=3) @@ -2453,9 +2453,9 @@ function get_exdir($num,$level=3) } /** - \brief Création de répertoire recursive - \param $dir Répertoire à créer - \return int < 0 si erreur, >= 0 si succès + \brief Cr�ation de r�pertoire recursive + \param $dir R�pertoire � cr�er + \return int < 0 si erreur, >= 0 si succ�s */ function create_exdir($dir) { @@ -2474,7 +2474,7 @@ function create_exdir($dir) else $ccdir = $cdir[$i]; if (eregi("^.:$",$ccdir,$regs)) continue; // Si chemin Windows incomplet, on poursuit par rep suivant - // Attention, le is_dir() peut échouer bien que le rep existe. + // Attention, le is_dir() peut �chouer bien que le rep existe. // (ex selon config de open_basedir) if ($ccdir) { @@ -2485,20 +2485,20 @@ function create_exdir($dir) umask(0); if (! @mkdir($ccdir, 0755)) { - // Si le is_dir a renvoyé une fausse info, alors on passe ici. + // Si le is_dir a renvoy� une fausse info, alors on passe ici. dolibarr_syslog("functions.inc.php::create_exdir: Fails to create directory '".$ccdir."' or directory already exists.",LOG_WARNING); $nberr++; } else { dolibarr_syslog("functions.inc.php::create_exdir: Directory '".$ccdir."' created",LOG_DEBUG); - $nberr=0; // On remet à zéro car si on arrive ici, cela veut dire que les échecs précédents peuvent etre ignorés + $nberr=0; // On remet � z�ro car si on arrive ici, cela veut dire que les �checs pr�c�dents peuvent etre ignor�s $nbcreated++; } } else { - $nberr=0; // On remet à zéro car si on arrive ici, cela veut dire que les échecs précédents peuvent etre ignorés + $nberr=0; // On remet � z�ro car si on arrive ici, cela veut dire que les �checs pr�c�dents peuvent etre ignor�s } } } @@ -2595,9 +2595,9 @@ function dolibarr_dir_list($path, $types="all", $recursive=0, $filter="", $exclu } } /** - \brief Retourne le numéro de la semaine par rapport a une date + \brief Retourne le num�ro de la semaine par rapport a une date \param time Date au format 'timestamp' - \return int Numéro de semaine + \return int Num�ro de semaine */ function numero_semaine($time) { @@ -2613,12 +2613,12 @@ function numero_semaine($time) /* * Norme ISO-8601: - * - La semaine 1 de toute année est celle qui contient le 4 janvier ou que la semaine 1 de toute année est celle qui contient le 1er jeudi de janvier. - * - La majorité des années ont 52 semaines mais les années qui commence un jeudi et les années bissextiles commençant un mercredi en possède 53. + * - La semaine 1 de toute ann�e est celle qui contient le 4 janvier ou que la semaine 1 de toute ann�e est celle qui contient le 1er jeudi de janvier. + * - La majorit� des ann�es ont 52 semaines mais les ann�es qui commence un jeudi et les ann�es bissextiles commen�ant un mercredi en poss�de 53. * - Le 1er jour de la semaine est le Lundi */ - // Définition du Jeudi de la semaine + // D�finition du Jeudi de la semaine if (date("w",mktime(12,0,0,$mois,$jour,$annee))==0) // Dimanche $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee)-3*24*60*60; else if (date("w",mktime(12,0,0,$mois,$jour,$annee))<4) // du Lundi au Mercredi @@ -2628,7 +2628,7 @@ function numero_semaine($time) else // Jeudi $jeudiSemaine = mktime(12,0,0,$mois,$jour,$annee); - // Définition du premier Jeudi de l'année + // D�finition du premier Jeudi de l'ann�e if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==0) // Dimanche { $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine))+4*24*60*60; @@ -2646,7 +2646,7 @@ function numero_semaine($time) $premierJeudiAnnee = mktime(12,0,0,1,1,date("Y",$jeudiSemaine)); } - // Définition du numéro de semaine: nb de jours entre "premier Jeudi de l'année" et "Jeudi de la semaine"; + // D�finition du num�ro de semaine: nb de jours entre "premier Jeudi de l'ann�e" et "Jeudi de la semaine"; $numeroSemaine = ( ( date("z",mktime(12,0,0,date("m",$jeudiSemaine),date("d",$jeudiSemaine),date("Y",$jeudiSemaine))) @@ -2658,7 +2658,7 @@ function numero_semaine($time) // Cas particulier de la semaine 53 if ($numeroSemaine==53) { - // Les années qui commence un Jeudi et les années bissextiles commençant un Mercredi en possède 53 + // Les ann�es qui commence un Jeudi et les ann�es bissextiles commen�ant un Mercredi en poss�de 53 if (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==4 || (date("w",mktime(12,0,0,1,1,date("Y",$jeudiSemaine)))==3 && date("z",mktime(12,0,0,12,31,date("Y",$jeudiSemaine)))==365)) { $numeroSemaine = 53; @@ -2719,13 +2719,13 @@ function weight_convert($weight,&$from_unit,$to_unit) \param int Unit \param measuring_style Le style de mesure : weight, volume,... \return string Unite - \todo gerer les autres unités de mesure comme la livre, le gallon, le litre, ... + \todo gerer les autres unit�s de mesure comme la livre, le gallon, le litre, ... */ function measuring_units_string($unit,$measuring_style='') { /* Note Rodo aux dev :) - * Ne pas insérer dans la base de données ces valeurs - * cela surchagerait inutilement d'une requete supplémentaire + * Ne pas ins�rer dans la base de donn�es ces valeurs + * cela surchagerait inutilement d'une requete suppl�mentaire * pour quelque chose qui est somme toute peu variable */ @@ -2767,22 +2767,28 @@ function dol_entity_decode($StringHtml) */ function clean_url($url,$http=1) { - if (eregi('^(http(s)?:[\\\/]+)?[0-9A-Z-]+\.([0-9A-Z-]+\.)+[A-Z]{2,4}(:[0-9]+)?',$url)) + if (eregi('^(https?:[\\\/]+)?([0-9A-Z\-\.]+\.[A-Z]{2,4})(:[0-9]+)?',$url,$regs)) { - //Todo: voir plus tard pour les url avec accent - $url = unaccent(trim($url)); + $proto=$regs[1]; + $domain=$regs[2]; + $port=$regs[3]; + //print $url." -> ".$proto." - ".$domain." - ".$port; + $url = unaccent(trim($url)); - // Si défini on supprime le http - // TODO: supprimer les slashs en trop - if ($http==0) $url = eregi_replace('^http(s)?:[\\\/]+','',$url); + // Si http: defini on supprime le http (Si https on ne supprime pas) + if ($http==0) + { + if (eregi('^http:[\\\/]+',$url)) + { + $url = eregi_replace('^http:[\\\/]+','',$url); + $proto = ''; + } + } - // On récupère le nom de domaine - $domain = eregi('^(http(s)?:[\\\/]+)?[0-9A-Z-]+\.([0-9A-Z-]+\.)+[A-Z]{2,4}(:[0-9]+)?',$url,$regs); + // On passe le nom de domaine en minuscule + $url = eregi_replace('^(https?:[\\\/]+)?'.$domain,$proto.strtolower($domain),$url); - // On passe le nom de domaine en minuscule - $url = eregi_replace($regs[0],strtolower($regs[0]),$url); - - return $url; + return $url; } } @@ -2808,7 +2814,7 @@ function clean_html($StringHtml) } /** - \brief Convertir du binaire en héxadécimal + \brief Convertir du binaire en h�xad�cimal \param string bin \return string x */ @@ -2822,7 +2828,7 @@ function binhex($bin, $pad=false, $upper=false){ } /** - \brief Convertir de l'héxadécimal en binaire + \brief Convertir de l'h�xad�cimal en binaire \param string hexa \return string bin */ @@ -2836,12 +2842,12 @@ function hexbin($hexa){ } /* -* \brief Cette fonction est appelée pour coder ou non une chaine en html. +* \brief Cette fonction est appel�e pour coder ou non une chaine en html. * \param stringtoencode String to encode * \param htmlinfo 1=String IS already html, 0=String IS NOT html, -1=Unknown need autodetection * \remarks Selon qu'on compte l'afficher dans le PDF avec: -* writeHTMLCell -> a besoin d'etre encodé en HTML -* MultiCell -> ne doit pas etre encodé en HTML +* writeHTMLCell -> a besoin d'etre encod� en HTML +* MultiCell -> ne doit pas etre encod� en HTML */ function dol_htmlentities($stringtoencode,$htmlinfo=-1) { @@ -2856,8 +2862,8 @@ function dol_htmlentities($stringtoencode,$htmlinfo=-1) } /** - \brief Encode\decode le mot de passe de la base de données dans le fichier de conf - \param level niveau d'encodage : 0 non encodé, 1 encodé + \brief Encode\decode le mot de passe de la base de donn�es dans le fichier de conf + \param level niveau d'encodage : 0 non encod�, 1 encod� */ function encodedecode_dbpassconf($level=0) { @@ -2908,9 +2914,9 @@ function encodedecode_dbpassconf($level=0) } /** - \brief Encode une chaine de caractère - \param chain chaine de caractères à encoder - \return string_coded chaine de caractères encodée + \brief Encode une chaine de caract�re + \param chain chaine de caract�res � encoder + \return string_coded chaine de caract�res encod�e */ function dolibarr_encode($chain) { @@ -2924,9 +2930,9 @@ function dolibarr_encode($chain) } /** - \brief Decode une chaine de caractère - \param chain chaine de caractères à decoder - \return string_coded chaine de caractères decodée + \brief Decode une chaine de caract�re + \param chain chaine de caract�res � decoder + \return string_coded chaine de caract�res decod�e */ function dolibarr_decode($chain) { @@ -2942,17 +2948,17 @@ function dolibarr_decode($chain) } /** - \brief Fonction retournant le nombre de jour fériés samedis et dimanches entre 2 dates entrées en timestamp + \brief Fonction retournant le nombre de jour f�ri�s samedis et dimanches entre 2 dates entr�es en timestamp \brief SERVANT AU CALCUL DES JOURS OUVRABLES - \param timestampStart Timestamp de début + \param timestampStart Timestamp de d�but \param timestampEnd Timestamp de fin - \return nbFerie Nombre de jours fériés - \TODO: Prévoir les jours fériés hors France. + \return nbFerie Nombre de jours f�ri�s + \TODO: Pr�voir les jours f�ri�s hors France. */ function num_public_holiday($timestampStart, $timestampEnd) { - // Initialisation de la date de début + // Initialisation de la date de d�but $jour = date("d", $timestampStart); $mois = date("m", $timestampStart); $annee = date("Y", $timestampStart); @@ -2960,7 +2966,7 @@ function num_public_holiday($timestampStart, $timestampEnd) while ($timestampStart != $timestampEnd) { - // Définition des dates fériées fixes + // D�finition des dates f�ri�es fixes if($jour == 1 && $mois == 1) $nbFerie++; // 1er janvier if($jour == 1 && $mois == 5) $nbFerie++; // 1er mai if($jour == 8 && $mois == 5) $nbFerie++; // 5 mai @@ -2968,16 +2974,16 @@ function num_public_holiday($timestampStart, $timestampEnd) if($jour == 15 && $mois == 8) $nbFerie++; // 15 aout if($jour == 1 && $mois == 11) $nbFerie++; // 1 novembre if($jour == 11 && $mois == 11) $nbFerie++; // 11 novembre - if($jour == 25 && $mois == 12) $nbFerie++; // 25 décembre + if($jour == 25 && $mois == 12) $nbFerie++; // 25 d�cembre - // Calcul du jour de pâques + // Calcul du jour de p�ques $date_paques = easter_date($annee); $jour_paques = date("d", $date_paques); $mois_paques = date("m", $date_paques); if($jour_paques == $jour && $mois_paques == $mois) $nbFerie++; - // Pâques + // P�ques - // Calcul du jour de l ascension (38 jours après Paques) + // Calcul du jour de l ascension (38 jours apr�s Paques) $date_ascension = mktime(date("H", $date_paques), date("i", $date_paques), date("s", $date_paques), @@ -2990,7 +2996,7 @@ function num_public_holiday($timestampStart, $timestampEnd) if($jour_ascension == $jour && $mois_ascension == $mois) $nbFerie++; //Ascension - // Calcul de Pentecôte (11 jours après Paques) + // Calcul de Pentec�te (11 jours apr�s Paques) $date_pentecote = mktime(date("H", $date_ascension), date("i", $date_ascension), date("s", $date_ascension), @@ -3009,7 +3015,7 @@ function num_public_holiday($timestampStart, $timestampEnd) if($jour_semaine == 0 || $jour_semaine == 6) $nbFerie++; //Samedi (6) et dimanche (0) - // Incrémentation du nombre de jour ( on avance dans la boucle) + // Incr�mentation du nombre de jour ( on avance dans la boucle) $jour++; $timestampStart=mktime(0,0,0,$mois,$jour,$annee); @@ -3021,7 +3027,7 @@ function num_public_holiday($timestampStart, $timestampEnd) /** \brief Fonction retournant le nombre de jour entre deux dates - \param timestampStart Timestamp de début + \param timestampStart Timestamp de d�but \param timestampEnd Timestamp de fin \param lastday On prend en compte le dernier jour, 0: non, 1:oui \return nbjours Nombre de jours @@ -3044,8 +3050,8 @@ function num_between_day($timestampStart, $timestampEnd, $lastday=0) } /** - \brief Fonction retournant le nombre de jour entre deux dates sans les jours fériés (jours ouvrés) - \param timestampStart Timestamp de début + \brief Fonction retournant le nombre de jour entre deux dates sans les jours f�ri�s (jours ouvr�s) + \param timestampStart Timestamp de d�but \param timestampEnd Timestamp de fin \param inhour 0: sort le nombre de jour , 1: sort le nombre d'heure \param lastday On prend en compte le dernier jour, 0: non, 1:oui @@ -3070,7 +3076,7 @@ function num_open_day($timestampStart, $timestampEnd,$inhour=0,$lastday=0) } /** - \brief Fonction retournant le nombre de lignes dans un texte formaté + \brief Fonction retournant le nombre de lignes dans un texte format� \param texte Texte \return nblines Nombre de lignes */ @@ -3091,11 +3097,11 @@ function ajax_indicator($htmlname,$indicator='working') } /** - \brief Récupère la valeur d'un champ, effectue un traitement Ajax et affiche le résultat + \brief R�cup�re la valeur d'un champ, effectue un traitement Ajax et affiche le r�sultat \param htmlname nom et id du champ - \param keysearch nom et id complémentaire du champ de collecte - \param url chemin du fichier de réponse : /chemin/fichier.php - \param option champ supplémentaire de recherche dans les paramètres + \param keysearch nom et id compl�mentaire du champ de collecte + \param url chemin du fichier de r�ponse : /chemin/fichier.php + \param option champ suppl�mentaire de recherche dans les param�tres \param indicator Nom de l'image gif sans l'extension \return script script complet */ @@ -3134,12 +3140,12 @@ function ajax_updater($htmlname,$keysearch,$url,$option='',$indicator='working') } /** - \brief Récupère la valeur d'un champ, effectue un traitement Ajax et affiche le résultat + \brief R�cup�re la valeur d'un champ, effectue un traitement Ajax et affiche le r�sultat \param htmlname nom et id du champ - \param keysearch nom et id complémentaire du champ de collecte - \param id ID du champ à modifier - \param url chemin du fichier de réponse : /chemin/fichier.php - \param option champ supplémentaire de recherche dans les paramètres + \param keysearch nom et id compl�mentaire du champ de collecte + \param id ID du champ � modifier + \param url chemin du fichier de r�ponse : /chemin/fichier.php + \param option champ suppl�mentaire de recherche dans les param�tres \param indicator Nom de l'image gif sans l'extension \return script script complet */ @@ -3176,9 +3182,9 @@ function ajax_updaterWithID($htmlname,$keysearch,$id,$url,$option='',$indicator= } /** - \brief Récupère la valeur d'un champ, effectue un traitement Ajax et affiche le résultat + \brief R�cup�re la valeur d'un champ, effectue un traitement Ajax et affiche le r�sultat \param htmlname nom et id du champ - \param url chemin du fichier de réponse : /chemin/fichier.php + \param url chemin du fichier de r�ponse : /chemin/fichier.php \param indicator nom de l'image gif sans l'extension \return script script complet */ @@ -3201,7 +3207,7 @@ function ajax_autocompleter($selected='',$htmlname,$url,$indicator='working') } /** -* \brief Fonction simple identique à microtime de PHP 5 mais compatible PHP 4 +* \brief Fonction simple identique � microtime de PHP 5 mais compatible PHP 4 * \return float Time en millisecondes avec decimal pour microsecondes */ function dol_microtime_float() @@ -3240,10 +3246,10 @@ function dol_textishtml($msg,$option=0) } /* - * \brief Effectue les substitutions des mots clés par les données en fonction du tableau + * \brief Effectue les substitutions des mots cl�s par les donn�es en fonction du tableau * \param chaine Chaine dans laquelle faire les substitutions - * \param substitutionarray Tableau clé substitution => valeur a mettre - * \return string Chaine avec les substitutions effectuées + * \param substitutionarray Tableau cl� substitution => valeur a mettre + * \return string Chaine avec les substitutions effectu�es */ function make_substitutions($chaine,$substitutionarray) { @@ -3286,14 +3292,14 @@ function make_substitutions($chaine,$substitutionarray) $result = "\"" . addslashes(stripslashes($var)) . "\""; return $result; } - // autres cas: objets, on ne les gère pas + // autres cas: objets, on ne les g�re pas $result = FALSE; return $result; } /* - * \brief Formate l'affichage de date de début et de fin - * \param date_start date de début + * \brief Formate l'affichage de date de d�but et de fin + * \param date_start date de d�but * \param date_end date de fin */ function print_date_range($date_start,$date_end) @@ -3315,13 +3321,13 @@ function print_date_range($date_start,$date_end) } /* - * \brief Création de 2 vignettes à partir d'un fichier image (une small et un mini) + * \brief Cr�ation de 2 vignettes � partir d'un fichier image (une small et un mini) * \brief Les extension prise en compte sont jpg et png - * \param file Chemin du fichier image à redimensionner - * \param maxWidth Largeur maximum que dois faire la miniature (160 par défaut) - * \param maxHeight Hauteur maximum que dois faire l'image (120 par défaut) - * \param extName Extension pour différencier le nom de la vignette - * \param quality Qualité de compression (0=worst, 100=best) + * \param file Chemin du fichier image � redimensionner + * \param maxWidth Largeur maximum que dois faire la miniature (160 par d�faut) + * \param maxHeight Hauteur maximum que dois faire l'image (120 par d�faut) + * \param extName Extension pour diff�rencier le nom de la vignette + * \param quality Qualit� de compression (0=worst, 100=best) * \return string Chemin de la vignette */ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $quality=50) @@ -3333,15 +3339,15 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ // Nettoyage parametres $file=trim($file); - // Vérification des paramètres + // V�rification des param�tres if (! $file) { - // Si le fichier n'a pas été indiqué + // Si le fichier n'a pas �t� indiqu� return 'Bad parameter file'; } elseif (! file_exists($file)) { - // Si le fichier passé en paramètre n'existe pas + // Si le fichier pass� en param�tre n'existe pas return $langs->trans("ErrorFileNotFound",$file); } elseif(image_format_supported($file) < 0) @@ -3349,11 +3355,11 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ return 'This file '.$file.' does not seem to be an image format file name.'; } elseif(!is_numeric($maxWidth) || empty($maxWidth) || $maxWidth < 0){ - // Si la largeur max est incorrecte (n'est pas numérique, est vide, ou est inférieure à 0) + // Si la largeur max est incorrecte (n'est pas num�rique, est vide, ou est inf�rieure � 0) return 'Valeur de la largeur incorrecte.'; } elseif(!is_numeric($maxHeight) || empty($maxHeight) || $maxHeight < 0){ - // Si la hauteur max est incorrecte (n'est pas numérique, est vide, ou est inférieure à 0) + // Si la hauteur max est incorrecte (n'est pas num�rique, est vide, ou est inf�rieure � 0) return 'Valeur de la hauteur incorrecte.'; } @@ -3361,16 +3367,16 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ $dir = dirname($file).'/'; // Chemin du dossier contenant l'image $dirthumb = $dir.'thumbs/'; // Chemin du dossier contenant les vignettes - $infoImg = getimagesize($fichier); // Récupération des infos de l'image + $infoImg = getimagesize($fichier); // R�cup�ration des infos de l'image $imgWidth = $infoImg[0]; // Largeur de l'image $imgHeight = $infoImg[1]; // Hauteur de l'image - // Si l'image est plus petite que la largeur et la hauteur max, on ne crée pas de vignette + // Si l'image est plus petite que la largeur et la hauteur max, on ne cr�e pas de vignette if ($infoImg[0] < $maxWidth && $infoImg[1] < $maxHeight) { // On cree toujours les vignettes dolibarr_syslog("File size is smaller than thumb size",LOG_DEBUG); - //return 'Le fichier '.$file.' ne nécessite pas de création de vignette'; + //return 'Le fichier '.$file.' ne n�cessite pas de cr�ation de vignette'; } $imgfonction=''; @@ -3398,7 +3404,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ } } - // On crée le répertoire contenant les vignettes + // On cr�e le r�pertoire contenant les vignettes if (! file_exists($dirthumb)) { create_exdir($dirthumb); @@ -3430,7 +3436,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ break; } - // Initialisation des dimensions de la vignette si elles sont supérieures à l'original + // Initialisation des dimensions de la vignette si elles sont sup�rieures � l'original if($maxWidth > $imgWidth){ $maxWidth = $imgWidth; } if($maxHeight > $imgHeight){ $maxHeight = $imgHeight; } @@ -3439,11 +3445,11 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ // Fixe les dimensions de la vignette if($whFact < $imgWhFact){ - // Si largeur déterminante + // Si largeur d�terminante $thumbWidth = $maxWidth; $thumbHeight = $thumbWidth / $imgWhFact; } else { - // Si hauteur déterminante + // Si hauteur d�terminante $thumbHeight = $maxHeight; $thumbWidth = $thumbHeight * $imgWhFact; } @@ -3453,7 +3459,7 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ // Create empty image if ($infoImg[2] == 1) { - // Compatibilité image GIF + // Compatibilit� image GIF $imgThumb = imagecreate($thumbWidth, $thumbHeight); } else @@ -3477,14 +3483,14 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ switch($infoImg[2]) { case 1: // Gif - $trans_colour = imagecolorallocate($imgThumb, 255, 255, 255); // On procède autrement pour le format GIF + $trans_colour = imagecolorallocate($imgThumb, 255, 255, 255); // On proc�de autrement pour le format GIF imagecolortransparent($imgThumb,$trans_colour); break; case 2: // Jpg $trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 0); break; case 3: // Png - imagealphablending($imgThumb,false); // Pour compatibilité sur certain système + imagealphablending($imgThumb,false); // Pour compatibilit� sur certain syst�me $trans_colour = imagecolorallocatealpha($imgThumb, 255, 255, 255, 127); // Keep transparent channel break; case 4: // Bmp @@ -3494,8 +3500,8 @@ function vignette($file, $maxWidth = 160, $maxHeight = 120, $extName='_small', $ if (function_exists("imagefill")) imagefill($imgThumb, 0, 0, $trans_colour); dolibarr_syslog("vignette: convert image from ($imgWidth x $imgHeight) to ($thumbWidth x $thumbHeight) as $extImg, newquality=$newquality"); - //imagecopyresized($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Insère l'image de base redimensionnée - imagecopyresampled($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Insère l'image de base redimensionnée + //imagecopyresized($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins�re l'image de base redimensionn�e + imagecopyresampled($imgThumb, $img, 0, 0, 0, 0, $thumbWidth, $thumbHeight, $imgWidth, $imgHeight); // Ins�re l'image de base redimensionn�e $fileName = eregi_replace('(\.gif|\.jpeg|\.jpg|\.png|\.bmp)$','',$file); // On enleve extension quelquesoit la casse $fileName = basename($fileName); @@ -3545,7 +3551,7 @@ function ConvertTime2Seconds($iHours=0,$iMinutes=0,$iSeconds=0) * \brief Converti les secondes en heures et minutes * \param iSecond Nombre de secondes * \param format Choix de l'affichage (all:affichage complet, hour: n'affiche que les heures, min: n'affiche que les minutes) - * \return sTime Temps formaté + * \return sTime Temps format� */ function ConvertSecondToTime($iSecond,$format='all'){ if ($format == 'all'){ @@ -3578,8 +3584,8 @@ function make_alpha_from_numbers($number) /* * \brief Affiche le contenu d'un fichier CSV sous forme de tableau - * \param file_to_include Fichier CSV à afficher - * \param max_rows Nombre max de lignes à afficher (0 = illimité) + * \param file_to_include Fichier CSV � afficher + * \param max_rows Nombre max de lignes � afficher (0 = illimit�) */ function viewCsvFileContent($file_to_include='',$max_rows=0) { @@ -3603,9 +3609,9 @@ function viewCsvFileContent($file_to_include='',$max_rows=0) /* * \brief Affiche le contenu d'un fichier Excel (avec les feuilles de calcul) sous forme de tableau - * \param file_to_include Fichier Excel à afficher - * \param max_rows Nombre max de lignes à afficher (0 = illimité) - * \param max_cols Nombre max de colonnes à afficher (0 = illimité) + * \param file_to_include Fichier Excel � afficher + * \param max_rows Nombre max de lignes � afficher (0 = illimit�) + * \param max_cols Nombre max de colonnes � afficher (0 = illimit�) */ function viewExcelFileContent($file_to_include='',$max_rows=0,$max_cols=0) { @@ -3735,10 +3741,10 @@ function viewExcelFileContent($file_to_include='',$max_rows=0,$max_cols=0) } /** - \brief Générateur de codes barres - \param $code Valeur numérique à coder + \brief G�n�rateur de codes barres + \param $code Valeur num�rique � coder \param $encoding Mode de codage - \param $generator Générateur utilisé (1=php-barcode, 2=pi_barcode) + \param $generator G�n�rateur utilis� (1=php-barcode, 2=pi_barcode) \param $readable Code lisible \return url */ @@ -3761,8 +3767,8 @@ function dol_genbarcode($code,$encoding,$generator=1,$readable='Y') } /** - \brief Retourne un tableau des mois ou le mois sélectionné - \param Mois sélectionné + \brief Retourne un tableau des mois ou le mois s�lectionn� + \param Mois s�lectionn� \return month */ function monthArrayOrSelected($selected=0)
'; print '