Merge pull request #194 from robertodr/yaml-project-language
Parse language field in YAML
This commit is contained in:
commit
5c4a515a31
@ -53,14 +53,16 @@ matrix:
|
||||
- libboost-all-dev
|
||||
|
||||
- os: osx
|
||||
osx_image: xcode6.4
|
||||
osx_image: xcode7.3
|
||||
compiler: gcc
|
||||
env: SOURCES=homebrew
|
||||
env:
|
||||
- SOURCES=homebrew
|
||||
|
||||
install:
|
||||
- |
|
||||
if [[ "${TRAVIS_OS_NAME}" == "osx" ]]; then
|
||||
brew install cmake boost python gcc open-mpi
|
||||
brew install cmake boost python open-mpi
|
||||
brew reinstall gcc
|
||||
pip install virtualenv
|
||||
elif [[ "${TRAVIS_OS_NAME}" == "linux" ]]; then
|
||||
pip install --user virtualenv
|
||||
|
@ -118,7 +118,7 @@ def gen_setup(config, default_build_type, relative_path, setup_script_name):
|
||||
return s
|
||||
|
||||
|
||||
def gen_cmakelists(project_name, min_cmake_version, default_build_type, relative_path, modules):
|
||||
def gen_cmakelists(project_name, project_language, min_cmake_version, default_build_type, relative_path, modules):
|
||||
"""
|
||||
Generate CMakeLists.txt.
|
||||
"""
|
||||
@ -132,7 +132,7 @@ def gen_cmakelists(project_name, min_cmake_version, default_build_type, relative
|
||||
s.append('cmake_minimum_required(VERSION {0} FATAL_ERROR)'.format(min_cmake_version))
|
||||
|
||||
s.append('\n# project name')
|
||||
s.append('project({0})'.format(project_name))
|
||||
s.append('project({0} {1})'.format(project_name, project_language))
|
||||
|
||||
s.append('\n# do not rebuild if rules (compiler flags) change')
|
||||
s.append('set(CMAKE_SKIP_RULE_DEPENDENCY TRUE)')
|
||||
|
@ -25,8 +25,6 @@
|
||||
# export: "'CC={0}'.format(arguments['--cc'])"
|
||||
# define: "'-DEXTRA_CFLAGS=\"{0}\"'.format(arguments['--extra-cc-flags'])"
|
||||
|
||||
enable_language(C)
|
||||
|
||||
if(NOT DEFINED CMAKE_C_COMPILER_ID)
|
||||
message(FATAL_ERROR "CMAKE_C_COMPILER_ID variable is not defined!")
|
||||
endif()
|
||||
|
@ -25,14 +25,12 @@
|
||||
# export: "'CXX={0}'.format(arguments['--cxx'])"
|
||||
# define: "'-DEXTRA_CXXFLAGS=\"{0}\"'.format(arguments['--extra-cxx-flags'])"
|
||||
|
||||
enable_language(CXX)
|
||||
|
||||
if(NOT DEFINED CMAKE_C_COMPILER_ID)
|
||||
message(FATAL_ERROR "CMAKE_C_COMPILER_ID variable is not defined!")
|
||||
if(NOT DEFINED CMAKE_CXX_COMPILER_ID)
|
||||
message(FATAL_ERROR "CMAKE_CXX_COMPILER_ID variable is not defined!")
|
||||
endif()
|
||||
|
||||
if(NOT CMAKE_C_COMPILER_WORKS)
|
||||
message(FATAL_ERROR "CMAKE_C_COMPILER_WORKS is false!")
|
||||
if(NOT CMAKE_CXX_COMPILER_WORKS)
|
||||
message(FATAL_ERROR "CMAKE_CXX_COMPILER_WORKS is false!")
|
||||
endif()
|
||||
|
||||
if(DEFINED EXTRA_CXXFLAGS)
|
||||
|
@ -29,8 +29,6 @@
|
||||
# export: "'FC={0}'.format(arguments['--fc'])"
|
||||
# define: "'-DEXTRA_FCFLAGS=\"{0}\"'.format(arguments['--extra-fc-flags'])"
|
||||
|
||||
enable_language(Fortran)
|
||||
|
||||
set(CMAKE_Fortran_MODULE_DIRECTORY ${PROJECT_BINARY_DIR}/modules)
|
||||
include_directories(${PROJECT_BINARY_DIR}/modules)
|
||||
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,8 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language:
|
||||
- CXX
|
||||
- C
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,8 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language:
|
||||
- C
|
||||
- CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: Fortran
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- fc:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: Fortran
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- fc:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: Fortran
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- fc:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: Fortran
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- fc:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: Fortran
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- fc:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: Fortran
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- fc:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,7 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language:
|
||||
- CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -1,5 +1,6 @@
|
||||
name: example
|
||||
min_cmake_version: 2.8
|
||||
language: CXX
|
||||
default_build_type: debug
|
||||
modules:
|
||||
- cxx:
|
||||
|
@ -141,6 +141,12 @@ def process_yaml(argv):
|
||||
sys.stderr.write("ERROR: project name contains a space\n")
|
||||
sys.exit(-1)
|
||||
|
||||
if 'language' in config:
|
||||
project_language = ' '.join(config['language']) if isinstance(config['language'], list) else config['language']
|
||||
else:
|
||||
sys.stderr.write("ERROR: you have to specify the project language(s) in autocmake.yml\n")
|
||||
sys.exit(-1)
|
||||
|
||||
if 'min_cmake_version' in config:
|
||||
min_cmake_version = config['min_cmake_version']
|
||||
else:
|
||||
@ -179,7 +185,7 @@ def process_yaml(argv):
|
||||
|
||||
# create CMakeLists.txt
|
||||
print('- generating CMakeLists.txt')
|
||||
s = gen_cmakelists(project_name, min_cmake_version, default_build_type, relative_path, modules)
|
||||
s = gen_cmakelists(project_name, project_language, min_cmake_version, default_build_type, relative_path, modules)
|
||||
with open(os.path.join(project_root, 'CMakeLists.txt'), 'w') as f:
|
||||
f.write('{0}\n'.format('\n'.join(s)))
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user