You can contribute to this project:
- writing issues
- contributing to the code basis
If you find some bug or you think some new feature could improve the package, please write an issue going to New Issue and follow the instructions under the corresponding template
We follow the nbdev framework for the literate programming development of this project. So if you want to contribute, please familiarize first with this framework. Specially, we write our code, tests and documentation at the same time in jupyter notebooks.
If you have not heard about nbdev
yet and / or find the idea weird to develop in notebooks as it was the case for me, please watch the following youtube video first: I like notebooks by Jeremy Howard, the creator of this wonderful framework.
Prerequisites to setup the development environment:
- conda
To setup the development environment:
- Fork this project repository, i.e., click on the "Fork" button on the right of the top of the repo page. This creates a copy of the project code on your GitHub user account.
- Clone your forked project from your GitHub account to your local disk and navigate into it:
git clone [email protected]:YourLogin/sql_formatter.git
cd sql_formatter
- Setup the
upstream
remote to be the original project repository (this one and not your forked one):
git remote add upstream https://github.com/PabloRMira/sql_formatter.git
- Synchronize your master branch with the upstream branch:
git checkout master
git pull upstream master
- Create a new branch to hold your development changes:
git checkout -b my_feature_branch
- Install our conda development environment running
conda env create -f environment.yml
- Activate the python environment using
conda activate sql-formatter-dev
- Run
nbdev_install_git_hooks
- Run
pip install -e .
to install the package in editable mode. This way the command line interface (CLI)sql-formatter
will incorporate your changes in the python code - When your change is ready commit it, and push it to your fork
git add modified_files
git commit -m "some message"
git push -u origin my_feature_brach
- Follow these instructions to create a pull request from your fork.
For development we follow these steps:
- Pick an existing issue and write in the comments you would like to fix it
- If your idea is not documented in an issue yet, please write first an issue
- Create a branch from
master
and implement your idea - Before pushing your solution run first
make prepush
to make sure everything is allright to merge, specially our tests - Make a pull request for your solution
- The pull request title should be meaningful, something like "[PREFIX] Title of the issue you fixed". Please try to use some of the following prefixes:
- [FIX] for bugfixes
- [FEA] for new features
- [DOC] for documentation
- [MNT] for maintenance
Only pull requests / commits using the aforementioned prefixes will be added to the changelog / release notes