interface  com.github.benmanes.caffeine.cache.LocalAsyncCache extends java.lang.Object implements com.github.benmanes.caffeine.cache.AsyncCache
{
public static final java.lang.System$Logger logger;
public abstract com.github.benmanes.caffeine.cache.LocalCache cache();
public abstract com.github.benmanes.caffeine.cache.Policy policy();
public java.util.concurrent.CompletableFuture getIfPresent(java.lang.Object)
{
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
com.github.benmanes.caffeine.cache.LocalCache v;
java.lang.Object v, v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Object;
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.lang.Object getIfPresent(java.lang.Object,boolean)>(v, 1);
return v;
}
public java.util.concurrent.CompletableFuture get(java.lang.Object, java.util.function.Function)
{
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
java.util.function.BiFunction v;
java.lang.Object v;
java.util.concurrent.CompletableFuture v;
java.util.function.Function v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Object;
v := @parameter: java.util.function.Function;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache$lambda_get_1__393: java.util.function.BiFunction bootstrap$(java.util.function.Function,java.lang.Object)>(v, v);
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: java.util.concurrent.CompletableFuture get(java.lang.Object,java.util.function.BiFunction)>(v, v);
return v;
}
public java.util.concurrent.CompletableFuture get(java.lang.Object, java.util.function.BiFunction)
{
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
java.util.function.BiFunction v;
java.lang.Object v;
java.util.concurrent.CompletableFuture v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Object;
v := @parameter: java.util.function.BiFunction;
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: java.util.concurrent.CompletableFuture get(java.lang.Object,java.util.function.BiFunction,boolean)>(v, v, 1);
return v;
}
public java.util.concurrent.CompletableFuture get(java.lang.Object, java.util.function.BiFunction, boolean)
{
com.github.benmanes.caffeine.cache.Ticker v;
java.util.function.BiFunction v;
java.util.concurrent.CompletableFuture v, v;
long v;
java.util.function.Function v;
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
java.util.concurrent.CompletableFuture[] v;
com.github.benmanes.caffeine.cache.LocalCache v, v;
java.lang.Object v, v;
boolean v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Object;
v := @parameter: java.util.function.BiFunction;
v := @parameter: boolean;
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: com.github.benmanes.caffeine.cache.Ticker statsTicker()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.Ticker: long read()>();
v = newarray (java.util.concurrent.CompletableFuture)[1];
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache$lambda_get_2__394: java.util.function.Function bootstrap$(com.github.benmanes.caffeine.cache.LocalAsyncCache,java.util.function.BiFunction,java.lang.Object,java.util.concurrent.CompletableFuture[])>(v, v, v, v);
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.lang.Object computeIfAbsent(java.lang.Object,java.util.function.Function,boolean,boolean)>(v, v, v, 0);
v = v[0];
if v == null goto label;
v = v[0];
interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: void handleCompletion(java.lang.Object,java.util.concurrent.CompletableFuture,long,boolean)>(v, v, v, 0);
label:
return v;
}
public java.util.concurrent.CompletableFuture getAll(java.lang.Iterable, java.util.function.Function)
{
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
java.util.function.BiFunction v;
java.util.concurrent.CompletableFuture v;
java.util.function.Function v;
java.lang.Iterable v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Iterable;
v := @parameter: java.util.function.Function;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache$lambda_getAll_4__395: java.util.function.BiFunction bootstrap$(java.util.function.Function)>(v);
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: java.util.concurrent.CompletableFuture getAll(java.lang.Iterable,java.util.function.BiFunction)>(v, v);
return v;
}
public java.util.concurrent.CompletableFuture getAll(java.lang.Iterable, java.util.function.BiFunction)
{
java.util.function.BiFunction v;
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
boolean v, v, v;
java.util.Set v, v;
com.github.benmanes.caffeine.cache.LocalAsyncCache$AsyncBulkCompleter v;
com.github.benmanes.caffeine.cache.LocalCache v, v, v, v, v, v;
java.lang.Throwable v;
java.util.HashMap v;
java.util.concurrent.CompletableFuture v, v, v;
java.lang.Iterable v;
java.util.LinkedHashMap v;
int v, v, v, v, v;
com.github.benmanes.caffeine.cache.stats.StatsCounter v, v;
java.util.Iterator v;
java.util.concurrent.Executor v;
java.lang.Object v, v, v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Iterable;
v := @parameter: java.util.function.BiFunction;
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
virtualinvoke v.<java.lang.Object: java.lang.Class getClass()>();
v = staticinvoke <com.github.benmanes.caffeine.cache.Caffeine: int calculateHashMapCapacity(java.lang.Iterable)>(v);
v = new java.util.LinkedHashMap;
specialinvoke v.<java.util.LinkedHashMap: void <init>(int)>(v);
v = new java.util.HashMap;
specialinvoke v.<java.util.HashMap: void <init>(int)>(v);
v = interfaceinvoke v.<java.lang.Iterable: java.util.Iterator iterator()>();
label:
v = interfaceinvoke v.<java.util.Iterator: boolean hasNext()>();
if v == 0 goto label;
v = interfaceinvoke v.<java.util.Iterator: java.lang.Object next()>();
v = virtualinvoke v.<java.util.LinkedHashMap: boolean containsKey(java.lang.Object)>(v);
if v != 0 goto label;
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.lang.Object getIfPresent(java.lang.Object,boolean)>(v, 0);
if v != null goto label;
v = new java.util.concurrent.CompletableFuture;
specialinvoke v.<java.util.concurrent.CompletableFuture: void <init>()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.lang.Object putIfAbsent(java.lang.Object,java.lang.Object)>(v, v);
v = v;
virtualinvoke v.<java.util.HashMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
label:
virtualinvoke v.<java.util.LinkedHashMap: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
goto label;
label:
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: com.github.benmanes.caffeine.cache.stats.StatsCounter statsCounter()>();
v = virtualinvoke v.<java.util.HashMap: int size()>();
interfaceinvoke v.<com.github.benmanes.caffeine.cache.stats.StatsCounter: void recordMisses(int)>(v);
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: com.github.benmanes.caffeine.cache.stats.StatsCounter statsCounter()>();
v = virtualinvoke v.<java.util.LinkedHashMap: int size()>();
v = virtualinvoke v.<java.util.HashMap: int size()>();
v = v - v;
interfaceinvoke v.<com.github.benmanes.caffeine.cache.stats.StatsCounter: void recordHits(int)>(v);
v = virtualinvoke v.<java.util.HashMap: boolean isEmpty()>();
if v == 0 goto label;
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache: java.util.concurrent.CompletableFuture composeResult(java.util.Map)>(v);
return v;
label:
v = new com.github.benmanes.caffeine.cache.LocalAsyncCache$AsyncBulkCompleter;
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
specialinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache$AsyncBulkCompleter: void <init>(com.github.benmanes.caffeine.cache.LocalCache,java.util.Map)>(v, v);
label:
v = virtualinvoke v.<java.util.HashMap: java.util.Set keySet()>();
v = staticinvoke <java.util.Collections: java.util.Set unmodifiableSet(java.util.Set)>(v);
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.util.concurrent.Executor executor()>();
v = interfaceinvoke v.<java.util.function.BiFunction: java.lang.Object apply(java.lang.Object,java.lang.Object)>(v, v);
virtualinvoke v.<java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture whenComplete(java.util.function.BiConsumer)>(v);
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache: java.util.concurrent.CompletableFuture composeResult(java.util.Map)>(v);
label:
return v;
label:
v := @caughtexception;
virtualinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache$AsyncBulkCompleter: void accept(java.util.Map,java.lang.Throwable)>(null, v);
throw v;
catch java.lang.Throwable from label to label with label;
}
public static java.util.concurrent.CompletableFuture composeResult(java.util.Map)
{
java.lang.Object[] v;
java.util.Collection v;
java.util.concurrent.CompletableFuture v, v, v;
java.util.function.Function v;
java.util.concurrent.CompletableFuture[] v;
java.util.Map v, v, v;
boolean v;
v := @parameter: java.util.Map;
v = interfaceinvoke v.<java.util.Map: boolean isEmpty()>();
if v == 0 goto label;
v = staticinvoke <java.util.Collections: java.util.Map emptyMap()>();
v = staticinvoke <java.util.Collections: java.util.Map unmodifiableMap(java.util.Map)>(v);
v = staticinvoke <java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture completedFuture(java.lang.Object)>(v);
return v;
label:
v = interfaceinvoke v.<java.util.Map: java.util.Collection values()>();
v = newarray (java.util.concurrent.CompletableFuture)[0];
v = interfaceinvoke v.<java.util.Collection: java.lang.Object[] toArray(java.lang.Object[])>(v);
v = staticinvoke <java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture allOf(java.util.concurrent.CompletableFuture[])>(v);
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache$lambda_composeResult_6__396: java.util.function.Function bootstrap$(java.util.Map)>(v);
v = virtualinvoke v.<java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture thenApply(java.util.function.Function)>(v);
return v;
}
public void put(java.lang.Object, java.util.concurrent.CompletableFuture)
{
com.github.benmanes.caffeine.cache.stats.StatsCounter v;
com.github.benmanes.caffeine.cache.Ticker v;
java.util.concurrent.CompletableFuture v;
long v;
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
com.github.benmanes.caffeine.cache.LocalCache v, v, v, v;
java.lang.Object v, v;
boolean v, v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Object;
v := @parameter: java.util.concurrent.CompletableFuture;
v = virtualinvoke v.<java.util.concurrent.CompletableFuture: boolean isCompletedExceptionally()>();
if v != 0 goto label;
v = virtualinvoke v.<java.util.concurrent.CompletableFuture: boolean isDone()>();
if v == 0 goto label;
v = virtualinvoke v.<java.util.concurrent.CompletableFuture: java.lang.Object join()>();
if v != null goto label;
label:
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: com.github.benmanes.caffeine.cache.stats.StatsCounter statsCounter()>();
interfaceinvoke v.<com.github.benmanes.caffeine.cache.stats.StatsCounter: void recordLoadFailure(long)>(0L);
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.lang.Object remove(java.lang.Object)>(v);
return;
label:
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: com.github.benmanes.caffeine.cache.Ticker statsTicker()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.Ticker: long read()>();
v = interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: com.github.benmanes.caffeine.cache.LocalCache cache()>();
interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalCache: java.lang.Object put(java.lang.Object,java.lang.Object)>(v, v);
interfaceinvoke v.<com.github.benmanes.caffeine.cache.LocalAsyncCache: void handleCompletion(java.lang.Object,java.util.concurrent.CompletableFuture,long,boolean)>(v, v, v, 0);
return;
}
public void handleCompletion(java.lang.Object, java.util.concurrent.CompletableFuture, long, boolean)
{
com.github.benmanes.caffeine.cache.LocalAsyncCache v;
java.util.function.BiConsumer v;
java.util.concurrent.atomic.AtomicBoolean v;
java.lang.Object v;
java.util.concurrent.CompletableFuture v;
long v;
boolean v;
v := @this: com.github.benmanes.caffeine.cache.LocalAsyncCache;
v := @parameter: java.lang.Object;
v := @parameter: java.util.concurrent.CompletableFuture;
v := @parameter: long;
v := @parameter: boolean;
v = new java.util.concurrent.atomic.AtomicBoolean;
specialinvoke v.<java.util.concurrent.atomic.AtomicBoolean: void <init>()>();
v = staticinvoke <com.github.benmanes.caffeine.cache.LocalAsyncCache$lambda_handleCompletion_7__397: java.util.function.BiConsumer bootstrap$(com.github.benmanes.caffeine.cache.LocalAsyncCache,java.util.concurrent.atomic.AtomicBoolean,long,java.lang.Object,java.util.concurrent.CompletableFuture,boolean)>(v, v, v, v, v, v);
virtualinvoke v.<java.util.concurrent.CompletableFuture: java.util.concurrent.CompletableFuture whenComplete(java.util.function.BiConsumer)>(v);
return;
}
static void <clinit>()
{
java.lang.System$Logger v;
java.lang.Class v;
java.lang.String v;
v = class "Lcom/github/benmanes/caffeine/cache/LocalAsyncCache;";
v = virtualinvoke v.<java.lang.Class: java.lang.String getName()>();
v = staticinvoke <java.lang.System: java.lang.System$Logger getLogger(java.lang.String)>(v);
<com.github.benmanes.caffeine.cache.LocalAsyncCache: java.lang.System$Logger logger> = v;
return;
}
}