2013-04-02 21:15:22 +00:00
|
|
|
language: cpp
|
2013-04-05 22:45:04 +00:00
|
|
|
branches:
|
|
|
|
only:
|
|
|
|
- master
|
2014-12-17 22:22:20 +00:00
|
|
|
- coverity_scan
|
2014-02-13 11:30:53 +00:00
|
|
|
- /openmw-.*$/
|
2014-12-17 22:19:37 +00:00
|
|
|
env:
|
|
|
|
global:
|
|
|
|
# The next declaration is the encrypted COVERITY_SCAN_TOKEN, created
|
|
|
|
# via the "travis encrypt" command using the project repo's public key
|
2015-01-10 14:54:13 +00:00
|
|
|
- secure: "jybGzAdUbqt9vWR/GEnRd96BgAi/7Zd1+2HK68j/i/8+/1YH2XxLOy4Jv/DUBhBlJIkxs/Xv8dRcUlFOclZDHX1d/9Qnsqd3oUVkD7k1y7cTOWy9TBQaE/v/kZo3LpzA3xPwwthrb0BvqIbOfIELi5fS5s8ba85WFRg3AX70wWE="
|
2014-12-17 22:19:37 +00:00
|
|
|
addons:
|
2016-08-15 14:04:29 +00:00
|
|
|
apt:
|
|
|
|
sources:
|
|
|
|
- sourceline: 'ppa:openmw/openmw'
|
|
|
|
- ubuntu-toolchain-r-test
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
- llvm-toolchain-trusty-7
|
2016-08-15 14:04:29 +00:00
|
|
|
packages: [
|
|
|
|
# Dev
|
2018-11-12 22:54:22 +00:00
|
|
|
cmake, clang-7, clang-tools-7, gcc-6, g++-6,
|
2016-08-15 14:04:29 +00:00
|
|
|
# Boost
|
2017-05-05 19:42:57 +00:00
|
|
|
libboost-filesystem-dev, libboost-program-options-dev, libboost-system-dev,
|
2016-08-15 14:04:29 +00:00
|
|
|
# FFmpeg
|
|
|
|
libavcodec-dev, libavformat-dev, libavutil-dev, libswscale-dev,
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
# Audio, Video and Misc. deps
|
|
|
|
libsdl2-dev, libqt4-dev, libopenal-dev, libunshield-dev, libtinyxml-dev,
|
2016-08-30 17:12:18 +00:00
|
|
|
# The other ones from OpenMW ppa
|
2016-08-30 18:09:28 +00:00
|
|
|
libbullet-dev, libswresample-dev, libopenscenegraph-3.4-dev, libmygui-dev
|
2016-08-15 14:04:29 +00:00
|
|
|
]
|
2018-11-12 14:09:49 +00:00
|
|
|
coverity_scan:
|
|
|
|
project:
|
|
|
|
name: "OpenMW/openmw"
|
|
|
|
description: "<Your project description here>"
|
|
|
|
branch_pattern: coverity_scan
|
|
|
|
notification_email: 720642+scrawl@users.noreply.github.com
|
2018-11-12 22:54:22 +00:00
|
|
|
build_command_prepend: "cov-configure --comptype gcc --compiler gcc-6 --template; cmake . -DBUILD_OPENCS=FALSE -DBUILD_WIZARD=FALSE -DBUILD_UNITTESTS=FALSE -DBUILD_BSATOOL=FALSE -DBUILD_ESMTOOL=FALSE -DBUILD_MWINIIMPORTER=FALSE -DBUILD_ESSIMPORTER=FALSE -DBUILD_LAUNCHER=FALSE -DBUILD_MYGUI_PLUGIN=FALSE"
|
2018-11-12 14:09:49 +00:00
|
|
|
build_command: "make VERBOSE=1 -j3"
|
2015-03-17 13:45:31 +00:00
|
|
|
matrix:
|
|
|
|
include:
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
- name: OpenMW (all) on MacOS xcode9.4
|
|
|
|
os: osx
|
|
|
|
osx_image: xcode9.4
|
2018-11-12 14:05:09 +00:00
|
|
|
if: branch != coverity_scan
|
2018-11-12 22:54:22 +00:00
|
|
|
- name: OpenMW (all) on Ubuntu Trusty GCC-6
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
os: linux
|
|
|
|
dist: trusty
|
|
|
|
sudo: required
|
2015-03-17 13:45:31 +00:00
|
|
|
env:
|
2018-11-12 22:54:22 +00:00
|
|
|
- MATRIX_EVAL="CC=gcc-6 && CXX=g++-6"
|
2018-11-12 14:05:09 +00:00
|
|
|
if: branch != coverity_scan
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
- name: OpenMW (openmw) on Ubuntu Trusty Clang-7 with Static Analysis
|
|
|
|
os: linux
|
|
|
|
dist: trusty
|
|
|
|
sudo: required
|
|
|
|
env:
|
|
|
|
- MATRIX_EVAL="CC=clang-7 && CXX=clang++-7"
|
|
|
|
- ANALYZE="scan-build-7 --use-cc clang-7 --use-c++ clang++-7"
|
|
|
|
- BUILD_OPENMW_CS="OFF"
|
2018-11-12 14:05:09 +00:00
|
|
|
if: branch != coverity_scan
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
compiler: clang
|
|
|
|
- name: OpenMW (openmw-cs) on Ubuntu Trusty Clang-7 with Static Analysis
|
|
|
|
os: linux
|
|
|
|
dist: trusty
|
|
|
|
sudo: required
|
|
|
|
env:
|
|
|
|
- MATRIX_EVAL="CC=clang-7 && CXX=clang++-7"
|
|
|
|
- ANALYZE="scan-build-7 --use-cc clang-7 --use-c++ clang++-7"
|
|
|
|
- BUILD_OPENMW="OFF"
|
2018-11-12 14:05:09 +00:00
|
|
|
if: branch != coverity_scan
|
2015-03-17 13:45:31 +00:00
|
|
|
compiler: clang
|
2018-11-12 13:39:50 +00:00
|
|
|
- name: OpenMW Coverity Scan
|
|
|
|
os: linux
|
|
|
|
dist: trusty
|
|
|
|
sudo: required
|
2018-11-12 14:05:09 +00:00
|
|
|
env:
|
2018-11-12 22:54:22 +00:00
|
|
|
- MATRIX_EVAL="CC=gcc-6 && CXX=g++-6"
|
2018-11-12 14:05:09 +00:00
|
|
|
if: branch = coverity_scan
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
# allow_failures:
|
|
|
|
# - name: OpenMW (openmw) on Ubuntu Trusty Clang-7 with Static Analysis
|
2014-12-17 22:19:37 +00:00
|
|
|
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
before_install:
|
|
|
|
- if [ "${TRAVIS_OS_NAME}" = "linux" ]; then eval "${MATRIX_EVAL}"; fi
|
2018-11-12 13:39:50 +00:00
|
|
|
- if [ "${COVERITY_SCAN_BRANCH}" != 1 ]; then ./CI/before_install.${TRAVIS_OS_NAME}.sh; fi
|
use c++11 std::align from <memory> (#2026)
* use c++11 std::align from <memory>
* for Ubuntu, use gcc5 instead of 4.8
* use travis to set gcc to 5
eval
and sudo
* use eval in .travis.yml
* use gcc-8
* replace precise with trusty llvm toolchain, because we have been using trusty for awhile now
* push things to matrix, so we can support multiple releases if we want
* we should not be allowing for failures, we are ready to start trusting clang and its analyzer
* scan-build was pushed to another package
* use gcc-8 still but wrap in scan-build
* travis.yml cleanup, have output of scripts go to stdout, make search for substring a regex
use double []
fix missing ,
use bash to use regex
black spaces matter
* set human readable names for our various builds, split out our static analysis between openmw and openmw-cs
* test if not set, then set otherwise ignore
* use quotes
* do not eval it, set it in travis env
* no more &&
* what does clang7 have to say?
* use sourceline for now
* use clang-7 instead of clang-7.0
* yes, llvm-toolchain-trusty-7 not llvm-toolchain-trusty-7.0
* for static analysis, openmw is compiled and checked on its own while openmw-cs is build with all the rest. this might change in the future.
and actually do it the other way around
2018-11-08 16:38:09 +00:00
|
|
|
before_script:
|
2018-11-12 13:39:50 +00:00
|
|
|
- if [ "${COVERITY_SCAN_BRANCH}" != 1 ]; then ./CI/before_script.${TRAVIS_OS_NAME}.sh; fi
|
2013-04-05 22:45:04 +00:00
|
|
|
script:
|
2014-10-04 11:23:23 +00:00
|
|
|
- cd ./build
|
2018-11-12 13:39:50 +00:00
|
|
|
- if [ "${COVERITY_SCAN_BRANCH}" != 1 ]; then ${ANALYZE} make -j3; fi
|
|
|
|
- if [ "${COVERITY_SCAN_BRANCH}" != 1 ] && [ "${TRAVIS_OS_NAME}" = "osx" ]; then make package; fi
|
|
|
|
- if [ "${COVERITY_SCAN_BRANCH}" != 1 ] && [ "${TRAVIS_OS_NAME}" = "linux" ]; then ./openmw_test_suite; fi
|
|
|
|
- if [ "${COVERITY_SCAN_BRANCH}" != 1 ] && [ "${TRAVIS_OS_NAME}" = "linux" ]; then cd .. && ./CI/check_tabs.sh; fi
|
2017-03-04 20:29:02 +00:00
|
|
|
- cd "${TRAVIS_BUILD_DIR}"
|
|
|
|
deploy:
|
|
|
|
provider: script
|
|
|
|
script: ./CI/deploy.osx.sh
|
|
|
|
skip_cleanup: true
|
|
|
|
on:
|
|
|
|
branch: master
|
|
|
|
condition: "$TRAVIS_EVENT_TYPE = cron && $TRAVIS_OS_NAME = osx"
|
|
|
|
repo: OpenMW/openmw
|
2013-04-02 21:15:22 +00:00
|
|
|
notifications:
|
|
|
|
email:
|
2016-12-18 13:43:50 +00:00
|
|
|
recipients:
|
|
|
|
- corrmage+travis-ci@gmail.com
|
2013-04-02 21:15:22 +00:00
|
|
|
on_success: change
|
|
|
|
on_failure: always
|
2014-10-21 14:12:33 +00:00
|
|
|
irc:
|
|
|
|
channels:
|
|
|
|
- "chat.freenode.net#openmw"
|
|
|
|
on_success: change
|
|
|
|
on_failure: always
|
|
|
|
use_notice: true
|