Skip to main content

Awesome build manager to replace Makefiles. It allows very fast building!

Project description

AwesomeBuild

Philosophy

Like a Makefile Awesomebuild is structured in rules. Each rule may depend on other rules and may include so called triggers which are used to check whether the rule needs to run.

Usage

usage: AwesomeBuild [-h] [--config CONFIG] [targets [targets ...]]

Awesome build manager to replace Makefiles. It allows very fast building!

positional arguments:
  targets          defaults to the main rule defined in the config file

optional arguments:
  -h, --help       show this help message and exit
  --config CONFIG  default: awesomebuild.json
  --status STATUS  Relative to project folder, default: awesomestatus.json

Configuration

First of you need to create a configuration file in your projects man directory called awesomebuild.json.

{
  "project": "TestProject",
  "import": {
    "rules": []
  },
  "main": "mainrule",
  "rules": {}
}

Empty fields can be omitted.

Field overview:

project: project name

ìmport: Here you can define whixh external configuration files you want to import. The currently only known import type is rules.

main: This defines which rule to run if no targets were defined by the user. This rule may be defined in an external configuration file.

rules: Here you can define rules.

Rule Definition

"rule-name": {
  "cmd": [
    "cmd1",
    "cmd2"
  ],
  "call":[
    "other-rule-1",
    "other-rule-2"
  ],
  "callBefore": [
    "other-rule-3",
    "other-rule-4"
  ],
  "callAfter":"other-rule-5",
  "trigger": [],
}

All fields may be omitted, provided as single value or list. "field": "hello world" is the same as "field": ["hello world"] and "field": [] is the same as omitting field.

cmd: This field handles shell commands to execute. All commands run in the main project directory.

call: This field handles other rules which are needed to run.

callBefore: This field handles all rules that need to run before.

callAfter: This field handles all rules that need to run after. There is a little difference to call. Check Rule Execution

trigger: This field handles the rule´s triggers.

Trigger Definition

{
  "type": "trigger type",
  "subtype": "trigger sub type",
  "value": "value for trigger"
}

Currently known triggers are:

type subtype value usage
file changed path to file
file exist path to file
file not exist path to file
directory changed path to directory
directory exist path to directory
directory not exist path to directory

Import Rules

{
  "rules": "name",
  "type": "importtype",
  "value": "path"
}

Field overview:

rules: This can either be the name of a single rule "rules": "rulename", a list of rules "rules": ["rule-1", "rule-2"] or a wildcard "rules": "*" to import all rules found.

type: This defines whether a single file or a whole directory (recursively) is imported.

value: This defines the path to the file or directory.

Rule Execution

  1. If callBefore-rules are defined, these rules will run now. If any of these were executed now the run variable will be set. Check Status Field rules-callBefore
  2. If triggers are defined, these will be checked now. If any of these triggers was positive or no triggers were defined, the run variable will be set
  3. If the run variable is set, the cmds will run now.
  4. If the run variable is set, the call-rules will run now.
  5. If callAfter-rules are defined, these rules will run now.

In-depth information

Status File

To allow fast builds (skipping build steps) it is needed to save some information about the last known as build state of the source and build files. Therefore AwesomeBuild saves many hashes which are checked upon rule execution. If there is a hash mismatch AwesomeBuild triggers a rebuild. All information is saved in the file awesomestatus.json. Most of its content are SHA512 hashes to prevent easy manipulation.

Status Field awesomestatusversion

From time to time the structure of the status file will chenge. Therefore the version of the file is saved as an integer. Upon loading AwesomeBuild will check the version and update the status file as needed.

Status Field configstatus

When the configuration is changed AwesomeBuild will trigger a rebuild. To check for configuration changes it generates a SHA512 hash of the complete configuration. If AwesomeBuild detects a hash mismatch it clears the rules, rules-callBefore and triggers fields of the status file.

Status Field rules

After a rule was executed AwesomeBuild saves a SHA512 hash of the string of python´s time.time() function.

Status Field rules-callBefore

Each rule must know whether its callBefore rules were executed. This is checked by creating a SHA512 hash over the combined string of all affected rules´ time hash. By using this approach we can just run all callBefore rules without caring whether they really run cause we need to check for rules that were executed before anyway.

Status Field triggers

Each trigger may need to save its status information. Check Trigger_

Trigger

(Not) Exist Triggers

The technique of checking whether a file/directory exists should be quite clear ;-)

Changed Triggers

The most efficient way to check for file/directory changed would be to use inotify. Therefore we would need to have a script running all the time. This might be implemented in a later version.

File Changed Trigger

To check whether a file was changed AwesomeBuild generated a SH512 hash over the files content.

directory Changed Trigger

directories can be quite large in both count and size of files. Generating a checksum over all file contents would be very inefficient. Therefore AwesomeBuild generates a checksum over as much as possible meta data. It generates a SHA512 hash over the output of ls -RlgAGi --time-style=+%s PATH. This way it should be quite safe to trigger a rebuild upon file changes. If you have a better solution feel fre to open an issue/PR :)

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

AwesomeBuild-2.1.1.tar.gz (6.7 kB view hashes)

Uploaded Source

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