Merge branch 'master' into example_parsebyparts
This commit is contained in:
commit
2de47aae12
160
.travis.yml
160
.travis.yml
@ -1,54 +1,138 @@
|
|||||||
language: cpp
|
language: cpp
|
||||||
|
sudo: false
|
||||||
|
cache:
|
||||||
|
- ccache
|
||||||
|
|
||||||
compiler:
|
addons:
|
||||||
- clang
|
apt:
|
||||||
- gcc
|
packages: &default_packages
|
||||||
|
- cmake
|
||||||
|
- valgrind
|
||||||
|
|
||||||
env:
|
env:
|
||||||
matrix:
|
global:
|
||||||
- CONF=debug ARCH=x86_64 CXX11=ON
|
- USE_CCACHE=1
|
||||||
- CONF=release ARCH=x86_64 CXX11=ON
|
- CCACHE_SLOPPINESS=pch_defines,time_macros
|
||||||
- CONF=debug ARCH=x86 CXX11=ON
|
- CCACHE_COMPRESS=1
|
||||||
- CONF=release ARCH=x86 CXX11=ON
|
- CCACHE_MAXSIZE=100M
|
||||||
- CONF=debug ARCH=x86_64 CXX11=OFF
|
|
||||||
- CONF=debug ARCH=x86 CXX11=OFF
|
|
||||||
global:
|
|
||||||
- ARCH_FLAGS_x86='-m32' # #266: don't use SSE on 32-bit
|
- ARCH_FLAGS_x86='-m32' # #266: don't use SSE on 32-bit
|
||||||
- ARCH_FLAGS_x86_64='-msse4.2' # use SSE4.2 on 64-bit
|
- ARCH_FLAGS_x86_64='-msse4.2' # use SSE4.2 on 64-bit
|
||||||
- GITHUB_REPO='miloyip/rapidjson'
|
- GITHUB_REPO='miloyip/rapidjson'
|
||||||
- secure: "HrsaCb+N66EG1HR+LWH1u51SjaJyRwJEDzqJGYMB7LJ/bfqb9mWKF1fLvZGk46W5t7TVaXRDD5KHFx9DPWvKn4gRUVkwTHEy262ah5ORh8M6n/6VVVajeV/AYt2C0sswdkDBDO4Xq+xy5gdw3G8s1A4Inbm73pUh+6vx+7ltBbk="
|
- secure: "HrsaCb+N66EG1HR+LWH1u51SjaJyRwJEDzqJGYMB7LJ/bfqb9mWKF1fLvZGk46W5t7TVaXRDD5KHFx9DPWvKn4gRUVkwTHEy262ah5ORh8M6n/6VVVajeV/AYt2C0sswdkDBDO4Xq+xy5gdw3G8s1A4Inbm73pUh+6vx+7ltBbk="
|
||||||
|
|
||||||
before_install:
|
matrix:
|
||||||
- sudo apt-get update -qq
|
include:
|
||||||
- sudo apt-get install -qq cmake valgrind
|
# gcc
|
||||||
- sudo apt-get --no-install-recommends install doxygen # Don't install LaTeX stuffs
|
- env: CONF=release ARCH=x86 CXX11=ON
|
||||||
- if [ "$ARCH" = "x86" ]; then sudo apt-get install -qq g++-multilib libc6-dbg:i386; fi
|
compiler: gcc
|
||||||
- if [ "$CC" = "gcc" ] && [ "$CONF" = "debug" ]; then sudo pip install cpp-coveralls; export GCOV_FLAGS='--coverage'; fi
|
addons:
|
||||||
|
apt:
|
||||||
install: true
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
- env: CONF=release ARCH=x86_64 CXX11=ON
|
||||||
|
compiler: gcc
|
||||||
|
- env: CONF=debug ARCH=x86 CXX11=OFF
|
||||||
|
compiler: gcc
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
- env: CONF=debug ARCH=x86_64 CXX11=OFF
|
||||||
|
compiler: gcc
|
||||||
|
# clang
|
||||||
|
- env: CONF=debug ARCH=x86 CXX11=ON CCACHE_CPP2=yes
|
||||||
|
compiler: clang
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
- env: CONF=debug ARCH=x86_64 CXX11=ON CCACHE_CPP2=yes
|
||||||
|
compiler: clang
|
||||||
|
- env: CONF=debug ARCH=x86 CXX11=OFF CCACHE_CPP2=yes
|
||||||
|
compiler: clang
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
- env: CONF=debug ARCH=x86_64 CXX11=OFF CCACHE_CPP2=yes
|
||||||
|
compiler: clang
|
||||||
|
- env: CONF=release ARCH=x86 CXX11=ON CCACHE_CPP2=yes
|
||||||
|
compiler: clang
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
- env: CONF=release ARCH=x86_64 CXX11=ON CCACHE_CPP2=yes
|
||||||
|
compiler: clang
|
||||||
|
# coverage report
|
||||||
|
- env: CONF=debug ARCH=x86 CXX11=ON GCOV_FLAGS='--coverage'
|
||||||
|
compiler: gcc
|
||||||
|
cache:
|
||||||
|
- ccache
|
||||||
|
- pip
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
after_success:
|
||||||
|
- pip install --user cpp-coveralls
|
||||||
|
- coveralls -r .. --gcov-options '\-lp' -e thirdparty -e example -e test -e build/CMakeFiles -e include/rapidjson/msinttypes -e include/rapidjson/internal/meta.h -e include/rapidjson/error/en.h
|
||||||
|
- env: CONF=debug ARCH=x86_64 GCOV_FLAGS='--coverage'
|
||||||
|
compiler: gcc
|
||||||
|
cache:
|
||||||
|
- ccache
|
||||||
|
- pip
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- *default_packages
|
||||||
|
- g++-multilib
|
||||||
|
- libc6-dbg:i386
|
||||||
|
after_success:
|
||||||
|
- pip install --user cpp-coveralls
|
||||||
|
- coveralls -r .. --gcov-options '\-lp' -e thirdparty -e example -e test -e build/CMakeFiles -e include/rapidjson/msinttypes -e include/rapidjson/internal/meta.h -e include/rapidjson/error/en.h
|
||||||
|
- script: # Documentation task
|
||||||
|
- cd build
|
||||||
|
- cmake .. -DRAPIDJSON_HAS_STDSTRING=ON -DCMAKE_VERBOSE_MAKEFILE=ON
|
||||||
|
- make travis_doc
|
||||||
|
cache: false
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
packages:
|
||||||
|
- doxygen
|
||||||
|
|
||||||
before_script:
|
before_script:
|
||||||
# hack to avoid Valgrind bug (https://bugs.kde.org/show_bug.cgi?id=326469),
|
- ccache -s
|
||||||
# exposed by merging PR#163 (using -march=native)
|
# hack to avoid Valgrind bug (https://bugs.kde.org/show_bug.cgi?id=326469),
|
||||||
|
# exposed by merging PR#163 (using -march=native)
|
||||||
|
# TODO: Since this bug is already fixed. Remove this when valgrind can be upgraded.
|
||||||
- sed -i "s/-march=native//" CMakeLists.txt
|
- sed -i "s/-march=native//" CMakeLists.txt
|
||||||
- mkdir build
|
- mkdir build
|
||||||
- >
|
|
||||||
eval "ARCH_FLAGS=\${ARCH_FLAGS_${ARCH}}" ;
|
|
||||||
(cd build && cmake
|
|
||||||
-DRAPIDJSON_HAS_STDSTRING=ON
|
|
||||||
-DRAPIDJSON_BUILD_CXX11=$CXX11
|
|
||||||
-DCMAKE_VERBOSE_MAKEFILE=ON
|
|
||||||
-DCMAKE_BUILD_TYPE=$CONF
|
|
||||||
-DCMAKE_CXX_FLAGS="$ARCH_FLAGS $GCOV_FLAGS"
|
|
||||||
-DCMAKE_EXE_LINKER_FLAGS=$GCOV_FLAGS
|
|
||||||
..)
|
|
||||||
|
|
||||||
script:
|
script:
|
||||||
|
- >
|
||||||
|
eval "ARCH_FLAGS=\${ARCH_FLAGS_${ARCH}}" ;
|
||||||
|
(cd build && cmake
|
||||||
|
-DRAPIDJSON_HAS_STDSTRING=ON
|
||||||
|
-DRAPIDJSON_BUILD_CXX11=$CXX11
|
||||||
|
-DCMAKE_VERBOSE_MAKEFILE=ON
|
||||||
|
-DCMAKE_BUILD_TYPE=$CONF
|
||||||
|
-DCMAKE_CXX_FLAGS="$ARCH_FLAGS $GCOV_FLAGS"
|
||||||
|
-DCMAKE_EXE_LINKER_FLAGS=$GCOV_FLAGS
|
||||||
|
..)
|
||||||
- cd build
|
- cd build
|
||||||
- make tests
|
- make tests -j 2
|
||||||
- make examples
|
- make examples -j 2
|
||||||
- ctest -V `[ "$CONF" = "release" ] || echo "-E perftest"`
|
- ctest -j 2 -V `[ "$CONF" = "release" ] || echo "-E perftest"`
|
||||||
- make travis_doc
|
|
||||||
|
|
||||||
after_success:
|
|
||||||
- coveralls -r .. --gcov-options '\-lp' -e thirdparty -e example -e test -e build/CMakeFiles -e include/rapidjson/msinttypes -e include/rapidjson/internal/meta.h -e include/rapidjson/error/en.h
|
|
||||||
|
@ -29,6 +29,15 @@ if(RAPIDJSON_HAS_STDSTRING)
|
|||||||
add_definitions(-DRAPIDJSON_HAS_STDSTRING)
|
add_definitions(-DRAPIDJSON_HAS_STDSTRING)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
find_program(CCACHE_FOUND ccache)
|
||||||
|
if(CCACHE_FOUND)
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache)
|
||||||
|
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Qunused-arguments -fcolor-diagnostics")
|
||||||
|
endif()
|
||||||
|
endif(CCACHE_FOUND)
|
||||||
|
|
||||||
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=native -Wall -Wextra -Werror")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=native -Wall -Wextra -Werror")
|
||||||
if (RAPIDJSON_BUILD_CXX11)
|
if (RAPIDJSON_BUILD_CXX11)
|
||||||
|
@ -159,7 +159,7 @@
|
|||||||
*/
|
*/
|
||||||
#ifndef RAPIDJSON_NO_INT64DEFINE
|
#ifndef RAPIDJSON_NO_INT64DEFINE
|
||||||
//!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
|
//!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
|
||||||
#ifdef _MSC_VER
|
#if defined(_MSC_VER) && (_MSC_VER < 1800) // Visual Studio 2013
|
||||||
#include "msinttypes/stdint.h"
|
#include "msinttypes/stdint.h"
|
||||||
#include "msinttypes/inttypes.h"
|
#include "msinttypes/inttypes.h"
|
||||||
#else
|
#else
|
||||||
|
@ -10,6 +10,15 @@ target_link_libraries(perftest ${TEST_LIBRARIES})
|
|||||||
|
|
||||||
add_dependencies(tests perftest)
|
add_dependencies(tests perftest)
|
||||||
|
|
||||||
|
find_program(CCACHE_FOUND ccache)
|
||||||
|
if(CCACHE_FOUND)
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache)
|
||||||
|
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Qunused-arguments -fcolor-diagnostics")
|
||||||
|
endif()
|
||||||
|
endif(CCACHE_FOUND)
|
||||||
|
|
||||||
IF(NOT (CMAKE_BUILD_TYPE STREQUAL "Debug"))
|
IF(NOT (CMAKE_BUILD_TYPE STREQUAL "Debug"))
|
||||||
add_test(NAME perftest
|
add_test(NAME perftest
|
||||||
COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/perftest
|
COMMAND ${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/perftest
|
||||||
|
@ -25,6 +25,15 @@ set(UNITTEST_SOURCES
|
|||||||
valuetest.cpp
|
valuetest.cpp
|
||||||
writertest.cpp)
|
writertest.cpp)
|
||||||
|
|
||||||
|
find_program(CCACHE_FOUND ccache)
|
||||||
|
if(CCACHE_FOUND)
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_COMPILE ccache)
|
||||||
|
set_property(GLOBAL PROPERTY RULE_LAUNCH_LINK ccache)
|
||||||
|
if (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Qunused-arguments -fcolor-diagnostics")
|
||||||
|
endif()
|
||||||
|
endif(CCACHE_FOUND)
|
||||||
|
|
||||||
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror -Wall -Wextra -Weffc++ -Wswitch-default -Wfloat-equal")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror -Wall -Wextra -Weffc++ -Wswitch-default -Wfloat-equal")
|
||||||
elseif (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
elseif (CMAKE_CXX_COMPILER_ID MATCHES "Clang")
|
||||||
|
Loading…
x
Reference in New Issue
Block a user