Skip to main content
Python Software Foundation 20th Year Anniversary Fundraiser  Donate today!

Get a project running quickly

Project description


.. image::
:alt: PyPi Status

.. image::
:alt: PyPi Version

.. image::
:alt: Python Versions

.. image::
:alt: Build Status

.. image::
:alt: Test Coverage

.. image::
:alt: Code Health

Have you ever had this moment when you wanted to write a small tool or just try
out some new algorithm but the thought of assembling proper project folder
structure spoiled the desire...

CRUTCH is a console development environment, though its definition sounds a bit
weird it does allow you to create a fully customized project, manage its
lifecycle, including `configure`, `build`, `test`, `clean` `add/remove
files/features/tests`, plus language specific features. Also you can extend its
functionality by writing a language module or a feature for already existing

.. contents::


>From pip::

$ pip install crutch


In its simplest form you interact with CRUTCH via two commands::

$ crutch new <type>
$ crutch

Those two lines create a project and `build`, `test`, `run` or whatever default
action is configured for this type of project... that is all you need to get
things going. The default project configuration supposed to provide you with
things necessary to just start writing stuff, but if you need more you can add
features to your projects.


Feature is something that extends CRUTCH capabilities and specifically adds
functionality to your projects's runner. CRUTCH itself has only one feature,
which is called `new`, that all it does: *create a new project*, and it will
stay this way forever. Additional functionality will be added via language
extensions and features for them.

>From user perspective feature is an action keyword that follows `crutch`
command, akin to `new`. For example compile-time projects normally will include
`build` feature, most projects will include `clean` and `test` features. Nice
features to have are: `install`, `publish`, `debug` etc.

Feature allows for a second cli parameters parsing, thus you can invoke an
action for a feature::

$ crutch test add core/runner

This line invokes `test` feature of the current project with `add` action that
allows you to add a test file in one go(assuming you are not wearing yours
smart ass hat and not trying to modify configuration files manually). The
symmetrical operation would be::

$ crutch test remove core/runner

This will remove the test files and do cleanup afterwards. Using `test` feature
to manage test files is WAY better than doing this manually...

So, how do you add features? One way is to stay with default provided features,
another is to specify a list of features with `new` action::

$ crutch new cpp -f xcode gtest

This line forces `cpp` extension to generate `xcode` build project using `cmake`
and add `gtest` based `test` feature.

What if you want to add a feature after you've already created a project? What
might be the way? Just guess... The `feature` feature of course::

$ crutch feature add doxygen

This line adds `doxygen` based `doc` feature to the project.

The last thing... a feature has a default action, normally it is associated
with its essence, invoking this::

$ crutch doxygen

Naturally will build documentation, and by invoking this::

$ crutch doc

You achieve the same, because `doxygen` feature belongs to `doc` feature

Feature Category

Feature categories is something that is not really reflected in CLI, but
nonetheless is very important concept. Every feature belongs to a category,
duh... This means that at the very least you can invoke an action on a feature
by providing its category name instead. This is very true for categories that
can have only `one` active feature at a time. BUT, if category can have
multiple active features it can modify or even add new actions you can invoke::

$ crutch lint

This `lint` category has several features: `pep8`, `pylint`, `flake8` etc. So
by invoking category's default action you run all those linter features one
after another to verify your code, alternatively you can run them separately::

$ crutch pep8
$ crutch pylint

This opens door for a very complex scenarios, like running custom test server
bench that is basically a tech-stack that needs to be managed. So you can
provide a custom category `bench` that contains multitude of optional features,
like `mysql`, `maria`, `couchbase`, `apache`, etc. And this category provides
few actions like `start`, `stop`, `publish` etc that you can invoke to run all
this madness...Anyway this multi-category is a far feature, and I am writing
this here so I won't forget it later


In Progress::


In Future::



* PyPI_
* GitHub_
* `Travis CI`_
* Coveralls_

.. _PyPI:
.. _GitHub:
.. _`Travis CI`:
.. _`Coveralls`:

Project details

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Files for crutch, version 0.3.0
Filename, size File type Python version Upload date Hashes
Filename, size crutch-0.3.0-py2-none-any.whl (7.0 kB) File type Wheel Python version py2 Upload date Hashes View
Filename, size crutch-0.3.0.tar.gz (4.2 kB) File type Source Python version None Upload date Hashes View

Supported by

AWS AWS Cloud computing Datadog Datadog Monitoring DigiCert DigiCert EV certificate Facebook / Instagram Facebook / Instagram PSF Sponsor Fastly Fastly CDN Google Google Object Storage and Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Salesforce Salesforce PSF Sponsor Sentry Sentry Error logging StatusPage StatusPage Status page