| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 | <?php/* * This file is part of the Symfony package. * * (c) Fabien Potencier <fabien@symfony.com> * * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */namespace Symfony\Component\HttpKernel\Controller\ArgumentResolver;use Symfony\Component\HttpFoundation\Request;use Symfony\Component\HttpKernel\Controller\ArgumentValueResolverInterface;use Symfony\Component\HttpKernel\ControllerMetadata\ArgumentMetadata;use Symfony\Component\Stopwatch\Stopwatch;/** * Provides timing information via the stopwatch. * * @author Iltar van der Berg <kjarli@gmail.com> */final class TraceableValueResolver implements ArgumentValueResolverInterface{    private $inner;    private $stopwatch;    public function __construct(ArgumentValueResolverInterface $inner, Stopwatch $stopwatch)    {        $this->inner = $inner;        $this->stopwatch = $stopwatch;    }    /**     * {@inheritdoc}     */    public function supports(Request $request, ArgumentMetadata $argument): bool    {        $method = \get_class($this->inner).'::'.__FUNCTION__;        $this->stopwatch->start($method, 'controller.argument_value_resolver');        $return = $this->inner->supports($request, $argument);        $this->stopwatch->stop($method);        return $return;    }    /**     * {@inheritdoc}     */    public function resolve(Request $request, ArgumentMetadata $argument): iterable    {        $method = \get_class($this->inner).'::'.__FUNCTION__;        $this->stopwatch->start($method, 'controller.argument_value_resolver');        yield from $this->inner->resolve($request, $argument);        $this->stopwatch->stop($method);    }}
 |