DidJSUpdateUiDuringFrameDetector.smali
.class public Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/facebook/react/bridge/NotThreadSafeBridgeIdleDebugListener;
.implements Lcom/facebook/react/uimanager/debug/NotThreadSafeViewHierarchyUpdateDebugListener;
# instance fields
.field private final mTransitionToBusyEvents:Lcom/facebook/react/common/LongArray;
.field private final mTransitionToIdleEvents:Lcom/facebook/react/common/LongArray;
.field private final mViewHierarchyUpdateEnqueuedEvents:Lcom/facebook/react/common/LongArray;
.field private final mViewHierarchyUpdateFinishedEvents:Lcom/facebook/react/common/LongArray;
.field private volatile mWasIdleAtEndOfLastFrame:Z
# direct methods
.method public constructor <init>()V
.registers 3
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/16 v0, 0x14
.line 2
invoke-static {v0}, Lcom/facebook/react/common/LongArray;->createWithInitialCapacity(I)Lcom/facebook/react/common/LongArray;
move-result-object v1
iput-object v1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToIdleEvents:Lcom/facebook/react/common/LongArray;
.line 3
invoke-static {v0}, Lcom/facebook/react/common/LongArray;->createWithInitialCapacity(I)Lcom/facebook/react/common/LongArray;
move-result-object v1
iput-object v1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToBusyEvents:Lcom/facebook/react/common/LongArray;
.line 4
invoke-static {v0}, Lcom/facebook/react/common/LongArray;->createWithInitialCapacity(I)Lcom/facebook/react/common/LongArray;
move-result-object v1
iput-object v1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateEnqueuedEvents:Lcom/facebook/react/common/LongArray;
.line 5
invoke-static {v0}, Lcom/facebook/react/common/LongArray;->createWithInitialCapacity(I)Lcom/facebook/react/common/LongArray;
move-result-object v0
iput-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateFinishedEvents:Lcom/facebook/react/common/LongArray;
const/4 v0, 0x1
.line 6
iput-boolean v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mWasIdleAtEndOfLastFrame:Z
return-void
.end method
.method private static cleanUp(Lcom/facebook/react/common/LongArray;J)V
.registers 10
.line 1
invoke-virtual {p0}, Lcom/facebook/react/common/LongArray;->size()I
move-result v0
const/4 v1, 0x0
const/4 v2, 0x0
const/4 v3, 0x0
:goto_7
if-ge v2, v0, :cond_16
.line 2
invoke-virtual {p0, v2}, Lcom/facebook/react/common/LongArray;->get(I)J
move-result-wide v4
cmp-long v6, v4, p1
if-gez v6, :cond_13
add-int/lit8 v3, v3, 0x1
:cond_13
add-int/lit8 v2, v2, 0x1
goto :goto_7
:cond_16
if-lez v3, :cond_2b
:goto_18
sub-int p1, v0, v3
if-ge v1, p1, :cond_28
add-int p1, v1, v3
.line 3
invoke-virtual {p0, p1}, Lcom/facebook/react/common/LongArray;->get(I)J
move-result-wide p1
invoke-virtual {p0, v1, p1, p2}, Lcom/facebook/react/common/LongArray;->set(IJ)V
add-int/lit8 v1, v1, 0x1
goto :goto_18
.line 4
:cond_28
invoke-virtual {p0, v3}, Lcom/facebook/react/common/LongArray;->dropTail(I)V
:cond_2b
return-void
.end method
.method private didEndFrameIdle(JJ)Z
.registers 8
.line 1
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToIdleEvents:Lcom/facebook/react/common/LongArray;
.line 2
invoke-static {v0, p1, p2, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->getLastEventBetweenTimestamps(Lcom/facebook/react/common/LongArray;JJ)J
move-result-wide v0
.line 3
iget-object v2, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToBusyEvents:Lcom/facebook/react/common/LongArray;
.line 4
invoke-static {v2, p1, p2, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->getLastEventBetweenTimestamps(Lcom/facebook/react/common/LongArray;JJ)J
move-result-wide p1
const-wide/16 p3, -0x1
cmp-long v2, v0, p3
if-nez v2, :cond_19
cmp-long v2, p1, p3
if-nez v2, :cond_19
.line 5
iget-boolean p1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mWasIdleAtEndOfLastFrame:Z
return p1
:cond_19
cmp-long p3, v0, p1
if-lez p3, :cond_1f
const/4 p1, 0x1
goto :goto_20
:cond_1f
const/4 p1, 0x0
:goto_20
return p1
.end method
.method private static getLastEventBetweenTimestamps(Lcom/facebook/react/common/LongArray;JJ)J
.registers 11
const-wide/16 v0, -0x1
const/4 v2, 0x0
.line 1
:goto_3
invoke-virtual {p0}, Lcom/facebook/react/common/LongArray;->size()I
move-result v3
if-ge v2, v3, :cond_1f
.line 2
invoke-virtual {p0, v2}, Lcom/facebook/react/common/LongArray;->get(I)J
move-result-wide v3
cmp-long v5, v3, p1
if-ltz v5, :cond_17
cmp-long v5, v3, p3
if-gez v5, :cond_17
move-wide v0, v3
goto :goto_1c
:cond_17
cmp-long v5, v3, p3
if-ltz v5, :cond_1c
goto :goto_1f
:cond_1c
:goto_1c
add-int/lit8 v2, v2, 0x1
goto :goto_3
:cond_1f
:goto_1f
return-wide v0
.end method
.method private static hasEventBetweenTimestamps(Lcom/facebook/react/common/LongArray;JJ)Z
.registers 10
const/4 v0, 0x0
const/4 v1, 0x0
.line 1
:goto_2
invoke-virtual {p0}, Lcom/facebook/react/common/LongArray;->size()I
move-result v2
if-ge v1, v2, :cond_19
.line 2
invoke-virtual {p0, v1}, Lcom/facebook/react/common/LongArray;->get(I)J
move-result-wide v2
cmp-long v4, v2, p1
if-ltz v4, :cond_16
cmp-long v4, v2, p3
if-gez v4, :cond_16
const/4 p0, 0x1
return p0
:cond_16
add-int/lit8 v1, v1, 0x1
goto :goto_2
:cond_19
return v0
.end method
# virtual methods
.method public declared-synchronized getDidJSHitFrameAndCleanup(JJ)Z
.registers 8
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateFinishedEvents:Lcom/facebook/react/common/LongArray;
.line 2
invoke-static {v0, p1, p2, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->hasEventBetweenTimestamps(Lcom/facebook/react/common/LongArray;JJ)Z
move-result v0
.line 3
invoke-direct {p0, p1, p2, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->didEndFrameIdle(JJ)Z
move-result v1
const/4 v2, 0x1
if-eqz v0, :cond_f
goto :goto_1c
:cond_f
if-eqz v1, :cond_1a
.line 4
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateEnqueuedEvents:Lcom/facebook/react/common/LongArray;
.line 5
invoke-static {v0, p1, p2, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->hasEventBetweenTimestamps(Lcom/facebook/react/common/LongArray;JJ)Z
move-result p1
if-nez p1, :cond_1a
goto :goto_1c
:cond_1a
const/4 p1, 0x0
const/4 v2, 0x0
.line 6
:goto_1c
iget-object p1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToIdleEvents:Lcom/facebook/react/common/LongArray;
invoke-static {p1, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->cleanUp(Lcom/facebook/react/common/LongArray;J)V
.line 7
iget-object p1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToBusyEvents:Lcom/facebook/react/common/LongArray;
invoke-static {p1, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->cleanUp(Lcom/facebook/react/common/LongArray;J)V
.line 8
iget-object p1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateEnqueuedEvents:Lcom/facebook/react/common/LongArray;
invoke-static {p1, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->cleanUp(Lcom/facebook/react/common/LongArray;J)V
.line 9
iget-object p1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateFinishedEvents:Lcom/facebook/react/common/LongArray;
invoke-static {p1, p3, p4}, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->cleanUp(Lcom/facebook/react/common/LongArray;J)V
.line 10
iput-boolean v1, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mWasIdleAtEndOfLastFrame:Z
:try_end_32
.catchall {:try_start_1 .. :try_end_32} :catchall_34
.line 11
monitor-exit p0
return v2
:catchall_34
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized onBridgeDestroyed()V
.registers 1
monitor-enter p0
monitor-exit p0
return-void
.end method
.method public declared-synchronized onTransitionToBridgeBusy()V
.registers 4
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToBusyEvents:Lcom/facebook/react/common/LongArray;
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/facebook/react/common/LongArray;->add(J)V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 2
monitor-exit p0
return-void
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized onTransitionToBridgeIdle()V
.registers 4
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mTransitionToIdleEvents:Lcom/facebook/react/common/LongArray;
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/facebook/react/common/LongArray;->add(J)V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 2
monitor-exit p0
return-void
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized onViewHierarchyUpdateEnqueued()V
.registers 4
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateEnqueuedEvents:Lcom/facebook/react/common/LongArray;
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/facebook/react/common/LongArray;->add(J)V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 2
monitor-exit p0
return-void
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized onViewHierarchyUpdateFinished()V
.registers 4
monitor-enter p0
.line 1
:try_start_1
iget-object v0, p0, Lcom/facebook/react/modules/debug/DidJSUpdateUiDuringFrameDetector;->mViewHierarchyUpdateFinishedEvents:Lcom/facebook/react/common/LongArray;
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v1
invoke-virtual {v0, v1, v2}, Lcom/facebook/react/common/LongArray;->add(J)V
:try_end_a
.catchall {:try_start_1 .. :try_end_a} :catchall_c
.line 2
monitor-exit p0
return-void
:catchall_c
move-exception v0
monitor-exit p0
throw v0
.end method