diff --git a/.travis/build-osx.sh b/.travis/build-osx.sh index a6e1933a1..68b07b2f9 100755 --- a/.travis/build-osx.sh +++ b/.travis/build-osx.sh @@ -1,6 +1,6 @@ #!/bin/bash # -# Copyright © 2016 by The qTox Project Contributors +# Copyright © 2016-2017 by The qTox Project Contributors # # This program is libre software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -23,9 +23,6 @@ set -e -o pipefail install_ccache() { echo "Installing ccache ..." brew install ccache - # make sure to use ccache for all the compiling - export CC="ccache $CC" - export CXX="ccache $CXX" } # Build OSX diff --git a/.travis/build-ubuntu-14-04.sh b/.travis/build-ubuntu-14-04.sh index 763770974..c10c11796 100755 --- a/.travis/build-ubuntu-14-04.sh +++ b/.travis/build-ubuntu-14-04.sh @@ -1,6 +1,6 @@ #!/bin/bash # -# Copyright © 2015-2016 by The qTox Project Contributors +# Copyright © 2015-2017 by The qTox Project Contributors # # This program is libre software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -48,10 +48,6 @@ sudo apt-get install -y --force-yes \ qt53xmlpatterns \ pkg-config || yes -# make sure to use ccache for all the compiling -export CC="ccache $CC" -export CXX="ccache $CXX" - # Qt source /opt/qt53/bin/qt53-env.sh || yes @@ -72,7 +68,7 @@ cd ffmpeg* # demuxers, decoders and parsers needed for webcams: # mjpeg, h264 -./configure --prefix="$PREFIX_DIR" \ +CC="ccache $CC" CXX="ccache $CXX" ./configure --prefix="$PREFIX_DIR" \ --disable-avfilter \ --disable-avresample \ --disable-bzlib \ @@ -120,7 +116,7 @@ cd ffmpeg* --enable-decoder=h264 \ --enable-decoder=mjpeg -make -j$(nproc) +CC="ccache $CC" CXX="ccache $CXX" make -j$(nproc) make install cd ../../ # libsodium @@ -128,7 +124,8 @@ git clone git://github.com/jedisct1/libsodium.git cd libsodium git checkout tags/1.0.8 ./autogen.sh -./configure && make -j$(nproc) +CC="ccache $CC" CXX="ccache $CXX" ./configure +CC="ccache $CC" CXX="ccache $CXX" make -j$(nproc) sudo checkinstall --install --pkgname libsodium --pkgversion 1.0.8 --nodoc -y sudo ldconfig cd .. @@ -136,8 +133,8 @@ cd .. git clone --branch v0.1.0 --depth=1 https://github.com/toktok/c-toxcore.git toxcore cd toxcore autoreconf -if -./configure -make -j$(nproc) > /dev/null +CC="ccache $CC" CXX="ccache $CXX" ./configure +CC="ccache $CC" CXX="ccache $CXX" make -j$(nproc) > /dev/null sudo make install echo '/usr/local/lib/' | sudo tee -a /etc/ld.so.conf.d/locallib.conf sudo ldconfig @@ -149,14 +146,33 @@ $CXX --version # needed, otherwise ffmpeg doesn't get detected export PKG_CONFIG_PATH="$PWD/libs/lib/pkgconfig" -# first build qTox without support for optional dependencies -echo '*** BUILDING "MINIMAL" VERSION ***' -cmake . -DCMAKE_C_COMPILER="$CC" -DCMAKE_CXX_COMPILER="$CXX" -DENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND=NO -DENABLE_SYSTRAY_GTK_BACKEND=NO -DDISABLE_PLATFORM_EXT=YES -DSMILEYS=DISABLED -# ↓ reduce if build fails with OOM -make -j$(nproc) -# clean it up, and build normal version -make clean -echo '*** BUILDING "FULL" VERSION ***' -cmake . -DCMAKE_C_COMPILER="$CC" -DCMAKE_CXX_COMPILER="$CXX" -# ↓ reduce if build fails with OOM -make -j$(nproc) + +build_qtox() { + bdir() { + pushd . + cd $BUILDDIR + make -j$(nproc) + # check if `qtox` file has been made, is non-empty and is an executable + [[ -s qtox ]] && [[ -x qtox ]] + popd + } + + local BUILDDIR=_build + + # first build qTox without support for optional dependencies + echo '*** BUILDING "MINIMAL" VERSION ***' + cmake -H. -B"$BUILDDIR" \ + -DSMILEYS=DISABLED \ + -DENABLE_STATUSNOTIFIER=False \ + -DENABLE_GTK_SYSTRAY=False + + bdir + + # clean it up, and build normal version + rm -rf "$BUILDDIR" + + echo '*** BUILDING "FULL" VERSION ***' + cmake -H. -B"$BUILDDIR" + bdir +} +build_qtox diff --git a/INSTALL.md b/INSTALL.md index 4a9feef28..0d8559bfd 100644 --- a/INSTALL.md +++ b/INSTALL.md @@ -34,6 +34,7 @@ - [Compile qTox](#compile-qtox) - [OS X](#osx) - [Windows](#windows) +- [Compile-time switches](#compile-time-switches) ## Dependencies @@ -52,8 +53,8 @@ ## Optional dependencies -They can be disabled/enabled by passing arguments to `cmake` as -`-D{name}={value}` command when building qTox. +They can be disabled/enabled by passing arguments to `cmake` command when +building qTox. If they are missing, qTox is built without support for the functionality. @@ -66,7 +67,7 @@ If they are missing, qTox is built without support for the functionality. | [libXScrnSaver] | >= 1.2 | | [libX11] | >= 1.6.0 | -To disable: `DISABLE_PLATFORM_EXT=YES` +Disabled if dependencies are missing during compilation. #### KDE Status Notifier / GTK tray backend @@ -79,8 +80,7 @@ To disable: `DISABLE_PLATFORM_EXT=YES` | [GTK+] | >= 2.0 | | [Pango] | >= 1.18 | -To disable: `ENABLE_SYSTRAY_STATUSNOTIFIER_BACKEND=NO -ENABLE_SYSTRAY_GTK_BACKEND=NO` +To disable: `-DENABLE_STATUSNOTIFIER=False -DENABLE_GTK_SYSTRAY=False` #### Unity tray backend @@ -97,7 +97,7 @@ Disabled by default. | [libappindicator] | >= 0.4.92 | | [Pango] | >= 1.18 | -To enable: `ENABLE_SYSTRAY_UNITY_BACKEND=YES` +To enable: `-DENABLE_APPINDICATOR=True` @@ -238,10 +238,25 @@ your `sources.list`. Adding backports: http://backports.debian.org/Instructions/ ```bash -sudo apt-get install build-essential cmake qt5-qmake qt5-default qttools5-dev-tools \ -libqt5opengl5-dev libqt5svg5-dev libopenal-dev libxss-dev qrencode \ -libqrencode-dev libglib2.0-dev libgdk-pixbuf2.0-dev libgtk2.0-dev ffmpeg \ -libsqlcipher-dev pkg-config yasm +sudo apt-get install \ + build-essential \ + cmake \ + ffmpeg \ + libgdk-pixbuf2.0-dev \ + libglib2.0-dev \ + libgtk2.0-dev \ + libopenal-dev \ + libqrencode-dev \ + libqt5opengl5-dev \ + libqt5svg5-dev \ + libsqlcipher-dev \ + libxss-dev \ + pkg-config \ + qrencode \ + qt5-default \ + qt5-qmake \ + qttools5-dev-tools \ + yasm ``` **Go to [FFmpeg](#ffmpeg) section to compile it.** @@ -288,22 +303,54 @@ http://slackbuilds.org/repository/14.1/network/qTox/ #### Ubuntu >=15.04 ```bash -sudo apt-get install build-essential cmake qt5-qmake qt5-default qttools5-dev-tools \ -libqt5opengl5-dev libqt5svg5-dev libopenal-dev libxss-dev qrencode \ -libqrencode-dev libavutil-ffmpeg-dev libswresample-ffmpeg-dev \ -libavcodec-ffmpeg-dev libswscale-ffmpeg-dev libavfilter-ffmpeg-dev \ -libavdevice-ffmpeg-dev libglib2.0-dev libgdk-pixbuf2.0-dev libgtk2.0-dev \ -libsqlcipher-dev +sudo apt-get install \ + build-essential cmake \ + libavcodec-ffmpeg-dev \ + libavdevice-ffmpeg-dev \ + libavfilter-ffmpeg-dev \ + libavutil-ffmpeg-dev \ + libgdk-pixbuf2.0-dev \ + libglib2.0-dev \ + libgtk2.0-dev \ + libopenal-dev \ + libqrencode-dev \ + libqt5opengl5-dev \ + libqt5svg5-dev \ + libsqlcipher-dev \ + libswresample-ffmpeg-dev \ + libswscale-ffmpeg-dev \ + libxss-dev \ + qrencode \ + qt5-default \ + qt5-qmake \ + qttools5-dev-tools ``` #### Ubuntu >=16.04: ```bash -sudo apt-get install build-essential cmake qt5-qmake qt5-default \ -qttools5-dev-tools libqt5opengl5-dev libqt5svg5-dev libopenal-dev \ -libxss-dev qrencode libqrencode-dev libavutil-dev libswresample-dev \ -libavcodec-dev libswscale-dev libavfilter-dev libavdevice-dev \ -libglib2.0-dev libgdk-pixbuf2.0-dev libgtk2.0-dev libsqlcipher-dev +sudo apt-get install \ + build-essential \ + cmake \ + libavcodec-dev \ + libavdevice-dev \ + libavfilter-dev \ + libavutil-dev \ + libgdk-pixbuf2.0-dev \ + libglib2.0-dev \ + libgtk2.0-dev \ + libopenal-dev \ + libqrencode-dev \ + libqt5opengl5-dev \ + libqt5svg5-dev \ + libsqlcipher-dev \ + libswresample-dev \ + libswscale-dev \ + libxss-dev \ + qrencode \ + qt5-default \ + qt5-qmake \ + qttools5-dev-tools ``` ### FFmpeg @@ -680,6 +727,25 @@ Run `bootstrap.bat` in cloned `C:\qTox` directory. Script will download rest of dependencies compile them and put to appropriate directories. +## Compile-time switches + +They are passed as an argument to `cmake` command. E.g. with a switch `SWITCH` +that has value `YES` it would be passed to `cmake` in a following manner: + +```bash +cmake -DSWITCH=yes +``` + +Switches: + +- `SMILEYS`, values: + - if not defined or an unsupported value is passed, all emoticon packs are + included + - `DISABLED` – don't include any emoticon packs, custom ones are still loaded + - `MIN` – minimal support for emoticons, only a single emoticon pack is + included + + [Atk]: https://wiki.gnome.org/Accessibility [Cairo]: https://www.cairographics.org/ [DBus Menu]: https://launchpad.net/libdbusmenu diff --git a/osx/qTox-Mac-Deployer-ULTIMATE.sh b/osx/qTox-Mac-Deployer-ULTIMATE.sh index 7d1302757..d599b4ab3 100755 --- a/osx/qTox-Mac-Deployer-ULTIMATE.sh +++ b/osx/qTox-Mac-Deployer-ULTIMATE.sh @@ -2,7 +2,7 @@ # # Copyright © 2015 by RowenStipe -# Copyright © 2016 by The qTox Project Contributors +# Copyright © 2016-2017 by The qTox Project Contributors # # This program is libre software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -166,6 +166,8 @@ install() { then fcho "Updating brew formulas ..." brew update > /dev/null + else + brew install cmake fi brew install ffmpeg qrencode qt5 sqlcipher @@ -226,8 +228,9 @@ build() { cd $BUILD_DIR fcho "Now working in ${PWD}" fcho "Starting cmake ... " - cmake $QTOX_DIR - make + export CMAKE_PREFIX_PATH=$(brew --prefix qt5) + cmake -H$QTOX_DIR -B. + make -j$(sysctl -n hw.ncpu) } deploy() { diff --git a/simple_make.sh b/simple_make.sh index 2eef6bf49..226c3632e 100755 --- a/simple_make.sh +++ b/simple_make.sh @@ -8,6 +8,7 @@ apt_install() { autotools-dev check checkinstall + cmake git build-essential libavdevice-dev libgdk-pixbuf2.0-dev @@ -27,7 +28,6 @@ apt_install() { qt5-default qt5-qmake qttools5-dev-tools - cmake ) local codename=$(lsb_release -c -s) @@ -115,27 +115,27 @@ fedora_locallib() { zypper_install() { local zypper_packages=( + cmake git - libffmpeg-devel - libopus-devel libQt5Concurrent-devel - libqt5-linguist libQt5Network-devel libQt5OpenGL-devel + libQt5Sql-devel + libQt5Sql5-sqlite + libQt5Xml-devel + libXScrnSaver-devel + libffmpeg-devel + libopus-devel + libqt5-linguist libqt5-qtbase-common-devel libqt5-qtsvg-devel - libQt5Sql5-sqlite - libQt5Sql-devel - libQt5Xml-devel libsodium-devel libvpx-devel - libXScrnSaver-devel openal-soft-devel patterns-openSUSE-devel_basis patterns-openSUSE-devel_basis qrencode-devel sqlcipher-devel - cmake ) sudo zypper in "${zypper_packages[@]}" } @@ -159,7 +159,7 @@ main() { fi ./bootstrap.sh - cmake . + cmake -H. -B_build make -j$(nproc) } main