bt.peerexchange.PeerExchangePeerSource Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of bt-core Show documentation
Show all versions of bt-core Show documentation
BitTorrent Client Library (Core)
package bt.peerexchange;
import bt.net.Peer;
import bt.peer.PeerSource;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
import java.util.Queue;
import java.util.Set;
import java.util.concurrent.LinkedBlockingQueue;
class PeerExchangePeerSource implements PeerSource {
private Queue messages;
private volatile Collection peers;
private volatile boolean hasNewPeers;
private final Object lock;
PeerExchangePeerSource() {
messages = new LinkedBlockingQueue<>();
peers = Collections.emptyList();
lock = new Object();
}
@Override
public boolean update() {
if (!hasNewPeers) {
return false;
}
synchronized (lock) {
peers = collectPeers(messages);
hasNewPeers = false;
}
return true;
}
private Collection collectPeers(Collection messages) {
Set peers = new HashSet<>();
messages.forEach(message -> {
message.getAdded().forEach(peers::add);
message.getDropped().forEach(peers::remove);
});
return peers;
}
void addMessage(PeerExchange message) {
synchronized (lock) {
messages.add(message);
// according to BEP-11 the same peers can't be dropped in the same message,
// so it's sufficient to check if list of added peers is not empty
hasNewPeers = hasNewPeers || !message.getAdded().isEmpty();
}
}
@Override
public Collection getPeers() {
return peers;
}
}