Go to file
cursey 61d5e64d87
Fix parser expecting to always find templates
3 years ago
.github Add script to automatically bump the version 3 years ago
cmake Bump to 0.2.5 3 years ago
docs Add root, x64 and x32 conditions 3 years ago
include Add support for target templates 3 years ago
src Fix parser expecting to always find templates 3 years ago
tests Add support for target templates 3 years ago
third_party prelim vcpkg manifest support 4 years ago
.clang-format WIP DSL for generating cmake 4 years ago
.gitattributes Merge cmkrlib into the cmkr target 4 years ago
.gitignore Fix warnings on AppleClang 12 4 years ago
CMakeLists.txt Bump to 0.2.5 3 years ago
LICENSE Create LICENSE 4 years ago
README.md Improve onboarding experience 3 years ago
cmake.toml Bump to 0.2.5 3 years ago

README.md

cmkr

cmkr, pronounced "cmaker", is a modern build system based on CMake and TOML.

cmkr parses cmake.toml files and generates a modern, idiomatic CMakeLists.txt for you. A minimal example:

[project]
name = "cmkr_for_beginners"

[target.hello_world]
type = "executable"
sources = ["src/main.cpp"]

cmkr can bootstrap itself from CMake and you only need CMake to use it.

Getting started

To get started run the following commands from your project directory:

curl https://raw.githubusercontent.com/build-cpp/cmkr/main/cmake/cmkr.cmake -o cmkr.cmake
cmake -P cmkr.cmake

After the bootstrapping process finishes, modify cmake.toml and open the project in your favorite IDE or build with CMake:

cmake -B build
cmake --build build

Once bootstrapped, cmkr does not introduce extra steps to your workflow. After modifying cmake.toml you simply build/configure your CMake project and cmkr will automatically regenerate CMakeLists.txt.

In CI settings the cmkr bootstrapping process is skipped so there is no extra configure-time overhead in your pipelines.

Template repositories

Another way to get started is to use the cmkr_for_beginners template repository. Either open it in Gitpod, or clone the repository and run:

cmake -B build
cmake --build build

Check out the cmkr topic, the build-cpp organization or the tests for more examples and templates.

Command line

Optionally you can put a cmkr release in your PATH and use it as a utility from the command line:

Usage: cmkr [arguments]
arguments:
    init    [executable|library|shared|static|interface] Starts a new project in the same directory.
    gen                                                  Generates CMakeLists.txt file.
    build   <extra cmake args>                           Run cmake and build.
    install                                              Run cmake --install. Needs admin privileges.
    clean                                                Clean the build directory.
    help                                                 Show help.
    version                                              Current cmkr version.

Credits