forked from openambitproject/openambit
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDockerfile
98 lines (90 loc) · 3.28 KB
/
Dockerfile
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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
# Dockerfile -- to build the sources on a well-known platform
# Copyright (C) 2014, 2015, 2019 Olaf Meeuwissen
#
# This file is part of Openambit.
#
# Openambit is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published
# by the Free Software Foundation, either version 3 of the License,
# or (at your option) any later version.
#
# Openambit distributed in the hope that it will be useful, but
# WITHOUT ANY WARRANTY --- without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Openambit. If not, see https://www.gnu.org/licenses/.
# Recommended way to build the container this creates (for lack of
# an easy way to exclude everything but the Dockerfile):
#
# docker build -t openambit:stretch - < Dockerfile
#
# After that is just a matter of compiling the sources with:
#
# docker run --rm -v $PWD:/code -u $(id -u) openambit:stretch
#
# Doing so gives you a basic sanity check of code compilability on a
# minimalistic, reproducible development platform.
#
# If you don't like the defaults of building in $PWD/_build with no
# options to either cmake or make, feel free to adjust the relevant
# environment variables. For example, you could build with:
#
# docker run --rm -v $PWD:/code -u $(id -u) \
# --env BUILD_DIR=tmp \
# --env CMAKE_OPTS="-DBUILD_EXTRAS=1" \
# --env MAKE_OPTS=-k \
# openambit:stretch
#
# Check out the --env-file option to docker if you find that overly
# long-winded. If you use a BUILD_DIR that is not below /code make
# sure to drop the --rm option.
#
# For interactive sessions, you may want to use:
#
# docker run -i -t --rm -v $PWD:/code -u $(id -u) \
# openambit:stretch /bin/bash
#
# Again, drop the --rm option if you build in a location that is not
# below /code.
FROM debian:stretch
MAINTAINER Olaf Meeuwissen <[email protected]>
ENV APT_OPTS --assume-yes --no-install-recommends
# build system dependencies
# Note that gcc does *not* depend on any specific C library. Debian
# and derivatives ship several ...
RUN apt-get update \
&& apt-get install ${APT_OPTS} \
cmake \
make \
gcc \
libc-dev
# libambit and example application build dependencies
# The HID API support needs at least one of these to be available. The
# HIDAPI_DRIVER `cmake` variable controls what is used.
RUN apt-get update \
&& apt-get install ${APT_OPTS} \
libudev-dev \
libusb-1.0-0-dev \
libpcap-dev
# openambit build dependencies
RUN apt-get update \
&& apt-get install ${APT_OPTS} \
g++ \
qtbase5-dev \
qttools5-dev \
qttools5-dev-tools \
zlib1g-dev
# wireshark dissector build dependencies
RUN apt-get update \
&& apt-get install ${APT_OPTS} \
libglib2.0-dev \
libwireshark-dev \
python
WORKDIR /code
ENV BUILD_DIR _build
CMD test -d ${BUILD_DIR} || mkdir ${BUILD_DIR}; \
cd ${BUILD_DIR} \
&& cmake ${CMAKE_OPTS} .. \
&& make ${MAKE_OPTS}