.class public Landroidx/work/impl/workers/DiagnosticsWorker; .super Landroidx/work/Worker; .source "DiagnosticsWorker.java" # annotations .annotation build Landroidx/annotation/RestrictTo; value = { .enum Landroidx/annotation/RestrictTo$Scope;->LIBRARY_GROUP:Landroidx/annotation/RestrictTo$Scope; } .end annotation # static fields .field private static final TAG:Ljava/lang/String; # direct methods .method public static constructor ()V .locals 1 const-string v0, "DiagnosticsWrkr" invoke-static {v0}, Landroidx/work/Logger;->tagWithPrefix(Ljava/lang/String;)Ljava/lang/String; move-result-object v0 sput-object v0, Landroidx/work/impl/workers/DiagnosticsWorker;->TAG:Ljava/lang/String; return-void .end method .method public constructor (Landroid/content/Context;Landroidx/work/WorkerParameters;)V .locals 0 .param p1 # Landroid/content/Context; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p2 # Landroidx/work/WorkerParameters; .annotation build Landroidx/annotation/NonNull; .end annotation .end param invoke-direct {p0, p1, p2}, Landroidx/work/Worker;->(Landroid/content/Context;Landroidx/work/WorkerParameters;)V return-void .end method .method private static workSpecRow(Landroidx/work/impl/model/WorkSpec;Ljava/lang/String;Ljava/lang/Integer;Ljava/lang/String;)Ljava/lang/String; .locals 3 .param p0 # Landroidx/work/impl/model/WorkSpec; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p1 # Ljava/lang/String; .annotation build Landroidx/annotation/Nullable; .end annotation .end param .param p2 # Ljava/lang/Integer; .annotation build Landroidx/annotation/Nullable; .end annotation .end param .param p3 # Ljava/lang/String; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/NonNull; .end annotation const/4 v0, 0x6 new-array v0, v0, [Ljava/lang/Object; iget-object v1, p0, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; const/4 v2, 0x0 aput-object v1, v0, v2 iget-object v1, p0, Landroidx/work/impl/model/WorkSpec;->workerClassName:Ljava/lang/String; const/4 v2, 0x1 aput-object v1, v0, v2 const/4 v1, 0x2 aput-object p2, v0, v1 iget-object p0, p0, Landroidx/work/impl/model/WorkSpec;->state:Landroidx/work/WorkInfo$State; invoke-virtual {p0}, Ljava/lang/Enum;->name()Ljava/lang/String; move-result-object p0 const/4 p2, 0x3 aput-object p0, v0, p2 const/4 p0, 0x4 aput-object p1, v0, p0 const/4 p0, 0x5 aput-object p3, v0, p0 const-string p0, "\n%s\t %s\t %s\t %s\t %s\t %s\t" invoke-static {p0, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object p0 return-object p0 .end method .method private static workSpecRows(Landroidx/work/impl/model/WorkNameDao;Landroidx/work/impl/model/WorkTagDao;Landroidx/work/impl/model/SystemIdInfoDao;Ljava/util/List;)Ljava/lang/String; .locals 6 .param p0 # Landroidx/work/impl/model/WorkNameDao; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p1 # Landroidx/work/impl/model/WorkTagDao; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p2 # Landroidx/work/impl/model/SystemIdInfoDao; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .param p3 # Ljava/util/List; .annotation build Landroidx/annotation/NonNull; .end annotation .end param .annotation build Landroidx/annotation/NonNull; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(", "Landroidx/work/impl/model/WorkNameDao;", "Landroidx/work/impl/model/WorkTagDao;", "Landroidx/work/impl/model/SystemIdInfoDao;", "Ljava/util/List<", "Landroidx/work/impl/model/WorkSpec;", ">;)", "Ljava/lang/String;" } .end annotation new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V sget v1, Landroid/os/Build$VERSION;->SDK_INT:I const/16 v2, 0x17 if-lt v1, v2, :cond_0 const-string v1, "Job Id" goto :goto_0 :cond_0 const-string v1, "Alarm Id" :goto_0 const/4 v2, 0x1 new-array v2, v2, [Ljava/lang/Object; const/4 v3, 0x0 aput-object v1, v2, v3 const-string v1, "\n Id \t Class Name\t %s\t State\t Unique Name\t Tags\t" invoke-static {v1, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String; move-result-object v1 invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-interface {p3}, Ljava/util/List;->iterator()Ljava/util/Iterator; move-result-object p3 :goto_1 invoke-interface {p3}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_2 invoke-interface {p3}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v1 check-cast v1, Landroidx/work/impl/model/WorkSpec; const/4 v2, 0x0 iget-object v3, v1, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-interface {p2, v3}, Landroidx/work/impl/model/SystemIdInfoDao;->getSystemIdInfo(Ljava/lang/String;)Landroidx/work/impl/model/SystemIdInfo; move-result-object v3 if-eqz v3, :cond_1 iget v2, v3, Landroidx/work/impl/model/SystemIdInfo;->systemId:I invoke-static {v2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer; move-result-object v2 :cond_1 iget-object v3, v1, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-interface {p0, v3}, Landroidx/work/impl/model/WorkNameDao;->getNamesForWorkSpecId(Ljava/lang/String;)Ljava/util/List; move-result-object v3 iget-object v4, v1, Landroidx/work/impl/model/WorkSpec;->id:Ljava/lang/String; invoke-interface {p1, v4}, Landroidx/work/impl/model/WorkTagDao;->getTagsForWorkSpecId(Ljava/lang/String;)Ljava/util/List; move-result-object v4 const-string v5, "," invoke-static {v5, v3}, Landroid/text/TextUtils;->join(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String; move-result-object v3 invoke-static {v5, v4}, Landroid/text/TextUtils;->join(Ljava/lang/CharSequence;Ljava/lang/Iterable;)Ljava/lang/String; move-result-object v4 invoke-static {v1, v3, v2, v4}, Landroidx/work/impl/workers/DiagnosticsWorker;->workSpecRow(Landroidx/work/impl/model/WorkSpec;Ljava/lang/String;Ljava/lang/Integer;Ljava/lang/String;)Ljava/lang/String; move-result-object v1 invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; goto :goto_1 :cond_2 invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p0 return-object p0 .end method # virtual methods .method public doWork()Landroidx/work/ListenableWorker$Result; .locals 11 .annotation build Landroidx/annotation/NonNull; .end annotation invoke-virtual {p0}, Landroidx/work/ListenableWorker;->getApplicationContext()Landroid/content/Context; move-result-object v0 invoke-static {v0}, Landroidx/work/impl/WorkManagerImpl;->getInstance(Landroid/content/Context;)Landroidx/work/impl/WorkManagerImpl; move-result-object v0 invoke-virtual {v0}, Landroidx/work/impl/WorkManagerImpl;->getWorkDatabase()Landroidx/work/impl/WorkDatabase; move-result-object v0 invoke-virtual {v0}, Landroidx/work/impl/WorkDatabase;->workSpecDao()Landroidx/work/impl/model/WorkSpecDao; move-result-object v1 invoke-virtual {v0}, Landroidx/work/impl/WorkDatabase;->workNameDao()Landroidx/work/impl/model/WorkNameDao; move-result-object v2 invoke-virtual {v0}, Landroidx/work/impl/WorkDatabase;->workTagDao()Landroidx/work/impl/model/WorkTagDao; move-result-object v3 invoke-virtual {v0}, Landroidx/work/impl/WorkDatabase;->systemIdInfoDao()Landroidx/work/impl/model/SystemIdInfoDao; move-result-object v0 invoke-static {}, Ljava/lang/System;->currentTimeMillis()J move-result-wide v4 sget-object v6, Ljava/util/concurrent/TimeUnit;->DAYS:Ljava/util/concurrent/TimeUnit; const-wide/16 v7, 0x1 invoke-virtual {v6, v7, v8}, Ljava/util/concurrent/TimeUnit;->toMillis(J)J move-result-wide v6 sub-long/2addr v4, v6 invoke-interface {v1, v4, v5}, Landroidx/work/impl/model/WorkSpecDao;->getRecentlyCompletedWork(J)Ljava/util/List; move-result-object v4 invoke-interface {v1}, Landroidx/work/impl/model/WorkSpecDao;->getRunningWork()Ljava/util/List; move-result-object v5 invoke-interface {v1}, Landroidx/work/impl/model/WorkSpecDao;->getAllEligibleWorkSpecsForScheduling()Ljava/util/List; move-result-object v1 const/4 v6, 0x0 if-eqz v4, :cond_0 invoke-interface {v4}, Ljava/util/List;->isEmpty()Z move-result v7 if-nez v7, :cond_0 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v7 sget-object v8, Landroidx/work/impl/workers/DiagnosticsWorker;->TAG:Ljava/lang/String; new-array v9, v6, [Ljava/lang/Throwable; const-string v10, "Recently completed work:\n\n" invoke-virtual {v7, v8, v10, v9}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v7 invoke-static {v2, v3, v0, v4}, Landroidx/work/impl/workers/DiagnosticsWorker;->workSpecRows(Landroidx/work/impl/model/WorkNameDao;Landroidx/work/impl/model/WorkTagDao;Landroidx/work/impl/model/SystemIdInfoDao;Ljava/util/List;)Ljava/lang/String; move-result-object v4 new-array v9, v6, [Ljava/lang/Throwable; invoke-virtual {v7, v8, v4, v9}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V :cond_0 if-eqz v5, :cond_1 invoke-interface {v5}, Ljava/util/List;->isEmpty()Z move-result v4 if-nez v4, :cond_1 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v4 sget-object v7, Landroidx/work/impl/workers/DiagnosticsWorker;->TAG:Ljava/lang/String; new-array v8, v6, [Ljava/lang/Throwable; const-string v9, "Running work:\n\n" invoke-virtual {v4, v7, v9, v8}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v4 invoke-static {v2, v3, v0, v5}, Landroidx/work/impl/workers/DiagnosticsWorker;->workSpecRows(Landroidx/work/impl/model/WorkNameDao;Landroidx/work/impl/model/WorkTagDao;Landroidx/work/impl/model/SystemIdInfoDao;Ljava/util/List;)Ljava/lang/String; move-result-object v5 new-array v8, v6, [Ljava/lang/Throwable; invoke-virtual {v4, v7, v5, v8}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V :cond_1 if-eqz v1, :cond_2 invoke-interface {v1}, Ljava/util/List;->isEmpty()Z move-result v4 if-nez v4, :cond_2 invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v4 sget-object v5, Landroidx/work/impl/workers/DiagnosticsWorker;->TAG:Ljava/lang/String; new-array v7, v6, [Ljava/lang/Throwable; const-string v8, "Enqueued work:\n\n" invoke-virtual {v4, v5, v8, v7}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V invoke-static {}, Landroidx/work/Logger;->get()Landroidx/work/Logger; move-result-object v4 invoke-static {v2, v3, v0, v1}, Landroidx/work/impl/workers/DiagnosticsWorker;->workSpecRows(Landroidx/work/impl/model/WorkNameDao;Landroidx/work/impl/model/WorkTagDao;Landroidx/work/impl/model/SystemIdInfoDao;Ljava/util/List;)Ljava/lang/String; move-result-object v0 new-array v1, v6, [Ljava/lang/Throwable; invoke-virtual {v4, v5, v0, v1}, Landroidx/work/Logger;->info(Ljava/lang/String;Ljava/lang/String;[Ljava/lang/Throwable;)V :cond_2 invoke-static {}, Landroidx/work/ListenableWorker$Result;->success()Landroidx/work/ListenableWorker$Result; move-result-object v0 return-object v0 .end method