.class public Landroidx/work/impl/utils/WorkTimer; .super Ljava/lang/Object; .source "SourceFile" # annotations .annotation build Landroidx/annotation/RestrictTo; value = { .enum Landroidx/annotation/RestrictTo$Scope;->LIBRARY_GROUP:Landroidx/annotation/RestrictTo$Scope; } .end annotation .annotation system Ldalvik/annotation/MemberClasses; value = { Landroidx/work/impl/utils/WorkTimer$WorkTimerRunnable;, Landroidx/work/impl/utils/WorkTimer$TimeLimitExceededListener; } .end annotation # static fields .field private static final TAG:Ljava/lang/String; # instance fields .field final mListeners:Ljava/util/Map; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/Map<", "Landroidx/work/impl/model/WorkGenerationalId;", "Landroidx/work/impl/utils/WorkTimer$TimeLimitExceededListener;", ">;" } .end annotation .end field .field final mLock:Ljava/lang/Object; .field final mRunnableScheduler:Landroidx/work/RunnableScheduler; .field final mTimerMap:Ljava/util/Map; .annotation system Ldalvik/annotation/Signature; value = { "Ljava/util/Map<", "Landroidx/work/impl/model/WorkGenerationalId;", "Landroidx/work/impl/utils/WorkTimer$WorkTimerRunnable;", ">;" } .end annotation .end field # direct methods .method static constructor ()V .locals 1 const-string v0, "WorkTimer" .line 39 invoke-static {v0}, Landroidx/work/Logger;->tagWithPrefix(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 sput-object v0, Landroidx/work/impl/utils/WorkTimer;->TAG:Ljava/lang/String; return-void .end method .method public constructor (Landroidx/work/RunnableScheduler;)V .locals 1 .param p1 # Landroidx/work/RunnableScheduler; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .line 46 invoke-direct {p0}, Ljava/lang/Object;->()V .line 47 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()V iput-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mTimerMap:Ljava/util/Map; .line 48 new-instance v0, Ljava/util/HashMap; invoke-direct {v0}, Ljava/util/HashMap;->()V iput-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mListeners:Ljava/util/Map; .line 49 new-instance v0, Ljava/lang/Object; invoke-direct {v0}, Ljava/lang/Object;->()V iput-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mLock:Ljava/lang/Object; iput-object p1, p0, Landroidx/work/impl/utils/WorkTimer;->mRunnableScheduler:Landroidx/work/RunnableScheduler; return-void .end method # virtual methods .method public getListeners()Ljava/util/Map; .locals 2 .annotation build Landroidx/annotation/NonNull; .end annotation .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Map<", "Landroidx/work/impl/model/WorkGenerationalId;", "Landroidx/work/impl/utils/WorkTimer$TimeLimitExceededListener;", ">;" } .end annotation iget-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mLock:Ljava/lang/Object; .line 105 monitor-enter v0 :try_start_0 iget-object v1, p0, Landroidx/work/impl/utils/WorkTimer;->mListeners:Ljava/util/Map; .line 106 monitor-exit v0 return-object v1 :catchall_0 move-exception v1 .line 107 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw v1 .end method .method public getTimerMap()Ljava/util/Map; .locals 2 .annotation build Landroidx/annotation/NonNull; .end annotation .annotation build Landroidx/annotation/VisibleForTesting; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Map<", "Landroidx/work/impl/model/WorkGenerationalId;", "Landroidx/work/impl/utils/WorkTimer$WorkTimerRunnable;", ">;" } .end annotation iget-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mLock:Ljava/lang/Object; .line 97 monitor-enter v0 :try_start_0 iget-object v1, p0, Landroidx/work/impl/utils/WorkTimer;->mTimerMap:Ljava/util/Map; .line 98 monitor-exit v0 return-object v1 :catchall_0 move-exception v1 .line 99 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw v1 .end method .method public startTimer(Landroidx/work/impl/model/WorkGenerationalId;JLandroidx/work/impl/utils/WorkTimer$TimeLimitExceededListener;)V .locals 5 .param p1 # Landroidx/work/impl/model/WorkGenerationalId; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p4 # Landroidx/work/impl/utils/WorkTimer$TimeLimitExceededListener; .annotation build Landroidx/annotation/NonNull; .end annotation .end param iget-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mLock:Ljava/lang/Object; .line 68 monitor-enter v0 .line 69 :try_start_0 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v1 sget-object v2, Landroidx/work/impl/utils/WorkTimer;->TAG:Ljava/lang/String; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "Starting timer for " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v1, v2, v3}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V .line 71 invoke-virtual {p0, p1}, Landroidx/work/impl/utils/WorkTimer;->stopTimer(Landroidx/work/impl/model/WorkGenerationalId;)V .line 72 new-instance v1, Landroidx/work/impl/utils/WorkTimer$WorkTimerRunnable; invoke-direct {v1, p0, p1}, Landroidx/work/impl/utils/WorkTimer$WorkTimerRunnable;->(Landroidx/work/impl/utils/WorkTimer;Landroidx/work/impl/model/WorkGenerationalId;)V iget-object v2, p0, Landroidx/work/impl/utils/WorkTimer;->mTimerMap:Ljava/util/Map; .line 73 invoke-interface {v2, p1, v1}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; iget-object v2, p0, Landroidx/work/impl/utils/WorkTimer;->mListeners:Ljava/util/Map; .line 74 invoke-interface {v2, p1, p4}, Ljava/util/Map;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object; iget-object p1, p0, Landroidx/work/impl/utils/WorkTimer;->mRunnableScheduler:Landroidx/work/RunnableScheduler; .line 75 invoke-interface {p1, p2, p3, v1}, Landroidx/work/RunnableScheduler;->scheduleWithDelay(JLjava/lang/Runnable;)V .line 76 monitor-exit v0 return-void :catchall_0 move-exception p1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw p1 .end method .method public stopTimer(Landroidx/work/impl/model/WorkGenerationalId;)V .locals 5 .param p1 # Landroidx/work/impl/model/WorkGenerationalId; .annotation build Landroidx/annotation/NonNull; .end annotation .end param iget-object v0, p0, Landroidx/work/impl/utils/WorkTimer;->mLock:Ljava/lang/Object; .line 85 monitor-enter v0 :try_start_0 iget-object v1, p0, Landroidx/work/impl/utils/WorkTimer;->mTimerMap:Ljava/util/Map; .line 86 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/WorkTimer$WorkTimerRunnable; if-eqz v1, :cond_0 .line 88 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v1 sget-object v2, Landroidx/work/impl/utils/WorkTimer;->TAG:Ljava/lang/String; new-instance v3, Ljava/lang/StringBuilder; invoke-direct {v3}, Ljava/lang/StringBuilder;->()V const-string v4, "Stopping timer for " invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v3, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder; invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object v3 invoke-virtual {v1, v2, v3}, Landroidx/work/Logger;->debug(Ljava/lang/String;Ljava/lang/String;)V iget-object v1, p0, Landroidx/work/impl/utils/WorkTimer;->mListeners:Ljava/util/Map; .line 89 invoke-interface {v1, p1}, Ljava/util/Map;->remove(Ljava/lang/Object;)Ljava/lang/Object; goto :goto_0 :catchall_0 move-exception p1 goto :goto_1 .line 91 :cond_0 :goto_0 monitor-exit v0 return-void :goto_1 monitor-exit v0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw p1 .end method