blob: 21ca26efdd2a4a56898d87103dc2c8dc6afeb441 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
// Copyright 2016 Yahoo Inc. Licensed under the terms of the Apache 2.0 license. See LICENSE in the project root.
package com.yahoo.logserver.handlers.archive;
import java.io.IOException;
import java.util.logging.Logger;
import java.util.logging.Level;
import java.util.LinkedHashMap;
import java.util.Map;
/**
* @author <a href="mailto:borud@yahoo-inc.com">Bjorn Borud</a>
*/
@SuppressWarnings("serial")
public class LogWriterLRUCache extends LinkedHashMap<Integer, LogWriter>
{
private static final Logger log
= Logger.getLogger(LogWriterLRUCache.class.getName());
final int maxEntries = 100;
public LogWriterLRUCache(int initialCapacity,
float loadFactor) {
super(initialCapacity, loadFactor, true);
}
// TODO: implement unit test for this
protected boolean removeEldestEntry (Map.Entry<Integer, LogWriter> eldest) {
if (size() > maxEntries) {
LogWriter logWriter = (LogWriter)eldest.getValue();
log.fine("Closing oldest LogWriter: " + logWriter);
try {
logWriter.close();
} catch (IOException e) {
log.log(Level.WARNING, "closing LogWriter failed", e);
}
return true;
}
return false;
}
}
|