| Server IP : 127.0.1.1 / Your IP : 216.73.216.152 Web Server : Apache/2.4.52 (Ubuntu) System : Linux bahcrestlinepropertiesllc 5.15.0-113-generic #123-Ubuntu SMP Mon Jun 10 08:16:17 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /var/www/bahcrestline/core/vendor/league/commonmark/src/Util/ |
Upload File : |
<?php
/*
* This file is part of the league/commonmark package.
*
* (c) Colin O'Dell <colinodell@gmail.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace League\CommonMark\Util;
/**
* Array collection
*
* Provides a wrapper around a standard PHP array.
*
* @internal
*/
class ArrayCollection implements \IteratorAggregate, \Countable, \ArrayAccess
{
/**
* @var array
*/
private $elements;
/**
* Constructor
*
* @param array $elements
*/
public function __construct(array $elements = [])
{
$this->elements = $elements;
}
/**
* @return mixed
*/
public function first()
{
return \reset($this->elements);
}
/**
* @return mixed
*/
public function last()
{
return \end($this->elements);
}
/**
* Retrieve an external iterator
*
* @return \ArrayIterator
*/
public function getIterator()
{
return new \ArrayIterator($this->elements);
}
/**
* @param mixed $element
*
* @return bool
*/
public function add($element): bool
{
$this->elements[] = $element;
return true;
}
/**
* @param mixed $key
* @param mixed $value
*/
public function set($key, $value)
{
$this->elements[$key] = $value;
}
/**
* @param mixed $key
*
* @return mixed
*/
public function get($key)
{
return isset($this->elements[$key]) ? $this->elements[$key] : null;
}
/**
* @param mixed $key
*
* @return mixed|null
*/
public function remove($key)
{
if (!\array_key_exists($key, $this->elements)) {
return;
}
$removed = $this->elements[$key];
unset($this->elements[$key]);
return $removed;
}
/**
* @return bool
*/
public function isEmpty(): bool
{
return empty($this->elements);
}
/**
* @param mixed $element
*
* @return bool
*/
public function contains($element): bool
{
return \in_array($element, $this->elements, true);
}
/**
* @param mixed $element
*
* @return mixed|false
*/
public function indexOf($element)
{
return \array_search($element, $this->elements, true);
}
/**
* @param mixed $key
*
* @return bool
*/
public function containsKey($key): bool
{
return \array_key_exists($key, $this->elements);
}
/**
* Count elements of an object
*
* @return int The count as an integer.
*/
public function count(): int
{
return \count($this->elements);
}
/**
* Whether an offset exists
*
* @param mixed $offset An offset to check for.
*
* @return bool true on success or false on failure.
*/
public function offsetExists($offset): bool
{
return $this->containsKey($offset);
}
/**
* Offset to retrieve
*
* @param mixed $offset The offset to retrieve.
*
* @return mixed
*/
public function offsetGet($offset)
{
return $this->get($offset);
}
/**
* Offset to set
*
* @param mixed $offset The offset to assign the value to.
* @param mixed $value The value to set.
*
* @return void
*/
public function offsetSet($offset, $value)
{
if ($offset === null) {
$this->add($value);
} else {
$this->set($offset, $value);
}
}
/**
* Offset to unset
*
* @param mixed $offset The offset to unset.
*
* @return void
*/
public function offsetUnset($offset)
{
$this->remove($offset);
}
/**
* Returns a subset of the array
*
* @param int $offset
* @param int|null $length
*
* @return array
*/
public function slice(int $offset, ?int $length = null): array
{
return \array_slice($this->elements, $offset, $length, true);
}
/**
* @return array
*/
public function toArray(): array
{
return $this->elements;
}
/**
* @param array $elements
*
* @return $this
*/
public function replaceWith(array $elements)
{
$this->elements = $elements;
return $this;
}
public function removeGaps()
{
$this->elements = \array_filter($this->elements);
}
}