bidict/CHANGELOG.rst

255 lines
8.4 KiB
ReStructuredText
Raw Normal View History

2016-06-28 04:05:22 +00:00
.. _changelog:
Changelog
=========
Release Notifications
---------------------
`Follow bidict on VersionEye <https://www.versioneye.com/python/bidict>`_
to automatically be notified via email
when a new version of bidict is released.
2016-07-04 03:29:24 +00:00
0.12.0 (2016-07-03)
-------------------
- New/renamed exceptions:
- :class:`KeyDuplicationError <bidict.KeyDuplicationError>`
- :class:`ValueDuplicationError <bidict.ValueDuplicationError>`
- :class:`KeyAndValueDuplicationError <bidict.KeyAndValueDuplicationError>`
- :class:`DuplicationError <bidict.DuplicationError>` (base class for the above)
2016-06-28 04:05:22 +00:00
- :func:`put() <bidict.bidict.put>`
now accepts ``on_dup_key``, ``on_dup_val``, and ``on_dup_kv`` keyword args
which allow you to override the default behavior
2016-07-04 03:29:24 +00:00
when the key or value of a given item
duplicates that (those) of any existing item(s).
2016-06-28 04:05:22 +00:00
These can take the following values:
- :attr:`bidict.DuplicationBehavior.RAISE`
- :attr:`bidict.DuplicationBehavior.OVERWRITE`
- :attr:`bidict.DuplicationBehavior.IGNORE`
``on_dup_kv`` can also take :attr:`bidict.DuplicationBehavior.ON_DUP_VAL`.
If not provided,
:func:`put() <bidict.bidict.put>` uses
2016-07-04 03:29:24 +00:00
:attr:`RAISE <bidict.DuplicationBehavior.RAISE>` behavior by default.
2016-06-28 04:05:22 +00:00
- New :func:`putall() <bidict.bidict.putall>` method
2016-07-04 03:29:24 +00:00
provides a bulk :func:`put() <bidict.bidict.put>` API,
allowing you to override the default duplication handling behavior
that :func:`update() <bidict.bidict.update>` uses.
2016-06-28 04:05:22 +00:00
2016-07-04 03:29:24 +00:00
- :func:`bidict.update() <bidict.bidict.update>` now fails clean,
so if an :func:`update() <bidict.bidict.update>` call raises a
:class:`DuplicationError <bidict.DuplicationError>`,
you can now be sure that none of the given items was inserted.
2016-06-28 04:05:22 +00:00
2016-07-04 03:29:24 +00:00
Previously, all of the given items that were processed
2016-06-28 04:05:22 +00:00
before the one causing the failure would have been inserted,
2016-07-04 03:29:24 +00:00
and no facility was provided to recover
which items were inserted and which weren't,
nor to revert any changes made by the failed
:func:`update() <bidict.bidict.update>` call.
2016-06-28 04:05:22 +00:00
The new behavior makes it easier to reason about and control
2016-07-04 03:29:24 +00:00
the effects of failed :func:`update() <bidict.bidict.update>` calls.
2016-06-28 04:05:22 +00:00
The new :func:`putall() <bidict.bidict.putall>` method also fails clean.
2016-07-04 03:29:24 +00:00
Internally, this is implemented by storing a log of changes
made while an update is being processed, and rolling back the changes
when one of them is found to cause an error.
This required reimplementing :class:`orderedbidict <bidict.orderedbidict>`
on top of two dicts and a linked list, rather than two OrderedDicts,
since :class:`OrderedDict <collections.OrderedDict>` does not expose
its underlying linked list.
2016-06-28 04:05:22 +00:00
2016-07-04 03:29:24 +00:00
- :func:`orderedbidict.move_to_end() <bidict.orderedbidict.move_to_end>`
now works on Python < 3.2 as a result of the new
:class:`orderedbidict <bidict.orderedbidict>` implementation.
2016-06-28 04:05:22 +00:00
- Add
- :func:`bidict.compat.viewkeys`
- :func:`bidict.compat.viewvalues`
- :func:`bidict.compat.iterkeys`
- :func:`bidict.compat.itervalues`
- :func:`bidict.compat.izip`
- :func:`bidict.compat.izip_longest`
to complement the existing
:func:`iteritems() <bidict.compat.iteritems>` and
:func:`viewitems() <bidict.compat.viewitems>`
compatibility helpers.
2016-07-04 03:29:24 +00:00
- More efficient implementations of
2016-06-28 04:05:22 +00:00
:func:`pairs() <bidict.util.pairs>`,
:func:`inverted() <bidict.util.inverted>`, and
2016-07-04 03:29:24 +00:00
:func:`bidict.copy() <bidict.BidirectionalMapping.copy>`.
2016-06-28 04:05:22 +00:00
2016-07-04 03:29:24 +00:00
- Implement :func:`bidict.__copy__() <bidict.BidirectionalMapping.__copy__>`
2016-06-28 04:05:22 +00:00
for use with the :mod:`copy` module.
- Fix issue preventing a client class from inheriting from
:class:`loosebidict <bidict.loosebidict>`
(see `#34 <https://github.com/jab/bidict/issues/34>`_).
- Add benchmarking to tests.
- Drop official support for CPython 3.3.
(It may continue to work, but is no longer being tested.)
Breaking API Changes
^^^^^^^^^^^^^^^^^^^^
2016-07-04 03:29:24 +00:00
- Rename ``KeyExistsException`` to :class:`KeyDuplicationError <bidict.KeyDuplicationError>`
and ``ValueExistsException`` to :class:`ValueDuplicationError <bidict.ValueDuplicationError>`.
- When overwriting the key of an existing value in an :class:`orderedbidict <bidict.orderedbidict>`,
the position of the existing item is now preserved,
overwriting the key of the existing item in place,
rather than moving the item to the end.
This now matches the behavior of overwriting the value of an existing key,
which has always preserved the position of the existing item.
(If inserting an item whose key duplicates that of one existing item
and whose value duplicates that of another,
the existing item whose value is duplicated is still dropped,
and the existing item whose key is duplicated
still gets its value overwritten in place, as before.)
For example::
>>> from bidict import orderedbidict
>>> o = orderedbidict([(0, 1), (2, 3)])
>>> o.forceput(4, 1)
previously would have resulted in::
>>> o # doctest: +SKIP
orderedbidict([(2, 3), (4, 1)])
but now results in::
>>> o
orderedbidict([(4, 1), (2, 3)])
2016-06-28 04:05:22 +00:00
0.11.0 (2016-02-05)
-------------------
- Add
:class:`bidict.orderedbidict`,
:class:`bidict.looseorderedbidict`,
and
:class:`bidict.frozenorderedbidict`.
- Add :doc:`Code of Conduct <code-of-conduct>`
(`<./CODE_OF_CONDUCT.rst>`_ |
`<https://bidict.readthedocs.io/code-of-conduct.html>`_).
- Drop official support for pypy3.
(It still may work but is no longer being tested.
Support may be added back once pypy3 has made more progress.)
0.10.0.post1 (2015-12-23)
-------------------------
- Minor documentation fixes and improvements.
0.10.0 (2015-12-23)
-------------------
- Remove several features in favor of keeping the API simpler
and the code more maintainable.
- In the interest of protecting data safety more proactively, by default
bidict now raises an error on attempting to insert a non-unique value,
rather than allowing its associated key to be silently overwritten.
See discussion in `#21 <https://github.com/jab/bidict/issues/21>`_.
- New :attr:`forceupdate() <bidict.bidict.forceupdate>` method
provides a bulk :attr:`forceput() <bidict.bidict.forceput>` operation.
- Fix bugs in
:attr:`pop() <bidict.bidict.pop>` and
:attr:`setdefault() <bidict.bidict.setdefault>`
which could leave a bidict in an inconsistent state.
Breaking API Changes
^^^^^^^^^^^^^^^^^^^^
- Remove ``bidict.__invert__``, and with it, support for the ``~b`` syntax.
Use :attr:`b.inv <bidict.BidirectionalMapping.inv>` instead.
`#19 <https://github.com/jab/bidict/issues/19>`_
- Remove support for the slice syntax.
Use ``b.inv[val]`` rather than ``b[:val]``.
`#19 <https://github.com/jab/bidict/issues/19>`_
- Remove ``bidict.invert``.
Use :attr:`b.inv <bidict.BidirectionalMapping.inv>`
rather than inverting a bidict in place.
`#20 <https://github.com/jab/bidict/issues/20>`_
- Raise ``ValueExistsException``
when attempting to insert a mapping with a non-unique key.
`#21 <https://github.com/jab/bidict/issues/21>`_
- Rename ``collapsingbidict`` to :class:`loosebidict <bidict.loosebidict>`
now that it suppresses
``ValueExistsException``
rather than the less general ``CollapseException``.
`#21 <https://github.com/jab/bidict/issues/21>`_
- ``CollapseException`` has been subsumed by
``ValueExistsException``.
`#21 <https://github.com/jab/bidict/issues/21>`_
- :attr:`put <bidict.bidict.put>` now raises ``KeyExistsException``
when attempting to insert an already-existing
key, and ``ValueExistsException`` when
attempting to insert an already-existing value.
0.9.0.post1 (2015-06-06)
------------------------
- Fix metadata missing in the 0.9.0rc0 release.
0.9.0rc0 (2015-05-30)
---------------------
- Add a Changelog!
Also a
`Contributors' Guide <https://github.com/jab/bidict/blob/master/CONTRIBUTING.rst>`_,
`Gitter chat room <https://gitter.im/jab/bidict>`_,
and other community-oriented improvements.
- Adopt Pytest (thanks Tom Viner and Adopt Pytest Month).
- Added property-based tests via
`hypothesis <https://hypothesis.readthedocs.io>`_.
- Other code, tests, and docs improvements.
Breaking API Changes
^^^^^^^^^^^^^^^^^^^^
- Move ``bidict.iteritems`` and ``bidict.viewitems``
to new :mod:`bidict.compat` module.
- Move :class:`bidict.inverted`
to new :attr:`bidict.util` module
(still available from top-level :mod:`bidict` module as well).
- Move ``bidict.fancy_iteritems``
to :func:`bidict.util.pairs`
(also available from top level as :func:`bidict.pairs`).
- Rename ``bidict_type`` keyword arg to ``base_type``
in :func:`bidict.namedbidict`.