g.smali
.class public abstract Ltq/g;
.super Ljava/lang/Object;
.source "ZoneRulesInitializer.java"
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Ltq/g$b;,
Ltq/g$a;
}
.end annotation
# static fields
.field public static final DO_NOTHING:Ltq/g;
.field public static final INITIALIZED:Ljava/util/concurrent/atomic/AtomicBoolean;
.field public static final INITIALIZER:Ljava/util/concurrent/atomic/AtomicReference;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/atomic/AtomicReference<",
"Ltq/g;",
">;"
}
.end annotation
.end field
# direct methods
.method public static constructor <clinit>()V
.registers 2
new-instance v0, Ltq/g$a;
invoke-direct {v0}, Ltq/g$a;-><init>()V
sput-object v0, Ltq/g;->DO_NOTHING:Ltq/g;
new-instance v0, Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v1, 0x0
invoke-direct {v0, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;-><init>(Z)V
sput-object v0, Ltq/g;->INITIALIZED:Ljava/util/concurrent/atomic/AtomicBoolean;
new-instance v0, Ljava/util/concurrent/atomic/AtomicReference;
invoke-direct {v0}, Ljava/util/concurrent/atomic/AtomicReference;-><init>()V
sput-object v0, Ltq/g;->INITIALIZER:Ljava/util/concurrent/atomic/AtomicReference;
return-void
.end method
.method public constructor <init>()V
.registers 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static initialize()V
.registers 3
sget-object v0, Ltq/g;->INITIALIZED:Ljava/util/concurrent/atomic/AtomicBoolean;
const/4 v1, 0x1
invoke-virtual {v0, v1}, Ljava/util/concurrent/atomic/AtomicBoolean;->getAndSet(Z)Z
move-result v0
if-nez v0, :cond_20
sget-object v0, Ltq/g;->INITIALIZER:Ljava/util/concurrent/atomic/AtomicReference;
const/4 v1, 0x0
new-instance v2, Ltq/g$b;
invoke-direct {v2}, Ltq/g$b;-><init>()V
invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicReference;->compareAndSet(Ljava/lang/Object;Ljava/lang/Object;)Z
sget-object v0, Ltq/g;->INITIALIZER:Ljava/util/concurrent/atomic/AtomicReference;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicReference;->get()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ltq/g;
invoke-virtual {v0}, Ltq/g;->initializeProviders()V
return-void
:cond_20
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "Already initialized"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method public static setInitializer(Ltq/g;)V
.registers 3
sget-object v0, Ltq/g;->INITIALIZED:Ljava/util/concurrent/atomic/AtomicBoolean;
invoke-virtual {v0}, Ljava/util/concurrent/atomic/AtomicBoolean;->get()Z
move-result v0
if-nez v0, :cond_1a
sget-object v0, Ltq/g;->INITIALIZER:Ljava/util/concurrent/atomic/AtomicReference;
const/4 v1, 0x0
invoke-virtual {v0, v1, p0}, Ljava/util/concurrent/atomic/AtomicReference;->compareAndSet(Ljava/lang/Object;Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_12
return-void
:cond_12
new-instance p0, Ljava/lang/IllegalStateException;
const-string v0, "Initializer was already set, possibly with a default during initialization"
invoke-direct {p0, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p0
:cond_1a
new-instance p0, Ljava/lang/IllegalStateException;
const-string v0, "Already initialized"
invoke-direct {p0, v0}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p0
.end method
# virtual methods
.method public abstract initializeProviders()V
.end method