114 lines
3 KiB
Markdown
114 lines
3 KiB
Markdown
# Cutekit
|
|
|
|
Cutekit is a build system that aims to be simple, fast and easy to use.
|
|
A project is described using json files.
|
|
|
|
## Project file
|
|
|
|
The project file is used to describe the project and its dependencies.
|
|
|
|
See: [doc/spec/project.md](doc/spec/project.md) for the full specification.
|
|
|
|
Example:
|
|
|
|
> project.json
|
|
```json
|
|
{
|
|
"$schema": "https://schemas.cute.engineering/stable/cutekit.manifest.project.v1",
|
|
"id": "skift-org/skift",
|
|
"type": "project",
|
|
"description": "The Skift Operating System",
|
|
"extern": {
|
|
"cute-engineering/libheap": {
|
|
"git": "https://github.com/cute-engineering/libheap.git",
|
|
"tag": "v1.1.0"
|
|
}
|
|
}
|
|
}
|
|
```
|
|
|
|
Here we describe a project with the id `skift-org/skift` and a dependency to `cute-engineering/libheap` at version `v1.1.0`.
|
|
|
|
## An executable package manifest
|
|
|
|
|
|
When you want to create an executable package, you need to create a `manifest.json` file in any directory under `src/`.
|
|
This is the file that describe an executable with its dependencies.
|
|
|
|
> src/nyan-cat-app/manifest.json
|
|
```json
|
|
{
|
|
"$schema": "https://schemas.cute.engineering/stable/cutekit.manifest.component.v1",
|
|
"id": "nyan-cat-app",
|
|
"type": "exe",
|
|
"description": "rainbows everywhere",
|
|
"requires": [
|
|
"easy-lib"
|
|
]
|
|
}
|
|
```
|
|
|
|
Here we describe an executable with the id `nyan-cat-app` and a dependency to `easy-lib` (which is a library built by the project).
|
|
|
|
You can run the executable by running `$ ck run nyan-cat-app`.
|
|
|
|
## A library package manifest
|
|
|
|
When you want to create a library package, you need to create a `manifest.json` file in any directory under `src/`, like an executable package.
|
|
|
|
> src/easy-lib/manifest.json
|
|
```json
|
|
{
|
|
"$schema": "https://schemas.cute.engineering/stable/cutekit.manifest.component.v1",
|
|
"id": "easy-lib",
|
|
"type": "lib",
|
|
"description": "easy to use library",
|
|
"requires": [
|
|
"cute-engineering/libheap"
|
|
]
|
|
}
|
|
```
|
|
|
|
Here we describe a library with the id `easy-lib` and a dependency to `cute-engineering/libheap` (which is an external dependency described above in the `project.json`).
|
|
|
|
## Using installed libraries
|
|
|
|
You can create a specific installed library through the use of `pkg-config` files.
|
|
For example here is how you add `SDL2` to your project:
|
|
|
|
|
|
> src/extern/sdl2/manifest.json
|
|
```json
|
|
{
|
|
"$schema": "https://schemas.cute.engineering/stable/cutekit.manifest.component.v1",
|
|
"id": "sdl2",
|
|
"type": "lib",
|
|
"description": "A cross-platform development library designed to provide low level access to hardware",
|
|
"tools": {
|
|
"cc": {
|
|
"args": [
|
|
"@exec",
|
|
"pkg-config",
|
|
"--cflags",
|
|
"sdl2"
|
|
]
|
|
},
|
|
"cxx": {
|
|
"args": [
|
|
"@exec",
|
|
"pkg-config",
|
|
"--cflags",
|
|
"sdl2"
|
|
]
|
|
},
|
|
"ld": {
|
|
"args": [
|
|
"@exec",
|
|
"pkg-config",
|
|
"--libs",
|
|
"sdl2"
|
|
]
|
|
}
|
|
}
|
|
}
|
|
```
|