From 6bd335c7382c0da8486e94d253dffa28525ceec7 Mon Sep 17 00:00:00 2001 From: Sam Anthony Date: Mon, 18 Nov 2024 10:35:22 -0500 Subject: reliable multicast: avoid receiving duplicate messages --- src/main/java/derms/net/rmulticast/ReceivedSet.java | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) (limited to 'src/main/java/derms/net/rmulticast/ReceivedSet.java') diff --git a/src/main/java/derms/net/rmulticast/ReceivedSet.java b/src/main/java/derms/net/rmulticast/ReceivedSet.java index 831ecbe..5fd8ce5 100644 --- a/src/main/java/derms/net/rmulticast/ReceivedSet.java +++ b/src/main/java/derms/net/rmulticast/ReceivedSet.java @@ -14,8 +14,18 @@ class ReceivedSet { this.received = new ConcurrentLinkedQueue>(); } - void add(Message e) { - received.add(e); + /** + * Add a message to the set if it is not already present. + * + * @param msg The message to add to the set. + * @return True if the set did not already contain the specified message. + */ + // TODO: faster insertion. + boolean add(Message msg) { + if (contains(msg)) + return false; + received.add(msg); + return true; } // TODO: faster search. @@ -35,6 +45,10 @@ class ReceivedSet { } } + boolean contains(Message msg) { + return contains(msg.id()); + } + /** Remove the specified message from the set, if it is present. */ void remove(Message msg) { received.remove(msg); -- cgit v1.2.3