Add web build to Debian armhf package build
This commit is contained in:
parent
d22fd964c2
commit
b9e0a0b1ac
|
@ -29,6 +29,12 @@ RUN dpkg --add-architecture armhf \
|
||||||
&& cd cross-gcc-packages-amd64/cross-gcc-8-armhf \
|
&& cd cross-gcc-packages-amd64/cross-gcc-8-armhf \
|
||||||
&& apt-get install -y gcc-8-source libstdc++-8-dev-armhf-cross binutils-aarch64-linux-gnu bison flex libtool gdb sharutils netbase libmpc-dev libmpfr-dev libgmp-dev systemtap-sdt-dev autogen expect chrpath zlib1g-dev zip binutils-arm-linux-gnueabihf libc6-dev:armhf linux-libc-dev:armhf libgcc1:armhf libcurl4-openssl-dev:armhf libfontconfig1-dev:armhf libfreetype6-dev:armhf libssl-dev:armhf liblttng-ust0:armhf libstdc++-8-dev:armhf
|
&& apt-get install -y gcc-8-source libstdc++-8-dev-armhf-cross binutils-aarch64-linux-gnu bison flex libtool gdb sharutils netbase libmpc-dev libmpfr-dev libgmp-dev systemtap-sdt-dev autogen expect chrpath zlib1g-dev zip binutils-arm-linux-gnueabihf libc6-dev:armhf linux-libc-dev:armhf libgcc1:armhf libcurl4-openssl-dev:armhf libfontconfig1-dev:armhf libfreetype6-dev:armhf libssl-dev:armhf liblttng-ust0:armhf libstdc++-8-dev:armhf
|
||||||
|
|
||||||
|
# Install yarn package manager
|
||||||
|
RUN wget -q -O- https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \
|
||||||
|
&& echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \
|
||||||
|
&& apt update \
|
||||||
|
&& apt install -y yarn
|
||||||
|
|
||||||
# Link to docker-build script
|
# Link to docker-build script
|
||||||
RUN ln -sf ${PLATFORM_DIR}/docker-build.sh /docker-build.sh
|
RUN ln -sf ${PLATFORM_DIR}/docker-build.sh /docker-build.sh
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,12 @@ RUN wget https://download.visualstudio.microsoft.com/download/pr/3cb1d917-19cc-4
|
||||||
&& tar -xzf dotnet-sdk.tar.gz -C dotnet-sdk \
|
&& tar -xzf dotnet-sdk.tar.gz -C dotnet-sdk \
|
||||||
&& ln -s $( pwd )/dotnet-sdk/dotnet /usr/bin/dotnet
|
&& ln -s $( pwd )/dotnet-sdk/dotnet /usr/bin/dotnet
|
||||||
|
|
||||||
|
# Install yarn package manager
|
||||||
|
RUN wget -q -O- https://dl.yarnpkg.com/debian/pubkey.gpg | apt-key add - \
|
||||||
|
&& echo "deb https://dl.yarnpkg.com/debian/ stable main" | tee /etc/apt/sources.list.d/yarn.list \
|
||||||
|
&& apt update \
|
||||||
|
&& apt install -y yarn
|
||||||
|
|
||||||
# Link to docker-build script
|
# Link to docker-build script
|
||||||
RUN ln -sf ${PLATFORM_DIR}/docker-build.sh /docker-build.sh
|
RUN ln -sf ${PLATFORM_DIR}/docker-build.sh /docker-build.sh
|
||||||
|
|
||||||
|
|
|
@ -11,6 +11,21 @@ pushd ${SOURCE_DIR}
|
||||||
# Remove build-dep for dotnet-sdk-2.2, since it's not a package in this image
|
# Remove build-dep for dotnet-sdk-2.2, since it's not a package in this image
|
||||||
sed -i '/dotnet-sdk-2.2,/d' debian/control
|
sed -i '/dotnet-sdk-2.2,/d' debian/control
|
||||||
|
|
||||||
|
|
||||||
|
# Clone down and build Web frontend
|
||||||
|
web_build_dir="$( mktemp -d )"
|
||||||
|
web_target="${SOURCE_DIR}/MediaBrowser.WebDashboard/jellyfin-web"
|
||||||
|
git clone https://github.com/jellyfin/jellyfin-web.git ${web_build_dir}/
|
||||||
|
pushd ${web_build_dir}
|
||||||
|
if [[ -n ${web_branch} ]]; then
|
||||||
|
checkout -b origin/${web_branch}
|
||||||
|
fi
|
||||||
|
yarn install
|
||||||
|
yarn build
|
||||||
|
mkdir -p ${web_target}
|
||||||
|
mv dist/* ${web_target}/
|
||||||
|
popd
|
||||||
|
|
||||||
# Build DEB
|
# Build DEB
|
||||||
export CONFIG_SITE=/etc/dpkg-cross/cross-config.${ARCH}
|
export CONFIG_SITE=/etc/dpkg-cross/cross-config.${ARCH}
|
||||||
dpkg-buildpackage -us -uc -aarmhf
|
dpkg-buildpackage -us -uc -aarmhf
|
||||||
|
|
|
@ -2,6 +2,12 @@
|
||||||
|
|
||||||
source ../common.build.sh
|
source ../common.build.sh
|
||||||
|
|
||||||
|
args="${@}"
|
||||||
|
declare -a docker_envvars
|
||||||
|
for arg in ${args}; do
|
||||||
|
docker_envvars+=("-e ${arg}")
|
||||||
|
done
|
||||||
|
|
||||||
ARCH="$( arch )"
|
ARCH="$( arch )"
|
||||||
WORKDIR="$( pwd )"
|
WORKDIR="$( pwd )"
|
||||||
|
|
||||||
|
@ -35,7 +41,7 @@ mkdir -p "${package_temporary_dir}"
|
||||||
# Set up the build environment Docker image
|
# Set up the build environment Docker image
|
||||||
${docker_sudo} docker build ../.. -t "${image_name}" -f ./${DOCKERFILE}
|
${docker_sudo} docker build ../.. -t "${image_name}" -f ./${DOCKERFILE}
|
||||||
# Build the DEBs and copy out to ${package_temporary_dir}
|
# Build the DEBs and copy out to ${package_temporary_dir}
|
||||||
${docker_sudo} docker run --rm -v "${package_temporary_dir}:/dist" "${image_name}"
|
${docker_sudo} docker run --rm -v "${package_temporary_dir}:/dist" "${image_name}" ${docker_envvars}
|
||||||
# Move the DEBs to the output directory
|
# Move the DEBs to the output directory
|
||||||
mkdir -p "${output_dir}"
|
mkdir -p "${output_dir}"
|
||||||
mv "${package_temporary_dir}"/deb/* "${output_dir}"
|
mv "${package_temporary_dir}"/deb/* "${output_dir}"
|
||||||
|
|
Loading…
Reference in New Issue
Block a user