We understand that open-source contributions can be intimidating, so we've created detailed documentation and guidelines to help you get started 📚. Our community is friendly and welcoming 🤗, and we're always happy to answer any questions you may have 💬. We also have a Code of Conduct in place to ensure that everyone feels safe and respected while contributing to the project 💛.
If you're looking for a specific task to work on, check out our issues page on GitHub 🐞. We've labeled issues with various levels of difficulty 💪, so you can find something that's a good fit for your skills and interests. You can also propose new features or improvements by opening an issue or pull request 🚀.
To sum up, PyLFG is an open-source project that welcomes contributions from anyone and everyone 🌎. We're excited to see what you can bring to the table, and we look forward to working with you to make PyLFG an even better tool for linguistics students and professors, language learning applications, and documenting under-resourced languages 🌟. So, don't hesitate, join us today and make an impact on the field of linguistics!🌟🌟🌟🌟🌟
Report bugs at https://github.com/Ars-Linguistica/PyLFG/issues.
If you are reporting a bug, please include:
- Your operating system name and version.
- Any details about your local setup that might be helpful in troubleshooting.
- Detailed steps to reproduce the bug.
Look through the GitHub issues for bugs. Anything tagged with "bug" and "help wanted" is open to whoever wants to implement it.
Look through the GitHub issues for features. Anything tagged with "enhancement" and "help wanted" is open to whoever wants to implement it.
PyLFG could always use more documentation, whether as part of the official PyLFG docs, in docstrings, or even on the web in blog posts, articles, and such.
The best way to send feedback is to file an issue at https://github.com/Ars-Linguistica/PyLFG/issues.
If you are proposing a feature:
- Explain in detail how it would work.
- Keep the scope as narrow as possible, to make it easier to implement.
- Remember that this is a volunteer-driven project, and that contributions are welcome :)
To get started, you'll need to fork the PyLFG repository on GitHub and clone your fork locally. You can do this by running the following commands in your terminal:
$ git clone [email protected]:Ars-Linguistica/PyLFG.git
We recommend using poetry as our build manager and the pyproject.toml file to manage our dependencies. Make sure you have poetry installed, then
$ cd PyLFG
$ poetry install
Before you begin working on a new feature or bugfix, create a new branch for it. This makes it easier to isolate changes and submit them in a pull request. You can create a new branch by running the following command:
$ git checkout -b name-of-your-bugfix-or-feature
We support Python versions 3.11 and higher, make sure that your code is compatible with all of them by running the tests:
$ poetry run pytest
$ poetry run tox
When you're ready to submit your changes, first make sure that all tests pass. Then, commit your changes and push your branch to your fork on GitHub:
$ git add .
$ git commit -m "Your detailed description of your changes."
$ git push origin name-of-your-bugfix-or-feature
Finally, submit a pull request through the GitHub website.
Before you submit, make sure that all of the following are true:
- All tests pass
- The pull request includes a clear description of the changes you've made
- You've added yourself to the CONTRIBUTORS.rst file
- You've added and ran the appropriate GitHub action workflows and checked that they have passed.
Please note that we may ask you to make changes to your pull request before it is merged. We'll review your changes and provide feedback as soon as possible. Thank you for your contribution!
Checking the status of the GitHub workflows of a pull request can be done by following these steps:
- Go to the pull request on GitHub that you want to check the status of.
- Look at the "Checks" section of the pull request, which is located at the bottom of the pull request page, next to the "Files changed" tab.
- Here, you will see the status of all the workflows that are associated with the pull request. Each workflow will have a name and a status (e.g. "continuous-integration/travis-ci/pr", "success").
- Click on the name of the workflow to view more details about it. This will take you to the "Actions" tab of the pull request, where you can see the output of each job that is associated with that workflow.
- Look for the "Status" field of each job to see if it has passed or failed. If a job has failed, you can click on the job name to view more details about the failure, such as the error message or log output.
- If any of the workflows fail, make changes to your pull request to address the issues and update the pull request.
Once all workflows have passed, your pull request will be ready for review and merging. It's also worth noting that you can also check the status of the workflows on the GitHub Actions tab of the repository, where you can see all the recent workflows runs and their statuses.
Here are a few tips to assist you in your development.
To run a subset of the tests:
$ poetry run pytest tests/test_module.py
To run pytest with coverage:
$ poetry run pytest --cov=PyLFG
To run mypy type checks:
$ poetry run mypy
To check for any code style issues using flake8:
$ poetry run flake8 PyLFG
To automatically format your code using black:
$ poetry run black PyLFG
It is also recommended to use pre-commit hooks to automatically run these checks before committing your changes. This can be easily set up using pre-commit by installing it in your virtual environment with
$ poetry add pre-commit
and then running
$ pre-commit install
in the root of your local repository.
Additionally, it is a good practice to regularly update your dependencies to ensure compatibility and security. This can be done by running
$ poetry update
and committing the updated pyproject.toml and poetry.lock files.
By following these best practices and utilizing these tools, you can ensure that your contributions adhere to the project's standards and maintain the overall quality of the codebase.