zze.smali
.class final Lcom/google/android/gms/common/internal/zze;
.super Lcom/google/android/gms/common/internal/GmsClientSupervisor;
# interfaces
.implements Landroid/os/Handler$Callback;
# instance fields
.field private final mHandler:Landroid/os/Handler;
.field private final zzdu:Ljava/util/HashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/HashMap<",
"Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;",
"Lcom/google/android/gms/common/internal/zzf;",
">;"
}
.end annotation
.end field
.field private final zzdv:Landroid/content/Context;
.field private final zzdw:Lcom/google/android/gms/common/stats/ConnectionTracker;
.field private final zzdx:J
.field private final zzdy:J
# direct methods
.method static constructor <clinit>()V
.registers 1
return-void
.end method
.method constructor <init>(Landroid/content/Context;)V
.registers 4
.line 1
invoke-direct {p0}, Lcom/google/android/gms/common/internal/GmsClientSupervisor;-><init>()V
.line 2
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
.line 3
invoke-virtual {p1}, Landroid/content/Context;->getApplicationContext()Landroid/content/Context;
move-result-object v0
iput-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdv:Landroid/content/Context;
.line 4
new-instance v0, Lcom/google/android/gms/internal/common/zze;
invoke-virtual {p1}, Landroid/content/Context;->getMainLooper()Landroid/os/Looper;
move-result-object p1
invoke-direct {v0, p1, p0}, Lcom/google/android/gms/internal/common/zze;-><init>(Landroid/os/Looper;Landroid/os/Handler$Callback;)V
iput-object v0, p0, Lcom/google/android/gms/common/internal/zze;->mHandler:Landroid/os/Handler;
.line 5
invoke-static {}, Lcom/google/android/gms/common/stats/ConnectionTracker;->getInstance()Lcom/google/android/gms/common/stats/ConnectionTracker;
move-result-object p1
iput-object p1, p0, Lcom/google/android/gms/common/internal/zze;->zzdw:Lcom/google/android/gms/common/stats/ConnectionTracker;
.line 6
const-wide/16 v0, 0x1388
iput-wide v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdx:J
.line 7
const-wide/32 v0, 0x493e0
iput-wide v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdy:J
.line 8
return-void
.end method
.method static synthetic zza(Lcom/google/android/gms/common/internal/zze;)Ljava/util/HashMap;
.registers 1
.line 63
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
return-object p0
.end method
.method static synthetic zzb(Lcom/google/android/gms/common/internal/zze;)Landroid/os/Handler;
.registers 1
.line 64
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->mHandler:Landroid/os/Handler;
return-object p0
.end method
.method static synthetic zzc(Lcom/google/android/gms/common/internal/zze;)Landroid/content/Context;
.registers 1
.line 65
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->zzdv:Landroid/content/Context;
return-object p0
.end method
.method static synthetic zzd(Lcom/google/android/gms/common/internal/zze;)Lcom/google/android/gms/common/stats/ConnectionTracker;
.registers 1
.line 66
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->zzdw:Lcom/google/android/gms/common/stats/ConnectionTracker;
return-object p0
.end method
.method static synthetic zze(Lcom/google/android/gms/common/internal/zze;)J
.registers 3
.line 67
iget-wide v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdy:J
return-wide v0
.end method
# virtual methods
.method public final handleMessage(Landroid/os/Message;)Z
.registers 9
.line 39
iget v0, p1, Landroid/os/Message;->what:I
const/4 v1, 0x1
if-eqz v0, :cond_6a
if-eq v0, v1, :cond_9
.line 62
const/4 p1, 0x0
return p1
.line 49
:cond_9
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
.line 50
:try_start_c
iget-object p1, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
check-cast p1, Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;
.line 51
iget-object v2, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
invoke-virtual {v2, p1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/google/android/gms/common/internal/zzf;
.line 52
if-eqz v2, :cond_65
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->getState()I
move-result v3
const/4 v4, 0x3
if-ne v3, v4, :cond_65
.line 53
const-string v3, "GmsClientSupervisor"
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v4
invoke-static {v4}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object v5
invoke-virtual {v5}, Ljava/lang/String;->length()I
move-result v5
add-int/lit8 v5, v5, 0x2f
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6, v5}, Ljava/lang/StringBuilder;-><init>(I)V
const-string v5, "Timeout waiting for ServiceConnection callback "
invoke-virtual {v6, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v4
new-instance v5, Ljava/lang/Exception;
invoke-direct {v5}, Ljava/lang/Exception;-><init>()V
invoke-static {v3, v4, v5}, Landroid/util/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 54
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->getComponentName()Landroid/content/ComponentName;
move-result-object v3
.line 55
if-nez v3, :cond_54
.line 56
invoke-virtual {p1}, Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;->getComponentName()Landroid/content/ComponentName;
move-result-object v3
.line 57
:cond_54
if-nez v3, :cond_62
.line 58
new-instance v3, Landroid/content/ComponentName;
invoke-virtual {p1}, Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;->getPackage()Ljava/lang/String;
move-result-object p1
const-string/jumbo v4, "unknown"
invoke-direct {v3, p1, v4}, Landroid/content/ComponentName;-><init>(Ljava/lang/String;Ljava/lang/String;)V
.line 59
:cond_62
invoke-virtual {v2, v3}, Lcom/google/android/gms/common/internal/zzf;->onServiceDisconnected(Landroid/content/ComponentName;)V
.line 60
:cond_65
monitor-exit v0
.line 61
return v1
.line 60
:catchall_67
move-exception p1
monitor-exit v0
:try_end_69
.catchall {:try_start_c .. :try_end_69} :catchall_67
throw p1
.line 40
:cond_6a
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
.line 41
:try_start_6d
iget-object p1, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
check-cast p1, Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;
.line 42
iget-object v2, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
invoke-virtual {v2, p1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lcom/google/android/gms/common/internal/zzf;
.line 43
if-eqz v2, :cond_91
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->zzr()Z
move-result v3
if-eqz v3, :cond_91
.line 44
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->isBound()Z
move-result v3
if-eqz v3, :cond_8c
.line 45
const-string v3, "GmsClientSupervisor"
invoke-virtual {v2, v3}, Lcom/google/android/gms/common/internal/zzf;->zzf(Ljava/lang/String;)V
.line 46
:cond_8c
iget-object v2, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
invoke-virtual {v2, p1}, Ljava/util/HashMap;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 47
:cond_91
monitor-exit v0
.line 48
return v1
.line 47
:catchall_93
move-exception p1
monitor-exit v0
:try_end_95
.catchall {:try_start_6d .. :try_end_95} :catchall_93
throw p1
.end method
.method protected final zza(Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;Landroid/content/ServiceConnection;Ljava/lang/String;)Z
.registers 8
.line 9
const-string v0, "ServiceConnection must not be null"
invoke-static {p2, v0}, Lcom/google/android/gms/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 10
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
.line 11
:try_start_8
iget-object v1, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
invoke-virtual {v1, p1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/android/gms/common/internal/zzf;
.line 12
if-nez v1, :cond_23
.line 13
new-instance v1, Lcom/google/android/gms/common/internal/zzf;
invoke-direct {v1, p0, p1}, Lcom/google/android/gms/common/internal/zzf;-><init>(Lcom/google/android/gms/common/internal/zze;Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;)V
.line 14
invoke-virtual {v1, p2, p3}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;Ljava/lang/String;)V
.line 15
invoke-virtual {v1, p3}, Lcom/google/android/gms/common/internal/zzf;->zze(Ljava/lang/String;)V
.line 16
iget-object p2, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
invoke-virtual {p2, p1, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_4d
.line 17
:cond_23
iget-object v2, p0, Lcom/google/android/gms/common/internal/zze;->mHandler:Landroid/os/Handler;
const/4 v3, 0x0
invoke-virtual {v2, v3, p1}, Landroid/os/Handler;->removeMessages(ILjava/lang/Object;)V
.line 18
invoke-virtual {v1, p2}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;)Z
move-result v2
if-nez v2, :cond_53
.line 20
invoke-virtual {v1, p2, p3}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;Ljava/lang/String;)V
.line 21
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->getState()I
move-result p1
const/4 v2, 0x1
if-eq p1, v2, :cond_41
const/4 p2, 0x2
if-eq p1, p2, :cond_3d
goto :goto_4d
.line 24
:cond_3d
invoke-virtual {v1, p3}, Lcom/google/android/gms/common/internal/zzf;->zze(Ljava/lang/String;)V
goto :goto_4d
.line 22
:cond_41
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->getComponentName()Landroid/content/ComponentName;
move-result-object p1
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->getBinder()Landroid/os/IBinder;
move-result-object p3
invoke-interface {p2, p1, p3}, Landroid/content/ServiceConnection;->onServiceConnected(Landroid/content/ComponentName;Landroid/os/IBinder;)V
.line 23
nop
.line 25
:goto_4d
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->isBound()Z
move-result p1
monitor-exit v0
return p1
.line 19
:cond_53
new-instance p2, Ljava/lang/IllegalStateException;
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p3
invoke-virtual {p3}, Ljava/lang/String;->length()I
move-result p3
add-int/lit8 p3, p3, 0x51
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1, p3}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p3, "Trying to bind a GmsServiceConnection that was already connected before. config="
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p2
.line 26
:catchall_78
move-exception p1
monitor-exit v0
:try_end_7a
.catchall {:try_start_8 .. :try_end_7a} :catchall_78
throw p1
.end method
.method protected final zzb(Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;Landroid/content/ServiceConnection;Ljava/lang/String;)V
.registers 7
.line 27
const-string v0, "ServiceConnection must not be null"
invoke-static {p2, v0}, Lcom/google/android/gms/common/internal/Preconditions;->checkNotNull(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 28
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
.line 29
:try_start_8
iget-object v1, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
invoke-virtual {v1, p1}, Ljava/util/HashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/google/android/gms/common/internal/zzf;
.line 30
if-eqz v1, :cond_56
.line 32
invoke-virtual {v1, p2}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;)Z
move-result v2
if-eqz v2, :cond_31
.line 34
invoke-virtual {v1, p2, p3}, Lcom/google/android/gms/common/internal/zzf;->zzb(Landroid/content/ServiceConnection;Ljava/lang/String;)V
.line 35
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->zzr()Z
move-result p2
if-eqz p2, :cond_2f
.line 36
iget-object p2, p0, Lcom/google/android/gms/common/internal/zze;->mHandler:Landroid/os/Handler;
const/4 p3, 0x0
invoke-virtual {p2, p3, p1}, Landroid/os/Handler;->obtainMessage(ILjava/lang/Object;)Landroid/os/Message;
move-result-object p1
.line 37
iget-object p2, p0, Lcom/google/android/gms/common/internal/zze;->mHandler:Landroid/os/Handler;
iget-wide v1, p0, Lcom/google/android/gms/common/internal/zze;->zzdx:J
invoke-virtual {p2, p1, v1, v2}, Landroid/os/Handler;->sendMessageDelayed(Landroid/os/Message;J)Z
.line 38
:cond_2f
monitor-exit v0
return-void
.line 33
:cond_31
new-instance p2, Ljava/lang/IllegalStateException;
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p3
invoke-virtual {p3}, Ljava/lang/String;->length()I
move-result p3
add-int/lit8 p3, p3, 0x4c
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1, p3}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p3, "Trying to unbind a GmsServiceConnection that was not bound before. config="
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p2
.line 31
:cond_56
new-instance p2, Ljava/lang/IllegalStateException;
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p1
invoke-static {p1}, Ljava/lang/String;->valueOf(Ljava/lang/Object;)Ljava/lang/String;
move-result-object p3
invoke-virtual {p3}, Ljava/lang/String;->length()I
move-result p3
add-int/lit8 p3, p3, 0x32
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1, p3}, Ljava/lang/StringBuilder;-><init>(I)V
const-string p3, "Nonexistent connection status for service config: "
invoke-virtual {v1, p3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p2
.line 38
:catchall_7b
move-exception p1
monitor-exit v0
:try_end_7d
.catchall {:try_start_8 .. :try_end_7d} :catchall_7b
throw p1
.end method