summaryrefslogtreecommitdiff
path: root/var/spack/repos/builtin/packages/visit/package.py
diff options
context:
space:
mode:
Diffstat (limited to 'var/spack/repos/builtin/packages/visit/package.py')
-rw-r--r--var/spack/repos/builtin/packages/visit/package.py63
1 files changed, 44 insertions, 19 deletions
diff --git a/var/spack/repos/builtin/packages/visit/package.py b/var/spack/repos/builtin/packages/visit/package.py
index 4ec7326f29..4c7e25e693 100644
--- a/var/spack/repos/builtin/packages/visit/package.py
+++ b/var/spack/repos/builtin/packages/visit/package.py
@@ -10,8 +10,10 @@ class Visit(CMakePackage):
"""VisIt is an Open Source, interactive, scalable, visualization,
animation and analysis tool."""
homepage = "https://wci.llnl.gov/simulation/computer-codes/visit/"
- url = "http://portal.nersc.gov/project/visit/releases/2.10.1/visit2.10.1.tar.gz"
+ url = "https://portal.nersc.gov/project/visit/releases/3.0.1/visit3.0.1.tar.gz"
+ version('3.0.1', 'a506d4d83b8973829e68787d8d721199523ce7ec73e7594e93333c214c2c12bd')
+ version('2.13.3', 'cf0b3d2e39e1cd102dd886d3ef6da892733445e362fc28f24d9682012cccf2e5')
version('2.13.0', '716644b8e78a00ff82691619d4d1e7a914965b6535884890b667b97ba08d6a0f')
version('2.12.3', '2dd351a291ee3e79926bc00391ca89b202cfa4751331b0fdee1b960c7922161f')
version('2.12.2', '355779b1dbf440cdd548526eecd77b60')
@@ -20,61 +22,84 @@ class Visit(CMakePackage):
version('2.10.1', '3cbca162fdb0249f17c4456605c4211e')
variant('gui', default=True, description='Enable VisIt\'s GUI')
+ variant('adios2', default=False, description='Enable ADIOS2 file format')
variant('hdf5', default=True, description='Enable HDF5 file format')
variant('silo', default=True, description='Enable Silo file format')
variant('python', default=True, description='Enable Python support')
variant('mpi', default=True, description='Enable parallel engine')
+ patch('spack-changes.patch')
+ patch('nonframework-qwt.patch', when='^qt~framework platform=darwin')
+
depends_on('cmake@3.0:', type='build')
- depends_on('vtk@6.1.0~opengl2~mpi')
- depends_on('qt@4.8.6', when='+gui')
+ depends_on('vtk@8.1.0:+opengl2', when='@3.0:3.0.1')
+ depends_on('vtk@6.1.0~opengl2', when='@:2.999')
+ depends_on('vtk+python', when='+python @3.0:')
+ depends_on('vtk~mpi')
+ depends_on('vtk+qt', when='+gui')
+ depends_on('qt@4.8.6:4.999', when='+gui @:2.999')
+ depends_on('qt@5.10:', when='+gui @3.0:')
depends_on('qwt', when='+gui')
- depends_on('python', when='+python')
+ depends_on('python@2.6:2.8', when='+python')
depends_on('silo+shared', when='+silo')
depends_on('hdf5', when='+hdf5')
depends_on('mpi', when='+mpi')
+ depends_on('adios2', when='+adios2')
- conflicts('+hdf5', when='~gui')
- conflicts('+silo', when='~gui')
+ conflicts('+adios2', when='@:2.999')
+ conflicts('+hdf5', when='~gui @:2.999')
+ conflicts('+silo', when='~gui @:2.999')
root_cmakelists_dir = 'src'
+ @when('@3.0.0:3.0.1')
+ def patch(self):
+ # Some of VTK's targets don't create explicit libraries, so there is no
+ # 'vtktiff'. Instead, replace with the library variable defined from
+ # VTK's module flies (e.g. lib/cmake/vtk-8.1/Modules/vtktiff.cmake)
+ for filename in find('src', 'CMakeLists.txt'):
+ filter_file(r'\bvtk(tiff|jpeg|png)', r'${vtk\1_LIBRARIES}',
+ filename)
+
def cmake_args(self):
spec = self.spec
args = [
- '-DVTK_MAJOR_VERSION={0}'.format(spec['vtk'].version[0]),
- '-DVTK_MINOR_VERSION={0}'.format(spec['vtk'].version[1]),
- '-DVISIT_VTK_DIR:PATH={0}'.format(spec['vtk'].prefix),
+ '-DVTK_MAJOR_VERSION=' + str(spec['vtk'].version[0]),
+ '-DVTK_MINOR_VERSION=' + str(spec['vtk'].version[1]),
+ '-DVISIT_VTK_DIR:PATH=' + spec['vtk'].prefix,
+ '-DVISIT_ZLIB_DIR:PATH=' + spec['zlib'].prefix,
'-DVISIT_USE_GLEW=OFF',
- '-DCMAKE_CXX_FLAGS=-fPIC',
- '-DCMAKE_C_FLAGS=-fPIC'
+ '-DCMAKE_CXX_FLAGS=' + self.compiler.pic_flag,
+ '-DCMAKE_C_FLAGS=' + self.compiler.pic_flag,
]
- if(spec.variants['python'].value):
+ if '+python' in spec:
args.append('-DPYTHON_DIR:PATH={0}'.format(spec['python'].home))
- if(spec.variants['gui'].value):
+ if '+gui' in spec:
qt_bin = spec['qt'].prefix.bin
- args.append(
- '-DVISIT_LOC_QMAKE_EXE:FILEPATH={0}/qmake-qt4'.format(qt_bin))
- args.append('-DVISIT_QWT_DIR:PATH={0}'.format(spec['qwt'].prefix))
+ args.extend([
+ '-DVISIT_LOC_QMAKE_EXE:FILEPATH={0}/qmake'.format(qt_bin),
+ '-DVISIT_QT_DIR:PATH=' + spec['qt'].prefix,
+ '-DVISIT_QWT_DIR:PATH=' + spec['qwt'].prefix
+ ])
else:
args.append('-DVISIT_SERVER_COMPONENTS_ONLY=ON')
args.append('-DVISIT_ENGINE_ONLY=ON')
- if(spec.variants['hdf5'].value):
+ if '+hdf5' in spec:
args.append(
'-DVISIT_HDF5_DIR:PATH={0}'.format(spec['hdf5'].prefix))
if spec.satisfies('^hdf5+mpi', strict=True):
args.append('-DVISIT_HDF5_MPI_DIR:PATH={0}'.format(
spec['hdf5'].prefix))
- if(spec.variants['silo'].value):
+ if '+silo' in spec:
args.append(
'-DVISIT_SILO_DIR:PATH={0}'.format(spec['silo'].prefix))
- if(spec.variants['mpi'].value):
+ if '+mpi' in spec:
args.append('-DVISIT_PARALLEL=ON')
args.append('-DVISIT_C_COMPILER={0}'.format(spec['mpi'].mpicc))
args.append('-DVISIT_CXX_COMPILER={0}'.format(spec['mpi'].mpicxx))