mirror of
https://github.com/WinampDesktop/winamp.git
synced 2025-04-27 08:15:42 -04:00
Achievements: Always recompute state data size on save
It can be smaller, or, apparently fail in some cases...
This commit is contained in:
parent
5c94ab9f22
commit
a89ec0eaf9
@ -1543,6 +1543,7 @@ bool Achievements::DoState(StateWrapper& sw)
|
|||||||
return !sw.HasError();
|
return !sw.HasError();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (data_size > s_state_buffer.size())
|
||||||
s_state_buffer.resize(data_size);
|
s_state_buffer.resize(data_size);
|
||||||
if (data_size > 0)
|
if (data_size > 0)
|
||||||
sw.DoBytes(s_state_buffer.data(), data_size);
|
sw.DoBytes(s_state_buffer.data(), data_size);
|
||||||
@ -1569,7 +1570,7 @@ bool Achievements::DoState(StateWrapper& sw)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
u32 data_size;
|
size_t data_size;
|
||||||
|
|
||||||
#ifdef ENABLE_RAINTEGRATION
|
#ifdef ENABLE_RAINTEGRATION
|
||||||
if (IsUsingRAIntegration())
|
if (IsUsingRAIntegration())
|
||||||
@ -1592,18 +1593,13 @@ bool Achievements::DoState(StateWrapper& sw)
|
|||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
int result = RC_INSUFFICIENT_BUFFER;
|
data_size = rc_client_progress_size(s_client);
|
||||||
if (!s_state_buffer.empty())
|
if (data_size > 0)
|
||||||
result = rc_client_serialize_progress_sized(s_client, s_state_buffer.data(), s_state_buffer.size());
|
|
||||||
|
|
||||||
if (result == RC_INSUFFICIENT_BUFFER)
|
|
||||||
{
|
{
|
||||||
const size_t size = rc_client_progress_size(s_client);
|
if (s_state_buffer.size() < data_size)
|
||||||
s_state_buffer.resize(size);
|
s_state_buffer.resize(data_size);
|
||||||
result = rc_client_serialize_progress_sized(s_client, s_state_buffer.data(), s_state_buffer.size());
|
|
||||||
}
|
|
||||||
|
|
||||||
data_size = static_cast<u32>(s_state_buffer.size());
|
const int result = rc_client_serialize_progress_sized(s_client, s_state_buffer.data(), data_size);
|
||||||
if (result != RC_OK)
|
if (result != RC_OK)
|
||||||
{
|
{
|
||||||
// set data to zero, effectively serializing nothing
|
// set data to zero, effectively serializing nothing
|
||||||
@ -1611,6 +1607,7 @@ bool Achievements::DoState(StateWrapper& sw)
|
|||||||
data_size = 0;
|
data_size = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sw.Do(&data_size);
|
sw.Do(&data_size);
|
||||||
if (data_size > 0)
|
if (data_size > 0)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user