From 82466ca2e55884c1942e18ee4cd4f563a18fe232 Mon Sep 17 00:00:00 2001 From: Brecht Van Lommel Date: Thu, 1 Jul 2021 21:18:55 +0200 Subject: Fix T89581: Cycles crash rendering some OpenVDB files with inactive voxels Print an error message instead. --- intern/cycles/render/image_vdb.cpp | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) (limited to 'intern') diff --git a/intern/cycles/render/image_vdb.cpp b/intern/cycles/render/image_vdb.cpp index 13cdda552ba..6202035ba3b 100644 --- a/intern/cycles/render/image_vdb.cpp +++ b/intern/cycles/render/image_vdb.cpp @@ -16,6 +16,7 @@ #include "render/image_vdb.h" +#include "util/util_logging.h" #include "util/util_openvdb.h" #ifdef WITH_OPENVDB @@ -61,7 +62,13 @@ struct ToNanoOp { bool operator()(const openvdb::GridBase::ConstPtr &grid) { if constexpr (!std::is_same_v) { - nanogrid = nanovdb::openToNanoVDB(FloatGridType(*openvdb::gridConstPtrCast(grid))); + try { + nanogrid = nanovdb::openToNanoVDB( + FloatGridType(*openvdb::gridConstPtrCast(grid))); + } + catch (const std::exception &e) { + VLOG(1) << "Error converting OpenVDB to NanoVDB grid: " << e.what(); + } return true; } else { -- cgit v1.2.3