summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/main/java/derms/net/rmulticast/Receive.java5
-rw-r--r--src/main/java/derms/net/rmulticast/ReliableMulticast.java7
2 files changed, 10 insertions, 2 deletions
diff --git a/src/main/java/derms/net/rmulticast/Receive.java b/src/main/java/derms/net/rmulticast/Receive.java
index c8467c2..c1965ed 100644
--- a/src/main/java/derms/net/rmulticast/Receive.java
+++ b/src/main/java/derms/net/rmulticast/Receive.java
@@ -18,14 +18,16 @@ class Receive<T extends Serializable & Hashable> implements Runnable {
private final Set<MessageID> negativeAcks;
private final ReceivedSet<T> received;
private final BlockingQueue<Message<T>> retransmissions;
+ private final BlockingQueue<Message<T>> delivered;
private final Logger log;
- Receive(ConcurrentMulticastSocket inSock, Set<MessageID> positiveAcks, Set<MessageID> negativeAcks, ReceivedSet<T> received, BlockingQueue<Message<T>> retransmissions) {
+ Receive(ConcurrentMulticastSocket inSock, Set<MessageID> positiveAcks, Set<MessageID> negativeAcks, ReceivedSet<T> received, BlockingQueue<Message<T>> retransmissions, BlockingQueue<Message<T>> delivered) {
this.inSock = inSock;
this.positiveAcks = positiveAcks;
this.negativeAcks = negativeAcks;
this.received = received;
this.retransmissions = retransmissions;
+ this.delivered = delivered;
this.log = Logger.getLogger(this.getClass().getName());
}
@@ -47,6 +49,7 @@ class Receive<T extends Serializable & Hashable> implements Runnable {
private void receive(Message<T> msg) {
positiveAcks.add(msg.id());
received.add(msg);
+ delivered.add(msg);
negativeAcks.remove(msg.id());
retransmissions.remove(msg);
diff --git a/src/main/java/derms/net/rmulticast/ReliableMulticast.java b/src/main/java/derms/net/rmulticast/ReliableMulticast.java
index 44fc10c..600b536 100644
--- a/src/main/java/derms/net/rmulticast/ReliableMulticast.java
+++ b/src/main/java/derms/net/rmulticast/ReliableMulticast.java
@@ -48,7 +48,7 @@ public class ReliableMulticast<T extends Serializable & Hashable> {
this.log = Logger.getLogger(this.getClass().getName());
- (new Thread(new Receive<T>(inSock, positiveAcks, negativeAcks, received, retransmissions))).start();
+ (new Thread(new Receive<T>(inSock, positiveAcks, negativeAcks, received, retransmissions, delivered))).start();
(new Thread(new Retransmit<T>(retransmissions, outSock, group))).start();
}
@@ -64,4 +64,9 @@ public class ReliableMulticast<T extends Serializable & Hashable> {
(new Thread(new Timeout<T>(msg, positiveAcks, retransmissions))).start();
lastSend.set(Instant.now());
}
+
+ public T receive() throws InterruptedException {
+ Message<T> msg = delivered.take();
+ return msg.payload;
+ }
}