public final class org.ehcache.core.spi.ServiceLocator implements org.ehcache.spi.service.ServiceProvider<org.ehcache.spi.service.Service>
minor version: 0
major version: 59
flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
this_class: org.ehcache.core.spi.ServiceLocator
super_class: java.lang.Object
{
private static final org.slf4j.Logger LOGGER;
descriptor: Lorg/slf4j/Logger;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
private final org.ehcache.core.spi.ServiceLocator$ServiceMap services;
descriptor: Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.locks.ReadWriteLock runningLock;
descriptor: Ljava/util/concurrent/locks/ReadWriteLock;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
private final java.util.concurrent.atomic.AtomicBoolean running;
descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
flags: (0x0012) ACC_PRIVATE, ACC_FINAL
static void <clinit>();
descriptor: ()V
flags: (0x0008) ACC_STATIC
Code:
stack=1, locals=0, args_size=0
0: ldc Lorg/ehcache/core/spi/ServiceLocator;
invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
putstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
return
LocalVariableTable:
Start End Slot Name Signature
public static org.ehcache.core.spi.ServiceLocator$DependencySet dependencySet();
descriptor: ()Lorg/ehcache/core/spi/ServiceLocator$DependencySet;
flags: (0x0009) ACC_PUBLIC, ACC_STATIC
Code:
stack=2, locals=0, args_size=0
0: new org.ehcache.core.spi.ServiceLocator$DependencySet
dup
invokespecial org.ehcache.core.spi.ServiceLocator$DependencySet.<init>:()V
areturn
LocalVariableTable:
Start End Slot Name Signature
private void <init>(org.ehcache.core.spi.ServiceLocator$ServiceMap);
descriptor: (Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.concurrent.locks.ReentrantReadWriteLock
dup
invokespecial java.util.concurrent.locks.ReentrantReadWriteLock.<init>:()V
putfield org.ehcache.core.spi.ServiceLocator.runningLock:Ljava/util/concurrent/locks/ReadWriteLock;
2: aload 0
new java.util.concurrent.atomic.AtomicBoolean
dup
iconst_0
invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:(Z)V
putfield org.ehcache.core.spi.ServiceLocator.running:Ljava/util/concurrent/atomic/AtomicBoolean;
3: aload 0
aload 1
putfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
4: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Lorg/ehcache/core/spi/ServiceLocator;
0 5 1 services Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
MethodParameters:
Name Flags
services
public <T extends org.ehcache.spi.service.Service> T getService(java.lang.Class<T>);
descriptor: (Ljava/lang/Class;)Lorg/ehcache/spi/service/Service;
flags: (0x0001) ACC_PUBLIC
Code:
stack=5, locals=3, args_size=2
start local 0 start local 1 0: aload 1
ldc Lorg/ehcache/spi/service/PluralService;
invokevirtual java.lang.Class.isAnnotationPresent:(Ljava/lang/Class;)Z
ifeq 2
1: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
aload 1
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
ldc " is marked as a PluralService"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
2: StackMap locals:
StackMap stack:
aload 0
aload 1
invokevirtual org.ehcache.core.spi.ServiceLocator.getServicesOfType:(Ljava/lang/Class;)Ljava/util/Collection;
astore 2
start local 2 3: aload 2
invokeinterface java.util.Collection.size:()I
iconst_1
if_icmple 7
4: new java.lang.AssertionError
dup
new java.lang.StringBuilder
dup
ldc "The non-PluralService type"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
5: ldc " has more than one service registered"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
6: invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
7: StackMap locals: java.util.Collection
StackMap stack:
aload 2
invokeinterface java.util.Collection.isEmpty:()Z
ifeq 8
aconst_null
goto 9
StackMap locals:
StackMap stack:
8: aload 2
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.ehcache.spi.service.Service
StackMap locals:
StackMap stack: org.ehcache.spi.service.Service
9: areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/ehcache/core/spi/ServiceLocator;
0 10 1 serviceType Ljava/lang/Class<TT;>;
3 10 2 registeredServices Ljava/util/Collection<TT;>;
Signature: <T::Lorg/ehcache/spi/service/Service;>(Ljava/lang/Class<TT;>;)TT;
MethodParameters:
Name Flags
serviceType
public <T extends org.ehcache.spi.service.Service> java.util.Collection<T> getServicesOfType(java.lang.Class<T>);
descriptor: (Ljava/lang/Class;)Ljava/util/Collection;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
aload 1
invokevirtual org.ehcache.core.spi.ServiceLocator$ServiceMap.get:(Ljava/lang/Class;)Ljava/util/Set;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/ehcache/core/spi/ServiceLocator;
0 1 1 serviceType Ljava/lang/Class<TT;>;
Signature: <T::Lorg/ehcache/spi/service/Service;>(Ljava/lang/Class<TT;>;)Ljava/util/Collection<TT;>;
MethodParameters:
Name Flags
serviceType
public boolean knowsServiceFor(org.ehcache.spi.service.ServiceConfiguration<?>);
descriptor: (Lorg/ehcache/spi/service/ServiceConfiguration;)Z
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
aload 1
invokeinterface org.ehcache.spi.service.ServiceConfiguration.getServiceType:()Ljava/lang/Class;
invokevirtual org.ehcache.core.spi.ServiceLocator$ServiceMap.contains:(Ljava/lang/Class;)Z
ireturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lorg/ehcache/core/spi/ServiceLocator;
0 1 1 serviceConfig Lorg/ehcache/spi/service/ServiceConfiguration<*>;
Signature: (Lorg/ehcache/spi/service/ServiceConfiguration<*>;)Z
MethodParameters:
Name Flags
serviceConfig
public void startAllServices();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=11, args_size=1
start local 0 0: new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
astore 1
start local 1 1: aload 0
getfield org.ehcache.core.spi.ServiceLocator.runningLock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
astore 2
start local 2 2: aload 2
invokeinterface java.util.concurrent.locks.Lock.lock:()V
3: aload 0
getfield org.ehcache.core.spi.ServiceLocator.running:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_0
iconst_1
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifne 5
4: new java.lang.IllegalStateException
dup
ldc "Already started!"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals: java.util.Deque java.util.concurrent.locks.Lock
StackMap stack:
new java.util.LinkedList
dup
aload 0
getfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
invokevirtual org.ehcache.core.spi.ServiceLocator$ServiceMap.all:()Ljava/util/Set;
invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
astore 3
start local 3 6: aload 3
invokevirtual java.util.LinkedList.size:()I
istore 4
start local 4 7: invokestatic java.lang.System.currentTimeMillis:()J
lstore 5
start local 5 8: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Starting {} Services..."
iload 4
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
9: goto 27
10: StackMap locals: java.util.LinkedList int long
StackMap stack:
iconst_0
istore 7
start local 7 11: aload 3
invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
astore 8
start local 8 12: goto 22
13: StackMap locals: int java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.ehcache.spi.service.Service
astore 9
start local 9 14: aload 0
aload 9
aload 3
invokevirtual org.ehcache.core.spi.ServiceLocator.hasUnstartedDependencies:(Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable;)Z
ifeq 17
15: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Delaying starting {}"
aload 9
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
16: goto 22
17: StackMap locals: org.ehcache.spi.service.Service
StackMap stack:
getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Starting {}"
aload 9
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
18: aload 9
aload 0
invokeinterface org.ehcache.spi.service.Service.start:(Lorg/ehcache/spi/service/ServiceProvider;)V
19: aload 1
aload 9
invokeinterface java.util.Deque.push:(Ljava/lang/Object;)V
20: aload 8
invokeinterface java.util.Iterator.remove:()V
21: iconst_1
istore 7
end local 9 22: StackMap locals:
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 13
end local 8 23: iload 7
ifeq 26
24: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
new java.lang.StringBuilder
dup
ldc "Cycle complete: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual java.util.LinkedList.size:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc " Services remaining"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
25: goto 27
26: StackMap locals:
StackMap stack:
new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "Cyclic dependency in Service set: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 7 27: StackMap locals:
StackMap stack:
aload 3
invokevirtual java.util.LinkedList.isEmpty:()Z
ifeq 10
28: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "All Services successfully started, {} Services in {}ms"
iload 4
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokestatic java.lang.System.currentTimeMillis:()J
lload 5
lsub
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
end local 5 end local 4 end local 3 29: goto 42
StackMap locals: org.ehcache.core.spi.ServiceLocator java.util.Deque java.util.concurrent.locks.Lock
StackMap stack: java.lang.Exception
30: astore 3
start local 3 31: goto 37
32: StackMap locals: java.lang.Exception
StackMap stack:
aload 1
invokeinterface java.util.Deque.pop:()Ljava/lang/Object;
checkcast org.ehcache.spi.service.Service
astore 4
start local 4 33: aload 4
invokeinterface org.ehcache.spi.service.Service.stop:()V
34: goto 37
StackMap locals: org.ehcache.core.spi.ServiceLocator java.util.Deque java.util.concurrent.locks.Lock java.lang.Exception org.ehcache.spi.service.Service
StackMap stack: java.lang.Exception
35: astore 5
start local 5 36: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Stopping Service failed due to "
aload 5
invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 5 end local 4 37: StackMap locals:
StackMap stack:
aload 1
invokeinterface java.util.Deque.isEmpty:()Z
ifeq 32
38: aload 3
athrow
end local 3 39: StackMap locals: org.ehcache.core.spi.ServiceLocator java.util.Deque java.util.concurrent.locks.Lock
StackMap stack: java.lang.Throwable
astore 10
40: aload 2
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
41: aload 10
athrow
42: StackMap locals:
StackMap stack:
aload 2
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
43: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 44 0 this Lorg/ehcache/core/spi/ServiceLocator;
1 44 1 started Ljava/util/Deque<Lorg/ehcache/spi/service/Service;>;
2 44 2 lock Ljava/util/concurrent/locks/Lock;
6 29 3 unstarted Ljava/util/LinkedList<Lorg/ehcache/spi/service/Service;>;
7 29 4 totalServices I
8 29 5 start J
11 27 7 startedSomething Z
12 23 8 it Ljava/util/Iterator<Lorg/ehcache/spi/service/Service;>;
14 22 9 s Lorg/ehcache/spi/service/Service;
31 39 3 e Ljava/lang/Exception;
33 37 4 toBeStopped Lorg/ehcache/spi/service/Service;
36 37 5 e1 Ljava/lang/Exception;
Exception table:
from to target type
3 29 30 Class java.lang.Exception
33 34 35 Class java.lang.Exception
3 39 39 any
public void stopAllServices();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=7, locals=12, args_size=1
start local 0 0: aconst_null
astore 1
start local 1 1: aload 0
getfield org.ehcache.core.spi.ServiceLocator.runningLock:Ljava/util/concurrent/locks/ReadWriteLock;
invokeinterface java.util.concurrent.locks.ReadWriteLock.writeLock:()Ljava/util/concurrent/locks/Lock;
astore 2
start local 2 2: aload 2
invokeinterface java.util.concurrent.locks.Lock.lock:()V
3: aload 0
getfield org.ehcache.core.spi.ServiceLocator.running:Ljava/util/concurrent/atomic/AtomicBoolean;
iconst_1
iconst_0
invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
ifne 5
4: new java.lang.IllegalStateException
dup
ldc "Already stopped!"
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals: java.lang.Exception java.util.concurrent.locks.Lock
StackMap stack:
new java.util.LinkedList
dup
aload 0
getfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
invokevirtual org.ehcache.core.spi.ServiceLocator$ServiceMap.all:()Ljava/util/Set;
invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
astore 3
start local 3 6: aload 3
invokeinterface java.util.Collection.size:()I
istore 4
start local 4 7: invokestatic java.lang.System.currentTimeMillis:()J
lstore 5
start local 5 8: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Stopping {} Services..."
iload 4
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
9: goto 32
10: StackMap locals: java.util.Collection int long
StackMap stack:
iconst_0
istore 7
start local 7 11: aload 3
invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
astore 8
start local 8 12: goto 27
13: StackMap locals: int java.util.Iterator
StackMap stack:
aload 8
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.ehcache.spi.service.Service
astore 9
start local 9 14: aload 0
aload 9
aload 3
invokevirtual org.ehcache.core.spi.ServiceLocator.hasRunningDependents:(Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable;)Z
ifeq 17
15: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Delaying stopping {}"
aload 9
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
16: goto 27
17: StackMap locals: org.ehcache.spi.service.Service
StackMap stack:
getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Stopping {}"
aload 9
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
18: aload 9
invokeinterface org.ehcache.spi.service.Service.stop:()V
19: goto 25
StackMap locals:
StackMap stack: java.lang.Exception
20: astore 10
start local 10 21: aload 1
ifnonnull 24
22: aload 10
astore 1
23: goto 25
24: StackMap locals: java.lang.Exception
StackMap stack:
getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "Stopping Service failed due to "
aload 10
invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
end local 10 25: StackMap locals:
StackMap stack:
aload 8
invokeinterface java.util.Iterator.remove:()V
26: iconst_1
istore 7
end local 9 27: StackMap locals:
StackMap stack:
aload 8
invokeinterface java.util.Iterator.hasNext:()Z
ifne 13
end local 8 28: iload 7
ifeq 31
29: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
new java.lang.StringBuilder
dup
ldc "Cycle complete: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
invokeinterface java.util.Collection.size:()I
invokevirtual java.lang.StringBuilder.append:(I)Ljava/lang/StringBuilder;
ldc " Services remaining"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;)V
30: goto 32
31: StackMap locals:
StackMap stack:
new java.lang.AssertionError
dup
new java.lang.StringBuilder
dup
ldc "Cyclic dependency in Service set: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 3
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
athrow
end local 7 32: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Collection.isEmpty:()Z
ifeq 10
33: getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
ldc "All Services successfully stopped, {} Services in {}ms"
iload 4
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokestatic java.lang.System.currentTimeMillis:()J
lload 5
lsub
invokestatic java.lang.Long.valueOf:(J)Ljava/lang/Long;
invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
end local 5 end local 4 end local 3 34: goto 38
StackMap locals: org.ehcache.core.spi.ServiceLocator java.lang.Exception java.util.concurrent.locks.Lock
StackMap stack: java.lang.Throwable
35: astore 11
36: aload 2
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
37: aload 11
athrow
38: StackMap locals:
StackMap stack:
aload 2
invokeinterface java.util.concurrent.locks.Lock.unlock:()V
39: aload 1
ifnull 41
40: aload 1
athrow
41: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 42 0 this Lorg/ehcache/core/spi/ServiceLocator;
1 42 1 firstException Ljava/lang/Exception;
2 42 2 lock Ljava/util/concurrent/locks/Lock;
6 34 3 running Ljava/util/Collection<Lorg/ehcache/spi/service/Service;>;
7 34 4 totalServices I
8 34 5 start J
11 32 7 stoppedSomething Z
12 28 8 it Ljava/util/Iterator<Lorg/ehcache/spi/service/Service;>;
14 27 9 s Lorg/ehcache/spi/service/Service;
21 25 10 e Ljava/lang/Exception;
Exception table:
from to target type
18 19 20 Class java.lang.Exception
3 35 35 any
Exceptions:
throws java.lang.Exception
private boolean hasUnstartedDependencies(org.ehcache.spi.service.Service, java.lang.Iterable<org.ehcache.spi.service.Service>);
descriptor: (Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=7, args_size=3
start local 0 start local 1 start local 2 0: aload 1
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokestatic org.ehcache.core.spi.ServiceLocator.identifyTransitiveDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
goto 7
StackMap locals: org.ehcache.core.spi.ServiceLocator org.ehcache.spi.service.Service java.lang.Iterable top java.util.Iterator
StackMap stack:
1: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Class
astore 3
start local 3 2: aload 2
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
astore 6
goto 6
StackMap locals: org.ehcache.core.spi.ServiceLocator org.ehcache.spi.service.Service java.lang.Iterable java.lang.Class java.util.Iterator top java.util.Iterator
StackMap stack:
3: aload 6
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.ehcache.spi.service.Service
astore 5
start local 5 4: aload 3
aload 5
invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
ifeq 6
5: iconst_1
ireturn
end local 5 6: StackMap locals:
StackMap stack:
aload 6
invokeinterface java.util.Iterator.hasNext:()Z
ifne 3
end local 3 7: StackMap locals: org.ehcache.core.spi.ServiceLocator org.ehcache.spi.service.Service java.lang.Iterable top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
8: iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Lorg/ehcache/core/spi/ServiceLocator;
0 9 1 service Lorg/ehcache/spi/service/Service;
0 9 2 unstarted Ljava/lang/Iterable<Lorg/ehcache/spi/service/Service;>;
2 7 3 dep Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
4 6 5 s Lorg/ehcache/spi/service/Service;
Signature: (Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable<Lorg/ehcache/spi/service/Service;>;)Z
MethodParameters:
Name Flags
service
unstarted
private boolean hasRunningDependents(org.ehcache.spi.service.Service, java.lang.Iterable<org.ehcache.spi.service.Service>);
descriptor: (Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable;)Z
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=8, args_size=3
start local 0 start local 1 start local 2 0: aload 2
invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
astore 4
goto 8
StackMap locals: org.ehcache.core.spi.ServiceLocator org.ehcache.spi.service.Service java.lang.Iterable top java.util.Iterator
StackMap stack:
1: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast org.ehcache.spi.service.Service
astore 3
start local 3 2: aload 3
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
invokestatic org.ehcache.core.spi.ServiceLocator.identifyTransitiveDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
astore 5
start local 5 3: aload 5
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 7
goto 7
StackMap locals: org.ehcache.core.spi.ServiceLocator org.ehcache.spi.service.Service java.lang.Iterable org.ehcache.spi.service.Service java.util.Iterator java.util.Set top java.util.Iterator
StackMap stack:
4: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Class
astore 6
start local 6 5: aload 6
aload 1
invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
ifeq 7
6: iconst_1
ireturn
end local 6 7: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 4
end local 5 end local 3 8: StackMap locals: org.ehcache.core.spi.ServiceLocator org.ehcache.spi.service.Service java.lang.Iterable top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
9: iconst_0
ireturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 10 0 this Lorg/ehcache/core/spi/ServiceLocator;
0 10 1 service Lorg/ehcache/spi/service/Service;
0 10 2 running Ljava/lang/Iterable<Lorg/ehcache/spi/service/Service;>;
2 8 3 runningService Lorg/ehcache/spi/service/Service;
3 8 5 dependencyClasses Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
5 7 6 dependencyClass Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
Signature: (Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable<Lorg/ehcache/spi/service/Service;>;)Z
MethodParameters:
Name Flags
service
running
private static java.util.Collection<java.lang.Class<?>> getAllInterfaces(java.lang.Class<?>);
descriptor: (Ljava/lang/Class;)Ljava/util/Collection;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=2, locals=7, args_size=1
start local 0 0: new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
astore 1
start local 1 1: aload 0
astore 2
start local 2 2: goto 10
3: StackMap locals: java.util.ArrayList java.lang.Class
StackMap stack:
aload 2
invokevirtual java.lang.Class.getInterfaces:()[Ljava/lang/Class;
dup
astore 6
arraylength
istore 5
iconst_0
istore 4
goto 8
StackMap locals: java.lang.Class java.util.ArrayList java.lang.Class top int int java.lang.Class[]
StackMap stack:
4: aload 6
iload 4
aaload
astore 3
start local 3 5: aload 1
aload 3
invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
pop
6: aload 1
aload 3
invokestatic org.ehcache.core.spi.ServiceLocator.getAllInterfaces:(Ljava/lang/Class;)Ljava/util/Collection;
invokevirtual java.util.ArrayList.addAll:(Ljava/util/Collection;)Z
pop
end local 3 7: iinc 4 1
StackMap locals:
StackMap stack:
8: iload 4
iload 5
if_icmplt 4
9: aload 2
invokevirtual java.lang.Class.getSuperclass:()Ljava/lang/Class;
astore 2
StackMap locals: java.lang.Class java.util.ArrayList java.lang.Class
StackMap stack:
10: aload 2
ifnonnull 3
end local 2 11: aload 1
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 clazz Ljava/lang/Class<*>;
1 12 1 interfaces Ljava/util/ArrayList<Ljava/lang/Class<*>;>;
2 11 2 c Ljava/lang/Class<*>;
5 7 3 i Ljava/lang/Class<*>;
Signature: (Ljava/lang/Class<*>;)Ljava/util/Collection<Ljava/lang/Class<*>;>;
MethodParameters:
Name Flags
clazz final
private static java.util.Set<java.lang.Class<? extends org.ehcache.spi.service.Service>> identifyImmediateDependenciesOf(java.lang.Class<?>);
descriptor: (Ljava/lang/Class;)Ljava/util/Set;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=10, args_size=1
start local 0 0: aload 0
ifnonnull 2
1: invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
areturn
2: StackMap locals:
StackMap stack:
new java.util.HashSet
dup
invokespecial java.util.HashSet.<init>:()V
astore 1
start local 1 3: aload 0
ldc Lorg/ehcache/spi/service/ServiceDependencies;
invokevirtual java.lang.Class.getAnnotation:(Ljava/lang/Class;)Ljava/lang/annotation/Annotation;
checkcast org.ehcache.spi.service.ServiceDependencies
astore 2
start local 2 4: aload 2
ifnull 16
5: aload 2
invokeinterface org.ehcache.spi.service.ServiceDependencies.value:()[Ljava/lang/Class;
dup
astore 6
arraylength
istore 5
iconst_0
istore 4
goto 15
StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies top int int java.lang.Class[]
StackMap stack:
6: aload 6
iload 4
aaload
astore 3
start local 3 7: ldc Lorg/ehcache/spi/service/Service;
aload 3
invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
ifeq 11
8: aload 3
astore 7
start local 7 9: aload 1
aload 7
invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
pop
end local 7 10: goto 14
11: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies java.lang.Class int int java.lang.Class[]
StackMap stack:
new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "Service dependency declared by "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
12: ldc " is not a Service: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 3
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
13: invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 3 14: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies top int int java.lang.Class[]
StackMap stack:
iinc 4 1
StackMap locals:
StackMap stack:
15: iload 4
iload 5
if_icmplt 6
16: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies
StackMap stack:
aload 0
ldc Lorg/ehcache/spi/service/OptionalServiceDependencies;
invokevirtual java.lang.Class.getAnnotation:(Ljava/lang/Class;)Ljava/lang/annotation/Annotation;
checkcast org.ehcache.spi.service.OptionalServiceDependencies
astore 3
start local 3 17: aload 3
ifnull 29
18: aload 3
invokeinterface org.ehcache.spi.service.OptionalServiceDependencies.value:()[Ljava/lang/String;
dup
astore 7
arraylength
istore 6
iconst_0
istore 5
goto 28
StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies top int int java.lang.String[]
StackMap stack:
19: aload 7
iload 5
aaload
astore 4
start local 4 20: iconst_2
anewarray java.lang.ClassLoader
dup
iconst_0
invokestatic org.ehcache.core.util.ClassLoading.getDefaultClassLoader:()Ljava/lang/ClassLoader;
aastore
dup
iconst_1
aload 0
invokevirtual java.lang.Class.getClassLoader:()Ljava/lang/ClassLoader;
aastore
invokestatic org.ehcache.core.util.ClassLoading.delegationChain:([Ljava/lang/ClassLoader;)Ljava/lang/ClassLoader;
aload 4
invokevirtual java.lang.ClassLoader.loadClass:(Ljava/lang/String;)Ljava/lang/Class;
astore 8
start local 8 21: ldc Lorg/ehcache/spi/service/Service;
aload 8
invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
ifeq 25
22: aload 8
astore 9
start local 9 23: aload 1
aload 9
invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
pop
end local 9 24: goto 27
25: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies java.lang.String int int java.lang.String[] java.lang.Class
StackMap stack:
new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "Service dependency declared by "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 4
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " is not a Service: "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 8
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 8 26: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies java.lang.String int int java.lang.String[]
StackMap stack: java.lang.ClassNotFoundException
pop
end local 4 27: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies top int int java.lang.String[]
StackMap stack:
iinc 5 1
StackMap locals:
StackMap stack:
28: iload 5
iload 6
if_icmplt 19
29: StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies
StackMap stack:
aload 0
invokevirtual java.lang.Class.getInterfaces:()[Ljava/lang/Class;
dup
astore 7
arraylength
istore 6
iconst_0
istore 5
goto 34
StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies top int int java.lang.Class[]
StackMap stack:
30: aload 7
iload 5
aaload
astore 4
start local 4 31: ldc Lorg/ehcache/spi/service/Service;
aload 4
invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
ifeq 33
32: aload 1
ldc Lorg/ehcache/spi/service/Service;
invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
aload 4
invokevirtual java.lang.Class.cast:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.lang.Class
invokestatic org.ehcache.core.spi.ServiceLocator.identifyImmediateDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
pop
end local 4 33: StackMap locals:
StackMap stack:
iinc 5 1
StackMap locals:
StackMap stack:
34: iload 5
iload 6
if_icmplt 30
35: aload 1
aload 0
invokevirtual java.lang.Class.getSuperclass:()Ljava/lang/Class;
invokestatic org.ehcache.core.spi.ServiceLocator.identifyImmediateDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
pop
36: aload 1
areturn
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 37 0 clazz Ljava/lang/Class<*>;
3 37 1 dependencies Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
4 37 2 annotation Lorg/ehcache/spi/service/ServiceDependencies;
7 14 3 dependency Ljava/lang/Class<*>;
9 10 7 serviceDependency Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
17 37 3 optionalAnnotation Lorg/ehcache/spi/service/OptionalServiceDependencies;
20 27 4 className Ljava/lang/String;
21 26 8 dependencyClass Ljava/lang/Class<*>;
23 24 9 serviceDependency Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
31 33 4 interfaceClazz Ljava/lang/Class<*>;
Exception table:
from to target type
20 26 26 Class java.lang.ClassNotFoundException
Signature: (Ljava/lang/Class<*>;)Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
MethodParameters:
Name Flags
clazz final
private static java.util.Set<java.lang.Class<? extends org.ehcache.spi.service.Service>> identifyTransitiveDependenciesOf(java.lang.Class<?>);
descriptor: (Ljava/lang/Class;)Ljava/util/Set;
flags: (0x000a) ACC_PRIVATE, ACC_STATIC
Code:
stack=5, locals=8, args_size=1
start local 0 0: aload 0
invokestatic org.ehcache.core.spi.ServiceLocator.identifyImmediateDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
astore 1
start local 1 1: aload 1
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 3
goto 5
StackMap locals: java.lang.Class java.util.Set top java.util.Iterator
StackMap stack:
2: aload 3
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Class
astore 2
start local 2 3: aload 2
aload 0
if_acmpne 5
4: new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "Circular dependency found. Service "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " cannot depend on itself."
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 2 5: StackMap locals:
StackMap stack:
aload 3
invokeinterface java.util.Iterator.hasNext:()Z
ifne 2
6: new java.util.HashSet
dup
aload 1
invokeinterface java.util.Set.size:()I
iconst_3
imul
invokespecial java.util.HashSet.<init>:(I)V
astore 2
start local 2 7: aload 2
aload 1
invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
pop
8: aload 1
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 4
goto 17
StackMap locals: java.lang.Class java.util.Set java.util.Set top java.util.Iterator
StackMap stack:
9: aload 4
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Class
astore 3
start local 3 10: aload 3
invokestatic org.ehcache.core.spi.ServiceLocator.identifyTransitiveDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
astore 5
start local 5 11: aload 5
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
astore 7
goto 15
StackMap locals: java.lang.Class java.util.Set java.util.Set java.lang.Class java.util.Iterator java.util.Set top java.util.Iterator
StackMap stack:
12: aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.lang.Class
astore 6
start local 6 13: aload 6
aload 0
if_acmpne 15
14: new java.lang.IllegalStateException
dup
new java.lang.StringBuilder
dup
ldc "Circular dependency found. A dependency of service "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 0
invokevirtual java.lang.Class.getName:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc " depends on it."
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
athrow
end local 6 15: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 12
16: aload 2
aload 5
invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
pop
end local 5 end local 3 17: StackMap locals: java.lang.Class java.util.Set java.util.Set top java.util.Iterator
StackMap stack:
aload 4
invokeinterface java.util.Iterator.hasNext:()Z
ifne 9
18: aload 2
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 clazz Ljava/lang/Class<*>;
1 19 1 dependencies Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
3 5 2 dependencyClass Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
7 19 2 transitive Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
10 17 3 klazz Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
11 17 5 identified Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
13 15 6 dep Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;
Signature: (Ljava/lang/Class<*>;)Ljava/util/Set<Ljava/lang/Class<+Lorg/ehcache/spi/service/Service;>;>;
MethodParameters:
Name Flags
clazz final
}
Signature: Ljava/lang/Object;Lorg/ehcache/spi/service/ServiceProvider<Lorg/ehcache/spi/service/Service;>;
SourceFile: "ServiceLocator.java"
NestMembers:
org.ehcache.core.spi.ServiceLocator$DependencyException org.ehcache.core.spi.ServiceLocator$DependencySet org.ehcache.core.spi.ServiceLocator$ServiceMap
InnerClasses:
private DependencyException = org.ehcache.core.spi.ServiceLocator$DependencyException of org.ehcache.core.spi.ServiceLocator
public DependencySet = org.ehcache.core.spi.ServiceLocator$DependencySet of org.ehcache.core.spi.ServiceLocator
private ServiceMap = org.ehcache.core.spi.ServiceLocator$ServiceMap of org.ehcache.core.spi.ServiceLocator