f.smali
.class final Lcom/cleanmaster/service/scantree/f;
.super Ljava/lang/Object;
.source "TaskExecutors.java"
# interfaces
.implements Ljava/util/concurrent/RejectedExecutionHandler;
# direct methods
.method constructor <init>()V
.registers 1
.prologue
.line 32
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public rejectedExecution(Ljava/lang/Runnable;Ljava/util/concurrent/ThreadPoolExecutor;)V
.registers 12
.prologue
.line 34
sget-object v0, Ljava/lang/System;->out:Ljava/io/PrintStream;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "SDTree_TaskExecutors Exceeded ThreadPoolExecutor pool size "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/io/PrintStream;->println(Ljava/lang/String;)V
.line 35
monitor-enter p0
.line 36
:try_start_19
invoke-static {}, Lcom/cleanmaster/service/scantree/d;->b()Ljava/util/concurrent/ThreadPoolExecutor;
move-result-object v0
if-nez v0, :cond_45
.line 37
new-instance v0, Ljava/util/concurrent/LinkedBlockingQueue;
invoke-direct {v0}, Ljava/util/concurrent/LinkedBlockingQueue;-><init>()V
invoke-static {v0}, Lcom/cleanmaster/service/scantree/d;->a(Ljava/util/concurrent/LinkedBlockingQueue;)Ljava/util/concurrent/LinkedBlockingQueue;
.line 38
new-instance v1, Ljava/util/concurrent/ThreadPoolExecutor;
const/4 v2, 0x5
const/4 v3, 0x5
const-wide/16 v4, 0x3
sget-object v6, Ljava/util/concurrent/TimeUnit;->SECONDS:Ljava/util/concurrent/TimeUnit;
.line 40
invoke-static {}, Lcom/cleanmaster/service/scantree/d;->c()Ljava/util/concurrent/LinkedBlockingQueue;
move-result-object v7
invoke-static {}, Lcom/cleanmaster/service/scantree/d;->d()Ljava/util/concurrent/ThreadFactory;
move-result-object v8
invoke-direct/range {v1 .. v8}, Ljava/util/concurrent/ThreadPoolExecutor;-><init>(IIJLjava/util/concurrent/TimeUnit;Ljava/util/concurrent/BlockingQueue;Ljava/util/concurrent/ThreadFactory;)V
.line 38
invoke-static {v1}, Lcom/cleanmaster/service/scantree/d;->a(Ljava/util/concurrent/ThreadPoolExecutor;)Ljava/util/concurrent/ThreadPoolExecutor;
.line 41
invoke-static {}, Lcom/cleanmaster/service/scantree/d;->b()Ljava/util/concurrent/ThreadPoolExecutor;
move-result-object v0
const/4 v1, 0x1
invoke-virtual {v0, v1}, Ljava/util/concurrent/ThreadPoolExecutor;->allowCoreThreadTimeOut(Z)V
.line 43
:cond_45
monitor-exit p0
:try_end_46
.catchall {:try_start_19 .. :try_end_46} :catchall_4e
.line 44
invoke-static {}, Lcom/cleanmaster/service/scantree/d;->b()Ljava/util/concurrent/ThreadPoolExecutor;
move-result-object v0
invoke-virtual {v0, p1}, Ljava/util/concurrent/ThreadPoolExecutor;->execute(Ljava/lang/Runnable;)V
.line 45
return-void
.line 43
:catchall_4e
move-exception v0
:try_start_4f
monitor-exit p0
:try_end_50
.catchall {:try_start_4f .. :try_end_50} :catchall_4e
throw v0
.end method