Skip to content

Commit

Permalink
Merge branch 'develop'
Browse files Browse the repository at this point in the history
  • Loading branch information
rspiegel-nc committed Oct 4, 2023
2 parents f9cbad2 + e7ed12b commit d3ecc14
Show file tree
Hide file tree
Showing 145 changed files with 180,342 additions and 27,627 deletions.
6 changes: 5 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -33,6 +33,9 @@ qrc_*.*
# Vim backup files
*~

# Vim temporary files
.*.swp

# Nixnote database backup files
*.nnex

Expand Down Expand Up @@ -72,4 +75,5 @@ testsrc/qmake-build-*

/_build_dir_.txt


# Autogenerated VersionInfo.h header in build dir
VersionInfo.h
48 changes: 28 additions & 20 deletions .travis.yml
Original file line number Diff line number Diff line change
@@ -1,10 +1,9 @@
language: cpp
compiler: gcc
sudo: require
dist: xenial
dist: focal

before_install:
- sudo add-apt-repository ppa:nixnote/nixnote2-stable -y
- sudo apt-get update -qq

install:
Expand All @@ -13,35 +12,44 @@ install:
wget curl make pkg-config \
libboost-dev libboost-test-dev libboost-program-options-dev libevent-dev libcurl4-openssl-dev \
libpoppler-qt5-dev libqt5webkit5-dev qt5-qmake qttools5-dev-tools libqt5sql5-sqlite \
libhunspell-dev \
nixnote2-tidy
libhunspell-dev libtidy-dev libqt5positioning5-plugins
script:
- #ls -lR /opt/tidy56
- export TIDY_LIB_DIR=/usr/lib/nixnote2/tidy
- export PKG_CONFIG_PATH=$TIDY_LIB_DIR/pkgconfig
- echo PKG_CONFIG_PATH=$PKG_CONFIG_PATH
- echo qmake CONFIG+=release PREFIX=/usr QMAKE_RPATHDIR+=$TIDY_LIB_DIR
- echo qmake CONFIG+=release PREFIX=/usr
- |
qmake CONFIG+=release PREFIX=/usr QMAKE_RPATHDIR+=$TIDY_LIB_DIR &&
qmake CONFIG+=release PREFIX=/usr &&
ls -l ./development &&
make -j$(nproc) &&
make INSTALL_ROOT=appdir -j$(nproc) install &&
find appdir/ &&
qmake testsrc/tests.pro CONFIG+=release PREFIX=/usr QMAKE_RPATHDIR+=$TIDY_LIB_DIR &&
qmake testsrc/tests.pro CONFIG+=release PREFIX=/usr &&
make &&
./qmake-build-release-t/tests -platform offscreen
- wget -c "https://github.com/probonopd/linuxdeployqt/releases/download/continuous/linuxdeployqt-continuous-x86_64.AppImage"
- chmod a+x linuxdeployqt*.AppImage
- unset QTDIR; unset QT_PLUGIN_PATH ; unset LD_LIBRARY_PATH
- ./linuxdeployqt*.AppImage ./appdir/usr/share/applications/*.desktop -bundle-non-qt-libs
- ./linuxdeployqt*.AppImage --appimage-extract
- export PATH=$(readlink -f ./squashfs-root/usr/bin/):$PATH
- ./squashfs-root/usr/bin/appimagetool appdir/

- |
wget -nv "https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage" && \
chmod a+x ./linuxdeploy-x86_64.AppImage && \
./linuxdeploy-x86_64.AppImage --appimage-extract && \
mv squashfs-root linuxdeploy && \
mv linuxdeploy/AppRun linuxdeploy/linuxdeploy
- |
wget -nv "https://github.com/linuxdeploy/linuxdeploy-plugin-qt/releases/download/continuous/linuxdeploy-plugin-qt-x86_64.AppImage" && \
chmod a+x ./linuxdeploy-plugin-qt-x86_64.AppImage && \
./linuxdeploy-plugin-qt-x86_64.AppImage --appimage-extract && \
mv squashfs-root linuxdeploy-plugin-qt && \
mv linuxdeploy-plugin-qt/AppRun linuxdeploy-plugin-qt/linuxdeploy-plugin-qt
- |
wget -nv "https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage" && \
chmod a+x appimagetool-x86_64.AppImage && \
./appimagetool-x86_64.AppImage --appimage-extract && \
mv squashfs-root appimagetool && \
mv appimagetool/AppRun appimagetool/appimagetool
- export PATH=linuxdeploy:linuxdeploy-plugin-qt:appimagetool:$PATH
- linuxdeploy --desktop-file=./appdir/usr/share/applications/nixnote2.desktop --appdir=appdir --plugin qt
- rm -f appdir/usr/lib/libnss3.so
- rm -f appdir/usr/lib/libnssutil3.so
- appimagetool -n appdir

after_success:
- find appdir -executable -type f -exec ldd {} \; | grep " => /usr" | cut -d " " -f 2-3 | sort | uniq
- wget -c https://github.com/probonopd/uploadtool/raw/master/upload.sh
- #wget -c https://raw.githubusercontent.com/robert7/uploadtool/temp/upload.sh
- |
Expand Down
3 changes: 1 addition & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,6 @@
Nixnote is Evernote desktop client for Linux (can be also build on macOS and Windows).

* [Getting started](https://github.com/robert7/nixnote2/wiki/Getting-started)
* **Important**: if you have problem with Evernote login (white dialog shown after entering password) - see [workaround](https://github.com/robert7/nixnote2/issues/171#issuecomment-1509087526)
* [Features](https://github.com/robert7/nixnote2/wiki/Features)
* [CHANGELOG](https://github.com/robert7/nixnote2/blob/master/debian/changelog)
* [Contributing](CONTRIBUTING.md)
Expand Down Expand Up @@ -101,7 +100,7 @@ Basic familiarity with docker is helpful.
More info in: [DOCKER README](docs/DOCKER-README.md)

### Linux - manual build
* Install development dependencies - look in content of [this docker file](development/docker/Dockerfile.ubuntu_xenial)
* Install development dependencies - look in content of [this docker file](development/docker/Dockerfile.ubuntu_focal)
or [.travis.yml](https://github.com/robert7/nixnote2/blob/master/.travis.yml)
or [debian/control](https://github.com/robert7/nixnote2/blob/master/debian/control)
to see example, what is needed for Ubuntu. If you use another distribution/version,
Expand Down
13 changes: 13 additions & 0 deletions changelog.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,14 @@
NixNote (2.1.10) stable; urgency=low
* Authentication (Evernote login) now uses system browser which fixes login problems and also enables to use all
login options supported by Evernote (multifactor authentication, login by Google etc.)
* AppImage is now built on Ubuntu 20.04 (focal) - i.e. will not run on older distribution that Ubuntu 20.04,
should of course run on all newer systems
* AppImage is now created by linuxdeploy tool (instead of linuxdeployqt)
* Removed the usage of custom built tidy-html5 in favour of the package provided by distribution
* Updated Evernote client - QEverCloud version 4.1.0 to 6.2.0
* All changes thanks to https://github.com/d1vanov
-- Robert Spiegel <nightingale7@gmail.com> Wed, 19 Apr 2023 19:11:10 +0200

NixNote (2.1.9) stable; urgency=low
* Added a new dark theme.
* Optimised the sql statements of note creating and updating.
Expand All @@ -12,6 +23,7 @@ NixNote (2.1.9) stable; urgency=low
* RAM usage optimizations.
* Fixed file downloading under Windows.
* Made the editor not render the note content when Key_Up or Key_Down keeps being pressed.
* All changes thanks to https://github.com/boo-yee
-- Robert Spiegel <nightingale7@gmail.com> Sat, 15 Apr 2023 12:15:22 +0200

NixNote (2.1.8) stable; urgency=low
Expand All @@ -24,6 +36,7 @@ NixNote (2.1.8) stable; urgency=low
* Fixed: Nixnote2 exits when network gets disconnected - issue #189
* Fixed: Import all notes, tag issue - issue #153
* Fixed: Local images cannot be pasted, images in notes cannot be saved.
* All changes thanks to https://github.com/boo-yee
-- Robert Spiegel <nightingale7@gmail.com> Sat, 10 Sep 2022 10:00:00 +0200

NixNote (2.1.7) stable; urgency=low
Expand Down
14 changes: 14 additions & 0 deletions debian/changelog
Original file line number Diff line number Diff line change
@@ -1,3 +1,14 @@
NixNote (2.1.10) stable; urgency=low
* Authentication (Evernote login) now uses system browser which fixes login problems and also enables to use all
login options supported by Evernote (multifactor authentication, login by Google etc.)
* AppImage is now built on Ubuntu 20.04 (focal) - i.e. will not run on older distribution that Ubuntu 20.04,
should of course run on all newer systems
* AppImage is now created by linuxdeploy tool (instead of linuxdeployqt)
* Removed the usage of custom built tidy-html5 in favour of the package provided by distribution
* Updated Evernote client - QEverCloud version 4.1.0 to 6.2.0
* All changes thanks to https://github.com/d1vanov
-- Robert Spiegel <nightingale7@gmail.com> Wed, 19 Apr 2023 19:11:10 +0200

NixNote (2.1.9) stable; urgency=low
* Added a new dark theme.
* Optimised the sql statements of note creating and updating.
Expand All @@ -12,6 +23,7 @@ NixNote (2.1.9) stable; urgency=low
* RAM usage optimizations.
* Fixed file downloading under Windows.
* Made the editor not render the note content when Key_Up or Key_Down keeps being pressed.
* All changes thanks to https://github.com/boo-yee
-- Robert Spiegel <nightingale7@gmail.com> Sat, 15 Apr 2023 12:15:22 +0200

NixNote (2.1.8) stable; urgency=low
Expand All @@ -24,6 +36,7 @@ NixNote (2.1.8) stable; urgency=low
* Fixed: Nixnote2 exits when network gets disconnected - issue #189
* Fixed: Import all notes, tag issue - issue #153
* Fixed: Local images cannot be pasted, images in notes cannot be saved.
* All changes thanks to https://github.com/boo-yee
-- Robert Spiegel <nightingale7@gmail.com> Sat, 10 Sep 2022 10:00:00 +0200

NixNote (2.1.7) stable; urgency=low
Expand Down Expand Up @@ -449,3 +462,4 @@ NixNote (2.0-beta-3) stable; urgency=low
NixNote (2.0-beta-2) stable; urgency=low
* Beta 2. Lots of bug fixes and removal of Thrift.
-- Randy Baumgarte <randy@fbn.cx> Sat, 26 Apr 2014 14:00:00 -0400

5 changes: 4 additions & 1 deletion development/build-dependencies-ubuntu-2004.sh
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
#!/bin/bash

## 2023.04: this file is not updated see docker/Dockerfile.ubuntu_focal


# preparation
# sudo apt update
# sudo apt upgrade
Expand All @@ -23,4 +26,4 @@ sudo apt-get -y install git-core qt5-default build-essential \
# ./development/build-with-qmake.sh debug noclean /usr/lib/nixnote2/tidy
# then binary is in: ./qmake-build-debug/nixnote2
# cd appdir
# ./usr/appdir/nixnote2
# ./usr/appdir/nixnote2
36 changes: 3 additions & 33 deletions development/build-with-docker.sh
Original file line number Diff line number Diff line change
Expand Up @@ -3,12 +3,8 @@ PROJECTBRANCH=${1}
PROJECTDIR=`pwd`
set -xe

# note: all with DOCKERMODIFIER != "" is highly experimental and needs "someway" to include webkit binaries
# so without it will fail
#DOCKERMODIFIER=_qt562

DOCKERTAG=nixnote2/xenial${DOCKERMODIFIER}
DOCKERFILE=./development/docker/Dockerfile.ubuntu_xenial${DOCKERMODIFIER}
DOCKERTAG=nixnote2/focal
DOCKERFILE=./development/docker/Dockerfile.ubuntu_focal

function error_exit {
echo "$0: ***********error_exit***********"
Expand All @@ -33,12 +29,6 @@ cd $PROJECTDIR
docker build -t ${DOCKERTAG} -f ${DOCKERFILE} ./development/docker

# stop after creating the image (e.g. you want to do the build manually)
if [ ! -z ${DOCKERMODIFIER} ] ; then
echo "Docker image ${DOCKERTAG} created.. "
echo "DOCKERMODIFIER set to $DOCKERMODIFIER .. you need to provide webkit manually.."
exit 1
fi

if [ ! -d appdir ] ; then
mkdir appdir || error_exit "mkdir appdir"
fi
Expand All @@ -53,33 +43,13 @@ if [ ! -d docker-build-${BUILD_TYPE} ]; then
fi

# start container (note: each call creates new container)



# to try manually:
# DOCKERTAG=..
# docker run --rm -it ${DOCKERTAG} /bin/bash
# then
# PROJECTBRANCH=feature/rc1
# BUILD_TYPE=release
# ...copy command from bellow & paste..
# --------------------

# **TEMPORARY** for beineri PPA recompile #################
# PROJECTBRANCH=feature/rc1;BUILD_TYPE=release
# source /opt/qt*/bin/qt*-env.sh
# git fetch && git checkout $PROJECTBRANCH && git pull && ./development/build-with-qmake.sh ${BUILD_TYPE} noclean /usr/lib/nixnote2/tidy
# unset QTDIR; unset QT_PLUGIN_PATH ; unset LD_LIBRARY_PATH
# ./development/create-AppImage.sh
# mv *.AppImage appdir2 && chmod -R a+rwx appdir/*.AppImage

time docker run \
--rm \
-v $PROJECTDIR/appdir:/opt/nixnote2/appdir \
-v $PROJECTDIR/docker-build-${BUILD_TYPE}:/opt/nixnote2/qmake-build-${BUILD_TYPE} \
-v $PROJECTDIR/docker-build-${BUILD_TYPE}-t:/opt/nixnote2/qmake-build-${BUILD_TYPE}-t \
-it ${DOCKERTAG} \
/bin/bash -c "cd nixnote2 && git fetch && git checkout $PROJECTBRANCH && git pull && ./development/build-with-qmake.sh ${BUILD_TYPE} noclean /usr/lib/nixnote2/tidy && ./development/run-tests.sh ${BUILD_TYPE} noclean /usr/lib/nixnote2/tidy && ./development/create-AppImage.sh && mv *.AppImage appdir && chmod -R a+rwx appdir/*.AppImage"
/bin/bash -c "cd nixnote2 && git fetch && git checkout --track origin/$PROJECTBRANCH && git reset --hard origin/$PROJECTBRANCH && ./development/build-with-qmake.sh ${BUILD_TYPE} noclean /usr/lib browser && ./development/run-tests.sh ${BUILD_TYPE} noclean /usr/lib && ./development/create-AppImage-linuxdeploy.sh && mv *.AppImage appdir && chmod -R a+rwx appdir/*.AppImage"

ls appdir/*.AppImage
echo "If all got well then AppImage file in appdir is your binary"
Expand Down
17 changes: 13 additions & 4 deletions development/build-with-qmake.sh
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ set -xe
BUILD_TYPE=${1}
CLEAN=${2}
TIDY_LIB_DIR=${3}
OAUTH_BACKEND=${4}
CDIR=`pwd`

function error_exit {
Expand Down Expand Up @@ -44,6 +45,15 @@ if [ ! -d "${TIDY_LIB_DIR}" ]; then
fi
echo "$0: libtidy is expected in: ${TIDY_LIB_DIR}"

if [ -z "${OAUTH_BACKEND}" ] || [ "${OAUTH_BACKEND}" == "browser" ]; then
# by default will use system browser for OAuth because it's the simplest and working option
OAUTH_CONFIG=""
elif [ "${OAUTH_BACKEND}" == "webengine" ]; then
OAUTH_CONFIG="CONFIG+=oauth_webengine"
else
OAUTH_CONFIG="CONFIG+=oauth_webkit"
fi

if [ ! -d "${BUILD_DIR}" ]; then
mkdir ${BUILD_DIR}
fi
Expand All @@ -56,7 +66,6 @@ if [ -d "${APPDIR}" ]; then
rm *.AppImage 2>/dev/null || echo "failed to remove"
fi


QMAKE_BINARY=qmake

if [ "${TIDY_LIB_DIR}" == "/usr/lib" ] ; then
Expand All @@ -71,10 +80,10 @@ elif [ -d ${TIDY_LIB_DIR}/pkgconfig ] ; then
export PKG_CONFIG_PATH=${TIDY_LIB_DIR}/pkgconfig
fi

echo ${QMAKE_BINARY} CONFIG+=${BUILD_TYPE} ${OAUTH_CONFIG} PREFIX=appdir/usr QMAKE_RPATHDIR+=${TIDY_LIB_DIR} QMAKE_CXX="ccache g++" || error_exit "$0: qmake"
${QMAKE_BINARY} CONFIG+=${BUILD_TYPE} ${OAUTH_CONFIG} PREFIX=appdir/usr QMAKE_RPATHDIR+=${TIDY_LIB_DIR} QMAKE_CXX="ccache g++" || error_exit "$0: qmake"

echo ${QMAKE_BINARY} CONFIG+=${BUILD_TYPE} PREFIX=appdir/usr QMAKE_RPATHDIR+=${TIDY_LIB_DIR} || error_exit "$0: qmake"
${QMAKE_BINARY} CONFIG+=${BUILD_TYPE} PREFIX=appdir/usr QMAKE_RPATHDIR+=${TIDY_LIB_DIR} || error_exit "$0: qmake"

make clean
make -j$(nproc) || error_exit "$0: make"
make -j$(nproc) install || error_exit "$0: make install"

Expand Down
29 changes: 29 additions & 0 deletions development/create-AppImage-linuxdeploy.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,29 @@
#!/bin/bash

PROG=nixnote2
DESKTOP_FILE=appdir/usr/share/applications/${PROG}.desktop

BUILD_DIR=$(cat _build_dir_.txt)
echo Build dir: ${BUILD_DIR}

if [ ! -f "$DESKTOP_FILE" ]; then
echo "$DESKTOP_FILE not found!"
exit 1
fi

export VERSIONX=$(cat appdir/usr/share/nixnote2/version.txt)
echo Version: ${VERSIONX}

# First, create appdir with bundled binaries
CMD="linuxdeploy --desktop-file=$DESKTOP_FILE --appdir=appdir --plugin qt"
echo About to run: $CMD
$CMD

# Then remove nss libs from the AppDir as they are known to cause troubles, see
# https://github.com/probonopd/linuxdeployqt/issues/35
rm -f appdir/usr/lib/libnss3.so
rm -f appdir/usr/lib/libnssutil3.so

# Now create the actual appimage
echo "Creating AppImage"
appimagetool -n appdir
41 changes: 41 additions & 0 deletions development/docker/Dockerfile.ubuntu_focal
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
FROM ubuntu:focal

ARG wdir="/opt"
WORKDIR $wdir

ARG make_core=4
ENV PATH="${wdir}/linuxdeploy:${wdir}/linuxdeploy-plugin-qt:${wdir}/appimagetool:${PATH}"
ENV DEBIAN_FRONTEND=noninteractive

RUN apt-get update && apt-get install -y software-properties-common
#RUN add-apt-repository ppa:nixnote/nixnote2-stable -y && apt-get update -qq
RUN apt-get update && apt-get install -y git-core qt5-default build-essential ccache p7zip-full libssl1.1 libcrypt1 libnss3 \
wget curl make pkg-config \
qtwebengine5-dev qtwebengine5-dev-tools \
libboost-dev libboost-test-dev libboost-program-options-dev libevent-dev libcurl4-openssl-dev \
libpoppler-qt5-dev libqt5webkit5-dev qt5-qmake qttools5-dev-tools libhunspell-dev libtidy-dev libqt5positioning5-plugins

# install linuxdeploy
RUN wget -nv "https://github.com/linuxdeploy/linuxdeploy/releases/download/continuous/linuxdeploy-x86_64.AppImage" && \
chmod a+x ./linuxdeploy-x86_64.AppImage && \
./linuxdeploy-x86_64.AppImage --appimage-extract && \
mv squashfs-root linuxdeploy && \
mv linuxdeploy/AppRun linuxdeploy/linuxdeploy

# install linuxdeploy-plugin-qt
RUN wget -nv "https://github.com/linuxdeploy/linuxdeploy-plugin-qt/releases/download/continuous/linuxdeploy-plugin-qt-x86_64.AppImage" && \
chmod a+x ./linuxdeploy-plugin-qt-x86_64.AppImage && \
./linuxdeploy-plugin-qt-x86_64.AppImage --appimage-extract && \
mv squashfs-root linuxdeploy-plugin-qt && \
mv linuxdeploy-plugin-qt/AppRun linuxdeploy-plugin-qt/linuxdeploy-plugin-qt

# install appimagetool
RUN wget -nv "https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage" && \
chmod a+x appimagetool-x86_64.AppImage && \
./appimagetool-x86_64.AppImage --appimage-extract && \
mv squashfs-root appimagetool && \
mv appimagetool/AppRun appimagetool/appimagetool

RUN cd $wdir && git clone "https://github.com/robert7/nixnote2.git" && cd nixnote2 && git checkout master

CMD /bin/bash
Loading

0 comments on commit d3ecc14

Please sign in to comment.