c.smali

.class public Lcom/google/android/datatransport/runtime/d/c;
.super Ljava/lang/Object;
.source "DefaultScheduler.java"

# interfaces
.implements Lcom/google/android/datatransport/runtime/d/e;


# static fields
.field private static final a:Ljava/util/logging/Logger;


# instance fields
.field private final b:Lcom/google/android/datatransport/runtime/scheduling/jobscheduling/s;

.field private final c:Ljava/util/concurrent/Executor;

.field private final d:Lcom/google/android/datatransport/runtime/backends/f;

.field private final e:Lcom/google/android/datatransport/runtime/d/a/d;

.field private final f:Lcom/google/android/datatransport/runtime/synchronization/a;


# direct methods
.method static constructor <clinit>()V
    .registers 1

    .line 1
    const-class v0, Lcom/google/android/datatransport/runtime/v;

    invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;

    move-result-object v0

    invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;

    move-result-object v0

    sput-object v0, Lcom/google/android/datatransport/runtime/d/c;->a:Ljava/util/logging/Logger;

    return-void
.end method

.method public constructor <init>(Ljava/util/concurrent/Executor;Lcom/google/android/datatransport/runtime/backends/f;Lcom/google/android/datatransport/runtime/scheduling/jobscheduling/s;Lcom/google/android/datatransport/runtime/d/a/d;Lcom/google/android/datatransport/runtime/synchronization/a;)V
    .registers 6

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    .line 2
    iput-object p1, p0, Lcom/google/android/datatransport/runtime/d/c;->c:Ljava/util/concurrent/Executor;

    .line 3
    iput-object p2, p0, Lcom/google/android/datatransport/runtime/d/c;->d:Lcom/google/android/datatransport/runtime/backends/f;

    .line 4
    iput-object p3, p0, Lcom/google/android/datatransport/runtime/d/c;->b:Lcom/google/android/datatransport/runtime/scheduling/jobscheduling/s;

    .line 5
    iput-object p4, p0, Lcom/google/android/datatransport/runtime/d/c;->e:Lcom/google/android/datatransport/runtime/d/a/d;

    .line 6
    iput-object p5, p0, Lcom/google/android/datatransport/runtime/d/c;->f:Lcom/google/android/datatransport/runtime/synchronization/a;

    return-void
.end method

.method static synthetic a(Lcom/google/android/datatransport/runtime/d/c;Lcom/google/android/datatransport/runtime/q;Lcom/google/android/datatransport/runtime/l;)Ljava/lang/Object;
    .registers 4

    .line 14
    iget-object v0, p0, Lcom/google/android/datatransport/runtime/d/c;->e:Lcom/google/android/datatransport/runtime/d/a/d;

    invoke-interface {v0, p1, p2}, Lcom/google/android/datatransport/runtime/d/a/d;->a(Lcom/google/android/datatransport/runtime/q;Lcom/google/android/datatransport/runtime/l;)Lcom/google/android/datatransport/runtime/d/a/j;

    .line 15
    iget-object p0, p0, Lcom/google/android/datatransport/runtime/d/c;->b:Lcom/google/android/datatransport/runtime/scheduling/jobscheduling/s;

    const/4 p2, 0x1

    invoke-interface {p0, p1, p2}, Lcom/google/android/datatransport/runtime/scheduling/jobscheduling/s;->a(Lcom/google/android/datatransport/runtime/q;I)V

    const/4 p0, 0x0

    return-object p0
.end method

.method static synthetic a(Lcom/google/android/datatransport/runtime/d/c;Lcom/google/android/datatransport/runtime/q;Lcom/google/android/datatransport/g;Lcom/google/android/datatransport/runtime/l;)V
    .registers 6

    .line 2
    :try_start_0
    iget-object v0, p0, Lcom/google/android/datatransport/runtime/d/c;->d:Lcom/google/android/datatransport/runtime/backends/f;

    .line 3
    invoke-virtual {p1}, Lcom/google/android/datatransport/runtime/q;->b()Ljava/lang/String;

    move-result-object v1

    invoke-interface {v0, v1}, Lcom/google/android/datatransport/runtime/backends/f;->get(Ljava/lang/String;)Lcom/google/android/datatransport/runtime/backends/m;

    move-result-object v0

    if-nez v0, :cond_2a

    const-string p0, "Transport backend \'%s\' is not registered"

    const/4 p3, 0x1

    .line 4
    new-array p3, p3, [Ljava/lang/Object;

    const/4 v0, 0x0

    .line 5
    invoke-virtual {p1}, Lcom/google/android/datatransport/runtime/q;->b()Ljava/lang/String;

    move-result-object p1

    aput-object p1, p3, v0

    .line 6
    invoke-static {p0, p3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;

    move-result-object p0

    .line 7
    sget-object p1, Lcom/google/android/datatransport/runtime/d/c;->a:Ljava/util/logging/Logger;

    invoke-virtual {p1, p0}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V

    .line 8
    new-instance p1, Ljava/lang/IllegalArgumentException;

    invoke-direct {p1, p0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V

    invoke-interface {p2, p1}, Lcom/google/android/datatransport/g;->onSchedule(Ljava/lang/Exception;)V

    return-void

    .line 9
    :cond_2a
    invoke-interface {v0, p3}, Lcom/google/android/datatransport/runtime/backends/m;->a(Lcom/google/android/datatransport/runtime/l;)Lcom/google/android/datatransport/runtime/l;

    move-result-object p3

    .line 10
    iget-object v0, p0, Lcom/google/android/datatransport/runtime/d/c;->f:Lcom/google/android/datatransport/runtime/synchronization/a;

    invoke-static {p0, p1, p3}, Lcom/google/android/datatransport/runtime/d/b;->a(Lcom/google/android/datatransport/runtime/d/c;Lcom/google/android/datatransport/runtime/q;Lcom/google/android/datatransport/runtime/l;)Lcom/google/android/datatransport/runtime/synchronization/a$a;

    move-result-object p0

    invoke-interface {v0, p0}, Lcom/google/android/datatransport/runtime/synchronization/a;->a(Lcom/google/android/datatransport/runtime/synchronization/a$a;)Ljava/lang/Object;

    const/4 p0, 0x0

    .line 11
    invoke-interface {p2, p0}, Lcom/google/android/datatransport/g;->onSchedule(Ljava/lang/Exception;)V
    :try_end_3b
    .catch Ljava/lang/Exception; {:try_start_0 .. :try_end_3b} :catch_3c

    goto :goto_5a

    :catch_3c
    move-exception p0

    .line 12
    sget-object p1, Lcom/google/android/datatransport/runtime/d/c;->a:Ljava/util/logging/Logger;

    new-instance p3, Ljava/lang/StringBuilder;

    invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V

    const-string v0, "Error scheduling event "

    invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {p0}, Ljava/lang/Exception;->getMessage()Ljava/lang/String;

    move-result-object v0

    invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p3

    invoke-virtual {p1, p3}, Ljava/util/logging/Logger;->warning(Ljava/lang/String;)V

    .line 13
    invoke-interface {p2, p0}, Lcom/google/android/datatransport/g;->onSchedule(Ljava/lang/Exception;)V

    :goto_5a
    return-void
.end method


# virtual methods
.method public a(Lcom/google/android/datatransport/runtime/q;Lcom/google/android/datatransport/runtime/l;Lcom/google/android/datatransport/g;)V
    .registers 5

    .line 1
    iget-object v0, p0, Lcom/google/android/datatransport/runtime/d/c;->c:Ljava/util/concurrent/Executor;

    invoke-static {p0, p1, p3, p2}, Lcom/google/android/datatransport/runtime/d/a;->a(Lcom/google/android/datatransport/runtime/d/c;Lcom/google/android/datatransport/runtime/q;Lcom/google/android/datatransport/g;Lcom/google/android/datatransport/runtime/l;)Ljava/lang/Runnable;

    move-result-object p1

    invoke-interface {v0, p1}, Ljava/util/concurrent/Executor;->execute(Ljava/lang/Runnable;)V

    return-void
.end method