Skip to content

Latest commit

 

History

History
134 lines (91 loc) · 5.88 KB

CONTRIBUTING.md

File metadata and controls

134 lines (91 loc) · 5.88 KB

How to contribute to FXGL

Contribution of any form is welcome! Please see the list below on how you can contribute to the project. Once you've decided what you would like to do, let us know about it first. This is to make sure that the issue you want hasn't already been implemented or being worked on in newer versions.

  • Proof read the public documentation for errors, ambiguities and typos.
  • Crash test features for bugs.
  • Add missing tests.
  • Create an issue or suggest a feature backed up by a use case.
  • Provide or suggest an implementation of an issue from GitHub Issues.
  • Suggest an API change to simplify user workflow.
  • Samples might get outdated quickly, see if you can find something weird or not working.
  • Share details about your project based on FXGL (this will go to the showcase section).
  • Write a tutorial on how to use FXGL.

If you want to be involved with the project on a long-term basis, please scroll down to community roles.

Workflow

There are 2 branches: dev and release. The release branch is for releases only. All the work goes to your dev branch, then pull a request back to dev.

Development

Due to use of Kotlin, IntelliJ IDEA is recommended. To start developing FXGL you can set up IDEA (2021.3+) as follows:

  1. Fork FXGL into your GitHub repo, then clone your repo to your machine.
  2. Open IDEA -> File -> New -> Project from Existing Sources -> Select the cloned FXGL directory.
  3. Import project from external model -> Maven -> Finish.

Ensure you are using JDK 17 (or higher). You can set this via File -> Project Structure -> Project.

You should now see something like this:

Next:

  1. In the fxgl module, in IntelliJ, right-click on src/main/java-templates and mark directory as sources root.
  2. Right-click on the fxgl-test module and rebuild fxgl-test module.

You should now be able to run samples and tests.

Running all tests

In IntelliJ,

  1. Run -> Edit Configurations
  2. Add new JUnit configuration with name "ALL FXGL TESTS"
  3. Select "Test kind" - "All in package" and "Search for tests" - "In whole project".
  4. Apply -> OK.

Now you can run your configuration "ALL FXGL TESTS" which runs tests from all modules.

Note: if you encounter errors, such as "Cannot create process = 206", go to Edit Configurations again and clear the "working directory" text field.

Coding Standards

The project uses the following guidelines:

  • Tabs set to 4 spaces & consistent indentation.
  • Consistent naming conventions (no Hungarian notation).
  • Javadoc on public and protected API (where appropriate).
  • Keep access to fields and methods as restricted as you can.
  • When using text in UI, use localization (e.g. english.properties).
  • Short license header in each new file and @author.

If in doubt, skim through the existing source code to get a feel for it.

Conventional Commits for Changelogs

From version 17, the project uses the following commit message guidelines to auto-generate changelogs, based on Conventional Commits 1.0.0:

  • build: message -- change affects the build system, configuration files, scripts, or external dependencies
  • docs: message -- change affects documentation only
  • feat: message -- change adds a new or modifies an existing feature
  • fix: message -- change fixes a bug
  • perf: message -- change improves performance
  • refactor: message -- change cleans up or restructures code
  • test: message -- change that adds new or updates existing tests
  • repo: message -- change that is related to repository maintenance

Examples:

  • build: use JDK 17 as baseline
  • docs: update description of method X to match behavior

If the commit type follows a !, then it is a breaking change. Example: refactor!: removed deprecated methods X and Y

Optionally, the change scope can be provided. Example: feat(core): message.

If a commit does not follow the guidelines (i.e. no : character), then it is excluded from the changelog. Hence, the : character is banned from non-changelog commit messages.

Community Roles

Community developers may apply to any of these roles by opening an issue or discussing in the community chat. Each role is allocated based on discussions with the individual. The individual is expected to be committed to the role guidance. However, the role descriptions are merely a guidance and not binding in any way. The role may be revoked at the request of the individual or due to violation of the Code of Conduct.

Maintainer (Collaborator):

  • Lead the project development and set out project goals
  • Represent the project at conferences and other events
  • Engage with the community to obtain feedback
  • Review Pull Requests
  • Guide new and existing Contributors to develop Pull Requests
  • Provide technical support in the community chat

Coordinator:

  • Lead one or more areas of the project development
  • Engage with the Maintainers to discuss the development
  • Review Pull Requests
  • Guide new and existing Contributors to develop Pull Requests
  • Provide technical support in the community chat

Tester:

  • Provide feedback on latest project versions
  • Crash test new and existing features after major updates
  • Provide technical support in the community chat

Contributor:

Any developer whose Pull Request has been merged is considered a Contributor.

Sponsor:

Any developer who is sponsoring (or has sponsored in the past) the project is considered a Sponsor.