Skip to content

Update game admin guide #3231

Update game admin guide

Update game admin guide #3231

Workflow file for this run

name: Build
on:
push: {}
pull_request: {}
schedule:
- cron: "0 5 * * MON"
workflow_dispatch: {}
concurrency:
group: ${{ github.repository }}-${{ github.head_ref || github.run_id }}-build
cancel-in-progress: true
jobs:
ubuntu:
name: "Ubuntu"
needs: clang-format
strategy:
matrix:
os: [ubuntu-22.04]
compiler: [gcc, clang]
build_type: ["", Release, Debug, RelWithDebInfo]
exclude:
- compiler: clang
build_type: RelWithDebInfo
runs-on: ${{ matrix.os }}
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install GCC
if: ${{ matrix.compiler == 'gcc' }}
run: |
sudo apt-get install g++
- name: Install clang
if: ${{ matrix.compiler == 'clang' }}
run: |
sudo apt-get install clang
export CC=$(which clang)
export CXX=$(which clang++)
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install \
cmake \
ninja-build \
python3 \
python3-pip \
gettext \
qtbase5-dev \
libqt5svg5-dev \
libkf5archive-dev \
liblua5.3-dev \
libsqlite3-dev \
libsdl2-mixer-dev \
python3-sphinx
pip install -r docs/requirements.txt
- name: Configure
run: |
cmake . -B build -G Ninja \
-DCMAKE_BUILD_TYPE=${{ matrix.build_type }} \
-DCMAKE_INSTALL_PREFIX=/usr
- name: Build
run: |
cmake --build build
- name: Test
run: |
cmake --build build --target test
- name: Debug
if: failure()
run: |
cat build/Testing/Temporary/LastTest.log
- name: Install
run: |
DESTDIR=$PWD/build/install cmake --build build --target install
- name: Package
run: |
cmake --build build --target package
- name: Upload package
uses: softprops/action-gh-release@v2
if: |
startsWith(github.ref, 'refs/tags/')
&& matrix.compiler == 'gcc'
&& matrix.build_type == 'Release'
with:
files: |
build/Linux-x86_64/freeciv21_*_amd64.deb
build/Linux-x86_64/freeciv21_*_amd64.deb.sha256
flagstest:
name: "Additional compile flags in Ubuntu"
needs: clang-format
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install GCC
run: |
sudo apt-get install g++
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install \
cmake \
ninja-build \
python3 \
gettext \
qtbase5-dev \
libqt5svg5-dev \
libkf5archive-dev \
liblua5.3-dev \
libsqlite3-dev \
libsdl2-mixer-dev
- name: Configure
run: |
cmake . -B build -G "Ninja Multi-Config" --preset "DistroRelease"
- name: Build
run: |
cmake --build build
- name: Test
run: |
cmake --build build --target test
windows:
name: "Windows MSYS2 (gcc)"
runs-on: windows-latest
needs: clang-format
defaults:
run:
shell: msys2 {0}
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: msys2/setup-msys2@v2
with:
msystem: MINGW64
update: true
install: |
git
mingw-w64-x86_64-cmake
mingw-w64-x86_64-ninja
mingw-w64-x86_64-nsis
mingw-w64-x86_64-gcc
mingw-w64-x86_64-libunwind
mingw-w64-x86_64-readline
mingw-w64-x86_64-lua
mingw-w64-x86_64-SDL2_mixer
mingw-w64-x86_64-qt5
mingw-w64-x86_64-qt5-svg
mingw-w64-x86_64-karchive-qt5
- name: Configure
run: |
export PATH=/mingw64/bin:${PATH}
export MSYSTEM=MINGW64
export PKG_CONFIG_PATH=${PKG_CONFIG_PATH}:/mingw64/lib/pkgconfig:/mingw64/share/pkgconfig
cmake . -B build -G Ninja \
-DCMAKE_INSTALL_PREFIX=$PWD/build/install \
-DCMAKE_BUILD_TYPE=Release
- name: Build
run: |
cmake --build build
#- name: Test
# run: |
# cmake --build build --target test
- name: Install
run: |
cmake --build build --target install
- name: Package
run: |
cmake --build build --target package
- name: Upload package
uses: softprops/action-gh-release@v2
if: startsWith(github.ref, 'refs/tags/')
with:
files: |
build/Windows-x86_64/Freeciv21-*-Windows-x86_64.exe
build/Windows-x86_64/Freeciv21-*-Windows-x86_64.exe.sha256
- name: Upload a build
uses: actions/upload-artifact@v4
with:
name: Windows-exe
path: build/Windows-x86_64/Freeciv21-*.exe
windows_clang_msvc:
name: "Windows Clang"
runs-on: windows-latest
needs: clang-format
if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch'
env:
VCPKG_ROOT: ${{github.workspace}}/vcpkg
VCPKG_DEFAULT_BINARY_CACHE: ${{github.workspace}}/vcpkg/bincache
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- uses: lukka/run-vcpkg@v11
name: Install dependencies
with:
vcpkgGitCommitId: 3508985146f1b1d248c67ead13f8f54be5b4f5da
- name: Configure
run: cmake -S . -B build --preset "windows-debug"
- name: Building
run: cmake --build build --config Debug
#- name: Test
# run: cmake --build build --target test
os_x:
name: "macOS"
runs-on: macos-latest
needs: clang-format
env:
VCPKG_BUILD_TYPE: release
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install build tools
run: |
brew update
# Remove the bloat installed by default to avoid conflicts
brew remove --force $(brew list)
# Make sure to overwrite existing symlinks
brew install --overwrite \
cmake \
create-dmg \
gettext \
ninja \
pkg-config
brew link gettext --force
- uses: actions/setup-python@v5 # Workaround for #2069
with:
python-version: '3.11'
- uses: lukka/run-vcpkg@v11
name: Install dependencies
with:
vcpkgGitCommitId: 3508985146f1b1d248c67ead13f8f54be5b4f5da
- name: Build
uses: lukka/run-cmake@v10
with:
configurePreset: 'fullrelease-macos'
buildPreset: 'fullrelease-macos'
- name: Test
run: |
cmake --build build* --target test
- name: Split Branch Name
env:
BRANCH: ${{github.ref_name}}
id: split
run: echo "fragment=${BRANCH##*/}" >> $GITHUB_OUTPUT
- name: Create App Bundle
run: |
mkdir -p Freeciv21.app/Contents/MacOS Freeciv21.app/Contents/Resources
cp dist/Info.plist Freeciv21.app/Contents/
cp -r .install/share/freeciv21/* Freeciv21.app/Contents/Resources
cp .install/bin/freeciv21-* Freeciv21.app/Contents/MacOS
mkdir client.iconset
cp data/icons/16x16/freeciv21-client.png client.iconset/icon_16x16.png
cp data/icons/32x32/freeciv21-client.png client.iconset/[email protected]
cp data/icons/32x32/freeciv21-client.png client.iconset/icon_32x32.png
cp data/icons/64x64/freeciv21-client.png client.iconset/[email protected]
cp data/icons/128x128/freeciv21-client.png client.iconset/icon_128x128.png
iconutil -c icns client.iconset
cp client.icns Freeciv21.app/Contents/Resources
mkdir staging
mv Freeciv21.app staging
create-dmg \
--hdiutil-verbose \
--volname "Freeciv21 Installer" \
--volicon "client.icns" \
--window-pos 200 120 \
--window-size 800 400 \
--icon-size 100 \
--icon "Freeciv21.app" 200 190 \
--hide-extension "Freeciv21.app" \
--app-drop-link 600 185 \
"Freeciv21-${{steps.split.outputs.fragment}}.dmg" \
"staging/"
shasum -a 256 Freeciv21-${{steps.split.outputs.fragment}}.dmg > Freeciv21-${{steps.split.outputs.fragment}}.dmg.sha256
- name: Upload package
uses: softprops/action-gh-release@v2
if: startsWith(github.ref, 'refs/tags/')
with:
files: |
Freeciv21-*.dmg
Freeciv21-*.dmg.sha256
- name: Upload a build
uses: actions/upload-artifact@v4
with:
name: macOS-dmg
path: Freeciv21-*.dmg
fedora:
runs-on: ubuntu-latest
if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch'
container: fedora:latest
steps:
- name: Install dependencies
run: |
sudo dnf install -y \
git \
cmake \
ninja-build \
python \
gettext \
qt5-qtbase-devel \
qt5-qtsvg-devel \
kf5-karchive-devel \
lua-devel \
sqlite-devel \
SDL2_mixer-devel \
readline-devel \
zlib-devel \
libunwind-devel \
elfutils-libs
- uses: actions/checkout@v4
- name: Configure
# Set ALWAYS_ROOT because the container user is root and creating an
# unpriviledged user would be too much work.
run: |
cmake . -B build -G Ninja \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_INSTALL_PREFIX=/usr \
-DALWAYS_ROOT=YES
- name: Build
run: |
cmake --build build
- name: Test
run: |
cmake --build build --target test
- name: Install
run: |
DESTDIR=$PWD/build/install cmake --build build --target install
freebsd:
runs-on: ubuntu-latest
if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch'
steps:
- uses: actions/checkout@v4
# This has to be executed in a single step because freebsd-vm fails if run
# twice.
- name: Build, test, and install on FreeBSD
uses: vmactions/freebsd-vm@v1
with:
# qmake is required by /usr/local/lib/cmake/Qt5Core/Qt5CoreConfig.cmake
run: |
set -e
pkg install -y \
git \
cmake \
ninja \
gettext \
qt5-buildtools \
qt5-qmake \
qt5-network \
qt5-svg \
qt5-testlib \
qt5-widgets \
kf5-karchive \
lua53 \
sqlite3 \
sdl2_mixer \
readline \
zlib-ng \
libunwind \
elfutils
# Create an unpriviledged user to run tests as, otherwise the server
# refuses to start (and rightfully so)
pw user add -n action -m
# Create a script with the commands to run
cat >build-and-test.sh <<EOF
cmake -B build -G Ninja \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_INSTALL_PREFIX=/usr
cmake --build build
cmake --build build --target test
DESTDIR=$PWD/build/install cmake --build build --target install
EOF
chmod +x build-and-test.sh
su action -c 'sh build-and-test.sh'
nix:
runs-on: ubuntu-latest
if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch'
steps:
- name: checkout
uses: actions/checkout@v4
- uses: cachix/install-nix-action@v22
- run: nix flake check
# TODO: We can add the build to a cache for others (see cachix.org)
# It's free for FOSS.
- run: nix build .#freeciv21
wasm:
name: "WebAssembly"
runs-on: ubuntu-latest
if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch'
needs: clang-format
env:
QT_VERSION: v5.15.8-lts-lgpl
steps:
- uses: actions/checkout@v4
- name: Cache Qt build
id: qtcache
uses: actions/cache@v4
with:
path: ~/qt
key: qt-wasm-${{ env.QT_VERSION }}-svg-socket-v2
- name: Install build tools
run: |
sudo apt-get update
sudo apt-get install \
cmake \
ninja-build \
clang \
python3 \
gettext
- uses: actions/checkout@v4
name: Checkout emsdk
with:
repository: emscripten-core/emsdk
path: emsdk
- name: Install emsdk
run: |
cd emsdk
./emsdk install latest
./emsdk activate latest
touch prime.c
source emsdk_env.sh
emcc -sUSE_ZLIB=1 -sUSE_SDL=2 -sUSE_SDL_MIXER=2 prime.c -o prime.o
ln -s libSDL2_mixer_ogg.a upstream/emscripten/cache/sysroot/lib/wasm32-emscripten/libSDL2_mixer.a
- name: Install lua
run: |
source emsdk/emsdk_env.sh
wget https://www.lua.org/ftp/lua-5.4.3.tar.gz
tar xf lua-5.4.3.tar.gz
cp dist/wasm/lua.CMakeLists.txt lua-5.4.3/CMakeLists.txt
cd lua-5.4.3
emcmake cmake .
emmake make install
- uses: actions/checkout@v4
if: steps.qtcache.outputs.cache-hit != 'true'
name: Checkout qtbase
with:
repository: qt/qtbase
ref: ${{ env.QT_VERSION }}
path: qtbase
- name: Build Qt
if: steps.qtcache.outputs.cache-hit != 'true'
run: |
source emsdk/emsdk_env.sh
cd qtbase
git config --global user.email "[email protected]"
git config --global user.name "root"
git fetch origin 76d12eea2252c5e537dff15b103bdc1f925cf760
git cherry-pick 76d12eea2252c5e537dff15b103bdc1f925cf760
./configure -xplatform wasm-emscripten -opensource -confirm-license -prefix ~/qt -nomake examples
make install
- uses: actions/checkout@v4
if: steps.qtcache.outputs.cache-hit != 'true'
name: Checkout qtsvg
with:
repository: qt/qtsvg
ref: ${{ env.QT_VERSION }}
path: qtsvg
- name: Build QtSvg
if: steps.qtcache.outputs.cache-hit != 'true'
run: |
source emsdk/emsdk_env.sh
cd qtsvg
~/qt/bin/qmake
make install
- uses: actions/checkout@v4
name: Checkout zstd
with:
repository: facebook/zstd
ref: v1.5.0
path: zstd
- name: Build zstd
run: |
source emsdk/emsdk_env.sh
cd zstd
mkdir bld
emcmake cmake build/cmake -DZSTD_BUILD_PROGRAMS=0 -DZSTD_BUILD_SHARED=0
emmake make install
- uses: actions/checkout@v4
name: Checkout extra-cmake-modules
with:
repository: KDE/extra-cmake-modules
ref: v5.96.0
path: ecm
- name: Install ecm
run: |
cd ecm
cmake .
sudo make install
- uses: actions/checkout@v4
name: Checkout karchive
with:
repository: KDE/karchive
ref: v5.96.0
path: karchive
- name: Install karchive
run: |
source emsdk/emsdk_env.sh
cd karchive
git apply ../dist/wasm/karchive.diff
emcmake cmake . \
-DECM_DIR=/usr/local/share/ECM/cmake -DBUILD_TESTING=0 \
-DQt5Core_DIR=$HOME/qt/lib/cmake/Qt5Core \
-DKF_IGNORE_PLATFORM_CHECK=1 \
-DCMAKE_INSTALL_PREFIX=../emsdk/upstream/emscripten/cache/sysroot
emmake make install
- name: Build Freeciv
run: |
source emsdk/emsdk_env.sh
ls $HOME/qt/lib/cmake/Qt5
emcmake cmake . \
-DCMAKE_BUILD_TYPE=Release \
-DQt5_DIR=$HOME/qt/lib/cmake/Qt5 \
-DQt5Svg_DIR=$HOME/qt/lib/cmake/Qt5Svg \
-DQt5Gui_DIR=$HOME/qt/lib/cmake/Qt5Gui \
-DQt5Core_DIR=$HOME/qt/lib/cmake/Qt5Core \
-DQt5Network_DIR=$HOME/qt/lib/cmake/Qt5Network \
-DFREECIV_ENABLE_SERVER=0 \
-DLUA_MATH_LIBRARY=emsdk/upstream/emscripten/cache/sysroot/lib/wasm32-emscripten/libc.a \
-DQt5Widgets_DIR=$HOME/qt/lib/cmake/Qt5Widgets \
-DQt5EventDispatcherSupport_DIR=$HOME/qt/lib/cmake/Qt5EventDispatcherSupport \
-DQt5FontDatabaseSupport_DIR=$HOME/qt/lib/cmake/Qt5FontDatabaseSupport \
-DQt5EglSupport_DIR=$HOME/qt/lib/cmake/Qt5EglSupport \
-DFREECIV_ENABLE_FCMP_CLI=0 -DFREECIV_ENABLE_FCMP_QT=0 \
-DFREECIV_BUILD_LIBSERVER=0 -DFREECIV_ENABLE_RULEUP=0 \
-DFREECIV_ENABLE_RULEDIT=0 -DFREECIV_ENABLE_CIVMANUAL=0 \
-DKF5Archive_DIR=../emsdk/upstream/emscripten/cache/sysroot/lib/cmake \
-DCAN_UNWIND_STACK=0
VERBOSE=1 emmake make
- name: Debug
if: failure()
run: |
cat common/networking/CMakeFiles/networking.dir/includes_CXX.rsp
cat CMakeCache.txt
- uses: actions/upload-artifact@v4
if: failure()
with:
name: cmakecache
path: CMakeCache.txt
- name: Archive production artifacts
uses: actions/upload-artifact@v4
with:
name: wasm-client
path: freeciv21-client.*
snapcraft:
name: "Snap Package"
runs-on: ubuntu-latest
if: github.event_name == 'schedule' || github.event_name == 'workflow_dispatch'
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Install dependencies
run: |
sudo apt-get update
sudo apt-get install \
cmake \
ninja-build \
gettext \
qtbase5-dev \
libqt5svg5-dev \
libkf5archive-dev \
liblua5.3-dev \
libsqlite3-dev \
libsdl2-mixer-dev
- name: Configure
run: |
mkdir -p build/snap/local
cmake . -B build -G Ninja
cp data/icons/128x128/freeciv21-client.png build/snap/local
- uses: snapcore/action-build@v1
id: snapcraft
with:
path: build
- name: Upload a build
uses: actions/upload-artifact@v4
with:
name: snap
path: ${{ steps.snapcraft.outputs.snap }}
clang-format:
name: clang-format Code Formatter
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
fetch-depth: 0
- name: Run clang-format style check for C/C++
uses: jidicula/[email protected]
with:
clang-format-version: '11'
exclude-regex: 'dependencies'