Add deb and rpm packages on releases
This commit is contained in:
parent
1ab55d4732
commit
155a9e828d
49
.ci/linux/create-packages.sh
Executable file
49
.ci/linux/create-packages.sh
Executable file
@ -0,0 +1,49 @@
|
|||||||
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
|
#
|
||||||
|
# Create deb & rpm packages from the AppImage.
|
||||||
|
#
|
||||||
|
|
||||||
|
DIR=package.dir
|
||||||
|
VERSION=`git tag -l --points-at HEAD`
|
||||||
|
|
||||||
|
# Installing dependencies on travis.
|
||||||
|
if [ ! -z "$TRAVIS_OS_NAME" ]; then
|
||||||
|
sudo apt-add-repository -y ppa:brightbox/ruby-ng
|
||||||
|
sudo apt-get update -qq
|
||||||
|
sudo apt-get install -y ruby2.1 ruby-switch
|
||||||
|
sudo ruby-switch --set ruby2.1
|
||||||
|
sudo apt-get install -y ruby2.1-dev rpm libffi-dev
|
||||||
|
|
||||||
|
sudo gem install --no-ri --no-rdoc fpm
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Set up deb structure.
|
||||||
|
mkdir -p ${DIR}/usr/{bin,share/pixmaps,share/applications}
|
||||||
|
|
||||||
|
# Copy resources.
|
||||||
|
cp nheko*.AppImage ${DIR}/usr/bin/nheko
|
||||||
|
cp resources/nheko.desktop ${DIR}/usr/share/applications/nheko.desktop
|
||||||
|
cp resources/nheko.png ${DIR}/usr/share/pixmaps/nheko.png
|
||||||
|
|
||||||
|
for iconSize in 16 32 48 64 128 256 512; do
|
||||||
|
IconDir=${DIR}/usr/share/icons/hicolor/${iconSize}x${iconSize}/apps
|
||||||
|
mkdir -p ${IconDir}
|
||||||
|
cp resources/nheko-${iconSize}.png ${IconDir}/nheko.png
|
||||||
|
done
|
||||||
|
|
||||||
|
fpm --force \
|
||||||
|
-s dir \
|
||||||
|
--output-type deb \
|
||||||
|
--name nheko \
|
||||||
|
--description "Desktop client for the Matrix protocol" \
|
||||||
|
--url "https://github.com/mujx/nheko" \
|
||||||
|
--version ${VERSION} \
|
||||||
|
--architecture x86_64 \
|
||||||
|
--maintainer "mujx (https://github.com/mujx)" \
|
||||||
|
--license "GPLv3" \
|
||||||
|
--prefix / \
|
||||||
|
--deb-no-default-config-files \
|
||||||
|
--chdir ${DIR} usr
|
||||||
|
|
||||||
|
fpm -s deb -t rpm nheko_${VERSION}_amd64.deb
|
12
.travis.yml
12
.travis.yml
@ -52,6 +52,11 @@ script:
|
|||||||
- if [ $TRAVIS_OS_NAME == osx ]; then make lint; fi
|
- if [ $TRAVIS_OS_NAME == osx ]; then make lint; fi
|
||||||
- if [ $TRAVIS_OS_NAME == osx ] && [ $DEPLOYMENT == 1 ]; then ./.ci/macos/deploy.sh; fi
|
- if [ $TRAVIS_OS_NAME == osx ] && [ $DEPLOYMENT == 1 ]; then ./.ci/macos/deploy.sh; fi
|
||||||
- if [ $TRAVIS_OS_NAME == linux ] && [ $DEPLOYMENT == 1 ]; then ./.ci/linux/deploy.sh; fi
|
- if [ $TRAVIS_OS_NAME == linux ] && [ $DEPLOYMENT == 1 ]; then ./.ci/linux/deploy.sh; fi
|
||||||
|
- if [ $TRAVIS_OS_NAME == linux ] && [ $DEPLOYMENT == 1 ]; then ./.ci/linux/create-packages.sh; fi
|
||||||
|
|
||||||
|
before_deploy:
|
||||||
|
- export RELEASE_DEB_FILE=$(ls *.deb)
|
||||||
|
- export RELEASE_RPM_FILE=$(ls *.rpm)
|
||||||
|
|
||||||
deploy:
|
deploy:
|
||||||
- skip_cleanup: true
|
- skip_cleanup: true
|
||||||
@ -59,11 +64,16 @@ deploy:
|
|||||||
provider: releases
|
provider: releases
|
||||||
api_key:
|
api_key:
|
||||||
secure: oprXzESukFiXBeF2BXkXUlegsAQc95Ub4kc/OkoNFaYBvqpA+IGpWHmHCx5JPny/OT3Kc2Urpe2JUeGSWDHZ7UCKDjH+NzGP3uN82fHh/HiszG/Srw7+hWEHm1ve+gMK9GS8pr+yUsUrPP0UfVXlPoI4pBWa4zGi2Ndb/SqvjCgIHFLtGyoBo6CydKQ/AyWiXSMKDfJL+Dx4JLIPP4RTCBJy8ZrZ8m/a5Tgy4Ij6+djjrgYCZCEhGxSYw7xDIT/9SV8g9NkrbisqBDrILzAH8Yhe4XMRMXo88OAxV5+Vb9Rw1hrqczez6lpFDbJetv8MjofND+pSoAFwtjaL1wTFK9Ud6w4O9AuHlEQH9cGVdvsxFcosRwJVh58x51JM9ptoktqhx/HHJBTuCHCYYlHwtRwbwqnMYdLzKZG5FnujT8DG+9mcva1fL6tzW/XD505VPMWwXFC/2/pvolgAkTFFXYSALAwZlK3IgoXU8Gok/3B4iHofzQsFf6Yq3BI/88x7tVASUqiYhoKrO50+gb6pNIRCyWgGUiBEVXBp6Ziq3ORQPyQJg7i9HHUGTUu74yvGLHWLwjNQzZP/hxJZK3VlJxzyXntdOxiJc8iOzNrU+rPKBAlAaE6bQDOoniIysEgdD5BXHTLFzPvts4P1n2Ckor5/rNJ+qXR8GU+/y7e1GKU=
|
secure: oprXzESukFiXBeF2BXkXUlegsAQc95Ub4kc/OkoNFaYBvqpA+IGpWHmHCx5JPny/OT3Kc2Urpe2JUeGSWDHZ7UCKDjH+NzGP3uN82fHh/HiszG/Srw7+hWEHm1ve+gMK9GS8pr+yUsUrPP0UfVXlPoI4pBWa4zGi2Ndb/SqvjCgIHFLtGyoBo6CydKQ/AyWiXSMKDfJL+Dx4JLIPP4RTCBJy8ZrZ8m/a5Tgy4Ij6+djjrgYCZCEhGxSYw7xDIT/9SV8g9NkrbisqBDrILzAH8Yhe4XMRMXo88OAxV5+Vb9Rw1hrqczez6lpFDbJetv8MjofND+pSoAFwtjaL1wTFK9Ud6w4O9AuHlEQH9cGVdvsxFcosRwJVh58x51JM9ptoktqhx/HHJBTuCHCYYlHwtRwbwqnMYdLzKZG5FnujT8DG+9mcva1fL6tzW/XD505VPMWwXFC/2/pvolgAkTFFXYSALAwZlK3IgoXU8Gok/3B4iHofzQsFf6Yq3BI/88x7tVASUqiYhoKrO50+gb6pNIRCyWgGUiBEVXBp6Ziq3ORQPyQJg7i9HHUGTUu74yvGLHWLwjNQzZP/hxJZK3VlJxzyXntdOxiJc8iOzNrU+rPKBAlAaE6bQDOoniIysEgdD5BXHTLFzPvts4P1n2Ckor5/rNJ+qXR8GU+/y7e1GKU=
|
||||||
file: nheko-x86_64.AppImage
|
file_glob: true
|
||||||
|
file:
|
||||||
|
- nheko-x86_64.AppImage
|
||||||
|
- $RELEASE_DEB_FILE
|
||||||
|
- $RELEASE_RPM_FILE
|
||||||
on:
|
on:
|
||||||
condition: $TRAVIS_OS_NAME == linux && $DEPLOYMENT == 1
|
condition: $TRAVIS_OS_NAME == linux && $DEPLOYMENT == 1
|
||||||
repo: mujx/nheko
|
repo: mujx/nheko
|
||||||
tags: true
|
tags: true
|
||||||
|
|
||||||
- skip_cleanup: true
|
- skip_cleanup: true
|
||||||
overwrite: true
|
overwrite: true
|
||||||
provider: releases
|
provider: releases
|
||||||
|
@ -291,12 +291,15 @@ add_custom_target(LANG_QRC ALL DEPENDS ${QM_SRC})
|
|||||||
|
|
||||||
# Generate a qrc file for the translations
|
# Generate a qrc file for the translations
|
||||||
set(_qrc ${CMAKE_CURRENT_BINARY_DIR}/translations.qrc)
|
set(_qrc ${CMAKE_CURRENT_BINARY_DIR}/translations.qrc)
|
||||||
file(WRITE ${_qrc} "<RCC> <qresource prefix=\"/translations\">")
|
|
||||||
foreach(_lang ${QM_SRC})
|
if(NOT EXISTS ${_qrc})
|
||||||
|
file(WRITE ${_qrc} "<RCC> <qresource prefix=\"/translations\">")
|
||||||
|
foreach(_lang ${QM_SRC})
|
||||||
get_filename_component(_filename ${_lang} NAME)
|
get_filename_component(_filename ${_lang} NAME)
|
||||||
file(APPEND ${_qrc} "<file>${_filename}</file>")
|
file(APPEND ${_qrc} "<file>${_filename}</file>")
|
||||||
endforeach(_lang)
|
endforeach(_lang)
|
||||||
file(APPEND ${_qrc} "</qresource> </RCC>")
|
file(APPEND ${_qrc} "</qresource> </RCC>")
|
||||||
|
endif()
|
||||||
|
|
||||||
qt5_add_resources(LANG_QRC ${_qrc})
|
qt5_add_resources(LANG_QRC ${_qrc})
|
||||||
qt5_add_resources(QRC resources/res.qrc)
|
qt5_add_resources(QRC resources/res.qrc)
|
||||||
|
@ -31,6 +31,9 @@ RUN update-alternatives --install \
|
|||||||
clang-format \
|
clang-format \
|
||||||
/usr/bin/clang-format-5.0 100
|
/usr/bin/clang-format-5.0 100
|
||||||
|
|
||||||
|
RUN apt-get -y install ruby ruby-dev rubygems rpm && \
|
||||||
|
gem install --no-ri --no-rdoc fpm
|
||||||
|
|
||||||
ENV PATH=/opt/qt59/bin:$PATH
|
ENV PATH=/opt/qt59/bin:$PATH
|
||||||
|
|
||||||
RUN mkdir /build
|
RUN mkdir /build
|
||||||
|
9
Makefile
9
Makefile
@ -41,5 +41,14 @@ docker-app-image: image
|
|||||||
--privileged \
|
--privileged \
|
||||||
-v `pwd`:/build nheko-app-image make linux-appimage
|
-v `pwd`:/build nheko-app-image make linux-appimage
|
||||||
|
|
||||||
|
docker-packages: image
|
||||||
|
docker run \
|
||||||
|
-e CXX=g++-7 \
|
||||||
|
-e CC=gcc-7 \
|
||||||
|
-v `pwd`:/build nheko-app-image make release
|
||||||
|
docker run \
|
||||||
|
--privileged \
|
||||||
|
-v `pwd`:/build nheko-app-image ./.ci/linux/create-packages.sh
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -rf build
|
rm -rf build
|
||||||
|
Loading…
Reference in New Issue
Block a user