public class android.telecom.Logging.SessionManager
minor version: 0
major version: 59
flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
this_class: android.telecom.Logging.SessionManager
super_class: java.lang.Object
{
private static final long SESSION_ID_ROLLOVER_THRESHOLD;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 262144
private static final long DEFAULT_SESSION_TIMEOUT_MS;
descriptor: J
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: 30000
private static final java.lang.String LOGGING_TAG;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "Logging"
private static final java.lang.String TIMEOUTS_PREFIX;
descriptor: Ljava/lang/String;
flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
ConstantValue: "telecom."
private int sCodeEntryCounter;
descriptor: I
flags: (0x0002) ACC_PRIVATE
private android.content.Context mContext;
descriptor: Landroid/content/Context;
flags: (0x0002) ACC_PRIVATE
public java.util.concurrent.ConcurrentHashMap<java.lang.Integer, android.telecom.Logging.Session> mSessionMapper;
descriptor: Ljava/util/concurrent/ConcurrentHashMap;
flags: (0x0001) ACC_PUBLIC
Signature: Ljava/util/concurrent/ConcurrentHashMap<Ljava/lang/Integer;Landroid/telecom/Logging/Session;>;
RuntimeInvisibleAnnotations:
com.android.internal.annotations.VisibleForTesting()
public java.lang.Runnable mCleanStaleSessions;
descriptor: Ljava/lang/Runnable;
flags: (0x0001) ACC_PUBLIC
RuntimeInvisibleAnnotations:
com.android.internal.annotations.VisibleForTesting()
private android.os.Handler mSessionCleanupHandler;
descriptor: Landroid/os/Handler;
flags: (0x0002) ACC_PRIVATE
public android.telecom.Logging.SessionManager$ICurrentThreadId mCurrentThreadId;
descriptor: Landroid/telecom/Logging/SessionManager$ICurrentThreadId;
flags: (0x0001) ACC_PUBLIC
RuntimeInvisibleAnnotations:
com.android.internal.annotations.VisibleForTesting()
private android.telecom.Logging.SessionManager$ISessionCleanupTimeoutMs mSessionCleanupTimeoutMs;
descriptor: Landroid/telecom/Logging/SessionManager$ISessionCleanupTimeoutMs;
flags: (0x0002) ACC_PRIVATE
private java.util.List<android.telecom.Logging.SessionManager$ISessionListener> mSessionListeners;
descriptor: Ljava/util/List;
flags: (0x0002) ACC_PRIVATE
Signature: Ljava/util/List<Landroid/telecom/Logging/SessionManager$ISessionListener;>;
public void setContext(android.content.Context);
descriptor: (Landroid/content/Context;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
aload 1
putfield android.telecom.Logging.SessionManager.mContext:Landroid/content/Context;
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/telecom/Logging/SessionManager;
0 2 1 context Landroid/content/Context;
MethodParameters:
Name Flags
context
public void <init>();
descriptor: ()V
flags: (0x0001) ACC_PUBLIC
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
iconst_0
putfield android.telecom.Logging.SessionManager.sCodeEntryCounter:I
2: aload 0
new java.util.concurrent.ConcurrentHashMap
dup
bipush 100
invokespecial java.util.concurrent.ConcurrentHashMap.<init>:(I)V
putfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
3: aload 0
aload 0
invokedynamic run(Landroid/telecom/Logging/SessionManager;)Ljava/lang/Runnable;
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:
()V
android/telecom/Logging/SessionManager.lambda$0()V (7)
()V
putfield android.telecom.Logging.SessionManager.mCleanStaleSessions:Ljava/lang/Runnable;
4: aload 0
new android.os.Handler
dup
invokestatic android.os.Looper.getMainLooper:()Landroid/os/Looper;
invokespecial android.os.Handler.<init>:(Landroid/os/Looper;)V
putfield android.telecom.Logging.SessionManager.mSessionCleanupHandler:Landroid/os/Handler;
5: aload 0
invokedynamic get()Landroid/telecom/Logging/SessionManager$ICurrentThreadId;
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:
()I
android/os/Process.myTid()I (6)
()I
putfield android.telecom.Logging.SessionManager.mCurrentThreadId:Landroid/telecom/Logging/SessionManager$ICurrentThreadId;
6: aload 0
aload 0
invokedynamic get(Landroid/telecom/Logging/SessionManager;)Landroid/telecom/Logging/SessionManager$ISessionCleanupTimeoutMs;
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:
()J
android/telecom/Logging/SessionManager.lambda$2()J (7)
()J
putfield android.telecom.Logging.SessionManager.mSessionCleanupTimeoutMs:Landroid/telecom/Logging/SessionManager$ISessionCleanupTimeoutMs;
7: aload 0
new java.util.ArrayList
dup
invokespecial java.util.ArrayList.<init>:()V
putfield android.telecom.Logging.SessionManager.mSessionListeners:Ljava/util/List;
8: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 9 0 this Landroid/telecom/Logging/SessionManager;
private long getSessionCleanupTimeoutMs();
descriptor: ()J
flags: (0x0002) ACC_PRIVATE
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield android.telecom.Logging.SessionManager.mSessionCleanupTimeoutMs:Landroid/telecom/Logging/SessionManager$ISessionCleanupTimeoutMs;
invokeinterface android.telecom.Logging.SessionManager$ISessionCleanupTimeoutMs.get:()J
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/telecom/Logging/SessionManager;
private synchronized void resetStaleSessionTimer();
descriptor: ()V
flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
Code:
stack=4, locals=1, args_size=1
start local 0 0: aload 0
getfield android.telecom.Logging.SessionManager.mSessionCleanupHandler:Landroid/os/Handler;
aconst_null
invokevirtual android.os.Handler.removeCallbacksAndMessages:(Ljava/lang/Object;)V
1: aload 0
getfield android.telecom.Logging.SessionManager.mCleanStaleSessions:Ljava/lang/Runnable;
ifnull 3
2: aload 0
getfield android.telecom.Logging.SessionManager.mSessionCleanupHandler:Landroid/os/Handler;
aload 0
getfield android.telecom.Logging.SessionManager.mCleanStaleSessions:Ljava/lang/Runnable;
aload 0
invokevirtual android.telecom.Logging.SessionManager.getSessionCleanupTimeoutMs:()J
invokevirtual android.os.Handler.postDelayed:(Ljava/lang/Runnable;J)Z
pop
3: StackMap locals:
StackMap stack:
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Landroid/telecom/Logging/SessionManager;
public synchronized void startSession(android.telecom.Logging.Session$Info, java.lang.String, java.lang.String);
descriptor: (Landroid/telecom/Logging/Session$Info;Ljava/lang/String;Ljava/lang/String;)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 1
ifnonnull 3
1: aload 0
aload 2
aload 3
invokevirtual android.telecom.Logging.SessionManager.startSession:(Ljava/lang/String;Ljava/lang/String;)V
2: goto 4
3: StackMap locals:
StackMap stack:
aload 0
aload 1
aload 2
invokevirtual android.telecom.Logging.SessionManager.startExternalSession:(Landroid/telecom/Logging/Session$Info;Ljava/lang/String;)V
4: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Landroid/telecom/Logging/SessionManager;
0 5 1 info Landroid/telecom/Logging/Session$Info;
0 5 2 shortMethodName Ljava/lang/String;
0 5 3 callerIdentification Ljava/lang/String;
MethodParameters:
Name Flags
info
shortMethodName
callerIdentification
public synchronized void startSession(java.lang.String, java.lang.String);
descriptor: (Ljava/lang/String;Ljava/lang/String;)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=8, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
invokevirtual android.telecom.Logging.SessionManager.resetStaleSessionTimer:()V
1: aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
istore 3
start local 3 2: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 3
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 4
start local 4 3: aload 4
ifnull 7
4: aload 0
iconst_1
invokevirtual android.telecom.Logging.SessionManager.createSubsession:(Z)Landroid/telecom/Logging/Session;
astore 5
start local 5 5: aload 0
aload 5
aload 1
invokevirtual android.telecom.Logging.SessionManager.continueSession:(Landroid/telecom/Logging/Session;Ljava/lang/String;)V
6: return
end local 5 7: StackMap locals: int android.telecom.Logging.Session
StackMap stack:
ldc "Logging"
ldc "START_SESSION"
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.d:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
8: new android.telecom.Logging.Session
dup
aload 0
invokevirtual android.telecom.Logging.SessionManager.getNextSessionID:()Ljava/lang/String;
aload 1
9: invokestatic java.lang.System.currentTimeMillis:()J
iconst_0
aload 2
10: invokespecial android.telecom.Logging.Session.<init>:(Ljava/lang/String;Ljava/lang/String;JZLjava/lang/String;)V
astore 5
start local 5 11: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 3
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 5
invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
12: return
end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 13 0 this Landroid/telecom/Logging/SessionManager;
0 13 1 shortMethodName Ljava/lang/String;
0 13 2 callerIdentification Ljava/lang/String;
2 13 3 threadId I
3 13 4 activeSession Landroid/telecom/Logging/Session;
5 7 5 childSession Landroid/telecom/Logging/Session;
11 13 5 newSession Landroid/telecom/Logging/Session;
MethodParameters:
Name Flags
shortMethodName
callerIdentification
public synchronized void startExternalSession(android.telecom.Logging.Session$Info, java.lang.String);
descriptor: (Landroid/telecom/Logging/Session$Info;Ljava/lang/String;)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=8, locals=7, args_size=3
start local 0 start local 1 start local 2 0: aload 1
ifnonnull 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
istore 3
start local 3 3: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 3
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 4
start local 4 4: aload 4
ifnull 7
5: ldc "Logging"
ldc "trying to start an external session with a session already active."
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.w:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
6: return
7: StackMap locals: int android.telecom.Logging.Session
StackMap stack:
ldc "Logging"
ldc "START_EXTERNAL_SESSION"
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.d:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
8: new android.telecom.Logging.Session
dup
new java.lang.StringBuilder
dup
ldc "E-"
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 1
getfield android.telecom.Logging.Session$Info.sessionId:Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
9: aload 1
getfield android.telecom.Logging.Session$Info.methodPath:Ljava/lang/String;
invokestatic java.lang.System.currentTimeMillis:()J
10: iconst_0
aconst_null
11: invokespecial android.telecom.Logging.Session.<init>:(Ljava/lang/String;Ljava/lang/String;JZLjava/lang/String;)V
astore 5
start local 5 12: aload 5
iconst_1
invokevirtual android.telecom.Logging.Session.setIsExternal:(Z)V
13: aload 5
ldc -1
invokevirtual android.telecom.Logging.Session.markSessionCompleted:(J)V
14: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 3
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 5
invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
15: aload 0
invokevirtual android.telecom.Logging.SessionManager.createSubsession:()Landroid/telecom/Logging/Session;
astore 6
start local 6 16: aload 0
aload 6
aload 2
invokevirtual android.telecom.Logging.SessionManager.continueSession:(Landroid/telecom/Logging/Session;Ljava/lang/String;)V
17: return
end local 6 end local 5 end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Landroid/telecom/Logging/SessionManager;
0 18 1 sessionInfo Landroid/telecom/Logging/Session$Info;
0 18 2 shortMethodName Ljava/lang/String;
3 18 3 threadId I
4 18 4 threadSession Landroid/telecom/Logging/Session;
12 18 5 externalSession Landroid/telecom/Logging/Session;
16 18 6 childSession Landroid/telecom/Logging/Session;
MethodParameters:
Name Flags
sessionInfo
shortMethodName
public android.telecom.Logging.Session createSubsession();
descriptor: ()Landroid/telecom/Logging/Session;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
iconst_0
invokevirtual android.telecom.Logging.SessionManager.createSubsession:(Z)Landroid/telecom/Logging/Session;
areturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/telecom/Logging/SessionManager;
private synchronized android.telecom.Logging.Session createSubsession(boolean);
descriptor: (Z)Landroid/telecom/Logging/Session;
flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
Code:
stack=8, locals=5, args_size=2
start local 0 start local 1 0: aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
istore 2
start local 2 1: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 2
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 3
start local 3 2: aload 3
ifnonnull 5
3: ldc "Logging"
ldc "Log.createSubsession was called with no session active."
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.d:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
4: aconst_null
areturn
5: StackMap locals: int android.telecom.Logging.Session
StackMap stack:
new android.telecom.Logging.Session
dup
aload 3
invokevirtual android.telecom.Logging.Session.getNextChildId:()Ljava/lang/String;
6: aload 3
invokevirtual android.telecom.Logging.Session.getShortMethodName:()Ljava/lang/String;
invokestatic java.lang.System.currentTimeMillis:()J
7: iload 1
aconst_null
8: invokespecial android.telecom.Logging.Session.<init>:(Ljava/lang/String;Ljava/lang/String;JZLjava/lang/String;)V
astore 4
start local 4 9: aload 3
aload 4
invokevirtual android.telecom.Logging.Session.addChild:(Landroid/telecom/Logging/Session;)V
10: aload 4
aload 3
invokevirtual android.telecom.Logging.Session.setParentSession:(Landroid/telecom/Logging/Session;)V
11: iload 1
ifne 16
12: ldc "Logging"
new java.lang.StringBuilder
dup
ldc "CREATE_SUBSESSION "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
13: aload 4
invokevirtual android.telecom.Logging.Session.toString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
14: invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
15: goto 17
16: StackMap locals: android.telecom.Logging.Session
StackMap stack:
ldc "Logging"
ldc "CREATE_SUBSESSION (Invisible subsession)"
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
17: StackMap locals:
StackMap stack:
aload 4
areturn
end local 4 end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Landroid/telecom/Logging/SessionManager;
0 18 1 isStartedFromActiveSession Z
1 18 2 threadId I
2 18 3 threadSession Landroid/telecom/Logging/Session;
9 18 4 newSubsession Landroid/telecom/Logging/Session;
MethodParameters:
Name Flags
isStartedFromActiveSession
public synchronized android.telecom.Logging.Session$Info getExternalSession();
descriptor: ()Landroid/telecom/Logging/Session$Info;
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=3, args_size=1
start local 0 0: aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
istore 1
start local 1 1: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 2
start local 2 2: aload 2
ifnonnull 5
3: ldc "Logging"
ldc "Log.getExternalSession was called with no session active."
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.d:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
4: aconst_null
areturn
5: StackMap locals: int android.telecom.Logging.Session
StackMap stack:
aload 2
invokevirtual android.telecom.Logging.Session.getInfo:()Landroid/telecom/Logging/Session$Info;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Landroid/telecom/Logging/SessionManager;
1 6 1 threadId I
2 6 2 threadSession Landroid/telecom/Logging/Session;
public synchronized void cancelSubsession(android.telecom.Logging.Session);
descriptor: (Landroid/telecom/Logging/Session;)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=3, locals=2, args_size=2
start local 0 start local 1 0: aload 1
ifnonnull 2
1: return
2: StackMap locals:
StackMap stack:
aload 1
ldc -1
invokevirtual android.telecom.Logging.Session.markSessionCompleted:(J)V
3: aload 0
aload 1
invokevirtual android.telecom.Logging.SessionManager.endParentSessions:(Landroid/telecom/Logging/Session;)V
4: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Landroid/telecom/Logging/SessionManager;
0 5 1 subsession Landroid/telecom/Logging/Session;
MethodParameters:
Name Flags
subsession
public synchronized void continueSession(android.telecom.Logging.Session, java.lang.String);
descriptor: (Landroid/telecom/Logging/Session;Ljava/lang/String;)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=4, locals=4, args_size=3
start local 0 start local 1 start local 2 0: aload 1
ifnonnull 2
1: return
2: StackMap locals:
StackMap stack:
aload 0
invokevirtual android.telecom.Logging.SessionManager.resetStaleSessionTimer:()V
3: aload 1
aload 2
invokevirtual android.telecom.Logging.Session.setShortMethodName:(Ljava/lang/String;)V
4: aload 1
invokestatic java.lang.System.currentTimeMillis:()J
invokevirtual android.telecom.Logging.Session.setExecutionStartTimeMs:(J)V
5: aload 1
invokevirtual android.telecom.Logging.Session.getParentSession:()Landroid/telecom/Logging/Session;
astore 3
start local 3 6: aload 3
ifnonnull 11
7: ldc "Logging"
new java.lang.StringBuilder
dup
ldc "Log.continueSession was called with no session active for method "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
8: aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
9: invokestatic android.telecom.Log.i:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
10: return
11: StackMap locals: android.telecom.Logging.Session
StackMap stack:
aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 1
invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
12: aload 1
invokevirtual android.telecom.Logging.Session.isStartedFromActiveSession:()Z
ifne 15
13: ldc "Logging"
ldc "CONTINUE_SUBSESSION"
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
14: goto 18
15: StackMap locals:
StackMap stack:
ldc "Logging"
new java.lang.StringBuilder
dup
ldc "CONTINUE_SUBSESSION (Invisible Subsession) with Method "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
16: aload 2
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
17: invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
18: StackMap locals:
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 19 0 this Landroid/telecom/Logging/SessionManager;
0 19 1 subsession Landroid/telecom/Logging/Session;
0 19 2 shortMethodName Ljava/lang/String;
6 19 3 parentSession Landroid/telecom/Logging/Session;
MethodParameters:
Name Flags
subsession
shortMethodName
public synchronized void endSession();
descriptor: ()V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=4, locals=4, args_size=1
start local 0 0: aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
istore 1
start local 1 1: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 2
start local 2 2: aload 2
ifnonnull 5
3: ldc "Logging"
ldc "Log.endSession was called with no session active."
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.w:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
4: return
5: StackMap locals: int android.telecom.Logging.Session
StackMap stack:
aload 2
invokestatic java.lang.System.currentTimeMillis:()J
invokevirtual android.telecom.Logging.Session.markSessionCompleted:(J)V
6: aload 2
invokevirtual android.telecom.Logging.Session.isStartedFromActiveSession:()Z
ifne 11
7: ldc "Logging"
new java.lang.StringBuilder
dup
ldc "END_SUBSESSION (dur: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
8: aload 2
invokevirtual android.telecom.Logging.Session.getLocalExecutionTime:()J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
ldc " mS)"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
9: invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
10: goto 15
11: StackMap locals:
StackMap stack:
ldc "Logging"
new java.lang.StringBuilder
dup
ldc "END_SUBSESSION (Invisible Subsession) (dur: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
12: aload 2
invokevirtual android.telecom.Logging.Session.getLocalExecutionTime:()J
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
13: ldc " ms)"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
14: invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
15: StackMap locals:
StackMap stack:
aload 2
invokevirtual android.telecom.Logging.Session.getParentSession:()Landroid/telecom/Logging/Session;
astore 3
start local 3 16: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
pop
17: aload 0
aload 2
invokevirtual android.telecom.Logging.SessionManager.endParentSessions:(Landroid/telecom/Logging/Session;)V
18: aload 3
ifnull 21
aload 3
invokevirtual android.telecom.Logging.Session.isSessionCompleted:()Z
ifne 21
19: aload 2
invokevirtual android.telecom.Logging.Session.isStartedFromActiveSession:()Z
ifeq 21
20: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
iload 1
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
aload 3
invokevirtual java.util.concurrent.ConcurrentHashMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
pop
21: StackMap locals: android.telecom.Logging.Session
StackMap stack:
return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 22 0 this Landroid/telecom/Logging/SessionManager;
1 22 1 threadId I
2 22 2 completedSession Landroid/telecom/Logging/Session;
16 22 3 parentSession Landroid/telecom/Logging/Session;
private void endParentSessions(android.telecom.Logging.Session);
descriptor: (Landroid/telecom/Logging/Session;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=5, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual android.telecom.Logging.Session.isSessionCompleted:()Z
ifeq 1
aload 1
invokevirtual android.telecom.Logging.Session.getChildSessions:()Ljava/util/ArrayList;
invokevirtual java.util.ArrayList.size:()I
ifeq 2
1: StackMap locals:
StackMap stack:
return
2: StackMap locals:
StackMap stack:
aload 1
invokevirtual android.telecom.Logging.Session.getParentSession:()Landroid/telecom/Logging/Session;
astore 2
start local 2 3: aload 2
ifnull 12
4: aload 1
aconst_null
invokevirtual android.telecom.Logging.Session.setParentSession:(Landroid/telecom/Logging/Session;)V
5: aload 2
aload 1
invokevirtual android.telecom.Logging.Session.removeChild:(Landroid/telecom/Logging/Session;)V
6: aload 2
invokevirtual android.telecom.Logging.Session.isExternal:()Z
ifeq 10
7: invokestatic java.lang.System.currentTimeMillis:()J
aload 1
invokevirtual android.telecom.Logging.Session.getExecutionStartTimeMilliseconds:()J
lsub
8: lstore 3
start local 3 9: aload 0
aload 1
invokevirtual android.telecom.Logging.Session.getShortMethodName:()Ljava/lang/String;
lload 3
invokevirtual android.telecom.Logging.SessionManager.notifySessionCompleteListeners:(Ljava/lang/String;J)V
end local 3 10: StackMap locals: android.telecom.Logging.Session
StackMap stack:
aload 0
aload 2
invokevirtual android.telecom.Logging.SessionManager.endParentSessions:(Landroid/telecom/Logging/Session;)V
11: goto 19
12: StackMap locals:
StackMap stack:
invokestatic java.lang.System.currentTimeMillis:()J
aload 1
invokevirtual android.telecom.Logging.Session.getExecutionStartTimeMilliseconds:()J
lsub
13: lstore 3
start local 3 14: ldc "Logging"
new java.lang.StringBuilder
dup
ldc "END_SESSION (dur: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
lload 3
invokevirtual java.lang.StringBuilder.append:(J)Ljava/lang/StringBuilder;
15: ldc " ms): "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 1
invokevirtual android.telecom.Logging.Session.toString:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
iconst_0
anewarray java.lang.Object
16: invokestatic android.telecom.Log.d:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
17: aload 1
invokevirtual android.telecom.Logging.Session.isExternal:()Z
ifne 19
18: aload 0
aload 1
invokevirtual android.telecom.Logging.Session.getShortMethodName:()Ljava/lang/String;
lload 3
invokevirtual android.telecom.Logging.SessionManager.notifySessionCompleteListeners:(Ljava/lang/String;J)V
end local 3 19: StackMap locals:
StackMap stack:
return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 20 0 this Landroid/telecom/Logging/SessionManager;
0 20 1 subsession Landroid/telecom/Logging/Session;
3 20 2 parentSession Landroid/telecom/Logging/Session;
9 10 3 fullSessionTimeMs J
14 19 3 fullSessionTimeMs J
MethodParameters:
Name Flags
subsession
private void notifySessionCompleteListeners(java.lang.String, long);
descriptor: (Ljava/lang/String;J)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=6, args_size=3
start local 0 start local 1 start local 2 0: aload 0
getfield android.telecom.Logging.SessionManager.mSessionListeners:Ljava/util/List;
invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
astore 5
goto 3
StackMap locals: android.telecom.Logging.SessionManager java.lang.String long top java.util.Iterator
StackMap stack:
1: aload 5
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast android.telecom.Logging.SessionManager$ISessionListener
astore 4
start local 4 2: aload 4
aload 1
lload 2
invokeinterface android.telecom.Logging.SessionManager$ISessionListener.sessionComplete:(Ljava/lang/String;J)V
end local 4 3: StackMap locals:
StackMap stack:
aload 5
invokeinterface java.util.Iterator.hasNext:()Z
ifne 1
4: return
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Landroid/telecom/Logging/SessionManager;
0 5 1 methodName Ljava/lang/String;
0 5 2 sessionTimeMs J
2 3 4 l Landroid/telecom/Logging/SessionManager$ISessionListener;
MethodParameters:
Name Flags
methodName
sessionTimeMs
public java.lang.String getSessionId();
descriptor: ()Ljava/lang/String;
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=1
start local 0 0: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
aload 0
invokevirtual android.telecom.Logging.SessionManager.getCallingThreadId:()I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 1
start local 1 1: aload 1
ifnull 2
aload 1
invokevirtual android.telecom.Logging.Session.toString:()Ljava/lang/String;
goto 3
StackMap locals: android.telecom.Logging.Session
StackMap stack:
2: ldc ""
StackMap locals:
StackMap stack: java.lang.String
3: areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 4 0 this Landroid/telecom/Logging/SessionManager;
1 4 1 currentSession Landroid/telecom/Logging/Session;
public synchronized void registerSessionListener(android.telecom.Logging.SessionManager$ISessionListener);
descriptor: (Landroid/telecom/Logging/SessionManager$ISessionListener;)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 1
ifnull 2
1: aload 0
getfield android.telecom.Logging.SessionManager.mSessionListeners:Ljava/util/List;
aload 1
invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
pop
2: StackMap locals:
StackMap stack:
return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/telecom/Logging/SessionManager;
0 3 1 l Landroid/telecom/Logging/SessionManager$ISessionListener;
MethodParameters:
Name Flags
l
private synchronized java.lang.String getNextSessionID();
descriptor: ()Ljava/lang/String;
flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
Code:
stack=4, locals=2, args_size=1
start local 0 0: aload 0
dup
getfield android.telecom.Logging.SessionManager.sCodeEntryCounter:I
dup_x1
iconst_1
iadd
putfield android.telecom.Logging.SessionManager.sCodeEntryCounter:I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
astore 1
start local 1 1: aload 1
invokevirtual java.lang.Integer.intValue:()I
i2l
ldc 262144
lcmp
iflt 4
2: aload 0
invokevirtual android.telecom.Logging.SessionManager.restartSessionCounter:()V
3: aload 0
dup
getfield android.telecom.Logging.SessionManager.sCodeEntryCounter:I
dup_x1
iconst_1
iadd
putfield android.telecom.Logging.SessionManager.sCodeEntryCounter:I
invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
astore 1
4: StackMap locals: java.lang.Integer
StackMap stack:
aload 0
aload 1
invokevirtual java.lang.Integer.intValue:()I
invokevirtual android.telecom.Logging.SessionManager.getBase64Encoding:(I)Ljava/lang/String;
areturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 5 0 this Landroid/telecom/Logging/SessionManager;
1 5 1 nextId Ljava/lang/Integer;
private synchronized void restartSessionCounter();
descriptor: ()V
flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
iconst_0
putfield android.telecom.Logging.SessionManager.sCodeEntryCounter:I
1: return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Landroid/telecom/Logging/SessionManager;
private java.lang.String getBase64Encoding(int);
descriptor: (I)Ljava/lang/String;
flags: (0x0002) ACC_PRIVATE
Code:
stack=3, locals=3, args_size=2
start local 0 start local 1 0: iconst_4
invokestatic java.nio.ByteBuffer.allocate:(I)Ljava/nio/ByteBuffer;
iload 1
invokevirtual java.nio.ByteBuffer.putInt:(I)Ljava/nio/ByteBuffer;
invokevirtual java.nio.ByteBuffer.array:()[B
astore 2
start local 2 1: aload 2
iconst_2
iconst_4
invokestatic java.util.Arrays.copyOfRange:([BII)[B
astore 2
2: aload 2
iconst_3
invokestatic android.util.Base64.encodeToString:([BI)Ljava/lang/String;
areturn
end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/telecom/Logging/SessionManager;
0 3 1 number I
1 3 2 idByteArray [B
MethodParameters:
Name Flags
number
private int getCallingThreadId();
descriptor: ()I
flags: (0x0002) ACC_PRIVATE
Code:
stack=1, locals=1, args_size=1
start local 0 0: aload 0
getfield android.telecom.Logging.SessionManager.mCurrentThreadId:Landroid/telecom/Logging/SessionManager$ICurrentThreadId;
invokeinterface android.telecom.Logging.SessionManager$ICurrentThreadId.get:()I
ireturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/telecom/Logging/SessionManager;
public synchronized void cleanupStaleSessions(long);
descriptor: (J)V
flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
Code:
stack=4, locals=10, args_size=2
start local 0 start local 1 0: ldc "Stale Sessions Cleaned:\n"
astore 3
start local 3 1: iconst_0
istore 4
start local 4 2: invokestatic java.lang.System.currentTimeMillis:()J
lstore 5
start local 5 3: aload 0
getfield android.telecom.Logging.SessionManager.mSessionMapper:Ljava/util/concurrent/ConcurrentHashMap;
invokevirtual java.util.concurrent.ConcurrentHashMap.entrySet:()Ljava/util/Set;
invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
4: astore 7
start local 7 5: goto 12
6: StackMap locals: android.telecom.Logging.SessionManager long java.lang.String int long java.util.Iterator
StackMap stack:
aload 7
invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
checkcast java.util.Map$Entry
astore 8
start local 8 7: aload 8
invokeinterface java.util.Map$Entry.getValue:()Ljava/lang/Object;
checkcast android.telecom.Logging.Session
astore 9
start local 9 8: lload 5
aload 9
invokevirtual android.telecom.Logging.Session.getExecutionStartTimeMilliseconds:()J
lsub
lload 1
lcmp
ifle 12
9: aload 7
invokeinterface java.util.Iterator.remove:()V
10: new java.lang.StringBuilder
dup
aload 3
invokestatic java.lang.String.valueOf:(Ljava/lang/Object;)Ljava/lang/String;
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
aload 9
invokevirtual android.telecom.Logging.Session.printFullSessionTree:()Ljava/lang/String;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
ldc "\n"
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
astore 3
11: iconst_1
istore 4
end local 9 end local 8 12: StackMap locals:
StackMap stack:
aload 7
invokeinterface java.util.Iterator.hasNext:()Z
ifne 6
end local 7 13: iload 4
ifeq 16
14: ldc "Logging"
aload 3
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.w:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
15: goto 17
16: StackMap locals:
StackMap stack:
ldc "Logging"
ldc "No stale logging sessions needed to be cleaned..."
iconst_0
anewarray java.lang.Object
invokestatic android.telecom.Log.v:(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
17: StackMap locals:
StackMap stack:
return
end local 5 end local 4 end local 3 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 18 0 this Landroid/telecom/Logging/SessionManager;
0 18 1 timeoutMs J
1 18 3 logMessage Ljava/lang/String;
2 18 4 isSessionsStale Z
3 18 5 currentTimeMs J
5 13 7 it Ljava/util/Iterator<Ljava/util/Map$Entry<Ljava/lang/Integer;Landroid/telecom/Logging/Session;>;>;
7 12 8 entry Ljava/util/Map$Entry<Ljava/lang/Integer;Landroid/telecom/Logging/Session;>;
8 12 9 session Landroid/telecom/Logging/Session;
RuntimeInvisibleAnnotations:
com.android.internal.annotations.VisibleForTesting()
MethodParameters:
Name Flags
timeoutMs
private long getCleanupTimeout(android.content.Context);
descriptor: (Landroid/content/Context;)J
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 1
invokevirtual android.content.Context.getContentResolver:()Landroid/content/ContentResolver;
ldc "telecom.stale_session_cleanup_timeout_millis"
1: ldc 30000
2: invokestatic android.provider.Settings$Secure.getLong:(Landroid/content/ContentResolver;Ljava/lang/String;J)J
lreturn
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/telecom/Logging/SessionManager;
0 3 1 context Landroid/content/Context;
MethodParameters:
Name Flags
context
private void lambda$0();
descriptor: ()V
flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
Code:
stack=3, locals=1, args_size=1
start local 0 0: aload 0
aload 0
invokevirtual android.telecom.Logging.SessionManager.getSessionCleanupTimeoutMs:()J
invokevirtual android.telecom.Logging.SessionManager.cleanupStaleSessions:(J)V
return
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Landroid/telecom/Logging/SessionManager;
private long lambda$2();
descriptor: ()J
flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
Code:
stack=2, locals=1, args_size=1
start local 0 0: aload 0
getfield android.telecom.Logging.SessionManager.mContext:Landroid/content/Context;
ifnonnull 2
1: ldc 30000
lreturn
2: StackMap locals:
StackMap stack:
aload 0
aload 0
getfield android.telecom.Logging.SessionManager.mContext:Landroid/content/Context;
invokevirtual android.telecom.Logging.SessionManager.getCleanupTimeout:(Landroid/content/Context;)J
lreturn
end local 0 LocalVariableTable:
Start End Slot Name Signature
0 3 0 this Landroid/telecom/Logging/SessionManager;
}
SourceFile: "SessionManager.java"
NestMembers:
android.telecom.Logging.SessionManager$ICurrentThreadId android.telecom.Logging.SessionManager$ISessionCleanupTimeoutMs android.telecom.Logging.SessionManager$ISessionIdQueryHandler android.telecom.Logging.SessionManager$ISessionListener
InnerClasses:
public final Secure = android.provider.Settings$Secure of android.provider.Settings
public Info = android.telecom.Logging.Session$Info of android.telecom.Logging.Session
public abstract ICurrentThreadId = android.telecom.Logging.SessionManager$ICurrentThreadId of android.telecom.Logging.SessionManager
private abstract ISessionCleanupTimeoutMs = android.telecom.Logging.SessionManager$ISessionCleanupTimeoutMs of android.telecom.Logging.SessionManager
public abstract ISessionIdQueryHandler = android.telecom.Logging.SessionManager$ISessionIdQueryHandler of android.telecom.Logging.SessionManager
public abstract ISessionListener = android.telecom.Logging.SessionManager$ISessionListener of android.telecom.Logging.SessionManager
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
public abstract Entry = java.util.Map$Entry of java.util.Map