Accepting request 915019 from science
- Add PrusaSlicer-issue6681-openvdb.patch * gh#prusa3d/PrusaSlicer#6681 * ilmbase-devel is now provided by openexr-devel * OpenVDB's FindOpenVDB.cmake requires blosc-devel OBS-URL: https://build.opensuse.org/request/show/915019 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/PrusaSlicer?expand=0&rev=12
This commit is contained in:
77
PrusaSlicer-issue6681-openvdb.patch
Normal file
77
PrusaSlicer-issue6681-openvdb.patch
Normal file
@@ -0,0 +1,77 @@
|
||||
From e6507594fb6893156056c2123822a2b37f7f179d Mon Sep 17 00:00:00 2001
|
||||
From: tamasmeszaros <meszaros.q@gmail.com>
|
||||
Date: Wed, 14 Jul 2021 16:26:44 +0200
|
||||
Subject: [PATCH] Search for a better openvdb find module if available
|
||||
|
||||
Solves #6681, alternative path for openvdb installation can be specified via cache variable
|
||||
---
|
||||
CMakeLists.txt | 12 +++++++++---
|
||||
cmake/modules/FindOpenVDB.cmake | 21 +++++++++++++++++++++
|
||||
2 files changed, 30 insertions(+), 3 deletions(-)
|
||||
|
||||
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||
index b6fe88e48f..b8b9add60f 100644
|
||||
--- a/CMakeLists.txt
|
||||
+++ b/CMakeLists.txt
|
||||
@@ -33,6 +33,8 @@ option(SLIC3R_MSVC_PDB "Generate PDB files on MSVC in Release mode" 1)
|
||||
option(SLIC3R_PERL_XS "Compile XS Perl module and enable Perl unit and integration tests" 0)
|
||||
option(SLIC3R_ASAN "Enable ASan on Clang and GCC" 0)
|
||||
|
||||
+set(OPENVDB_FIND_MODULE_PATH "" CACHE PATH "Path to OpenVDB installation's find modules.")
|
||||
+
|
||||
set(SLIC3R_GTK "2" CACHE STRING "GTK version to use with wxWidgets on Linux")
|
||||
|
||||
set(IS_CROSS_COMPILE FALSE)
|
||||
@@ -492,13 +494,17 @@ find_package(NLopt 1.4 REQUIRED)
|
||||
if(SLIC3R_STATIC)
|
||||
set(OPENVDB_USE_STATIC_LIBS ON)
|
||||
set(USE_BLOSC TRUE)
|
||||
-endif()
|
||||
+endif ()
|
||||
|
||||
-find_package(OpenVDB 5.0 REQUIRED COMPONENTS openvdb)
|
||||
+find_package(OpenVDB 5.0 COMPONENTS openvdb)
|
||||
if(OpenVDB_FOUND)
|
||||
slic3r_remap_configs(IlmBase::Half RelWithDebInfo Release)
|
||||
slic3r_remap_configs(Blosc::blosc RelWithDebInfo Release)
|
||||
-endif()
|
||||
+else ()
|
||||
+ message(FATAL_ERROR "OpenVDB could not be found with the bundled find module. "
|
||||
+ "You can try to specify the find module location of your "
|
||||
+ "OpenVDB installation with the OPENVDB_FIND_MODULE_PATH cache variable.")
|
||||
+endif ()
|
||||
|
||||
set(TOP_LEVEL_PROJECT_DIR ${PROJECT_SOURCE_DIR})
|
||||
function(prusaslicer_copy_dlls target)
|
||||
diff --git a/cmake/modules/FindOpenVDB.cmake b/cmake/modules/FindOpenVDB.cmake
|
||||
index 02420fed8e..3b60ac9d36 100644
|
||||
--- a/cmake/modules/FindOpenVDB.cmake
|
||||
+++ b/cmake/modules/FindOpenVDB.cmake
|
||||
@@ -102,6 +102,27 @@ may be provided to tell this module where to look.
|
||||
|
||||
#]=======================================================================]
|
||||
|
||||
+# If an explicit openvdb module path was specified, that will be used
|
||||
+if (OPENVDB_FIND_MODULE_PATH)
|
||||
+ set(_module_path_bak ${CMAKE_MODULE_PATH})
|
||||
+ set(CMAKE_MODULE_PATH ${OPENVDB_FIND_MODULE_PATH})
|
||||
+ find_package(
|
||||
+ OpenVDB ${OpenVDB_FIND_VERSION} QUIET
|
||||
+ COMPONENTS
|
||||
+ ${OpenVDB_FIND_COMPONENTS}
|
||||
+ )
|
||||
+
|
||||
+ set(CMAKE_MODULE_PATH ${_module_path_bak})
|
||||
+ if (OpenVDB_FOUND)
|
||||
+ return()
|
||||
+ endif ()
|
||||
+
|
||||
+ if (NOT OpenVDB_FIND_QUIETLY)
|
||||
+ message(STATUS "Using bundled find module for OpenVDB")
|
||||
+ endif ()
|
||||
+endif ()
|
||||
+# ###########################################################################
|
||||
+
|
||||
cmake_minimum_required(VERSION 3.3)
|
||||
# Monitoring <PackageName>_ROOT variables
|
||||
if(POLICY CMP0074)
|
@@ -1,3 +1,11 @@
|
||||
-------------------------------------------------------------------
|
||||
Mon Aug 30 11:37:03 UTC 2021 - Ben Greiner <code@bnavigator.de>
|
||||
|
||||
- Add PrusaSlicer-issue6681-openvdb.patch
|
||||
* gh#prusa3d/PrusaSlicer#6681
|
||||
* ilmbase-devel is now provided by openexr-devel
|
||||
* OpenVDB's FindOpenVDB.cmake requires blosc-devel
|
||||
|
||||
-------------------------------------------------------------------
|
||||
Fri Jul 16 15:22:48 UTC 2021 - Ben Greiner <code@bnavigator.de>
|
||||
|
||||
|
@@ -24,6 +24,9 @@ License: AGPL-3.0-only
|
||||
Group: Hardware/Printing
|
||||
URL: https://www.prusa3d.com/prusaslicer/
|
||||
Source0: https://github.com/prusa3d/PrusaSlicer/archive/version_%{version}.tar.gz#/%{name}-%{version}.tar.gz
|
||||
# PATCH-FIX-UPSTREAM PrusaSlicer-issue6681-openvdb.patch -- gh#prusa3d/PrusaSlicer#6681
|
||||
Patch0: https://github.com/prusa3d/PrusaSlicer/commit/e6507594fb6893156056c2123822a2b37f7f179d.patch#/PrusaSlicer-issue6681-openvdb.patch
|
||||
BuildRequires: blosc-devel
|
||||
BuildRequires: cereal-devel
|
||||
BuildRequires: cgal-devel >= 4.13.2
|
||||
BuildRequires: cmake
|
||||
@@ -34,7 +37,6 @@ BuildRequires: gcc-c++
|
||||
# For now, use bundled GLEW because of gh#prusa3d/PrusaSlicer#6396
|
||||
#!BuildIgnore: glew-devel
|
||||
BuildRequires: gtest >= 1.7
|
||||
BuildRequires: ilmbase-devel
|
||||
BuildRequires: libboost_atomic-devel
|
||||
BuildRequires: libboost_filesystem-devel
|
||||
BuildRequires: libboost_iostreams-devel
|
||||
@@ -47,6 +49,7 @@ BuildRequires: libcurl-devel
|
||||
BuildRequires: libexpat-devel
|
||||
BuildRequires: memory-constraints
|
||||
BuildRequires: nlopt-devel
|
||||
BuildRequires: openexr-devel
|
||||
BuildRequires: openvdb-devel >= 5
|
||||
BuildRequires: openvdb-tools
|
||||
BuildRequires: tbb-devel
|
||||
@@ -82,8 +85,10 @@ rm -r resources/data/flatpak
|
||||
export CFLAGS="%optflags -mfpmath=sse -msse2"
|
||||
export CXXFLAGS="$CFLAGS"
|
||||
%endif
|
||||
%cmake -DSLIC3R_FHS=1 \
|
||||
-DSLIC3R_GTK=3
|
||||
%cmake \
|
||||
-DSLIC3R_FHS=1 \
|
||||
-DSLIC3R_GTK=3 \
|
||||
-DOPENVDB_FIND_MODULE_PATH=%{_libdir}/cmake/OpenVDB
|
||||
%cmake_build
|
||||
|
||||
%install
|
||||
|
Reference in New Issue
Block a user