library to control placement in a hierarchy
Project description
crush
crush is a library to control placement in a hierarchy
Home page : http://http://libcrush.org/main/python-crush
Documentation : http://crush.readthedocs.org/
GNU/Linux Installation
pip install crush
Other Installation
When using pip versions lower than 8.1 or other operating systems, compilation is necessary and packages must be installed first.
apt-get install -y gcc g++ python-pip python-all-dev libpython3-all-dev cmake libboost-all-dev libatomic-ops-dev
dnf / yum / zypper install -y gcc gcc-c++ python-pip python-devel python3-devel cmake boost-devel libatomic_ops-devel
pip install crush
Hacking
Get the code:
git clone --recursive http://libcrush.org/main/python-crush.git
Set up the development environment:
deactivate || true ; source bootstrap
Run the tests:
deactivate || true ; bash run-tests.sh
Sync the libcrush submodule:
git submodule update --remote libcrush
Run a single test:
tox -e py27 -- -s -k test_one tests/test_crush.py
Check the documentation:
python setup.py build_sphinx firefox build/html/index.html
Update requirements
rm -fr virtualenv virtualenv virtualenv source virtualenv/bin/activate # update some module in requirements.txt tox # if that works pip install -r requirements.txt pip freeze -r requirements.txt > new-requirements.txt .tox/py3/bin/pip freeze -r requirements-dev.txt > new-requirements-dev.txt diff <(.tox/py27/bin/pip freeze -r requirements-dev.txt) new-requirements-dev.txt # all lines after the first “were added by pip freeze” are indirect dependencies remove pkg-resources==0.0.0 https://bugs.launchpad.net/ubuntu/+source/python-pip/+bug/1635463
Release management
Prepare a new version
version=1.0.0 ; perl -pi -e “s/^version.*/version = $version/” setup.cfg ; for i in 1 2 ; do python setup.py sdist ; amend=$(git log -1 –oneline | grep –quiet “version $version” && echo –amend) ; git commit $amend -m “version $version” ChangeLog setup.cfg ; git tag -a -f -m “version $version” $version ; done
Publish a new version
docker build –tag manylinux manylinux
docker run –rm -v $(pwd):/io manylinux /io/manylinux/build-wheels.sh OR docker run –rm -v $(pwd):/io manylinux env PYBINS=/opt/python/cp27-cp27mu/bin /io/manylinux/build-wheels.sh
sudo chown -R $(id -u) wheelhouse/
twine upload –sign wheelhouse/crush
rm -fr dist
python setup.py sdist
twine upload –sign dist/*.tar.gz
git push ; git push –tags
pypi maintenance
trim old versions at https://pypi.python.org/pypi/crush
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Hashes for crush-1.0.20-cp36-cp36m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 63383cbc952a747c67c143e93869f0ebb7d5511b27bd9f93ec05c9971bc20f47 |
|
MD5 | 272db6b3da2730ec1648fb178bd152db |
|
BLAKE2b-256 | 32ad8d3dc1935d6b6d8cd095f7a2d472538ab2d96ea2b0b6b9d0234ac3b6ea6f |
Hashes for crush-1.0.20-cp35-cp35m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ee9f3c36bd15282605a5ca65abd05d9dbd97628d06fbcf45199197af7a8ad82a |
|
MD5 | a3c7a16f28b19da0d01018fedb6bc32b |
|
BLAKE2b-256 | d27868c7a5ae1bb90179fe5c9181e5a9a22e04943a4738265b4f4b9895b39ee0 |
Hashes for crush-1.0.20-cp34-cp34m-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 03c82ddea5266c49dccc7ee9700f188b44ea375582d8776459d301ecefe6528b |
|
MD5 | 5d69da326797d1c1123c8c6d7e894fee |
|
BLAKE2b-256 | c3480cbf56f7439937b530fd4a4fa3967d2699448036dcd33ec2d167a80b689e |
Hashes for crush-1.0.20-cp27-cp27mu-manylinux1_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e8d83fa90b9d783e45259681c5ee9ab98679890187b7af8e6cbe8ac7dbd56369 |
|
MD5 | 440cb2d46212343c53e28b984421e277 |
|
BLAKE2b-256 | d8d4582227cd4ba20d8d9174f9f94589b07d42ffab1d84506b7df15d44fd8810 |