Passed
Push — 0.6.x ( 9a1948...a98caa )
by Shinji
03:23 queued 01:32
created

PhpReaderWorkerProtocol::sendDetachWorker()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
rs 10
c 0
b 0
f 0
1
<?php
2
3
/**
4
 * This file is part of the reliforp/reli-prof package.
5
 *
6
 * (c) sji <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
declare(strict_types=1);
13
14
namespace Reli\Inspector\Daemon\Reader\Worker;
15
16
use Amp\Parallel\Sync\Channel;
0 ignored issues
show
Bug introduced by
The type Amp\Parallel\Sync\Channel was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
17
use Amp\Promise;
0 ignored issues
show
Bug introduced by
The type Amp\Promise was not found. Maybe you did not declare it correctly or list all dependencies?

The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g. excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:

filter:
    dependency_paths: ["lib/*"]

For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths

Loading history...
18
use Reli\Inspector\Daemon\Reader\Protocol\Message\AttachMessage;
19
use Reli\Inspector\Daemon\Reader\Protocol\Message\DetachWorkerMessage;
20
use Reli\Inspector\Daemon\Reader\Protocol\Message\SetSettingsMessage;
21
use Reli\Inspector\Daemon\Reader\Protocol\Message\TraceMessage;
22
use Reli\Inspector\Daemon\Reader\Protocol\PhpReaderWorkerProtocolInterface;
23
24
final class PhpReaderWorkerProtocol implements PhpReaderWorkerProtocolInterface
25
{
26
    public function __construct(
27
        private Channel $channel
28
    ) {
29
    }
30
31
    public static function createFromChannel(Channel $channel): static
32
    {
33
        return new self($channel);
34
    }
35
36
    public function receiveSettings(): Promise
37
    {
38
        /** @var Promise<SetSettingsMessage> */
39
        return $this->channel->receive();
40
    }
41
42
    public function receiveAttach(): Promise
43
    {
44
        /** @var Promise<AttachMessage> */
45
        return $this->channel->receive();
46
    }
47
48
    public function sendTrace(TraceMessage $message): Promise
49
    {
50
        return $this->channel->send($message);
51
    }
52
53
    public function sendDetachWorker(DetachWorkerMessage $message): Promise
54
    {
55
        return $this->channel->send($message);
56
    }
57
}
58