blob: 9eaf58f5eead5f7706b1e4c9c3576b1c599cd741 (
plain)
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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
|
# Copyright 1999-2024 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=8
inherit cmake cuda toolchain-funcs
MY_PV="$(ver_rs "1-3" '_')"
DESCRIPTION="An Open-Source subdivision surface library"
HOMEPAGE="https://graphics.pixar.com/opensubdiv/docs/intro.html"
SRC_URI="https://github.com/PixarAnimationStudios/OpenSubdiv/archive/v${MY_PV}.tar.gz -> ${P}.tar.gz"
S="${WORKDIR}/OpenSubdiv-${MY_PV}"
# Modfied Apache-2.0 license, where section 6 has been replaced.
# See for example CMakeLists.txt for details.
LICENSE="Apache-2.0"
SLOT="0"
KEYWORDS="~amd64 ~arm ~arm64 ~x86"
IUSE="cuda examples opencl openmp ptex tbb test tutorials"
RESTRICT="!test? ( test )"
RDEPEND="
examples? (
media-libs/glew:=
media-libs/glfw:=
x11-libs/libXinerama
)
cuda? ( dev-util/nvidia-cuda-toolkit:* )
opencl? ( virtual/opencl )
ptex? ( media-libs/ptex )
"
DEPEND="
${RDEPEND}
tbb? ( dev-cpp/tbb:= )
"
PATCHES=(
"${FILESDIR}/${PN}-3.3.0-use-gnuinstalldirs.patch"
"${FILESDIR}/${PN}-3.4.3-install-tutorials-into-bin.patch"
"${FILESDIR}/${PN}-3.4.4-tbb-2021.patch"
)
pkg_pretend() {
[[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
}
pkg_setup() {
[[ ${MERGE_TYPE} != binary ]] && use openmp && tc-check-openmp
}
src_prepare() {
cmake_src_prepare
use cuda && cuda_src_prepare
}
src_configure() {
# GLTESTS are disabled as portage is unable to open a display during test phase
# TODO: virtx work?
local mycmakeargs=(
-DGLEW_LOCATION="${ESYSROOT}/usr/$(get_libdir)"
-DGLFW_LOCATION="${ESYSROOT}/usr/$(get_libdir)"
-DNO_CLEW=ON
-DNO_CUDA=$(usex !cuda)
# Docs needed Python 2 so disabled
# bug #815172
-DNO_DOC=ON
-DNO_EXAMPLES=$(usex !examples)
-DNO_GLTESTS=ON
-DNO_OMP=$(usex !openmp)
-DNO_OPENCL=$(usex !opencl)
-DNO_PTEX=$(usex !ptex)
-DNO_REGRESSION=$(usex !test)
-DNO_TBB=$(usex !tbb)
-DNO_TESTS=$(usex !test)
-DNO_TUTORIALS=$(usex !tutorials)
)
if use cuda; then
# old cmake CUDA module doesn't use environment variable to initialize flags
mycmakeargs+=( -DCUDA_NVCC_FLAGS="${NVCCFLAGS}" )
# check if user provided --gpu-architecture/-arch flag and prevent cmake from overriding it if so
for f in ${NVCCFLAGS}; do
if [[ ${f} == -arch* || ${f} == --gpu-architecture* ]]; then
mycmakeargs+=( -DOSD_CUDA_NVCC_FLAGS="" )
break
fi
done
fi
cmake_src_configure
}
src_test() {
CMAKE_SKIP_TESTS=(
"far_tutorial_1_2"
)
cmake_src_test
}
src_install() {
cmake_src_install
rm -f "${ED}/usr/$(get_libdir)/libosdCPU.a" || die
if use cuda || use opencl ; then
rm -f "${ED}/usr/$(get_libdir)/libosdGPU.a" || die
fi
if use test; then
rm -f \
"${ED}/usr/bin/bfr_evaluate" \
"${ED}/usr/bin/far_perf" \
"${ED}/usr/bin/far_regression" \
"${ED}/usr/bin/hbr_baseline" \
"${ED}/usr/bin/hbr_regression" \
"${ED}/usr/bin/osd_regression" \
|| die
fi
}
|