diff options
author | Keunhong Park <keunhong@codeaurora.org> | 2012-07-25 10:28:46 -0600 |
---|---|---|
committer | Keunhong Park <keunhong@codeaurora.org> | 2012-08-02 12:58:15 -0600 |
commit | c3a31c25950cf005099b098b44a40032658ea2c3 (patch) | |
tree | 04a96fd6aa56ed230acfa58397cab312f46bde07 /gerrit-cache-h2 | |
parent | 07c45144c4f3a09b6b864d10cd5fde47ba389127 (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.java | 16 |
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; |