| @@ 34-41 (lines=8) @@ | ||
| 31 | /** |
|
| 32 | * @return Traversable |
|
| 33 | */ |
|
| 34 | public function getIterator(): Traversable |
|
| 35 | { |
|
| 36 | if (!$this->isSorted) { |
|
| 37 | usort($this->list, [$this, 'compare']); |
|
| 38 | $this->isSorted = true; |
|
| 39 | } |
|
| 40 | return new ArrayIterator($this->list); |
|
| 41 | } |
|
| 42 | ||
| 43 | /** |
|
| 44 | * @param Box $item |
|
| @@ 41-48 (lines=8) @@ | ||
| 38 | /** |
|
| 39 | * @return Traversable |
|
| 40 | */ |
|
| 41 | public function getIterator(): Traversable |
|
| 42 | { |
|
| 43 | if (!$this->isSorted) { |
|
| 44 | usort($this->list, [$this, 'compare']); |
|
| 45 | $this->isSorted = true; |
|
| 46 | } |
|
| 47 | return new ArrayIterator($this->list); |
|
| 48 | } |
|
| 49 | ||
| 50 | /** |
|
| 51 | * Number of items in list |
|
| @@ 83-90 (lines=8) @@ | ||
| 80 | * @internal |
|
| 81 | * @return PackedBox |
|
| 82 | */ |
|
| 83 | public function top(): PackedBox |
|
| 84 | { |
|
| 85 | if (!$this->isSorted) { |
|
| 86 | usort($this->list, [$this, 'compare']); |
|
| 87 | $this->isSorted = true; |
|
| 88 | } |
|
| 89 | return reset($this->list); |
|
| 90 | } |
|
| 91 | ||
| 92 | /** |
|
| 93 | * @param PackedBox $boxA |
|
| @@ 42-49 (lines=8) @@ | ||
| 39 | /** |
|
| 40 | * @return Traversable |
|
| 41 | */ |
|
| 42 | public function getIterator(): Traversable |
|
| 43 | { |
|
| 44 | if (!$this->isSorted) { |
|
| 45 | usort($this->list, [$this, 'compare']); |
|
| 46 | $this->isSorted = true; |
|
| 47 | } |
|
| 48 | return new ArrayIterator($this->list); |
|
| 49 | } |
|
| 50 | ||
| 51 | /** |
|
| 52 | * Number of items in list |
|
| @@ 43-50 (lines=8) @@ | ||
| 40 | * @internal |
|
| 41 | * @return Item |
|
| 42 | */ |
|
| 43 | public function extract(): Item |
|
| 44 | { |
|
| 45 | if (!$this->isSorted) { |
|
| 46 | usort($this->list, [$this, 'compare']); |
|
| 47 | $this->isSorted = true; |
|
| 48 | } |
|
| 49 | return array_shift($this->list); |
|
| 50 | } |
|
| 51 | ||
| 52 | /** |
|
| 53 | * @internal |
|
| @@ 56-64 (lines=9) @@ | ||
| 53 | * @internal |
|
| 54 | * @return Item |
|
| 55 | */ |
|
| 56 | public function top(): Item |
|
| 57 | { |
|
| 58 | if (!$this->isSorted) { |
|
| 59 | usort($this->list, [$this, 'compare']); |
|
| 60 | $this->isSorted = true; |
|
| 61 | } |
|
| 62 | $temp = $this->list; |
|
| 63 | return reset($temp); |
|
| 64 | } |
|
| 65 | ||
| 66 | /** |
|
| 67 | * @return Traversable |
|
| @@ 69-76 (lines=8) @@ | ||
| 66 | /** |
|
| 67 | * @return Traversable |
|
| 68 | */ |
|
| 69 | public function getIterator(): Traversable |
|
| 70 | { |
|
| 71 | if (!$this->isSorted) { |
|
| 72 | usort($this->list, [$this, 'compare']); |
|
| 73 | $this->isSorted = true; |
|
| 74 | } |
|
| 75 | return new ArrayIterator($this->list); |
|
| 76 | } |
|
| 77 | ||
| 78 | /** |
|
| 79 | * Number of items in list |
|