DTBTimeTrace.smali
.class public Lcom/amazon/device/ads/DTBTimeTrace;
.super Ljava/lang/Object;
.source "SourceFile"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;
}
.end annotation
# static fields
.field private static final SERVERLESS_METRICS_TAG:Ljava/lang/String; = "ServerlessMetrics"
.field public static final TIMETRACE_AD_DISPLAY_FAILED:Ljava/lang/String; = "AD display failed"
.field public static final TIMETRACE_AD_DISPLAY_SUCCEEDED:Ljava/lang/String; = "AD displayed"
.field public static final TIMETRACE_AD_LOADED:Ljava/lang/String; = "AD loaded"
.field public static final TIMETRACE_AD_LOAD_FAILED:Ljava/lang/String; = "AD load failed"
.field public static final TIMETRACE_AD_REQUESTED:Ljava/lang/String; = "Request Ad"
.field public static final TIMETRACE_BID_FAILED:Ljava/lang/String; = "Bid failed"
.field public static final TIMETRACE_BID_START:Ljava/lang/String; = "Bid requested"
.field public static final TIMETRACE_BID_SUCCEEDED:Ljava/lang/String; = "Bid succeeded"
.field public static final TIMETRACE_CUSTOM_EVENT_ACCEPTED:Ljava/lang/String; = "Custom event accepted"
.field public static final TIMETRACE_CUSTOM_EVENT_IGNORED:Ljava/lang/String; = "Custom event ignored"
.field private static theTrace:Lcom/amazon/device/ads/DTBTimeTrace;
# instance fields
.field private isStarted:Z
.field private records:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList<",
"Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;",
">;"
}
.end annotation
.end field
.field private startDate:Ljava/util/Date;
# direct methods
.method constructor <init>()V
.registers 2
.line 26
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/4 v0, 0x0
.line 22
iput-boolean v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->isStarted:Z
.line 27
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->records:Ljava/util/ArrayList;
return-void
.end method
.method public static getInstance()Lcom/amazon/device/ads/DTBTimeTrace;
.registers 1
.line 31
sget-object v0, Lcom/amazon/device/ads/DTBTimeTrace;->theTrace:Lcom/amazon/device/ads/DTBTimeTrace;
if-nez v0, :cond_b
.line 32
new-instance v0, Lcom/amazon/device/ads/DTBTimeTrace;
invoke-direct {v0}, Lcom/amazon/device/ads/DTBTimeTrace;-><init>()V
sput-object v0, Lcom/amazon/device/ads/DTBTimeTrace;->theTrace:Lcom/amazon/device/ads/DTBTimeTrace;
.line 34
:cond_b
sget-object v0, Lcom/amazon/device/ads/DTBTimeTrace;->theTrace:Lcom/amazon/device/ads/DTBTimeTrace;
return-object v0
.end method
# virtual methods
.method public addPhase(Ljava/lang/String;)V
.registers 4
.line 38
iget-boolean v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->isStarted:Z
if-nez v0, :cond_5
return-void
.line 41
:cond_5
iget-object v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->records:Ljava/util/ArrayList;
new-instance v1, Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;
invoke-direct {v1, p1}, Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;-><init>(Ljava/lang/String;)V
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
return-void
.end method
.method public logTrace()V
.registers 3
.line 45
invoke-static {}, Lcom/amazon/device/ads/AdRegistration;->isTestMode()Z
move-result v0
if-eqz v0, :cond_13
.line 46
invoke-static {}, Lcom/amazon/device/ads/DTBTimeTrace;->getInstance()Lcom/amazon/device/ads/DTBTimeTrace;
move-result-object v0
invoke-virtual {v0}, Lcom/amazon/device/ads/DTBTimeTrace;->toString()Ljava/lang/String;
move-result-object v0
const-string v1, "ServerlessMetrics"
invoke-static {v1, v0}, Lcom/amazon/device/ads/DtbLog;->debug(Ljava/lang/String;Ljava/lang/String;)V
:cond_13
return-void
.end method
.method public start()V
.registers 2
.line 51
invoke-static {}, Lcom/amazon/device/ads/AdRegistration;->isTestMode()Z
move-result v0
if-eqz v0, :cond_15
const/4 v0, 0x1
.line 52
iput-boolean v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->isStarted:Z
.line 53
new-instance v0, Ljava/util/Date;
invoke-direct {v0}, Ljava/util/Date;-><init>()V
iput-object v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->startDate:Ljava/util/Date;
.line 54
iget-object v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->records:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->clear()V
:cond_15
return-void
.end method
.method public stop()V
.registers 2
const/4 v0, 0x0
.line 60
iput-boolean v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->isStarted:Z
.line 61
iget-object v0, p0, Lcom/amazon/device/ads/DTBTimeTrace;->records:Ljava/util/ArrayList;
invoke-virtual {v0}, Ljava/util/ArrayList;->clear()V
return-void
.end method
.method public toString()Ljava/lang/String;
.registers 10
.line 66
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
.line 67
iget-object v1, p0, Lcom/amazon/device/ads/DTBTimeTrace;->startDate:Ljava/util/Date;
if-eqz v1, :cond_57
.line 69
iget-object v2, p0, Lcom/amazon/device/ads/DTBTimeTrace;->records:Ljava/util/ArrayList;
invoke-virtual {v2}, Ljava/util/ArrayList;->iterator()Ljava/util/Iterator;
move-result-object v2
:goto_f
invoke-interface {v2}, Ljava/util/Iterator;->hasNext()Z
move-result v3
const-string v4, "\n"
if-eqz v3, :cond_41
invoke-interface {v2}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v3
check-cast v3, Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;
.line 71
# getter for: Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;->label:Ljava/lang/String;
invoke-static {v3}, Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;->access$100(Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;)Ljava/lang/String;
move-result-object v5
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v5, "-> "
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
# getter for: Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;->date:Ljava/util/Date;
invoke-static {v3}, Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;->access$000(Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;)Ljava/util/Date;
move-result-object v5
invoke-virtual {v5}, Ljava/util/Date;->getTime()J
move-result-wide v5
invoke-virtual {v1}, Ljava/util/Date;->getTime()J
move-result-wide v7
sub-long/2addr v5, v7
invoke-virtual {v0, v5, v6}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 72
# getter for: Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;->date:Ljava/util/Date;
invoke-static {v3}, Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;->access$000(Lcom/amazon/device/ads/DTBTimeTrace$DTBTimeTracePhase;)Ljava/util/Date;
move-result-object v1
goto :goto_f
:cond_41
const-string v2, "Total Time:"
.line 75
invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/util/Date;->getTime()J
move-result-wide v1
iget-object v3, p0, Lcom/amazon/device/ads/DTBTimeTrace;->startDate:Ljava/util/Date;
invoke-virtual {v3}, Ljava/util/Date;->getTime()J
move-result-wide v5
sub-long/2addr v1, v5
invoke-virtual {v0, v1, v2}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v0, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 77
:cond_57
invoke-virtual {p0}, Lcom/amazon/device/ads/DTBTimeTrace;->start()V
.line 78
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method