New Package: Process-in-Process (PiP) -- 2nd trial (#20925)
* Adding PiP recipe * pip@1 recipe (it seems working) * change install dir hierarchy * installing PiP man pages * add pip-glibc & pip-gdb * fix configure option designations, fix dependency types * fix dependency type of pip * use AutotoolsPackage in pip recipe * add patch for pip-glibc & pip-gdb to enable 'disable-werror' * change glibc install directory * add linux distro check to pip-gdb * create process-in-process package * use flag_handler and join_path * add gcc version constraint, change install-test to check-installed * fix gcc version designations on conflicts() * add constraint of target cpu, fix flake8 warnings * add version constraint to resource() * Some fixes to adapt the current version not to execute 'piplnlibs' change documentation install command * Update new branch name of PiP-gdb adapting PiP-Testsuite * update pip-gdb github urls * The very first commit of Process-in-Process (PiP) details can be found at https://github.com/RIKEN-SysSoft/PiP * Fix comment style issues * New Package: Process-in-Process (PiP) -- 2nd trial * fix style issue * change inline comments style (required to have two spaces) Co-authored-by: Daiki Matsunaga <daikim@axe.bz>
This commit is contained in:
parent
b7badf2447
commit
777901843f
1 changed files with 177 additions and 0 deletions
177
var/spack/repos/builtin/packages/process-in-process/package.py
Normal file
177
var/spack/repos/builtin/packages/process-in-process/package.py
Normal file
|
@ -0,0 +1,177 @@
|
|||
# Copyright 2013-2021 Lawrence Livermore National Security, LLC and other
|
||||
# Spack Project Developers. See the top-level COPYRIGHT file for details.
|
||||
#
|
||||
# SPDX-License-Identifier: (Apache-2.0 OR MIT)
|
||||
|
||||
from spack import *
|
||||
|
||||
|
||||
class ProcessInProcess(Package):
|
||||
"""Process-in-Process"""
|
||||
|
||||
homepage = "https://github.com/RIKEN-SysSoft/PiP"
|
||||
git = "https://github.com/RIKEN-SysSoft/PiP.git"
|
||||
|
||||
maintainers = ['ahori']
|
||||
|
||||
# PiP version 1 is obsolete
|
||||
version('2', branch='pip-2', preferred=True)
|
||||
version('3', branch='pip-3') # experimental
|
||||
|
||||
conflicts('%gcc@:3', when='os=centos7')
|
||||
conflicts('%gcc@5:', when='os=centos7')
|
||||
conflicts('%gcc@:3', when='os=rhel7')
|
||||
conflicts('%gcc@5:', when='os=rhel7')
|
||||
conflicts('%gcc@:7', when='os=centos8')
|
||||
conflicts('%gcc@9:', when='os=centos8')
|
||||
conflicts('%gcc@:7', when='os=rhel8')
|
||||
conflicts('%gcc@9:', when='os=rhel8')
|
||||
|
||||
# packages required for building PiP-gdb
|
||||
depends_on('texinfo', type='build')
|
||||
|
||||
# resources for PiP version 2
|
||||
# PiP-glibc resource
|
||||
# for rhel/centos 7
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.17-260.el7.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@2 os=centos7')
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.17-260.el7.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@2 os=rhel7')
|
||||
# for rhel/centos 8
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.28-72.el8_1.1.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@2 os=centos8')
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.28-72.el8_1.1.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@2 os=rhel8')
|
||||
|
||||
# PiP-gdb resource
|
||||
# for rhel/centos 7
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-7.6.1-94.el7.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@2 os=centos7')
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-7.6.1-94.el7.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@2 os=rhel7')
|
||||
# for rhel/centos 8
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-8.2-12.el8.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@2 os=centos8')
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-8.2-12.el8.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@2 os=rhel8')
|
||||
|
||||
# resources for PiP version 3
|
||||
# PiP-glibc resource
|
||||
# for rhel/centos 7
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.17-260.el7.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@3 os=centos7')
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.17-260.el7.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@3 os=rhel7')
|
||||
# for rhel/centos 8
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.28-72.el8_1.1.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@3 os=centos8')
|
||||
resource(name='PiP-glibc',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-glibc.git',
|
||||
branch='centos/glibc-2.28-72.el8_1.1.pip.branch',
|
||||
destination='PiP-glibc',
|
||||
when='@3 os=rhel8')
|
||||
|
||||
# PiP-gdb resource
|
||||
# for rhel/centos 7
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-7.6.1-94.el7.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@3 os=centos7')
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-7.6.1-94.el7.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@3 os=rhel7')
|
||||
# for rhel/centos 8
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-8.2-12.el8.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@3 os=centos8')
|
||||
resource(name='PiP-gdb',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-gdb.git',
|
||||
branch='centos/gdb-8.2-12.el8.pip.branch',
|
||||
destination='PiP-gdb',
|
||||
when='@3 os=rhel8')
|
||||
|
||||
# PiP testsuite (agnostic with PiP and OS versions)
|
||||
resource(name='PiP-Testsuite',
|
||||
git='https://github.com/RIKEN-SysSoft/PiP-Testsuite.git',
|
||||
destination='PiP-Testsuite')
|
||||
|
||||
def install(self, spec, prefix):
|
||||
"Install Process-in-Process including PiP-glibc, PiP-gdb"
|
||||
|
||||
# checking os and arch
|
||||
arch = self.spec.architecture
|
||||
target = self.spec.target
|
||||
if arch.os not in ['centos7', 'rhel7', 'centos8', 'rhel8']:
|
||||
raise InstallError('PIP only supports rhel/centos 7 and 8')
|
||||
if target.family not in ['x86_64', 'aarch64']:
|
||||
raise InstallError('PIP only supports x86_64 and aarch64')
|
||||
|
||||
bash = which('bash')
|
||||
|
||||
# installing PiP-glibc
|
||||
glibc_builddir = join_path('PiP-glibc', 'PiP-glibc.build')
|
||||
with working_dir(glibc_builddir, create=True):
|
||||
# build.sh does build and install
|
||||
bash(join_path('..', 'PiP-glibc', 'build.sh'), prefix.glibc)
|
||||
|
||||
# installing PiP lib
|
||||
configure('--prefix=%s' % prefix,
|
||||
'--with-glibc-libdir=%s' % prefix.glibc.lib)
|
||||
make()
|
||||
make('install')
|
||||
# installing already-doxygen-ed documents (man pages, html, ...)
|
||||
make('doc')
|
||||
|
||||
# testing PiP by using PiP-Testsuite (another repo), no need install
|
||||
with working_dir(join_path('PiP-Testsuite', 'PiP-Testsuite')):
|
||||
bash('configure', '--with-pip=%s' % prefix)
|
||||
# make test programs
|
||||
make()
|
||||
# and run the test programs
|
||||
make('test10', parallel=False)
|
||||
|
||||
# installing PiP-gdb
|
||||
with working_dir(join_path('PiP-gdb', 'PiP-gdb')):
|
||||
# build.sh does build and install
|
||||
bash('build.sh', '--prefix=%s' % prefix, '--with-pip=%s' % prefix)
|
||||
# testing PiP-gdb
|
||||
bash('test.sh', parallel=False)
|
||||
# all done !!
|
Loading…
Reference in a new issue