Rechercher une fonction PHP

Modifications entrainant une incompatibilité ascendante

Bien que la plupart du code PHP 5 existant devrait fonctionner sans aucune modification, vous devez prendre en considération quelques incompatibilités ascendantes :

Abandon du support de Windows XP et 2003

Le support de Windows XP et 2003 a été supprimé. Les binaires Windows de PHP requièrent maintenant Windows Vista ou supérieur.

Retour à la première page de Manuel PHP  Table des matières Haut

La sensibilité à la casse ne dépend plus de la locale utilisée

Toutes les comparaisons insensibles à la casse pour les noms de fonctions, de classes, et de constantes sont maintenant indépendantes de la locale utilisée, et respectent les règles ASCII. Ceci permet une meilleure prise en charge des langues utilisant l'alphabet latin avec des règles d'assemblage inhabituelles, comme le turc et l'azerbaïdjan.

Ceci peut avoir des impacts sur le code qui utilise l'insensibilité à la casse pour des caractères non-ASCII avec des jeux de caractères multi-octets (incluant l'UTF-8), comme les caractères accentués pour de nombreuses langues européennes. Si vous avez du code basé sur des langues non-anglaises, et non-ASCII, alors vous devriez tester que vous n'êtes pas impacté par ce changement de comportement avant de déployer PHP 5.5 en environnement de production.

Modifications des fonctions pack() et unpack()

Des modifications ont été réalisées sur les fonctions pack() et unpack() pour les rendre plus compatible avec Perl :

  • pack() supporte maintenant le code format "Z", dont le comportement est identique à "a".
  • unpack() supporte maintenant le code format "Z" pour les chaînes de caractères complétées avec la valeur NULL, et se comporte comme "a" dans les précédentes versions : il va supprimer les octets NULL finaux.
  • unpack() conserve maintenant les octets NULL finaux lorsque le code format "a" est utilisé.
  • unpack() supprime maintenant les espaces blancs ASCII finaux lorsque le code format "A" est utilisé.

L'écriture de code compatible de façon ascendante qui utilise le code format "a" avec la fonction unpack() requiert l'utilisation de la fonction version_compare(), en raison de cette cassure de compatiblité ascendante.

Par exemple :

<?php
// Ancien code :
$data unpack('a5'$packed);

// Nouveau code :
if (version_compare(PHP_VERSION'5.5.0-dev''>=')) {
  
$data unpack('Z5'$packed);
} else {
  
$data unpack('a5'$packed);
}
?>

self, parent et static sont maintenant insensible à la casse

Avant PHP 5.5, des cas existaient où les mots clés self, parent et static étaient traités de façon sensible à la casse. Ceci a maintenant été résolu, et ces mots clés sont toujours gérés de façon insensible à la casse : SELF::CONSTANT est maintenant traité exactement comme self::CONSTANT.

Retour à la première page de Manuel PHP  Table des matières Haut

Suppression des logos PHP GUIDs

Les GUIDs qui permettaient précédemment l'affichage de divers logos PHP ont été supprimés. Ceci inclut la suppression des fonctions qui retournaient ces GUIDs. Voici une liste des fonctions supprimées :

Retour à la première page de Manuel PHP  Table des matières Haut

Modification dans l'exécution interne

Les auteurs d'extensions devraient noter que la fonction zend_execute() ne peut plus être surchargée, et que de nombreux changements ont été effectués sur la structure execute_data ainsi que sur les fonctions associées et sur les opcodes de gestion de méthodes.

La plupart des extensions ne sont normalement pas affectées par ces modifications, mais celles profondément ancrées dans le moteur Zend le seront, et nous recommandons à leurs auteurs de lire les notes relatives à ces modifications.

Rechercher une fonction PHP

Document créé le 30/01/2003, dernière modification le 26/10/2018
Source du document imprimé : https://www.gaudry.be/php-rf-migration55.incompatible.html

L'infobrol est un site personnel dont le contenu n'engage que moi. Le texte est mis à disposition sous licence CreativeCommons(BY-NC-SA). Plus d'info sur les conditions d'utilisation et sur l'auteur.

Références

  1. Consulter le document html Langue du document :fr Manuel PHP : http://php.net

Ces références et liens indiquent des documents consultés lors de la rédaction de cette page, ou qui peuvent apporter un complément d'information, mais les auteurs de ces sources ne peuvent être tenus responsables du contenu de cette page.
L'auteur de ce site est seul responsable de la manière dont sont présentés ici les différents concepts, et des libertés qui sont prises avec les ouvrages de référence. N'oubliez pas que vous devez croiser les informations de sources multiples afin de diminuer les risques d'erreurs.

Table des matières Haut