apkfuckery/com.discord/smali_classes2/l0/l/b/a.smali
2020-09-22 07:09:10 +00:00

496 lines
8 KiB
Smali

.class public final Ll0/l/b/a;
.super Ljava/lang/Object;
.source "ProducerArbiter.java"
# interfaces
.implements Lrx/Producer;
# static fields
.field public static final j:Lrx/Producer;
# instance fields
.field public d:J
.field public e:Lrx/Producer;
.field public f:Z
.field public g:J
.field public h:J
.field public i:Lrx/Producer;
# direct methods
.method public static constructor <clinit>()V
.locals 1
new-instance v0, Ll0/l/b/a$a;
invoke-direct {v0}, Ll0/l/b/a$a;-><init>()V
sput-object v0, Ll0/l/b/a;->j:Lrx/Producer;
return-void
.end method
.method public constructor <init>()V
.locals 0
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public a()V
.locals 14
:cond_0
:goto_0
monitor-enter p0
:try_start_0
iget-wide v0, p0, Ll0/l/b/a;->g:J
iget-wide v2, p0, Ll0/l/b/a;->h:J
iget-object v4, p0, Ll0/l/b/a;->i:Lrx/Producer;
const-wide/16 v5, 0x0
cmp-long v7, v0, v5
if-nez v7, :cond_1
cmp-long v8, v2, v5
if-nez v8, :cond_1
if-nez v4, :cond_1
const/4 v0, 0x0
iput-boolean v0, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
return-void
:cond_1
iput-wide v5, p0, Ll0/l/b/a;->g:J
iput-wide v5, p0, Ll0/l/b/a;->h:J
const/4 v8, 0x0
iput-object v8, p0, Ll0/l/b/a;->i:Lrx/Producer;
monitor-exit p0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_0
iget-wide v9, p0, Ll0/l/b/a;->d:J
const-wide v11, 0x7fffffffffffffffL
cmp-long v13, v9, v11
if-eqz v13, :cond_5
add-long/2addr v9, v0
cmp-long v13, v9, v5
if-ltz v13, :cond_4
cmp-long v13, v9, v11
if-nez v13, :cond_2
goto :goto_1
:cond_2
sub-long/2addr v9, v2
cmp-long v2, v9, v5
if-ltz v2, :cond_3
iput-wide v9, p0, Ll0/l/b/a;->d:J
goto :goto_2
:cond_3
new-instance v0, Ljava/lang/IllegalStateException;
const-string v1, "more produced than requested"
invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw v0
:cond_4
:goto_1
iput-wide v11, p0, Ll0/l/b/a;->d:J
move-wide v9, v11
:cond_5
:goto_2
if-eqz v4, :cond_7
sget-object v0, Ll0/l/b/a;->j:Lrx/Producer;
if-ne v4, v0, :cond_6
iput-object v8, p0, Ll0/l/b/a;->e:Lrx/Producer;
goto :goto_0
:cond_6
iput-object v4, p0, Ll0/l/b/a;->e:Lrx/Producer;
invoke-interface {v4, v9, v10}, Lrx/Producer;->n(J)V
goto :goto_0
:cond_7
iget-object v2, p0, Ll0/l/b/a;->e:Lrx/Producer;
if-eqz v2, :cond_0
if-eqz v7, :cond_0
invoke-interface {v2, v0, v1}, Lrx/Producer;->n(J)V
goto :goto_0
:catchall_0
move-exception v0
:try_start_1
monitor-exit p0
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
throw v0
.end method
.method public b(J)V
.locals 7
const-wide/16 v0, 0x0
cmp-long v2, p1, v0
if-lez v2, :cond_3
monitor-enter p0
:try_start_0
iget-boolean v2, p0, Ll0/l/b/a;->f:Z
if-eqz v2, :cond_0
iget-wide v0, p0, Ll0/l/b/a;->h:J
add-long/2addr v0, p1
iput-wide v0, p0, Ll0/l/b/a;->h:J
monitor-exit p0
return-void
:cond_0
const/4 v2, 0x1
iput-boolean v2, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_2
:try_start_1
iget-wide v2, p0, Ll0/l/b/a;->d:J
const-wide v4, 0x7fffffffffffffffL
cmp-long v6, v2, v4
if-eqz v6, :cond_2
sub-long/2addr v2, p1
cmp-long p1, v2, v0
if-ltz p1, :cond_1
iput-wide v2, p0, Ll0/l/b/a;->d:J
goto :goto_0
:cond_1
new-instance p1, Ljava/lang/IllegalStateException;
const-string p2, "more items arrived than were requested"
invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p1
:cond_2
:goto_0
invoke-virtual {p0}, Ll0/l/b/a;->a()V
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
return-void
:catchall_0
move-exception p1
monitor-enter p0
const/4 p2, 0x0
:try_start_2
iput-boolean p2, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_1
throw p1
:catchall_1
move-exception p1
:try_start_3
monitor-exit p0
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_1
throw p1
:catchall_2
move-exception p1
:try_start_4
monitor-exit p0
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_2
throw p1
:cond_3
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "n > 0 required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public c(Lrx/Producer;)V
.locals 2
monitor-enter p0
:try_start_0
iget-boolean v0, p0, Ll0/l/b/a;->f:Z
if-eqz v0, :cond_1
if-nez p1, :cond_0
sget-object p1, Ll0/l/b/a;->j:Lrx/Producer;
:cond_0
iput-object p1, p0, Ll0/l/b/a;->i:Lrx/Producer;
monitor-exit p0
return-void
:cond_1
const/4 v0, 0x1
iput-boolean v0, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_2
:try_start_1
iput-object p1, p0, Ll0/l/b/a;->e:Lrx/Producer;
if-eqz p1, :cond_2
iget-wide v0, p0, Ll0/l/b/a;->d:J
invoke-interface {p1, v0, v1}, Lrx/Producer;->n(J)V
:cond_2
invoke-virtual {p0}, Ll0/l/b/a;->a()V
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
return-void
:catchall_0
move-exception p1
monitor-enter p0
const/4 v0, 0x0
:try_start_2
iput-boolean v0, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_1
throw p1
:catchall_1
move-exception p1
:try_start_3
monitor-exit p0
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_1
throw p1
:catchall_2
move-exception p1
:try_start_4
monitor-exit p0
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_2
throw p1
.end method
.method public n(J)V
.locals 5
const-wide/16 v0, 0x0
cmp-long v2, p1, v0
if-ltz v2, :cond_4
if-nez v2, :cond_0
return-void
:cond_0
monitor-enter p0
:try_start_0
iget-boolean v2, p0, Ll0/l/b/a;->f:Z
if-eqz v2, :cond_1
iget-wide v0, p0, Ll0/l/b/a;->g:J
add-long/2addr v0, p1
iput-wide v0, p0, Ll0/l/b/a;->g:J
monitor-exit p0
return-void
:cond_1
const/4 v2, 0x1
iput-boolean v2, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
:try_end_0
.catchall {:try_start_0 .. :try_end_0} :catchall_2
:try_start_1
iget-wide v2, p0, Ll0/l/b/a;->d:J
add-long/2addr v2, p1
cmp-long v4, v2, v0
if-gez v4, :cond_2
const-wide v2, 0x7fffffffffffffffL
:cond_2
iput-wide v2, p0, Ll0/l/b/a;->d:J
iget-object v0, p0, Ll0/l/b/a;->e:Lrx/Producer;
if-eqz v0, :cond_3
invoke-interface {v0, p1, p2}, Lrx/Producer;->n(J)V
:cond_3
invoke-virtual {p0}, Ll0/l/b/a;->a()V
:try_end_1
.catchall {:try_start_1 .. :try_end_1} :catchall_0
return-void
:catchall_0
move-exception p1
monitor-enter p0
const/4 p2, 0x0
:try_start_2
iput-boolean p2, p0, Ll0/l/b/a;->f:Z
monitor-exit p0
:try_end_2
.catchall {:try_start_2 .. :try_end_2} :catchall_1
throw p1
:catchall_1
move-exception p1
:try_start_3
monitor-exit p0
:try_end_3
.catchall {:try_start_3 .. :try_end_3} :catchall_1
throw p1
:catchall_2
move-exception p1
:try_start_4
monitor-exit p0
:try_end_4
.catchall {:try_start_4 .. :try_end_4} :catchall_2
throw p1
:cond_4
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "n >= 0 required"
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.end method