| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103 | <?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\HttpFoundation;/** * Request stack that controls the lifecycle of requests. * * @author Benjamin Eberlei <kontakt@beberlei.de> */class RequestStack{    /**     * @var Request[]     */    private $requests = array();    /**     * Pushes a Request on the stack.     *     * This method should generally not be called directly as the stack     * management should be taken care of by the application itself.     */    public function push(Request $request)    {        $this->requests[] = $request;    }    /**     * Pops the current request from the stack.     *     * This operation lets the current request go out of scope.     *     * This method should generally not be called directly as the stack     * management should be taken care of by the application itself.     *     * @return Request|null     */    public function pop()    {        if (!$this->requests) {            return;        }        return array_pop($this->requests);    }    /**     * @return Request|null     */    public function getCurrentRequest()    {        return end($this->requests) ?: null;    }    /**     * Gets the master Request.     *     * Be warned that making your code aware of the master request     * might make it un-compatible with other features of your framework     * like ESI support.     *     * @return Request|null     */    public function getMasterRequest()    {        if (!$this->requests) {            return;        }        return $this->requests[0];    }    /**     * Returns the parent request of the current.     *     * Be warned that making your code aware of the parent request     * might make it un-compatible with other features of your framework     * like ESI support.     *     * If current Request is the master request, it returns null.     *     * @return Request|null     */    public function getParentRequest()    {        $pos = count($this->requests) - 2;        if (!isset($this->requests[$pos])) {            return;        }        return $this->requests[$pos];    }}
 |