mirror of
https://github.com/tfussell/xlnt.git
synced 2024-03-22 13:11:17 +08:00
try to integrate coveralls and improve configure script
This commit is contained in:
parent
acfb5c642b
commit
6fd3fef717
64
.travis.yml
64
.travis.yml
|
@ -1,21 +1,51 @@
|
||||||
|
# from: https://github.com/nlohmann/json/blob/master/.travis.yml
|
||||||
|
|
||||||
language: cpp
|
language: cpp
|
||||||
script:
|
|
||||||
- python configure --shared --build-tests --autotest && make -C build
|
|
||||||
compiler:
|
|
||||||
- clang
|
|
||||||
- gcc
|
|
||||||
install:
|
|
||||||
- if [ "$CXX" = "g++" ]; then export CXX="g++-4.8" CC="gcc-4.8"; fi
|
|
||||||
addons:
|
|
||||||
apt:
|
|
||||||
sources:
|
|
||||||
- ubuntu-toolchain-r-test
|
|
||||||
packages:
|
|
||||||
- gcc-4.8
|
|
||||||
- g++-4.8
|
|
||||||
- clang
|
|
||||||
notifications:
|
|
||||||
email: false
|
|
||||||
sudo: false
|
sudo: false
|
||||||
|
|
||||||
|
matrix:
|
||||||
|
include:
|
||||||
|
- os: linux
|
||||||
|
compiler: gcc
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
sources: ['ubuntu-toolchain-r-test']
|
||||||
|
packages: ['g++-4.9', 'valgrind', 'python-pip', 'python-yaml']
|
||||||
|
before_script:
|
||||||
|
- pip install --user git+git://github.com/eddyxu/cpp-coveralls.git
|
||||||
|
env: COMPILER=g++-4.9
|
||||||
|
|
||||||
|
- os: linux
|
||||||
|
compiler: gcc
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
sources: ['ubuntu-toolchain-r-test']
|
||||||
|
packages: ['g++-5', 'valgrind']
|
||||||
|
env: COMPILER=g++-5
|
||||||
|
|
||||||
|
- os: linux
|
||||||
|
compiler: clang
|
||||||
|
addons:
|
||||||
|
apt:
|
||||||
|
sources: ['ubuntu-toolchain-r-test', 'llvm-toolchain-precise-3.6']
|
||||||
|
packages: ['clang-3.6', 'valgrind']
|
||||||
|
env: COMPILER=clang++-3.6
|
||||||
|
|
||||||
|
script:
|
||||||
|
- ./configure --enable-shared --enable-tests
|
||||||
|
- make -C build CXX=$COMPILER CXXFLAGS="-lstdc++"
|
||||||
|
- ./bin/xlnt.test
|
||||||
|
- valgrind --error-exitcode=1 --leak-check=full ./xlnt.test
|
||||||
|
|
||||||
|
after_success:
|
||||||
|
- if [ "$COMPILER" = "g++-4.9" ]; then make -C build clean ; fi
|
||||||
|
- if [ "$COMPILER" = "g++-4.9" ]; then touch include/xlnt/xlnt_config.hpp ; fi
|
||||||
|
- if [ "$COMPILER" = "g++-4.9" ]; then make -C build xlnt.test CXXFLAGS="-fprofile-arcs -ftest-coverage -std=c++11 -lstdc++" CXX=$COMPILER ; fi
|
||||||
|
- if [ "$COMPILER" = "g++-4.9" ]; then ./bin/xlnt.test ; fi
|
||||||
|
- if [ "$COMPILER" = "g++-4.9" ]; then coveralls --include source/worksheet/test_worksheet.hpp --gcov-options '\-lp' --gcov 'gcov-4.9' ; fi
|
||||||
|
|
||||||
|
notifications:
|
||||||
|
email: false
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -67,23 +67,40 @@ SET(MINIZ ../third-party/miniz/miniz.c ../third-party/miniz/miniz.h)
|
||||||
SET(PUGIXML ../third-party/pugixml/src/pugixml.hpp ../third-party/pugixml/src/pugixml.cpp ../third-party/pugixml/src/pugiconfig.hpp)
|
SET(PUGIXML ../third-party/pugixml/src/pugixml.hpp ../third-party/pugixml/src/pugixml.cpp ../third-party/pugixml/src/pugiconfig.hpp)
|
||||||
|
|
||||||
if(SHARED)
|
if(SHARED)
|
||||||
add_library(xlnt SHARED ${HEADERS} ${SOURCES} ${MINIZ} ${PUGIXML})
|
add_library(xlnt.shared SHARED ${HEADERS} ${SOURCES} ${MINIZ} ${PUGIXML})
|
||||||
add_definitions(-DXLNT_SHARED)
|
add_definitions(-DXLNT_SHARED)
|
||||||
if(MSVC)
|
if(MSVC)
|
||||||
target_compile_definitions(xlnt PRIVATE XLNT_EXPORT=1)
|
target_compile_definitions(xlnt.shared PRIVATE XLNT_EXPORT=1)
|
||||||
set_target_properties(xlnt PROPERTIES COMPILE_FLAGS "/wd\"4251\" /wd\"4275\"")
|
set_target_properties(xlnt.shared PROPERTIES COMPILE_FLAGS "/wd\"4251\" /wd\"4275\"")
|
||||||
endif()
|
endif()
|
||||||
else()
|
install(TARGETS xlnt.shared
|
||||||
add_library(xlnt STATIC ${HEADERS} ${SOURCES} ${MINIZ} ${PUGIXML})
|
LIBRARY DESTINATION ${LIB_DEST_DIR}
|
||||||
endif()
|
ARCHIVE DESTINATION ${LIB_DEST_DIR}
|
||||||
|
RUNTIME DESTINATION ${BIN_DEST_DIR}
|
||||||
|
)
|
||||||
SET_TARGET_PROPERTIES(
|
SET_TARGET_PROPERTIES(
|
||||||
xlnt
|
xlnt.shared
|
||||||
PROPERTIES
|
PROPERTIES
|
||||||
|
OUTPUT_NAME xlnt
|
||||||
VERSION ${PROJECT_VERSION_FULL}
|
VERSION ${PROJECT_VERSION_FULL}
|
||||||
SOVERSION ${PROJECT_VERSION}
|
SOVERSION ${PROJECT_VERSION}
|
||||||
INSTALL_NAME_DIR "${LIB_DEST_DIR}"
|
INSTALL_NAME_DIR "${LIB_DEST_DIR}"
|
||||||
)
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(STATIC)
|
||||||
|
add_library(xlnt.static STATIC ${HEADERS} ${SOURCES} ${MINIZ} ${PUGIXML})
|
||||||
|
install(TARGETS xlnt.static
|
||||||
|
LIBRARY DESTINATION ${LIB_DEST_DIR}
|
||||||
|
ARCHIVE DESTINATION ${LIB_DEST_DIR}
|
||||||
|
RUNTIME DESTINATION ${BIN_DEST_DIR}
|
||||||
|
)
|
||||||
|
SET_TARGET_PROPERTIES(
|
||||||
|
xlnt.static
|
||||||
|
PROPERTIES
|
||||||
|
OUTPUT_NAME xlnt
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
source_group(xlnt FILES ${ROOT_HEADERS})
|
source_group(xlnt FILES ${ROOT_HEADERS})
|
||||||
source_group(detail FILES ${DETAIL_HEADERS} ${DETAIL_SOURCES})
|
source_group(detail FILES ${DETAIL_HEADERS} ${DETAIL_SOURCES})
|
||||||
|
@ -118,18 +135,11 @@ configure_file(
|
||||||
"${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
|
"${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
|
||||||
IMMEDIATE @ONLY)
|
IMMEDIATE @ONLY)
|
||||||
|
|
||||||
|
|
||||||
install(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/../include/xlnt
|
install(DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}/../include/xlnt
|
||||||
DESTINATION include
|
DESTINATION include
|
||||||
PATTERN ".DS_Store" EXCLUDE
|
PATTERN ".DS_Store" EXCLUDE
|
||||||
)
|
)
|
||||||
|
|
||||||
install(TARGETS xlnt
|
|
||||||
LIBRARY DESTINATION ${LIB_DEST_DIR}
|
|
||||||
ARCHIVE DESTINATION ${LIB_DEST_DIR}
|
|
||||||
RUNTIME DESTINATION ${BIN_DEST_DIR}
|
|
||||||
)
|
|
||||||
|
|
||||||
install(FILES "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.pc"
|
install(FILES "${CMAKE_BINARY_DIR}/${PROJECT_NAME}.pc"
|
||||||
DESTINATION ${LIB_DEST_DIR}/pkgconfig
|
DESTINATION ${LIB_DEST_DIR}/pkgconfig
|
||||||
)
|
)
|
||||||
|
|
|
@ -43,7 +43,11 @@ source_group(tests\\workbook FILES ${WORKBOOK_TESTS})
|
||||||
source_group(tests\\worksheet FILES ${WORKSHEET_TESTS})
|
source_group(tests\\worksheet FILES ${WORKSHEET_TESTS})
|
||||||
source_group(runner FILES ${RUNNER})
|
source_group(runner FILES ${RUNNER})
|
||||||
|
|
||||||
target_link_libraries(xlnt.test xlnt)
|
if(SHARED)
|
||||||
|
target_link_libraries(xlnt.test xlnt.shared)
|
||||||
|
else()
|
||||||
|
target_link_libraries(xlnt.test xlnt.static)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(MSVC)
|
if(MSVC)
|
||||||
set_target_properties(xlnt.test PROPERTIES COMPILE_FLAGS "/wd\"4251\" /wd\"4275\"")
|
set_target_properties(xlnt.test PROPERTIES COMPILE_FLAGS "/wd\"4251\" /wd\"4275\"")
|
||||||
|
|
24
configure
vendored
24
configure
vendored
|
@ -58,7 +58,7 @@ def find_cmake():
|
||||||
return cmake
|
return cmake
|
||||||
|
|
||||||
def parse_args(args):
|
def parse_args(args):
|
||||||
options = {}
|
options = {'SHARED' : 1}
|
||||||
generator = default_generator(sys.platform)
|
generator = default_generator(sys.platform)
|
||||||
|
|
||||||
if len(args) == 0:
|
if len(args) == 0:
|
||||||
|
@ -73,18 +73,24 @@ def parse_args(args):
|
||||||
if not option.startswith('--'):
|
if not option.startswith('--'):
|
||||||
raise Exception('bad option: {}'.format(option))
|
raise Exception('bad option: {}'.format(option))
|
||||||
|
|
||||||
if option == '--shared':
|
if option == '--enable-shared':
|
||||||
options['SHARED'] = 1
|
options['SHARED'] = 1
|
||||||
elif option == '--static':
|
elif option == '--enable-static':
|
||||||
|
options['STATIC'] = 1
|
||||||
|
elif option == '--disable-shared':
|
||||||
options['SHARED'] = 0
|
options['SHARED'] = 0
|
||||||
elif option == '--build-tests':
|
elif option == '--disable-static':
|
||||||
|
options['STATIC'] = 0
|
||||||
|
elif option == '--enable-tests':
|
||||||
options['BUILD_TESTS'] = 1
|
options['BUILD_TESTS'] = 1
|
||||||
elif option == '--autotest':
|
elif option == '--enable-coverage':
|
||||||
options['AUTORUN_TESTS'] = 1
|
options['CALC_COVERAGE'] = 1
|
||||||
elif option == '--coverage':
|
elif option == '--enable-examples':
|
||||||
options['COVERAGE'] = 1
|
|
||||||
elif option == '--build-examples':
|
|
||||||
options['BUILD_EXAMPLES'] = 1
|
options['BUILD_EXAMPLES'] = 1
|
||||||
|
elif option == '--enable-benchmarks':
|
||||||
|
options['BUILD_BENCHMARKS'] = 1
|
||||||
|
elif option == '--enable-benchmarks':
|
||||||
|
options['BUILD_BENCHMARKS'] = 1
|
||||||
elif option.startswith('--prefix='):
|
elif option.startswith('--prefix='):
|
||||||
options['CMAKE_INSTALL_PREFIX'] = option.split('=')[1]
|
options['CMAKE_INSTALL_PREFIX'] = option.split('=')[1]
|
||||||
else:
|
else:
|
||||||
|
|
Loading…
Reference in New Issue
Block a user