Вход Регистрация
Файл: symfony-2.7/src/Symfony/Bridge/Twig/Extension/HttpFoundationExtension.php
Строк: 104
<?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 SymfonyBridgeTwigExtension;

use 
SymfonyComponentHttpFoundationRequestStack;
use 
SymfonyComponentHttpFoundationRequest;

/**
 * Twig extension for the Symfony HttpFoundation component.
 *
 * @author Fabien Potencier <fabien@symfony.com>
 */
class HttpFoundationExtension extends Twig_Extension
{
    private 
$requestStack;

    public function 
__construct(RequestStack $requestStack)
    {
        
$this->requestStack $requestStack;
    }

    
/**
     * {@inheritdoc}
     */
    
public function getFunctions()
    {
        return array(
            new 
Twig_SimpleFunction('absolute_url', array($this'generateAbsoluteUrl')),
            new 
Twig_SimpleFunction('relative_path', array($this'generateRelativePath')),
        );
    }

    
/**
     * Returns the absolute URL for the given absolute or relative path.
     *
     * This method returns the path unchanged if no request is available.
     *
     * @param string $path The path
     *
     * @return string The absolute URL
     *
     * @see Request::getUriForPath()
     */
    
public function generateAbsoluteUrl($path)
    {
        if (
false !== strpos($path'://') || '//' === substr($path02)) {
            return 
$path;
        }

        if (!
$request $this->requestStack->getMasterRequest()) {
            return 
$path;
        }

        if (!
$path || '/' !== $path[0]) {
            
$prefix $request->getPathInfo();
            
$last strlen($prefix) - 1;
            if (
$last !== $pos strrpos($prefix'/')) {
                
$prefix substr($prefix0$pos).'/';
            }

            
$path $prefix.$path;
        }

        return 
$request->getUriForPath($path);
    }

    
/**
     * Returns a relative path based on the current Request.
     *
     * This method returns the path unchanged if no request is available.
     *
     * @param string $path The path
     *
     * @return string The relative path
     *
     * @see Request::getRelativeUriForPath()
     */
    
public function generateRelativePath($path)
    {
        if (
false !== strpos($path'://') || '//' === substr($path02)) {
            return 
$path;
        }

        if (!
$request $this->requestStack->getMasterRequest()) {
            return 
$path;
        }

        return 
$request->getRelativeUriForPath($path);
    }

    
/**
     * Returns the name of the extension.
     *
     * @return string The extension name
     */
    
public function getName()
    {
        return 
'request';
    }
}
Онлайн: 1
Реклама