Skip to main content

Deprecate your code effortlessly with decorators. Give useful warnings and docstrings for different deprecations.

Project description

wabisabi

pypi Travis Docs

Python3 wabisabi. Automatically write boilerplate code for many kinds of deperecations through python decorators.

Link above not working for now: https://deprecation-factory.readthedocs.io/en/latest/?badge=latest

Motivations

Breaking things is important! Breaking other's things is just mean!

The goal of deprecations is to warn other library writers that their code is about to break so you can keep making agressive changes to your own.

Often when you want to deprecate a feature, you end up following a procedure similar to

  1. Make the useful modification to your code.
  2. Decide on when the old behaviour should be switched over.
  3. Add warnings INSIDE your function to warn users.
  4. Change the function signature to something non-sensical to detect the default behaviour.
  5. Add messages in the documentation (numpydoc compatible)

Finally, when the behaviour is official depreprecated, you need to do all these changes again.

  1. Remove the warnings.
  2. Remove the documentation messages.
  3. Remove the old behaviour.
  4. Change the function signature back to something useful.

The goal of this library is to allow you to shortcut steps 3-9. You shouldn't have to revisit the deprecation long after you completed implementing your new features. You write your code how it is supposed to look, this library, makes ensures your users have enough time to update their code.

This library

  • Modifies function signatures so to ensure correctness for the current version. This should help with autocompletions.
  • Adds a warning section to the docstrings. An attempt is made to properly indent the docstring.
  • Point the user to their line of code, so that they know where to make make the appropriate modification.
  • Leaving deprecators in place after the desired threshold results in a noop. This means that you can be lazy about ripping them out of code. Deprecations should not have to be blockers for your development.
  • If numpydoc > 0.7 is installed, the "Warns" sections are combined into a single section allowing you to chain deprecators.

Installation

While you can depend on this, I strongly recommend you version the files you need in your project as the API is highly likely to change and break your code.

Current deprecators

  • Deprecator for change of default values in kwargs. Handles kwargs passed as positional arguments too!
  • Transitionning to keyword only arguments.
  • kwarg renaming

Future deprecators

  • Swapping the order of positional arguments
  • Making an old kwarg a manditory positional arg
  • Feature requests are welcome!

Development Lead

  • Mark Harfouche

Contributors

Could be you!

How to contribute

Ready to contribute? We use the standard github contribution model. scikit-image has a great writeup on how to setup your environment. Adapt it for our environment.

Cookiecutter

This package was created with Cookiecutter and the audreyr/cookiecutter-pypackage project template.

History

0.3.0 (2022.10.30)

  • Use packaging instead of distutils for version comaprison. Note that this might cause certain versions to fail. Notably, '0.1.dev3' is now older than '0.1'.
  • Require Python 3.8.
  • New explicit dependency on packaging.

0.2.4 (2018.08.13)

  • Apparently numpydoc 0.6 didn't have a __version__ attribute....

0.2.3 (2018.08.13)

  • Check for numpydoc 0.7
  • Fix a typo in the docstring message

0.2.2 (2018.08.12)

  • API change. change_default_parameter now takes a dictionary for the old_kwargs so that parameter names don't conflict

0.2.1 (2018.08.12)

  • Merge with other numpydocs so that documentation in Sphinx doesn't crash

0.2.0 (2018.08.11)

  • Provide a deprecator for changing the number of keyword only arguments.

0.1.1 (2018.08.09)

  • Deprecated arguments appear in order for Python 3.5 as well.

0.1.0 (2018.08.09)

  • New deprecator for changing the default value of kwards. Handles arguments passed as positional argumnets too.

0.0.1 (2018-07-29)

  • First release on PyPi

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wabisabi-0.3.0.tar.gz (22.1 kB view details)

Uploaded Source

Built Distribution

wabisabi-0.3.0-py3-none-any.whl (23.4 kB view details)

Uploaded Python 3

File details

Details for the file wabisabi-0.3.0.tar.gz.

File metadata

  • Download URL: wabisabi-0.3.0.tar.gz
  • Upload date:
  • Size: 22.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for wabisabi-0.3.0.tar.gz
Algorithm Hash digest
SHA256 0d3655926cd1360add5ca7301310b9fee18fa49537c68e1291e2525ae34b2b4e
MD5 b53ff91b987b8383656bd5b285977a4c
BLAKE2b-256 763b9a3146e83fad4fd279d204c4b0822042f37c5d639156f6c518e587477b4a

See more details on using hashes here.

File details

Details for the file wabisabi-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: wabisabi-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 23.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.9.15

File hashes

Hashes for wabisabi-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 45a68f6616f55874c3ec401388d8fcf3d10fae33704cba540198cc761866b20a
MD5 c1cd8b24caa16b3c0d05352e80dbb345
BLAKE2b-256 326cf1e001d0b7c5c1887f07bccc4a0e505df29f7011b0c3b03cdab26f821b31

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page