blob: caad51d439eebcec8df3a6b8bda6ecdbca8b9b58 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
|
# Introduction
Have you ever wondered, if you want to compile a C++ program, why you always
need to learn another language to make it build properly with dependency
tracking and so on.
Many good build-systems exists which all have their strengths and weeknesses
autotools, cmake, meson to name a few.
`ctor` tries to make it possible to use all the cool features of the above
in a tool only using C++ (through the compiler).
## Getting Started: 3 Simple Steps
Step 1: Create a build configuration, in C++
A really simple example ('hello_config.cc'):
```c++
#include "libctor.h"
namespace
{
BuildConfigurations helloConfigs()
{
return
{
{
.target = "hello",
.sources = {
"hello.cc",
},
.cxxflags = {
"-Wall",
"-std=c++17",
}
},
};
}
REG(helloConfigs);
}
```
Step 2: Bootstrap the system by compiling your build configuration along with
the libctor.a static library:
```sh
g++ -std=c++17 hello_config.cc -pthread libctor.a -o ctor
```
Step 3: Run ctor to build you application:
```sh
./ctor
```
Any consecutive changes to the build configuration or any of the sources will
automagically trigger a rebuild of all (and only) affected sources the next time
ctor is executed.
|