Compare commits

..

No commits in common. "782325ecc8c498a051d847a74574101dde78bb7f" and "dd1ec57cd321f8aa28f8b2dd5d4168e2b5f5ce9e" have entirely different histories.

3 changed files with 20 additions and 15 deletions

View File

@ -47,9 +47,14 @@ public class CliEngine {
}
void handleHelp() {
registry.values().stream().map(handler -> handler.usage()).forEach(System.out::println);
System.out.printf(Command.templateUsage, "help", "Вот этот список команд\n");
System.out.printf(Command.templateUsage, "exit", "Выход, но лучше не надо)\n");
var template = " %-30s // %s";
System.out.println("Доступные команды:\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");
}

View File

@ -5,12 +5,11 @@ import java.util.Optional;
import ru.kamask.pet.todo.service.TaskService;
public interface Command {
String templateUsage = " %-30s // %s";
String errorMessage = "Не корректно введена команда. Введите help для спарвки.";
Optional<String> handle(String[] args, TaskService service);
String name();
String usage();
String example();
String description();
}

View File

@ -12,16 +12,17 @@ public class CreateCommand implements Command {
@Override
public Optional<String> handle(String[] args, TaskService service) {
if (args.length > 0) {
var title = String.join(" ", args);
service.create(title);
return Optional.of(String.format("Задача \"%s\" успешно добавлена!", title));
}
return Optional.of(Command.errorMessage);
// TODO create new todo
return Optional.of("Добавление новой задачи");
}
@Override
public String usage() {
return String.format(templateUsage, name() + "азваниеадачи>", "Добавление новой задачи");
public String example() {
return name() + " <title>";
}
@Override
public String description() {
return "Добавление новой задачи";
}
}