Skip to main content

Scalable persistent object containers

Project description

BTrees: scalable persistent components

This package contains a set of persistent object containers built around a modified BTree data structure. The trees are optimized for use inside ZODB’s “optimistic concurrency” paradigm, and include explicit resolution of conflicts detected by that mechannism.

Please see the Sphinx documentation (docs/index.rst) for further information.

BTrees Changelog

4.2.0 (2015-11-13)

  • Python 3.5 support.

4.1.4 (2015-06-02)

  • Ensure that pure-Python Bucket and Set objects have a human readable __repr__ like the C versions.

4.1.3 (2015-05-19)

4.1.2 (2015-04-07)

4.1.1 (2014-12-27)

  • Accomodate long values in pure-Python OLBTrees.

4.1.0 (2014-12-26)

  • Add support for PyPy and PyPy3.

  • Add support for Python 3.4.

  • BTree subclasses can define max_leaf_size or max_internal_size to control maximum sizes for Bucket/Set and BTree/TreeSet nodes.

  • Detect integer overflow on 32-bit machines correctly under Python 3.

  • Update pure-Python and C trees / sets to accept explicit None to indicate max / min value for minKey, maxKey. (PR #3)

  • Update pure-Python trees / sets to accept explicit None to indicate open ranges for keys, values, items. (PR #3)

4.0.8 (2013-05-25)

  • Fix value-based comparison for objects under Py3k: addresses invalid merges of [OLI]OBTrees/OBuckets.

  • Ensure that pure-Python implementation of OOBTree.byValue matches semantics (reversed-sort) of C implementation.

4.0.7 (2013-05-22)

  • Issue #2: compilation error on 32-bit mode of OS/X.

  • Test PURE_PYTHON environment variable support: if set, the C extensions will not be built, imported, or tested.

4.0.6 (2013-05-14)

  • Changed the ZODB extra to require only the real ZODB package, rather than the ZODB3 metapackage: depending on the version used, the metapackage could pull in stale versions of this package and persistent.

  • Fixed Python version check in setup.py.

4.0.5 (2013-01-15)

  • Fit the repr of bucket objects, which could contain garbage characters.

4.0.4 (2013-01-12)

  • Emulate the (private) iterators used by the C extension modules from pure Python. This change is “cosmetic” only: it prevents the ZCML zope.app.security:permission.zcml from failing. The emulated classes are not functional, and should be considered implementation details.

  • Accomodate buildout to the fact that we no longer bundle a copy of ‘persistent.h’.

  • Fix test failures on Windows: no longer rely on overflows from sys.maxint.

4.0.3 (2013-01-04)

  • Added setup_requires==['persistent'].

4.0.2 (2013-01-03)

  • Updated Trove classifiers.

  • Added explicit support for Python 3.2, Python 3.3, and PyPy. Note that the C extensions are not (yet) available on PyPy.

  • Python reference implementations now tested separately from the C verions on all platforms.

  • 100% unit test coverage.

4.0.1 (2012-10-21)

  • Provide local fallback for persistent C header inclusion if the persistent distribution isn’t installed. This makes the winbot happy.

4.0.0 (2012-10-20)

Platform Changes

  • Dropped support for Python < 2.6.

  • Factored BTrees as a separate distribution.

Testing Changes

  • All covered platforms tested under tox.

  • Added support for continuous integration using tox and jenkins.

  • Added setup.py dev alias (installs nose and coverage).

  • Dropped dependency on zope.testing / zope.testrunner: tests now run with setup.py test.

Documentation Changes

  • Added API reference, generated via Spinx’ autodoc.

  • Added Sphinx documentation based on ZODB Guide (snippets are exercised via ‘tox’).

  • Added setup.py docs alias (installs Sphinx and repoze.sphinx.autointerface).

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

BTrees-4.2.0.tar.gz (209.1 kB view hashes)

Uploaded Source

Built Distributions

BTrees-4.2.0.win-amd64-py3.3.exe (718.5 kB view hashes)

Uploaded Source

BTrees-4.2.0.win-amd64-py3.2.exe (717.3 kB view hashes)

Uploaded Source

BTrees-4.2.0.win-amd64-py2.7.exe (717.5 kB view hashes)

Uploaded Source

BTrees-4.2.0.win-amd64-py2.6.exe (716.9 kB view hashes)

Uploaded Source

BTrees-4.2.0.win32-py3.3.exe (633.5 kB view hashes)

Uploaded Source

BTrees-4.2.0.win32-py3.2.exe (632.8 kB view hashes)

Uploaded Source

BTrees-4.2.0.win32-py2.7.exe (633.2 kB view hashes)

Uploaded Source

BTrees-4.2.0.win32-py2.6.exe (632.5 kB view hashes)

Uploaded Source

BTrees-4.2.0-py3.3-win-amd64.egg (654.6 kB view hashes)

Uploaded Source

BTrees-4.2.0-py3.3-win32.egg (600.5 kB view hashes)

Uploaded Source

BTrees-4.2.0-py3.2-win-amd64.egg (635.8 kB view hashes)

Uploaded Source

BTrees-4.2.0-py3.2-win32.egg (579.1 kB view hashes)

Uploaded Source

BTrees-4.2.0-py2.7-win-amd64.egg (631.5 kB view hashes)

Uploaded Source

BTrees-4.2.0-py2.7-win32.egg (574.6 kB view hashes)

Uploaded Source

BTrees-4.2.0-py2.6-win-amd64.egg (631.5 kB view hashes)

Uploaded Source

BTrees-4.2.0-py2.6-win32.egg (574.5 kB view hashes)

Uploaded Source

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