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
|
- libboost-all-dev
|
||||||
|
|
||||||
- os: osx
|
- os: osx
|
||||||
osx_image: xcode6.4
|
osx_image: xcode7.3
|
||||||
compiler: gcc
|
compiler: gcc
|
||||||
env: SOURCES=homebrew
|
env:
|
||||||
|
- SOURCES=homebrew
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- |
|
- |
|
||||||
if [[ "${TRAVIS_OS_NAME}" == "osx" ]]; then
|
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
|
pip install virtualenv
|
||||||
elif [[ "${TRAVIS_OS_NAME}" == "linux" ]]; then
|
elif [[ "${TRAVIS_OS_NAME}" == "linux" ]]; then
|
||||||
pip install --user virtualenv
|
pip install --user virtualenv
|
||||||
|
@ -118,7 +118,7 @@ def gen_setup(config, default_build_type, relative_path, setup_script_name):
|
|||||||
return s
|
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.
|
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('cmake_minimum_required(VERSION {0} FATAL_ERROR)'.format(min_cmake_version))
|
||||||
|
|
||||||
s.append('\n# project name')
|
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('\n# do not rebuild if rules (compiler flags) change')
|
||||||
s.append('set(CMAKE_SKIP_RULE_DEPENDENCY TRUE)')
|
s.append('set(CMAKE_SKIP_RULE_DEPENDENCY TRUE)')
|
||||||
|
@ -25,8 +25,6 @@
|
|||||||
# export: "'CC={0}'.format(arguments['--cc'])"
|
# export: "'CC={0}'.format(arguments['--cc'])"
|
||||||
# define: "'-DEXTRA_CFLAGS=\"{0}\"'.format(arguments['--extra-cc-flags'])"
|
# define: "'-DEXTRA_CFLAGS=\"{0}\"'.format(arguments['--extra-cc-flags'])"
|
||||||
|
|
||||||
enable_language(C)
|
|
||||||
|
|
||||||
if(NOT DEFINED CMAKE_C_COMPILER_ID)
|
if(NOT DEFINED CMAKE_C_COMPILER_ID)
|
||||||
message(FATAL_ERROR "CMAKE_C_COMPILER_ID variable is not defined!")
|
message(FATAL_ERROR "CMAKE_C_COMPILER_ID variable is not defined!")
|
||||||
endif()
|
endif()
|
||||||
|
@ -25,14 +25,12 @@
|
|||||||
# export: "'CXX={0}'.format(arguments['--cxx'])"
|
# export: "'CXX={0}'.format(arguments['--cxx'])"
|
||||||
# define: "'-DEXTRA_CXXFLAGS=\"{0}\"'.format(arguments['--extra-cxx-flags'])"
|
# define: "'-DEXTRA_CXXFLAGS=\"{0}\"'.format(arguments['--extra-cxx-flags'])"
|
||||||
|
|
||||||
enable_language(CXX)
|
if(NOT DEFINED CMAKE_CXX_COMPILER_ID)
|
||||||
|
message(FATAL_ERROR "CMAKE_CXX_COMPILER_ID variable is not defined!")
|
||||||
if(NOT DEFINED CMAKE_C_COMPILER_ID)
|
|
||||||
message(FATAL_ERROR "CMAKE_C_COMPILER_ID variable is not defined!")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(NOT CMAKE_C_COMPILER_WORKS)
|
if(NOT CMAKE_CXX_COMPILER_WORKS)
|
||||||
message(FATAL_ERROR "CMAKE_C_COMPILER_WORKS is false!")
|
message(FATAL_ERROR "CMAKE_CXX_COMPILER_WORKS is false!")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(DEFINED EXTRA_CXXFLAGS)
|
if(DEFINED EXTRA_CXXFLAGS)
|
||||||
|
@ -29,8 +29,6 @@
|
|||||||
# export: "'FC={0}'.format(arguments['--fc'])"
|
# export: "'FC={0}'.format(arguments['--fc'])"
|
||||||
# define: "'-DEXTRA_FCFLAGS=\"{0}\"'.format(arguments['--extra-fc-flags'])"
|
# define: "'-DEXTRA_FCFLAGS=\"{0}\"'.format(arguments['--extra-fc-flags'])"
|
||||||
|
|
||||||
enable_language(Fortran)
|
|
||||||
|
|
||||||
set(CMAKE_Fortran_MODULE_DIRECTORY ${PROJECT_BINARY_DIR}/modules)
|
set(CMAKE_Fortran_MODULE_DIRECTORY ${PROJECT_BINARY_DIR}/modules)
|
||||||
include_directories(${PROJECT_BINARY_DIR}/modules)
|
include_directories(${PROJECT_BINARY_DIR}/modules)
|
||||||
|
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language:
|
||||||
|
- CXX
|
||||||
|
- C
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language:
|
||||||
|
- C
|
||||||
|
- CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: Fortran
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- fc:
|
- fc:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: Fortran
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- fc:
|
- fc:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: Fortran
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- fc:
|
- fc:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: Fortran
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- fc:
|
- fc:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: Fortran
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- fc:
|
- fc:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: Fortran
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- fc:
|
- fc:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,7 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language:
|
||||||
|
- CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
name: example
|
name: example
|
||||||
min_cmake_version: 2.8
|
min_cmake_version: 2.8
|
||||||
|
language: CXX
|
||||||
default_build_type: debug
|
default_build_type: debug
|
||||||
modules:
|
modules:
|
||||||
- cxx:
|
- cxx:
|
||||||
|
@ -141,6 +141,12 @@ def process_yaml(argv):
|
|||||||
sys.stderr.write("ERROR: project name contains a space\n")
|
sys.stderr.write("ERROR: project name contains a space\n")
|
||||||
sys.exit(-1)
|
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:
|
if 'min_cmake_version' in config:
|
||||||
min_cmake_version = config['min_cmake_version']
|
min_cmake_version = config['min_cmake_version']
|
||||||
else:
|
else:
|
||||||
@ -179,7 +185,7 @@ def process_yaml(argv):
|
|||||||
|
|
||||||
# create CMakeLists.txt
|
# create CMakeLists.txt
|
||||||
print('- generating 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:
|
with open(os.path.join(project_root, 'CMakeLists.txt'), 'w') as f:
|
||||||
f.write('{0}\n'.format('\n'.join(s)))
|
f.write('{0}\n'.format('\n'.join(s)))
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user