-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #90 from Ultraviolet-Ninja/dev
Update Cycle
- Loading branch information
Showing
53 changed files
with
636 additions
and
352 deletions.
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
103 changes: 103 additions & 0 deletions
103
Contribution Guidelines for the Gradle Centurion Project.md
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,103 @@ | ||
# Contribution Guidelines for the Gradle Centurion Project | ||
|
||
Welcome to the Gradle Centurion project! This JavaFX application aims to provide solutions for the various puzzles | ||
found in the Centurion bomb mod of *Keep Talking and Nobody Explodes*. I welcome contributions from developers of all | ||
skill levels to help enhance and expand this project! | ||
|
||
## Getting Started | ||
|
||
To contribute, follow these steps: | ||
|
||
1. **Parse the README**: If you've never heard of the game, this would be an excellent place to understand what the | ||
game is and what the project is about | ||
|
||
2. **Fork the Repository**: Click on the "Fork" button at the top right of this repository to create a copy on your | ||
GitHub account. | ||
|
||
3. **Clone the Forked Repository**: Clone your fork to your local machine using: | ||
|
||
```bash | ||
git clone https://github.com/your-username/GradleCenturion.git | ||
``` | ||
|
||
4. **Set Up the Development Environment**: Ensure you have **Java 21** set up on your machine, then Gradle should be | ||
able to handle the rest of the dependencies when loading up the project. This project is developed in Intellij; all | ||
other IDEs are fine, but we'd have to discuss IDE specific issues if/when they occur. | ||
|
||
5. **Explore the Codebase**: Take a look at the existing puzzles implemented in the project to understand the | ||
structure and coding style. The codebase is set up with basic outlines for `.fxml` files, and it will be up to the | ||
programmer to work on the associated controller and puzzle classes. | ||
|
||
## Areas of Contribution | ||
|
||
I'm looking for contributors to help tackle some of the **unhandled puzzles** or to **fix one of the few UI issues** | ||
I'm having with the project. Unhandled puzzles can be seen in the [Progress file](Progress.md) at the base-level of the | ||
project repository. To claim that you'll be tackling a certain puzzle, please add a comment to the | ||
[discussion board](https://github.com/Ultraviolet-Ninja/GradleCenturion/issues/131). After approval, create an issue | ||
on the given page so that we can discuss further instructions. | ||
|
||
### Unhandled Puzzles | ||
|
||
Every puzzle has an associated manual page that you can find in the `maunals/` subdirectory or on the | ||
[KTANE Manual Page Website](https://ktane.timwi.de/). It will be your job to interpret the manual page so that a | ||
computer can solve the puzzle. This involves developing the algorithm that will handle the inputs, the UI that displays | ||
what a 'manual expert' needs to fill in, the controller that acts as the middleware between the two and the test code | ||
that validates the algorithm to be correct in different scenarios. | ||
|
||
#### How to choose a puzzle to solve | ||
|
||
The `manuals/Centurion Puzzle Difficulty.xlsx` file contains all the puzzles and their relative 'manual expert' | ||
difficulty. This would probably be a good place to start for finding interesting problems. | ||
|
||
#### Testing Puzzle Solutions | ||
|
||
Puzzle solutions should have tests associated with them. Unit testing will be an important part of making sure that | ||
your solutions are correct and tested against wrong user input. | ||
|
||
### UI Issues | ||
|
||
There are a few known UI issues that occur in the project. If you're interested in looking into fixing those, | ||
I can explain more about the problem that occurs. | ||
|
||
## Creating a Pull Request | ||
|
||
1. **Create a New Branch**: | ||
|
||
- **Features** can just be labeled as the puzzle name | ||
- **Issues** can be prefixed with `issue/` | ||
|
||
```bash | ||
git checkout -b puzzle-name | ||
``` | ||
|
||
2. **Make Your Changes**: Implement your solution to the chosen puzzle. | ||
|
||
3. **Commit Your Changes**: Ensure your commits are descriptive. | ||
|
||
```bash | ||
git commit -m "Add solution for Puzzle A" | ||
``` | ||
|
||
4. **Push Your Changes**: | ||
|
||
```bash | ||
git push origin puzzle-name | ||
``` | ||
|
||
5. **Open a Pull Request**: Go to the original repository and click on "Pull Requests" to open a new pull request. | ||
Provide a summary of your changes and make sure that you are merging to the `dev` branch. | ||
|
||
## Code Style | ||
|
||
Please glance at existing puzzle solutions to get a feel for the coding style of the project. This project is run | ||
through automatic code style checking using **Codacy** for new code changes, so fixing most code style issues will | ||
be an important part of this project's development process. | ||
|
||
Java files for a new puzzle solution should live under the `bomb.modules.[ALPHABETIC_LABEL].[PUZZLE_NAME]` package. | ||
Sub-package organization at that point is left to your discretion. | ||
|
||
## Questions and Support | ||
|
||
If you have any questions, feel free to open an issue or reach out to me. I'm here to help! | ||
|
||
Thank you for contributing to the Gradle Centurion project, and happy coding! |
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 |
---|---|---|
@@ -1,37 +1,64 @@ | ||
# What I've learned | ||
# What have I learned through this project? | ||
|
||
## JavaFX Custom Components | ||
- Understanding how to create CC's with this [video](https://www.youtube.com/watch?v=1yuaJQJ1FXg) as a guide. | ||
- Experimenting with CC's to figure out how to correctly turn them into jar files that are compatible with SceneBuilder. | ||
- Experimenting with CC's to figure out how to correctly turn them into jar files that are compatible with SceneBuilder, | ||
thus making them easier to work with in front-end design. | ||
- Utilizing CSS to style components and make them look like the puzzles in the game. | ||
|
||
## Project Tech/Design Choices | ||
When my friend was working on the project, he helped me decide to move to a RadioButton design for switching between puzzles. This helped me get away from my previous design of nested TabPanes in a TabPane, which probably isn't the most visually appealing. | ||
When my friend was working on the project, he helped me decide to move to a RadioButton design for switching between | ||
puzzle displays. This helped me get away from my previous design of nested TabPanes in a TabPane, which probably | ||
isn't the most visually appealing. | ||
|
||
Another thing we talked about while he was on the project was moving back to `Java 8` since it was easier to work | ||
with JavaFX. This decision was later reversed after some time experimenting in Gradle. | ||
|
||
Another thing we talked about while he was on the project was moving back to Java 8 since it was easier to work with JavaFX. This decision was later reversed after some time experimenting in Gradle. | ||
## Gradle/Continuous Integration | ||
- Using the build.gradle file to organize dependencies and plugins, facilitate testing, set up distributions in zip and tar files, and releases for GitHub. | ||
- Using the `build.gradle` file to organize dependencies and plugins, facilitate testing, set up distributions in zip | ||
and tar files, and releases for GitHub. | ||
- Making custom tasks and using parameters for CI pipelines to partition my test suite. | ||
- Automating tests with CircleCI using this [video](https://www.youtube.com/watch?v=9PgZCJNzY9M) as a guide. | ||
- Coming across ~~LGTM~~ (_when it was still around_) Codacy and taking advantage of its code quality checking for flaws in my Java code. | ||
- Automating tests with CircleCI using this [video](https://www.youtube.com/watch?v=9PgZCJNzY9M) as a guide to get the initial set up. | ||
- Partitioning my test suite to understand how test splitting and YML file syntax worked and how to parse | ||
[Circle CI documentation](https://circleci.com/docs/parallelism-faster-jobs/) | ||
- Coming across ~~LGTM~~ (_when it was still around_) Codacy and taking advantage of its code quality checking for | ||
flaws in my Java code. | ||
|
||
## Graphs and their Algorithms | ||
- Creating graphs by looking up the concept or using the JGraphT library. | ||
- Understanding how graphs work by watching videos on the theory, creating them from scratch and using the | ||
[JGraphT library](https://jgrapht.org/) to solve different puzzles. | ||
- Making use of Dijkstra's Shortest Path and A* to solve different problems. | ||
## From my Internship | ||
|
||
## From my first internship | ||
- Using a backlog to organize tasks that are done, in progress, or haven't been looked at. | ||
- Creating results that get deployed to GitHub and can be downloaded by anyone. | ||
- Using a less technical version of design documents. I used them to outline how I will solve puzzles and what the front end will look like. | ||
- Using a less technical version of design documents. I used them to outline how I will solve puzzles and what the | ||
front end will look like. | ||
|
||
## From my Classes | ||
|
||
### School | ||
|
||
#### Tools & Practices | ||
- Understanding how to use Git and GitHub to host my project. | ||
- Having an introduction to Gradle from one of my teammates trying to bring it into another project. (_Wasn't successful, but still_) | ||
- Understanding how to use Git and GitHub to host my project when analyzing the needs of my project. | ||
- Having an introduction to Gradle from one of my teammates trying to bring it into our school project. | ||
(_Wasn't successful, but still, it was a discovery_) | ||
|
||
#### Verification | ||
- Understanding the perks of TestNG vs. my previous experience with J-Unit. | ||
- Discovering Pitest, Exploratory Testing, Mockito, and Jacoco as different ways to test code and thinking about which concepts I should implement into the project. | ||
- Understanding the perks of TestNG vs. my previous experience with J-Unit as it relates to how the project | ||
could benefit. | ||
- Discovering Pitest, Exploratory Testing, Mockito, and Jacoco as different ways to test code and thinking about | ||
which concepts I should implement into the project. | ||
|
||
#### Design Patterns | ||
- Using Adapters, Factories, Facades, and Observers to facilitate repeating code and updating related modules. | ||
- Using Strategies, Factories, Facades, and Observers to facilitate repeated code and updating related modules. | ||
- Being introduced to code coupling and cohesion, which was later applied when I had a CodeMR free trial. | ||
|
||
### Udemy | ||
- Understanding how to write Groovy code. [Link](https://www.udemy.com/course/gradle-for-java-developers/) | ||
- Using CompletableFuture to split up unrelated tasks. [Link](https://www.udemy.com/course/parallel-and-asynchronous-programming-in-modern-java/) | ||
- Utilizing functional interfaces and the Streams API wherever necessary. [Link](https://www.udemy.com/course/functional-programming-and-reactive-programming-in-java/) | ||
- Learning about graph algorithms and heuristics. [Link](https://www.udemy.com/course/artificial-intelligence-games-in-java/learn/lecture/5958944?start=0#overview) | ||
- Using CompletableFuture to split up unrelated tasks, especially for the program boot up process. | ||
[Link](https://www.udemy.com/course/parallel-and-asynchronous-programming-in-modern-java/) | ||
- Utilizing functional interfaces and the Streams API wherever necessary. | ||
[Link](https://www.udemy.com/course/functional-programming-and-reactive-programming-in-java/) | ||
- Learning about graph algorithms and heuristics. | ||
[Link](https://www.udemy.com/course/artificial-intelligence-games-in-java/learn/lecture/5958944?start=0#overview) |
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 |
---|---|---|
@@ -1,4 +1,5 @@ | ||
# Module Progress | ||
|
||
### Finished Modules | ||
- Alphabet | ||
- Astrology | ||
|
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
Binary file not shown.
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 |
---|---|---|
@@ -1,5 +1,5 @@ | ||
distributionBase=GRADLE_USER_HOME | ||
distributionPath=wrapper/dists | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.4-bin.zip | ||
distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-bin.zip | ||
zipStoreBase=GRADLE_USER_HOME | ||
zipStorePath=wrapper/dists |
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
Oops, something went wrong.