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
|
set -ex
if [ "$CXX" = "g++" ]; then
sudo apt-get install -qq g++-$GCC_VERSION;
export CXX="g++-$GCC_VERSION" CC="gcc-$GCC_VERSION";
fi
if [ "$CXX" = "clang++" ]; then
sudo apt-get install -qq clang-$CLANG_VERSION;
export CXX="clang++-$CLANG_VERSION" CC="clang-$CLANG_VERSION";
fi
# Configure the build
mkdir build
cd build
cmake .. -DCMAKE_BUILD_TYPE:STRING="$BUILD_TYPE"
if [ "$BUILD_TYPE" == "Debug" ]; then
# Build the documentation. Any warning is an error.
sudo pip install sphinx
pushd ../doc/sphinx
mkdir source/_static
./extract_rst.py
sphinx-build -W -b json -d build/doctrees source build/json
popd
# Run the codecheck test suite.
pushd ../cmake/codecheck
./run_tests.py
popd
# Any codecheck warning is an error in Debug builds. Keep the codebase clean!!
# Suppress color output.
TERM=dumb make -j1 codecheck 2>&1 | tee codecheck.out
if grep '^[/_.a-zA-Z]\+:[0-9]\+:' codecheck.out; then
echo "You have codecheck warnings (see above) Please fix."
exit 1 # CodeCheck warnings.
fi
fi
# Do the actual build.
make -k -j3
# Run the regression suite.
cd ..
./regression_test.py -b build/src/widelands
|