2
0

Zend_Locale-Migration.xml 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15617 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.locale.migration">
  5. <title>Migrer à partir des versions précédentes</title>
  6. <para>
  7. L'API de <classname>Zend_Locale</classname> a changé au cours du temps. Si vous avez
  8. commencé à utiliser <classname>Zend_Locale</classname> et ses sous-composants avec les
  9. versions précédentes, suivez les lignes directrices ci-dessous pour migrer vos scripts et
  10. ainsi utiliser la nouvelle API.
  11. </para>
  12. <sect2 id="zend.locale.migration.fromonesixtooneseven">
  13. <title>Migrer de la version 1.6 vers 1.7 ou plus récent</title>
  14. <sect3 id="zend.locale.migration.fromonesixtooneseven.islocale">
  15. <title>Changement dans l'utilisation de isLocale()</title>
  16. <para>
  17. Conformément aux standards de codage <code>isLocale()</code> a été changé pour
  18. retourner un booléen. Dans les versions précédentes une chaîne était retournée lors
  19. du succès. Pour la version 1.7 un mode de compatibilité a été ajouté qui vous permet
  20. d'utiliser l'ancien comportement (avec une chaîne retournée), mais ceci émet un
  21. warning pour vous informer de changer vers le nouveau comportement. Le reroutage que
  22. l'ancien comportement de <code>isLocale()</code> pouvait avoir à faire n'est plus
  23. nécessaire car tous les composants de l'I18N traiteront maintenant eux-mêmes le
  24. reroutage.
  25. </para>
  26. <para>
  27. Pour migrer vos scripts vers la nouvelle API, utilisez simplement la méthode
  28. décrite ci-dessous.
  29. </para>
  30. <example id="zend.locale.migration.fromonesixtooneseven.example">
  31. <title>Comment changer l'appel de isLocale() de 1.6 vers 1.7 ?</title>
  32. <programlisting language="php"><![CDATA[
  33. // Exemple pour ZF 1.6
  34. if ($locale = Zend_Locale::isLocale($locale)) {
  35. // faire qqch
  36. }
  37. // Même exemple pour ZF 1.7
  38. // Vous devez changer le mode de compatibilité pour empêcher l'émission de warning
  39. // Mais ceci peut être fait dans votre bootstrap
  40. Zend_Locale::$compatibilityMode = false;
  41. if (Zend_Locale::isLocale($locale)) {
  42. }
  43. ]]></programlisting>
  44. <para>
  45. Notez que vous pouvez utiliser le second paramètre pour voir si la locale
  46. est correcte sans nécessiter de reroutage.
  47. </para>
  48. <programlisting language="php"><![CDATA[
  49. // Exemple pour ZF 1.6
  50. if ($locale = Zend_Locale::isLocale($locale, false)) {
  51. // do something
  52. }
  53. // Même exemple pour ZF 1.7
  54. // Vous devez changer le mode de compatibilité pour empêcher l'émission de warning
  55. // Mais ceci peut être fait dans votre bootstrap
  56. Zend_Locale::$compatibilityMode = false;
  57. if (Zend_Locale::isLocale($locale, false)) {
  58. if (Zend_Locale::isLocale($locale, true)) {
  59. // pas de locale du tout
  60. }
  61. // original string is no locale but can be rerouted
  62. }
  63. ]]></programlisting>
  64. </example>
  65. </sect3>
  66. <sect3 id="zend.locale.migration.fromonesixtooneseven.getdefault">
  67. <title>Changement dans l'utilisation de getDefault()</title>
  68. <para>
  69. La signification de la méthode <code>getDefault()</code> a été changé étant
  70. donné que nous avons intégré une locale de framework qui peut être paramétrée avec
  71. <code>setDefault()</code>. Ceci ne renvoie plus la chaîne de la locale mais
  72. seulement la locale du framework.
  73. </para>
  74. <para>
  75. Pour migrer vos scripts vers la nouvelle API, utilisez simplement la méthode
  76. décrite ci-dessous.
  77. </para>
  78. <example id="zend.locale.migration.fromonesixtooneseven.getdefault.example">
  79. <title>Comment changer l'appel de getDefaut() de 1.6 vers 1.7 ?</title>
  80. <programlisting language="php"><![CDATA[
  81. // Exemple pour ZF 1.6
  82. $locales = $locale->getDefault(Zend_Locale::BROWSER);
  83. // Même exemple pour ZF 1.7
  84. // Vous devez changer le mode de compatibilité pour empêcher l'émission de warning
  85. // Mais ceci peut être fait dans votre bootstrap
  86. Zend_Locale::$compatibilityMode = false;
  87. $locale = Zend_Locale::getOrder(Zend_Locale::BROWSER);
  88. ]]></programlisting>
  89. <para>
  90. Notez que le second paramètre de l'ancienne implémentation de
  91. <code>getDefault()</code> n'est plus disponible non plus, mais les valeurs
  92. retournées sont les mêmes.
  93. </para>
  94. </example>
  95. <note>
  96. <para>
  97. Par défaut l'ancien comportement est toujours actif, mais émet un warning.
  98. Quand vous avez changé votre code vers le nouveau comportement, vous devriez
  99. aussi changer le mode de compatibilité à <code>false</code> ainsi aucun nouveau
  100. warning ne sera émis.
  101. </para>
  102. </note>
  103. </sect3>
  104. </sect2>
  105. </sect1>