Contributor guide

Thank you for your interest in improving this project.

This project is no longer maintained. For bug fixing and improvements, fork this repository and continue development elsewhere.

This project is open source under the MIT License.

Here is a list of important resources for contributors:

Report bugs

Report bugs on the Issue Tracker.

When filing an issue, make sure to answer these questions:

  • Which operating system and Python version are you using?

  • Which version of this project are you using?

  • What did you do?

  • What did you expect to see?

  • What did you see instead?

  • Any details about your local setup that might be helpful in troubleshooting

An effective way to get your bug fixed is to provide a test case, and/or steps to reproduce the issue.

Fix bugs

Look through the GitHub issues for bugs. Anything tagged with “bug” and “help wanted” is open to whoever wants to fix it.

Request features

Request features on the Issue Tracker.

If you are proposing a new feature:

  • Explain in detail how it would work.

  • Keep the scope as narrow as possible, to make it easier to add.

  • Remember that this is a volunteer-driven project, and that contributions are welcome :)

Add features

Look through the GitHub issues for features. Anything tagged with “enhancement” and “help wanted” is open to whoever wants to Add it.

Write documentation

Unofficial Tabdeal API could always use more documentation, whether as part of the official docs, in docstrings, or even on the web in blog posts, articles, and such.

Submit feedback

A great way to send feedback is to file an issue at Issue Tracker

How to set up your development environment

Ready to contribute? Here’s how to set up Unofficial Tabdeal API for local development.

Use VS Code Dev Containers extension and clone this repository.

Requirements will be installed automatically

Poetry manages virtual environments and dependencies for this project.

pre-commit manages linters, static analysis, and other tools for this project.

Install pre-commit hooks after cloning, run:

pre-commit install

Using pre-commit ensures PRs match the linting requirements of the codebase.

Possible issues you may encounter

If you encounter an error about not setting user.name and user.email for committing with git:

  • Run the following commands on your local machine terminal to set-up your git connection

git config --global user.name "YOUR_USER_NAME"

git config --global user.email "YOUR_EMAIL"
  • Rebuild the container

If you encounter an error about not having the permission to .git/object for committing with git: insufficient permission for adding an object to repository database .git/objects

  • Run the following commands on dev container terminal:

sudo chmod -R a+rwX .

sudo find . -type d -exec chmod g+s '{}' +
  • Check the output of shared repository:

git config core.sharedRepository
  • If the output of last command is empty or doesn’t include group , true or 1, run the following:

git config core.sharedRepository group
  • Finally, fix the root cause by following the answer from stackoverflow.

Documenting your code

Whenever possible, please add docstrings to your code.

This project follows the google-style docstrings format.

To confirm docstrings are valid, build the docs by running nox -t docs

Good docstrings include information like:

  1. If the intended use-case doesn’t appear clear, what purpose does this function serve? When should someone use it?

  2. What happens during errors/edge-cases.

  3. When dealing with physical values, include units.

How to test the project

The pytest framework provides unit testing for this project.

Ideally, all new code is paired with new unit tests to exercise that code.

If fixing a bug, consider writing the test first to confirm the existence of the bug, and to confirm that the new code fixes it.

Unit tests should only test a single concise body of code.

Run the full test suite:

nox -t test

Lint using Ruff:

nox -t fix

Typecheck using MyPy:

nox -t type

Build and live-preview documentation:

nox -t preview

Run pre-commit hooks:

nox -t pre-commit

List the available Nox sessions:

nox --list

Unit tests are located in the tests directory, and are written using the pytest testing framework.

Coding style

In an attempt to keep consistency and maintainability in the code-base, here are some high-level guidelines for code that might not be enforced by linters:

  • Use f-strings.

  • Keep/cast path variables as pathlib.Path objects. Don’t use os.path. For public-facing functions, cast path arguments immediately to Path.

  • Avoid deeply nested code. Techniques like returning early and breaking up a complicated function into smaller functions results in easier-to-read and test code.

  • Consider if you are double-name-spacing and how modules are meant to be imported. for example, it might be better to name a function read instead of image_read in the module my_package/image.py. Consider the module name-space and check if it’s flattened in __init__.py.

How to submit changes

Open a pull request and target the dev branch to submit changes to this project.

Don’t target the main branch, as it’s reserved for releases.

Your pull request needs to meet the following guidelines for acceptance:

  • The Nox test suite must pass without errors and warnings.

  • Include unit tests. This project maintains high code coverage.

  • If your changes add capability, update the documentation accordingly.

Feel free to submit early, iteration and improvement can happen as needed.

It’s recommended to open an issue before starting work on anything. This will allow a chance to discuss your approach with the owners and confirm it fits the project’s direction.