mirror of
https://github.com/Detanup01/gbe_fork.git
synced 2025-01-13 10:53:57 +08:00
Much faster stat get.
This commit is contained in:
parent
942f011ee0
commit
173c65a229
@ -195,11 +195,22 @@ bool GetStat( const char *pchName, int32 *pData )
|
|||||||
if (stats_data->second.type != Stat_Type::STAT_TYPE_INT) return false;
|
if (stats_data->second.type != Stat_Type::STAT_TYPE_INT) return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_data = local_storage->get_data(Local_Storage::stats_storage_folder, stat_name, (char* )pData, sizeof(*pData));
|
auto cached_stat = stats_cache_int.find(stat_name);
|
||||||
if (read_data == sizeof(int32))
|
if (cached_stat != stats_cache_int.end()) {
|
||||||
|
*pData = cached_stat->second;
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
int32 output = 0;
|
||||||
|
int read_data = local_storage->get_data(Local_Storage::stats_storage_folder, stat_name, (char* )&output, sizeof(output));
|
||||||
|
if (read_data == sizeof(int32)) {
|
||||||
|
stats_cache_int[stat_name] = output;
|
||||||
|
*pData = output;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (stats_data != stats_config.end()) {
|
if (stats_data != stats_config.end()) {
|
||||||
|
stats_cache_int[stat_name] = stats_data->second.default_value_int;
|
||||||
*pData = stats_data->second.default_value_int;
|
*pData = stats_data->second.default_value_int;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -220,11 +231,22 @@ bool GetStat( const char *pchName, float *pData )
|
|||||||
if (stats_data->second.type == Stat_Type::STAT_TYPE_INT) return false;
|
if (stats_data->second.type == Stat_Type::STAT_TYPE_INT) return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
int read_data = local_storage->get_data(Local_Storage::stats_storage_folder, stat_name, (char* )pData, sizeof(*pData));
|
auto cached_stat = stats_cache_float.find(stat_name);
|
||||||
if (read_data == sizeof(float))
|
if (cached_stat != stats_cache_float.end()) {
|
||||||
|
*pData = cached_stat->second;
|
||||||
return true;
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
float output = 0.0;
|
||||||
|
int read_data = local_storage->get_data(Local_Storage::stats_storage_folder, stat_name, (char* )&output, sizeof(output));
|
||||||
|
if (read_data == sizeof(float)) {
|
||||||
|
stats_cache_float[stat_name] = output;
|
||||||
|
*pData = output;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
if (stats_data != stats_config.end()) {
|
if (stats_data != stats_config.end()) {
|
||||||
|
stats_cache_float[stat_name] = stats_data->second.default_value_float;
|
||||||
*pData = stats_data->second.default_value_float;
|
*pData = stats_data->second.default_value_float;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -313,7 +335,12 @@ bool UpdateAvgRateStat( const char *pchName, float flCountThisSession, double dS
|
|||||||
memcpy(data + sizeof(float), &oldcount, sizeof(oldcount));
|
memcpy(data + sizeof(float), &oldcount, sizeof(oldcount));
|
||||||
memcpy(data + sizeof(float) * 2, &oldsessionlength, sizeof(oldsessionlength));
|
memcpy(data + sizeof(float) * 2, &oldsessionlength, sizeof(oldsessionlength));
|
||||||
|
|
||||||
return local_storage->store_data(Local_Storage::stats_storage_folder, stat_name, data, sizeof(data)) == sizeof(data);
|
if (local_storage->store_data(Local_Storage::stats_storage_folder, stat_name, data, sizeof(data)) == sizeof(data)) {
|
||||||
|
stats_cache_float[stat_name] = average;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user