Skip to main content

A practical Python project skeleton generator.

Project description

https://img.shields.io/pypi/v/micc.svg https://img.shields.io/travis/etijskens/micc.svg Documentation Status

Micc is a Python project manager: it helps you organize your Python project from simple single file modules to fully fledged Python packages containing modules, sub-modules, apps and binary extension modules written in Fortran or C++. Micc organizes your project in a way that is considered good practice by a large part of the Python community.

  • Micc helps you create new projects. You can start small with a simple one-file package and add material as you go, such as:

    • Python sub-modules and sub-packages,

    • applications, also known as command line interfaces (CLIs).

    • binary extension modules written in C++ and Fortran. Boiler plate code is automatically added as to build these binary extension with having to go through al the details. This is, in fact, the foremost reason that got me started on this project: For High Performance Python it is essential to rewrite slow and time consuming parts of a Python script or module in a language that is made for High Performance Computing. As figuring out how that can be done, requires quite some effort, Micc was made to automate this part while maintaining the flexibility.

    • Micc adds typically files containing example code to show you how to add your own functionality.

  • You can automatically extract documentation from the doc-strings of your files, and build html documentation that you can consult in your browser, or a .pdf documentation file.

  • With a little extra effort the generated html documentation is automatically published to readthedocs.

  • Micc helps you with version management and control.

  • Micc helps you with testing your code.

  • Micc helps you with publishing your code to e.g. PyPI, so that you colleagues can use your code by simply running:

    > pip install your_nifty_package

Credits

Micc does not do all of this by itself. For many things it relies on other strong open source tools and it is therefor open source as well (MIT Licence). Here is a list of tools micc is using or cooperating with happily:

  • Pyenv: management of different Python versions.

  • Pipx for installation of CLIs in a system-wide way.

  • Poetry for dependency management, virtual environment management, packaging and publishing.

  • Git for version control.

  • CMake is usde for building binary extension modules written in C++.

The above tools are not dependencies of Micc and must be installed separately. Then there are a number of python packages on which micc depends and which are automatically installed when poetry creates a virtual environment for a project.

  • Cookiecutter for creating boilerplate code from templates for all the parts that can be added to your project.

  • Python-semanticversion for managing version strings and dependency version constraints according to the Semver 2.0 specification.

  • Pytest for testing your code.

  • Click for a pythonic and intuitive definition of command-line interfaces (CLIs).

  • Sphinx to extract documentation from your project’s doc-strings.

  • Sphinx-click for extracting documentation from the click command descriptions.

  • F2py for transforming modern Fortran code into performant binary extension modules interfacing nicely with Numpy.

  • Pybind11 as the glue between C++ source code and performant binary extension modules, also interfacing nicely with Numpy.

Roadmap

These features are still on our wish list:

  • Contininous integtration (CI)

  • Code style, e.g. flake8 or black

  • Profiling

  • Gui for debugging C++/Fortran binary extensions

  • Micc projects on Windows (So far, only support on Linux and MacOS).

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

et-micc-1.1.8.tar.gz (48.5 kB view details)

Uploaded Source

Built Distribution

et_micc-1.1.8-py3-none-any.whl (69.3 kB view details)

Uploaded Python 3

File details

Details for the file et-micc-1.1.8.tar.gz.

File metadata

  • Download URL: et-micc-1.1.8.tar.gz
  • Upload date:
  • Size: 48.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.5 CPython/3.8.5 Darwin/20.3.0

File hashes

Hashes for et-micc-1.1.8.tar.gz
Algorithm Hash digest
SHA256 37c7b2d666c7c8326db4503a5d541f105786207015107fa88410d2d34615ec99
MD5 2f189271023a48b569c14344d73e2a26
BLAKE2b-256 8cd3743f6ce072f133c6184d337e451084a4693c902bc1324a8f11d3d6bb24cd

See more details on using hashes here.

File details

Details for the file et_micc-1.1.8-py3-none-any.whl.

File metadata

  • Download URL: et_micc-1.1.8-py3-none-any.whl
  • Upload date:
  • Size: 69.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.5 CPython/3.8.5 Darwin/20.3.0

File hashes

Hashes for et_micc-1.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1893b7c9d0ddb16545f0b7b6b260aea0cbcf9fe5d7dbf210b5e8f4a3022eba76
MD5 f32acab86c96da2c07b0110415050671
BLAKE2b-256 30b5560cbd46b3c8ddaf009d2bd39dcfc11367b5db5c94b2e240ab8237bb4f91

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page