summaryrefslogtreecommitdiffstats
path: root/gerrit-cache-h2
diff options
context:
space:
mode:
authorKeunhong Park <keunhong@codeaurora.org>2012-07-25 10:28:46 -0600
committerKeunhong Park <keunhong@codeaurora.org>2012-08-02 12:58:15 -0600
commitc3a31c25950cf005099b098b44a40032658ea2c3 (patch)
tree04a96fd6aa56ed230acfa58397cab312f46bde07 /gerrit-cache-h2
parent07c45144c4f3a09b6b864d10cd5fde47ba389127 (diff)
Add support for binding CacheRemovalListener
This can be used to dynamically bind removal listeners for use in multi-master support. Change-Id: I9c58740c54c89e5bd75accc64f03f1fdddc8d581
Diffstat (limited to 'gerrit-cache-h2')
-rw-r--r--gerrit-cache-h2/src/main/java/com/google/gerrit/server/cache/h2/DefaultCacheFactory.java16
1 files changed, 15 insertions, 1 deletions
diff --git a/gerrit-cache-h2/src/main/java/com/google/gerrit/server/cache/h2/DefaultCacheFactory.java b/gerrit-cache-h2/src/main/java/com/google/gerrit/server/cache/h2/DefaultCacheFactory.java
index 8bb0709170..a6e28da139 100644
--- a/gerrit-cache-h2/src/main/java/com/google/gerrit/server/cache/h2/DefaultCacheFactory.java
+++ b/gerrit-cache-h2/src/main/java/com/google/gerrit/server/cache/h2/DefaultCacheFactory.java
@@ -22,10 +22,12 @@ import com.google.common.cache.LoadingCache;
import com.google.common.cache.Weigher;
import com.google.gerrit.lifecycle.LifecycleModule;
import com.google.gerrit.server.cache.CacheBinding;
+import com.google.gerrit.server.cache.ForwardingRemovalListener;;
import com.google.gerrit.server.cache.MemoryCacheFactory;
import com.google.gerrit.server.cache.PersistentCacheFactory;
import com.google.gerrit.server.cache.h2.H2CacheImpl.ValueHolder;
import com.google.gerrit.server.config.ConfigUtil;
+import com.google.gerrit.server.config.FactoryModule;
import com.google.gerrit.server.config.GerritServerConfig;
import com.google.inject.Inject;
@@ -37,6 +39,13 @@ public class DefaultCacheFactory implements MemoryCacheFactory {
public static class Module extends LifecycleModule {
@Override
protected void configure() {
+ install(new FactoryModule() {
+ @Override
+ protected void configure() {
+ factory(ForwardingRemovalListener.Factory.class);
+ }
+ });
+
bind(DefaultCacheFactory.class);
bind(MemoryCacheFactory.class).to(DefaultCacheFactory.class);
bind(PersistentCacheFactory.class).to(H2CacheFactory.class);
@@ -45,10 +54,13 @@ public class DefaultCacheFactory implements MemoryCacheFactory {
}
private final Config cfg;
+ private final ForwardingRemovalListener.Factory forwardingRemovalListenerFactory;
@Inject
- public DefaultCacheFactory(@GerritServerConfig Config config) {
+ public DefaultCacheFactory(@GerritServerConfig Config config,
+ ForwardingRemovalListener.Factory forwardingRemovalListenerFactory) {
this.cfg = config;
+ this.forwardingRemovalListenerFactory = forwardingRemovalListenerFactory;
}
@Override
@@ -73,6 +85,8 @@ public class DefaultCacheFactory implements MemoryCacheFactory {
"cache", def.name(), "memoryLimit",
def.maximumWeight()));
+ builder.removalListener(forwardingRemovalListenerFactory.create(def.name()));
+
Weigher<K, V> weigher = def.weigher();
if (weigher != null && unwrapValueHolder) {
final Weigher<K, V> impl = weigher;