diff --git a/.travis.yml b/.travis.yml
index df2aebbb4..dbbdcda7c 100644
--- a/.travis.yml
+++ b/.travis.yml
@@ -1,11 +1,20 @@
sudo: required
dist: trusty
language: cpp
-os:
-- linux
-- osx
-script:
-- bash ./.travis/travis.sh
+
+matrix:
+ fast_finish: true
+ include:
+ - os: linux
+ env: JOB=verify-commit-format
+ - os: linux
+ env: JOB=build-docs
+ - os: linux
+ env: JOB=build-ubuntu-14-04
+ - os: osx
+ env: JOB=build-osx
+
+script: "./.travis/$JOB.sh"
deploy:
provider: releases
@@ -19,4 +28,4 @@ deploy:
skip_cleanup: true
after_success:
-- test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && bash ./.travis/build-docs.sh
+ - test $TRAVIS_PULL_REQUEST == "false" && test $TRAVIS_BRANCH == "master" && bash ./.travis/deploy-docs.sh
diff --git a/.travis/build-docs.sh b/.travis/build-docs.sh
old mode 100644
new mode 100755
index 3c47d592f..57d9e1f1d
--- a/.travis/build-docs.sh
+++ b/.travis/build-docs.sh
@@ -15,38 +15,22 @@
# You should have received a copy of the GNU General Public License
# along with this program. If not, see .
+# Fail out on error
+set -eu -o pipefail
# Obtain doxygen
sudo apt-get install doxygen
CONFIG_FILE="doxygen.conf"
-CONFIG_FILE_TMP="$CONFIG_FILE.tmp.autogen"
GIT_DESC=$(git describe --tags 2> /dev/null)
GIT_CHASH=$(git rev-parse HEAD)
-# Create temporary config file
-cp "$CONFIG_FILE" "$CONFIG_FILE_TMP"
-
# Append git version to doxygen version string
-echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$CONFIG_FILE_TMP"
+echo "PROJECT_NUMBER = \"Version: $GIT_DESC | Commit: $GIT_CHASH\"" >> "$CONFIG_FILE"
# Generate documentation
echo "Generating documentation..."
echo
-doxygen "$CONFIG_FILE_TMP"
-rm "$CONFIG_FILE_TMP"
-
-# Push generated doxygen to GitHub pages
-cd ./doc/html/
-
-git init
-git config user.name "Travis CI"
-git config user.email "qTox@users.noreply.github.com"
-
-git add .
-git commit -m "Deploy to GH pages from commit: $GIT_CHASH"
-
-echo "Pushing to GH pages..."
-git push --force --quiet "https://${GH_TOKEN}@github.com/qTox/doxygen.git" master:gh-pages &> /dev/null
+doxygen "$CONFIG_FILE"
diff --git a/.travis/build-osx.sh b/.travis/build-osx.sh
new file mode 100755
index 000000000..950efb3f3
--- /dev/null
+++ b/.travis/build-osx.sh
@@ -0,0 +1,25 @@
+#!/bin/bash
+#
+# Copyright © 2016 by The qTox Project
+#
+# 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
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+
+# Fail out on error
+set -e -o pipefail
+
+# Build OSX
+bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -i
+bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -b
+bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -d
+# The following line can randomly fail due to travis emitting the error:
+# "hdiutil: create failed - Resource busy"
+bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -dmg
diff --git a/.travis/build-ubuntu_14_04.sh b/.travis/build-ubuntu-14-04.sh
similarity index 100%
rename from .travis/build-ubuntu_14_04.sh
rename to .travis/build-ubuntu-14-04.sh
diff --git a/.travis/deploy-docs.sh b/.travis/deploy-docs.sh
new file mode 100755
index 000000000..0fdccded1
--- /dev/null
+++ b/.travis/deploy-docs.sh
@@ -0,0 +1,43 @@
+#!/bin/bash
+#
+# Copyright © 2016 by The qTox Project
+#
+# 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
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see .
+
+# Fail out on error
+set -eu -o pipefail
+
+DOCS_FOLDER="./doc/html"
+
+# Ensure docs exists
+if [ ! -d "$DOCS_FOLDER" ]
+then
+ exit 1
+fi
+
+# Obtain git commit hash from HEAD
+GIT_CHASH=$(git rev-parse HEAD)
+
+# Push generated doxygen to GitHub pages
+cd "$DOCS_FOLDER"
+
+git --quiet init
+git config user.name "Travis CI"
+git config user.email "qTox@users.noreply.github.com"
+
+git add .
+git commit --quiet -m "Deploy to GH pages from commit: $GIT_CHASH"
+
+echo "Pushing to GH pages..."
+git push --force --quiet "https://${GH_TOKEN}@github.com/qTox/doxygen.git" master:gh-pages &> /dev/null
diff --git a/.travis/travis.sh b/.travis/travis.sh
deleted file mode 100755
index 2b082cb6d..000000000
--- a/.travis/travis.sh
+++ /dev/null
@@ -1,22 +0,0 @@
-#!/bin/bash
-#
-# Script that runs all the necessary tests on travis.
-#
-# Exits as soon as there's a failure in test.
-
-set -e
-
-if [[ "$TRAVIS_OS_NAME" == "linux" ]]
-then
- # osx cannot into extended regexp for grep, thus verify only on Linux
- bash ./verify-commit-messages.sh "$TRAVIS_COMMIT_RANGE"
- bash ./.travis/build-ubuntu_14_04.sh
-elif [[ "$TRAVIS_OS_NAME" == "osx" ]]
-then
- bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -i
- bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -b
- bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -d
- # The following line can randomly fail due to travis emitting the error:
- # "hdiutil: create failed - Resource busy"
- bash ./osx/qTox-Mac-Deployer-ULTIMATE.sh -dmg
-fi
diff --git a/.travis/verify-commit-format.sh b/.travis/verify-commit-format.sh
new file mode 100755
index 000000000..c419be8a1
--- /dev/null
+++ b/.travis/verify-commit-format.sh
@@ -0,0 +1,22 @@
+#!/bin/bash
+#
+# Copyright © 2016 by The qTox Project
+#
+# 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
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program. If not, see .
+
+# Fail out on error
+set -eu -o pipefail
+
+# Verify commit messages
+bash ./verify-commit-messages.sh "$TRAVIS_COMMIT_RANGE"