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: .line 67
            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: .line 75
            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 // org.ehcache.core.spi.ServiceLocator this
        start local 1 // org.ehcache.core.spi.ServiceLocator$ServiceMap services
         0: .line 78
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            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: .line 72
            aload 0 /* this */
            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: .line 79
            aload 0 /* this */
            aload 1 /* services */
            putfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
         4: .line 80
            return
        end local 1 // org.ehcache.core.spi.ServiceLocator$ServiceMap services
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
        start local 1 // java.lang.Class serviceType
         0: .line 84
            aload 1 /* serviceType */
            ldc Lorg/ehcache/spi/service/PluralService;
            invokevirtual java.lang.Class.isAnnotationPresent:(Ljava/lang/Class;)Z
            ifeq 2
         1: .line 85
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            aload 1 /* serviceType */
            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: .line 87
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* serviceType */
            invokevirtual org.ehcache.core.spi.ServiceLocator.getServicesOfType:(Ljava/lang/Class;)Ljava/util/Collection;
            astore 2 /* registeredServices */
        start local 2 // java.util.Collection registeredServices
         3: .line 88
            aload 2 /* registeredServices */
            invokeinterface java.util.Collection.size:()I
            iconst_1
            if_icmple 7
         4: .line 89
            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 /* serviceType */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
         5: .line 90
            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: .line 89
            invokespecial java.lang.AssertionError.<init>:(Ljava/lang/Object;)V
            athrow
         7: .line 92
      StackMap locals: java.util.Collection
      StackMap stack:
            aload 2 /* registeredServices */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 8
            aconst_null
            goto 9
      StackMap locals:
      StackMap stack:
         8: aload 2 /* registeredServices */
            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 // java.util.Collection registeredServices
        end local 1 // java.lang.Class serviceType
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
        start local 1 // java.lang.Class serviceType
         0: .line 97
            aload 0 /* this */
            getfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
            aload 1 /* serviceType */
            invokevirtual org.ehcache.core.spi.ServiceLocator$ServiceMap.get:(Ljava/lang/Class;)Ljava/util/Set;
            areturn
        end local 1 // java.lang.Class serviceType
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
        start local 1 // org.ehcache.spi.service.ServiceConfiguration serviceConfig
         0: .line 101
            aload 0 /* this */
            getfield org.ehcache.core.spi.ServiceLocator.services:Lorg/ehcache/core/spi/ServiceLocator$ServiceMap;
            aload 1 /* serviceConfig */
            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 // org.ehcache.spi.service.ServiceConfiguration serviceConfig
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
         0: .line 105
            new java.util.LinkedList
            dup
            invokespecial java.util.LinkedList.<init>:()V
            astore 1 /* started */
        start local 1 // java.util.Deque started
         1: .line 106
            aload 0 /* this */
            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 /* lock */
        start local 2 // java.util.concurrent.locks.Lock lock
         2: .line 107
            aload 2 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 109
            aload 0 /* this */
            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: .line 110
            new java.lang.IllegalStateException
            dup
            ldc "Already started!"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 116
      StackMap locals: java.util.Deque java.util.concurrent.locks.Lock
      StackMap stack:
            new java.util.LinkedList
            dup
            aload 0 /* this */
            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 /* unstarted */
        start local 3 // java.util.LinkedList unstarted
         6: .line 117
            aload 3 /* unstarted */
            invokevirtual java.util.LinkedList.size:()I
            istore 4 /* totalServices */
        start local 4 // int totalServices
         7: .line 118
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 5 /* start */
        start local 5 // long start
         8: .line 119
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Starting {} Services..."
            iload 4 /* totalServices */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         9: .line 120
            goto 27
        10: .line 121
      StackMap locals: java.util.LinkedList int long
      StackMap stack:
            iconst_0
            istore 7 /* startedSomething */
        start local 7 // boolean startedSomething
        11: .line 122
            aload 3 /* unstarted */
            invokevirtual java.util.LinkedList.iterator:()Ljava/util/Iterator;
            astore 8 /* it */
        start local 8 // java.util.Iterator it
        12: goto 22
        13: .line 123
      StackMap locals: int java.util.Iterator
      StackMap stack:
            aload 8 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.ehcache.spi.service.Service
            astore 9 /* s */
        start local 9 // org.ehcache.spi.service.Service s
        14: .line 124
            aload 0 /* this */
            aload 9 /* s */
            aload 3 /* unstarted */
            invokevirtual org.ehcache.core.spi.ServiceLocator.hasUnstartedDependencies:(Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable;)Z
            ifeq 17
        15: .line 125
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Delaying starting {}"
            aload 9 /* s */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
        16: .line 126
            goto 22
        17: .line 127
      StackMap locals: org.ehcache.spi.service.Service
      StackMap stack:
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Starting {}"
            aload 9 /* s */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
        18: .line 128
            aload 9 /* s */
            aload 0 /* this */
            invokeinterface org.ehcache.spi.service.Service.start:(Lorg/ehcache/spi/service/ServiceProvider;)V
        19: .line 129
            aload 1 /* started */
            aload 9 /* s */
            invokeinterface java.util.Deque.push:(Ljava/lang/Object;)V
        20: .line 130
            aload 8 /* it */
            invokeinterface java.util.Iterator.remove:()V
        21: .line 131
            iconst_1
            istore 7 /* startedSomething */
        end local 9 // org.ehcache.spi.service.Service s
        22: .line 122
      StackMap locals:
      StackMap stack:
            aload 8 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        end local 8 // java.util.Iterator it
        23: .line 134
            iload 7 /* startedSomething */
            ifeq 26
        24: .line 135
            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 /* unstarted */
            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: .line 136
            goto 27
        26: .line 137
      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 /* unstarted */
            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 // boolean startedSomething
        27: .line 120
      StackMap locals:
      StackMap stack:
            aload 3 /* unstarted */
            invokevirtual java.util.LinkedList.isEmpty:()Z
            ifeq 10
        28: .line 140
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "All Services successfully started, {} Services in {}ms"
            iload 4 /* totalServices */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 5 /* start */
            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 // long start
        end local 4 // int totalServices
        end local 3 // java.util.LinkedList unstarted
        29: .line 141
            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 /* e */
        start local 3 // java.lang.Exception e
        31: .line 142
            goto 37
        32: .line 143
      StackMap locals: java.lang.Exception
      StackMap stack:
            aload 1 /* started */
            invokeinterface java.util.Deque.pop:()Ljava/lang/Object;
            checkcast org.ehcache.spi.service.Service
            astore 4 /* toBeStopped */
        start local 4 // org.ehcache.spi.service.Service toBeStopped
        33: .line 145
            aload 4 /* toBeStopped */
            invokeinterface org.ehcache.spi.service.Service.stop:()V
        34: .line 146
            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 /* e1 */
        start local 5 // java.lang.Exception e1
        36: .line 147
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Stopping Service failed due to "
            aload 5 /* e1 */
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 5 // java.lang.Exception e1
        end local 4 // org.ehcache.spi.service.Service toBeStopped
        37: .line 142
      StackMap locals:
      StackMap stack:
            aload 1 /* started */
            invokeinterface java.util.Deque.isEmpty:()Z
            ifeq 32
        38: .line 150
            aload 3 /* e */
            athrow
        end local 3 // java.lang.Exception e
        39: .line 151
      StackMap locals: org.ehcache.core.spi.ServiceLocator java.util.Deque java.util.concurrent.locks.Lock
      StackMap stack: java.lang.Throwable
            astore 10
        40: .line 152
            aload 2 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        41: .line 153
            aload 10
            athrow
        42: .line 152
      StackMap locals:
      StackMap stack:
            aload 2 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        43: .line 154
            return
        end local 2 // java.util.concurrent.locks.Lock lock
        end local 1 // java.util.Deque started
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
         0: .line 157
            aconst_null
            astore 1 /* firstException */
        start local 1 // java.lang.Exception firstException
         1: .line 158
            aload 0 /* this */
            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 /* lock */
        start local 2 // java.util.concurrent.locks.Lock lock
         2: .line 159
            aload 2 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.lock:()V
         3: .line 161
            aload 0 /* this */
            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: .line 162
            new java.lang.IllegalStateException
            dup
            ldc "Already stopped!"
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
         5: .line 168
      StackMap locals: java.lang.Exception java.util.concurrent.locks.Lock
      StackMap stack:
            new java.util.LinkedList
            dup
            aload 0 /* this */
            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 /* running */
        start local 3 // java.util.Collection running
         6: .line 169
            aload 3 /* running */
            invokeinterface java.util.Collection.size:()I
            istore 4 /* totalServices */
        start local 4 // int totalServices
         7: .line 170
            invokestatic java.lang.System.currentTimeMillis:()J
            lstore 5 /* start */
        start local 5 // long start
         8: .line 171
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Stopping {} Services..."
            iload 4 /* totalServices */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         9: .line 172
            goto 32
        10: .line 173
      StackMap locals: java.util.Collection int long
      StackMap stack:
            iconst_0
            istore 7 /* stoppedSomething */
        start local 7 // boolean stoppedSomething
        11: .line 174
            aload 3 /* running */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 8 /* it */
        start local 8 // java.util.Iterator it
        12: goto 27
        13: .line 175
      StackMap locals: int java.util.Iterator
      StackMap stack:
            aload 8 /* it */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.ehcache.spi.service.Service
            astore 9 /* s */
        start local 9 // org.ehcache.spi.service.Service s
        14: .line 176
            aload 0 /* this */
            aload 9 /* s */
            aload 3 /* running */
            invokevirtual org.ehcache.core.spi.ServiceLocator.hasRunningDependents:(Lorg/ehcache/spi/service/Service;Ljava/lang/Iterable;)Z
            ifeq 17
        15: .line 177
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Delaying stopping {}"
            aload 9 /* s */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
        16: .line 178
            goto 27
        17: .line 179
      StackMap locals: org.ehcache.spi.service.Service
      StackMap stack:
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "Stopping {}"
            aload 9 /* s */
            invokeinterface org.slf4j.Logger.trace:(Ljava/lang/String;Ljava/lang/Object;)V
        18: .line 181
            aload 9 /* s */
            invokeinterface org.ehcache.spi.service.Service.stop:()V
        19: .line 182
            goto 25
      StackMap locals:
      StackMap stack: java.lang.Exception
        20: astore 10 /* e */
        start local 10 // java.lang.Exception e
        21: .line 183
            aload 1 /* firstException */
            ifnonnull 24
        22: .line 184
            aload 10 /* e */
            astore 1 /* firstException */
        23: .line 185
            goto 25
        24: .line 186
      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 /* e */
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Throwable;)V
        end local 10 // java.lang.Exception e
        25: .line 189
      StackMap locals:
      StackMap stack:
            aload 8 /* it */
            invokeinterface java.util.Iterator.remove:()V
        26: .line 190
            iconst_1
            istore 7 /* stoppedSomething */
        end local 9 // org.ehcache.spi.service.Service s
        27: .line 174
      StackMap locals:
      StackMap stack:
            aload 8 /* it */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 13
        end local 8 // java.util.Iterator it
        28: .line 193
            iload 7 /* stoppedSomething */
            ifeq 31
        29: .line 194
            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 /* running */
            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: .line 195
            goto 32
        31: .line 196
      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 /* running */
            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 // boolean stoppedSomething
        32: .line 172
      StackMap locals:
      StackMap stack:
            aload 3 /* running */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 10
        33: .line 199
            getstatic org.ehcache.core.spi.ServiceLocator.LOGGER:Lorg/slf4j/Logger;
            ldc "All Services successfully stopped, {} Services in {}ms"
            iload 4 /* totalServices */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokestatic java.lang.System.currentTimeMillis:()J
            lload 5 /* start */
            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 // long start
        end local 4 // int totalServices
        end local 3 // java.util.Collection running
        34: .line 200
            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: .line 201
            aload 2 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        37: .line 202
            aload 11
            athrow
        38: .line 201
      StackMap locals:
      StackMap stack:
            aload 2 /* lock */
            invokeinterface java.util.concurrent.locks.Lock.unlock:()V
        39: .line 203
            aload 1 /* firstException */
            ifnull 41
        40: .line 204
            aload 1 /* firstException */
            athrow
        41: .line 206
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.concurrent.locks.Lock lock
        end local 1 // java.lang.Exception firstException
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
        start local 1 // org.ehcache.spi.service.Service service
        start local 2 // java.lang.Iterable unstarted
         0: .line 209
            aload 1 /* service */
            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 /* dep */
        start local 3 // java.lang.Class dep
         2: .line 210
            aload 2 /* unstarted */
            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 /* s */
        start local 5 // org.ehcache.spi.service.Service s
         4: .line 211
            aload 3 /* dep */
            aload 5 /* s */
            invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
            ifeq 6
         5: .line 212
            iconst_1
            ireturn
        end local 5 // org.ehcache.spi.service.Service s
         6: .line 210
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        end local 3 // java.lang.Class dep
         7: .line 209
      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: .line 216
            iconst_0
            ireturn
        end local 2 // java.lang.Iterable unstarted
        end local 1 // org.ehcache.spi.service.Service service
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // org.ehcache.core.spi.ServiceLocator this
        start local 1 // org.ehcache.spi.service.Service service
        start local 2 // java.lang.Iterable running
         0: .line 220
            aload 2 /* running */
            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 /* runningService */
        start local 3 // org.ehcache.spi.service.Service runningService
         2: .line 221
            aload 3 /* runningService */
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            invokestatic org.ehcache.core.spi.ServiceLocator.identifyTransitiveDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
            astore 5 /* dependencyClasses */
        start local 5 // java.util.Set dependencyClasses
         3: .line 222
            aload 5 /* dependencyClasses */
            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 /* dependencyClass */
        start local 6 // java.lang.Class dependencyClass
         5: .line 223
            aload 6 /* dependencyClass */
            aload 1 /* service */
            invokevirtual java.lang.Class.isInstance:(Ljava/lang/Object;)Z
            ifeq 7
         6: .line 224
            iconst_1
            ireturn
        end local 6 // java.lang.Class dependencyClass
         7: .line 222
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        end local 5 // java.util.Set dependencyClasses
        end local 3 // org.ehcache.spi.service.Service runningService
         8: .line 220
      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: .line 228
            iconst_0
            ireturn
        end local 2 // java.lang.Iterable running
        end local 1 // org.ehcache.spi.service.Service service
        end local 0 // org.ehcache.core.spi.ServiceLocator this
      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 // java.lang.Class clazz
         0: .line 438
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* interfaces */
        start local 1 // java.util.ArrayList interfaces
         1: .line 439
            aload 0 /* clazz */
            astore 2 /* c */
        start local 2 // java.lang.Class c
         2: goto 10
         3: .line 440
      StackMap locals: java.util.ArrayList java.lang.Class
      StackMap stack:
            aload 2 /* c */
            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 /* i */
        start local 3 // java.lang.Class i
         5: .line 441
            aload 1 /* interfaces */
            aload 3 /* i */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
         6: .line 442
            aload 1 /* interfaces */
            aload 3 /* i */
            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 // java.lang.Class i
         7: .line 440
            iinc 4 1
      StackMap locals:
      StackMap stack:
         8: iload 4
            iload 5
            if_icmplt 4
         9: .line 439
            aload 2 /* c */
            invokevirtual java.lang.Class.getSuperclass:()Ljava/lang/Class;
            astore 2 /* c */
      StackMap locals: java.lang.Class java.util.ArrayList java.lang.Class
      StackMap stack:
        10: aload 2 /* c */
            ifnonnull 3
        end local 2 // java.lang.Class c
        11: .line 445
            aload 1 /* interfaces */
            areturn
        end local 1 // java.util.ArrayList interfaces
        end local 0 // java.lang.Class clazz
      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 // java.lang.Class clazz
         0: .line 449
            aload 0 /* clazz */
            ifnonnull 2
         1: .line 450
            invokestatic java.util.Collections.emptySet:()Ljava/util/Set;
            areturn
         2: .line 453
      StackMap locals:
      StackMap stack:
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 1 /* dependencies */
        start local 1 // java.util.Set dependencies
         3: .line 454
            aload 0 /* clazz */
            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 /* annotation */
        start local 2 // org.ehcache.spi.service.ServiceDependencies annotation
         4: .line 455
            aload 2 /* annotation */
            ifnull 16
         5: .line 456
            aload 2 /* annotation */
            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 /* dependency */
        start local 3 // java.lang.Class dependency
         7: .line 457
            ldc Lorg/ehcache/spi/service/Service;
            aload 3 /* dependency */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 11
         8: .line 459
            aload 3 /* dependency */
            astore 7 /* serviceDependency */
        start local 7 // java.lang.Class serviceDependency
         9: .line 460
            aload 1 /* dependencies */
            aload 7 /* serviceDependency */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // java.lang.Class serviceDependency
        10: .line 461
            goto 14
        11: .line 462
      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 /* clazz */
            invokevirtual java.lang.Class.getName:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
        12: .line 463
            ldc " is not a Service: "
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            aload 3 /* dependency */
            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: .line 462
            invokespecial java.lang.IllegalStateException.<init>:(Ljava/lang/String;)V
            athrow
        end local 3 // java.lang.Class dependency
        14: .line 456
      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: .line 467
      StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies
      StackMap stack:
            aload 0 /* clazz */
            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 /* optionalAnnotation */
        start local 3 // org.ehcache.spi.service.OptionalServiceDependencies optionalAnnotation
        17: .line 468
            aload 3 /* optionalAnnotation */
            ifnull 29
        18: .line 469
            aload 3 /* optionalAnnotation */
            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 /* className */
        start local 4 // java.lang.String className
        20: .line 471
            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 /* clazz */
            invokevirtual java.lang.Class.getClassLoader:()Ljava/lang/ClassLoader;
            aastore
            invokestatic org.ehcache.core.util.ClassLoading.delegationChain:([Ljava/lang/ClassLoader;)Ljava/lang/ClassLoader;
            aload 4 /* className */
            invokevirtual java.lang.ClassLoader.loadClass:(Ljava/lang/String;)Ljava/lang/Class;
            astore 8 /* dependencyClass */
        start local 8 // java.lang.Class dependencyClass
        21: .line 472
            ldc Lorg/ehcache/spi/service/Service;
            aload 8 /* dependencyClass */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 25
        22: .line 474
            aload 8 /* dependencyClass */
            astore 9 /* serviceDependency */
        start local 9 // java.lang.Class serviceDependency
        23: .line 475
            aload 1 /* dependencies */
            aload 9 /* serviceDependency */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 9 // java.lang.Class serviceDependency
        24: .line 476
            goto 27
        25: .line 477
      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 /* className */
            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 /* dependencyClass */
            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 // java.lang.Class dependencyClass
        26: .line 479
      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 // java.lang.String className
        27: .line 469
      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: .line 485
      StackMap locals: java.lang.Class java.util.Set org.ehcache.spi.service.ServiceDependencies org.ehcache.spi.service.OptionalServiceDependencies
      StackMap stack:
            aload 0 /* clazz */
            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 /* interfaceClazz */
        start local 4 // java.lang.Class interfaceClazz
        31: .line 486
            ldc Lorg/ehcache/spi/service/Service;
            aload 4 /* interfaceClazz */
            invokevirtual java.lang.Class.isAssignableFrom:(Ljava/lang/Class;)Z
            ifeq 33
        32: .line 487
            aload 1 /* dependencies */
            ldc Lorg/ehcache/spi/service/Service;
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            aload 4 /* interfaceClazz */
            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 // java.lang.Class interfaceClazz
        33: .line 485
      StackMap locals:
      StackMap stack:
            iinc 5 1
      StackMap locals:
      StackMap stack:
        34: iload 5
            iload 6
            if_icmplt 30
        35: .line 491
            aload 1 /* dependencies */
            aload 0 /* clazz */
            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: .line 493
            aload 1 /* dependencies */
            areturn
        end local 3 // org.ehcache.spi.service.OptionalServiceDependencies optionalAnnotation
        end local 2 // org.ehcache.spi.service.ServiceDependencies annotation
        end local 1 // java.util.Set dependencies
        end local 0 // java.lang.Class clazz
      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 // java.lang.Class clazz
         0: .line 498
            aload 0 /* clazz */
            invokestatic org.ehcache.core.spi.ServiceLocator.identifyImmediateDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
            astore 1 /* dependencies */
        start local 1 // java.util.Set dependencies
         1: .line 499
            aload 1 /* dependencies */
            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 /* dependencyClass */
        start local 2 // java.lang.Class dependencyClass
         3: .line 500
            aload 2 /* dependencyClass */
            aload 0 /* clazz */
            if_acmpne 5
         4: .line 501
            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 /* clazz */
            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 // java.lang.Class dependencyClass
         5: .line 499
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         6: .line 504
            new java.util.HashSet
            dup
            aload 1 /* dependencies */
            invokeinterface java.util.Set.size:()I
            iconst_3
            imul
            invokespecial java.util.HashSet.<init>:(I)V
            astore 2 /* transitive */
        start local 2 // java.util.Set transitive
         7: .line 505
            aload 2 /* transitive */
            aload 1 /* dependencies */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
         8: .line 507
            aload 1 /* dependencies */
            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 /* klazz */
        start local 3 // java.lang.Class klazz
        10: .line 508
            aload 3 /* klazz */
            invokestatic org.ehcache.core.spi.ServiceLocator.identifyTransitiveDependenciesOf:(Ljava/lang/Class;)Ljava/util/Set;
            astore 5 /* identified */
        start local 5 // java.util.Set identified
        11: .line 509
            aload 5 /* identified */
            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 /* dep */
        start local 6 // java.lang.Class dep
        13: .line 510
            aload 6 /* dep */
            aload 0 /* clazz */
            if_acmpne 15
        14: .line 511
            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 /* clazz */
            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 // java.lang.Class dep
        15: .line 509
      StackMap locals:
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        16: .line 514
            aload 2 /* transitive */
            aload 5 /* identified */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
        end local 5 // java.util.Set identified
        end local 3 // java.lang.Class klazz
        17: .line 507
      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: .line 517
            aload 2 /* transitive */
            areturn
        end local 2 // java.util.Set transitive
        end local 1 // java.util.Set dependencies
        end local 0 // java.lang.Class clazz
      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