apkfuckery/com.discord/smali/okhttp3/internal/framed/Http2$FrameLogger.smali
2019-02-04 21:05:16 +01:00

618 lines
13 KiB
Smali

.class final Lokhttp3/internal/framed/Http2$FrameLogger;
.super Ljava/lang/Object;
.source "Http2.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lokhttp3/internal/framed/Http2;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x18
name = "FrameLogger"
.end annotation
# static fields
.field private static final BINARY:[Ljava/lang/String;
.field private static final FLAGS:[Ljava/lang/String;
.field private static final TYPES:[Ljava/lang/String;
# direct methods
.method static constructor <clinit>()V
.locals 14
.prologue
const/16 v11, 0x8
const/4 v13, 0x4
const/4 v12, 0x3
const/4 v10, 0x1
const/4 v6, 0x0
const/16 v5, 0xa
new-array v5, v5, [Ljava/lang/String;
const-string v7, "DATA"
aput-object v7, v5, v6
const-string v7, "HEADERS"
aput-object v7, v5, v10
const/4 v7, 0x2
const-string v8, "PRIORITY"
aput-object v8, v5, v7
const-string v7, "RST_STREAM"
aput-object v7, v5, v12
const-string v7, "SETTINGS"
aput-object v7, v5, v13
const/4 v7, 0x5
const-string v8, "PUSH_PROMISE"
aput-object v8, v5, v7
const/4 v7, 0x6
const-string v8, "PING"
aput-object v8, v5, v7
const/4 v7, 0x7
const-string v8, "GOAWAY"
aput-object v8, v5, v7
const-string v7, "WINDOW_UPDATE"
aput-object v7, v5, v11
const/16 v7, 0x9
const-string v8, "CONTINUATION"
aput-object v8, v5, v7
sput-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->TYPES:[Ljava/lang/String;
const/16 v5, 0x40
new-array v5, v5, [Ljava/lang/String;
sput-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const/16 v5, 0x100
new-array v5, v5, [Ljava/lang/String;
sput-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
const/4 v2, 0x0
.local v2, "i":I
:goto_0
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
array-length v5, v5
if-ge v2, v5, :cond_0
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
const-string v7, "%8s"
new-array v8, v10, [Ljava/lang/Object;
invoke-static {v2}, Ljava/lang/Integer;->toBinaryString(I)Ljava/lang/String;
move-result-object v9
aput-object v9, v8, v6
invoke-static {v7, v8}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v7
const/16 v8, 0x20
const/16 v9, 0x30
invoke-virtual {v7, v8, v9}, Ljava/lang/String;->replace(CC)Ljava/lang/String;
move-result-object v7
aput-object v7, v5, v2
add-int/lit8 v2, v2, 0x1
goto :goto_0
:cond_0
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const-string v7, ""
aput-object v7, v5, v6
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const-string v7, "END_STREAM"
aput-object v7, v5, v10
new-array v4, v10, [I
aput v10, v4, v6
.local v4, "prefixFlags":[I
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const-string v7, "PADDED"
aput-object v7, v5, v11
array-length v7, v4
move v5, v6
:goto_1
if-ge v5, v7, :cond_1
aget v3, v4, v5
.local v3, "prefixFlag":I
sget-object v8, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
or-int/lit8 v9, v3, 0x8
new-instance v10, Ljava/lang/StringBuilder;
invoke-direct {v10}, Ljava/lang/StringBuilder;-><init>()V
sget-object v11, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v11, v11, v3
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v10
const-string v11, "|PADDED"
invoke-virtual {v10, v11}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v10
invoke-virtual {v10}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v10
aput-object v10, v8, v9
add-int/lit8 v5, v5, 0x1
goto :goto_1
.end local v3 # "prefixFlag":I
:cond_1
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const-string v7, "END_HEADERS"
aput-object v7, v5, v13
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const/16 v7, 0x20
const-string v8, "PRIORITY"
aput-object v8, v5, v7
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
const/16 v7, 0x24
const-string v8, "END_HEADERS|PRIORITY"
aput-object v8, v5, v7
new-array v1, v12, [I
fill-array-data v1, :array_0
.local v1, "frameFlags":[I
array-length v8, v1
move v7, v6
:goto_2
if-ge v7, v8, :cond_3
aget v0, v1, v7
.local v0, "frameFlag":I
array-length v9, v4
move v5, v6
:goto_3
if-ge v5, v9, :cond_2
aget v3, v4, v5
.restart local v3 # "prefixFlag":I
sget-object v10, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
or-int v11, v3, v0
new-instance v12, Ljava/lang/StringBuilder;
invoke-direct {v12}, Ljava/lang/StringBuilder;-><init>()V
sget-object v13, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v13, v13, v3
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
const/16 v13, 0x7c
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v12
sget-object v13, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v13, v13, v0
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v12
aput-object v12, v10, v11
sget-object v10, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
or-int v11, v3, v0
or-int/lit8 v11, v11, 0x8
new-instance v12, Ljava/lang/StringBuilder;
invoke-direct {v12}, Ljava/lang/StringBuilder;-><init>()V
sget-object v13, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v13, v13, v3
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
const/16 v13, 0x7c
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
move-result-object v12
sget-object v13, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v13, v13, v0
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
const-string v13, "|PADDED"
invoke-virtual {v12, v13}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v12
invoke-virtual {v12}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v12
aput-object v12, v10, v11
add-int/lit8 v5, v5, 0x1
goto :goto_3
.end local v3 # "prefixFlag":I
:cond_2
add-int/lit8 v5, v7, 0x1
move v7, v5
goto :goto_2
.end local v0 # "frameFlag":I
:cond_3
const/4 v2, 0x0
:goto_4
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
array-length v5, v5
if-ge v2, v5, :cond_5
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v5, v5, v2
if-nez v5, :cond_4
sget-object v5, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
sget-object v6, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
aget-object v6, v6, v2
aput-object v6, v5, v2
:cond_4
add-int/lit8 v2, v2, 0x1
goto :goto_4
:cond_5
return-void
nop
:array_0
.array-data 4
0x4
0x20
0x24
.end array-data
.end method
.method constructor <init>()V
.locals 0
.prologue
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method static formatFlags(BB)Ljava/lang/String;
.locals 3
.param p0, "type" # B
.param p1, "flags" # B
.prologue
if-nez p1, :cond_0
const-string v1, ""
:goto_0
return-object v1
:cond_0
packed-switch p0, :pswitch_data_0
:pswitch_0
sget-object v1, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
array-length v1, v1
if-ge p1, v1, :cond_2
sget-object v1, Lokhttp3/internal/framed/Http2$FrameLogger;->FLAGS:[Ljava/lang/String;
aget-object v0, v1, p1
.local v0, "result":Ljava/lang/String;
:goto_1
const/4 v1, 0x5
if-ne p0, v1, :cond_3
and-int/lit8 v1, p1, 0x4
if-eqz v1, :cond_3
const-string v1, "HEADERS"
const-string v2, "PUSH_PROMISE"
invoke-virtual {v0, v1, v2}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v1
goto :goto_0
.end local v0 # "result":Ljava/lang/String;
:pswitch_1
const/4 v1, 0x1
if-ne p1, v1, :cond_1
const-string v1, "ACK"
goto :goto_0
:cond_1
sget-object v1, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
aget-object v1, v1, p1
goto :goto_0
:pswitch_2
sget-object v1, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
aget-object v1, v1, p1
goto :goto_0
:cond_2
sget-object v1, Lokhttp3/internal/framed/Http2$FrameLogger;->BINARY:[Ljava/lang/String;
aget-object v0, v1, p1
goto :goto_1
.restart local v0 # "result":Ljava/lang/String;
:cond_3
if-nez p0, :cond_4
and-int/lit8 v1, p1, 0x20
if-eqz v1, :cond_4
const-string v1, "PRIORITY"
const-string v2, "COMPRESSED"
invoke-virtual {v0, v1, v2}, Ljava/lang/String;->replace(Ljava/lang/CharSequence;Ljava/lang/CharSequence;)Ljava/lang/String;
move-result-object v1
goto :goto_0
:cond_4
move-object v1, v0
goto :goto_0
nop
:pswitch_data_0
.packed-switch 0x2
:pswitch_2
:pswitch_2
:pswitch_1
:pswitch_0
:pswitch_1
:pswitch_2
:pswitch_2
.end packed-switch
.end method
.method static formatHeader(ZIIBB)Ljava/lang/String;
.locals 7
.param p0, "inbound" # Z
.param p1, "streamId" # I
.param p2, "length" # I
.param p3, "type" # B
.param p4, "flags" # B
.prologue
const/4 v6, 0x1
const/4 v5, 0x0
sget-object v2, Lokhttp3/internal/framed/Http2$FrameLogger;->TYPES:[Ljava/lang/String;
array-length v2, v2
if-ge p3, v2, :cond_0
sget-object v2, Lokhttp3/internal/framed/Http2$FrameLogger;->TYPES:[Ljava/lang/String;
aget-object v1, v2, p3
.local v1, "formattedType":Ljava/lang/String;
:goto_0
invoke-static {p3, p4}, Lokhttp3/internal/framed/Http2$FrameLogger;->formatFlags(BB)Ljava/lang/String;
move-result-object v0
.local v0, "formattedFlags":Ljava/lang/String;
const-string v3, "%s 0x%08x %5d %-13s %s"
const/4 v2, 0x5
new-array v4, v2, [Ljava/lang/Object;
if-eqz p0, :cond_1
const-string v2, "<<"
:goto_1
aput-object v2, v4, v5
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
aput-object v2, v4, v6
const/4 v2, 0x2
invoke-static {p2}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v5
aput-object v5, v4, v2
const/4 v2, 0x3
aput-object v1, v4, v2
const/4 v2, 0x4
aput-object v0, v4, v2
invoke-static {v3, v4}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v2
return-object v2
.end local v0 # "formattedFlags":Ljava/lang/String;
.end local v1 # "formattedType":Ljava/lang/String;
:cond_0
const-string v2, "0x%02x"
new-array v3, v6, [Ljava/lang/Object;
invoke-static {p3}, Ljava/lang/Byte;->valueOf(B)Ljava/lang/Byte;
move-result-object v4
aput-object v4, v3, v5
invoke-static {v2, v3}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
goto :goto_0
.restart local v0 # "formattedFlags":Ljava/lang/String;
.restart local v1 # "formattedType":Ljava/lang/String;
:cond_1
const-string v2, ">>"
goto :goto_1
.end method