IMVideo$a.smali

.class public final Lcom/yysdk/mobile/vpsdk/IMVideo$a;
.super Ljava/lang/Thread;
.source "SourceFile"


# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
    value = Lcom/yysdk/mobile/vpsdk/IMVideo;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x1
    name = "a"
.end annotation


# instance fields
.field final synthetic a:Lcom/yysdk/mobile/vpsdk/IMVideo;


# direct methods
.method public constructor <init>(Lcom/yysdk/mobile/vpsdk/IMVideo;Ljava/lang/String;)V
    .registers 3

    .line 1561
    iput-object p1, p0, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    .line 1562
    invoke-direct {p0, p2}, Ljava/lang/Thread;-><init>(Ljava/lang/String;)V

    return-void
.end method


# virtual methods
.method public final run()V
    .registers 19

    move-object/from16 v1, p0

    .line 1567
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v2, "[run] FramePushingThread TID = "

    invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v3

    invoke-virtual {v3}, Ljava/lang/Thread;->getId()J

    move-result-wide v3

    invoke-virtual {v0, v3, v4}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v3, " entry "

    invoke-virtual {v0, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    const-string v3, "IMVideo"

    invoke-static {v3, v0}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I

    const/4 v0, 0x0

    move-object v4, v0

    .line 1578
    :goto_27
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v5

    invoke-interface {v5}, Ljava/util/concurrent/locks/Lock;->lock()V

    .line 1580
    :goto_30
    :try_start_30
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v5

    iget-boolean v5, v5, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->c:Z

    if-nez v5, :cond_44

    .line 1581
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->w(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Condition;

    move-result-object v5

    invoke-interface {v5}, Ljava/util/concurrent/locks/Condition;->await()V

    goto :goto_30

    .line 1582
    :cond_44
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v5

    iget-boolean v5, v5, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->e:Z

    const/4 v6, 0x1

    if-eqz v5, :cond_80

    .line 1583
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v5

    iput-boolean v6, v5, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->d:Z
    :try_end_57
    .catch Ljava/lang/Exception; {:try_start_30 .. :try_end_57} :catch_187
    .catchall {:try_start_30 .. :try_end_57} :catchall_17c

    .line 1600
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V

    .line 1638
    new-instance v0, Ljava/lang/StringBuilder;

    invoke-direct {v0, v2}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-static {}, Ljava/lang/Thread;->currentThread()Ljava/lang/Thread;

    move-result-object v2

    invoke-virtual {v2}, Ljava/lang/Thread;->getId()J

    move-result-wide v4

    invoke-virtual {v0, v4, v5}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v2, " exit "

    invoke-virtual {v0, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;

    invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object v0

    invoke-static {v3, v0}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I

    return-void

    .line 1587
    :cond_80
    :try_start_80
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v5

    iget-object v5, v5, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->a:[B
    :try_end_88
    .catch Ljava/lang/Exception; {:try_start_80 .. :try_end_88} :catch_187
    .catchall {:try_start_80 .. :try_end_88} :catchall_17c

    .line 1588
    :try_start_88
    iget-object v7, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v7}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v7

    iput-object v0, v7, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->a:[B

    .line 1589
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v0

    iget-wide v8, v0, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->b:J

    .line 1590
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v0

    iget v0, v0, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->f:I

    .line 1591
    iget-object v7, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v7}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v7

    iget v7, v7, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->g:I

    .line 1592
    iget-object v10, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v10}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v10

    iget v10, v10, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->h:I

    .line 1594
    iget-object v11, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v11}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v11

    const/4 v15, 0x0

    iput-boolean v15, v11, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->c:Z

    .line 1595
    iget-object v11, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v11}, Lcom/yysdk/mobile/vpsdk/IMVideo;->n(Lcom/yysdk/mobile/vpsdk/IMVideo;)Z

    move-result v11

    if-eqz v11, :cond_c8

    sget-object v11, Lcom/yysdk/mobile/vpsdk/p;->a:Ljava/lang/String;

    const-string v12, "[run] Push New Frame Start "

    invoke-static {v11, v12}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_c8
    .catch Ljava/lang/Exception; {:try_start_88 .. :try_end_c8} :catch_17a
    .catchall {:try_start_88 .. :try_end_c8} :catchall_17c

    .line 1600
    :cond_c8
    iget-object v11, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v11}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v11

    invoke-interface {v11}, Ljava/util/concurrent/locks/Lock;->unlock()V

    const/16 v11, 0x12

    if-ne v10, v11, :cond_fb

    if-eqz v4, :cond_e0

    .line 1607
    array-length v10, v4

    mul-int v11, v0, v7

    mul-int/lit8 v11, v11, 0x3

    div-int/lit8 v11, v11, 0x2

    if-ge v10, v11, :cond_e8

    :cond_e0
    mul-int v4, v0, v7

    mul-int/lit8 v4, v4, 0x3

    .line 1608
    div-int/lit8 v4, v4, 0x2

    new-array v4, v4, [B

    .line 1610
    :cond_e8
    invoke-static {v5}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;

    move-result-object v11

    const/16 v16, 0x259

    move-object v10, v4

    move v12, v0

    move v13, v7

    move v14, v0

    const/16 v17, 0x0

    move/from16 v15, v16

    invoke-static/range {v10 .. v15}, Lcom/yysdk/mobile/vpsdk/AutoToucherWrapper;->bigo_rgbaToYuv420([BLjava/nio/ByteBuffer;IIII)V

    move-object v13, v4

    goto :goto_fe

    :cond_fb
    const/16 v17, 0x0

    move-object v13, v5

    :goto_fe
    if-eqz v13, :cond_10c

    const/4 v10, 0x1

    const/4 v11, 0x0

    .line 1615
    array-length v14, v13

    move v12, v7

    move v7, v10

    move v10, v11

    move v11, v0

    invoke-static/range {v7 .. v14}, Lcom/yysdk/mobile/vpsdk/VPSDKNativeLibrary;->imPushVideo(IJIII[BI)I

    move-result v15

    goto :goto_10d

    :cond_10c
    const/4 v15, 0x0

    .line 1617
    :goto_10d
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->x(Lcom/yysdk/mobile/vpsdk/IMVideo;)I

    if-lez v15, :cond_127

    .line 1620
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->y(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/j/g;

    move-result-object v0

    if-eqz v0, :cond_134

    .line 1621
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->y(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/j/g;

    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->z(Lcom/yysdk/mobile/vpsdk/IMVideo;)I

    goto :goto_134

    .line 1624
    :cond_127
    invoke-static {v15}, Ljava/lang/String;->valueOf(I)Ljava/lang/String;

    move-result-object v0

    const-string v7, "[run] push video fail ret = "

    invoke-virtual {v7, v0}, Ljava/lang/String;->concat(Ljava/lang/String;)Ljava/lang/String;

    move-result-object v0

    invoke-static {v3, v0}, Lcom/yysdk/mobile/vpsdk/p;->c(Ljava/lang/String;Ljava/lang/String;)I

    .line 1628
    :cond_134
    :goto_134
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->lock()V

    .line 1629
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v0

    iget-boolean v0, v0, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->c:Z

    if-nez v0, :cond_15f

    .line 1630
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->v(Lcom/yysdk/mobile/vpsdk/IMVideo;)Lcom/yysdk/mobile/vpsdk/IMVideo$b;

    move-result-object v0

    iput-boolean v6, v0, Lcom/yysdk/mobile/vpsdk/IMVideo$b;->d:Z

    .line 1631
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->n(Lcom/yysdk/mobile/vpsdk/IMVideo;)Z

    move-result v0

    if-eqz v0, :cond_16e

    sget-object v0, Lcom/yysdk/mobile/vpsdk/p;->a:Ljava/lang/String;

    const-string v6, "[run] Push New Frame Finished"

    invoke-static {v0, v6}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I

    goto :goto_16e

    .line 1634
    :cond_15f
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->n(Lcom/yysdk/mobile/vpsdk/IMVideo;)Z

    move-result v0

    if-eqz v0, :cond_16e

    sget-object v0, Lcom/yysdk/mobile/vpsdk/p;->a:Ljava/lang/String;

    const-string v6, "[run]  Push New Frame Finished , But There\'s a New One."

    invoke-static {v0, v6}, Lcom/yysdk/mobile/vpsdk/p;->a(Ljava/lang/String;Ljava/lang/String;)I

    .line 1636
    :cond_16e
    :goto_16e
    iget-object v0, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v0}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v0

    invoke-interface {v0}, Ljava/util/concurrent/locks/Lock;->unlock()V

    move-object v0, v5

    goto/16 :goto_27

    :catch_17a
    move-object v0, v5

    goto :goto_187

    :catchall_17c
    move-exception v0

    .line 1600
    iget-object v2, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v2}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v2

    invoke-interface {v2}, Ljava/util/concurrent/locks/Lock;->unlock()V

    throw v0

    :catch_187
    :goto_187
    iget-object v5, v1, Lcom/yysdk/mobile/vpsdk/IMVideo$a;->a:Lcom/yysdk/mobile/vpsdk/IMVideo;

    invoke-static {v5}, Lcom/yysdk/mobile/vpsdk/IMVideo;->u(Lcom/yysdk/mobile/vpsdk/IMVideo;)Ljava/util/concurrent/locks/Lock;

    move-result-object v5

    invoke-interface {v5}, Ljava/util/concurrent/locks/Lock;->unlock()V

    goto/16 :goto_27
.end method