react-native-tvos 0.84.1-0 → 0.85.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.
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +3 -3
- package/Libraries/Animated/Animated.d.ts +8 -1
- package/Libraries/Animated/AnimatedEvent.js +4 -4
- package/Libraries/Animated/AnimatedImplementation.js +2 -2
- package/Libraries/Animated/animations/Animation.js +3 -3
- package/Libraries/Animated/animations/DecayAnimation.js +4 -4
- package/Libraries/Animated/animations/SpringAnimation.js +5 -5
- package/Libraries/Animated/animations/TimingAnimation.js +5 -5
- package/Libraries/Animated/createAnimatedComponent.js +7 -7
- package/Libraries/Animated/nodes/AnimatedColor.js +2 -2
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +12 -12
- package/Libraries/Animated/nodes/AnimatedNode.js +3 -3
- package/Libraries/Animated/nodes/AnimatedObject.js +3 -3
- package/Libraries/Animated/nodes/AnimatedProps.js +6 -6
- package/Libraries/Animated/nodes/AnimatedStyle.js +7 -7
- package/Libraries/Animated/nodes/AnimatedTransform.js +13 -13
- package/Libraries/Animated/nodes/AnimatedValue.js +1 -1
- package/Libraries/Animated/nodes/AnimatedValueXY.js +1 -1
- package/Libraries/Animated/nodes/AnimatedWithChildren.js +1 -1
- package/{jest/mocks/Vibration.js → Libraries/Animated/useAnimatedColor.d.ts} +5 -6
- package/Libraries/Animated/useAnimatedColor.js +25 -0
- package/{jest/mocks/Clipboard.js → Libraries/Animated/useAnimatedValueXY.d.ts} +5 -6
- package/Libraries/Animated/useAnimatedValueXY.js +26 -0
- package/Libraries/AppDelegate/RCTAppDelegate.mm +0 -8
- package/Libraries/AppDelegate/RCTDefaultReactNativeFactoryDelegate.mm +1 -3
- package/Libraries/AppDelegate/RCTReactNativeFactory.mm +1 -0
- package/Libraries/AppDelegate/RCTRootViewFactory.mm +2 -6
- package/Libraries/AppState/AppState.js +1 -1
- package/Libraries/BatchedBridge/MessageQueue.js +3 -3
- package/Libraries/BatchedBridge/NativeModules.js +12 -10
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +30 -26
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +2 -2
- package/Libraries/Components/Button.js +2 -2
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroidTypes.js +2 -2
- package/Libraries/Components/Keyboard/Keyboard.js +6 -6
- package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +1 -1
- package/Libraries/Components/LayoutConformance/LayoutConformance.js +1 -1
- package/Libraries/Components/LayoutConformance/LayoutConformanceNativeComponent.js +1 -1
- package/Libraries/Components/Pressable/Pressable.d.ts +5 -0
- package/Libraries/Components/Pressable/Pressable.js +3 -3
- package/Libraries/Components/Pressable/useAndroidRippleForView.js +4 -4
- package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroid.js +1 -1
- package/Libraries/Components/ProgressBarAndroid/ProgressBarAndroidTypes.js +3 -3
- package/Libraries/Components/RefreshControl/RefreshControl.js +5 -5
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +10 -12
- package/Libraries/Components/ScrollView/ScrollView.d.ts +18 -1
- package/Libraries/Components/ScrollView/ScrollView.js +33 -10
- package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +12 -18
- package/Libraries/Components/ScrollView/ScrollViewNativeComponentType.js +7 -4
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +1 -1
- package/Libraries/Components/StaticRenderer.js +1 -1
- package/Libraries/Components/StatusBar/StatusBar.js +8 -8
- package/Libraries/Components/Switch/Switch.js +3 -3
- package/Libraries/Components/TV/TVViewPropTypes.js +7 -0
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +33 -48
- package/Libraries/Components/TextInput/InputAccessoryView.js +1 -1
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +6 -11
- package/Libraries/Components/TextInput/TextInput.flow.js +21 -20
- package/Libraries/Components/TextInput/TextInput.js +8 -4
- package/Libraries/Components/Touchable/PooledClass.js +1 -1
- package/Libraries/Components/Touchable/Touchable.js +2 -2
- package/Libraries/Components/Touchable/TouchableBounce.js +4 -4
- package/Libraries/Components/Touchable/TouchableHighlight.js +6 -6
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +7 -7
- package/Libraries/Components/Touchable/TouchableOpacity.js +3 -3
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +1 -1
- package/Libraries/Components/UnimplementedViews/UnimplementedView.js +1 -1
- package/Libraries/Components/View/ReactNativeStyleAttributes.js +68 -31
- package/Libraries/Components/View/View.js +6 -0
- package/Libraries/Components/View/ViewAccessibility.js +7 -7
- package/Libraries/Components/View/ViewPropTypes.js +15 -15
- package/Libraries/Core/Devtools/parseHermesStack.js +8 -8
- package/Libraries/Core/Devtools/symbolicateStackTrace.js +2 -2
- package/Libraries/Core/ExceptionsManager.js +2 -2
- package/Libraries/Core/ExtendedError.js +3 -3
- package/Libraries/Core/RawEventEmitter.js +1 -1
- package/Libraries/Core/ReactNativeVersion.js +2 -2
- package/Libraries/Core/Timers/JSTimers.js +3 -2
- package/Libraries/Core/setUpDeveloperTools.js +1 -1
- package/Libraries/Core/setUpErrorHandling.js +4 -2
- package/Libraries/Core/setUpReactDevTools.js +23 -6
- package/Libraries/Core/setUpSegmentFetcher.js +1 -1
- package/Libraries/Debugging/DebuggingOverlay.js +2 -2
- package/Libraries/EventEmitter/NativeEventEmitter.js +7 -9
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +1 -1
- package/Libraries/FBLazyVector/FBLazyVector/FBLazyIterator.h +0 -6
- package/Libraries/Image/AssetSourceResolver.js +1 -1
- package/Libraries/Image/Image.android.js +172 -306
- package/Libraries/Image/ImageProps.js +9 -11
- package/Libraries/Image/ImageSource.js +2 -2
- package/Libraries/Image/ImageSourceUtils.js +8 -4
- package/Libraries/Image/ImageTypes.flow.js +2 -2
- package/Libraries/Image/ImageViewNativeComponent.js +7 -16
- package/Libraries/Image/RCTImageUtils.mm +37 -1
- package/Libraries/Image/nativeImageSource.js +1 -1
- package/Libraries/Interaction/InteractionManager.js +5 -4
- package/Libraries/Interaction/PanResponder.js +1 -1
- package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -2
- package/Libraries/Linking/Linking.js +1 -1
- package/Libraries/Lists/FlatList.js +3 -3
- package/Libraries/Lists/SectionList.js +1 -1
- package/Libraries/Lists/SectionListModern.js +2 -2
- package/Libraries/LogBox/Data/LogBoxData.js +38 -24
- package/Libraries/LogBox/Data/LogBoxLog.js +43 -112
- package/Libraries/LogBox/Data/parseLogBoxLog.js +21 -117
- package/Libraries/LogBox/LogBox.js +42 -19
- package/Libraries/LogBox/LogBoxInspectorContainer.js +2 -2
- package/Libraries/LogBox/LogBoxNotificationContainer.js +2 -2
- package/Libraries/LogBox/UI/LogBoxButton.js +28 -30
- package/Libraries/LogBox/UI/LogBoxInspector.js +2 -2
- package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.js +6 -9
- package/Libraries/LogBox/UI/LogBoxInspectorFooter.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspectorFooterButton.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspectorHeader.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspectorHeaderButton.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspectorMessageHeader.js +10 -15
- package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.js +25 -18
- package/Libraries/LogBox/UI/LogBoxInspectorSection.js +5 -7
- package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +8 -10
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +8 -6
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrames.js +17 -29
- package/Libraries/LogBox/UI/LogBoxMessage.js +28 -37
- package/Libraries/LogBox/UI/LogBoxNotification.js +1 -1
- package/Libraries/Modal/Modal.js +3 -3
- package/Libraries/NativeComponent/BaseViewConfig.android.js +28 -52
- package/Libraries/NativeComponent/BaseViewConfig.ios.js +19 -21
- package/Libraries/NativeComponent/TVViewConfig.js +1 -0
- package/Libraries/Network/RCTHTTPRequestHandler.h +9 -0
- package/Libraries/Network/RCTHTTPRequestHandler.mm +15 -1
- package/Libraries/Network/RCTNetworking.android.js +1 -1
- package/Libraries/Network/RCTNetworking.ios.js +1 -1
- package/Libraries/Network/RCTNetworking.js.flow +1 -1
- package/Libraries/Network/RCTNetworkingEventDefinitions.flow.js +1 -1
- package/Libraries/Network/XMLHttpRequest.js +1 -1
- package/Libraries/PermissionsAndroid/PermissionsAndroid.js +3 -3
- package/Libraries/Pressability/Pressability.js +12 -5
- package/Libraries/Pressability/PressabilityDebug.js +1 -1
- package/Libraries/Pressability/PressabilityPerformanceEventEmitter.js +1 -1
- package/Libraries/Pressability/usePressability.js +3 -14
- package/Libraries/PushNotificationIOS/PushNotificationIOS.js +2 -2
- package/Libraries/PushNotificationIOS/RCTPushNotificationManager.mm +11 -21
- package/Libraries/ReactNative/AppContainer-dev.js +18 -1
- package/Libraries/ReactNative/AppContainer.js +1 -1
- package/Libraries/ReactNative/AppRegistry.flow.js +2 -2
- package/Libraries/ReactNative/AppRegistryImpl.js +2 -2
- package/Libraries/ReactNative/FabricUIManager.js +1 -1
- package/Libraries/ReactNative/RendererImplementation.js +4 -4
- package/Libraries/ReactNative/UIManagerProperties.js +1 -1
- package/Libraries/Renderer/implementations/ReactNativeRenderer-dev.js +3 -2
- package/Libraries/Renderer/implementations/ReactNativeRenderer-prod.js +3 -2
- package/Libraries/Renderer/implementations/ReactNativeRenderer-profiling.js +3 -2
- package/Libraries/Renderer/shims/ReactFabric.js +1 -3
- package/Libraries/Renderer/shims/ReactFeatureFlags.js +1 -3
- package/Libraries/Renderer/shims/ReactNative.js +3 -2
- package/Libraries/Renderer/shims/ReactNativeTypes.js +1 -3
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +1 -3
- package/Libraries/Renderer/shims/createReactNativeComponentClass.js +1 -3
- package/Libraries/StyleSheet/PointPropType.js +1 -1
- package/Libraries/StyleSheet/Rect.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.d.ts +0 -5
- package/Libraries/StyleSheet/StyleSheet.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.js.flow +1 -1
- package/Libraries/StyleSheet/StyleSheetExports.js +16 -25
- package/Libraries/StyleSheet/StyleSheetExports.js.flow +2 -7
- package/Libraries/StyleSheet/StyleSheetTypes.js +33 -36
- package/Libraries/StyleSheet/private/_StyleSheetTypesOverrides.js +5 -5
- package/Libraries/StyleSheet/private/_TransformStyle.js +7 -7
- package/Libraries/StyleSheet/processBackgroundImage.js +7 -7
- package/Libraries/StyleSheet/processBackgroundPosition.js +4 -4
- package/Libraries/StyleSheet/processBackgroundRepeat.js +4 -4
- package/Libraries/StyleSheet/processBackgroundSize.js +4 -4
- package/Libraries/StyleSheet/processBoxShadow.js +44 -4
- package/Libraries/StyleSheet/processColorArray.js +2 -2
- package/Libraries/StyleSheet/processFilter.js +2 -2
- package/Libraries/Text/Text/RCTDynamicTypeRamp.mm +5 -4
- package/Libraries/Text/Text.js +295 -627
- package/Libraries/Text/TextInput/Multiline/RCTUITextView.mm +7 -1
- package/Libraries/Text/TextInput/RCTBackedTextInputDelegateAdapter.mm +14 -12
- package/Libraries/Text/TextInput/Singleline/RCTUITextField.mm +1 -1
- package/Libraries/Text/TextNativeComponent.js +14 -7
- package/Libraries/Text/TextProps.js +4 -4
- package/Libraries/Types/CodegenTypes.js +1 -1
- package/Libraries/Types/CoreEventTypes.js +21 -21
- package/Libraries/Types/ReactDevToolsTypes.js +2 -2
- package/Libraries/Utilities/Appearance.js +6 -1
- package/Libraries/Utilities/Dimensions.js +1 -1
- package/Libraries/Utilities/HMRClient.js +4 -4
- package/Libraries/Utilities/IPerformanceLogger.js +4 -4
- package/Libraries/Utilities/codegenNativeCommands.js +4 -4
- package/Libraries/Utilities/codegenNativeComponent.d.ts +2 -0
- package/Libraries/Utilities/codegenNativeComponent.js +2 -2
- package/Libraries/Utilities/logError.js +1 -1
- package/Libraries/Utilities/stringifySafe.js +3 -3
- package/Libraries/Utilities/useMergeRefs.js +2 -2
- package/Libraries/WebSocket/RCTReconnectingWebSocket.m +4 -1
- package/Libraries/vendor/core/ErrorUtils.js +4 -4
- package/Libraries/vendor/emitter/EventEmitter.js +16 -20
- package/README.md +52 -0
- package/React/Base/RCTBridge.mm +1 -1
- package/React/Base/RCTBundleURLProvider.mm +29 -8
- package/React/Base/RCTConvert.mm +3 -18
- package/React/Base/RCTDefines.h +7 -8
- package/React/Base/RCTDevSupportHttpHeaders.h +24 -0
- package/React/Base/RCTDevSupportHttpHeaders.m +65 -0
- package/React/Base/RCTJavaScriptLoader.h +1 -0
- package/React/Base/RCTJavaScriptLoader.mm +6 -2
- package/React/Base/RCTMultipartDataTask.h +9 -0
- package/React/Base/RCTMultipartDataTask.m +19 -1
- package/React/Base/RCTTVColorSupport.h +17 -0
- package/React/Base/RCTTVColorSupport.mm +23 -0
- package/React/Base/RCTUtils.mm +15 -6
- package/React/Base/RCTVersion.m +2 -2
- package/React/CoreModules/RCTActionSheetManager.mm +28 -3
- package/React/CoreModules/RCTClipboard.mm +5 -5
- package/React/CoreModules/RCTDevLoadingView.mm +1 -1
- package/React/CoreModules/RCTDevSettings.mm +8 -0
- package/React/CoreModules/RCTDeviceInfo.mm +4 -3
- package/React/CoreModules/RCTKeyboardObserver.mm +9 -2
- package/React/CoreModules/RCTLogBoxView.mm +4 -8
- package/React/CoreModules/RCTPerfMonitor.mm +5 -0
- package/React/CoreModules/RCTStatusBarManager.h +2 -0
- package/React/CoreModules/RCTWebSocketModule.h +6 -0
- package/React/CoreModules/RCTWebSocketModule.mm +14 -1
- package/React/DevSupport/RCTInspectorDevServerHelper.mm +33 -22
- package/React/DevSupport/RCTInspectorNetworkHelper.mm +2 -0
- package/React/FBReactNativeSpec/FBReactNativeSpecJSI.h +66 -79
- package/React/FBReactNativeSpec/react/renderer/components/FBReactNativeSpec/Props.cpp +8 -8
- package/React/FBReactNativeSpec/react/renderer/components/FBReactNativeSpec/Props.h +1 -1
- package/React/Fabric/Mounting/ComponentViews/Image/RCTImageComponentView.mm +2 -2
- package/React/Fabric/Mounting/ComponentViews/InputAccessory/RCTInputAccessoryComponentView.mm +4 -0
- package/React/Fabric/Mounting/ComponentViews/Modal/RCTFabricModalHostViewController.mm +6 -0
- package/React/Fabric/Mounting/ComponentViews/Modal/RCTModalHostViewComponentView.mm +8 -4
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTEnhancedScrollView.h +2 -0
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTEnhancedScrollView.mm +81 -0
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTPullToRefreshViewComponentView.mm +16 -4
- package/React/Fabric/Mounting/ComponentViews/ScrollView/RCTScrollViewComponentView.mm +145 -8
- package/React/Fabric/Mounting/ComponentViews/Switch/RCTSwitchComponentView.mm +10 -5
- package/React/Fabric/Mounting/ComponentViews/Text/RCTParagraphComponentView.mm +13 -0
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputComponentView.mm +9 -13
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputUtils.h +2 -0
- package/React/Fabric/Mounting/ComponentViews/TextInput/RCTTextInputUtils.mm +2 -0
- package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.h +2 -0
- package/React/Fabric/Mounting/ComponentViews/View/RCTViewComponentView.mm +42 -4
- package/React/Fabric/Mounting/ComponentViews/VirtualView/RCTVirtualViewComponentView.h +2 -1
- package/React/Fabric/Mounting/ComponentViews/VirtualView/RCTVirtualViewComponentView.mm +92 -163
- package/React/Fabric/Mounting/RCTMountingManager.mm +8 -3
- package/React/Fabric/RCTScheduler.h +2 -0
- package/React/Fabric/RCTScheduler.mm +57 -0
- package/React/Fabric/RCTSurfacePointerHandler.mm +15 -9
- package/React/Fabric/RCTSurfacePresenter.mm +9 -0
- package/React/Fabric/RCTSurfaceTouchHandler.mm +4 -2
- package/React/Fabric/Surface/RCTFabricSurface.mm +4 -0
- package/React/Fabric/Utils/RCTLinearGradient.mm +4 -9
- package/React/Inspector/RCTCxxInspectorWebSocketAdapter.mm +5 -1
- package/React/Modules/RCTLayoutAnimation.m +10 -0
- package/React/Modules/RCTUIManager.mm +2 -4
- package/React/Profiler/RCTProfile.m +2 -0
- package/React/React-RCTFabric.podspec +3 -0
- package/React/Views/RCTView.m +6 -1
- package/React/Views/ScrollView/RCTScrollViewManager.m +1 -0
- package/React-Core-prebuilt.podspec +1 -1
- package/ReactAndroid/api/ReactAndroid.api +120 -298
- package/ReactAndroid/build.gradle.kts +9 -0
- package/ReactAndroid/gradle.properties +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManager.java +11 -101
- package/ReactAndroid/src/main/java/com/facebook/react/ReactInstanceManagerBuilder.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/ReactRootView.java +10 -10
- package/ReactAndroid/src/main/java/com/facebook/react/animated/AnimationDriver.kt +1 -3
- package/ReactAndroid/src/main/java/com/facebook/react/animated/ColorAnimatedNode.kt +11 -11
- package/ReactAndroid/src/main/java/com/facebook/react/animated/DiffClampAnimatedNode.kt +11 -11
- package/ReactAndroid/src/main/java/com/facebook/react/animated/EventAnimationDriver.kt +0 -26
- package/ReactAndroid/src/main/java/com/facebook/react/animated/InterpolationAnimatedNode.kt +12 -0
- package/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedModule.kt +11 -1
- package/ReactAndroid/src/main/java/com/facebook/react/animated/NativeAnimatedNodesManager.kt +5 -5
- package/ReactAndroid/src/main/java/com/facebook/react/animated/PropsAnimatedNode.kt +5 -5
- package/ReactAndroid/src/main/java/com/facebook/react/animated/SpringAnimation.kt +19 -19
- package/ReactAndroid/src/main/java/com/facebook/react/animated/TrackingAnimatedNode.kt +5 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/DynamicFromArray.kt +9 -4
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JavaMethodWrapper.kt +15 -15
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/JavaOnlyMap.kt +8 -6
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/NativeModuleRegistry.kt +3 -1
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ReactContext.java +10 -0
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/ScrollEndedListener.kt +70 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/assets/ReactFontManager.kt +4 -0
- package/ReactAndroid/src/main/java/com/facebook/react/common/mapbuffer/ReadableMapBuffer.kt +4 -4
- package/ReactAndroid/src/main/java/com/facebook/react/defaults/DefaultReactHost.kt +36 -34
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/BundleDownloader.kt +14 -9
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/CxxInspectorPackagerConnection.kt +2 -8
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DefaultDevLoadingViewImplementation.kt +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevServerHelper.kt +17 -13
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/DevSupportManagerBase.kt +5 -5
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/PackagerStatusCheck.kt +10 -19
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/RedBoxContentView.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/DevSupportHttpClient.kt +74 -0
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/FrameTimingSequence.kt +2 -3
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/FrameTimingsObserver.kt +110 -80
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/inspector/InspectorNetworkHelper.kt +1 -12
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/DevBundleDownloadListener.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/devsupport/interfaces/DevLoadingViewManager.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/AnimationBackendChoreographer.kt +87 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManager.java +36 -7
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManagerBinding.kt +16 -2
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/FabricUIManagerProviderImpl.kt +3 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/LongStreamingStats.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/SurfaceHandlerBinding.kt +6 -6
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/EventBeatManager.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/events/FabricEventEmitter.kt +0 -29
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/MountingManager.kt +2 -8
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/SurfaceMountingManager.kt +1258 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/FabricNameComponentMapping.kt +1 -0
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/IntBufferBatchMountItem.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/MountItemFactory.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/mountitems/PreAllocateViewMountItem.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlags.kt +37 -55
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxAccessor.kt +66 -96
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsCxxInterop.kt +14 -20
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsDefaults.kt +15 -21
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsLocalAccessor.kt +74 -107
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsOverrides_RNOSS_Experimental_Android.kt +5 -1
- package/ReactAndroid/src/main/java/com/facebook/react/internal/featureflags/ReactNativeFeatureFlagsProvider.kt +14 -20
- package/ReactAndroid/src/main/java/com/facebook/react/internal/interop/InteropEventEmitter.kt +1 -15
- package/ReactAndroid/src/main/java/com/facebook/react/internal/turbomodule/core/TurboModuleManager.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/accessibilityinfo/AccessibilityInfoModule.kt +4 -10
- package/ReactAndroid/src/main/java/com/facebook/react/modules/blob/BlobModule.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/core/JavaTimerManager.kt +4 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/i18nmanager/I18nManagerModule.kt +4 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkEventUtil.kt +45 -74
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/NetworkingModule.kt +17 -13
- package/ReactAndroid/src/main/java/com/facebook/react/modules/network/ProgressRequestBody.kt +2 -5
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/AndroidInfoHelpers.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/modules/systeminfo/ReactNativeVersion.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/modules/websocket/WebSocketModule.kt +3 -4
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/JSPackagerClient.kt +2 -1
- package/ReactAndroid/src/main/java/com/facebook/react/packagerconnection/ReconnectingWebSocket.kt +2 -8
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessAtomicRef.kt +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessCatalystInstance.kt +9 -3
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/BridgelessReactContext.kt +8 -8
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostImpl.kt +12 -12
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactHostInspectorTarget.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactInstance.kt +13 -7
- package/ReactAndroid/src/main/java/com/facebook/react/runtime/ReactSurfaceView.kt +14 -14
- package/ReactAndroid/src/main/java/com/facebook/react/shell/MainReactPackage.kt +14 -6
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BackgroundStyleApplicator.kt +42 -28
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/BaseViewManager.java +8 -49
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/DisplayMetricsHolder.kt +11 -8
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/GuardedFrameCallback.kt +17 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/JSPointerDispatcher.java +13 -8
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/LayoutShadowNode.kt +751 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyManager.java +104 -781
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyOptimizer.kt +18 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactShadowNode.java +7 -9
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactShadowNodeImpl.java +7 -31
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ReactZIndexedViewGroup.kt +11 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ThemedReactContext.kt +4 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/TouchTargetHelper.kt +1 -4
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIImplementation.java +103 -759
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerHelper.kt +14 -38
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIManagerModule.java +41 -170
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/UIViewOperationQueue.java +33 -962
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/ViewGroupDrawingOrderHelper.kt +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/common/UIManagerType.kt +22 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/common/ViewUtil.kt +15 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/FabricEventDispatcher.kt +1 -6
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTEventEmitter.kt +2 -9
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/RCTModernEventEmitter.kt +12 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchEvent.kt +1 -16
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/TouchesHelper.kt +0 -33
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BackgroundImageLayer.kt +27 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BackgroundPosition.kt +20 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BackgroundRepeat.kt +27 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BackgroundSize.kt +50 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BorderColors.kt +33 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BorderInsets.kt +25 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BorderRadiusStyle.kt +46 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BorderStyle.kt +14 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/BoxShadow.kt +23 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/ColorStop.kt +45 -7
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/ComputedBorderRadius.kt +40 -2
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/CornerRadii.kt +21 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/Gradient.kt +16 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/LinearGradient.kt +34 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/LogicalEdge.kt +33 -1
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/OutlineStyle.kt +17 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/Overflow.kt +15 -0
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/style/RadialGradient.kt +42 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/common/UiModeUtils.kt +20 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/drawer/ReactDrawerLayoutManager.kt +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/image/ReactImageView.kt +9 -10
- package/ReactAndroid/src/main/java/com/facebook/react/views/modal/ReactModalHostManager.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ReactProgressBarViewManager.kt +6 -5
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollView.java +132 -16
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactHorizontalScrollViewManager.kt +17 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactNestedScrollView.java +1647 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactNestedScrollViewManager.kt +466 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollView.java +104 -10
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewHelper.kt +71 -9
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/ReactScrollViewManager.kt +17 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/VirtualViewContainer.kt +2 -35
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/VirtualViewContainerStateClassic.kt +7 -30
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/VirtualViewContainerStateExperimental.kt +20 -41
- package/ReactAndroid/src/main/java/com/facebook/react/views/scroll/generate-nested-scroll-view.js +270 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/swiperefresh/ReactSwipeRefreshLayout.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/swiperefresh/SwipeRefreshLayoutManager.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitchManager.kt +7 -7
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/PreparedLayout.kt +2 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/PreparedLayoutTextView.kt +39 -17
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/PreparedLayoutTextViewManager.kt +4 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextUpdate.kt +4 -65
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextView.java +86 -111
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextViewAccessibilityDelegate.kt +6 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextViewManager.kt +243 -20
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTypefaceUtils.kt +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/SelectableTextViewManager.kt +29 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextAttributeProps.kt +1 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/TextLayoutManager.kt +54 -77
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/span/DrawCommandSpan.kt +27 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/span/ReactClickableSpan.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/span/ReactLinkSpan.kt +10 -3
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactEditText.kt +2 -75
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextChangedEvent.kt +8 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextContentSizeWatcher.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputManager.kt +5 -38
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputTextWatcher.kt +3 -2
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextScrollWatcher.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextSelectionWatcher.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ImportantForInteractionHelper.kt +55 -0
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewGroup.kt +19 -60
- package/ReactAndroid/src/main/java/com/facebook/react/views/view/ReactViewManager.kt +7 -4
- package/ReactAndroid/src/main/java/com/facebook/react/views/virtual/view/ReactVirtualView.kt +150 -296
- package/ReactAndroid/src/main/java/com/facebook/react/views/virtual/view/ReactVirtualViewManager.kt +11 -13
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfig.kt +2 -2
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfigJNIBase.kt +64 -0
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfigJNIFinalizer.java +4 -4
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaDirection.kt +29 -0
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNative.kt +1 -1
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNode.kt +244 -0
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNodeJNIBase.java +1 -1
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaProps.kt +183 -0
- package/ReactAndroid/src/main/jni/CMakeLists.txt +6 -0
- package/ReactAndroid/src/main/jni/react/fabric/AndroidAnimationChoreographer.h +38 -0
- package/ReactAndroid/src/main/jni/react/fabric/CoreComponentsRegistry.cpp +4 -4
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.cpp +7 -0
- package/ReactAndroid/src/main/jni/react/fabric/FabricMountingManager.h +2 -0
- package/ReactAndroid/src/main/jni/react/fabric/FabricUIManagerBinding.cpp +50 -2
- package/ReactAndroid/src/main/jni/react/fabric/FabricUIManagerBinding.h +11 -0
- package/ReactAndroid/src/main/jni/react/fabric/JAnimationBackendChoreographer.cpp +23 -0
- package/ReactAndroid/src/main/jni/react/fabric/JAnimationBackendChoreographer.h +37 -0
- package/ReactAndroid/src/main/jni/react/fabric/StateWrapperImpl.h +2 -1
- package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.cpp +89 -131
- package/ReactAndroid/src/main/jni/react/featureflags/JReactNativeFeatureFlagsCxxInterop.h +19 -28
- package/ReactAndroid/src/main/jni/react/jni/CMakeLists.txt +0 -1
- package/ReactAndroid/src/main/jni/react/jni/JavaModuleWrapper.cpp +1 -1
- package/ReactAndroid/src/main/jni/react/jni/OnLoad.cpp +0 -7
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactHostInspectorTarget.cpp +24 -60
- package/ReactAndroid/src/main/jni/react/runtime/jni/JReactHostInspectorTarget.h +12 -28
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.cpp +13 -6
- package/ReactAndroid/src/main/jni/react/turbomodule/ReactCommon/TurboModuleManager.h +2 -1
- package/{ReactCommon/react/renderer/components/text/ParagraphComponentDescriptor.cpp → ReactAndroid/src/main/jni/react/uimanager/StateWrapper.h} +7 -2
- package/ReactAndroid/src/main/res/views/uimanager/values/ids.xml +3 -0
- package/ReactAndroid/src/main/res/views/uimanager/values-ne/strings.xml +2 -0
- package/ReactApple/RCTAnimatedModuleProvider/RCTAnimatedModuleProvider.mm +8 -1
- package/ReactApple/RCTSwiftUI/RCTSwiftUI.podspec +1 -1
- package/ReactApple/RCTSwiftUIWrapper/RCTSwiftUIWrapper.podspec +1 -2
- package/ReactCommon/React-Fabric.podspec +5 -6
- package/ReactCommon/React-FabricComponents.podspec +6 -8
- package/ReactCommon/cxxreact/ReactNativeVersion.h +8 -6
- package/ReactCommon/hermes/executor/HermesExecutorFactory.cpp +1 -1
- package/ReactCommon/hermes/inspector-modern/chrome/HermesRuntimeTargetDelegate.cpp +25 -16
- package/ReactCommon/hermes/inspector-modern/chrome/HermesRuntimeTargetDelegate.h +1 -1
- package/ReactCommon/jsinspector-modern/HostAgent.cpp +10 -30
- package/ReactCommon/jsinspector-modern/HostAgent.h +4 -11
- package/ReactCommon/jsinspector-modern/HostTarget.cpp +33 -33
- package/ReactCommon/jsinspector-modern/HostTarget.h +23 -24
- package/ReactCommon/jsinspector-modern/HostTargetTraceRecording.cpp +1 -2
- package/ReactCommon/jsinspector-modern/HostTargetTracing.h +89 -0
- package/ReactCommon/jsinspector-modern/InspectorInterfaces.cpp +4 -9
- package/ReactCommon/jsinspector-modern/InspectorInterfaces.h +0 -1
- package/ReactCommon/jsinspector-modern/InspectorPackagerConnection.cpp +164 -54
- package/ReactCommon/jsinspector-modern/InspectorPackagerConnectionImpl.h +39 -4
- package/ReactCommon/jsinspector-modern/NetworkIOAgent.cpp +12 -3
- package/ReactCommon/jsinspector-modern/NetworkIOAgent.h +13 -0
- package/ReactCommon/jsinspector-modern/RuntimeAgent.cpp +6 -0
- package/ReactCommon/jsinspector-modern/RuntimeTarget.cpp +34 -18
- package/ReactCommon/jsinspector-modern/RuntimeTarget.h +19 -0
- package/ReactCommon/jsinspector-modern/RuntimeTargetDebuggerSessionObserver.cpp +6 -95
- package/ReactCommon/jsinspector-modern/RuntimeTargetGlobalStateObserver.cpp +122 -0
- package/ReactCommon/jsinspector-modern/RuntimeTargetGlobalStateObserver.h +42 -0
- package/ReactCommon/jsinspector-modern/RuntimeTargetTracingStateObserver.cpp +27 -0
- package/ReactCommon/jsinspector-modern/RuntimeTargetTracingStateObserver.h +27 -0
- package/ReactCommon/jsinspector-modern/TracingAgent.cpp +7 -45
- package/ReactCommon/jsinspector-modern/TracingAgent.h +0 -11
- package/ReactCommon/jsinspector-modern/UniqueMonostate.h +0 -4
- package/ReactCommon/jsinspector-modern/WeakList.h +60 -1
- package/ReactCommon/jsinspector-modern/network/NetworkHandler.cpp +25 -21
- package/ReactCommon/jsinspector-modern/network/NetworkHandler.h +21 -15
- package/ReactCommon/jsinspector-modern/tests/GmockHelpers.h +1 -1
- package/ReactCommon/jsinspector-modern/tests/HostTargetTest.cpp +3 -3
- package/ReactCommon/jsinspector-modern/tests/InspectorPackagerConnectionMultiSessionTest.cpp +692 -0
- package/ReactCommon/jsinspector-modern/tests/InspectorPackagerConnectionTest.cpp +10 -123
- package/ReactCommon/jsinspector-modern/tests/InspectorPackagerConnectionTest.h +140 -0
- package/ReactCommon/jsinspector-modern/tests/JsiIntegrationTest.cpp +158 -6
- package/ReactCommon/jsinspector-modern/tests/NetworkReporterTest.cpp +34 -0
- package/ReactCommon/jsinspector-modern/tests/TracingTest.cpp +223 -4
- package/ReactCommon/jsinspector-modern/tests/WeakListTest.cpp +31 -1
- package/ReactCommon/jsinspector-modern/tests/engines/JsiIntegrationTestHermesEngineAdapter.cpp +1 -1
- package/ReactCommon/jsinspector-modern/tracing/FrameTimingSequence.h +6 -9
- package/ReactCommon/jsinspector-modern/tracing/HostTracingProfileSerializer.cpp +4 -6
- package/ReactCommon/jsinspector-modern/tracing/TraceEventGenerator.cpp +6 -17
- package/ReactCommon/jsinspector-modern/tracing/TraceEventGenerator.h +4 -5
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.cpp +27 -39
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlags.h +32 -47
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.cpp +153 -207
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsAccessor.h +18 -24
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDefaults.h +26 -38
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsDynamicProvider.h +56 -83
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsOverridesOSSExperimental.h +9 -1
- package/ReactCommon/react/featureflags/ReactNativeFeatureFlagsProvider.h +9 -12
- package/ReactCommon/react/nativemodule/core/platform/ios/ReactCommon/RCTTurboModule.mm +3 -1
- package/ReactCommon/react/nativemodule/defaults/CMakeLists.txt +1 -0
- package/ReactCommon/react/nativemodule/defaults/DefaultTurboModules.cpp +10 -4
- package/ReactCommon/react/nativemodule/defaults/React-defaultsnativemodule.podspec +1 -0
- package/ReactCommon/react/nativemodule/fantomtestspecificmethods/NativeFantomTestSpecificMethods.cpp +32 -0
- package/ReactCommon/react/nativemodule/fantomtestspecificmethods/NativeFantomTestSpecificMethods.h +2 -0
- package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.cpp +32 -47
- package/ReactCommon/react/nativemodule/featureflags/NativeReactNativeFeatureFlags.h +14 -20
- package/ReactCommon/react/renderer/animated/AnimatedModule.h +1 -1
- package/ReactCommon/react/renderer/animated/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManager.cpp +108 -151
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManager.h +16 -11
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManagerProvider.cpp +80 -86
- package/ReactCommon/react/renderer/animated/NativeAnimatedNodesManagerProvider.h +0 -1
- package/ReactCommon/react/renderer/animated/event_drivers/EventAnimationDriver.h +0 -1
- package/ReactCommon/react/renderer/animated/internal/AnimatedMountingOverrideDelegate.h +0 -2
- package/ReactCommon/react/renderer/animated/internal/NativeAnimatedAllowlist.h +2 -2
- package/ReactCommon/react/renderer/animated/nodes/PropsAnimatedNode.cpp +32 -4
- package/ReactCommon/react/renderer/animated/nodes/PropsAnimatedNode.h +6 -0
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropSerializer.cpp +14 -21
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropsRegistry.cpp +3 -1
- package/ReactCommon/react/renderer/animationbackend/AnimatedPropsRegistry.h +6 -3
- package/ReactCommon/react/renderer/animationbackend/AnimationBackend.cpp +125 -63
- package/ReactCommon/react/renderer/animationbackend/AnimationBackend.h +33 -33
- package/ReactCommon/react/renderer/animationbackend/AnimationBackendCommitHook.cpp +18 -8
- package/ReactCommon/react/renderer/animationbackend/AnimationBackendCommitHook.h +1 -1
- package/ReactCommon/react/renderer/animationbackend/AnimationChoreographer.h +39 -0
- package/ReactCommon/react/renderer/animationbackend/CMakeLists.txt +0 -1
- package/ReactCommon/react/renderer/animations/LayoutAnimationKeyFrameManager.cpp +1 -2
- package/ReactCommon/react/renderer/attributedstring/AttributedString.h +0 -1
- package/ReactCommon/react/renderer/attributedstring/AttributedStringBox.cpp +0 -6
- package/ReactCommon/react/renderer/attributedstring/AttributedStringBox.h +0 -1
- package/ReactCommon/react/renderer/attributedstring/ParagraphAttributes.cpp +0 -4
- package/ReactCommon/react/renderer/attributedstring/ParagraphAttributes.h +0 -1
- package/ReactCommon/react/renderer/attributedstring/conversions.h +60 -0
- package/ReactCommon/react/renderer/componentregistry/componentNameByReactViewName.cpp +3 -5
- package/ReactCommon/react/renderer/components/image/ImageProps.h +1 -1
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/{LegacyViewManagerInteropComponentDescriptor.mm → platform/ios/react/renderer/components/legacyviewmanagerinterop/LegacyViewManagerInteropComponentDescriptor.mm} +1 -1
- package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/{LegacyViewManagerInteropState.mm → platform/ios/react/renderer/components/legacyviewmanagerinterop/LegacyViewManagerInteropState.mm} +1 -1
- package/ReactCommon/react/renderer/components/root/RootShadowNode.cpp +1 -1
- package/ReactCommon/react/renderer/components/scrollview/BaseScrollViewProps.cpp +20 -0
- package/ReactCommon/react/renderer/components/scrollview/BaseScrollViewProps.h +2 -0
- package/ReactCommon/react/renderer/components/scrollview/ScrollViewState.h +1 -1
- package/ReactCommon/react/renderer/components/scrollview/conversions.h +6 -0
- package/ReactCommon/react/renderer/components/scrollview/platform/android/react/renderer/components/scrollview/HostPlatformScrollViewProps.cpp +18 -1
- package/ReactCommon/react/renderer/components/scrollview/platform/android/react/renderer/components/scrollview/HostPlatformScrollViewProps.h +2 -0
- package/ReactCommon/react/renderer/components/scrollview/primitives.h +2 -11
- package/ReactCommon/react/renderer/components/scrollview/tests/ScrollViewTest.cpp +83 -3
- package/ReactCommon/react/renderer/components/text/BaseParagraphComponentDescriptor.h +49 -0
- package/ReactCommon/react/renderer/components/text/BaseTextProps.cpp +14 -14
- package/ReactCommon/react/renderer/components/text/ParagraphComponentDescriptor.h +3 -28
- package/ReactCommon/react/renderer/components/text/ParagraphShadowNode.cpp +10 -10
- package/ReactCommon/react/renderer/components/text/ParagraphShadowNode.h +4 -4
- package/ReactCommon/react/renderer/components/text/SelectableParagraphComponentDescriptor.h +24 -0
- package/ReactCommon/react/renderer/components/text/SelectableParagraphShadowNode.h +32 -0
- package/ReactCommon/react/renderer/components/text/platform/android/react/renderer/components/text/HostPlatformParagraphProps.cpp +1 -1
- package/ReactCommon/react/renderer/components/text/platform/android/react/renderer/components/text/ParagraphState.cpp +1 -1
- package/ReactCommon/react/renderer/components/text/platform/android/react/renderer/components/text/ParagraphState.h +2 -2
- package/ReactCommon/react/renderer/components/textinput/BaseTextInputShadowNode.h +13 -1
- package/ReactCommon/react/renderer/components/textinput/TextInputEventEmitter.cpp +2 -1
- package/ReactCommon/react/renderer/components/view/AccessibilityPrimitives.h +2 -21
- package/ReactCommon/react/renderer/components/view/BackgroundImagePropsConversions.cpp +15 -24
- package/ReactCommon/react/renderer/components/view/BaseTouch.h +7 -7
- package/ReactCommon/react/renderer/components/view/BaseViewProps.cpp +11 -1
- package/ReactCommon/react/renderer/components/view/BaseViewProps.h +4 -0
- package/ReactCommon/react/renderer/components/view/ConcreteViewShadowNode.h +0 -3
- package/ReactCommon/react/renderer/components/view/FilterPropsConversions.h +57 -53
- package/ReactCommon/react/renderer/components/view/ViewShadowNode.cpp +1 -0
- package/ReactCommon/react/renderer/components/view/conversions.h +250 -2
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/HostPlatformViewProps.cpp +19 -63
- package/ReactCommon/react/renderer/components/view/platform/android/react/renderer/components/view/HostPlatformViewProps.h +1 -0
- package/ReactCommon/react/renderer/components/view/primitives.h +3 -86
- package/ReactCommon/react/renderer/components/view/tests/ConversionsTest.cpp +215 -0
- package/ReactCommon/react/renderer/components/view/tests/LayoutTest.cpp +1 -1
- package/ReactCommon/react/renderer/components/virtualview/VirtualViewComponentDescriptor.h +1 -1
- package/ReactCommon/react/renderer/core/ConcreteComponentDescriptor.h +1 -1
- package/ReactCommon/react/renderer/core/EventEmitter.cpp +2 -2
- package/ReactCommon/react/renderer/core/EventEmitter.h +8 -8
- package/ReactCommon/react/renderer/core/EventPipe.h +1 -1
- package/ReactCommon/react/renderer/core/EventTarget.cpp +3 -3
- package/ReactCommon/react/renderer/core/EventTarget.h +7 -7
- package/ReactCommon/react/renderer/core/LayoutConstraints.h +0 -5
- package/ReactCommon/react/renderer/core/LayoutContext.h +0 -5
- package/ReactCommon/react/renderer/core/LayoutMetrics.h +0 -2
- package/ReactCommon/react/renderer/core/RawPropsKey.cpp +11 -21
- package/ReactCommon/react/renderer/core/RawPropsKey.h +0 -1
- package/ReactCommon/react/renderer/core/RawPropsKeyMap.cpp +4 -1
- package/ReactCommon/react/renderer/core/RawPropsParser.cpp +1 -7
- package/ReactCommon/react/renderer/core/RawPropsParser.h +2 -6
- package/ReactCommon/react/renderer/core/RawValue.h +1 -2
- package/ReactCommon/react/renderer/core/ShadowNode.cpp +33 -31
- package/ReactCommon/react/renderer/core/ShadowNode.h +19 -29
- package/ReactCommon/react/renderer/core/ShadowNodeFamily.cpp +6 -6
- package/ReactCommon/react/renderer/core/ShadowNodeFamily.h +14 -14
- package/ReactCommon/react/renderer/core/ShadowNodeFragment.cpp +4 -2
- package/ReactCommon/react/renderer/core/ShadowNodeFragment.h +2 -2
- package/ReactCommon/react/renderer/core/tests/ShadowNodeTest.cpp +57 -2
- package/ReactCommon/react/renderer/css/CSSBackgroundImage.h +112 -140
- package/ReactCommon/react/renderer/css/CSSColor.h +7 -8
- package/ReactCommon/react/renderer/css/CSSColorFunction.h +38 -39
- package/ReactCommon/react/renderer/css/CSSCompoundDataType.h +23 -17
- package/ReactCommon/react/renderer/css/CSSDataType.h +15 -10
- package/ReactCommon/react/renderer/css/CSSFilter.h +12 -17
- package/ReactCommon/react/renderer/css/CSSKeyword.h +8 -0
- package/ReactCommon/react/renderer/css/CSSList.h +11 -11
- package/ReactCommon/react/renderer/css/CSSRatio.h +4 -4
- package/ReactCommon/react/renderer/css/CSSShadow.h +7 -7
- package/ReactCommon/react/renderer/css/CSSSyntaxParser.h +10 -6
- package/ReactCommon/react/renderer/css/CSSTokenizer.h +2 -0
- package/ReactCommon/react/renderer/css/CSSTransform.h +20 -20
- package/ReactCommon/react/renderer/css/CSSTransformOrigin.h +4 -5
- package/ReactCommon/react/renderer/css/CSSValueParser.h +71 -67
- package/ReactCommon/react/renderer/css/tests/CSSValueParserTest.cpp +11 -10
- package/ReactCommon/react/renderer/graphics/BackgroundPosition.h +0 -1
- package/ReactCommon/react/renderer/graphics/BackgroundRepeat.h +0 -1
- package/ReactCommon/react/renderer/graphics/BackgroundSize.h +0 -1
- package/ReactCommon/react/renderer/graphics/Filter.h +3 -2
- package/ReactCommon/react/renderer/graphics/LinearGradient.cpp +9 -15
- package/ReactCommon/react/renderer/graphics/LinearGradient.h +7 -19
- package/ReactCommon/react/renderer/graphics/Point.h +0 -2
- package/ReactCommon/react/renderer/graphics/RadialGradient.h +4 -35
- package/ReactCommon/react/renderer/graphics/React-graphics.podspec +1 -0
- package/ReactCommon/react/renderer/graphics/Rect.h +1 -9
- package/ReactCommon/react/renderer/graphics/RectangleCorners.h +1 -10
- package/ReactCommon/react/renderer/graphics/RectangleEdges.h +1 -10
- package/ReactCommon/react/renderer/graphics/Size.h +0 -5
- package/ReactCommon/react/renderer/graphics/Transform.cpp +0 -4
- package/ReactCommon/react/renderer/graphics/Transform.h +1 -13
- package/ReactCommon/react/renderer/graphics/TransformUtils.h +95 -0
- package/ReactCommon/react/renderer/graphics/ValueUnit.h +3 -11
- package/ReactCommon/react/renderer/graphics/fromRawValueShared.h +13 -1
- package/ReactCommon/react/renderer/imagemanager/ImageManager.h +0 -4
- package/ReactCommon/react/renderer/imagemanager/ImageResponseObserverCoordinator.cpp +11 -12
- package/ReactCommon/react/renderer/imagemanager/ImageResponseObserverCoordinator.h +4 -3
- package/ReactCommon/react/renderer/imagemanager/platform/android/react/renderer/imagemanager/ImageRequestParams.h +1 -36
- package/ReactCommon/react/renderer/imagemanager/platform/cxx/react/renderer/imagemanager/ImageRequestParams.h +1 -9
- package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/ImageRequestParams.h +1 -9
- package/ReactCommon/react/renderer/imagemanager/platform/ios/react/renderer/imagemanager/RCTSyncImageManager.mm +1 -1
- package/ReactCommon/react/renderer/imagemanager/primitives.h +0 -5
- package/ReactCommon/react/renderer/mapbuffer/MapBuffer.cpp +51 -30
- package/ReactCommon/react/renderer/mapbuffer/MapBuffer.h +2 -0
- package/ReactCommon/react/renderer/mounting/Differentiator.cpp +21 -38
- package/ReactCommon/react/renderer/mounting/ShadowTree.cpp +153 -18
- package/ReactCommon/react/renderer/mounting/ShadowTree.h +30 -6
- package/ReactCommon/react/renderer/mounting/ShadowTreeDelegate.h +11 -0
- package/ReactCommon/react/renderer/mounting/ShadowView.cpp +0 -4
- package/ReactCommon/react/renderer/mounting/ShadowView.h +0 -1
- package/ReactCommon/react/renderer/mounting/internal/DiffMap.h +170 -0
- package/ReactCommon/react/renderer/mounting/internal/ShadowViewNodePair.h +0 -5
- package/ReactCommon/react/renderer/mounting/internal/sliceChildShadowNodeViewPairs.h +3 -3
- package/ReactCommon/react/renderer/mounting/stubs/StubView.cpp +0 -4
- package/ReactCommon/react/renderer/mounting/stubs/StubView.h +0 -1
- package/ReactCommon/react/renderer/mounting/stubs/StubViewTree.cpp +0 -4
- package/ReactCommon/react/renderer/mounting/stubs/StubViewTree.h +0 -2
- package/ReactCommon/react/renderer/mounting/tests/StateReconciliationTest.cpp +6 -0
- package/ReactCommon/react/renderer/mounting/updateMountedFlag.cpp +12 -4
- package/ReactCommon/react/renderer/observers/intersection/IntersectionObserver.cpp +2 -1
- package/ReactCommon/react/renderer/observers/intersection/IntersectionObserverState.cpp +0 -5
- package/ReactCommon/react/renderer/observers/intersection/IntersectionObserverState.h +0 -1
- package/ReactCommon/react/renderer/runtimescheduler/tests/RuntimeSchedulerTest.cpp +1 -1
- package/ReactCommon/react/renderer/scheduler/CMakeLists.txt +1 -0
- package/ReactCommon/react/renderer/scheduler/Scheduler.cpp +28 -1
- package/ReactCommon/react/renderer/scheduler/Scheduler.h +2 -2
- package/ReactCommon/react/renderer/scheduler/SchedulerDelegate.h +6 -0
- package/ReactCommon/react/renderer/scheduler/SchedulerToolbox.h +7 -0
- package/ReactCommon/react/renderer/scheduler/SurfaceHandler.cpp +2 -2
- package/ReactCommon/react/renderer/textlayoutmanager/TextLayoutManagerExtended.h +18 -18
- package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.cpp +8 -7
- package/ReactCommon/react/renderer/textlayoutmanager/platform/android/react/renderer/textlayoutmanager/TextLayoutManager.h +5 -5
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTAttributedTextUtils.h +3 -3
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTAttributedTextUtils.mm +4 -3
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTTextLayoutManager.h +1 -1
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTTextLayoutManager.mm +15 -5
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/RCTTextPrimitivesConversions.h +2 -2
- package/ReactCommon/react/renderer/textlayoutmanager/platform/ios/react/renderer/textlayoutmanager/TextLayoutManager.mm +10 -1
- package/ReactCommon/react/renderer/uimanager/PointerEventsProcessor.cpp +1 -1
- package/ReactCommon/react/renderer/uimanager/PointerEventsProcessor.h +1 -3
- package/ReactCommon/react/renderer/uimanager/PointerHoverTracker.cpp +1 -1
- package/ReactCommon/react/renderer/uimanager/UIManager.cpp +68 -38
- package/ReactCommon/react/renderer/uimanager/UIManager.h +17 -8
- package/ReactCommon/react/renderer/uimanager/UIManagerAnimationBackend.h +17 -5
- package/ReactCommon/react/renderer/uimanager/UIManagerBinding.cpp +2 -2
- package/ReactCommon/react/renderer/uimanager/UIManagerBinding.h +2 -2
- package/ReactCommon/react/renderer/uimanager/UIManagerDelegate.h +10 -0
- package/ReactCommon/react/renderer/uimanager/consistency/LazyShadowTreeRevisionConsistencyManager.cpp +19 -23
- package/ReactCommon/react/renderer/uimanager/consistency/LazyShadowTreeRevisionConsistencyManager.h +2 -3
- package/ReactCommon/react/renderer/uimanager/consistency/tests/LazyShadowTreeRevisionConsistencyManagerTest.cpp +13 -5
- package/ReactCommon/react/renderer/uimanager/primitives.h +16 -7
- package/ReactCommon/react/renderer/uimanager/tests/FindShadowNodeByTagTest.cpp +287 -0
- package/ReactCommon/react/runtime/TimerManager.cpp +16 -2
- package/ReactCommon/react/runtime/hermes/HermesInstance.cpp +11 -6
- package/ReactCommon/react/runtime/iostests/RCTHostTests.mm +11 -0
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.h +17 -3
- package/ReactCommon/react/runtime/platform/ios/ReactCommon/RCTHost.mm +8 -1
- package/ReactCommon/react/test_utils/shadowTreeGeneration.h +8 -5
- package/ReactCommon/react/utils/ContextContainer.h +0 -2
- package/ReactCommon/yoga/yoga/YGNode.cpp +14 -0
- package/ReactCommon/yoga/yoga/YGValue.h +0 -4
- package/ReactCommon/yoga/yoga/algorithm/CalculateLayout.cpp +7 -7
- package/ReactCommon/yoga/yoga/enums/YogaEnums.h +0 -1
- package/ReactCommon/yoga/yoga/node/LayoutResults.h +0 -3
- package/ReactCommon/yoga/yoga/numeric/FloatOptional.h +0 -9
- package/ReactCommon/yoga/yoga/style/Style.h +0 -4
- package/flow/bom.js.flow +18 -17
- package/flow/dom.js.flow +12 -5
- package/flow/global.js +1 -1
- package/gradle/libs.versions.toml +1 -1
- package/index.js +9 -0
- package/index.js.flow +8 -1
- package/jest-preset.js +14 -18
- package/package.json +17 -17
- package/scripts/cocoapods/rncore.rb +111 -2
- package/scripts/cocoapods/utils.rb +2 -0
- package/scripts/codegen/templates/Package.swift.template +7 -0
- package/scripts/react_native_pods.rb +13 -6
- package/scripts/replace-rncore-version.js +12 -3
- package/sdks/.hermesv1version +1 -1
- package/sdks/.hermesversion +1 -1
- package/sdks/hermes-engine/version.properties +2 -2
- package/src/private/animated/NativeAnimatedHelper.js +2 -2
- package/src/private/animated/createAnimatedPropsMemoHook.js +19 -19
- package/src/private/components/virtualview/VirtualView.js +14 -21
- package/src/private/components/virtualview/VirtualViewExperimentalNativeComponent.js +11 -10
- package/src/private/components/virtualview/VirtualViewNativeComponent.js +4 -4
- package/src/private/devsupport/devmenu/elementinspector/BorderBox.js +2 -2
- package/src/private/devsupport/devmenu/elementinspector/BoxInspector.js +3 -3
- package/src/private/devsupport/devmenu/elementinspector/ElementBox.js +4 -4
- package/src/private/devsupport/devmenu/elementinspector/ElementProperties.js +1 -1
- package/src/private/devsupport/devmenu/elementinspector/Inspector.js +39 -17
- package/src/private/devsupport/devmenu/elementinspector/InspectorOverlay.js +15 -3
- package/src/private/devsupport/devmenu/elementinspector/InspectorPanel.js +2 -2
- package/src/private/devsupport/devmenu/elementinspector/ReactDevToolsOverlay.js +2 -8
- package/src/private/devsupport/devmenu/elementinspector/StyleInspector.js +1 -1
- package/src/private/devsupport/devmenu/elementinspector/resolveBoxStyle.js +1 -1
- package/src/private/devsupport/devmenu/elementinspector/useExternalInspection.js +102 -0
- package/src/private/devsupport/rndevtools/FuseboxSessionObserver.js +12 -25
- package/src/private/devsupport/rndevtools/GlobalStateObserver.js +56 -0
- package/src/private/devsupport/rndevtools/TracingStateObserver.js +28 -0
- package/src/private/featureflags/ReactNativeFeatureFlags.js +49 -82
- package/src/private/featureflags/ReactNativeFeatureFlagsBase.js +2 -2
- package/src/private/featureflags/specs/NativeReactNativeFeatureFlags.js +9 -12
- package/src/private/specs_DEPRECATED/components/ActivityIndicatorViewNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/components/AndroidDrawerLayoutNativeComponent.js +3 -3
- package/src/private/specs_DEPRECATED/components/AndroidHorizontalScrollContentViewNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/components/AndroidSwipeRefreshLayoutNativeComponent.js +2 -2
- package/src/private/specs_DEPRECATED/components/AndroidSwitchNativeComponent.js +2 -2
- package/src/private/specs_DEPRECATED/components/DebuggingOverlayNativeComponent.js +3 -3
- package/src/private/specs_DEPRECATED/components/ProgressBarAndroidNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/components/PullToRefreshViewNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/components/RCTInputAccessoryViewNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/components/RCTModalHostViewNativeComponent.js +3 -3
- package/src/private/specs_DEPRECATED/components/RCTSafeAreaViewNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/components/SwitchNativeComponent.js +2 -2
- package/src/private/specs_DEPRECATED/components/UnimplementedNativeViewNativeComponent.js +1 -1
- package/src/private/specs_DEPRECATED/modules/NativeImageLoaderIOS.js +1 -1
- package/src/private/styles/composeStyles.js +1 -1
- package/src/private/utilities/toError.js +27 -0
- package/src/private/utilities/toExtendedError.js +30 -0
- package/src/private/webapis/dom/events/Event.js +1 -1
- package/src/private/webapis/dom/events/EventHandlerAttributes.js +2 -2
- package/src/private/webapis/dom/events/EventTarget.js +3 -3
- package/src/private/webapis/dom/events/internals/EventInternals.js +2 -2
- package/src/private/webapis/dom/nodes/ReadOnlyElement.js +1 -1
- package/src/private/webapis/dom/nodes/ReadOnlyNode.js +2 -2
- package/src/private/webapis/dom/nodes/specs/NativeDOM.js +14 -14
- package/src/private/webapis/dom/oldstylecollections/HTMLCollection.js +2 -2
- package/src/private/webapis/dom/oldstylecollections/HTMLCollection.js.flow +1 -1
- package/src/private/webapis/dom/oldstylecollections/NodeList.js +2 -2
- package/src/private/webapis/dom/oldstylecollections/NodeList.js.flow +1 -1
- package/src/private/webapis/geometry/DOMRectList.js +2 -2
- package/src/private/webapis/geometry/DOMRectList.js.flow +1 -1
- package/src/private/webapis/intersectionobserver/IntersectionObserver.js +8 -8
- package/src/private/webapis/intersectionobserver/specs/NativeIntersectionObserver.js +6 -6
- package/src/private/webapis/mutationobserver/MutationObserver.js +2 -2
- package/src/private/webapis/mutationobserver/MutationRecord.js +2 -2
- package/src/private/webapis/mutationobserver/internals/MutationObserverManager.js +1 -1
- package/src/private/webapis/mutationobserver/specs/NativeMutationObserver.js +3 -3
- package/src/private/webapis/performance/LongTasks.js +3 -3
- package/src/private/webapis/performance/Performance.js +4 -4
- package/src/private/webapis/performance/PerformanceEntry.js +1 -1
- package/src/private/webapis/performance/PerformanceObserver.js +2 -2
- package/src/private/webapis/performance/specs/NativePerformance.js +8 -8
- package/src/private/webapis/structuredClone/structuredClone.js +2 -2
- package/src/types/globals.d.ts +4 -4
- package/third-party-podspecs/RCT-Folly.podspec +1 -1
- package/third-party-podspecs/fmt.podspec +2 -2
- package/types/index.d.ts +2 -0
- package/types/public/ReactNativeTVTypes.d.ts +27 -2
- package/Libraries/Components/View/ReactNativeViewAttributes.js +0 -60
- package/Libraries/Image/TextInlineImageNativeComponent.js +0 -49
- package/React/Fabric/Mounting/ComponentViews/VirtualViewExperimental/RCTVirtualViewExperimentalComponentView.h +0 -25
- package/React/Fabric/Mounting/ComponentViews/VirtualViewExperimental/RCTVirtualViewExperimentalComponentView.mm +0 -321
- package/ReactAndroid/src/main/java/com/facebook/react/bridge/CatalystInstanceImpl.java +0 -620
- package/ReactAndroid/src/main/java/com/facebook/react/fabric/mounting/SurfaceMountingManager.java +0 -1411
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/LayoutShadowNode.java +0 -985
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/NativeViewHierarchyOptimizer.java +0 -403
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventDispatcherImpl.kt +0 -336
- package/ReactAndroid/src/main/java/com/facebook/react/uimanager/events/EventEmitterImpl.kt +0 -135
- package/ReactAndroid/src/main/java/com/facebook/react/views/progressbar/ProgressBarShadowNode.kt +0 -81
- package/ReactAndroid/src/main/java/com/facebook/react/views/switchview/ReactSwitchShadowNode.kt +0 -72
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactBaseTextShadowNode.kt +0 -677
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextAnchorViewManager.kt +0 -218
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/ReactTextShadowNode.kt +0 -369
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageShadowNode.kt +0 -156
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageSpan.kt +0 -174
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/frescosupport/FrescoBasedReactTextInlineImageViewManager.kt +0 -54
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/ReactTextInlineImageShadowNode.kt +0 -30
- package/ReactAndroid/src/main/java/com/facebook/react/views/text/internal/span/TextInlineImageSpan.kt +0 -58
- package/ReactAndroid/src/main/java/com/facebook/react/views/textinput/ReactTextInputShadowNode.kt +0 -228
- package/ReactAndroid/src/main/java/com/facebook/react/views/virtual/viewexperimental/ReactVirtualViewExperimental.kt +0 -305
- package/ReactAndroid/src/main/java/com/facebook/react/views/virtual/viewexperimental/ReactVirtualViewExperimentalManager.kt +0 -110
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaConfigJNIBase.java +0 -62
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaDirection.java +0 -35
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaNode.java +0 -279
- package/ReactAndroid/src/main/java/com/facebook/yoga/YogaProps.java +0 -197
- package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.cpp +0 -410
- package/ReactAndroid/src/main/jni/react/jni/CatalystInstanceImpl.h +0 -113
- package/ReactCommon/react/renderer/components/virtualviewexperimental/VirtualViewExperimentalComponentDescriptor.h +0 -19
- package/ReactCommon/react/renderer/components/virtualviewexperimental/VirtualViewExperimentalShadowNode.h +0 -38
- package/jest/MockNativeMethods.js +0 -27
- package/jest/RefreshControlMock.js +0 -32
- package/jest/assetFileTransformer.js +0 -33
- package/jest/local-setup.js +0 -29
- package/jest/mock.js +0 -39
- package/jest/mockComponent.js +0 -104
- package/jest/mockNativeComponent.js +0 -52
- package/jest/mocks/AccessibilityInfo.js +0 -62
- package/jest/mocks/ActivityIndicator.js +0 -23
- package/jest/mocks/AppState.js +0 -19
- package/jest/mocks/Image.js +0 -23
- package/jest/mocks/InitializeCore.js +0 -9
- package/jest/mocks/Linking.js +0 -28
- package/jest/mocks/Modal.js +0 -33
- package/jest/mocks/NativeComponentRegistry.js +0 -30
- package/jest/mocks/NativeModules.js +0 -239
- package/jest/mocks/RefreshControl.js +0 -31
- package/jest/mocks/RendererProxy.js +0 -45
- package/jest/mocks/ScrollView.js +0 -58
- package/jest/mocks/Text.js +0 -27
- package/jest/mocks/TextInput.js +0 -32
- package/jest/mocks/UIManager.js +0 -60
- package/jest/mocks/View.js +0 -27
- package/jest/mocks/ViewNativeComponent.js +0 -23
- package/jest/mocks/requireNativeComponent.js +0 -22
- package/jest/mocks/useColorScheme.js +0 -18
- package/jest/react-native-env.js +0 -17
- package/jest/renderer.js +0 -40
- package/jest/resolver.js +0 -32
- package/jest/setup.js +0 -140
- /package/React/Fabric/Mounting/ComponentViews/{VirtualViewExperimental → VirtualView}/RCTVirtualViewMode.h +0 -0
- /package/React/Fabric/Mounting/ComponentViews/{VirtualViewExperimental → VirtualView}/RCTVirtualViewRenderState.h +0 -0
- /package/ReactAndroid/src/main/java/com/facebook/react/fabric/internal/interop/{InteropUiBlockListener.kt → InteropUIBlockListener.kt} +0 -0
- /package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/{LegacyViewManagerInteropComponentDescriptor.h → platform/ios/react/renderer/components/legacyviewmanagerinterop/LegacyViewManagerInteropComponentDescriptor.h} +0 -0
- /package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/{RCTLegacyViewManagerInteropCoordinator.h → platform/ios/react/renderer/components/legacyviewmanagerinterop/RCTLegacyViewManagerInteropCoordinator.h} +0 -0
- /package/ReactCommon/react/renderer/components/legacyviewmanagerinterop/{RCTLegacyViewManagerInteropCoordinator.mm → platform/ios/react/renderer/components/legacyviewmanagerinterop/RCTLegacyViewManagerInteropCoordinator.mm} +0 -0
- /package/ReactCommon/react/renderer/components/scrollview/{RCTComponentViewHelpers.h → platform/ios/react/renderer/components/scrollview/RCTComponentViewHelpers.h} +0 -0
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
*/
|
|
7
7
|
|
|
8
8
|
#include "MapBuffer.h"
|
|
9
|
+
#include <react/renderer/mapbuffer/MapBufferBuilder.h>
|
|
9
10
|
|
|
10
11
|
namespace facebook::react {
|
|
11
12
|
|
|
@@ -51,17 +52,27 @@ int32_t MapBuffer::getKeyBucket(Key key) const {
|
|
|
51
52
|
return -1;
|
|
52
53
|
}
|
|
53
54
|
|
|
55
|
+
inline int32_t MapBuffer::getIntAtBucket(int32_t bucketIndex) const {
|
|
56
|
+
return *reinterpret_cast<const int32_t*>(
|
|
57
|
+
bytes_.data() + valueOffset(bucketIndex));
|
|
58
|
+
}
|
|
59
|
+
|
|
54
60
|
int32_t MapBuffer::getInt(Key key) const {
|
|
55
61
|
auto bucketIndex = getKeyBucket(key);
|
|
56
62
|
react_native_assert(bucketIndex != -1 && "Key not found in MapBuffer");
|
|
63
|
+
if (bucketIndex == -1) {
|
|
64
|
+
return 0;
|
|
65
|
+
}
|
|
57
66
|
|
|
58
|
-
return
|
|
59
|
-
bytes_.data() + valueOffset(bucketIndex));
|
|
67
|
+
return getIntAtBucket(bucketIndex);
|
|
60
68
|
}
|
|
61
69
|
|
|
62
70
|
int64_t MapBuffer::getLong(Key key) const {
|
|
63
71
|
auto bucketIndex = getKeyBucket(key);
|
|
64
72
|
react_native_assert(bucketIndex != -1 && "Key not found in MapBuffer");
|
|
73
|
+
if (bucketIndex == -1) {
|
|
74
|
+
return 0;
|
|
75
|
+
}
|
|
65
76
|
|
|
66
77
|
return *reinterpret_cast<const int64_t*>(
|
|
67
78
|
bytes_.data() + valueOffset(bucketIndex));
|
|
@@ -74,6 +85,9 @@ bool MapBuffer::getBool(Key key) const {
|
|
|
74
85
|
double MapBuffer::getDouble(Key key) const {
|
|
75
86
|
auto bucketIndex = getKeyBucket(key);
|
|
76
87
|
react_native_assert(bucketIndex != -1 && "Key not found in MapBuffer");
|
|
88
|
+
if (bucketIndex == -1) {
|
|
89
|
+
return 0;
|
|
90
|
+
}
|
|
77
91
|
|
|
78
92
|
return *reinterpret_cast<const double*>(
|
|
79
93
|
bytes_.data() + valueOffset(bucketIndex));
|
|
@@ -86,56 +100,63 @@ int32_t MapBuffer::getDynamicDataOffset() const {
|
|
|
86
100
|
}
|
|
87
101
|
|
|
88
102
|
std::string MapBuffer::getString(Key key) const {
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
103
|
+
auto bucketIndex = getKeyBucket(key);
|
|
104
|
+
react_native_assert(bucketIndex != -1 && "Key not found in MapBuffer");
|
|
105
|
+
if (bucketIndex == -1) {
|
|
106
|
+
return "";
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
int32_t offset = getDynamicDataOffset() + getIntAtBucket(bucketIndex);
|
|
110
|
+
int32_t stringLength =
|
|
111
|
+
*reinterpret_cast<const int32_t*>(bytes_.data() + offset);
|
|
112
|
+
const uint8_t* stringPtr = bytes_.data() + offset + sizeof(int);
|
|
97
113
|
|
|
98
114
|
return {stringPtr, stringPtr + stringLength};
|
|
99
115
|
}
|
|
100
116
|
|
|
101
117
|
MapBuffer MapBuffer::getMapBuffer(Key key) const {
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
118
|
+
auto bucketIndex = getKeyBucket(key);
|
|
119
|
+
react_native_assert(bucketIndex != -1 && "Key not found in MapBuffer");
|
|
120
|
+
if (bucketIndex == -1) {
|
|
121
|
+
return MapBufferBuilder::EMPTY();
|
|
122
|
+
}
|
|
105
123
|
|
|
106
|
-
int32_t offset =
|
|
107
|
-
int32_t mapBufferLength =
|
|
108
|
-
bytes_.data() +
|
|
124
|
+
int32_t offset = getDynamicDataOffset() + getIntAtBucket(bucketIndex);
|
|
125
|
+
int32_t mapBufferLength =
|
|
126
|
+
*reinterpret_cast<const int32_t*>(bytes_.data() + offset);
|
|
127
|
+
size_t maxLength = bytes_.size() - offset - sizeof(int32_t);
|
|
128
|
+
if (mapBufferLength > maxLength) {
|
|
129
|
+
mapBufferLength = maxLength;
|
|
130
|
+
}
|
|
109
131
|
|
|
110
132
|
std::vector<uint8_t> value(mapBufferLength);
|
|
111
133
|
|
|
112
134
|
memcpy(
|
|
113
|
-
value.data(),
|
|
114
|
-
bytes_.data() + dynamicDataOffset + offset + sizeof(int32_t),
|
|
115
|
-
mapBufferLength);
|
|
135
|
+
value.data(), bytes_.data() + offset + sizeof(int32_t), mapBufferLength);
|
|
116
136
|
|
|
117
137
|
return MapBuffer(std::move(value));
|
|
118
138
|
}
|
|
119
139
|
|
|
120
140
|
std::vector<MapBuffer> MapBuffer::getMapBufferList(MapBuffer::Key key) const {
|
|
121
|
-
|
|
141
|
+
auto bucketIndex = getKeyBucket(key);
|
|
142
|
+
react_native_assert(bucketIndex != -1 && "Key not found in MapBuffer");
|
|
143
|
+
if (bucketIndex == -1) {
|
|
144
|
+
return {};
|
|
145
|
+
}
|
|
122
146
|
|
|
123
|
-
|
|
124
|
-
int32_t offset =
|
|
125
|
-
int32_t mapBufferListLength =
|
|
126
|
-
bytes_.data() +
|
|
147
|
+
std::vector<MapBuffer> mapBufferList;
|
|
148
|
+
int32_t offset = getDynamicDataOffset() + getIntAtBucket(bucketIndex);
|
|
149
|
+
int32_t mapBufferListLength =
|
|
150
|
+
*reinterpret_cast<const int32_t*>(bytes_.data() + offset);
|
|
127
151
|
offset = offset + sizeof(uint32_t);
|
|
128
152
|
|
|
129
153
|
int32_t curLen = 0;
|
|
130
154
|
while (curLen < mapBufferListLength) {
|
|
131
|
-
int32_t mapBufferLength =
|
|
132
|
-
bytes_.data() +
|
|
155
|
+
int32_t mapBufferLength =
|
|
156
|
+
*reinterpret_cast<const int32_t*>(bytes_.data() + offset + curLen);
|
|
133
157
|
curLen = curLen + sizeof(uint32_t);
|
|
134
158
|
std::vector<uint8_t> value(mapBufferLength);
|
|
135
|
-
memcpy(
|
|
136
|
-
value.data(),
|
|
137
|
-
bytes_.data() + dynamicDataOffset + offset + curLen,
|
|
138
|
-
mapBufferLength);
|
|
159
|
+
memcpy(value.data(), bytes_.data() + offset + curLen, mapBufferLength);
|
|
139
160
|
mapBufferList.emplace_back(std::move(value));
|
|
140
161
|
curLen = curLen + mapBufferLength;
|
|
141
162
|
}
|
|
@@ -9,11 +9,10 @@
|
|
|
9
9
|
|
|
10
10
|
#include <cxxreact/TraceSection.h>
|
|
11
11
|
#include <react/debug/react_native_assert.h>
|
|
12
|
-
#include <react/featureflags/ReactNativeFeatureFlags.h>
|
|
13
12
|
#include <algorithm>
|
|
14
13
|
#include "internal/CullingContext.h"
|
|
14
|
+
#include "internal/DiffMap.h"
|
|
15
15
|
#include "internal/ShadowViewNodePair.h"
|
|
16
|
-
#include "internal/TinyMap.h"
|
|
17
16
|
#include "internal/sliceChildShadowNodeViewPairs.h"
|
|
18
17
|
|
|
19
18
|
#include "ShadowView.h"
|
|
@@ -58,7 +57,7 @@ static std::ostream& operator<<(
|
|
|
58
57
|
|
|
59
58
|
#ifdef DEBUG_LOGS_DIFFER
|
|
60
59
|
template <typename KeyT, typename ValueT>
|
|
61
|
-
static std::ostream& operator<<(std::ostream& out,
|
|
60
|
+
static std::ostream& operator<<(std::ostream& out, DiffMap<KeyT, ValueT>& map) {
|
|
62
61
|
auto it = map.begin();
|
|
63
62
|
if (it != map.end()) {
|
|
64
63
|
out << *it->second;
|
|
@@ -143,7 +142,7 @@ struct OrderedMutationInstructionContainer {
|
|
|
143
142
|
static void updateMatchedPairSubtrees(
|
|
144
143
|
ViewNodePairScope& scope,
|
|
145
144
|
OrderedMutationInstructionContainer& mutationContainer,
|
|
146
|
-
|
|
145
|
+
DiffMap<Tag, ShadowViewNodePair*>& newRemainingPairs,
|
|
147
146
|
std::vector<ShadowViewNodePair*>& oldChildPairs,
|
|
148
147
|
Tag parentTag,
|
|
149
148
|
const ShadowViewNodePair& oldPair,
|
|
@@ -164,11 +163,11 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
164
163
|
ReparentMode reparentMode,
|
|
165
164
|
OrderedMutationInstructionContainer& mutationContainer,
|
|
166
165
|
Tag parentTag,
|
|
167
|
-
|
|
166
|
+
DiffMap<Tag, ShadowViewNodePair*>& unvisitedOtherNodes,
|
|
168
167
|
const ShadowViewNodePair& node,
|
|
169
168
|
Tag parentTagForUpdate,
|
|
170
|
-
|
|
171
|
-
|
|
169
|
+
DiffMap<Tag, ShadowViewNodePair*>* parentSubVisitedOtherNewNodes,
|
|
170
|
+
DiffMap<Tag, ShadowViewNodePair*>* parentSubVisitedOtherOldNodes,
|
|
172
171
|
const CullingContext& cullingContextForUnvisitedOtherNodes,
|
|
173
172
|
const CullingContext& cullingContext);
|
|
174
173
|
|
|
@@ -183,7 +182,7 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
183
182
|
static void updateMatchedPairSubtrees(
|
|
184
183
|
ViewNodePairScope& scope,
|
|
185
184
|
OrderedMutationInstructionContainer& mutationContainer,
|
|
186
|
-
|
|
185
|
+
DiffMap<Tag, ShadowViewNodePair*>& newRemainingPairs,
|
|
187
186
|
std::vector<ShadowViewNodePair*>& oldChildPairs,
|
|
188
187
|
Tag parentTag,
|
|
189
188
|
const ShadowViewNodePair& oldPair,
|
|
@@ -232,7 +231,6 @@ static void updateMatchedPairSubtrees(
|
|
|
232
231
|
// Unflattening
|
|
233
232
|
else {
|
|
234
233
|
// Construct unvisited nodes map
|
|
235
|
-
auto unvisitedOldChildPairs = TinyMap<Tag, ShadowViewNodePair*>{};
|
|
236
234
|
// We don't know where all the children of oldChildPair are
|
|
237
235
|
// within oldChildPairs, but we know that they're in the same
|
|
238
236
|
// relative order. The reason for this is because of flattening
|
|
@@ -240,6 +238,8 @@ static void updateMatchedPairSubtrees(
|
|
|
240
238
|
// interwoven with children from other nodes, etc.
|
|
241
239
|
auto oldFlattenedNodes = sliceChildShadowNodeViewPairsFromViewNodePair(
|
|
242
240
|
oldPair, scope, true, oldCullingContextCopy);
|
|
241
|
+
auto unvisitedOldChildPairs =
|
|
242
|
+
DiffMap<Tag, ShadowViewNodePair*>(oldFlattenedNodes.size());
|
|
243
243
|
for (size_t i = 0, j = 0;
|
|
244
244
|
i < oldChildPairs.size() && j < oldFlattenedNodes.size();
|
|
245
245
|
i++) {
|
|
@@ -422,11 +422,11 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
422
422
|
ReparentMode reparentMode,
|
|
423
423
|
OrderedMutationInstructionContainer& mutationContainer,
|
|
424
424
|
Tag parentTag,
|
|
425
|
-
|
|
425
|
+
DiffMap<Tag, ShadowViewNodePair*>& unvisitedOtherNodes,
|
|
426
426
|
const ShadowViewNodePair& node,
|
|
427
427
|
Tag parentTagForUpdate,
|
|
428
|
-
|
|
429
|
-
|
|
428
|
+
DiffMap<Tag, ShadowViewNodePair*>* parentSubVisitedOtherNewNodes,
|
|
429
|
+
DiffMap<Tag, ShadowViewNodePair*>* parentSubVisitedOtherOldNodes,
|
|
430
430
|
const CullingContext& cullingContextForUnvisitedOtherNodes,
|
|
431
431
|
const CullingContext& cullingContext) {
|
|
432
432
|
// Step 1: iterate through entire tree
|
|
@@ -445,8 +445,8 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
445
445
|
|
|
446
446
|
// Views in other tree that are visited by sub-flattening or
|
|
447
447
|
// sub-unflattening
|
|
448
|
-
|
|
449
|
-
|
|
448
|
+
DiffMap<Tag, ShadowViewNodePair*> subVisitedOtherNewNodes{};
|
|
449
|
+
DiffMap<Tag, ShadowViewNodePair*> subVisitedOtherOldNodes{};
|
|
450
450
|
auto subVisitedNewMap =
|
|
451
451
|
(parentSubVisitedOtherNewNodes != nullptr ? parentSubVisitedOtherNewNodes
|
|
452
452
|
: &subVisitedOtherNewNodes);
|
|
@@ -456,7 +456,7 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
456
456
|
|
|
457
457
|
// Candidates for full tree creation or deletion at the end of this function
|
|
458
458
|
auto deletionCreationCandidatePairs =
|
|
459
|
-
|
|
459
|
+
DiffMap<Tag, const ShadowViewNodePair*>(treeChildren.size());
|
|
460
460
|
|
|
461
461
|
for (size_t index = 0;
|
|
462
462
|
index < treeChildren.size() && index < treeChildren.size();
|
|
@@ -471,7 +471,7 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
471
471
|
: subVisitedNewMap->end());
|
|
472
472
|
auto subVisitedOtherOldIt =
|
|
473
473
|
(unvisitedIt == unvisitedOtherNodes.end() &&
|
|
474
|
-
|
|
474
|
+
subVisitedOtherNewIt == subVisitedNewMap->end()
|
|
475
475
|
? subVisitedOldMap->find(treeChildPair.shadowView.tag)
|
|
476
476
|
: subVisitedOldMap->end());
|
|
477
477
|
|
|
@@ -697,7 +697,7 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
697
697
|
: adjustedOldCullingContext);
|
|
698
698
|
// Construct unvisited nodes map
|
|
699
699
|
auto unvisitedRecursiveChildPairs =
|
|
700
|
-
|
|
700
|
+
DiffMap<Tag, ShadowViewNodePair*>(flattenedNodes.size());
|
|
701
701
|
for (auto& flattenedNode : flattenedNodes) {
|
|
702
702
|
auto& newChild = *flattenedNode;
|
|
703
703
|
|
|
@@ -756,9 +756,6 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
756
756
|
// loop of this function.
|
|
757
757
|
for (auto& unvisitedRecursiveChildPair :
|
|
758
758
|
unvisitedRecursiveChildPairs) {
|
|
759
|
-
if (unvisitedRecursiveChildPair.first == 0) {
|
|
760
|
-
continue;
|
|
761
|
-
}
|
|
762
759
|
auto& oldFlattenedNode = *unvisitedRecursiveChildPair.second;
|
|
763
760
|
|
|
764
761
|
// Node unvisited - mark the entire subtree for deletion
|
|
@@ -820,9 +817,6 @@ static void calculateShadowViewMutationsFlattener(
|
|
|
820
817
|
// subtrees if they were never visited during the execution of the above
|
|
821
818
|
// loop and recursions.
|
|
822
819
|
for (auto& deletionCreationCandidatePair : deletionCreationCandidatePairs) {
|
|
823
|
-
if (deletionCreationCandidatePair.first == 0) {
|
|
824
|
-
continue;
|
|
825
|
-
}
|
|
826
820
|
auto& treeChildPair = *deletionCreationCandidatePair.second;
|
|
827
821
|
|
|
828
822
|
// If node was visited during a flattening/unflattening recursion,
|
|
@@ -1042,9 +1036,10 @@ static void calculateShadowViewMutations(
|
|
|
1042
1036
|
}
|
|
1043
1037
|
} else {
|
|
1044
1038
|
// Collect map of tags in the new list
|
|
1045
|
-
auto
|
|
1046
|
-
auto
|
|
1047
|
-
auto
|
|
1039
|
+
auto remainingCount = newChildPairs.size() - index;
|
|
1040
|
+
auto newRemainingPairs = DiffMap<Tag, ShadowViewNodePair*>(remainingCount);
|
|
1041
|
+
auto newInsertedPairs = DiffMap<Tag, ShadowViewNodePair*>(remainingCount);
|
|
1042
|
+
auto deletionCandidatePairs = DiffMap<Tag, const ShadowViewNodePair*>{};
|
|
1048
1043
|
for (; index < newChildPairs.size(); index++) {
|
|
1049
1044
|
auto& newChildPair = *newChildPairs[index];
|
|
1050
1045
|
newRemainingPairs.insert({newChildPair.shadowView.tag, &newChildPair});
|
|
@@ -1243,10 +1238,6 @@ static void calculateShadowViewMutations(
|
|
|
1243
1238
|
// list to make sure that a node was not reparented into an unflattened
|
|
1244
1239
|
// node that occurs *after* it in the hierarchy, due to zIndex ordering.
|
|
1245
1240
|
for (auto& deletionCandidatePair : deletionCandidatePairs) {
|
|
1246
|
-
if (deletionCandidatePair.first == 0) {
|
|
1247
|
-
continue;
|
|
1248
|
-
}
|
|
1249
|
-
|
|
1250
1241
|
const auto& oldChildPair = *deletionCandidatePair.second;
|
|
1251
1242
|
|
|
1252
1243
|
DEBUG_LOGS({
|
|
@@ -1285,14 +1276,6 @@ static void calculateShadowViewMutations(
|
|
|
1285
1276
|
// Final step: generate Create instructions for entirely new
|
|
1286
1277
|
// subtrees/nodes that are not the result of flattening or unflattening.
|
|
1287
1278
|
for (auto& newInsertedPair : newInsertedPairs) {
|
|
1288
|
-
// Erased elements of a TinyMap will have a Tag/key of 0 - skip those
|
|
1289
|
-
// These *should* be removed by the map; there are currently no KNOWN
|
|
1290
|
-
// cases where TinyMap will do the wrong thing, but there are not yet
|
|
1291
|
-
// any unit tests explicitly for TinyMap, so this is safer for now.
|
|
1292
|
-
if (newInsertedPair.first == 0) {
|
|
1293
|
-
continue;
|
|
1294
|
-
}
|
|
1295
|
-
|
|
1296
1279
|
const auto& newChildPair = *newInsertedPair.second;
|
|
1297
1280
|
|
|
1298
1281
|
DEBUG_LOGS({
|
|
@@ -170,6 +170,37 @@ static std::shared_ptr<ShadowNode> progressState(
|
|
|
170
170
|
});
|
|
171
171
|
}
|
|
172
172
|
|
|
173
|
+
/*
|
|
174
|
+
* Updates the layout context and layout metrics on the RootNode for commits
|
|
175
|
+
* coming from React. The RootNode is managed outside of it, and may have been
|
|
176
|
+
* modified concurrently with the React revision.
|
|
177
|
+
*/
|
|
178
|
+
static std::shared_ptr<RootShadowNode> progressRootLayoutInfo(
|
|
179
|
+
const std::shared_ptr<RootShadowNode>& shadowNode,
|
|
180
|
+
const RootShadowNode& baseShadowNode,
|
|
181
|
+
const ShadowTreeCommitOptions& commitOptions) {
|
|
182
|
+
if (commitOptions.source == ShadowTreeCommitSource::React ||
|
|
183
|
+
commitOptions.source == ShadowTreeCommitSource::ReactRevisionMerge) {
|
|
184
|
+
const auto& mainBranchRootProps = baseShadowNode.getConcreteProps();
|
|
185
|
+
const auto& jsBranchRootProps = shadowNode->getConcreteProps();
|
|
186
|
+
|
|
187
|
+
if (mainBranchRootProps.layoutConstraints ==
|
|
188
|
+
jsBranchRootProps.layoutConstraints &&
|
|
189
|
+
mainBranchRootProps.layoutContext == jsBranchRootProps.layoutContext) {
|
|
190
|
+
// The layout information kept in the JS branch is up to date.
|
|
191
|
+
return shadowNode;
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
const auto clonedNode = baseShadowNode.ShadowNode::clone(
|
|
195
|
+
{.children = std::make_shared<
|
|
196
|
+
const std::vector<std::shared_ptr<const ShadowNode>>>(
|
|
197
|
+
shadowNode->getChildren())});
|
|
198
|
+
return std::static_pointer_cast<RootShadowNode>(clonedNode);
|
|
199
|
+
}
|
|
200
|
+
|
|
201
|
+
return shadowNode;
|
|
202
|
+
}
|
|
203
|
+
|
|
173
204
|
ShadowTree::ShadowTree(
|
|
174
205
|
SurfaceId surfaceId,
|
|
175
206
|
const LayoutConstraints& layoutConstraints,
|
|
@@ -220,7 +251,7 @@ void ShadowTree::setCommitMode(CommitMode commitMode) const {
|
|
|
220
251
|
auto revision = ShadowTreeRevision{};
|
|
221
252
|
|
|
222
253
|
{
|
|
223
|
-
ShadowTree::UniqueLock lock =
|
|
254
|
+
ShadowTree::UniqueLock lock = uniqueRevisionLock();
|
|
224
255
|
|
|
225
256
|
if (commitMode_ == commitMode) {
|
|
226
257
|
return;
|
|
@@ -238,7 +269,7 @@ void ShadowTree::setCommitMode(CommitMode commitMode) const {
|
|
|
238
269
|
}
|
|
239
270
|
|
|
240
271
|
CommitMode ShadowTree::getCommitMode() const {
|
|
241
|
-
SharedLock lock =
|
|
272
|
+
SharedLock lock = sharedRevisionLock();
|
|
242
273
|
return commitMode_;
|
|
243
274
|
}
|
|
244
275
|
|
|
@@ -262,7 +293,7 @@ CommitStatus ShadowTree::commit(
|
|
|
262
293
|
}
|
|
263
294
|
|
|
264
295
|
{
|
|
265
|
-
std::unique_lock lock(
|
|
296
|
+
std::unique_lock lock(revisionMutexRecursive_);
|
|
266
297
|
return tryCommit(transaction, commitOptions);
|
|
267
298
|
}
|
|
268
299
|
} else {
|
|
@@ -286,18 +317,32 @@ CommitStatus ShadowTree::tryCommit(
|
|
|
286
317
|
const CommitOptions& commitOptions) const {
|
|
287
318
|
TraceSection s("ShadowTree::commit");
|
|
288
319
|
|
|
320
|
+
auto isReactBranch = ReactNativeFeatureFlags::enableFabricCommitBranching() &&
|
|
321
|
+
commitOptions.source == CommitSource::React;
|
|
322
|
+
|
|
323
|
+
// Commits on the JS branch are never synchronous.
|
|
324
|
+
react_native_assert(!isReactBranch || !commitOptions.mountSynchronously);
|
|
325
|
+
|
|
289
326
|
auto telemetry = TransactionTelemetry{};
|
|
290
327
|
telemetry.willCommit();
|
|
291
328
|
|
|
292
329
|
CommitMode commitMode;
|
|
293
330
|
auto oldRevision = ShadowTreeRevision{};
|
|
331
|
+
auto oldRevisionForStateProgression = ShadowTreeRevision{};
|
|
294
332
|
auto newRevision = ShadowTreeRevision{};
|
|
295
333
|
|
|
296
334
|
{
|
|
297
335
|
// Reading `currentRevision_` in shared manner.
|
|
298
|
-
SharedLock lock =
|
|
336
|
+
SharedLock lock = sharedRevisionLock();
|
|
299
337
|
commitMode = commitMode_;
|
|
300
|
-
|
|
338
|
+
|
|
339
|
+
if (isReactBranch && currentReactRevision_.has_value()) {
|
|
340
|
+
oldRevision = currentReactRevision_.value();
|
|
341
|
+
} else {
|
|
342
|
+
oldRevision = currentRevision_;
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
oldRevisionForStateProgression = currentRevision_;
|
|
301
346
|
}
|
|
302
347
|
|
|
303
348
|
const auto& oldRootShadowNode = oldRevision.rootShadowNode;
|
|
@@ -308,14 +353,21 @@ CommitStatus ShadowTree::tryCommit(
|
|
|
308
353
|
}
|
|
309
354
|
|
|
310
355
|
if (commitOptions.enableStateReconciliation) {
|
|
311
|
-
auto updatedNewRootShadowNode =
|
|
312
|
-
|
|
356
|
+
auto updatedNewRootShadowNode = progressState(
|
|
357
|
+
*newRootShadowNode, *oldRevisionForStateProgression.rootShadowNode);
|
|
313
358
|
if (updatedNewRootShadowNode) {
|
|
314
359
|
newRootShadowNode =
|
|
315
360
|
std::static_pointer_cast<RootShadowNode>(updatedNewRootShadowNode);
|
|
316
361
|
}
|
|
317
362
|
}
|
|
318
363
|
|
|
364
|
+
if (ReactNativeFeatureFlags::enableFabricCommitBranching()) {
|
|
365
|
+
newRootShadowNode = progressRootLayoutInfo(
|
|
366
|
+
newRootShadowNode,
|
|
367
|
+
*oldRevisionForStateProgression.rootShadowNode,
|
|
368
|
+
commitOptions);
|
|
369
|
+
}
|
|
370
|
+
|
|
319
371
|
// Run commit hooks.
|
|
320
372
|
newRootShadowNode = delegate_.shadowTreeWillCommit(
|
|
321
373
|
*this, oldRootShadowNode, newRootShadowNode, commitOptions);
|
|
@@ -336,9 +388,10 @@ CommitStatus ShadowTree::tryCommit(
|
|
|
336
388
|
|
|
337
389
|
{
|
|
338
390
|
// Updating `currentRevision_` in unique manner if it hasn't changed.
|
|
339
|
-
UniqueLock lock =
|
|
391
|
+
UniqueLock lock = uniqueRevisionLock(
|
|
392
|
+
/*defer*/ isReactBranch);
|
|
340
393
|
|
|
341
|
-
if (currentRevision_.number != oldRevision.number) {
|
|
394
|
+
if (!isReactBranch && currentRevision_.number != oldRevision.number) {
|
|
342
395
|
return CommitStatus::Failed;
|
|
343
396
|
}
|
|
344
397
|
|
|
@@ -364,12 +417,21 @@ CommitStatus ShadowTree::tryCommit(
|
|
|
364
417
|
.number = newRevisionNumber,
|
|
365
418
|
.telemetry = telemetry};
|
|
366
419
|
|
|
367
|
-
|
|
420
|
+
if (isReactBranch) {
|
|
421
|
+
// Lock the deferred lock to ensure that the new React revision is not
|
|
422
|
+
// reset during a scheduled merge.
|
|
423
|
+
std::visit([](auto& concreteLock) { concreteLock.lock(); }, lock);
|
|
424
|
+
currentReactRevision_ = newRevision;
|
|
425
|
+
} else {
|
|
426
|
+
currentRevision_ = newRevision;
|
|
427
|
+
}
|
|
368
428
|
}
|
|
369
429
|
|
|
370
430
|
emitLayoutEvents(affectedLayoutableNodes);
|
|
371
431
|
|
|
372
|
-
if (
|
|
432
|
+
if (isReactBranch) {
|
|
433
|
+
scheduleReactRevisionPromotion();
|
|
434
|
+
} else if (commitMode == CommitMode::Normal) {
|
|
373
435
|
mount(std::move(newRevision), commitOptions.mountSynchronously);
|
|
374
436
|
}
|
|
375
437
|
|
|
@@ -377,10 +439,15 @@ CommitStatus ShadowTree::tryCommit(
|
|
|
377
439
|
}
|
|
378
440
|
|
|
379
441
|
ShadowTreeRevision ShadowTree::getCurrentRevision() const {
|
|
380
|
-
SharedLock lock =
|
|
442
|
+
SharedLock lock = sharedRevisionLock();
|
|
381
443
|
return currentRevision_;
|
|
382
444
|
}
|
|
383
445
|
|
|
446
|
+
std::optional<ShadowTreeRevision> ShadowTree::getCurrentReactRevision() const {
|
|
447
|
+
SharedLock lock = sharedRevisionLock();
|
|
448
|
+
return currentReactRevision_;
|
|
449
|
+
}
|
|
450
|
+
|
|
384
451
|
void ShadowTree::mount(ShadowTreeRevision revision, bool mountSynchronously)
|
|
385
452
|
const {
|
|
386
453
|
mountingCoordinator_->push(std::move(revision));
|
|
@@ -388,6 +455,72 @@ void ShadowTree::mount(ShadowTreeRevision revision, bool mountSynchronously)
|
|
|
388
455
|
mountingCoordinator_, mountSynchronously);
|
|
389
456
|
}
|
|
390
457
|
|
|
458
|
+
void ShadowTree::mergeReactRevision() const {
|
|
459
|
+
ShadowTreeRevision promotedRevision;
|
|
460
|
+
|
|
461
|
+
{
|
|
462
|
+
UniqueLock lock = uniqueRevisionLock(false);
|
|
463
|
+
|
|
464
|
+
if (!reactRevisionToBePromoted_.has_value()) {
|
|
465
|
+
return;
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
promotedRevision =
|
|
469
|
+
std::exchange(reactRevisionToBePromoted_, std::nullopt).value();
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
const auto mergedRevisionNumber = promotedRevision.number;
|
|
473
|
+
|
|
474
|
+
this->commit(
|
|
475
|
+
[revision = std::move(promotedRevision)](
|
|
476
|
+
const RootShadowNode& /*oldRootShadowNode*/) {
|
|
477
|
+
return std::make_shared<RootShadowNode>(
|
|
478
|
+
*revision.rootShadowNode, ShadowNodeFragment{});
|
|
479
|
+
},
|
|
480
|
+
{
|
|
481
|
+
.enableStateReconciliation = true,
|
|
482
|
+
.mountSynchronously = true,
|
|
483
|
+
.source = CommitSource::ReactRevisionMerge,
|
|
484
|
+
});
|
|
485
|
+
|
|
486
|
+
{
|
|
487
|
+
UniqueLock commitLock = uniqueRevisionLock(
|
|
488
|
+
/*defer*/ false);
|
|
489
|
+
|
|
490
|
+
// If the current react revision is the same as the one that was just
|
|
491
|
+
// merged, clear it.
|
|
492
|
+
if (currentReactRevision_.has_value() &&
|
|
493
|
+
mergedRevisionNumber == currentReactRevision_.value().number) {
|
|
494
|
+
currentReactRevision_.reset();
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
}
|
|
498
|
+
|
|
499
|
+
void ShadowTree::promoteReactRevision() const {
|
|
500
|
+
ShadowTreeRevision currentReactRevision;
|
|
501
|
+
{
|
|
502
|
+
SharedLock lock = sharedRevisionLock();
|
|
503
|
+
// Promotion happens at the end of the event loop tick, it's possible to
|
|
504
|
+
// have more than one promotion in a row. In this case, all but the first
|
|
505
|
+
// one should no-op.
|
|
506
|
+
if (!currentReactRevision_.has_value()) {
|
|
507
|
+
return;
|
|
508
|
+
}
|
|
509
|
+
currentReactRevision = currentReactRevision_.value();
|
|
510
|
+
}
|
|
511
|
+
|
|
512
|
+
{
|
|
513
|
+
UniqueLock lock = uniqueRevisionLock(false);
|
|
514
|
+
reactRevisionToBePromoted_ = std::move(currentReactRevision);
|
|
515
|
+
}
|
|
516
|
+
|
|
517
|
+
delegate_.shadowTreeDidPromoteReactRevision(*this);
|
|
518
|
+
}
|
|
519
|
+
|
|
520
|
+
void ShadowTree::scheduleReactRevisionPromotion() const {
|
|
521
|
+
delegate_.shadowTreeDidFinishReactCommit(*this);
|
|
522
|
+
}
|
|
523
|
+
|
|
391
524
|
void ShadowTree::commitEmptyTree() const {
|
|
392
525
|
commit(
|
|
393
526
|
[](const RootShadowNode& oldRootShadowNode)
|
|
@@ -426,19 +559,21 @@ void ShadowTree::notifyDelegatesOfUpdates() const {
|
|
|
426
559
|
delegate_.shadowTreeDidFinishTransaction(mountingCoordinator_, true);
|
|
427
560
|
}
|
|
428
561
|
|
|
429
|
-
inline ShadowTree::UniqueLock ShadowTree::
|
|
562
|
+
inline ShadowTree::UniqueLock ShadowTree::uniqueRevisionLock(bool defer) const {
|
|
430
563
|
if (ReactNativeFeatureFlags::preventShadowTreeCommitExhaustion()) {
|
|
431
|
-
return std::unique_lock{
|
|
564
|
+
return defer ? std::unique_lock{revisionMutexRecursive_, std::defer_lock}
|
|
565
|
+
: std::unique_lock{revisionMutexRecursive_};
|
|
432
566
|
} else {
|
|
433
|
-
return std::unique_lock{
|
|
567
|
+
return defer ? std::unique_lock{revisionMutex_, std::defer_lock}
|
|
568
|
+
: std::unique_lock{revisionMutex_};
|
|
434
569
|
}
|
|
435
570
|
}
|
|
436
571
|
|
|
437
|
-
inline ShadowTree::SharedLock ShadowTree::
|
|
572
|
+
inline ShadowTree::SharedLock ShadowTree::sharedRevisionLock() const {
|
|
438
573
|
if (ReactNativeFeatureFlags::preventShadowTreeCommitExhaustion()) {
|
|
439
|
-
return std::unique_lock{
|
|
574
|
+
return std::unique_lock{revisionMutexRecursive_};
|
|
440
575
|
} else {
|
|
441
|
-
return std::shared_lock{
|
|
576
|
+
return std::shared_lock{revisionMutex_};
|
|
442
577
|
}
|
|
443
578
|
}
|
|
444
579
|
|
|
@@ -50,6 +50,8 @@ enum class ShadowTreeCommitMode {
|
|
|
50
50
|
enum class ShadowTreeCommitSource {
|
|
51
51
|
Unknown,
|
|
52
52
|
React,
|
|
53
|
+
AnimationEndSync,
|
|
54
|
+
ReactRevisionMerge,
|
|
53
55
|
};
|
|
54
56
|
|
|
55
57
|
struct ShadowTreeCommitOptions {
|
|
@@ -123,6 +125,12 @@ class ShadowTree final {
|
|
|
123
125
|
*/
|
|
124
126
|
ShadowTreeRevision getCurrentRevision() const;
|
|
125
127
|
|
|
128
|
+
/*
|
|
129
|
+
* Returns a `ShadowTreeRevision` representing the momentary state of
|
|
130
|
+
* the `ShadowTree` in the JS thread.
|
|
131
|
+
*/
|
|
132
|
+
std::optional<ShadowTreeRevision> getCurrentReactRevision() const;
|
|
133
|
+
|
|
126
134
|
/*
|
|
127
135
|
* Commit an empty tree (a new `RootShadowNode` with no children).
|
|
128
136
|
*/
|
|
@@ -136,6 +144,18 @@ class ShadowTree final {
|
|
|
136
144
|
|
|
137
145
|
std::shared_ptr<const MountingCoordinator> getMountingCoordinator() const;
|
|
138
146
|
|
|
147
|
+
/**
|
|
148
|
+
* Promotes the current React revision to be merged into the main branch of the
|
|
149
|
+
* ShadowTree.
|
|
150
|
+
*/
|
|
151
|
+
void promoteReactRevision() const;
|
|
152
|
+
|
|
153
|
+
/**
|
|
154
|
+
* Commits the currently promoted React revision to the "main" branch of the
|
|
155
|
+
* ShadowTree. No-op if the promoted React revision doesn't exist.
|
|
156
|
+
*/
|
|
157
|
+
void mergeReactRevision() const;
|
|
158
|
+
|
|
139
159
|
private:
|
|
140
160
|
constexpr static ShadowTreeRevision::Number INITIAL_REVISION{0};
|
|
141
161
|
|
|
@@ -143,19 +163,23 @@ class ShadowTree final {
|
|
|
143
163
|
|
|
144
164
|
void emitLayoutEvents(std::vector<const LayoutableShadowNode *> &affectedLayoutableNodes) const;
|
|
145
165
|
|
|
166
|
+
void scheduleReactRevisionPromotion() const;
|
|
167
|
+
|
|
146
168
|
const SurfaceId surfaceId_;
|
|
147
169
|
const ShadowTreeDelegate &delegate_;
|
|
148
|
-
mutable std::shared_mutex
|
|
149
|
-
mutable std::recursive_mutex
|
|
150
|
-
mutable CommitMode commitMode_{CommitMode::Normal}; // Protected by `
|
|
151
|
-
mutable ShadowTreeRevision currentRevision_; // Protected by `
|
|
170
|
+
mutable std::shared_mutex revisionMutex_;
|
|
171
|
+
mutable std::recursive_mutex revisionMutexRecursive_;
|
|
172
|
+
mutable CommitMode commitMode_{CommitMode::Normal}; // Protected by `revisionMutex_`.
|
|
173
|
+
mutable ShadowTreeRevision currentRevision_; // Protected by `revisionMutex_`.
|
|
174
|
+
mutable std::optional<ShadowTreeRevision> currentReactRevision_; // Protected by `revisionMutex_`.
|
|
175
|
+
mutable std::optional<ShadowTreeRevision> reactRevisionToBePromoted_; // Protected by `revisionMutex_`.
|
|
152
176
|
std::shared_ptr<const MountingCoordinator> mountingCoordinator_;
|
|
153
177
|
|
|
154
178
|
using UniqueLock = std::variant<std::unique_lock<std::shared_mutex>, std::unique_lock<std::recursive_mutex>>;
|
|
155
179
|
using SharedLock = std::variant<std::shared_lock<std::shared_mutex>, std::unique_lock<std::recursive_mutex>>;
|
|
156
180
|
|
|
157
|
-
inline UniqueLock
|
|
158
|
-
inline SharedLock
|
|
181
|
+
inline UniqueLock uniqueRevisionLock(bool defer = false) const;
|
|
182
|
+
inline SharedLock sharedRevisionLock() const;
|
|
159
183
|
};
|
|
160
184
|
|
|
161
185
|
} // namespace facebook::react
|