bootstrap80.php 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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. use Symfony\Polyfill\Mbstring as p;
  11. if (!function_exists('mb_convert_encoding')) {
  12. function mb_convert_encoding(array|string $string, string $to_encoding, array|string|null $from_encoding = null): array|string|false { return p\Mbstring::mb_convert_encoding($string, $to_encoding, $from_encoding); }
  13. }
  14. if (!function_exists('mb_decode_mimeheader')) {
  15. function mb_decode_mimeheader(string $string): string { return p\Mbstring::mb_decode_mimeheader($string); }
  16. }
  17. if (!function_exists('mb_encode_mimeheader')) {
  18. function mb_encode_mimeheader(string $string, string $charset = null, string $transfer_encoding = null, string $newline = "\r\n", int $indent = 0): string { return p\Mbstring::mb_encode_mimeheader($string, $charset, $transfer_encoding, $newline, $indent); }
  19. }
  20. if (!function_exists('mb_decode_numericentity')) {
  21. function mb_decode_numericentity(string $string, array $map, string $encoding = null): string { return p\Mbstring::mb_decode_numericentity($string, $map, $encoding); }
  22. }
  23. if (!function_exists('mb_encode_numericentity')) {
  24. function mb_encode_numericentity(string $string, array $map, string $encoding = null, bool $hex = false): string { return p\Mbstring::mb_encode_numericentity($string, $map, $encoding, $hex); }
  25. }
  26. if (!function_exists('mb_convert_case')) {
  27. function mb_convert_case(string $string, int $mode, string $encoding = null): string { return p\Mbstring::mb_convert_case($string, $mode, $encoding); }
  28. }
  29. if (!function_exists('mb_internal_encoding')) {
  30. function mb_internal_encoding(string $encoding = null): string|bool { return p\Mbstring::mb_internal_encoding($encoding); }
  31. }
  32. if (!function_exists('mb_language')) {
  33. function mb_language(string $language = null): string|bool { return p\Mbstring::mb_language($language); }
  34. }
  35. if (!function_exists('mb_list_encodings')) {
  36. function mb_list_encodings(): array { return p\Mbstring::mb_list_encodings(); }
  37. }
  38. if (!function_exists('mb_encoding_aliases')) {
  39. function mb_encoding_aliases(string $encoding): array { return p\Mbstring::mb_encoding_aliases($encoding); }
  40. }
  41. if (!function_exists('mb_check_encoding')) {
  42. function mb_check_encoding(array|string|null $value = null, string $encoding = null): bool { return p\Mbstring::mb_check_encoding($value, $encoding); }
  43. }
  44. if (!function_exists('mb_detect_encoding')) {
  45. function mb_detect_encoding(string $string, array|string|null $encodings = null, bool $strict = false): string|false { return p\Mbstring::mb_detect_encoding($string, $encodings, $strict); }
  46. }
  47. if (!function_exists('mb_detect_order')) {
  48. function mb_detect_order(array|string|null $encoding = null): array|bool { return p\Mbstring::mb_detect_order($encoding); }
  49. }
  50. if (!function_exists('mb_parse_str')) {
  51. function mb_parse_str(string $string, &$result = array()): bool { parse_str($string, $result); }
  52. }
  53. if (!function_exists('mb_strlen')) {
  54. function mb_strlen(string $string, string $encoding = null): int { return p\Mbstring::mb_strlen($string, $encoding); }
  55. }
  56. if (!function_exists('mb_strpos')) {
  57. function mb_strpos(string $haystack, string $needle, int $offset = 0, string $encoding = null): int|false { return p\Mbstring::mb_strpos($haystack, $needle, $offset, $encoding); }
  58. }
  59. if (!function_exists('mb_strtolower')) {
  60. function mb_strtolower(string $string, string $encoding = null): string { return p\Mbstring::mb_strtolower($string, $encoding); }
  61. }
  62. if (!function_exists('mb_strtoupper')) {
  63. function mb_strtoupper(string $string, string $encoding = null): string { return p\Mbstring::mb_strtoupper($string, $encoding); }
  64. }
  65. if (!function_exists('mb_substitute_character')) {
  66. function mb_substitute_character(string|int|null $substitute_character = null): string|int|bool { return p\Mbstring::mb_substitute_character($substitute_character); }
  67. }
  68. if (!function_exists('mb_substr')) {
  69. function mb_substr(string $string, int $start, int $length = null, string $encoding = null): string { return p\Mbstring::mb_substr($string, $start, $length, $encoding); }
  70. }
  71. if (!function_exists('mb_stripos')) {
  72. function mb_stripos(string $haystack, string $needle, int $offset = 0, string $encoding = null): int|false { return p\Mbstring::mb_stripos($haystack, $needle, $offset, $encoding); }
  73. }
  74. if (!function_exists('mb_stristr')) {
  75. function mb_stristr(string $haystack, string $needle, bool $before_needle = false, string $encoding = null): string|false { return p\Mbstring::mb_stristr($haystack, $needle, $before_needle, $encoding); }
  76. }
  77. if (!function_exists('mb_strrchr')) {
  78. function mb_strrchr(string $haystack, string $needle, bool $before_needle = false, string $encoding = null): string|false { return p\Mbstring::mb_strrchr($haystack, $needle, $before_needle, $encoding); }
  79. }
  80. if (!function_exists('mb_strrichr')) {
  81. function mb_strrichr(string $haystack, string $needle, bool $before_needle = false, string $encoding = null): string|false { return p\Mbstring::mb_strrichr($haystack, $needle, $before_needle, $encoding); }
  82. }
  83. if (!function_exists('mb_strripos')) {
  84. function mb_strripos(string $haystack, string $needle, int $offset = 0, string $encoding = null): int|false { return p\Mbstring::mb_strripos($haystack, $needle, $offset, $encoding); }
  85. }
  86. if (!function_exists('mb_strrpos')) {
  87. function mb_strrpos(string $haystack, string $needle, int $offset = 0, string $encoding = null): int|false { return p\Mbstring::mb_strrpos($haystack, $needle, $offset, $encoding); }
  88. }
  89. if (!function_exists('mb_strstr')) {
  90. function mb_strstr(string $haystack, string $needle, bool $before_needle = false, string $encoding = null): string|false { return p\Mbstring::mb_strstr($haystack, $needle, $before_needle, $encoding); }
  91. }
  92. if (!function_exists('mb_get_info')) {
  93. function mb_get_info(string $type = 'all'): array|string|int|false { return p\Mbstring::mb_get_info($type); }
  94. }
  95. if (!function_exists('mb_http_output')) {
  96. function mb_http_output(string $encoding = null): string|bool { return p\Mbstring::mb_http_output($encoding); }
  97. }
  98. if (!function_exists('mb_strwidth')) {
  99. function mb_strwidth(string $string, string $encoding = null): int { return p\Mbstring::mb_strwidth($string, $encoding); }
  100. }
  101. if (!function_exists('mb_substr_count')) {
  102. function mb_substr_count(string $haystack, string $needle, string $encoding = null): int { return p\Mbstring::mb_substr_count($haystack, $needle, $encoding); }
  103. }
  104. if (!function_exists('mb_output_handler')) {
  105. function mb_output_handler(string $string, int $status): string { return p\Mbstring::mb_output_handler($string, $status); }
  106. }
  107. if (!function_exists('mb_http_input')) {
  108. function mb_http_input(string $type = null): array|string|false { return p\Mbstring::mb_http_input($type); }
  109. }
  110. if (!function_exists('mb_convert_variables')) {
  111. function mb_convert_variables(string $to_encoding, array|string $from_encoding, mixed &$var, mixed &...$vars): string|false { return p\Mbstring::mb_convert_variables($to_encoding, $from_encoding, $var, ...$vars); }
  112. }
  113. if (!function_exists('mb_ord')) {
  114. function mb_ord(string $string, string $encoding = null): int|false { return p\Mbstring::mb_ord($string, $encoding); }
  115. }
  116. if (!function_exists('mb_chr')) {
  117. function mb_chr(int $codepoint, string $encoding = null): string|false { return p\Mbstring::mb_chr($codepoint, $encoding); }
  118. }
  119. if (!function_exists('mb_scrub')) {
  120. function mb_scrub(string $string, string $encoding = null): string { $encoding ??= mb_internal_encoding(); return mb_convert_encoding($string, $encoding, $encoding); }
  121. }
  122. if (!function_exists('mb_str_split')) {
  123. function mb_str_split(string $string, int $length = 1, string $encoding = null): array { return p\Mbstring::mb_str_split($string, $length, $encoding); }
  124. }
  125. if (extension_loaded('mbstring')) {
  126. return;
  127. }
  128. if (!defined('MB_CASE_UPPER')) {
  129. define('MB_CASE_UPPER', 0);
  130. }
  131. if (!defined('MB_CASE_LOWER')) {
  132. define('MB_CASE_LOWER', 1);
  133. }
  134. if (!defined('MB_CASE_TITLE')) {
  135. define('MB_CASE_TITLE', 2);
  136. }