evmc/cmake/cable/README.md
2018-10-05 16:05:42 +02:00

93 lines
2.4 KiB
Markdown

# Cable
[![readme style: standard][readme style standard badge]][standard readme]
> Cable: CMake Bootstrap Library
Cable is a set of CMake modules and scripts containing common patterns used
in CMake-based C++ projects. The design goal is to be pragmatic rather than
generic so the number of provided options is minimal. The Cable modules are
independent and it is easy to use them individually.
## Table of Contents
- [Install](#install)
- [Usage](#usage)
- [Maintainer](#maintainer)
- [License](#license)
## Install
The suggested Cable location is `cmake/cable` relative to your project root directory.
### As git subtree
Adding a dependency project as a [git subtree] is just a copy of the source code
done in a bit more systematic way.
If you are not familiar with managing dependencies with git subtree read the
[Git subtree: the alternative to Git submodule][git subtree tutorial].
#### To install
```sh
git remote add cable https://github.com/ethereum/cable
git subtree add --prefix cmake/cable cable master --squash
```
#### To update
```sh
git subtree pull --prefix cmake/cable cable master --squash
```
### As git submodule
Include the Cable library as [git submodule] in your project.
```sh
git submodule add https://github.com/ethereum/cable cmake/cable
```
## Usage
Cable contains the `bootstrap.cmake` file that initializes the library.
Start by including this file in your main `CMakeLists.txt` from the Cable
submodule/subtree or any other location. The `bootstrap.cmake` must be included
before the `project()` command. After that, you can include and use other
Cable modules.
### Example
```cmake
cmake_minimum_required(VERSION 3.5)
include(cmake/cable/bootstrap.cmake)
include(CableBuildType)
project(tothemoon)
cable_set_build_type(DEFAULT RelWithDebInfo CONFIGURATION_TYPES Debug Release RelWithDebInfo)
```
## Maintainer
Paweł Bylica [@chfast]
## License
Licensed under the [Apache License, Version 2.0].
[@chfast]: https://github.com/chfast
[Apache License, Version 2.0]: LICENSE
[git submodule]: https://git-scm.com/book/en/v2/Git-Tools-Submodules
[git subtree]: https://github.com/git/git/blob/master/contrib/subtree/git-subtree.txt
[git subtree tutorial]: https://www.atlassian.com/blog/git/alternatives-to-git-submodule-git-subtree
[standard readme]: https://github.com/RichardLitt/standard-readme
[readme style standard badge]: https://img.shields.io/badge/readme%20style-standard-brightgreen.svg?style=flat-square