s.smali
.class public Landroidx/work/impl/utils/s;
.super Ljava/lang/Object;
.source "WorkTimer.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Landroidx/work/impl/utils/s$a;,
Landroidx/work/impl/utils/s$b;
}
.end annotation
# static fields
.field private static final a:Ljava/lang/String;
# instance fields
.field private final b:Ljava/util/concurrent/ThreadFactory;
.field private final c:Ljava/util/concurrent/ScheduledExecutorService;
.field final d:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Landroidx/work/impl/utils/s$b;",
">;"
}
.end annotation
.end field
.field final e:Ljava/util/Map;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Map<",
"Ljava/lang/String;",
"Landroidx/work/impl/utils/s$a;",
">;"
}
.end annotation
.end field
.field final f:Ljava/lang/Object;
# direct methods
.method static constructor <clinit>()V
.registers 1
const-string v0, "WorkTimer"
.line 1
invoke-static {v0}, Landroidx/work/k;->a(Ljava/lang/String;)Ljava/lang/String;
move-result-object v0
sput-object v0, Landroidx/work/impl/utils/s;->a:Ljava/lang/String;
return-void
.end method
.method public constructor <init>()V
.registers 2
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Landroidx/work/impl/utils/r;
invoke-direct {v0, p0}, Landroidx/work/impl/utils/r;-><init>(Landroidx/work/impl/utils/s;)V
iput-object v0, p0, Landroidx/work/impl/utils/s;->b:Ljava/util/concurrent/ThreadFactory;
.line 3
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Landroidx/work/impl/utils/s;->d:Ljava/util/Map;
.line 4
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
iput-object v0, p0, Landroidx/work/impl/utils/s;->e:Ljava/util/Map;
.line 5
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Landroidx/work/impl/utils/s;->f:Ljava/lang/Object;
.line 6
iget-object v0, p0, Landroidx/work/impl/utils/s;->b:Ljava/util/concurrent/ThreadFactory;
invoke-static {v0}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor(Ljava/util/concurrent/ThreadFactory;)Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
iput-object v0, p0, Landroidx/work/impl/utils/s;->c:Ljava/util/concurrent/ScheduledExecutorService;
return-void
.end method
# virtual methods
.method public a()V
.registers 2
.line 14
iget-object v0, p0, Landroidx/work/impl/utils/s;->c:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->isShutdown()Z
move-result v0
if-nez v0, :cond_d
.line 15
iget-object v0, p0, Landroidx/work/impl/utils/s;->c:Ljava/util/concurrent/ScheduledExecutorService;
invoke-interface {v0}, Ljava/util/concurrent/ScheduledExecutorService;->shutdownNow()Ljava/util/List;
:cond_d
return-void
.end method
.method public a(Ljava/lang/String;)V
.registers 8
.line 9
iget-object v0, p0, Landroidx/work/impl/utils/s;->f:Ljava/lang/Object;
monitor-enter v0
.line 10
:try_start_3
iget-object v1, p0, Landroidx/work/impl/utils/s;->d:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Landroidx/work/impl/utils/s$b;
if-eqz v1, :cond_29
.line 11
invoke-static {}, Landroidx/work/k;->a()Landroidx/work/k;
move-result-object v1
sget-object v2, Landroidx/work/impl/utils/s;->a:Ljava/lang/String;
const-string v3, "Stopping timer for %s"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
aput-object p1, v4, v5
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v5, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/k;->a(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 12
iget-object v1, p0, Landroidx/work/impl/utils/s;->e:Ljava/util/Map;
invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object;
.line 13
:cond_29
monitor-exit v0
return-void
:catchall_2b
move-exception p1
monitor-exit v0
:try_end_2d
.catchall {:try_start_3 .. :try_end_2d} :catchall_2b
throw p1
.end method
.method public a(Ljava/lang/String;JLandroidx/work/impl/utils/s$a;)V
.registers 11
.line 1
iget-object v0, p0, Landroidx/work/impl/utils/s;->f:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
invoke-static {}, Landroidx/work/k;->a()Landroidx/work/k;
move-result-object v1
sget-object v2, Landroidx/work/impl/utils/s;->a:Ljava/lang/String;
const-string v3, "Starting timer for %s"
const/4 v4, 0x1
new-array v4, v4, [Ljava/lang/Object;
const/4 v5, 0x0
aput-object p1, v4, v5
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v3
new-array v4, v5, [Ljava/lang/Throwable;
invoke-virtual {v1, v2, v3, v4}, Landroidx/work/k;->a(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V
.line 3
invoke-virtual {p0, p1}, Landroidx/work/impl/utils/s;->a(Ljava/lang/String;)V
.line 4
new-instance v1, Landroidx/work/impl/utils/s$b;
invoke-direct {v1, p0, p1}, Landroidx/work/impl/utils/s$b;-><init>(Landroidx/work/impl/utils/s;Ljava/lang/String;)V
.line 5
iget-object v2, p0, Landroidx/work/impl/utils/s;->d:Ljava/util/Map;
invoke-interface {v2, p1, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 6
iget-object v2, p0, Landroidx/work/impl/utils/s;->e:Ljava/util/Map;
invoke-interface {v2, p1, p4}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 7
iget-object p1, p0, Landroidx/work/impl/utils/s;->c:Ljava/util/concurrent/ScheduledExecutorService;
sget-object p4, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {p1, v1, p2, p3, p4}, Ljava/util/concurrent/ScheduledExecutorService;->schedule(Ljava/lang/Runnable;JLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
.line 8
monitor-exit v0
return-void
:catchall_35
move-exception p1
monitor-exit v0
:try_end_37
.catchall {:try_start_3 .. :try_end_37} :catchall_35
throw p1
.end method