mirror of
https://gitlab.com/Mr_Goldberg/goldberg_emulator.git
synced 2024-11-14 10:50:13 +01:00
Make isteamutils call result functions respect callback delays.
This commit is contained in:
parent
1427a4bcef
commit
736d1a9090
1 changed files with 7 additions and 3 deletions
10
dll/base.h
10
dll/base.h
|
@ -110,8 +110,12 @@ struct Steam_Call_Result {
|
||||||
return check_timedout(created, STEAM_CALLRESULT_TIMEOUT);
|
return check_timedout(created, STEAM_CALLRESULT_TIMEOUT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool call_completed() {
|
||||||
|
return (!reserved) && check_timedout(created, run_in);
|
||||||
|
}
|
||||||
|
|
||||||
bool can_execute() {
|
bool can_execute() {
|
||||||
return (!reserved) && (!to_delete) && check_timedout(created, run_in);
|
return (!to_delete) && call_completed();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool has_cb() {
|
bool has_cb() {
|
||||||
|
@ -169,14 +173,14 @@ public:
|
||||||
bool exists(SteamAPICall_t api_call) {
|
bool exists(SteamAPICall_t api_call) {
|
||||||
auto cr = std::find_if(callresults.begin(), callresults.end(), [api_call](struct Steam_Call_Result const& item) { return item.api_call == api_call; });
|
auto cr = std::find_if(callresults.begin(), callresults.end(), [api_call](struct Steam_Call_Result const& item) { return item.api_call == api_call; });
|
||||||
if (cr == callresults.end()) return false;
|
if (cr == callresults.end()) return false;
|
||||||
if (cr->reserved) return false;
|
if (!cr->call_completed()) return false;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool callback_result(SteamAPICall_t api_call, void *copy_to, unsigned int size) {
|
bool callback_result(SteamAPICall_t api_call, void *copy_to, unsigned int size) {
|
||||||
auto cb_result = std::find_if(callresults.begin(), callresults.end(), [api_call](struct Steam_Call_Result const& item) { return item.api_call == api_call; });
|
auto cb_result = std::find_if(callresults.begin(), callresults.end(), [api_call](struct Steam_Call_Result const& item) { return item.api_call == api_call; });
|
||||||
if (cb_result != callresults.end()) {
|
if (cb_result != callresults.end()) {
|
||||||
if (cb_result->reserved) return false;
|
if (!cb_result->call_completed()) return false;
|
||||||
if (cb_result->result.size() > size) return false;
|
if (cb_result->result.size() > size) return false;
|
||||||
|
|
||||||
memcpy(copy_to, &(cb_result->result[0]), cb_result->result.size());
|
memcpy(copy_to, &(cb_result->result[0]), cb_result->result.size());
|
||||||
|
|
Loading…
Reference in a new issue