Skip to content

Commit 7e3855d

Browse files
feature #38974 [Intl] deprecate polyfills in favor of symfony/polyfill-intl-icu (nicolas-grekas)
This PR was merged into the 5.x branch. Discussion ---------- [Intl] deprecate polyfills in favor of symfony/polyfill-intl-icu | Q | A | ------------- | --- | Branch? | 5.x | Bug fix? | no | New feature? | no | Deprecations? | yes | Tickets | Fix #37758 | License | MIT | Doc PR | - Follows symfony/polyfill#310 /cc @stof Commits ------- 6ad0169 [Intl] deprecate polyfills in favor of symfony/polyfill-intl-icu
2 parents b285584 + 6ad0169 commit 7e3855d

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

43 files changed

+242
-48
lines changed

src/Symfony/Component/Form/composer.json

+1-1
Original file line numberDiff line numberDiff line change
@@ -22,6 +22,7 @@
2222
"symfony/intl": "^4.4|^5.0",
2323
"symfony/options-resolver": "^5.1",
2424
"symfony/polyfill-ctype": "~1.8",
25+
"symfony/polyfill-intl-icu": "^1.21",
2526
"symfony/polyfill-mbstring": "~1.0",
2627
"symfony/polyfill-php80": "^1.15",
2728
"symfony/property-access": "^5.0.8",
@@ -48,7 +49,6 @@
4849
"symfony/error-handler": "<4.4.5",
4950
"symfony/framework-bundle": "<4.4",
5051
"symfony/http-kernel": "<4.4",
51-
"symfony/intl": "<4.4",
5252
"symfony/translation": "<4.4",
5353
"symfony/translation-contracts": "<1.1.7",
5454
"symfony/twig-bridge": "<4.4"

src/Symfony/Component/Intl/Collator/Collator.php

+2
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,8 @@
3232
* @author Bernhard Schussek <[email protected]>
3333
*
3434
* @internal
35+
*
36+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
3537
*/
3638
abstract class Collator
3739
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/AmPmTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class AmPmTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/DayOfWeekTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class DayOfWeekTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/DayOfYearTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class DayOfYearTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/DayTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class DayTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/FullTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -20,6 +20,8 @@
2020
* @author Igor Wiedler <[email protected]>
2121
*
2222
* @internal
23+
*
24+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2325
*/
2426
class FullTransformer
2527
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/Hour1200Transformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class Hour1200Transformer extends HourTransformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/Hour1201Transformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class Hour1201Transformer extends HourTransformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/Hour2400Transformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class Hour2400Transformer extends HourTransformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/Hour2401Transformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class Hour2401Transformer extends HourTransformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/HourTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Eriksen Costa <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
abstract class HourTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/MinuteTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class MinuteTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/MonthTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class MonthTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/QuarterTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class QuarterTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/SecondTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class SecondTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/TimezoneTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,8 @@
1919
* @author Igor Wiedler <[email protected]>
2020
*
2121
* @internal
22+
*
23+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2224
*/
2325
class TimezoneTransformer extends Transformer
2426
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/Transformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
abstract class Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/DateFormat/YearTransformer.php

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@
1717
* @author Igor Wiedler <[email protected]>
1818
*
1919
* @internal
20+
*
21+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2022
*/
2123
class YearTransformer extends Transformer
2224
{

src/Symfony/Component/Intl/DateFormatter/IntlDateFormatter.php

+2
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,8 @@
4545
* @author Bernhard Schussek <[email protected]>
4646
*
4747
* @internal
48+
*
49+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
4850
*/
4951
abstract class IntlDateFormatter
5052
{

src/Symfony/Component/Intl/Exception/MethodArgumentNotImplementedException.php

+2
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313

1414
/**
1515
* @author Eriksen Costa <[email protected]>
16+
*
17+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
1618
*/
1719
class MethodArgumentNotImplementedException extends NotImplementedException
1820
{

src/Symfony/Component/Intl/Exception/MethodArgumentValueNotImplementedException.php

+2
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313

1414
/**
1515
* @author Eriksen Costa <[email protected]>
16+
*
17+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
1618
*/
1719
class MethodArgumentValueNotImplementedException extends NotImplementedException
1820
{

src/Symfony/Component/Intl/Exception/MethodNotImplementedException.php

+2
Original file line numberDiff line numberDiff line change
@@ -13,6 +13,8 @@
1313

1414
/**
1515
* @author Eriksen Costa <[email protected]>
16+
*
17+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
1618
*/
1719
class MethodNotImplementedException extends NotImplementedException
1820
{

src/Symfony/Component/Intl/Exception/NotImplementedException.php

+2
Original file line numberDiff line numberDiff line change
@@ -15,6 +15,8 @@
1515
* Base exception class for not implemented behaviors of the intl extension in the Locale component.
1616
*
1717
* @author Eriksen Costa <[email protected]>
18+
*
19+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
1820
*/
1921
class NotImplementedException extends RuntimeException
2022
{

src/Symfony/Component/Intl/Globals/IntlGlobals.php

+32
Original file line numberDiff line numberDiff line change
@@ -11,12 +11,16 @@
1111

1212
namespace Symfony\Component\Intl\Globals;
1313

14+
use Symfony\Polyfill\Intl\Icu\Icu;
15+
1416
/**
1517
* Provides fake static versions of the global functions in the intl extension.
1618
*
1719
* @author Bernhard Schussek <[email protected]>
1820
*
1921
* @internal
22+
*
23+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2024
*/
2125
abstract class IntlGlobals
2226
{
@@ -61,6 +65,12 @@ abstract class IntlGlobals
6165
*/
6266
public static function isFailure(int $errorCode): bool
6367
{
68+
if (class_exists(Icu::class)) {
69+
return Icu::isFailure($errorCode);
70+
}
71+
72+
trigger_deprecation('symfony/intl', '5.3', 'Polyfills are deprecated, try running "composer require symfony/polyfill-intl-icu ^1.21" instead.');
73+
6474
return isset(self::$errorCodes[$errorCode])
6575
&& $errorCode > self::U_ZERO_ERROR;
6676
}
@@ -74,6 +84,12 @@ public static function isFailure(int $errorCode): bool
7484
*/
7585
public static function getErrorCode()
7686
{
87+
if (class_exists(Icu::class)) {
88+
return Icu::getErrorCode();
89+
}
90+
91+
trigger_deprecation('symfony/intl', '5.3', 'Polyfills are deprecated, try running "composer require symfony/polyfill-intl-icu ^1.21" instead.');
92+
7793
return self::$errorCode;
7894
}
7995

@@ -84,6 +100,12 @@ public static function getErrorCode()
84100
*/
85101
public static function getErrorMessage(): string
86102
{
103+
if (class_exists(Icu::class)) {
104+
return Icu::getErrorMessage();
105+
}
106+
107+
trigger_deprecation('symfony/intl', '5.3', 'Polyfills are deprecated, try running "composer require symfony/polyfill-intl-icu ^1.21" instead.');
108+
87109
return self::$errorMessage;
88110
}
89111

@@ -94,6 +116,12 @@ public static function getErrorMessage(): string
94116
*/
95117
public static function getErrorName(int $code): string
96118
{
119+
if (class_exists(Icu::class)) {
120+
return Icu::getErrorName($code);
121+
}
122+
123+
trigger_deprecation('symfony/intl', '5.3', 'Polyfills are deprecated, try running "composer require symfony/polyfill-intl-icu ^1.21" instead.');
124+
97125
return self::$errorCodes[$code] ?? '[BOGUS UErrorCode]';
98126
}
99127

@@ -107,6 +135,10 @@ public static function getErrorName(int $code): string
107135
*/
108136
public static function setError(int $code, string $message = '')
109137
{
138+
if (class_exists(Icu::class)) {
139+
return Icu::setError($code, $message);
140+
}
141+
110142
if (!isset(self::$errorCodes[$code])) {
111143
throw new \InvalidArgumentException(sprintf('No such error code: "%s".', $code));
112144
}

src/Symfony/Component/Intl/Locale/Locale.php

+2
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,8 @@
2323
* @author Bernhard Schussek <[email protected]>
2424
*
2525
* @internal
26+
*
27+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
2628
*/
2729
abstract class Locale
2830
{

src/Symfony/Component/Intl/NumberFormatter/NumberFormatter.php

+2
Original file line numberDiff line numberDiff line change
@@ -39,6 +39,8 @@
3939
* @author Bernhard Schussek <[email protected]>
4040
*
4141
* @internal
42+
*
43+
* @deprecated since Symfony 5.3, use symfony/polyfill-intl-icu ^1.21 instead
4244
*/
4345
abstract class NumberFormatter
4446
{

src/Symfony/Component/Intl/README.md

+1-7
Original file line numberDiff line numberDiff line change
@@ -1,11 +1,7 @@
11
Intl Component
22
=============
33

4-
A PHP replacement layer for the C intl extension that also provides access to
5-
the localization data of the ICU library.
6-
7-
The replacement layer is limited to the locale "en". If you want to use other
8-
locales, you should [install the intl PHP extension][0] instead.
4+
This package provides access to the CLDR localization data of the ICU library.
95

106
Resources
117
---------
@@ -17,5 +13,3 @@ Resources
1713
in the [main Symfony repository](https://github.com/symfony/symfony)
1814
* [Docker images with intl support](https://hub.docker.com/r/jakzal/php-intl)
1915
(for the Intl component development)
20-
21-
[0]: https://php.net/intl.setup
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,37 @@
1+
<?php
2+
3+
/*
4+
* This file is part of the Symfony package.
5+
*
6+
* (c) Fabien Potencier <[email protected]>
7+
*
8+
* For the full copyright and license information, please view the LICENSE
9+
* file that was distributed with this source code.
10+
*/
11+
12+
use Symfony\Component\Intl\Globals\IntlGlobals;
13+
14+
if (!function_exists('intl_is_failure')) {
15+
function intl_is_failure($error_code)
16+
{
17+
return IntlGlobals::isFailure($error_code);
18+
}
19+
}
20+
if (!function_exists('intl_get_error_code')) {
21+
function intl_get_error_code()
22+
{
23+
return IntlGlobals::getErrorCode();
24+
}
25+
}
26+
if (!function_exists('intl_get_error_message')) {
27+
function intl_get_error_message()
28+
{
29+
return IntlGlobals::getErrorMessage();
30+
}
31+
}
32+
if (!function_exists('intl_error_name')) {
33+
function intl_error_name($error_code)
34+
{
35+
return IntlGlobals::getErrorName($error_code);
36+
}
37+
}

0 commit comments

Comments
 (0)