From b2e3a3b48dc14a877dccab151ef310627e93f301 Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 09:51:23 +0800 Subject: [PATCH 1/8] add an abstract method 'isMutating' in the Command class --- src/seedu/addressbook/commands/Command.java | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/src/seedu/addressbook/commands/Command.java b/src/seedu/addressbook/commands/Command.java index ccd4fcbf4..643d0539e 100644 --- a/src/seedu/addressbook/commands/Command.java +++ b/src/seedu/addressbook/commands/Command.java @@ -26,6 +26,12 @@ public Command(int targetIndex) { protected Command() { } + /** + * Checks whether the command type mutates the data + * @return true if the data is mutated, false otherwise + */ + public abstract boolean isMutating(); + /** * Constructs a feedback message to summarise an operation that displayed a listing of persons. * From ab08066c429c6abc84cc75eaeb67188f94657be7 Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 09:56:09 +0800 Subject: [PATCH 2/8] Override the isMutating Method in all the children classes of Command accordingly --- src/seedu/addressbook/commands/AddCommand.java | 5 +++++ src/seedu/addressbook/commands/ClearCommand.java | 5 +++++ src/seedu/addressbook/commands/DeleteCommand.java | 4 ++++ src/seedu/addressbook/commands/ExitCommand.java | 5 +++++ src/seedu/addressbook/commands/FindCommand.java | 5 +++++ src/seedu/addressbook/commands/HelpCommand.java | 5 +++++ src/seedu/addressbook/commands/IncorrectCommand.java | 5 +++++ src/seedu/addressbook/commands/ListCommand.java | 4 ++++ src/seedu/addressbook/commands/ViewAllCommand.java | 4 ++++ src/seedu/addressbook/commands/ViewCommand.java | 4 ++++ 10 files changed, 46 insertions(+) diff --git a/src/seedu/addressbook/commands/AddCommand.java b/src/seedu/addressbook/commands/AddCommand.java index b0f202d42..dfd692e97 100644 --- a/src/seedu/addressbook/commands/AddCommand.java +++ b/src/seedu/addressbook/commands/AddCommand.java @@ -57,6 +57,11 @@ public ReadOnlyPerson getPerson() { return toAdd; } + @Override + public boolean isMutating() { + return true; + } + @Override public CommandResult execute() { try { diff --git a/src/seedu/addressbook/commands/ClearCommand.java b/src/seedu/addressbook/commands/ClearCommand.java index 330146aaa..cb93824fd 100644 --- a/src/seedu/addressbook/commands/ClearCommand.java +++ b/src/seedu/addressbook/commands/ClearCommand.java @@ -11,6 +11,11 @@ public class ClearCommand extends Command { public static final String MESSAGE_SUCCESS = "Address book has been cleared!"; + @Override + public boolean isMutating() { + return true; + } + @Override public CommandResult execute() { addressBook.clear(); diff --git a/src/seedu/addressbook/commands/DeleteCommand.java b/src/seedu/addressbook/commands/DeleteCommand.java index 1dd78f85e..7fc9adf43 100644 --- a/src/seedu/addressbook/commands/DeleteCommand.java +++ b/src/seedu/addressbook/commands/DeleteCommand.java @@ -24,6 +24,10 @@ public DeleteCommand(int targetVisibleIndex) { super(targetVisibleIndex); } + @Override + public boolean isMutating() { + return true; + } @Override public CommandResult execute() { diff --git a/src/seedu/addressbook/commands/ExitCommand.java b/src/seedu/addressbook/commands/ExitCommand.java index 0585451f1..c116a61f5 100644 --- a/src/seedu/addressbook/commands/ExitCommand.java +++ b/src/seedu/addressbook/commands/ExitCommand.java @@ -11,6 +11,11 @@ public class ExitCommand extends Command { + "Example: " + COMMAND_WORD; public static final String MESSAGE_EXIT_ACKNOWEDGEMENT = "Exiting Address Book as requested ..."; + @Override + public boolean isMutating() { + return false; + } + @Override public CommandResult execute() { return new CommandResult(MESSAGE_EXIT_ACKNOWEDGEMENT); diff --git a/src/seedu/addressbook/commands/FindCommand.java b/src/seedu/addressbook/commands/FindCommand.java index c8e9a380f..8251a1afd 100644 --- a/src/seedu/addressbook/commands/FindCommand.java +++ b/src/seedu/addressbook/commands/FindCommand.java @@ -30,6 +30,11 @@ public Set getKeywords() { return new HashSet<>(keywords); } + @Override + public boolean isMutating() { + return false; + } + @Override public CommandResult execute() { final List personsFound = getPersonsWithNameContainingAnyKeyword(keywords); diff --git a/src/seedu/addressbook/commands/HelpCommand.java b/src/seedu/addressbook/commands/HelpCommand.java index ef2ed7d0e..05fcf3072 100644 --- a/src/seedu/addressbook/commands/HelpCommand.java +++ b/src/seedu/addressbook/commands/HelpCommand.java @@ -21,6 +21,11 @@ public class HelpCommand extends Command { + "\n" + HelpCommand.MESSAGE_USAGE + "\n" + ExitCommand.MESSAGE_USAGE; + @Override + public boolean isMutating() { + return false; + } + @Override public CommandResult execute() { return new CommandResult(MESSAGE_ALL_USAGES); diff --git a/src/seedu/addressbook/commands/IncorrectCommand.java b/src/seedu/addressbook/commands/IncorrectCommand.java index 81abba7a1..08cead05e 100644 --- a/src/seedu/addressbook/commands/IncorrectCommand.java +++ b/src/seedu/addressbook/commands/IncorrectCommand.java @@ -12,6 +12,11 @@ public IncorrectCommand(String feedbackToUser){ this.feedbackToUser = feedbackToUser; } + @Override + public boolean isMutating() { + return false; + } + @Override public CommandResult execute() { return new CommandResult(feedbackToUser); diff --git a/src/seedu/addressbook/commands/ListCommand.java b/src/seedu/addressbook/commands/ListCommand.java index cb604a8e9..fdc5b8f7d 100644 --- a/src/seedu/addressbook/commands/ListCommand.java +++ b/src/seedu/addressbook/commands/ListCommand.java @@ -16,6 +16,10 @@ public class ListCommand extends Command { + "Displays all persons in the address book as a list with index numbers.\n\t" + "Example: " + COMMAND_WORD; + @Override + public boolean isMutating() { + return false; + } @Override public CommandResult execute() { diff --git a/src/seedu/addressbook/commands/ViewAllCommand.java b/src/seedu/addressbook/commands/ViewAllCommand.java index ed2c16e83..2e2957784 100644 --- a/src/seedu/addressbook/commands/ViewAllCommand.java +++ b/src/seedu/addressbook/commands/ViewAllCommand.java @@ -24,6 +24,10 @@ public ViewAllCommand(int targetVisibleIndex) { super(targetVisibleIndex); } + @Override + public boolean isMutating() { + return false; + } @Override public CommandResult execute() { diff --git a/src/seedu/addressbook/commands/ViewCommand.java b/src/seedu/addressbook/commands/ViewCommand.java index 1058c4b52..9b67b0dc7 100644 --- a/src/seedu/addressbook/commands/ViewCommand.java +++ b/src/seedu/addressbook/commands/ViewCommand.java @@ -24,6 +24,10 @@ public ViewCommand(int targetVisibleIndex) { super(targetVisibleIndex); } + @Override + public boolean isMutating() { + return false; + } @Override public CommandResult execute() { From b07eda55cd68da08c785a215b8715a488fe3dc7b Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 10:24:06 +0800 Subject: [PATCH 3/8] limits file saving to only for command types that mutate data --- src/seedu/addressbook/logic/Logic.java | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/seedu/addressbook/logic/Logic.java b/src/seedu/addressbook/logic/Logic.java index 17afd61a0..fe2bd529d 100644 --- a/src/seedu/addressbook/logic/Logic.java +++ b/src/seedu/addressbook/logic/Logic.java @@ -85,7 +85,9 @@ public CommandResult execute(String userCommandText) throws Exception { private CommandResult execute(Command command) throws Exception { command.setData(addressBook, lastShownList); CommandResult result = command.execute(); - storage.save(addressBook); + if (command.isMutating()) { + storage.save(addressBook); + } return result; } From ac14e5da735fe064cb18d16a20474266cfd227eb Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 10:58:47 +0800 Subject: [PATCH 4/8] adds a Printable interface --- src/seedu/addressbook/data/person/Address.java | 2 +- src/seedu/addressbook/data/person/Email.java | 2 +- src/seedu/addressbook/data/person/Name.java | 2 +- src/seedu/addressbook/data/person/Phone.java | 2 +- src/seedu/addressbook/data/person/Printable.java | 9 +++++++++ 5 files changed, 13 insertions(+), 4 deletions(-) create mode 100644 src/seedu/addressbook/data/person/Printable.java diff --git a/src/seedu/addressbook/data/person/Address.java b/src/seedu/addressbook/data/person/Address.java index 8ac726444..56bcc8aad 100644 --- a/src/seedu/addressbook/data/person/Address.java +++ b/src/seedu/addressbook/data/person/Address.java @@ -6,7 +6,7 @@ * Represents a Person's address in the address book. * Guarantees: immutable; is valid as declared in {@link #isValidAddress(String)} */ -public class Address { +public class Address implements Printable { public static final String EXAMPLE = "123, some street"; public static final String MESSAGE_ADDRESS_CONSTRAINTS = "Person addresses can be in any format"; diff --git a/src/seedu/addressbook/data/person/Email.java b/src/seedu/addressbook/data/person/Email.java index c946f1eb3..d7ca4bee7 100644 --- a/src/seedu/addressbook/data/person/Email.java +++ b/src/seedu/addressbook/data/person/Email.java @@ -6,7 +6,7 @@ * Represents a Person's email in the address book. * Guarantees: immutable; is valid as declared in {@link #isValidEmail(String)} */ -public class Email { +public class Email implements Printable{ public static final String EXAMPLE = "valid@e.mail"; public static final String MESSAGE_EMAIL_CONSTRAINTS = diff --git a/src/seedu/addressbook/data/person/Name.java b/src/seedu/addressbook/data/person/Name.java index 487b7ad9c..b132f7a1b 100644 --- a/src/seedu/addressbook/data/person/Name.java +++ b/src/seedu/addressbook/data/person/Name.java @@ -9,7 +9,7 @@ * Represents a Person's name in the address book. * Guarantees: immutable; is valid as declared in {@link #isValidName(String)} */ -public class Name { +public class Name implements Printable{ public static final String EXAMPLE = "John Doe"; public static final String MESSAGE_NAME_CONSTRAINTS = "Person names should be spaces or alphanumeric characters"; diff --git a/src/seedu/addressbook/data/person/Phone.java b/src/seedu/addressbook/data/person/Phone.java index b5a556de4..437659bce 100644 --- a/src/seedu/addressbook/data/person/Phone.java +++ b/src/seedu/addressbook/data/person/Phone.java @@ -6,7 +6,7 @@ * Represents a Person's phone number in the address book. * Guarantees: immutable; is valid as declared in {@link #isValidPhone(String)} */ -public class Phone { +public class Phone implements Printable { public static final String EXAMPLE = "123456789"; public static final String MESSAGE_PHONE_CONSTRAINTS = "Person phone numbers should only contain numbers"; diff --git a/src/seedu/addressbook/data/person/Printable.java b/src/seedu/addressbook/data/person/Printable.java new file mode 100644 index 000000000..9983b55c6 --- /dev/null +++ b/src/seedu/addressbook/data/person/Printable.java @@ -0,0 +1,9 @@ +package seedu.addressbook.data.person; + +public interface Printable { + + public default String getPrintableString() { + return null; + } + +} From 94ec90e09258ce58febb6677b5d91d729f529ba6 Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 11:11:15 +0800 Subject: [PATCH 5/8] Override the getPrintableString in classes Name, Phone, Email, and Address --- src/seedu/addressbook/data/person/Address.java | 5 +++++ src/seedu/addressbook/data/person/Email.java | 5 +++++ src/seedu/addressbook/data/person/Name.java | 5 +++++ src/seedu/addressbook/data/person/Phone.java | 5 +++++ 4 files changed, 20 insertions(+) diff --git a/src/seedu/addressbook/data/person/Address.java b/src/seedu/addressbook/data/person/Address.java index 56bcc8aad..7c6efd5ca 100644 --- a/src/seedu/addressbook/data/person/Address.java +++ b/src/seedu/addressbook/data/person/Address.java @@ -28,6 +28,11 @@ public Address(String address, boolean isPrivate) throws IllegalValueException { this.value = address; } + @Override + public String getPrintableString() { + return "Address: " + EXAMPLE; + } + /** * Returns true if a given string is a valid person email. */ diff --git a/src/seedu/addressbook/data/person/Email.java b/src/seedu/addressbook/data/person/Email.java index d7ca4bee7..a0a643457 100644 --- a/src/seedu/addressbook/data/person/Email.java +++ b/src/seedu/addressbook/data/person/Email.java @@ -30,6 +30,11 @@ public Email(String email, boolean isPrivate) throws IllegalValueException { this.value = email; } + @Override + public String getPrintableString() { + return "Email: " + EXAMPLE; + } + /** * Checks if a given string is a valid person email. */ diff --git a/src/seedu/addressbook/data/person/Name.java b/src/seedu/addressbook/data/person/Name.java index b132f7a1b..403035587 100644 --- a/src/seedu/addressbook/data/person/Name.java +++ b/src/seedu/addressbook/data/person/Name.java @@ -30,6 +30,11 @@ public Name(String name) throws IllegalValueException { this.fullName = name; } + @Override + public String getPrintableString() { + return "Name: " + EXAMPLE; + } + /** * Returns true if a given string is a valid person name. */ diff --git a/src/seedu/addressbook/data/person/Phone.java b/src/seedu/addressbook/data/person/Phone.java index 437659bce..2dce7fb34 100644 --- a/src/seedu/addressbook/data/person/Phone.java +++ b/src/seedu/addressbook/data/person/Phone.java @@ -29,6 +29,11 @@ public Phone(String phone, boolean isPrivate) throws IllegalValueException { this.value = phone; } + @Override + public String getPrintableString() { + return "Phone: " + EXAMPLE; + } + /** * Checks if a given string is a valid person phone number. */ From c2510db1bb92d0460ad46ea759379a7d7d55a726 Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 11:11:55 +0800 Subject: [PATCH 6/8] change the scope of the 'getPrintableString' method to package --- src/seedu/addressbook/data/person/Printable.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/seedu/addressbook/data/person/Printable.java b/src/seedu/addressbook/data/person/Printable.java index 9983b55c6..b636e9936 100644 --- a/src/seedu/addressbook/data/person/Printable.java +++ b/src/seedu/addressbook/data/person/Printable.java @@ -2,7 +2,7 @@ public interface Printable { - public default String getPrintableString() { + default String getPrintableString() { return null; } From 9d543880e0fb69a5656add99d3db99dcdad9907c Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 21:08:12 +0800 Subject: [PATCH 7/8] correct the getPrintableString method --- src/seedu/addressbook/data/person/Address.java | 7 ++++++- src/seedu/addressbook/data/person/Email.java | 7 ++++++- src/seedu/addressbook/data/person/Name.java | 3 ++- src/seedu/addressbook/data/person/Phone.java | 6 +++++- 4 files changed, 19 insertions(+), 4 deletions(-) diff --git a/src/seedu/addressbook/data/person/Address.java b/src/seedu/addressbook/data/person/Address.java index 7c6efd5ca..03ec8d4ae 100644 --- a/src/seedu/addressbook/data/person/Address.java +++ b/src/seedu/addressbook/data/person/Address.java @@ -30,9 +30,14 @@ public Address(String address, boolean isPrivate) throws IllegalValueException { @Override public String getPrintableString() { - return "Address: " + EXAMPLE; + if (isPrivate) { + return "Address: private"; + } else { + return "Address: " + value; + } } + /** * Returns true if a given string is a valid person email. */ diff --git a/src/seedu/addressbook/data/person/Email.java b/src/seedu/addressbook/data/person/Email.java index a0a643457..2ab6a0905 100644 --- a/src/seedu/addressbook/data/person/Email.java +++ b/src/seedu/addressbook/data/person/Email.java @@ -32,9 +32,14 @@ public Email(String email, boolean isPrivate) throws IllegalValueException { @Override public String getPrintableString() { - return "Email: " + EXAMPLE; + if (isPrivate) { + return "Email: private"; + } else { + return "Email: " + value; + } } + /** * Checks if a given string is a valid person email. */ diff --git a/src/seedu/addressbook/data/person/Name.java b/src/seedu/addressbook/data/person/Name.java index 403035587..5028d0e5c 100644 --- a/src/seedu/addressbook/data/person/Name.java +++ b/src/seedu/addressbook/data/person/Name.java @@ -32,9 +32,10 @@ public Name(String name) throws IllegalValueException { @Override public String getPrintableString() { - return "Name: " + EXAMPLE; + return "Name: " + fullName; } + /** * Returns true if a given string is a valid person name. */ diff --git a/src/seedu/addressbook/data/person/Phone.java b/src/seedu/addressbook/data/person/Phone.java index 2dce7fb34..234853ba9 100644 --- a/src/seedu/addressbook/data/person/Phone.java +++ b/src/seedu/addressbook/data/person/Phone.java @@ -31,7 +31,11 @@ public Phone(String phone, boolean isPrivate) throws IllegalValueException { @Override public String getPrintableString() { - return "Phone: " + EXAMPLE; + if (isPrivate) { + return "Phone: private"; + } else { + return "Phone: " + value; + } } /** From cd12b9f029ceb91f6aef818391c3c35361be588b Mon Sep 17 00:00:00 2001 From: "LAPTOP-7KFM2KSP\\User" <594395096@qq.com> Date: Tue, 19 Sep 2017 21:08:32 +0800 Subject: [PATCH 8/8] modify getPrintableString in Person class --- src/seedu/addressbook/data/person/Person.java | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/src/seedu/addressbook/data/person/Person.java b/src/seedu/addressbook/data/person/Person.java index cf6211841..af4985cec 100644 --- a/src/seedu/addressbook/data/person/Person.java +++ b/src/seedu/addressbook/data/person/Person.java @@ -34,6 +34,17 @@ public Person(ReadOnlyPerson source) { this(source.getName(), source.getPhone(), source.getEmail(), source.getAddress(), source.getTags()); } + /** + * Returns a concatenated version of the printable strings of each object. + */ + String getPrintableString(Printable... printables){ + String returnString = ""; + for (Printable p : printables) { + returnString += " " + p; + } + return returnString; + } + @Override public Name getName() { return name;