Skip to content

Commit

Permalink
squash
Browse files Browse the repository at this point in the history
  • Loading branch information
nic11 committed Dec 23, 2024
1 parent ea08224 commit 9f11620
Show file tree
Hide file tree
Showing 18 changed files with 556 additions and 46 deletions.
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
name: PR Ubuntu Docker
# TODO(#2280): keep in line with deploy.yml
name: PR Linux
on:
pull_request:
# any
Expand All @@ -10,20 +11,114 @@ env:
BUILD_TYPE: RelWithDebInfo

jobs:
pr-ubuntu-docker:
pr-docker:
strategy:
matrix:
base_system:
# The usual container used for all builds within the CI and the one
# we use as the base for server builds with preinstalled/cached deps
- ubuntu-vcpkg-deps

# Distros that our contributors are likely to run
- ubuntu-2204
- ubuntu-2404
- ubuntu-2410 # latest non-LTS
- debian-12
- archlinux

# TODO(#2280): add Fedora
# TODO(#2280): test gcc build, test build w/o ninja

runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
with:
submodules: recursive

- name: Get image to build upon
- name: Debug - print env
run: env

- name: Get/build image to use for building & testing
run: |
cat ${{github.workspace}}/misc/github_env_linux >> "$GITHUB_ENV"
set -x # print executed commands
echo Some debug data
id
uname -a
lsb_release -a
# cat ${{github.workspace}}/misc/github_env_linux >> "$GITHUB_ENV"
# get base image for this distro (or build configuration, in case with skymp-deps)
base_image="`misc/deps_linux/${{ matrix.base_system }}.sh --get-image-uri`"
docker run \
--name prepare_deps_container \
-v "${{github.workspace}}:/src" \
-e "CI=$CI" \
-e "CREATE_UID=`id -u`" \
"$base_image" \
'/src/misc/deps_linux/${{ matrix.base_system }}.sh' '--ensure-deps-noninteractive'
docker commit prepare_deps_container localhost/buildimage
- name: Debug - check build tools
uses: addnab/docker-run-action@v3
with:
image: localhost/buildimage
options: |
-v ${{github.workspace}}:/src
-w /src
-u skymp
run: |
print_info_unsafe() {
echo .
echo .
echo "=== Checking $1 ==="
out="`which $1`"
ret="$?"
if [ "$ret" != 0 -o -z "$out" ]; then
echo "Which exited with $ret $out"
return
fi
ls -lh "$out"
echo "version call:"
"$out" --version
}
print_info() {
print_info_unsafe "$@" || true
}
print_info clang++
print_info clang++-15
print_info cmake
print_info ninja
print_info node
print_info yarn
print_info git
print_info zip
print_info unzip
print_info curl
echo .
echo .
echo === misc ===
echo "current dir is $PWD"
echo /src:
ls -lh /src
echo .
echo .
echo === env ===
./build.sh --print-env
- name: Store SP types from commit
run: |
id
ls -lh ${{github.workspace}}/skyrim-platform/src/platform_se/codegen/convert-files
commit=$(< ${{github.workspace}}/skyrim-platform/src/platform_se/codegen/convert-files/skyrimPlatform.ts)
chmod 777 ${{github.workspace}}/skyrim-platform/src/platform_se/codegen/convert-files
echo "$commit" > ${{github.workspace}}/skyrim-platform/src/platform_se/codegen/convert-files/temp.txt
Expand Down Expand Up @@ -58,7 +153,7 @@ jobs:
- name: Prepare
uses: addnab/docker-run-action@v3
with:
image: ${{ env.SKYMP_VCPKG_DEPS_IMAGE }}
image: localhost/buildimage
options: |
-v ${{github.workspace}}:/src
run: |
Expand All @@ -68,7 +163,7 @@ jobs:
id: cmake_configure
uses: addnab/docker-run-action@v3
with:
image: ${{ env.SKYMP_VCPKG_DEPS_IMAGE }}
image: localhost/buildimage
options: |
-v ${{github.workspace}}:/src
-u skymp
Expand All @@ -78,23 +173,25 @@ jobs:
-DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} \
-DUNIT_DATA_DIR="/src/skyrim_data_files"
- name: Upload vcpkg failure logs
if: failure()
- name: Upload vcpkg logs
if: always()
uses: actions/upload-artifact@v4
with:
name: install-x64-linux-dbg-out.log
path: ${{github.workspace}}/vcpkg/buildtrees/rsm-bsa/install-x64-linux-dbg-out.log
name: ${{matrix.base_system}}_vcpkg_logs
path: |
${{github.workspace}}/build/vcpkg-bootstrap.log
${{github.workspace}}/vcpkg/buildtrees/**/*.log
- name: Upload compile_commands.json
uses: actions/upload-artifact@v4
with:
name: compile_commands.json
name: ${{matrix.base_system}}_compile_commands.json
path: ${{github.workspace}}/build/compile_commands.json

- name: Build
uses: addnab/docker-run-action@v3
with:
image: ${{ env.SKYMP_VCPKG_DEPS_IMAGE }}
image: localhost/buildimage
options: |
-v ${{github.workspace}}:/src
-u skymp
Expand All @@ -105,7 +202,7 @@ jobs:
- name: Prepare dist.tar.gz
uses: addnab/docker-run-action@v3
with:
image: ${{ env.SKYMP_VCPKG_DEPS_IMAGE }}
image: localhost/buildimage
options: |
-v ${{github.workspace}}:/src
-u skymp
Expand All @@ -116,7 +213,7 @@ jobs:
- name: Upload dist.tar.gz
uses: actions/upload-artifact@v4
with:
name: dist.tar.gz
name: ${{matrix.base_system}}_dist.tar.gz
path: ${{github.workspace}}/build/dist.tar.gz

- name: SP Types Check
Expand Down Expand Up @@ -148,7 +245,7 @@ jobs:
echo "ConstEnumApi.cpp has changed after running const_enum_extractor. Please re-run it locally and commit changes"
exit 1
fi
- name: SP Types Check failed - Here is what you can do
if: ${{ failure() && steps.sp_types_check.outcome == 'failure' }}
run: |
Expand All @@ -164,7 +261,7 @@ jobs:
- name: Test
uses: addnab/docker-run-action@v3
with:
image: ${{ env.SKYMP_VCPKG_DEPS_IMAGE }}
image: localhost/buildimage
options: |
-v ${{github.workspace}}:/src
-u skymp
Expand Down
3 changes: 3 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,10 @@ RUN useradd -m skymp
# It contains everything that should be installed on the system.
FROM skymp-runtime-base AS skymp-build-base

# TODO: replace with a call to ubuntu2204?

# TODO: update clang
# TODO: remove unnecessary packages based on ubuntu-2204.sh
RUN \
curl -fsSL https://dl.yarnpkg.com/debian/pubkey.gpg | gpg --dearmor > /usr/share/keyrings/yarnkey.gpg \
&& echo "deb [signed-by=/usr/share/keyrings/yarnkey.gpg] https://dl.yarnpkg.com/debian stable main" > /etc/apt/sources.list.d/yarn.list \
Expand Down
66 changes: 37 additions & 29 deletions build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ eecho() {
echo "$@" >&2
}

if [ "`basename "$PWD"`" = "build" ]; then
if [[ "`basename "$PWD"`" = "build" ]]; then
cd ..
fi

Expand All @@ -15,55 +15,63 @@ fi

export VCPKG_DISABLE_METRICS=1

export CC=/usr/bin/clang-15
export CPP=/usr/bin/clang-cpp-15
export CXX=/usr/bin/clang++-15
export LD=/usr/bin/ld.lld-15
if which clang++ > /dev/null 2>&1; then
export CC=/usr/bin/clang
export CPP=/usr/bin/clang-cpp
export CXX=/usr/bin/clang++
else
export CC=/usr/bin/clang-15
export CPP=/usr/bin/clang-cpp-15
export CXX=/usr/bin/clang++-15
fi

export CMAKE_C_COMPILER="$CC"
export CMAKE_CXX_COMPILER="$CXX"
export CMAKE_MAKE_PROGRAM="ninja"

# Some build dependencies require some strange stuff.
# Some other deps won't work if we can't call clang without exact version.
# It's better to make compatibility aliases than breaking main system's root.
export SKYMP_COMPAT_BIN="$PWD/build/skymp_compat/bin"
export PATH="$SKYMP_COMPAT_BIN:$PATH"
export CMAKE_MAKE_PROGRAM="/usr/bin/ninja"

if [ ! -d build ]; then
mkdir -v build
fi

if [ ! -d "$SKYMP_COMPAT_BIN" ]; then
mkdir -pv "$SKYMP_COMPAT_BIN"
ln -s "$CC" "$SKYMP_COMPAT_BIN/clang"
ln -s "$CXX" "$SKYMP_COMPAT_BIN/clang++"

echo "Set up compatibility path for build."
fi

# TODO reverse the order or use [[ ]] ?
if [ "$1" = "--configure" ]; then
if [[ "$1" = "--configure" ]]; then
shift && \
cd build && \
exec cmake -G "Ninja" .. -DCMAKE_EXPORT_COMPILE_COMMANDS=ON "$@"
elif [ "$1" = "--build" ]; then
elif [[ "$1" = "--build" ]]; then
shift && \
cd build && \
exec cmake --build . "$@"
elif [ "$1" = "--clean" ]; then
eecho "NOTE: --clean was deprecated, please use --clean-cpp or --clean-node"
elif [[ "$1" = "--clean" ]]; then
eecho "NOTE: --clean was deprecated, please use one of the options listed in --help"
eecho "Proceeding with cleaning cpp build data"
exec rm -rf build/
elif [ "$1" = "--clean-cpp" ]; then
elif [[ "$1" = "--clean-cpp" ]]; then
exec rm -rf build/
elif [ "$1" = "--clean-node" ]; then
echo not implemented yet, TODO delete node_modules dirs
elif [[ "$1" = "--clean-node" ]]; then
find -name node_modules -type d -prune -print0 | xargs -0 echo rm -rf
echo -n Ctrl-C to abort, Return/Enter to proceed
read
find -name node_modules -type d -prune -print0 | xargs --verbose -0 rm -rf
elif [[ "$1" = "--clean-vcpkg" ]]; then
(cd vcpkg && git clean -xfd --dry-run)
echo -n Ctrl-C to abort, Return/Enter to proceed
read
(cd vcpkg && git clean -xfd)
elif [[ "$1" = "--print-env" ]]; then
env
else
eecho "Usage:"
eecho " ./build.sh --configure <cmake args...>"
eecho " runs in build: cmake .. <some extra args> <your args>"
eecho "OR"
eecho " ./build.sh --build <cmake args...>"
eecho " runs in build: cmake build . <your args>"
eecho " you can add args like --target=unit"
eecho "OR"
eecho " ./build.sh --clean-<cpp|node|vcpkg>"
eecho "OR"
eecho " ./build.sh --clean-<cpp|node>"
eecho " ./build.sh --print-env"
if [[ "$1" != "--help" ]]; then
exit 1
fi
fi
2 changes: 1 addition & 1 deletion cmake/yarn.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ function(yarn_execute_command)

if("${A_RESULT_VARIABLE}" STREQUAL "")
if(NOT "${yarn_result}" STREQUAL "0")
message(FATAL_ERROR "yarn ${A_COMMAND} exited with ${yarn_result}:\n${yarn_output}\n${yarn_error}")
message(FATAL_ERROR "yarn ${A_COMMAND} (working dir ${A_WORKING_DIRECTORY}) exited with ${yarn_result}:\n${yarn_output}\n${yarn_error}")
endif()
else()
set("${A_RESULT_VARIABLE}" "${yarn_result}" PARENT_SCOPE)
Expand Down
3 changes: 3 additions & 0 deletions libespm/src/WRLD.cpp
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
#include "libespm/WRLD.h"

#include <algorithm>

#include "libespm/RecordHeaderAccess.h"

namespace espm {
Expand Down
Loading

0 comments on commit 9f11620

Please sign in to comment.