n.smali
.class final Lcom/squareup/picasso/n;
.super Ljava/io/InputStream;
.source ""
# instance fields
.field private final e:Ljava/io/InputStream;
.field private f:J
.field private g:J
.field private h:J
.field private i:J
.field private j:Z
.field private k:I
# direct methods
.method constructor <init>(Ljava/io/InputStream;)V
.registers 3
const/16 v0, 0x1000
invoke-direct {p0, p1, v0}, Lcom/squareup/picasso/n;-><init>(Ljava/io/InputStream;I)V
return-void
.end method
.method constructor <init>(Ljava/io/InputStream;I)V
.registers 4
const/16 v0, 0x400
invoke-direct {p0, p1, p2, v0}, Lcom/squareup/picasso/n;-><init>(Ljava/io/InputStream;II)V
return-void
.end method
.method private constructor <init>(Ljava/io/InputStream;II)V
.registers 6
invoke-direct {p0}, Ljava/io/InputStream;-><init>()V
const-wide/16 v0, -0x1
iput-wide v0, p0, Lcom/squareup/picasso/n;->i:J
const/4 v0, 0x1
iput-boolean v0, p0, Lcom/squareup/picasso/n;->j:Z
const/4 v0, -0x1
iput v0, p0, Lcom/squareup/picasso/n;->k:I
invoke-virtual {p1}, Ljava/io/InputStream;->markSupported()Z
move-result v0
if-nez v0, :cond_19
new-instance v0, Ljava/io/BufferedInputStream;
invoke-direct {v0, p1, p2}, Ljava/io/BufferedInputStream;-><init>(Ljava/io/InputStream;I)V
move-object p1, v0
:cond_19
iput-object p1, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
iput p3, p0, Lcom/squareup/picasso/n;->k:I
return-void
.end method
.method private G(JJ)V
.registers 10
:goto_0
cmp-long v0, p1, p3
if-gez v0, :cond_1e
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
sub-long v1, p3, p1
invoke-virtual {v0, v1, v2}, Ljava/io/InputStream;->skip(J)J
move-result-wide v0
const-wide/16 v2, 0x0
cmp-long v4, v0, v2
if-nez v4, :cond_1c
invoke-virtual {p0}, Lcom/squareup/picasso/n;->read()I
move-result v0
const/4 v1, -0x1
if-ne v0, v1, :cond_1a
goto :goto_1e
:cond_1a
const-wide/16 v0, 0x1
:cond_1c
add-long/2addr p1, v0
goto :goto_0
:cond_1e
:goto_1e
return-void
.end method
.method private x(J)V
.registers 8
:try_start_0
iget-wide v0, p0, Lcom/squareup/picasso/n;->g:J
iget-wide v2, p0, Lcom/squareup/picasso/n;->f:J
cmp-long v4, v0, v2
if-gez v4, :cond_25
iget-wide v0, p0, Lcom/squareup/picasso/n;->h:J
cmp-long v4, v2, v0
if-gtz v4, :cond_25
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0}, Ljava/io/InputStream;->reset()V
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
iget-wide v1, p0, Lcom/squareup/picasso/n;->g:J
sub-long v1, p1, v1
long-to-int v2, v1
invoke-virtual {v0, v2}, Ljava/io/InputStream;->mark(I)V
iget-wide v0, p0, Lcom/squareup/picasso/n;->g:J
iget-wide v2, p0, Lcom/squareup/picasso/n;->f:J
invoke-direct {p0, v0, v1, v2, v3}, Lcom/squareup/picasso/n;->G(JJ)V
goto :goto_2f
:cond_25
iput-wide v2, p0, Lcom/squareup/picasso/n;->g:J
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
sub-long v2, p1, v2
long-to-int v1, v2
invoke-virtual {v0, v1}, Ljava/io/InputStream;->mark(I)V
:goto_2f
iput-wide p1, p0, Lcom/squareup/picasso/n;->h:J
:try_end_31
.catch Ljava/io/IOException; {:try_start_0 .. :try_end_31} :catch_32
return-void
:catch_32
move-exception p1
new-instance p2, Ljava/lang/IllegalStateException;
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
const-string v1, "Unable to mark: "
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
invoke-direct {p2, p1}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
throw p2
.end method
# virtual methods
.method public available()I
.registers 2
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0}, Ljava/io/InputStream;->available()I
move-result v0
return v0
.end method
.method public close()V
.registers 2
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0}, Ljava/io/InputStream;->close()V
return-void
.end method
.method public k(Z)V
.registers 2
iput-boolean p1, p0, Lcom/squareup/picasso/n;->j:Z
return-void
.end method
.method public m(J)V
.registers 8
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
iget-wide v2, p0, Lcom/squareup/picasso/n;->h:J
cmp-long v4, v0, v2
if-gtz v4, :cond_1b
iget-wide v0, p0, Lcom/squareup/picasso/n;->g:J
cmp-long v2, p1, v0
if-ltz v2, :cond_1b
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0}, Ljava/io/InputStream;->reset()V
iget-wide v0, p0, Lcom/squareup/picasso/n;->g:J
invoke-direct {p0, v0, v1, p1, p2}, Lcom/squareup/picasso/n;->G(JJ)V
iput-wide p1, p0, Lcom/squareup/picasso/n;->f:J
return-void
:cond_1b
new-instance p1, Ljava/io/IOException;
const-string p2, "Cannot reset"
invoke-direct {p1, p2}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method public mark(I)V
.registers 4
invoke-virtual {p0, p1}, Lcom/squareup/picasso/n;->r(I)J
move-result-wide v0
iput-wide v0, p0, Lcom/squareup/picasso/n;->i:J
return-void
.end method
.method public markSupported()Z
.registers 2
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0}, Ljava/io/InputStream;->markSupported()Z
move-result v0
return v0
.end method
.method public r(I)J
.registers 6
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
int-to-long v2, p1
add-long/2addr v0, v2
iget-wide v2, p0, Lcom/squareup/picasso/n;->h:J
cmp-long p1, v2, v0
if-gez p1, :cond_d
invoke-direct {p0, v0, v1}, Lcom/squareup/picasso/n;->x(J)V
:cond_d
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
return-wide v0
.end method
.method public read()I
.registers 8
iget-boolean v0, p0, Lcom/squareup/picasso/n;->j:Z
const-wide/16 v1, 0x1
if-nez v0, :cond_16
iget-wide v3, p0, Lcom/squareup/picasso/n;->f:J
add-long/2addr v3, v1
iget-wide v5, p0, Lcom/squareup/picasso/n;->h:J
cmp-long v0, v3, v5
if-lez v0, :cond_16
iget v0, p0, Lcom/squareup/picasso/n;->k:I
int-to-long v3, v0
add-long/2addr v5, v3
invoke-direct {p0, v5, v6}, Lcom/squareup/picasso/n;->x(J)V
:cond_16
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0}, Ljava/io/InputStream;->read()I
move-result v0
const/4 v3, -0x1
if-eq v0, v3, :cond_24
iget-wide v3, p0, Lcom/squareup/picasso/n;->f:J
add-long/2addr v3, v1
iput-wide v3, p0, Lcom/squareup/picasso/n;->f:J
:cond_24
return v0
.end method
.method public read([B)I
.registers 9
iget-boolean v0, p0, Lcom/squareup/picasso/n;->j:Z
if-nez v0, :cond_19
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
array-length v2, p1
int-to-long v2, v2
add-long/2addr v2, v0
iget-wide v4, p0, Lcom/squareup/picasso/n;->h:J
cmp-long v6, v2, v4
if-lez v6, :cond_19
array-length v2, p1
int-to-long v2, v2
add-long/2addr v0, v2
iget v2, p0, Lcom/squareup/picasso/n;->k:I
int-to-long v2, v2
add-long/2addr v0, v2
invoke-direct {p0, v0, v1}, Lcom/squareup/picasso/n;->x(J)V
:cond_19
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0, p1}, Ljava/io/InputStream;->read([B)I
move-result p1
const/4 v0, -0x1
if-eq p1, v0, :cond_28
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
int-to-long v2, p1
add-long/2addr v0, v2
iput-wide v0, p0, Lcom/squareup/picasso/n;->f:J
:cond_28
return p1
.end method
.method public read([BII)I
.registers 13
iget-boolean v0, p0, Lcom/squareup/picasso/n;->j:Z
if-nez v0, :cond_17
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
int-to-long v2, p3
add-long v4, v0, v2
iget-wide v6, p0, Lcom/squareup/picasso/n;->h:J
cmp-long v8, v4, v6
if-lez v8, :cond_17
add-long/2addr v0, v2
iget v2, p0, Lcom/squareup/picasso/n;->k:I
int-to-long v2, v2
add-long/2addr v0, v2
invoke-direct {p0, v0, v1}, Lcom/squareup/picasso/n;->x(J)V
:cond_17
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0, p1, p2, p3}, Ljava/io/InputStream;->read([BII)I
move-result p1
const/4 p2, -0x1
if-eq p1, p2, :cond_26
iget-wide p2, p0, Lcom/squareup/picasso/n;->f:J
int-to-long v0, p1
add-long/2addr p2, v0
iput-wide p2, p0, Lcom/squareup/picasso/n;->f:J
:cond_26
return p1
.end method
.method public reset()V
.registers 3
iget-wide v0, p0, Lcom/squareup/picasso/n;->i:J
invoke-virtual {p0, v0, v1}, Lcom/squareup/picasso/n;->m(J)V
return-void
.end method
.method public skip(J)J
.registers 10
iget-boolean v0, p0, Lcom/squareup/picasso/n;->j:Z
if-nez v0, :cond_16
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
add-long v2, v0, p1
iget-wide v4, p0, Lcom/squareup/picasso/n;->h:J
cmp-long v6, v2, v4
if-lez v6, :cond_16
add-long/2addr v0, p1
iget v2, p0, Lcom/squareup/picasso/n;->k:I
int-to-long v2, v2
add-long/2addr v0, v2
invoke-direct {p0, v0, v1}, Lcom/squareup/picasso/n;->x(J)V
:cond_16
iget-object v0, p0, Lcom/squareup/picasso/n;->e:Ljava/io/InputStream;
invoke-virtual {v0, p1, p2}, Ljava/io/InputStream;->skip(J)J
move-result-wide p1
iget-wide v0, p0, Lcom/squareup/picasso/n;->f:J
add-long/2addr v0, p1
iput-wide v0, p0, Lcom/squareup/picasso/n;->f:J
return-wide p1
.end method