Merge branch 'ubruntu/trade-fix-part3' into 'master'

Trade fix (with hashmap awareness)

See merge request veloren/veloren!2877
This commit is contained in:
Imbris 2021-10-01 21:17:19 +00:00
commit 396604f6d8
2 changed files with 13 additions and 0 deletions

View File

@ -218,6 +218,18 @@ pub fn handle_invite_accept(server: &mut Server, entity: specs::Entity) {
(uids.get(inviter).copied(), uids.get(entity).copied())
{
let mut trades = state.ecs().write_resource::<Trades>();
// check if the person that invited me has started a new trade since the
// invitation was sent
if trades.entity_trades.get(&inviter_uid).copied().is_some() {
for client in clients.get(entity).into_iter().chain(clients.get(inviter)) {
client.send_fallible(ServerGeneral::server_msg(
ChatType::Meta,
"Trade failed, inviter initiated new trade since sending trade \
request.",
));
}
return;
}
let id = trades.begin_trade(inviter_uid, invitee_uid);
let trade = trades.trades[&id].clone();
if let Some(agent) = agents.get_mut(inviter) {

View File

@ -102,6 +102,7 @@ pub fn handle_process_trade_action(
AgentEvent::FinishedTrade(result.clone()),
);
}
trades.entity_trades.remove_entry(party);
}
} else {
let mut entities: [Option<specs::Entity>; 2] = [None, None];