diff --git a/.travis.yml b/.travis.yml index eeb50ce0de71..3b9136a3e48c 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,9 +5,9 @@ os: - osx before_install: - - if [ $TRAVIS_OS_NAME == osx ]; then curl http://www.cmake.org/files/v2.8/cmake-2.8.12.2-Darwin64-universal.tar.gz -o cmake.tar.gz; fi + - if [ $TRAVIS_OS_NAME == osx ]; then curl http://www.cmake.org/files/v3.0/cmake-3.0.2-Darwin64-universal.tar.gz -o cmake.tar.gz; fi - if [ $TRAVIS_OS_NAME == osx ]; then tar xzf cmake.tar.gz; fi - - if [ $TRAVIS_OS_NAME == osx ]; then export PATH=$PATH:"cmake-2.8.12.2-Darwin64-universal/CMake 2.8-12.app/Contents/bin"; fi + - if [ $TRAVIS_OS_NAME == osx ]; then export PATH=$PATH:"cmake-3.0.2-Darwin64-universal/CMake.app/Contents/bin"; fi - git submodule update --init env: @@ -15,9 +15,14 @@ env: - BUILD_TYPE=Release script: - - cmake -DCMAKE_BUILD_TYPE=$BUILD_TYPE -DFMT_EXTRA_TESTS=ON . + - mkdir build && cd build + - cmake -DCMAKE_BUILD_TYPE=$BUILD_TYPE -DFMT_EXTRA_TESTS=ON .. - make -j4 - CTEST_OUTPUT_ON_FAILURE=1 make test + - cd .. && rm -rf build/ + # Building with biicode + - ./biicode/support/travis-build.sh + after_failure: - cat Testing/Temporary/LastTest.log diff --git a/CMakeLists.txt b/CMakeLists.txt index b73f5979c51f..bf3de7183986 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -61,6 +61,11 @@ if (CPP11_FLAG) set(CMAKE_REQUIRED_FLAGS ${CPP11_FLAG}) endif () +if(BIICODE) + include(biicode/cmake/biicode.cmake) + return() +endif(BIICODE) + add_library(format ${FMT_SOURCES}) if (CMAKE_COMPILER_IS_GNUCXX) set_target_properties(format PROPERTIES COMPILE_FLAGS diff --git a/biicode.conf b/biicode.conf new file mode 100644 index 000000000000..f4fd4bce2d61 --- /dev/null +++ b/biicode.conf @@ -0,0 +1,16 @@ +# Biicode configuration file + +[paths] + # Local directories to look for headers (within block) + / + +[dependencies] + # Manual adjust file implicit dependencies, add (+), remove (-), or overwrite (=) + CMakeLists.txt + cmake/FindSetEnv.cmake + format.h = format.cc + format.cc - test/* posix.cc + biicode/samples/basic.cpp - test/* + +[mains] + # Manual adjust of files that define an executable + !test/test-main.cc diff --git a/biicode/cmake/biicode.cmake b/biicode/cmake/biicode.cmake new file mode 100644 index 000000000000..02d6ee2465c6 --- /dev/null +++ b/biicode/cmake/biicode.cmake @@ -0,0 +1,18 @@ +# Initializes block variables +INIT_BIICODE_BLOCK() + +# Actually create targets: EXEcutables and libraries. +ADD_BIICODE_TARGETS() + +target_include_directories(${BII_BLOCK_TARGET} INTERFACE ${CMAKE_CURRENT_SOURCE_DIR}) + +if (HAVE_OPEN) + target_compile_definitions(${BII_BLOCK_TARGET} INTERFACE -DFMT_USE_FILE_DESCRIPTORS=1) +endif () + +if (CMAKE_COMPILER_IS_GNUCXX) + target_compile_options(${BII_BLOCK_TARGET} INTERFACE -Wall -Wextra -Wshadow -pedantic) +endif () +if (CPP11_FLAG AND FMT_EXTRA_TESTS) + target_compile_options(${BII_BLOCK_TARGET} INTERFACE ${CPP11_FLAG}) +endif () diff --git a/biicode/samples/basic.cpp b/biicode/samples/basic.cpp new file mode 100644 index 000000000000..727ed013690d --- /dev/null +++ b/biicode/samples/basic.cpp @@ -0,0 +1,18 @@ +#include "vitaut/cppformat/format.h" + +class Date { + int year_, month_, day_; + public: + Date(int year, int month, int day) : year_(year), month_(month), day_(day) {} + + friend std::ostream &operator<<(std::ostream &os, const Date &d) { + return os << d.year_ << '-' << d.month_ << '-' << d.day_; + } +}; + +int main(int argc, char *argv[]){ + std::string s = fmt::format("The date is {}", Date(2012, 12, 9)); + fmt::print("Hello, {}!", "world"); // uses Python-like format string syntax + fmt::printf("\n%s", s); // uses printf format string syntax + return 0; +} diff --git a/biicode/support/travis-build.sh b/biicode/support/travis-build.sh new file mode 100755 index 000000000000..6984bc2d3801 --- /dev/null +++ b/biicode/support/travis-build.sh @@ -0,0 +1,30 @@ +#!/bin/bash + +if [ $TRAVIS_OS_NAME == linux ]; then + sudo apt-get install libglu1-mesa-dev xorg-dev + wget http://www.biicode.com/downloads/latest/ubuntu64 + mv ubuntu64 bii-ubuntu64.deb + (sudo dpkg -i bii-ubuntu64.deb) && sudo apt-get -f install + rm bii-ubuntu64.deb + wget https://s3.amazonaws.com/biibinaries/thirdparty/cmake-3.0.2-Linux-64.tar.gz + tar -xzf cmake-3.0.2-Linux-64.tar.gz + sudo cp -fR cmake-3.0.2-Linux-64/* /usr + rm -rf cmake-3.0.2-Linux-64 + rm cmake-3.0.2-Linux-64.tar.gz +elif [ $TRAVIS_OS_NAME == osx ]; then + wget http://www.biicode.com/downloads/latest/macos + mv macos macos.pkg + sudo installer -pkg macos.pkg -target / + rm macos.pkg +fi + +cmake --version +bii init biicode_project +mkdir -p ./biicode_project/blocks/vitaut/cppformat +shopt -s extglob +mv !(biicode_project|cmake-3.0.2-Darwin64-universal) ./biicode_project/blocks/vitaut/cppformat +cd biicode_project +bii cpp:build +ls bin/* +./bin/vitaut_cppformat_biicode_samples_basic + diff --git a/ignore.bii b/ignore.bii new file mode 100644 index 000000000000..8944b6194d65 --- /dev/null +++ b/ignore.bii @@ -0,0 +1,3 @@ +doc/* +breathe/* +gmock/*