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
![]() |
|||||
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
![]() |
|||||
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 |