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/3] 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/3] 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/3] 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; }