Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php declare(strict_types=1); /* * This file is part of PHP CS Fixer. * * (c) Fabien..

Decoded Output download

<?php

declare(strict_types=1);

/*
 * This file is part of PHP CS Fixer.
 *
 * (c) Fabien Potencier <[email protected]>
 *     Dariusz Rumiski <[email protected]>
 *
 * This source file is subject to the MIT license that is bundled
 * with this source code in the file LICENSE.
 */

namespace PhpCsFixer\Tests\Fixer\Whitespace;

use PhpCsFixer\Tests\Test\AbstractFixerTestCase;

/**
 * @internal
 *
 * @covers \PhpCsFixer\Fixer\Whitespace\TypesSpacesFixer
 *
 * @extends AbstractFixerTestCase<\PhpCsFixer\Fixer\Whitespace\TypesSpacesFixer>
 *
 * @phpstan-import-type _AutogeneratedInputConfiguration from \PhpCsFixer\Fixer\Whitespace\TypesSpacesFixer
 */
final class TypesSpacesFixerTest extends AbstractFixerTestCase
{
    /**
     * @param _AutogeneratedInputConfiguration $configuration
     *
     * @dataProvider provideFixCases
     */
    public function testFix(string $expected, ?string $input = null, array $configuration = []): void
    {
        $this->fixer->configure($configuration);
        $this->doTest($expected, $input);
    }

    public static function provideFixCases(): iterable
    {
        yield [
            '<?php try {} catch (ErrorA|ErrorB $e) {}',
            '<?php try {} catch (ErrorA | ErrorB $e) {}',
        ];

        yield [
            '<?php try {} catch (ErrorA|ErrorB $e) {}',
            '<?php try {} catch (ErrorA    |    ErrorB $e) {}',
        ];

        yield [
            '<?php try {} catch (ErrorA | ErrorB $e) {}',
            '<?php try {} catch (ErrorA|ErrorB $e) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php try {} catch (ErrorA | ErrorB $e) {}',
            '<?php try {} catch (ErrorA    |    ErrorB $e) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            ['space' => 'single'],
        ];
    }

    /**
     * @param _AutogeneratedInputConfiguration $configuration
     *
     * @dataProvider provideFix80Cases
     *
     * @requires PHP 8.0
     */
    public function testFix80(string $expected, ?string $input = null, array $configuration = []): void
    {
        $this->fixer->configure($configuration);
        $this->doTest($expected, $input);
    }

    public static function provideFix80Cases(): iterable
    {
        yield [
            '<?php function foo(TypeA|TypeB $x) {}',
            '<?php function foo(TypeA | TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA|TypeB|TypeC|TypeD $x, TypeE|TypeF $y, TypeA|TypeB $z) {}',
            '<?php function foo(TypeA | TypeB    |    TypeC | TypeD $x, TypeE    |    TypeF $y, TypeA| TypeB $z) {}',
        ];

        yield [
            '<?php function foo(): TypeA|TypeB {}',
            '<?php function foo(): TypeA | TypeB {}',
        ];

        yield [
            '<?php class Foo { private array|int $x; }',
            '<?php class Foo { private array | int $x; }',
        ];

        yield [
            '<?php function foo(TypeA
                |
                TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA
                |
                TypeB $x) {}',
            null,
            ['space' => 'single'],
        ];

        yield [
            '<?php function foo(TypeA/* not a space */|/* not a space */TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA/* not a space */ | /* not a space */TypeB $x) {}',
            '<?php function foo(TypeA/* not a space */|/* not a space */TypeB $x) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php function foo(TypeA// not a space
|//not a space
TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA// not a space
| //not a space
TypeB $x) {}',
            '<?php function foo(TypeA// not a space
|//not a space
TypeB $x) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php class Foo {
                public function __construct(
                    public int|string $a,
                    protected int|string $b,
                    private int|string $c
                ) {}
            }',
            '<?php class Foo {
                public function __construct(
                    public int    |    string $a,
                    protected int | string $b,
                    private int   |   string $c
                ) {}
            }',
        ];

        yield [
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA |TypeB $x) {}
                try {} catch (ErrorA| ErrorB $e) {}
            ',
            [
                'space' => 'single',
                'space_multiple_catch' => 'none',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            [
                'space' => 'none',
                'space_multiple_catch' => 'single',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA| TypeB $x) {}
                try {} catch (ErrorA |ErrorB $e) {}
            ',
            [
                'space' => 'none',
                'space_multiple_catch' => 'none',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA |TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            [
                'space' => 'single',
                'space_multiple_catch' => 'single',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            [
                'space' => 'single',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA  | TypeB $x) {}
                try {} catch (ErrorA  | ErrorB $e) {}
            ',
            [
                'space' => 'none',
            ],
        ];
    }

    /**
     * @dataProvider provideFix81Cases
     *
     * @requires PHP 8.1
     */
    public function testFix81(string $expected, string $input): void
    {
        $this->doTest($expected, $input);
    }

    public static function provideFix81Cases(): iterable
    {
        yield [
            '<?php class Foo {
                public function __construct(
                    public readonly int|string $a,
                    protected    readonly       int|string $b,
                    private  readonly int|string $c
                ) {}
            }',
            '<?php class Foo {
                public function __construct(
                    public readonly int    |    string $a,
                    protected    readonly       int | string $b,
                    private  readonly int   |   string $c
                ) {}
            }',
        ];

        yield [
            '<?php function foo(): \Foo&Bar {}',
            '<?php function foo(): \Foo  &  Bar {}',
        ];
    }
}
 ?>

Did this file decode correctly?

Original Code

<?php

declare(strict_types=1);

/*
 * This file is part of PHP CS Fixer.
 *
 * (c) Fabien Potencier <[email protected]>
 *     Dariusz Rumiski <[email protected]>
 *
 * This source file is subject to the MIT license that is bundled
 * with this source code in the file LICENSE.
 */

namespace PhpCsFixer\Tests\Fixer\Whitespace;

use PhpCsFixer\Tests\Test\AbstractFixerTestCase;

/**
 * @internal
 *
 * @covers \PhpCsFixer\Fixer\Whitespace\TypesSpacesFixer
 *
 * @extends AbstractFixerTestCase<\PhpCsFixer\Fixer\Whitespace\TypesSpacesFixer>
 *
 * @phpstan-import-type _AutogeneratedInputConfiguration from \PhpCsFixer\Fixer\Whitespace\TypesSpacesFixer
 */
final class TypesSpacesFixerTest extends AbstractFixerTestCase
{
    /**
     * @param _AutogeneratedInputConfiguration $configuration
     *
     * @dataProvider provideFixCases
     */
    public function testFix(string $expected, ?string $input = null, array $configuration = []): void
    {
        $this->fixer->configure($configuration);
        $this->doTest($expected, $input);
    }

    public static function provideFixCases(): iterable
    {
        yield [
            '<?php try {} catch (ErrorA|ErrorB $e) {}',
            '<?php try {} catch (ErrorA | ErrorB $e) {}',
        ];

        yield [
            '<?php try {} catch (ErrorA|ErrorB $e) {}',
            '<?php try {} catch (ErrorA    |    ErrorB $e) {}',
        ];

        yield [
            '<?php try {} catch (ErrorA | ErrorB $e) {}',
            '<?php try {} catch (ErrorA|ErrorB $e) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php try {} catch (ErrorA | ErrorB $e) {}',
            '<?php try {} catch (ErrorA    |    ErrorB $e) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            ['space' => 'single'],
        ];
    }

    /**
     * @param _AutogeneratedInputConfiguration $configuration
     *
     * @dataProvider provideFix80Cases
     *
     * @requires PHP 8.0
     */
    public function testFix80(string $expected, ?string $input = null, array $configuration = []): void
    {
        $this->fixer->configure($configuration);
        $this->doTest($expected, $input);
    }

    public static function provideFix80Cases(): iterable
    {
        yield [
            '<?php function foo(TypeA|TypeB $x) {}',
            '<?php function foo(TypeA | TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA|TypeB|TypeC|TypeD $x, TypeE|TypeF $y, TypeA|TypeB $z) {}',
            '<?php function foo(TypeA | TypeB    |    TypeC | TypeD $x, TypeE    |    TypeF $y, TypeA| TypeB $z) {}',
        ];

        yield [
            '<?php function foo(): TypeA|TypeB {}',
            '<?php function foo(): TypeA | TypeB {}',
        ];

        yield [
            '<?php class Foo { private array|int $x; }',
            '<?php class Foo { private array | int $x; }',
        ];

        yield [
            '<?php function foo(TypeA
                |
                TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA
                |
                TypeB $x) {}',
            null,
            ['space' => 'single'],
        ];

        yield [
            '<?php function foo(TypeA/* not a space */|/* not a space */TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA/* not a space */ | /* not a space */TypeB $x) {}',
            '<?php function foo(TypeA/* not a space */|/* not a space */TypeB $x) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php function foo(TypeA// not a space
|//not a space
TypeB $x) {}',
        ];

        yield [
            '<?php function foo(TypeA// not a space
| //not a space
TypeB $x) {}',
            '<?php function foo(TypeA// not a space
|//not a space
TypeB $x) {}',
            ['space' => 'single'],
        ];

        yield [
            '<?php class Foo {
                public function __construct(
                    public int|string $a,
                    protected int|string $b,
                    private int|string $c
                ) {}
            }',
            '<?php class Foo {
                public function __construct(
                    public int    |    string $a,
                    protected int | string $b,
                    private int   |   string $c
                ) {}
            }',
        ];

        yield [
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA |TypeB $x) {}
                try {} catch (ErrorA| ErrorB $e) {}
            ',
            [
                'space' => 'single',
                'space_multiple_catch' => 'none',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            [
                'space' => 'none',
                'space_multiple_catch' => 'single',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA| TypeB $x) {}
                try {} catch (ErrorA |ErrorB $e) {}
            ',
            [
                'space' => 'none',
                'space_multiple_catch' => 'none',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA |TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            [
                'space' => 'single',
                'space_multiple_catch' => 'single',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA | TypeB $x) {}
                try {} catch (ErrorA | ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            [
                'space' => 'single',
            ],
        ];

        yield [
            '<?php
                function foo(TypeA|TypeB $x) {}
                try {} catch (ErrorA|ErrorB $e) {}
            ',
            '<?php
                function foo(TypeA  | TypeB $x) {}
                try {} catch (ErrorA  | ErrorB $e) {}
            ',
            [
                'space' => 'none',
            ],
        ];
    }

    /**
     * @dataProvider provideFix81Cases
     *
     * @requires PHP 8.1
     */
    public function testFix81(string $expected, string $input): void
    {
        $this->doTest($expected, $input);
    }

    public static function provideFix81Cases(): iterable
    {
        yield [
            '<?php class Foo {
                public function __construct(
                    public readonly int|string $a,
                    protected    readonly       int|string $b,
                    private  readonly int|string $c
                ) {}
            }',
            '<?php class Foo {
                public function __construct(
                    public readonly int    |    string $a,
                    protected    readonly       int | string $b,
                    private  readonly int   |   string $c
                ) {}
            }',
        ];

        yield [
            '<?php function foo(): \Foo&Bar {}',
            '<?php function foo(): \Foo  &  Bar {}',
        ];
    }
}

Function Calls

None

Variables

None

Stats

MD5 2a15c372bfe6a9c7c8e96561bde4e19e
Eval Count 0
Decode Time 110 ms