SerializingExecutor$TaskRunner.smali
.class Lio/grpc/internal/SerializingExecutor$TaskRunner;
.super Ljava/lang/Object;
.source "SerializingExecutor.java"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lio/grpc/internal/SerializingExecutor;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x2
name = "TaskRunner"
.end annotation
# instance fields
.field final synthetic this$0:Lio/grpc/internal/SerializingExecutor;
# direct methods
.method private constructor <init>(Lio/grpc/internal/SerializingExecutor;)V
.registers 2
.line 1
iput-object p1, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method synthetic constructor <init>(Lio/grpc/internal/SerializingExecutor;Lio/grpc/internal/SerializingExecutor$1;)V
.registers 3
.line 2
invoke-direct {p0, p1}, Lio/grpc/internal/SerializingExecutor$TaskRunner;-><init>(Lio/grpc/internal/SerializingExecutor;)V
return-void
.end method
# virtual methods
.method public run()V
.registers 9
:goto_0
const/4 v0, 0x0
const/4 v1, 0x1
.line 1
:try_start_2
iget-object v2, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
# getter for: Lio/grpc/internal/SerializingExecutor;->internalLock:Ljava/lang/Object;
invoke-static {v2}, Lio/grpc/internal/SerializingExecutor;->access$100(Lio/grpc/internal/SerializingExecutor;)Ljava/lang/Object;
move-result-object v2
monitor-enter v2
:try_end_9
.catchall {:try_start_2 .. :try_end_9} :catchall_4f
.line 2
:try_start_9
iget-object v3, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
# getter for: Lio/grpc/internal/SerializingExecutor;->isThreadScheduled:Z
invoke-static {v3}, Lio/grpc/internal/SerializingExecutor;->access$200(Lio/grpc/internal/SerializingExecutor;)Z
move-result v3
invoke-static {v3}, Lcom/google/common/base/r;->b(Z)V
.line 3
iget-object v3, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
# getter for: Lio/grpc/internal/SerializingExecutor;->waitQueue:Ljava/util/Queue;
invoke-static {v3}, Lio/grpc/internal/SerializingExecutor;->access$300(Lio/grpc/internal/SerializingExecutor;)Ljava/util/Queue;
move-result-object v3
invoke-interface {v3}, Ljava/util/Queue;->poll()Ljava/lang/Object;
move-result-object v3
check-cast v3, Ljava/lang/Runnable;
if-nez v3, :cond_2b
.line 4
iget-object v3, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
# setter for: Lio/grpc/internal/SerializingExecutor;->isThreadScheduled:Z
invoke-static {v3, v0}, Lio/grpc/internal/SerializingExecutor;->access$202(Lio/grpc/internal/SerializingExecutor;Z)Z
:try_end_25
.catchall {:try_start_9 .. :try_end_25} :catchall_4c
.line 5
:try_start_25
monitor-exit v2
:try_end_26
.catchall {:try_start_25 .. :try_end_26} :catchall_27
return-void
:catchall_27
move-exception v1
move-object v3, v1
const/4 v1, 0x0
goto :goto_4d
.line 6
:cond_2b
:try_start_2b
monitor-exit v2
:try_end_2c
.catchall {:try_start_2b .. :try_end_2c} :catchall_4c
.line 7
:try_start_2c
invoke-interface {v3}, Ljava/lang/Runnable;->run()V
:try_end_2f
.catch Ljava/lang/RuntimeException; {:try_start_2c .. :try_end_2f} :catch_30
.catchall {:try_start_2c .. :try_end_2f} :catchall_4f
goto :goto_0
:catch_30
move-exception v2
.line 8
:try_start_31
# getter for: Lio/grpc/internal/SerializingExecutor;->log:Ljava/util/logging/Logger;
invoke-static {}, Lio/grpc/internal/SerializingExecutor;->access$400()Ljava/util/logging/Logger;
move-result-object v4
sget-object v5, Ljava/util/logging/Level;->SEVERE:Ljava/util/logging/Level;
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "Exception while executing runnable "
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v6, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-virtual {v4, v5, v3, v2}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_4b
.catchall {:try_start_31 .. :try_end_4b} :catchall_4f
goto :goto_0
:catchall_4c
move-exception v3
.line 9
:goto_4d
:try_start_4d
monitor-exit v2
:try_end_4e
.catchall {:try_start_4d .. :try_end_4e} :catchall_4c
:try_start_4e
throw v3
:try_end_4f
.catchall {:try_start_4e .. :try_end_4f} :catchall_4f
:catchall_4f
move-exception v2
if-eqz v1, :cond_63
.line 10
iget-object v1, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
# getter for: Lio/grpc/internal/SerializingExecutor;->internalLock:Ljava/lang/Object;
invoke-static {v1}, Lio/grpc/internal/SerializingExecutor;->access$100(Lio/grpc/internal/SerializingExecutor;)Ljava/lang/Object;
move-result-object v1
monitor-enter v1
.line 11
:try_start_59
iget-object v3, p0, Lio/grpc/internal/SerializingExecutor$TaskRunner;->this$0:Lio/grpc/internal/SerializingExecutor;
# setter for: Lio/grpc/internal/SerializingExecutor;->isThreadScheduled:Z
invoke-static {v3, v0}, Lio/grpc/internal/SerializingExecutor;->access$202(Lio/grpc/internal/SerializingExecutor;Z)Z
.line 12
monitor-exit v1
goto :goto_63
:catchall_60
move-exception v0
monitor-exit v1
:try_end_62
.catchall {:try_start_59 .. :try_end_62} :catchall_60
throw v0
:cond_63
:goto_63
goto :goto_65
:goto_64
throw v2
:goto_65
goto :goto_64
.end method