mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
FIX Ensure DataList::eagerLoad() returns a clone (#10899)
This commit is contained in:
parent
3628cec1f3
commit
c9f48089c9
@ -1478,9 +1478,10 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li
|
|||||||
*/
|
*/
|
||||||
public function eagerLoad(...$relationChains): static
|
public function eagerLoad(...$relationChains): static
|
||||||
{
|
{
|
||||||
|
$list = clone $this;
|
||||||
foreach ($relationChains as $relationChain) {
|
foreach ($relationChains as $relationChain) {
|
||||||
// Don't add any relations we've added before
|
// Don't add any relations we've added before
|
||||||
if (array_key_exists($relationChain, $this->eagerLoadAllRelations)) {
|
if (array_key_exists($relationChain, $list->eagerLoadAllRelations)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
$parts = explode('.', $relationChain);
|
$parts = explode('.', $relationChain);
|
||||||
@ -1496,15 +1497,15 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li
|
|||||||
foreach ($parts as $part) {
|
foreach ($parts as $part) {
|
||||||
$usedParts[] = $part;
|
$usedParts[] = $part;
|
||||||
$item = implode('.', $usedParts);
|
$item = implode('.', $usedParts);
|
||||||
unset($this->eagerLoadRelationChains[$item]);
|
unset($list->eagerLoadRelationChains[$item]);
|
||||||
// Keep track of what we've seen before so we don't accidentally add a level 1 relation
|
// Keep track of what we've seen before so we don't accidentally add a level 1 relation
|
||||||
// (e.g. "Players") to the chains list when we already have it as part of a longer chain
|
// (e.g. "Players") to the chains list when we already have it as part of a longer chain
|
||||||
// (e.g. "Players.Teams")
|
// (e.g. "Players.Teams")
|
||||||
$this->eagerLoadAllRelations[$item] = $item;
|
$list->eagerLoadAllRelations[$item] = $item;
|
||||||
}
|
}
|
||||||
$this->eagerLoadRelationChains[$relationChain] = $relationChain;
|
$list->eagerLoadRelationChains[$relationChain] = $relationChain;
|
||||||
}
|
}
|
||||||
return $this;
|
return $list;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
Loading…
x
Reference in New Issue
Block a user