.class public final Lc/l; .super Ljava/lang/Object; .source "" # interfaces .implements Lc/w; # instance fields .field private final a:Lc/g; .field private final b:Ljava/util/zip/Inflater; .field private c:I .field private d:Z # direct methods .method constructor (Lc/g;Ljava/util/zip/Inflater;)V .locals 0 invoke-direct {p0}, Ljava/lang/Object;->()V if-eqz p1, :cond_1 if-eqz p2, :cond_0 iput-object p1, p0, Lc/l;->a:Lc/g; iput-object p2, p0, Lc/l;->b:Ljava/util/zip/Inflater; return-void :cond_0 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "inflater == null" invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 :cond_1 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "source == null" invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 .end method .method private i()V .locals 4 iget v0, p0, Lc/l;->c:I if-nez v0, :cond_0 return-void :cond_0 iget-object v1, p0, Lc/l;->b:Ljava/util/zip/Inflater; invoke-virtual {v1}, Ljava/util/zip/Inflater;->getRemaining()I move-result v1 sub-int/2addr v0, v1 iget v1, p0, Lc/l;->c:I sub-int/2addr v1, v0 iput v1, p0, Lc/l;->c:I iget-object v1, p0, Lc/l;->a:Lc/g; int-to-long v2, v0 invoke-interface {v1, v2, v3}, Lc/g;->skip(J)V return-void .end method # virtual methods .method public b(Lc/e;J)J .locals 4 const-wide/16 v0, 0x0 cmp-long v2, p2, v0 if-ltz v2, :cond_7 iget-boolean v2, p0, Lc/l;->d:Z if-nez v2, :cond_6 cmp-long v2, p2, v0 if-nez v2, :cond_0 return-wide v0 :cond_0 :goto_0 invoke-virtual {p0}, Lc/l;->h()Z move-result p2 const/4 p3, 0x1 :try_start_0 invoke-virtual {p1, p3}, Lc/e;->b(I)Lc/s; move-result-object p3 iget-object v0, p0, Lc/l;->b:Ljava/util/zip/Inflater; iget-object v1, p3, Lc/s;->a:[B iget v2, p3, Lc/s;->c:I iget v3, p3, Lc/s;->c:I rsub-int v3, v3, 0x2000 invoke-virtual {v0, v1, v2, v3}, Ljava/util/zip/Inflater;->inflate([BII)I move-result v0 if-lez v0, :cond_1 iget p2, p3, Lc/s;->c:I add-int/2addr p2, v0 iput p2, p3, Lc/s;->c:I iget-wide p2, p1, Lc/e;->c:J int-to-long v0, v0 add-long/2addr p2, v0 iput-wide p2, p1, Lc/e;->c:J return-wide v0 :cond_1 iget-object v0, p0, Lc/l;->b:Ljava/util/zip/Inflater; invoke-virtual {v0}, Ljava/util/zip/Inflater;->finished()Z move-result v0 if-nez v0, :cond_4 iget-object v0, p0, Lc/l;->b:Ljava/util/zip/Inflater; invoke-virtual {v0}, Ljava/util/zip/Inflater;->needsDictionary()Z move-result v0 if-eqz v0, :cond_2 goto :goto_1 :cond_2 if-nez p2, :cond_3 goto :goto_0 :cond_3 new-instance p1, Ljava/io/EOFException; const-string p2, "source exhausted prematurely" invoke-direct {p1, p2}, Ljava/io/EOFException;->(Ljava/lang/String;)V throw p1 :cond_4 :goto_1 invoke-direct {p0}, Lc/l;->i()V iget p2, p3, Lc/s;->b:I iget v0, p3, Lc/s;->c:I if-ne p2, v0, :cond_5 invoke-virtual {p3}, Lc/s;->b()Lc/s; move-result-object p2 iput-object p2, p1, Lc/e;->b:Lc/s; invoke-static {p3}, Lc/t;->a(Lc/s;)V :try_end_0 .catch Ljava/util/zip/DataFormatException; {:try_start_0 .. :try_end_0} :catch_0 :cond_5 const-wide/16 p1, -0x1 return-wide p1 :catch_0 move-exception p1 new-instance p2, Ljava/io/IOException; invoke-direct {p2, p1}, Ljava/io/IOException;->(Ljava/lang/Throwable;)V throw p2 :cond_6 new-instance p1, Ljava/lang/IllegalStateException; const-string p2, "closed" invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw p1 :cond_7 new-instance p1, Ljava/lang/IllegalArgumentException; new-instance v0, Ljava/lang/StringBuilder; invoke-direct {v0}, Ljava/lang/StringBuilder;->()V const-string v1, "byteCount < 0: " invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder; invoke-virtual {v0, p2, p3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder; invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String; move-result-object p2 invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V goto :goto_3 :goto_2 throw p1 :goto_3 goto :goto_2 .end method .method public b()Lc/y; .locals 1 iget-object v0, p0, Lc/l;->a:Lc/g; invoke-interface {v0}, Lc/w;->b()Lc/y; move-result-object v0 return-object v0 .end method .method public close()V .locals 1 iget-boolean v0, p0, Lc/l;->d:Z if-eqz v0, :cond_0 return-void :cond_0 iget-object v0, p0, Lc/l;->b:Ljava/util/zip/Inflater; invoke-virtual {v0}, Ljava/util/zip/Inflater;->end()V const/4 v0, 0x1 iput-boolean v0, p0, Lc/l;->d:Z iget-object v0, p0, Lc/l;->a:Lc/g; invoke-interface {v0}, Lc/w;->close()V return-void .end method .method public h()Z .locals 5 iget-object v0, p0, Lc/l;->b:Ljava/util/zip/Inflater; invoke-virtual {v0}, Ljava/util/zip/Inflater;->needsInput()Z move-result v0 const/4 v1, 0x0 if-nez v0, :cond_0 return v1 :cond_0 invoke-direct {p0}, Lc/l;->i()V iget-object v0, p0, Lc/l;->b:Ljava/util/zip/Inflater; invoke-virtual {v0}, Ljava/util/zip/Inflater;->getRemaining()I move-result v0 if-nez v0, :cond_2 iget-object v0, p0, Lc/l;->a:Lc/g; invoke-interface {v0}, Lc/g;->c()Z move-result v0 if-eqz v0, :cond_1 const/4 v0, 0x1 return v0 :cond_1 iget-object v0, p0, Lc/l;->a:Lc/g; invoke-interface {v0}, Lc/g;->a()Lc/e; move-result-object v0 iget-object v0, v0, Lc/e;->b:Lc/s; iget v2, v0, Lc/s;->c:I iget v3, v0, Lc/s;->b:I sub-int/2addr v2, v3 iput v2, p0, Lc/l;->c:I iget-object v2, p0, Lc/l;->b:Ljava/util/zip/Inflater; iget-object v0, v0, Lc/s;->a:[B iget v4, p0, Lc/l;->c:I invoke-virtual {v2, v0, v3, v4}, Ljava/util/zip/Inflater;->setInput([BII)V return v1 :cond_2 new-instance v0, Ljava/lang/IllegalStateException; const-string v1, "?" invoke-direct {v0, v1}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw v0 .end method