Skip to main content

Nestable, tab-able options for use in Python programs

Project description

https://img.shields.io/pypi/v/optioneer.svg https://img.shields.io/pypi/status/optioneer.svg https://travis-ci.com/topper-123/optioneer.svg?branch=master https://img.shields.io/badge/License-BSD%203--Clause-blue.svg https://img.shields.io/pypi/pyversions/optioneer.svg

Optioneer makes in-program options, that:

  • are nestable and groupable,

  • are tab-able in the REPL for easy options discoverability

  • give each option a optional doc string, for easily explaining the option

  • may deprecate according to a transparent deprecation cycle

  • may be validated upon change

  • can do custom callbacks

Optioneer is based on the core/config.py module in pandas.

Installation

Installing is easy using pip:

pip install optioneer

Usage guide

In a config.py file set up your options:

from optioneer import Optioneer
options_maker = Optioneer()
options_maker.register_option('api_key', 'abcdefg')
options_maker.register_option('display.width', 200, doc='Width of our display')
options_maker.register_option('display.height', 200, doc='Height of our display')
options_maker.register_option('color', 'red', validator=options_maker.is_str)

options = options_maker.options

Then, in the relevant location of your library, just do from config import options and you’re got your options set up.

Users of your library can now access the options from the relevant location in your package, e.g. if you’ve made it available in the top-level __init__.py of a package called mylib:

>>> import mylib
>>> import mylib.options
Options(
  api_key: No description available.
      [default: abcdefg] [currently: abcdefg]
  color: No description available.
      [default: red] [currently: red]
  display.height: Height of our display
      [default: 200] [currently: 200]
  display.width: Width of our display
      [default: 200] [currently: 200]
  )

Notice how the repr output shows the relevant options and their descriptions.

The relevant options are discoverable using tabs in the REPL:

>>> mylib.options.<TAB>
option.api_key options.color options.display
>>> mylib.options.display.<TAB>
options.display.height options.display.width

You can also easily see the options and their values and docs for subgroups in the repr string:

>>> mylib.options.display
Options(
  display.height: Height of our display
      [default: 200] [currently: 200]
  display.width: Width of our display
      [default: 200] [currently: 200]
  )

Callbacks

By providing a callback when registering options, changing options may trigger a desired actions. For example, if you in your config.py do:

options_maker.register_option('shout', True, callback=lambda x: print("YEAH!"))

Then the user, when changing that option will see:

>>> mylib.options.shout = False
YEAH!

Of course, the callback can be more realistic than above, e.g. logging or setting some internal option or something else.

Deprecating options

If you want to deprecate an option, optioneer allows you to do that:

options_maker.deprecate_option('api_key', msg='An api key is no longer needed')

Now your users get a deprecation warning, if they access this option:

>>> mylib.options.api_key
An api key is no longer needed
C:\Users\TP\Documents\Python\optioneer\optioneer\lib.py:677: FutureWarning: An api key is no longer needed
  warnings.warn(deprecated_option.msg, FutureWarning)
Out[20]: 'abcdefg'

If an options should be renamed and/or a marker should be for when the option will be removed, that is also possible:

options_maker.register_option('display.length', 300, doc='Length of our display')
options_maker.deprecate_option('display.height', redirect_key='display.length',
                               removal_version='v1.3')

Then accessing the option will show

>>> mylib.options.display.height
C:\Users\TP\Documents\Python\optioneer\optioneer\lib.py:689: FutureWarning: 'display.height' is deprecated and will be removed in v1.3, please use 'display.length' instead.
  warnings.warn(msg, FutureWarning)
Out[24]: 300

Deprecated options will not show up in repr output or when tab-completing.

Dependencies

Optioneer has no external dependencies.

Optioneer uses pytest for testing.

License

Optioneer is BSD 3-licensed.

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

optioneer-1.0.3.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

optioneer-1.0.3-py2.py3-none-any.whl (10.6 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file optioneer-1.0.3.tar.gz.

File metadata

  • Download URL: optioneer-1.0.3.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.2 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.6.6

File hashes

Hashes for optioneer-1.0.3.tar.gz
Algorithm Hash digest
SHA256 907b22822a2825b18b53dfffdfa50cbc834ddd3efe7a26d9185cb17f951fbcf1
MD5 660bc405151df395e2bdf4fbe2b7023e
BLAKE2b-256 88d1bb5c86aed73d5819e024ad5c9e04232d1d72f7904929a092f9e78e75aaf9

See more details on using hashes here.

File details

Details for the file optioneer-1.0.3-py2.py3-none-any.whl.

File metadata

  • Download URL: optioneer-1.0.3-py2.py3-none-any.whl
  • Upload date:
  • Size: 10.6 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.11.0 pkginfo/1.4.2 requests/2.19.1 setuptools/40.4.2 requests-toolbelt/0.8.0 tqdm/4.26.0 CPython/3.6.6

File hashes

Hashes for optioneer-1.0.3-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 b8cef229aba4da721bf3506a2c54dbb248af5e1174c1176bb74fe2cf8407f461
MD5 a657d0dbf3cd6e334debe3828659b108
BLAKE2b-256 a143d3536369ddb1ff40932c56949418b42b708b13a8afde49b4409fa8e50407

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