IntlCaster.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. <?php
  2. /*
  3. * This file is part of the Symfony package.
  4. *
  5. * (c) Fabien Potencier <fabien@symfony.com>
  6. *
  7. * For the full copyright and license information, please view the LICENSE
  8. * file that was distributed with this source code.
  9. */
  10. namespace Symfony\Component\VarDumper\Caster;
  11. use Symfony\Component\VarDumper\Cloner\Stub;
  12. /**
  13. * @author Nicolas Grekas <p@tchwork.com>
  14. * @author Jan Schädlich <jan.schaedlich@sensiolabs.de>
  15. *
  16. * @final
  17. *
  18. * @internal since Symfony 7.3
  19. */
  20. class IntlCaster
  21. {
  22. public static function castMessageFormatter(\MessageFormatter $c, array $a, Stub $stub, bool $isNested): array
  23. {
  24. $a += [
  25. Caster::PREFIX_VIRTUAL.'locale' => $c->getLocale(),
  26. Caster::PREFIX_VIRTUAL.'pattern' => $c->getPattern(),
  27. ];
  28. return self::castError($c, $a);
  29. }
  30. public static function castNumberFormatter(\NumberFormatter $c, array $a, Stub $stub, bool $isNested, int $filter = 0): array
  31. {
  32. $a += [
  33. Caster::PREFIX_VIRTUAL.'locale' => $c->getLocale(),
  34. Caster::PREFIX_VIRTUAL.'pattern' => $c->getPattern(),
  35. ];
  36. if ($filter & Caster::EXCLUDE_VERBOSE) {
  37. $stub->cut += 3;
  38. return self::castError($c, $a);
  39. }
  40. $a += [
  41. Caster::PREFIX_VIRTUAL.'attributes' => new EnumStub(
  42. [
  43. 'PARSE_INT_ONLY' => $c->getAttribute(\NumberFormatter::PARSE_INT_ONLY),
  44. 'GROUPING_USED' => $c->getAttribute(\NumberFormatter::GROUPING_USED),
  45. 'DECIMAL_ALWAYS_SHOWN' => $c->getAttribute(\NumberFormatter::DECIMAL_ALWAYS_SHOWN),
  46. 'MAX_INTEGER_DIGITS' => $c->getAttribute(\NumberFormatter::MAX_INTEGER_DIGITS),
  47. 'MIN_INTEGER_DIGITS' => $c->getAttribute(\NumberFormatter::MIN_INTEGER_DIGITS),
  48. 'INTEGER_DIGITS' => $c->getAttribute(\NumberFormatter::INTEGER_DIGITS),
  49. 'MAX_FRACTION_DIGITS' => $c->getAttribute(\NumberFormatter::MAX_FRACTION_DIGITS),
  50. 'MIN_FRACTION_DIGITS' => $c->getAttribute(\NumberFormatter::MIN_FRACTION_DIGITS),
  51. 'FRACTION_DIGITS' => $c->getAttribute(\NumberFormatter::FRACTION_DIGITS),
  52. 'MULTIPLIER' => $c->getAttribute(\NumberFormatter::MULTIPLIER),
  53. 'GROUPING_SIZE' => $c->getAttribute(\NumberFormatter::GROUPING_SIZE),
  54. 'ROUNDING_MODE' => $c->getAttribute(\NumberFormatter::ROUNDING_MODE),
  55. 'ROUNDING_INCREMENT' => $c->getAttribute(\NumberFormatter::ROUNDING_INCREMENT),
  56. 'FORMAT_WIDTH' => $c->getAttribute(\NumberFormatter::FORMAT_WIDTH),
  57. 'PADDING_POSITION' => $c->getAttribute(\NumberFormatter::PADDING_POSITION),
  58. 'SECONDARY_GROUPING_SIZE' => $c->getAttribute(\NumberFormatter::SECONDARY_GROUPING_SIZE),
  59. 'SIGNIFICANT_DIGITS_USED' => $c->getAttribute(\NumberFormatter::SIGNIFICANT_DIGITS_USED),
  60. 'MIN_SIGNIFICANT_DIGITS' => $c->getAttribute(\NumberFormatter::MIN_SIGNIFICANT_DIGITS),
  61. 'MAX_SIGNIFICANT_DIGITS' => $c->getAttribute(\NumberFormatter::MAX_SIGNIFICANT_DIGITS),
  62. 'LENIENT_PARSE' => $c->getAttribute(\NumberFormatter::LENIENT_PARSE),
  63. ]
  64. ),
  65. Caster::PREFIX_VIRTUAL.'text_attributes' => new EnumStub(
  66. [
  67. 'POSITIVE_PREFIX' => $c->getTextAttribute(\NumberFormatter::POSITIVE_PREFIX),
  68. 'POSITIVE_SUFFIX' => $c->getTextAttribute(\NumberFormatter::POSITIVE_SUFFIX),
  69. 'NEGATIVE_PREFIX' => $c->getTextAttribute(\NumberFormatter::NEGATIVE_PREFIX),
  70. 'NEGATIVE_SUFFIX' => $c->getTextAttribute(\NumberFormatter::NEGATIVE_SUFFIX),
  71. 'PADDING_CHARACTER' => $c->getTextAttribute(\NumberFormatter::PADDING_CHARACTER),
  72. 'CURRENCY_CODE' => $c->getTextAttribute(\NumberFormatter::CURRENCY_CODE),
  73. 'DEFAULT_RULESET' => $c->getTextAttribute(\NumberFormatter::DEFAULT_RULESET),
  74. 'PUBLIC_RULESETS' => $c->getTextAttribute(\NumberFormatter::PUBLIC_RULESETS),
  75. ]
  76. ),
  77. Caster::PREFIX_VIRTUAL.'symbols' => new EnumStub(
  78. [
  79. 'DECIMAL_SEPARATOR_SYMBOL' => $c->getSymbol(\NumberFormatter::DECIMAL_SEPARATOR_SYMBOL),
  80. 'GROUPING_SEPARATOR_SYMBOL' => $c->getSymbol(\NumberFormatter::GROUPING_SEPARATOR_SYMBOL),
  81. 'PATTERN_SEPARATOR_SYMBOL' => $c->getSymbol(\NumberFormatter::PATTERN_SEPARATOR_SYMBOL),
  82. 'PERCENT_SYMBOL' => $c->getSymbol(\NumberFormatter::PERCENT_SYMBOL),
  83. 'ZERO_DIGIT_SYMBOL' => $c->getSymbol(\NumberFormatter::ZERO_DIGIT_SYMBOL),
  84. 'DIGIT_SYMBOL' => $c->getSymbol(\NumberFormatter::DIGIT_SYMBOL),
  85. 'MINUS_SIGN_SYMBOL' => $c->getSymbol(\NumberFormatter::MINUS_SIGN_SYMBOL),
  86. 'PLUS_SIGN_SYMBOL' => $c->getSymbol(\NumberFormatter::PLUS_SIGN_SYMBOL),
  87. 'CURRENCY_SYMBOL' => $c->getSymbol(\NumberFormatter::CURRENCY_SYMBOL),
  88. 'INTL_CURRENCY_SYMBOL' => $c->getSymbol(\NumberFormatter::INTL_CURRENCY_SYMBOL),
  89. 'MONETARY_SEPARATOR_SYMBOL' => $c->getSymbol(\NumberFormatter::MONETARY_SEPARATOR_SYMBOL),
  90. 'EXPONENTIAL_SYMBOL' => $c->getSymbol(\NumberFormatter::EXPONENTIAL_SYMBOL),
  91. 'PERMILL_SYMBOL' => $c->getSymbol(\NumberFormatter::PERMILL_SYMBOL),
  92. 'PAD_ESCAPE_SYMBOL' => $c->getSymbol(\NumberFormatter::PAD_ESCAPE_SYMBOL),
  93. 'INFINITY_SYMBOL' => $c->getSymbol(\NumberFormatter::INFINITY_SYMBOL),
  94. 'NAN_SYMBOL' => $c->getSymbol(\NumberFormatter::NAN_SYMBOL),
  95. 'SIGNIFICANT_DIGIT_SYMBOL' => $c->getSymbol(\NumberFormatter::SIGNIFICANT_DIGIT_SYMBOL),
  96. 'MONETARY_GROUPING_SEPARATOR_SYMBOL' => $c->getSymbol(\NumberFormatter::MONETARY_GROUPING_SEPARATOR_SYMBOL),
  97. ]
  98. ),
  99. ];
  100. return self::castError($c, $a);
  101. }
  102. public static function castIntlTimeZone(\IntlTimeZone $c, array $a, Stub $stub, bool $isNested): array
  103. {
  104. $a += [
  105. Caster::PREFIX_VIRTUAL.'display_name' => $c->getDisplayName(),
  106. Caster::PREFIX_VIRTUAL.'id' => $c->getID(),
  107. Caster::PREFIX_VIRTUAL.'raw_offset' => $c->getRawOffset(),
  108. ];
  109. if ($c->useDaylightTime()) {
  110. $a += [
  111. Caster::PREFIX_VIRTUAL.'dst_savings' => $c->getDSTSavings(),
  112. ];
  113. }
  114. return self::castError($c, $a);
  115. }
  116. public static function castIntlCalendar(\IntlCalendar $c, array $a, Stub $stub, bool $isNested, int $filter = 0): array
  117. {
  118. $a += [
  119. Caster::PREFIX_VIRTUAL.'type' => $c->getType(),
  120. Caster::PREFIX_VIRTUAL.'first_day_of_week' => $c->getFirstDayOfWeek(),
  121. Caster::PREFIX_VIRTUAL.'minimal_days_in_first_week' => $c->getMinimalDaysInFirstWeek(),
  122. Caster::PREFIX_VIRTUAL.'repeated_wall_time_option' => $c->getRepeatedWallTimeOption(),
  123. Caster::PREFIX_VIRTUAL.'skipped_wall_time_option' => $c->getSkippedWallTimeOption(),
  124. Caster::PREFIX_VIRTUAL.'time' => $c->getTime(),
  125. Caster::PREFIX_VIRTUAL.'in_daylight_time' => $c->inDaylightTime(),
  126. Caster::PREFIX_VIRTUAL.'is_lenient' => $c->isLenient(),
  127. Caster::PREFIX_VIRTUAL.'time_zone' => ($filter & Caster::EXCLUDE_VERBOSE) ? new CutStub($c->getTimeZone()) : $c->getTimeZone(),
  128. ];
  129. return self::castError($c, $a);
  130. }
  131. public static function castIntlDateFormatter(\IntlDateFormatter $c, array $a, Stub $stub, bool $isNested, int $filter = 0): array
  132. {
  133. $a += [
  134. Caster::PREFIX_VIRTUAL.'locale' => $c->getLocale(),
  135. Caster::PREFIX_VIRTUAL.'pattern' => $c->getPattern(),
  136. Caster::PREFIX_VIRTUAL.'calendar' => $c->getCalendar(),
  137. Caster::PREFIX_VIRTUAL.'time_zone_id' => $c->getTimeZoneId(),
  138. Caster::PREFIX_VIRTUAL.'time_type' => $c->getTimeType(),
  139. Caster::PREFIX_VIRTUAL.'date_type' => $c->getDateType(),
  140. Caster::PREFIX_VIRTUAL.'calendar_object' => ($filter & Caster::EXCLUDE_VERBOSE) ? new CutStub($c->getCalendarObject()) : $c->getCalendarObject(),
  141. Caster::PREFIX_VIRTUAL.'time_zone' => ($filter & Caster::EXCLUDE_VERBOSE) ? new CutStub($c->getTimeZone()) : $c->getTimeZone(),
  142. ];
  143. return self::castError($c, $a);
  144. }
  145. private static function castError(object $c, array $a): array
  146. {
  147. if ($errorCode = $c->getErrorCode()) {
  148. $a += [
  149. Caster::PREFIX_VIRTUAL.'error_code' => $errorCode,
  150. Caster::PREFIX_VIRTUAL.'error_message' => $c->getErrorMessage(),
  151. ];
  152. }
  153. return $a;
  154. }
  155. }