Compare commits

..

2 Commits

Author SHA1 Message Date
Mr_Goldberg 978a1b81e3
Don't write stats to disk if value didn't change. 2021-12-22 13:33:13 -05:00
Mr_Goldberg 9eb7066098
Fix crash.
Thanks wizark952.
2021-12-22 13:32:35 -05:00
2 changed files with 25 additions and 4 deletions

View File

@ -55,6 +55,9 @@ private:
nlohmann::json defined_achievements; nlohmann::json defined_achievements;
nlohmann::json user_achievements; nlohmann::json user_achievements;
std::vector<std::string> sorted_achievement_names; std::vector<std::string> sorted_achievement_names;
std::map<std::string, int32> stats_cache_int;
std::map<std::string, float> stats_cache_float;
unsigned int find_leaderboard(std::string name) unsigned int find_leaderboard(std::string name)
{ {
@ -200,8 +203,17 @@ bool SetStat( const char *pchName, int32 nData )
PRINT_DEBUG("SetStat int32 %s\n", pchName); PRINT_DEBUG("SetStat int32 %s\n", pchName);
if (!pchName) return false; if (!pchName) return false;
std::lock_guard<std::recursive_mutex> lock(global_mutex); std::lock_guard<std::recursive_mutex> lock(global_mutex);
auto cached_stat = stats_cache_int.find(pchName);
if (cached_stat != stats_cache_int.end()) {
if (cached_stat->second == nData) return true;
}
return local_storage->store_data(Local_Storage::stats_storage_folder, pchName, (char* )&nData, sizeof(nData)) == sizeof(nData); if (local_storage->store_data(Local_Storage::stats_storage_folder, pchName, (char* )&nData, sizeof(nData)) == sizeof(nData)) {
stats_cache_int[pchName] = nData;
return true;
}
return false;
} }
bool SetStat( const char *pchName, float fData ) bool SetStat( const char *pchName, float fData )
@ -209,8 +221,17 @@ bool SetStat( const char *pchName, float fData )
PRINT_DEBUG("SetStat float %s\n", pchName); PRINT_DEBUG("SetStat float %s\n", pchName);
if (!pchName) return false; if (!pchName) return false;
std::lock_guard<std::recursive_mutex> lock(global_mutex); std::lock_guard<std::recursive_mutex> lock(global_mutex);
auto cached_stat = stats_cache_float.find(pchName);
if (cached_stat != stats_cache_float.end()) {
if (cached_stat->second == fData) return true;
}
return local_storage->store_data(Local_Storage::stats_storage_folder, pchName, (char* )&fData, sizeof(fData)) == sizeof(fData); if (local_storage->store_data(Local_Storage::stats_storage_folder, pchName, (char* )&fData, sizeof(fData)) == sizeof(fData)) {
stats_cache_float[pchName] = fData;
return true;
}
return false;
} }
bool UpdateAvgRateStat( const char *pchName, float flCountThisSession, double dSessionLength ) bool UpdateAvgRateStat( const char *pchName, float flCountThisSession, double dSessionLength )

View File

@ -175,10 +175,10 @@ ESteamAPICallFailure GetAPICallFailureReason( SteamAPICall_t hSteamAPICall )
bool GetAPICallResult( SteamAPICall_t hSteamAPICall, void *pCallback, int cubCallback, int iCallbackExpected, bool *pbFailed ) bool GetAPICallResult( SteamAPICall_t hSteamAPICall, void *pCallback, int cubCallback, int iCallbackExpected, bool *pbFailed )
{ {
PRINT_DEBUG("GetAPICallResult %llu %i %i\n", hSteamAPICall, cubCallback, iCallbackExpected); PRINT_DEBUG("GetAPICallResult %llu %i %i %p\n", hSteamAPICall, cubCallback, iCallbackExpected, pbFailed);
std::lock_guard<std::recursive_mutex> lock(global_mutex); std::lock_guard<std::recursive_mutex> lock(global_mutex);
if (callback_results->callback_result(hSteamAPICall, pCallback, cubCallback)) { if (callback_results->callback_result(hSteamAPICall, pCallback, cubCallback)) {
*pbFailed = false; if (pbFailed) *pbFailed = false;
PRINT_DEBUG("GetAPICallResult Succeeded\n"); PRINT_DEBUG("GetAPICallResult Succeeded\n");
return true; return true;
} else { } else {