public class android.telecom.Logging.EventManager
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: android.telecom.Logging.EventManager
  super_class: java.lang.Object
{
  public static final java.lang.String TAG;
    descriptor: Ljava/lang/String;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: "Logging.Events"

  public static final int DEFAULT_EVENTS_TO_CACHE;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 10
    RuntimeInvisibleAnnotations: 
      com.android.internal.annotations.VisibleForTesting()

  public static final java.time.format.DateTimeFormatter DATE_TIME_FORMATTER;
    descriptor: Ljava/time/format/DateTimeFormatter;
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL

  private final java.util.Map<android.telecom.Logging.EventManager$Loggable, android.telecom.Logging.EventManager$EventRecord> mCallEventRecordMap;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Landroid/telecom/Logging/EventManager$Loggable;Landroid/telecom/Logging/EventManager$EventRecord;>;

  private java.util.concurrent.LinkedBlockingQueue<android.telecom.Logging.EventManager$EventRecord> mEventRecords;
    descriptor: Ljava/util/concurrent/LinkedBlockingQueue;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/concurrent/LinkedBlockingQueue<Landroid/telecom/Logging/EventManager$EventRecord;>;

  private java.util.List<android.telecom.Logging.EventManager$EventListener> mEventListeners;
    descriptor: Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/List<Landroid/telecom/Logging/EventManager$EventListener;>;

  private android.telecom.Logging.SessionManager$ISessionIdQueryHandler mSessionIdHandler;
    descriptor: Landroid/telecom/Logging/SessionManager$ISessionIdQueryHandler;
    flags: (0x0002) ACC_PRIVATE

  private final java.util.Map<java.lang.String, java.util.List<android.telecom.Logging.EventManager$TimedEventPair>> requestResponsePairs;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/util/List<Landroid/telecom/Logging/EventManager$TimedEventPair;>;>;

  private static final java.lang.Object mSync;
    descriptor: Ljava/lang/Object;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 56
            ldc "HH:mm:ss.SSS"
            invokestatic java.time.format.DateTimeFormatter.ofPattern:(Ljava/lang/String;)Ljava/time/format/DateTimeFormatter;
         1: .line 55
            putstatic android.telecom.Logging.EventManager.DATE_TIME_FORMATTER:Ljava/time/format/DateTimeFormatter;
         2: .line 91
            new java.lang.Object
            dup
            invokespecial java.lang.Object.<init>:()V
            putstatic android.telecom.Logging.EventManager.mSync:Ljava/lang/Object;
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void addRequestResponsePair(android.telecom.Logging.EventManager$TimedEventPair);
    descriptor: (Landroid/telecom/Logging/EventManager$TimedEventPair;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.EventManager$TimedEventPair p
         0: .line 120
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.requestResponsePairs:Ljava/util/Map;
            aload 1 /* p */
            getfield android.telecom.Logging.EventManager$TimedEventPair.mRequest:Ljava/lang/String;
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifeq 3
         1: .line 121
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.requestResponsePairs:Ljava/util/Map;
            aload 1 /* p */
            getfield android.telecom.Logging.EventManager$TimedEventPair.mRequest:Ljava/lang/String;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.List
            aload 1 /* p */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         2: .line 122
            goto 6
         3: .line 123
      StackMap locals:
      StackMap stack:
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* responses */
        start local 2 // java.util.ArrayList responses
         4: .line 124
            aload 2 /* responses */
            aload 1 /* p */
            invokevirtual java.util.ArrayList.add:(Ljava/lang/Object;)Z
            pop
         5: .line 125
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.requestResponsePairs:Ljava/util/Map;
            aload 1 /* p */
            getfield android.telecom.Logging.EventManager$TimedEventPair.mRequest:Ljava/lang/String;
            aload 2 /* responses */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // java.util.ArrayList responses
         6: .line 127
      StackMap locals:
      StackMap stack:
            return
        end local 1 // android.telecom.Logging.EventManager$TimedEventPair p
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Landroid/telecom/Logging/EventManager;
            0    7     1          p  Landroid/telecom/Logging/EventManager$TimedEventPair;
            4    6     2  responses  Ljava/util/ArrayList<Landroid/telecom/Logging/EventManager$TimedEventPair;>;
    MethodParameters:
      Name  Flags
      p     

  public void <init>(android.telecom.Logging.SessionManager$ISessionIdQueryHandler);
    descriptor: (Landroid/telecom/Logging/SessionManager$ISessionIdQueryHandler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.SessionManager$ISessionIdQueryHandler l
         0: .line 276
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 70
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
         2: .line 71
            aload 0 /* this */
         3: .line 72
            new java.util.concurrent.LinkedBlockingQueue
            dup
            bipush 10
            invokespecial java.util.concurrent.LinkedBlockingQueue.<init>:(I)V
            putfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
         4: .line 74
            aload 0 /* this */
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            putfield android.telecom.Logging.EventManager.mEventListeners:Ljava/util/List;
         5: .line 89
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield android.telecom.Logging.EventManager.requestResponsePairs:Ljava/util/Map;
         6: .line 277
            aload 0 /* this */
            aload 1 /* l */
            putfield android.telecom.Logging.EventManager.mSessionIdHandler:Landroid/telecom/Logging/SessionManager$ISessionIdQueryHandler;
         7: .line 278
            return
        end local 1 // android.telecom.Logging.SessionManager$ISessionIdQueryHandler l
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Landroid/telecom/Logging/EventManager;
            0    8     1     l  Landroid/telecom/Logging/SessionManager$ISessionIdQueryHandler;
    MethodParameters:
      Name  Flags
      l     

  public void event(android.telecom.Logging.EventManager$Loggable, java.lang.String, java.lang.Object);
    descriptor: (Landroid/telecom/Logging/EventManager$Loggable;Ljava/lang/String;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, locals=7, args_size=4
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.EventManager$Loggable recordEntry
        start local 2 // java.lang.String event
        start local 3 // java.lang.Object data
         0: .line 281
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mSessionIdHandler:Landroid/telecom/Logging/SessionManager$ISessionIdQueryHandler;
            invokeinterface android.telecom.Logging.SessionManager$ISessionIdQueryHandler.getSessionId:()Ljava/lang/String;
            astore 4 /* currentSessionID */
        start local 4 // java.lang.String currentSessionID
         1: .line 283
            aload 1 /* recordEntry */
            ifnonnull 4
         2: .line 284
            ldc "Logging.Events"
            ldc "Non-call EVENT: %s, %s"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 2 /* event */
            aastore
            dup
            iconst_1
            aload 3 /* data */
            aastore
            invokestatic android.telecom.Log.i:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
         3: .line 285
            return
         4: .line 287
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            dup
            astore 5
            monitorenter
         5: .line 288
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            aload 1 /* recordEntry */
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifne 8
         6: .line 289
            new android.telecom.Logging.EventManager$EventRecord
            dup
            aload 0 /* this */
            aload 1 /* recordEntry */
            invokespecial android.telecom.Logging.EventManager$EventRecord.<init>:(Landroid/telecom/Logging/EventManager;Landroid/telecom/Logging/EventManager$Loggable;)V
            astore 6 /* newRecord */
        start local 6 // android.telecom.Logging.EventManager$EventRecord newRecord
         7: .line 290
            aload 0 /* this */
            aload 6 /* newRecord */
            invokevirtual android.telecom.Logging.EventManager.addEventRecord:(Landroid/telecom/Logging/EventManager$EventRecord;)V
        end local 6 // android.telecom.Logging.EventManager$EventRecord newRecord
         8: .line 293
      StackMap locals: java.util.concurrent.LinkedBlockingQueue
      StackMap stack:
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            aload 1 /* recordEntry */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$EventRecord
            astore 6 /* record */
        start local 6 // android.telecom.Logging.EventManager$EventRecord record
         9: .line 294
            aload 6 /* record */
            aload 2 /* event */
            aload 4 /* currentSessionID */
            aload 3 /* data */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.addEvent:(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;)V
        end local 6 // android.telecom.Logging.EventManager$EventRecord record
        10: .line 287
            aload 5
            monitorexit
        11: goto 14
      StackMap locals:
      StackMap stack: java.lang.Throwable
        12: aload 5
            monitorexit
        13: athrow
        14: .line 296
      StackMap locals:
      StackMap stack:
            return
        end local 4 // java.lang.String currentSessionID
        end local 3 // java.lang.Object data
        end local 2 // java.lang.String event
        end local 1 // android.telecom.Logging.EventManager$Loggable recordEntry
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   15     0              this  Landroid/telecom/Logging/EventManager;
            0   15     1       recordEntry  Landroid/telecom/Logging/EventManager$Loggable;
            0   15     2             event  Ljava/lang/String;
            0   15     3              data  Ljava/lang/Object;
            1   15     4  currentSessionID  Ljava/lang/String;
            7    8     6         newRecord  Landroid/telecom/Logging/EventManager$EventRecord;
            9   10     6            record  Landroid/telecom/Logging/EventManager$EventRecord;
      Exception table:
        from    to  target  type
           5    11      12  any
          12    13      12  any
    MethodParameters:
             Name  Flags
      recordEntry  
      event        
      data         

  public void event(android.telecom.Logging.EventManager$Loggable, java.lang.String, java.lang.String, java.lang.Object[]);
    descriptor: (Landroid/telecom/Logging/EventManager$Loggable;Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
    flags: (0x0081) ACC_PUBLIC, ACC_VARARGS
    Code:
      stack=7, locals=7, args_size=5
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.EventManager$Loggable recordEntry
        start local 2 // java.lang.String event
        start local 3 // java.lang.String format
        start local 4 // java.lang.Object[] args
         0: .line 301
            aload 4 /* args */
            ifnull 1
            aload 4 /* args */
            arraylength
            ifne 2
      StackMap locals:
      StackMap stack:
         1: aload 3 /* format */
            goto 3
         2: .line 302
      StackMap locals:
      StackMap stack:
            getstatic java.util.Locale.US:Ljava/util/Locale;
            aload 3 /* format */
            aload 4 /* args */
            invokestatic java.lang.String.format:(Ljava/util/Locale;Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
         3: .line 301
      StackMap locals:
      StackMap stack: java.lang.String
            astore 5 /* msg */
        start local 5 // java.lang.String msg
         4: .line 303
            goto 10
        end local 5 // java.lang.String msg
      StackMap locals:
      StackMap stack: java.util.IllegalFormatException
         5: astore 6 /* ife */
        start local 6 // java.util.IllegalFormatException ife
         6: .line 304
            aload 0 /* this */
            aload 6 /* ife */
            ldc "IllegalFormatException: formatString='%s' numArgs=%d"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 3 /* format */
            aastore
            dup
            iconst_1
         7: .line 305
            aload 4 /* args */
            arraylength
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
         8: .line 304
            invokestatic android.telecom.Log.e:(Ljava/lang/Object;Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V
         9: .line 306
            new java.lang.StringBuilder
            dup
            aload 3 /* format */
            invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            ldc " (An error occurred while formatting the message.)"
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            astore 5 /* msg */
        end local 6 // java.util.IllegalFormatException ife
        start local 5 // java.lang.String msg
        10: .line 309
      StackMap locals: java.lang.String
      StackMap stack:
            aload 0 /* this */
            aload 1 /* recordEntry */
            aload 2 /* event */
            aload 5 /* msg */
            invokevirtual android.telecom.Logging.EventManager.event:(Landroid/telecom/Logging/EventManager$Loggable;Ljava/lang/String;Ljava/lang/Object;)V
        11: .line 310
            return
        end local 5 // java.lang.String msg
        end local 4 // java.lang.Object[] args
        end local 3 // java.lang.String format
        end local 2 // java.lang.String event
        end local 1 // android.telecom.Logging.EventManager$Loggable recordEntry
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   12     0         this  Landroid/telecom/Logging/EventManager;
            0   12     1  recordEntry  Landroid/telecom/Logging/EventManager$Loggable;
            0   12     2        event  Ljava/lang/String;
            0   12     3       format  Ljava/lang/String;
            0   12     4         args  [Ljava/lang/Object;
            4    5     5          msg  Ljava/lang/String;
           10   12     5          msg  Ljava/lang/String;
            6   10     6          ife  Ljava/util/IllegalFormatException;
      Exception table:
        from    to  target  type
           0     4       5  Class java.util.IllegalFormatException
    MethodParameters:
             Name  Flags
      recordEntry  
      event        
      format       
      args         

  public void dumpEvents(com.android.internal.util.IndentingPrintWriter);
    descriptor: (Lcom/android/internal/util/IndentingPrintWriter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // com.android.internal.util.IndentingPrintWriter pw
         0: .line 313
            aload 1 /* pw */
            ldc "Historical Events:"
            invokevirtual com.android.internal.util.IndentingPrintWriter.println:(Ljava/lang/String;)V
         1: .line 314
            aload 1 /* pw */
            invokevirtual com.android.internal.util.IndentingPrintWriter.increaseIndent:()Lcom/android/internal/util/IndentingPrintWriter;
            pop
         2: .line 315
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            invokevirtual java.util.concurrent.LinkedBlockingQueue.iterator:()Ljava/util/Iterator;
            astore 3
            goto 5
      StackMap locals: android.telecom.Logging.EventManager com.android.internal.util.IndentingPrintWriter top java.util.Iterator
      StackMap stack:
         3: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$EventRecord
            astore 2 /* eventRecord */
        start local 2 // android.telecom.Logging.EventManager$EventRecord eventRecord
         4: .line 316
            aload 2 /* eventRecord */
            aload 1 /* pw */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.dump:(Lcom/android/internal/util/IndentingPrintWriter;)V
        end local 2 // android.telecom.Logging.EventManager$EventRecord eventRecord
         5: .line 315
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         6: .line 318
            aload 1 /* pw */
            invokevirtual com.android.internal.util.IndentingPrintWriter.decreaseIndent:()Lcom/android/internal/util/IndentingPrintWriter;
            pop
         7: .line 319
            return
        end local 1 // com.android.internal.util.IndentingPrintWriter pw
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Landroid/telecom/Logging/EventManager;
            0    8     1           pw  Lcom/android/internal/util/IndentingPrintWriter;
            4    5     2  eventRecord  Landroid/telecom/Logging/EventManager$EventRecord;
    MethodParameters:
      Name  Flags
      pw    

  public void dumpEventsTimeline(com.android.internal.util.IndentingPrintWriter);
    descriptor: (Lcom/android/internal/util/IndentingPrintWriter;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=7, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // com.android.internal.util.IndentingPrintWriter pw
         0: .line 327
            aload 1 /* pw */
            ldc "Historical Events (sorted by time):"
            invokevirtual com.android.internal.util.IndentingPrintWriter.println:(Ljava/lang/String;)V
         1: .line 330
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* events */
        start local 2 // java.util.List events
         2: .line 331
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            invokevirtual java.util.concurrent.LinkedBlockingQueue.iterator:()Ljava/util/Iterator;
            astore 4
            goto 8
      StackMap locals: android.telecom.Logging.EventManager com.android.internal.util.IndentingPrintWriter java.util.List top java.util.Iterator
      StackMap stack:
         3: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$EventRecord
            astore 3 /* er */
        start local 3 // android.telecom.Logging.EventManager$EventRecord er
         4: .line 332
            aload 3 /* er */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.getEvents:()Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 7
      StackMap locals: android.telecom.Logging.EventManager com.android.internal.util.IndentingPrintWriter java.util.List android.telecom.Logging.EventManager$EventRecord java.util.Iterator top java.util.Iterator
      StackMap stack:
         5: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$Event
            astore 5 /* ev */
        start local 5 // android.telecom.Logging.EventManager$Event ev
         6: .line 333
            aload 2 /* events */
            new android.util.Pair
            dup
            aload 3 /* er */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.getRecordEntry:()Landroid/telecom/Logging/EventManager$Loggable;
            aload 5 /* ev */
            invokespecial android.util.Pair.<init>:(Ljava/lang/Object;Ljava/lang/Object;)V
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 5 // android.telecom.Logging.EventManager$Event ev
         7: .line 332
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        end local 3 // android.telecom.Logging.EventManager$EventRecord er
         8: .line 331
      StackMap locals: android.telecom.Logging.EventManager com.android.internal.util.IndentingPrintWriter java.util.List top java.util.Iterator
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         9: .line 340
            invokedynamic applyAsLong()Ljava/util/function/ToLongFunction;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)J
                  android/telecom/Logging/EventManager.lambda$0(Landroid/util/Pair;)J (6)
                  (Landroid/util/Pair;)J
            invokestatic java.util.Comparator.comparingLong:(Ljava/util/function/ToLongFunction;)Ljava/util/Comparator;
        10: .line 339
            astore 3 /* byEventTime */
        start local 3 // java.util.Comparator byEventTime
        11: .line 341
            aload 2 /* events */
            aload 3 /* byEventTime */
            invokeinterface java.util.List.sort:(Ljava/util/Comparator;)V
        12: .line 343
            aload 1 /* pw */
            invokevirtual com.android.internal.util.IndentingPrintWriter.increaseIndent:()Lcom/android/internal/util/IndentingPrintWriter;
            pop
        13: .line 344
            aload 2 /* events */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 22
      StackMap locals: android.telecom.Logging.EventManager com.android.internal.util.IndentingPrintWriter java.util.List java.util.Comparator top java.util.Iterator
      StackMap stack:
        14: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast android.util.Pair
            astore 4 /* event */
        start local 4 // android.util.Pair event
        15: .line 345
            aload 1 /* pw */
            aload 4 /* event */
            getfield android.util.Pair.second:Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$Event
            getfield android.telecom.Logging.EventManager$Event.timestampString:Ljava/lang/String;
            invokevirtual com.android.internal.util.IndentingPrintWriter.print:(Ljava/lang/String;)V
        16: .line 346
            aload 1 /* pw */
            ldc ","
            invokevirtual com.android.internal.util.IndentingPrintWriter.print:(Ljava/lang/String;)V
        17: .line 347
            aload 1 /* pw */
            aload 4 /* event */
            getfield android.util.Pair.first:Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$Loggable
            invokeinterface android.telecom.Logging.EventManager$Loggable.getId:()Ljava/lang/String;
            invokevirtual com.android.internal.util.IndentingPrintWriter.print:(Ljava/lang/String;)V
        18: .line 348
            aload 1 /* pw */
            ldc ","
            invokevirtual com.android.internal.util.IndentingPrintWriter.print:(Ljava/lang/String;)V
        19: .line 349
            aload 1 /* pw */
            aload 4 /* event */
            getfield android.util.Pair.second:Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$Event
            getfield android.telecom.Logging.EventManager$Event.eventId:Ljava/lang/String;
            invokevirtual com.android.internal.util.IndentingPrintWriter.print:(Ljava/lang/String;)V
        20: .line 350
            aload 1 /* pw */
            ldc ","
            invokevirtual com.android.internal.util.IndentingPrintWriter.print:(Ljava/lang/String;)V
        21: .line 351
            aload 1 /* pw */
            aload 4 /* event */
            getfield android.util.Pair.second:Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$Event
            getfield android.telecom.Logging.EventManager$Event.data:Ljava/lang/Object;
            invokevirtual com.android.internal.util.IndentingPrintWriter.println:(Ljava/lang/Object;)V
        end local 4 // android.util.Pair event
        22: .line 344
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 14
        23: .line 353
            aload 1 /* pw */
            invokevirtual com.android.internal.util.IndentingPrintWriter.decreaseIndent:()Lcom/android/internal/util/IndentingPrintWriter;
            pop
        24: .line 354
            return
        end local 3 // java.util.Comparator byEventTime
        end local 2 // java.util.List events
        end local 1 // com.android.internal.util.IndentingPrintWriter pw
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   25     0         this  Landroid/telecom/Logging/EventManager;
            0   25     1           pw  Lcom/android/internal/util/IndentingPrintWriter;
            2   25     2       events  Ljava/util/List<Landroid/util/Pair<Landroid/telecom/Logging/EventManager$Loggable;Landroid/telecom/Logging/EventManager$Event;>;>;
            4    8     3           er  Landroid/telecom/Logging/EventManager$EventRecord;
            6    7     5           ev  Landroid/telecom/Logging/EventManager$Event;
           11   25     3  byEventTime  Ljava/util/Comparator<Landroid/util/Pair<Landroid/telecom/Logging/EventManager$Loggable;Landroid/telecom/Logging/EventManager$Event;>;>;
           15   22     4        event  Landroid/util/Pair<Landroid/telecom/Logging/EventManager$Loggable;Landroid/telecom/Logging/EventManager$Event;>;
    MethodParameters:
      Name  Flags
      pw    

  public void changeEventCacheSize(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // int newSize
         0: .line 359
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            astore 2 /* oldEventLog */
        start local 2 // java.util.concurrent.LinkedBlockingQueue oldEventLog
         1: .line 360
            aload 0 /* this */
            new java.util.concurrent.LinkedBlockingQueue
            dup
            iload 1 /* newSize */
            invokespecial java.util.concurrent.LinkedBlockingQueue.<init>:(I)V
            putfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
         2: .line 361
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            invokeinterface java.util.Map.clear:()V
         3: .line 363
            aload 2 /* oldEventLog */
            aload 0 /* this */
            invokedynamic accept(Landroid/telecom/Logging/EventManager;)Ljava/util/function/Consumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;)V
                  android/telecom/Logging/EventManager.lambda$1(Landroid/telecom/Logging/EventManager$EventRecord;)V (7)
                  (Landroid/telecom/Logging/EventManager$EventRecord;)V
            invokevirtual java.util.concurrent.LinkedBlockingQueue.forEach:(Ljava/util/function/Consumer;)V
         4: .line 380
            return
        end local 2 // java.util.concurrent.LinkedBlockingQueue oldEventLog
        end local 1 // int newSize
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    5     0         this  Landroid/telecom/Logging/EventManager;
            0    5     1      newSize  I
            1    5     2  oldEventLog  Ljava/util/concurrent/LinkedBlockingQueue<Landroid/telecom/Logging/EventManager$EventRecord;>;
    MethodParameters:
         Name  Flags
      newSize  

  public void registerEventListener(android.telecom.Logging.EventManager$EventListener);
    descriptor: (Landroid/telecom/Logging/EventManager$EventListener;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.EventManager$EventListener e
         0: .line 383
            aload 1 /* e */
            ifnull 7
         1: .line 384
            getstatic android.telecom.Logging.EventManager.mSync:Ljava/lang/Object;
            dup
            astore 2
            monitorenter
         2: .line 385
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventListeners:Ljava/util/List;
            aload 1 /* e */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
         3: .line 384
            aload 2
            monitorexit
         4: goto 7
      StackMap locals: android.telecom.Logging.EventManager android.telecom.Logging.EventManager$EventListener java.lang.Object
      StackMap stack: java.lang.Throwable
         5: aload 2
            monitorexit
         6: athrow
         7: .line 388
      StackMap locals:
      StackMap stack:
            return
        end local 1 // android.telecom.Logging.EventManager$EventListener e
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    8     0  this  Landroid/telecom/Logging/EventManager;
            0    8     1     e  Landroid/telecom/Logging/EventManager$EventListener;
      Exception table:
        from    to  target  type
           2     4       5  any
           5     6       5  any
    MethodParameters:
      Name  Flags
      e     

  public java.util.concurrent.LinkedBlockingQueue<android.telecom.Logging.EventManager$EventRecord> getEventRecords();
    descriptor: ()Ljava/util/concurrent/LinkedBlockingQueue;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // android.telecom.Logging.EventManager this
         0: .line 392
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            areturn
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Landroid/telecom/Logging/EventManager;
    Signature: ()Ljava/util/concurrent/LinkedBlockingQueue<Landroid/telecom/Logging/EventManager$EventRecord;>;
    RuntimeInvisibleAnnotations: 
      com.android.internal.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.android.internal.annotations.VisibleForTesting()

  public java.util.Map<android.telecom.Logging.EventManager$Loggable, android.telecom.Logging.EventManager$EventRecord> getCallEventRecordMap();
    descriptor: ()Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // android.telecom.Logging.EventManager this
         0: .line 397
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            areturn
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Landroid/telecom/Logging/EventManager;
    Signature: ()Ljava/util/Map<Landroid/telecom/Logging/EventManager$Loggable;Landroid/telecom/Logging/EventManager$EventRecord;>;
    RuntimeInvisibleAnnotations: 
      com.android.internal.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.android.internal.annotations.VisibleForTesting()

  private void addEventRecord(android.telecom.Logging.EventManager$EventRecord);
    descriptor: (Landroid/telecom/Logging/EventManager$EventRecord;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.EventManager$EventRecord newRecord
         0: .line 401
            aload 1 /* newRecord */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.getRecordEntry:()Landroid/telecom/Logging/EventManager$Loggable;
            astore 2 /* recordEntry */
        start local 2 // android.telecom.Logging.EventManager$Loggable recordEntry
         1: .line 404
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            invokevirtual java.util.concurrent.LinkedBlockingQueue.remainingCapacity:()I
            ifne 5
         2: .line 405
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            invokevirtual java.util.concurrent.LinkedBlockingQueue.poll:()Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$EventRecord
            astore 3 /* record */
        start local 3 // android.telecom.Logging.EventManager$EventRecord record
         3: .line 406
            aload 3 /* record */
            ifnull 5
         4: .line 407
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            aload 3 /* record */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.getRecordEntry:()Landroid/telecom/Logging/EventManager$Loggable;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 3 // android.telecom.Logging.EventManager$EventRecord record
         5: .line 412
      StackMap locals: android.telecom.Logging.EventManager$Loggable
      StackMap stack:
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            aload 1 /* newRecord */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.add:(Ljava/lang/Object;)Z
            pop
         6: .line 413
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            aload 2 /* recordEntry */
            aload 1 /* newRecord */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         7: .line 414
            getstatic android.telecom.Logging.EventManager.mSync:Ljava/lang/Object;
            dup
            astore 3
            monitorenter
         8: .line 415
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventListeners:Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 5
            goto 11
      StackMap locals: android.telecom.Logging.EventManager android.telecom.Logging.EventManager$EventRecord android.telecom.Logging.EventManager$Loggable java.lang.Object top java.util.Iterator
      StackMap stack:
         9: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$EventListener
            astore 4 /* l */
        start local 4 // android.telecom.Logging.EventManager$EventListener l
        10: .line 416
            aload 4 /* l */
            aload 1 /* newRecord */
            invokeinterface android.telecom.Logging.EventManager$EventListener.eventRecordAdded:(Landroid/telecom/Logging/EventManager$EventRecord;)V
        end local 4 // android.telecom.Logging.EventManager$EventListener l
        11: .line 415
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        12: .line 414
            aload 3
            monitorexit
        13: goto 16
      StackMap locals: android.telecom.Logging.EventManager android.telecom.Logging.EventManager$EventRecord android.telecom.Logging.EventManager$Loggable java.lang.Object
      StackMap stack: java.lang.Throwable
        14: aload 3
            monitorexit
        15: athrow
        16: .line 419
      StackMap locals:
      StackMap stack:
            return
        end local 2 // android.telecom.Logging.EventManager$Loggable recordEntry
        end local 1 // android.telecom.Logging.EventManager$EventRecord newRecord
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   17     0         this  Landroid/telecom/Logging/EventManager;
            0   17     1    newRecord  Landroid/telecom/Logging/EventManager$EventRecord;
            1   17     2  recordEntry  Landroid/telecom/Logging/EventManager$Loggable;
            3    5     3       record  Landroid/telecom/Logging/EventManager$EventRecord;
           10   11     4            l  Landroid/telecom/Logging/EventManager$EventListener;
      Exception table:
        from    to  target  type
           8    13      14  any
          14    15      14  any
    MethodParameters:
           Name  Flags
      newRecord  

  private static long lambda$0(android.util.Pair);
    descriptor: (Landroid/util/Pair;)J
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // android.util.Pair e
         0: .line 340
            aload 0 /* e */
            getfield android.util.Pair.second:Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$Event
            getfield android.telecom.Logging.EventManager$Event.time:J
            lreturn
        end local 0 // android.util.Pair e
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0     e  Landroid/util/Pair<Landroid/telecom/Logging/EventManager$Loggable;Landroid/telecom/Logging/EventManager$Event;>;

  private void lambda$1(android.telecom.Logging.EventManager$EventRecord);
    descriptor: (Landroid/telecom/Logging/EventManager$EventRecord;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // android.telecom.Logging.EventManager this
        start local 1 // android.telecom.Logging.EventManager$EventRecord newRecord
         0: .line 364
            aload 1 /* newRecord */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.getRecordEntry:()Landroid/telecom/Logging/EventManager$Loggable;
            astore 2 /* recordEntry */
        start local 2 // android.telecom.Logging.EventManager$Loggable recordEntry
         1: .line 367
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            invokevirtual java.util.concurrent.LinkedBlockingQueue.remainingCapacity:()I
            ifne 5
         2: .line 368
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            invokevirtual java.util.concurrent.LinkedBlockingQueue.poll:()Ljava/lang/Object;
            checkcast android.telecom.Logging.EventManager$EventRecord
            astore 3 /* record */
        start local 3 // android.telecom.Logging.EventManager$EventRecord record
         3: .line 369
            aload 3 /* record */
            ifnull 5
         4: .line 370
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            aload 3 /* record */
            invokevirtual android.telecom.Logging.EventManager$EventRecord.getRecordEntry:()Landroid/telecom/Logging/EventManager$Loggable;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 3 // android.telecom.Logging.EventManager$EventRecord record
         5: .line 375
      StackMap locals: android.telecom.Logging.EventManager$Loggable
      StackMap stack:
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mEventRecords:Ljava/util/concurrent/LinkedBlockingQueue;
            aload 1 /* newRecord */
            invokevirtual java.util.concurrent.LinkedBlockingQueue.add:(Ljava/lang/Object;)Z
            pop
         6: .line 376
            aload 0 /* this */
            getfield android.telecom.Logging.EventManager.mCallEventRecordMap:Ljava/util/Map;
            aload 2 /* recordEntry */
            aload 1 /* newRecord */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 2 // android.telecom.Logging.EventManager$Loggable recordEntry
         7: .line 379
            return
        end local 1 // android.telecom.Logging.EventManager$EventRecord newRecord
        end local 0 // android.telecom.Logging.EventManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    8     0         this  Landroid/telecom/Logging/EventManager;
            0    8     1    newRecord  Landroid/telecom/Logging/EventManager$EventRecord;
            1    7     2  recordEntry  Landroid/telecom/Logging/EventManager$Loggable;
            3    5     3       record  Landroid/telecom/Logging/EventManager$EventRecord;
}
SourceFile: "EventManager.java"
NestMembers:
  android.telecom.Logging.EventManager$Event  android.telecom.Logging.EventManager$EventListener  android.telecom.Logging.EventManager$EventRecord  android.telecom.Logging.EventManager$EventRecord$EventTiming  android.telecom.Logging.EventManager$EventRecord$PendingResponse  android.telecom.Logging.EventManager$Loggable  android.telecom.Logging.EventManager$TimedEventPair
InnerClasses:
  public Event = android.telecom.Logging.EventManager$Event of android.telecom.Logging.EventManager
  public abstract EventListener = android.telecom.Logging.EventManager$EventListener of android.telecom.Logging.EventManager
  public EventRecord = android.telecom.Logging.EventManager$EventRecord of android.telecom.Logging.EventManager
  public abstract Loggable = android.telecom.Logging.EventManager$Loggable of android.telecom.Logging.EventManager
  public TimedEventPair = android.telecom.Logging.EventManager$TimedEventPair of android.telecom.Logging.EventManager
  public abstract ISessionIdQueryHandler = android.telecom.Logging.SessionManager$ISessionIdQueryHandler of android.telecom.Logging.SessionManager
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles