Zend_Locale-Migration.xml 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15666 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.locale.migration">
  5. <title>Migrieren von vorhergehenden Versionen</title>
  6. <para>
  7. Die API von <classname>Zend_Locale</classname> wurde von Zeit zu Zeit verändert. Wenn man
  8. begonnen hat <classname>Zend_Locale</classname> und seine Unterkomponenten in früheren
  9. Versionen dann sollte man den unteren Richtlinien folgen um die Skripte so zu migrieren das
  10. sie die neue API verwenden.
  11. </para>
  12. <sect2 id="zend.locale.migration.fromoneeighttoonenine">
  13. <title>Migrieren von 1.8 zu 1.9 oder neueren</title>
  14. <sect3 id="zend.locale.migration.fromoneeighttoonenine.depreciated">
  15. <title>Abgelaufene Methoden</title>
  16. <para>
  17. Einige spezialisiertere Übersetzungsmethoden stehen nicht mehr zur Verfügung weil
  18. Sie bestehende Verhaltensweisen duplizieren. Beachten Sie das die alten Methoden
  19. weiterhin funktionieren, aber eine Benutzer Notiz geworfen wird, die den neuen
  20. Aufruf beschreibt. Diese Methoden werden mit 2.0 entfernt. Die folgende Liste zeigt
  21. die alten und neuen Methodenaufrufe.
  22. </para>
  23. <table id="zend.locale.migration.fromoneeighttoonenine.depreciated.table-1">
  24. <title>List der Methodenaufrufe</title>
  25. <tgroup cols="2">
  26. <thead>
  27. <row>
  28. <entry>Alter Aufruf</entry>
  29. <entry>Neuer Aufruf</entry>
  30. </row>
  31. </thead>
  32. <tbody>
  33. <row>
  34. <entry>getLanguageTranslationList($locale)</entry>
  35. <entry>getTranslationList('language', $locale)</entry>
  36. </row>
  37. <row>
  38. <entry>getScriptTranslationList($locale)</entry>
  39. <entry>getTranslationList('script', $locale)</entry>
  40. </row>
  41. <row>
  42. <entry>getCountryTranslationList($locale)</entry>
  43. <entry>getTranslationList('territory', $locale, 2)</entry>
  44. </row>
  45. <row>
  46. <entry>getTerritoryTranslationList($locale)</entry>
  47. <entry>getTranslationList('territory', $locale, 1)</entry>
  48. </row>
  49. <row>
  50. <entry>getLanguageTranslation($value, $locale)</entry>
  51. <entry>getTranslation($value, 'language', $locale)</entry>
  52. </row>
  53. <row>
  54. <entry>getScriptTranslation($value, $locale)</entry>
  55. <entry>getTranslation($value, 'script', $locale)</entry>
  56. </row>
  57. <row>
  58. <entry>getCountryTranslation($value, $locale)</entry>
  59. <entry>getTranslation($value, 'country', $locale)</entry>
  60. </row>
  61. <row>
  62. <entry>getTerritoryTranslation($value, $locale)</entry>
  63. <entry>getTranslation($value, 'territory', $locale)</entry>
  64. </row>
  65. </tbody>
  66. </tgroup>
  67. </table>
  68. </sect3>
  69. </sect2>
  70. <sect2 id="zend.locale.migration.fromonesixtooneseven">
  71. <title>Migrieren von 1.6 oder 1.7 zu neueren</title>
  72. <sect3 id="zend.locale.migration.fromonesixtooneseven.islocale">
  73. <title>Änderungen bei der Verwendung von isLocale()</title>
  74. <para>
  75. Bezugnehmend auf den Codingstandard mußte isLocale() so geändert werden das es ein
  76. Boolean zurückgibt. In vorhergehenden Releases wurde im Erfolgsfall ein String
  77. zurückgegeben. Für das Release 1.7 wurde ein Kompatibilitätsmodus hinzugefügt der es
  78. erlaubt das alte Verhalten, das ein String zurückgegeben wird, zu verwenden, aber
  79. das triggert auch eine User Warning die darauf hinweist das man auf das neue
  80. Verhalten wechseln sollte. Das Rerouting welches das alte Verhalten von isLocale()
  81. durchgeführt hätte ist nicht länger notwendig, da alle I18N Komponenten jetzt das
  82. Rerouting selbst durchführen.
  83. </para>
  84. <para>
  85. Um die Skripte auf die neue API zu migrieren muß die Methode einfach wie anbei
  86. gezeigt verwendet werden.
  87. </para>
  88. <example id="zend.locale.migration.fromonesixtooneseven.example">
  89. <title>Wie man isLocale() von 1.6 nach 1.7 ändern muß</title>
  90. <programlisting language="php"><![CDATA[
  91. // Beispiel für 1.6
  92. if ($locale = Zend_Locale::isLocale($locale)) {
  93. // mach was
  94. }
  95. // Selbes Beispiel für 1.7
  96. // Man sollte den Kompatibilitätsmodus ändern um User Warnings zu verhindern
  97. // Aber man kann das in der Bootstrap tun
  98. Zend_Locale::$compatibilityMode = false;
  99. if (Zend_Locale::isLocale($locale)) {
  100. }
  101. ]]></programlisting>
  102. <para>
  103. Es ist zu beachten das man den zweiten Parameter verwendet kann um zu sehen ob
  104. das Gebietsschema richtig ist ohne das ein Rerouting durchgeführt wird.
  105. </para>
  106. <programlisting language="php"><![CDATA[
  107. // Beispiel für 1.6
  108. if ($locale = Zend_Locale::isLocale($locale, false)) {
  109. // mach was
  110. }
  111. // Selbes Beispiel für 1.7
  112. // Man sollte den Kompatibilitätsmodus ändern um User Warnings zu verhindern
  113. // Aber man kann das in der Bootstrap tun
  114. Zend_Locale::$compatibilityMode = false;
  115. if (Zend_Locale::isLocale($locale, false)) {
  116. if (Zend_Locale::isLocale($locale, true)) {
  117. // gar kein Gebietsschema
  118. }
  119. // Original String ist kein Gebietsschema, kann aber Reroutet werden
  120. }
  121. ]]></programlisting>
  122. </example>
  123. </sect3>
  124. <sect3 id="zend.locale.migration.fromonesixtooneseven.getdefault">
  125. <title>Änderungen bei der Verwendung von getDefault()</title>
  126. <para>
  127. Die Bedeutung der getDefault() Methode wurde verändert durch den Fakt das
  128. Framework-weite Gebietsschemata integriert wurden welche mit setDefault() gesetzt
  129. werden können. Deswegen gibe es nicht mehr die Kette der Gebietsschemata zurück
  130. sondern nur die gesetzten Framework-weiten Gebietsschemata.
  131. </para>
  132. <para>
  133. Um die eigenen Skripte auf die neue API zu migrieren, muß einfach die Methode wie
  134. unten gezeigt verwendet werden.
  135. </para>
  136. <example id="zend.locale.migration.fromonesixtooneseven.getdefault.example">
  137. <title>Wie man getDefault() von 1.6 auf 1.7 ändert</title>
  138. <programlisting language="php"><![CDATA[
  139. // Beispiel für 1.6
  140. $locales = $locale->getDefault(Zend_Locale::BROWSER);
  141. // Selbes Beispiel für 1.7
  142. // Man sollte den Compatibility Mode setzen um User Notices zu verhindern
  143. // Das kann in der Bootstrap Datei getan werden
  144. Zend_Locale::$compatibilityMode = false;
  145. $locale = Zend_Locale::getOrder(Zend_Locale::BROWSER);
  146. ]]></programlisting>
  147. <para>
  148. Es ist zu beachten das der zweite Parameter der alten getDefault()
  149. Implementation nicht mehr vorhanden ist, aber die zurückgegebenen Werte die
  150. gleichen sind.
  151. </para>
  152. </example>
  153. <note>
  154. <para>
  155. Standardmäßig ist das alte Verhalten noch immer aktiv, wirft aber eine User
  156. Notice. Wenn man den eigenen Code zum neuen Verhalten geändert hat sollte man
  157. auch den Compatibility Mode auf false setzen damit keine Notices mehr geworfen
  158. werden.
  159. </para>
  160. </note>
  161. </sect3>
  162. </sect2>
  163. </sect1>