We (as one entity) salute you for reading this contributing guide.
Any contribution you make will be reflected/committed to this repository, so be careful on what you're doing!
Read our Code of Conduct to keep our community approachable and respectable.
Use the table of contents icon on the top left corner of this document to get to a specific section of this guide quickly.
To get an overview of the project, read the README.
Here are some resources to help you get started with open source contributions:
- Finding ways to contribute to open source on GitHub
- Set up Git
- GitHub flow
- Collaborating with pull requests
To give us a suggestion on what utility to do next, you can open up an issue.
The first and most important step is getting to know yourself and your setup:
- Can you write code in
Java
?- Can you understand it's syntax properly?
- Can you solve common problems that occur when writing a program?
- Have you experienced coding alone with no help?
- Do you know when and how to ask for help on sites like Stack Overflow?
- Do you have your
Java
environment setup ready?- Do you have a JDK that supports
Java-8
and above? (personally using Java-11)- Check it with
java --version
on your terminal.
- Check it with
- Do you have a JDK that supports
- Do you know how to use
Git
orGitHub
properly?
Next step would be *drum-roll* forking the repository!
- You can now write the actual code.
- Make the code concise.
- Make the code compact.
- Make the code readable.
- Don't make it too readable or else we won't be accepting it!
- Also, don't make the code too unreadable or else we won't be accepting it as well!
- Always include a demo
- Take a look at some of our files to know what I meant by that.
- Include as much functionality as possible only when practical.
- In other words, don't make
god classes
please.
- In other words, don't make
- Follow the directory as a basis on how your contribution should look like when looking at it's directory tree.
- Never forget to test and compile the code first on your machine before making such reckless moves!
- Check, test and compile your code into it's appropriate directory.
- Commit your changes into your fork.
- Use Gitmojis before your commit message to indicate what your commit is for.
- Open up a PR.
- Fill up the form!
- Wait for me to accept your changes!
To navigate the repository without wasting time and bandwidth.
Should be automatically updated after every commit.
├── .github
│ ├── CODE_OF_CONDUCT.md
│ ├── CONTRIBUTING.md
│ ├── DirectoryMaintainer.java
│ ├── ISSUE_TEMPLATE
│ │ ├── bug_report.md
│ │ └── feature_request.md
│ ├── Logo.apng
│ ├── Rough_demo.gif
│ ├── pull_request_template.md
│ └── workflows
│ ├── code_checker.yml
│ ├── delete_workflow_history.yml
│ └── directory_maintainer.yml
├── LICENSE
├── README.md
├── build
│ └── SomeUtils
│ ├── Clock
│ │ ├── Alarm$1.class
│ │ ├── Alarm$2.class
│ │ ├── Alarm$3.class
│ │ ├── Alarm$4.class
│ │ ├── Alarm$AlarmWatcher.class
│ │ ├── Alarm.class
│ │ ├── Stopwatch.class
│ │ ├── Timer$1.class
│ │ ├── Timer$2.class
│ │ ├── Timer$TimerWatcher.class
│ │ └── Timer.class
│ ├── DynamicArray
│ │ └── DynamicArray.class
│ ├── Pattern
│ │ ├── PatternFinder.class
│ │ └── PatternMaker.class
│ ├── ProgressBar
│ │ └── ProgressBar.class
│ ├── Storage
│ │ └── Inventory.class
│ └── TerminalMap
│ └── TerminalMap.class
└── src
└── SomeUtils
├── Clock
│ ├── Alarm.java
│ ├── README.md
│ ├── Stopwatch.java
│ └── Timer.java
├── DynamicArray
│ ├── DynamicArray.java
│ └── README.md
├── Pattern
│ ├── PatternFinder.java
│ ├── PatternMaker.java
│ └── README.md
├── ProgressBar
│ ├── ProgressBar.java
│ └── README.md
├── Storage
│ ├── Inventory.java
│ └── README.md
└── TerminalMap
├── README.md
└── TerminalMap.java
If you spotted a problem or would like to create a new issue, search if an issue already exists.
If a related issue doesn't exist, you can open a new issue using a relevant issue form.
Scan through our existing issues to find one that interests you.
You can narrow down the search at will using filters.
If you find an issue to work on, you are welcome to fork this repository and open up a PR containing your fix.
Remember, fill up the forms to give us as much information as possible!