Merge pull request #194 from robertodr/yaml-project-language

Parse language field in YAML
This commit is contained in:
Radovan Bast 2017-05-18 20:32:02 +02:00 committed by GitHub
commit 5c4a515a31
22 changed files with 39 additions and 16 deletions

View File

@ -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

View File

@ -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)')

View File

@ -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()

View File

@ -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)

View File

@ -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)

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,8 @@
name: example
min_cmake_version: 2.8
language:
- CXX
- C
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,8 @@
name: example
min_cmake_version: 2.8
language:
- C
- CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: Fortran
default_build_type: debug
modules:
- fc:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: Fortran
default_build_type: debug
modules:
- fc:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: Fortran
default_build_type: debug
modules:
- fc:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: Fortran
default_build_type: debug
modules:
- fc:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: Fortran
default_build_type: debug
modules:
- fc:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: Fortran
default_build_type: debug
modules:
- fc:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,7 @@
name: example
min_cmake_version: 2.8
language:
- CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -1,5 +1,6 @@
name: example
min_cmake_version: 2.8
language: CXX
default_build_type: debug
modules:
- cxx:

View File

@ -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)))