You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Go to file
Duncan Ogilvie 7cdf36f317
Initial support for conditional arguments
3 years ago
.github/workflows Initial attempt at adding tests 3 years ago
cmake Make cmkr bootstrapper more robust 3 years ago
include 0.1.4 3 years ago
src Initial support for conditional arguments 3 years ago
tests Initial support for conditional arguments 3 years ago
third_party Preserve ordering and switch target syntax to use tables 3 years ago
.clang-format WIP DSL for generating cmake 3 years ago
.gitignore Fix warnings on AppleClang 12 3 years ago
CHANGELOG.md 0.1.4 3 years ago
CMakeLists.txt Initial support for conditional arguments 3 years ago
LICENSE Create LICENSE 4 years ago
README.md Initial support for conditional arguments 3 years ago
cmake.toml Merge remote-tracking branch 'origin/master' into develop 3 years ago

README.md

cmkr

cmkr, pronounced "cmaker", is A CMakeLists.txt generator from TOML.

See the cmkr topic for examples. Feel free to add the cmkr topic to your projects if you used cmkr!

Building

cmkr requires a C++11 compiler, cmake >= 3.15.

git clone https://github.com/moalyousef/cmkr
cd cmkr
cmake -Bbin
cmake --build bin --parallel

Usage

cmkr parses cmake.toml files (using toml11 by Toru Niina) at the project directory. A basic hello world format with the minimum required fields:

[cmake]
minimum = "3.15"

[project]
name = "app"
version = "0.1.0"

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

NOTE: The documentation is currently a work-in-progress due to breaking changes since 0.1.4. For examples you can check the cmkr topic.

The cmkr executable can be run 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.

The build command invokes cmake and the default build-system on your platform (unless a generator is specified), it also accepts extra cmake build arguments:

cmkr build --config Release 

Binary types

executable

Executable binary. Equivalent to add_executable(name).

library

Library, can be static or shared depending on the BUILD_SHARED_LIBS variable. Equivalent to add_library().

static

Static library/archive. Equivalent to add_library(name STATIC).

shared

Shared/dynamic library. Equivalent to add_library(name SHARED).

interface

Header-only library. Equivalent to add_library(name INTERFACE).

Roadmap

  • Support more cmake fields.