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