Compare commits
No commits in common. "01742240896f2ab9ed4447fceae3f9a1f4177d2d" and "da878ec81c454c9291df6548711e109d6c96e4aa" have entirely different histories.
0174224089
...
da878ec81c
@ -3,13 +3,12 @@ package ru.kamask.pet.todo;
|
||||
import java.io.IOException;
|
||||
|
||||
import ru.kamask.pet.todo.cli.CliEngine;
|
||||
import ru.kamask.pet.todo.model.SimpleTask;
|
||||
import ru.kamask.pet.todo.repo.InMemoryRepository;
|
||||
import ru.kamask.pet.todo.repo.InMemoryTaskRepository;
|
||||
import ru.kamask.pet.todo.service.TaskService;
|
||||
|
||||
public class TodoApp {
|
||||
public static void main(String[] args) throws IOException {
|
||||
var service = new TaskService(new InMemoryRepository<SimpleTask>());
|
||||
var service = new TaskService(new InMemoryTaskRepository());
|
||||
var cli = new CliEngine(service);
|
||||
|
||||
cli.start();
|
||||
|
||||
@ -6,23 +6,23 @@ import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Optional;
|
||||
|
||||
import ru.kamask.pet.todo.model.Identifiable;
|
||||
import ru.kamask.pet.todo.model.SimpleTask;
|
||||
|
||||
public class InMemoryRepository<T extends Identifiable> implements Repository<T> {
|
||||
private Map<Integer, T> storage = new HashMap<>();
|
||||
public class InMemoryTaskRepository implements TaskRepository {
|
||||
private Map<Integer, SimpleTask> storage = new HashMap<>();
|
||||
|
||||
@Override
|
||||
public void save(T obj) {
|
||||
storage.put(obj.getId(), obj);
|
||||
public void save(SimpleTask task) {
|
||||
storage.put(task.id(), task);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Optional<T> findById(int id) {
|
||||
public Optional<SimpleTask> findById(int id) {
|
||||
return Optional.ofNullable(storage.get(id));
|
||||
}
|
||||
|
||||
@Override
|
||||
public List<T> findAll() {
|
||||
public List<SimpleTask> findAll() {
|
||||
return new ArrayList<>(storage.values());
|
||||
}
|
||||
|
||||
@ -0,0 +1,5 @@
|
||||
package ru.kamask.pet.todo.repo;
|
||||
|
||||
import ru.kamask.pet.todo.model.SimpleTask;
|
||||
|
||||
public interface TaskRepository extends Repository<SimpleTask> {}
|
||||
@ -4,12 +4,12 @@ import java.util.List;
|
||||
import java.util.Optional;
|
||||
|
||||
import ru.kamask.pet.todo.model.SimpleTask;
|
||||
import ru.kamask.pet.todo.repo.InMemoryRepository;
|
||||
import ru.kamask.pet.todo.repo.TaskRepository;
|
||||
|
||||
public class TaskService {
|
||||
private final InMemoryRepository<SimpleTask> repo;
|
||||
private final TaskRepository repo;
|
||||
|
||||
public TaskService(InMemoryRepository<SimpleTask> repo) {
|
||||
public TaskService(TaskRepository repo) {
|
||||
this.repo = repo;
|
||||
}
|
||||
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user