123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113 |
- ##############################################################################
- #
- # Copyright (c) 2001-2012 Zope Foundation and Contributors.
- # All Rights Reserved.
- #
- # This software is subject to the provisions of the Zope Public License,
- # Version 2.1 (ZPL). A copy of the ZPL should accompany this distribution.
- # THIS SOFTWARE IS PROVIDED "AS IS" AND ANY AND ALL EXPRESS OR IMPLIED
- # WARRANTIES ARE DISCLAIMED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- # WARRANTIES OF TITLE, MERCHANTABILITY, AGAINST INFRINGEMENT, AND FITNESS
- # FOR A PARTICULAR PURPOSE
- #
- ##############################################################################
-
- __all__ = ('Bucket', 'Set', 'BTree', 'TreeSet',
- 'LFBucket', 'LFSet', 'LFBTree', 'LFTreeSet',
- 'union', 'intersection', 'difference',
- 'weightedUnion', 'weightedIntersection', 'multiunion',
- )
-
- from zope.interface import moduleProvides
-
- from .Interfaces import IIntegerFloatBTreeModule
- from ._base import Bucket
- from ._base import MERGE
- from ._base import MERGE_WEIGHT_numeric
- from ._base import MERGE_DEFAULT_float
- from ._base import Set
- from ._base import Tree as BTree
- from ._base import TreeSet
- from ._base import _TreeIterator
- from ._base import difference as _difference
- from ._base import intersection as _intersection
- from ._base import multiunion as _multiunion
- from ._base import set_operation as _set_operation
- from ._base import to_long as _to_key
- from ._base import to_float as _to_value
- from ._base import union as _union
- from ._base import weightedIntersection as _weightedIntersection
- from ._base import weightedUnion as _weightedUnion
- from ._base import _fix_pickle
- from ._compat import import_c_extension
-
- _BUCKET_SIZE = 120
- _TREE_SIZE = 500
- using64bits = True
-
-
- class LFBucketPy(Bucket):
- _to_key = _to_key
- _to_value = _to_value
- MERGE = MERGE
- MERGE_WEIGHT = MERGE_WEIGHT_numeric
- MERGE_DEFAULT = MERGE_DEFAULT_float
-
-
- class LFSetPy(Set):
- _to_key = _to_key
- MERGE = MERGE
- MERGE_WEIGHT = MERGE_WEIGHT_numeric
- MERGE_DEFAULT = MERGE_DEFAULT_float
-
-
- class LFBTreePy(BTree):
- max_leaf_size = _BUCKET_SIZE
- max_internal_size = _TREE_SIZE
- _to_key = _to_key
- _to_value = _to_value
- MERGE = MERGE
- MERGE_WEIGHT = MERGE_WEIGHT_numeric
- MERGE_DEFAULT = MERGE_DEFAULT_float
-
-
- class LFTreeSetPy(TreeSet):
- max_leaf_size = _BUCKET_SIZE
- max_internal_size = _TREE_SIZE
- _to_key = _to_key
- MERGE = MERGE
- MERGE_WEIGHT = MERGE_WEIGHT_numeric
- MERGE_DEFAULT = MERGE_DEFAULT_float
-
-
- class LFTreeIteratorPy(_TreeIterator):
- pass
-
-
- # Can't declare forward refs, so fix up afterwards:
-
- LFBucketPy._mapping_type = LFBucketPy._bucket_type = LFBucketPy
- LFBucketPy._set_type = LFSetPy
-
- LFSetPy._mapping_type = LFBucketPy
- LFSetPy._set_type = LFSetPy._bucket_type = LFSetPy
-
- LFBTreePy._mapping_type = LFBTreePy._bucket_type = LFBucketPy
- LFBTreePy._set_type = LFSetPy
-
- LFTreeSetPy._mapping_type = LFBucketPy
- LFTreeSetPy._set_type = LFTreeSetPy._bucket_type = LFSetPy
-
-
- differencePy = _set_operation(_difference, LFSetPy)
- unionPy = _set_operation(_union, LFSetPy)
- intersectionPy = _set_operation(_intersection, LFSetPy)
- multiunionPy = _set_operation(_multiunion, LFSetPy)
- weightedUnionPy = _set_operation(_weightedUnion, LFSetPy)
- weightedIntersectionPy = _set_operation(_weightedIntersection, LFSetPy)
-
- import_c_extension(globals())
-
- _fix_pickle(globals(), __name__)
-
- moduleProvides(IIntegerFloatBTreeModule)
|