KeepAliveJob.smali

.class public Lim/tpelyyftgw/messenger/KeepAliveJob;
.super Lim/tpelyyftgw/messenger/support/JobIntentService;
.source "KeepAliveJob.java"


# static fields
.field private static volatile countDownLatch:Ljava/util/concurrent/CountDownLatch;

.field private static finishJobByTimeoutRunnable:Ljava/lang/Runnable;

.field private static volatile startingJob:Z

.field private static final sync:Ljava/lang/Object;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .line 15
    new-instance v0, Ljava/lang/Object;

    invoke-direct {v0}, Ljava/lang/Object;-><init>()V

    sput-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->sync:Ljava/lang/Object;

    .line 65
    new-instance v0, Lim/tpelyyftgw/messenger/KeepAliveJob$3;

    invoke-direct {v0}, Lim/tpelyyftgw/messenger/KeepAliveJob$3;-><init>()V

    sput-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->finishJobByTimeoutRunnable:Ljava/lang/Runnable;

    return-void
.end method

.method public constructor <init>()V
    .registers 1

    .line 11
    invoke-direct {p0}, Lim/tpelyyftgw/messenger/support/JobIntentService;-><init>()V

    return-void
.end method

.method static synthetic access$000()Z
    .registers 1

    .line 11
    sget-boolean v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->startingJob:Z

    return v0
.end method

.method static synthetic access$002(Z)Z
    .registers 1
    .param p0, "x0"    # Z

    .line 11
    sput-boolean p0, Lim/tpelyyftgw/messenger/KeepAliveJob;->startingJob:Z

    return p0
.end method

.method static synthetic access$100()Ljava/util/concurrent/CountDownLatch;
    .registers 1

    .line 11
    sget-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->countDownLatch:Ljava/util/concurrent/CountDownLatch;

    return-object v0
.end method

.method static synthetic access$200()Ljava/lang/Object;
    .registers 1

    .line 11
    sget-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->sync:Ljava/lang/Object;

    return-object v0
.end method

.method static synthetic access$300()V
    .registers 0

    .line 11
    invoke-static {}, Lim/tpelyyftgw/messenger/KeepAliveJob;->finishJobInternal()V

    return-void
.end method

.method public static finishJob()V
    .registers 2

    .line 57
    sget-object v0, Lim/tpelyyftgw/messenger/Utilities;->globalQueue:Lim/tpelyyftgw/messenger/DispatchQueue;

    new-instance v1, Lim/tpelyyftgw/messenger/KeepAliveJob$2;

    invoke-direct {v1}, Lim/tpelyyftgw/messenger/KeepAliveJob$2;-><init>()V

    invoke-virtual {v0, v1}, Lim/tpelyyftgw/messenger/DispatchQueue;->postRunnable(Ljava/lang/Runnable;)V

    .line 63
    return-void
.end method

.method private static finishJobInternal()V
    .registers 2

    .line 40
    sget-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->sync:Ljava/lang/Object;

    monitor-enter v0

    .line 41
    :try_start_3
    sget-object v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->countDownLatch:Ljava/util/concurrent/CountDownLatch;

    if-eqz v1, :cond_15

    .line 42
    sget-boolean v1, Lim/tpelyyftgw/messenger/BuildVars;->LOGS_ENABLED:Z

    if-eqz v1, :cond_10

    .line 43
    const-string v1, "finish keep-alive job"

    invoke-static {v1}, Lim/tpelyyftgw/messenger/FileLog;->d(Ljava/lang/String;)V

    .line 45
    :cond_10
    sget-object v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->countDownLatch:Ljava/util/concurrent/CountDownLatch;

    invoke-virtual {v1}, Ljava/util/concurrent/CountDownLatch;->countDown()V

    .line 47
    :cond_15
    sget-boolean v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->startingJob:Z

    if-eqz v1, :cond_25

    .line 48
    sget-boolean v1, Lim/tpelyyftgw/messenger/BuildVars;->LOGS_ENABLED:Z

    if-eqz v1, :cond_22

    .line 49
    const-string v1, "finish queued keep-alive job"

    invoke-static {v1}, Lim/tpelyyftgw/messenger/FileLog;->d(Ljava/lang/String;)V

    .line 51
    :cond_22
    const/4 v1, 0x0

    sput-boolean v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->startingJob:Z

    .line 53
    :cond_25
    monitor-exit v0

    .line 54
    return-void

    .line 53
    :catchall_27
    move-exception v1

    monitor-exit v0
    :try_end_29
    .catchall {:try_start_3 .. :try_end_29} :catchall_27

    throw v1
.end method

.method public static startJob()V
    .registers 2

    .line 18
    sget-object v0, Lim/tpelyyftgw/messenger/Utilities;->globalQueue:Lim/tpelyyftgw/messenger/DispatchQueue;

    new-instance v1, Lim/tpelyyftgw/messenger/KeepAliveJob$1;

    invoke-direct {v1}, Lim/tpelyyftgw/messenger/KeepAliveJob$1;-><init>()V

    invoke-virtual {v0, v1}, Lim/tpelyyftgw/messenger/DispatchQueue;->postRunnable(Ljava/lang/Runnable;)V

    .line 37
    return-void
.end method


# virtual methods
.method protected onHandleWork(Landroid/content/Intent;)V
    .registers 6
    .param p1, "intent"    # Landroid/content/Intent;

    .line 74
    sget-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->sync:Ljava/lang/Object;

    monitor-enter v0

    .line 75
    :try_start_3
    sget-boolean v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->startingJob:Z

    if-nez v1, :cond_9

    .line 76
    monitor-exit v0

    return-void

    .line 78
    :cond_9
    new-instance v1, Ljava/util/concurrent/CountDownLatch;

    const/4 v2, 0x1

    invoke-direct {v1, v2}, Ljava/util/concurrent/CountDownLatch;-><init>(I)V

    sput-object v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->countDownLatch:Ljava/util/concurrent/CountDownLatch;

    .line 79
    monitor-exit v0
    :try_end_12
    .catchall {:try_start_3 .. :try_end_12} :catchall_48

    .line 80
    sget-boolean v0, Lim/tpelyyftgw/messenger/BuildVars;->LOGS_ENABLED:Z

    if-eqz v0, :cond_1c

    .line 81
    const-string/jumbo v0, "started keep-alive job"

    invoke-static {v0}, Lim/tpelyyftgw/messenger/FileLog;->d(Ljava/lang/String;)V

    .line 83
    :cond_1c
    sget-object v0, Lim/tpelyyftgw/messenger/Utilities;->globalQueue:Lim/tpelyyftgw/messenger/DispatchQueue;

    sget-object v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->finishJobByTimeoutRunnable:Ljava/lang/Runnable;

    const-wide/32 v2, 0xea60

    invoke-virtual {v0, v1, v2, v3}, Lim/tpelyyftgw/messenger/DispatchQueue;->postRunnable(Ljava/lang/Runnable;J)V

    .line 85
    :try_start_26
    sget-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->countDownLatch:Ljava/util/concurrent/CountDownLatch;

    invoke-virtual {v0}, Ljava/util/concurrent/CountDownLatch;->await()V
    :try_end_2b
    .catchall {:try_start_26 .. :try_end_2b} :catchall_2c

    .line 88
    goto :goto_2d

    .line 86
    :catchall_2c
    move-exception v0

    .line 89
    :goto_2d
    sget-object v0, Lim/tpelyyftgw/messenger/Utilities;->globalQueue:Lim/tpelyyftgw/messenger/DispatchQueue;

    sget-object v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->finishJobByTimeoutRunnable:Ljava/lang/Runnable;

    invoke-virtual {v0, v1}, Lim/tpelyyftgw/messenger/DispatchQueue;->cancelRunnable(Ljava/lang/Runnable;)V

    .line 90
    sget-object v1, Lim/tpelyyftgw/messenger/KeepAliveJob;->sync:Ljava/lang/Object;

    monitor-enter v1

    .line 91
    const/4 v0, 0x0

    :try_start_38
    sput-object v0, Lim/tpelyyftgw/messenger/KeepAliveJob;->countDownLatch:Ljava/util/concurrent/CountDownLatch;

    .line 92
    monitor-exit v1
    :try_end_3b
    .catchall {:try_start_38 .. :try_end_3b} :catchall_45

    .line 93
    sget-boolean v0, Lim/tpelyyftgw/messenger/BuildVars;->LOGS_ENABLED:Z

    if-eqz v0, :cond_44

    .line 94
    const-string v0, "ended keep-alive job"

    invoke-static {v0}, Lim/tpelyyftgw/messenger/FileLog;->d(Ljava/lang/String;)V

    .line 96
    :cond_44
    return-void

    .line 92
    :catchall_45
    move-exception v0

    :try_start_46
    monitor-exit v1
    :try_end_47
    .catchall {:try_start_46 .. :try_end_47} :catchall_45

    throw v0

    .line 79
    :catchall_48
    move-exception v1

    :try_start_49
    monitor-exit v0
    :try_end_4a
    .catchall {:try_start_49 .. :try_end_4a} :catchall_48

    throw v1
.end method