Contributing ============ Generally, branch off from ``master``, implement stuff® and file a pull request back to ``master``. Feel free to do the latter at an early stage using the GitHub's "Submit Draft" feature. Versioning Philosophy: - ``master`` should always improve. Incomplete functionality is welcome. - API-breaking changes imply transition to a new major version - We use `Semantic Versioning `__ Code style is *black* for Python and *LLVM* for C++. To format your code, use - ``black .`` for Python. Make sure to use the correct version as specified in ``pyproject.toml``. It is automatically installed when installing the ``dev`` extras via ``pip install -e .[dev]``. Also, consider using the pre-commit hook (``pre-commit install``). - ``find . -regex '.*\.\(cxx\|h\)' -exec clang-format -style=file -i {} \;`` for C++ Testing ~~~~~~~ - For each new feature introduced, tests should be written, using the `pytest `__ framework - Running tests is easy---just execute ``pytest`` in the project directory - Additional pointers for running pytest: - Drop into a debugger on failing test using ``pytest --pdb`` - Show stdout with ``pytest -s`` - Run only specific tests by matching the test function name ``pytest -k `` - Be more verbose with ``pytest -v`` - Warning 1: Pytest may cause confusion as it automagically imports stuff and supplies functions with things they need based on their signature. For this, see e.g. the docs on `fixtures `__. - Warning 2: Warning 1 applies in particular to stuff hiding in innocent-looking files named ``conftest.py``. See docs on `conftest `__.