Skip to content

Commit

Permalink
Add multiply to collection
Browse files Browse the repository at this point in the history
Multiply the items in the collection by the multiplier.
  • Loading branch information
patrickomeara committed Jun 21, 2024
1 parent 5104bce commit 3eca897
Show file tree
Hide file tree
Showing 4 changed files with 62 additions and 0 deletions.
17 changes: 17 additions & 0 deletions src/Illuminate/Collections/Collection.php
Original file line number Diff line number Diff line change
Expand Up @@ -830,6 +830,23 @@ public function mergeRecursive($items)
return new static(array_merge_recursive($this->items, $this->getArrayableItems($items)));
}

/**
* Multiply the items in the collection by the multiplier.
*
* @param $multiplier
* @return static
*/
public function multiply($multiplier)
{
$new = new static();

for ($i = 0; $i < $multiplier; $i++) {
$new->push(...$this->items);
}

return $new;
}

/**
* Create a collection by using this collection for keys and another for its values.
*
Expand Down
11 changes: 11 additions & 0 deletions src/Illuminate/Collections/LazyCollection.php
Original file line number Diff line number Diff line change
Expand Up @@ -841,6 +841,17 @@ public function mergeRecursive($items)
return $this->passthru('mergeRecursive', func_get_args());
}

/**
* Multiply the items in the collection by the multiplier.
*
* @param $multiplier
* @return static
*/
public function multiply($multiplier)
{
return $this->passthru('multiply', func_get_args());
}

/**
* Create a collection by using this collection for keys and another for its values.
*
Expand Down
15 changes: 15 additions & 0 deletions tests/Database/DatabaseEloquentCollectionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -510,6 +510,21 @@ public function testMakeVisibleRemovesHiddenAndIncludesVisible()
$this->assertEquals(['visible', 'hidden'], $c[0]->getVisible());
}

public function testMultiply()
{
$a = new TestEloquentCollectionModel();
$b = new TestEloquentCollectionModel();

$c = new Collection([$a, $b]);

$this->assertEquals([], $c->multiply(-1)->all());
$this->assertEquals([], $c->multiply(0)->all());

$this->assertEquals([$a, $b], $c->multiply(1)->all());

$this->assertEquals([$a, $b, $a, $b, $a, $b], $c->multiply(3)->all());
}

public function testQueueableCollectionImplementation()
{
$c = new Collection([new TestEloquentCollectionModel, new TestEloquentCollectionModel]);
Expand Down
19 changes: 19 additions & 0 deletions tests/Support/SupportCollectionTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -1231,6 +1231,25 @@ public function testMergeRecursiveCollection($collection)
);
}

#[DataProvider('collectionClassProvider')]
public function testMultiplyCollection($collection)
{
$c = new $collection(['Hello', 1, ['tags' => ['a', 'b'], 'admin']]);

$this->assertEquals([], $c->multiply(-1)->all());
$this->assertEquals([], $c->multiply(0)->all());

$this->assertEquals(
['Hello', 1, ['tags' => ['a', 'b'], 'admin']],
$c->multiply(1)->all()
);

$this->assertEquals(
['Hello', 1, ['tags' => ['a', 'b'], 'admin'], 'Hello', 1, ['tags' => ['a', 'b'], 'admin'], 'Hello', 1, ['tags' => ['a', 'b'], 'admin']],
$c->multiply(3)->all()
);
}

#[DataProvider('collectionClassProvider')]
public function testReplaceNull($collection)
{
Expand Down

0 comments on commit 3eca897

Please sign in to comment.