forked from OpenKH/OpenKh
-
Notifications
You must be signed in to change notification settings - Fork 0
/
build.sh
75 lines (64 loc) · 2.52 KB
/
build.sh
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
#!/bin/sh
##############################################################################
# Build the entire solution in a very similar way of Azure Pipelines #
# #
# This script is essentially the same exact script of "build.ps1", but it #
# works on both Linux and macOS without necessarly install PowerShell. #
# #
# The only problem here is that .NET Core 3.1 sdk does not allow to build #
# OpenKh.sln because of the Windows-only projects there. So this script #
# temporarly creates a solution that only includes OpenKh.Command.* projects.#
# #
# This also print some configuration to easily access CLI tools from a shell.#
##############################################################################
export configuration="Release"
export verbosity="minimal"
export output="bin"
export solutionBase="OpenKh.Linux"
export solution="$solutionBase.sln"
git submodule update --init --recursive --depth 1
if [ $? -ne 0 ]
then
exit 1
fi
# Create solution for Linux and macOS
dotnet new sln -n $solutionBase --force
if [ $? -ne 0 ]
then
exit 1
fi
# Add only command line tools to the new solution
for project in ./OpenKh.Command.*/*.csproj; do
dotnet sln $solution add "$project"
done
for project in ./OpenKh.Game*/*.csproj; do
dotnet sln $solution add "$project"
done
# Restore NuGet packages
dotnet restore $solution
if [ $? -ne 0 ]
then
rm $solution
exit 1
fi
# Run tests
dotnet test $solution --configuration $configuration --verbosity $verbosity
if [ $? -ne 0 ]
then
rm $solution
exit 1
fi
# Publish solution
dotnet publish $solution --configuration $configuration --verbosity $verbosity --framework net6.0 --output $output /p:DebugType=None /p:DebugSymbols=false
rm $solution
# Print some potentially useful info
echo "It is very recommended to append to your '~/.profile' file the path of"
echo "OpenKH binaries and their alias to run them from any folder. You only"
echo "need to do it once per user."
echo "To do so, please execute the following commands:"
awk '{ sub("\r$", ""); print }' ./openkh_alias > ./bin/openkh_alias
chmod +x ./bin/OpenKh.Command.*
export OPENKH_BIN="$(realpath ./bin)"
echo "echo 'export OPENKH_BIN=\"$OPENKH_BIN\"' >> ~/.profile"
echo "echo 'export PATH=\$PATH:\$OPENKH_BIN' >> ~/.profile"
echo "echo 'source \$OPENKH_BIN/openkh_alias' >> ~/.profile"