initx /
querabilis
| 1 | <?php declare(strict_types=1); |
||||
| 2 | |||||
| 3 | namespace Initx\Querabilis\Driver; |
||||
| 4 | |||||
| 5 | use Initx\Querabilis\Envelope; |
||||
| 6 | use Initx\Querabilis\Exception\NoSuchElementException; |
||||
| 7 | |||||
| 8 | trait HasDefaultRemoveAndElement |
||||
| 9 | { |
||||
| 10 | 12 | public function remove(): Envelope |
|||
| 11 | { |
||||
| 12 | 12 | return $this->returnOrThrowNoSuchElement($this->poll()); |
|||
|
0 ignored issues
–
show
Bug
introduced
by
Loading history...
|
|||||
| 13 | } |
||||
| 14 | |||||
| 15 | 11 | public function element(): Envelope |
|||
| 16 | { |
||||
| 17 | 11 | return $this->returnOrThrowNoSuchElement($this->peek()); |
|||
|
0 ignored issues
–
show
It seems like
peek() must be provided by classes using this trait. How about adding it as abstract method to this trait?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
Loading history...
|
|||||
| 18 | } |
||||
| 19 | |||||
| 20 | 18 | private function returnOrThrowNoSuchElement(?Envelope $envelope = null): Envelope |
|||
| 21 | { |
||||
| 22 | 18 | if (!$envelope) { |
|||
| 23 | 5 | throw new NoSuchElementException(); |
|||
| 24 | } |
||||
| 25 | |||||
| 26 | 13 | return $envelope; |
|||
| 27 | } |
||||
| 28 | } |
||||
| 29 |