react-native-tvos 0.77.1-0 → 0.78.0-0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (636) hide show
  1. package/Libraries/Animated/animations/Animation.js +22 -1
  2. package/Libraries/Animated/animations/DecayAnimation.js +1 -0
  3. package/Libraries/Animated/animations/SpringAnimation.js +1 -0
  4. package/Libraries/Animated/animations/TimingAnimation.js +1 -0
  5. package/Libraries/Animated/nodes/AnimatedAddition.js +9 -2
  6. package/Libraries/Animated/nodes/AnimatedColor.js +4 -1
  7. package/Libraries/Animated/nodes/AnimatedDiffClamp.js +10 -2
  8. package/Libraries/Animated/nodes/AnimatedDivision.js +9 -2
  9. package/Libraries/Animated/nodes/AnimatedInterpolation.js +5 -1
  10. package/Libraries/Animated/nodes/AnimatedModulo.js +5 -2
  11. package/Libraries/Animated/nodes/AnimatedMultiplication.js +9 -2
  12. package/Libraries/Animated/nodes/AnimatedNode.js +25 -46
  13. package/Libraries/Animated/nodes/AnimatedObject.js +9 -2
  14. package/Libraries/Animated/nodes/AnimatedProps.js +5 -1
  15. package/Libraries/Animated/nodes/AnimatedStyle.js +5 -1
  16. package/Libraries/Animated/nodes/AnimatedSubtraction.js +9 -2
  17. package/Libraries/Animated/nodes/AnimatedTracking.js +5 -1
  18. package/Libraries/Animated/nodes/AnimatedTransform.js +5 -1
  19. package/Libraries/Animated/nodes/AnimatedValue.js +63 -4
  20. package/Libraries/Animated/nodes/AnimatedValueXY.js +3 -1
  21. package/Libraries/Animated/useAnimatedProps.js +14 -56
  22. package/Libraries/AppDelegate/RCTAppDelegate.h +6 -48
  23. package/Libraries/AppDelegate/RCTAppDelegate.mm +5 -230
  24. package/Libraries/AppDelegate/RCTDefaultReactNativeFactoryDelegate.h +21 -0
  25. package/Libraries/AppDelegate/RCTDefaultReactNativeFactoryDelegate.mm +123 -0
  26. package/Libraries/AppDelegate/RCTReactNativeFactory.h +98 -0
  27. package/Libraries/AppDelegate/RCTReactNativeFactory.mm +266 -0
  28. package/Libraries/AppDelegate/RCTRootViewFactory.mm +1 -1
  29. package/Libraries/AppDelegate/React-RCTAppDelegate.podspec +0 -1
  30. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.d.ts +1 -1
  31. package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.js +3 -1
  32. package/Libraries/Components/LayoutConformance/LayoutConformance.d.ts +21 -0
  33. package/Libraries/Components/LayoutConformance/LayoutConformance.js +59 -0
  34. package/Libraries/Components/LayoutConformance/LayoutConformanceNativeComponent.js +29 -0
  35. package/Libraries/Components/Pressable/Pressable.d.ts +1 -1
  36. package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +1 -0
  37. package/Libraries/Components/TextInput/TextInput.d.ts +5 -0
  38. package/Libraries/Components/TextInput/TextInput.flow.js +6 -0
  39. package/Libraries/Components/TextInput/TextInput.js +6 -0
  40. package/Libraries/Components/View/ViewPropTypes.d.ts +4 -5
  41. package/Libraries/Components/View/ViewPropTypes.js +0 -9
  42. package/Libraries/Core/ReactNativeVersion.js +2 -2
  43. package/Libraries/Core/setUpBatchedBridge.js +1 -16
  44. package/Libraries/EventEmitter/RCTEventEmitter.js +2 -6
  45. package/Libraries/Image/AssetSourceResolver.js +11 -0
  46. package/Libraries/Image/RCTImageView.mm +3 -3
  47. package/Libraries/Inspector/BorderBox.js +26 -14
  48. package/Libraries/Inspector/BoxInspector.js +60 -42
  49. package/Libraries/Inspector/ElementBox.js +55 -48
  50. package/Libraries/Inspector/StyleInspector.js +36 -30
  51. package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -2
  52. package/Libraries/Lists/FlatList.d.ts +1 -1
  53. package/Libraries/Modal/Modal.js +2 -0
  54. package/Libraries/NativeAnimation/RCTNativeAnimatedNodesManager.mm +1 -1
  55. package/Libraries/NativeComponent/BaseViewConfig.android.js +0 -2
  56. package/Libraries/NativeComponent/BaseViewConfig.ios.js +0 -2
  57. package/Libraries/Network/RCTNetworking.android.js +24 -16
  58. package/Libraries/Network/RCTNetworking.ios.js +1 -46
  59. package/Libraries/Network/RCTNetworking.js.flow +1 -46
  60. package/Libraries/Network/RCTNetworkingEventDefinitions.flow.js +57 -0
  61. package/Libraries/ReactNative/UIManagerProperties.js +3 -1
  62. package/Libraries/Renderer/implementations/ReactFabric-dev.js +15829 -26461
  63. package/Libraries/Renderer/implementations/ReactFabric-prod.js +3907 -2560
  64. package/Libraries/Renderer/implementations/ReactFabric-profiling.js +4399 -2878
  65. package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +16103 -26908
  66. package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +4034 -2695
  67. package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +4535 -3045
  68. package/Libraries/Renderer/shims/ReactNativeTypes.js +5 -6
  69. package/Libraries/StyleSheet/processTransform.js +6 -0
  70. package/Libraries/Text/Text/NSTextStorage+FontScaling.m +9 -0
  71. package/Libraries/Text/Text.d.ts +6 -1
  72. package/Libraries/Text/TextInput/Multiline/RCTUITextView.h +2 -0
  73. package/Libraries/Text/TextInput/Multiline/RCTUITextView.mm +26 -0
  74. package/Libraries/Text/TextInput/RCTBackedTextInputViewProtocol.h +2 -0
  75. package/Libraries/Text/TextInput/RCTBaseTextInputView.mm +25 -0
  76. package/Libraries/Text/TextInput/RCTBaseTextInputViewManager.mm +2 -0
  77. package/Libraries/Text/TextInput/Singleline/RCTUITextField.h +1 -0
  78. package/Libraries/Text/TextInput/Singleline/RCTUITextField.mm +26 -0
  79. package/Libraries/Text/TextProps.js +2 -2
  80. package/Libraries/Utilities/BackHandler.android.js +5 -4
  81. package/Libraries/Utilities/BackHandler.ios.js +3 -4
  82. package/README-core.md +2 -2
  83. package/React/Base/RCTVersion.m +2 -2
  84. package/React/CoreModules/RCTDevSettings.h +0 -1
  85. package/React/CoreModules/RCTDeviceInfo.mm +4 -0
  86. package/React/CxxLogUtils/RCTDefaultCxxLogFunction.mm +3 -5
  87. package/React/DevSupport/RCTInspectorDevServerHelper.mm +1 -6
  88. package/React/DevSupport/RCTPausedInDebuggerOverlayController.mm +3 -5
  89. package/React/FBReactNativeSpec/FBReactNativeSpec/FBReactNativeSpec-generated.mm +0 -24
  90. package/React/FBReactNativeSpec/FBReactNativeSpec/FBReactNativeSpec.h +0 -28
  91. package/React/FBReactNativeSpec/FBReactNativeSpecJSI-generated.cpp +90 -57
  92. package/React/FBReactNativeSpec/FBReactNativeSpecJSI.h +241 -104
  93. package/React/Fabric/Mounting/ComponentViews/InputAccessory/RCTInputAccessoryContentView.mm +0 -5
  94. package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTEnhancedScrollView.mm +39 -10
  95. package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTPullToRefreshViewComponentView.mm +3 -3
  96. package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTScrollViewComponentView.mm +22 -3
  97. package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputComponentView.mm +5 -0
  98. package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputUtils.mm +1 -0
  99. package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.mm +7 -2
  100. package/React/Fabric/Mounting/RCTComponentViewFactory.mm +3 -0
  101. package/React/Fabric/Mounting/RCTMountingManager.mm +6 -9
  102. package/React/Fabric/RCTScheduler.mm +1 -1
  103. package/React/I18n/strings/da.lproj/fbt_language_pack.bin +0 -0
  104. package/React/Modules/RCTUIManager.mm +1 -2
  105. package/React/React-RCTFBReactNativeSpec.podspec +1 -0
  106. package/React/React-RCTFabric.podspec +3 -2
  107. package/React/Tests/Text/RCTParagraphComponentViewTests.mm +12 -12
  108. package/React/Views/RCTComponentData.mm +1 -5
  109. package/React/Views/RCTLayout.m +3 -0
  110. package/React/Views/RCTShadowView.h +3 -3
  111. package/React/Views/RCTShadowView.m +52 -20
  112. package/React/Views/RCTView.m +6 -2
  113. package/React/Views/RCTViewManager.m +0 -7
  114. package/React/Views/ScrollView/RCTScrollView.m +46 -19
  115. package/React-Core.podspec +1 -1
  116. package/ReactAndroid/api/ReactAndroid.api +120 -227
  117. package/ReactAndroid/build.gradle.kts +8 -13
  118. package/ReactAndroid/cmake-utils/default-app-setup/OnLoad.cpp +2 -0
  119. package/ReactAndroid/external-artifacts/build.gradle.kts +5 -5
  120. package/ReactAndroid/gradle.properties +1 -1
  121. package/ReactAndroid/src/main/java/com/facebook/hermes/instrumentation/{HermesMemoryDumper.java → HermesMemoryDumper.kt} +5 -5
  122. package/ReactAndroid/src/main/java/com/facebook/hermes/instrumentation/{HermesSamplingProfiler.java → HermesSamplingProfiler.kt} +8 -10
  123. package/ReactAndroid/src/main/java/com/facebook/react/DebugCorePackage.java +12 -59
  124. package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManager.java +12 -1
  125. package/ReactAndroid/src/main/java/com/facebook/react/{ReactPackageLogger.java → ReactPackageLogger.kt} +3 -3
  126. package/ReactAndroid/src/main/java/com/facebook/react/animated/EventAnimationDriver.kt +8 -8
  127. package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactContext.java +1 -3
  128. package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactSoftExceptionLogger.kt +6 -0
  129. package/ReactAndroid/src/main/java/com/facebook/react/bridge/SoftAssertions.kt +5 -3
  130. package/ReactAndroid/src/main/java/com/facebook/react/common/network/OkHttpCallUtil.kt +4 -8
  131. package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactHost.kt +11 -5
  132. package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactHostDelegate.kt +0 -7
  133. package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactNativeHost.kt +1 -3
  134. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DefaultDevSupportManagerFactory.kt +6 -1
  135. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevServerHelper.java +11 -23
  136. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerBase.java +3 -30
  137. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/HMRClient.java +4 -1
  138. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/InspectorFlags.kt +2 -0
  139. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/StackTraceHelper.java +4 -4
  140. package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManager.java +21 -26
  141. package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManagerBinding.kt +1 -14
  142. package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManagerProviderImpl.java +2 -11
  143. package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/EventEmitterWrapper.kt +88 -0
  144. package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/FabricEventEmitter.kt +6 -6
  145. package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/MountingManager.java +24 -0
  146. package/ReactAndroid/src/main/java/com/facebook/react/interfaces/exceptionmanager/ReactJsExceptionHandler.kt +7 -7
  147. package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlags.kt +21 -21
  148. package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxAccessor.kt +36 -36
  149. package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxInterop.kt +8 -8
  150. package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsDefaults.kt +10 -10
  151. package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsLocalAccessor.kt +40 -40
  152. package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsProvider.kt +8 -8
  153. package/ReactAndroid/src/main/java/com/facebook/react/internal/interop/InteropEventEmitter.kt +3 -3
  154. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/HeadlessJsTaskConfig.kt +55 -0
  155. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/HeadlessJsTaskContext.kt +185 -0
  156. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/{HeadlessJsTaskEventListener.java → HeadlessJsTaskEventListener.kt} +5 -6
  157. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/HeadlessJsTaskRetryPolicy.kt +20 -0
  158. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/LinearCountingRetryPolicy.kt +4 -4
  159. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/NoRetryPolicy.kt +7 -8
  160. package/ReactAndroid/src/main/java/com/facebook/react/modules/appearance/AppearanceModule.kt +8 -5
  161. package/ReactAndroid/src/main/java/com/facebook/react/modules/fresco/FrescoModule.kt +11 -17
  162. package/ReactAndroid/src/main/java/com/facebook/react/modules/fresco/ReactOkHttpNetworkFetcher.kt +1 -1
  163. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/CookieJarContainer.kt +16 -0
  164. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ForwardingCookieHandler.kt +107 -0
  165. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkingModule.java +18 -19
  166. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ReactCookieJarContainer.kt +48 -0
  167. package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/ReactNativeVersion.java +2 -2
  168. package/ReactAndroid/src/main/java/com/facebook/react/modules/websocket/WebSocketModule.kt +397 -0
  169. package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostDelegate.kt +0 -10
  170. package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostImpl.java +1 -1
  171. package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactInstance.java +8 -8
  172. package/ReactAndroid/src/main/java/com/facebook/react/runtime/hermes/HermesInstance.kt +4 -10
  173. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BackgroundStyleApplicator.kt +4 -0
  174. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BaseViewManager.java +13 -12
  175. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BaseViewManagerDelegate.kt +15 -12
  176. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/{ComponentNameResolver.java → ComponentNameResolver.kt} +4 -5
  177. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/GuardedFrameCallback.kt +5 -2
  178. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/LayoutShadowNode.java +0 -5
  179. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactOverflowView.kt +21 -0
  180. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactPointerEventsView.kt +18 -0
  181. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/{RootView.java → RootView.kt} +11 -12
  182. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/RootViewManager.kt +1 -1
  183. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/{UIBlock.java → UIBlock.kt} +3 -3
  184. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIViewOperationQueue.java +2 -5
  185. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewManager.java +25 -0
  186. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewManagerDelegate.kt +1 -1
  187. package/{Libraries/AppDelegate/RCTAppDelegate+Protected.h → ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewManagerWithGeneratedInterface.kt} +3 -8
  188. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewProps.kt +12 -5
  189. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/drawable/BackgroundDrawable.kt +46 -80
  190. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/drawable/BorderDrawable.kt +5 -5
  191. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/drawable/CSSBackgroundDrawable.java +5 -5
  192. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/drawable/CompositeBackgroundDrawable.kt +8 -9
  193. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/{BatchEventDispatchedListener.java → BatchEventDispatchedListener.kt} +3 -3
  194. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventCategoryDef.kt +46 -0
  195. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcher.kt +40 -0
  196. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherImpl.java +2 -6
  197. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherListener.kt +19 -0
  198. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherProvider.kt +23 -0
  199. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/FabricEventDispatcher.kt +241 -0
  200. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/PointerEventHelper.kt +193 -0
  201. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTEventEmitter.kt +44 -0
  202. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTModernEventEmitter.kt +37 -0
  203. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/ReactEventEmitter.kt +130 -0
  204. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEvent.kt +1 -1
  205. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEventCoalescingKeyHelper.kt +77 -0
  206. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchesHelper.kt +196 -0
  207. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BorderRadiusStyle.kt +16 -17
  208. package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ReactModalHostManager.kt +5 -0
  209. package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ReactModalHostView.kt +34 -1
  210. package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ProgressBarContainerView.kt +11 -0
  211. package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/{FpsListener.java → FpsListener.kt} +4 -4
  212. package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollView.java +16 -0
  213. package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollViewManager.java +3 -3
  214. package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewAccessibilityDelegate.kt +136 -0
  215. package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewManager.java +2 -2
  216. package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitchManager.kt +152 -0
  217. package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitchShadowNode.kt +52 -0
  218. package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactBaseTextShadowNode.java +1 -7
  219. package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManager.java +8 -13
  220. package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageViewManager.kt +50 -0
  221. package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/span/ShadowStyleSpan.kt +1 -1
  222. package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactEditText.java +1 -9
  223. package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactDrawableHelper.kt +111 -0
  224. package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewGroup.java +90 -20
  225. package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewManager.kt +2 -2
  226. package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNative.java +22 -1
  227. package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNode.java +43 -1
  228. package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNodeJNIBase.java +86 -2
  229. package/ReactAndroid/src/main/java/com/facebook/yoga/YogaProps.java +44 -2
  230. package/ReactAndroid/src/main/java/com/facebook/yoga/YogaUnit.java +7 -1
  231. package/ReactAndroid/src/main/jni/CMakeLists.txt +5 -6
  232. package/ReactAndroid/src/main/jni/first-party/yogajni/CMakeLists.txt +6 -1
  233. package/ReactAndroid/src/main/jni/first-party/yogajni/jni/YGJNIVanilla.cpp +96 -11
  234. package/ReactAndroid/src/main/jni/react/devsupport/JInspectorFlags.cpp +9 -0
  235. package/ReactAndroid/src/main/jni/react/devsupport/JInspectorFlags.h +1 -0
  236. package/ReactAndroid/src/main/jni/react/fabric/CMakeLists.txt +0 -3
  237. package/ReactAndroid/src/main/jni/react/fabric/CoreComponentsRegistry.cpp +3 -0
  238. package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.cpp +41 -25
  239. package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.h +0 -2
  240. package/ReactAndroid/src/main/jni/react/fabric/FabricUIManagerBinding.cpp +63 -91
  241. package/ReactAndroid/src/main/jni/react/fabric/FabricUIManagerBinding.h +1 -7
  242. package/ReactAndroid/src/main/jni/react/fabric/MountItem.cpp +9 -9
  243. package/ReactAndroid/src/main/jni/react/fabric/MountItem.h +6 -10
  244. package/ReactAndroid/src/main/jni/react/fabric/OnLoad.cpp +0 -2
  245. package/ReactAndroid/src/main/jni/react/fabric/StateWrapperImpl.cpp +4 -0
  246. package/ReactAndroid/src/main/jni/react/fabric/StateWrapperImpl.h +1 -0
  247. package/ReactAndroid/src/main/jni/react/featureflags/CMakeLists.txt +0 -1
  248. package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.cpp +49 -49
  249. package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.h +11 -11
  250. package/ReactAndroid/src/main/jni/react/hermes/reactexecutor/OnLoad.cpp +1 -4
  251. package/ReactAndroid/src/main/jni/react/jni/CMakeLists.txt +0 -1
  252. package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.cpp +0 -1
  253. package/ReactAndroid/src/main/jni/react/jni/JSLogging.cpp +4 -9
  254. package/ReactAndroid/src/main/jni/react/jni/JSLogging.h +0 -4
  255. package/ReactAndroid/src/main/jni/react/jni/JniJSModulesUnbundle.cpp +3 -4
  256. package/ReactAndroid/src/main/jni/react/jni/ProxyExecutor.cpp +3 -4
  257. package/ReactAndroid/src/main/jni/react/jni/WritableNativeArray.cpp +6 -0
  258. package/ReactAndroid/src/main/jni/react/jni/WritableNativeArray.h +1 -0
  259. package/ReactAndroid/src/main/jni/react/jni/WritableNativeMap.cpp +6 -0
  260. package/ReactAndroid/src/main/jni/react/jni/WritableNativeMap.h +1 -0
  261. package/ReactAndroid/src/main/jni/react/jscexecutor/OnLoad.cpp +3 -7
  262. package/ReactAndroid/src/main/jni/react/mapbuffer/CMakeLists.txt +0 -2
  263. package/ReactAndroid/src/main/jni/react/reactnativeblob/CMakeLists.txt +0 -1
  264. package/ReactAndroid/src/main/jni/react/reactperflogger/CMakeLists.txt +0 -1
  265. package/ReactAndroid/src/main/jni/react/runtime/hermes/jni/JHermesInstance.cpp +2 -8
  266. package/ReactAndroid/src/main/jni/react/runtime/hermes/jni/JHermesInstance.h +2 -8
  267. package/ReactAndroid/src/main/jni/react/runtime/jni/CMakeLists.txt +0 -1
  268. package/ReactAndroid/src/main/jni/react/runtime/jni/JReactExceptionManager.cpp +18 -17
  269. package/ReactAndroid/src/main/jni/react/runtime/jni/JReactExceptionManager.h +1 -1
  270. package/ReactAndroid/src/main/jni/react/runtime/jni/JReactInstance.cpp +1 -1
  271. package/ReactAndroid/src/main/jni/react/turbomodule/CMakeLists.txt +0 -2
  272. package/ReactAndroid/src/main/jni/react/uimanager/CMakeLists.txt +0 -1
  273. package/ReactAndroid/src/main/res/views/view/values/ids.xml +5 -0
  274. package/ReactCommon/React-Fabric.podspec +8 -0
  275. package/ReactCommon/React-FabricComponents.podspec +2 -2
  276. package/ReactCommon/React-FabricImage.podspec +4 -1
  277. package/ReactCommon/cxxreact/CxxNativeModule.cpp +3 -3
  278. package/ReactCommon/cxxreact/Instance.cpp +6 -6
  279. package/ReactCommon/cxxreact/JSBigString.cpp +1 -1
  280. package/ReactCommon/cxxreact/JSExecutor.cpp +4 -2
  281. package/ReactCommon/cxxreact/ModuleRegistry.cpp +6 -6
  282. package/ReactCommon/cxxreact/NativeToJsBridge.cpp +3 -3
  283. package/ReactCommon/cxxreact/ReactNativeVersion.h +2 -2
  284. package/ReactCommon/cxxreact/SystraceSection.h +8 -141
  285. package/ReactCommon/cxxreact/TraceSection.h +181 -0
  286. package/ReactCommon/cxxreact/tests/jsbigstring.cpp +19 -0
  287. package/ReactCommon/hermes/executor/HermesExecutorFactory.cpp +2 -2
  288. package/ReactCommon/jsc/JSCRuntime.cpp +0 -2
  289. package/ReactCommon/jsc/React-jsc.podspec +1 -1
  290. package/ReactCommon/jserrorhandler/JsErrorHandler.cpp +27 -19
  291. package/ReactCommon/jserrorhandler/JsErrorHandler.h +5 -3
  292. package/ReactCommon/jserrorhandler/StackTraceParser.cpp +16 -16
  293. package/ReactCommon/jserrorhandler/StackTraceParser.h +1 -1
  294. package/ReactCommon/jserrorhandler/tests/StackTraceParserTest.cpp +252 -246
  295. package/ReactCommon/jsi/jsi/CMakeLists.txt +0 -3
  296. package/ReactCommon/jsi/jsi/JSIDynamic.cpp +1 -1
  297. package/ReactCommon/jsi/jsi/JSIDynamic.h +1 -1
  298. package/ReactCommon/jsi/jsi/decorator.h +61 -0
  299. package/ReactCommon/jsi/jsi/jsi-inl.h +4 -0
  300. package/ReactCommon/jsi/jsi/jsi.cpp +37 -0
  301. package/ReactCommon/jsi/jsi/jsi.h +81 -0
  302. package/ReactCommon/jsi/jsi/test/testlib.cpp +88 -0
  303. package/ReactCommon/jsiexecutor/jsireact/JSIExecutor.cpp +9 -9
  304. package/ReactCommon/jsinspector-modern/CMakeLists.txt +1 -1
  305. package/ReactCommon/jsinspector-modern/HostAgent.cpp +3 -7
  306. package/ReactCommon/jsinspector-modern/HostTarget.cpp +22 -1
  307. package/ReactCommon/jsinspector-modern/HostTarget.h +1 -1
  308. package/ReactCommon/jsinspector-modern/InspectorFlags.cpp +19 -4
  309. package/ReactCommon/jsinspector-modern/InspectorFlags.h +14 -0
  310. package/ReactCommon/jsinspector-modern/React-jsinspector.podspec +21 -10
  311. package/ReactCommon/jsinspector-modern/TracingAgent.cpp +12 -11
  312. package/ReactCommon/jsinspector-modern/tests/JsiIntegrationTest.cpp +2 -16
  313. package/ReactCommon/jsinspector-modern/tests/ReactInstanceIntegrationTest.cpp +14 -14
  314. package/ReactCommon/jsinspector-modern/tests/ReactInstanceIntegrationTest.h +7 -13
  315. package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestGenericEngineAdapter.cpp +1 -1
  316. package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestHermesEngineAdapter.cpp +1 -3
  317. package/ReactCommon/jsinspector-modern/tests/utils/InspectorFlagOverridesGuard.cpp +3 -3
  318. package/ReactCommon/jsinspector-modern/tests/utils/InspectorFlagOverridesGuard.h +1 -1
  319. package/ReactCommon/jsinspector-modern/tracing/CMakeLists.txt +26 -0
  320. package/ReactCommon/jsinspector-modern/tracing/CdpTracing.h +21 -0
  321. package/ReactCommon/jsinspector-modern/tracing/PerformanceTracer.cpp +187 -0
  322. package/ReactCommon/jsinspector-modern/tracing/PerformanceTracer.h +126 -0
  323. package/ReactCommon/jsinspector-modern/tracing/React-jsinspectortracing.podspec +56 -0
  324. package/ReactCommon/react/featureflags/CMakeLists.txt +3 -0
  325. package/ReactCommon/react/featureflags/React-featureflags.podspec +7 -0
  326. package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.cpp +15 -15
  327. package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.h +18 -18
  328. package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.cpp +88 -88
  329. package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.h +9 -9
  330. package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDefaults.h +17 -17
  331. package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDynamicProvider.h +454 -0
  332. package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsProvider.h +5 -5
  333. package/ReactCommon/react/featureflags/tests/ReactNativeFeatureFlagsDynamicProviderTest.cpp +78 -0
  334. package/ReactCommon/react/nativemodule/core/ReactCommon/TurboModuleBinding.cpp +2 -3
  335. package/ReactCommon/react/nativemodule/core/platform/android/ReactCommon/JavaTurboModule.cpp +3 -3
  336. package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.h +1 -5
  337. package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.mm +13 -23
  338. package/ReactCommon/react/nativemodule/cputime/CPUTime.h +55 -0
  339. package/ReactCommon/react/nativemodule/cputime/NativeCPUTime.cpp +35 -0
  340. package/ReactCommon/react/nativemodule/cputime/NativeCPUTime.h +28 -0
  341. package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.cpp +18 -18
  342. package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.h +8 -8
  343. package/ReactCommon/react/nativemodule/idlecallbacks/React-idlecallbacksnativemodule.podspec +1 -0
  344. package/ReactCommon/react/nativemodule/intersectionobserver/NativeIntersectionObserver.cpp +5 -8
  345. package/ReactCommon/react/nativemodule/mutationobserver/NativeMutationObserver.cpp +3 -3
  346. package/ReactCommon/react/nativemodule/webperformance/NativePerformance.cpp +22 -43
  347. package/ReactCommon/react/nativemodule/webperformance/NativePerformance.h +0 -15
  348. package/ReactCommon/react/performance/timeline/CMakeLists.txt +1 -0
  349. package/ReactCommon/react/performance/timeline/PerformanceEntryReporter.cpp +22 -2
  350. package/ReactCommon/react/performance/timeline/PerformanceEntryReporter.h +9 -4
  351. package/ReactCommon/react/performance/timeline/React-performancetimeline.podspec +1 -0
  352. package/ReactCommon/react/renderer/animations/CMakeLists.txt +0 -1
  353. package/ReactCommon/react/renderer/animations/LayoutAnimationDriver.cpp +1 -1
  354. package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.cpp +25 -19
  355. package/ReactCommon/react/renderer/animations/primitives.h +1 -1
  356. package/ReactCommon/react/renderer/animations/utils.h +3 -4
  357. package/ReactCommon/react/renderer/attributedstring/ParagraphAttributes.cpp +31 -9
  358. package/ReactCommon/react/renderer/attributedstring/TextAttributes.cpp +81 -31
  359. package/ReactCommon/react/renderer/componentregistry/CMakeLists.txt +0 -1
  360. package/ReactCommon/react/renderer/components/image/ImageComponentDescriptor.cpp +4 -1
  361. package/ReactCommon/react/renderer/components/image/ImageComponentDescriptor.h +2 -0
  362. package/ReactCommon/react/renderer/components/image/ImageEventEmitter.cpp +2 -2
  363. package/ReactCommon/react/renderer/components/image/ImageProps.cpp +5 -5
  364. package/ReactCommon/react/renderer/components/image/ImageProps.h +1 -1
  365. package/ReactCommon/react/renderer/components/image/ImageShadowNode.cpp +38 -10
  366. package/ReactCommon/react/renderer/components/image/ImageShadowNode.h +1 -1
  367. package/ReactCommon/react/renderer/components/image/ImageState.cpp +2 -3
  368. package/ReactCommon/react/renderer/components/image/ImageState.h +9 -6
  369. package/ReactCommon/react/renderer/components/progressbar/android/react/renderer/components/progressbar/AndroidProgressBarComponentDescriptor.h +0 -4
  370. package/ReactCommon/react/renderer/components/progressbar/android/react/renderer/components/progressbar/AndroidProgressBarShadowNode.h +7 -0
  371. package/ReactCommon/react/renderer/components/root/RootShadowNode.cpp +2 -2
  372. package/ReactCommon/react/renderer/components/scrollview/CMakeLists.txt +2 -2
  373. package/ReactCommon/react/renderer/components/scrollview/ScrollEvent.cpp +33 -0
  374. package/ReactCommon/react/renderer/components/scrollview/ScrollEvent.h +17 -0
  375. package/ReactCommon/react/renderer/components/scrollview/ScrollViewEventEmitter.cpp +3 -2
  376. package/ReactCommon/react/renderer/components/scrollview/ScrollViewEventEmitter.h +2 -1
  377. package/ReactCommon/react/renderer/components/switch/androidswitch/react/renderer/components/androidswitch/AndroidSwitchComponentDescriptor.h +0 -4
  378. package/ReactCommon/react/renderer/components/switch/androidswitch/react/renderer/components/androidswitch/AndroidSwitchShadowNode.h +7 -0
  379. package/ReactCommon/react/renderer/{uimanager/bindingUtils.h → components/text/ParagraphComponentDescriptor.cpp} +2 -8
  380. package/ReactCommon/react/renderer/components/text/ParagraphComponentDescriptor.h +10 -7
  381. package/ReactCommon/react/renderer/components/textinput/BaseTextInputProps.cpp +23 -0
  382. package/ReactCommon/react/renderer/components/textinput/BaseTextInputProps.h +8 -1
  383. package/ReactCommon/react/renderer/components/textinput/BaseTextInputShadowNode.h +243 -0
  384. package/ReactCommon/react/renderer/components/textinput/TextInputState.cpp +71 -0
  385. package/ReactCommon/react/renderer/components/textinput/{platform/ios/react/renderer/components/iostextinput/TextInputState.h → TextInputState.h} +27 -7
  386. package/ReactCommon/react/renderer/components/textinput/platform/android/react/renderer/components/androidtextinput/AndroidTextInputComponentDescriptor.h +6 -13
  387. package/ReactCommon/react/renderer/components/textinput/platform/android/react/renderer/components/androidtextinput/AndroidTextInputProps.h +0 -2
  388. package/ReactCommon/react/renderer/components/textinput/platform/android/react/renderer/components/androidtextinput/AndroidTextInputShadowNode.cpp +145 -144
  389. package/ReactCommon/react/renderer/components/textinput/platform/android/react/renderer/components/androidtextinput/AndroidTextInputShadowNode.h +27 -29
  390. package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputComponentDescriptor.h +4 -5
  391. package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputProps.cpp +0 -26
  392. package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputProps.h +0 -6
  393. package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputShadowNode.cpp +0 -147
  394. package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputShadowNode.h +5 -57
  395. package/ReactCommon/react/renderer/components/view/BaseViewProps.cpp +60 -70
  396. package/ReactCommon/react/renderer/components/view/BaseViewProps.h +3 -3
  397. package/ReactCommon/react/renderer/components/view/LayoutConformanceComponentDescriptor.h +18 -0
  398. package/ReactCommon/react/renderer/components/view/LayoutConformanceProps.h +36 -0
  399. package/ReactCommon/react/renderer/components/view/LayoutConformanceShadowNode.h +28 -0
  400. package/ReactCommon/react/renderer/components/view/ViewPropsInterpolation.h +4 -0
  401. package/ReactCommon/react/renderer/components/view/ViewShadowNode.cpp +0 -1
  402. package/ReactCommon/react/renderer/components/view/YogaLayoutableShadowNode.cpp +21 -22
  403. package/ReactCommon/react/renderer/components/view/YogaStylableProps.cpp +3 -2
  404. package/ReactCommon/react/renderer/components/view/YogaStylableProps.h +3 -1
  405. package/ReactCommon/react/renderer/components/view/conversions.h +117 -43
  406. package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/HostPlatformViewProps.cpp +3 -2
  407. package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/HostPlatformViewProps.h +3 -1
  408. package/ReactCommon/react/renderer/components/view/primitives.h +1 -1
  409. package/ReactCommon/react/renderer/components/view/tests/LayoutTest.cpp +12 -12
  410. package/ReactCommon/react/renderer/core/CMakeLists.txt +0 -1
  411. package/ReactCommon/react/renderer/core/ComponentDescriptor.cpp +4 -2
  412. package/ReactCommon/react/renderer/core/ComponentDescriptor.h +4 -2
  413. package/ReactCommon/react/renderer/core/ConcreteComponentDescriptor.h +17 -2
  414. package/ReactCommon/react/renderer/core/DynamicPropsUtilities.cpp +26 -0
  415. package/ReactCommon/react/renderer/core/DynamicPropsUtilities.h +4 -0
  416. package/ReactCommon/react/renderer/core/EventEmitter.cpp +3 -3
  417. package/ReactCommon/react/renderer/core/Props.cpp +16 -5
  418. package/ReactCommon/react/renderer/core/Props.h +11 -4
  419. package/ReactCommon/react/renderer/core/RawProps.cpp +30 -5
  420. package/ReactCommon/react/renderer/core/RawProps.h +10 -1
  421. package/ReactCommon/react/renderer/core/RawPropsParser.cpp +7 -2
  422. package/ReactCommon/react/renderer/core/RawPropsParser.h +7 -1
  423. package/ReactCommon/react/renderer/core/RawPropsPrimitives.h +1 -0
  424. package/ReactCommon/react/renderer/core/RawValue.h +315 -22
  425. package/ReactCommon/react/renderer/core/tests/DynamicPropsUtilitiesTest.cpp +95 -4
  426. package/ReactCommon/react/renderer/debug/debugStringConvertibleUtils.h +19 -4
  427. package/ReactCommon/react/renderer/graphics/CMakeLists.txt +7 -1
  428. package/ReactCommon/react/renderer/graphics/React-graphics.podspec +7 -5
  429. package/ReactCommon/react/renderer/graphics/Transform.cpp +11 -2
  430. package/ReactCommon/react/renderer/graphics/Transform.h +2 -1
  431. package/ReactCommon/react/renderer/imagemanager/CMakeLists.txt +4 -2
  432. package/ReactCommon/react/renderer/imagemanager/ImageManager.h +7 -0
  433. package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageFetcher.cpp +43 -0
  434. package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageFetcher.h +36 -0
  435. package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageManager.cpp +43 -0
  436. package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageRequestParams.h +94 -0
  437. package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/conversions.h +101 -0
  438. package/ReactCommon/react/renderer/imagemanager/platform/cxx/react/renderer/imagemanager/ImageManager.cpp +9 -1
  439. package/ReactCommon/react/renderer/imagemanager/platform/cxx/react/renderer/imagemanager/ImageRequestParams.h +30 -0
  440. package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/ImageManager.mm +9 -0
  441. package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/ImageRequestParams.h +30 -0
  442. package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/RCTImageManager.mm +2 -2
  443. package/ReactCommon/react/renderer/mounting/Differentiator.cpp +187 -152
  444. package/ReactCommon/react/renderer/mounting/MountingCoordinator.cpp +4 -5
  445. package/ReactCommon/react/renderer/mounting/ShadowTree.cpp +10 -16
  446. package/ReactCommon/react/renderer/mounting/ShadowViewMutation.cpp +12 -12
  447. package/ReactCommon/react/renderer/mounting/ShadowViewMutation.h +44 -14
  448. package/ReactCommon/react/renderer/mounting/stubs/StubViewTree.cpp +8 -4
  449. package/ReactCommon/react/renderer/mounting/stubs/stubs.cpp +1 -1
  450. package/ReactCommon/react/renderer/mounting/tests/MountingTest.cpp +116 -193
  451. package/ReactCommon/react/renderer/mounting/tests/ShadowTreeLifeCycleTest.cpp +0 -3
  452. package/ReactCommon/react/renderer/observers/intersection/IntersectionObserver.cpp +7 -4
  453. package/ReactCommon/react/renderer/observers/intersection/IntersectionObserver.h +2 -1
  454. package/ReactCommon/react/renderer/observers/intersection/IntersectionObserverManager.cpp +7 -8
  455. package/ReactCommon/react/renderer/observers/mutation/MutationObserverManager.cpp +6 -6
  456. package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler.cpp +3 -1
  457. package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler.h +2 -0
  458. package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler_Legacy.cpp +11 -11
  459. package/ReactCommon/react/renderer/runtimescheduler/RuntimeScheduler_Modern.cpp +14 -15
  460. package/ReactCommon/react/renderer/runtimescheduler/SchedulerPriorityUtils.h +4 -3
  461. package/ReactCommon/react/renderer/scheduler/CMakeLists.txt +0 -1
  462. package/ReactCommon/react/renderer/scheduler/Scheduler.cpp +6 -37
  463. package/ReactCommon/react/renderer/scheduler/Scheduler.h +0 -3
  464. package/ReactCommon/react/renderer/scheduler/SurfaceHandler.cpp +15 -11
  465. package/ReactCommon/react/renderer/scheduler/SurfaceHandler.h +1 -0
  466. package/ReactCommon/react/renderer/scheduler/SurfaceManager.cpp +56 -2
  467. package/ReactCommon/react/renderer/scheduler/SurfaceManager.h +23 -3
  468. package/ReactCommon/react/renderer/textlayoutmanager/CMakeLists.txt +1 -2
  469. package/ReactCommon/react/renderer/textlayoutmanager/TextLayoutManager.cpp +26 -0
  470. package/ReactCommon/react/renderer/textlayoutmanager/{platform/android/react/renderer/textlayoutmanager/TextLayoutManager.h → TextLayoutManager.h} +18 -17
  471. package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.cpp +77 -89
  472. package/ReactCommon/react/renderer/textlayoutmanager/platform/cxx/TextLayoutManager.cpp +6 -10
  473. package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTAttributedTextUtils.mm +6 -2
  474. package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTFontUtils.mm +23 -1
  475. package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTTextLayoutManager.mm +11 -32
  476. package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/TextLayoutManager.mm +9 -23
  477. package/ReactCommon/react/renderer/uimanager/AppRegistryBinding.cpp +88 -0
  478. package/ReactCommon/react/renderer/uimanager/AppRegistryBinding.h +50 -0
  479. package/ReactCommon/react/renderer/uimanager/CMakeLists.txt +0 -1
  480. package/ReactCommon/react/renderer/uimanager/SurfaceRegistryBinding.h +3 -40
  481. package/ReactCommon/react/renderer/uimanager/UIManager.cpp +23 -18
  482. package/ReactCommon/react/renderer/uimanager/UIManager.h +2 -0
  483. package/ReactCommon/react/renderer/uimanager/UIManagerBinding.cpp +2 -31
  484. package/ReactCommon/react/renderer/uimanager/UIManagerBinding.h +0 -4
  485. package/ReactCommon/react/renderer/uimanager/tests/PointerEventsProcessorTest.cpp +10 -10
  486. package/ReactCommon/react/runtime/CMakeLists.txt +0 -1
  487. package/ReactCommon/react/runtime/React-RuntimeHermes.podspec +1 -2
  488. package/ReactCommon/react/runtime/ReactInstance.cpp +43 -57
  489. package/ReactCommon/react/runtime/TimerManager.cpp +4 -4
  490. package/ReactCommon/react/runtime/hermes/HermesInstance.cpp +5 -1
  491. package/ReactCommon/react/runtime/hermes/HermesInstance.h +0 -2
  492. package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHermesInstance.h +2 -6
  493. package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHermesInstance.mm +6 -15
  494. package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.mm +3 -1
  495. package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTInstance.mm +15 -15
  496. package/ReactCommon/react/runtime/tests/cxx/ReactInstanceTest.cpp +5 -4
  497. package/ReactCommon/react/test_utils/shadowTreeGeneration.h +0 -3
  498. package/ReactCommon/reactperflogger/fusebox/FuseboxTracer.cpp +33 -17
  499. package/ReactCommon/reactperflogger/fusebox/FuseboxTracer.h +8 -2
  500. package/ReactCommon/reactperflogger/reactperflogger/{ReactPerfLogger.cpp → ReactPerfettoLogger.cpp} +25 -24
  501. package/ReactCommon/reactperflogger/reactperflogger/{ReactPerfLogger.h → ReactPerfettoLogger.h} +9 -9
  502. package/ReactCommon/yoga/yoga/YGEnums.cpp +6 -0
  503. package/ReactCommon/yoga/yoga/YGEnums.h +4 -1
  504. package/ReactCommon/yoga/yoga/YGNodeStyle.cpp +124 -24
  505. package/ReactCommon/yoga/yoga/YGNodeStyle.h +22 -1
  506. package/ReactCommon/yoga/yoga/YGValue.h +3 -0
  507. package/ReactCommon/yoga/yoga/algorithm/CalculateLayout.cpp +6 -6
  508. package/ReactCommon/yoga/yoga/algorithm/FlexLine.cpp +2 -2
  509. package/ReactCommon/yoga/yoga/algorithm/FlexLine.h +1 -1
  510. package/ReactCommon/yoga/yoga/algorithm/PixelGrid.cpp +9 -6
  511. package/ReactCommon/yoga/yoga/enums/Unit.h +4 -1
  512. package/ReactCommon/yoga/yoga/node/Node.cpp +8 -8
  513. package/ReactCommon/yoga/yoga/node/Node.h +5 -5
  514. package/ReactCommon/yoga/yoga/style/Style.h +14 -12
  515. package/ReactCommon/yoga/yoga/style/StyleLength.h +14 -7
  516. package/ReactCommon/yoga/yoga/style/StyleSizeLength.h +139 -0
  517. package/ReactCommon/yoga/yoga/style/StyleValueHandle.h +8 -0
  518. package/ReactCommon/yoga/yoga/style/StyleValuePool.h +60 -3
  519. package/gradle/libs.versions.toml +6 -2
  520. package/index.js +5 -0
  521. package/package.json +12 -13
  522. package/react-native.config.js +6 -0
  523. package/scripts/cocoapods/codegen_utils.rb +4 -4
  524. package/scripts/cocoapods/new_architecture.rb +3 -3
  525. package/scripts/cocoapods/utils.rb +4 -3
  526. package/scripts/codegen/generate-artifacts-executor.js +8 -4
  527. package/scripts/generate-codegen-artifacts.js +6 -1
  528. package/scripts/react-native-xcode.sh +1 -1
  529. package/scripts/react_native_pods.rb +3 -3
  530. package/scripts/xcode/ccache-clang++.sh +1 -1
  531. package/scripts/xcode/ccache-clang.sh +1 -1
  532. package/sdks/.hermesversion +1 -1
  533. package/sdks/hermes-engine/utils/build-hermes-xcode.sh +1 -1
  534. package/sdks/hermesc/linux64-bin/hermesc +0 -0
  535. package/sdks/hermesc/osx-bin/hermes +0 -0
  536. package/sdks/hermesc/osx-bin/hermesc +0 -0
  537. package/sdks/hermesc/win64-bin/hermesc.exe +0 -0
  538. package/src/private/animated/NativeAnimatedValidation.js +1 -1
  539. package/src/private/featureflags/README.md +5 -0
  540. package/src/private/featureflags/ReactNativeFeatureFlags.js +33 -27
  541. package/src/private/featureflags/specs/NativeReactNativeFeatureFlags.js +5 -5
  542. package/src/private/renderer/errorhandling/ErrorHandlers.js +12 -55
  543. package/src/private/specs/modules/{NativeJSCSamplingProfiler.js → NativeCPUTime.js} +7 -2
  544. package/src/private/specs/modules/NativeFantom.js +37 -0
  545. package/src/private/utilities/ensureInstance.js +21 -0
  546. package/src/private/webapis/dom/nodes/ReactNativeElement.js +49 -6
  547. package/src/private/webapis/dom/nodes/ReadOnlyNode.js +17 -9
  548. package/src/private/webapis/intersectionobserver/IntersectionObserver.js +11 -11
  549. package/src/private/webapis/intersectionobserver/IntersectionObserverEntry.js +1 -1
  550. package/src/private/webapis/intersectionobserver/IntersectionObserverManager.js +1 -1
  551. package/src/private/webapis/intersectionobserver/specs/NativeIntersectionObserver.js +1 -0
  552. package/src/private/webapis/performance/Performance.js +0 -12
  553. package/src/private/webapis/performance/specs/NativePerformance.js +0 -11
  554. package/types/index.d.ts +1 -0
  555. package/types/public/ReactNativeTVTypes.d.ts +49 -51
  556. package/Libraries/HeapCapture/HeapCapture.js +0 -29
  557. package/Libraries/HeapCapture/NativeJSCHeapCapture.js +0 -13
  558. package/Libraries/Performance/NativeJSCSamplingProfiler.js +0 -13
  559. package/Libraries/Performance/SamplingProfiler.js +0 -39
  560. package/Libraries/ReactNative/__mocks__/FabricUIManager.js +0 -334
  561. package/React/Inspector/RCTInspectorPackagerConnection.m +0 -325
  562. package/ReactAndroid/src/main/java/com/facebook/react/bridge/GuardedResultAsyncTask.java +0 -50
  563. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/InspectorPackagerConnection.java +0 -314
  564. package/ReactAndroid/src/main/java/com/facebook/react/devsupport/JSCHeapCapture.java +0 -76
  565. package/ReactAndroid/src/main/java/com/facebook/react/fabric/EmptyReactNativeConfig.kt +0 -36
  566. package/ReactAndroid/src/main/java/com/facebook/react/fabric/GuardedFrameCallback.kt +0 -33
  567. package/ReactAndroid/src/main/java/com/facebook/react/fabric/ReactNativeConfig.kt +0 -54
  568. package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/EventEmitterWrapper.java +0 -83
  569. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/HeadlessJsTaskConfig.java +0 -121
  570. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/HeadlessJsTaskContext.java +0 -214
  571. package/ReactAndroid/src/main/java/com/facebook/react/jstasks/HeadlessJsTaskRetryPolicy.java +0 -22
  572. package/ReactAndroid/src/main/java/com/facebook/react/modules/fresco/XmlFormat.kt +0 -143
  573. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/CookieJarContainer.java +0 -17
  574. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ForwardingCookieHandler.java +0 -124
  575. package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ReactCookieJarContainer.java +0 -58
  576. package/ReactAndroid/src/main/java/com/facebook/react/modules/websocket/WebSocketModule.java +0 -422
  577. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/FabricViewStateManager.java +0 -98
  578. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactOverflowView.java +0 -25
  579. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactPointerEventsView.java +0 -20
  580. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventCategoryDef.java +0 -45
  581. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcher.java +0 -37
  582. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherListener.java +0 -19
  583. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherProvider.java +0 -24
  584. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/FabricEventDispatcher.java +0 -257
  585. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/PointerEventHelper.java +0 -210
  586. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTEventEmitter.java +0 -43
  587. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTModernEventEmitter.java +0 -39
  588. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/ReactEventEmitter.java +0 -165
  589. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEventCoalescingKeyHelper.java +0 -85
  590. package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchesHelper.java +0 -204
  591. package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewAccessibilityDelegate.java +0 -161
  592. package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitchManager.java +0 -232
  593. package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageViewManager.java +0 -70
  594. package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/span/LegacyLineHeightSpan.kt +0 -69
  595. package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactDrawableHelper.java +0 -114
  596. package/ReactAndroid/src/main/jni/first-party/fb/CMakeLists.txt +0 -31
  597. package/ReactAndroid/src/main/jni/first-party/fb/assert.cpp +0 -39
  598. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/ALog.h +0 -82
  599. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/Build.h +0 -31
  600. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/Countable.h +0 -45
  601. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/Doxyfile +0 -18
  602. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/Environment.h +0 -93
  603. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/ProgramLocation.h +0 -58
  604. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/RefPtr.h +0 -266
  605. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/StaticInitialized.h +0 -37
  606. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/ThreadLocal.h +0 -112
  607. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/assert.h +0 -43
  608. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/log.h +0 -350
  609. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/noncopyable.h +0 -20
  610. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/nonmovable.h +0 -20
  611. package/ReactAndroid/src/main/jni/first-party/fb/include/fb/visibility.h +0 -10
  612. package/ReactAndroid/src/main/jni/first-party/fb/log.cpp +0 -102
  613. package/ReactAndroid/src/main/jni/react/fabric/JEmptyReactNativeConfig.cpp +0 -47
  614. package/ReactAndroid/src/main/jni/react/fabric/JEmptyReactNativeConfig.h +0 -38
  615. package/ReactAndroid/src/main/jni/react/fabric/ReactNativeConfigHolder.cpp +0 -41
  616. package/ReactAndroid/src/main/jni/react/fabric/ReactNativeConfigHolder.h +0 -35
  617. package/ReactAndroid/src/main/jni/react/perftests/OnLoad.cpp +0 -243
  618. package/ReactAndroid/src/main/jni/third-party/jsc/CMakeLists.txt +0 -15
  619. package/ReactCommon/React-nativeconfig.podspec +0 -36
  620. package/ReactCommon/cxxreact/tests/main.cpp +0 -15
  621. package/ReactCommon/react/config/CMakeLists.txt +0 -20
  622. package/ReactCommon/react/config/ReactNativeConfig.cpp +0 -28
  623. package/ReactCommon/react/config/ReactNativeConfig.h +0 -42
  624. package/ReactCommon/react/renderer/components/textinput/platform/android/react/renderer/components/androidtextinput/AndroidTextInputState.cpp +0 -95
  625. package/ReactCommon/react/renderer/components/textinput/platform/android/react/renderer/components/androidtextinput/AndroidTextInputState.h +0 -80
  626. package/ReactCommon/react/renderer/components/textinput/platform/ios/react/renderer/components/iostextinput/TextInputState.cpp +0 -10
  627. package/ReactCommon/react/renderer/textlayoutmanager/platform/cxx/TextLayoutManager.h +0 -78
  628. package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/TextLayoutManager.h +0 -69
  629. package/ReactCommon/react/renderer/uimanager/SurfaceRegistryBinding.cpp +0 -123
  630. package/ReactCommon/react/renderer/uimanager/bindingUtils.cpp +0 -79
  631. package/src/private/webapis/dom/nodes/specs/__mocks__/NativeDOMMock.js +0 -413
  632. package/src/private/webapis/intersectionobserver/specs/__mocks__/NativeIntersectionObserver.js +0 -181
  633. package/src/private/webapis/mutationobserver/specs/__mocks__/NativeMutationObserver.js +0 -327
  634. /package/ReactCommon/react/renderer/components/scrollview/{AndroidHorizontalScrollContentViewComponentDescriptor.h → platform/android/react/renderer/components/scrollview/AndroidHorizontalScrollContentViewComponentDescriptor.h} +0 -0
  635. /package/ReactCommon/react/renderer/components/scrollview/{AndroidHorizontalScrollContentViewShadowNode.cpp → platform/android/react/renderer/components/scrollview/AndroidHorizontalScrollContentViewShadowNode.cpp} +0 -0
  636. /package/ReactCommon/react/renderer/components/scrollview/{AndroidHorizontalScrollContentViewShadowNode.h → platform/android/react/renderer/components/scrollview/AndroidHorizontalScrollContentViewShadowNode.h} +0 -0
@@ -32,9 +32,6 @@ static SharedViewProps nonFlattenedDefaultProps(
32
32
  dynamic["accessible"] = true;
33
33
 
34
34
  ContextContainer contextContainer;
35
- contextContainer.insert(
36
- "ReactNativeConfig", std::make_shared<EmptyReactNativeConfig>());
37
-
38
35
  PropsParserContext parserContext{-1, contextContainer};
39
36
 
40
37
  return std::static_pointer_cast<const ViewProps>(
@@ -45,17 +42,22 @@ static SharedViewProps nonFlattenedDefaultProps(
45
42
  static ShadowNode::Shared makeNode(
46
43
  const ComponentDescriptor& componentDescriptor,
47
44
  int tag,
48
- const ShadowNode::ListOfShared& children,
45
+ std::shared_ptr<ShadowNode::ListOfShared> children,
49
46
  bool flattened = false) {
50
47
  auto props = flattened ? generateDefaultProps(componentDescriptor)
51
48
  : nonFlattenedDefaultProps(componentDescriptor);
52
49
 
53
50
  return componentDescriptor.createShadowNode(
54
- ShadowNodeFragment{
55
- props, std::make_shared<ShadowNode::ListOfShared>(children)},
51
+ ShadowNodeFragment{std::move(props), std::move(children)},
56
52
  componentDescriptor.createFamily({tag, SurfaceId(1), nullptr}));
57
53
  }
58
54
 
55
+ static std::shared_ptr<ShadowNode::ListOfShared> listOfChildren(
56
+ std::initializer_list<ShadowNode::Shared> list) {
57
+ return std::make_shared<ShadowNode::ListOfShared>(
58
+ ShadowNode::ListOfShared{list});
59
+ }
60
+
59
61
  /**
60
62
  * Test reordering of views with the same parent:
61
63
  *
@@ -69,9 +71,6 @@ TEST(MountingTest, testReorderingInstructionGeneration) {
69
71
  auto eventDispatcher = EventDispatcher::Shared{};
70
72
 
71
73
  auto contextContainer = std::make_shared<ContextContainer>();
72
- contextContainer->insert(
73
- "ReactNativeConfig", std::make_shared<EmptyReactNativeConfig>());
74
-
75
74
  auto componentDescriptorParameters =
76
75
  ComponentDescriptorParameters{eventDispatcher, contextContainer, nullptr};
77
76
  auto viewComponentDescriptor =
@@ -117,25 +116,20 @@ TEST(MountingTest, testReorderingInstructionGeneration) {
117
116
  auto shadowNodeV1 = viewComponentDescriptor.createShadowNode(
118
117
  ShadowNodeFragment{
119
118
  generateDefaultProps(viewComponentDescriptor),
120
- std::make_shared<ShadowNode::ListOfShared>(
121
- ShadowNode::ListOfShared{childB, childC, childD})},
119
+ listOfChildren({childB, childC, childD})},
122
120
  family);
123
121
  auto shadowNodeV2 = shadowNodeV1->clone(ShadowNodeFragment{
124
122
  generateDefaultProps(viewComponentDescriptor),
125
- std::make_shared<ShadowNode::ListOfShared>(
126
- ShadowNode::ListOfShared{childA, childB, childC, childD})});
123
+ listOfChildren({childA, childB, childC, childD})});
127
124
  auto shadowNodeV3 = shadowNodeV2->clone(ShadowNodeFragment{
128
125
  generateDefaultProps(viewComponentDescriptor),
129
- std::make_shared<ShadowNode::ListOfShared>(
130
- ShadowNode::ListOfShared{childB, childC, childD})});
126
+ listOfChildren({childB, childC, childD})});
131
127
  auto shadowNodeV4 = shadowNodeV3->clone(ShadowNodeFragment{
132
128
  generateDefaultProps(viewComponentDescriptor),
133
- std::make_shared<ShadowNode::ListOfShared>(
134
- ShadowNode::ListOfShared{childB, childD, childE})});
129
+ listOfChildren({childB, childD, childE})});
135
130
  auto shadowNodeV5 = shadowNodeV4->clone(ShadowNodeFragment{
136
131
  generateDefaultProps(viewComponentDescriptor),
137
- std::make_shared<ShadowNode::ListOfShared>(
138
- ShadowNode::ListOfShared{childB, childA, childE, childC})});
132
+ listOfChildren({childB, childA, childE, childC})});
139
133
  auto shadowNodeV6 = shadowNodeV5->clone(ShadowNodeFragment{
140
134
  generateDefaultProps(viewComponentDescriptor),
141
135
  std::make_shared<ShadowNode::ListOfShared>(ShadowNode::ListOfShared{
@@ -157,38 +151,31 @@ TEST(MountingTest, testReorderingInstructionGeneration) {
157
151
  auto rootNodeV1 = std::static_pointer_cast<const RootShadowNode>(
158
152
  emptyRootNode->ShadowNode::clone(ShadowNodeFragment{
159
153
  ShadowNodeFragment::propsPlaceholder(),
160
- std::make_shared<ShadowNode::ListOfShared>(
161
- ShadowNode::ListOfShared{shadowNodeV1})}));
154
+ listOfChildren({shadowNodeV1})}));
162
155
  auto rootNodeV2 = std::static_pointer_cast<const RootShadowNode>(
163
156
  rootNodeV1->ShadowNode::clone(ShadowNodeFragment{
164
157
  ShadowNodeFragment::propsPlaceholder(),
165
- std::make_shared<ShadowNode::ListOfShared>(
166
- ShadowNode::ListOfShared{shadowNodeV2})}));
158
+ listOfChildren({shadowNodeV2})}));
167
159
  auto rootNodeV3 = std::static_pointer_cast<const RootShadowNode>(
168
160
  rootNodeV2->ShadowNode::clone(ShadowNodeFragment{
169
161
  ShadowNodeFragment::propsPlaceholder(),
170
- std::make_shared<ShadowNode::ListOfShared>(
171
- ShadowNode::ListOfShared{shadowNodeV3})}));
162
+ listOfChildren({shadowNodeV3})}));
172
163
  auto rootNodeV4 = std::static_pointer_cast<const RootShadowNode>(
173
164
  rootNodeV3->ShadowNode::clone(ShadowNodeFragment{
174
165
  ShadowNodeFragment::propsPlaceholder(),
175
- std::make_shared<ShadowNode::ListOfShared>(
176
- ShadowNode::ListOfShared{shadowNodeV4})}));
166
+ listOfChildren({shadowNodeV4})}));
177
167
  auto rootNodeV5 = std::static_pointer_cast<const RootShadowNode>(
178
168
  rootNodeV4->ShadowNode::clone(ShadowNodeFragment{
179
169
  ShadowNodeFragment::propsPlaceholder(),
180
- std::make_shared<ShadowNode::ListOfShared>(
181
- ShadowNode::ListOfShared{shadowNodeV5})}));
170
+ listOfChildren({shadowNodeV5})}));
182
171
  auto rootNodeV6 = std::static_pointer_cast<const RootShadowNode>(
183
172
  rootNodeV5->ShadowNode::clone(ShadowNodeFragment{
184
173
  ShadowNodeFragment::propsPlaceholder(),
185
- std::make_shared<ShadowNode::ListOfShared>(
186
- ShadowNode::ListOfShared{shadowNodeV6})}));
174
+ listOfChildren({shadowNodeV6})}));
187
175
  auto rootNodeV7 = std::static_pointer_cast<const RootShadowNode>(
188
176
  rootNodeV6->ShadowNode::clone(ShadowNodeFragment{
189
177
  ShadowNodeFragment::propsPlaceholder(),
190
- std::make_shared<ShadowNode::ListOfShared>(
191
- ShadowNode::ListOfShared{shadowNodeV7})}));
178
+ listOfChildren({shadowNodeV7})}));
192
179
 
193
180
  // Layout
194
181
  std::vector<const LayoutableShadowNode*> affectedLayoutableNodesV1{};
@@ -289,7 +276,6 @@ TEST(MountingTest, testReorderingInstructionGeneration) {
289
276
 
290
277
  // Calculating mutations.
291
278
  auto mutations3 = calculateShadowViewMutations(*rootNodeV3, *rootNodeV4);
292
- LOG(ERROR) << "Num mutations IN OLD TEST mutations3: " << mutations3.size();
293
279
 
294
280
  // The order and exact mutation instructions here may change at any time.
295
281
  // This test just ensures that any changes are intentional.
@@ -380,9 +366,6 @@ TEST(MountingTest, testReorderingInstructionGeneration) {
380
366
  TEST(MountingTest, testViewReparentingInstructionGeneration) {
381
367
  auto eventDispatcher = EventDispatcher::Shared{};
382
368
  auto contextContainer = std::make_shared<ContextContainer>();
383
- contextContainer->insert(
384
- "ReactNativeConfig", std::make_shared<EmptyReactNativeConfig>());
385
-
386
369
  auto componentDescriptorParameters =
387
370
  ComponentDescriptorParameters{eventDispatcher, contextContainer, nullptr};
388
371
  auto viewComponentDescriptor =
@@ -425,172 +408,107 @@ TEST(MountingTest, testViewReparentingInstructionGeneration) {
425
408
  auto family =
426
409
  viewComponentDescriptor.createFamily({10, SurfaceId(1), nullptr});
427
410
 
428
- auto reparentedViewA = makeNode(
429
- viewComponentDescriptor,
430
- 1000,
431
- ShadowNode::ListOfShared{
432
- childC->clone({}), childA->clone({}), childB->clone({})});
411
+ auto reparentedViewA_ = makeNode(
412
+ viewComponentDescriptor, 1000, listOfChildren({childC, childA, childB}));
413
+ auto reparentedViewA = reparentedViewA_->clone(
414
+ ShadowNodeFragment{nonFlattenedDefaultProps(viewComponentDescriptor)});
433
415
  auto reparentedViewB = makeNode(
434
- viewComponentDescriptor,
435
- 2000,
436
- ShadowNode::ListOfShared{
437
- childF->clone({}), childE->clone({}), childD->clone({})});
416
+ viewComponentDescriptor, 2000, listOfChildren({childF, childE, childD}));
438
417
 
439
418
  // Root -> G* -> H -> I -> J -> A* [nodes with * are _not_ flattened]
440
419
  auto shadowNodeV1 = viewComponentDescriptor.createShadowNode(
441
420
  ShadowNodeFragment{
442
421
  generateDefaultProps(viewComponentDescriptor),
443
- std::make_shared<ShadowNode::ListOfShared>(
444
- ShadowNode::ListOfShared{childG->clone(ShadowNodeFragment{
445
- nonFlattenedDefaultProps(viewComponentDescriptor),
446
- std::make_shared<ShadowNode::ListOfShared>(
447
- ShadowNode::ListOfShared{childH->clone(ShadowNodeFragment{
422
+ listOfChildren({childG->clone(ShadowNodeFragment{
423
+ nonFlattenedDefaultProps(viewComponentDescriptor),
424
+ listOfChildren({childH->clone(ShadowNodeFragment{
425
+ generateDefaultProps(viewComponentDescriptor),
426
+ listOfChildren({childI->clone(ShadowNodeFragment{
427
+ generateDefaultProps(viewComponentDescriptor),
428
+ listOfChildren({childJ->clone(ShadowNodeFragment{
448
429
  generateDefaultProps(viewComponentDescriptor),
449
- std::make_shared<ShadowNode::ListOfShared>(
450
- ShadowNode::ListOfShared{
451
- childI->clone(ShadowNodeFragment{
452
- generateDefaultProps(
453
- viewComponentDescriptor),
454
- std::make_shared<
455
- ShadowNode::ListOfShared>(
456
- ShadowNode::ListOfShared{
457
- childJ->clone(ShadowNodeFragment{
458
- generateDefaultProps(
459
- viewComponentDescriptor),
460
- std::make_shared<
461
- ShadowNode::ListOfShared>(
462
- ShadowNode::ListOfShared{
463
- reparentedViewA->clone(
464
- {})})})})})})})})})})},
430
+ listOfChildren({reparentedViewA_})})})})})})})})})},
465
431
  family);
466
432
 
467
433
  // Root -> G* -> H* -> I -> J -> A* [nodes with * are _not_ flattened]
434
+ // Force an update with A with new props
468
435
  auto shadowNodeV2 = shadowNodeV1->clone(ShadowNodeFragment{
469
436
  generateDefaultProps(viewComponentDescriptor),
470
- std::make_shared<ShadowNode::ListOfShared>(
471
- ShadowNode::ListOfShared{childG->clone(ShadowNodeFragment{
437
+ listOfChildren({childG->clone(ShadowNodeFragment{
438
+ nonFlattenedDefaultProps(viewComponentDescriptor),
439
+ listOfChildren({childH->clone(ShadowNodeFragment{
472
440
  nonFlattenedDefaultProps(viewComponentDescriptor),
473
- std::make_shared<ShadowNode::ListOfShared>(
474
- ShadowNode::ListOfShared{childH->clone(ShadowNodeFragment{
475
- nonFlattenedDefaultProps(viewComponentDescriptor),
476
- std::make_shared<
477
- ShadowNode::ListOfShared>(ShadowNode::ListOfShared{
478
- childI->clone(ShadowNodeFragment{
479
- generateDefaultProps(viewComponentDescriptor),
480
- std::make_shared<ShadowNode::ListOfShared>(
481
- ShadowNode::ListOfShared{
482
- childJ->clone(ShadowNodeFragment{
483
- generateDefaultProps(
484
- viewComponentDescriptor),
485
- std::make_shared<
486
- ShadowNode::ListOfShared>(
487
- ShadowNode::ListOfShared{
488
- reparentedViewA->clone(
489
- {})})})})})})})})})})});
441
+ listOfChildren({childI->clone(ShadowNodeFragment{
442
+ generateDefaultProps(viewComponentDescriptor),
443
+ listOfChildren({childJ->clone(ShadowNodeFragment{
444
+ generateDefaultProps(viewComponentDescriptor),
445
+ listOfChildren({reparentedViewA})})})})})})})})})});
490
446
 
491
447
  // Root -> G* -> H -> I -> J -> A* [nodes with * are _not_ flattened]
492
448
  auto shadowNodeV3 = shadowNodeV2->clone(ShadowNodeFragment{
493
449
  generateDefaultProps(viewComponentDescriptor),
494
- std::make_shared<ShadowNode::ListOfShared>(
495
- ShadowNode::ListOfShared{childG->clone(ShadowNodeFragment{
496
- nonFlattenedDefaultProps(viewComponentDescriptor),
497
- std::make_shared<ShadowNode::ListOfShared>(
498
- ShadowNode::ListOfShared{childH->clone(ShadowNodeFragment{
450
+ listOfChildren({childG->clone(ShadowNodeFragment{
451
+ nonFlattenedDefaultProps(viewComponentDescriptor),
452
+ listOfChildren({childH->clone(ShadowNodeFragment{
453
+ generateDefaultProps(viewComponentDescriptor),
454
+ listOfChildren({childI->clone(ShadowNodeFragment{
455
+ generateDefaultProps(viewComponentDescriptor),
456
+ listOfChildren({childJ->clone(ShadowNodeFragment{
499
457
  generateDefaultProps(viewComponentDescriptor),
500
- std::make_shared<
501
- ShadowNode::ListOfShared>(ShadowNode::ListOfShared{
502
- childI->clone(ShadowNodeFragment{
503
- generateDefaultProps(viewComponentDescriptor),
504
- std::make_shared<ShadowNode::ListOfShared>(
505
- ShadowNode::ListOfShared{
506
- childJ->clone(ShadowNodeFragment{
507
- generateDefaultProps(
508
- viewComponentDescriptor),
509
- std::make_shared<
510
- ShadowNode::ListOfShared>(
511
- ShadowNode::ListOfShared{
512
- reparentedViewA->clone(
513
- {})})})})})})})})})})});
458
+ listOfChildren({reparentedViewA})})})})})})})})})});
514
459
 
515
460
  // The view is reparented 1 level down with a different sibling
516
461
  // Root -> G* -> H* -> I* -> J -> [B*, A*] [nodes with * are _not_ flattened]
517
462
  auto shadowNodeV4 = shadowNodeV3->clone(ShadowNodeFragment{
518
463
  generateDefaultProps(viewComponentDescriptor),
519
- std::make_shared<ShadowNode::ListOfShared>(
520
- ShadowNode::ListOfShared{childG->clone(ShadowNodeFragment{
464
+ listOfChildren({childG->clone(ShadowNodeFragment{
465
+ nonFlattenedDefaultProps(viewComponentDescriptor),
466
+ listOfChildren({childH->clone(ShadowNodeFragment{
521
467
  nonFlattenedDefaultProps(viewComponentDescriptor),
522
- std::make_shared<ShadowNode::ListOfShared>(
523
- ShadowNode::ListOfShared{childH->clone(ShadowNodeFragment{
524
- nonFlattenedDefaultProps(viewComponentDescriptor),
525
- std::make_shared<
526
- ShadowNode::ListOfShared>(ShadowNode::ListOfShared{
527
- childI->clone(ShadowNodeFragment{
528
- nonFlattenedDefaultProps(viewComponentDescriptor),
529
- std::make_shared<ShadowNode::ListOfShared>(
530
- ShadowNode::ListOfShared{
531
- childJ->clone(ShadowNodeFragment{
532
- generateDefaultProps(
533
- viewComponentDescriptor),
534
- std::make_shared<
535
- ShadowNode::ListOfShared>(
536
- ShadowNode::ListOfShared{
537
- reparentedViewB->clone({}),
538
- reparentedViewA->clone(
539
- {})})})})})})})})})})});
468
+ listOfChildren({childI->clone(ShadowNodeFragment{
469
+ nonFlattenedDefaultProps(viewComponentDescriptor),
470
+ listOfChildren({childJ->clone(ShadowNodeFragment{
471
+ generateDefaultProps(viewComponentDescriptor),
472
+ listOfChildren(
473
+ {reparentedViewB, reparentedViewA})})})})})})})})})});
540
474
 
541
475
  // The view is reparented 1 level further down with its order with the sibling
542
476
  // swapped
543
477
  // Root -> G* -> H* -> I* -> J* -> [A*, B*] [nodes with * are _not_ flattened]
544
478
  auto shadowNodeV5 = shadowNodeV4->clone(ShadowNodeFragment{
545
479
  generateDefaultProps(viewComponentDescriptor),
546
- std::make_shared<ShadowNode::ListOfShared>(
547
- ShadowNode::ListOfShared{childG->clone(ShadowNodeFragment{
480
+ listOfChildren({childG->clone(ShadowNodeFragment{
481
+ nonFlattenedDefaultProps(viewComponentDescriptor),
482
+ listOfChildren({childH->clone(ShadowNodeFragment{
548
483
  nonFlattenedDefaultProps(viewComponentDescriptor),
549
- std::make_shared<ShadowNode::ListOfShared>(
550
- ShadowNode::ListOfShared{childH->clone(ShadowNodeFragment{
484
+ listOfChildren({childI->clone(ShadowNodeFragment{
485
+ nonFlattenedDefaultProps(viewComponentDescriptor),
486
+ listOfChildren({childJ->clone(ShadowNodeFragment{
551
487
  nonFlattenedDefaultProps(viewComponentDescriptor),
552
- std::make_shared<
553
- ShadowNode::ListOfShared>(ShadowNode::ListOfShared{
554
- childI->clone(ShadowNodeFragment{
555
- nonFlattenedDefaultProps(viewComponentDescriptor),
556
- std::make_shared<ShadowNode::ListOfShared>(
557
- ShadowNode::ListOfShared{
558
- childJ->clone(ShadowNodeFragment{
559
- nonFlattenedDefaultProps(
560
- viewComponentDescriptor),
561
- std::make_shared<
562
- ShadowNode::ListOfShared>(
563
- ShadowNode::ListOfShared{
564
- reparentedViewA->clone({}),
565
- reparentedViewB->clone(
566
- {})})})})})})})})})})});
488
+ listOfChildren(
489
+ {reparentedViewA, reparentedViewB})})})})})})})})})});
567
490
 
568
491
  // Injecting a tree into the root node.
569
492
  auto rootNodeV1 = std::static_pointer_cast<const RootShadowNode>(
570
493
  emptyRootNode->ShadowNode::clone(ShadowNodeFragment{
571
494
  ShadowNodeFragment::propsPlaceholder(),
572
- std::make_shared<ShadowNode::ListOfShared>(
573
- ShadowNode::ListOfShared{shadowNodeV1})}));
495
+ listOfChildren({shadowNodeV1})}));
574
496
  auto rootNodeV2 = std::static_pointer_cast<const RootShadowNode>(
575
497
  rootNodeV1->ShadowNode::clone(ShadowNodeFragment{
576
498
  ShadowNodeFragment::propsPlaceholder(),
577
- std::make_shared<ShadowNode::ListOfShared>(
578
- ShadowNode::ListOfShared{shadowNodeV2})}));
499
+ listOfChildren({shadowNodeV2})}));
579
500
  auto rootNodeV3 = std::static_pointer_cast<const RootShadowNode>(
580
501
  rootNodeV2->ShadowNode::clone(ShadowNodeFragment{
581
502
  ShadowNodeFragment::propsPlaceholder(),
582
- std::make_shared<ShadowNode::ListOfShared>(
583
- ShadowNode::ListOfShared{shadowNodeV3})}));
503
+ listOfChildren({shadowNodeV3})}));
584
504
  auto rootNodeV4 = std::static_pointer_cast<const RootShadowNode>(
585
505
  rootNodeV3->ShadowNode::clone(ShadowNodeFragment{
586
506
  ShadowNodeFragment::propsPlaceholder(),
587
- std::make_shared<ShadowNode::ListOfShared>(
588
- ShadowNode::ListOfShared{shadowNodeV4})}));
507
+ listOfChildren({shadowNodeV4})}));
589
508
  auto rootNodeV5 = std::static_pointer_cast<const RootShadowNode>(
590
509
  rootNodeV4->ShadowNode::clone(ShadowNodeFragment{
591
510
  ShadowNodeFragment::propsPlaceholder(),
592
- std::make_shared<ShadowNode::ListOfShared>(
593
- ShadowNode::ListOfShared{shadowNodeV5})}));
511
+ listOfChildren({shadowNodeV5})}));
594
512
 
595
513
  // Layout
596
514
  std::vector<const LayoutableShadowNode*> affectedLayoutableNodesV1{};
@@ -626,33 +544,37 @@ TEST(MountingTest, testViewReparentingInstructionGeneration) {
626
544
  // Calculating mutations.
627
545
  auto mutations1 = calculateShadowViewMutations(*rootNodeV1, *rootNodeV2);
628
546
 
629
- EXPECT_EQ(mutations1.size(), 5);
547
+ EXPECT_EQ(mutations1.size(), 6);
630
548
  EXPECT_EQ(mutations1[0].type, ShadowViewMutation::Update);
631
- EXPECT_EQ(mutations1[0].oldChildShadowView.tag, 106);
632
- EXPECT_EQ(mutations1[1].type, ShadowViewMutation::Remove);
633
- EXPECT_EQ(mutations1[1].oldChildShadowView.tag, 1000);
634
- EXPECT_EQ(mutations1[2].type, ShadowViewMutation::Create);
635
- EXPECT_EQ(mutations1[2].newChildShadowView.tag, 107);
636
- EXPECT_EQ(mutations1[3].type, ShadowViewMutation::Insert);
637
- EXPECT_EQ(mutations1[3].newChildShadowView.tag, 107);
549
+ EXPECT_EQ(mutations1[0].oldChildShadowView.tag, childG->getTag());
550
+ EXPECT_EQ(mutations1[1].type, ShadowViewMutation::Update);
551
+ EXPECT_EQ(mutations1[1].oldChildShadowView.tag, reparentedViewA->getTag());
552
+ EXPECT_EQ(mutations1[1].parentTag, childG->getTag());
553
+ EXPECT_EQ(mutations1[2].type, ShadowViewMutation::Remove);
554
+ EXPECT_EQ(mutations1[2].oldChildShadowView.tag, reparentedViewA->getTag());
555
+ EXPECT_EQ(mutations1[3].type, ShadowViewMutation::Create);
556
+ EXPECT_EQ(mutations1[3].newChildShadowView.tag, childH->getTag());
638
557
  EXPECT_EQ(mutations1[4].type, ShadowViewMutation::Insert);
639
- EXPECT_EQ(mutations1[4].newChildShadowView.tag, 1000);
558
+ EXPECT_EQ(mutations1[4].newChildShadowView.tag, childH->getTag());
559
+ EXPECT_EQ(mutations1[5].type, ShadowViewMutation::Insert);
560
+ EXPECT_EQ(mutations1[5].newChildShadowView.tag, reparentedViewA->getTag());
640
561
 
641
562
  auto mutations2 = calculateShadowViewMutations(*rootNodeV2, *rootNodeV3);
642
563
 
643
564
  EXPECT_EQ(mutations2.size(), 5);
644
565
  EXPECT_EQ(mutations2[0].type, ShadowViewMutation::Update);
645
- EXPECT_EQ(mutations2[0].oldChildShadowView.tag, 106);
566
+ EXPECT_EQ(mutations2[0].oldChildShadowView.tag, childG->getTag());
567
+ EXPECT_EQ(mutations2[0].parentTag, emptyRootNode->getTag());
646
568
  EXPECT_EQ(mutations2[1].type, ShadowViewMutation::Remove);
647
- EXPECT_EQ(mutations2[1].oldChildShadowView.tag, 1000);
569
+ EXPECT_EQ(mutations2[1].oldChildShadowView.tag, reparentedViewA->getTag());
648
570
  EXPECT_EQ(mutations2[2].type, ShadowViewMutation::Remove);
649
- EXPECT_EQ(mutations2[2].oldChildShadowView.tag, 107);
571
+ EXPECT_EQ(mutations2[2].oldChildShadowView.tag, childH->getTag());
650
572
  EXPECT_EQ(
651
573
  mutations2[3].type,
652
- ShadowViewMutation::Delete); // correct, 107 is removed from tree entirely
653
- EXPECT_EQ(mutations2[3].oldChildShadowView.tag, 107);
574
+ ShadowViewMutation::Delete); // correct, H is removed from tree entirely
575
+ EXPECT_EQ(mutations2[3].oldChildShadowView.tag, childH->getTag());
654
576
  EXPECT_EQ(mutations2[4].type, ShadowViewMutation::Insert);
655
- EXPECT_EQ(mutations2[4].newChildShadowView.tag, 1000);
577
+ EXPECT_EQ(mutations2[4].newChildShadowView.tag, reparentedViewA->getTag());
656
578
 
657
579
  auto mutations3 = calculateShadowViewMutations(*rootNodeV3, *rootNodeV4);
658
580
 
@@ -661,57 +583,58 @@ TEST(MountingTest, testViewReparentingInstructionGeneration) {
661
583
 
662
584
  EXPECT_EQ(mutations3.size(), 15);
663
585
  EXPECT_EQ(mutations3[0].type, ShadowViewMutation::Update);
664
- EXPECT_EQ(mutations3[0].oldChildShadowView.tag, 106);
586
+ EXPECT_EQ(mutations3[0].oldChildShadowView.tag, childG->getTag());
587
+ EXPECT_EQ(mutations3[0].parentTag, emptyRootNode->getTag());
665
588
  EXPECT_EQ(mutations3[1].type, ShadowViewMutation::Remove);
666
- EXPECT_EQ(mutations3[1].oldChildShadowView.tag, 1000);
589
+ EXPECT_EQ(mutations3[1].oldChildShadowView.tag, reparentedViewA->getTag());
667
590
  EXPECT_EQ(mutations3[2].type, ShadowViewMutation::Create);
668
- EXPECT_EQ(mutations3[2].newChildShadowView.tag, 107);
591
+ EXPECT_EQ(mutations3[2].newChildShadowView.tag, childH->getTag());
669
592
  EXPECT_EQ(mutations3[3].type, ShadowViewMutation::Create);
670
- EXPECT_EQ(mutations3[3].newChildShadowView.tag, 2000);
593
+ EXPECT_EQ(mutations3[3].newChildShadowView.tag, reparentedViewB->getTag());
671
594
  EXPECT_EQ(mutations3[4].type, ShadowViewMutation::Create);
672
- EXPECT_EQ(mutations3[4].newChildShadowView.tag, 108);
595
+ EXPECT_EQ(mutations3[4].newChildShadowView.tag, childI->getTag());
673
596
  EXPECT_EQ(mutations3[5].type, ShadowViewMutation::Create);
674
- EXPECT_EQ(mutations3[5].newChildShadowView.tag, 105);
597
+ EXPECT_EQ(mutations3[5].newChildShadowView.tag, childF->getTag());
675
598
  EXPECT_EQ(mutations3[6].type, ShadowViewMutation::Create);
676
- EXPECT_EQ(mutations3[6].newChildShadowView.tag, 104);
599
+ EXPECT_EQ(mutations3[6].newChildShadowView.tag, childE->getTag());
677
600
  EXPECT_EQ(mutations3[7].type, ShadowViewMutation::Create);
678
- EXPECT_EQ(mutations3[7].newChildShadowView.tag, 103);
601
+ EXPECT_EQ(mutations3[7].newChildShadowView.tag, childD->getTag());
679
602
  EXPECT_EQ(mutations3[8].type, ShadowViewMutation::Insert);
680
- EXPECT_EQ(mutations3[8].newChildShadowView.tag, 105);
603
+ EXPECT_EQ(mutations3[8].newChildShadowView.tag, childF->getTag());
681
604
  EXPECT_EQ(mutations3[9].type, ShadowViewMutation::Insert);
682
- EXPECT_EQ(mutations3[9].newChildShadowView.tag, 104);
605
+ EXPECT_EQ(mutations3[9].newChildShadowView.tag, childE->getTag());
683
606
  EXPECT_EQ(mutations3[10].type, ShadowViewMutation::Insert);
684
- EXPECT_EQ(mutations3[10].newChildShadowView.tag, 103);
607
+ EXPECT_EQ(mutations3[10].newChildShadowView.tag, childD->getTag());
685
608
  EXPECT_EQ(mutations3[11].type, ShadowViewMutation::Insert);
686
- EXPECT_EQ(mutations3[11].newChildShadowView.tag, 107);
609
+ EXPECT_EQ(mutations3[11].newChildShadowView.tag, childH->getTag());
687
610
  EXPECT_EQ(mutations3[12].type, ShadowViewMutation::Insert);
688
- EXPECT_EQ(mutations3[12].newChildShadowView.tag, 108);
611
+ EXPECT_EQ(mutations3[12].newChildShadowView.tag, childI->getTag());
689
612
  EXPECT_EQ(mutations3[13].type, ShadowViewMutation::Insert);
690
- EXPECT_EQ(mutations3[13].newChildShadowView.tag, 2000);
613
+ EXPECT_EQ(mutations3[13].newChildShadowView.tag, reparentedViewB->getTag());
691
614
  EXPECT_EQ(mutations3[14].type, ShadowViewMutation::Insert);
692
- EXPECT_EQ(mutations3[14].newChildShadowView.tag, 1000);
615
+ EXPECT_EQ(mutations3[14].newChildShadowView.tag, reparentedViewA->getTag());
693
616
 
694
617
  auto mutations4 = calculateShadowViewMutations(*rootNodeV4, *rootNodeV5);
695
618
 
696
619
  EXPECT_EQ(mutations4.size(), 9);
697
620
  EXPECT_EQ(mutations4[0].type, ShadowViewMutation::Update);
698
- EXPECT_EQ(mutations4[0].oldChildShadowView.tag, 106);
621
+ EXPECT_EQ(mutations4[0].oldChildShadowView.tag, childG->getTag());
699
622
  EXPECT_EQ(mutations4[1].type, ShadowViewMutation::Update);
700
- EXPECT_EQ(mutations4[1].oldChildShadowView.tag, 107);
623
+ EXPECT_EQ(mutations4[1].oldChildShadowView.tag, childH->getTag());
701
624
  EXPECT_EQ(mutations4[2].type, ShadowViewMutation::Update);
702
- EXPECT_EQ(mutations4[2].oldChildShadowView.tag, 108);
625
+ EXPECT_EQ(mutations4[2].oldChildShadowView.tag, childI->getTag());
703
626
  EXPECT_EQ(mutations4[3].type, ShadowViewMutation::Remove);
704
- EXPECT_EQ(mutations4[3].oldChildShadowView.tag, 1000);
627
+ EXPECT_EQ(mutations4[3].oldChildShadowView.tag, reparentedViewA->getTag());
705
628
  EXPECT_EQ(mutations4[4].type, ShadowViewMutation::Remove);
706
- EXPECT_EQ(mutations4[4].oldChildShadowView.tag, 2000);
629
+ EXPECT_EQ(mutations4[4].oldChildShadowView.tag, reparentedViewB->getTag());
707
630
  EXPECT_EQ(mutations4[5].type, ShadowViewMutation::Create);
708
- EXPECT_EQ(mutations4[5].newChildShadowView.tag, 109);
631
+ EXPECT_EQ(mutations4[5].newChildShadowView.tag, childJ->getTag());
709
632
  EXPECT_EQ(mutations4[6].type, ShadowViewMutation::Insert);
710
- EXPECT_EQ(mutations4[6].newChildShadowView.tag, 109);
633
+ EXPECT_EQ(mutations4[6].newChildShadowView.tag, childJ->getTag());
711
634
  EXPECT_EQ(mutations4[7].type, ShadowViewMutation::Insert);
712
- EXPECT_EQ(mutations4[7].newChildShadowView.tag, 1000);
635
+ EXPECT_EQ(mutations4[7].newChildShadowView.tag, reparentedViewA->getTag());
713
636
  EXPECT_EQ(mutations4[8].type, ShadowViewMutation::Insert);
714
- EXPECT_EQ(mutations4[8].newChildShadowView.tag, 2000);
637
+ EXPECT_EQ(mutations4[8].newChildShadowView.tag, reparentedViewB->getTag());
715
638
  }
716
639
 
717
640
  } // namespace facebook::react
@@ -10,7 +10,6 @@
10
10
  #include <glog/logging.h>
11
11
  #include <gtest/gtest.h>
12
12
 
13
- #include <react/config/ReactNativeConfig.h>
14
13
  #include <react/renderer/components/root/RootComponentDescriptor.h>
15
14
  #include <react/renderer/components/view/ViewComponentDescriptor.h>
16
15
  #include <react/renderer/core/PropsParserContext.h>
@@ -183,8 +182,6 @@ static void testShadowNodeTreeLifeCycleExtensiveFlatteningUnflattening(
183
182
 
184
183
  auto eventDispatcher = EventDispatcher::Shared{};
185
184
  auto contextContainer = std::make_shared<ContextContainer>();
186
- contextContainer->insert(
187
- "ReactNativeConfig", std::make_shared<EmptyReactNativeConfig>());
188
185
 
189
186
  auto componentDescriptorParameters =
190
187
  ComponentDescriptorParameters{eventDispatcher, contextContainer, nullptr};
@@ -135,7 +135,8 @@ IntersectionObserver::updateIntersectionObservation(
135
135
  : intersectionRectArea / targetBoundingRectArea;
136
136
 
137
137
  if (intersectionRatio == 0) {
138
- return setNotIntersectingState(rootBoundingRect, targetBoundingRect, time);
138
+ return setNotIntersectingState(
139
+ rootBoundingRect, targetBoundingRect, intersectionRect, time);
139
140
  }
140
141
 
141
142
  auto highestThresholdCrossed =
@@ -154,7 +155,8 @@ IntersectionObserver::updateIntersectionObservation(
154
155
 
155
156
  if (highestThresholdCrossed == -1.0f &&
156
157
  highestRootThresholdCrossed == -1.0f) {
157
- return setNotIntersectingState(rootBoundingRect, targetBoundingRect, time);
158
+ return setNotIntersectingState(
159
+ rootBoundingRect, targetBoundingRect, intersectionRect, time);
158
160
  }
159
161
 
160
162
  return setIntersectingState(
@@ -169,7 +171,7 @@ IntersectionObserver::updateIntersectionObservation(
169
171
  std::optional<IntersectionObserverEntry>
170
172
  IntersectionObserver::updateIntersectionObservationForSurfaceUnmount(
171
173
  double time) {
172
- return setNotIntersectingState(Rect{}, Rect{}, time);
174
+ return setNotIntersectingState(Rect{}, Rect{}, Rect{}, time);
173
175
  }
174
176
 
175
177
  std::optional<IntersectionObserverEntry>
@@ -204,6 +206,7 @@ std::optional<IntersectionObserverEntry>
204
206
  IntersectionObserver::setNotIntersectingState(
205
207
  const Rect& rootBoundingRect,
206
208
  const Rect& targetBoundingRect,
209
+ const Rect& intersectionRect,
207
210
  double time) {
208
211
  if (state_ != IntersectionObserverState::NotIntersecting()) {
209
212
  state_ = IntersectionObserverState::NotIntersecting();
@@ -212,7 +215,7 @@ IntersectionObserver::setNotIntersectingState(
212
215
  targetShadowNode_,
213
216
  targetBoundingRect,
214
217
  rootBoundingRect,
215
- std::nullopt,
218
+ intersectionRect,
216
219
  false,
217
220
  time,
218
221
  };
@@ -23,7 +23,7 @@ struct IntersectionObserverEntry {
23
23
  ShadowNode::Shared shadowNode;
24
24
  Rect targetRect;
25
25
  Rect rootRect;
26
- std::optional<Rect> intersectionRect;
26
+ Rect intersectionRect;
27
27
  bool isIntersectingAboveThresholds;
28
28
  // TODO(T156529385) Define `DOMHighResTimeStamp` as an alias for `double` and
29
29
  // use it here.
@@ -71,6 +71,7 @@ class IntersectionObserver {
71
71
  std::optional<IntersectionObserverEntry> setNotIntersectingState(
72
72
  const Rect& rootBoundingRect,
73
73
  const Rect& targetBoundingRect,
74
+ const Rect& intersectionRect,
74
75
  double time);
75
76
 
76
77
  IntersectionObserverObserverId intersectionObserverId_;
@@ -7,7 +7,7 @@
7
7
 
8
8
  #include "IntersectionObserverManager.h"
9
9
  #include <cxxreact/JSExecutor.h>
10
- #include <cxxreact/SystraceSection.h>
10
+ #include <cxxreact/TraceSection.h>
11
11
  #include <utility>
12
12
  #include "IntersectionObserver.h"
13
13
 
@@ -21,7 +21,7 @@ void IntersectionObserverManager::observe(
21
21
  std::vector<Float> thresholds,
22
22
  std::optional<std::vector<Float>> rootThresholds,
23
23
  const UIManager& uiManager) {
24
- SystraceSection s("IntersectionObserverManager::observe");
24
+ TraceSection s("IntersectionObserverManager::observe");
25
25
 
26
26
  auto surfaceId = shadowNode->getSurfaceId();
27
27
 
@@ -78,7 +78,7 @@ void IntersectionObserverManager::observe(
78
78
  void IntersectionObserverManager::unobserve(
79
79
  IntersectionObserverObserverId intersectionObserverId,
80
80
  const ShadowNode& shadowNode) {
81
- SystraceSection s("IntersectionObserverManager::unobserve");
81
+ TraceSection s("IntersectionObserverManager::unobserve");
82
82
 
83
83
  {
84
84
  std::unique_lock lock(observersMutex_);
@@ -127,7 +127,7 @@ void IntersectionObserverManager::unobserve(
127
127
  void IntersectionObserverManager::connect(
128
128
  UIManager& uiManager,
129
129
  std::function<void()> notifyIntersectionObserversCallback) {
130
- SystraceSection s("IntersectionObserverManager::connect");
130
+ TraceSection s("IntersectionObserverManager::connect");
131
131
  notifyIntersectionObserversCallback_ =
132
132
  std::move(notifyIntersectionObserversCallback);
133
133
 
@@ -141,7 +141,7 @@ void IntersectionObserverManager::connect(
141
141
  }
142
142
 
143
143
  void IntersectionObserverManager::disconnect(UIManager& uiManager) {
144
- SystraceSection s("IntersectionObserverManager::disconnect");
144
+ TraceSection s("IntersectionObserverManager::disconnect");
145
145
 
146
146
  // Fail-safe in case the caller doesn't guarantee consistency.
147
147
  if (!mountHookRegistered_) {
@@ -185,8 +185,7 @@ void IntersectionObserverManager::updateIntersectionObservations(
185
185
  SurfaceId surfaceId,
186
186
  const RootShadowNode* rootShadowNode,
187
187
  double time) {
188
- SystraceSection s(
189
- "IntersectionObserverManager::updateIntersectionObservations");
188
+ TraceSection s("IntersectionObserverManager::updateIntersectionObservations");
190
189
 
191
190
  std::vector<IntersectionObserverEntry> entries;
192
191
 
@@ -248,7 +247,7 @@ void IntersectionObserverManager::notifyObserversIfNecessary() {
248
247
  }
249
248
 
250
249
  void IntersectionObserverManager::notifyObservers() {
251
- SystraceSection s("IntersectionObserverManager::notifyObservers");
250
+ TraceSection s("IntersectionObserverManager::notifyObservers");
252
251
  notifyIntersectionObserversCallback_();
253
252
  }
254
253