SerializeReentrantCallsDirectExecutor.smali
.class Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;
.super Ljava/lang/Object;
.source "SerializeReentrantCallsDirectExecutor.java"
# interfaces
.implements Ljava/util/concurrent/Executor;
# static fields
.field private static final log:Ljava/util/logging/Logger;
# instance fields
.field private executing:Z
.field private taskQueue:Ljava/util/ArrayDeque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayDeque<",
"Ljava/lang/Runnable;",
">;"
}
.end annotation
.end field
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 1
const-class v0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;
.line 2
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;
move-result-object v0
sput-object v0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->log:Ljava/util/logging/Logger;
return-void
.end method
.method constructor <init>()V
.registers 1
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method private completeQueuedTasks()V
.registers 7
.line 1
:goto_0
iget-object v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0}, Ljava/util/ArrayDeque;->poll()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/lang/Runnable;
if-eqz v0, :cond_28
.line 2
:try_start_a
invoke-interface {v0}, Ljava/lang/Runnable;->run()V
:try_end_d
.catch Ljava/lang/Throwable; {:try_start_a .. :try_end_d} :catch_e
goto :goto_0
:catch_e
move-exception v1
.line 3
sget-object v2, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->log:Ljava/util/logging/Logger;
sget-object v3, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Exception while executing runnable "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v2, v3, v0, v1}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_0
:cond_28
return-void
.end method
.method private enqueue(Ljava/lang/Runnable;)V
.registers 4
.line 1
iget-object v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
if-nez v0, :cond_c
.line 2
new-instance v0, Ljava/util/ArrayDeque;
const/4 v1, 0x4
invoke-direct {v0, v1}, Ljava/util/ArrayDeque;-><init>(I)V
iput-object v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
.line 3
:cond_c
iget-object v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
invoke-virtual {v0, p1}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
return-void
.end method
# virtual methods
.method public execute(Ljava/lang/Runnable;)V
.registers 8
const-string v0, "\'task\' must not be null."
.line 1
invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 2
iget-boolean v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->executing:Z
if-nez v0, :cond_44
const/4 v0, 0x1
.line 3
iput-boolean v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->executing:Z
const/4 v0, 0x0
.line 4
:try_start_d
invoke-interface {p1}, Ljava/lang/Runnable;->run()V
:try_end_10
.catch Ljava/lang/Throwable; {:try_start_d .. :try_end_10} :catch_1c
.catchall {:try_start_d .. :try_end_10} :catchall_1a
.line 5
iget-object p1, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
if-eqz p1, :cond_17
.line 6
:goto_14
invoke-direct {p0}, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->completeQueuedTasks()V
.line 7
:cond_17
iput-boolean v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->executing:Z
goto :goto_47
:catchall_1a
move-exception p1
goto :goto_3a
:catch_1c
move-exception v1
.line 8
:try_start_1d
sget-object v2, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->log:Ljava/util/logging/Logger;
sget-object v3, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;
new-instance v4, Ljava/lang/StringBuilder;
invoke-direct {v4}, Ljava/lang/StringBuilder;-><init>()V
const-string v5, "Exception while executing runnable "
invoke-virtual {v4, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v4, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v4}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-virtual {v2, v3, p1, v1}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_35
.catchall {:try_start_1d .. :try_end_35} :catchall_1a
.line 9
iget-object p1, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
if-eqz p1, :cond_17
goto :goto_14
:goto_3a
iget-object v1, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->taskQueue:Ljava/util/ArrayDeque;
if-eqz v1, :cond_41
.line 10
invoke-direct {p0}, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->completeQueuedTasks()V
.line 11
:cond_41
iput-boolean v0, p0, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->executing:Z
throw p1
.line 12
:cond_44
invoke-direct {p0, p1}, Lio/grpc/internal/SerializeReentrantCallsDirectExecutor;->enqueue(Ljava/lang/Runnable;)V
:goto_47
return-void
.end method