Thanks for taking the time to contribute! We appreciate all contributions, from reporting bugs to implementing new features. If you're unclear on how to proceed after reading this guide, please contact us on Discord.
We use GitHub issues to track bugs and suggested enhancements. You can report a bug by opening a new issue. Use the appropriate issue type for the language you are using (Rust / Python / Node.js).
Before creating a bug report, please check that your bug has not already been reported, and that your bug exists on the latest version of Polars. If you find a closed issue that seems to report the same bug you're experiencing, open a new issue and include a link to the original issue in your issue description.
Please include as many details as possible in your bug report. The information helps the maintainers resolve the issue faster.
We use GitHub issues to track bugs and suggested enhancements. You can suggest an enhancement by opening a new feature request. Before creating an enhancement suggestion, please check that a similar issue does not already exist.
Please describe the behavior you want and why, and provide examples of how Polars would be used if your feature were added.
Pick an issue by going through the issue tracker and finding an issue you would like to work on. Feel free to pick any issue that is not already assigned. We use the help wanted label to indicate issues that are high on our wishlist.
If you are a first time contributor, you might want to look for issues labeled good first issue. The Polars code base is quite complex, so starting with a small issue will help you find your way around!
If you would like to take on an issue, please comment on the issue to let others know. You may use the issue to discuss possible solutions.
Polars development flow relies on both Rust and Python, which means setting up your local development environment is not trivial. For contributing to Node.js Polars, please check out the Node.js Polars repository. If you run into problems, please contact us on Discord.
Note that if you are a Windows user, the steps below might not work as expected; try developing using WSL.
Start by forking the Polars repository, then clone your forked repository using git
:
git clone git@github.com:<username>/polars.git
cd polars
In order to work on Polars effectively, you will need Rust, Python, and dprint.
First, install Rust using rustup. After the initial installation, you will also need to install the nightly toolchain:
rustup toolchain install nightly --component miri
Next, install Python, for example using pyenv.
We recommend using the latest Python version (3.11
).
Make sure you deactivate any active virtual environments or conda environments, as the steps below will create a new virtual environment for Polars.
You will need Python even if you intend to work on the Rust code only, as we rely on the Python tests to verify all functionality.
Finally, install dprint. This is not strictly required, but it is recommended as we use it to autoformat certain file types.
You can now check that everything works correctly by going into the py-polars
directory and running the test suite
(warning: this may be slow the first time you run it):
cd py-polars
make test
This will do a number of things:
- Use Python to create a virtual environment in the
py-polars/venv
folder. - Use pip to install all Python dependencies for development, linting, and building documentation.
- Use Rust to compile and install Polars in your virtual environment.
- Use pytest to run the Python unittests in your virtual environment
Check if linting also works correctly by running:
make pre-commit
Note that we do not actually use the pre-commit tool. We use the Makefile to conveniently run the following formatting and linting tools:
If this all runs correctly, you're ready to start contributing to the Polars codebase!
Create a new git branch from the master
branch in your local repository, and start coding!
The Rust codebase is located in the polars
directory, while the Python codebase is located in the py-polars
directory.
Both directories contain a Makefile
with helpful commands. Most notably:
make test
to run the test suitemake pre-commit
to run autoformatting and linting
Note that your work cannot be merged if these checks fail!
Run make help
to get a list of other helpful commands.
Two other things to keep in mind:
- If you add code that should be tested, add tests.
- If you change the public API, update the documentation.
When you have resolved your issue, open a pull request in the Polars repository. Please adhere to the following guidelines:
- Start your pull request title with a conventional commit tag. This helps us add your contribution to the right section of the changelog. We use the Angular convention. Scope can be
rust
and/orpython
, depending on your contribution. - Use a descriptive title. This text will end up in the changelog.
- In the pull request description, link to the issue you were working on.
- Add any relevant information to the description that you think may help the maintainers review your code.
- Make sure your branch is rebased against the latest version of the
master
branch. - Make sure all GitHub Actions checks pass.
After you have opened your pull request, a maintainer will review it and possibly leave some comments. Once all issues are resolved, the maintainer will merge your pull request, and your work will be part of the next Polars release!
Keep in mind that your work does not have to be perfect right away! If you are stuck or unsure about your solution, feel free to open a draft pull request and ask for help.
In short, when you submit code changes, your submissions are understood to be under the same MIT License that covers the project.
The most important components of Polars documentation are the user guide, the API references, and the database of questions on StackOverflow.
The user guide is maintained in the polars-book repository. For contributing to the user guide, please refer to the contributing guide in that repository.
Polars has separate API references for Rust, Python, and Node.js. These are generated directly from the codebase, so in order to contribute, you will have to follow the steps outlined in this section above.
Rust Polars uses cargo doc
to build its documentation. Contributions to improve or clarify the API reference are welcome.
For the Python API reference, we always welcome good docstring examples. There are still parts of the API that do not have any code examples. This is a great way to start contributing to Polars!
Note that we follow the numpydoc convention.
Docstring examples should also follow the Black codestyle.
From the py-polars
directory, run make fmt
to make sure your additions pass the linter, and run make doctest
to make sure your docstring examples are valid.
Polars uses Sphinx to build the API reference.
This means docstrings in general should follow the reST format.
If you want to build the API reference locally, go to the py-polars/docs
directory and run make html SPHINXOPTS=-W
.
The resulting HTML files will be in py-polars/docs/build/html
.
New additions to the API should be added manually to the API reference by adding an entry to the correct .rst
file in the py-polars/docs/source/reference
directory.
For contributions to Node.js Polars, please refer to the official Node.js Polars repository.
We use StackOverflow to create a database of high quality questions and answers that is searchable and remains up-to-date. There is a separate tag for each language:
Contributions in the form of well-formulated questions or answers are always welcome! If you add a new question, please notify us by adding a matching issue to our GitHub issue tracker.