diff --git a/.circleci/config.yml b/.circleci/config.yml index 9e825b38a..1af870812 100644 --- a/.circleci/config.yml +++ b/.circleci/config.yml @@ -5,7 +5,7 @@ executors: docker: - image: ghcr.io/ecell/image environment: - ECELLVER: "2.1.0b2" + ECELLVER: "2.1.0" BOOSTVER: "1.73.0" BOOSTFILE: "boost_1_73_0" jobs: diff --git a/setup.py b/setup.py index 1d379fc04..fb70e6173 100644 --- a/setup.py +++ b/setup.py @@ -1,121 +1,121 @@ -import os -import re -import sys -import glob -import platform -import sysconfig -import subprocess - -from setuptools import setup, Extension -from setuptools.command.build_ext import build_ext -from setuptools.command.test import test -from distutils.version import LooseVersion - - -class CMakeExtension(Extension): - def __init__(self, name, sourcedir=''): - super(CMakeExtension, self).__init__(name, sources=[]) - self.sourcedir = os.path.abspath(sourcedir) - - -class CMakeBuild(build_ext): - user_options = [ - ('jobs=', 'j', 'Specify the number of build jobs at once'), - ] - - def initialize_options(self): - super().initialize_options() - self.jobs = None - - def finalize_options(self): - super().finalize_options() - assert self.jobs is None or self.jobs.isdecimal(), 'Invalid argument for --jobs or -j' - - def run(self): - try: - out = subprocess.check_output(['cmake', '--version']) - except OSError: - raise RuntimeError("CMake must be installed to build the following extensions: " + - ", ".join(e.name for e in self.extensions)) - - cmake_minimum_version_for_windows = '3.1.0' - if platform.system() == "Windows": - cmake_version = LooseVersion(re.search(r'version\s*([\d.]+)', out.decode()).group(1)) - if cmake_version < cmake_minimum_version_for_windows: - raise RuntimeError("CMake >= {} is required on Windows".format( - cmake_minimum_version_for_windows)) - - for ext in self.extensions: - self.build_extension(ext) - - def build_extension(self, ext): - extdir = os.path.abspath(os.path.dirname(self.get_ext_fullpath(ext.name))) - cmake_args = ['-DCMAKE_LIBRARY_OUTPUT_DIRECTORY=' + extdir, - '-DPYTHON_EXECUTABLE=' + sys.executable] - - cfg = 'Debug' if self.debug else 'Release' - build_args = ['--config', cfg] - if self.jobs: - build_args += ['-j', self.jobs] - - if platform.system() == "Windows": - cmake_args += ['-DCMAKE_LIBRARY_OUTPUT_DIRECTORY_{}={}'.format(cfg.upper(), extdir)] - if sys.maxsize > 2**32: - cmake_args += ['-A', 'x64'] - build_args += ['--', '/m'] - cmake_args += ['-DCMAKE_BUILD_TYPE=' + cfg] - - if platform.system() == "Windows": - env = os.environ.copy() - env['CXXFLAGS'] = '{} -DVERSION_INFO=\\"{}\\" -I {}'.format( - env.get('CXXFLAGS', ''), - self.distribution.get_version(), - sysconfig.get_path('include')) - else: - env = os.environ.copy() - env['CXXFLAGS'] = '{} -DVERSION_INFO=\\"{}\\" -isystem {}'.format( - env.get('CXXFLAGS', ''), - self.distribution.get_version(), - sysconfig.get_path('include')) - - if not os.path.exists(self.build_temp): - os.makedirs(self.build_temp) - subprocess.check_call(['cmake', ext.sourcedir] + cmake_args, cwd=self.build_temp, env=env) - subprocess.check_call(['cmake', '--build', '.'] + build_args, cwd=self.build_temp) - - -class CustomTestCommand(test): - def run(self): - super().run() - build_py = self.get_finalized_command('build_ext') - if platform.system() == "Windows": - subprocess.check_call(['ctest', '--output-on-failure', '--build-config', 'Release'], cwd=build_py.build_temp) - else: - subprocess.check_call(['ctest', '--output-on-failure'], cwd=build_py.build_temp) - - -DESCRIPTION = ( - "A software platform for modeling, simulation and analysis of complex, " - "heterogeneous and multi-scale systems like the cell. E-Cell has " - "multi-algorithm, multi-timescale and multi-spatial-representation as " - "its central feature." -) - -LONG_DESCRIPTION = open("README.md").read() - - -setup( - name='ecell4_base', - version = '2.1.0b2', - license = "the GNU General Public License v2", - author = "Kazunari Kaizu", - author_email = "kaizu@riken.jp", - url = "https://github.com/ecell/ecell4_base", - description = DESCRIPTION, - long_description = LONG_DESCRIPTION, - long_description_content_type='text/markdown', - data_files = [('ecell4-licenses', glob.glob('licenses/*'))], - ext_modules=[CMakeExtension('ecell4_base')], - cmdclass=dict(build_ext=CMakeBuild, test=CustomTestCommand), - zip_safe=False, -) +import os +import re +import sys +import glob +import platform +import sysconfig +import subprocess + +from setuptools import setup, Extension +from setuptools.command.build_ext import build_ext +from setuptools.command.test import test +from distutils.version import LooseVersion + + +class CMakeExtension(Extension): + def __init__(self, name, sourcedir=''): + super(CMakeExtension, self).__init__(name, sources=[]) + self.sourcedir = os.path.abspath(sourcedir) + + +class CMakeBuild(build_ext): + user_options = [ + ('jobs=', 'j', 'Specify the number of build jobs at once'), + ] + + def initialize_options(self): + super().initialize_options() + self.jobs = None + + def finalize_options(self): + super().finalize_options() + assert self.jobs is None or self.jobs.isdecimal(), 'Invalid argument for --jobs or -j' + + def run(self): + try: + out = subprocess.check_output(['cmake', '--version']) + except OSError: + raise RuntimeError("CMake must be installed to build the following extensions: " + + ", ".join(e.name for e in self.extensions)) + + cmake_minimum_version_for_windows = '3.1.0' + if platform.system() == "Windows": + cmake_version = LooseVersion(re.search(r'version\s*([\d.]+)', out.decode()).group(1)) + if cmake_version < cmake_minimum_version_for_windows: + raise RuntimeError("CMake >= {} is required on Windows".format( + cmake_minimum_version_for_windows)) + + for ext in self.extensions: + self.build_extension(ext) + + def build_extension(self, ext): + extdir = os.path.abspath(os.path.dirname(self.get_ext_fullpath(ext.name))) + cmake_args = ['-DCMAKE_LIBRARY_OUTPUT_DIRECTORY=' + extdir, + '-DPYTHON_EXECUTABLE=' + sys.executable] + + cfg = 'Debug' if self.debug else 'Release' + build_args = ['--config', cfg] + if self.jobs: + build_args += ['-j', self.jobs] + + if platform.system() == "Windows": + cmake_args += ['-DCMAKE_LIBRARY_OUTPUT_DIRECTORY_{}={}'.format(cfg.upper(), extdir)] + if sys.maxsize > 2**32: + cmake_args += ['-A', 'x64'] + build_args += ['--', '/m'] + cmake_args += ['-DCMAKE_BUILD_TYPE=' + cfg] + + if platform.system() == "Windows": + env = os.environ.copy() + env['CXXFLAGS'] = '{} -DVERSION_INFO=\\"{}\\" -I {}'.format( + env.get('CXXFLAGS', ''), + self.distribution.get_version(), + sysconfig.get_path('include')) + else: + env = os.environ.copy() + env['CXXFLAGS'] = '{} -DVERSION_INFO=\\"{}\\" -isystem {}'.format( + env.get('CXXFLAGS', ''), + self.distribution.get_version(), + sysconfig.get_path('include')) + + if not os.path.exists(self.build_temp): + os.makedirs(self.build_temp) + subprocess.check_call(['cmake', ext.sourcedir] + cmake_args, cwd=self.build_temp, env=env) + subprocess.check_call(['cmake', '--build', '.'] + build_args, cwd=self.build_temp) + + +class CustomTestCommand(test): + def run(self): + super().run() + build_py = self.get_finalized_command('build_ext') + if platform.system() == "Windows": + subprocess.check_call(['ctest', '--output-on-failure', '--build-config', 'Release'], cwd=build_py.build_temp) + else: + subprocess.check_call(['ctest', '--output-on-failure'], cwd=build_py.build_temp) + + +DESCRIPTION = ( + "A software platform for modeling, simulation and analysis of complex, " + "heterogeneous and multi-scale systems like the cell. E-Cell has " + "multi-algorithm, multi-timescale and multi-spatial-representation as " + "its central feature." +) + +LONG_DESCRIPTION = open("README.md").read() + + +setup( + name='ecell4_base', + version = '2.1.0', + license = "the GNU General Public License v2", + author = "Kazunari Kaizu", + author_email = "kaizu@riken.jp", + url = "https://github.com/ecell/ecell4_base", + description = DESCRIPTION, + long_description = LONG_DESCRIPTION, + long_description_content_type='text/markdown', + data_files = [('ecell4-licenses', glob.glob('licenses/*'))], + ext_modules=[CMakeExtension('ecell4_base')], + cmdclass=dict(build_ext=CMakeBuild, test=CustomTestCommand), + zip_safe=False, +)