mirror of https://github.com/jab/bidict.git
57 lines
1.7 KiB
PHP
57 lines
1.7 KiB
PHP
![]() |
.. _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.
|