DynamiteClearcutLogger.smali
.class public Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation build Landroidx/annotation/Keep;
.end annotation
# static fields
.field private static final zzbn:Ljava/util/concurrent/ThreadPoolExecutor;
# instance fields
.field private zzbo:Lcom/google/android/gms/vision/clearcut/zzb;
.field private zzbp:Lcom/google/android/gms/vision/clearcut/VisionClearcutLogger;
# direct methods
.method public static constructor <clinit>()V
.registers 10
.line 1
sget-object v5, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
new-instance v6, Ljava/util/concurrent/LinkedBlockingQueue;
const/16 v0, 0xa
invoke-direct {v6, v0}, Ljava/util/concurrent/LinkedBlockingQueue;-><init>(I)V
new-instance v7, Ljava/util/concurrent/ThreadPoolExecutor$DiscardPolicy;
invoke-direct {v7}, Ljava/util/concurrent/ThreadPoolExecutor$DiscardPolicy;-><init>()V
.line 2
invoke-static {}, Lcom/garena/android/appkit/logging/a;->C()Z
move-result v0
if-eqz v0, :cond_2a
const/4 v0, 0x0
const-string v1, "com/google/android/gms/vision/clearcut/DynamiteClearcutLogger"
.line 3
invoke-static {v0, v1}, Lcom/garena/android/appkit/logging/a;->t0(Ljava/util/concurrent/ThreadFactory;Ljava/lang/String;)Ljava/util/concurrent/ThreadFactory;
move-result-object v8
const/4 v0, 0x1
const/4 v1, 0x2
const-wide/16 v2, 0x2
const-string v9, "com/shopee/app/asm/fix/threadpool/ResetThreadPoolName"
move-object v4, v5
move-object v5, v6
move-object v6, v8
move-object v8, v9
invoke-static/range {v0 .. v8}, Lcom/garena/android/appkit/logging/a;->S(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;Ljava/util/concurrent/RejectedExecutionHandler;Ljava/lang/String;)Ljava/util/concurrent/ThreadPoolExecutor;
move-result-object v0
goto :goto_34
.line 4
:cond_2a
new-instance v8, Ljava/util/concurrent/ThreadPoolExecutor;
const/4 v1, 0x1
const/4 v2, 0x2
const-wide/16 v3, 0x2
move-object v0, v8
invoke-direct/range {v0 .. v7}, Ljava/util/concurrent/ThreadPoolExecutor;-><init>(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/RejectedExecutionHandler;)V
.line 5
:goto_34
sput-object v0, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->zzbn:Ljava/util/concurrent/ThreadPoolExecutor;
return-void
.end method
.method public constructor <init>(Landroid/content/Context;)V
.registers 5
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Lcom/google/android/gms/vision/clearcut/zzb;
const-wide v1, 0x3fa1111111111111L # 0.03333333333333333
invoke-direct {v0, v1, v2}, Lcom/google/android/gms/vision/clearcut/zzb;-><init>(D)V
iput-object v0, p0, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->zzbo:Lcom/google/android/gms/vision/clearcut/zzb;
.line 3
new-instance v0, Lcom/google/android/gms/vision/clearcut/VisionClearcutLogger;
invoke-direct {v0, p1}, Lcom/google/android/gms/vision/clearcut/VisionClearcutLogger;-><init>(Landroid/content/Context;)V
iput-object v0, p0, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->zzbp:Lcom/google/android/gms/vision/clearcut/VisionClearcutLogger;
return-void
.end method
.method public static INVOKEVIRTUAL_com_google_android_gms_vision_clearcut_DynamiteClearcutLogger_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/ThreadPoolExecutor;Ljava/lang/Runnable;)V
.registers 4
.line 1
invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->b()Z
move-result v0
if-eqz v0, :cond_3a
invoke-static {}, Lcom/shopee/app/asm/anr/threadpool/c;->a()Z
move-result v0
if-eqz v0, :cond_3a
.line 2
:try_start_c
sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 3
sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->b:Landroid/os/Handler;
new-instance v1, Lcom/shopee/app/asm/anr/threadpool/a$b;
invoke-direct {v1, p0, p1}, Lcom/shopee/app/asm/anr/threadpool/a$b;-><init>(Ljava/util/concurrent/Executor;Ljava/lang/Runnable;)V
invoke-virtual {v0, v1}, Landroid/os/Handler;->post(Ljava/lang/Runnable;)Z
:try_end_18
.catchall {:try_start_c .. :try_end_18} :catchall_19
goto :goto_54
:catchall_19
move-exception v0
.line 4
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
sget-object v0, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 5
:try_start_1f
invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_2b
.line 6
sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;
.line 7
invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V
return-void
.line 8
:cond_2b
invoke-virtual {p0, p1}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
:try_end_2e
.catchall {:try_start_1f .. :try_end_2e} :catchall_2f
goto :goto_54
:catchall_2f
move-exception p0
.line 9
sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 10
invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;
move-result-object p1
invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V
goto :goto_54
.line 11
:cond_3a
:try_start_3a
invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_46
.line 12
sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;
.line 13
invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V
return-void
.line 14
:cond_46
invoke-virtual {p0, p1}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
:try_end_49
.catchall {:try_start_3a .. :try_end_49} :catchall_4a
goto :goto_54
:catchall_4a
move-exception p0
.line 15
sget-object p1, Lcom/shopee/app/asm/anr/threadpool/c;->a:Landroid/os/HandlerThread;
.line 16
invoke-static {}, Lcom/shopee/app/apm/c;->d()Lcom/shopee/app/apm/nonfatal/a;
move-result-object p1
invoke-virtual {p1, p0}, Lcom/shopee/app/apm/nonfatal/a;->c(Ljava/lang/Throwable;)V
:goto_54
return-void
.end method
.method public static INVOKEVIRTUAL_com_google_android_gms_vision_clearcut_DynamiteClearcutLogger_com_shopee_app_asm_anr_threadpool_ExecutorProxy_executeThread(Ljava/util/concurrent/ThreadPoolExecutor;Ljava/lang/Runnable;)V
.registers 3
.line 1
invoke-static {p1, p0}, Lcom/shopee/app/asm/anr/threadpool/a;->a(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_c
.line 2
sget-object p0, Lcom/shopee/app/asm/fix/threadpool/global/i;->e:Lcom/shopee/app/asm/fix/threadpool/global/j;
.line 3
invoke-virtual {p0, p1}, Lcom/shopee/app/asm/anr/threadpool/b;->execute(Ljava/lang/Runnable;)V
return-void
.line 4
:cond_c
invoke-static {p0, p1}, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->INVOKEVIRTUAL_com_google_android_gms_vision_clearcut_DynamiteClearcutLogger_com_shopee_app_asm_anr_threadpool_ExecutorProxy_execute(Ljava/util/concurrent/ThreadPoolExecutor;Ljava/lang/Runnable;)V
return-void
.end method
.method public static synthetic zza(Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;)Lcom/google/android/gms/vision/clearcut/VisionClearcutLogger;
.registers 1
.line 4
iget-object p0, p0, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->zzbp:Lcom/google/android/gms/vision/clearcut/VisionClearcutLogger;
return-object p0
.end method
# virtual methods
.method public final zza(ILcom/google/android/gms/internal/vision/zzea$zzo;)V
.registers 5
const/4 v0, 0x3
if-ne p1, v0, :cond_14
.line 1
iget-object v0, p0, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->zzbo:Lcom/google/android/gms/vision/clearcut/zzb;
invoke-virtual {v0}, Lcom/google/android/gms/vision/clearcut/zzb;->tryAcquire()Z
move-result v0
if-nez v0, :cond_14
const/4 p1, 0x0
new-array p1, p1, [Ljava/lang/Object;
const-string p2, "Skipping image analysis log due to rate limiting"
.line 2
invoke-static {p2, p1}, Lcom/google/android/gms/vision/L;->v(Ljava/lang/String;[Ljava/lang/Object;)I
return-void
.line 3
:cond_14
sget-object v0, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->zzbn:Ljava/util/concurrent/ThreadPoolExecutor;
new-instance v1, Lcom/google/android/gms/vision/clearcut/zza;
invoke-direct {v1, p0, p1, p2}, Lcom/google/android/gms/vision/clearcut/zza;-><init>(Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;ILcom/google/android/gms/internal/vision/zzea$zzo;)V
invoke-static {v0, v1}, Lcom/google/android/gms/vision/clearcut/DynamiteClearcutLogger;->INVOKEVIRTUAL_com_google_android_gms_vision_clearcut_DynamiteClearcutLogger_com_shopee_app_asm_anr_threadpool_ExecutorProxy_executeThread(Ljava/util/concurrent/ThreadPoolExecutor;Ljava/lang/Runnable;)V
return-void
.end method