From c9f48089c9a8ce8d220b4ad42c32b8b56b0d87d1 Mon Sep 17 00:00:00 2001 From: Guy Sartorelli <36352093+GuySartorelli@users.noreply.github.com> Date: Fri, 4 Aug 2023 12:04:20 +1200 Subject: [PATCH] FIX Ensure DataList::eagerLoad() returns a clone (#10899) --- src/ORM/DataList.php | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/ORM/DataList.php b/src/ORM/DataList.php index 397192b1b..e2df7893e 100644 --- a/src/ORM/DataList.php +++ b/src/ORM/DataList.php @@ -1478,9 +1478,10 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li */ public function eagerLoad(...$relationChains): static { + $list = clone $this; foreach ($relationChains as $relationChain) { // Don't add any relations we've added before - if (array_key_exists($relationChain, $this->eagerLoadAllRelations)) { + if (array_key_exists($relationChain, $list->eagerLoadAllRelations)) { continue; } $parts = explode('.', $relationChain); @@ -1496,15 +1497,15 @@ class DataList extends ViewableData implements SS_List, Filterable, Sortable, Li foreach ($parts as $part) { $usedParts[] = $part; $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 // (e.g. "Players") to the chains list when we already have it as part of a longer chain // (e.g. "Players.Teams") - $this->eagerLoadAllRelations[$item] = $item; + $list->eagerLoadAllRelations[$item] = $item; } - $this->eagerLoadRelationChains[$relationChain] = $relationChain; + $list->eagerLoadRelationChains[$relationChain] = $relationChain; } - return $this; + return $list; } /**