Compare commits
No commits in common. "782325ecc8c498a051d847a74574101dde78bb7f" and "dd1ec57cd321f8aa28f8b2dd5d4168e2b5f5ce9e" have entirely different histories.
782325ecc8
...
dd1ec57cd3
@ -47,9 +47,14 @@ public class CliEngine {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void handleHelp() {
|
void handleHelp() {
|
||||||
registry.values().stream().map(handler -> handler.usage()).forEach(System.out::println);
|
var template = " %-30s // %s";
|
||||||
System.out.printf(Command.templateUsage, "help", "Вот этот список команд\n");
|
System.out.println("Доступные команды:\n");
|
||||||
System.out.printf(Command.templateUsage, "exit", "Выход, но лучше не надо)\n");
|
registry.values().stream()
|
||||||
|
.map(handler -> String.format(template, handler.example(), handler.description()))
|
||||||
|
.forEach(System.out::println);
|
||||||
|
System.out.println();
|
||||||
|
System.out.printf(template, "help", "Вот этот список команд\n");
|
||||||
|
System.out.printf(template, "exit", "Выход, но лучше не надо)\n");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -5,12 +5,11 @@ import java.util.Optional;
|
|||||||
import ru.kamask.pet.todo.service.TaskService;
|
import ru.kamask.pet.todo.service.TaskService;
|
||||||
|
|
||||||
public interface Command {
|
public interface Command {
|
||||||
String templateUsage = " %-30s // %s";
|
|
||||||
String errorMessage = "Не корректно введена команда. Введите help для спарвки.";
|
|
||||||
|
|
||||||
Optional<String> handle(String[] args, TaskService service);
|
Optional<String> handle(String[] args, TaskService service);
|
||||||
|
|
||||||
String name();
|
String name();
|
||||||
|
|
||||||
String usage();
|
String example();
|
||||||
|
|
||||||
|
String description();
|
||||||
}
|
}
|
||||||
|
|||||||
@ -12,16 +12,17 @@ public class CreateCommand implements Command {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Optional<String> handle(String[] args, TaskService service) {
|
public Optional<String> handle(String[] args, TaskService service) {
|
||||||
if (args.length > 0) {
|
// TODO create new todo
|
||||||
var title = String.join(" ", args);
|
return Optional.of("Добавление новой задачи");
|
||||||
service.create(title);
|
|
||||||
return Optional.of(String.format("Задача \"%s\" успешно добавлена!", title));
|
|
||||||
}
|
|
||||||
return Optional.of(Command.errorMessage);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String usage() {
|
public String example() {
|
||||||
return String.format(templateUsage, name() + " <название_задачи>", "Добавление новой задачи");
|
return name() + " <title>";
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String description() {
|
||||||
|
return "Добавление новой задачи";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user