From d9477fdd9ec5082b2c6821218623de4891a07541 Mon Sep 17 00:00:00 2001 From: Pi Lanningham Date: Tue, 10 Dec 2024 03:38:19 -0500 Subject: [PATCH] Better disagreement timer --- src/utils/HydraMultiplayer/dedicated.ts | 20 ++++++++++++-------- 1 file changed, 12 insertions(+), 8 deletions(-) diff --git a/src/utils/HydraMultiplayer/dedicated.ts b/src/utils/HydraMultiplayer/dedicated.ts index 8216e41..1aea2be 100644 --- a/src/utils/HydraMultiplayer/dedicated.ts +++ b/src/utils/HydraMultiplayer/dedicated.ts @@ -60,6 +60,7 @@ export class HydraMultiplayerDedicated extends HydraMultiplayer { console.log("Kills: ", this.clients); let keys = Object.keys(this.clients); + let allAgree = true; for(let i = 0; i < keys.length; i++) { for(let j = i + 1; j < keys.length; j++) { const clientA = this.clients[keys[i]]; @@ -69,18 +70,21 @@ export class HydraMultiplayerDedicated extends HydraMultiplayer { console.log(`Client A: ${clientA.kills}`); console.log(`Client B: ${clientB.kills}`); if(clientA.kills.toString() != clientB.kills.toString()) { - this.disagreeementTimer += 1; - console.log(`Players disagree on kills! They have ${10 - this.disagreeementTimer} to resolve this`); - if (this.disagreeementTimer > 10) { - console.log(`Players disagree on kills for too long; cancelling game!`); - this.onDisagreement?.(); - } - } else { - this.disagreeementTimer = 0; + allAgree = false; } } } } + if (!allAgree) { + this.disagreeementTimer++; + console.log(`Players disagree on kills! They have ${10 - this.disagreeementTimer} to resolve this`); + if (this.disagreeementTimer > 10) { + console.log(`Players disagree on kills for too long; cancelling game!`); + this.onDisagreement?.(); + } + } else { + this.disagreeementTimer = 0; + } } protected override buildTx(datum: string): [UTxO, string] {