From e13a251e4900fea60cae05a616a9a4634b2c3d99 Mon Sep 17 00:00:00 2001 From: Skyler Grey Date: Mon, 2 Oct 2023 12:25:59 +0000 Subject: [PATCH] Fix tile dumping when /tmp is not temporary directory On iOS, each app has its own sandbox which has a temporary directory. The FileUtil::getSysTempDirectoryPath() method successfully gets this directory and we create a tiledump directory under it. Sadly, we then try to write to /tmp regardless of where the temporary directory is. This commit makes us also write our file in the directory returned by FileUtil::getSysTempDirectoryPath() Signed-off-by: Skyler Grey Change-Id: Ic8425cb94d1d85ac9c77212eb84d0ca7c46cd34e --- kit/Delta.hpp | 61 +++++++++++++++++++++++---------------------------- 1 file changed, 28 insertions(+), 33 deletions(-) diff --git a/kit/Delta.hpp b/kit/Delta.hpp index d2505a30d9763..a315cd47c00f4 100644 --- a/kit/Delta.hpp +++ b/kit/Delta.hpp @@ -734,45 +734,40 @@ class DeltaGenerator { int dumpedIndex = 1; if (dumpTiles) { - std::string path = "/tmp/tiledump"; - bool directoryExists = !FileUtil::isEmptyDirectory(path); + std::string path = FileUtil::getSysTempDirectoryPath() + "/tiledump"; + bool directoryExists = FileUtil::Stat(path).exists(); if (!directoryExists) - { FileUtil::createTmpDir("tiledump"); - directoryExists = true; - } - if (directoryExists) - { - // filename format: tile-----.png - std::ostringstream oss; - oss << "tile-" << loc._canonicalViewId << "-" << loc._part << "-" << loc._left << "-" << loc._top << "-"; - std::string baseFilename = oss.str(); - // find the next available filename - bool found = false; - int index = 1; + // filename format: tile-----.png + std::ostringstream oss; + oss << "tile-" << loc._canonicalViewId << "-" << loc._part << "-" << loc._left << "-" << loc._top << "-"; + std::string baseFilename = oss.str(); + + // find the next available filename + bool found = false; + int index = 1; - while (!found) + while (!found) + { + std::string filename = std::string("/") + baseFilename + std::to_string(index) + ".png"; + if (!FileUtil::Stat(path + filename).exists()) { - std::string filename = std::string("/") + baseFilename + std::to_string(index) + ".png"; - if (!FileUtil::Stat(path + filename).exists()) - { - found = true; - path += filename; - dumpedIndex = index; - } - else - { - index++; - } + found = true; + path += filename; + dumpedIndex = index; + } + else + { + index++; } - - std::ofstream tileFile(path, std::ios::binary); - std::vector pngOutput; - Png::encodeSubBufferToPNG(pixmap, startX, startY, width, height, - bufferWidth, bufferHeight, pngOutput, mode); - tileFile.write(pngOutput.data(), pngOutput.size()); } + + std::ofstream tileFile(path, std::ios::binary); + std::vector pngOutput; + Png::encodeSubBufferToPNG(pixmap, startX, startY, width, height, + bufferWidth, bufferHeight, pngOutput, mode); + tileFile.write(pngOutput.data(), pngOutput.size()); } if (!createDelta(pixmap, startX, startY, width, height, @@ -839,7 +834,7 @@ class DeltaGenerator { // Dump the delta if (dumpTiles) { - std::string path = "/tmp/tiledump"; + std::string path = FileUtil::getSysTempDirectoryPath() + "tiledump"; std::ostringstream oss; // filename format: tile-delta-----_to_.zstd oss << "tile-delta-" << loc._canonicalViewId << "-" << loc._part << "-" << loc._left << "-" << loc._top