/*
* Copyright 2015 Ben Manes. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.github.benmanes.caffeine.cache;
import java.util.Set;
import java.util.stream.Collectors;
import java.util.stream.StreamSupport;
import com.google.common.base.CaseFormat;
import com.google.common.collect.Sets;
/**
* The features that may be code generated.
*
* @author ben.manes@gmail.com (Ben Manes)
*/
public enum Feature {
STRONG_KEYS,
WEAK_KEYS,
STRONG_VALUES,
INFIRM_VALUES,
WEAK_VALUES,
SOFT_VALUES,
EXPIRE_ACCESS,
EXPIRE_WRITE,
REFRESH_WRITE,
MAXIMUM_SIZE,
MAXIMUM_WEIGHT,
LISTENING,
STATS;
public static String makeEnumName(Iterable<Feature> features) {
return StreamSupport.stream(features.spliterator(), false)
.map(Feature::name)
.collect(Collectors.joining("_"));
}
public static String makeEnumName(String enumName) {
return CaseFormat.UPPER_CAMEL.to(CaseFormat.UPPER_UNDERSCORE, enumName);
}
public static String makeClassName(Iterable<Feature> features) {
String enumName = makeEnumName(features);
return makeClassName(enumName);
}
public static String makeClassName(String enumName) {
return CaseFormat.UPPER_UNDERSCORE.to(CaseFormat.UPPER_CAMEL, enumName);
}
public static boolean usesWriteOrderDeque(Set<Feature> features) {
return features.contains(Feature.EXPIRE_WRITE);
}
public static boolean usesAccessOrderEdenDeque(Set<Feature> features) {
return features.contains(Feature.MAXIMUM_SIZE)
|| features.contains(Feature.MAXIMUM_WEIGHT)
|| features.contains(Feature.EXPIRE_ACCESS);
}
public static boolean usesAccessOrderMainDeque(Set<Feature> features) {
return features.contains(Feature.MAXIMUM_SIZE)
|| features.contains(Feature.MAXIMUM_WEIGHT);
}
public static boolean usesWriteQueue(Set<Feature> features) {
return features.contains(Feature.MAXIMUM_SIZE)
|| features.contains(Feature.MAXIMUM_WEIGHT)
|| features.contains(Feature.EXPIRE_ACCESS)
|| features.contains(Feature.EXPIRE_WRITE)
|| features.contains(Feature.REFRESH_WRITE);
}
public static boolean useWriteTime(Set<Feature> features) {
return features.contains(Feature.EXPIRE_WRITE)
|| features.contains(Feature.REFRESH_WRITE);
}
public static boolean usesExpirationTicker(Set<Feature> features) {
return features.contains(Feature.EXPIRE_ACCESS)
|| features.contains(Feature.EXPIRE_WRITE)
|| features.contains(Feature.REFRESH_WRITE);
}
public static boolean usesMaximum(Set<Feature> features) {
return features.contains(Feature.MAXIMUM_SIZE)
|| features.contains(Feature.MAXIMUM_WEIGHT);
}
public static boolean usesFastPath(Set<Feature> features) {
Set<Feature> incompatible = Sets.immutableEnumSet(Feature.EXPIRE_ACCESS,
Feature.WEAK_KEYS, Feature.INFIRM_VALUES, Feature.WEAK_VALUES, Feature.SOFT_VALUES);
return !features.stream().anyMatch(incompatible::contains) && usesMaximum(features);
}
}