mirror of
https://github.com/LongSoft/UEFITool.git
synced 2025-05-14 15:15:04 -04:00
Add Linux x86-64 CI support
This commit is contained in:
parent
b35193b3df
commit
a03b87785f
3 changed files with 104 additions and 76 deletions
87
unixbuild.sh
Executable file
87
unixbuild.sh
Executable file
|
@ -0,0 +1,87 @@
|
|||
#!/bin/bash
|
||||
|
||||
UTARGET=$(uname)
|
||||
|
||||
if [ "$UTARGET" = "Darwin" ]; then
|
||||
export UPLATFORM="mac"
|
||||
elif [ "$UTARGET" = "Linux" ]; then
|
||||
export UPLATFORM="linux_$(uname -m)"
|
||||
else
|
||||
# Fallback to something...
|
||||
export UPLATFORM="$UTARGET"
|
||||
fi
|
||||
|
||||
if [ "$UPLATFORM" = "mac" ]; then
|
||||
if [ ! -d /opt/qt56sm ]; then
|
||||
curl -L -o /tmp/qt-5.6.3-static-mac.zip https://github.com/distdb/qtbuilds/blob/master/qt-5.6.3-static-mac.zip?raw=true || exit 1
|
||||
qtsum=$(shasum -a 256 /tmp/qt-5.6.3-static-mac.zip | cut -f1 -d' ')
|
||||
qtexpsum="214d22d8572ea6162753c8dd251d79275f3b22d49204718c637d722409e0cfcb"
|
||||
if [ "$qtsum" != "$qtexpsum" ]; then
|
||||
echo "Qt hash $qtsum does not match $qtexpsum"
|
||||
exit 1
|
||||
fi
|
||||
sudo mkdir -p /opt || exit 1
|
||||
cd /opt || exit 1
|
||||
sudo unzip -q /tmp/qt-5.6.3-static-mac.zip || exit 1
|
||||
cd - || exit 1
|
||||
fi
|
||||
|
||||
export PATH="/opt/qt56sm/bin:$PATH"
|
||||
fi
|
||||
|
||||
echo "Attempting to build UEFITool NE for ${UPLATFORM}..."
|
||||
|
||||
UEFITOOL_VER=$(cat UEFITool/uefitool.cpp | grep ^version | cut -d'"' -f2 | sed 's/NE alpha /A/')
|
||||
UEFIDUMP_VER=$(cat UEFIDump/uefidump_main.cpp | grep '"UEFIDump [0-9]' | cut -d'"' -f2 | cut -d' ' -f2)
|
||||
UEFIEXTRACT_VER=$(cat UEFIExtract/uefiextract_main.cpp | grep '"UEFIExtract [0-9]' | cut -d'"' -f2 | cut -d' ' -f2)
|
||||
UEFIFIND_VER=$(cat UEFIFind/uefifind_main.cpp | grep '"UEFIFind [0-9]' | cut -d'"' -f2 | cut -d' ' -f2)
|
||||
|
||||
build_tool() {
|
||||
echo "Building $1 $2"
|
||||
# Check version
|
||||
if [ "$(echo "$2" | grep '^[0-9]*\.[0-9]*\.[0-9]*$')" != "$2" ] && [ "$(echo "$2" | grep '^A[0-9]*$')" != "$2" ]; then
|
||||
echo "Invalid $1 version!"
|
||||
exit 1
|
||||
fi
|
||||
# Tools are in subdirectories
|
||||
cd "$1" || exit 1
|
||||
|
||||
# Build
|
||||
if [ "$3" != "" ]; then
|
||||
# -flto is flawed on CI atm
|
||||
if [ "$UPLATFORM" = "mac" ]; then
|
||||
qmake $3 QMAKE_CXXFLAGS+=-flto QMAKE_LFLAGS+=-flto CONFIG+=optimize_size || exit 1
|
||||
else
|
||||
qmake $3 CONFIG+=optimize_size
|
||||
fi
|
||||
else
|
||||
if [ "$UPLATFORM" = "mac" ]; then
|
||||
cmake -G "Unix Makefiles" -DCMAKE_CXX_FLAGS="-stdlib=libc++ -flto -Os -mmacosx-version-min=10.7" -DCMAKE_C_FLAGS="-flto -Os -mmacosx-version-min=10.7" || exit 1
|
||||
else
|
||||
cmake -G "Unix Makefiles" -DCMAKE_CXX_FLAGS="-Os" -DCMAKE_C_FLAGS="-Os" || exit 1
|
||||
fi
|
||||
fi
|
||||
make || exit 1
|
||||
|
||||
# Archive
|
||||
if [ "$1" = "UEFITool" ] && [ "$UPLATFORM" = "mac" ]; then
|
||||
strip -x UEFITool.app/Contents/MacOS/UEFITool || exit 1
|
||||
zip -qry ../dist/"${1}_NE_${2}_${UPLATFORM}.zip" UEFITool.app "${4}" || exit 1
|
||||
else
|
||||
strip -x "$1" || exit 1
|
||||
zip -qry ../dist/"${1}_NE_${2}_${UPLATFORM}.zip" "${1}" "${4}" || exit 1
|
||||
fi
|
||||
|
||||
# Return to parent
|
||||
cd - || exit 1
|
||||
}
|
||||
|
||||
rm -rf dist
|
||||
mkdir -p dist || exit 1
|
||||
|
||||
build_tool UEFITool "$UEFITOOL_VER" uefitool.pro
|
||||
build_tool UEFIDump "$UEFIDUMP_VER" ""
|
||||
build_tool UEFIExtract "$UEFIEXTRACT_VER" uefiextract.pro
|
||||
build_tool UEFIFind "$UEFIFIND_VER" uefifind.pro
|
||||
|
||||
exit 0
|
Loading…
Add table
Add a link
Reference in a new issue