From 5d6055d0fc712929357b34cef657156ac837b736 Mon Sep 17 00:00:00 2001 From: Jeremy Lorelli Date: Sat, 31 Aug 2024 16:33:38 -0700 Subject: [PATCH] cli: Fix crash when packing --- src/cli/action_pack.cpp | 30 ++++++++++++++++++------------ 1 file changed, 18 insertions(+), 12 deletions(-) diff --git a/src/cli/action_pack.cpp b/src/cli/action_pack.cpp index 0f7d699..b805e63 100644 --- a/src/cli/action_pack.cpp +++ b/src/cli/action_pack.cpp @@ -322,24 +322,24 @@ bool ActionPack::pack_mrao( pack::ChannelPack_t pack[] = { {.srcChan = 0, .dstChan = 0, - .srcData = metalnessData->data(), - .comps = metalnessData->channels(), + .srcData = metalnessData ? metalnessData->data() : nullptr, + .comps = metalnessData ? metalnessData->channels() : 1, .constant = mconst}, {.srcChan = 0, .dstChan = 1, - .srcData = roughnessData->data(), - .comps = roughnessData->channels(), + .srcData = roughnessData ? roughnessData->data() : nullptr, + .comps = roughnessData ? roughnessData->channels() : 1, .constant = rconst}, {.srcChan = 0, .dstChan = 2, - .srcData = aoData->data(), - .comps = aoData->channels(), + .srcData = aoData ? aoData->data() : nullptr, + .comps = aoData ? aoData->channels() : 1, .constant = aoconst}, { .srcChan = 0, .dstChan = 3, - .srcData = tmaskData->data(), - .comps = tmaskData->channels(), + .srcData = tmaskData ? tmaskData->data() : nullptr, + .comps = tmaskData ? tmaskData->channels() : 1, .constant = 1, }}; @@ -355,9 +355,14 @@ bool ActionPack::pack_mrao( } // Free up some mem - roughnessData->clear(); - aoData->clear(); - metalnessData->clear(); + if (roughnessData) + roughnessData->clear(); + if (aoData) + aoData->clear(); + if (metalnessData) + metalnessData->clear(); + if (tmaskData) + tmaskData->clear(); // If user requested clamp, do that now if (clampw > 0 || clamph > 0) { @@ -373,7 +378,8 @@ bool ActionPack::pack_mrao( bool success = true; if ((success = save_vtf(outpath, outImage, opts, false))) - std::cout << fmt::format("Finished processing {}\n", outpath.string()); + if (!opts.get(opts::quiet)) + std::cout << fmt::format("Finished {} ({} KiB)\n", outpath.string(), file_->GetSize() / 1024); return success; }