Crafter.Build/README.md
2024-12-28 22:13:21 +01:00

1.6 KiB

About

This is a simple and easy to use C++ build system for Linux, it uses JSON based project files.

Install

Prerequisites:

clang 18>
git

Clone and build:

git clone https://github.com/The-Mighty-Cat/Crafter.Build.git
cd Crafter.Build
./build.sh

(optionally add to path)

How to use

Quickstart

create a project.json in an empty folder, open it in your preffered text editor. Create a basic project file, with a base configuration and debug and release configuration

{
    "name": "hello-world",
    "configurations": [
        {
            "name": "base",
            "standard": "c++26",
            "source_files": ["main"],
            "module_files": [],
            "build_dir": "./build",
            "output_dir": "./bin"
        },
        {
            "name": "debug",
            "extends": ["base"],
            "optimization_level": "0"
        }
        {
            "name": "release",
            "extends": ["base"],
            "optimization_level": "3"
        }
    ]
}

Save and close the file, create a main.cpp

#include <print>
int main() {
  std::println("Hello World!");
}

Save and close, then run crafter-build debug. Now you can run the hello-world executable that has appeared in the build folder

CLI arguments

crafter-build <configuration>

builds the project with the specified configuration, using the defualt project filename project.json

crafter-build <configuration> <filename> 

builds the project with the specified configuration, using the specified project filename

crafter-build --help

displays this help message