1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
# Copyright 2013-2019 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 Openglu(Package):
"""Placeholder for external OpenGL utility library (GLU) from hardware
vendors"""
homepage = "https://www.opengl.org/resources/libraries"
provides('glu@:1.3', when='@1.3:')
provides('glu@:1.2', when='@1.2:')
provides('glu@:1.1', when='@1.1:')
provides('glu@:1.0', when='@1.0:')
# Override the fetcher method to throw a useful error message;
# fixes an issue similar to Github issue (#7061), in which the
# opengl package threw a generic, uninformative error message
# during the `fetch` step
@property
def fetcher(self):
msg = """This package is intended to be a placeholder for
system-provided OpenGL utility (GLU) libraries from hardware vendors.
Please download and install the GLU drivers/libraries for your
graphics hardware separately, and then set that up as an external
package. An example of a working packages.yaml:
packages:
openglu:
paths:
openglu@1.3: /opt/opengl
buildable: False
In that case, /opt/opengl/ should contain these two folders:
include/GL/ (opengl headers, including "glu.h")
lib (opengl libraries, including "libGLU.so")
On Apple Darwin (OS X, macOS) systems, this package is
normally installed as part of the XCode Command Line Tools in
/usr/X11R6, so a working packages.yaml would be
packages:
openglu:
paths:
openglu@1.3: /usr/X11R6
buildable: False
In that case, /usr/X11R6 should contain
include/GL (GLU headers, including "glu.h")
lib (GLU libraries, including "libGLU.dylib")"""
raise InstallError(msg)
@property
def libs(self):
for dir in ['lib64', 'lib']:
libs = find_libraries('libGLU', join_path(self.prefix, dir),
shared=True, recursive=False)
if libs:
return libs
|