Skip to content

Commit

Permalink
Merge pull request #6 from chadicus/fea/pad
Browse files Browse the repository at this point in the history
Add Arrays::pad
  • Loading branch information
jncarver authored Sep 14, 2020
2 parents 6c4f92c + 9f8d3a3 commit da4b4ab
Show file tree
Hide file tree
Showing 3 changed files with 91 additions and 0 deletions.
9 changes: 9 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,15 @@ $value = \TraderInteractive\Filter\Arrays::flatten([[1, 2], [3, [4, 5]]]);
assert($value === [1, 2, 3, 4, 5]);
```

#### Arrays::pad

This filter pads an array to the specified length with a value. Padding optionally to the front or end of the array.

```php
$value = \TraderInteractive\Filter\Arrays::pad([1, 2], 5, 0, \TraderInteractive\Filter\Arrays::ARRAY_PAD_FRONT);
assert($value === [0, 0, 0, 1, 2]);
```

## Project Build

With a checkout of the code get [Composer](http://getcomposer.org) in your PATH and run:
Expand Down
40 changes: 40 additions & 0 deletions src/Arrays.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,13 +2,24 @@

namespace TraderInteractive\Filter;

use InvalidArgumentException;
use TraderInteractive\Exceptions\FilterException;

/**
* A collection of filters for arrays.
*/
final class Arrays
{
/**
* @var int
*/
const ARRAY_PAD_END = 1;

/**
* @var int
*/
const ARRAY_PAD_FRONT = 2;

/**
* Filter an array by throwing if not an array or count not in the min/max range.
*
Expand Down Expand Up @@ -149,4 +160,33 @@ public static function copy(array $source, array $keyMap) : array

return $result;
}

/**
* Pad array to the specified length with a value. Padding optionally to the front or end of the array.
*
* @param array $input Initial array of values to pad.
* @param int $size The new size of the array.
* @param mixed $padValue Value to pad if $input is less than $size.
* @param int $padType Optional argument to specify which end of the array to pad.
*
* @return array Returns a copy of the $input array padded to size specified by $size with value $padValue
*
* @throws InvalidArgumentException Thrown if $padType is invalid.
*/
public static function pad(array $input, int $size, $padValue = null, int $padType = self::ARRAY_PAD_END) : array
{
if ($padType === self::ARRAY_PAD_END) {
return array_pad($input, $size, $padValue);
}

if ($padType !== self::ARRAY_PAD_FRONT) {
throw new InvalidArgumentException('Invalid $padType value provided');
}

while (count($input) < $size) {
array_unshift($input, $padValue);
}

return $input;
}
}
42 changes: 42 additions & 0 deletions tests/ArraysTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@

namespace TraderInteractive\Filter;

use InvalidArgumentException;
use PHPUnit\Framework\TestCase;
use TraderInteractive\Exceptions\FilterException;

Expand Down Expand Up @@ -198,4 +199,45 @@ public function copyEach()
$result
);
}

/**
* @test
* @covers ::pad
*/
public function pad()
{
$result = Arrays::pad([12, 10, 9], 5, 0);
$this->assertSame([12, 10, 9, 0, 0], $result);
}

/**
* @test
* @covers ::pad
*/
public function padArrayLengthGreaterThanSize()
{
$result = Arrays::pad(['a', 'b', 'c'], 2, 0);
$this->assertSame(['a', 'b', 'c'], $result);
}

/**
* @test
* @covers ::pad
*/
public function padFront()
{
$result = Arrays::pad(['a', 'b', 'c'], 5, null, Arrays::ARRAY_PAD_FRONT);
$this->assertSame([null, null, 'a', 'b', 'c'], $result);
}

/**
* @test
* @covers ::pad
*/
public function padInvalidPadType()
{
$this->expectException(InvalidArgumentException::class);
$this->expectExceptionMessage('Invalid $padType value provided');
Arrays::pad(['a', 'b', 'c'], 5, null, 0);
}
}

0 comments on commit da4b4ab

Please sign in to comment.