Merge pull request #8333 from CookiePLMonster/screenshot-timestamp

Core: Generate screenshot name with timestamps
This commit is contained in:
JMC47 2019-09-30 00:32:07 -04:00 committed by GitHub
commit bec433cb40
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 17 additions and 11 deletions

View File

@ -13,6 +13,7 @@
#include <variant> #include <variant>
#include <fmt/format.h> #include <fmt/format.h>
#include <fmt/time.h>
#ifdef _WIN32 #ifdef _WIN32
#include <windows.h> #include <windows.h>
@ -677,15 +678,20 @@ static std::string GenerateScreenshotFolderPath()
static std::string GenerateScreenshotName() static std::string GenerateScreenshotName()
{ {
std::string path = GenerateScreenshotFolderPath();
// append gameId, path only contains the folder here. // append gameId, path only contains the folder here.
path += SConfig::GetInstance().GetGameID(); const std::string path_prefix =
GenerateScreenshotFolderPath() + SConfig::GetInstance().GetGameID();
std::string name; const std::time_t cur_time = std::time(nullptr);
for (int i = 1; File::Exists(name = fmt::format("{}-{}.png", path, i)); ++i) const std::string base_name =
fmt::format("{}_{:%Y-%m-%d_%H-%M-%S}", path_prefix, *std::localtime(&cur_time));
// First try a filename without any suffixes, if already exists then append increasing numbers
std::string name = fmt::format("{}.png", base_name);
if (File::Exists(name))
{ {
// TODO? for (u32 i = 1; File::Exists(name = fmt::format("{}_{}.png", base_name, i)); ++i)
;
} }
return name; return name;
@ -709,8 +715,8 @@ void SaveScreenShot(std::string_view name, bool wait_for_completion)
SetState(State::Paused); SetState(State::Paused);
const std::string path = fmt::format("{}{}.png", GenerateScreenshotFolderPath(), name); g_renderer->SaveScreenshot(fmt::format("{}{}.png", GenerateScreenshotFolderPath(), name),
g_renderer->SaveScreenshot(path, wait_for_completion); wait_for_completion);
if (!bPaused) if (!bPaused)
SetState(State::Running); SetState(State::Running);

View File

@ -369,12 +369,12 @@ Renderer::ConvertStereoRectangle(const MathUtil::Rectangle<int>& rc) const
return std::make_tuple(left_rc, right_rc); return std::make_tuple(left_rc, right_rc);
} }
void Renderer::SaveScreenshot(const std::string& filename, bool wait_for_completion) void Renderer::SaveScreenshot(std::string filename, bool wait_for_completion)
{ {
// We must not hold the lock while waiting for the screenshot to complete. // We must not hold the lock while waiting for the screenshot to complete.
{ {
std::lock_guard<std::mutex> lk(m_screenshot_lock); std::lock_guard<std::mutex> lk(m_screenshot_lock);
m_screenshot_name = filename; m_screenshot_name = std::move(filename);
m_screenshot_request.Set(); m_screenshot_request.Set();
} }

View File

@ -196,7 +196,7 @@ public:
float EFBToScaledYf(float y) const; float EFBToScaledYf(float y) const;
// Random utilities // Random utilities
void SaveScreenshot(const std::string& filename, bool wait_for_completion); void SaveScreenshot(std::string filename, bool wait_for_completion);
void DrawDebugText(); void DrawDebugText();
// ImGui initialization depends on being able to create textures and pipelines, so do it last. // ImGui initialization depends on being able to create textures and pipelines, so do it last.