Change Log ========== New in version 2.2.0 (unreleased) --------------------------------- * Use ``setup.cfg`` metadata instead ``setup.py`` config to generate package. * Add ``default_noreply`` parameter to ``HashClient``. * Handle unicode key values in ``MockMemcacheClient`` correctly. New in version 2.1.1 -------------------- * Fix ``setup.py`` dependency on six already being installed. New in version 2.1.0 -------------------- * Public classes and exceptions can now be imported from the top-level ``pymemcache`` package (e.g. ``pymemcache.Client``). `#197 `_ * Add UNIX domain socket support and document server connection options. `#206 `_ * Add support for the ``cache_memlimit`` command. `#211 `_ * Commands key are now always sent in their original order. `#209 `_ New in version 2.0.0 -------------------- * Change set_many and set_multi api return value. `#179 `_ * Fix support for newbytes from python-future. `#187 `_ * Add support for Python 3.7, and drop support for Python 3.3 * Properly batch Client.set_many() call. `#182 `_ * Improve _check_key() and _store_cmd() performance. `#183 `_ * Properly batch Client.delete_many() call. `#184 `_ * Add option to explicitly set pickle version used by serde. `#190 `_ New in version 1.4.4 -------------------- * pypy3 to travis test matrix * full benchmarks in test * fix flake8 issues * Have mockmemcacheclient support non-ascii strings * Switch from using pickle format 0 to the highest available version. See `#156 `_ *Warning*: different versions of python have different highest pickle versions: https://docs.python.org/3/library/pickle.html New in version 1.4.3 -------------------- * Documentation improvements * Fixed cachedump stats command, see `#103 `_ * Honor default_value in HashClient New in version 1.4.2 -------------------- * Drop support for python 2.6, see `#109 `_ New in version 1.4.1 -------------------- * Python 3 serializations fixes `#131 `_ * Drop support for pypy3 * Comment cleanup * Add gets_many to hash_client * Better checking for illegal chars in key New in version 1.4.0 -------------------- * Unicode keys support. It is now possible to pass the flag `allow_unicode_keys` when creating the clients, thanks @jogo! * Fixed a bug where PooledClient wasn't following `default_noreply` arg set on init, thanks @kols! * Improved documentation New in version 1.3.8 -------------------- * use cpickle instead of pickle when possible (python2) New in version 1.3.7 -------------------- * default parameter on get(key, default=0) * fixed docs to autogenerate themselves with sphinx * fix linter to work with python3 * improve error message on illegal Input for the key * refactor stat parsing * fix MockMemcacheClient * fix unicode char in middle of key bug New in version 1.3.6 -------------------- * Fix flake8 and cleanup tox building * Fix security vulnerability by sanitizing key input New in version 1.3.5 -------------------- * Bug fix for HashClient when retries is set to zero. * Adding the VERSION command to the clients. New in version 1.3.4 -------------------- * Bug fix for the HashClient that corrects behavior when there are no working servers. New in version 1.3.3 -------------------- * Adding caching to the Travis build. * A bug fix for pluggable hashing in HashClient. * Adding a default_noreply argument to the Client ctor. New in version 1.3.2 -------------------- * Making the location of Memcache Exceptions backwards compatible. New in version 1.3.0 -------------------- * Python 3 Support * Introduced HashClient that uses consistent hasing for allocating keys across many memcached nodes. It also can detect servers going down and rebalance keys across the available nodes. * Retry sock.recv() when it raises EINTR New in version 1.2.9 -------------------- * Introduced PooledClient a thread-safe pool of clients