There are two Cython files: cgbinder.pxd describing the C++ API of the libgbinder library, and gbinder.pyx describing classes that will be visible from Python user code.
The .pyx imports .pxd to learn about C functions available to be called.
There is also setup.py file.
This file describes how to build the extension module, using distutils.
In there, we specify the library to link with as libraries=['gbinder']. The gbinder stands for libgbinder.so that we previously installed.
There are two options to build the package:
One, use Cython’s cythonize() function to generate a .c file from the .pyx one, and then compile it against the libgbinder.so library.
Two, if the .c is already provided, just compile it - no Cython required!
Development build
For development, use option 1 by providing --cython flag:
python setup.py build_ext --inplace --cython
The result will be a .so shared library named like gbinder.cpython-38-x86_64-linux-gnu.so.
build_ext means we’re building a C++ extension. --inplace means to put it in the current directory.
If you run python from current directory, you’ll be able to import gbinder.
Distribute
To distribute, call sdist with --cython flag to create source distribution (unbuilt):
python setup.py sdist --cython
The result will be a dist/ directory with a distribution named like gbinder-python-*.tar.gz inside.
The archive contains setup.py and gbinder.c, so users can build and install it without having Cython!
To publish to PyPI, run:
twine upload -r pypi dist/*
Install
To install, locate the .tar.gz distribution and run:
Cython extension module for
gbinder
Prerequisites
For development, you will also need Cython:
Description
There are two Cython files:
cgbinder.pxd
describing the C++ API of thelibgbinder
library, andgbinder.pyx
describing classes that will be visible from Python user code. The.pyx
imports.pxd
to learn about C functions available to be called.There is also
setup.py
file. This file describes how to build the extension module, usingdistutils
. In there, we specify the library to link with aslibraries=['gbinder']
. Thegbinder
stands forlibgbinder.so
that we previously installed.There are two options to build the package:
cythonize()
function to generate a.c
file from the.pyx
one, and then compile it against thelibgbinder.so
library..c
is already provided, just compile it - no Cython required!Development build
For development, use option 1 by providing
--cython
flag:The result will be a
.so
shared library named likegbinder.cpython-38-x86_64-linux-gnu.so
.build_ext
means we’re building a C++ extension.--inplace
means to put it in the current directory. If you runpython
from current directory, you’ll be able toimport gbinder
.Distribute
To distribute, call
sdist
with--cython
flag to create source distribution (unbuilt):The result will be a
dist/
directory with a distribution named likegbinder-python-*.tar.gz
inside. The archive containssetup.py
andgbinder.c
, so users can build and install it without having Cython!To publish to PyPI, run:
Install
To install, locate the
.tar.gz
distribution and run:Readme and setup.py is based on
geographiclib-cython-bindings
repo thanks to @megaserg