Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

add custom easyblock for STAR-CCM+ #1613

Merged
merged 5 commits into from
Jun 10, 2022
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
129 changes: 129 additions & 0 deletions easybuild/easyblocks/s/star_ccm.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,129 @@
##
# Copyright 2018-2019 Ghent University
#
# This file is part of EasyBuild,
# originally created by the HPC team of Ghent University (http://ugent.be/hpc/en),
# with support of Ghent University (http://ugent.be/hpc),
# the Flemish Supercomputer Centre (VSC) (https://www.vscentrum.be),
# Flemish Research Foundation (FWO) (http://www.fwo.be/en)
# and the Department of Economy, Science and Innovation (EWI) (http://www.ewi-vlaanderen.be/en).
#
# https://github.com/easybuilders/easybuild
#
# EasyBuild is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation v2.
#
# EasyBuild is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with EasyBuild. If not, see <http://www.gnu.org/licenses/>.
##
"""
EasyBuild support for building and installing STAR-CCM+, implemented as an easyblock
boegel marked this conversation as resolved.
Show resolved Hide resolved

@author: Kenneth Hoste (Ghent University)
"""
import os
import tempfile

import easybuild.tools.environment as env
from easybuild.framework.easyblock import EasyBlock
from easybuild.tools.config import build_option
from easybuild.tools.filetools import change_dir, find_glob_pattern
from easybuild.tools.run import run_cmd


class EB_STAR_minus_CCM_plus_(EasyBlock):
"""Support for building/installing STAR-CCM+."""

def __init__(self, *args, **kwargs):
"""Initialise STAR-CCM+ easyblock."""
super(EB_STAR_minus_CCM_plus_, self).__init__(*args, **kwargs)
self.starccm_subdir = None
self.starview_subdir = None

def configure_step(self):
"""No configuration procedure for STAR-CCM+."""
pass

def build_step(self):
"""No build procedure for STAR-CCM+."""
pass

def install_step(self):
"""Custom install procedure for STAR-CCM+."""

install_script_pattern = "./STAR-CCM+%s_*.sh" % self.version
if self.dry_run:
install_script = install_script_pattern
else:
install_script = find_glob_pattern(install_script_pattern)

# depending of the target filesystem the check for available disk space may fail, so disable it;
# note that this makes the installer exit with non-zero exit code...
# env.setvar('CHECK_DISK_SPACE', 'OFF')
env.setvar('IATEMPDIR', tempfile.mkdtemp())

cmd = ' '.join([
self.cfg['preinstallopts'],
install_script,
"-i silent",
"-DINSTALLDIR=%s" % self.installdir,
"-DINSTALLFLEX=false",
"-DADDSYSTEMPATH=false",
self.cfg['installopts'],
])
run_cmd(cmd, log_all=True, simple=True)

def find_starccm_subdirs(self):
"""Determine subdirectory of install directory in which STAR-CCM+ was installed."""
starccm_subdir_pattern = os.path.join(self.version + '*', 'STAR-CCM+%s*' % self.version)

if self.dry_run:
self.starccm_subdir = starccm_subdir_pattern
else:
# take into account that install directory may not exist or be totally empty,
# for example when --module-only --force is used
try:
cwd = change_dir(self.installdir)
self.starccm_subdir = find_glob_pattern(starccm_subdir_pattern)
self.log.info("Found STAR-CCM+ subdirectory: %s", self.starccm_subdir)
change_dir(cwd)
except Exception:
if build_option('module_only') and build_option('force'):
self.starccm_subdir = starccm_subdir_pattern
else:
raise

self.starview_subdir = os.path.join(os.path.dirname(self.starccm_subdir), 'STAR-View+%s' % self.version)

def sanity_check_step(self):
"""Custom sanity check for STAR-CCM+."""
if self.starccm_subdir is None or self.starview_subdir is None:
self.find_starccm_subdirs()

custom_paths = {
'files': [os.path.join(self.installdir, self.starccm_subdir, 'star', 'bin', 'starccm+'),
os.path.join(self.installdir, self.starview_subdir, 'bin', 'starview+')],
'dirs': [],
}
super(EB_STAR_minus_CCM_plus_, self).sanity_check_step(custom_paths=custom_paths)

def make_module_extra(self):
"""Extra statements specific to STAR-CCM+ to include in generated module file."""
if self.starccm_subdir is None or self.starview_subdir is None:
self.find_starccm_subdirs()
boegel marked this conversation as resolved.
Show resolved Hide resolved

txt = super(EB_STAR_minus_CCM_plus_, self).make_module_extra()

bin_dirs = [
os.path.join(self.starccm_subdir, 'star', 'bin'),
os.path.join(self.starview_subdir, 'bin'),
]
txt += self.module_generator.prepend_paths('PATH', bin_dirs)

return txt