.class final Lb/a/h/f; .super Ljava/lang/Object; .source "" # annotations .annotation system Ldalvik/annotation/MemberClasses; value = { Lb/a/h/f$a; } .end annotation # instance fields .field final a:Z .field final b:Ljava/util/Random; .field final c:Lc/f; .field d:Z .field final e:Lc/e; .field final f:Lb/a/h/f$a; .field g:Z .field final h:[B .field final i:[B # direct methods .method constructor (ZLc/f;Ljava/util/Random;)V .locals 1 invoke-direct {p0}, Ljava/lang/Object;->()V new-instance v0, Lc/e; invoke-direct {v0}, Lc/e;->()V iput-object v0, p0, Lb/a/h/f;->e:Lc/e; new-instance v0, Lb/a/h/f$a; invoke-direct {v0, p0}, Lb/a/h/f$a;->(Lb/a/h/f;)V iput-object v0, p0, Lb/a/h/f;->f:Lb/a/h/f$a; if-eqz p2, :cond_3 if-eqz p3, :cond_2 iput-boolean p1, p0, Lb/a/h/f;->a:Z iput-object p2, p0, Lb/a/h/f;->c:Lc/f; iput-object p3, p0, Lb/a/h/f;->b:Ljava/util/Random; const/4 p2, 0x0 if-eqz p1, :cond_0 const/4 p3, 0x4 new-array p3, p3, [B goto :goto_0 :cond_0 move-object p3, p2 :goto_0 iput-object p3, p0, Lb/a/h/f;->h:[B if-eqz p1, :cond_1 const/16 p1, 0x2000 new-array p2, p1, [B :cond_1 iput-object p2, p0, Lb/a/h/f;->i:[B return-void :cond_2 new-instance p1, Ljava/lang/NullPointerException; const-string p2, "random == null" invoke-direct {p1, p2}, Ljava/lang/NullPointerException;->(Ljava/lang/String;)V throw p1 :cond_3 new-instance p1, Ljava/lang/NullPointerException; const-string p2, "sink == null" invoke-direct {p1, p2}, Ljava/lang/NullPointerException;->(Ljava/lang/String;)V throw p1 .end method .method private b(ILc/h;)V .locals 7 iget-boolean v0, p0, Lb/a/h/f;->d:Z if-nez v0, :cond_2 invoke-virtual {p2}, Lc/h;->e()I move-result v0 int-to-long v1, v0 const-wide/16 v3, 0x7d cmp-long v5, v1, v3 if-gtz v5, :cond_1 or-int/lit16 p1, p1, 0x80 iget-object v1, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {v1, p1}, Lc/f;->writeByte(I)Lc/f; iget-boolean p1, p0, Lb/a/h/f;->a:Z if-eqz p1, :cond_0 or-int/lit16 p1, v0, 0x80 iget-object v0, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {v0, p1}, Lc/f;->writeByte(I)Lc/f; iget-object p1, p0, Lb/a/h/f;->b:Ljava/util/Random; iget-object v0, p0, Lb/a/h/f;->h:[B invoke-virtual {p1, v0}, Ljava/util/Random;->nextBytes([B)V iget-object p1, p0, Lb/a/h/f;->c:Lc/f; iget-object v0, p0, Lb/a/h/f;->h:[B invoke-interface {p1, v0}, Lc/f;->write([B)Lc/f; invoke-virtual {p2}, Lc/h;->g()[B move-result-object p1 array-length p2, p1 int-to-long v2, p2 iget-object v4, p0, Lb/a/h/f;->h:[B const-wide/16 v5, 0x0 move-object v1, p1 invoke-static/range {v1 .. v6}, Lb/a/h/d;->a([BJ[BJ)V iget-object p2, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p2, p1}, Lc/f;->write([B)Lc/f; goto :goto_0 :cond_0 iget-object p1, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p1, v0}, Lc/f;->writeByte(I)Lc/f; iget-object p1, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p1, p2}, Lc/f;->a(Lc/h;)Lc/f; :goto_0 iget-object p1, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p1}, Lc/f;->flush()V return-void :cond_1 new-instance p1, Ljava/lang/IllegalArgumentException; const-string p2, "Payload size must be less than or equal to 125" invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 :cond_2 new-instance p1, Ljava/io/IOException; const-string p2, "closed" invoke-direct {p1, p2}, Ljava/io/IOException;->(Ljava/lang/String;)V throw p1 .end method # virtual methods .method a(IJ)Lc/v; .locals 2 iget-boolean v0, p0, Lb/a/h/f;->g:Z if-nez v0, :cond_0 const/4 v0, 0x1 iput-boolean v0, p0, Lb/a/h/f;->g:Z iget-object v1, p0, Lb/a/h/f;->f:Lb/a/h/f$a; iput p1, v1, Lb/a/h/f$a;->a:I iput-wide p2, v1, Lb/a/h/f$a;->b:J iput-boolean v0, v1, Lb/a/h/f$a;->c:Z const/4 p1, 0x0 iput-boolean p1, v1, Lb/a/h/f$a;->d:Z return-object v1 :cond_0 new-instance p1, Ljava/lang/IllegalStateException; const-string p2, "Another message writer is active. Did you call close()?" invoke-direct {p1, p2}, Ljava/lang/IllegalStateException;->(Ljava/lang/String;)V throw p1 .end method .method a(IJZZ)V .locals 9 iget-boolean v0, p0, Lb/a/h/f;->d:Z if-nez v0, :cond_8 const/4 v0, 0x0 if-eqz p4, :cond_0 goto :goto_0 :cond_0 const/4 p1, 0x0 :goto_0 if-eqz p5, :cond_1 or-int/lit16 p1, p1, 0x80 :cond_1 iget-object p4, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p4, p1}, Lc/f;->writeByte(I)Lc/f; iget-boolean p1, p0, Lb/a/h/f;->a:Z if-eqz p1, :cond_2 const/16 p1, 0x80 goto :goto_1 :cond_2 const/4 p1, 0x0 :goto_1 const-wide/16 p4, 0x7d cmp-long v1, p2, p4 if-gtz v1, :cond_3 long-to-int p4, p2 or-int/2addr p1, p4 iget-object p4, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p4, p1}, Lc/f;->writeByte(I)Lc/f; goto :goto_2 :cond_3 const-wide/32 p4, 0xffff cmp-long v1, p2, p4 if-gtz v1, :cond_4 or-int/lit8 p1, p1, 0x7e iget-object p4, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p4, p1}, Lc/f;->writeByte(I)Lc/f; iget-object p1, p0, Lb/a/h/f;->c:Lc/f; long-to-int p4, p2 invoke-interface {p1, p4}, Lc/f;->writeShort(I)Lc/f; goto :goto_2 :cond_4 or-int/lit8 p1, p1, 0x7f iget-object p4, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p4, p1}, Lc/f;->writeByte(I)Lc/f; iget-object p1, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p1, p2, p3}, Lc/f;->writeLong(J)Lc/f; :goto_2 iget-boolean p1, p0, Lb/a/h/f;->a:Z if-eqz p1, :cond_6 iget-object p1, p0, Lb/a/h/f;->b:Ljava/util/Random; iget-object p4, p0, Lb/a/h/f;->h:[B invoke-virtual {p1, p4}, Ljava/util/Random;->nextBytes([B)V iget-object p1, p0, Lb/a/h/f;->c:Lc/f; iget-object p4, p0, Lb/a/h/f;->h:[B invoke-interface {p1, p4}, Lc/f;->write([B)Lc/f; const-wide/16 p4, 0x0 :goto_3 cmp-long p1, p4, p2 if-gez p1, :cond_7 iget-object p1, p0, Lb/a/h/f;->i:[B array-length p1, p1 int-to-long v1, p1 invoke-static {p2, p3, v1, v2}, Ljava/lang/Math;->min(JJ)J move-result-wide v1 long-to-int p1, v1 iget-object v1, p0, Lb/a/h/f;->e:Lc/e; iget-object v2, p0, Lb/a/h/f;->i:[B invoke-virtual {v1, v2, v0, p1}, Lc/e;->read([BII)I move-result p1 const/4 v1, -0x1 if-eq p1, v1, :cond_5 iget-object v1, p0, Lb/a/h/f;->i:[B int-to-long v7, p1 iget-object v4, p0, Lb/a/h/f;->h:[B move-wide v2, v7 move-wide v5, p4 invoke-static/range {v1 .. v6}, Lb/a/h/d;->a([BJ[BJ)V iget-object v1, p0, Lb/a/h/f;->c:Lc/f; iget-object v2, p0, Lb/a/h/f;->i:[B invoke-interface {v1, v2, v0, p1}, Lc/f;->write([BII)Lc/f; add-long/2addr p4, v7 goto :goto_3 :cond_5 new-instance p1, Ljava/lang/AssertionError; invoke-direct {p1}, Ljava/lang/AssertionError;->()V throw p1 :cond_6 iget-object p1, p0, Lb/a/h/f;->c:Lc/f; iget-object p4, p0, Lb/a/h/f;->e:Lc/e; invoke-interface {p1, p4, p2, p3}, Lc/v;->c(Lc/e;J)V :cond_7 iget-object p1, p0, Lb/a/h/f;->c:Lc/f; invoke-interface {p1}, Lc/f;->h()Lc/f; return-void :cond_8 new-instance p1, Ljava/io/IOException; const-string p2, "closed" invoke-direct {p1, p2}, Ljava/io/IOException;->(Ljava/lang/String;)V goto :goto_5 :goto_4 throw p1 :goto_5 goto :goto_4 .end method .method a(ILc/h;)V .locals 1 sget-object v0, Lc/h;->b:Lc/h; if-nez p1, :cond_0 if-eqz p2, :cond_3 :cond_0 if-eqz p1, :cond_1 invoke-static {p1}, Lb/a/h/d;->b(I)V :cond_1 new-instance v0, Lc/e; invoke-direct {v0}, Lc/e;->()V invoke-virtual {v0, p1}, Lc/e;->writeShort(I)Lc/e; if-eqz p2, :cond_2 invoke-virtual {v0, p2}, Lc/e;->a(Lc/h;)Lc/e; :cond_2 invoke-virtual {v0}, Lc/e;->m()Lc/h; move-result-object v0 :cond_3 monitor-enter p0 const/16 p1, 0x8 const/4 p2, 0x1 :try_start_0 invoke-direct {p0, p1, v0}, Lb/a/h/f;->b(ILc/h;)V :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_1 :try_start_1 iput-boolean p2, p0, Lb/a/h/f;->d:Z monitor-exit p0 return-void :catchall_0 move-exception p1 goto :goto_0 :catchall_1 move-exception p1 iput-boolean p2, p0, Lb/a/h/f;->d:Z throw p1 :goto_0 monitor-exit p0 :try_end_1 .catchall {:try_start_1 .. :try_end_1} :catchall_0 throw p1 .end method .method a(Lc/h;)V .locals 1 monitor-enter p0 const/16 v0, 0x9 :try_start_0 invoke-direct {p0, v0, p1}, Lb/a/h/f;->b(ILc/h;)V monitor-exit p0 return-void :catchall_0 move-exception p1 monitor-exit p0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw p1 .end method .method b(Lc/h;)V .locals 1 monitor-enter p0 const/16 v0, 0xa :try_start_0 invoke-direct {p0, v0, p1}, Lb/a/h/f;->b(ILc/h;)V monitor-exit p0 return-void :catchall_0 move-exception p1 monitor-exit p0 :try_end_0 .catchall {:try_start_0 .. :try_end_0} :catchall_0 throw p1 .end method