Skip to content

Commit

Permalink
Issue #5287 - Pool the entries instead of just the Deflater/Inflaters
Browse files Browse the repository at this point in the history
Signed-off-by: Lachlan Roberts <lachlan@webtide.com>
  • Loading branch information
lachlan-roberts committed Oct 14, 2020
1 parent 21576f2 commit d241c66
Showing 1 changed file with 29 additions and 14 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,8 @@

package org.eclipse.jetty.util.compression;

import java.io.Closeable;

import org.eclipse.jetty.util.Pool;
import org.eclipse.jetty.util.component.AbstractLifeCycle;

Expand All @@ -26,7 +28,7 @@ public abstract class CompressionPool<T> extends AbstractLifeCycle
public static final int INFINITE_CAPACITY = Integer.MAX_VALUE;

private int _capacity;
private Pool<T> _pool;
private Pool<Entry> _pool;

/**
* Create a Pool of {@link T} instances.
Expand Down Expand Up @@ -65,10 +67,18 @@ public void setCapacity(int capacity)
*/
public Entry acquire()
{
Entry entry = null;
if (_pool != null)
return new Entry(_pool.acquire(e -> newObject()));
else
return new Entry();
{
Pool<Entry>.Entry acquiredEntry = _pool.acquire(e -> new Entry(newObject()));
if (acquiredEntry != null)
{
entry = acquiredEntry.getPooled();
entry.setEntry(acquiredEntry);
}
}

return (entry == null) ? new Entry(newObject()) : entry;
}

/**
Expand All @@ -90,26 +100,25 @@ protected void doStart() throws Exception
@Override
public void doStop() throws Exception
{
// TODO: Pool.close() will not end the entries after it removes them.
_pool.close();
_pool = null;
super.doStop();
}

public class Entry
public class Entry implements Closeable
{
private T _value;
private Pool<T>.Entry _entry;
private Pool<Entry>.Entry _entry;

Entry()
Entry(T value)
{
this(null);
_value = value;
_entry = null;
}

Entry(Pool<T>.Entry entry)
void setEntry(Pool<Entry>.Entry entry)
{
_entry = entry;
_value = (_entry != null) ? _entry.getPooled() : newObject();
}

public T get()
Expand All @@ -127,12 +136,18 @@ public void release()
// If release return false, the entry should be removed and the object should be disposed.
if (!_pool.release(_entry))
{
// TODO: what does it mean if this returns false???
if (_pool.remove(_entry))
end(_value);
close();
}

_entry = null;
}
}

@Override
public void close()
{
end(_value);
_value = null;
_entry = null;
}
Expand All @@ -145,7 +160,7 @@ public String toString()
getClass().getSimpleName(),
hashCode(),
getState(),
_pool.size(),
(_pool == null) ? -1 : _pool.size(),
_capacity);
}
}

0 comments on commit d241c66

Please sign in to comment.