Skip to main content

A task-centric build system with simple declarative recipes specified in Python

Project description

🧑‍🍳 Cook

Cook is a task-centric build system with simple declarative recipes specified in Python.

Getting Started

Tasks are declared in a recipe.py file using the cook.manager.create_task function. Each task must have a unique name, may depend on files or other tasks, and can execute an action, typically a shell command. The simple example below creates a C source file, compiles it, and executes the binary.

>>> from cook import create_task

>>> create_task("src", targets=["hello.c"],
...             action="echo 'int main() { return 0; }' > hello.c")
>>> create_task("cc", dependencies=["hello.c"], targets=["hello"],
...             action="cc -o hello hello.c")
>>> create_task("hello", dependencies=["hello"], action="./hello")

Running cook ls from the command line lists all known tasks, e.g.,

$ cook ls
<task `src` @ /.../recipe.py:3>
<task `cc` @ /.../recipe.py:6>
<task `hello` @ /.../recipe.py:9>

Running cook exec hello creates the source file, compiles it, and executes the binary (using --log-level=debug can provide additional information).

$ cook exec hello
INFO: executing <task `src` @ /.../recipe.py:3> ...
INFO: completed <task `src` @ /.../recipe.py:3> in 0:00:...
INFO: executing <task `cc` @ /.../recipe.py:6> ...
INFO: completed <task `cc` @ /.../recipe.py:6> in 0:00:...
INFO: executing <task `hello` @ /.../recipe.py:9> ...
INFO: completed <task `hello` @ /.../recipe.py:9> in 0:00:...

To rerun a task, tell Cook to reset it.

$ cook reset cc
INFO: reset 1 task

The full set of available commands can be explored using cook --help as shown below.

$ cook --help
usage: cook [-h] [--recipe RECIPE] [--module MODULE] [--db DB]
            [--log-level {warning,error,info,debug}]
            {exec,ls,info,reset} ...

positional arguments:
  {exec,ls,info,reset}
    exec                Execute one or more tasks.
    ls                  List tasks.
    info                Display information about one or more tasks.
    reset               Reset the status of one or more tasks.

options:
  -h, --help            show this help message and exit
  --recipe RECIPE       file containing declarative recipe for tasks
  --module, -m MODULE   module containing declarative recipe for tasks
  --db DB               database for keeping track of assets
  --log-level {warning,error,info,debug}
                        log level

Tasks Are Dumb; Contexts Are Smart

cook.task.Tasks do not provide any functionality beyond storing metadata, including

  • targets, the files generated by the task,
  • dependencies, the files the task depends on,
  • action, the cook.actions.Action to execute when the task is run,
  • task_dependencies, other tasks that should be executed first,
  • location, filename and line number where the task was defined.

All logic is handled by cook.contexts.Contexts which are applied to each task when it is created. For example, cook.contexts.create_group adds all tasks created within the context to a group. This group can be executed to execute all child tasks.

Project details


Download files

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

Source Distribution

cook_build-0.7.0.tar.gz (27.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

cook_build-0.7.0-py3-none-any.whl (21.6 kB view details)

Uploaded Python 3

File details

Details for the file cook_build-0.7.0.tar.gz.

File metadata

  • Download URL: cook_build-0.7.0.tar.gz
  • Upload date:
  • Size: 27.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cook_build-0.7.0.tar.gz
Algorithm Hash digest
SHA256 4bfc7125ebd57485c358e01837848fb250c9d43b5b6f404b77cd4ca76765604a
MD5 cf292b6c7df408bc09befe9c0d101820
BLAKE2b-256 86d75b5085335ce0270215444d5155e0fcece9c9282c3ca0ef8cb37a221f1dd5

See more details on using hashes here.

Provenance

The following attestation bundles were made for cook_build-0.7.0.tar.gz:

Publisher: main.yaml on tillahoffmann/cook-build

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file cook_build-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: cook_build-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 21.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for cook_build-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9ed38ac14bceacf56a6d7c49654776c1b45c1175a644c94cc0601d6920252439
MD5 bf895e6ee724495bae0b8c9e064246f7
BLAKE2b-256 f158a7c20e7979d83dffc66e416fe47e2eea288198a4bdf6bd49463af0a0a92a

See more details on using hashes here.

Provenance

The following attestation bundles were made for cook_build-0.7.0-py3-none-any.whl:

Publisher: main.yaml on tillahoffmann/cook-build

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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