From 75717e8f6540e79df0e7ad200ec27e2671afff80 Mon Sep 17 00:00:00 2001 From: Antonio Martinez Date: Wed, 20 Aug 2025 21:00:06 -0400 Subject: [PATCH] Audit platinums --- src/d_netcmd.c | 1 + src/p_setup.cpp | 61 +++++++++++++++++++++++++++++++++++++++++++++++++ src/p_setup.h | 1 + 3 files changed, 63 insertions(+) diff --git a/src/d_netcmd.c b/src/d_netcmd.c index 090c7edaf..75bd50915 100644 --- a/src/d_netcmd.c +++ b/src/d_netcmd.c @@ -542,6 +542,7 @@ void D_RegisterClientCommands(void) COM_AddCommand("stopmovie", Command_StopMovie_f); COM_AddDebugCommand("minigen", M_MinimapGenerate); COM_AddDebugCommand("dumprrautomedaltimes", Command_dumprrautomedaltimes); + COM_AddDebugCommand("platinums", Command_Platinums); #ifdef SRB2_CONFIG_ENABLE_WEBM_MOVIES M_AVRecorder_AddCommands(); diff --git a/src/p_setup.cpp b/src/p_setup.cpp index 4115ec71a..43da65825 100644 --- a/src/p_setup.cpp +++ b/src/p_setup.cpp @@ -9501,6 +9501,67 @@ void Command_dumprrautomedaltimes(void) fclose(out); } +void Command_Platinums(void) +{ + srb2::Vector platinums; + + for (INT32 j = 0; j < nummapheaders; j++) + { + mapheader_t *map = mapheaderinfo[j]; + + if (map == NULL || map->ghostCount < 1) + continue; + + // Gather staff ghost times + srb2::Vector stafftimes; + for (int i = 0; i < map->ghostCount; i++) + { + tic_t time = map->ghostBrief[i]->time; + if (time <= 0) + { + continue; + } + + stafftimes.push_back(map->ghostBrief[i]->time); + } + + if (stafftimes.empty()) + { + continue; + } + + std::sort(stafftimes.begin(), stafftimes.end()); + + for (int i = 0; i < map->ghostCount; i++) + { + tic_t time = map->ghostBrief[i]->time; + if (time == stafftimes.at(0)) + { + tic_t delta = map->automedaltime[1] - map->automedaltime[0]; + + CONS_Printf("%s: %s (-%s)\n", map->lumpname, map->ghostBrief[i]->name, va("%d\"%02d", + G_TicsToSeconds(delta), + G_TicsToCentiseconds(delta)) + ); + platinums.push_back(map->ghostBrief[i]->name); + break; + } + } + } + + std::unordered_map frequency; + + for (const auto& platinum : platinums) + { + frequency[platinum]++; + } + + for (const auto& pair : frequency) + { + CONS_Printf("%s: %d\n", pair.first.c_str(), pair.second); + } +} + // // Add a wadfile to the active wad files, // replace sounds, musics, patches, textures, sprites and maps diff --git a/src/p_setup.h b/src/p_setup.h index a9839e3f8..7233f885f 100644 --- a/src/p_setup.h +++ b/src/p_setup.h @@ -162,6 +162,7 @@ void P_DeleteHeaderFollowers(UINT16 i); void P_ReloadRings(void); void Command_dumprrautomedaltimes(void); +void Command_Platinums(void); #ifdef __cplusplus } // extern "C"