Passed
Pull Request — master (#1819)
by Nico
52:14 queued 25:19
created

ColonyDefendingBattleParty::getAttackCause()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
nc 1
nop 0
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
c 1
b 0
f 0
1
<?php
2
3
namespace Stu\Module\Ship\Lib\Battle\Party;
4
5
use Doctrine\Common\Collections\Collection;
6
use Stu\Module\Ship\Lib\Battle\ShipAttackCauseEnum;
7
use Stu\Module\Ship\Lib\ShipWrapperInterface;
8
9
class ColonyDefendingBattleParty extends AbstractBattleParty implements AlertedBattlePartyInterface
10
{
11 4
    public function __construct(
12
        ShipWrapperInterface $leader
13
    ) {
14 4
        parent::__construct($leader);
15
    }
16
17 2
    public function initMembers(): Collection
18
    {
19 2
        $fleet = $this->leader->getFleetWrapper();
20
21 2
        if ($fleet === null) {
22 1
            return $this->createSingleton($this->leader);
23
        } else {
24
25
            // only uncloaked ships enter fight
26 1
            return $fleet->getShipWrappers()
27 1
                ->filter(fn (ShipWrapperInterface $wrapper) => !$wrapper->get()->getCloakState());
28
        }
29
    }
30
31 1
    public function getAttackCause(): ShipAttackCauseEnum
32
    {
33 1
        return ShipAttackCauseEnum::COLONY_DEFENSE;
34
    }
35
36 1
    public function getAlertDescription(): string
37
    {
38 1
        return '[b][color=orange]Kolonie-Verteidigung[/color][/b]';
39
    }
40
}
41