Skip to main content

Enhancements over Python's standard types

Project description

extypes
=======

This project provides a few enhanced types for Python:

* A "constrained set" (ordered or not)
* That's all for now.


It also provides extensions for Django (1.7 - 1.10).


It has been fully tested with all versions of Python from 2.7 to 3.4; and is distributed under the BSD license.


Links
-----

* Package on PyPI: http://pypi.python.org/pypi/extypes
* Repository and issues on GitHub: http://github.com/rbarrois/extypes
* Doc on https://extypes.readthedocs.io/ (not available yet)


Getting started
---------------

Intall the package from PyPI, using pip:

.. code-block:: sh

$ pip install extypes

Or from GitHub:

.. code-block:: sh

$ git clone git://github.com/rbarrois/extypes
$ cd extypes
$ python setup.py install


To check that everything went fine, fire a Python shell and import ``extypes``:


.. code-block:: python

import extypes


Introduction
------------

.. currentmodule:: extypes

``extypes`` provides a new type, ``ConstrainedSet``.

This is a ``set()``-like object, but values can only be taken from a
specific set of options.


A ``ConstrainedSet`` is declared in a manner very similar to ``collections.namedtuple``:

.. code-block:: python

import extypes
Foods = extypes.ConstrainedSet(['eggs', 'spam', 'bacon'])

This will declare a new class, ``Foods``, whose instances are ``ConstrainedSet`` that only accept
options among ``'eggs'``, ``'spam'`` and ``'bacon'``.


Those objects can be used as simple ``set()`` objects:

.. code-block:: pycon

>>> import extypes
>>> Foods = extypes.ConstrainedSet(['eggs', 'spam', 'bacon'])
>>> meat = Foods(['spam', 'bacon'])
>>> fresh = Foods(['bacon', 'eggs'])
>>> 'eggs' in meat
False
>>> 'eggs' in fresh
True
>>> meat & fresh
Foods(['bacon'])

As a ``set()`` object, they are mutable:

.. code-block:: pycon

>>> import extypes
>>> Foods = extypes.ConstrainedSet(['eggs', 'spam', 'bacon'])
>>> meat = Foods(['spam', 'bacon'])
>>> meat.remove('spam')
>>> meat
Foods(['bacon'])

And iterable:

.. code-block:: pycon

>>> import extypes
>>> Foods = extypes.ConstrainedSet(['eggs', 'spam', 'bacon'])
>>> meat = Foods(['bacon', 'spam'])
>>> list(meat)
['spam', 'bacon']

But only valid options are accepted:

.. code-block:: pycon

>>> Foods = extypes.ConstrainedSet(['eggs', 'spam', 'bacon'])
>>> greens = Foods(['spinach']
Traceback (most recent call last):
...
ValueError: Invalid keys ['spinach'], please use a value in ['spam', 'bacon', 'eggs'].


Extensions: Django
------------------

.. currentmodule:: extypes.django

``extypes`` also provides custom fields for Django - compatible with Django 1.7 and upwards.

.. code-block:: python

from django.db import models
import extypes
import extypes.django

Foods = extypes.ConstrainedSet(['eggs', 'spam', 'bacon'])

class Fridge(models.Model):
contents = extypes.django.SetField(choices=Foods)

This field will simply behave as a simple ``ConstrainedSet``.

.. code-block:: pycon

>>> fridge = Fridge(contents=['bacon'])
>>> fridge.contents.add('eggs')
>>> fridge.save()


It is displayed in forms as a multiple choice field.
In the database, it is saved as a ``|``-separated list of enabled values
(in the above example, the field is stored as ``|eggs|bacon|``).

.. note:: ``extypes.django.SetField`` can also receive a choice-like list:

.. code-block:: python

class Fridge(models.Model):
contents = extypes.django.SetField(choices=[('eggs', "Eggs"), ('spam', "Spam"), ('bacon', "Yummy bacon")])


In that case, the field definition is available at ``Fridge.contents.set_definition``:

.. code-block:: pycon

>>> f = Fridge(contents=Fridge.contents.set_definition(['eggs', 'spam']))
>>> f.get_contents_display()
"Eggs, Spam"

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

extypes-1.0.1.tar.gz (5.8 kB view details)

Uploaded Source

Built Distribution

extypes-1.0.1-py3-none-any.whl (6.4 kB view details)

Uploaded Python 3

File details

Details for the file extypes-1.0.1.tar.gz.

File metadata

  • Download URL: extypes-1.0.1.tar.gz
  • Upload date:
  • Size: 5.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for extypes-1.0.1.tar.gz
Algorithm Hash digest
SHA256 e5032caf22fe249f146c429bbd39e78380e3713242edc6ce38f4e47fa13d171d
MD5 15b29b4456efb7d394223df9e497a610
BLAKE2b-256 2cbbc9cd89854dbee776d81ee0c356a6b44eb8a9ba18caaebc122b1eeb80ce92

See more details on using hashes here.

File details

Details for the file extypes-1.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for extypes-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 34e3ac90b0d1b7f2d68d851ed1ba0bd94eaad06b07c74adb4b6cbaefed28346e
MD5 9cf64352e1ba76d935b8c36a7658509d
BLAKE2b-256 77a4a2eefad5012190950bce53d8f59f5a7072f7dd45bd52b10bd23324c2d34f

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