1
0
mirror of synced 2025-01-03 10:21:32 +01:00

Adding install, typos fixed

This commit is contained in:
Henry Fredrick Schreiner 2017-10-18 10:20:39 -04:00
parent c00cc734a2
commit 9b61fdaf38
6 changed files with 80 additions and 10 deletions

View File

@ -9,9 +9,19 @@ cache:
before_script: before_script:
- npm install gitbook-cli -g # install gitbook - npm install gitbook-cli -g # install gitbook
- gitbook fetch latest # fetch latest stable version - gitbook fetch latest # fetch latest stable version
- gitbook install # add any requested plugins in book.json
#- gitbook fetch pre # fetch latest pre-release version #- gitbook fetch pre # fetch latest pre-release version
#- gitbook fetch 2.6.7 # fetch specific version #- gitbook fetch 2.6.7 # fetch specific version
test:
stage: test
script:
- gitbook build . public # build to public path
only:
- branches # this job will affect only the 'master' branch
except:
- master
# the 'pages' job will deploy and build your site to the 'public' path # the 'pages' job will deploy and build your site to the 'public' path
pages: pages:
stage: deploy stage: deploy
@ -20,5 +30,7 @@ pages:
artifacts: artifacts:
paths: paths:
- public - public
expire_in: 1 week
only: only:
- master # this job will affect only the 'master' branch - master # this job will affect only the 'master' branch

View File

@ -8,9 +8,9 @@ This raises the question: Why?
Certainly there are no shortage of problems when building. Certainly there are no shortage of problems when building.
But I think that, in 2017, we have a very good solution to quite a few of those problems. But I think that, in 2017, we have a very good solution to quite a few of those problems.
It's CMake. Not CMake 2.8 though; that was released before C++11 even existed! It's CMake. Not CMake 2.8 though; that was released before C++11 even existed!
Nor the horible examples out there for CMake (even those posted on KitWare's own tutorials list). Nor the horrible examples out there for CMake (even those posted on KitWare's own tutorials list).
I'm talking about Modern CMake. CMake 3.1+, maybe even CMake 3.8+! I'm talking about Modern CMake. CMake 3.1+, maybe even CMake 3.8+!
It's clean, powerful, and elegant, so you can spend most of your time coding, not addding lines to an unreadable, unmaintainable Make (Or CMake 2) file. It's clean, powerful, and elegant, so you can spend most of your time coding, not adding lines to an unreadable, unmaintainable Make (Or CMake 2) file.
{% hint style='working' %} {% hint style='working' %}
This document is a work in progress. This document is a work in progress.
@ -24,8 +24,8 @@ Do any of the following apply to you?
* You want to avoid hard-coding paths * You want to avoid hard-coding paths
* You need to build a package on more than one computer * You need to build a package on more than one computer
* You want to use CI (continious integration) * You want to use CI (continuous integration)
* You need to support diffent OSs (maybe even just flavors of Unix) * You need to support different OSs (maybe even just flavors of Unix)
* You want to support multiple compilers * You want to support multiple compilers
* You want to use an IDE, but maybe not all of the time * You want to use an IDE, but maybe not all of the time
* You want to describe how your program is structured logically, not flags and commands * You want to describe how your program is structured logically, not flags and commands
@ -33,18 +33,18 @@ Do any of the following apply to you?
* You want to use tools, like Clang-Tidy, to help you code * You want to use tools, like Clang-Tidy, to help you code
* You want to use a debugger * You want to use a debugger
If so, you'll benifit from a CMake-like build system. If so, you'll benefit from a CMake-like build system.
## Why must the answer be CMake? ## Why must the answer be CMake?
Build systems is a hot topic. Of course there are many options. But even a really good one, or one that re-uses a familar syntax, can't come close to CMake. Build systems is a hot topic. Of course there are many options. But even a really good one, or one that re-uses a familiar syntax, can't come close to CMake.
Why? Why?
Support. Support.
Every IDE supports CMake (or CMake supports that IDE). Every IDE supports CMake (or CMake supports that IDE).
More packages use CMake than any other system. More packages use CMake than any other system.
So, if you use a library that is designed to be included in your code, you have a choice: Make your own build system, or use one of of the provided ones, and that will almost always include CMake. So, if you use a library that is designed to be included in your code, you have a choice: Make your own build system, or use one of of the provided ones, and that will almost always include CMake.
And that will quickly be the common denominator if you include multiple projects. And that will quickly be the common denominator if you include multiple projects.
And, if you need a library that's preinstalled, the chances of it having a find cmake script or config cmake script are excellent. And, if you need a library that's preinstalled, the chances of it having a find CMake script or config CMake script are excellent.
## Why use a Modern CMake? ## Why use a Modern CMake?
@ -64,7 +64,7 @@ Even though every version of CMake is insanely backward compatible, the 3 series
And so, you'll find OS's like CentOS7 with GCC 4.8, with almost-complete C++14 support, and CMake 2.8, which came out before C++11. And so, you'll find OS's like CentOS7 with GCC 4.8, with almost-complete C++14 support, and CMake 2.8, which came out before C++11.
You really should *at least* use a version of CMake that came out after your compiler, since it needs to know compiler flags, etc, for that version. You really should *at least* use a version of CMake that came out after your compiler, since it needs to know compiler flags, etc, for that version.
And, since CMake will dumb itself down to the minimium required version in your CMake file, installing a new CMake, even system wide, is pretty safe. And, since CMake will dumb itself down to the minimum required version in your CMake file, installing a new CMake, even system wide, is pretty safe.
You should *at least* install it locally. You should *at least* install it locally.
It's easy (1-2 lines in many cases), and you'll find that 5 minutes of work will save you hundreds of lines and hours of CMakeLists.txt writing, and will be much easier to maintain in the long run. It's easy (1-2 lines in many cases), and you'll find that 5 minutes of work will save you hundreds of lines and hours of CMakeLists.txt writing, and will be much easier to maintain in the long run.

View File

@ -1,7 +1,7 @@
# Summary # Summary
* [An Introduction to Modern CMake](README.md) * [An Introduction to Modern CMake](README.md)
* [Installing CMake](chapters/install.md) * [Installing CMake](chapters/installing.md)
* [Running CMake](chapters/running.md) * [Running CMake](chapters/running.md)
## Making a CMakeLists ## Making a CMakeLists

View File

@ -14,6 +14,11 @@ Let's mention a bit of CMake syntax. The function name is case insensitive, so t
This line is special! [^2] The version of CMake will also dictate the policies, which define behavior changes. So, if you set `minimum_required` to `VERSION 2.8`, you'll get the wrong linking behavior on macOS, for example, even in the newest CMake versions. A list of policies and versions is [here](https://cmake.org/cmake/help/v3.9/manual/cmake-policies.7.html). This line is special! [^2] The version of CMake will also dictate the policies, which define behavior changes. So, if you set `minimum_required` to `VERSION 2.8`, you'll get the wrong linking behavior on macOS, for example, even in the newest CMake versions. A list of policies and versions is [here](https://cmake.org/cmake/help/v3.9/manual/cmake-policies.7.html).
{% hint style='info' %}
If you really need to set to a low value here, you can use [`cmake_policy`] to conditinally increase the policy level or set a specific policy. Please at least do this for your macOS users!
{% endhint %}
## Setting a project ## Setting a project
Now, every top-level CMake file will have the next line: Now, every top-level CMake file will have the next line:
@ -105,3 +110,5 @@ target_link_libraries(calc PUBLIC calclib)
[^2]: You will sometimes see `FATAL_ERROR` here, that was needed to support nice failures when running this in CMake <2.6, which should not be a problem anymore. [^2]: You will sometimes see `FATAL_ERROR` here, that was needed to support nice failures when running this in CMake <2.6, which should not be a problem anymore.
[^3]: The `::` syntax was originally intended for `INTERFACE IMPORTED` libraries, which were explicitly supposed to be libraries defined outside the current project. But, because of this, most of the `target_*` commands don't work on `IMPORTED` libraries, making them hard to set up yourself. So don't use the `IMPORTED` keyword for now, and use an `ALIAS` target instead. There's a project in the works to fix this limitation for CMake 3.11. [^3]: The `::` syntax was originally intended for `INTERFACE IMPORTED` libraries, which were explicitly supposed to be libraries defined outside the current project. But, because of this, most of the `target_*` commands don't work on `IMPORTED` libraries, making them hard to set up yourself. So don't use the `IMPORTED` keyword for now, and use an `ALIAS` target instead. There's a project in the works to fix this limitation for CMake 3.11.
[`cmake_policy`]: https://cmake.org/cmake/help/v3.0/command/cmake_policy.html

50
chapters/installing.md Normal file
View File

@ -0,0 +1,50 @@
# Installing CMake
> Your CMake version should be newer than your compiler. It should be newer than the libraries you are using (especially Boost). New versions work better for everyone.
If you have a built in copy of CMake, it isn't special or customized for your system. You can easily install a new one instead, either on the system level or the user level. Feel free to instruct your users here if they complain about a CMake requirement being set too high. Especially if they want < 3.1 support. Maybe even if they want CMake < 3.8 support...
## Official package
You can [download CMake from KitWare][cmake-download]. This is how you'll probably get CMake if you are on Windows. It's not a bad way to get it on macOS either, but using `brew install cmake` is much nicer if you use [Homebrew](https://brew.sh) (and you should).
On Linux, there are binaries provided, but you'll need to pick an install location. If you already use `~/.local` for user-space packages, the following single line command will get CMake for you [^1]:
{% terminal %}
~ $ wget -qO- "https://cmake.org/files/v3.9/cmake-3.9.4-Linux-x86_64.tar.gz" | tar --strip-components=1 -xz -C ~/.local
{% endterminal %}
If you just want a local folder with CMake only:
{% terminal %}
~ $ mkdir -p cmake39 && wget -qO- "https://cmake.org/files/v3.9/cmake-3.9.4-Linux-x86_64.tar.gz" | tar --strip-components=1 -xz -C cmake39
~ $ export PATH=`pwd`/cmake39/bin:$PATH
{% endterminal %}
You'll obviously want to append to the PATH every time you start a new terminal, or add it to your `.bashrc` or to an [LMod] system.
And, if you want a system install (I'm only brave enough to run this in Docker):
You can also build CMake on any system, it's pretty easy, but binaries are faster.
## Pip
This is also provide as an official package, maintained by the authors of CMake at KitWare. It's a rather new method, and might fail on some systems (Alpine isn't supported last I checked, but that has CMake 3.8), but works really well when it works (like on Travis CI). If you have pip (Python's package installer), you can do:
```bash
pip install cmake
```
And as long as a binary exists for your system, you'll be up-and-running almost immediately. If a binary doesn't exist, it will try to use KitWare's `scikit-build` package to build, which currently can't be listed as a dependency in the packaging system, and might even require (an older) copy of CMake to build. So only use this system if binaries exist, which is most of the time.
This has the benefit of respecting your current virtual environment, as well.
{% hint style='info' %}
Personally, on Linux, I put versions of CMake in folders, like `/opt/cmake39` or `~/opt/cmake39`, and then add them to [LMod]. See [`envmodule_setup`] for help setting up an LMod system on macOS or Linux. It's takes a bit to learn, but is a great way to manage package and compiler versions.
{% endhint %}
[^1]: If don't have a `.local` in your home directory, it's easy to start. Just make the folder, then add `export PATH="$HOME/.local/bin:$PATH"` to your `.bashrc` or `.bash_profile` or `.profile` file in your home directory. Now you can install any packages you build to `-DCMAKE_INSTALL_PREFIX=~/.local` instead of `/usr/local`!
[cmake-download]: https://cmake.org/download/
[LMod]: http://lmod.readthedocs.io/en/latest/
[`envmodule_setup`]: https://github.com/CLIUtils/envmodule_setup

View File

@ -58,3 +58,4 @@ These are common CMake options to most packages:
* `-DCMAKE_BUILD_TYPE=` Pick from Release, RelWithDebInfo, Debug, or sometimes more. * `-DCMAKE_BUILD_TYPE=` Pick from Release, RelWithDebInfo, Debug, or sometimes more.
* `-DCMAKE_INSTALL_PREFIX=` The location to install to. System install on UNIX would often be `/usr/local` (the default), user directories are often `~/.local`, or you can pick a folder. * `-DCMAKE_INSTALL_PREFIX=` The location to install to. System install on UNIX would often be `/usr/local` (the default), user directories are often `~/.local`, or you can pick a folder.
* `-D BUILD_SHARED_LIBS=` You can set this `ON` or `OFF` to control the default for shared libraries (the author can pick one vs. the other explicitly instead of using the default, though)