-
Notifications
You must be signed in to change notification settings - Fork 315
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Ryan Chew] Duke Increments #355
Open
iltep64
wants to merge
50
commits into
nus-cs2103-AY1920S1:master
Choose a base branch
from
iltep64:pr
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
+3,334
−16
Open
Changes from 1 commit
Commits
Show all changes
50 commits
Select commit
Hold shift + click to select a range
65f72a8
Add support for Gradle workflow
j-lum 0112efe
Add sample checkstyle configuration
j-lum 7faa65a
Added Greet, Echo, Exit features
iltep64 46c55c6
Implement list add and show features.
iltep64 94b4414
Created Task class to represent tasks.
iltep64 4cec14a
Implemented marking a task as done.
iltep64 013cc37
Refactor IO interface into DukeIO instance, and Duke logic into objec…
iltep64 9303e1d
Implement deadline task class and addition logic
iltep64 5abe5d0
Refactor out and improve task-adding logic.
iltep64 11f4134
Create a uniform command interface, with parsing logic.
iltep64 3ec4d4e
Implement dialog block logic, so messages get aggregated into a singl…
iltep64 b79c5c0
Add header to list command output.
iltep64 3a0d632
Add Event task and make it available by the 'event' command.
iltep64 0139127
Add basic error handling support.
iltep64 16718fb
Added deletion functionality.
iltep64 8dd4b9b
Implement basic JSON decoder
iltep64 d7e9187
Add basic JSON writer
iltep64 501ae91
Add type registry for JSON serializiation
iltep64 9880921
Add convenience functions for JSON encoding/decoding.
iltep64 db72071
Refactor task types to enums
iltep64 6ca4441
Add JSON builder class for Tasks
iltep64 1cf63ce
Add listOf function, and produce ArrayList<> values instead of just L…
iltep64 f5ccf6e
Use JSON to load/store task list
iltep64 a0d17c1
Fix completed status not being loaded
iltep64 0b162a2
Add date parsing logic
iltep64 c842c6f
Have EventTask and DeadlineTask to use date logic.
iltep64 355f065
Merge branch 'branch-Level-7'
iltep64 93b6e1c
Merge branch 'branch-Level-8'
iltep64 dce444a
Add encoder lookup cache for Registry, and avoid printing debug messages
iltep64 45172d8
Move all classes into (sub)packages of org.duke
iltep64 9f28efa
Add task find command
iltep64 ed5ea49
Reformat code to satisfy standards
iltep64 8c16531
Add javadocs to public classes and methods.
iltep64 c907b2c
Merge branch 'branch-Level-9'
iltep64 c5eee9a
Merge branch 'codingstandard'
iltep64 af1b0d4
Merge branch 'javadocs'
iltep64 7e2227e
Merge branch 'gradle'
iltep64 e0b6066
Add JAR build plugin.
iltep64 63d9c81
Add tests for Command and DateParser, and automate via Gradle.
iltep64 3bfe760
Refactor out IO and command parsing.
iltep64 1e6e594
Implement a basic JavaFX UI.
iltep64 31fb5b4
Merge branch 'branch-Level-10'
iltep64 b04abda
Encapsulate Command fields.
iltep64 354adca
Beautify DukeFx UI, by adding colored message boxes for Duke and user.
iltep64 f653e2d
Extract command handlers into their own classes, and add a help command.
iltep64 7ea74be
Refactor storage out into own class, and improve CounterDecorator.
iltep64 00772ef
Refactored JavaFX UI to use FXML custom components.
iltep64 6d9eb22
Fix JavaFX startup classpath issues.
iltep64 1eebc7b
Add user guide/documentation.
iltep64 b508421
Set theme jekyll-theme-slate
iltep64 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
import java.util.function.Function; | ||
|
||
class CounterDecorator implements Function<String, String> { | ||
private int counter; | ||
public CounterDecorator(int start) { | ||
this.counter = start; | ||
} | ||
public String apply(String str) { | ||
String ret = String.format("%d: %s", this.counter, str); | ||
this.counter++; | ||
return ret; | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,78 @@ | ||
import java.util.Arrays; | ||
import java.util.Iterator; | ||
import java.util.HashMap; | ||
import java.util.Map; | ||
import java.util.Scanner; | ||
import java.util.function.Predicate; | ||
|
||
public class DukeIO { | ||
|
||
private static final String lineRule = | ||
"____________________________________________________________"; | ||
|
||
private final Map<String, Predicate<String>> commandMap | ||
= new HashMap<>(); | ||
private Predicate<String> defaultHandler = null; | ||
|
||
private final Scanner parser; | ||
|
||
public DukeIO() { | ||
this.parser = new Scanner(System.in); | ||
} | ||
|
||
public void say(String... lines) { | ||
say(Arrays.asList(lines).iterator()); | ||
} | ||
public void say(Iterator<String> lines) { | ||
//Print start of reply line | ||
System.out.println(lineRule); | ||
|
||
//Print each given line | ||
while(lines.hasNext()) { | ||
System.out.println(lines.next()); | ||
} | ||
|
||
//Print end of reply line, and extra empty line | ||
System.out.println(lineRule); | ||
System.out.println(); | ||
} | ||
|
||
public void bindCommand(String command, Predicate<String> handler) { | ||
this.commandMap.put(command, handler); | ||
} | ||
|
||
public void setUnknownCommandHandler(Predicate<String> handler) { | ||
this.defaultHandler = handler; | ||
} | ||
|
||
public void listen() { | ||
//While there is still input from user | ||
while(parser.hasNextLine()) { | ||
//Read single line of user input, and remove extra spaces | ||
String userInput = parser.nextLine().trim(); | ||
|
||
int spacePos = userInput.indexOf(' '); | ||
String command, rest; | ||
if(spacePos == -1) { | ||
command = userInput; | ||
rest = null; | ||
} else { | ||
command = userInput.substring(0, spacePos); | ||
rest = userInput.substring(spacePos+1); | ||
} | ||
|
||
Predicate<String> cmdHandler = commandMap.get(command); | ||
boolean shouldExit; | ||
if(cmdHandler != null) { | ||
shouldExit = cmdHandler.test(rest); | ||
} else { | ||
shouldExit = defaultHandler.test(userInput); | ||
} | ||
|
||
if(shouldExit) { | ||
break; | ||
} | ||
} | ||
} | ||
|
||
} |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I like that you create a class to format the string representation of a
Task
.