A lightweight, minimal python package that ships magic libraries
using automake, CMake, scikit-build, and cibuildwheel.
If you use python-magic, you typically get an error like this
>>> import magic
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/Users/kratsg/.pyenv/versions/venv/lib/python3.7/site-packages/magic/__init__.py", line 209, in <module>
libmagic = loader.load_lib()
File "/Users/kratsg/.pyenv/versions/venv/lib/python3.7/site-packages/magic/loader.py", line 49, in load_lib
raise ImportError('failed to find libmagic. Check your installation')
ImportError: failed to find libmagic. Check your installationwhich is frustrating because they don’t ship shared lib with their
python distribution. pylibmagic helps fill in the missing gap by
shipping the required magic library and adding it to your path, so
you can just do:
>>> import pylibmagic
>>> import magicand be on your way. pylibmagic is designed to be very minimal and
lightweight.
$ docker run -it --rm -v $PWD:/home/root -w /home/root ubuntu
# apt install cmake autoconf automake libtool build-essential git python3-dev python3-pip
# cmake -S . -B build
# cmake --build build$ python3 -m pip install pylibmagicand the libraries are installed at
$ python -c "import pylibmagic; print(pylibmagic.data)"To release, due to concurrency issues, we need to push the tag after Cirrus CI finishes with the building for pushing to the main branch. So the order is typically:
tbump 0.5.0 --no-tag-push
# wait until Cirrus CI finishes
git push origin v0.5.0
# wait until Cirrus CI finishes
gh release createSee [cirruslabs/cirrus-ci-docs#1167](cirruslabs/cirrus-ci-docs#1167) for more details.