From eda0d883e30946b20b1430fc30be38c984495035 Mon Sep 17 00:00:00 2001 From: vektor Date: Thu, 21 Nov 2024 15:10:48 +0100 Subject: [PATCH] tweak(streaming): add statistics about asset type usage --- .../gta-streaming-five/src/LoadStreamingFile.cpp | 14 +++++++++++++- 1 file changed, 13 insertions(+), 1 deletion(-) diff --git a/code/components/gta-streaming-five/src/LoadStreamingFile.cpp b/code/components/gta-streaming-five/src/LoadStreamingFile.cpp index cb89999d51..e7667e1410 100644 --- a/code/components/gta-streaming-five/src/LoadStreamingFile.cpp +++ b/code/components/gta-streaming-five/src/LoadStreamingFile.cpp @@ -1757,6 +1757,8 @@ static hook::cdecl_stub initGfxTexture([]() }); #endif +std::unordered_map g_resourceStats; + static void LoadStreamingFiles(LoadType loadType) { auto cstreaming = streaming::Manager::GetInstance(); @@ -1835,6 +1837,8 @@ static void LoadStreamingFiles(LoadType loadType) continue; } + g_resourceStats[ext]++; + // this may get used on unloading if (baseName == "busy_spinner.gfx") { @@ -2884,6 +2888,8 @@ static void SafelyDrainStreamer() _unloadTextureLODs(); trace("Shutdown: streamer tasks done\n"); + + g_resourceStats.clear(); } #ifdef GTA_FIVE @@ -3276,7 +3282,13 @@ void* chunkyArrayAppend(hook::FlexStruct* self) const int32_t loadedEntriesCount = self->Get(chunkyArrayCountOffset); if (loadedEntriesCount >= 0xFFFF) { - FatalError("ERR_STR_FAILURE: trying to add more assets to pgRawStreamer when it's already full (65535)."); + std::stringstream ss; + for (auto& [ext, num] : g_resourceStats) + { + ss << ext << ": " << num << ", "; + } + AddCrashometry("asset_stats", ss.str()); + FatalError("ERR_STR_FAILURE: trying to add more assets to pgRawStreamer when it's already full (65535)."); } return g_chunkyArrayAppend(self);