Your contribution is always appreciated!
Contributions don't need to be perfect, but they must move GodSVG in the right direction. If you are planning to implement a feature or overhaul a system, it's important to write a proposal and discuss your ideas. I will try to quickly accept or decline them. Please do understand that PRs with a large maintenance cost may be under high scrutiny because of their long-term responsibility, even in the absence of the original contributor.
GodSVG is made in Godot using its GDScript language. Refer to the README on how to get GodSVG running.
Git must be configured, then you can clone the repository to your local machine: git clone [email protected]:MewPurPur/GodSVG.git
The documentation won't go into detail about how to use Git. Refer to outside resources if you are unfamiliar with it.
Look through the list of issues to see if your contribution would resolve any of them. If said issue is not assigned to anyone and you don't want anyone else to work on it, ask to be assigned to the issue. If an issue doesn't exist and you want to fix a bug, then it's a good practice, but not required, to make an issue for it.
- Fork the repository.
- Create a new branch:
git checkout -b implement-gradients
- Make your modifications, add them with
git add .
- Commit your changes:
git commit -m "Implement linear gradients"
- Push to the branch:
git push origin implement-gradients
- Create a new pull request with a clear and informative title and describe your changes.
This is the preferred workflow, but tidiness is not as important as work being done, so feel free to do something different you may be comfortable with.
After submitting your pull request, I (MewPurPur) will review your changes and may provide feedback or request modifications. Be responsive to any comments or suggestions. Once your pull request is approved, it will be merged. Afterward, you can delete your branch from your fork.
Editing tranlations is explained here
For scripts, only GDScript code is allowed. Follow the GDScript style guide. Most of its rules are enforced here. Additionally:
- Static typing is predominantly used.
- Comments are normally written like sentences with punctuation.
- Two spaces are used to separate code and inline comments.
- For empty lines in the middle of indented blocks, the scope's indentation is kept.
- Class names use
class_name X extends Y
syntax. - StringNames are only used if something is performance-critical.
@export
for nodes is only used if the runtime structure is not known.
Don't make pull requests for code style changes without discussing them first (unless it's for corrections to abide by the ones described here). Pull requests may also get production tweaks to fix their style before being merged.