Commit f45d4709 authored by Tobias Meuser's avatar Tobias Meuser Committed by Jose Ignacio Monreal Bailey
Browse files

Create a new cache instance for every host

parent 7176ebc8
...@@ -23,15 +23,19 @@ package de.tud.kom.p2psim.impl.vehicular.caching.invalidation; ...@@ -23,15 +23,19 @@ package de.tud.kom.p2psim.impl.vehicular.caching.invalidation;
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.invalidation.CacheInvalidationStrategy; import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.invalidation.CacheInvalidationStrategy;
public enum CacheInvalidationStrategyType { public enum CacheInvalidationStrategyType {
DEFAULT(new DefaultCacheInvalidationStrategy()); DEFAULT(DefaultCacheInvalidationStrategy.class);
private final CacheInvalidationStrategy replacementStrategy; private final Class<? extends CacheInvalidationStrategy> replacementStrategy;
private CacheInvalidationStrategyType(final CacheInvalidationStrategy replacementStrategy) { private CacheInvalidationStrategyType(final Class<? extends CacheInvalidationStrategy> replacementStrategy) {
this.replacementStrategy = replacementStrategy; this.replacementStrategy = replacementStrategy;
} }
public CacheInvalidationStrategy getInvalidationStrategy() { public CacheInvalidationStrategy getInvalidationStrategy() {
return replacementStrategy; try {
return replacementStrategy.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
throw new AssertionError(e);
}
} }
} }
...@@ -23,15 +23,19 @@ package de.tud.kom.p2psim.impl.vehicular.caching.replacement; ...@@ -23,15 +23,19 @@ package de.tud.kom.p2psim.impl.vehicular.caching.replacement;
import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.replacement.CacheReplacementStrategy; import de.tudarmstadt.maki.simonstrator.api.component.vehicular.caching.replacement.CacheReplacementStrategy;
public enum CacheReplacementStrategyType { public enum CacheReplacementStrategyType {
DEFAULT(new DefaultCacheReplacementStrategy()); DEFAULT(DefaultCacheReplacementStrategy.class);
private final CacheReplacementStrategy replacementStrategy; private final Class<? extends CacheReplacementStrategy> replacementStrategy;
private CacheReplacementStrategyType(final CacheReplacementStrategy replacementStrategy) { private CacheReplacementStrategyType(final Class<? extends CacheReplacementStrategy> replacementStrategy) {
this.replacementStrategy = replacementStrategy; this.replacementStrategy = replacementStrategy;
} }
public CacheReplacementStrategy getReplacementStrategy() { public CacheReplacementStrategy getReplacementStrategy() {
return replacementStrategy; try {
return replacementStrategy.newInstance();
} catch (InstantiationException | IllegalAccessException e) {
throw new AssertionError(e);
}
} }
} }
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment