zze.smali
.class public 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 public final mHandler:Landroid/os/Handler;
.field public 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
.annotation build Ljavax/annotation/concurrent/GuardedBy;
value = "mConnectionStatus"
.end annotation
.end field
.field public final zzdv:Landroid/content/Context;
.field public final zzdw:Lcom/google/android/gms/common/stats/ConnectionTracker;
.field public final zzdx:J
.field public final zzdy:J
# direct methods
.method static constructor <clinit>()V
.registers 1
return-void
.end method
.method public constructor <init>(Landroid/content/Context;)V
.registers 4
invoke-direct {p0}, Lcom/google/android/gms/common/internal/GmsClientSupervisor;-><init>()V
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;
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;
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;
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;
const-wide/16 v0, 0x1388
iput-wide v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdx:J
const-wide/32 v0, 0x493e0
iput-wide v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdy:J
return-void
.end method
.method public static synthetic zza(Lcom/google/android/gms/common/internal/zze;)Ljava/util/HashMap;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
return-object p0
.end method
.method public static synthetic zzb(Lcom/google/android/gms/common/internal/zze;)Landroid/os/Handler;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->mHandler:Landroid/os/Handler;
return-object p0
.end method
.method public static synthetic zzc(Lcom/google/android/gms/common/internal/zze;)Landroid/content/Context;
.registers 1
iget-object p0, p0, Lcom/google/android/gms/common/internal/zze;->zzdv:Landroid/content/Context;
return-object p0
.end method
.method public static synthetic zzd(Lcom/google/android/gms/common/internal/zze;)Lcom/google/android/gms/common/stats/ConnectionTracker;
.registers 1
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 public static synthetic zze(Lcom/google/android/gms/common/internal/zze;)J
.registers 3
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
iget v0, p1, Landroid/os/Message;->what:I
const/4 v1, 0x1
if-eqz v0, :cond_69
if-eq v0, v1, :cond_9
const/4 p1, 0x0
return p1
:cond_9
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
: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;
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;
if-eqz v2, :cond_64
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->getState()I
move-result v3
const/4 v4, 0x3
if-ne v3, v4, :cond_64
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
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->getComponentName()Landroid/content/ComponentName;
move-result-object v3
if-nez v3, :cond_54
invoke-virtual {p1}, Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;->getComponentName()Landroid/content/ComponentName;
move-result-object v3
:cond_54
if-nez v3, :cond_61
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 v4, "unknown"
invoke-direct {v3, p1, v4}, Landroid/content/ComponentName;-><init>(Ljava/lang/String;Ljava/lang/String;)V
:cond_61
invoke-virtual {v2, v3}, Lcom/google/android/gms/common/internal/zzf;->onServiceDisconnected(Landroid/content/ComponentName;)V
:cond_64
monitor-exit v0
return v1
:catchall_66
move-exception p1
monitor-exit v0
:try_end_68
.catchall {:try_start_c .. :try_end_68} :catchall_66
throw p1
:cond_69
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
:try_start_6c
iget-object p1, p1, Landroid/os/Message;->obj:Ljava/lang/Object;
check-cast p1, Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;
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;
if-eqz v2, :cond_90
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->zzr()Z
move-result v3
if-eqz v3, :cond_90
invoke-virtual {v2}, Lcom/google/android/gms/common/internal/zzf;->isBound()Z
move-result v3
if-eqz v3, :cond_8b
const-string v3, "GmsClientSupervisor"
invoke-virtual {v2, v3}, Lcom/google/android/gms/common/internal/zzf;->zzf(Ljava/lang/String;)V
:cond_8b
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;
:cond_90
monitor-exit v0
return v1
:catchall_92
move-exception p1
monitor-exit v0
:try_end_94
.catchall {:try_start_6c .. :try_end_94} :catchall_92
throw p1
.end method
.method public final zza(Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;Landroid/content/ServiceConnection;Ljava/lang/String;)Z
.registers 8
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;
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
: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;
if-nez v1, :cond_23
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
invoke-virtual {v1, p2, p3}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;Ljava/lang/String;)V
invoke-virtual {v1, p3}, Lcom/google/android/gms/common/internal/zzf;->zze(Ljava/lang/String;)V
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_4c
: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
invoke-virtual {v1, p2}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;)Z
move-result v2
if-nez v2, :cond_52
invoke-virtual {v1, p2, p3}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;Ljava/lang/String;)V
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_4c
:cond_3d
invoke-virtual {v1, p3}, Lcom/google/android/gms/common/internal/zzf;->zze(Ljava/lang/String;)V
goto :goto_4c
: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
:goto_4c
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->isBound()Z
move-result p1
monitor-exit v0
return p1
:cond_52
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
:catchall_77
move-exception p1
monitor-exit v0
:try_end_79
.catchall {:try_start_8 .. :try_end_79} :catchall_77
throw p1
.end method
.method public final zzb(Lcom/google/android/gms/common/internal/GmsClientSupervisor$zza;Landroid/content/ServiceConnection;Ljava/lang/String;)V
.registers 7
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;
iget-object v0, p0, Lcom/google/android/gms/common/internal/zze;->zzdu:Ljava/util/HashMap;
monitor-enter v0
: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;
if-eqz v1, :cond_56
invoke-virtual {v1, p2}, Lcom/google/android/gms/common/internal/zzf;->zza(Landroid/content/ServiceConnection;)Z
move-result v2
if-eqz v2, :cond_31
invoke-virtual {v1, p2, p3}, Lcom/google/android/gms/common/internal/zzf;->zzb(Landroid/content/ServiceConnection;Ljava/lang/String;)V
invoke-virtual {v1}, Lcom/google/android/gms/common/internal/zzf;->zzr()Z
move-result p2
if-eqz p2, :cond_2f
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
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
:cond_2f
monitor-exit v0
return-void
: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
: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
:catchall_7b
move-exception p1
monitor-exit v0
:try_end_7d
.catchall {:try_start_8 .. :try_end_7d} :catchall_7b
throw p1
.end method