.class public final Lcom/google/android/gms/internal/ads/zzm; .super Ljava/lang/Thread; .source "com.google.android.gms:play-services-ads@@19.1.0" # instance fields .field private final zzaa:Lcom/google/android/gms/internal/ads/zzn; .field private final zzc:Lcom/google/android/gms/internal/ads/zza; .field private final zzd:Lcom/google/android/gms/internal/ads/zzaa; .field private volatile zze:Z .field private final zzz:Ljava/util/concurrent/BlockingQueue; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/concurrent/BlockingQueue<", "Lcom/google/android/gms/internal/ads/zzq<", "*>;>;" } .end annotation .end field # direct methods .method public constructor (Ljava/util/concurrent/BlockingQueue;Lcom/google/android/gms/internal/ads/zzn;Lcom/google/android/gms/internal/ads/zza;Lcom/google/android/gms/internal/ads/zzaa;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/concurrent/BlockingQueue<", "Lcom/google/android/gms/internal/ads/zzq<", "*>;>;", "Lcom/google/android/gms/internal/ads/zzn;", "Lcom/google/android/gms/internal/ads/zza;", "Lcom/google/android/gms/internal/ads/zzaa;", ")V" } .end annotation .line 1 invoke-direct {p0}, Ljava/lang/Thread;->()V const/4 v0, 0x0 .line 2 iput-boolean v0, p0, Lcom/google/android/gms/internal/ads/zzm;->zze:Z .line 3 iput-object p1, p0, Lcom/google/android/gms/internal/ads/zzm;->zzz:Ljava/util/concurrent/BlockingQueue; .line 4 iput-object p2, p0, Lcom/google/android/gms/internal/ads/zzm;->zzaa:Lcom/google/android/gms/internal/ads/zzn; .line 5 iput-object p3, p0, Lcom/google/android/gms/internal/ads/zzm;->zzc:Lcom/google/android/gms/internal/ads/zza; .line 6 iput-object p4, p0, Lcom/google/android/gms/internal/ads/zzm;->zzd:Lcom/google/android/gms/internal/ads/zzaa; return-void .end method .method private final processRequest()V .locals 9 .annotation system Ldalvik/annotation/Throws; value = { Ljava/lang/InterruptedException; } .end annotation .line 1 iget-object v0, p0, Lcom/google/android/gms/internal/ads/zzm;->zzz:Ljava/util/concurrent/BlockingQueue; invoke-interface {v0}, Ljava/util/concurrent/BlockingQueue;->take()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/android/gms/internal/ads/zzq; .line 2 invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J move-result-wide v1 const/4 v3, 0x3 .line 3 invoke-virtual {v0, v3}, Lcom/google/android/gms/internal/ads/zzq;->zza(I)V const/4 v3, 0x4 :try_start_0 const-string v4, "network-queue-take" .line 4 invoke-virtual {v0, v4}, Lcom/google/android/gms/internal/ads/zzq;->zzb(Ljava/lang/String;)V .line 5 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->isCanceled()Z .line 6 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzd()I move-result v4 invoke-static {v4}, Landroid/net/TrafficStats;->setThreadStatsTag(I)V .line 7 iget-object v4, p0, Lcom/google/android/gms/internal/ads/zzm;->zzaa:Lcom/google/android/gms/internal/ads/zzn; invoke-interface {v4, v0}, Lcom/google/android/gms/internal/ads/zzn;->zzc(Lcom/google/android/gms/internal/ads/zzq;)Lcom/google/android/gms/internal/ads/zzo; move-result-object v4 const-string v5, "network-http-complete" .line 8 invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/ads/zzq;->zzb(Ljava/lang/String;)V .line 9 iget-boolean v5, v4, Lcom/google/android/gms/internal/ads/zzo;->zzac:Z if-eqz v5, :cond_0 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzl()Z move-result v5 if-eqz v5, :cond_0 const-string v4, "not-modified" .line 10 invoke-virtual {v0, v4}, Lcom/google/android/gms/internal/ads/zzq;->zzc(Ljava/lang/String;)V .line 11 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzm()V :try_end_0 .catch Lcom/google/android/gms/internal/ads/zzae; {:try_start_0 .. :try_end_0} :catch_1 .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_0} :catch_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 .line 12 invoke-virtual {v0, v3}, Lcom/google/android/gms/internal/ads/zzq;->zza(I)V return-void .line 13 :cond_0 :try_start_1 invoke-virtual {v0, v4}, Lcom/google/android/gms/internal/ads/zzq;->zza(Lcom/google/android/gms/internal/ads/zzo;)Lcom/google/android/gms/internal/ads/zzz; move-result-object v4 const-string v5, "network-parse-complete" .line 14 invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/ads/zzq;->zzb(Ljava/lang/String;)V .line 15 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzh()Z move-result v5 if-eqz v5, :cond_1 iget-object v5, v4, Lcom/google/android/gms/internal/ads/zzz;->zzbh:Lcom/google/android/gms/internal/ads/zzd; if-eqz v5, :cond_1 .line 16 iget-object v5, p0, Lcom/google/android/gms/internal/ads/zzm;->zzc:Lcom/google/android/gms/internal/ads/zza; invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zze()Ljava/lang/String; move-result-object v6 iget-object v7, v4, Lcom/google/android/gms/internal/ads/zzz;->zzbh:Lcom/google/android/gms/internal/ads/zzd; invoke-interface {v5, v6, v7}, Lcom/google/android/gms/internal/ads/zza;->zza(Ljava/lang/String;Lcom/google/android/gms/internal/ads/zzd;)V const-string v5, "network-cache-written" .line 17 invoke-virtual {v0, v5}, Lcom/google/android/gms/internal/ads/zzq;->zzb(Ljava/lang/String;)V .line 18 :cond_1 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzk()V .line 19 iget-object v5, p0, Lcom/google/android/gms/internal/ads/zzm;->zzd:Lcom/google/android/gms/internal/ads/zzaa; invoke-interface {v5, v0, v4}, Lcom/google/android/gms/internal/ads/zzaa;->zzb(Lcom/google/android/gms/internal/ads/zzq;Lcom/google/android/gms/internal/ads/zzz;)V .line 20 invoke-virtual {v0, v4}, Lcom/google/android/gms/internal/ads/zzq;->zza(Lcom/google/android/gms/internal/ads/zzz;)V :try_end_1 .catch Lcom/google/android/gms/internal/ads/zzae; {:try_start_1 .. :try_end_1} :catch_1 .catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1} :catch_0 .catchall {:try_start_1 .. :try_end_1} :catchall_0 .line 21 invoke-virtual {v0, v3}, Lcom/google/android/gms/internal/ads/zzq;->zza(I)V return-void :catchall_0 move-exception v1 goto :goto_0 :catch_0 move-exception v4 :try_start_2 const-string v5, "Unhandled exception %s" const/4 v6, 0x1 new-array v6, v6, [Ljava/lang/Object; const/4 v7, 0x0 .line 22 invoke-virtual {v4}, Ljava/lang/Exception;->toString()Ljava/lang/String; move-result-object v8 aput-object v8, v6, v7 invoke-static {v4, v5, v6}, Lcom/google/android/gms/internal/ads/zzag;->zza(Ljava/lang/Throwable;Ljava/lang/String;[Ljava/lang/Object;)V .line 23 new-instance v5, Lcom/google/android/gms/internal/ads/zzae; invoke-direct {v5, v4}, Lcom/google/android/gms/internal/ads/zzae;->(Ljava/lang/Throwable;)V .line 24 invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J move-result-wide v6 sub-long/2addr v6, v1 invoke-virtual {v5, v6, v7}, Lcom/google/android/gms/internal/ads/zzae;->zza(J)V .line 25 iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzm;->zzd:Lcom/google/android/gms/internal/ads/zzaa; invoke-interface {v1, v0, v5}, Lcom/google/android/gms/internal/ads/zzaa;->zza(Lcom/google/android/gms/internal/ads/zzq;Lcom/google/android/gms/internal/ads/zzae;)V .line 26 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzm()V :try_end_2 .catchall {:try_start_2 .. :try_end_2} :catchall_0 .line 27 invoke-virtual {v0, v3}, Lcom/google/android/gms/internal/ads/zzq;->zza(I)V return-void :catch_1 move-exception v4 .line 28 :try_start_3 invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J move-result-wide v5 sub-long/2addr v5, v1 invoke-virtual {v4, v5, v6}, Lcom/google/android/gms/internal/ads/zzae;->zza(J)V .line 29 iget-object v1, p0, Lcom/google/android/gms/internal/ads/zzm;->zzd:Lcom/google/android/gms/internal/ads/zzaa; invoke-interface {v1, v0, v4}, Lcom/google/android/gms/internal/ads/zzaa;->zza(Lcom/google/android/gms/internal/ads/zzq;Lcom/google/android/gms/internal/ads/zzae;)V .line 30 invoke-virtual {v0}, Lcom/google/android/gms/internal/ads/zzq;->zzm()V :try_end_3 .catchall {:try_start_3 .. :try_end_3} :catchall_0 .line 31 invoke-virtual {v0, v3}, Lcom/google/android/gms/internal/ads/zzq;->zza(I)V return-void .line 32 :goto_0 invoke-virtual {v0, v3}, Lcom/google/android/gms/internal/ads/zzq;->zza(I)V .line 33 throw v1 .end method # virtual methods .method public final quit()V .locals 1 const/4 v0, 0x1 .line 1 iput-boolean v0, p0, Lcom/google/android/gms/internal/ads/zzm;->zze:Z .line 2 invoke-virtual {p0}, Ljava/lang/Thread;->interrupt()V return-void .end method .method public final run()V .locals 2 const/16 v0, 0xa .line 1 invoke-static {v0}, Landroid/os/Process;->setThreadPriority(I)V .line 2 :goto_0 :try_start_0 invoke-direct {p0}, Lcom/google/android/gms/internal/ads/zzm;->processRequest()V :try_end_0 .catch Ljava/lang/InterruptedException; {:try_start_0 .. :try_end_0} :catch_0 goto :goto_0 .line 3 :catch_0 iget-boolean v0, p0, Lcom/google/android/gms/internal/ads/zzm;->zze:Z if-eqz v0, :cond_0 .line 4 invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread; move-result-object v0 invoke-virtual {v0}, Ljava/lang/Thread;->interrupt()V return-void :cond_0 const/4 v0, 0x0 new-array v0, v0, [Ljava/lang/Object; const-string v1, "Ignoring spurious interrupt of NetworkDispatcher thread; use quit() to terminate it" .line 5 invoke-static {v1, v0}, Lcom/google/android/gms/internal/ads/zzag;->e(Ljava/lang/String;[Ljava/lang/Object;)V goto :goto_0 .end method