mirror of
https://github.com/Nheko-Reborn/nheko.git
synced 2024-11-26 04:58:49 +03:00
Merge in master
This commit is contained in:
commit
bca4d7eef6
19 changed files with 185 additions and 150 deletions
|
@ -1,14 +1,15 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
# Runs the Clang Formatter
|
# Runs the Clang Formatter
|
||||||
# Return codes:
|
# Return codes:
|
||||||
# - 1 there are files to be formatted
|
# - 1 there are files to be formatted
|
||||||
# - 0 everything looks fine
|
# - 0 everything looks fine
|
||||||
|
|
||||||
set -o errexit
|
set -eu
|
||||||
set -o pipefail
|
|
||||||
set -o nounset
|
|
||||||
|
|
||||||
FILES=`find src -type f -type f \( -iname "*.cpp" -o -iname "*.h" \)`
|
FILES=$(find src -type f -type f \( -iname "*.cpp" -o -iname "*.h" \))
|
||||||
|
|
||||||
clang-format -i $FILES && git diff --exit-code
|
for f in $FILES
|
||||||
|
do
|
||||||
|
clang-format -i "$f" && git diff --exit-code
|
||||||
|
done;
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "osx" ]; then
|
if [ "$TRAVIS_OS_NAME" = "osx" ]; then
|
||||||
brew update
|
brew update
|
||||||
brew install qt5 lmdb clang-format ninja libsodium cmark
|
brew install qt5 lmdb clang-format ninja libsodium cmark
|
||||||
brew upgrade boost cmake icu4c || true
|
brew upgrade boost cmake icu4c || true
|
||||||
|
@ -20,7 +20,7 @@ if [ "$TRAVIS_OS_NAME" == "osx" ]; then
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "linux" ]; then
|
if [ "$TRAVIS_OS_NAME" = "linux" ]; then
|
||||||
|
|
||||||
if [ -z "$QT_VERSION" ]; then
|
if [ -z "$QT_VERSION" ]; then
|
||||||
QT_VERSION="592"
|
QT_VERSION="592"
|
||||||
|
@ -31,16 +31,21 @@ if [ "$TRAVIS_OS_NAME" == "linux" ]; then
|
||||||
sudo sh cmake-3.12.2-Linux-x86_64.sh --skip-license --prefix=/usr/local
|
sudo sh cmake-3.12.2-Linux-x86_64.sh --skip-license --prefix=/usr/local
|
||||||
|
|
||||||
mkdir -p build-libsodium
|
mkdir -p build-libsodium
|
||||||
pushd build-libsodium
|
( cd build-libsodium
|
||||||
curl -L https://download.libsodium.org/libsodium/releases/libsodium-1.0.16.tar.gz -o libsodium-1.0.16.tar.gz
|
curl -L https://download.libsodium.org/libsodium/releases/libsodium-1.0.16.tar.gz -o libsodium-1.0.16.tar.gz
|
||||||
tar xfz libsodium-1.0.16.tar.gz
|
tar xfz libsodium-1.0.16.tar.gz
|
||||||
cd libsodium-1.0.16/
|
cd libsodium-1.0.16/
|
||||||
./configure && make && make check && sudo make install
|
./configure && make && make check && sudo make install )
|
||||||
popd
|
|
||||||
|
|
||||||
sudo add-apt-repository -y ppa:beineri/opt-qt${QT_VERSION}-trusty
|
sudo add-apt-repository -y ppa:beineri/opt-qt${QT_VERSION}-trusty
|
||||||
sudo apt-get update -qq
|
# needed for git-lfs, otherwise the follow apt update fails.
|
||||||
sudo apt-get install -qq -y \
|
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 6B05F25D762E3157
|
||||||
|
|
||||||
|
# needed for mongodb repository: https://github.com/travis-ci/travis-ci/issues/9037
|
||||||
|
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 0C49F3730359A14518585931BC711F9BA15703C6
|
||||||
|
|
||||||
|
sudo apt update -qq
|
||||||
|
sudo apt install -qq -y \
|
||||||
qt${QT_PKG}base \
|
qt${QT_PKG}base \
|
||||||
qt${QT_PKG}tools \
|
qt${QT_PKG}tools \
|
||||||
qt${QT_PKG}svg \
|
qt${QT_PKG}svg \
|
||||||
|
|
|
@ -1,13 +1,17 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
APP=nheko
|
APP=nheko
|
||||||
DIR=${APP}.AppDir
|
DIR=${APP}.AppDir
|
||||||
TAG=`git tag -l --points-at HEAD`
|
# unused but may be useful...
|
||||||
|
#TAG=$(git tag -l --points-at HEAD)
|
||||||
|
|
||||||
# Set up AppImage structure.
|
# Set up AppImage structure.
|
||||||
mkdir -p ${DIR}/usr/{bin,lib,share/pixmaps,share/applications}
|
for d in bin lib share/pixmaps share/applications
|
||||||
|
do
|
||||||
|
mkdir -p ${DIR}/usr/$d
|
||||||
|
done
|
||||||
|
|
||||||
# Copy resources.
|
# Copy resources.
|
||||||
cp build/nheko ${DIR}/usr/bin
|
cp build/nheko ${DIR}/usr/bin
|
||||||
|
@ -30,15 +34,22 @@ unset QTDIR
|
||||||
unset QT_PLUGIN_PATH
|
unset QT_PLUGIN_PATH
|
||||||
unset LD_LIBRARY_PATH
|
unset LD_LIBRARY_PATH
|
||||||
|
|
||||||
export ARCH=$(uname -m)
|
ARCH=$(uname -m)
|
||||||
export LD_LIBRARY_PATH=$(pwd)/.deps/usr/lib/:$LD_LIBRARY_PATH
|
export ARCH
|
||||||
|
LD_LIBRARY_PATH=$(pwd)/.deps/usr/lib/:$LD_LIBRARY_PATH
|
||||||
|
export LD_LIBRARY_PATH
|
||||||
|
|
||||||
./linuxdeployqt*.AppImage ${DIR}/usr/share/applications/*.desktop -unsupported-allow-new-glibc -bundle-non-qt-libs
|
for res in ./linuxdeployqt*.AppImage
|
||||||
./linuxdeployqt*.AppImage ${DIR}/usr/share/applications/*.desktop -unsupported-allow-new-glibc -appimage
|
do
|
||||||
|
linuxdeployqt=$res
|
||||||
|
done
|
||||||
|
|
||||||
|
./"$linuxdeployqt" ${DIR}/usr/share/applications/*.desktop -unsupported-allow-new-glibc -bundle-non-qt-libs
|
||||||
|
./"$linuxdeployqt" ${DIR}/usr/share/applications/*.desktop -unsupported-allow-new-glibc -appimage
|
||||||
|
|
||||||
chmod +x nheko-*x86_64.AppImage
|
chmod +x nheko-*x86_64.AppImage
|
||||||
|
|
||||||
if [ ! -z $VERSION ]; then
|
if [ ! -z "$VERSION" ]; then
|
||||||
# commented out for now, as AppImage file appears to already contain the version.
|
# commented out for now, as AppImage file appears to already contain the version.
|
||||||
#mv nheko-*x86_64.AppImage nheko-${VERSION}-x86_64.AppImage
|
#mv nheko-*x86_64.AppImage nheko-${VERSION}-x86_64.AppImage
|
||||||
echo "nheko-${VERSION}-x86_64.AppImage"
|
echo "nheko-${VERSION}-x86_64.AppImage"
|
||||||
|
|
|
@ -1,29 +1,30 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env sh
|
||||||
|
|
||||||
set -ex
|
set -eux
|
||||||
|
|
||||||
TAG=`git tag -l --points-at HEAD`
|
# unused
|
||||||
|
#TAG=$(git tag -l --points-at HEAD)
|
||||||
|
|
||||||
# Add Qt binaries to path
|
# Add Qt binaries to path
|
||||||
PATH=/usr/local/opt/qt/bin/:${PATH}
|
PATH=/usr/local/opt/qt/bin/:${PATH}
|
||||||
|
|
||||||
pushd build
|
( cd build
|
||||||
|
# macdeployqt does not copy symlinks over.
|
||||||
|
# this specifically addresses icu4c issues but nothing else.
|
||||||
|
ICU_LIB="$(brew --prefix icu4c)/lib"
|
||||||
|
export ICU_LIB
|
||||||
|
mkdir -p nheko.app/Contents/Frameworks
|
||||||
|
find "${ICU_LIB}" -type l -name "*.dylib" -exec cp -a -n {} nheko.app/Contents/Frameworks/ \; || true
|
||||||
|
|
||||||
# macdeployqt does not copy symlinks over.
|
sudo macdeployqt nheko.app -dmg -always-overwrite
|
||||||
# this specifically addresses icu4c issues but nothing else.
|
|
||||||
export ICU_LIB="$(brew --prefix icu4c)/lib"
|
|
||||||
mkdir -p nheko.app/Contents/Frameworks
|
|
||||||
find ${ICU_LIB} -type l -name "*.dylib" -exec cp -a -n {} nheko.app/Contents/Frameworks/ \; || true
|
|
||||||
|
|
||||||
sudo macdeployqt nheko.app -dmg -always-overwrite
|
user=$(id -nu)
|
||||||
|
sudo chown "${user}" nheko.dmg
|
||||||
user=$(id -nu)
|
mv nheko.dmg ..
|
||||||
sudo chown ${user} nheko.dmg
|
)
|
||||||
mv nheko.dmg ..
|
|
||||||
popd
|
|
||||||
|
|
||||||
dmgbuild -s ./.ci/macos/settings.json "Nheko" nheko.dmg
|
dmgbuild -s ./.ci/macos/settings.json "Nheko" nheko.dmg
|
||||||
|
|
||||||
if [ ! -z $VERSION ]; then
|
if [ ! -z "$VERSION" ]; then
|
||||||
mv nheko.dmg nheko-${VERSION}.dmg
|
mv nheko.dmg "nheko-${VERSION}.dmg"
|
||||||
fi
|
fi
|
||||||
|
|
|
@ -2,30 +2,33 @@
|
||||||
|
|
||||||
set -ex
|
set -ex
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "linux" ]; then
|
if [ "$TRAVIS_OS_NAME" = "linux" ]; then
|
||||||
export CC=${C_COMPILER}
|
export CC=${C_COMPILER}
|
||||||
export CXX=${CXX_COMPILER}
|
export CXX=${CXX_COMPILER}
|
||||||
|
# make build use all available cores
|
||||||
|
export CMAKE_BUILD_PARALLEL_LEVEL=$(cat /proc/cpuinfo | awk '/^processor/{print $3}' | wc -l)
|
||||||
|
|
||||||
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/${C_COMPILER} 10
|
sudo update-alternatives --install /usr/bin/gcc gcc "/usr/bin/${C_COMPILER}" 10
|
||||||
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/${CXX_COMPILER} 10
|
sudo update-alternatives --install /usr/bin/g++ g++ "/usr/bin/${CXX_COMPILER}" 10
|
||||||
|
|
||||||
sudo update-alternatives --set gcc "/usr/bin/${C_COMPILER}"
|
sudo update-alternatives --set gcc "/usr/bin/${C_COMPILER}"
|
||||||
sudo update-alternatives --set g++ "/usr/bin/${CXX_COMPILER}"
|
sudo update-alternatives --set g++ "/usr/bin/${CXX_COMPILER}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "linux" ]; then
|
if [ "$TRAVIS_OS_NAME" = "linux" ]; then
|
||||||
source /opt/qt${QT_PKG}/bin/qt${QT_PKG}-env.sh || true;
|
# shellcheck disable=SC1090
|
||||||
|
. "/opt/qt${QT_PKG}/bin/qt${QT_PKG}-env.sh" || true;
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "osx" ]; then
|
if [ "$TRAVIS_OS_NAME" = "osx" ]; then
|
||||||
export CMAKE_PREFIX_PATH=/usr/local/opt/qt5
|
export CMAKE_PREFIX_PATH=/usr/local/opt/qt5
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Build & install dependencies
|
# Build & install dependencies
|
||||||
cmake -GNinja -Hdeps -B.deps \
|
cmake -GNinja -Hdeps -B.deps \
|
||||||
-DUSE_BUNDLED_BOOST=${USE_BUNDLED_BOOST} \
|
-DUSE_BUNDLED_BOOST="${USE_BUNDLED_BOOST}" \
|
||||||
-DUSE_BUNDLED_CMARK=${USE_BUNDLED_CMARK} \
|
-DUSE_BUNDLED_CMARK="${USE_BUNDLED_CMARK}" \
|
||||||
-DUSE_BUNDLED_JSON=${USE_BUNDLED_JSON}
|
-DUSE_BUNDLED_JSON="${USE_BUNDLED_JSON}"
|
||||||
cmake --build .deps
|
cmake --build .deps
|
||||||
|
|
||||||
# Build nheko
|
# Build nheko
|
||||||
|
@ -34,14 +37,14 @@ cmake -GNinja -H. -Bbuild \
|
||||||
-DCMAKE_INSTALL_PREFIX=.deps/usr
|
-DCMAKE_INSTALL_PREFIX=.deps/usr
|
||||||
cmake --build build
|
cmake --build build
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "osx" ]; then
|
if [ "$TRAVIS_OS_NAME" = "osx" ]; then
|
||||||
make lint;
|
make lint;
|
||||||
|
|
||||||
if [ $DEPLOYMENT == 1 ] && [ ! -z $VERSION ] ; then
|
if [ "$DEPLOYMENT" = 1 ] && [ ! -z "$VERSION" ] ; then
|
||||||
make macos-deploy;
|
make macos-deploy;
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$TRAVIS_OS_NAME" == "linux" ] && [ $DEPLOYMENT == 1 ] && [ ! -z $VERSION ]; then
|
if [ "$TRAVIS_OS_NAME" = "linux" ] && [ "$DEPLOYMENT" = 1 ] && [ ! -z "$VERSION" ]; then
|
||||||
make linux-deploy;
|
make linux-deploy;
|
||||||
fi
|
fi
|
||||||
|
|
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -101,3 +101,6 @@ package.dir
|
||||||
# Dependencies
|
# Dependencies
|
||||||
.third-party
|
.third-party
|
||||||
.deps
|
.deps
|
||||||
|
|
||||||
|
# Archives
|
||||||
|
*.bz2
|
||||||
|
|
22
CHANGELOG.md
22
CHANGELOG.md
|
@ -2,6 +2,28 @@
|
||||||
|
|
||||||
## [Unreleased]
|
## [Unreleased]
|
||||||
|
|
||||||
|
## [0.6.4] - 2019-05-22
|
||||||
|
|
||||||
|
*Most* of the below fixes are due to updates in mtxclient. Make sure you compile against 0.2.1
|
||||||
|
if you do not use the mtxclient bundled with nheko to get these fixes.
|
||||||
|
|
||||||
|
### Features
|
||||||
|
- Support V3 Rooms
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- Fix #19
|
||||||
|
- Fix initial sync issue caused by matrix-org/synapse#4898 (thanks @monokelpinguin)
|
||||||
|
- Add additional lmbd max_dbs setting (thanks @AndrewJDR)
|
||||||
|
- Update DE translations (thanks @miocho)
|
||||||
|
- Update Dutch translations (thanks @vistaus)
|
||||||
|
- Fix text input UI bug (thanks @0xd800)
|
||||||
|
- Update linkifyMessage to parse HTML better (thanks @monokelpinguin)
|
||||||
|
- Update to Boost 1.69.0
|
||||||
|
- Fix some memory-leak scenarios due to mismatched new / delete (thanks @monokelpinguin)
|
||||||
|
|
||||||
|
### Other Changes
|
||||||
|
- mtxclient now builds as a Shared Library by default (instead of statically)
|
||||||
|
|
||||||
## [0.6.3] - 2019-02-08
|
## [0.6.3] - 2019-02-08
|
||||||
|
|
||||||
### Features
|
### Features
|
||||||
|
|
|
@ -16,7 +16,7 @@ include(QtCommon)
|
||||||
project(nheko LANGUAGES C CXX)
|
project(nheko LANGUAGES C CXX)
|
||||||
set(CPACK_PACKAGE_VERSION_MAJOR "0")
|
set(CPACK_PACKAGE_VERSION_MAJOR "0")
|
||||||
set(CPACK_PACKAGE_VERSION_MINOR "6")
|
set(CPACK_PACKAGE_VERSION_MINOR "6")
|
||||||
set(CPACK_PACKAGE_VERSION_PATCH "3")
|
set(CPACK_PACKAGE_VERSION_PATCH "4")
|
||||||
set(PROJECT_VERSION_MAJOR ${CPACK_PACKAGE_VERSION_MAJOR})
|
set(PROJECT_VERSION_MAJOR ${CPACK_PACKAGE_VERSION_MAJOR})
|
||||||
set(PROJECT_VERSION_MINOR ${CPACK_PACKAGE_VERSION_MINOR})
|
set(PROJECT_VERSION_MINOR ${CPACK_PACKAGE_VERSION_MINOR})
|
||||||
set(PROJECT_VERSION_PATCH ${CPACK_PACKAGE_VERSION_PATCH})
|
set(PROJECT_VERSION_PATCH ${CPACK_PACKAGE_VERSION_PATCH})
|
||||||
|
@ -104,7 +104,8 @@ if(NOT MSVC)
|
||||||
-pedantic \
|
-pedantic \
|
||||||
-fsized-deallocation \
|
-fsized-deallocation \
|
||||||
-fdiagnostics-color=always \
|
-fdiagnostics-color=always \
|
||||||
-Wunreachable-code"
|
-Wunreachable-code \
|
||||||
|
-std=c++14"
|
||||||
)
|
)
|
||||||
if (NOT CMAKE_COMPILER_IS_GNUCXX)
|
if (NOT CMAKE_COMPILER_IS_GNUCXX)
|
||||||
# -Wshadow is buggy and broken in GCC, so do not enable it.
|
# -Wshadow is buggy and broken in GCC, so do not enable it.
|
||||||
|
|
|
@ -2,10 +2,11 @@ nheko
|
||||||
----
|
----
|
||||||
[![Build Status](https://travis-ci.org/Nheko-Reborn/nheko.svg?branch=master)](https://travis-ci.org/Nheko-Reborn/nheko)
|
[![Build Status](https://travis-ci.org/Nheko-Reborn/nheko.svg?branch=master)](https://travis-ci.org/Nheko-Reborn/nheko)
|
||||||
[![Build status](https://ci.appveyor.com/api/projects/status/07qrqbfylsg4hw2h/branch/master?svg=true)](https://ci.appveyor.com/project/redsky17/nheko/branch/master)
|
[![Build status](https://ci.appveyor.com/api/projects/status/07qrqbfylsg4hw2h/branch/master?svg=true)](https://ci.appveyor.com/project/redsky17/nheko/branch/master)
|
||||||
[![Stable Version](https://img.shields.io/badge/download-stable-green.svg)](https://github.com/Nheko-Reborn/nheko/releases/v0.6.3)
|
[![Stable Version](https://img.shields.io/badge/download-stable-green.svg)](https://github.com/Nheko-Reborn/nheko/releases/v0.6.4)
|
||||||
[![Nightly](https://img.shields.io/badge/download-nightly-green.svg)](https://github.com/Nheko-Reborn/nheko/releases/nightly)
|
[![Nightly](https://img.shields.io/badge/download-nightly-green.svg)](https://bintray.com/nheko-reborn/nheko/nheko)
|
||||||
[![#nheko-reborn:matrix.org](https://img.shields.io/matrix/nheko-reborn:matrix.org.svg?label=%23nheko-reborn:matrix.org)](https://matrix.to/#/#nheko-reborn:matrix.org)
|
[![#nheko-reborn:matrix.org](https://img.shields.io/matrix/nheko-reborn:matrix.org.svg?label=%23nheko-reborn:matrix.org)](https://matrix.to/#/#nheko-reborn:matrix.org)
|
||||||
[![AUR: nheko](https://img.shields.io/badge/AUR-nheko-blue.svg)](https://aur.archlinux.org/packages/nheko)
|
[![AUR: nheko](https://img.shields.io/badge/AUR-nheko-blue.svg)](https://aur.archlinux.org/packages/nheko)
|
||||||
|
<a href='https://flathub.org/apps/details/io.github.NhekoReborn.Nheko'><img width='240' alt='Download on Flathub' src='https://flathub.org/assets/badges/flathub-badge-en.png'/></a>
|
||||||
|
|
||||||
The motivation behind the project is to provide a native desktop app for [Matrix] that
|
The motivation behind the project is to provide a native desktop app for [Matrix] that
|
||||||
feels more like a mainstream chat app ([Riot], Telegram etc) and less like an IRC client.
|
feels more like a mainstream chat app ([Riot], Telegram etc) and less like an IRC client.
|
||||||
|
@ -70,7 +71,7 @@ sudo apk add nheko
|
||||||
#### Flatpak
|
#### Flatpak
|
||||||
|
|
||||||
```
|
```
|
||||||
flatpak install flathub io.github.mujx.Nheko
|
flatpak install flathub io.github.NhekoReborn.Nheko
|
||||||
```
|
```
|
||||||
|
|
||||||
#### macOS (10.12 and above)
|
#### macOS (10.12 and above)
|
||||||
|
|
21
appveyor.yml
21
appveyor.yml
|
@ -1,6 +1,6 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
version: 0.6.3-{build}
|
version: 0.6.4-{build}
|
||||||
|
|
||||||
configuration: Release
|
configuration: Release
|
||||||
image: Visual Studio 2017
|
image: Visual Studio 2017
|
||||||
|
@ -20,7 +20,9 @@ install:
|
||||||
- set PATH=%PATH%;%QT_DIR%\bin;C:\MinGW\bin
|
- set PATH=%PATH%;%QT_DIR%\bin;C:\MinGW\bin
|
||||||
- set PATH=%PATH%;C:\mingw-w64\x86_64-7.2.0-posix-seh-rt_v5-rev1\mingw64\bin
|
- set PATH=%PATH%;C:\mingw-w64\x86_64-7.2.0-posix-seh-rt_v5-rev1\mingw64\bin
|
||||||
- call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars64.bat"
|
- call "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars64.bat"
|
||||||
|
- cd "C:\Tools\vcpkg"&& git pull && .\bootstrap-vcpkg.bat && cd %APPVEYOR_BUILD_FOLDER%
|
||||||
- vcpkg install
|
- vcpkg install
|
||||||
|
nlohmann-json:%PLATFORM%-windows
|
||||||
boost-asio:%PLATFORM%-windows
|
boost-asio:%PLATFORM%-windows
|
||||||
boost-beast:%PLATFORM%-windows
|
boost-beast:%PLATFORM%-windows
|
||||||
boost-iostreams:%PLATFORM%-windows
|
boost-iostreams:%PLATFORM%-windows
|
||||||
|
@ -37,8 +39,8 @@ build_script:
|
||||||
# VERSION format: branch-master/branch-1.2
|
# VERSION format: branch-master/branch-1.2
|
||||||
# INSTVERSION format: x.y.z
|
# INSTVERSION format: x.y.z
|
||||||
# WINVERSION format: 9999.0.0.123/1.2.0.234
|
# WINVERSION format: 9999.0.0.123/1.2.0.234
|
||||||
- if "%APPVEYOR_REPO_TAG%"=="false" set INSTVERSION=0.6.3
|
- if "%APPVEYOR_REPO_TAG%"=="false" set INSTVERSION=0.6.4
|
||||||
- if "%APPVEYOR_REPO_TAG%"=="false" set VERSION=0.6.3
|
- if "%APPVEYOR_REPO_TAG%"=="false" set VERSION=0.6.4
|
||||||
- if "%APPVEYOR_REPO_TAG%"=="false" if "%APPVEYOR_REPO_BRANCH%"=="master" set INSTVERSION=9999.0
|
- if "%APPVEYOR_REPO_TAG%"=="false" if "%APPVEYOR_REPO_BRANCH%"=="master" set INSTVERSION=9999.0
|
||||||
- if "%APPVEYOR_REPO_TAG%"=="false" set WINVERSION=%INSTVERSION%.0.%APPVEYOR_BUILD_NUMBER%
|
- if "%APPVEYOR_REPO_TAG%"=="false" set WINVERSION=%INSTVERSION%.0.%APPVEYOR_BUILD_NUMBER%
|
||||||
# VERSION format: v1.2.3/v1.3.4
|
# VERSION format: v1.2.3/v1.3.4
|
||||||
|
@ -56,7 +58,8 @@ build_script:
|
||||||
- cmake -G "Visual Studio 15 2017 Win64" -Hdeps -B.deps
|
- cmake -G "Visual Studio 15 2017 Win64" -Hdeps -B.deps
|
||||||
-DCMAKE_TOOLCHAIN_FILE=C:/Tools/vcpkg/scripts/buildsystems/vcpkg.cmake
|
-DCMAKE_TOOLCHAIN_FILE=C:/Tools/vcpkg/scripts/buildsystems/vcpkg.cmake
|
||||||
-DUSE_BUNDLED_BOOST=OFF
|
-DUSE_BUNDLED_BOOST=OFF
|
||||||
-DUSE_BUNDLED_JSON=ON
|
-DUSE_BUNDLED_JSON=OFF
|
||||||
|
-DMTX_STATIC=ON
|
||||||
- cmake --build .deps --config Release
|
- cmake --build .deps --config Release
|
||||||
|
|
||||||
# Build nheko
|
# Build nheko
|
||||||
|
@ -102,8 +105,8 @@ after_build:
|
||||||
# Copy installer data
|
# Copy installer data
|
||||||
- copy %BUILD%\resources\nheko.ico installer\config
|
- copy %BUILD%\resources\nheko.ico installer\config
|
||||||
- copy %BUILD%\resources\nheko.png installer\config
|
- copy %BUILD%\resources\nheko.png installer\config
|
||||||
- copy %BUILD%\LICENSE installer\packages\com.mujx.nheko\meta\license.txt
|
- copy %BUILD%\COPYING installer\packages\com.mujx.nheko\meta\license.txt
|
||||||
- copy %BUILD%\LICENSE installer\packages\com.mujx.nheko.cleanup\meta\license.txt
|
- copy %BUILD%\COPYING installer\packages\com.mujx.nheko.cleanup\meta\license.txt
|
||||||
- copy %BUILD%\deploy\installer\config.xml installer\config
|
- copy %BUILD%\deploy\installer\config.xml installer\config
|
||||||
- copy %BUILD%\deploy\installer\controlscript.qs installer\config
|
- copy %BUILD%\deploy\installer\controlscript.qs installer\config
|
||||||
- copy %BUILD%\deploy\installer\uninstall.qs installer\packages\com.mujx.nheko\data
|
- copy %BUILD%\deploy\installer\uninstall.qs installer\packages\com.mujx.nheko\data
|
||||||
|
@ -112,9 +115,9 @@ after_build:
|
||||||
- copy %BUILD%\deploy\installer\cleanup\package.xml installer\packages\com.mujx.nheko.cleanup\meta
|
- copy %BUILD%\deploy\installer\cleanup\package.xml installer\packages\com.mujx.nheko.cleanup\meta
|
||||||
- copy %BUILD%\deploy\installer\cleanup\installscript.qs installer\packages\com.mujx.nheko.cleanup\meta
|
- copy %BUILD%\deploy\installer\cleanup\installscript.qs installer\packages\com.mujx.nheko.cleanup\meta
|
||||||
# Amend version and date
|
# Amend version and date
|
||||||
- sed -i "s/__VERSION__/0.6.3/" installer\config\config.xml
|
- sed -i "s/__VERSION__/0.6.4/" installer\config\config.xml
|
||||||
- sed -i "s/__VERSION__/0.6.3/" installer\packages\com.mujx.nheko\meta\package.xml
|
- sed -i "s/__VERSION__/0.6.4/" installer\packages\com.mujx.nheko\meta\package.xml
|
||||||
- sed -i "s/__VERSION__/0.6.3/" installer\packages\com.mujx.nheko.cleanup\meta\package.xml
|
- sed -i "s/__VERSION__/0.6.4/" installer\packages\com.mujx.nheko.cleanup\meta\package.xml
|
||||||
- sed -i "s/__DATE__/%DATE%/" installer\packages\com.mujx.nheko\meta\package.xml
|
- sed -i "s/__DATE__/%DATE%/" installer\packages\com.mujx.nheko\meta\package.xml
|
||||||
- sed -i "s/__DATE__/%DATE%/" installer\packages\com.mujx.nheko.cleanup\meta\package.xml
|
- sed -i "s/__DATE__/%DATE%/" installer\packages\com.mujx.nheko.cleanup\meta\package.xml
|
||||||
# Copy nheko data
|
# Copy nheko data
|
||||||
|
|
7
deps/CMakeLists.txt
vendored
7
deps/CMakeLists.txt
vendored
|
@ -30,6 +30,7 @@ option(USE_BUNDLED_LMDBXX "Use the bundled version of lmdbxx." ${USE_BUNDLED})
|
||||||
option(USE_BUNDLED_MATRIX_CLIENT "Use the bundled version of mtxclient."
|
option(USE_BUNDLED_MATRIX_CLIENT "Use the bundled version of mtxclient."
|
||||||
${USE_BUNDLED})
|
${USE_BUNDLED})
|
||||||
option(USE_BUNDLED_JSON "Use the bundled version of nlohmann json." ${USE_BUNDLED})
|
option(USE_BUNDLED_JSON "Use the bundled version of nlohmann json." ${USE_BUNDLED})
|
||||||
|
option(MTX_STATIC "Compile / link bundled mtx client statically" OFF)
|
||||||
|
|
||||||
if(USE_BUNDLED_BOOST)
|
if(USE_BUNDLED_BOOST)
|
||||||
# bundled boost is 1.68, which requires CMake 3.12 or greater.
|
# bundled boost is 1.68, which requires CMake 3.12 or greater.
|
||||||
|
@ -39,9 +40,9 @@ endif()
|
||||||
include(ExternalProject)
|
include(ExternalProject)
|
||||||
|
|
||||||
set(BOOST_URL
|
set(BOOST_URL
|
||||||
https://dl.bintray.com/boostorg/release/1.68.0/source/boost_1_68_0.tar.bz2)
|
https://dl.bintray.com/boostorg/release/1.69.0/source/boost_1_69_0.tar.bz2)
|
||||||
set(BOOST_SHA256
|
set(BOOST_SHA256
|
||||||
7f6130bc3cf65f56a618888ce9d5ea704fa10b462be126ad053e80e553d6d8b7)
|
8f32d4617390d1c2d16f26a27ab60d97807b35440d45891fa340fc2648b04406)
|
||||||
|
|
||||||
set(
|
set(
|
||||||
MTXCLIENT_URL
|
MTXCLIENT_URL
|
||||||
|
@ -63,7 +64,7 @@ set(
|
||||||
set(LMDBXX_HASH
|
set(LMDBXX_HASH
|
||||||
c57b501a4e8fa1187fa7fd348da415c7685a50a7cb25b17b3f257b9e9426f73d)
|
c57b501a4e8fa1187fa7fd348da415c7685a50a7cb25b17b3f257b9e9426f73d)
|
||||||
|
|
||||||
set(OLM_URL https://git.matrix.org/git/olm.git)
|
set(OLM_URL https://gitlab.matrix.org/matrix-org/olm.git)
|
||||||
set(OLM_TAG 4065c8e11a33ba41133a086ed3de4da94dcb6bae)
|
set(OLM_TAG 4065c8e11a33ba41133a086ed3de4da94dcb6bae)
|
||||||
|
|
||||||
set(CMARK_URL https://github.com/commonmark/cmark/archive/0.28.3.tar.gz)
|
set(CMARK_URL https://github.com/commonmark/cmark/archive/0.28.3.tar.gz)
|
||||||
|
|
2
deps/cmake/Boost.cmake
vendored
2
deps/cmake/Boost.cmake
vendored
|
@ -16,7 +16,7 @@ ExternalProject_Add(
|
||||||
CONFIGURE_COMMAND ${DEPS_BUILD_DIR}/boost/bootstrap.sh
|
CONFIGURE_COMMAND ${DEPS_BUILD_DIR}/boost/bootstrap.sh
|
||||||
--with-libraries=random,thread,system,iostreams,atomic,chrono,date_time,regex
|
--with-libraries=random,thread,system,iostreams,atomic,chrono,date_time,regex
|
||||||
--prefix=${DEPS_INSTALL_DIR}
|
--prefix=${DEPS_INSTALL_DIR}
|
||||||
BUILD_COMMAND ${DEPS_BUILD_DIR}/boost/b2 -d0 cxxstd=14 variant=release link=static threading=multi --layout=system
|
BUILD_COMMAND ${DEPS_BUILD_DIR}/boost/b2 -d0 cxxstd=14 variant=release link=shared runtime-link=shared threading=multi --layout=system
|
||||||
INSTALL_COMMAND ${DEPS_BUILD_DIR}/boost/b2 -d0 install
|
INSTALL_COMMAND ${DEPS_BUILD_DIR}/boost/b2 -d0 install
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
7
deps/cmake/MatrixClient.cmake
vendored
7
deps/cmake/MatrixClient.cmake
vendored
|
@ -13,6 +13,12 @@ endif()
|
||||||
# instead of the bundled version of Boost, like we wanted.
|
# instead of the bundled version of Boost, like we wanted.
|
||||||
set(BOOST_BUNDLE_ROOT "-DBOOST_ROOT=${DEPS_BUILD_DIR}/boost")
|
set(BOOST_BUNDLE_ROOT "-DBOOST_ROOT=${DEPS_BUILD_DIR}/boost")
|
||||||
|
|
||||||
|
set (MTX_SHARED ON)
|
||||||
|
|
||||||
|
if (MTX_STATIC)
|
||||||
|
set (MTX_SHARED OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
ExternalProject_Add(
|
ExternalProject_Add(
|
||||||
MatrixClient
|
MatrixClient
|
||||||
|
|
||||||
|
@ -28,6 +34,7 @@ ExternalProject_Add(
|
||||||
-DBUILD_LIB_EXAMPLES=OFF
|
-DBUILD_LIB_EXAMPLES=OFF
|
||||||
-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}
|
-DCMAKE_TOOLCHAIN_FILE=${CMAKE_TOOLCHAIN_FILE}
|
||||||
${BOOST_BUNDLE_ROOT}
|
${BOOST_BUNDLE_ROOT}
|
||||||
|
-DBUILD_SHARED_LIBS=${MTX_SHARED}
|
||||||
${PLATFORM_FLAGS}
|
${PLATFORM_FLAGS}
|
||||||
${DEPS_BUILD_DIR}/mtxclient
|
${DEPS_BUILD_DIR}/mtxclient
|
||||||
BUILD_COMMAND
|
BUILD_COMMAND
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- Copyright 2019 mujx, nheko reborn developers -->
|
||||||
<component type="desktop">
|
<component type="desktop">
|
||||||
<id>nheko.desktop</id>
|
<id>nheko.desktop</id>
|
||||||
<metadata_license>CC0-1.0</metadata_license>
|
<metadata_license>CC0-1.0</metadata_license>
|
||||||
|
@ -10,15 +11,39 @@
|
||||||
desktop app for Matrix that feels more like a mainstream
|
desktop app for Matrix that feels more like a mainstream
|
||||||
chat app.</p>
|
chat app.</p>
|
||||||
</description>
|
</description>
|
||||||
|
<translation/>
|
||||||
|
<languages>
|
||||||
|
<lang>de</lang>
|
||||||
|
<lang>el</lang>
|
||||||
|
<lang>en</lang>
|
||||||
|
<lang>fr</lang>
|
||||||
|
<lang>nl</lang>
|
||||||
|
<lang>pl</lang>
|
||||||
|
<lang>ru</lang>
|
||||||
|
<lang>zh_CN</lang>
|
||||||
|
</languages>
|
||||||
|
<content_rating type="oars-1.0">
|
||||||
|
<content_attribute id="social-chat">intense</content_attribute>
|
||||||
|
<content_attribute id="social-audio">intense</content_attribute>
|
||||||
|
</content_rating>
|
||||||
<screenshots>
|
<screenshots>
|
||||||
<screenshot type="default">
|
<screenshot type="default">
|
||||||
<image>
|
<image>https://nheko-reborn.github.io/images/screenshots/chat-resized.png</image>
|
||||||
https://dl.dropboxusercontent.com/s/x638uft1fcnybv9/nheko-gnome.png</image>
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://nheko-reborn.github.io/images/screenshots/Start-resized.png</image>
|
||||||
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://nheko-reborn.github.io/images/screenshots/settings-resized.png</image>
|
||||||
|
</screenshot>
|
||||||
|
<screenshot>
|
||||||
|
<image>https://nheko-reborn.github.io/images/screenshots/login-resized.png</image>
|
||||||
</screenshot>
|
</screenshot>
|
||||||
</screenshots>
|
</screenshots>
|
||||||
<url type="homepage">https://github.com/Nheko-Reborn/nheko</url>
|
<url type="homepage">https://github.com/Nheko-Reborn/nheko</url>
|
||||||
<update_contact>https://github.com/Nheko-Reborn</update_contact>
|
<update_contact>https://github.com/Nheko-Reborn</update_contact>
|
||||||
<releases>
|
<releases>
|
||||||
|
<release version="0.6.4" date="2019-05-22" />
|
||||||
<release version="0.6.3" date="2019-02-08" />
|
<release version="0.6.3" date="2019-02-08" />
|
||||||
<release version="0.6.2" date="2018-10-07" />
|
<release version="0.6.2" date="2018-10-07" />
|
||||||
<release version="0.6.1" date="2018-09-26" />
|
<release version="0.6.1" date="2018-09-26" />
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
#!/bin/bash -e
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -eu
|
||||||
|
|
||||||
PREFIX=$(basename "$(pwd -P)")
|
PREFIX=$(basename "$(pwd -P)")
|
||||||
{
|
{
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
#!/bin/bash
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -eu
|
||||||
|
|
||||||
#
|
#
|
||||||
# Manually generate icon set for MacOS.
|
# Manually generate icon set for MacOS.
|
||||||
|
@ -9,17 +11,17 @@ OUTPUT=nheko
|
||||||
|
|
||||||
mkdir ${OUTPUT}.iconset
|
mkdir ${OUTPUT}.iconset
|
||||||
|
|
||||||
sips -z 16 16 ${INPUT} --out ${OUTPUT}.iconset/icon_16x16.png
|
sips -z 16 16 "${INPUT}" --out ${OUTPUT}.iconset/icon_16x16.png
|
||||||
sips -z 32 32 ${INPUT} --out ${OUTPUT}.iconset/icon_16x16@2x.png
|
sips -z 32 32 "${INPUT}" --out ${OUTPUT}.iconset/icon_16x16@2x.png
|
||||||
sips -z 32 32 ${INPUT} --out ${OUTPUT}.iconset/icon_32x32.png
|
sips -z 32 32 "${INPUT}" --out ${OUTPUT}.iconset/icon_32x32.png
|
||||||
sips -z 64 64 ${INPUT} --out ${OUTPUT}.iconset/icon_32x32@2x.png
|
sips -z 64 64 "${INPUT}" --out ${OUTPUT}.iconset/icon_32x32@2x.png
|
||||||
sips -z 128 128 ${INPUT} --out ${OUTPUT}.iconset/icon_128x128.png
|
sips -z 128 128 "${INPUT}" --out ${OUTPUT}.iconset/icon_128x128.png
|
||||||
sips -z 256 256 ${INPUT} --out ${OUTPUT}.iconset/icon_128x128@2x.png
|
sips -z 256 256 "${INPUT}" --out ${OUTPUT}.iconset/icon_128x128@2x.png
|
||||||
sips -z 256 256 ${INPUT} --out ${OUTPUT}.iconset/icon_256x256.png
|
sips -z 256 256 "${INPUT}" --out ${OUTPUT}.iconset/icon_256x256.png
|
||||||
sips -z 512 512 ${INPUT} --out ${OUTPUT}.iconset/icon_256x256@2x.png
|
sips -z 512 512 "${INPUT}" --out ${OUTPUT}.iconset/icon_256x256@2x.png
|
||||||
sips -z 512 512 ${INPUT} --out ${OUTPUT}.iconset/icon_512x512.png
|
sips -z 512 512 "${INPUT}" --out ${OUTPUT}.iconset/icon_512x512.png
|
||||||
|
|
||||||
cp ${INPUT} ${OUTPUT}.iconset/icon_512x512@2x.png
|
cp "${INPUT}" ${OUTPUT}.iconset/icon_512x512@2x.png
|
||||||
|
|
||||||
iconutil -c icns ${OUTPUT}.iconset
|
iconutil -c icns ${OUTPUT}.iconset
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include <QRegExp>
|
#include <QRegularExpression>
|
||||||
#include <QString>
|
#include <QString>
|
||||||
|
|
||||||
// Non-theme app configuration. Layouts, fonts spacing etc.
|
// Non-theme app configuration. Layouts, fonts spacing etc.
|
||||||
|
@ -51,8 +51,11 @@ constexpr auto LABEL_BIG_SIZE_RATIO = 2;
|
||||||
|
|
||||||
namespace strings {
|
namespace strings {
|
||||||
const QString url_html = "<a href=\"\\1\">\\1</a>";
|
const QString url_html = "<a href=\"\\1\">\\1</a>";
|
||||||
const QRegExp url_regex(
|
const QRegularExpression url_regex(
|
||||||
"((www\\.(?!\\.)|[a-z][a-z0-9+.-]*://)[^\\s<>'\"]+[^!,\\.\\s<>'\"\\]\\)\\:])");
|
// match an URL, that is not quoted, i.e.
|
||||||
|
// vvvvvvv match quote via negative lookahead/lookbehind vvvvvv
|
||||||
|
// vvvv atomic match url -> fail if there is a " before or after vv
|
||||||
|
"(?<!\")(?>((www\\.(?!\\.)|[a-z][a-z0-9+.-]*://)[^\\s<>'\"]+[^!,\\.\\s<>'\"\\]\\)\\:]))(?!\")");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Window geometry.
|
// Window geometry.
|
||||||
|
|
|
@ -291,65 +291,9 @@ utils::linkifyMessage(const QString &body)
|
||||||
{
|
{
|
||||||
// Convert to valid XML.
|
// Convert to valid XML.
|
||||||
auto doc = QString("<html>%1</html>").arg(body);
|
auto doc = QString("<html>%1</html>").arg(body);
|
||||||
|
doc.replace(conf::strings::url_regex, conf::strings::url_html);
|
||||||
|
|
||||||
doc.replace("<mx-reply>", "");
|
|
||||||
doc.replace("</mx-reply>", "");
|
|
||||||
doc.replace("<br>", "<br></br>");
|
|
||||||
|
|
||||||
QXmlStreamReader xml{doc};
|
|
||||||
|
|
||||||
QString textString;
|
|
||||||
while (!xml.atEnd() && !xml.hasError()) {
|
|
||||||
auto t = xml.readNext();
|
|
||||||
|
|
||||||
switch (t) {
|
|
||||||
case QXmlStreamReader::Characters: {
|
|
||||||
auto text = xml.text().toString();
|
|
||||||
text.replace(conf::strings::url_regex, conf::strings::url_html);
|
|
||||||
|
|
||||||
textString += text;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case QXmlStreamReader::StartDocument:
|
|
||||||
case QXmlStreamReader::EndDocument:
|
|
||||||
break;
|
|
||||||
case QXmlStreamReader::StartElement: {
|
|
||||||
if (xml.name() == "html")
|
|
||||||
break;
|
|
||||||
|
|
||||||
textString += QString("<%1").arg(xml.name().toString());
|
|
||||||
|
|
||||||
const auto attrs = xml.attributes();
|
|
||||||
for (const auto &e : attrs)
|
|
||||||
textString += QString(" %1=\"%2\"")
|
|
||||||
.arg(e.name().toString())
|
|
||||||
.arg(e.value().toString());
|
|
||||||
|
|
||||||
textString += ">";
|
|
||||||
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
case QXmlStreamReader::EndElement: {
|
|
||||||
if (xml.name() == "html")
|
|
||||||
break;
|
|
||||||
|
|
||||||
textString += QString("</%1>").arg(xml.name().toString());
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
default: {
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (xml.hasError()) {
|
|
||||||
qWarning() << "error while parsing xml" << xml.errorString() << doc;
|
|
||||||
doc.replace("<html>", "");
|
|
||||||
doc.replace("</html>", "");
|
|
||||||
return doc;
|
return doc;
|
||||||
}
|
|
||||||
|
|
||||||
return textString;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
QString
|
QString
|
||||||
|
|
Loading…
Reference in a new issue