forked from nus-cs2103-AY1920S1/addressbook-level3
/
Logic.java
112 lines (92 loc) · 3.03 KB
/
Logic.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
package seedu.address.logic;
import java.nio.file.Path;
import javafx.collections.ObservableList;
import seedu.address.commons.core.GuiSettings;
import seedu.address.logic.commands.CommandResult;
import seedu.address.logic.commands.exceptions.CommandException;
import seedu.address.logic.parser.exceptions.ParseException;
import seedu.address.model.legacy.ReadOnlyAddressBook;
import seedu.address.model.person.Customer;
import seedu.address.model.person.Driver;
import seedu.address.model.person.Person;
import seedu.address.model.task.Task;
/**
* API of the Logic component
*/
public interface Logic {
/**
* Executes the command and returns the result.
* @param commandText The command as entered by the user.
* @return the result of the command execution.
* @throws CommandException If an error occurs during command execution.
* @throws ParseException If an error occurs during parsing.
*/
CommandResult execute(String commandText) throws CommandException, ParseException;
/**
* Returns the AddressBook.
*
* @see seedu.address.model.Model#getAddressBook()
*/
ReadOnlyAddressBook getAddressBook();
/**
* Returns an unmodifiable view of the filtered list of persons.
*/
ObservableList<Person> getFilteredPersonList();
/**
* Returns an unmodifiable view of the filtered list of tasks.
*/
ObservableList<Task> getFilteredTaskList();
/**
* Returns an unmodifiable view of the filtered list of unassigned task list.
*/
ObservableList<Task> getFilteredUnassignedTaskList();
/**
* Returns an unmodifiable view of the filtered list of assigned task list.
*/
ObservableList<Task> getFilteredAssignedTaskList();
/**
* Returns an unmodifiable view of the filtered list of unassigned task list.
*/
ObservableList<Task> getFilteredCompletedTaskList();
/**
* Returns an unmodifiable view of the filtered list of drivers.
*/
ObservableList<Driver> getFilteredDriverList();
/**
* Returns an unmodifiable view of the filtered list of customers.
*/
ObservableList<Customer> getFilteredCustomerList();
boolean isStartAfresh();
/**
* Returns an unmodifiable view of the incomplete tasks from previous days.
*/
ObservableList<Task> getIncompleteTaskList();
/**
* Returns an unmodifiable view of the command list.
*/
ObservableList<String> getCommandList();
/**
* Refreshes filtered lists
*/
void refreshFilteredTaskList();
/**
* Returns the user prefs' address book file path.
*/
Path getAddressBookFilePath();
/**
* Returns the user prefs' GUI settings.
*/
GuiSettings getGuiSettings();
/**
* Set the user prefs' GUI settings.
*/
void setGuiSettings(GuiSettings guiSettings);
/**
* Retrieves driver for view Driver window.
*/
Driver getDriver(int driverId);
/**
* Retrieves customer for view Customer window.
*/
Customer getCustomer(int customerId);
}