Initially Buildcloth was a meta-build tool: by writing python code you could assemble a Makefile that you could use to orchestrate a build process. However, for some classes of builds, it may be more efficient use buildc, which implements a subset of Make features use pure Python and avoids some of the overhead associated with Make-based build processes.
This tutorial describes the schema for buildc definitions and provides a high level introduction to running a build using the buildc tool.
There two fundamental kinds of build definitions in build systems, to define different kinds of tasks, and several variations that build on these types.
The smallest unit of work defined in a build system is a job.
These objects define work units that call Python functions. Consider the following prototype document in both YAML and JSON notation:
{
  "job": <func>,
  "args": [ <arg,> <arg> ],
  "stage": <name>
}
job: <func>
args: [ <arg,> <arg> ]
stage: <name>
---
These jobs name:
These objects define work units that run arbitrary process using Python’s subprocess module. Consider the following prototype document in both YAML and JSON notation:
{
  "dir": <path>,
  "cmd: <program>,
  "args": [ <arg,> <arg> ],
  "stage": <name>
}
dir: <path>
cmd: <program>
args: [ <arg,> <arg> ]
stage: <name>
---
These jobs name:
In both shell and python jobs, you may specify dependencies and targets. In job specifications rather than stages to allow buildcloth to order tasks based on the relationships of the dependency graph. Consider the following python and shell jobs with dependency information:
{
  "dir": <path>,
  "cmd: <program>,
  "args": [ <arg,> <arg> ],
  "target": <product>,
  "dependency": <product>
}
dir: <path>
cmd: <program>
args: [ <arg,> <arg> ]
target: <product>
dependency: <product>
---
{
  "job": <func>,
  "args": [ <arg,> <arg> ],
  "target": <product>,
  "dependency": <product>
}
job: <func>
args: [ <arg,> <arg> ]
target: <product>
dependency: <product>
---
Most buildcloth job statements specify single tasks. Buildcloth also supports job compound job statements that specify an ordered list of tasks for a single target. These sequences can combine Python and shell jobs, and have the following form:
tasks:
  - job: <name>
    args: [ <arg>, <arg> ]
  - dir: <path>
    cmd: <program>
    args: [ <arg>, <arg> ]
stage: <name>
---
{
  "tasks" :  [
    {
      "job": <name>,
      "args": [ <arg,> <arg> ],
    },
    {
      "dir": <path>,
      "cmd: <program>,
      "args": <name>
    }
  ]
  "stage": <name>
}
The components of a fully specified buildc-based build system are:
The final argument to buildc is an optional list of stages that you want to build. This is: