bidict/docs/overwritingbidict.rst.inc

57 lines
1.7 KiB
PHP
Raw Normal View History

.. _overwritingbidict:
``OverwritingBidict`` Recipe
############################
If you'd like
:class:`OVERWRITE <bidict.DuplicationPolicy.OVERWRITE>`
to be the default duplication policy for
:func:`__setitem__() <bidict.bidict.__setitem__>` and
:func:`update() <bidict.bidict.update>`,
rather than always having to use
:func:`forceput() <bidict.bidict.forceput>` and
:func:`forceupdate() <bidict.bidict.forceupdate>`,
you can use the following recipe::
>>> from bidict import bidict, OVERWRITE
>>> class OverwritingBidict(bidict):
... on_dup_val = OVERWRITE
>>> b = OverwritingBidict({'one': 1})
>>> b['two'] = 1 # succeeds, no ValueDuplicationError
>>> b
OverwritingBidict({'two': 1})
>>> b.update({'three': 1}) # ditto
>>> b
OverwritingBidict({'three': 1})
As with
:class:`bidict.bidict <bidict.bidict>`,
``OverwritingBidict.put()`` and
``OverwritingBidict.putall()``
will still provide per-call overrides for duplication policies,
and will both still default to raising for all duplication types
unless you override those methods too.
To make an overwriting *ordered* bidict,
simply adapt this recipe to have the class inherit from
:class:`bidict.OrderedBidict`.
Beware of ``OVERWRITE``
:::::::::::::::::::::::
With a default :class:`OVERWRITE <bidict.DuplicationPolicy.OVERWRITE>` policy
as in the ``OverwritingBidict`` recipe above,
beware of the following potentially surprising behavior::
>>> b = OverwritingBidict({'one': 1, 'two': 2})
>>> b['one'] = 2
>>> b
OverwritingBidict({'one': 2})
That is, setting an existing key to the value of a different existing item
causes both existing items to be collapsed into a single item.