Skip to content

Commit

Permalink
Merge branch 'develop' into update-DeveloperGuide
Browse files Browse the repository at this point in the history
  • Loading branch information
Skaty authored Nov 7, 2016
2 parents 8b95972 + 304d79e commit 8803fc8
Show file tree
Hide file tree
Showing 7 changed files with 80 additions and 73 deletions.
153 changes: 80 additions & 73 deletions docs/DeveloperGuide.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

> Having any Java 8 version is not enough. <br>
This app will not work with earlier versions of Java 8.

2. **Eclipse** IDE
3. **e(fx)clipse** plugin for Eclipse (Do the steps 2 onwards given in
[this page](http://www.eclipse.org/efxclipse/install.html#for-the-ambitious))
Expand Down Expand Up @@ -122,10 +122,12 @@ The `UI` component,

**API** : [`Logic.java`](../src/main/java/seedu/task/logic/Logic.java)

1. `Logic` uses the `Parser` class to parse the user command.
2. This results in a `Command` object which is executed by the `LogicManager`.
3. The command execution can affect the `Model` (e.g. adding a person) and/or raise events.
4. The result of the command execution is encapsulated as a `CommandResult` object which is passed back to the `Ui`.
1. `Logic` uses the `ParseSwitcher` to parse the command.
2. `ParseSwitcher` uses `ParserMapping` to determine which `BaseParser` object to use.
3. The `BaseParser` object is executed in `ParserMapping`, which parses the command.
4. This results in a `Command` object which is executed by the `LogicManager`.
5. The command execution can affect the `Model` (e.g. adding a person) and/or raise events.
6. The result of the command execution is encapsulated as a `CommandResult` object which is passed back to the `Ui`.

Given below is the Sequence Diagram for interactions within the `Logic` component for the `execute("delete 1")` API call.<br>

Expand Down Expand Up @@ -237,7 +239,7 @@ Here are the steps to create a new release.
2. Tag the repo with the version number. e.g. `v0.1`
2. [Crete a new release using GitHub](https://help.github.com/articles/creating-releases/)
and upload the JAR file your created.

### Managing Dependencies

A project often depends on third-party libraries. Managing these _dependencies_
Expand All @@ -250,9 +252,9 @@ b. Require developers to download those libraries manually (this creates extra w

<!-- @@author A0153467Y-->
## Appendix A : User Stories

Priorities: High (must have) - `* * *`, Medium (nice to have) - `* *`, Low (unlikely to have) - `*`

Priority | As a ... | I want to ... | So that I can...
-------- | :-------- | :--------- | :-----------
`* * *` | new user | see usage instructions | refer to instructions when I forget how to use the App
Expand Down Expand Up @@ -280,15 +282,15 @@ The activity diagram below shows the simple flow of getting command from user<br
<img src="images/ActivityDiagram.jpg" width="600"><br>

(For all use cases below, the **System** is the `MESS` and the **Actor** is the `user`, unless specified otherwise)

#### Use case: Add task

**MSS**

1. User requests to add a task
2. MESS adds the task to the list<br>
Use case ends.

**Extensions**

1a. The input command format is wrong
Expand All @@ -301,13 +303,13 @@ Use case ends.
<!-- @@author -->
<!-- @@author A0144939R -->
#### Use case: Alias command

**MSS**

1. User requests to alias a command
2. MESS aliases the command to the given symbol<br>
Use case ends.

**Extensions**

1a. The symbol is already aliased to another command
Expand All @@ -322,145 +324,145 @@ Use case ends.
> MESS maps the given symbol to the command, as a command can have multiple aliases
Use case ends.

<!-- @@author -->
<!-- @@author -->

<!-- @@author A0153467Y -->
<!-- @@author A0153467Y -->
#### Use case: Delete task by index

**MSS**

1. User requests to list tasks
2. MESS shows a list of tasks
3. User requests to delete a specific task in the list
4. MESS deletes the task <br>
Use case ends.

**Extensions**

1a. The list is empty

> Use case ends
3a. The given index is invalid

>MESS shows an error message <br>
Use case ends.

#### Use case: Update task

**MSS**

1. User requests to list tasks
2. MESS shows a list of tasks
3. User requests to update a specific task by index in the list
4. MESS updates the task <br>
Use case ends.

**Extensions**

1a. The list is empty

> User case ends
3a. The given index is invalid

>MESS shows an error message <br>
User case ends.

#### Use case: Pin task

**MSS**

1. User requests to list tasks
2. MESS shows a list of tasks
3. User requests to pin a specific task by index in the list
4. MESS pins the task <br>
Use case ends.

**Extensions**

1a. The list is empty

> User case ends
3a. The given index is invalid

>MESS shows an error message <br>
User case ends.

#### Use case: Unpin task

**MSS**

1. User requests to list tasks
2. MESS shows a list of tasks
3. User requests to unpin a pinned task by index in the list
4. MESS unpins the task <br>
Use case ends.

**Extensions**

1a. The list is empty

> User case ends
3a. The given index is invalid

> MESS shows an error message <br>
User case ends.

3b. The task is not pinned before

> MESS shows an error message <br>
User case ends.

#### Use case: Complete task

**MSS**

1. User requests to list tasks
2. MESS shows a list of tasks
3. User requests to mark a specific task as completed by index in the list
4. MESS marks the task <br>
Use case ends.

**Extensions**

1a. The list is empty

> User case ends
3a. The given index is invalid

>MESS shows an error message <br>
User case ends.

#### Use case: Uncomplete task

**MSS**

1. User requests to list tasks
2. MESS shows a list of tasks
3. User requests to mark a completed task as not completed by index in the list
4. MESS marks the task back to not completed <br>
Use case ends.

**Extensions**

1a. The list is empty

> User case ends
3a. The given index is invalid

>MESS shows an error message <br>
User case ends.

3b. The task is not marked as completed before

>MESS shows an error message <br>
User case ends.
User case ends.

#### Use case: Undo previous action

**MSS**
Expand All @@ -474,7 +476,12 @@ Use case ends.
1a. There is no previous action

> Use case ends
<!-- @@author A0141052Y -->
1b. The previous action does not support undo
> Use case ends
<!-- @@author -->
#### Use case: Find task

**MSS**
Expand Down Expand Up @@ -532,7 +539,7 @@ Use case ends.
<!-- @@author -->
<!-- @@author A0153467Y -->
## Appendix C : Non Functional Requirements

1. Should work on any mainstream OS as long as it has Java `1.8.0_60` or higher installed
2. Should be able to process user’s request and show result in 3 seconds
3. Should be user-friendly for both beginners and advanced users
Expand All @@ -543,9 +550,9 @@ Use case ends.
8. Should come with automated unit tests and open source code

## Appendix D : Glossary

##### Mainstream OS

> Windows, Linux, Unix, OS-X
##### Floating Tasks
Expand All @@ -554,7 +561,7 @@ Use case ends.
<!-- @@author-->
## Appendix E : Product Survey

### Google Calendar
#### Strengths
1. Simple 'what you see is what you get' interface
Expand All @@ -564,7 +571,7 @@ Use case ends.
5. Global Search; data searched through other google products as well; Gmail, Drive, etc.
6. Automatic generation of start and end times enforcing structure in all entries
7. Recurring events

#### Weaknesses
1. No tagging mechanism for more complex organization
2. No analysis, summary nor statistics of data the user has entered
Expand All @@ -584,16 +591,16 @@ Use case ends.
8. Priority can be set for each task
9. Can be extended to add-ons
10. Can be connected to Dropbox

#### Weakness:
1. UI does not look good
2. All the output will only be shown in CLI format (no colour, no font change)
3. Need to update whether the task has finished or not by the user
4. No notification for task near deadline
5. Require users to remember too many commands

### Wunderlist (Free version)

#### Strength
1. Easy to use
2. Cross-platform application
Expand All @@ -602,12 +609,12 @@ Use case ends.
5. Use hashtag to categorize tasks
6. Plug-in for Microsoft Outlook and Google Calendar
7. Can take notes (not only task)

#### Weakness
1. Cannot create task using one line command
2. Have limited number subtasks (only premium version has unlimited)
3. Cannot customize the interface (only premium version can do)

### Todoist (Free version)
#### Strength
1. Simple to use
Expand All @@ -616,7 +623,7 @@ Use case ends.
4. Have both online and offline access
5. Have different priority level for tasks
6. Can track your productivity and visualize your achievement trends over time.

#### Weakness
1. tasks for free version
2. Cannot use label to categorize tasks for free version
Expand Down
Binary file modified docs/Diagram/LogicComponentClassDiagram.pptx
Binary file not shown.
Binary file modified docs/Diagram/ModelComponentClassDiagram.pptx
Binary file not shown.
Binary file modified docs/Diagram/UiComponentClassDiagram.pptx
Binary file not shown.
Binary file modified docs/images/LogicClassDiagram.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified docs/images/ModelClassDiagram.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file modified docs/images/UiClassDiagram.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.

0 comments on commit 8803fc8

Please sign in to comment.