diff --git a/check_api/src/main/java/com/google/errorprone/dataflow/DataFlow.java b/check_api/src/main/java/com/google/errorprone/dataflow/DataFlow.java index 7cd46c97187..1769ea5e878 100644 --- a/check_api/src/main/java/com/google/errorprone/dataflow/DataFlow.java +++ b/check_api/src/main/java/com/google/errorprone/dataflow/DataFlow.java @@ -16,12 +16,11 @@ package com.google.errorprone.dataflow; +import com.github.benmanes.caffeine.cache.CacheLoader; +import com.github.benmanes.caffeine.cache.Caffeine; +import com.github.benmanes.caffeine.cache.LoadingCache; import com.google.auto.value.AutoValue; import com.google.common.base.Preconditions; -import com.google.common.cache.CacheBuilder; -import com.google.common.cache.CacheLoader; -import com.google.common.cache.LoadingCache; -import com.google.common.util.concurrent.UncheckedExecutionException; import com.sun.source.tree.BlockTree; import com.sun.source.tree.ClassTree; import com.sun.source.tree.CompilationUnitTree; @@ -46,6 +45,8 @@ import org.checkerframework.errorprone.dataflow.cfg.UnderlyingAST; import org.checkerframework.errorprone.dataflow.cfg.builder.CFGBuilder; +import java.util.concurrent.CompletionException; + /** * Provides a wrapper around {@link org.checkerframework.errorprone.dataflow.analysis.Analysis}. * @@ -73,7 +74,7 @@ public interface Result< * TODO(b/158869538): Write a test that checks these assumptions */ private static final LoadingCache> analysisCache = - CacheBuilder.newBuilder() + Caffeine.newBuilder() .build( new CacheLoader>() { @Override @@ -89,7 +90,7 @@ public interface Result< }); private static final LoadingCache cfgCache = - CacheBuilder.newBuilder() + Caffeine.newBuilder() .maximumSize(1) .build( new CacheLoader() { @@ -173,13 +174,13 @@ Result methodDataflow(TreePath methodPath, Context context, T transfer) ControlFlowGraph cfg; try { - cfg = cfgCache.getUnchecked(CfgParams.create(methodPath, env)); - } catch (UncheckedExecutionException e) { + cfg = cfgCache.get(CfgParams.create(methodPath, env)); + } catch (CompletionException e) { throw e.getCause() instanceof CompletionFailure ? (CompletionFailure) e.getCause() : e; } AnalysisParams aparams = AnalysisParams.create(transfer, cfg, env); @SuppressWarnings("unchecked") - Analysis analysis = (Analysis) analysisCache.getUnchecked(aparams); + Analysis analysis = (Analysis) analysisCache.get(aparams); return new Result() { @Override diff --git a/check_api/src/main/java/com/google/errorprone/dataflow/nullnesspropagation/inference/NullnessQualifierInference.java b/check_api/src/main/java/com/google/errorprone/dataflow/nullnesspropagation/inference/NullnessQualifierInference.java index 5131040944e..97ab452d1da 100644 --- a/check_api/src/main/java/com/google/errorprone/dataflow/nullnesspropagation/inference/NullnessQualifierInference.java +++ b/check_api/src/main/java/com/google/errorprone/dataflow/nullnesspropagation/inference/NullnessQualifierInference.java @@ -18,16 +18,15 @@ import static com.google.common.base.Preconditions.checkArgument; +import com.github.benmanes.caffeine.cache.CacheLoader; +import com.github.benmanes.caffeine.cache.Caffeine; +import com.github.benmanes.caffeine.cache.LoadingCache; import com.google.auto.value.AutoValue; -import com.google.common.cache.CacheBuilder; -import com.google.common.cache.CacheLoader; -import com.google.common.cache.LoadingCache; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableSet; import com.google.common.collect.Streams; import com.google.common.graph.GraphBuilder; import com.google.common.graph.MutableGraph; -import com.google.common.util.concurrent.UncheckedExecutionException; import com.google.errorprone.dataflow.nullnesspropagation.Nullness; import com.google.errorprone.dataflow.nullnesspropagation.NullnessAnnotations; import com.sun.source.tree.ArrayAccessTree; @@ -64,6 +63,7 @@ import java.util.Iterator; import java.util.List; import java.util.Optional; +import java.util.concurrent.CompletionException; import java.util.function.Consumer; import javax.annotation.Nullable; import javax.lang.model.type.TypeVariable; @@ -78,7 +78,7 @@ public class NullnessQualifierInference extends TreeScanner { private static final LoadingCache inferenceCache = - CacheBuilder.newBuilder() + Caffeine.newBuilder() .maximumSize(1) .build( new CacheLoader() { @@ -100,8 +100,8 @@ public static InferredNullability getInferredNullability(Tree methodOrInitialize "Tree `%s` is not a lambda, initializer, or method.", methodOrInitializerOrLambda); try { - return inferenceCache.getUnchecked(methodOrInitializerOrLambda); - } catch (UncheckedExecutionException e) { + return inferenceCache.get(methodOrInitializerOrLambda); + } catch (CompletionException e) { throw e.getCause() instanceof CompletionFailure ? (CompletionFailure) e.getCause() : e; } }