Skip to content

Commit

Permalink
Fixes #6. Reimplement type length calculation to cover all possible c…
Browse files Browse the repository at this point in the history
…ases with DNF types
  • Loading branch information
erickskrauch committed Jan 7, 2024
1 parent 6b0e22f commit dddfa99
Show file tree
Hide file tree
Showing 3 changed files with 86 additions and 17 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,8 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).

## [Unreleased]
### Fixed
- Bug #5: `ErickSkrauch/align_multiline_parameters` not working correctly with unions and intersections.

## [1.2.1] - 2023-11-16
### Fixed
Expand Down
28 changes: 11 additions & 17 deletions src/FunctionNotation/AlignMultilineParametersFixer.php
Original file line number Diff line number Diff line change
Expand Up @@ -183,33 +183,27 @@ protected function applyFix(SplFileInfo $file, Tokens $tokens): void {
}
}

private function getFullTypeLength(Tokens $tokens, ?int $typeIndex): int {
/** @var \PhpCsFixer\Tokenizer\Token $typeToken */
$typeToken = $tokens[$typeIndex];
$typeLength = strlen($typeToken->getContent());

if ($typeToken->isGivenKind(CT::T_NULLABLE_TYPE)) {
$possiblyWhitespace = $tokens[$typeIndex + 1];
if ($possiblyWhitespace->isWhitespace()) {
$typeLength += strlen($possiblyWhitespace->getContent());
}

$realTypeToken = $tokens[$tokens->getNextMeaningfulToken($typeIndex)];
$typeLength += strlen($realTypeToken->getContent());
/**
* TODO: The declaration might be split across multiple lines.
* In such case we need to find the longest line and return it as the full type length
*
* @param int $typeIndex points to the beginning of the type
*/
private function getFullTypeLength(Tokens $tokens, int $typeIndex): int {
$typeLength = 0;
$varNameTokenIndex = $tokens->getNextTokenOfKind($typeIndex, [[T_VARIABLE]]);
for ($i = $typeIndex; $i < $varNameTokenIndex - 1; $i++) { // -1 to avoid whitespace between param name and type
$typeLength += strlen($tokens[$i]->getContent());
}

/** @var \PhpCsFixer\Tokenizer\Token $possiblyReadonlyToken */
$possiblyReadonlyToken = $tokens[$typeIndex - 2];
if ($possiblyReadonlyToken->isGivenKind($this->parameterModifiers)) {
/** @var \PhpCsFixer\Tokenizer\Token $whitespaceToken */
$whitespaceToken = $tokens[$typeIndex - 1];
$typeLength += strlen($possiblyReadonlyToken->getContent() . $whitespaceToken->getContent());
}

/** @var \PhpCsFixer\Tokenizer\Token $possiblyPromotionToken */
$possiblyPromotionToken = $tokens[$typeIndex - 4];
if ($possiblyPromotionToken->isGivenKind($this->parameterModifiers)) {
/** @var \PhpCsFixer\Tokenizer\Token $whitespaceToken */
$whitespaceToken = $tokens[$typeIndex - 3];
$typeLength += strlen($possiblyPromotionToken->getContent() . $whitespaceToken->getContent());
}
Expand Down
73 changes: 73 additions & 0 deletions tests/FunctionNotation/AlignMultilineParametersFixerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -344,6 +344,24 @@ public function __construct(
}
',
];
yield 'constructor with union types, mixed whitespace' => [
'<?php
class Test {
public function __construct(
string $string = "string",
protected readonly int | string|null $int = 0
) {}
}
',
'<?php
class Test {
public function __construct(
string $string = "string",
protected readonly int | string|null $int = 0
) {}
}
',
];
}

/**
Expand All @@ -368,6 +386,61 @@ public function provideFalse81Cases(): iterable {
}
}

/**
* @dataProvider provide82TrueCases
* @requires PHP 8.2
*/
public function test82BothTrue(string $expected, ?string $input = null): void {
$this->fixer->configure([
AlignMultilineParametersFixer::C_VARIABLES => true,
AlignMultilineParametersFixer::C_DEFAULTS => true,
]);
$this->doTest($expected, $input);
}

public function provide82TrueCases(): iterable {
yield 'constructor with union types, mixed whitespace' => [
'<?php
class Test {
public function __construct(
string $string = "string",
protected readonly int | (JsonSerializable& Stringable)|null $int = 0
) {}
}
',
'<?php
class Test {
public function __construct(
string $string = "string",
protected readonly int | (JsonSerializable& Stringable)|null $int = 0
) {}
}
',
];
}

/**
* @dataProvider provideFalse82Cases
* @requires PHP 8.2
*/
public function test82BothFalse(string $expected, ?string $input = null): void {
$this->fixer->configure([
AlignMultilineParametersFixer::C_VARIABLES => false,
AlignMultilineParametersFixer::C_DEFAULTS => false,
]);
$this->doTest($expected, $input);
}

public function provideFalse82Cases(): iterable {
foreach ($this->provide82TrueCases() as $key => $case) {
if (isset($case[1])) {
yield $key => [$case[1], $case[0]];
} else {
yield $key => $case;
}
}
}

protected function createFixer(): AbstractFixer {
return new AlignMultilineParametersFixer();
}
Expand Down

0 comments on commit dddfa99

Please sign in to comment.