2013-04-02 23:15:22 +02:00
|
|
|
language: cpp
|
2013-04-06 00:45:04 +02:00
|
|
|
branches:
|
|
|
|
only:
|
|
|
|
- master
|
2014-02-13 12:30:53 +01:00
|
|
|
- /openmw-.*$/
|
2020-01-26 20:17:33 +01:00
|
|
|
cache: ccache
|
2014-12-17 23:19:37 +01:00
|
|
|
addons:
|
2016-08-15 17:04:29 +03:00
|
|
|
apt:
|
|
|
|
sources:
|
|
|
|
- sourceline: 'ppa:openmw/openmw'
|
|
|
|
packages: [
|
|
|
|
# Dev
|
2021-04-08 00:05:02 +02:00
|
|
|
build-essential, cmake, clang-tools-9, ccache,
|
2016-08-15 17:04:29 +03:00
|
|
|
# Boost
|
2019-01-20 21:18:52 +01:00
|
|
|
libboost-filesystem-dev, libboost-iostreams-dev, libboost-program-options-dev, libboost-system-dev,
|
2016-08-15 17:04:29 +03:00
|
|
|
# FFmpeg
|
2018-11-14 21:14:14 +01:00
|
|
|
libavcodec-dev, libavformat-dev, libavutil-dev, libswresample-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 17:38:09 +01:00
|
|
|
# Audio, Video and Misc. deps
|
2020-11-13 16:38:53 +01:00
|
|
|
libsdl2-dev, libqt5opengl5-dev, libopenal-dev, libunshield-dev, libtinyxml-dev, liblz4-dev,
|
2020-10-16 00:05:55 +02:00
|
|
|
# The other ones from OpenMW ppa
|
2020-04-19 17:35:01 +02:00
|
|
|
libbullet-dev, libopenscenegraph-dev, libmygui-dev
|
2016-08-15 17:04:29 +03:00
|
|
|
]
|
2015-03-17 09:45:31 -04:00
|
|
|
matrix:
|
|
|
|
include:
|
2021-04-25 13:26:50 +00:00
|
|
|
- name: OpenMW (all) on MacOS 10.15 with Xcode 11.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 17:38:09 +01:00
|
|
|
os: osx
|
2021-04-25 13:26:50 +00:00
|
|
|
osx_image: xcode11.6
|
2020-06-23 07:59:05 +02:00
|
|
|
- name: OpenMW (all) on Ubuntu Focal with GCC
|
2018-11-14 21:14:14 +01:00
|
|
|
os: linux
|
2020-06-22 15:51:56 +02:00
|
|
|
dist: focal
|
2020-10-02 22:46:23 +02:00
|
|
|
- name: OpenMW (tests only) on Ubuntu Focal with GCC
|
|
|
|
os: linux
|
|
|
|
dist: focal
|
|
|
|
env:
|
|
|
|
- BUILD_TESTS_ONLY: 1
|
2020-06-23 07:59:05 +02:00
|
|
|
- name: OpenMW (openmw) on Ubuntu Focal with Clang's Static Analysis
|
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 17:38:09 +01:00
|
|
|
os: linux
|
2020-06-22 15:51:56 +02:00
|
|
|
dist: focal
|
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 17:38:09 +01:00
|
|
|
env:
|
2021-04-08 00:05:02 +02:00
|
|
|
- MATRIX_EVAL="CC=clang-9 && CXX=clang++-9"
|
|
|
|
- ANALYZE="scan-build-9 --force-analyze-debug-code --use-cc clang-9 --use-c++ clang++-9"
|
2015-03-17 09:45:31 -04:00
|
|
|
compiler: clang
|
2014-12-17 23:19:37 +01: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 17:38:09 +01:00
|
|
|
before_install:
|
|
|
|
- if [ "${TRAVIS_OS_NAME}" = "linux" ]; then eval "${MATRIX_EVAL}"; fi
|
2020-11-13 16:38:53 +01:00
|
|
|
- ./CI/before_install.${TRAVIS_OS_NAME}.sh
|
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 17:38:09 +01:00
|
|
|
before_script:
|
2020-01-26 20:44:31 +01:00
|
|
|
- ccache -z
|
2020-11-13 16:42:10 +01:00
|
|
|
- ./CI/before_script.${TRAVIS_OS_NAME}.sh
|
2013-04-06 00:45:04 +02:00
|
|
|
script:
|
2014-10-04 15:23:23 +04:00
|
|
|
- cd ./build
|
2020-11-13 16:38:53 +01:00
|
|
|
- ${ANALYZE} make -j3;
|
|
|
|
- if [ "${TRAVIS_OS_NAME}" = "osx" ]; then make package; fi
|
|
|
|
- if [ "${TRAVIS_OS_NAME}" = "osx" ]; then ../CI/check_package.osx.sh; fi
|
|
|
|
- if [ "${TRAVIS_OS_NAME}" = "linux" ] && [ "${BUILD_TESTS_ONLY}" ]; then ./openmw_test_suite; fi
|
|
|
|
- if [ "${TRAVIS_OS_NAME}" = "linux" ]; then cd .. && ./CI/check_tabs.sh; fi
|
2017-03-04 21:29:02 +01:00
|
|
|
- cd "${TRAVIS_BUILD_DIR}"
|
2020-01-26 20:44:31 +01:00
|
|
|
- ccache -s
|
2017-03-04 21:29:02 +01:00
|
|
|
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 23:15:22 +02:00
|
|
|
notifications:
|
|
|
|
email:
|
2021-04-08 00:24:15 +02:00
|
|
|
if: repository_slug = OpenMW/openmw AND branch = master
|
2016-12-18 14:43:50 +01:00
|
|
|
recipients:
|
|
|
|
- corrmage+travis-ci@gmail.com
|
2013-04-02 23:15:22 +02:00
|
|
|
on_success: change
|
|
|
|
on_failure: always
|
2014-10-21 16:12:33 +02:00
|
|
|
irc:
|
2021-04-08 00:24:15 +02:00
|
|
|
if: repository_slug = OpenMW/openmw AND branch = master
|
2014-10-21 16:12:33 +02:00
|
|
|
channels:
|
2021-05-31 21:11:43 +01:00
|
|
|
- "irc.libera.chat#openmw"
|
2014-10-21 16:12:33 +02:00
|
|
|
on_success: change
|
|
|
|
on_failure: always
|
|
|
|
use_notice: true
|