diff --git a/Neos.Eel/Classes/Context.php b/Neos.Eel/Classes/Context.php index ba441e2d69..ead8d97b54 100644 --- a/Neos.Eel/Classes/Context.php +++ b/Neos.Eel/Classes/Context.php @@ -94,7 +94,6 @@ public function call($method, array $arguments = []) if ($this->value === null) { return null; } elseif (is_object($this->value)) { - $this->tracer?->recordMethodCall($this->value, $method); $callback = [$this->value, $method]; } elseif (is_array($this->value)) { if (!array_key_exists($method, $this->value)) { @@ -113,6 +112,14 @@ public function call($method, array $arguments = []) $arguments[$i] = $arguments[$i]->unwrap(); } } + if ($this->tracer !== null) { + // optional experimental tracing + if (is_object($this->value)) { + $this->tracer->recordMethodCall($this->value, $method, $arguments); + } else { + $this->tracer->recordFunctionCall($callback, $method, $arguments); + } + } return call_user_func_array($callback, $arguments); } diff --git a/Neos.Eel/Classes/EelInvocationTracerInterface.php b/Neos.Eel/Classes/EelInvocationTracerInterface.php index 9ad7c93d0b..4ef07b334d 100644 --- a/Neos.Eel/Classes/EelInvocationTracerInterface.php +++ b/Neos.Eel/Classes/EelInvocationTracerInterface.php @@ -9,5 +9,13 @@ interface EelInvocationTracerInterface { public function recordPropertyAccess(object $object, string $propertyName): void; - public function recordMethodCall(object $object, string $methodName): void; + /** + * @param array $arguments + */ + public function recordMethodCall(object $object, string $methodName, array $arguments): void; + + /** + * @param array $arguments + */ + public function recordFunctionCall(callable $function, string $functionName, array $arguments): void; }