about summary refs log tree commit diff
path: root/cmake/INSTALL.md
blob: 1377d652ed09b8034f041660ca1a94ec4ca824ba (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
# Glog - CMake Support

Glog comes with a CMake build script ([CMakeLists.txt](../CMakeLists.txt)) that can be used on a wide range of platforms.  
If you don't have CMake installed already, you can download it for free from <http://www.cmake.org/>.

CMake works by generating native makefiles or build projects that can be used in the compiler environment of your choice.  
You can either build Glog with CMake as a standalone project or it can be incorporated into an existing CMake build for another project.

## Table of Contents

- [Building Glog with CMake](#building-glog-with-cmake)
- [Consuming Glog in a CMake Project](#consuming-glog-in-a-cmake-project)
- [Incorporating Glog into a CMake Project](#incorporating-glog-into-a-cmake-project)

## Building Glog with CMake

When building Glog as a standalone project, on Unix-like systems with GNU Make as build tool, the typical workflow is:  

1. Get the source code and change to it.
e.g. cloning with git:
```bash
git clone git@github.com:google/glog.git
cd glog
```

2. Run CMake to configure the build tree.
```bash
cmake -H. -Bbuild -G "Unix Makefiles"
```
note: To get the list of available generators (e.g. Visual Studio), use `-G ""`

3. Afterwards, generated files can be used to compile the project.
```bash
cmake --build build
```

4. Test the build software (optional).
```bash
cmake --build build --target test
```

5. Install the built files (optional).
```bash
cmake --build build --target install
```

## Consuming Glog in a CMake Project

If you have Glog installed in your system, you can use the CMake command
`find_package()` to include it in your CMake Project.

```cmake
cmake_minimum_required(VERSION 3.0.2)
project(myproj VERSION 1.0)

find_package(glog 0.4.0 REQUIRED)

add_executable(myapp main.cpp)
target_link_libraries(myapp glog::glog)
```

Compile definitions and options will be added automatically to your target as
needed.

## Incorporating Glog into a CMake Project

You can also use the CMake command `add_subdirectory()` to include Glog directly from a subdirectory of your project.  
The **glog::glog** target is in this case an ALIAS library target for the **glog** library target. 

```cmake
cmake_minimum_required(VERSION 3.0.2)
project(myproj VERSION 1.0)

add_subdirectory(glog)

add_executable(myapp main.cpp)
target_link_libraries(myapp glog::glog)
```

Again, compile definitions and options will be added automatically to your target as
needed.