Skip to content

Commit

Permalink
Merge pull request #83 from Ocramius/feature/improve-hydrator-closure…
Browse files Browse the repository at this point in the history
…-garbage-collection

Improved hydration of `private` properties by ~15%
  • Loading branch information
Ocramius authored Mar 4, 2019
2 parents a33f9c1 + bc03e8d commit 5838d24
Showing 1 changed file with 2 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ private function replaceConstructor(ClassMethod $method) : void
// then be called in order in the hydrate() and extract() methods.
foreach ($this->hiddenPropertyMap as $className => $propertyNames) {
// Hydrate closures
$bodyParts[] = '$this->hydrateCallbacks[] = \\Closure::bind(function ($object, $values) {';
$bodyParts[] = '$this->hydrateCallbacks[] = \\Closure::bind(static function ($object, $values) {';
foreach ($propertyNames as $propertyName) {
$bodyParts[] = " if (isset(\$values['" . $propertyName . "']) || " .
'$object->' . $propertyName . " !== null && \\array_key_exists('" . $propertyName . "', \$values)) {";
Expand All @@ -111,7 +111,7 @@ private function replaceConstructor(ClassMethod $method) : void
$bodyParts[] = '}, null, ' . var_export($className, true) . ');' . "\n";

// Extract closures
$bodyParts[] = '$this->extractCallbacks[] = \\Closure::bind(function ($object, &$values) {';
$bodyParts[] = '$this->extractCallbacks[] = \\Closure::bind(static function ($object, &$values) {';
foreach ($propertyNames as $propertyName) {
$bodyParts[] = " \$values['" . $propertyName . "'] = \$object->" . $propertyName . ';';
}
Expand Down

0 comments on commit 5838d24

Please sign in to comment.