mirror of
https://github.com/SpigotMC/BungeeCord.git
synced 2024-12-25 18:17:38 +01:00
Reduce ram usage by ~65kb / player. See #229
This commit is contained in:
parent
19c3c23b86
commit
88c99f071e
@ -16,8 +16,18 @@ public class CipherCodec extends ByteToByteCodec
|
||||
|
||||
private Cipher encrypt;
|
||||
private Cipher decrypt;
|
||||
private byte[] heapIn = new byte[ 0 ];
|
||||
private byte[] heapOut = new byte[ 0 ];
|
||||
private ThreadLocal<byte[]> heapInLocal = new EmptyByteThreadLocal();
|
||||
private ThreadLocal<byte[]> heapOutLocal = new EmptyByteThreadLocal();
|
||||
|
||||
private static class EmptyByteThreadLocal extends ThreadLocal<byte[]>
|
||||
{
|
||||
|
||||
@Override
|
||||
protected byte[] initialValue()
|
||||
{
|
||||
return new byte[ 0 ];
|
||||
}
|
||||
}
|
||||
|
||||
public CipherCodec(Cipher encrypt, Cipher decrypt)
|
||||
{
|
||||
@ -39,6 +49,7 @@ public class CipherCodec extends ByteToByteCodec
|
||||
|
||||
private void cipher(ByteBuf in, ByteBuf out, Cipher cipher) throws ShortBufferException
|
||||
{
|
||||
byte[] heapIn = heapInLocal.get();
|
||||
int readableBytes = in.readableBytes();
|
||||
if ( heapIn.length < readableBytes )
|
||||
{
|
||||
@ -46,6 +57,7 @@ public class CipherCodec extends ByteToByteCodec
|
||||
}
|
||||
in.readBytes( heapIn, 0, readableBytes );
|
||||
|
||||
byte[] heapOut = heapOutLocal.get();
|
||||
int outputSize = cipher.getOutputSize( readableBytes );
|
||||
if ( heapOut.length < outputSize )
|
||||
{
|
||||
|
Loading…
Reference in New Issue
Block a user