File: HOWTO-Compile.md

package info (click to toggle)
portsentry 2.0.6-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,404 kB
  • sloc: ansic: 6,481; sh: 920; perl: 18; makefile: 5
file content (69 lines) | stat: -rw-r--r-- 2,114 bytes parent folder | download
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
# HOWTO Compile Portsentry

## Requirements

In order to compile, Portsentry requires:

* **CMake (version 3.10 or higher)**
* **GCC or Clang**
* **libpcap** (including headers, often packaged as libpcap-dev)

## Quickstart

The build.sh convenience script can be used in order to build Portsentry

To build a debug version:

```
./build.sh debug
```

To build a release version

```
./build.sh release
```

## Running CMake manually

In order to compile, you should supply the **CMAKE_BUILD_TYPE** flag to CMake (see below). It should be set to either **Debug** or **Release**.

Portsentry accepts these flags:

| Flag | Default | Description |
| ---- | ------- | ----------- |
| CMAKE_BUILD_TYPE | Release | Should be set to either Debug or Release |
| USE_PCAP | ON | If used with **USE_PCAP=OFF** set, all pcap code is excluded and Portsentry will not link to libpcap. This option can be used where libpcap is not desired and/or available. |
| BUILD_FUZZER | OFF | If used with **BUILD_FUZZER=ON**, the clang fuzzer tests are built. |
| BUILD_TESTS | OFF | If used with **BUILD_TESTS=ON**, unit tests are built and can be run with the ctest suit. |
| INSTALL_LICENSE | ON | When **INSTALL_LICENSE=ON** the LICENSE file will be included in the generated install files. However, some package managers (like debian and red hat for example) handle license installations separately. In these cases (when building distro packages), you might want to set **INSTALL_LICENSE=OFF**. |

### Compilation Examples

**Compiling for release**
```
  cmake -B release -D CMAKE_BUILD_TYPE=Release
  cmake --build release -v
```

**Compiling with debug symbols**
```
  cmake -B debug -D CMAKE_BUILD_TYPE=Debug
  cmake --build debug -v
```

**Compiling without LIBPCAP**
```
  cmake -B release -D CMAKE_BUILD_TYPE=Release -DUSE_PCAP=OFF
  cmake --build release -v
```

**Compiling old version (v1.2)**

Tag v1.2 is the release from 2003, before the project was orphaned and uses a different build method, execute _make_ in order to see compilation instructions.

## Supported Platforms
- Linux
- OpenBSD
- FreeBSD
- NetBSD >= 8.0