blob: 7293f63a7ad23ba584b1619247d7c01905a5e7cf (
plain)
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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
|
# template start; name=systemd-git; version=1.0;
# template start; name=base; version=1.0;
# Maintainer: Xenhat Hex (aur@xenh.at)
# Contributor: Justin Jagieniak <justin@jagieniak.net>
# Contributor: Rye Mutt
#
# shellcheck disable=2034,3030,2154
pkgdesc="A Second Life client with focus on performance and code correctness."
arch=('x86_64')
license=('LGPL')
options=('!buildflags' '!lto' '!strip')
url="https://www.alchemyviewer.org"
install=alchemy.install
# template end;
# template start; name=deps; version=1.0;
depends=(glu libgl libiconv libidn libjpeg-turbo libpng libxss libxml2 mesa nss openal sdl2 vlc xdg-desktop-portal zlib)
makedepends=('gcc' 'python-virtualenv' 'python-pip' 'git' 'xz')
optdepends=(
'alsa-lib: ALSA support'
'freealut: OpenAL support'
'gamemode: Gamemode support'
'lib32-libidn11: SLVoice support'
'lib32-libsndfile: SLVoice support'
'lib32-util-linux: SLVoice support'
'lib32-gstreamer0.10: SLVoice support'
'libpulse: PulseAudio support'
'mesa-libgl: Intel, Radeon, Nouveau support'
'nvidia-libgl: NVIDIA support'
'nvidia-utils: NVIDIA support'
'wine: More up-to-date, less buggy SLVoice support')
# template end;
pkgname=alchemy-next-viewer-git
pkgver=7.0.1.54509.4de3730a21
pkgrel=2
replaces=('alchemy-viewer-git')
provides=('alchemy-viewer')
source=("${pkgname}"::'git+https://git.alchemyviewer.org/alchemy/alchemy-next.git#branch='"${AL_BRANCH_OVERRIDE:-main}")
sha256sums=('SKIP')
depends+=(dbus-glib systemd-libs)
conflicts+=("alchemy-next-viewer-nosystemd-git")
# template start; name=pkgver; version=1.0;
pkgver() {
cd "${pkgname}" || exit 1
(
set -o pipefail
vwr_version=$(cat indra/newview/VIEWER_VERSION.txt)
rev=$(git rev-list --count HEAD)
short=$(git rev-parse --short HEAD)
printf "%s.%s.%s" "${vwr_version}" "${rev}" "${short}"
)
}
# template end;
# template start; name=prepare; version=1.0;
prepare() {
cd ${srcdir} || exit
msg2 "Creating virtual environment in $PWD"
virtualenv ".venv" -p python3
source "${srcdir}/.venv/bin/activate"
msg2 "Installing build toolchain..."
pip3 install --upgrade certifi --quiet
pip3 install --upgrade llbase --quiet
pip3 install --no-cache --upgrade autobuild --quiet
pip3 install --upgrade cmake ninja
}
# template end;
# template start; name=build; version=1.0;
build() {
cd "${pkgname}" || exit 1
source "${srcdir}/.venv/bin/activate"
build_jobs=$(nproc)
if [[ -z "$NO_SMART_JOB_COUNT" ]]; then
if [[ ${build_jobs} -gt 1 ]]; then
jobs=1
# The viewer requires an average of 2GB of memory per core to link
# Note: Behaviour change compared to the previous versions:
# This script will no longer try to allocate build memory into swap
# This is bad practice, and swap should be reserved to evict process
# memory from physical ram to make place for the current workset.
# This script will now try to check if swap is present and sufficent
# for the current used memory to be stored in swap before allocating,
# and will fallback to conservative allocation if swap is not available
gigperlinkprocess=2
mempercorekb=$((gigperlinkprocess * 1048576))
requiredmemorykb=$(($(nproc) * mempercorekb))
free_output="$(free --kilo --total | tail -n+2 | tr -s ' ')"
physical_output=$(grep "Mem:" <<<"$free_output")
#total_output=$(grep Total: <<< "$free_output")
usedmemorykbphysical=$(cut -d ' ' -f 3 <<<"$physical_output")
totalmemorykbphysical=$(cut -d ' ' -f 2 <<<"$physical_output")
swap_output=$(grep Swap: <<<"$free_output")
# Determine available swap space
availableswapkb=0
if [[ -n "$swap_output" ]]; then
availableswapkb=$(cut -d ' ' -f 4 <<<"$swap_output")
fi
availablememorykbphysical=$(cut -d ' ' -f 7 <<<"$free_output")
# msg2 "Total memory: $totalmemorykbphysical (includes swap)"
# msg2 "Available memory: $availablememorykbphysical"
# msg2 "Required memory: $requiredmemorykb"
# msg2 "Available physical memory on this system: $((availablememorykbphysical / 1024 / 1024)) GB"
# msg2 "Estimated required memory to build with all cores: $((requiredmemorykb / 1024 / 1024)) GB"
if [[ ${requiredmemorykb} -gt ${availablememorykbphysical} ]]; then
# msg2 "Warning: Not enough available physical memory to build with all cores"
if [[ ${usedmemorykbphysical} -lt ${availableswapkb} ]]; then
# use all physical ram as swap will do its job
# msg2 "There is enough free swap to store the currently used memory"
jobs=$(((totalmemorykbphysical / 1024 / 1024) / gigperlinkprocess))
else
# Not enough swap to hold ram contents, calculate manually
# msg2 "Allocating build jobs according to available physical memory ("$((availablememorykbphysical / 1024 / 1024))"/"$((requiredmemorykb / 1024 / 1024))"GB)..."
# FIXME: Goes one iteration beyond what it should
while [[ $((jobs * mempercorekb)) -lt ${availablememorykbphysical} ]]; do
jobs=$((jobs + 1))
msg2 "${jobs} jobs would consume $(((jobs * mempercorekb) / 1024 / 1024))GB"
done
# Back off one job count. Not sure why I have to do this but
# the loop is doing one extra iteration.
jobs=$((jobs - 1))
fi
build_jobs=${jobs}
# msg2 "Adjusted job count: ${build_jobs}"
fi
fi
fi
export AUTOBUILD_CPU_COUNT=$build_jobs
AL_CMAKE_CONFIG=(
-DLL_TESTS:BOOL=ON
-DDISABLE_FATAL_WARNINGS=ON
-DUSE_LTO:BOOL=OFF
-DVIEWER_CHANNEL="Alchemy Test"
)
#msg2 "BUILDENV: ${BUILDENV[*]}"
msg2 "Configuring build environment..."
# if [[ " ${BUILDENV[*]} " =~ ' ccache ' ]] && command -v ccache >/dev/null 2>&1; then
AL_CMAKE_CONFIG+=("-DCMAKE_CXX_COMPILER_LAUNCHER=$(which ccache)")
msg2 "ccache was found and will be used"
# fi
if command -v clang++ >/dev/null 2>&1; then
AL_CMAKE_CONFIG+=("-DCMAKE_C_COMPILER=$(which clang)")
AL_CMAKE_CONFIG+=("-DCMAKE_CXX_COMPILER=$(which clang++)")
msg2 "clang was found and will be used instead of gcc"
fi
_logfile="${srcdir}/build.${CARCH}.$(date +%s).log"
$prefix_cmd autobuild configure -A 64 -c ReleaseOS -- "${AL_CMAKE_CONFIG[@]}" > >(tee -a "$_logfile") 2> >(tee -a "$_logfile" >&2)
msg2 "Building with ${AUTOBUILD_CPU_COUNT} jobs"
$prefix_cmd autobuild build -A 64 -c ReleaseOS --no-configure > >(tee -a "$_logfile") 2> >(tee -a "$_logfile" >&2)
}
# template end;
# template start; name=package; version=1.0;
package() {
mkdir -p "${pkgdir}/opt"
mkdir -p "${pkgdir}/usr/local/share/applications"
# Patch shortcut maker
sed -i 's;Name=Alchemy;Name=Alchemy (git build);' "${pkgname}/build-linux-64/newview/packaged/etc/refresh_desktop_app_entry.sh"
sed -i 's;alchemy-viewer\.desktop;'"${pkgname}\.desktop"';' "${pkgname}/build-linux-64/newview/packaged/etc/refresh_desktop_app_entry.sh"
mv "${pkgname}/build-linux-64/newview/packaged" "${pkgdir}/opt/${pkgname}"
}
# template end;
# template end;
|