the middle of the idiots
This commit is contained in:
		
							
								
								
									
										5
									
								
								qwen/php/vendor/symfony/deprecation-contracts/CHANGELOG.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								qwen/php/vendor/symfony/deprecation-contracts/CHANGELOG.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,5 @@
 | 
			
		||||
CHANGELOG
 | 
			
		||||
=========
 | 
			
		||||
 | 
			
		||||
The changelog is maintained for all Symfony contracts at the following URL:
 | 
			
		||||
https://github.com/symfony/contracts/blob/main/CHANGELOG.md
 | 
			
		||||
							
								
								
									
										19
									
								
								qwen/php/vendor/symfony/deprecation-contracts/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								qwen/php/vendor/symfony/deprecation-contracts/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,19 @@
 | 
			
		||||
Copyright (c) 2020-present Fabien Potencier
 | 
			
		||||
 | 
			
		||||
Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
in the Software without restriction, including without limitation the rights
 | 
			
		||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
copies of the Software, and to permit persons to whom the Software is furnished
 | 
			
		||||
to do so, subject to the following conditions:
 | 
			
		||||
 | 
			
		||||
The above copyright notice and this permission notice shall be included in all
 | 
			
		||||
copies or substantial portions of the Software.
 | 
			
		||||
 | 
			
		||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
THE SOFTWARE.
 | 
			
		||||
							
								
								
									
										26
									
								
								qwen/php/vendor/symfony/deprecation-contracts/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								qwen/php/vendor/symfony/deprecation-contracts/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,26 @@
 | 
			
		||||
Symfony Deprecation Contracts
 | 
			
		||||
=============================
 | 
			
		||||
 | 
			
		||||
A generic function and convention to trigger deprecation notices.
 | 
			
		||||
 | 
			
		||||
This package provides a single global function named `trigger_deprecation()` that triggers silenced deprecation notices.
 | 
			
		||||
 | 
			
		||||
By using a custom PHP error handler such as the one provided by the Symfony ErrorHandler component,
 | 
			
		||||
the triggered deprecations can be caught and logged for later discovery, both on dev and prod environments.
 | 
			
		||||
 | 
			
		||||
The function requires at least 3 arguments:
 | 
			
		||||
 - the name of the Composer package that is triggering the deprecation
 | 
			
		||||
 - the version of the package that introduced the deprecation
 | 
			
		||||
 - the message of the deprecation
 | 
			
		||||
 - more arguments can be provided: they will be inserted in the message using `printf()` formatting
 | 
			
		||||
 | 
			
		||||
Example:
 | 
			
		||||
```php
 | 
			
		||||
trigger_deprecation('symfony/blockchain', '8.9', 'Using "%s" is deprecated, use "%s" instead.', 'bitcoin', 'fabcoin');
 | 
			
		||||
```
 | 
			
		||||
 | 
			
		||||
This will generate the following message:
 | 
			
		||||
`Since symfony/blockchain 8.9: Using "bitcoin" is deprecated, use "fabcoin" instead.`
 | 
			
		||||
 | 
			
		||||
While not recommended, the deprecation notices can be completely ignored by declaring an empty
 | 
			
		||||
`function trigger_deprecation() {}` in your application.
 | 
			
		||||
							
								
								
									
										35
									
								
								qwen/php/vendor/symfony/deprecation-contracts/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										35
									
								
								qwen/php/vendor/symfony/deprecation-contracts/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,35 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "symfony/deprecation-contracts",
 | 
			
		||||
    "type": "library",
 | 
			
		||||
    "description": "A generic function and convention to trigger deprecation notices",
 | 
			
		||||
    "homepage": "https://symfony.com",
 | 
			
		||||
    "license": "MIT",
 | 
			
		||||
    "authors": [
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Nicolas Grekas",
 | 
			
		||||
            "email": "p@tchwork.com"
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Symfony Community",
 | 
			
		||||
            "homepage": "https://symfony.com/contributors"
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "require": {
 | 
			
		||||
        "php": ">=8.1"
 | 
			
		||||
    },
 | 
			
		||||
    "autoload": {
 | 
			
		||||
        "files": [
 | 
			
		||||
            "function.php"
 | 
			
		||||
        ]
 | 
			
		||||
    },
 | 
			
		||||
    "minimum-stability": "dev",
 | 
			
		||||
    "extra": {
 | 
			
		||||
        "branch-alias": {
 | 
			
		||||
            "dev-main": "3.6-dev"
 | 
			
		||||
        },
 | 
			
		||||
        "thanks": {
 | 
			
		||||
            "name": "symfony/contracts",
 | 
			
		||||
            "url": "https://github.com/symfony/contracts"
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										27
									
								
								qwen/php/vendor/symfony/deprecation-contracts/function.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								qwen/php/vendor/symfony/deprecation-contracts/function.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,27 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (!function_exists('trigger_deprecation')) {
 | 
			
		||||
    /**
 | 
			
		||||
     * Triggers a silenced deprecation notice.
 | 
			
		||||
     *
 | 
			
		||||
     * @param string $package The name of the Composer package that is triggering the deprecation
 | 
			
		||||
     * @param string $version The version of the package that introduced the deprecation
 | 
			
		||||
     * @param string $message The message of the deprecation
 | 
			
		||||
     * @param mixed  ...$args Values to insert in the message using printf() formatting
 | 
			
		||||
     *
 | 
			
		||||
     * @author Nicolas Grekas <p@tchwork.com>
 | 
			
		||||
     */
 | 
			
		||||
    function trigger_deprecation(string $package, string $version, string $message, mixed ...$args): void
 | 
			
		||||
    {
 | 
			
		||||
        @trigger_error(($package || $version ? "Since $package $version: " : '').($args ? vsprintf($message, $args) : $message), \E_USER_DEPRECATED);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										232
									
								
								qwen/php/vendor/symfony/polyfill-ctype/Ctype.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										232
									
								
								qwen/php/vendor/symfony/polyfill-ctype/Ctype.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,232 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
namespace Symfony\Polyfill\Ctype;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Ctype implementation through regex.
 | 
			
		||||
 *
 | 
			
		||||
 * @internal
 | 
			
		||||
 *
 | 
			
		||||
 * @author Gert de Pagter <BackEndTea@gmail.com>
 | 
			
		||||
 */
 | 
			
		||||
final class Ctype
 | 
			
		||||
{
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is either a letter or a digit, FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-alnum
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_alnum($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^A-Za-z0-9]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is a letter, FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-alpha
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_alpha($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^A-Za-z]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is a control character from the current locale, FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-cntrl
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_cntrl($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^\x00-\x1f\x7f]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in the string text is a decimal digit, FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-digit
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_digit($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^0-9]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is printable and actually creates visible output (no white space), FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-graph
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_graph($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^!-~]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is a lowercase letter.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-lower
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_lower($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^a-z]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text will actually create output (including blanks). Returns FALSE if text contains control characters or characters that do not have any output or control function at all.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-print
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_print($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^ -~]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is printable, but neither letter, digit or blank, FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-punct
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_punct($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^!-\/\:-@\[-`\{-~]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text creates some sort of white space, FALSE otherwise. Besides the blank character this also includes tab, vertical tab, line feed, carriage return and form feed characters.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-space
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_space($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^\s]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is an uppercase letter.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-upper
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_upper($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^A-Z]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Returns TRUE if every character in text is a hexadecimal 'digit', that is a decimal digit or a character from [A-Fa-f] , FALSE otherwise.
 | 
			
		||||
     *
 | 
			
		||||
     * @see https://php.net/ctype-xdigit
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed $text
 | 
			
		||||
     *
 | 
			
		||||
     * @return bool
 | 
			
		||||
     */
 | 
			
		||||
    public static function ctype_xdigit($text)
 | 
			
		||||
    {
 | 
			
		||||
        $text = self::convert_int_to_char_for_ctype($text, __FUNCTION__);
 | 
			
		||||
 | 
			
		||||
        return \is_string($text) && '' !== $text && !preg_match('/[^A-Fa-f0-9]/', $text);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * Converts integers to their char versions according to normal ctype behaviour, if needed.
 | 
			
		||||
     *
 | 
			
		||||
     * If an integer between -128 and 255 inclusive is provided,
 | 
			
		||||
     * it is interpreted as the ASCII value of a single character
 | 
			
		||||
     * (negative values have 256 added in order to allow characters in the Extended ASCII range).
 | 
			
		||||
     * Any other integer is interpreted as a string containing the decimal digits of the integer.
 | 
			
		||||
     *
 | 
			
		||||
     * @param mixed  $int
 | 
			
		||||
     * @param string $function
 | 
			
		||||
     *
 | 
			
		||||
     * @return mixed
 | 
			
		||||
     */
 | 
			
		||||
    private static function convert_int_to_char_for_ctype($int, $function)
 | 
			
		||||
    {
 | 
			
		||||
        if (!\is_int($int)) {
 | 
			
		||||
            return $int;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($int < -128 || $int > 255) {
 | 
			
		||||
            return (string) $int;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (\PHP_VERSION_ID >= 80100) {
 | 
			
		||||
            @trigger_error($function.'(): Argument of type int will be interpreted as string in the future', \E_USER_DEPRECATED);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($int < 0) {
 | 
			
		||||
            $int += 256;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return \chr($int);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										19
									
								
								qwen/php/vendor/symfony/polyfill-ctype/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								qwen/php/vendor/symfony/polyfill-ctype/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,19 @@
 | 
			
		||||
Copyright (c) 2018-present Fabien Potencier
 | 
			
		||||
 | 
			
		||||
Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
in the Software without restriction, including without limitation the rights
 | 
			
		||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
copies of the Software, and to permit persons to whom the Software is furnished
 | 
			
		||||
to do so, subject to the following conditions:
 | 
			
		||||
 | 
			
		||||
The above copyright notice and this permission notice shall be included in all
 | 
			
		||||
copies or substantial portions of the Software.
 | 
			
		||||
 | 
			
		||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
THE SOFTWARE.
 | 
			
		||||
							
								
								
									
										12
									
								
								qwen/php/vendor/symfony/polyfill-ctype/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								qwen/php/vendor/symfony/polyfill-ctype/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,12 @@
 | 
			
		||||
Symfony Polyfill / Ctype
 | 
			
		||||
========================
 | 
			
		||||
 | 
			
		||||
This component provides `ctype_*` functions to users who run php versions without the ctype extension.
 | 
			
		||||
 | 
			
		||||
More information can be found in the
 | 
			
		||||
[main Polyfill README](https://github.com/symfony/polyfill/blob/main/README.md).
 | 
			
		||||
 | 
			
		||||
License
 | 
			
		||||
=======
 | 
			
		||||
 | 
			
		||||
This library is released under the [MIT license](LICENSE).
 | 
			
		||||
							
								
								
									
										50
									
								
								qwen/php/vendor/symfony/polyfill-ctype/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										50
									
								
								qwen/php/vendor/symfony/polyfill-ctype/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,50 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
use Symfony\Polyfill\Ctype as p;
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID >= 80000) {
 | 
			
		||||
    return require __DIR__.'/bootstrap80.php';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('ctype_alnum')) {
 | 
			
		||||
    function ctype_alnum($text) { return p\Ctype::ctype_alnum($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_alpha')) {
 | 
			
		||||
    function ctype_alpha($text) { return p\Ctype::ctype_alpha($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_cntrl')) {
 | 
			
		||||
    function ctype_cntrl($text) { return p\Ctype::ctype_cntrl($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_digit')) {
 | 
			
		||||
    function ctype_digit($text) { return p\Ctype::ctype_digit($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_graph')) {
 | 
			
		||||
    function ctype_graph($text) { return p\Ctype::ctype_graph($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_lower')) {
 | 
			
		||||
    function ctype_lower($text) { return p\Ctype::ctype_lower($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_print')) {
 | 
			
		||||
    function ctype_print($text) { return p\Ctype::ctype_print($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_punct')) {
 | 
			
		||||
    function ctype_punct($text) { return p\Ctype::ctype_punct($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_space')) {
 | 
			
		||||
    function ctype_space($text) { return p\Ctype::ctype_space($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_upper')) {
 | 
			
		||||
    function ctype_upper($text) { return p\Ctype::ctype_upper($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_xdigit')) {
 | 
			
		||||
    function ctype_xdigit($text) { return p\Ctype::ctype_xdigit($text); }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										46
									
								
								qwen/php/vendor/symfony/polyfill-ctype/bootstrap80.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										46
									
								
								qwen/php/vendor/symfony/polyfill-ctype/bootstrap80.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,46 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
use Symfony\Polyfill\Ctype as p;
 | 
			
		||||
 | 
			
		||||
if (!function_exists('ctype_alnum')) {
 | 
			
		||||
    function ctype_alnum(mixed $text): bool { return p\Ctype::ctype_alnum($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_alpha')) {
 | 
			
		||||
    function ctype_alpha(mixed $text): bool { return p\Ctype::ctype_alpha($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_cntrl')) {
 | 
			
		||||
    function ctype_cntrl(mixed $text): bool { return p\Ctype::ctype_cntrl($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_digit')) {
 | 
			
		||||
    function ctype_digit(mixed $text): bool { return p\Ctype::ctype_digit($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_graph')) {
 | 
			
		||||
    function ctype_graph(mixed $text): bool { return p\Ctype::ctype_graph($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_lower')) {
 | 
			
		||||
    function ctype_lower(mixed $text): bool { return p\Ctype::ctype_lower($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_print')) {
 | 
			
		||||
    function ctype_print(mixed $text): bool { return p\Ctype::ctype_print($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_punct')) {
 | 
			
		||||
    function ctype_punct(mixed $text): bool { return p\Ctype::ctype_punct($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_space')) {
 | 
			
		||||
    function ctype_space(mixed $text): bool { return p\Ctype::ctype_space($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_upper')) {
 | 
			
		||||
    function ctype_upper(mixed $text): bool { return p\Ctype::ctype_upper($text); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('ctype_xdigit')) {
 | 
			
		||||
    function ctype_xdigit(mixed $text): bool { return p\Ctype::ctype_xdigit($text); }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										38
									
								
								qwen/php/vendor/symfony/polyfill-ctype/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										38
									
								
								qwen/php/vendor/symfony/polyfill-ctype/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,38 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "symfony/polyfill-ctype",
 | 
			
		||||
    "type": "library",
 | 
			
		||||
    "description": "Symfony polyfill for ctype functions",
 | 
			
		||||
    "keywords": ["polyfill", "compatibility", "portable", "ctype"],
 | 
			
		||||
    "homepage": "https://symfony.com",
 | 
			
		||||
    "license": "MIT",
 | 
			
		||||
    "authors": [
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Gert de Pagter",
 | 
			
		||||
            "email": "BackEndTea@gmail.com"
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Symfony Community",
 | 
			
		||||
            "homepage": "https://symfony.com/contributors"
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "require": {
 | 
			
		||||
        "php": ">=7.2"
 | 
			
		||||
    },
 | 
			
		||||
    "provide": {
 | 
			
		||||
        "ext-ctype": "*"
 | 
			
		||||
    },
 | 
			
		||||
    "autoload": {
 | 
			
		||||
        "psr-4": { "Symfony\\Polyfill\\Ctype\\": "" },
 | 
			
		||||
        "files": [ "bootstrap.php" ]
 | 
			
		||||
    },
 | 
			
		||||
    "suggest": {
 | 
			
		||||
        "ext-ctype": "For best performance"
 | 
			
		||||
    },
 | 
			
		||||
    "minimum-stability": "dev",
 | 
			
		||||
    "extra": {
 | 
			
		||||
        "thanks": {
 | 
			
		||||
            "name": "symfony/polyfill",
 | 
			
		||||
            "url": "https://github.com/symfony/polyfill"
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										19
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,19 @@
 | 
			
		||||
Copyright (c) 2015-present Fabien Potencier
 | 
			
		||||
 | 
			
		||||
Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
in the Software without restriction, including without limitation the rights
 | 
			
		||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
copies of the Software, and to permit persons to whom the Software is furnished
 | 
			
		||||
to do so, subject to the following conditions:
 | 
			
		||||
 | 
			
		||||
The above copyright notice and this permission notice shall be included in all
 | 
			
		||||
copies or substantial portions of the Software.
 | 
			
		||||
 | 
			
		||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
THE SOFTWARE.
 | 
			
		||||
							
								
								
									
										1045
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Mbstring.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1045
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Mbstring.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										13
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,13 @@
 | 
			
		||||
Symfony Polyfill / Mbstring
 | 
			
		||||
===========================
 | 
			
		||||
 | 
			
		||||
This component provides a partial, native PHP implementation for the
 | 
			
		||||
[Mbstring](https://php.net/mbstring) extension.
 | 
			
		||||
 | 
			
		||||
More information can be found in the
 | 
			
		||||
[main Polyfill README](https://github.com/symfony/polyfill/blob/main/README.md).
 | 
			
		||||
 | 
			
		||||
License
 | 
			
		||||
=======
 | 
			
		||||
 | 
			
		||||
This library is released under the [MIT license](LICENSE).
 | 
			
		||||
							
								
								
									
										119
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/caseFolding.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										119
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/caseFolding.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,119 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
return [
 | 
			
		||||
    'İ' => 'i̇',
 | 
			
		||||
    'µ' => 'μ',
 | 
			
		||||
    'ſ' => 's',
 | 
			
		||||
    'ͅ' => 'ι',
 | 
			
		||||
    'ς' => 'σ',
 | 
			
		||||
    'ϐ' => 'β',
 | 
			
		||||
    'ϑ' => 'θ',
 | 
			
		||||
    'ϕ' => 'φ',
 | 
			
		||||
    'ϖ' => 'π',
 | 
			
		||||
    'ϰ' => 'κ',
 | 
			
		||||
    'ϱ' => 'ρ',
 | 
			
		||||
    'ϵ' => 'ε',
 | 
			
		||||
    'ẛ' => 'ṡ',
 | 
			
		||||
    'ι' => 'ι',
 | 
			
		||||
    'ß' => 'ss',
 | 
			
		||||
    'ʼn' => 'ʼn',
 | 
			
		||||
    'ǰ' => 'ǰ',
 | 
			
		||||
    'ΐ' => 'ΐ',
 | 
			
		||||
    'ΰ' => 'ΰ',
 | 
			
		||||
    'և' => 'եւ',
 | 
			
		||||
    'ẖ' => 'ẖ',
 | 
			
		||||
    'ẗ' => 'ẗ',
 | 
			
		||||
    'ẘ' => 'ẘ',
 | 
			
		||||
    'ẙ' => 'ẙ',
 | 
			
		||||
    'ẚ' => 'aʾ',
 | 
			
		||||
    'ẞ' => 'ss',
 | 
			
		||||
    'ὐ' => 'ὐ',
 | 
			
		||||
    'ὒ' => 'ὒ',
 | 
			
		||||
    'ὔ' => 'ὔ',
 | 
			
		||||
    'ὖ' => 'ὖ',
 | 
			
		||||
    'ᾀ' => 'ἀι',
 | 
			
		||||
    'ᾁ' => 'ἁι',
 | 
			
		||||
    'ᾂ' => 'ἂι',
 | 
			
		||||
    'ᾃ' => 'ἃι',
 | 
			
		||||
    'ᾄ' => 'ἄι',
 | 
			
		||||
    'ᾅ' => 'ἅι',
 | 
			
		||||
    'ᾆ' => 'ἆι',
 | 
			
		||||
    'ᾇ' => 'ἇι',
 | 
			
		||||
    'ᾈ' => 'ἀι',
 | 
			
		||||
    'ᾉ' => 'ἁι',
 | 
			
		||||
    'ᾊ' => 'ἂι',
 | 
			
		||||
    'ᾋ' => 'ἃι',
 | 
			
		||||
    'ᾌ' => 'ἄι',
 | 
			
		||||
    'ᾍ' => 'ἅι',
 | 
			
		||||
    'ᾎ' => 'ἆι',
 | 
			
		||||
    'ᾏ' => 'ἇι',
 | 
			
		||||
    'ᾐ' => 'ἠι',
 | 
			
		||||
    'ᾑ' => 'ἡι',
 | 
			
		||||
    'ᾒ' => 'ἢι',
 | 
			
		||||
    'ᾓ' => 'ἣι',
 | 
			
		||||
    'ᾔ' => 'ἤι',
 | 
			
		||||
    'ᾕ' => 'ἥι',
 | 
			
		||||
    'ᾖ' => 'ἦι',
 | 
			
		||||
    'ᾗ' => 'ἧι',
 | 
			
		||||
    'ᾘ' => 'ἠι',
 | 
			
		||||
    'ᾙ' => 'ἡι',
 | 
			
		||||
    'ᾚ' => 'ἢι',
 | 
			
		||||
    'ᾛ' => 'ἣι',
 | 
			
		||||
    'ᾜ' => 'ἤι',
 | 
			
		||||
    'ᾝ' => 'ἥι',
 | 
			
		||||
    'ᾞ' => 'ἦι',
 | 
			
		||||
    'ᾟ' => 'ἧι',
 | 
			
		||||
    'ᾠ' => 'ὠι',
 | 
			
		||||
    'ᾡ' => 'ὡι',
 | 
			
		||||
    'ᾢ' => 'ὢι',
 | 
			
		||||
    'ᾣ' => 'ὣι',
 | 
			
		||||
    'ᾤ' => 'ὤι',
 | 
			
		||||
    'ᾥ' => 'ὥι',
 | 
			
		||||
    'ᾦ' => 'ὦι',
 | 
			
		||||
    'ᾧ' => 'ὧι',
 | 
			
		||||
    'ᾨ' => 'ὠι',
 | 
			
		||||
    'ᾩ' => 'ὡι',
 | 
			
		||||
    'ᾪ' => 'ὢι',
 | 
			
		||||
    'ᾫ' => 'ὣι',
 | 
			
		||||
    'ᾬ' => 'ὤι',
 | 
			
		||||
    'ᾭ' => 'ὥι',
 | 
			
		||||
    'ᾮ' => 'ὦι',
 | 
			
		||||
    'ᾯ' => 'ὧι',
 | 
			
		||||
    'ᾲ' => 'ὰι',
 | 
			
		||||
    'ᾳ' => 'αι',
 | 
			
		||||
    'ᾴ' => 'άι',
 | 
			
		||||
    'ᾶ' => 'ᾶ',
 | 
			
		||||
    'ᾷ' => 'ᾶι',
 | 
			
		||||
    'ᾼ' => 'αι',
 | 
			
		||||
    'ῂ' => 'ὴι',
 | 
			
		||||
    'ῃ' => 'ηι',
 | 
			
		||||
    'ῄ' => 'ήι',
 | 
			
		||||
    'ῆ' => 'ῆ',
 | 
			
		||||
    'ῇ' => 'ῆι',
 | 
			
		||||
    'ῌ' => 'ηι',
 | 
			
		||||
    'ῒ' => 'ῒ',
 | 
			
		||||
    'ῖ' => 'ῖ',
 | 
			
		||||
    'ῗ' => 'ῗ',
 | 
			
		||||
    'ῢ' => 'ῢ',
 | 
			
		||||
    'ῤ' => 'ῤ',
 | 
			
		||||
    'ῦ' => 'ῦ',
 | 
			
		||||
    'ῧ' => 'ῧ',
 | 
			
		||||
    'ῲ' => 'ὼι',
 | 
			
		||||
    'ῳ' => 'ωι',
 | 
			
		||||
    'ῴ' => 'ώι',
 | 
			
		||||
    'ῶ' => 'ῶ',
 | 
			
		||||
    'ῷ' => 'ῶι',
 | 
			
		||||
    'ῼ' => 'ωι',
 | 
			
		||||
    'ff' => 'ff',
 | 
			
		||||
    'fi' => 'fi',
 | 
			
		||||
    'fl' => 'fl',
 | 
			
		||||
    'ffi' => 'ffi',
 | 
			
		||||
    'ffl' => 'ffl',
 | 
			
		||||
    'ſt' => 'st',
 | 
			
		||||
    'st' => 'st',
 | 
			
		||||
    'ﬓ' => 'մն',
 | 
			
		||||
    'ﬔ' => 'մե',
 | 
			
		||||
    'ﬕ' => 'մի',
 | 
			
		||||
    'ﬖ' => 'վն',
 | 
			
		||||
    'ﬗ' => 'մխ',
 | 
			
		||||
];
 | 
			
		||||
							
								
								
									
										1397
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1397
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/lowerCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										5
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/titleCaseRegexp.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										1489
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1489
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/Resources/unidata/upperCase.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										172
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										172
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,172 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
use Symfony\Polyfill\Mbstring as p;
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID >= 80000) {
 | 
			
		||||
    return require __DIR__.'/bootstrap80.php';
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_convert_encoding')) {
 | 
			
		||||
    function mb_convert_encoding($string, $to_encoding, $from_encoding = null) { return p\Mbstring::mb_convert_encoding($string, $to_encoding, $from_encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_decode_mimeheader')) {
 | 
			
		||||
    function mb_decode_mimeheader($string) { return p\Mbstring::mb_decode_mimeheader($string); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_encode_mimeheader')) {
 | 
			
		||||
    function mb_encode_mimeheader($string, $charset = null, $transfer_encoding = null, $newline = "\r\n", $indent = 0) { return p\Mbstring::mb_encode_mimeheader($string, $charset, $transfer_encoding, $newline, $indent); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_decode_numericentity')) {
 | 
			
		||||
    function mb_decode_numericentity($string, $map, $encoding = null) { return p\Mbstring::mb_decode_numericentity($string, $map, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_encode_numericentity')) {
 | 
			
		||||
    function mb_encode_numericentity($string, $map, $encoding = null, $hex = false) { return p\Mbstring::mb_encode_numericentity($string, $map, $encoding, $hex); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_convert_case')) {
 | 
			
		||||
    function mb_convert_case($string, $mode, $encoding = null) { return p\Mbstring::mb_convert_case($string, $mode, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_internal_encoding')) {
 | 
			
		||||
    function mb_internal_encoding($encoding = null) { return p\Mbstring::mb_internal_encoding($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_language')) {
 | 
			
		||||
    function mb_language($language = null) { return p\Mbstring::mb_language($language); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_list_encodings')) {
 | 
			
		||||
    function mb_list_encodings() { return p\Mbstring::mb_list_encodings(); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_encoding_aliases')) {
 | 
			
		||||
    function mb_encoding_aliases($encoding) { return p\Mbstring::mb_encoding_aliases($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_check_encoding')) {
 | 
			
		||||
    function mb_check_encoding($value = null, $encoding = null) { return p\Mbstring::mb_check_encoding($value, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_detect_encoding')) {
 | 
			
		||||
    function mb_detect_encoding($string, $encodings = null, $strict = false) { return p\Mbstring::mb_detect_encoding($string, $encodings, $strict); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_detect_order')) {
 | 
			
		||||
    function mb_detect_order($encoding = null) { return p\Mbstring::mb_detect_order($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_parse_str')) {
 | 
			
		||||
    function mb_parse_str($string, &$result = []) { parse_str($string, $result); return (bool) $result; }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strlen')) {
 | 
			
		||||
    function mb_strlen($string, $encoding = null) { return p\Mbstring::mb_strlen($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strpos')) {
 | 
			
		||||
    function mb_strpos($haystack, $needle, $offset = 0, $encoding = null) { return p\Mbstring::mb_strpos($haystack, $needle, $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strtolower')) {
 | 
			
		||||
    function mb_strtolower($string, $encoding = null) { return p\Mbstring::mb_strtolower($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strtoupper')) {
 | 
			
		||||
    function mb_strtoupper($string, $encoding = null) { return p\Mbstring::mb_strtoupper($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_substitute_character')) {
 | 
			
		||||
    function mb_substitute_character($substitute_character = null) { return p\Mbstring::mb_substitute_character($substitute_character); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_substr')) {
 | 
			
		||||
    function mb_substr($string, $start, $length = 2147483647, $encoding = null) { return p\Mbstring::mb_substr($string, $start, $length, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_stripos')) {
 | 
			
		||||
    function mb_stripos($haystack, $needle, $offset = 0, $encoding = null) { return p\Mbstring::mb_stripos($haystack, $needle, $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_stristr')) {
 | 
			
		||||
    function mb_stristr($haystack, $needle, $before_needle = false, $encoding = null) { return p\Mbstring::mb_stristr($haystack, $needle, $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strrchr')) {
 | 
			
		||||
    function mb_strrchr($haystack, $needle, $before_needle = false, $encoding = null) { return p\Mbstring::mb_strrchr($haystack, $needle, $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strrichr')) {
 | 
			
		||||
    function mb_strrichr($haystack, $needle, $before_needle = false, $encoding = null) { return p\Mbstring::mb_strrichr($haystack, $needle, $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strripos')) {
 | 
			
		||||
    function mb_strripos($haystack, $needle, $offset = 0, $encoding = null) { return p\Mbstring::mb_strripos($haystack, $needle, $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strrpos')) {
 | 
			
		||||
    function mb_strrpos($haystack, $needle, $offset = 0, $encoding = null) { return p\Mbstring::mb_strrpos($haystack, $needle, $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strstr')) {
 | 
			
		||||
    function mb_strstr($haystack, $needle, $before_needle = false, $encoding = null) { return p\Mbstring::mb_strstr($haystack, $needle, $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_get_info')) {
 | 
			
		||||
    function mb_get_info($type = 'all') { return p\Mbstring::mb_get_info($type); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_http_output')) {
 | 
			
		||||
    function mb_http_output($encoding = null) { return p\Mbstring::mb_http_output($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strwidth')) {
 | 
			
		||||
    function mb_strwidth($string, $encoding = null) { return p\Mbstring::mb_strwidth($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_substr_count')) {
 | 
			
		||||
    function mb_substr_count($haystack, $needle, $encoding = null) { return p\Mbstring::mb_substr_count($haystack, $needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_output_handler')) {
 | 
			
		||||
    function mb_output_handler($string, $status) { return p\Mbstring::mb_output_handler($string, $status); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_http_input')) {
 | 
			
		||||
    function mb_http_input($type = null) { return p\Mbstring::mb_http_input($type); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_convert_variables')) {
 | 
			
		||||
    function mb_convert_variables($to_encoding, $from_encoding, &...$vars) { return p\Mbstring::mb_convert_variables($to_encoding, $from_encoding, ...$vars); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_ord')) {
 | 
			
		||||
    function mb_ord($string, $encoding = null) { return p\Mbstring::mb_ord($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_chr')) {
 | 
			
		||||
    function mb_chr($codepoint, $encoding = null) { return p\Mbstring::mb_chr($codepoint, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_scrub')) {
 | 
			
		||||
    function mb_scrub($string, $encoding = null) { $encoding = null === $encoding ? mb_internal_encoding() : $encoding; return mb_convert_encoding($string, $encoding, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_str_split')) {
 | 
			
		||||
    function mb_str_split($string, $length = 1, $encoding = null) { return p\Mbstring::mb_str_split($string, $length, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_str_pad')) {
 | 
			
		||||
    function mb_str_pad(string $string, int $length, string $pad_string = ' ', int $pad_type = STR_PAD_RIGHT, ?string $encoding = null): string { return p\Mbstring::mb_str_pad($string, $length, $pad_string, $pad_type, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_ucfirst')) {
 | 
			
		||||
    function mb_ucfirst(string $string, ?string $encoding = null): string { return p\Mbstring::mb_ucfirst($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_lcfirst')) {
 | 
			
		||||
    function mb_lcfirst(string $string, ?string $encoding = null): string { return p\Mbstring::mb_lcfirst($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_trim')) {
 | 
			
		||||
    function mb_trim(string $string, ?string $characters = null, ?string $encoding = null): string { return p\Mbstring::mb_trim($string, $characters, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_ltrim')) {
 | 
			
		||||
    function mb_ltrim(string $string, ?string $characters = null, ?string $encoding = null): string { return p\Mbstring::mb_ltrim($string, $characters, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_rtrim')) {
 | 
			
		||||
    function mb_rtrim(string $string, ?string $characters = null, ?string $encoding = null): string { return p\Mbstring::mb_rtrim($string, $characters, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
if (extension_loaded('mbstring')) {
 | 
			
		||||
    return;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!defined('MB_CASE_UPPER')) {
 | 
			
		||||
    define('MB_CASE_UPPER', 0);
 | 
			
		||||
}
 | 
			
		||||
if (!defined('MB_CASE_LOWER')) {
 | 
			
		||||
    define('MB_CASE_LOWER', 1);
 | 
			
		||||
}
 | 
			
		||||
if (!defined('MB_CASE_TITLE')) {
 | 
			
		||||
    define('MB_CASE_TITLE', 2);
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										167
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/bootstrap80.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										167
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/bootstrap80.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,167 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
use Symfony\Polyfill\Mbstring as p;
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_convert_encoding')) {
 | 
			
		||||
    function mb_convert_encoding(array|string|null $string, ?string $to_encoding, array|string|null $from_encoding = null): array|string|false { return p\Mbstring::mb_convert_encoding($string ?? '', (string) $to_encoding, $from_encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_decode_mimeheader')) {
 | 
			
		||||
    function mb_decode_mimeheader(?string $string): string { return p\Mbstring::mb_decode_mimeheader((string) $string); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_encode_mimeheader')) {
 | 
			
		||||
    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) $string, $charset, $transfer_encoding, (string) $newline, (int) $indent); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_decode_numericentity')) {
 | 
			
		||||
    function mb_decode_numericentity(?string $string, array $map, ?string $encoding = null): string { return p\Mbstring::mb_decode_numericentity((string) $string, $map, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_encode_numericentity')) {
 | 
			
		||||
    function mb_encode_numericentity(?string $string, array $map, ?string $encoding = null, ?bool $hex = false): string { return p\Mbstring::mb_encode_numericentity((string) $string, $map, $encoding, (bool) $hex); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_convert_case')) {
 | 
			
		||||
    function mb_convert_case(?string $string, ?int $mode, ?string $encoding = null): string { return p\Mbstring::mb_convert_case((string) $string, (int) $mode, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_internal_encoding')) {
 | 
			
		||||
    function mb_internal_encoding(?string $encoding = null): string|bool { return p\Mbstring::mb_internal_encoding($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_language')) {
 | 
			
		||||
    function mb_language(?string $language = null): string|bool { return p\Mbstring::mb_language($language); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_list_encodings')) {
 | 
			
		||||
    function mb_list_encodings(): array { return p\Mbstring::mb_list_encodings(); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_encoding_aliases')) {
 | 
			
		||||
    function mb_encoding_aliases(?string $encoding): array { return p\Mbstring::mb_encoding_aliases((string) $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_check_encoding')) {
 | 
			
		||||
    function mb_check_encoding(array|string|null $value = null, ?string $encoding = null): bool { return p\Mbstring::mb_check_encoding($value, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_detect_encoding')) {
 | 
			
		||||
    function mb_detect_encoding(?string $string, array|string|null $encodings = null, ?bool $strict = false): string|false { return p\Mbstring::mb_detect_encoding((string) $string, $encodings, (bool) $strict); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_detect_order')) {
 | 
			
		||||
    function mb_detect_order(array|string|null $encoding = null): array|bool { return p\Mbstring::mb_detect_order($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_parse_str')) {
 | 
			
		||||
    function mb_parse_str(?string $string, &$result = []): bool { parse_str((string) $string, $result); return (bool) $result; }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strlen')) {
 | 
			
		||||
    function mb_strlen(?string $string, ?string $encoding = null): int { return p\Mbstring::mb_strlen((string) $string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strpos')) {
 | 
			
		||||
    function mb_strpos(?string $haystack, ?string $needle, ?int $offset = 0, ?string $encoding = null): int|false { return p\Mbstring::mb_strpos((string) $haystack, (string) $needle, (int) $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strtolower')) {
 | 
			
		||||
    function mb_strtolower(?string $string, ?string $encoding = null): string { return p\Mbstring::mb_strtolower((string) $string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strtoupper')) {
 | 
			
		||||
    function mb_strtoupper(?string $string, ?string $encoding = null): string { return p\Mbstring::mb_strtoupper((string) $string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_substitute_character')) {
 | 
			
		||||
    function mb_substitute_character(string|int|null $substitute_character = null): string|int|bool { return p\Mbstring::mb_substitute_character($substitute_character); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_substr')) {
 | 
			
		||||
    function mb_substr(?string $string, ?int $start, ?int $length = null, ?string $encoding = null): string { return p\Mbstring::mb_substr((string) $string, (int) $start, $length, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_stripos')) {
 | 
			
		||||
    function mb_stripos(?string $haystack, ?string $needle, ?int $offset = 0, ?string $encoding = null): int|false { return p\Mbstring::mb_stripos((string) $haystack, (string) $needle, (int) $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_stristr')) {
 | 
			
		||||
    function mb_stristr(?string $haystack, ?string $needle, ?bool $before_needle = false, ?string $encoding = null): string|false { return p\Mbstring::mb_stristr((string) $haystack, (string) $needle, (bool) $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strrchr')) {
 | 
			
		||||
    function mb_strrchr(?string $haystack, ?string $needle, ?bool $before_needle = false, ?string $encoding = null): string|false { return p\Mbstring::mb_strrchr((string) $haystack, (string) $needle, (bool) $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strrichr')) {
 | 
			
		||||
    function mb_strrichr(?string $haystack, ?string $needle, ?bool $before_needle = false, ?string $encoding = null): string|false { return p\Mbstring::mb_strrichr((string) $haystack, (string) $needle, (bool) $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strripos')) {
 | 
			
		||||
    function mb_strripos(?string $haystack, ?string $needle, ?int $offset = 0, ?string $encoding = null): int|false { return p\Mbstring::mb_strripos((string) $haystack, (string) $needle, (int) $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strrpos')) {
 | 
			
		||||
    function mb_strrpos(?string $haystack, ?string $needle, ?int $offset = 0, ?string $encoding = null): int|false { return p\Mbstring::mb_strrpos((string) $haystack, (string) $needle, (int) $offset, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strstr')) {
 | 
			
		||||
    function mb_strstr(?string $haystack, ?string $needle, ?bool $before_needle = false, ?string $encoding = null): string|false { return p\Mbstring::mb_strstr((string) $haystack, (string) $needle, (bool) $before_needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_get_info')) {
 | 
			
		||||
    function mb_get_info(?string $type = 'all'): array|string|int|false|null { return p\Mbstring::mb_get_info((string) $type); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_http_output')) {
 | 
			
		||||
    function mb_http_output(?string $encoding = null): string|bool { return p\Mbstring::mb_http_output($encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_strwidth')) {
 | 
			
		||||
    function mb_strwidth(?string $string, ?string $encoding = null): int { return p\Mbstring::mb_strwidth((string) $string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_substr_count')) {
 | 
			
		||||
    function mb_substr_count(?string $haystack, ?string $needle, ?string $encoding = null): int { return p\Mbstring::mb_substr_count((string) $haystack, (string) $needle, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_output_handler')) {
 | 
			
		||||
    function mb_output_handler(?string $string, ?int $status): string { return p\Mbstring::mb_output_handler((string) $string, (int) $status); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_http_input')) {
 | 
			
		||||
    function mb_http_input(?string $type = null): array|string|false { return p\Mbstring::mb_http_input($type); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_convert_variables')) {
 | 
			
		||||
    function mb_convert_variables(?string $to_encoding, array|string|null $from_encoding, mixed &$var, mixed &...$vars): string|false { return p\Mbstring::mb_convert_variables((string) $to_encoding, $from_encoding ?? '', $var, ...$vars); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_ord')) {
 | 
			
		||||
    function mb_ord(?string $string, ?string $encoding = null): int|false { return p\Mbstring::mb_ord((string) $string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_chr')) {
 | 
			
		||||
    function mb_chr(?int $codepoint, ?string $encoding = null): string|false { return p\Mbstring::mb_chr((int) $codepoint, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_scrub')) {
 | 
			
		||||
    function mb_scrub(?string $string, ?string $encoding = null): string { $encoding ??= mb_internal_encoding(); return mb_convert_encoding((string) $string, $encoding, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('mb_str_split')) {
 | 
			
		||||
    function mb_str_split(?string $string, ?int $length = 1, ?string $encoding = null): array { return p\Mbstring::mb_str_split((string) $string, (int) $length, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_str_pad')) {
 | 
			
		||||
    function mb_str_pad(string $string, int $length, string $pad_string = ' ', int $pad_type = STR_PAD_RIGHT, ?string $encoding = null): string { return p\Mbstring::mb_str_pad($string, $length, $pad_string, $pad_type, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_ucfirst')) {
 | 
			
		||||
    function mb_ucfirst(string $string, ?string $encoding = null): string { return p\Mbstring::mb_ucfirst($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_lcfirst')) {
 | 
			
		||||
    function mb_lcfirst(string $string, ?string $encoding = null): string { return p\Mbstring::mb_lcfirst($string, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_trim')) {
 | 
			
		||||
    function mb_trim(string $string, ?string $characters = null, ?string $encoding = null): string { return p\Mbstring::mb_trim($string, $characters, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_ltrim')) {
 | 
			
		||||
    function mb_ltrim(string $string, ?string $characters = null, ?string $encoding = null): string { return p\Mbstring::mb_ltrim($string, $characters, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('mb_rtrim')) {
 | 
			
		||||
    function mb_rtrim(string $string, ?string $characters = null, ?string $encoding = null): string { return p\Mbstring::mb_rtrim($string, $characters, $encoding); }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (extension_loaded('mbstring')) {
 | 
			
		||||
    return;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!defined('MB_CASE_UPPER')) {
 | 
			
		||||
    define('MB_CASE_UPPER', 0);
 | 
			
		||||
}
 | 
			
		||||
if (!defined('MB_CASE_LOWER')) {
 | 
			
		||||
    define('MB_CASE_LOWER', 1);
 | 
			
		||||
}
 | 
			
		||||
if (!defined('MB_CASE_TITLE')) {
 | 
			
		||||
    define('MB_CASE_TITLE', 2);
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										39
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								qwen/php/vendor/symfony/polyfill-mbstring/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,39 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "symfony/polyfill-mbstring",
 | 
			
		||||
    "type": "library",
 | 
			
		||||
    "description": "Symfony polyfill for the Mbstring extension",
 | 
			
		||||
    "keywords": ["polyfill", "shim", "compatibility", "portable", "mbstring"],
 | 
			
		||||
    "homepage": "https://symfony.com",
 | 
			
		||||
    "license": "MIT",
 | 
			
		||||
    "authors": [
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Nicolas Grekas",
 | 
			
		||||
            "email": "p@tchwork.com"
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Symfony Community",
 | 
			
		||||
            "homepage": "https://symfony.com/contributors"
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "require": {
 | 
			
		||||
        "php": ">=7.2",
 | 
			
		||||
        "ext-iconv": "*"
 | 
			
		||||
    },
 | 
			
		||||
    "provide": {
 | 
			
		||||
        "ext-mbstring": "*"
 | 
			
		||||
    },
 | 
			
		||||
    "autoload": {
 | 
			
		||||
        "psr-4": { "Symfony\\Polyfill\\Mbstring\\": "" },
 | 
			
		||||
        "files": [ "bootstrap.php" ]
 | 
			
		||||
    },
 | 
			
		||||
    "suggest": {
 | 
			
		||||
        "ext-mbstring": "For best performance"
 | 
			
		||||
    },
 | 
			
		||||
    "minimum-stability": "dev",
 | 
			
		||||
    "extra": {
 | 
			
		||||
        "thanks": {
 | 
			
		||||
            "name": "symfony/polyfill",
 | 
			
		||||
            "url": "https://github.com/symfony/polyfill"
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										19
									
								
								qwen/php/vendor/symfony/polyfill-php80/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								qwen/php/vendor/symfony/polyfill-php80/LICENSE
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,19 @@
 | 
			
		||||
Copyright (c) 2020-present Fabien Potencier
 | 
			
		||||
 | 
			
		||||
Permission is hereby granted, free of charge, to any person obtaining a copy
 | 
			
		||||
of this software and associated documentation files (the "Software"), to deal
 | 
			
		||||
in the Software without restriction, including without limitation the rights
 | 
			
		||||
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 | 
			
		||||
copies of the Software, and to permit persons to whom the Software is furnished
 | 
			
		||||
to do so, subject to the following conditions:
 | 
			
		||||
 | 
			
		||||
The above copyright notice and this permission notice shall be included in all
 | 
			
		||||
copies or substantial portions of the Software.
 | 
			
		||||
 | 
			
		||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | 
			
		||||
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | 
			
		||||
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | 
			
		||||
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | 
			
		||||
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 | 
			
		||||
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 | 
			
		||||
THE SOFTWARE.
 | 
			
		||||
							
								
								
									
										115
									
								
								qwen/php/vendor/symfony/polyfill-php80/Php80.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										115
									
								
								qwen/php/vendor/symfony/polyfill-php80/Php80.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,115 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
namespace Symfony\Polyfill\Php80;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * @author Ion Bazan <ion.bazan@gmail.com>
 | 
			
		||||
 * @author Nico Oelgart <nicoswd@gmail.com>
 | 
			
		||||
 * @author Nicolas Grekas <p@tchwork.com>
 | 
			
		||||
 *
 | 
			
		||||
 * @internal
 | 
			
		||||
 */
 | 
			
		||||
final class Php80
 | 
			
		||||
{
 | 
			
		||||
    public static function fdiv(float $dividend, float $divisor): float
 | 
			
		||||
    {
 | 
			
		||||
        return @($dividend / $divisor);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function get_debug_type($value): string
 | 
			
		||||
    {
 | 
			
		||||
        switch (true) {
 | 
			
		||||
            case null === $value: return 'null';
 | 
			
		||||
            case \is_bool($value): return 'bool';
 | 
			
		||||
            case \is_string($value): return 'string';
 | 
			
		||||
            case \is_array($value): return 'array';
 | 
			
		||||
            case \is_int($value): return 'int';
 | 
			
		||||
            case \is_float($value): return 'float';
 | 
			
		||||
            case \is_object($value): break;
 | 
			
		||||
            case $value instanceof \__PHP_Incomplete_Class: return '__PHP_Incomplete_Class';
 | 
			
		||||
            default:
 | 
			
		||||
                if (null === $type = @get_resource_type($value)) {
 | 
			
		||||
                    return 'unknown';
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                if ('Unknown' === $type) {
 | 
			
		||||
                    $type = 'closed';
 | 
			
		||||
                }
 | 
			
		||||
 | 
			
		||||
                return "resource ($type)";
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $class = \get_class($value);
 | 
			
		||||
 | 
			
		||||
        if (false === strpos($class, '@')) {
 | 
			
		||||
            return $class;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return (get_parent_class($class) ?: key(class_implements($class)) ?: 'class').'@anonymous';
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function get_resource_id($res): int
 | 
			
		||||
    {
 | 
			
		||||
        if (!\is_resource($res) && null === @get_resource_type($res)) {
 | 
			
		||||
            throw new \TypeError(sprintf('Argument 1 passed to get_resource_id() must be of the type resource, %s given', get_debug_type($res)));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return (int) $res;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function preg_last_error_msg(): string
 | 
			
		||||
    {
 | 
			
		||||
        switch (preg_last_error()) {
 | 
			
		||||
            case \PREG_INTERNAL_ERROR:
 | 
			
		||||
                return 'Internal error';
 | 
			
		||||
            case \PREG_BAD_UTF8_ERROR:
 | 
			
		||||
                return 'Malformed UTF-8 characters, possibly incorrectly encoded';
 | 
			
		||||
            case \PREG_BAD_UTF8_OFFSET_ERROR:
 | 
			
		||||
                return 'The offset did not correspond to the beginning of a valid UTF-8 code point';
 | 
			
		||||
            case \PREG_BACKTRACK_LIMIT_ERROR:
 | 
			
		||||
                return 'Backtrack limit exhausted';
 | 
			
		||||
            case \PREG_RECURSION_LIMIT_ERROR:
 | 
			
		||||
                return 'Recursion limit exhausted';
 | 
			
		||||
            case \PREG_JIT_STACKLIMIT_ERROR:
 | 
			
		||||
                return 'JIT stack limit exhausted';
 | 
			
		||||
            case \PREG_NO_ERROR:
 | 
			
		||||
                return 'No error';
 | 
			
		||||
            default:
 | 
			
		||||
                return 'Unknown error';
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function str_contains(string $haystack, string $needle): bool
 | 
			
		||||
    {
 | 
			
		||||
        return '' === $needle || false !== strpos($haystack, $needle);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function str_starts_with(string $haystack, string $needle): bool
 | 
			
		||||
    {
 | 
			
		||||
        return 0 === strncmp($haystack, $needle, \strlen($needle));
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public static function str_ends_with(string $haystack, string $needle): bool
 | 
			
		||||
    {
 | 
			
		||||
        if ('' === $needle || $needle === $haystack) {
 | 
			
		||||
            return true;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ('' === $haystack) {
 | 
			
		||||
            return false;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        $needleLength = \strlen($needle);
 | 
			
		||||
 | 
			
		||||
        return $needleLength <= \strlen($haystack) && 0 === substr_compare($haystack, $needle, -$needleLength);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										106
									
								
								qwen/php/vendor/symfony/polyfill-php80/PhpToken.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										106
									
								
								qwen/php/vendor/symfony/polyfill-php80/PhpToken.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,106 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
namespace Symfony\Polyfill\Php80;
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * @author Fedonyuk Anton <info@ensostudio.ru>
 | 
			
		||||
 *
 | 
			
		||||
 * @internal
 | 
			
		||||
 */
 | 
			
		||||
class PhpToken implements \Stringable
 | 
			
		||||
{
 | 
			
		||||
    /**
 | 
			
		||||
     * @var int
 | 
			
		||||
     */
 | 
			
		||||
    public $id;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @var string
 | 
			
		||||
     */
 | 
			
		||||
    public $text;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @var -1|positive-int
 | 
			
		||||
     */
 | 
			
		||||
    public $line;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @var int
 | 
			
		||||
     */
 | 
			
		||||
    public $pos;
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @param -1|positive-int $line
 | 
			
		||||
     */
 | 
			
		||||
    public function __construct(int $id, string $text, int $line = -1, int $position = -1)
 | 
			
		||||
    {
 | 
			
		||||
        $this->id = $id;
 | 
			
		||||
        $this->text = $text;
 | 
			
		||||
        $this->line = $line;
 | 
			
		||||
        $this->pos = $position;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function getTokenName(): ?string
 | 
			
		||||
    {
 | 
			
		||||
        if ('UNKNOWN' === $name = token_name($this->id)) {
 | 
			
		||||
            $name = \strlen($this->text) > 1 || \ord($this->text) < 32 ? null : $this->text;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return $name;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @param int|string|array $kind
 | 
			
		||||
     */
 | 
			
		||||
    public function is($kind): bool
 | 
			
		||||
    {
 | 
			
		||||
        foreach ((array) $kind as $value) {
 | 
			
		||||
            if (\in_array($value, [$this->id, $this->text], true)) {
 | 
			
		||||
                return true;
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return false;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function isIgnorable(): bool
 | 
			
		||||
    {
 | 
			
		||||
        return \in_array($this->id, [\T_WHITESPACE, \T_COMMENT, \T_DOC_COMMENT, \T_OPEN_TAG], true);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function __toString(): string
 | 
			
		||||
    {
 | 
			
		||||
        return (string) $this->text;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    /**
 | 
			
		||||
     * @return list<static>
 | 
			
		||||
     */
 | 
			
		||||
    public static function tokenize(string $code, int $flags = 0): array
 | 
			
		||||
    {
 | 
			
		||||
        $line = 1;
 | 
			
		||||
        $position = 0;
 | 
			
		||||
        $tokens = token_get_all($code, $flags);
 | 
			
		||||
        foreach ($tokens as $index => $token) {
 | 
			
		||||
            if (\is_string($token)) {
 | 
			
		||||
                $id = \ord($token);
 | 
			
		||||
                $text = $token;
 | 
			
		||||
            } else {
 | 
			
		||||
                [$id, $text, $line] = $token;
 | 
			
		||||
            }
 | 
			
		||||
            $tokens[$index] = new static($id, $text, $line, $position);
 | 
			
		||||
            $position += \strlen($text);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return $tokens;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										25
									
								
								qwen/php/vendor/symfony/polyfill-php80/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								qwen/php/vendor/symfony/polyfill-php80/README.md
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,25 @@
 | 
			
		||||
Symfony Polyfill / Php80
 | 
			
		||||
========================
 | 
			
		||||
 | 
			
		||||
This component provides features added to PHP 8.0 core:
 | 
			
		||||
 | 
			
		||||
- [`Stringable`](https://php.net/stringable) interface
 | 
			
		||||
- [`fdiv`](https://php.net/fdiv)
 | 
			
		||||
- [`ValueError`](https://php.net/valueerror) class
 | 
			
		||||
- [`UnhandledMatchError`](https://php.net/unhandledmatcherror) class
 | 
			
		||||
- `FILTER_VALIDATE_BOOL` constant
 | 
			
		||||
- [`get_debug_type`](https://php.net/get_debug_type)
 | 
			
		||||
- [`PhpToken`](https://php.net/phptoken) class
 | 
			
		||||
- [`preg_last_error_msg`](https://php.net/preg_last_error_msg)
 | 
			
		||||
- [`str_contains`](https://php.net/str_contains)
 | 
			
		||||
- [`str_starts_with`](https://php.net/str_starts_with)
 | 
			
		||||
- [`str_ends_with`](https://php.net/str_ends_with)
 | 
			
		||||
- [`get_resource_id`](https://php.net/get_resource_id)
 | 
			
		||||
 | 
			
		||||
More information can be found in the
 | 
			
		||||
[main Polyfill README](https://github.com/symfony/polyfill/blob/main/README.md).
 | 
			
		||||
 | 
			
		||||
License
 | 
			
		||||
=======
 | 
			
		||||
 | 
			
		||||
This library is released under the [MIT license](LICENSE).
 | 
			
		||||
							
								
								
									
										31
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/Attribute.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/Attribute.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,31 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#[Attribute(Attribute::TARGET_CLASS)]
 | 
			
		||||
final class Attribute
 | 
			
		||||
{
 | 
			
		||||
    public const TARGET_CLASS = 1;
 | 
			
		||||
    public const TARGET_FUNCTION = 2;
 | 
			
		||||
    public const TARGET_METHOD = 4;
 | 
			
		||||
    public const TARGET_PROPERTY = 8;
 | 
			
		||||
    public const TARGET_CLASS_CONSTANT = 16;
 | 
			
		||||
    public const TARGET_PARAMETER = 32;
 | 
			
		||||
    public const TARGET_ALL = 63;
 | 
			
		||||
    public const IS_REPEATABLE = 64;
 | 
			
		||||
 | 
			
		||||
    /** @var int */
 | 
			
		||||
    public $flags;
 | 
			
		||||
 | 
			
		||||
    public function __construct(int $flags = self::TARGET_ALL)
 | 
			
		||||
    {
 | 
			
		||||
        $this->flags = $flags;
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										16
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/PhpToken.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/PhpToken.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,16 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID < 80000 && extension_loaded('tokenizer')) {
 | 
			
		||||
    class PhpToken extends Symfony\Polyfill\Php80\PhpToken
 | 
			
		||||
    {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										20
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/Stringable.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/Stringable.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,20 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID < 80000) {
 | 
			
		||||
    interface Stringable
 | 
			
		||||
    {
 | 
			
		||||
        /**
 | 
			
		||||
         * @return string
 | 
			
		||||
         */
 | 
			
		||||
        public function __toString();
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										16
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/UnhandledMatchError.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,16 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID < 80000) {
 | 
			
		||||
    class UnhandledMatchError extends Error
 | 
			
		||||
    {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										16
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/ValueError.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								qwen/php/vendor/symfony/polyfill-php80/Resources/stubs/ValueError.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,16 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID < 80000) {
 | 
			
		||||
    class ValueError extends Error
 | 
			
		||||
    {
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										42
									
								
								qwen/php/vendor/symfony/polyfill-php80/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								qwen/php/vendor/symfony/polyfill-php80/bootstrap.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,42 @@
 | 
			
		||||
<?php
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * This file is part of the Symfony package.
 | 
			
		||||
 *
 | 
			
		||||
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
			
		||||
 *
 | 
			
		||||
 * For the full copyright and license information, please view the LICENSE
 | 
			
		||||
 * file that was distributed with this source code.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
use Symfony\Polyfill\Php80 as p;
 | 
			
		||||
 | 
			
		||||
if (\PHP_VERSION_ID >= 80000) {
 | 
			
		||||
    return;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!defined('FILTER_VALIDATE_BOOL') && defined('FILTER_VALIDATE_BOOLEAN')) {
 | 
			
		||||
    define('FILTER_VALIDATE_BOOL', \FILTER_VALIDATE_BOOLEAN);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
if (!function_exists('fdiv')) {
 | 
			
		||||
    function fdiv(float $num1, float $num2): float { return p\Php80::fdiv($num1, $num2); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('preg_last_error_msg')) {
 | 
			
		||||
    function preg_last_error_msg(): string { return p\Php80::preg_last_error_msg(); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('str_contains')) {
 | 
			
		||||
    function str_contains(?string $haystack, ?string $needle): bool { return p\Php80::str_contains($haystack ?? '', $needle ?? ''); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('str_starts_with')) {
 | 
			
		||||
    function str_starts_with(?string $haystack, ?string $needle): bool { return p\Php80::str_starts_with($haystack ?? '', $needle ?? ''); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('str_ends_with')) {
 | 
			
		||||
    function str_ends_with(?string $haystack, ?string $needle): bool { return p\Php80::str_ends_with($haystack ?? '', $needle ?? ''); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('get_debug_type')) {
 | 
			
		||||
    function get_debug_type($value): string { return p\Php80::get_debug_type($value); }
 | 
			
		||||
}
 | 
			
		||||
if (!function_exists('get_resource_id')) {
 | 
			
		||||
    function get_resource_id($resource): int { return p\Php80::get_resource_id($resource); }
 | 
			
		||||
}
 | 
			
		||||
							
								
								
									
										37
									
								
								qwen/php/vendor/symfony/polyfill-php80/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								qwen/php/vendor/symfony/polyfill-php80/composer.json
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@@ -0,0 +1,37 @@
 | 
			
		||||
{
 | 
			
		||||
    "name": "symfony/polyfill-php80",
 | 
			
		||||
    "type": "library",
 | 
			
		||||
    "description": "Symfony polyfill backporting some PHP 8.0+ features to lower PHP versions",
 | 
			
		||||
    "keywords": ["polyfill", "shim", "compatibility", "portable"],
 | 
			
		||||
    "homepage": "https://symfony.com",
 | 
			
		||||
    "license": "MIT",
 | 
			
		||||
    "authors": [
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Ion Bazan",
 | 
			
		||||
            "email": "ion.bazan@gmail.com"
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Nicolas Grekas",
 | 
			
		||||
            "email": "p@tchwork.com"
 | 
			
		||||
        },
 | 
			
		||||
        {
 | 
			
		||||
            "name": "Symfony Community",
 | 
			
		||||
            "homepage": "https://symfony.com/contributors"
 | 
			
		||||
        }
 | 
			
		||||
    ],
 | 
			
		||||
    "require": {
 | 
			
		||||
        "php": ">=7.2"
 | 
			
		||||
    },
 | 
			
		||||
    "autoload": {
 | 
			
		||||
        "psr-4": { "Symfony\\Polyfill\\Php80\\": "" },
 | 
			
		||||
        "files": [ "bootstrap.php" ],
 | 
			
		||||
        "classmap": [ "Resources/stubs" ]
 | 
			
		||||
    },
 | 
			
		||||
    "minimum-stability": "dev",
 | 
			
		||||
    "extra": {
 | 
			
		||||
        "thanks": {
 | 
			
		||||
            "name": "symfony/polyfill",
 | 
			
		||||
            "url": "https://github.com/symfony/polyfill"
 | 
			
		||||
        }
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
		Reference in New Issue
	
	Block a user