FabricUIManager.smali
.class public Lcom/facebook/react/fabric/FabricUIManager;
.super Ljava/lang/Object;
.source "SourceFile"
# interfaces
.implements Lcom/facebook/react/bridge/UIManager;
.implements Lcom/facebook/react/bridge/LifecycleEventListener;
# annotations
.annotation build Landroid/annotation/SuppressLint;
value = {
"MissingNativeLoadLibrary"
}
.end annotation
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
}
.end annotation
# static fields
.field public static final ENABLE_FABRIC_LOGS:Z
.field private static final FRAME_TIME_MS:I = 0x10
.field public static final IS_DEVELOPMENT_ENVIRONMENT:Z = false
.field private static final MAX_TIME_IN_FRAME_FOR_NON_BATCHED_OPERATIONS_MS:I = 0x8
.field private static final PRE_MOUNT_ITEMS_INITIAL_SIZE_ARRAY:I = 0xfa
.field public static final TAG:Ljava/lang/String; = "FabricUIManager"
# instance fields
.field private mBatchedExecutionTime:J
.field private mBinding:Lcom/facebook/react/fabric/Binding;
.field private mCommitStartTime:J
.field private mCurrentSynchronousCommitNumber:I
.field private volatile mDestroyed:Z
.field private final mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
.end field
.field private mDispatchViewUpdatesTime:J
.field private final mEventBeatManager:Lcom/facebook/react/fabric/events/EventBeatManager;
.field private final mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
.field private mFinishTransactionCPPTime:J
.field private mFinishTransactionTime:J
.field private mInDispatch:Z
.field private mLayoutTime:J
.field private mMountItems:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/facebook/react/fabric/mounting/mountitems/MountItem;",
">;"
}
.end annotation
.end field
.field private final mMountItemsLock:Ljava/lang/Object;
.field private final mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
.field private mPreMountItems:Ljava/util/ArrayDeque;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayDeque<",
"Lcom/facebook/react/fabric/mounting/mountitems/MountItem;",
">;"
}
.end annotation
.end field
.field private final mPreMountItemsLock:Ljava/lang/Object;
.field private mReDispatchCounter:I
.field private final mReactApplicationContext:Lcom/facebook/react/bridge/ReactApplicationContext;
.field private final mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/concurrent/ConcurrentHashMap<",
"Ljava/lang/Integer;",
"Lcom/facebook/react/uimanager/ThemedReactContext;",
">;"
}
.end annotation
.end field
.field private mRunStartTime:J
.field private mViewCommandMountItems:Ljava/util/List;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/List<",
"Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;",
">;"
}
.end annotation
.end field
.field private final mViewCommandMountItemsLock:Ljava/lang/Object;
# direct methods
.method public static constructor <clinit>()V
.registers 2
.line 1
sget-boolean v0, Lcom/facebook/react/config/ReactFeatureFlags;->enableFabricLogs:Z
if-nez v0, :cond_13
.line 2
invoke-static {}, Lcom/facebook/debug/holder/PrinterHolder;->getPrinter()Lcom/facebook/debug/holder/Printer;
move-result-object v0
sget-object v1, Lcom/facebook/debug/tags/ReactDebugOverlayTags;->FABRIC_UI_MANAGER:Lcom/facebook/debug/debugoverlay/model/DebugOverlayTag;
.line 3
invoke-interface {v0, v1}, Lcom/facebook/debug/holder/Printer;->shouldDisplayLogMessage(Lcom/facebook/debug/debugoverlay/model/DebugOverlayTag;)Z
move-result v0
if-eqz v0, :cond_11
goto :goto_13
:cond_11
const/4 v0, 0x0
goto :goto_14
:cond_13
:goto_13
const/4 v0, 0x1
:goto_14
sput-boolean v0, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
.line 4
invoke-static {}, Lcom/facebook/react/fabric/FabricSoLoader;->staticInit()V
return-void
.end method
.method public constructor <init>(Lcom/facebook/react/bridge/ReactApplicationContext;Lcom/facebook/react/uimanager/ViewManagerRegistry;Lcom/facebook/react/uimanager/events/EventDispatcher;Lcom/facebook/react/fabric/events/EventBeatManager;)V
.registers 8
.line 1
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
new-instance v0, Ljava/util/concurrent/ConcurrentHashMap;
invoke-direct {v0}, Ljava/util/concurrent/ConcurrentHashMap;-><init>()V
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
.line 3
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItemsLock:Ljava/lang/Object;
.line 4
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
.line 5
new-instance v0, Ljava/lang/Object;
invoke-direct {v0}, Ljava/lang/Object;-><init>()V
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItemsLock:Ljava/lang/Object;
const/4 v0, 0x0
.line 6
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
.line 7
iput v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
.line 8
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
iput-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItems:Ljava/util/List;
.line 9
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
iput-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
.line 10
new-instance v1, Ljava/util/ArrayDeque;
const/16 v2, 0xfa
invoke-direct {v1, v2}, Ljava/util/ArrayDeque;-><init>(I)V
iput-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItems:Ljava/util/ArrayDeque;
.line 11
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDestroyed:Z
const-wide/16 v0, 0x0
.line 12
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mRunStartTime:J
.line 13
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBatchedExecutionTime:J
.line 14
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchViewUpdatesTime:J
.line 15
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mCommitStartTime:J
.line 16
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mLayoutTime:J
.line 17
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mFinishTransactionTime:J
.line 18
iput-wide v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mFinishTransactionCPPTime:J
const/16 v0, 0x2710
.line 19
iput v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mCurrentSynchronousCommitNumber:I
.line 20
new-instance v0, Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
const/4 v1, 0x0
invoke-direct {v0, p0, p1, v1}, Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;-><init>(Lcom/facebook/react/fabric/FabricUIManager;Lcom/facebook/react/bridge/ReactContext;Lcom/facebook/react/fabric/FabricUIManager$1;)V
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
.line 21
iput-object p1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactApplicationContext:Lcom/facebook/react/bridge/ReactApplicationContext;
.line 22
new-instance v0, Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-direct {v0, p2}, Lcom/facebook/react/fabric/mounting/MountingManager;-><init>(Lcom/facebook/react/uimanager/ViewManagerRegistry;)V
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
.line 23
iput-object p3, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
.line 24
iput-object p4, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventBeatManager:Lcom/facebook/react/fabric/events/EventBeatManager;
.line 25
invoke-virtual {p1, p0}, Lcom/facebook/react/bridge/ReactContext;->addLifecycleEventListener(Lcom/facebook/react/bridge/LifecycleEventListener;)V
return-void
.end method
.method public static synthetic access$100(Lcom/facebook/react/fabric/FabricUIManager;)Z
.registers 1
iget-boolean p0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDestroyed:Z
return p0
.end method
.method public static synthetic access$200(Lcom/facebook/react/fabric/FabricUIManager;J)V
.registers 3
invoke-direct {p0, p1, p2}, Lcom/facebook/react/fabric/FabricUIManager;->dispatchPreMountItems(J)V
return-void
.end method
.method public static synthetic access$300(Lcom/facebook/react/fabric/FabricUIManager;)V
.registers 1
invoke-direct {p0}, Lcom/facebook/react/fabric/FabricUIManager;->tryDispatchMountItems()V
return-void
.end method
.method public static synthetic access$400(Lcom/facebook/react/fabric/FabricUIManager;)Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
.registers 1
iget-object p0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
return-object p0
.end method
.method private createBatchMountItem([Lcom/facebook/react/fabric/mounting/mountitems/MountItem;II)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 5
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/BatchMountItem;
invoke-direct {v0, p1, p2, p3}, Lcom/facebook/react/fabric/mounting/mountitems/BatchMountItem;-><init>([Lcom/facebook/react/fabric/mounting/mountitems/MountItem;II)V
return-object v0
.end method
.method private createMountItem(Ljava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Ljava/lang/Object;IIZ)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 15
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
.line 1
invoke-static {p1}, Lcom/facebook/react/fabric/FabricComponents;->getFabricComponentName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v4
.line 2
iget-object p1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
invoke-static {p4}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
invoke-virtual {p1, v0}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object p1
move-object v1, p1
check-cast v1, Lcom/facebook/react/uimanager/ThemedReactContext;
if-eqz v1, :cond_21
.line 3
new-instance p1, Lcom/facebook/react/fabric/mounting/mountitems/CreateMountItem;
move-object v6, p3
check-cast v6, Lcom/facebook/react/uimanager/StateWrapper;
move-object v0, p1
move v2, p4
move v3, p5
move-object v5, p2
move v7, p6
invoke-direct/range {v0 .. v7}, Lcom/facebook/react/fabric/mounting/mountitems/CreateMountItem;-><init>(Lcom/facebook/react/uimanager/ThemedReactContext;IILjava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/uimanager/StateWrapper;Z)V
return-object p1
.line 4
:cond_21
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string p2, "Unable to find ReactContext for root: "
.line 5
invoke-static {p2, p4}, Landroidx/appcompat/widget/h;->a(Ljava/lang/String;I)Ljava/lang/String;
move-result-object p2
.line 6
invoke-direct {p1, p2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private deleteMountItem(I)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 3
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/DeleteMountItem;
invoke-direct {v0, p1}, Lcom/facebook/react/fabric/mounting/mountitems/DeleteMountItem;-><init>(I)V
return-object v0
.end method
.method private dispatchCommandMountItem(Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;)V
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.line 1
sget-boolean v0, Lcom/facebook/react/config/ReactFeatureFlags;->allowEarlyViewCommandExecution:Z
if-eqz v0, :cond_11
.line 2
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 3
:try_start_7
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItems:Ljava/util/List;
invoke-interface {v1, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 4
monitor-exit v0
goto :goto_1a
:catchall_e
move-exception p1
monitor-exit v0
:try_end_10
.catchall {:try_start_7 .. :try_end_10} :catchall_e
throw p1
.line 5
:cond_11
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 6
:try_start_14
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
invoke-interface {v1, p1}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 7
monitor-exit v0
:goto_1a
return-void
:catchall_1b
move-exception p1
monitor-exit v0
:try_end_1d
.catchall {:try_start_14 .. :try_end_1d} :catchall_1b
throw p1
.end method
.method private dispatchMountItems()Z
.registers 14
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
const-string v0, "Caught exception executing ViewCommand: "
.line 1
iget v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
const-wide/16 v2, 0x0
if-nez v1, :cond_a
.line 2
iput-wide v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBatchedExecutionTime:J
.line 3
:cond_a
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v4
iput-wide v4, p0, Lcom/facebook/react/fabric/FabricUIManager;->mRunStartTime:J
.line 4
invoke-direct {p0}, Lcom/facebook/react/fabric/FabricUIManager;->getAndResetViewCommandMountItems()Ljava/util/List;
move-result-object v1
.line 5
invoke-direct {p0}, Lcom/facebook/react/fabric/FabricUIManager;->getAndResetMountItems()Ljava/util/List;
move-result-object v4
const/4 v5, 0x0
if-nez v4, :cond_1e
if-nez v1, :cond_1e
return v5
:cond_1e
const-string v5, "FabricUIManager"
if-eqz v1, :cond_a6
const-string v6, "FabricUIManager::mountViews viewCommandMountItems to execute: "
.line 6
invoke-static {v6}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
.line 7
invoke-interface {v1}, Ljava/util/List;->size()I
move-result v7
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v6}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
.line 8
invoke-static {v2, v3, v6}, Lcom/facebook/systrace/Systrace;->beginSection(JLjava/lang/String;)V
.line 9
invoke-interface {v1}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v1
:goto_3a
invoke-interface {v1}, Ljava/util/Iterator;->hasNext()Z
move-result v6
if-eqz v6, :cond_a3
invoke-interface {v1}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v6
check-cast v6, Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;
.line 10
sget-boolean v7, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
if-eqz v7, :cond_5e
const-string v7, "dispatchMountItems: Executing viewCommandMountItem: "
.line 11
invoke-static {v7}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v7
.line 12
invoke-virtual {v6}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v8
invoke-virtual {v7, v8}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v7}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v7
invoke-static {v5, v7}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 13
:cond_5e
:try_start_5e
iget-object v7, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-interface {v6, v7}, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;->execute(Lcom/facebook/react/fabric/mounting/MountingManager;)V
:try_end_63
.catch Lcom/facebook/react/bridge/RetryableMountingLayerException; {:try_start_5e .. :try_end_63} :catch_7d
.catchall {:try_start_5e .. :try_end_63} :catchall_64
goto :goto_3a
:catchall_64
move-exception v7
.line 14
new-instance v8, Ljava/lang/RuntimeException;
.line 15
invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v9
.line 16
invoke-virtual {v6}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v6
invoke-virtual {v9, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-direct {v8, v6, v7}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 17
invoke-static {v5, v8}, Lcom/facebook/react/bridge/ReactSoftException;->logSoftException(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_3a
:catch_7d
move-exception v7
.line 18
invoke-virtual {v6}, Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;->getRetries()I
move-result v8
if-nez v8, :cond_8b
.line 19
invoke-virtual {v6}, Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;->incrementRetries()V
.line 20
invoke-direct {p0, v6}, Lcom/facebook/react/fabric/FabricUIManager;->dispatchCommandMountItem(Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;)V
goto :goto_3a
.line 21
:cond_8b
new-instance v8, Lcom/facebook/react/bridge/ReactNoCrashSoftException;
.line 22
invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v9
.line 23
invoke-virtual {v6}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v6
invoke-virtual {v9, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v9}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v6
invoke-direct {v8, v6, v7}, Lcom/facebook/react/bridge/ReactNoCrashSoftException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 24
invoke-static {v5, v8}, Lcom/facebook/react/bridge/ReactSoftException;->logSoftException(Ljava/lang/String;Ljava/lang/Throwable;)V
goto :goto_3a
.line 25
:cond_a3
invoke-static {v2, v3}, Lcom/facebook/systrace/Systrace;->endSection(J)V
.line 26
:cond_a6
invoke-direct {p0}, Lcom/facebook/react/fabric/FabricUIManager;->getAndResetPreMountItems()Ljava/util/ArrayDeque;
move-result-object v0
if-eqz v0, :cond_d5
const-string v1, "FabricUIManager::mountViews preMountItems to execute: "
.line 27
invoke-static {v1}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 28
invoke-virtual {v0}, Ljava/util/ArrayDeque;->size()I
move-result v6
invoke-virtual {v1, v6}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
.line 29
invoke-static {v2, v3, v1}, Lcom/facebook/systrace/Systrace;->beginSection(JLjava/lang/String;)V
.line 30
:goto_c0
invoke-virtual {v0}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v1
if-nez v1, :cond_d2
.line 31
invoke-virtual {v0}, Ljava/util/ArrayDeque;->pollFirst()Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
iget-object v6, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-interface {v1, v6}, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;->execute(Lcom/facebook/react/fabric/mounting/MountingManager;)V
goto :goto_c0
.line 32
:cond_d2
invoke-static {v2, v3}, Lcom/facebook/systrace/Systrace;->endSection(J)V
:cond_d5
if-eqz v4, :cond_13a
const-string v0, "FabricUIManager::mountViews mountItems to execute: "
.line 33
invoke-static {v0}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
.line 34
invoke-interface {v4}, Ljava/util/List;->size()I
move-result v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
.line 35
invoke-static {v2, v3, v0}, Lcom/facebook/systrace/Systrace;->beginSection(JLjava/lang/String;)V
.line 36
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v0
.line 37
invoke-interface {v4}, Ljava/util/List;->iterator()Ljava/util/Iterator;
move-result-object v4
:goto_f3
invoke-interface {v4}, Ljava/util/Iterator;->hasNext()Z
move-result v6
if-eqz v6, :cond_130
invoke-interface {v4}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v6
check-cast v6, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.line 38
sget-boolean v7, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
if-eqz v7, :cond_12a
.line 39
invoke-virtual {v6}, Ljava/lang/Object;->toString()Ljava/lang/String;
move-result-object v7
const-string v8, "\n"
invoke-virtual {v7, v8}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v7
.line 40
array-length v8, v7
const/4 v9, 0x0
:goto_10f
if-ge v9, v8, :cond_12a
aget-object v10, v7, v9
.line 41
new-instance v11, Ljava/lang/StringBuilder;
invoke-direct {v11}, Ljava/lang/StringBuilder;-><init>()V
const-string v12, "dispatchMountItems: Executing mountItem: "
invoke-virtual {v11, v12}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11, v10}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v11}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v10
invoke-static {v5, v10}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;)V
add-int/lit8 v9, v9, 0x1
goto :goto_10f
.line 42
:cond_12a
iget-object v7, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-interface {v6, v7}, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;->execute(Lcom/facebook/react/fabric/mounting/MountingManager;)V
goto :goto_f3
.line 43
:cond_130
iget-wide v4, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBatchedExecutionTime:J
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v6
sub-long/2addr v6, v0
add-long/2addr v6, v4
iput-wide v6, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBatchedExecutionTime:J
.line 44
:cond_13a
invoke-static {v2, v3}, Lcom/facebook/systrace/Systrace;->endSection(J)V
const/4 v0, 0x1
return v0
.end method
.method private dispatchPreMountItems(J)V
.registers 12
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
const-string v0, "FabricUIManager::premountViews"
const-wide/16 v1, 0x0
.line 1
invoke-static {v1, v2, v0}, Lcom/facebook/systrace/Systrace;->beginSection(JLjava/lang/String;)V
const/4 v0, 0x1
.line 2
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
:goto_a
const-wide/16 v3, 0x10
const/4 v0, 0x0
.line 3
:try_start_d
invoke-static {}, Ljava/lang/System;->nanoTime()J
move-result-wide v5
sub-long/2addr v5, p1
const-wide/32 v7, 0xf4240
div-long/2addr v5, v7
sub-long/2addr v3, v5
const-wide/16 v5, 0x8
cmp-long v7, v3, v5
if-gez v7, :cond_1e
goto :goto_2a
.line 4
:cond_1e
iget-object v3, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItemsLock:Ljava/lang/Object;
monitor-enter v3
:try_end_21
.catchall {:try_start_d .. :try_end_21} :catchall_42
.line 5
:try_start_21
iget-object v4, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItems:Ljava/util/ArrayDeque;
invoke-virtual {v4}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v4
if-eqz v4, :cond_30
.line 6
monitor-exit v3
:try_end_2a
.catchall {:try_start_21 .. :try_end_2a} :catchall_3f
.line 7
:goto_2a
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
.line 8
invoke-static {v1, v2}, Lcom/facebook/systrace/Systrace;->endSection(J)V
return-void
.line 9
:cond_30
:try_start_30
iget-object v4, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItems:Ljava/util/ArrayDeque;
invoke-virtual {v4}, Ljava/util/ArrayDeque;->pollFirst()Ljava/lang/Object;
move-result-object v4
check-cast v4, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.line 10
monitor-exit v3
:try_end_39
.catchall {:try_start_30 .. :try_end_39} :catchall_3f
.line 11
:try_start_39
iget-object v3, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-interface {v4, v3}, Lcom/facebook/react/fabric/mounting/mountitems/MountItem;->execute(Lcom/facebook/react/fabric/mounting/MountingManager;)V
:try_end_3e
.catchall {:try_start_39 .. :try_end_3e} :catchall_42
goto :goto_a
:catchall_3f
move-exception p1
.line 12
:try_start_40
monitor-exit v3
:try_end_41
.catchall {:try_start_40 .. :try_end_41} :catchall_3f
:try_start_41
throw p1
:try_end_42
.catchall {:try_start_41 .. :try_end_42} :catchall_42
:catchall_42
move-exception p1
.line 13
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
.line 14
throw p1
.end method
.method private getAndResetMountItems()Ljava/util/List;
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Lcom/facebook/react/fabric/mounting/mountitems/MountItem;",
">;"
}
.end annotation
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
.line 3
invoke-interface {v1}, Ljava/util/List;->isEmpty()Z
move-result v2
if-eqz v2, :cond_e
const/4 v1, 0x0
.line 4
monitor-exit v0
return-object v1
.line 5
:cond_e
new-instance v2, Ljava/util/ArrayList;
invoke-direct {v2}, Ljava/util/ArrayList;-><init>()V
iput-object v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
.line 6
monitor-exit v0
return-object v1
:catchall_17
move-exception v1
.line 7
monitor-exit v0
:try_end_19
.catchall {:try_start_3 .. :try_end_19} :catchall_17
throw v1
.end method
.method private getAndResetPreMountItems()Ljava/util/ArrayDeque;
.registers 5
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/ArrayDeque<",
"Lcom/facebook/react/fabric/mounting/mountitems/MountItem;",
">;"
}
.end annotation
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItems:Ljava/util/ArrayDeque;
.line 3
invoke-virtual {v1}, Ljava/util/ArrayDeque;->isEmpty()Z
move-result v2
if-eqz v2, :cond_e
const/4 v1, 0x0
.line 4
monitor-exit v0
return-object v1
.line 5
:cond_e
new-instance v2, Ljava/util/ArrayDeque;
const/16 v3, 0xfa
invoke-direct {v2, v3}, Ljava/util/ArrayDeque;-><init>(I)V
iput-object v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItems:Ljava/util/ArrayDeque;
.line 6
monitor-exit v0
return-object v1
:catchall_19
move-exception v1
.line 7
monitor-exit v0
:try_end_1b
.catchall {:try_start_3 .. :try_end_1b} :catchall_19
throw v1
.end method
.method private getAndResetViewCommandMountItems()Ljava/util/List;
.registers 5
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/List<",
"Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;",
">;"
}
.end annotation
.line 1
sget-boolean v0, Lcom/facebook/react/config/ReactFeatureFlags;->allowEarlyViewCommandExecution:Z
const/4 v1, 0x0
if-nez v0, :cond_6
return-object v1
.line 2
:cond_6
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 3
:try_start_9
iget-object v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItems:Ljava/util/List;
.line 4
invoke-interface {v2}, Ljava/util/List;->isEmpty()Z
move-result v3
if-eqz v3, :cond_13
.line 5
monitor-exit v0
return-object v1
.line 6
:cond_13
new-instance v1, Ljava/util/ArrayList;
invoke-direct {v1}, Ljava/util/ArrayList;-><init>()V
iput-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mViewCommandMountItems:Ljava/util/List;
.line 7
monitor-exit v0
return-object v2
:catchall_1c
move-exception v1
.line 8
monitor-exit v0
:try_end_1e
.catchall {:try_start_9 .. :try_end_1e} :catchall_1c
throw v1
.end method
.method private insertMountItem(III)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 5
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/InsertMountItem;
invoke-direct {v0, p1, p2, p3}, Lcom/facebook/react/fabric/mounting/mountitems/InsertMountItem;-><init>(III)V
return-object v0
.end method
.method private measure(ILjava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;FFFF)J
.registers 21
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
const/4 v10, 0x0
move-object v0, p0
move v1, p1
move-object v2, p2
move-object v3, p3
move-object v4, p4
move-object/from16 v5, p5
move/from16 v6, p6
move/from16 v7, p7
move/from16 v8, p8
move/from16 v9, p9
.line 1
invoke-direct/range {v0 .. v10}, Lcom/facebook/react/fabric/FabricUIManager;->measure(ILjava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;FFFF[I)J
move-result-wide v0
return-wide v0
.end method
.method private measure(ILjava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;FFFF[I)J
.registers 24
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
move-object v0, p0
if-gez p1, :cond_6
.line 2
iget-object v1, v0, Lcom/facebook/react/fabric/FabricUIManager;->mReactApplicationContext:Lcom/facebook/react/bridge/ReactApplicationContext;
goto :goto_12
:cond_6
iget-object v1, v0, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v1
check-cast v1, Lcom/facebook/react/bridge/ReactContext;
:goto_12
move-object v3, v1
.line 3
iget-object v2, v0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
.line 4
invoke-static/range {p6 .. p7}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getYogaSize(FF)F
move-result v8
.line 5
invoke-static/range {p6 .. p7}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getYogaMeasureMode(FF)Lcom/facebook/yoga/YogaMeasureMode;
move-result-object v9
.line 6
invoke-static/range {p8 .. p9}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getYogaSize(FF)F
move-result v10
.line 7
invoke-static/range {p8 .. p9}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getYogaMeasureMode(FF)Lcom/facebook/yoga/YogaMeasureMode;
move-result-object v11
move-object v4, p2
move-object/from16 v5, p3
move-object/from16 v6, p4
move-object/from16 v7, p5
move-object/from16 v12, p10
.line 8
invoke-virtual/range {v2 .. v12}, Lcom/facebook/react/fabric/mounting/MountingManager;->measure(Landroid/content/Context;Ljava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/bridge/ReadableMap;FLcom/facebook/yoga/YogaMeasureMode;FLcom/facebook/yoga/YogaMeasureMode;[I)J
move-result-wide v1
return-wide v1
.end method
.method private preallocateView(IILjava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Ljava/lang/Object;Z)V
.registers 19
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
move-object v1, p0
.line 1
iget-object v0, v1, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
move-object v3, v0
check-cast v3, Lcom/facebook/react/uimanager/ThemedReactContext;
.line 2
invoke-static {p3}, Lcom/facebook/react/fabric/FabricComponents;->getFabricComponentName(Ljava/lang/String;)Ljava/lang/String;
move-result-object v6
.line 3
iget-object v10, v1, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItemsLock:Ljava/lang/Object;
monitor-enter v10
.line 4
:try_start_15
iget-object v0, v1, Lcom/facebook/react/fabric/FabricUIManager;->mPreMountItems:Ljava/util/ArrayDeque;
new-instance v11, Lcom/facebook/react/fabric/mounting/mountitems/PreAllocateViewMountItem;
move-object/from16 v8, p5
check-cast v8, Lcom/facebook/react/uimanager/StateWrapper;
move-object v2, v11
move v4, p1
move v5, p2
move-object/from16 v7, p4
move/from16 v9, p6
invoke-direct/range {v2 .. v9}, Lcom/facebook/react/fabric/mounting/mountitems/PreAllocateViewMountItem;-><init>(Lcom/facebook/react/uimanager/ThemedReactContext;IILjava/lang/String;Lcom/facebook/react/bridge/ReadableMap;Lcom/facebook/react/uimanager/StateWrapper;Z)V
invoke-virtual {v0, v11}, Ljava/util/ArrayDeque;->add(Ljava/lang/Object;)Z
.line 5
monitor-exit v10
return-void
:catchall_2c
move-exception v0
monitor-exit v10
:try_end_2e
.catchall {:try_start_15 .. :try_end_2e} :catchall_2c
throw v0
.end method
.method private removeDeleteMultiMountItem([I)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 3
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/RemoveDeleteMultiMountItem;
invoke-direct {v0, p1}, Lcom/facebook/react/fabric/mounting/mountitems/RemoveDeleteMultiMountItem;-><init>([I)V
return-object v0
.end method
.method private removeMountItem(III)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 5
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/RemoveMountItem;
invoke-direct {v0, p1, p2, p3}, Lcom/facebook/react/fabric/mounting/mountitems/RemoveMountItem;-><init>(III)V
return-object v0
.end method
.method private scheduleMountItem(Lcom/facebook/react/fabric/mounting/mountitems/MountItem;IJJJJJJJ)V
.registers 33
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
move-object/from16 v1, p0
move-object/from16 v0, p1
move/from16 v2, p2
move-wide/from16 v3, p3
move-wide/from16 v5, p9
move-wide/from16 v7, p11
move-wide/from16 v9, p13
move-wide/from16 v11, p15
.line 1
instance-of v13, v0, Lcom/facebook/react/fabric/mounting/mountitems/BatchMountItem;
if-eqz v13, :cond_2b
.line 2
iput-wide v3, v1, Lcom/facebook/react/fabric/FabricUIManager;->mCommitStartTime:J
sub-long v14, v7, v5
.line 3
iput-wide v14, v1, Lcom/facebook/react/fabric/FabricUIManager;->mLayoutTime:J
sub-long v14, v11, v9
.line 4
iput-wide v14, v1, Lcom/facebook/react/fabric/FabricUIManager;->mFinishTransactionCPPTime:J
.line 5
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v14
sub-long/2addr v14, v9
iput-wide v14, v1, Lcom/facebook/react/fabric/FabricUIManager;->mFinishTransactionTime:J
.line 6
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v14
iput-wide v14, v1, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchViewUpdatesTime:J
.line 7
:cond_2b
iget-object v14, v1, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
monitor-enter v14
.line 8
:try_start_2e
iget-object v15, v1, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
invoke-interface {v15, v0}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 9
monitor-exit v14
:try_end_34
.catchall {:try_start_2e .. :try_end_34} :catchall_6d
.line 10
invoke-static {}, Lcom/facebook/react/bridge/UiThreadUtil;->isOnUiThread()Z
move-result v0
if-eqz v0, :cond_3d
.line 11
invoke-direct/range {p0 .. p0}, Lcom/facebook/react/fabric/FabricUIManager;->tryDispatchMountItems()V
:cond_3d
if-eqz v13, :cond_6c
.line 12
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_COMMIT_START:Lcom/facebook/react/bridge/ReactMarkerConstants;
const/4 v13, 0x0
invoke-static {v0, v13, v2, v3, v4}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 13
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_FINISH_TRANSACTION_START:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v0, v13, v2, v9, v10}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 14
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_FINISH_TRANSACTION_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v0, v13, v2, v11, v12}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 15
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_DIFF_START:Lcom/facebook/react/bridge/ReactMarkerConstants;
move-wide/from16 v3, p5
invoke-static {v0, v13, v2, v3, v4}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 16
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_DIFF_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
move-wide/from16 v3, p7
invoke-static {v0, v13, v2, v3, v4}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 17
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_LAYOUT_START:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v0, v13, v2, v5, v6}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 18
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_LAYOUT_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v0, v13, v2, v7, v8}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;IJ)V
.line 19
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_COMMIT_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v0, v13, v2}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;I)V
:cond_6c
return-void
:catchall_6d
move-exception v0
.line 20
:try_start_6e
monitor-exit v14
:try_end_6f
.catchall {:try_start_6e .. :try_end_6f} :catchall_6d
throw v0
.end method
.method private tryDispatchMountItems()V
.registers 6
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
.line 1
iget-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
if-eqz v0, :cond_5
return-void
:cond_5
const/4 v0, 0x0
.line 2
:try_start_6
invoke-direct {p0}, Lcom/facebook/react/fabric/FabricUIManager;->dispatchMountItems()Z
move-result v1
:try_end_a
.catchall {:try_start_6 .. :try_end_a} :catchall_3b
.line 3
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
.line 4
iget v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
const/16 v3, 0xa
if-ge v2, v3, :cond_38
if-eqz v1, :cond_38
const/4 v1, 0x2
if-le v2, v1, :cond_2f
.line 5
new-instance v1, Lcom/facebook/react/bridge/ReactNoCrashSoftException;
const-string v2, "Re-dispatched "
.line 6
invoke-static {v2}, Landroid/support/v4/media/c;->c(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
.line 7
iget v3, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
const-string v4, " times. This indicates setState (?) is likely being called too many times during mounting."
.line 8
invoke-static {v2, v3, v4}, Landroidx/biometric/d0;->b(Ljava/lang/StringBuilder;ILjava/lang/String;)Ljava/lang/String;
move-result-object v2
.line 9
invoke-direct {v1, v2}, Lcom/facebook/react/bridge/ReactNoCrashSoftException;-><init>(Ljava/lang/String;)V
const-string v2, "FabricUIManager"
invoke-static {v2, v1}, Lcom/facebook/react/bridge/ReactSoftException;->logSoftException(Ljava/lang/String;Ljava/lang/Throwable;)V
.line 10
:cond_2f
iget v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
add-int/lit8 v1, v1, 0x1
iput v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
.line 11
invoke-direct {p0}, Lcom/facebook/react/fabric/FabricUIManager;->tryDispatchMountItems()V
.line 12
:cond_38
iput v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
return-void
:catchall_3b
move-exception v1
.line 13
:try_start_3c
iput v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReDispatchCounter:I
.line 14
throw v1
:try_end_3f
.catchall {:try_start_3c .. :try_end_3f} :catchall_3f
:catchall_3f
move-exception v1
.line 15
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mInDispatch:Z
.line 16
throw v1
.end method
.method private updateEventEmitterMountItem(ILjava/lang/Object;)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/UpdateEventEmitterMountItem;
check-cast p2, Lcom/facebook/react/fabric/events/EventEmitterWrapper;
invoke-direct {v0, p1, p2}, Lcom/facebook/react/fabric/mounting/mountitems/UpdateEventEmitterMountItem;-><init>(ILcom/facebook/react/fabric/events/EventEmitterWrapper;)V
return-object v0
.end method
.method private updateLayoutMountItem(IIIIII)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 15
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v7, Lcom/facebook/react/fabric/mounting/mountitems/UpdateLayoutMountItem;
move-object v0, v7
move v1, p1
move v2, p2
move v3, p3
move v4, p4
move v5, p5
move v6, p6
invoke-direct/range {v0 .. v6}, Lcom/facebook/react/fabric/mounting/mountitems/UpdateLayoutMountItem;-><init>(IIIIII)V
return-object v7
.end method
.method private updateLocalDataMountItem(ILcom/facebook/react/bridge/ReadableMap;)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/UpdateLocalDataMountItem;
invoke-direct {v0, p1, p2}, Lcom/facebook/react/fabric/mounting/mountitems/UpdateLocalDataMountItem;-><init>(ILcom/facebook/react/bridge/ReadableMap;)V
return-object v0
.end method
.method private updatePaddingMountItem(IIIII)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 13
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v6, Lcom/facebook/react/fabric/mounting/mountitems/UpdatePaddingMountItem;
move-object v0, v6
move v1, p1
move v2, p2
move v3, p3
move v4, p4
move v5, p5
invoke-direct/range {v0 .. v5}, Lcom/facebook/react/fabric/mounting/mountitems/UpdatePaddingMountItem;-><init>(IIIII)V
return-object v6
.end method
.method private updatePropsMountItem(ILcom/facebook/react/bridge/ReadableMap;)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/UpdatePropsMountItem;
invoke-direct {v0, p1, p2}, Lcom/facebook/react/fabric/mounting/mountitems/UpdatePropsMountItem;-><init>(ILcom/facebook/react/bridge/ReadableMap;)V
return-object v0
.end method
.method private updateStateMountItem(ILjava/lang/Object;)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/UpdateStateMountItem;
check-cast p2, Lcom/facebook/react/uimanager/StateWrapper;
invoke-direct {v0, p1, p2}, Lcom/facebook/react/fabric/mounting/mountitems/UpdateStateMountItem;-><init>(ILcom/facebook/react/uimanager/StateWrapper;)V
return-object v0
.end method
# virtual methods
.method public addRootView(Landroid/view/View;Lcom/facebook/react/bridge/WritableMap;Ljava/lang/String;)I
.registers 10
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Landroid/view/View;",
">(TT;",
"Lcom/facebook/react/bridge/WritableMap;",
"Ljava/lang/String;",
")I"
}
.end annotation
.line 1
invoke-static {}, Lcom/facebook/react/uimanager/ReactRootViewTagGenerator;->getNextRootViewTag()I
move-result v0
.line 2
move-object v1, p1
check-cast v1, Lcom/facebook/react/uimanager/ReactRoot;
.line 3
new-instance v2, Lcom/facebook/react/uimanager/ThemedReactContext;
iget-object v3, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactApplicationContext:Lcom/facebook/react/bridge/ReactApplicationContext;
.line 4
invoke-virtual {p1}, Landroid/view/View;->getContext()Landroid/content/Context;
move-result-object v4
invoke-interface {v1}, Lcom/facebook/react/uimanager/ReactRoot;->getSurfaceID()Ljava/lang/String;
move-result-object v5
invoke-direct {v2, v3, v4, v5}, Lcom/facebook/react/uimanager/ThemedReactContext;-><init>(Lcom/facebook/react/bridge/ReactApplicationContext;Landroid/content/Context;Ljava/lang/String;)V
.line 5
iget-object v3, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-virtual {v3, v0, p1}, Lcom/facebook/react/fabric/mounting/MountingManager;->addRootView(ILandroid/view/View;)V
.line 6
invoke-interface {v1}, Lcom/facebook/react/uimanager/ReactRoot;->getJSModuleName()Ljava/lang/String;
move-result-object p1
.line 7
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v3
invoke-virtual {v1, v3, v2}, Ljava/util/concurrent/ConcurrentHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 8
sget-boolean v1, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
if-eqz v1, :cond_37
.line 9
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
const-string v2, "FabricUIManager"
const-string v3, "Starting surface for module: %s and reactTag: %d"
invoke-static {v2, v3, p1, v1}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
.line 10
:cond_37
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
check-cast p2, Lcom/facebook/react/bridge/NativeMap;
invoke-virtual {v1, v0, p1, p2}, Lcom/facebook/react/fabric/Binding;->startSurface(ILjava/lang/String;Lcom/facebook/react/bridge/NativeMap;)V
if-eqz p3, :cond_45
.line 11
iget-object p1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
invoke-virtual {p1, v0, p3}, Lcom/facebook/react/fabric/Binding;->renderTemplateToSurface(ILjava/lang/String;)V
:cond_45
return v0
.end method
.method public clearJSResponder()V
.registers 4
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
new-instance v2, Lcom/facebook/react/fabric/FabricUIManager$2;
invoke-direct {v2, p0}, Lcom/facebook/react/fabric/FabricUIManager$2;-><init>(Lcom/facebook/react/fabric/FabricUIManager;)V
invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 3
monitor-exit v0
return-void
:catchall_f
move-exception v1
monitor-exit v0
:try_end_11
.catchall {:try_start_3 .. :try_end_11} :catchall_f
throw v1
.end method
.method public dispatchCommand(IILcom/facebook/react/bridge/ReadableArray;)V
.registers 5
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation runtime Ljava/lang/Deprecated;
.end annotation
.line 1
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/DispatchIntCommandMountItem;
invoke-direct {v0, p1, p2, p3}, Lcom/facebook/react/fabric/mounting/mountitems/DispatchIntCommandMountItem;-><init>(IILcom/facebook/react/bridge/ReadableArray;)V
invoke-direct {p0, v0}, Lcom/facebook/react/fabric/FabricUIManager;->dispatchCommandMountItem(Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;)V
return-void
.end method
.method public dispatchCommand(ILjava/lang/String;Lcom/facebook/react/bridge/ReadableArray;)V
.registers 5
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.line 2
new-instance v0, Lcom/facebook/react/fabric/mounting/mountitems/DispatchStringCommandMountItem;
invoke-direct {v0, p1, p2, p3}, Lcom/facebook/react/fabric/mounting/mountitems/DispatchStringCommandMountItem;-><init>(ILjava/lang/String;Lcom/facebook/react/bridge/ReadableArray;)V
invoke-direct {p0, v0}, Lcom/facebook/react/fabric/FabricUIManager;->dispatchCommandMountItem(Lcom/facebook/react/fabric/mounting/mountitems/DispatchCommandMountItem;)V
return-void
.end method
.method public getEventDispatcher()Lcom/facebook/react/uimanager/events/EventDispatcher;
.registers 2
.line 2
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
return-object v0
.end method
.method public bridge synthetic getEventDispatcher()Ljava/lang/Object;
.registers 2
.line 1
invoke-virtual {p0}, Lcom/facebook/react/fabric/FabricUIManager;->getEventDispatcher()Lcom/facebook/react/uimanager/events/EventDispatcher;
move-result-object v0
return-object v0
.end method
.method public getPerformanceCounters()Ljava/util/Map;
.registers 4
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Map<",
"Ljava/lang/String;",
"Ljava/lang/Long;",
">;"
}
.end annotation
.line 1
new-instance v0, Ljava/util/HashMap;
invoke-direct {v0}, Ljava/util/HashMap;-><init>()V
.line 2
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mCommitStartTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "CommitStartTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 3
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mLayoutTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "LayoutTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 4
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchViewUpdatesTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "DispatchViewUpdatesTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 5
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mRunStartTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "RunStartTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 6
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBatchedExecutionTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "BatchedExecutionTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 7
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mFinishTransactionTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "FinishFabricTransactionTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 8
iget-wide v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mFinishTransactionCPPTime:J
invoke-static {v1, v2}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
const-string v2, "FinishFabricTransactionCPPTime"
invoke-virtual {v0, v2, v1}, Ljava/util/HashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
return-object v0
.end method
.method public initialize()V
.registers 4
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
new-instance v1, Lcom/facebook/react/fabric/events/FabricEventEmitter;
invoke-direct {v1, p0}, Lcom/facebook/react/fabric/events/FabricEventEmitter;-><init>(Lcom/facebook/react/fabric/FabricUIManager;)V
const/4 v2, 0x2
invoke-virtual {v0, v2, v1}, Lcom/facebook/react/uimanager/events/EventDispatcher;->registerEventEmitter(ILcom/facebook/react/uimanager/events/RCTEventEmitter;)V
.line 2
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventBeatManager:Lcom/facebook/react/fabric/events/EventBeatManager;
invoke-virtual {v0, v1}, Lcom/facebook/react/uimanager/events/EventDispatcher;->addBatchEventDispatchedListener(Lcom/facebook/react/uimanager/events/BatchEventDispatchedListener;)V
return-void
.end method
.method public onCatalystInstanceDestroy()V
.registers 4
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
const-string v0, "FabricUIManager"
const-string v1, "FabricUIManager.onCatalystInstanceDestroy"
.line 1
invoke-static {v0, v1}, Lcom/facebook/common/logging/FLog;->i(Ljava/lang/String;Ljava/lang/String;)V
.line 2
iget-boolean v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDestroyed:Z
if-eqz v1, :cond_16
.line 3
new-instance v1, Ljava/lang/IllegalStateException;
const-string v2, "Cannot double-destroy FabricUIManager"
invoke-direct {v1, v2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
invoke-static {v0, v1}, Lcom/facebook/react/bridge/ReactSoftException;->logSoftException(Ljava/lang/String;Ljava/lang/Throwable;)V
return-void
:cond_16
const/4 v0, 0x1
.line 4
iput-boolean v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDestroyed:Z
.line 5
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
invoke-virtual {v0}, Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;->stop()V
.line 6
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventBeatManager:Lcom/facebook/react/fabric/events/EventBeatManager;
invoke-virtual {v0, v1}, Lcom/facebook/react/uimanager/events/EventDispatcher;->removeBatchEventDispatchedListener(Lcom/facebook/react/uimanager/events/BatchEventDispatchedListener;)V
.line 7
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
const/4 v1, 0x2
invoke-virtual {v0, v1}, Lcom/facebook/react/uimanager/events/EventDispatcher;->unregisterEventEmitter(I)V
.line 8
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactApplicationContext:Lcom/facebook/react/bridge/ReactApplicationContext;
invoke-virtual {v0, p0}, Lcom/facebook/react/bridge/ReactContext;->removeLifecycleEventListener(Lcom/facebook/react/bridge/LifecycleEventListener;)V
.line 9
invoke-virtual {p0}, Lcom/facebook/react/fabric/FabricUIManager;->onHostPause()V
.line 10
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
invoke-virtual {v0}, Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;->stop()V
.line 11
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
invoke-virtual {v0}, Lcom/facebook/react/fabric/Binding;->unregister()V
const/4 v0, 0x0
.line 12
iput-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
.line 13
invoke-static {}, Lcom/facebook/react/uimanager/ViewManagerPropertyUpdater;->clear()V
return-void
.end method
.method public onHostDestroy()V
.registers 1
return-void
.end method
.method public onHostPause()V
.registers 4
.line 1
invoke-static {}, Lcom/facebook/react/modules/core/ReactChoreographer;->getInstance()Lcom/facebook/react/modules/core/ReactChoreographer;
move-result-object v0
sget-object v1, Lcom/facebook/react/modules/core/ReactChoreographer$CallbackType;->DISPATCH_UI:Lcom/facebook/react/modules/core/ReactChoreographer$CallbackType;
iget-object v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
.line 2
invoke-virtual {v0, v1, v2}, Lcom/facebook/react/modules/core/ReactChoreographer;->removeFrameCallback(Lcom/facebook/react/modules/core/ReactChoreographer$CallbackType;Lcom/facebook/react/modules/core/ChoreographerCompat$FrameCallback;)V
return-void
.end method
.method public onHostResume()V
.registers 4
.line 1
invoke-static {}, Lcom/facebook/react/modules/core/ReactChoreographer;->getInstance()Lcom/facebook/react/modules/core/ReactChoreographer;
move-result-object v0
sget-object v1, Lcom/facebook/react/modules/core/ReactChoreographer$CallbackType;->DISPATCH_UI:Lcom/facebook/react/modules/core/ReactChoreographer$CallbackType;
iget-object v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mDispatchUIFrameCallback:Lcom/facebook/react/fabric/FabricUIManager$DispatchUIFrameCallback;
.line 2
invoke-virtual {v0, v1, v2}, Lcom/facebook/react/modules/core/ReactChoreographer;->postFrameCallback(Lcom/facebook/react/modules/core/ReactChoreographer$CallbackType;Lcom/facebook/react/modules/core/ChoreographerCompat$FrameCallback;)V
return-void
.end method
.method public onRequestEventBeat()V
.registers 2
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mEventDispatcher:Lcom/facebook/react/uimanager/events/EventDispatcher;
invoke-virtual {v0}, Lcom/facebook/react/uimanager/events/EventDispatcher;->dispatchAllEvents()V
return-void
.end method
.method public profileNextBatch()V
.registers 1
return-void
.end method
.method public receiveEvent(ILjava/lang/String;Lcom/facebook/react/bridge/WritableMap;)V
.registers 5
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
invoke-virtual {v0, p1}, Lcom/facebook/react/fabric/mounting/MountingManager;->getEventEmitter(I)Lcom/facebook/react/fabric/events/EventEmitterWrapper;
move-result-object v0
if-nez v0, :cond_27
.line 2
new-instance p3, Ljava/lang/StringBuilder;
invoke-direct {p3}, Ljava/lang/StringBuilder;-><init>()V
const-string v0, "Unable to invoke event: "
invoke-virtual {p3, v0}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string p2, " for reactTag: "
invoke-virtual {p3, p2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {p3, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
invoke-virtual {p3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object p1
const-string p2, "FabricUIManager"
invoke-static {p2, p1}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;)V
return-void
.line 3
:cond_27
invoke-virtual {v0, p2, p3}, Lcom/facebook/react/fabric/events/EventEmitterWrapper;->invoke(Ljava/lang/String;Lcom/facebook/react/bridge/WritableMap;)V
return-void
.end method
.method public sendAccessibilityEvent(II)V
.registers 6
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
new-instance v2, Lcom/facebook/react/fabric/mounting/mountitems/SendAccessibilityEvent;
invoke-direct {v2, p1, p2}, Lcom/facebook/react/fabric/mounting/mountitems/SendAccessibilityEvent;-><init>(II)V
invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 3
monitor-exit v0
return-void
:catchall_f
move-exception p1
monitor-exit v0
:try_end_11
.catchall {:try_start_3 .. :try_end_11} :catchall_f
throw p1
.end method
.method public setBinding(Lcom/facebook/react/fabric/Binding;)V
.registers 2
iput-object p1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
return-void
.end method
.method public setJSResponder(IIZ)V
.registers 7
.annotation build Lcom/facebook/proguard/annotations/DoNotStrip;
.end annotation
.line 1
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItemsLock:Ljava/lang/Object;
monitor-enter v0
.line 2
:try_start_3
iget-object v1, p0, Lcom/facebook/react/fabric/FabricUIManager;->mMountItems:Ljava/util/List;
new-instance v2, Lcom/facebook/react/fabric/FabricUIManager$1;
invoke-direct {v2, p0, p1, p2, p3}, Lcom/facebook/react/fabric/FabricUIManager$1;-><init>(Lcom/facebook/react/fabric/FabricUIManager;IIZ)V
invoke-interface {v1, v2}, Ljava/util/List;->add(Ljava/lang/Object;)Z
.line 3
monitor-exit v0
return-void
:catchall_f
move-exception p1
monitor-exit v0
:try_end_11
.catchall {:try_start_3 .. :try_end_11} :catchall_f
throw p1
.end method
.method public startSurface(Landroid/view/View;Ljava/lang/String;Lcom/facebook/react/bridge/WritableMap;II)I
.registers 19
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Landroid/view/View;",
">(TT;",
"Ljava/lang/String;",
"Lcom/facebook/react/bridge/WritableMap;",
"II)I"
}
.end annotation
move-object v0, p0
move-object v3, p2
.line 1
invoke-static {}, Lcom/facebook/react/uimanager/ReactRootViewTagGenerator;->getNextRootViewTag()I
move-result v11
.line 2
new-instance v1, Lcom/facebook/react/uimanager/ThemedReactContext;
iget-object v2, v0, Lcom/facebook/react/fabric/FabricUIManager;->mReactApplicationContext:Lcom/facebook/react/bridge/ReactApplicationContext;
.line 3
invoke-virtual {p1}, Landroid/view/View;->getContext()Landroid/content/Context;
move-result-object v4
invoke-direct {v1, v2, v4, p2}, Lcom/facebook/react/uimanager/ThemedReactContext;-><init>(Lcom/facebook/react/bridge/ReactApplicationContext;Landroid/content/Context;Ljava/lang/String;)V
.line 4
sget-boolean v2, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
if-eqz v2, :cond_20
.line 5
invoke-static {v11}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
const-string v4, "FabricUIManager"
const-string v5, "Starting surface for module: %s and reactTag: %d"
invoke-static {v4, v5, p2, v2}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
.line 6
:cond_20
iget-object v2, v0, Lcom/facebook/react/fabric/FabricUIManager;->mMountingManager:Lcom/facebook/react/fabric/mounting/MountingManager;
move-object v4, p1
invoke-virtual {v2, v11, p1}, Lcom/facebook/react/fabric/mounting/MountingManager;->addRootView(ILandroid/view/View;)V
.line 7
iget-object v2, v0, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
invoke-static {v11}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v5
invoke-virtual {v2, v5, v1}, Ljava/util/concurrent/ConcurrentHashMap;->put(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
.line 8
iget-object v1, v0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
move-object/from16 v5, p3
check-cast v5, Lcom/facebook/react/bridge/NativeMap;
.line 9
invoke-static/range {p4 .. p4}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMinSize(I)F
move-result v6
.line 10
invoke-static/range {p4 .. p4}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMaxSize(I)F
move-result v7
.line 11
invoke-static/range {p5 .. p5}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMinSize(I)F
move-result v8
.line 12
invoke-static/range {p5 .. p5}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMaxSize(I)F
move-result v9
.line 13
invoke-static {}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->getInstance()Lcom/facebook/react/modules/i18nmanager/I18nUtil;
move-result-object v2
invoke-virtual {p1}, Landroid/view/View;->getContext()Landroid/content/Context;
move-result-object v10
invoke-virtual {v2, v10}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->isRTL(Landroid/content/Context;)Z
move-result v10
.line 14
invoke-static {}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->getInstance()Lcom/facebook/react/modules/i18nmanager/I18nUtil;
move-result-object v2
invoke-virtual {p1}, Landroid/view/View;->getContext()Landroid/content/Context;
move-result-object v4
invoke-virtual {v2, v4}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->doLeftAndRightSwapInRTL(Landroid/content/Context;)Z
move-result v12
move v2, v11
move-object v3, p2
move-object v4, v5
move v5, v6
move v6, v7
move v7, v8
move v8, v9
move v9, v10
move v10, v12
.line 15
invoke-virtual/range {v1 .. v10}, Lcom/facebook/react/fabric/Binding;->startSurfaceWithConstraints(ILjava/lang/String;Lcom/facebook/react/bridge/NativeMap;FFFFZZ)V
return v11
.end method
.method public stopSurface(I)V
.registers 3
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "ANY"
.end annotation
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
invoke-virtual {v0, p1}, Lcom/facebook/react/fabric/Binding;->stopSurface(I)V
return-void
.end method
.method public synchronouslyUpdateViewOnUIThread(ILcom/facebook/react/bridge/ReadableMap;)V
.registers 24
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
move-object/from16 v4, p0
const-string v5, "FabricUIManager"
.line 1
invoke-static {}, Lcom/facebook/react/bridge/UiThreadUtil;->assertOnUiThread()V
.line 2
invoke-static {}, Landroid/os/SystemClock;->uptimeMillis()J
move-result-wide v18
.line 3
iget v3, v4, Lcom/facebook/react/fabric/FabricUIManager;->mCurrentSynchronousCommitNumber:I
add-int/lit8 v0, v3, 0x1
iput v0, v4, Lcom/facebook/react/fabric/FabricUIManager;->mCurrentSynchronousCommitNumber:I
const/4 v2, 0x0
.line 4
:try_start_12
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_UPDATE_UI_MAIN_THREAD_START:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v0, v2, v3}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;I)V
.line 5
sget-boolean v0, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
if-eqz v0, :cond_24
const-string v0, "SynchronouslyUpdateViewOnUIThread for tag %d"
.line 6
invoke-static/range {p1 .. p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
invoke-static {v5, v0, v1}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Object;)V
.line 7
:cond_24
invoke-direct/range {p0 .. p2}, Lcom/facebook/react/fabric/FabricUIManager;->updatePropsMountItem(ILcom/facebook/react/bridge/ReadableMap;)Lcom/facebook/react/fabric/mounting/mountitems/MountItem;
move-result-object v0
:try_end_28
.catch Ljava/lang/Exception; {:try_start_12 .. :try_end_28} :catch_56
.catchall {:try_start_12 .. :try_end_28} :catchall_53
const-wide/16 v6, 0x0
const-wide/16 v8, 0x0
const-wide/16 v10, 0x0
const-wide/16 v12, 0x0
const-wide/16 v14, 0x0
const-wide/16 v16, 0x0
move-object/from16 v1, p0
move-object v2, v0
move/from16 p1, v3
move-object/from16 v20, v5
move-wide/from16 v4, v18
.line 8
:try_start_3d
invoke-direct/range {v1 .. v17}, Lcom/facebook/react/fabric/FabricUIManager;->scheduleMountItem(Lcom/facebook/react/fabric/mounting/mountitems/MountItem;IJJJJJJJ)V
:try_end_40
.catch Ljava/lang/Exception; {:try_start_3d .. :try_end_40} :catch_4e
.catchall {:try_start_3d .. :try_end_40} :catchall_49
.line 9
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_UPDATE_UI_MAIN_THREAD_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
move/from16 v1, p1
const/4 v2, 0x0
:goto_45
invoke-static {v0, v2, v1}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;I)V
goto :goto_69
:catchall_49
move-exception v0
move/from16 v1, p1
const/4 v2, 0x0
goto :goto_6b
:catch_4e
move-exception v0
move/from16 v1, p1
const/4 v2, 0x0
goto :goto_5a
:catchall_53
move-exception v0
move v1, v3
goto :goto_6b
:catch_56
move-exception v0
move v1, v3
move-object/from16 v20, v5
.line 10
:goto_5a
:try_start_5a
new-instance v3, Lcom/facebook/react/bridge/ReactNoCrashSoftException;
const-string v4, "Caught exception in synchronouslyUpdateViewOnUIThread"
invoke-direct {v3, v4, v0}, Lcom/facebook/react/bridge/ReactNoCrashSoftException;-><init>(Ljava/lang/String;Ljava/lang/Throwable;)V
move-object/from16 v4, v20
invoke-static {v4, v3}, Lcom/facebook/react/bridge/ReactSoftException;->logSoftException(Ljava/lang/String;Ljava/lang/Throwable;)V
:try_end_66
.catchall {:try_start_5a .. :try_end_66} :catchall_6a
.line 11
sget-object v0, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_UPDATE_UI_MAIN_THREAD_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
goto :goto_45
:goto_69
return-void
:catchall_6a
move-exception v0
:goto_6b
sget-object v3, Lcom/facebook/react/bridge/ReactMarkerConstants;->FABRIC_UPDATE_UI_MAIN_THREAD_END:Lcom/facebook/react/bridge/ReactMarkerConstants;
invoke-static {v3, v2, v1}, Lcom/facebook/react/bridge/ReactMarker;->logFabricMarker(Lcom/facebook/react/bridge/ReactMarkerConstants;Ljava/lang/String;I)V
.line 12
throw v0
.end method
.method public updateRootLayoutSpecs(III)V
.registers 14
.annotation build Lcom/facebook/infer/annotation/ThreadConfined;
value = "UI"
.end annotation
.line 1
sget-boolean v0, Lcom/facebook/react/fabric/FabricUIManager;->ENABLE_FABRIC_LOGS:Z
const-string v1, "FabricUIManager"
if-eqz v0, :cond_b
const-string v0, "Updating Root Layout Specs"
.line 2
invoke-static {v1, v0}, Lcom/facebook/common/logging/FLog;->d(Ljava/lang/String;Ljava/lang/String;)V
.line 3
:cond_b
iget-object v0, p0, Lcom/facebook/react/fabric/FabricUIManager;->mReactContextForRootTag:Ljava/util/concurrent/ConcurrentHashMap;
invoke-static {p1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v2
invoke-virtual {v0, v2}, Ljava/util/concurrent/ConcurrentHashMap;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/facebook/react/uimanager/ThemedReactContext;
if-eqz v0, :cond_2c
.line 4
invoke-static {}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->getInstance()Lcom/facebook/react/modules/i18nmanager/I18nUtil;
move-result-object v1
invoke-virtual {v1, v0}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->isRTL(Landroid/content/Context;)Z
move-result v1
.line 5
invoke-static {}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->getInstance()Lcom/facebook/react/modules/i18nmanager/I18nUtil;
move-result-object v2
invoke-virtual {v2, v0}, Lcom/facebook/react/modules/i18nmanager/I18nUtil;->doLeftAndRightSwapInRTL(Landroid/content/Context;)Z
move-result v0
move v9, v0
move v8, v1
goto :goto_3e
.line 6
:cond_2c
new-instance v0, Ljava/lang/IllegalStateException;
const-string v2, "updateRootLayoutSpecs called before ReactContext set for tag: "
.line 7
invoke-static {v2, p1}, Landroidx/appcompat/widget/h;->a(Ljava/lang/String;I)Ljava/lang/String;
move-result-object v2
.line 8
invoke-direct {v0, v2}, Ljava/lang/IllegalStateException;-><init>(Ljava/lang/String;)V
invoke-static {v1, v0}, Lcom/facebook/react/bridge/ReactSoftException;->logSoftException(Ljava/lang/String;Ljava/lang/Throwable;)V
const/4 v1, 0x0
const/4 v0, 0x0
const/4 v8, 0x0
const/4 v9, 0x0
.line 9
:goto_3e
iget-object v2, p0, Lcom/facebook/react/fabric/FabricUIManager;->mBinding:Lcom/facebook/react/fabric/Binding;
.line 10
invoke-static {p2}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMinSize(I)F
move-result v4
.line 11
invoke-static {p2}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMaxSize(I)F
move-result v5
.line 12
invoke-static {p3}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMinSize(I)F
move-result v6
.line 13
invoke-static {p3}, Lcom/facebook/react/fabric/mounting/LayoutMetricsConversions;->getMaxSize(I)F
move-result v7
move v3, p1
.line 14
invoke-virtual/range {v2 .. v9}, Lcom/facebook/react/fabric/Binding;->setConstraints(IFFFFZZ)V
return-void
.end method