mirror of
https://github.com/collinsmith/riiablo.git
synced 2025-01-07 05:50:58 +07:00
Only send connection packets to unconnected players -- prevents flooding until sync packets aggregated
This commit is contained in:
parent
03c620d574
commit
25e057c08a
@ -115,7 +115,7 @@ public class ClientNetworkSyncronizer extends IntervalSystem {
|
|||||||
while (buffer.hasRemaining()) {
|
while (buffer.hasRemaining()) {
|
||||||
int size = ByteBufferUtil.getSizePrefix(buffer);
|
int size = ByteBufferUtil.getSizePrefix(buffer);
|
||||||
D2GS.getRootAsD2GS(ByteBufferUtil.removeSizePrefix(buffer), d2gs);
|
D2GS.getRootAsD2GS(ByteBufferUtil.removeSizePrefix(buffer), d2gs);
|
||||||
if (DEBUG_PACKET) Gdx.app.debug(TAG, "packet type " + D2GSData.name(d2gs.dataType()) + ":" + ByteBufferUtil.getSizePrefix(buffer) + "B");
|
if (DEBUG_PACKET) Gdx.app.debug(TAG, "packet type " + D2GSData.name(d2gs.dataType()) + ":" + size + "B");
|
||||||
connected = d2gs.dataType() == D2GSData.Connection;
|
connected = d2gs.dataType() == D2GSData.Connection;
|
||||||
if (!connected) {
|
if (!connected) {
|
||||||
if (DEBUG_CONNECT) Gdx.app.debug(TAG, "dropping... ");
|
if (DEBUG_CONNECT) Gdx.app.debug(TAG, "dropping... ");
|
||||||
|
@ -152,7 +152,7 @@ public class D2GS extends ApplicationAdapter {
|
|||||||
int connected = 0;
|
int connected = 0;
|
||||||
|
|
||||||
final BlockingQueue<Packet> packets = new ArrayBlockingQueue<>(32);
|
final BlockingQueue<Packet> packets = new ArrayBlockingQueue<>(32);
|
||||||
final Collection<Packet> cache = new ArrayList<>();
|
final Collection<Packet> cache = new ArrayList<>(1024);
|
||||||
final BlockingQueue<Packet> outPackets = new ArrayBlockingQueue<>(1024);
|
final BlockingQueue<Packet> outPackets = new ArrayBlockingQueue<>(1024);
|
||||||
final IntIntMap player = new IntIntMap();
|
final IntIntMap player = new IntIntMap();
|
||||||
|
|
||||||
@ -287,7 +287,7 @@ public class D2GS extends ApplicationAdapter {
|
|||||||
Gdx.app.log(TAG, "assigned " + socket.getRemoteAddress() + " to " + id);
|
Gdx.app.log(TAG, "assigned " + socket.getRemoteAddress() + " to " + id);
|
||||||
Client client = clients[id] = new Client(id, socket);
|
Client client = clients[id] = new Client(id, socket);
|
||||||
numClients++;
|
numClients++;
|
||||||
connected |= (1 << id);
|
//connected |= (1 << id);
|
||||||
client.start();
|
client.start();
|
||||||
}
|
}
|
||||||
} catch (Throwable t) {
|
} catch (Throwable t) {
|
||||||
@ -347,7 +347,7 @@ public class D2GS extends ApplicationAdapter {
|
|||||||
for (Packet packet : cache) {
|
for (Packet packet : cache) {
|
||||||
Gdx.app.log(TAG, "dispatching " + D2GSData.name(packet.data.dataType()) + " packet to " + String.format("0x%08X", packet.id));
|
Gdx.app.log(TAG, "dispatching " + D2GSData.name(packet.data.dataType()) + " packet to " + String.format("0x%08X", packet.id));
|
||||||
for (int i = 0, flag = 1; i < MAX_CLIENTS; i++, flag <<= 1) {
|
for (int i = 0, flag = 1; i < MAX_CLIENTS; i++, flag <<= 1) {
|
||||||
if ((packet.id & flag) == flag && (connected & flag) == flag) {
|
if ((packet.id & flag) == flag && ((connected & flag) == flag || packet.data.dataType() == D2GSData.Connection)) {
|
||||||
Client client = clients[i];
|
Client client = clients[i];
|
||||||
if (client == null) continue;
|
if (client == null) continue;
|
||||||
try {
|
try {
|
||||||
@ -499,6 +499,9 @@ public class D2GS extends ApplicationAdapter {
|
|||||||
packet.buffer.mark();
|
packet.buffer.mark();
|
||||||
out.write(packet.buffer);
|
out.write(packet.buffer);
|
||||||
packet.buffer.reset();
|
packet.buffer.reset();
|
||||||
|
if ((connected & (1 << id)) == 0 && packet.data.dataType() == D2GSData.Connection) {
|
||||||
|
connected |= (1 << id);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
Loading…
Reference in New Issue
Block a user