3.7 KiB
Contributing to PySol FC
You want to contribute? That's great! Welcome aboard. First of all see these links for general guidelines for contributing to open source.
Contribution constraints
- The GitHub Actions CI build and AppVeyor build (which also run the test suite) should pass on each commit.
- Your contributions should be under GPLv3+ or a compatible free software licence, but please don't put them under the AGPL, which adds additional restrictions.
- The code should be compatible with both Python 2.7.x and Python 3.4.x-and-above.
How you can contribute
- Translate PySol to a human language you know.
- Test the "master" branch version of the version control repository or other prereleases.
- Try to reproduce open issues
- Try to fix bugs.
- Add new games.
- Improve the documentation / online help
- Refactor the code.
- Add new features.
- Contribute graphics
- Improve the site
- Package PySol for a new package repository or OS, or update existing packages.
- Make a monetary donation.
- Star or Watch the repository on GitHub
Adding new games
First of all there is the "Solitaire Wizard" which may be used to generate many custom variants. It lives in the Edit menu.
Otherwise, the games' sources live under the pysollib/games/ directory in the repository, and are written in Python 2.7/3.x and you can try inheriting from an existing variant class.
Contributing changesets / patches / diffs
One can contribute changesets either by opening pull-requests or merge requests, or by submitting patches generated by git diff or git format-patch to a developer's email (e.g @shlomif's ) or uploading it to a web service (e.g: a pastesite, dropbox, or Google Drive).
The Release Process
In order to publish a new version, follow these steps:
- Update
NEWS.asciidoc
. - Update the
VERSION_TUPLE =
line inpysollib/settings.py
. - Test using
gmake test
. git commit
the changes .git tag pysolfc-2.6.5
(or equivalent version).git push
andgit push --tags
to https://github.com/shlomif/PySolFC .- Wait for the AppVeyor build for the tag to complete and scan the .exe using https://www.virustotal.com/ .
- Grab the macOS installer (.dmg) from GitHub Actions (look for an artifact called
pysolfc-dmg
). - Run
gmake dist
. - Use rexz9 on
dist/PySol*.tar.xz
. - Go to https://sourceforge.net/projects/pysolfc/files/PySolFC/ and add a folder called PySolFC-2.6.5 (note the capitalisation).
- Add the tar.xz, the .exe and the .dmg there and mark them as defaults for the right OSes.