Test Failed
Pull Request — master (#184)
by Vincent
09:57
created

fr.quatrevieux.araknemu.game.admin.exception.handler.CommandExceptionHandler   A

Complexity

Total Complexity 2

Size/Duplication

Total Lines 9
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 9
c 1
b 0
f 0
dl 0
loc 9
rs 10
wmc 2

1 Method

Rating   Name   Duplication   Size   Complexity  
A handle(AdminPerformer,CommandException,Arguments) 0 8 2
1
/*
2
 * This file is part of Araknemu.
3
 *
4
 * Araknemu is free software: you can redistribute it and/or modify
5
 * it under the terms of the GNU Lesser General Public License as published by
6
 * the Free Software Foundation, either version 3 of the License, or
7
 * (at your option) any later version.
8
 *
9
 * Araknemu is distributed in the hope that it will be useful,
10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
 * GNU Lesser General Public License for more details.
13
 *
14
 * You should have received a copy of the GNU Lesser General Public License
15
 * along with Araknemu.  If not, see <https://www.gnu.org/licenses/>.
16
 *
17
 * Copyright (c) 2017-2021 Vincent Quatrevieux
18
 */
19
20
package fr.quatrevieux.araknemu.game.admin.exception.handler;
21
22
import fr.quatrevieux.araknemu.game.admin.AdminPerformer;
23
import fr.quatrevieux.araknemu.game.admin.CommandParser;
24
import fr.quatrevieux.araknemu.game.admin.exception.CommandException;
25
import fr.quatrevieux.araknemu.game.admin.exception.ExceptionHandler;
26
import fr.quatrevieux.araknemu.game.admin.formatter.Link;
27
28
/**
29
 * Exception handler for base command exception
30
 */
31
public final class CommandExceptionHandler implements ExceptionHandler.Function<CommandException> {
32
    @Override
33
    public void handle(AdminPerformer performer, CommandException error, CommandParser.Arguments arguments) {
34
        performer.error("An error occurs during execution of '{}' : {}", error.command(), error.getMessage());
35
        performer.error(
36
            "See {} for usage",
37
            (new Link())
38
                .execute((arguments != null ? arguments.contextPath() : "") + " help " + error.command())
39
                .text("help")
40
        );
41
    }
42
}
43