PHP 8.3.31
Preview: DoubleEndedQueue.php Size: 4.19 KB
/home/getspomw/royalsquad.us/vendor/ramsey/collection/src/DoubleEndedQueue.php

<?php

/**
 * This file is part of the ramsey/collection library
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 *
 * @copyright Copyright (c) Ben Ramsey <ben@benramsey.com>
 * @license http://opensource.org/licenses/MIT MIT
 */

declare(strict_types=1);

namespace Ramsey\Collection;

use Ramsey\Collection\Exception\InvalidArgumentException;
use Ramsey\Collection\Exception\NoSuchElementException;

use function array_key_last;
use function array_pop;
use function array_unshift;

/**
 * This class provides a basic implementation of `DoubleEndedQueueInterface`, to
 * minimize the effort required to implement this interface.
 *
 * @template T
 * @extends Queue<T>
 * @implements DoubleEndedQueueInterface<T>
 */
class DoubleEndedQueue extends Queue implements DoubleEndedQueueInterface
{
    /**
     * Constructs a double-ended queue (dequeue) object of the specified type,
     * optionally with the specified data.
     *
     * @param string $queueType The type or class name associated with this dequeue.
     * @param array<array-key, T> $data The initial items to store in the dequeue.
     */
    public function __construct(private readonly string $queueType, array $data = [])
    {
        parent::__construct($this->queueType, $data);
    }

    /**
     * @throws InvalidArgumentException if $element is of the wrong type
     */
    public function addFirst(mixed $element): bool
    {
        if ($this->checkType($this->getType(), $element) === false) {
            throw new InvalidArgumentException(
                'Value must be of type ' . $this->getType() . '; value is '
                . $this->toolValueToString($element),
            );
        }

        array_unshift($this->data, $element);

        return true;
    }

    /**
     * @throws InvalidArgumentException if $element is of the wrong type
     */
    public function addLast(mixed $element): bool
    {
        return $this->add($element);
    }

    public function offerFirst(mixed $element): bool
    {
        try {
            return $this->addFirst($element);
        } catch (InvalidArgumentException) {
            return false;
        }
    }

    public function offerLast(mixed $element): bool
    {
        return $this->offer($element);
    }

    /**
     * @return T the first element in this queue.
     *
     * @throws NoSuchElementException if the queue is empty
     */
    public function removeFirst(): mixed
    {
        return $this->remove();
    }

    /**
     * @return T the last element in this queue.
     *
     * @throws NoSuchElementException if this queue is empty.
     */
    public function removeLast(): mixed
    {
        return $this->pollLast() ?? throw new NoSuchElementException(
            'Can\'t return element from Queue. Queue is empty.',
        );
    }

    /**
     * @return T | null the head of this queue, or `null` if this queue is empty.
     */
    public function pollFirst(): mixed
    {
        return $this->poll();
    }

    /**
     * @return T | null the tail of this queue, or `null` if this queue is empty.
     */
    public function pollLast(): mixed
    {
        return array_pop($this->data);
    }

    /**
     * @return T the head of this queue.
     *
     * @throws NoSuchElementException if this queue is empty.
     */
    public function firstElement(): mixed
    {
        return $this->element();
    }

    /**
     * @return T the tail of this queue.
     *
     * @throws NoSuchElementException if this queue is empty.
     */
    public function lastElement(): mixed
    {
        return $this->peekLast() ?? throw new NoSuchElementException(
            'Can\'t return element from Queue. Queue is empty.',
        );
    }

    /**
     * @return T | null the head of this queue, or `null` if this queue is empty.
     */
    public function peekFirst(): mixed
    {
        return $this->peek();
    }

    /**
     * @return T | null the tail of this queue, or `null` if this queue is empty.
     */
    public function peekLast(): mixed
    {
        $lastIndex = array_key_last($this->data);

        if ($lastIndex === null) {
            return null;
        }

        return $this->data[$lastIndex];
    }
}

Directory Contents

Dirs: 3 × Files: 14

Name Size Perms Modified Actions
Exception DIR
- drwxrwxrwx 2026-04-19 15:10:17
Edit Download
Map DIR
- drwxrwxrwx 2026-04-21 10:48:13
Edit Download
Tool DIR
- drwxrwxrwx 2025-09-17 06:53:33
Edit Download
4.27 KB lrw-rw-rw- 2025-09-17 06:53:33
Edit Download
11.82 KB lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
1.02 KB lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
1.04 KB lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
2.28 KB lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
8.94 KB lrw-rw-rw- 2025-09-17 06:53:33
Edit Download
4.19 KB lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
10.12 KB lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
10.84 KB lrw-r--r-- 2026-04-26 08:20:02
Edit Download
512 B lrw-rw-rw- 2025-09-17 06:53:32
Edit Download
3.58 KB lrw-rw-rw- 2025-09-17 06:53:33
Edit Download
7.22 KB lrw-rw-rw- 2025-09-17 06:53:33
Edit Download
1.54 KB lrw-rw-rw- 2025-09-17 06:53:33
Edit Download
621 B lrw-rw-rw- 2025-09-17 06:53:32
Edit Download

If ZipArchive is unavailable, a .tar will be created (no compression).